2023-05-29 17:47:18 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2023-06-06 21:26:58 -04:00
|
|
|
describe "Composer Form Templates", type: :system do
|
2023-05-29 17:47:18 -04:00
|
|
|
fab!(:user) { Fabricate(:user) }
|
|
|
|
fab!(:form_template_1) do
|
2023-06-08 15:49:18 -04:00
|
|
|
Fabricate(
|
|
|
|
:form_template,
|
|
|
|
name: "Bug Reports",
|
|
|
|
template:
|
|
|
|
"- type: input
|
2023-08-29 17:41:33 -04:00
|
|
|
id: full-name
|
2023-06-08 15:49:18 -04:00
|
|
|
attributes:
|
|
|
|
label: What is your full name?
|
|
|
|
placeholder: John Doe
|
|
|
|
validations:
|
|
|
|
required: true",
|
|
|
|
)
|
2023-05-29 17:47:18 -04:00
|
|
|
end
|
|
|
|
fab!(:form_template_2) do
|
2023-08-29 17:41:33 -04:00
|
|
|
Fabricate(:form_template, name: "Feature Request", template: "- type: checkbox\n id: check")
|
2023-05-29 17:47:18 -04:00
|
|
|
end
|
|
|
|
fab!(:form_template_3) do
|
2023-08-29 17:41:33 -04:00
|
|
|
Fabricate(:form_template, name: "Awesome Possum", template: "- type: dropdown\n id: dropdown")
|
2023-05-29 17:47:18 -04:00
|
|
|
end
|
|
|
|
fab!(:form_template_4) do
|
2023-08-29 17:41:33 -04:00
|
|
|
Fabricate(:form_template, name: "Biography", template: "- type: textarea\n id: bio")
|
2023-05-29 17:47:18 -04:00
|
|
|
end
|
2023-06-28 15:49:05 -04:00
|
|
|
fab!(:form_template_5) do
|
|
|
|
Fabricate(
|
|
|
|
:form_template,
|
|
|
|
name: "Medication",
|
|
|
|
template:
|
|
|
|
%Q(
|
|
|
|
- type: input
|
2023-08-29 17:41:33 -04:00
|
|
|
id: full-name
|
2023-06-28 15:49:05 -04:00
|
|
|
attributes:
|
|
|
|
label: "What is your name?"
|
|
|
|
placeholder: "John Smith"
|
|
|
|
validations:
|
|
|
|
required: false
|
|
|
|
- type: upload
|
2023-08-29 17:41:33 -04:00
|
|
|
id: prescription
|
2023-06-28 15:49:05 -04:00
|
|
|
attributes:
|
|
|
|
file_types: ".jpg, .png"
|
|
|
|
allow_multiple: false
|
|
|
|
label: "Upload your prescription"
|
|
|
|
validations:
|
|
|
|
required: true
|
|
|
|
- type: upload
|
2023-08-29 17:41:33 -04:00
|
|
|
id: additional-docs
|
2023-06-28 15:49:05 -04:00
|
|
|
attributes:
|
|
|
|
file_types: ".jpg, .png, .pdf, .mp3, .mp4"
|
|
|
|
allow_multiple: true
|
|
|
|
label: "Any additional docs"
|
|
|
|
validations:
|
|
|
|
required: false"),
|
|
|
|
)
|
|
|
|
end
|
2023-10-04 16:51:53 -04:00
|
|
|
fab!(:form_template_6) do
|
|
|
|
Fabricate(
|
|
|
|
:form_template,
|
|
|
|
name: "Descriptions",
|
|
|
|
template:
|
|
|
|
%Q(
|
|
|
|
- type: input
|
|
|
|
id: full-name
|
|
|
|
attributes:
|
|
|
|
label: "Full name"
|
|
|
|
description: "What is your full name?"
|
|
|
|
placeholder: "John Smith"
|
|
|
|
validations:
|
|
|
|
required: false
|
|
|
|
- type: upload
|
|
|
|
id: prescription
|
|
|
|
attributes:
|
|
|
|
file_types: ".jpg, .png"
|
|
|
|
allow_multiple: false
|
|
|
|
label: "Prescription"
|
|
|
|
description: "Upload your prescription"
|
|
|
|
validations:
|
|
|
|
required: true"),
|
|
|
|
)
|
|
|
|
end
|
2023-05-29 17:47:18 -04:00
|
|
|
fab!(:category_with_template_1) do
|
|
|
|
Fabricate(
|
|
|
|
:category,
|
|
|
|
name: "Reports",
|
|
|
|
slug: "reports",
|
|
|
|
topic_count: 2,
|
|
|
|
form_template_ids: [form_template_1.id],
|
|
|
|
)
|
|
|
|
end
|
|
|
|
fab!(:category_with_template_2) do
|
|
|
|
Fabricate(
|
|
|
|
:category,
|
|
|
|
name: "Features",
|
|
|
|
slug: "features",
|
|
|
|
topic_count: 3,
|
|
|
|
form_template_ids: [form_template_2.id],
|
|
|
|
)
|
|
|
|
end
|
|
|
|
fab!(:category_with_multiple_templates_1) do
|
|
|
|
Fabricate(
|
|
|
|
:category,
|
|
|
|
name: "Multiple",
|
2023-06-13 16:02:21 -04:00
|
|
|
slug: "multiple",
|
2023-05-29 17:47:18 -04:00
|
|
|
topic_count: 10,
|
|
|
|
form_template_ids: [form_template_1.id, form_template_2.id],
|
|
|
|
)
|
|
|
|
end
|
|
|
|
fab!(:category_with_multiple_templates_2) do
|
|
|
|
Fabricate(
|
|
|
|
:category,
|
|
|
|
name: "More Stuff",
|
|
|
|
slug: "more-stuff",
|
|
|
|
topic_count: 10,
|
|
|
|
form_template_ids: [form_template_3.id, form_template_4.id],
|
|
|
|
)
|
|
|
|
end
|
2023-06-28 15:49:05 -04:00
|
|
|
fab!(:category_with_upload_template) do
|
|
|
|
Fabricate(
|
|
|
|
:category,
|
|
|
|
name: "Medical",
|
|
|
|
slug: "medical",
|
|
|
|
topic_count: 2,
|
|
|
|
form_template_ids: [form_template_5.id],
|
|
|
|
)
|
|
|
|
end
|
2023-05-29 17:47:18 -04:00
|
|
|
fab!(:category_no_template) do
|
|
|
|
Fabricate(:category, name: "Staff", slug: "staff", topic_count: 2, form_template_ids: [])
|
|
|
|
end
|
|
|
|
fab!(:category_topic_template) do
|
|
|
|
Fabricate(
|
|
|
|
:category,
|
|
|
|
name: "Random",
|
|
|
|
slug: "random",
|
|
|
|
topic_count: 5,
|
|
|
|
form_template_ids: [],
|
|
|
|
topic_template: "Testing",
|
|
|
|
)
|
|
|
|
end
|
2023-10-04 16:51:53 -04:00
|
|
|
fab!(:category_with_template_6) do
|
|
|
|
Fabricate(
|
|
|
|
:category,
|
|
|
|
name: "Descriptions",
|
|
|
|
slug: "descriptions",
|
|
|
|
topic_count: 2,
|
|
|
|
form_template_ids: [form_template_6.id],
|
|
|
|
)
|
|
|
|
end
|
2023-06-28 15:49:05 -04:00
|
|
|
|
2023-05-29 17:47:18 -04:00
|
|
|
let(:category_page) { PageObjects::Pages::Category.new }
|
|
|
|
let(:composer) { PageObjects::Components::Composer.new }
|
|
|
|
let(:form_template_chooser) { PageObjects::Components::SelectKit.new(".form-template-chooser") }
|
2023-06-08 15:49:18 -04:00
|
|
|
let(:topic_page) { PageObjects::Pages::Topic.new }
|
2023-05-29 17:47:18 -04:00
|
|
|
|
|
|
|
before do
|
|
|
|
SiteSetting.experimental_form_templates = true
|
2023-06-28 15:49:05 -04:00
|
|
|
SiteSetting.authorized_extensions = "*"
|
2023-05-29 17:47:18 -04:00
|
|
|
sign_in user
|
|
|
|
end
|
|
|
|
|
2023-10-19 13:19:40 -04:00
|
|
|
describe "discard draft modal" do
|
|
|
|
it "does not show the modal if there is no draft on a topic without a template" do
|
|
|
|
category_page.visit(category_no_template)
|
|
|
|
category_page.new_topic_button.click
|
|
|
|
composer.close
|
|
|
|
expect(composer).to be_closed
|
|
|
|
end
|
|
|
|
|
|
|
|
it "shows the modal if there is a draft on a topic without a template" do
|
|
|
|
category_page.visit(category_no_template)
|
|
|
|
category_page.new_topic_button.click
|
|
|
|
composer.fill_content("abc")
|
|
|
|
composer.close
|
|
|
|
expect(composer).to be_opened
|
|
|
|
expect(composer).to have_discard_draft_modal
|
|
|
|
end
|
|
|
|
|
|
|
|
it "does not show the modal if there is no draft on a topic with a topic template" do
|
|
|
|
category_page.visit(category_topic_template)
|
|
|
|
category_page.new_topic_button.click
|
|
|
|
composer.close
|
|
|
|
expect(composer).to be_closed
|
|
|
|
end
|
|
|
|
|
|
|
|
it "shows the modal if there is a draft on a topic with a topic template" do
|
|
|
|
category_page.visit(category_topic_template)
|
|
|
|
category_page.new_topic_button.click
|
|
|
|
composer.append_content(" some more content")
|
|
|
|
composer.close
|
|
|
|
expect(composer).to be_opened
|
|
|
|
expect(composer).to have_discard_draft_modal
|
|
|
|
end
|
|
|
|
|
|
|
|
it "does not show the modal if on a topic with a form template" do
|
|
|
|
category_page.visit(category_with_template_1)
|
|
|
|
category_page.new_topic_button.click
|
|
|
|
composer.close
|
|
|
|
expect(composer).to be_closed
|
|
|
|
end
|
|
|
|
|
|
|
|
context "when the default template has a topic template" do
|
|
|
|
SiteSetting.default_composer_category =
|
|
|
|
(
|
|
|
|
if SiteSetting.general_category_id != -1
|
|
|
|
SiteSetting.general_category_id
|
|
|
|
else
|
|
|
|
SiteSetting.uncategorized_category_id
|
|
|
|
end
|
|
|
|
)
|
|
|
|
let(:default_category) { Category.find(SiteSetting.default_composer_category) }
|
|
|
|
|
|
|
|
before { default_category.update!(topic_template: "Testing") }
|
|
|
|
|
|
|
|
it "does not show the modal if there is no draft" do
|
|
|
|
category_page.visit(default_category)
|
|
|
|
category_page.new_topic_button.click
|
|
|
|
composer.close
|
|
|
|
expect(composer).to be_closed
|
|
|
|
end
|
|
|
|
|
|
|
|
it "shows the modal if there is a draft" do
|
|
|
|
category_page.visit(default_category)
|
|
|
|
category_page.new_topic_button.click
|
|
|
|
composer.append_content(" some more content")
|
|
|
|
composer.close
|
|
|
|
expect(composer).to be_opened
|
|
|
|
expect(composer).to have_discard_draft_modal
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-05-29 17:47:18 -04:00
|
|
|
it "shows a textarea when no form template is assigned to the category" do
|
|
|
|
category_page.visit(category_no_template)
|
|
|
|
category_page.new_topic_button.click
|
|
|
|
expect(composer).to have_composer_input
|
|
|
|
end
|
|
|
|
|
|
|
|
it "shows a textarea filled in with topic template when a topic template is assigned to the category" do
|
|
|
|
category_page.visit(category_topic_template)
|
|
|
|
category_page.new_topic_button.click
|
|
|
|
expect(composer).to have_composer_input
|
|
|
|
expect(composer).to have_content(category_topic_template.topic_template)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "shows a form when a form template is assigned to the category" do
|
|
|
|
category_page.visit(category_with_template_1)
|
|
|
|
category_page.new_topic_button.click
|
2023-05-30 19:00:16 -04:00
|
|
|
expect(composer).to have_no_composer_input
|
2023-05-29 17:47:18 -04:00
|
|
|
expect(composer).to have_form_template
|
2023-06-08 15:49:18 -04:00
|
|
|
expect(composer).to have_form_template_field("input")
|
|
|
|
end
|
|
|
|
|
|
|
|
it "shows the preview when a category without a form template is selected" do
|
|
|
|
category_page.visit(category_no_template)
|
|
|
|
category_page.new_topic_button.click
|
|
|
|
expect(composer).to have_composer_preview
|
|
|
|
expect(composer).to have_composer_preview_toggle
|
|
|
|
end
|
|
|
|
|
2023-06-13 16:02:21 -04:00
|
|
|
it "hides the preview when a category with a form template is selected" do
|
2023-06-08 15:49:18 -04:00
|
|
|
category_page.visit(category_with_template_1)
|
|
|
|
category_page.new_topic_button.click
|
|
|
|
expect(composer).to have_no_composer_preview
|
|
|
|
expect(composer).to have_no_composer_preview_toggle
|
2023-05-29 17:47:18 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "shows the correct template when switching categories" do
|
|
|
|
category_page.visit(category_no_template)
|
|
|
|
category_page.new_topic_button.click
|
|
|
|
# first category has no template
|
|
|
|
expect(composer).to have_composer_input
|
|
|
|
# switch to category with topic template
|
|
|
|
composer.switch_category(category_topic_template.name)
|
|
|
|
expect(composer).to have_composer_input
|
|
|
|
expect(composer).to have_content(category_topic_template.topic_template)
|
|
|
|
# switch to category with form template
|
|
|
|
composer.switch_category(category_with_template_1.name)
|
|
|
|
expect(composer).to have_form_template
|
2023-06-08 15:49:18 -04:00
|
|
|
expect(composer).to have_form_template_field("input")
|
2023-05-29 17:47:18 -04:00
|
|
|
# switch to category with a different form template
|
|
|
|
composer.switch_category(category_with_template_2.name)
|
|
|
|
expect(composer).to have_form_template
|
2023-06-08 15:49:18 -04:00
|
|
|
expect(composer).to have_form_template_field("checkbox")
|
2023-05-29 17:47:18 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "does not show form template chooser when a category only has form template" do
|
|
|
|
category_page.visit(category_with_template_1)
|
|
|
|
category_page.new_topic_button.click
|
2023-05-30 19:00:16 -04:00
|
|
|
expect(composer).to have_no_form_template_chooser
|
2023-05-29 17:47:18 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "shows form template chooser when a category has multiple form templates" do
|
|
|
|
category_page.visit(category_with_multiple_templates_1)
|
|
|
|
category_page.new_topic_button.click
|
|
|
|
expect(composer).to have_form_template_chooser
|
|
|
|
end
|
|
|
|
|
|
|
|
it "updates the form template when a different template is selected" do
|
|
|
|
category_page.visit(category_with_multiple_templates_1)
|
|
|
|
category_page.new_topic_button.click
|
|
|
|
expect(composer).to have_form_template_field("input")
|
2023-06-08 15:49:18 -04:00
|
|
|
form_template_chooser.select_row_by_name(form_template_2.name)
|
|
|
|
expect(composer).to have_form_template_field("checkbox")
|
2023-05-29 17:47:18 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "shows the correct template options when switching categories" do
|
|
|
|
category_page.visit(category_with_multiple_templates_1)
|
|
|
|
category_page.new_topic_button.click
|
|
|
|
expect(composer).to have_form_template_chooser
|
|
|
|
form_template_chooser.expand
|
|
|
|
expect(form_template_chooser).to have_selected_choice_name(form_template_1.name)
|
|
|
|
expect(form_template_chooser).to have_option_name(form_template_2.name)
|
|
|
|
composer.switch_category(category_with_multiple_templates_2.name)
|
|
|
|
form_template_chooser.expand
|
|
|
|
expect(form_template_chooser).to have_selected_choice_name(form_template_3.name)
|
|
|
|
expect(form_template_chooser).to have_option_name(form_template_4.name)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "shows the correct template name in the dropdown header after switching templates" do
|
|
|
|
category_page.visit(category_with_multiple_templates_1)
|
|
|
|
category_page.new_topic_button.click
|
|
|
|
expect(form_template_chooser).to have_selected_name(form_template_1.name)
|
|
|
|
form_template_chooser.select_row_by_name(form_template_2.name)
|
|
|
|
expect(form_template_chooser).to have_selected_name(form_template_2.name)
|
|
|
|
end
|
2023-06-08 15:49:18 -04:00
|
|
|
|
|
|
|
it "forms a post when template fields are filled in" do
|
|
|
|
topic_title = "A topic about Batman"
|
|
|
|
|
|
|
|
category_page.visit(category_with_template_1)
|
|
|
|
category_page.new_topic_button.click
|
|
|
|
composer.fill_title(topic_title)
|
|
|
|
composer.fill_form_template_field("input", "Bruce Wayne")
|
|
|
|
composer.create
|
|
|
|
|
|
|
|
expect(topic_page).to have_topic_title(topic_title)
|
|
|
|
expect(find("#{topic_page.post_by_number_selector(1)} .cooked p")).to have_content(
|
|
|
|
"Bruce Wayne",
|
|
|
|
)
|
2023-08-31 15:58:09 -04:00
|
|
|
expect(find("#{topic_page.post_by_number_selector(1)} .cooked h3")).to have_content(
|
|
|
|
"What is your full name?",
|
|
|
|
)
|
2023-06-08 15:49:18 -04:00
|
|
|
end
|
2023-06-28 15:49:05 -04:00
|
|
|
|
|
|
|
it "creates a post with an upload field" do
|
|
|
|
topic_title = "Bruce Wayne's Medication"
|
|
|
|
|
|
|
|
category_page.visit(category_with_upload_template)
|
|
|
|
category_page.new_topic_button.click
|
2023-08-29 17:41:33 -04:00
|
|
|
attach_file "prescription-uploader",
|
2023-06-28 15:49:05 -04:00
|
|
|
"#{Rails.root}/spec/fixtures/images/logo.png",
|
|
|
|
make_visible: true
|
|
|
|
composer.fill_title(topic_title)
|
|
|
|
composer.fill_form_template_field("input", "Bruce Wayne")
|
|
|
|
composer.create
|
|
|
|
|
|
|
|
expect(find("#{topic_page.post_by_number_selector(1)} .cooked")).to have_css(
|
|
|
|
"img[alt='logo.png']",
|
|
|
|
)
|
|
|
|
end
|
|
|
|
|
|
|
|
it "doesn't allow uploading an invalid file type" do
|
|
|
|
category_page.visit(category_with_upload_template)
|
|
|
|
category_page.new_topic_button.click
|
2023-08-29 17:41:33 -04:00
|
|
|
attach_file "prescription-uploader",
|
2023-06-28 15:49:05 -04:00
|
|
|
"#{Rails.root}/spec/fixtures/images/animated.gif",
|
|
|
|
make_visible: true
|
|
|
|
expect(find("#dialog-holder .dialog-body p", visible: :all)).to have_content(
|
|
|
|
I18n.t("js.pick_files_button.unsupported_file_picked", { types: ".jpg, .png" }),
|
|
|
|
)
|
2023-11-03 09:11:25 -04:00
|
|
|
expect(page).to have_no_css(".form-template-field__uploaded-files")
|
2023-06-28 15:49:05 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
it "creates a post with multiple uploads" do
|
|
|
|
topic_title = "Peter Parker's Medication"
|
|
|
|
|
|
|
|
category_page.visit(category_with_upload_template)
|
|
|
|
category_page.new_topic_button.click
|
2023-08-29 17:41:33 -04:00
|
|
|
attach_file "prescription-uploader",
|
2023-06-28 15:49:05 -04:00
|
|
|
"#{Rails.root}/spec/fixtures/images/logo.png",
|
|
|
|
make_visible: true
|
2023-08-29 17:41:33 -04:00
|
|
|
attach_file "additional-docs-uploader",
|
2023-06-28 15:49:05 -04:00
|
|
|
[
|
|
|
|
"#{Rails.root}/spec/fixtures/media/small.mp3",
|
|
|
|
"#{Rails.root}/spec/fixtures/media/small.mp4",
|
|
|
|
"#{Rails.root}/spec/fixtures/pdf/small.pdf",
|
|
|
|
],
|
|
|
|
make_visible: true
|
|
|
|
composer.fill_title(topic_title)
|
|
|
|
composer.fill_form_template_field("input", "Peter Parker}")
|
|
|
|
composer.create
|
|
|
|
|
|
|
|
expect(find("#{topic_page.post_by_number_selector(1)} .cooked")).to have_css(
|
|
|
|
"img[alt='logo.png']",
|
|
|
|
)
|
|
|
|
expect(find("#{topic_page.post_by_number_selector(1)} .cooked")).to have_css("a.attachment")
|
|
|
|
expect(find("#{topic_page.post_by_number_selector(1)} .cooked")).to have_css("audio")
|
2023-10-12 15:47:48 -04:00
|
|
|
expect(find("#{topic_page.post_by_number_selector(1)} .cooked")).to have_css(
|
|
|
|
".video-placeholder-container",
|
|
|
|
)
|
2023-06-28 15:49:05 -04:00
|
|
|
end
|
2023-10-04 16:51:53 -04:00
|
|
|
|
2023-11-03 09:11:25 -04:00
|
|
|
it "overrides uploaded file if allow_multiple false" do
|
|
|
|
topic_title = "Peter Parker's Medication"
|
|
|
|
|
|
|
|
category_page.visit(category_with_upload_template)
|
|
|
|
category_page.new_topic_button.click
|
|
|
|
attach_file "prescription-uploader",
|
|
|
|
"#{Rails.root}/spec/fixtures/images/logo.png",
|
|
|
|
make_visible: true
|
|
|
|
composer.fill_title(topic_title)
|
|
|
|
attach_file "prescription-uploader",
|
|
|
|
"#{Rails.root}/spec/fixtures/images/fake.jpg",
|
|
|
|
make_visible: true
|
|
|
|
|
|
|
|
expect(find(".form-template-field__uploaded-files")).to have_css("li", count: 1)
|
|
|
|
end
|
|
|
|
|
2023-10-04 16:51:53 -04:00
|
|
|
it "shows labels and descriptions when a form template is assigned to the category" do
|
|
|
|
category_page.visit(category_with_template_6)
|
|
|
|
category_page.new_topic_button.click
|
|
|
|
expect(composer).to have_no_composer_input
|
|
|
|
expect(composer).to have_form_template
|
|
|
|
|
|
|
|
expect(composer).to have_form_template_field("input")
|
|
|
|
expect(composer).to have_form_template_field_label("Full name")
|
|
|
|
expect(composer).to have_form_template_field_description("What is your full name?")
|
|
|
|
|
|
|
|
expect(composer).to have_form_template_field("upload")
|
|
|
|
expect(composer).to have_form_template_field_label("Prescription")
|
|
|
|
expect(composer).to have_form_template_field_description("Upload your prescription")
|
|
|
|
end
|
2023-05-29 17:47:18 -04:00
|
|
|
end
|