decidim-forms 0.28.5 → 0.29.0.rc1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (75) hide show
  1. checksums.yaml +4 -4
  2. data/app/cells/decidim/forms/question_readonly_cell.rb +0 -2
  3. data/app/cells/decidim/forms/step_navigation/show.erb +3 -3
  4. data/app/cells/decidim/forms/step_navigation_cell.rb +2 -3
  5. data/app/commands/decidim/forms/answer_questionnaire.rb +4 -4
  6. data/app/controllers/decidim/forms/concerns/has_questionnaire.rb +1 -1
  7. data/app/forms/decidim/forms/admin/questionnaire_form.rb +2 -2
  8. data/app/forms/decidim/forms/answer_form.rb +2 -2
  9. data/app/forms/decidim/forms/questionnaire_form.rb +1 -1
  10. data/app/helpers/decidim/forms/application_helper.rb +2 -2
  11. data/app/models/decidim/forms/answer_choice.rb +0 -2
  12. data/app/models/decidim/forms/answer_option.rb +1 -1
  13. data/app/models/decidim/forms/display_condition.rb +11 -3
  14. data/app/models/decidim/forms/question_matrix_row.rb +1 -1
  15. data/app/presenters/decidim/forms/admin/questionnaire_participant_presenter.rb +7 -7
  16. data/app/views/decidim/forms/admin/questionnaires/_answer_option.html.erb +1 -1
  17. data/app/views/decidim/forms/admin/questionnaires/_display_condition.html.erb +2 -2
  18. data/app/views/decidim/forms/admin/questionnaires/_matrix_row.html.erb +1 -1
  19. data/app/views/decidim/forms/admin/questionnaires/_question.html.erb +4 -4
  20. data/app/views/decidim/forms/admin/questionnaires/_separator.html.erb +4 -4
  21. data/app/views/decidim/forms/admin/questionnaires/_title_and_description.html.erb +4 -4
  22. data/app/views/decidim/forms/questionnaires/_answer.html.erb +1 -11
  23. data/config/initializers/wicked_pdf.rb +6 -4
  24. data/config/locales/ar.yml +2 -4
  25. data/config/locales/bg.yml +6 -2
  26. data/config/locales/ca.yml +4 -4
  27. data/config/locales/cs.yml +0 -1
  28. data/config/locales/de.yml +5 -5
  29. data/config/locales/el.yml +5 -2
  30. data/config/locales/en.yml +2 -2
  31. data/config/locales/es-MX.yml +5 -5
  32. data/config/locales/es-PY.yml +5 -5
  33. data/config/locales/es.yml +5 -5
  34. data/config/locales/eu.yml +8 -8
  35. data/config/locales/fi-plain.yml +4 -4
  36. data/config/locales/fi.yml +5 -5
  37. data/config/locales/fr-CA.yml +3 -3
  38. data/config/locales/fr.yml +3 -3
  39. data/config/locales/gl.yml +3 -1
  40. data/config/locales/hu.yml +6 -4
  41. data/config/locales/id-ID.yml +2 -1
  42. data/config/locales/it.yml +4 -1
  43. data/config/locales/ja.yml +6 -1
  44. data/config/locales/lb.yml +4 -1
  45. data/config/locales/lt.yml +5 -2
  46. data/config/locales/lv.yml +3 -1
  47. data/config/locales/nl.yml +5 -1
  48. data/config/locales/no.yml +5 -1
  49. data/config/locales/pl.yml +6 -1
  50. data/config/locales/pt-BR.yml +5 -1
  51. data/config/locales/pt.yml +4 -1
  52. data/config/locales/ro-RO.yml +5 -3
  53. data/config/locales/sk.yml +2 -1
  54. data/config/locales/sv.yml +31 -44
  55. data/config/locales/tr-TR.yml +4 -1
  56. data/config/locales/val-ES.yml +2 -0
  57. data/config/locales/zh-CN.yml +4 -1
  58. data/config/locales/zh-TW.yml +5 -2
  59. data/db/migrate/20240402092039_add_answer_options_counter_cache_to_questions.rb +16 -0
  60. data/db/migrate/20240402095253_add_matrix_row_counter_cache_to_questions.rb +16 -0
  61. data/db/migrate/20240416111953_add_display_conditions_counter_cache_to_questions.rb +16 -0
  62. data/db/migrate/20240416113926_add_display_conditions_for_other_questions_counter_cache_to_questions.rb +16 -0
  63. data/decidim-forms.gemspec +3 -2
  64. data/lib/decidim/forms/test/shared_examples/has_questionnaire.rb +44 -70
  65. data/lib/decidim/forms/test/shared_examples/manage_questionnaire_answers.rb +12 -12
  66. data/lib/decidim/forms/test/shared_examples/manage_questionnaires/add_display_conditions.rb +10 -10
  67. data/lib/decidim/forms/test/shared_examples/manage_questionnaires/add_questions.rb +85 -85
  68. data/lib/decidim/forms/test/shared_examples/manage_questionnaires/update_display_conditions.rb +8 -8
  69. data/lib/decidim/forms/test/shared_examples/manage_questionnaires/update_questions.rb +82 -82
  70. data/lib/decidim/forms/test/shared_examples/manage_questionnaires.rb +9 -9
  71. data/lib/decidim/forms/user_answers_serializer.rb +1 -1
  72. data/lib/decidim/forms/version.rb +1 -1
  73. metadata +31 -15
  74. data/config/locales/bn-BD.yml +0 -1
  75. data/config/locales/bs-BA.yml +0 -1
