@worksafevictoria/wcl7.5 1.17.0-beta.10 → 1.17.0-beta.12

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 (31) hide show
  1. package/package.json +1 -1
  2. package/src/components/Containers/SectionGroup/index.vue +0 -1
  3. package/src/components/Paragraphs/RTWPlanner/Injuries/index.vue +7 -1
  4. package/src/components/Paragraphs/RTWPlanner/Planners/PlannerNameModal.vue +56 -0
  5. package/src/components/SubComponents/FormInstance/models/base-form-element.js +4 -3
  6. package/src/components/SubComponents/FormInstance/services/form-render-parser.js +51 -16
  7. package/src/components/SubComponents/FormInstance/services/logic-parser.js +81 -9
  8. package/src/components/SubComponents/FormInstance/services/registry-factory.js +52 -50
  9. package/src/components/SubComponents/FormInstance/stories/mocks/checkboxesother.json +1 -10
  10. package/src/components/SubComponents/FormInstance/stories/mocks/emailconfirm.json +1 -10
  11. package/src/components/SubComponents/FormInstance/stories/mocks/jahd.json +1 -5
  12. package/src/components/SubComponents/FormInstance/stories/mocks/quad.json +1 -5
  13. package/src/components/SubComponents/FormInstance/stories/mocks/radiosother.json +1 -9
  14. package/src/components/SubComponents/FormInstance/stories/mocks/sameas.json +1 -5
  15. package/src/components/SubComponents/FormInstance/stories/mocks/selectother.json +1 -10
  16. package/src/components/SubComponents/FormInstance/stories/mocks/styles.json +1 -5
  17. package/src/components/SubComponents/FormInstance/stories/mocks/table-select.json +1 -15
  18. package/src/components/SubComponents/FormInstance/stories/mocks/token.json +1 -5
  19. package/src/components/SubComponents/FormInstance/stories/mocks/twig.json +1 -13
  20. package/src/components/SubComponents/FormInstance/stories/mocks/wizard.json +1 -13
  21. package/src/components/SubComponents/FormInstance/tests/form-test-utils.js +3 -0
  22. package/src/components/SubComponents/FormInstance/tests/form.test.js +2 -1
  23. package/src/components/SubComponents/FormInstance/tests/radiosother.test.js +12 -11
  24. package/src/components/SubComponents/FormInstance/tests/rule-disabled.test.js +13 -45
  25. package/src/components/SubComponents/FormInstance/tests/rule-enabled-value.test.js +8 -24
  26. package/src/components/SubComponents/FormInstance/tests/rule-hidden.test.js +13 -45
  27. package/src/components/SubComponents/FormInstance/tests/rule-required-value.test.js +15 -55
  28. package/src/components/SubComponents/FormInstance/tests/rule-visible.test.js +0 -413
  29. package/src/components/SubComponents/FormInstance/tests/sameas.test.js +9 -25
  30. package/src/components/SubComponents/FormInstance/tests/twig.test.js +7 -5
  31. package/src/index.js +6 -0
@@ -44,197 +44,197 @@ import { UnknownFormElement } from '../models/overrides/unknown'
44
44
  import { URLFormElement } from '../models/overrides/url'
45
45
 
