@wavemaker/app-ng-runtime 11.14.2-rc.6311 → 11.15.0-1.246

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 (177) hide show
  1. package/build-task/bundles/index.umd.js +13 -2
  2. package/build-task/esm2022/input/default/checkbox/checkbox.build.mjs +9 -2
  3. package/build-task/esm2022/input/default/radioset/radioset.build.mjs +6 -2
  4. package/build-task/fesm2022/index.mjs +13 -2
  5. package/build-task/fesm2022/index.mjs.map +1 -1
  6. package/components/base/bundles/index.umd.js +271 -128
  7. package/components/base/esm2022/public_api.mjs +2 -2
  8. package/components/base/esm2022/utils/autolayout-utils.mjs +252 -0
  9. package/components/base/esm2022/utils/live-utils.mjs +10 -7
  10. package/components/base/esm2022/utils/widget-utils.mjs +8 -1
  11. package/components/base/esm2022/widgets/common/base/base.component.mjs +7 -8
  12. package/components/base/esm2022/widgets/common/base/partial-container.directive.mjs +4 -1
  13. package/components/base/esm2022/widgets/common/container/container.directive.mjs +28 -150
  14. package/components/base/esm2022/widgets/common/container/container.props.mjs +6 -2
  15. package/components/base/fesm2022/index.mjs +273 -129
  16. package/components/base/fesm2022/index.mjs.map +1 -1
  17. package/components/base/public_api.d.ts +1 -1
  18. package/components/base/utils/autolayout-utils.d.ts +29 -0
  19. package/components/base/utils/widget-utils.d.ts +1 -0
  20. package/components/base/widgets/common/container/container.directive.d.ts +7 -9
  21. package/components/basic/label/bundles/index.umd.js +4 -0
  22. package/components/basic/label/esm2022/label.directive.mjs +5 -1
  23. package/components/basic/label/fesm2022/index.mjs +4 -0
  24. package/components/basic/label/fesm2022/index.mjs.map +1 -1
  25. package/components/basic/search/bundles/index.umd.js +13 -11
  26. package/components/basic/search/esm2022/search.component.mjs +14 -12
  27. package/components/basic/search/fesm2022/index.mjs +13 -11
  28. package/components/basic/search/fesm2022/index.mjs.map +1 -1
  29. package/components/chart/bundles/index.umd.js +2 -2
  30. package/components/chart/esm2022/chart.utils.mjs +3 -3
  31. package/components/chart/fesm2022/index.mjs +2 -2
  32. package/components/chart/fesm2022/index.mjs.map +1 -1
  33. package/components/containers/accordion/accordion-pane/accordion-pane.component.d.ts +2 -0
  34. package/components/containers/accordion/accordion.directive.d.ts +4 -0
  35. package/components/containers/accordion/bundles/index.umd.js +34 -0
  36. package/components/containers/accordion/esm2022/accordion-pane/accordion-pane.component.mjs +6 -2
  37. package/components/containers/accordion/esm2022/accordion.directive.mjs +32 -2
  38. package/components/containers/accordion/fesm2022/index.mjs +36 -2
  39. package/components/containers/accordion/fesm2022/index.mjs.map +1 -1
  40. package/components/containers/tabs/bundles/index.umd.js +34 -0
  41. package/components/containers/tabs/esm2022/tab-pane/tab-pane.component.mjs +6 -2
  42. package/components/containers/tabs/esm2022/tabs.component.mjs +33 -4
  43. package/components/containers/tabs/fesm2022/index.mjs +36 -2
  44. package/components/containers/tabs/fesm2022/index.mjs.map +1 -1
  45. package/components/containers/tabs/tab-pane/tab-pane.component.d.ts +2 -0
  46. package/components/containers/tabs/tabs.component.d.ts +5 -1
  47. package/components/containers/wizard/bundles/index.umd.js +46 -2
  48. package/components/containers/wizard/esm2022/wizard-step/wizard-step.component.mjs +8 -2
  49. package/components/containers/wizard/esm2022/wizard.component.mjs +42 -4
  50. package/components/containers/wizard/fesm2022/index.mjs +48 -4
  51. package/components/containers/wizard/fesm2022/index.mjs.map +1 -1
  52. package/components/containers/wizard/wizard-step/wizard-step.component.d.ts +4 -0
  53. package/components/containers/wizard/wizard.component.d.ts +1 -0
  54. package/components/data/form/bundles/index.umd.js +28 -1
  55. package/components/data/form/esm2022/form-field/form-field.directive.mjs +4 -1
  56. package/components/data/form/esm2022/form.component.mjs +24 -2
  57. package/components/data/form/esm2022/form.props.mjs +3 -2
  58. package/components/data/form/esm2022/live-filter/live-filter.directive.mjs +2 -1
  59. package/components/data/form/fesm2022/index.mjs +29 -2
  60. package/components/data/form/fesm2022/index.mjs.map +1 -1
  61. package/components/data/form/form.component.d.ts +3 -0
  62. package/components/data/list/bundles/index.umd.js +0 -9
  63. package/components/data/list/esm2022/list-item.directive.mjs +1 -10
  64. package/components/data/list/fesm2022/index.mjs +0 -9
  65. package/components/data/list/fesm2022/index.mjs.map +1 -1
  66. package/components/data/pagination/bundles/index.umd.js +6 -2
  67. package/components/data/pagination/esm2022/pagination.component.mjs +7 -3
  68. package/components/data/pagination/fesm2022/index.mjs +6 -2
  69. package/components/data/pagination/fesm2022/index.mjs.map +1 -1
  70. package/components/data/table/bundles/index.umd.js +21 -4
  71. package/components/data/table/esm2022/table.component.mjs +22 -5
  72. package/components/data/table/fesm2022/index.mjs +21 -4
  73. package/components/data/table/fesm2022/index.mjs.map +1 -1
  74. package/components/dialogs/alert-dialog/alert-dialog.component.d.ts +6 -2
  75. package/components/dialogs/alert-dialog/bundles/index.umd.js +18 -8
  76. package/components/dialogs/alert-dialog/esm2022/alert-dialog.component.mjs +17 -7
  77. package/components/dialogs/alert-dialog/fesm2022/index.mjs +15 -5
  78. package/components/dialogs/alert-dialog/fesm2022/index.mjs.map +1 -1
  79. package/components/input/checkbox/bundles/index.umd.js +12 -3
  80. package/components/input/checkbox/checkbox.component.d.ts +2 -0
  81. package/components/input/checkbox/esm2022/checkbox.component.mjs +9 -3
  82. package/components/input/checkbox/esm2022/checkbox.props.mjs +5 -2
  83. package/components/input/checkbox/fesm2022/index.mjs +12 -3
  84. package/components/input/checkbox/fesm2022/index.mjs.map +1 -1
  85. package/components/input/checkboxset/bundles/index.umd.js +12 -1
  86. package/components/input/checkboxset/checkboxset.component.d.ts +1 -0
  87. package/components/input/checkboxset/esm2022/checkboxset.component.mjs +11 -1
  88. package/components/input/checkboxset/esm2022/checkboxset.props.mjs +3 -2
  89. package/components/input/checkboxset/fesm2022/index.mjs +12 -1
  90. package/components/input/checkboxset/fesm2022/index.mjs.map +1 -1
  91. package/components/input/epoch/base-date-time/base-date-time.component.d.ts +0 -1
  92. package/components/input/epoch/base-date-time/bundles/index.umd.js +29 -27
  93. package/components/input/epoch/base-date-time/esm2022/base-date-time.component.mjs +30 -28
  94. package/components/input/epoch/base-date-time/fesm2022/index.mjs +29 -27
  95. package/components/input/epoch/base-date-time/fesm2022/index.mjs.map +1 -1
  96. package/components/input/epoch/date/bundles/index.umd.js +4 -3
  97. package/components/input/epoch/date/esm2022/date.component.mjs +5 -4
  98. package/components/input/epoch/date/fesm2022/index.mjs +4 -3
  99. package/components/input/epoch/date/fesm2022/index.mjs.map +1 -1
  100. package/components/input/epoch/date-time/bundles/index.umd.js +5 -4
  101. package/components/input/epoch/date-time/esm2022/date-time.component.mjs +7 -6
  102. package/components/input/epoch/date-time/fesm2022/index.mjs +6 -5
  103. package/components/input/epoch/date-time/fesm2022/index.mjs.map +1 -1
  104. package/components/input/file-upload/bundles/index.umd.js +1 -1
  105. package/components/input/file-upload/esm2022/file-upload.props.mjs +2 -2
  106. package/components/input/file-upload/fesm2022/index.mjs +1 -1
  107. package/components/input/file-upload/fesm2022/index.mjs.map +1 -1
  108. package/components/input/radioset/bundles/index.umd.js +13 -1
  109. package/components/input/radioset/esm2022/radioset.component.mjs +11 -1
  110. package/components/input/radioset/esm2022/radioset.props.mjs +4 -2
  111. package/components/input/radioset/fesm2022/index.mjs +13 -1
  112. package/components/input/radioset/fesm2022/index.mjs.map +1 -1
  113. package/components/input/radioset/radioset.component.d.ts +1 -0
  114. package/components/input/slider/bundles/index.umd.js +86 -16
  115. package/components/input/slider/esm2022/slider.component.mjs +76 -9
  116. package/components/input/slider/esm2022/slider.props.mjs +5 -1
  117. package/components/input/slider/fesm2022/index.mjs +79 -8
  118. package/components/input/slider/fesm2022/index.mjs.map +1 -1
  119. package/components/input/slider/slider.component.d.ts +12 -3
  120. package/components/input/text/bundles/index.umd.js +24 -3
  121. package/components/input/text/esm2022/input-text/input-text.component.mjs +6 -3
  122. package/components/input/text/esm2022/input-text/input-text.props.mjs +5 -2
  123. package/components/input/text/esm2022/number-locale/number-locale.mjs +16 -1
  124. package/components/input/text/fesm2022/index.mjs +24 -3
  125. package/components/input/text/fesm2022/index.mjs.map +1 -1
  126. package/components/input/text/input-text/input-text.component.d.ts +4 -0
  127. package/components/input/text/number-locale/number-locale.d.ts +12 -0
  128. package/components/navigation/breadcrumb/bundles/index.umd.js +2 -2
  129. package/components/navigation/breadcrumb/esm2022/breadcrumb.component.mjs +3 -3
  130. package/components/navigation/breadcrumb/fesm2022/index.mjs +2 -2
  131. package/components/navigation/breadcrumb/fesm2022/index.mjs.map +1 -1
  132. package/components/navigation/popover/bundles/index.umd.js +12 -0
  133. package/components/navigation/popover/esm2022/popover.component.mjs +13 -1
  134. package/components/navigation/popover/fesm2022/index.mjs +12 -0
  135. package/components/navigation/popover/fesm2022/index.mjs.map +1 -1
  136. package/components/navigation/popover/popover.component.d.ts +2 -0
  137. package/components/page/default/bundles/index.umd.js +0 -4
  138. package/components/page/default/esm2022/router-outlet.directive.mjs +1 -5
  139. package/components/page/default/fesm2022/index.mjs +0 -4
  140. package/components/page/default/fesm2022/index.mjs.map +1 -1
  141. package/components/page/header/bundles/index.umd.js +4 -3
  142. package/components/page/header/esm2022/header.component.mjs +5 -4
  143. package/components/page/header/fesm2022/index.mjs +4 -3
  144. package/components/page/header/fesm2022/index.mjs.map +1 -1
  145. package/components/page/header/header.component.d.ts +2 -1
  146. package/core/bundles/index.umd.js +90 -6
  147. package/core/enums/enums.d.ts +1 -0
  148. package/core/esm2022/enums/enums.mjs +2 -1
  149. package/core/esm2022/utils/build-utils.mjs +5 -1
  150. package/core/esm2022/utils/utils.mjs +5 -2
  151. package/core/esm2022/utils/watcher.mjs +83 -4
  152. package/core/fesm2022/index.mjs +91 -4
  153. package/core/fesm2022/index.mjs.map +1 -1
  154. package/core/utils/watcher.d.ts +2 -0
  155. package/npm-shrinkwrap.json +2 -2
  156. package/oAuth/esm2022/oAuth.service.mjs +1 -1
  157. package/oAuth/fesm2022/index.mjs.map +1 -1
  158. package/oAuth/oAuth.service.d.ts +1 -1
  159. package/package-lock.json +2 -2
  160. package/package.json +1 -1
  161. package/runtime/base/bundles/index.umd.js +33 -31
  162. package/runtime/base/components/base-prefab.component.d.ts +6 -4
  163. package/runtime/base/esm2022/components/app-component/app.component.mjs +1 -1
  164. package/runtime/base/esm2022/components/base-page.component.mjs +2 -5
  165. package/runtime/base/esm2022/components/base-partial.component.mjs +2 -2
  166. package/runtime/base/esm2022/components/base-prefab.component.mjs +20 -12
  167. package/runtime/base/esm2022/components/base-spa-page.component.mjs +1 -4
  168. package/runtime/base/esm2022/services/http-interceptor.services.mjs +14 -13
  169. package/runtime/base/fesm2022/index.mjs +34 -31
  170. package/runtime/base/fesm2022/index.mjs.map +1 -1
  171. package/runtime/base/runtime-base.module.d.ts +2 -1
  172. package/runtime/dynamic/app/app.config.d.ts +1 -1
  173. package/runtime/dynamic/bundles/index.umd.js +1 -1
  174. package/runtime/dynamic/esm2022/app/app.config.mjs +7 -7
  175. package/runtime/dynamic/fesm2022/index.mjs +2 -2
  176. package/runtime/dynamic/fesm2022/index.mjs.map +1 -1
  177. package/scripts/datatable/datatable.js +17 -15