@@ -20,18 +20,18 @@ shared_examples_for "update questions" do
20
20
  select "Long answer", from: "Type"
21
21
  end
22
22
 
23
- click_button "Save"
23
+ click_on "Save"
24
24
  end
25
25
 
26
26
  expect(page).to have_admin_callout("successfully")
27
27
 
28
28
  visit_questionnaire_edit_path_and_expand_all
29
29
 
30
- expect(page).to have_selector("input[value='Modified question']")
31
- expect(page).not_to have_selector("input[value='This is the first question']")
32
- expect(page).to have_selector("input#questionnaire_questions_#{question.id}_mandatory[checked]")
33
- expect(page).to have_selector("input#questionnaire_questions_#{question.id}_max_characters[value='30']")
34
- expect(page).to have_selector("select#questionnaire_questions_#{question.id}_question_type option[value='long_answer'][selected]")
30
+ expect(page).to have_css("input[value='Modified question']")
31
+ expect(page).to have_no_css("input[value='This is the first question']")
32
+ expect(page).to have_css("input#questionnaire_questions_#{question.id}_mandatory[checked]")
33
+ expect(page).to have_css("input#questionnaire_questions_#{question.id}_max_characters[value='30']")
34
+ expect(page).to have_css("select#questionnaire_questions_#{question.id}_question_type option[value='long_answer'][selected]")
35
35
  end
36
36
 
37
37
  it "re-renders the form when the information is invalid and displays errors" do
@@ -47,49 +47,49 @@ shared_examples_for "update questions" do
47
47
  select "2", from: "Maximum number of choices"
48
48
  end
49
49
 
50
- click_button "Save"
50
+ click_on "Save"
51
51
  end
52
52
 
53
53
  expand_all_questions
54
54
 
55
55
  expect(page).to have_admin_callout("There was a problem saving")
56
- expect(page).to have_content("cannot be blank", count: 5) # emtpy question, 2 empty default answer options, 2 empty default matrix rows
56
+ expect(page).to have_content("cannot be blank", count: 5) # empty question, 2 empty default answer options, 2 empty default matrix rows
57
57
  expect(page).to have_content("must be greater than or equal to 0", count: 1)
58
58
 
59
- expect(page).to have_selector("input[value='']")
60
- expect(page).not_to have_selector("input[value='This is the first question']")
61
- expect(page).to have_selector("input#questionnaire_questions_#{question.id}_mandatory[checked]")
62
- expect(page).to have_selector("input#questionnaire_questions_#{question.id}_max_characters[value='-3']")
59
+ expect(page).to have_css("input[value='']")
60
+ expect(page).to have_no_css("input[value='This is the first question']")
61
+ expect(page).to have_css("input#questionnaire_questions_#{question.id}_mandatory[checked]")
62
+ expect(page).to have_css("input#questionnaire_questions_#{question.id}_max_characters[value='-3']")
63
63
  expect(page).to have_select("Maximum number of choices", selected: "2")