46
46
  export class RegisterFactory {
47
- static getFormIOElement(webformElement, formSettingsMeta, parent) {
47
+ static getFormIOElement(webformElement, formSettingsMeta, parent, tree) {
48
48
  const matchingElements = [
49
49
  {
50
50
  isApplicable: (webformElement, type) =>
51
51
  type === 'textfield' &&
52
52
  webformElement['#input_mask']?.includes(`'alias': 'currency`),
53
- factory: CurrencyFormElement
53
+ factory: CurrencyFormElement,
54
54
  },
55
55
  {
56
56
  isApplicable: (webformElement, type) =>
57
57
  type === 'email' ||
58
58
  webformElement['#input_mask']?.includes(`'alias': 'email`),
59
- factory: EmailFormElement
59
+ factory: EmailFormElement,
60
60
  },
61
61
  {
62
62
  isApplicable: 'tel',
63
- factory: PhoneNumberFormElement
63
+ factory: PhoneNumberFormElement,
64
64
  },
65
65
  {
66
66
  isApplicable: 'select',
67
- factory: SelectFormElement
67
+ factory: SelectFormElement,
68
68
  },
69
69
  {
70
70
  isApplicable: [
71
71
  'webform_select_other',
72
72
  'webform_checkboxes_other',
73
- 'webform_radios_other'
73
+ 'webform_radios_other',
74
74
  ],
75
- factory: OptionsOtherFormElement
75
+ factory: OptionsOtherFormElement,
76
76
  },
77
77
  {
78
78
  isApplicable: 'radios',
79
- factory: RadioFormElement
79
+ factory: RadioFormElement,
80
80
  },
81
81
  {
82
82
  isApplicable: ['datelist'],
83
- factory: DateListFormElement
83
+ factory: DateListFormElement,
84
84
  },
85
85
  {
86
86
  isApplicable: ['date', 'datetime'],
87
- factory: DateFormElement
87
+ factory: DateFormElement,
88
88
  },
89
89
  {
90
90
  isApplicable: 'webform_time',
91
- factory: TimeFormElement
91
+ factory: TimeFormElement,
92
92
  },
93
93
  {
94
94
  isApplicable: 'number',
95
- factory: NumberFormElement
95
+ factory: NumberFormElement,
96
96
  },
97
97
  {
98
98
  isApplicable: 'range',
99
- factory: RangeFormElement
99
+ factory: RangeFormElement,
100
100
  },
101
101
  {
102
102
  isApplicable: 'webform_likert',
103
- factory: LikertFormElement
103
+ factory: LikertFormElement,
104
104
  },
105
105
  {
106
106
  isApplicable: 'tableselect',
107
- factory: TableSelectFormElement
107
+ factory: TableSelectFormElement,
108
108
  },
109
109
  {
110
110
  isApplicable: 'webform_multiple',
111
- factory: MultipleFormElement
111
+ factory: MultipleFormElement,
112
112
  },
113
113
  {
114
114
  isApplicable: 'webform_custom_composite',
115
- factory: CustomCompositeFormElement
115
+ factory: CustomCompositeFormElement,
116
116
  },
117
117
  {
118
118
  isApplicable: 'webform_signature',
119
- factory: SignatureFormElement
119
+ factory: SignatureFormElement,
120
120
  },
121
121
  {
122
122
  isApplicable: ['webform_message'],
123
- factory: MessageFormElement
123
+ factory: MessageFormElement,
124
124
  },
125
125
  {
126
126
  isApplicable: [
127
127
  'webform_markup',
128
128
  'processed_text',
129
129
  'webform_horizontal_rule',
130
- 'label'
130
+ 'label',
131
131
  ],
132
- factory: MarkupFormElement
132
+ factory: MarkupFormElement,
133
133
  },
134
134
  {
135
135
  isApplicable: ['managed_file'],
136
- factory: FileFormElement
136
+ factory: FileFormElement,
137
137
  },
138
138
  {
139
139
  isApplicable: ['textformat'],
140
- factory: TextFormatFormElement
140
+ factory: TextFormatFormElement,
141
141
  },
142
142
  {
143
143
  isApplicable: 'url',
144
- factory: URLFormElement
144
+ factory: URLFormElement,
145
145
  },
146
146
  {
147
147
  isApplicable: ['checkbox', 'webform_same'],
148
- factory: CheckboxFormElement
148
+ factory: CheckboxFormElement,
149
149
  },
150
150
  {
151
151
  isApplicable: ['checkboxes'],
152
- factory: CheckboxesFormElement
152
+ factory: CheckboxesFormElement,
153
153
  },
154
154
  {
155
155
  isApplicable: 'webform_autocomplete',
156
- factory: AutoCompleteFormElement
156
+ factory: AutoCompleteFormElement,
157
157
  },
158
158
  {
159
159
  isApplicable: 'webform_more',
160
- factory: MoreTextFormElement
160
+ factory: MoreTextFormElement,
161
161
  },
162
162
  {
163
163
  isApplicable: ['hidden'],
164
- factory: HiddenFormElement
164
+ factory: HiddenFormElement,
165
165
  },
166
166
  {
167
167
  isApplicable: 'webform_address',
168
- factory: AddresseFormElement
168
+ factory: AddresseFormElement,
169
169
  },
170
170
  {
171
171
  isApplicable: ['textfield'],
172
- factory: TextFormElement
172
+ factory: TextFormElement,
173
173
  },
174
174
  {
175
175
  isApplicable: ['value', 'textarea'],
176
- factory: TextAreaFormElement
176
+ factory: TextAreaFormElement,
177
177
  },
178
178
  {
179
179
  isApplicable: 'webform_rating',
180
- factory: RatingFormElement
180
+ factory: RatingFormElement,
181
181
  },
182
182
  // Matt testing
183
183
  {
184
184
  isApplicable: 'webform_testing',
185
- factory: TestingFormElement
185
+ factory: TestingFormElement,
186
186
  },
187
187
 
188
188
  // end Matt testing
189
189
  {
190
190
  isApplicable: 'webform_scale',
191
- factory: ScaleFormElement
191
+ factory: ScaleFormElement,
192
192
  },
193
193
  {
194
194
  isApplicable: 'webform_actions',
195
- factory: SubmitFormElement
195
+ factory: SubmitFormElement,
196
196
  },
197
197
  {
198
198
  isApplicable: (webformElement) =>
199
199
  webformElement['#webform_plugin_id'] === 'webform_wizard_page',
200
- factory: PageFormElement
200
+ factory: PageFormElement,
201
201
  },
202
202
  {
203
203
  isApplicable: 'details',
204
- factory: DetailFormElement
204
+ factory: DetailFormElement,
205
205
  },
206
206
  {
207
207
  isApplicable: 'container',
208
- factory: ContainerFormElement
208
+ factory: ContainerFormElement,
209
209
  },
210
210
  {
211
211
  isApplicable: 'webform_table',
212
- factory: TableFormElement
212
+ factory: TableFormElement,
213
213
  },
214
214
  {
215
215
  isApplicable: 'webform_table_row',
216
- factory: TableRowFormElement
216
+ factory: TableRowFormElement,
217
217
  },
218
218
  {
219
219
  isApplicable: 'item',
220
- factory: TwigFormElement
220
+ factory: TwigFormElement,
221
221
  },
222
222
  {
223
223
  isApplicable: ['fieldset', 'webform_section'],
224
- factory: SectionFormElement
224
+ factory: SectionFormElement,
225
225
  },
226
226
  {
227
227
  isApplicable: 'webform_flexbox',
228
- factory: FlexboxFormElement
228
+ factory: FlexboxFormElement,
229
229
  },
230
230
  {
231
231
  isApplicable: 'webform_email_confirm',
232
- factory: EmailConfirmFormElement
232
+ factory: EmailConfirmFormElement,
233
233
  },
234
234
  {
235
235
  isApplicable: 'webform_codemirror',
236
- factory: CodeFormElement
237
- }
236
+ factory: CodeFormElement,
237
+ },
238
238
  ]
239
239
 
240
240
  const matchingElement = matchingElements.find((item) => {
@@ -252,7 +252,7 @@ export class RegisterFactory {
252
252
  const ElementFactory = matchingElement?.factory
253
253
  const moreElement = RegisterFactory.getMoreTextInstance(
254
254
  webformElement,
255
- parent
255
+ parent,
256
256
  )
257
257
  const elementInstance = matchingElement
258
258
  ? new ElementFactory(webformElement, parent, moreElement)
@@ -263,6 +263,8 @@ export class RegisterFactory {
263
263
  }
264
264
 
265
265
  elementInstance.setFormSettingsMeta(formSettingsMeta)
266
+ // Set the tree for logic parsing
267
+ elementInstance.tree = tree
266
268
  return elementInstance
267
269
  }
268
270
 
@@ -274,9 +276,9 @@ export class RegisterFactory {
274
276
  ...webFormElement,
275
277
  '#type': 'webform_more',
276
278
  '#webform_id': 'webform_more' + webFormElement['#webform_id'],
277
- '#webform_key': 'webform_more' + webFormElement['#webform_key']
279
+ '#webform_key': 'webform_more' + webFormElement['#webform_key'],
278
280
  },
279
- parent
281
+ parent,
280
282
  )
281
283
  }
282
284
  return moreElement
@@ -184,14 +184,5 @@
184
184
  "#ajax_processed": false,
185
185
  "#sorted": true,
186
186
  "#after_build_done": true
187
- },
188
- "#tree": false,
189
- "#weight": 0.001,
190
- "#processed": false,
191
- "#required": false,
192
- "#title_display": "before",
193
- "#description_display": "after",
194
- "#errors": null,
195
- "#id": "edit-elements",
196
- "#sorted": true
187
+ }
197
188
  }
