@3t-transform/threeteeui 0.1.42 → 0.1.44

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 (163) hide show
  1. package/dist/cjs/{domsanitiser.options-277161b9.js → domsanitiser.options-975e3317.js} +12 -12
  2. package/dist/cjs/{index-76f14107.js → index-2ea393bb.js} +146 -3
  3. package/dist/cjs/loader.cjs.js +4 -19
  4. package/dist/cjs/tttx-button.cjs.entry.js +24 -24
  5. package/dist/cjs/tttx-dialog-box.cjs.entry.js +80 -0
  6. package/dist/cjs/tttx-filter.cjs.entry.js +177 -159
  7. package/dist/cjs/tttx-form.cjs.entry.js +458 -458
  8. package/dist/cjs/tttx-icon.cjs.entry.js +11 -11
  9. package/dist/cjs/tttx-keyvalue-block.cjs.entry.js +59 -59
  10. package/dist/cjs/tttx-list.cjs.entry.js +32 -32
  11. package/dist/cjs/tttx-loading-spinner.cjs.entry.js +16 -16
  12. package/dist/cjs/tttx-sorter.cjs.entry.js +102 -102
  13. package/dist/cjs/tttx-standalone-input.cjs.entry.js +79 -79
  14. package/dist/cjs/tttx-toolbar.cjs.entry.js +10 -10
  15. package/dist/cjs/tttx.cjs.js +9 -117
  16. package/dist/collection/collection-manifest.json +3 -2
  17. package/dist/collection/components/atoms/tttx-button/tttx-button.js +110 -110
  18. package/dist/collection/components/atoms/tttx-button/tttx-button.stories.js +14 -14
  19. package/dist/collection/components/atoms/tttx-icon/tttx-icon.js +62 -62
  20. package/dist/collection/components/atoms/tttx-icon/tttx-icon.stories.js +22 -22
  21. package/dist/collection/components/atoms/tttx-keyvalue-block/tttx-keyvalue-block.js +109 -109
  22. package/dist/collection/components/atoms/tttx-keyvalue-block/tttx-keyvalue-block.stories.js +38 -38
  23. package/dist/collection/components/atoms/tttx-loading-spinner/tttx-loading-spinner.js +67 -67
  24. package/dist/collection/components/atoms/tttx-loading-spinner/tttx-loading-spinner.stories.js +17 -17
  25. package/dist/collection/components/molecules/tttx-dialog-box/tttx-dialog-box.css +146 -0
  26. package/dist/collection/components/molecules/tttx-dialog-box/tttx-dialog-box.js +172 -0
  27. package/dist/collection/components/molecules/tttx-dialog-box/tttx-dialog-box.stories.js +380 -0
  28. package/dist/collection/components/molecules/tttx-filter/tttx-filter.js +369 -334
  29. package/dist/collection/components/molecules/tttx-filter/tttx-filter.stories.js +73 -62
  30. package/dist/collection/components/molecules/tttx-form/lib/setErrorState.js +37 -37
  31. package/dist/collection/components/molecules/tttx-form/lib/validityCheck.js +61 -61
  32. package/dist/collection/components/molecules/tttx-form/tttx-form.js +479 -479
  33. package/dist/collection/components/molecules/tttx-form/tttx-form.stories.js +272 -272
  34. package/dist/collection/components/molecules/tttx-list/tttx-list.js +105 -105
  35. package/dist/collection/components/molecules/tttx-list/tttx-list.stories.js +43 -43
  36. package/dist/collection/components/molecules/tttx-sorter/tttx-sorter.js +224 -224
  37. package/dist/collection/components/molecules/tttx-sorter/tttx-sorter.stories.js +42 -42
  38. package/dist/collection/components/molecules/tttx-standalone-input/tttx-standalone-input.js +759 -759
  39. package/dist/collection/components/molecules/tttx-standalone-input/tttx-standalone-input.stories.js +172 -172
  40. package/dist/collection/components/molecules/tttx-toolbar/tttx-toolbar.js +44 -44
  41. package/dist/collection/components/molecules/tttx-toolbar/tttx-toolbar.stories.js +14 -14
  42. package/dist/collection/components/palette.stories.js +7 -7
  43. package/dist/collection/docs/gettingstarted-developer.stories.js +5 -5
  44. package/dist/collection/icons.js +2838 -2838
  45. package/dist/collection/index.js +1 -1
  46. package/dist/collection/shared/domsanitiser.options.js +14 -14
  47. package/dist/components/domsanitiser.options.js +15 -45
  48. package/dist/components/index.d.ts +10 -0
  49. package/dist/components/index.js +2 -5
  50. package/dist/components/tttx-button.js +1 -54
  51. package/dist/{tttx/tttx-button.entry.js → components/tttx-button2.js} +52 -26
  52. package/dist/components/tttx-dialog-box.d.ts +11 -0
  53. package/dist/components/tttx-dialog-box.js +110 -0
  54. package/dist/components/tttx-filter.js +210 -191
  55. package/dist/components/tttx-form.js +475 -475
  56. package/dist/components/tttx-icon2.js +28 -28
  57. package/dist/components/tttx-keyvalue-block.js +76 -76
  58. package/dist/components/tttx-list.js +53 -53
  59. package/dist/components/tttx-loading-spinner.js +33 -33
  60. package/dist/components/tttx-sorter.js +130 -130
  61. package/dist/components/tttx-standalone-input.js +130 -130
  62. package/dist/components/tttx-toolbar.js +26 -26
  63. package/dist/esm/{domsanitiser.options-cc420431.js → domsanitiser.options-3c7ded83.js} +12 -12
  64. package/dist/esm/{index-9cde46a5.js → index-018a3e54.js} +146 -4
  65. package/dist/esm/loader.js +4 -19
  66. package/dist/esm/polyfills/core-js.js +0 -0
  67. package/dist/esm/polyfills/css-shim.js +1 -1
  68. package/dist/esm/polyfills/dom.js +0 -0
  69. package/dist/esm/polyfills/es5-html-element.js +0 -0
  70. package/dist/esm/polyfills/index.js +0 -0
  71. package/dist/esm/polyfills/system.js +0 -0
  72. package/dist/esm/tttx-button.entry.js +24 -24
  73. package/dist/esm/tttx-dialog-box.entry.js +76 -0
  74. package/dist/esm/tttx-filter.entry.js +177 -159
  75. package/dist/esm/tttx-form.entry.js +458 -458
  76. package/dist/esm/tttx-icon.entry.js +11 -11
  77. package/dist/esm/tttx-keyvalue-block.entry.js +59 -59
  78. package/dist/esm/tttx-list.entry.js +32 -32
  79. package/dist/esm/tttx-loading-spinner.entry.js +16 -16
  80. package/dist/esm/tttx-sorter.entry.js +102 -102
  81. package/dist/esm/tttx-standalone-input.entry.js +79 -79
  82. package/dist/esm/tttx-toolbar.entry.js +10 -10
  83. package/dist/esm/tttx.js +6 -117
  84. package/dist/tttx/index.esm.js +0 -1
  85. package/dist/tttx/{p-e53c7f9d.entry.js → p-01863bf1.entry.js} +1 -1
  86. package/dist/tttx/{p-4e637d50.entry.js → p-0ed6f369.entry.js} +1 -1
  87. package/dist/tttx/p-2dd43e97.entry.js +1 -0
  88. package/dist/tttx/{p-aef96333.entry.js → p-2e135be9.entry.js} +1 -1
  89. package/dist/tttx/p-350ddb03.js +3 -0
  90. package/dist/tttx/{p-d2f1aa8e.entry.js → p-48b15a3d.entry.js} +1 -1
  91. package/dist/tttx/{p-561224f5.entry.js → p-5e91cf1c.entry.js} +1 -1
  92. package/dist/tttx/p-71c244bd.js +2 -0
  93. package/dist/tttx/{p-dc2a37b0.entry.js → p-7bba2014.entry.js} +1 -1
  94. package/dist/tttx/p-d075a2c0.entry.js +1 -0
  95. package/dist/tttx/{p-bd1edaed.entry.js → p-deec335c.entry.js} +1 -1
  96. package/dist/tttx/{p-9f1e9cc1.entry.js → p-e061910d.entry.js} +1 -1
  97. package/dist/tttx/{p-f885f17a.entry.js → p-f247a7bc.entry.js} +1 -1
  98. package/dist/tttx/tttx.esm.js +1 -129
  99. package/dist/types/components/atoms/tttx-button/tttx-button.d.ts +10 -10
  100. package/dist/types/components/atoms/tttx-button/tttx-button.stories.d.ts +10 -10
  101. package/dist/types/components/atoms/tttx-icon/tttx-icon.d.ts +5 -5
  102. package/dist/types/components/atoms/tttx-icon/tttx-icon.stories.d.ts +20 -20
  103. package/dist/types/components/atoms/tttx-keyvalue-block/tttx-keyvalue-block.d.ts +7 -7
  104. package/dist/types/components/atoms/tttx-keyvalue-block/tttx-keyvalue-block.stories.d.ts +9 -9
  105. package/dist/types/components/atoms/tttx-loading-spinner/tttx-loading-spinner.d.ts +6 -6
  106. package/dist/types/components/atoms/tttx-loading-spinner/tttx-loading-spinner.stories.d.ts +17 -17
  107. package/dist/types/components/molecules/tttx-dialog-box/interfaces.d.ts +25 -0
  108. package/dist/types/components/molecules/tttx-dialog-box/tttx-dialog-box.d.ts +18 -0
  109. package/dist/types/components/molecules/tttx-dialog-box/tttx-dialog-box.stories.d.ts +23 -0
  110. package/dist/types/components/molecules/tttx-filter/tttx-filter.d.ts +41 -39
  111. package/dist/types/components/molecules/tttx-filter/tttx-filter.stories.d.ts +70 -68
  112. package/dist/types/components/molecules/tttx-form/lib/setErrorState.d.ts +13 -13
  113. package/dist/types/components/molecules/tttx-form/lib/validityCheck.d.ts +17 -17
  114. package/dist/types/components/molecules/tttx-form/tttx-form.d.ts +133 -133
  115. package/dist/types/components/molecules/tttx-form/tttx-form.stories.d.ts +278 -278
  116. package/dist/types/components/molecules/tttx-list/tttx-list.d.ts +11 -11
  117. package/dist/types/components/molecules/tttx-list/tttx-list.stories.d.ts +14 -14
  118. package/dist/types/components/molecules/tttx-sorter/tttx-sorter.d.ts +19 -19
  119. package/dist/types/components/molecules/tttx-sorter/tttx-sorter.stories.d.ts +30 -30
  120. package/dist/types/components/molecules/tttx-standalone-input/tttx-standalone-input.d.ts +69 -69
  121. package/dist/types/components/molecules/tttx-standalone-input/tttx-standalone-input.stories.d.ts +143 -143
  122. package/dist/types/components/molecules/tttx-toolbar/tttx-toolbar.d.ts +4 -4
  123. package/dist/types/components/molecules/tttx-toolbar/tttx-toolbar.stories.d.ts +13 -13
  124. package/dist/types/components/palette.stories.d.ts +6 -6
  125. package/dist/types/components.d.ts +26 -0
  126. package/dist/types/docs/gettingstarted-developer.stories.d.ts +5 -5
  127. package/dist/types/icons.d.ts +2 -2
  128. package/dist/types/index.d.ts +1 -1
  129. package/dist/types/shared/domsanitiser.options.d.ts +10 -10
  130. package/dist/types/stencil-public-runtime.d.ts +59 -3
  131. package/loader/index.d.ts +9 -0
  132. package/package.json +2 -2
  133. package/dist/cjs/app-globals-3a1e7e63.js +0 -5
  134. package/dist/cjs/css-shim-211819bc.js +0 -6
  135. package/dist/cjs/dom-9deb26c8.js +0 -75
  136. package/dist/cjs/domsanitiser.options-3f1501b5.js +0 -1697
  137. package/dist/cjs/index-39a867c5.js +0 -3298
  138. package/dist/cjs/shadow-css-bf3843d2.js +0 -389
  139. package/dist/esm/app-globals-0f993ce5.js +0 -3
  140. package/dist/esm/css-shim-9d54a2f2.js +0 -4
  141. package/dist/esm/dom-6be6f662.js +0 -73
  142. package/dist/esm/domsanitiser.options-6f2878c8.js +0 -1694
  143. package/dist/esm/index-e3e64631.js +0 -3262
  144. package/dist/esm/shadow-css-ed4599f8.js +0 -387
  145. package/dist/tttx/app-globals-0f993ce5.js +0 -3
  146. package/dist/tttx/css-shim-9d54a2f2.js +0 -4
  147. package/dist/tttx/dom-6be6f662.js +0 -73
  148. package/dist/tttx/domsanitiser.options-6f2878c8.js +0 -1694
  149. package/dist/tttx/index-e3e64631.js +0 -3262
  150. package/dist/tttx/p-3b1be372.entry.js +0 -1
  151. package/dist/tttx/p-b4290a5b.js +0 -3
  152. package/dist/tttx/p-d0ff9ad0.entry.js +0 -1
  153. package/dist/tttx/p-db059a69.js +0 -2
  154. package/dist/tttx/shadow-css-ed4599f8.js +0 -387
  155. package/dist/tttx/tttx-filter.entry.js +0 -165
  156. package/dist/tttx/tttx-form.entry.js +0 -468
  157. package/dist/tttx/tttx-icon.entry.js +0 -17
  158. package/dist/tttx/tttx-keyvalue-block.entry.js +0 -65
  159. package/dist/tttx/tttx-list.entry.js +0 -38
  160. package/dist/tttx/tttx-loading-spinner.entry.js +0 -22
  161. package/dist/tttx/tttx-sorter.entry.js +0 -108
  162. package/dist/tttx/tttx-standalone-input.entry.js +0 -85
  163. package/dist/tttx/tttx-toolbar.entry.js +0 -16