64
- expect(page).to have_selector("select#questionnaire_questions_#{question.id}_question_type option[value='matrix_multiple'][selected]")
64
+ expect(page).to have_css("select#questionnaire_questions_#{question.id}_question_type option[value='matrix_multiple'][selected]")
65
65
  end
66
66
 
67
67
  it "preserves deleted status across submission failures" do
68
68
  within "form.edit_questionnaire" do
69
69
  within ".questionnaire-question" do
70
- click_button "Remove"
70
+ click_on "Remove"
71
71
  end
72
72
  end
73
73
 
74
- click_button "Add question"
74
+ click_on "Add question"
75
75
 
76
- click_button "Save"
76
+ click_on "Save"
77
77
 
78
- expect(page).to have_selector(".questionnaire-question", count: 1)
78
+ expect(page).to have_css(".questionnaire-question", count: 1)
79
79
 
80
80
  within ".questionnaire-question" do
81
- expect(page).to have_selector(".card-title", text: "#1")
82
- expect(page).not_to have_button("Up")
81
+ expect(page).to have_css(".card-title", text: "#1")
82
+ expect(page).to have_no_button("Up")
83
83
  end
84
84
  end
85
85
 
86
86
  it "removes the question" do
87
87
  within "form.edit_questionnaire" do
88
88
  within ".questionnaire-question" do
89
- click_button "Remove"
89
+ click_on "Remove"
90
90
  end
91
91
 
92
- click_button "Save"
92
+ click_on "Save"
93
93
  end
94
94
 
95
95
  expect(page).to have_admin_callout("successfully")
@@ -97,14 +97,14 @@ shared_examples_for "update questions" do
97
97
  visit questionnaire_edit_path
98
98
 
99
99
  within "form.edit_questionnaire" do
100
- expect(page).to have_selector(".questionnaire-question", count: 0)
100
+ expect(page).to have_css(".questionnaire-question", count: 0)
101
101
  end
102
102
  end
103
103
 
104
104
  it "cannot be moved up" do
105
105
  within "form.edit_questionnaire" do
106
106
  within ".questionnaire-question" do
107
- expect(page).not_to have_button("Up")
107
+ expect(page).to have_no_button("Up")
108
108
  end
109
109
  end
110
110
  end
@@ -112,7 +112,7 @@ shared_examples_for "update questions" do
112
112
  it "cannot be moved down" do
113
113
  within "form.edit_questionnaire" do
114
114
  within ".questionnaire-question" do
115
- expect(page).not_to have_button("Down")
115
+ expect(page).to have_no_button("Down")
116
116
  end
117
117
  end
118
118
  end
@@ -132,15 +132,15 @@ shared_examples_for "update questions" do
132
132
  fill_in "questionnaire_questions_#{question.id}_body_en", with: "Modified title and description"
133
133
  end
134
134
 
135
- click_button "Save"
135
+ click_on "Save"
136
136
  end
137
137
 
138
138
  expect(page).to have_admin_callout("successfully")
139
139
 
140
140
  visit_questionnaire_edit_path_and_expand_all
141
141
 
142
- expect(page).to have_selector("input[value='Modified title and description']")
143
- expect(page).not_to have_selector("input[value='This is the first title and description']")
142
+ expect(page).to have_css("input[value='Modified title and description']")
143
+ expect(page).to have_no_css("input[value='This is the first title and description']")
144
144
  end
145
145
 
146
146
  it "re-renders the form when the information is invalid and displays errors" do
@@ -151,43 +151,43 @@ shared_examples_for "update questions" do
151
151
  fill_in "questionnaire_questions_#{question.id}_body_en", with: ""
152
152
  end
153
153
 
154
- click_button "Save"
154
+ click_on "Save"
155
155
  end
156
156
 
157
157
  expand_all_questions
158
158
 
159
159
  expect(page).to have_admin_callout("There was a problem saving")
160
160
  expect(page).to have_content("cannot be blank", count: 1)
161
- expect(page).to have_selector("input[value='']")
162
- expect(page).not_to have_selector("input[value='This is the first title and description']")
161
+ expect(page).to have_css("input[value='']")
162
+ expect(page).to have_no_css("input[value='This is the first title and description']")
163
163
  end
164
164
 
165
165
  it "preserves deleted status across submission failures" do
166
166
  within "form.edit_questionnaire" do
167
167
  within ".questionnaire-question" do
168
- click_button "Remove"
168
+ click_on "Remove"
169
169
  end