@@ -97,14 +97,5 @@
97
97
  },
98
98
  "#sorted": true,
99
99
  "#after_build_done": true
100
- },
101
- "#tree": false,
102
- "#weight": 0.001,
103
- "#processed": false,
104
- "#required": false,
105
- "#title_display": "before",
106
- "#description_display": "after",
107
- "#errors": null,
108
- "#id": "edit-elements",
109
- "#sorted": true
100
+ }
110
101
  }
@@ -1351,9 +1351,5 @@
1351
1351
  "#title_display": "before",
1352
1352
  "#description_display": "after",
1353
1353
  "#id": "edit-enter-details"
1354
- },
1355
- "#required": false,
1356
- "#title_display": "before",
1357
- "#description_display": "after",
1358
- "#id": "kitchen_sink_formio_v1"
1354
+ }
1359
1355
  }
@@ -241,9 +241,5 @@
241
241
  "#title_display": "before",
242
242
  "#description_display": "after",
243
243
  "#id": "edit-results"
244
- },
245
- "#required": false,
246
- "#title_display": "before",
247
- "#description_display": "after",
248
- "#id": "edit-elements"
244
+ }
249
245
  }
@@ -164,13 +164,5 @@
164
164
  "#ajax_processed": false,
165
165
  "#sorted": true,