@@ -1,70 +1,81 @@
1
- import { withActions } from '@storybook/addon-actions/decorator';
2
- export default {
3
- title: 'molecules/Filter',
4
- component: 'tttx-filter',
5
- argTypes: {
6
- filterOptions: {
7
- control: { type: 'object' }
8
- },
9
- filterButtonStyle: {
10
- table: { defaultValue: { summary: 'list filter' } },
11
- control: { type: 'select' },
12
- options: ['list filter', 'list icon', 'table icon'],
13
- },
14
- showSearchField: {
15
- table: { defaultValue: { summary: false } },
16
- control: { type: 'boolean' },
17
- },
18
- showSelectAll: {
19
- table: { defaultValue: { summary: true } },
20
- control: { type: 'boolean' },
21
- },
22
- showOptionIcons: {
23
- table: { defaultValue: { summary: true } },
24
- control: { type: 'boolean' },
25
- },
26
- filterHeader: {
27
- control: { type: 'text' },
28
- },
29
- },
30
- parameters: {
31
- actions: {
32
- handles: ['filterChangeEvent'],
33
- },
34
- },
35
- decorators: [withActions],
36
- };
37
- const filterOptions = [
38
- { optionIcon: 'cancel', optionIconColor: 'exit', optionText: 'Expired' },
39
- { optionIcon: 'warning', optionIconColor: 'orange', optionText: 'Expiring soon' },
40
- { optionIcon: 'check_circle', optionIconColor: 'green', optionText: 'Active' },
41
- ];
42
- const ExampleFilter = args => {
43
- const filterHeader = args.filterHeader || 'Qualification status';
44
- const jsonFilterOptions = args.filterOptions ? JSON.stringify(args.filterOptions) : undefined;
1
+ import { withActions } from '@storybook/addon-actions/decorator';
2
+ export default {
3
+ title: 'molecules/Filter',
4
+ component: 'tttx-filter',
5
+ argTypes: {
6
+ filterOptions: {
7
+ control: { type: 'object' }
8
+ },
9
+ filterButtonStyle: {
10
+ table: { defaultValue: { summary: 'list filter' } },
11
+ control: { type: 'select' },
12
+ options: ['list filter', 'list icon', 'table icon'],
13
+ },
14
+ showSearchField: {
15
+ table: { defaultValue: { summary: false } },
16
+ control: { type: 'boolean' },
17
+ },
18
+ showSelectAll: {
19
+ table: { defaultValue: { summary: true } },
20
+ control: { type: 'boolean' },
21
+ },
22
+ showOptionIcons: {
23
+ table: { defaultValue: { summary: true } },
24
+ control: { type: 'boolean' },
25
+ },
26
+ filterHeader: {
27
+ control: { type: 'text' },
28
+ },
29
+ },
30
+ parameters: {
31
+ actions: {
32
+ handles: ['filterChangeEvent'],
33
+ },
34
+ },
35
+ decorators: [withActions],
36
+ };
37
+ const filterOptions = [
38
+ { optionIcon: 'cancel', optionIconColor: 'exit', optionText: 'Expired' },
39
+ { optionIcon: 'warning', optionIconColor: 'orange', optionText: 'Expiring soon' },
40
+ { optionIcon: 'check_circle', optionIconColor: 'green', optionText: 'Active' },
41
+ ];
42
+ const ExampleFilter = args => {
43
+ const filterHeader = args.filterHeader || 'Qualification status';
44
+ const jsonFilterOptions = args.filterOptions ? JSON.stringify(args.filterOptions) : undefined;
45
45
  return `<tttx-filter
46
46
  ${jsonFilterOptions ? 'filter-options=\'' + jsonFilterOptions + '\'' : ''}
47
47
  ${args.showSearchField ? 'show-search-field=\'' + args.showSearchField + '\'' : ''}
48
48
  ${args.showSelectAll ? 'show-select-all=\'' + args.showSelectAll + '\'' : ''}
49
49
  ${args.filterButtonStyle ? 'filter-button-style=\'' + args.filterButtonStyle + '\'' : ''}
50
50
  ${args.showOptionIcons ? 'show-option-icons=\'' + args.showOptionIcons + '\'' : ''}
51
+ ${args.defaultFilterOptions ? 'default-filter-options=\'' + args.defaultFilterOptions + '\'' : ''}
51
52
  filter-header='${filterHeader}'
52
53
  filter-key='basic-filter'
53
- ></tttx-filter>`;
54
- };
55
- export const Default = ExampleFilter.bind({});
56
- export const CustomFilterOptions = ExampleFilter.bind({});
57
- CustomFilterOptions.args = {
58
- filterOptions
59
- };
60
- export const ListFilterWithoutSearchField = ExampleFilter.bind({});
61
- ListFilterWithoutSearchField.args = {
62
- filterOptions,
63
- showSearchField: false
64
- };
65
- export const TableIconWithoutOptionIconsOrSelectAll = ExampleFilter.bind({});
66
- TableIconWithoutOptionIconsOrSelectAll.args = {
67
- filterOptions,
68
- showOptionIcons: false,
69
- showSelectAll: false
70
- };
54
+ ></tttx-filter>`;
55
+ };
56
+ export const Default = ExampleFilter.bind({});
57
+ export const CustomFilterOptions = ExampleFilter.bind({});
58
+ CustomFilterOptions.args = {
59
+ filterOptions
60
+ };
61
+ export const DefaultFilterOptions = ExampleFilter.bind({});
62
+ DefaultFilterOptions.args = {
63
+ filterOptions,
64
+ defaultFilterOptions: JSON.stringify(['Active'])
65
+ };
66
+ export const EverythingDefaultFilterOptions = ExampleFilter.bind({});
67
+ EverythingDefaultFilterOptions.args = {
68
+ filterOptions,
69
+ defaultFilterOptions: JSON.stringify(['Active', 'Expiring soon', 'Expired'])
70
+ };
71
+ export const ListFilterWithoutSearchField = ExampleFilter.bind({});
72
+ ListFilterWithoutSearchField.args = {
73
+ filterOptions,
74
+ showSearchField: false
75
+ };
76
+ export const TableIconWithoutOptionIconsOrSelectAll = ExampleFilter.bind({});
77
+ TableIconWithoutOptionIconsOrSelectAll.args = {
78
+ filterOptions,
79
+ showOptionIcons: false,
80
+ showSelectAll: false
81
+ };
@@ -1,37 +1,37 @@
1
- /**
2
- * Sets the error state of an input field by updating its class and error message.
3
- * If an error was detected, it sets the input field's class to "invalid" and
4
- * displays the error message in an error bubble. If no error was detected,
5
- * it removes the "invalid" class from the input field and clears the error bubble.
6
- *
7
- * @param {HTMLInputElement} target - The input field to update.
8
- * @param {boolean} hasError - Whether an error was detected in the field.
9
- * @param {string} errorMessage - The error message to display (if any).
10
- * @return {void}
11
- */
12
- function setErrorState(target, hasError, errorMessage) {
13
- // Find the error bubble element for the input field
14
- const errorBubble = target.parentElement.querySelector('.errorBubble');
15
- // If an error was detected, set the input field's class to "invalid" and display the error message in the error bubble
16
- if (hasError) {
17
- target.classList.add('invalid');
18
- errorBubble.classList.add('visible');
19
- const errorIcon = document.createElement('span');
20
- // Set the class of the error icon to a pre-defined CSS class that specifies the icon's appearance
21
- errorIcon.className = 'material-symbols-rounded';
22
- // Set the text content of the error icon to the word "warning"
23
- errorIcon.textContent = 'warning';
24
- // errorBubble.replaceChildren cannot be used here because the tests don't support this new feature :(
25
- errorBubble.innerHTML = '';
26
- errorBubble.append(errorIcon);
27
- errorBubble.append(errorMessage);
28
- // errorBubble.replaceChildren(errorIcon, errorMessage);
29
- }
30
- // If no error was detected, remove the "invalid" class from the input field and clear the error bubble
31
- else {
32
- errorBubble.classList.remove('visible');
33
- target.classList.remove('invalid');
34
- errorBubble.innerHTML = '';
35
- }
36
- }
37
- export default setErrorState;
1
+ /**
2
+ * Sets the error state of an input field by updating its class and error message.
3
+ * If an error was detected, it sets the input field's class to "invalid" and
4
+ * displays the error message in an error bubble. If no error was detected,
5
+ * it removes the "invalid" class from the input field and clears the error bubble.
6
+ *
7
+ * @param {HTMLInputElement} target - The input field to update.
8
+ * @param {boolean} hasError - Whether an error was detected in the field.
9
+ * @param {string} errorMessage - The error message to display (if any).
10
+ * @return {void}
11
+ */
12
+ function setErrorState(target, hasError, errorMessage) {
13
+ // Find the error bubble element for the input field
14
+ const errorBubble = target.parentElement.querySelector('.errorBubble');
15
+ // If an error was detected, set the input field's class to "invalid" and display the error message in the error bubble
16
+ if (hasError) {
17
+ target.classList.add('invalid');
18
+ errorBubble.classList.add('visible');
19
+ const errorIcon = document.createElement('span');
20
+ // Set the class of the error icon to a pre-defined CSS class that specifies the icon's appearance
21
+ errorIcon.className = 'material-symbols-rounded';
22
+ // Set the text content of the error icon to the word "warning"
23
+ errorIcon.textContent = 'warning';
24
+ // errorBubble.replaceChildren cannot be used here because the tests don't support this new feature :(
25
+ errorBubble.innerHTML = '';
26
+ errorBubble.append(errorIcon);
27
+ errorBubble.append(errorMessage);
28
+ // errorBubble.replaceChildren(errorIcon, errorMessage);
29
+ }
30
+ // If no error was detected, remove the "invalid" class from the input field and clear the error bubble
31
+ else {
32
+ errorBubble.classList.remove('visible');
33
+ target.classList.remove('invalid');
34
+ errorBubble.innerHTML = '';
35
+ }
36
+ }
37
+ export default setErrorState;
@@ -1,61 +1,61 @@
1
- /**
2
- * Validates the input field on focusout event by checking its validity state,
3
- * sets an error message if there's an issue, and emits a "dataChanged" event to
4
- * the parent component with the field name and its new value.
5
- *
6
- * @param {Event} event - The focusout event triggered by the input field.
7
- * @return {void}
8
- */
9
- function validityCheck(event) {
10
- var _a, _b, _c, _d;
11
- event.preventDefault();
12
- const target = event.target;
13
- let hasError = true;
14
- let errorMessage = '';
15
- // validity object on HTML5 inputs has the following options
16
- // badInput
17
- // customError
18
- // patternMismatch
19
- // rangeOverflow
20
- // rangeUnderflow
21
- // stepMismatch
22
- // tooLong
23
- // tooShort
24
- // typeMismatch
25
- // valid
26
- // valueMissing
27
- // customErrors can be set with
28
- // target.setCustomValidity('custom error!');
29
- // and cleared with
30
- // target.setCustomValidity('');
31
- // Check the validity of the input field and set an error message if needed
32
- switch (true) {
33
- // The field is required, but has no value
34
- case target.validity.valueMissing:
35
- errorMessage = (_a = target.dataset.required) !== null && _a !== void 0 ? _a : 'This field is required';
36
- break;
37
- // The field's value does not match the expected pattern
38
- case target.validity.patternMismatch:
39
- errorMessage = (_b = target.dataset.pattern) !== null && _b !== void 0 ? _b : 'Incorrect format';
40
- break;
41
- // The field's value is not of the correct input type
42
- case target.validity.badInput:
43
- // IE string in a number field
44
- errorMessage = (_c = target.dataset.badinput) !== null && _c !== void 0 ? _c : 'Wrong input type';
45
- break;
46
- // The field's value is above or below the range set in the "min" and "max" attributes
47
- case target.validity.rangeOverflow || target.validity.rangeUnderflow:
48
- // IE date or number is above or below value set in min or max tags
49
- errorMessage = (_d = target.dataset.range) !== null && _d !== void 0 ? _d : 'Invalid value';
50
- break;
51
- case target.validity.customError:
52
- errorMessage = target.validationMessage;
53
- break;
54
- // No error detected
55
- default:
56
- hasError = false;
57
- }
58
- // Return the error state
59
- return { target, hasError, errorMessage };
60
- }
61
- export default validityCheck;
1
+ /**
2
+ * Validates the input field on focusout event by checking its validity state,
3
+ * sets an error message if there's an issue, and emits a "dataChanged" event to
4
+ * the parent component with the field name and its new value.
5
+ *
6
+ * @param {Event} event - The focusout event triggered by the input field.
7
+ * @return {void}
8
+ */
9
+ function validityCheck(event) {
10
+ var _a, _b, _c, _d;
11
+ event.preventDefault();
12
+ const target = event.target;
13
+ let hasError = true;
14
+ let errorMessage = '';
15
+ // validity object on HTML5 inputs has the following options
16
+ // badInput
17
+ // customError
18
+ // patternMismatch
19
+ // rangeOverflow
20
+ // rangeUnderflow
21
+ // stepMismatch
22
+ // tooLong
23
+ // tooShort
24
+ // typeMismatch
25
+ // valid
26
+ // valueMissing
27
+ // customErrors can be set with
28
+ // target.setCustomValidity('custom error!');
29
+ // and cleared with
30
+ // target.setCustomValidity('');
31
+ // Check the validity of the input field and set an error message if needed
32
+ switch (true) {
33
+ // The field is required, but has no value
34
+ case target.validity.valueMissing:
35
+ errorMessage = (_a = target.dataset.required) !== null && _a !== void 0 ? _a : 'This field is required';
36
+ break;
37
+ // The field's value does not match the expected pattern
38
+ case target.validity.patternMismatch:
39
+ errorMessage = (_b = target.dataset.pattern) !== null && _b !== void 0 ? _b : 'Incorrect format';
40
+ break;
41
+ // The field's value is not of the correct input type
42
+ case target.validity.badInput:
43
+ // IE string in a number field
44
+ errorMessage = (_c = target.dataset.badinput) !== null && _c !== void 0 ? _c : 'Wrong input type';
45
+ break;
46
+ // The field's value is above or below the range set in the "min" and "max" attributes
47
+ case target.validity.rangeOverflow || target.validity.rangeUnderflow:
48
+ // IE date or number is above or below value set in min or max tags
49
+ errorMessage = (_d = target.dataset.range) !== null && _d !== void 0 ? _d : 'Invalid value';
50
+ break;
51
+ case target.validity.customError:
52
+ errorMessage = target.validationMessage;
53
+ break;
54
+ // No error detected
55
+ default:
56
+ hasError = false;
57
+ }
58
+ // Return the error state
59
+ return { target, hasError, errorMessage };
60
+ }
61
+ export default validityCheck;