170
170
  end
171
171
 
172
- click_button "Add question"
172
+ click_on "Add question"
173
173
 
174
- click_button "Save"
174
+ click_on "Save"
175
175
 
176
- expect(page).to have_selector(".questionnaire-question", count: 1)
176
+ expect(page).to have_css(".questionnaire-question", count: 1)
177
177
 
178
178
  within ".questionnaire-question" do
179
- expect(page).to have_selector(".card-title", text: "#1")
180
- expect(page).not_to have_button("Up")
179
+ expect(page).to have_css(".card-title", text: "#1")
180
+ expect(page).to have_no_button("Up")
181
181
  end
182
182
  end
183
183
 
184
184
  it "removes the question" do
185
185
  within "form.edit_questionnaire" do
186
186
  within ".questionnaire-question" do
187
- click_button "Remove"
187
+ click_on "Remove"
188
188
  end
189
189
 
190
- click_button "Save"
190
+ click_on "Save"
191
191
  end
192
192
 
193
193
  expect(page).to have_admin_callout("successfully")
@@ -195,14 +195,14 @@ shared_examples_for "update questions" do
195
195
  visit questionnaire_edit_path
196
196
 
197
197
  within "form.edit_questionnaire" do
198
- expect(page).to have_selector(".questionnaire-question", count: 0)
198
+ expect(page).to have_css(".questionnaire-question", count: 0)
199
199
  end
200
200
  end
201
201
 
202
202
  it "cannot be moved up" do
203
203
  within "form.edit_questionnaire" do
204
204
  within ".questionnaire-question" do
205
- expect(page).not_to have_button("Up")
205
+ expect(page).to have_no_button("Up")
206
206
  end
207
207
  end
208
208
  end
@@ -210,7 +210,7 @@ shared_examples_for "update questions" do
210
210
  it "cannot be moved down" do
211
211
  within "form.edit_questionnaire" do
212
212
  within ".questionnaire-question" do
213
- expect(page).not_to have_button("Down")
213
+ expect(page).to have_no_button("Down")
214
214
  end
215
215
  end
216
216
  end
@@ -240,19 +240,19 @@ shared_examples_for "update questions" do
240
240
  expand_all_questions
241
241
 
242
242
  within ".questionnaire-question-answer-option:last-of-type" do
243
- click_button "Remove"
243
+ click_on "Remove"
244
244
  end
245
245
 
246
- click_button "Save"
246
+ click_on "Save"
247
247
 
248
248
  visit_questionnaire_edit_path_and_expand_all
249
249
 
250
- expect(page).to have_selector(".questionnaire-question-answer-option", count: 2)
250
+ expect(page).to have_css(".questionnaire-question-answer-option", count: 2)
251
251
  end
252
252
 
253
253
  it "still removes the question even if previous editions rendered the options invalid" do
254
254
  within "form.edit_questionnaire" do
255
- expect(page).to have_selector(".questionnaire-question", count: 1)
255
+ expect(page).to have_css(".questionnaire-question", count: 1)
256
256
 
257
257
  expand_all_questions
258
258
 
@@ -261,10 +261,10 @@ shared_examples_for "update questions" do
261
261
  end
262
262
 
263
263
  within ".questionnaire-question" do
264
- click_button "Remove", match: :first
264
+ click_on "Remove", match: :first
265
265
  end
266
266
 
267
- click_button "Save"
267
+ click_on "Save"
268
268
  end
269
269
 
270
270
  expect(page).to have_admin_callout("successfully")
@@ -272,7 +272,7 @@ shared_examples_for "update questions" do
272
272
  visit_questionnaire_edit_path_and_expand_all
273
273
 
274
274
  within "form.edit_questionnaire" do
275
- expect(page).to have_selector(".questionnaire-question", count: 0)
275
+ expect(page).to have_css(".questionnaire-question", count: 0)
276
276
  end
277
277
  end
278
278
  end
@@ -305,32 +305,32 @@ shared_examples_for "update questions" do
305
305
 
306
306
  it "allows deleting matrix rows" do
307
307
  within ".questionnaire-question-matrix-row:last-of-type" do
308
- click_button "Remove"
308
+ click_on "Remove"
309
309
  end
310
310
 
311
- click_button "Save"
311
+ click_on "Save"
312
312
 