166
166
  "#after_build_done": true
167
- },
168
- "#tree": false,
169
- "#processed": false,
170
- "#required": false,
171
- "#title_display": "before",
172
- "#description_display": "after",
173
- "#errors": null,
174
- "#id": "edit-elements",
175
- "#sorted": true
167
+ }
176
168
  }
@@ -58,9 +58,5 @@
58
58
  "#name": "samea",
59
59
  "#value": 0,
60
60
  "#checked": false
61
- },
62
- "#required": false,
63
- "#title_display": "before",
64
- "#description_display": "after",
65
- "#id": "edit-elements"
61
+ }
66
62
  }
@@ -102,14 +102,5 @@
102
102
  "#ajax_processed": false,
103
103
  "#sorted": true,
104
104
  "#after_build_done": true
105
- },
106
- "#tree": false,
107
- "#weight": 0.001,
108
- "#processed": false,
109
- "#required": false,
110
- "#title_display": "before",
111
- "#description_display": "after",
112
- "#errors": null,
113
- "#id": "edit-elements",
114
- "#sorted": true
105
+ }
115
106
  }
@@ -73,9 +73,5 @@
73
73
  "#id": "edit-element-without-styles",
74
74
  "#name": "element_without_styles",
75
75
  "#value": ""
76
- },
77
- "#required": false,
78
- "#title_display": "before",
79
- "#description_display": "after",
80
- "#id": "edit-elements"
76
+ }
81
77
  }
@@ -454,19 +454,5 @@
454
454
  },
455
455
  "#sorted": true,
456
456
  "#after_build_done": true