@@ -0,0 +1,252 @@
1
+ export class AutoLayoutUtils {
2
+ constructor() {
3
+ this.direction = 'row';
4
+ this.hasWrap = false;
5
+ this.alignment = 'top-left';
6
+ // Alignment matrix
7
+ this.alignmentMatrix = {
8
+ 'top-left': { justifyContent: 'flex-start', alignItems: 'flex-start' },
9
+ 'top-center': { justifyContent: 'center', alignItems: 'flex-start' },
10
+ 'top-right': { justifyContent: 'flex-end', alignItems: 'flex-start' },
11
+ 'middle-left': { justifyContent: 'flex-start', alignItems: 'center' },
12
+ 'middle-center': { justifyContent: 'center', alignItems: 'center' },
13
+ 'middle-right': { justifyContent: 'flex-end', alignItems: 'center' },
14
+ 'bottom-left': { justifyContent: 'flex-start', alignItems: 'flex-end' },
15
+ 'bottom-center': { justifyContent: 'center', alignItems: 'flex-end' },
16
+ 'bottom-right': { justifyContent: 'flex-end', alignItems: 'flex-end' },
17
+ 'start': { justifyContent: 'space-between', alignItems: 'flex-start' },
18
+ 'center': { justifyContent: 'space-between', alignItems: 'center' },
19
+ 'end': { justifyContent: 'space-between', alignItems: 'flex-end' }
20
+ };
21
+ }
22
+ /** Apply direction (row/column) */
23
+ applyDirection(direction) {
24
+ this.direction = direction;
25
+ if (direction === 'column')
26
+ this.hasWrap = false;
27
+ this.$element.css({ display: 'flex', flexDirection: direction });
28
+ this.applyAlignment(this.alignment);
29
+ }
30
+ /** Apply wrapping */
31
+ applyWrap(wrap) {
32
+ this.hasWrap = wrap;
33
+ this.$element.css('flex-wrap', wrap ? 'wrap' : 'nowrap');
34
+ }
35
+ /** Apply alignment based on direction */
36
+ applyAlignment(alignmentKey) {
37
+ if (!alignmentKey)
38
+ return;
39
+ const base = this.alignmentMatrix[alignmentKey];
40
+ if (!base)
41
+ return;
42
+ const isRow = this.direction === 'row';
43
+ let justifyContent = isRow ? base.justifyContent : base.alignItems;
44
+ let alignItems = isRow ? base.alignItems : base.justifyContent;
45
+ this.$element.css({
46
+ display: 'flex',
47
+ 'flex-wrap': this.hasWrap ? 'wrap' : 'nowrap',
48
+ justifyContent,
49
+ alignItems
50
+ });
51
+ }
52
+ /** Apply spacing for gap + column gap */
53
+ applySpacing(key, nv) {
54
+ const base = this.alignmentMatrix[this.alignment];
55
+ if (!base)
56
+ return;
57
+ const gapValue = key === 'gap' ? nv : this.gap;
58
+ const colValue = key === 'columngap' ? nv : this.columngap;
59
+ const isRow = this.direction === 'row';
60
+ const gapVal = (gapValue && gapValue !== 'auto') ? gapValue : null;
61
+ const colVal = (colValue && colValue !== 'auto') ? colValue : null;
62
+ const rowVal = this.hasWrap && gapVal ? gapVal : null;
63
+ let justifyContent = isRow ? base.justifyContent : base.alignItems;
64
+ let alignItems = isRow ? base.alignItems : base.justifyContent;
65
+ // ————— NO WRAP —————
66
+ if (!this.hasWrap) {
67
+ if (gapValue === 'auto') {
68
+ this.$element.css({
69
+ 'justify-content': base.justifyContent,
70
+ 'align-items': base.alignItems
71
+ });
72
+ }
73
+ else {
74
+ this.$element.css({
75
+ 'justify-content': justifyContent,
76
+ 'align-items': alignItems,
77
+ gap: `${gapVal}px`
78
+ });
79
+ }
80
+ }
81
+ // ————— WRAP LOGIC —————
82
+ else {
83
+ if (gapValue === 'auto' && colValue === 'auto') {
84
+ this.$element.css({
85
+ 'justify-content': justifyContent,
86
+ 'align-content': justifyContent
87
+ });
88
+ }
89
+ else if (gapValue !== 'auto' && colValue === 'auto') {
90
+ this.$element.css({
91
+ 'justify-content': justifyContent,
92
+ 'align-content': alignItems,
93
+ 'row-gap': `${rowVal}px`
94
+ });
95
+ }
96
+ else if (gapValue === 'auto' && colValue !== 'auto') {
97
+ this.$element.css({
98
+ 'align-content': 'space-between',
99
+ 'column-gap': `${colVal}px`
100
+ });
101
+ }
102
+ else {
103
+ if (colVal && rowVal) {
104
+ if (colVal === rowVal) {
105
+ this.$element.css({
106
+ 'gap': `${colVal}px`,
107
+ 'align-content': alignItems,
108
+ 'justify-content': justifyContent
109
+ });
110
+ }
111
+ else {
112
+ this.$element.css({
113
+ 'gap': `${rowVal}px ${colVal}px`,
114
+ 'align-content': alignItems,
115
+ 'justify-content': justifyContent
116
+ });
117
+ }
118
+ }
119
+ }
120
+ }
121
+ this.gap = gapValue?.toString();
122
+ this.columngap = colValue?.toString();
123
+ }
124
+ onPropertyChange(key, nv, ov) {
125
+ switch (key) {
126
+ case 'direction':
127
+ this.applyDirection(nv);
128
+ break;
129
+ case 'wrap':
130
+ this.applyWrap(nv);
131
+ break;
132
+ case 'alignment':
133
+ this.alignment = nv;
134
+ this.applyAlignment(nv);
135
+ break;
136
+ case 'gap':
137
+ case 'columngap':
138
+ setTimeout(() => {
139
+ this.applySpacing(key, nv);
140
+ });
141
+ break;
142
+ case 'position':
143
+ this.position = nv;
144
+ this.handlePosition();
145
+ break;
146
+ case 'clipcontent':
147
+ this.clipContent = nv;
148
+ this.handleClipBehaviour();
149
+ break;
150
+ }
151
+ }
152
+ applyStyleChange(key, nv) {
153
+ if (key === 'width' || key === 'height') {
154
+ this.applySize(key, nv);
155
+ }
156
+ else if (key === 'padding') {
157
+ this.$element.css('padding', nv);
158
+ }
159
+ else if (key === 'overflow') {
160
+ this.overflowtype = nv;
161
+ this.handleClipBehaviour();
162
+ }
163
+ else if (key === 'zindex') {
164
+ this.zIndex = nv;
165
+ this.handlePosition();
166
+ }
167
+ }
168
+ applySize(key, nv) {
169
+ if (nv === 'fill') {
170
+ if (key === 'width') {
171
+ this.$element.css('width', '100%');
172
+ }
173
+ if (key === 'height') {
174
+ if (this.parentElement?.hasAttribute('wmcontainer') || this.parentElement.hasAttribute('wmautolayout')) {
175
+ this.$element.css({
176
+ 'align-self': 'stretch',
177
+ 'flex-grow': '1'
178
+ });
179
+ }
180
+ else {
181
+ this.$element.css('height', '100%');
182
+ }
183
+ }
184
+ }
185
+ else if (nv === 'hug') {
186
+ if (key === 'width') {
187
+ this.$element.css('width', 'fit-content');
188
+ }
189
+ if (key === 'height') {
190
+ this.$element.css('height', 'fit-content');
191
+ }
192
+ }
193
+ else {
194
+ this.$element.css('flex-shrink', '0'); // Don't shrink when size is fixed
195
+ }
196
+ }
197
+ // Determine whether the container should clip its content and configure scrolling behaviour accordingly.
198
+ handleClipBehaviour() {
199
+ const overflow = this.overflowtype?.toLowerCase();
200
+ switch (overflow) {
201
+ case 'vertical':
202
+ this.$element.css({
203
+ 'overflow-x': 'hidden',
204
+ 'overflow-y': 'scroll'
205
+ });
206
+ break;
207
+ case 'horizontal':
208
+ this.$element.css({
209
+ 'overflow-x': 'scroll',
210
+ 'overflow-y': 'hidden'
211
+ });
212
+ break;
213
+ case 'both directions':
214
+ this.$element.css({
215
+ 'overflow': 'scroll'
216
+ });
217
+ break;
218
+ case 'no scrolling':
219
+ if (this.clipContent) {
220
+ this.$element.css({ 'overflow': 'hidden' });
221
+ }
222
+ else {
223
+ this.$element.css({ 'overflow': '' });
224
+ }
225
+ break;
226
+ default:
227
+ break;
228
+ }
229
+ }
230
+ // Toggle and apply positional behaviour and expose the z-index control when position is not relative.
231
+ handlePosition() {
232
+ if (this.position === 'sticky') {
233
+ // Apply sticky styles
234
+ this.$element.css({
235
+ 'position': 'sticky',
236
+ 'top': '0', // Sticks to top when scrolling vertically
237
+ 'left': '0', // Sticks to left when scrolling horizontally
238
+ 'z-index': this.zIndex
239
+ });
240
+ }
241
+ else {
242
+ // Reset to default (static/relative behavior)
243
+ this.$element.css({
244
+ 'position': '',
245
+ 'top': '',
246
+ 'left': '',
247
+ 'z-index': ''
248
+ });
249
+ }
250
+ }
251
+ }
252
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autolayout-utils.js","sourceRoot":"","sources":["../../../../../projects/components/base/src/utils/autolayout-utils.ts"],"names":[],"mappings":"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","sourcesContent":["export class AutoLayoutUtils {\n\n    direction: 'row' | 'column' = 'row';\n    hasWrap = false;\n    alignment: string = 'top-left';\n    gap: string;\n    columngap: string;\n    clipContent: string;\n    position: string;\n    overflowtype: string;\n    zIndex: string;\n\n    protected nativeElement!: HTMLElement;\n    protected $element!: any;\n    protected parentElement!: HTMLElement | null;\n\n\n    // Alignment matrix\n    private readonly alignmentMatrix = {\n        'top-left': { justifyContent: 'flex-start', alignItems: 'flex-start' },\n        'top-center': { justifyContent: 'center', alignItems: 'flex-start' },\n        'top-right': { justifyContent: 'flex-end', alignItems: 'flex-start' },\n\n        'middle-left': { justifyContent: 'flex-start', alignItems: 'center' },\n        'middle-center': { justifyContent: 'center', alignItems: 'center' },\n        'middle-right': { justifyContent: 'flex-end', alignItems: 'center' },\n\n        'bottom-left': { justifyContent: 'flex-start', alignItems: 'flex-end' },\n        'bottom-center': { justifyContent: 'center', alignItems: 'flex-end' },\n        'bottom-right': { justifyContent: 'flex-end', alignItems: 'flex-end' },\n\n        'start': { justifyContent: 'space-between', alignItems: 'flex-start' },\n        'center': { justifyContent: 'space-between', alignItems: 'center' },\n        'end': { justifyContent: 'space-between', alignItems: 'flex-end' }\n    };\n\n    constructor() { }\n\n    /** Apply direction (row/column) */\n    applyDirection(direction: 'row' | 'column') {\n        this.direction = direction;\n        if (direction === 'column') this.hasWrap = false;\n\n        this.$element.css({ display: 'flex', flexDirection: direction });\n        this.applyAlignment(this.alignment);\n    }\n\n    /** Apply wrapping */\n    applyWrap(wrap: boolean) {\n        this.hasWrap = wrap;\n        this.$element.css('flex-wrap', wrap ? 'wrap' : 'nowrap');\n    }\n\n    /** Apply alignment based on direction */\n    applyAlignment(alignmentKey: string) {\n        if (!alignmentKey) return;\n\n        const base = (this.alignmentMatrix as any)[alignmentKey];\n        if (!base) return;\n\n        const isRow = this.direction === 'row';\n\n        let justifyContent = isRow ? base.justifyContent : base.alignItems;\n        let alignItems = isRow ? base.alignItems : base.justifyContent;\n\n        this.$element.css({\n            display: 'flex',\n            'flex-wrap': this.hasWrap ? 'wrap' : 'nowrap',\n            justifyContent,\n            alignItems\n        });\n    }\n\n    /** Apply spacing for gap + column gap */\n    applySpacing(key: string, nv: string) {\n        const base = (this.alignmentMatrix as any)[this.alignment];\n        if (!base) return;\n\n        const gapValue = key === 'gap' ? nv : this.gap;\n        const colValue = key === 'columngap' ? nv : this.columngap;\n\n        const isRow = this.direction === 'row';\n\n        const gapVal = (gapValue && gapValue !== 'auto') ? gapValue : null;\n        const colVal = (colValue && colValue !== 'auto') ? colValue : null;\n        const rowVal = this.hasWrap && gapVal ? gapVal : null;\n\n        let justifyContent = isRow ? base.justifyContent : base.alignItems;\n        let alignItems = isRow ? base.alignItems : base.justifyContent;\n\n        // ————— NO WRAP —————\n        if (!this.hasWrap) {\n            if (gapValue === 'auto') {\n                this.$element.css({\n                    'justify-content': base.justifyContent,\n                    'align-items': base.alignItems\n                });\n            } else {\n                this.$element.css({\n                    'justify-content': justifyContent,\n                    'align-items': alignItems,\n                    gap: `${gapVal}px`\n                });\n            }\n        }\n\n        // ————— WRAP LOGIC —————\n        else {\n            if (gapValue === 'auto' && colValue === 'auto') {\n                this.$element.css({\n                    'justify-content': justifyContent,\n                    'align-content': justifyContent\n                });\n            }\n            else if (gapValue !== 'auto' && colValue === 'auto') {\n                this.$element.css({\n                    'justify-content': justifyContent,\n                    'align-content': alignItems,\n                    'row-gap': `${rowVal}px`\n                });\n            }\n            else if (gapValue === 'auto' && colValue !== 'auto') {\n                this.$element.css({\n                    'align-content': 'space-between',\n                    'column-gap': `${colVal}px`\n                });\n            }\n            else {\n                if (colVal && rowVal) {\n                    if (colVal === rowVal) {\n                        this.$element.css({\n                            'gap': `${colVal}px`,\n                            'align-content': alignItems,\n                            'justify-content': justifyContent\n                        });\n                    } else {\n                        this.$element.css({\n                            'gap': `${rowVal}px ${colVal}px`,\n                            'align-content': alignItems,\n                            'justify-content': justifyContent\n                        });\n                    }\n                }\n            }\n        }\n\n        this.gap = gapValue?.toString();\n        this.columngap = colValue?.toString();\n    }\n\n    onPropertyChange(key: string, nv: any, ov?: any) {\n        switch (key) {\n            case 'direction':\n                this.applyDirection(nv);\n                break;\n            case 'wrap':\n                this.applyWrap(nv);\n                break;\n            case 'alignment':\n                this.alignment = nv;\n                this.applyAlignment(nv);\n                break;\n            case 'gap':\n            case 'columngap':\n                setTimeout(() => {\n                    this.applySpacing(key, nv);\n                });\n                break;\n            case 'position':\n                this.position = nv;\n                this.handlePosition();\n                break;\n            case 'clipcontent':\n                this.clipContent = nv;\n                this.handleClipBehaviour();\n                break;\n        }\n    }\n\n    applyStyleChange(key: string, nv: any,) {\n\n        if (key === 'width' || key === 'height') {\n            this.applySize(key, nv);\n        }\n\n        else if (key === 'padding') {\n            this.$element.css('padding', nv);\n        }\n\n        else if(key === 'overflow') {\n            this.overflowtype = nv;\n            this.handleClipBehaviour();\n        }\n\n        else if(key === 'zindex') {\n            this.zIndex = nv;\n            this.handlePosition();\n        }\n    }\n\n    private applySize(key: string, nv: any) {\n\n        if (nv === 'fill') {\n\n            if (key === 'width') {\n                this.$element.css('width', '100%');\n            }\n\n            if (key === 'height') {\n                if (this.parentElement?.hasAttribute('wmcontainer') || this.parentElement.hasAttribute('wmautolayout')) {\n                    this.$element.css({\n                        'align-self': 'stretch',\n                        'flex-grow': '1'\n                    });\n                } else {\n                    this.$element.css('height', '100%');\n                }\n            }\n        }\n\n        else if (nv === 'hug') {\n\n            if (key === 'width') {\n                this.$element.css('width', 'fit-content');\n            }\n\n            if (key === 'height') {\n                this.$element.css('height', 'fit-content');\n            }\n        } else {\n            this.$element.css('flex-shrink', '0'); // Don't shrink when size is fixed\n        }\n    }\n\n    // Determine whether the container should clip its content and configure scrolling behaviour accordingly.\n    private handleClipBehaviour() {\n\n        const overflow = this.overflowtype?.toLowerCase();\n        switch (overflow) {\n            case 'vertical':\n                this.$element.css({\n                    'overflow-x': 'hidden',\n                    'overflow-y': 'scroll'\n                });\n                break;\n\n            case 'horizontal':\n                this.$element.css({\n                    'overflow-x': 'scroll',\n                    'overflow-y': 'hidden'\n                });\n                break;\n\n            case 'both directions':\n                this.$element.css({\n                    'overflow': 'scroll'\n                });\n                break;\n\n            case 'no scrolling':\n                if (this.clipContent) {\n                    this.$element.css({ 'overflow': 'hidden' });\n                } else {\n                    this.$element.css({ 'overflow': '' });\n                }\n                break;\n\n            default:\n                break;\n        }\n\n    }\n\n    // Toggle and apply positional behaviour and expose the z-index control when position is not relative.\n    private handlePosition() {\n        if (this.position === 'sticky') {\n            // Apply sticky styles\n            this.$element.css({\n                'position': 'sticky',\n                'top': '0',    // Sticks to top when scrolling vertically\n                'left': '0',   // Sticks to left when scrolling horizontally\n                'z-index': this.zIndex\n            });\n        } else {\n            // Reset to default (static/relative behavior)\n            this.$element.css({\n                'position': '',\n                'top': '',\n                'left': '',\n                'z-index': ''\n            });\n        }\n    }\n\n\n}\n"]}
@@ -87,7 +87,7 @@ export const getFieldLayoutConfig = (captionWidth, captionPosition, os) => {
87
87
  };
88
88
  };