313
313
  visit_questionnaire_edit_path_and_expand_all
314
314
 
315
315
  within ".questionnaire-question:last-of-type" do
316
- expect(page).to have_selector(".questionnaire-question-matrix-row", count: 2)
317
- expect(page).to have_selector(".questionnaire-question-answer-option", count: 3)
316
+ expect(page).to have_css(".questionnaire-question-matrix-row", count: 2)
317
+ expect(page).to have_css(".questionnaire-question-answer-option", count: 3)
318
318
  end
319
319
  end
320
320
 
321
321
  it "still removes the question even if previous editions rendered the rows invalid" do
322
322
  within "form.edit_questionnaire" do
323
- expect(page).to have_selector(".questionnaire-question", count: 2)
323
+ expect(page).to have_css(".questionnaire-question", count: 2)
324
324
 
325
325
  within ".questionnaire-question-matrix-row:first-of-type" do
326
326
  fill_in find_nested_form_field_locator("body_en"), with: ""
327
327
  end
328
328
 
329
329
  within ".questionnaire-question:last-of-type" do
330
- click_button "Remove", match: :first
330
+ click_on "Remove", match: :first
331
331
  end
332
332
 
333
- click_button "Save"
333
+ click_on "Save"
334
334
  end
335
335
 
336
336
  expect(page).to have_admin_callout("successfully")
@@ -338,7 +338,7 @@ shared_examples_for "update questions" do
338
338
  visit_questionnaire_edit_path_and_expand_all
339
339
 
340
340
  within "form.edit_questionnaire" do
341
- expect(page).to have_selector(".questionnaire-question", count: 1)
341
+ expect(page).to have_css(".questionnaire-question", count: 1)
342
342
  end
343
343
  end
344
344
  end
@@ -382,7 +382,7 @@ shared_examples_for "update questions" do
382
382
  context "when moving a question up" do
383
383
  before do
384
384
  within ".questionnaire-question:last-of-type" do
385
- click_button "Up"
385
+ click_on "Up"
386
386
  end
387
387
  end
388
388
 
@@ -392,7 +392,7 @@ shared_examples_for "update questions" do
392
392
  context "when moving a question down" do
393
393
  before do
394
394
  within ".questionnaire-question:first-of-type" do
395
- click_button "Down"
395
+ click_on "Down"
396
396
  end
397
397
  end
398
398
 
@@ -402,30 +402,30 @@ shared_examples_for "update questions" do
402
402
  describe "collapsible questions" do
403
403
  context "when clicking on Expand all button" do
404
404
  it "expands all questions" do
405
- click_button "Expand all questions"
406
- expect(page).to have_selector(".collapsible", visible: :all)
407
- expect(page).to have_selector(".question--collapse .icon-collapse", count: questionnaire.questions.count)
405
+ click_on "Expand all questions"
406
+ expect(page).to have_css(".collapsible", visible: :all)
407
+ expect(page).to have_css(".question--collapse .icon-collapse", count: questionnaire.questions.count)
408
408
  end
409
409
  end
410
410
 
411
411
  context "when clicking on Collapse all button" do
412
412
  it "collapses all questions" do
413
- click_button "Collapse all questions"
414
- expect(page).not_to have_selector(".collapsible", visible: :visible)
415
- expect(page).to have_selector(".question--collapse .icon-expand", count: questionnaire.questions.count)
413
+ click_on "Collapse all questions"
414
+ expect(page).to have_no_css(".collapsible", visible: :visible)
415
+ expect(page).to have_css(".question--collapse .icon-expand", count: questionnaire.questions.count)
416
416
  end
417
417
  end
418
418
 
419
419
  shared_examples_for "collapsing a question" do
420
420
  it "changes the toggle button" do
421
421
  within ".questionnaire-question:last-of-type" do
422
- expect(page).to have_selector(".icon-expand")
422
+ expect(page).to have_css(".icon-expand")
423
423
  end
424
424
  end
425
425
 
426
426
  it "hides the question card section" do
427
427
  within ".questionnaire-question:last-of-type" do
428
- expect(page).not_to have_selector(".collapsible", visible: :visible)
428
+ expect(page).to have_no_css(".collapsible", visible: :visible)
429
429
  end
430
430
  end
431
431
  end
@@ -433,12 +433,12 @@ shared_examples_for "update questions" do
433
433
  shared_examples_for "uncollapsing a question" do