457
- },
458
- "#tree": false,
459
- "#parents": ["elements"],
460
- "#array_parents": ["elements"],
461
- "#weight": 0.001,
462
- "#processed": false,
463
- "#required": false,
464
- "#attributes": {
465
- "data-drupal-selector": "edit-elements"
466
- },
467
- "#title_display": "before",
468
- "#description_display": "after",
469
- "#errors": null,
470
- "#id": "edit-elements",
471
- "#sorted": true
457
+ }
472
458
  }
@@ -252,9 +252,5 @@
252
252
  "#name": "tokens"
253
253
  }
254
254
  }
255
- },
256
- "#required": false,
257
- "#title_display": "before",
258
- "#description_display": "after",
259
- "#id": "edit-elements"
255
+ }
260
256
  }
@@ -138,17 +138,5 @@
138
138
  },
139
139
  "#sorted": true,
140
140
  "#after_build_done": true
141
- },
142
- "#tree": false,
143
- "#weight": 0.001,
144
- "#processed": false,
145
- "#required": false,
146
- "#attributes": {
147
- "data-drupal-selector": "edit-elements"
148
- },
149
- "#title_display": "before",
150
- "#description_display": "after",
151
- "#errors": null,
152
- "#id": "edit-elements",
153
- "#sorted": true
141
+ }
154
142
  }
@@ -337,17 +337,5 @@
337
337
  },
338
338
  "#theme": "webform_actions",
339
339
  "#after_build_done": true
340
- },
341
- "#tree": false,
342
- "#weight": 0.002,
343
- "#processed": false,
344
- "#required": false,
345
- "#attributes": {
346
- "data-drupal-selector": "edit-elements"
347
- },
348
- "#title_display": "before",
349
- "#description_display": "after",
350
- "#errors": null,
351
- "#id": "edit-elements",
352
- "#sorted": true
340
+ }
353
341
  }
@@ -5,17 +5,20 @@ import { FormSubmitParser } from '../services/form-submit-parser'
5
5
  export class FormTestUtils {
6
6
  static initialiseParser = () => {
7
7
  const parser = new FormRenderParser()
8
+
8
9
  parser.initialise('', false)
9
10
  let counter = 0
10
11
  jest.spyOn(formUtils, 'generateUniqueId').mockImplementation(() => {
11
12
  counter += 0
12
13
  return counter
13
14
  })
15
+
14
16
  return parser
15
17
  }
16
18
 
17
19
  static getParsedComponentsFromJSON = (json) => {
18
20
  const formIOform = FormTestUtils.getParsedFormFromJSON(json)
21
+ //console.log('🚀 ~ FormTestUtils ~ formIOform:', formIOform)
19
22
  const components = JSON.parse(
20
23
  JSON.stringify(formIOform.definition.components),
21
24
  )
@@ -10,9 +10,10 @@ describe(`Form parser`, () => {
10
10
 
11
11
  it(`should render a multi page form`, () => {
12
12
  const form = getParsedComponentsFromJSON(wizard)
13
+ console.log('🚀 ~ form:', form)
13
14
  expect(form).toEqual({
14
15
  display: 'wizard',
15
- id: 'edit-elements'
16
+ // id: 'edit-elements',
16
17
  })
17
18
  })
18
19
  })
@@ -5,6 +5,7 @@ const testComponent = 'radio other'
5
5
  describe(`Form ${testComponent} parser`, () => {
6
6
  it(`should render a ${testComponent} component`, () => {
7
7
  const components = FormTestUtils.getParsedComponentsFromJSON(json)
8
+ console.log('🚀 ~ components:', JSON.stringify(components))
8
9
  expect(components).toEqual(
9
10
  FormTestUtils.getComparisonJSON([
10
11
  {
@@ -32,11 +33,11 @@ describe(`Form ${testComponent} parser`, () => {
32
33
  values: [
33
34
  { label: 'Friday', value: 'Friday' },
34
35
  { label: 'Saturday', value: 'Saturday' },
35
- { label: 'Other…', value: '_other_' }
36
- ]
37
- }
36
+ { label: 'Other…', value: '_other_' },
37
+ ],
38
+ },
38
39
  ],
39
- width: 12
40
+ width: 12,
40
41
  },
41
42
  {
42
43
  components: [
@@ -54,11 +55,11 @@ describe(`Form ${testComponent} parser`, () => {
54
55
  mask: false,
55
56
  placeholder: 'Enter other…',
56
57
  type: 'textfield',
57
- validate: { maxLength: 255, required: false }
58
- }
58
+ validate: { maxLength: 255, required: false },
59
+ },
59
60
  ],
60
- width: 12
61
- }
61
+ width: 12,
62
+ },
62
63
  ],
63
64
  customClass: 'custom-formio-1',
64
65
  defaultValue: { other: null, radios: null },
@@ -71,9 +72,9 @@ describe(`Form ${testComponent} parser`, () => {
71
72
  labelPosition: 'top',
72
73
  mask: false,
73
74
  type: 'columns',
74
- validate: {}
75
- }
76
- ])
75
+ validate: {},
76
+ },
77
+ ]),
77
78
  )