89
89
  export const getDefaultViewModeWidget = widget => {
90
- if (includes(['checkbox', 'toggle', 'rating'], widget)) {
90
+ if (includes(['checkbox', 'toggle', 'iconbutton-toggle', 'rating'], widget)) {
91
91
  return VIEW_MODE_OPTIONS.DEFAULT;
92
92
  }
93
93
  return VIEW_MODE_OPTIONS.LABEL;
@@ -106,16 +106,19 @@ const parseBooleanValue = value => {
106
106
  };
107
107
  export const parseValueByType = (value, type, widget, trailingzero) => {
108
108
  if (widget) {
109
- if (widget === FormWidgetType.NUMBER || widget === FormWidgetType.SLIDER || widget === FormWidgetType.CURRENCY) {
109
+ if (widget === FormWidgetType.SLIDER || widget === FormWidgetType.CURRENCY) {
110
110
  return isNaN(Number(value)) ? null : trailingzero ? value : Number(value);
111
111
  }
112
- if (widget === FormWidgetType.CHECKBOX || widget === FormWidgetType.TOGGLE) {
112
+ if (widget === FormWidgetType.NUMBER) {
113
+ return (isNaN(Number(value)) || value == null) ? null : trailingzero ? value : Number(value);
114
+ }
115
+ if (widget === FormWidgetType.CHECKBOX || widget === FormWidgetType.TOGGLE || widget === FormWidgetType.ICONBUTTONTOGGLE) {
113
116
  return parseBooleanValue(value);
114
117
  }
115
118
  return value;
116
119
  }
117
120
  if (isNumberType(type)) {
118
- return isNaN(Number(value)) ? null : Number(value);
121
+ return (isNaN(Number(value)) || value == null) ? null : Number(value);
119
122
  }
120
123
  if (type === DataType.BOOLEAN) {
121
124
  return parseBooleanValue(value);
@@ -139,7 +142,7 @@ const fieldTypeWidgetTypeMap = {
139
142
  'time': ['time', 'text', 'number', 'select', 'checkboxset', 'radioset', 'autocomplete', 'chips'],
140
143
  'timestamp': ['timestamp', 'text', 'number', 'select', 'checkboxset', 'radioset', 'autocomplete', 'chips'],
141
144
  'datetime': ['datetime', 'text', 'select', 'checkboxset', 'radioset', 'autocomplete', 'chips'],
142
- 'boolean': ['checkbox', 'radioset', 'toggle', 'select'],
145
+ 'boolean': ['checkbox', 'radioset', 'toggle', 'iconbutton-toggle', 'select'],
143
146
  'list': ['select', 'radioset', 'checkboxset', 'switch', 'autocomplete', 'chips'],
144
147
  'clob': ['text', 'textarea', 'richtext'],
145
148
  'blob': ['upload'],
@@ -197,7 +200,7 @@ export const getDefaultValue = (value, type, widget) => {
197
200
  if (widget === FormWidgetType.NUMBER || widget === FormWidgetType.SLIDER || widget === FormWidgetType.CURRENCY) {
198
201
  return isNaN(Number(value)) ? null : Number(value);
199
202
  }
200
- if (widget === FormWidgetType.CHECKBOX || widget === FormWidgetType.TOGGLE) {
203
+ if (widget === FormWidgetType.CHECKBOX || widget === FormWidgetType.TOGGLE || widget === FormWidgetType.ICONBUTTONTOGGLE) {
201
204
  return parseBooleanValue(value);
202
205
  }
203
206
  return value;
@@ -210,4 +213,4 @@ export const getDefaultValue = (value, type, widget) => {
210
213
  }
211
214
  return value;
212
215
  };
213
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"live-utils.js","sourceRoot":"","sources":["../../../../../projects/components/base/src/utils/live-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { isNumberType, FormWidgetType, DataType, isAndroid } from '@wm/core';\nimport {forEach, get, includes, split} from \"lodash-es\";\n\nconst  VIEW_MODE_OPTIONS = {\n    DEFAULT : 'default',\n    LABEL : 'label'\n};\n\nexport const EDIT_MODE = {\n    QUICK_EDIT : 'quickedit',\n    INLINE : 'inline',\n    FORM : 'form',\n    DIALOG : 'dialog'\n};\n\n// Method to set the header config of the data table\nexport const setHeaderConfig = (headerConfig, config, field, index?: number): void => {\n    forEach(headerConfig, cols => {\n        if (get(cols, 'isGroup')) {\n            if (cols.field === field) {\n                const id = cols.columns?.findIndex((col) => col?.field === config.field);\n                if (id == -1) {\n                    cols.columns[index] = config;\n                } else {\n                    cols.columns[id] = config;\n                }\n            } else {\n                setHeaderConfig(cols.columns, config, field, index);\n            }\n        }\n    });\n};\n\nexport const setHeaderConfigForTable = (headerConfig: any, config: any, fieldName: string, index?: number): void => {\n    if (fieldName) {\n        setHeaderConfig(headerConfig, config, fieldName, index);\n    } else {\n        headerConfig[index] = config;\n    }\n};\n\nexport const getRowOperationsColumn = (): any => {\n    return {\n        'field'         : 'rowOperations',\n        'type'          : 'custom',\n        'displayName'   : 'Actions',\n        'width'         : '120px',\n        'readonly'      : true,\n        'sortable'      : false,\n        'searchable'    : false,\n        'resizable'     : false,\n        'selectable'    : false,\n        'show'          : true,\n        'operations'    : [],\n        'opConfig'      : {},\n        'pcDisplay'     : true,\n        'mobileDisplay' : true,\n        'tabletDisplay' : true,\n        'include'       : true,\n        'isRowOperation': true\n    };\n};\n\n/**\n * Returns caption and widget bootstrap classes for the field\n */\nexport const getFieldLayoutConfig = (captionWidth, captionPosition, os): any => {\n    let captionCls = '',\n        widgetCls = '';\n\n    captionPosition = captionPosition || 'top';\n\n    if (captionPosition === 'top' || captionPosition === 'floating') {\n        if ((os && os === 'android') || isAndroid()) { // Is android or not a mobile application\n            captionCls = widgetCls = 'col-xs-12';\n        }\n    } else if (captionWidth) {\n        // handling itemsperrow containing string of classes\n        forEach(split(captionWidth, ' '), function (cls) {\n            const keys = split(cls, '-'),\n                tier = keys[0];\n            let _captionWidth,\n                widgetWidth;\n            _captionWidth = parseInt(keys[1], 10);\n            widgetWidth  = 12 - _captionWidth;\n            widgetWidth  = widgetWidth <= 0 ? 12 : widgetWidth;\n            captionCls += ' ' + 'col-' + tier + '-' + _captionWidth;\n            widgetCls  += ' ' + 'col-' + tier + '-' + widgetWidth;\n        });\n    }\n    return {\n        'captionCls' : captionCls,\n        'widgetCls'  : widgetCls\n    };\n};\n\nexport const getDefaultViewModeWidget = widget => {\n    if (includes(['checkbox', 'toggle', 'rating'], widget)) {\n        return VIEW_MODE_OPTIONS.DEFAULT;\n    }\n    return VIEW_MODE_OPTIONS.LABEL;\n};\n\nconst parseBooleanValue = value => {\n    if (value === 'true') {\n        return true;\n    }\n    if (value === 'false') {\n        return false;\n    }\n    if (/^\\d+$/.test(value)) { // Check if the value is a string of number type like '123'\n        return +value;\n    }\n    return value;\n};\n\nexport const parseValueByType = (value, type, widget, trailingzero?) => {\n    if (widget) {\n        if (widget === FormWidgetType.NUMBER || widget === FormWidgetType.SLIDER || widget === FormWidgetType.CURRENCY) {\n            return isNaN(Number(value)) ? null : trailingzero ? value : Number(value);\n        }\n        if (widget === FormWidgetType.CHECKBOX || widget === FormWidgetType.TOGGLE) {\n            return parseBooleanValue(value);\n        }\n        return value;\n    }\n    if (isNumberType(type)) {\n        return isNaN(Number(value)) ? null : Number(value);\n    }\n    if (type === DataType.BOOLEAN) {\n        return parseBooleanValue(value);\n    }\n    return value;\n};\n\nconst fieldTypeWidgetTypeMap = {\n    'integer'    : ['number', 'text', 'select', 'checkboxset', 'radioset', 'rating', 'slider', 'currency', 'autocomplete', 'chips'],\n    'big_integer': ['number', 'text', 'select', 'checkboxset', 'radioset', 'rating', 'slider', 'currency', 'autocomplete', 'chips'],\n    'short'      : ['number', 'text', 'select', 'checkboxset', 'radioset', 'slider', 'currency', 'autocomplete', 'chips'],\n    'float'      : ['number', 'text', 'select', 'checkboxset', 'radioset', 'slider', 'currency', 'autocomplete', 'chips'],\n    'big_decimal': ['number', 'text', 'select', 'checkboxset', 'radioset', 'slider', 'currency', 'autocomplete', 'chips'],\n    'number'     : ['number', 'text', 'select', 'checkboxset', 'radioset', 'slider', 'currency', 'autocomplete', 'chips'],\n    'double'     : ['number', 'text', 'select', 'checkboxset', 'radioset', 'slider', 'currency', 'autocomplete', 'chips'],\n    'long'       : ['number', 'text', 'select', 'checkboxset', 'radioset', 'rating', 'slider', 'currency', 'autocomplete', 'chips'],\n    'byte'       : ['number', 'text', 'select', 'checkboxset', 'radioset', 'slider', 'currency', 'autocomplete', 'chips'],\n    'string'     : ['text', 'number',  'textarea', 'password', 'richtext', 'select', 'checkboxset', 'radioset', 'date', 'time', 'timestamp', 'switch', 'currency', 'autocomplete', 'chips', 'colorpicker'],\n    'character'  : ['text', 'number',  'textarea', 'password', 'richtext', 'select', 'checkboxset', 'radioset', 'switch', 'currency', 'autocomplete', 'chips'],\n    'text'       : ['text', 'number',  'textarea', 'password', 'richtext', 'select', 'checkboxset', 'radioset', 'date', 'time', 'timestamp', 'switch', 'currency', 'autocomplete', 'chips', 'colorpicker'],\n    'date'       : ['date', 'text', 'number', 'select', 'checkboxset', 'radioset', 'autocomplete', 'chips'],\n    'time'       : ['time', 'text', 'number', 'select', 'checkboxset', 'radioset', 'autocomplete', 'chips'],\n    'timestamp'  : ['timestamp', 'text', 'number', 'select', 'checkboxset', 'radioset', 'autocomplete', 'chips'],\n    'datetime'   : ['datetime', 'text', 'select', 'checkboxset', 'radioset', 'autocomplete', 'chips'],\n    'boolean'    : ['checkbox', 'radioset', 'toggle', 'select'],\n    'list'       : ['select', 'radioset', 'checkboxset', 'switch', 'autocomplete', 'chips'],\n    'clob'       : ['text', 'textarea', 'richtext'],\n    'blob'       : ['upload'],\n    'file'       : ['upload'],\n    'custom'     : ['text', 'number',  'textarea', 'password', 'checkbox', 'toggle', 'slider', 'richtext', 'currency', 'switch',\n        'select', 'checkboxset', 'radioset', 'date', 'time', 'timestamp', 'rating', 'datetime', 'autocomplete', 'chips', 'colorpicker']\n};\n\n// Get widgets applicable to the given type\nexport const getFieldTypeWidgetTypesMap = () => {\n    return fieldTypeWidgetTypeMap;\n};\n\n// Get filter widget applicable to the given type\nexport const getDataTableFilterWidget = type => {\n    let widget = fieldTypeWidgetTypeMap[type] && fieldTypeWidgetTypeMap[type][0];\n    if (type === DataType.BOOLEAN) {\n        widget = FormWidgetType.SELECT;\n    }\n    if (includes([FormWidgetType.TEXT, FormWidgetType.NUMBER, FormWidgetType.SELECT, FormWidgetType.AUTOCOMPLETE,\n            FormWidgetType.DATE, FormWidgetType.TIME, FormWidgetType.DATETIME], widget)) {\n        return widget;\n    }\n    return FormWidgetType.TEXT;\n};\n\n/**\n * @ngdoc function\n * @name wm.widgets.live.getEditModeWidget\n * @methodOf wm.widgets.live.LiveWidgetUtils\n * @function\n *\n * @description\n * This function returns the default widget for grid\n *\n * @param {object} colDef field definition\n */\nexport const getEditModeWidget = colDef => {\n    if (colDef['related-entity-name'] && colDef['primary-key']) {\n        return FormWidgetType.SELECT;\n    }\n    return (fieldTypeWidgetTypeMap[colDef.type] && fieldTypeWidgetTypeMap[colDef.type][0]) || FormWidgetType.TEXT;\n};\n\n/**\n * @ngdoc function\n * @name wm.widgets.live.LiveWidgetUtils#getDefaultValue\n * @methodOf wm.widgets.live.LiveWidgetUtils\n * @function\n *\n * @description\n * return the formatted default value\n *\n * @param {string} value value to be formatted\n * @param {string} type column type of the value\n */\nexport const getDefaultValue = (value, type, widget) => {\n    if (widget) {\n        if (widget === FormWidgetType.NUMBER || widget === FormWidgetType.SLIDER || widget === FormWidgetType.CURRENCY) {\n            return isNaN(Number(value)) ? null : Number(value);\n        }\n        if (widget === FormWidgetType.CHECKBOX || widget === FormWidgetType.TOGGLE) {\n            return parseBooleanValue(value);\n        }\n        return value;\n    }\n    if (isNumberType(type)) {\n        return isNaN(Number(value)) ? null : Number(value);\n    }\n    if (type === DataType.BOOLEAN) {\n        return parseBooleanValue(value);\n    }\n    return value;\n};\n"]}
216
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"live-utils.js","sourceRoot":"","sources":["../../../../../projects/components/base/src/utils/live-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { isNumberType, FormWidgetType, DataType, isAndroid } from '@wm/core';\nimport {forEach, get, includes, split} from \"lodash-es\";\n\nconst  VIEW_MODE_OPTIONS = {\n    DEFAULT : 'default',\n    LABEL : 'label'\n};\n\nexport const EDIT_MODE = {\n    QUICK_EDIT : 'quickedit',\n    INLINE : 'inline',\n    FORM : 'form',\n    DIALOG : 'dialog'\n};\n\n// Method to set the header config of the data table\nexport const setHeaderConfig = (headerConfig, config, field, index?: number): void => {\n    forEach(headerConfig, cols => {\n        if (get(cols, 'isGroup')) {\n            if (cols.field === field) {\n                const id = cols.columns?.findIndex((col) => col?.field === config.field);\n                if (id == -1) {\n                    cols.columns[index] = config;\n                } else {\n                    cols.columns[id] = config;\n                }\n            } else {\n                setHeaderConfig(cols.columns, config, field, index);\n            }\n        }\n    });\n};\n\nexport const setHeaderConfigForTable = (headerConfig: any, config: any, fieldName: string, index?: number): void => {\n    if (fieldName) {\n        setHeaderConfig(headerConfig, config, fieldName, index);\n    } else {\n        headerConfig[index] = config;\n    }\n};\n\nexport const getRowOperationsColumn = (): any => {\n    return {\n        'field'         : 'rowOperations',\n        'type'          : 'custom',\n        'displayName'   : 'Actions',\n        'width'         : '120px',\n        'readonly'      : true,\n        'sortable'      : false,\n        'searchable'    : false,\n        'resizable'     : false,\n        'selectable'    : false,\n        'show'          : true,\n        'operations'    : [],\n        'opConfig'      : {},\n        'pcDisplay'     : true,\n        'mobileDisplay' : true,\n        'tabletDisplay' : true,\n        'include'       : true,\n        'isRowOperation': true\n    };\n};\n\n/**\n * Returns caption and widget bootstrap classes for the field\n */\nexport const getFieldLayoutConfig = (captionWidth, captionPosition, os): any => {\n    let captionCls = '',\n        widgetCls = '';\n\n    captionPosition = captionPosition || 'top';\n\n    if (captionPosition === 'top' || captionPosition === 'floating') {\n        if ((os && os === 'android') || isAndroid()) { // Is android or not a mobile application\n            captionCls = widgetCls = 'col-xs-12';\n        }\n    } else if (captionWidth) {\n        // handling itemsperrow containing string of classes\n        forEach(split(captionWidth, ' '), function (cls) {\n            const keys = split(cls, '-'),\n                tier = keys[0];\n            let _captionWidth,\n                widgetWidth;\n            _captionWidth = parseInt(keys[1], 10);\n            widgetWidth  = 12 - _captionWidth;\n            widgetWidth  = widgetWidth <= 0 ? 12 : widgetWidth;\n            captionCls += ' ' + 'col-' + tier + '-' + _captionWidth;\n            widgetCls  += ' ' + 'col-' + tier + '-' + widgetWidth;\n        });\n    }\n    return {\n        'captionCls' : captionCls,\n        'widgetCls'  : widgetCls\n    };\n};\n\nexport const getDefaultViewModeWidget = widget => {\n    if (includes(['checkbox', 'toggle', 'iconbutton-toggle', 'rating'], widget)) {\n        return VIEW_MODE_OPTIONS.DEFAULT;\n    }\n    return VIEW_MODE_OPTIONS.LABEL;\n};\n\nconst parseBooleanValue = value => {\n    if (value === 'true') {\n        return true;\n    }\n    if (value === 'false') {\n        return false;\n    }\n    if (/^\\d+$/.test(value)) { // Check if the value is a string of number type like '123'\n        return +value;\n    }\n    return value;\n};\n\nexport const parseValueByType = (value, type, widget, trailingzero?) => {\n    if (widget) {\n        if (widget === FormWidgetType.SLIDER || widget === FormWidgetType.CURRENCY) {\n            return isNaN(Number(value))? null : trailingzero ? value : Number(value);\n        }\n        if (widget === FormWidgetType.NUMBER ) {\n            return (isNaN(Number(value))|| value == null) ? null : trailingzero ? value : Number(value);\n        }\n        if (widget === FormWidgetType.CHECKBOX || widget === FormWidgetType.TOGGLE || widget === FormWidgetType.ICONBUTTONTOGGLE) {\n            return parseBooleanValue(value);\n        }\n        return value;\n    }\n    if (isNumberType(type)) {\n        return (isNaN(Number(value))|| value == null) ? null : Number(value);\n    }\n    if (type === DataType.BOOLEAN) {\n        return parseBooleanValue(value);\n    }\n    return value;\n};\n\nconst fieldTypeWidgetTypeMap = {\n    'integer'    : ['number', 'text', 'select', 'checkboxset', 'radioset', 'rating', 'slider', 'currency', 'autocomplete', 'chips'],\n    'big_integer': ['number', 'text', 'select', 'checkboxset', 'radioset', 'rating', 'slider', 'currency', 'autocomplete', 'chips'],\n    'short'      : ['number', 'text', 'select', 'checkboxset', 'radioset', 'slider', 'currency', 'autocomplete', 'chips'],\n    'float'      : ['number', 'text', 'select', 'checkboxset', 'radioset', 'slider', 'currency', 'autocomplete', 'chips'],\n    'big_decimal': ['number', 'text', 'select', 'checkboxset', 'radioset', 'slider', 'currency', 'autocomplete', 'chips'],\n    'number'     : ['number', 'text', 'select', 'checkboxset', 'radioset', 'slider', 'currency', 'autocomplete', 'chips'],\n    'double'     : ['number', 'text', 'select', 'checkboxset', 'radioset', 'slider', 'currency', 'autocomplete', 'chips'],\n    'long'       : ['number', 'text', 'select', 'checkboxset', 'radioset', 'rating', 'slider', 'currency', 'autocomplete', 'chips'],\n    'byte'       : ['number', 'text', 'select', 'checkboxset', 'radioset', 'slider', 'currency', 'autocomplete', 'chips'],\n    'string'     : ['text', 'number',  'textarea', 'password', 'richtext', 'select', 'checkboxset', 'radioset', 'date', 'time', 'timestamp', 'switch', 'currency', 'autocomplete', 'chips', 'colorpicker'],\n    'character'  : ['text', 'number',  'textarea', 'password', 'richtext', 'select', 'checkboxset', 'radioset', 'switch', 'currency', 'autocomplete', 'chips'],\n    'text'       : ['text', 'number',  'textarea', 'password', 'richtext', 'select', 'checkboxset', 'radioset', 'date', 'time', 'timestamp', 'switch', 'currency', 'autocomplete', 'chips', 'colorpicker'],\n    'date'       : ['date', 'text', 'number', 'select', 'checkboxset', 'radioset', 'autocomplete', 'chips'],\n    'time'       : ['time', 'text', 'number', 'select', 'checkboxset', 'radioset', 'autocomplete', 'chips'],\n    'timestamp'  : ['timestamp', 'text', 'number', 'select', 'checkboxset', 'radioset', 'autocomplete', 'chips'],\n    'datetime'   : ['datetime', 'text', 'select', 'checkboxset', 'radioset', 'autocomplete', 'chips'],\n    'boolean'    : ['checkbox', 'radioset', 'toggle', 'iconbutton-toggle', 'select'],\n    'list'       : ['select', 'radioset', 'checkboxset', 'switch', 'autocomplete', 'chips'],\n    'clob'       : ['text', 'textarea', 'richtext'],\n    'blob'       : ['upload'],\n    'file'       : ['upload'],\n    'custom'     : ['text', 'number',  'textarea', 'password', 'checkbox', 'toggle', 'slider', 'richtext', 'currency', 'switch',\n        'select', 'checkboxset', 'radioset', 'date', 'time', 'timestamp', 'rating', 'datetime', 'autocomplete', 'chips', 'colorpicker']\n};\n\n// Get widgets applicable to the given type\nexport const getFieldTypeWidgetTypesMap = () => {\n    return fieldTypeWidgetTypeMap;\n};\n\n// Get filter widget applicable to the given type\nexport const getDataTableFilterWidget = type => {\n    let widget = fieldTypeWidgetTypeMap[type] && fieldTypeWidgetTypeMap[type][0];\n    if (type === DataType.BOOLEAN) {\n        widget = FormWidgetType.SELECT;\n    }\n    if (includes([FormWidgetType.TEXT, FormWidgetType.NUMBER, FormWidgetType.SELECT, FormWidgetType.AUTOCOMPLETE,\n            FormWidgetType.DATE, FormWidgetType.TIME, FormWidgetType.DATETIME], widget)) {\n        return widget;\n    }\n    return FormWidgetType.TEXT;\n};\n\n/**\n * @ngdoc function\n * @name wm.widgets.live.getEditModeWidget\n * @methodOf wm.widgets.live.LiveWidgetUtils\n * @function\n *\n * @description\n * This function returns the default widget for grid\n *\n * @param {object} colDef field definition\n */\nexport const getEditModeWidget = colDef => {\n    if (colDef['related-entity-name'] && colDef['primary-key']) {\n        return FormWidgetType.SELECT;\n    }\n    return (fieldTypeWidgetTypeMap[colDef.type] && fieldTypeWidgetTypeMap[colDef.type][0]) || FormWidgetType.TEXT;\n};\n\n/**\n * @ngdoc function\n * @name wm.widgets.live.LiveWidgetUtils#getDefaultValue\n * @methodOf wm.widgets.live.LiveWidgetUtils\n * @function\n *\n * @description\n * return the formatted default value\n *\n * @param {string} value value to be formatted\n * @param {string} type column type of the value\n */\nexport const getDefaultValue = (value, type, widget) => {\n    if (widget) {\n        if (widget === FormWidgetType.NUMBER || widget === FormWidgetType.SLIDER || widget === FormWidgetType.CURRENCY) {\n            return isNaN(Number(value)) ? null : Number(value);\n        }\n        if (widget === FormWidgetType.CHECKBOX || widget === FormWidgetType.TOGGLE || widget === FormWidgetType.ICONBUTTONTOGGLE) {\n            return parseBooleanValue(value);\n        }\n        return value;\n    }\n    if (isNumberType(type)) {\n        return isNaN(Number(value)) ? null : Number(value);\n    }\n    if (type === DataType.BOOLEAN) {\n        return parseBooleanValue(value);\n    }\n    return value;\n};\n"]}