434
434
  it "changes the toggle button" do
435
435
  within ".questionnaire-question:last-of-type" do
436
- expect(page).to have_selector(".icon-collapse")
436
+ expect(page).to have_css(".icon-collapse")
437
437
  end
438
438
  end
439
439
 
440
440
  it "shows the question card section" do
441
- expect(page).to have_selector(".collapsible", visible: :visible)
441
+ expect(page).to have_css(".collapsible", visible: :visible)
442
442
  end
443
443
  end
444
444
 
@@ -455,7 +455,7 @@ shared_examples_for "update questions" do
455
455
 
456
456
  context "when adding a new question" do
457
457
  before do
458
- click_button "Add question"
458
+ click_on "Add question"
459
459
  expand_all_questions
460
460
 
461
461
  within ".questionnaire-question:last-of-type" do
@@ -468,8 +468,8 @@ shared_examples_for "update questions" do
468
468
 
469
469
  context "when submitting a new question with an error" do
470
470
  before do
471
- click_button "Add question"
472
- click_button "Save"
471
+ click_on "Add question"
472
+ click_on "Save"
473
473
 
474
474
  within ".questionnaire-question:last-of-type" do
475
475
  page.find(".question--collapse").click
@@ -484,14 +484,14 @@ shared_examples_for "update questions" do
484
484
  end
485
485
 
486
486
  within ".questionnaire-question:last-of-type" do
487
- expect(page).to have_selector(".icon-collapse")
487
+ expect(page).to have_css(".icon-collapse")
488
488
  end
489
489
  end
490
490
  end
491
491
  end
492
492
 
493
493
  it "properly decides which button to show after adding/removing questions" do
494
- click_button "Add question"
494
+ click_on "Add question"
495
495
  expand_all_questions
496
496
 
497
497
  expect(page.find(".questionnaire-question:nth-of-type(1)")).to look_like_first_question
@@ -499,7 +499,7 @@ shared_examples_for "update questions" do
499
499
  expect(page.find(".questionnaire-question:nth-of-type(3)")).to look_like_last_question
500
500
 
501
501
  within ".questionnaire-question:first-of-type" do
502
- click_button "Remove"
502
+ click_on "Remove"
503
503
  end
504
504
 
505
505
  expect(page.all(".questionnaire-question").first).to look_like_first_question
@@ -508,41 +508,41 @@ shared_examples_for "update questions" do
508
508
 
509
509
  it "does not duplicate editors when adding new questions" do
510
510
  expect do
511
- click_button "Add question"
511
+ click_on "Add question"
512
512
  expand_all_questions
513
513
  end.to change { page.all(".editor-toolbar").size }.by(1)
514
514
  end
515
515
 
516
516
  it "properly decides which button to show after adding/removing answer options" do
517
- click_button "Add question"
517
+ click_on "Add question"
518
518
  expand_all_questions
519
519
 
520
520
  within ".questionnaire-question:last-of-type" do
521
521
  select "Single option", from: "Type"
522
522
 
523
523
  within ".questionnaire-question-answer-options-list" do
524
- expect(page).not_to have_button("Remove")
524
+ expect(page).to have_no_button("Remove")
525
525
  end
526
526
 
527
- click_button "Add answer option"
527
+ click_on "Add answer option"
528
528
 
529
529
  expect(page.all(".questionnaire-question-answer-option")).to all(have_button("Remove"))
530
530
 
531
531
  within ".questionnaire-question-answer-option:first-of-type" do
532
- click_button "Remove"
532
+ click_on "Remove"
533
533
  end
534
534
 
535
535
  within ".questionnaire-question-answer-options-list" do
536
- expect(page).not_to have_button("Remove")
536
+ expect(page).to have_no_button("Remove")
537
537
  end
538
538
  end
539
539
 
540
- click_button "Save"
540
+ click_on "Save"
541
541
  expand_all_questions
542
542
 
543
543
  within ".questionnaire-question:last-of-type" do
544
544
  within ".questionnaire-question-answer-options-list" do
545
- expect(page).not_to have_button("Remove")
545
+ expect(page).to have_no_button("Remove")
546
546
  end
547
547
  end
548
548
  end
@@ -35,7 +35,7 @@ shared_examples_for "manage questionnaires" do
35
35
 