78
79
  })
79
80
  })
@@ -22,7 +22,7 @@ describe(`Form ${testComponent} parser`, () => {
22
22
  placeholder:
23
23
  "type 'disable' to disable textfield2 and 'ro' to make textfield3 readonly",
24
24
  type: 'textfield',
25
- validate: { maxLength: 255, required: false }
25
+ validate: { maxLength: 255, required: false },
26
26
  },
27
27
  {
28
28
  attributes: { counter: 2 },
@@ -42,36 +42,20 @@ describe(`Form ${testComponent} parser`, () => {
42
42
  name: 0,
43
43
  property: { label: 0, type: 'boolean', value: 'disabled' },
44
44
  state: true,
45
- type: 'property'
46
- }
45
+ type: 'property',
46
+ },
47
47
  ],
48
48
  defaultProps: { disabled: false },
49
49
  name: 0,
50
50
  trigger: {
51
51
  javascript: "result = (Boolean(data.textfield1 === 'disable'))",
52
- type: 'javascript'
53
- }
52
+ type: 'javascript',
53
+ },
54
54
  },
55
- {
56
- actions: [
57
- {
58
- name: 0,
59
- property: { label: 0, type: 'boolean', value: 'disabled' },
60
- state: true,
61
- type: 'property'
62
- }
63
- ],
64
- defaultProps: { disabled: false },
65
- name: 0,
66
- trigger: {
67
- javascript: "result = (Boolean(data.textfield1 === 'disable'))",
68
- type: 'javascript'
69
- }
70
- }
71
55
  ],
72
56
  mask: false,
73
57
  type: 'textfield',
74
- validate: { maxLength: 255, required: false }
58
+ validate: { maxLength: 255, required: false },
75
59
  },
76
60
  {
77
61
  attributes: { counter: 3 },
@@ -91,38 +75,22 @@ describe(`Form ${testComponent} parser`, () => {
91
75
  name: 0,
92
76
  property: { label: 0, type: 'boolean', value: 'disabled' },
93
77
  state: true,
94
- type: 'property'
95
- }
78
+ type: 'property',
79
+ },
96
80
  ],
97
81
  defaultProps: { disabled: false },
98
82
  name: 0,
99
83
  trigger: {
100
84
  javascript: "result = (Boolean(data.textfield1 === 'ro'))",
101
- type: 'javascript'
102
- }
85
+ type: 'javascript',
86
+ },
103
87
  },
104
- {
105
- actions: [
106
- {
107
- name: 0,
108
- property: { label: 0, type: 'boolean', value: 'disabled' },
109
- state: true,
110
- type: 'property'
111
- }
112
- ],
113
- defaultProps: { disabled: false },
114
- name: 0,
115
- trigger: {
116
- javascript: "result = (Boolean(data.textfield1 === 'ro'))",
117
- type: 'javascript'
118
- }
119
- }
120
88
  ],
121
89
  mask: false,
122
90
  type: 'textfield',
123
- validate: { maxLength: 255, required: false }
124
- }
125
- ])
91
+ validate: { maxLength: 255, required: false },
92
+ },
93
+ ]),
126
94
  )
127
95
  })
128
96
  })