36
36
  within "form.edit_questionnaire" do
37
37
  fill_in_i18n_editor(:questionnaire_description, "#questionnaire-description-tabs", new_description)
38
- click_button "Save"
38
+ click_on "Save"
39
39
  end
40
40
 
41
41
  expect(page).to have_admin_callout("successfully")
@@ -63,16 +63,16 @@ shared_examples_for "manage questionnaires" do
63
63
  it "cannot modify questionnaire questions" do
64
64
  visit questionnaire_edit_path
65
65
 
66
- expect(page).not_to have_content("Add question")
67
- expect(page).not_to have_content("Remove")
66
+ expect(page).to have_no_content("Add question")
67
+ expect(page).to have_no_content("Remove")
68
68
 
69
69
  expand_all_questions
70
70
 
71
- expect(page).to have_selector("input[value='This is the first question'][disabled]")
72
- expect(page).to have_selector("select[id$=question_type][disabled]")
73
- expect(page).to have_selector("select[id$=max_choices][disabled]")
74
- expect(page).to have_selector("input[id$=max_characters][disabled]")
75
- expect(page).to have_selector(".ProseMirror[contenteditable=false]")
71
+ expect(page).to have_css("input[value='This is the first question'][disabled]")
72
+ expect(page).to have_css("select[id$=question_type][disabled]")
73
+ expect(page).to have_css("select[id$=max_choices][disabled]")
74
+ expect(page).to have_css("input[id$=max_characters][disabled]")
75
+ expect(page).to have_css(".ProseMirror[contenteditable=false]")
76
76
  end
77
77
  end
78
78
 
@@ -100,7 +100,7 @@ shared_examples_for "manage questionnaires" do
100
100
 
101
101
  def within_add_display_condition
102
102
  within ".questionnaire-question:last-of-type" do
103
- click_button "Add display condition"
103
+ click_on "Add display condition"
104
104
 
105
105
  within ".questionnaire-question-display-condition:last-of-type" do
106
106
  yield
@@ -42,7 +42,7 @@ module Decidim
42
42
  questionnaire_id = @answers.first&.decidim_questionnaire_id
43
43
  return {} unless questionnaire_id
44
44
 
45
- questions = Decidim::Forms::Question.where(decidim_questionnaire_id: questionnaire_id).order(:position)
45
+ questions = Decidim::Forms::Question.where(decidim_questionnaire_id: questionnaire_id)
46
46
  return {} if questions.none?
47
47
 
48
48
  questions.each.inject({}) do |serialized, question|
@@ -4,7 +4,7 @@ module Decidim
4
4
  # This holds the decidim-forms version.
5
5
  module Forms
6
6
  def self.version
7
- "0.28.5"
7
+ "0.29.0.rc1"
8
8
  end
9
9
  end
10
10
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: decidim-forms
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.28.5
4
+ version: 0.29.0.rc1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Josep Jaume Rey Peroy
@@ -11,7 +11,7 @@ authors:
11
11
  autorequire:
12
12
  bindir: bin
13
13
  cert_chain: []
14
- date: 2025-02-12 00:00:00.000000000 Z
14
+ date: 2024-07-16 00:00:00.000000000 Z
15
15
  dependencies:
16
16
  - !ruby/object:Gem::Dependency
17
17
  name: decidim-core
@@ -19,14 +19,14 @@ dependencies:
19
19
  requirements:
20
20
  - - '='
21
21
  - !ruby/object:Gem::Version
22
- version: 0.28.5
22
+ version: 0.29.0.rc1
23
23
  type: :runtime
24
24
  prerelease: false
25
25
  version_requirements: !ruby/object:Gem::Requirement
26
26
  requirements:
27
27
  - - '='
28
28
  - !ruby/object:Gem::Version
29
- version: 0.28.5
29
+ version: 0.29.0.rc1
30
30
  - !ruby/object:Gem::Dependency
31
31
  name: wicked_pdf
32
32
  requirement: !ruby/object:Gem::Requirement
@@ -41,34 +41,48 @@ dependencies:
41
41
  - - "~>"
42
42
  - !ruby/object:Gem::Version
43
43
  version: '2.1'
44
+ - !ruby/object:Gem::Dependency
45
+ name: wkhtmltopdf-binary
46
+ requirement: !ruby/object:Gem::Requirement
47
+ requirements:
48
+ - - "~>"
49
+ - !ruby/object:Gem::Version
50
+ version: '0.12'
51
+ type: :runtime
52
+ prerelease: false
53
+ version_requirements: !ruby/object:Gem::Requirement
54
+ requirements:
55
+ - - "~>"
56
+ - !ruby/object:Gem::Version
57
+ version: '0.12'
44
58
  - !ruby/object:Gem::Dependency
45
59
  name: decidim-admin
46
60
  requirement: !ruby/object:Gem::Requirement
47
61
  requirements:
48
62
  - - '='
49
63
  - !ruby/object:Gem::Version
50
- version: 0.28.5
64
+ version: 0.29.0.rc1
51
65
  type: :development
52
66
  prerelease: false
53
67
  version_requirements: !ruby/object:Gem::Requirement
54
68
  requirements:
55
69
  - - '='
56
70
  - !ruby/object:Gem::Version
57
- version: 0.28.5
71
+ version: 0.29.0.rc1
58
72
  - !ruby/object:Gem::Dependency
59
73
  name: decidim-dev
60
74
  requirement: !ruby/object:Gem::Requirement
61
75
  requirements:
62
76
  - - '='
63
77
  - !ruby/object:Gem::Version
64
- version: 0.28.5
78
+ version: 0.29.0.rc1
65
79
  type: :development
66
80
  prerelease: false
67
81
  version_requirements: !ruby/object:Gem::Requirement
68
82
  requirements:
69
83
  - - '='
70
84
  - !ruby/object:Gem::Version
71
- version: 0.28.5
85
+ version: 0.29.0.rc1
72
86
  description: A forms gem for decidim.
73
87
  email:
74
88
  - josepjaume@gmail.com
@@ -180,8 +194,6 @@ files:
180
194
  - config/locales/ar.yml
181
195
  - config/locales/bg-BG.yml
182
196
  - config/locales/bg.yml
183
- - config/locales/bn-BD.yml
184
- - config/locales/bs-BA.yml
185
197
  - config/locales/ca.yml
186
198
  - config/locales/cs-CZ.yml
187
199
  - config/locales/cs.yml
@@ -270,6 +282,10 @@ files:
270
282
  - db/migrate/20201110152921_add_salt_to_decidim_forms_questionnaires.rb
271
283
  - db/migrate/20210208094442_add_max_characters_to_decidim_forms_questions.rb
272
284
  - db/migrate/20210616153042_set_position_to_question_matrix_rows.rb
285
+ - db/migrate/20240402092039_add_answer_options_counter_cache_to_questions.rb
286
+ - db/migrate/20240402095253_add_matrix_row_counter_cache_to_questions.rb
287
+ - db/migrate/20240416111953_add_display_conditions_counter_cache_to_questions.rb
288
+ - db/migrate/20240416113926_add_display_conditions_for_other_questions_counter_cache_to_questions.rb
273
289
  - decidim-forms.gemspec
274
290
  - lib/decidim/api/answer_option_type.rb
275
291
  - lib/decidim/api/question_type.rb
@@ -296,7 +312,7 @@ files:
296
312
  - lib/decidim/forms/version.rb
297
313
  homepage: https://decidim.org
298
314
  licenses:
299
- - AGPL-3.0-or-later
315
+ - AGPL-3.0
300
316
  metadata:
301
317
  bug_tracker_uri: https://github.com/decidim/decidim/issues
302
318
  documentation_uri: https://docs.decidim.org/
@@ -311,14 +327,14 @@ required_ruby_version: !ruby/object:Gem::Requirement
311
327
  requirements:
312
328
  - - "~>"
313
329
  - !ruby/object:Gem::Version
314
- version: 3.1.0
330
+ version: 3.2.0
315
331
  required_rubygems_version: !ruby/object:Gem::Requirement
316
332
  requirements:
317
- - - ">="
333
+ - - ">"
318
334
  - !ruby/object:Gem::Version
319
- version: '0'
335
+ version: 1.3.1
320
336
  requirements: []
321
- rubygems_version: 3.3.7
337
+ rubygems_version: 3.4.10
322
338
  signing_key:
323
339
  specification_version: 4
324
340
  summary: Decidim forms
@@ -1 +0,0 @@
1
- bn:
@@ -1 +0,0 @@
1
- bs: