bromcom-ui 2.7.38-rc.4-0 → 2.7.38-rc.5

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 (205) hide show
  1. package/dist/bromcom-ui/bromcom-ui.esm.js +1 -1
  2. package/dist/bromcom-ui/{p-ac94ff20.entry.js → p-02df0e61.entry.js} +1 -1
  3. package/dist/bromcom-ui/{p-5696d100.js → p-06d5b45b.js} +1 -1
  4. package/dist/bromcom-ui/{p-9b349fd1.entry.js → p-09a7cbd8.entry.js} +1 -1
  5. package/dist/bromcom-ui/{p-42ccdbd8.entry.js → p-0da4b4f6.entry.js} +1 -1
  6. package/dist/bromcom-ui/{p-c51a9ec1.entry.js → p-0e47fd55.entry.js} +1 -1
  7. package/dist/bromcom-ui/{p-a5efb314.entry.js → p-10a311a3.entry.js} +1 -1
  8. package/dist/bromcom-ui/{p-82cf69c1.entry.js → p-17c906e2.entry.js} +1 -1
  9. package/dist/bromcom-ui/{p-0ed91122.entry.js → p-18b8a781.entry.js} +1 -1
  10. package/dist/bromcom-ui/{p-e48c96b5.entry.js → p-1a1ee7ac.entry.js} +1 -1
  11. package/dist/bromcom-ui/p-20a0dd5e.js +5 -0
  12. package/dist/bromcom-ui/{p-e9d4f2e3.entry.js → p-20ee086e.entry.js} +1 -1
  13. package/dist/bromcom-ui/{p-e83e3eae.entry.js → p-245639aa.entry.js} +1 -1
  14. package/dist/bromcom-ui/p-2535fab3.entry.js +5 -0
  15. package/dist/bromcom-ui/{p-882c3f88.js → p-32f45464.js} +1 -1
  16. package/dist/bromcom-ui/{p-6720d135.entry.js → p-375429c3.entry.js} +1 -1
  17. package/dist/bromcom-ui/{p-8c018ae0.js → p-3c7a0345.js} +1 -1
  18. package/dist/bromcom-ui/{p-82b4552b.entry.js → p-4416fc0a.entry.js} +1 -1
  19. package/dist/bromcom-ui/{p-ebce834a.entry.js → p-46bc2218.entry.js} +1 -1
  20. package/dist/bromcom-ui/{p-5782c63a.entry.js → p-51b7b796.entry.js} +1 -1
  21. package/dist/bromcom-ui/{p-3b6e2230.js → p-569a770d.js} +1 -1
  22. package/dist/bromcom-ui/{p-7e44e6b5.js → p-5ae0a59b.js} +1 -1
  23. package/dist/bromcom-ui/{p-4e16e6e3.entry.js → p-5c8da4ba.entry.js} +1 -1
  24. package/dist/bromcom-ui/{p-f5ae5381.entry.js → p-6bc8c9a5.entry.js} +1 -1
  25. package/dist/bromcom-ui/{p-67b2b680.entry.js → p-7d44d970.entry.js} +1 -1
  26. package/dist/bromcom-ui/{p-e3b93551.entry.js → p-8079d3c3.entry.js} +1 -1
  27. package/dist/bromcom-ui/{p-78cf8966.entry.js → p-9086c5e5.entry.js} +1 -1
  28. package/dist/bromcom-ui/p-910f82d6.entry.js +5 -0
  29. package/dist/bromcom-ui/{p-4e73ae71.entry.js → p-975d3153.entry.js} +1 -1
  30. package/dist/bromcom-ui/{p-2db34383.entry.js → p-98bc5080.entry.js} +1 -1
  31. package/dist/bromcom-ui/{p-b5f24bae.entry.js → p-9d791103.entry.js} +1 -1
  32. package/dist/bromcom-ui/{p-da7603b0.entry.js → p-9e6e812b.entry.js} +1 -1
  33. package/dist/bromcom-ui/{p-9192310c.entry.js → p-9fd54986.entry.js} +1 -1
  34. package/dist/bromcom-ui/{p-105ab305.entry.js → p-a24e8548.entry.js} +1 -1
  35. package/dist/bromcom-ui/p-a65d4efc.entry.js +5 -0
  36. package/dist/bromcom-ui/{p-f6730880.entry.js → p-a69c178b.entry.js} +1 -1
  37. package/dist/bromcom-ui/{p-a3ffcb0d.js → p-a8d1397d.js} +1 -1
  38. package/dist/bromcom-ui/{p-928f90f7.entry.js → p-afdbe4b8.entry.js} +1 -1
  39. package/dist/bromcom-ui/p-b00dce70.entry.js +5 -0
  40. package/dist/bromcom-ui/{p-d78f831f.entry.js → p-b1435ced.entry.js} +1 -1
  41. package/dist/bromcom-ui/p-b1b449e5.entry.js +5 -0
  42. package/dist/bromcom-ui/{p-22122329.entry.js → p-b42ba972.entry.js} +1 -1
  43. package/dist/bromcom-ui/{p-24ae390e.entry.js → p-b47a1f56.entry.js} +1 -1
  44. package/dist/bromcom-ui/p-b7d57364.entry.js +5 -0
  45. package/dist/bromcom-ui/p-b8ac51ee.entry.js +5 -0
  46. package/dist/bromcom-ui/{p-10235fe0.js → p-b99d105e.js} +1 -1
  47. package/dist/bromcom-ui/{p-870a8fd4.entry.js → p-c0367eac.entry.js} +1 -1
  48. package/dist/bromcom-ui/{p-1fc677ed.entry.js → p-c29da4ac.entry.js} +1 -1
  49. package/dist/bromcom-ui/{p-2bbc855e.entry.js → p-c59b1d70.entry.js} +1 -1
  50. package/dist/bromcom-ui/{p-f79130bd.js → p-c64aa680.js} +1 -1
  51. package/dist/bromcom-ui/{p-79d67b0d.entry.js → p-c80351a4.entry.js} +1 -1
  52. package/dist/bromcom-ui/{p-7b5e88c5.entry.js → p-cb975855.entry.js} +1 -1
  53. package/dist/bromcom-ui/{p-3c8a91b8.entry.js → p-cd228a80.entry.js} +1 -1
  54. package/dist/bromcom-ui/{p-89c1deda.entry.js → p-dbb1b1c8.entry.js} +1 -1
  55. package/dist/bromcom-ui/{p-66d04b59.entry.js → p-e6a8de73.entry.js} +1 -1
  56. package/dist/bromcom-ui/{p-b32bee88.entry.js → p-e92ea676.entry.js} +1 -1
  57. package/dist/bromcom-ui/{p-1978e4ae.entry.js → p-eaa34b84.entry.js} +1 -1
  58. package/dist/bromcom-ui/{p-44a08949.entry.js → p-f25e022d.entry.js} +1 -1
  59. package/dist/bromcom-ui/{p-7567855a.entry.js → p-f8debd1c.entry.js} +1 -1
  60. package/dist/bromcom-ui/{p-28d16808.entry.js → p-faf0477b.entry.js} +1 -1
  61. package/dist/bromcom-ui/p-fd1b7034.entry.js +5 -0
  62. package/dist/bromcom-ui/{p-12b09a8d.js → p-fef7d1c2.js} +1 -1
  63. package/dist/cjs/bcm-accordion.cjs.entry.js +1 -1
  64. package/dist/cjs/bcm-alert.cjs.entry.js +1 -1
  65. package/dist/cjs/bcm-attendance.cjs.entry.js +1 -1
  66. package/dist/cjs/bcm-avatar_2.cjs.entry.js +3 -3
  67. package/dist/cjs/bcm-breadcrumb.cjs.entry.js +1 -1
  68. package/dist/cjs/bcm-button-group.cjs.entry.js +1 -1
  69. package/dist/cjs/bcm-button.cjs.entry.js +384 -0
  70. package/dist/cjs/bcm-card.cjs.entry.js +1 -1
  71. package/dist/cjs/bcm-checkbox-group.cjs.entry.js +1 -1
  72. package/dist/cjs/bcm-checkbox-lite_9.cjs.entry.js +1 -1
  73. package/dist/cjs/bcm-checkbox_2.cjs.entry.js +1 -1
  74. package/dist/cjs/bcm-chip.cjs.entry.js +1 -1
  75. package/dist/cjs/bcm-collapse.cjs.entry.js +1 -1
  76. package/dist/cjs/{bcm-datetime-picker.cjs.entry.js → bcm-date-picker_7.cjs.entry.js} +830 -8
  77. package/dist/cjs/bcm-default.cjs.entry.js +1 -1
  78. package/dist/cjs/bcm-drawer.cjs.entry.js +3 -3
  79. package/dist/cjs/bcm-dropdown.cjs.entry.js +2 -2
  80. package/dist/cjs/bcm-expansion-panel.cjs.entry.js +1 -1
  81. package/dist/cjs/bcm-form-2.cjs.entry.js +1 -1
  82. package/dist/cjs/bcm-form.cjs.entry.js +487 -0
  83. package/dist/cjs/bcm-input.cjs.entry.js +341 -0
  84. package/dist/cjs/bcm-item.cjs.entry.js +1 -1
  85. package/dist/cjs/bcm-items.cjs.entry.js +1 -1
  86. package/dist/cjs/bcm-linked_2.cjs.entry.js +4 -4
  87. package/dist/cjs/bcm-list.cjs.entry.js +5 -6
  88. package/dist/cjs/bcm-modal.cjs.entry.js +142 -0
  89. package/dist/cjs/bcm-popconfirm-box.cjs.entry.js +1 -1
  90. package/dist/cjs/bcm-popconfirm.cjs.entry.js +1 -1
  91. package/dist/cjs/bcm-popover.cjs.entry.js +3 -3
  92. package/dist/cjs/bcm-progress.cjs.entry.js +1 -1
  93. package/dist/cjs/bcm-radio-group.cjs.entry.js +1 -1
  94. package/dist/cjs/bcm-radio.cjs.entry.js +1 -1
  95. package/dist/cjs/bcm-range.cjs.entry.js +1 -1
  96. package/dist/cjs/bcm-search.cjs.entry.js +2 -2
  97. package/dist/cjs/bcm-skeleton.cjs.entry.js +1 -1
  98. package/dist/cjs/bcm-step.cjs.entry.js +101 -0
  99. package/dist/cjs/bcm-stepper.cjs.entry.js +220 -0
  100. package/dist/cjs/bcm-switch.cjs.entry.js +1 -1
  101. package/dist/cjs/bcm-tab-group.cjs.entry.js +1 -1
  102. package/dist/cjs/bcm-tag.cjs.entry.js +2 -2
  103. package/dist/cjs/bcm-textarea.cjs.entry.js +2 -2
  104. package/dist/cjs/bromcom-ui.cjs.js +1 -1
  105. package/dist/cjs/{generate-96f85652.js → generate-444f78d8.js} +1 -1
  106. package/dist/cjs/{input-template-5a946790.js → input-template-1c41f731.js} +1 -1
  107. package/dist/cjs/{json-parse-decarator-e4fad91a.js → json-parse-decarator-1df79b49.js} +1 -1
  108. package/dist/cjs/loader.cjs.js +1 -1
  109. package/dist/cjs/{number-helper-ba86b114.js → number-helper-61ad541b.js} +1 -1
  110. package/dist/cjs/old-bcm-popover-box.cjs.entry.js +2 -2
  111. package/dist/cjs/old-bcm-popover.cjs.entry.js +1 -1
  112. package/dist/cjs/stepper-states-b820e69c.js +85 -0
  113. package/dist/cjs/{tooltip-helper-d01c7faf.js → tooltip-helper-22b169c4.js} +3 -3
  114. package/dist/cjs/{validators-c614157e.js → validators-3a5d3be9.js} +1 -1
  115. package/dist/collection/components/organism/date-picker/date-picker.js +20 -1
  116. package/dist/collection/components/organism/datetime-picker/datetime-picker.js +20 -1
  117. package/dist/collection/components/organism/list/list.js +0 -1
  118. package/dist/collection/components/organism/time-picker/time-picker.js +20 -1
  119. package/dist/components/bcm-date-picker.js +3 -1
  120. package/dist/components/bcm-list.js +0 -1
  121. package/dist/components/bcm-time-picker.js +3 -1
  122. package/dist/components/datetime-picker.js +3 -1
  123. package/dist/components/generate.js +1 -1
  124. package/dist/esm/bcm-accordion.entry.js +1 -1
  125. package/dist/esm/bcm-alert.entry.js +1 -1
  126. package/dist/esm/bcm-attendance.entry.js +1 -1
  127. package/dist/esm/bcm-avatar_2.entry.js +6 -6
  128. package/dist/esm/bcm-breadcrumb.entry.js +1 -1
  129. package/dist/esm/bcm-button-group.entry.js +1 -1
  130. package/dist/esm/bcm-button.entry.js +380 -0
  131. package/dist/esm/bcm-card.entry.js +3 -3
  132. package/dist/esm/bcm-checkbox-group.entry.js +2 -2
  133. package/dist/esm/bcm-checkbox-lite_9.entry.js +2 -2
  134. package/dist/esm/bcm-checkbox_2.entry.js +3 -3
  135. package/dist/esm/bcm-chip.entry.js +3 -3
  136. package/dist/esm/bcm-collapse-group.entry.js +1 -1
  137. package/dist/esm/bcm-collapse.entry.js +1 -1
  138. package/dist/esm/bcm-colorpicker.entry.js +2 -2
  139. package/dist/esm/{bcm-datetime-picker.entry.js → bcm-date-picker_7.entry.js} +827 -11
  140. package/dist/esm/bcm-default.entry.js +1 -1
  141. package/dist/esm/bcm-drawer.entry.js +6 -6
  142. package/dist/esm/bcm-dropdown.entry.js +2 -2
  143. package/dist/esm/bcm-expansion-panel.entry.js +3 -3
  144. package/dist/esm/bcm-form-2.entry.js +1 -1
  145. package/dist/esm/bcm-form.entry.js +483 -0
  146. package/dist/esm/bcm-input.entry.js +337 -0
  147. package/dist/esm/bcm-item.entry.js +3 -3
  148. package/dist/esm/bcm-items.entry.js +1 -1
  149. package/dist/esm/bcm-linked_2.entry.js +7 -7
  150. package/dist/esm/bcm-list.entry.js +8 -9
  151. package/dist/esm/bcm-modal.entry.js +138 -0
  152. package/dist/esm/bcm-old-tag_2.entry.js +1 -1
  153. package/dist/esm/bcm-popconfirm-box.entry.js +3 -3
  154. package/dist/esm/bcm-popconfirm.entry.js +1 -1
  155. package/dist/esm/bcm-popover.entry.js +6 -6
  156. package/dist/esm/bcm-progress.entry.js +3 -3
  157. package/dist/esm/bcm-radio-group.entry.js +2 -2
  158. package/dist/esm/bcm-radio.entry.js +3 -3
  159. package/dist/esm/bcm-range.entry.js +2 -2
  160. package/dist/esm/bcm-search.entry.js +3 -3
  161. package/dist/esm/bcm-select.entry.js +1 -1
  162. package/dist/esm/bcm-skeleton.entry.js +1 -1
  163. package/dist/esm/bcm-step.entry.js +97 -0
  164. package/dist/esm/bcm-stepper.entry.js +216 -0
  165. package/dist/esm/bcm-switch.entry.js +2 -2
  166. package/dist/esm/bcm-tab-group.entry.js +1 -1
  167. package/dist/esm/bcm-table.entry.js +1 -1
  168. package/dist/esm/bcm-tabs-content.entry.js +1 -1
  169. package/dist/esm/bcm-tabs.entry.js +1 -1
  170. package/dist/esm/bcm-tag.entry.js +3 -3
  171. package/dist/esm/bcm-text.entry.js +2 -2
  172. package/dist/esm/bcm-textarea.entry.js +3 -3
  173. package/dist/esm/bromcom-ui.js +1 -1
  174. package/dist/esm/{color-helper-7e202fd8.js → color-helper-b5e9aa56.js} +1 -1
  175. package/dist/esm/{element-dragger-89bb52fd.js → element-dragger-7ea06c76.js} +1 -1
  176. package/dist/esm/{generate-978067d3.js → generate-3650d0a8.js} +1 -1
  177. package/dist/esm/{input-template-4722e50b.js → input-template-0a009dc3.js} +1 -1
  178. package/dist/esm/{json-parse-decarator-6b685c81.js → json-parse-decarator-8a38db81.js} +1 -1
  179. package/dist/esm/loader.js +1 -1
  180. package/dist/esm/{number-helper-6cf8fb22.js → number-helper-ad46adfd.js} +1 -1
  181. package/dist/esm/old-bcm-popover-box.entry.js +4 -4
  182. package/dist/esm/old-bcm-popover.entry.js +1 -1
  183. package/dist/esm/stepper-states-808a6dce.js +83 -0
  184. package/dist/esm/{tooltip-helper-1ac48b48.js → tooltip-helper-fe6a79f6.js} +5 -5
  185. package/dist/esm/{utils-57652744.js → utils-b3338faf.js} +1 -1
  186. package/dist/esm/{validators-0bd486de.js → validators-18fc528d.js} +1 -1
  187. package/dist/types/components/organism/date-picker/date-picker.d.ts +1 -0
  188. package/dist/types/components/organism/datetime-picker/datetime-picker.d.ts +1 -0
  189. package/dist/types/components/organism/time-picker/time-picker.d.ts +1 -0
  190. package/dist/types/components.d.ts +6 -0
  191. package/package.json +1 -1
  192. package/dist/bromcom-ui/p-62b5f555.entry.js +0 -5
  193. package/dist/bromcom-ui/p-78ca0329.entry.js +0 -5
  194. package/dist/bromcom-ui/p-7f349606.entry.js +0 -5
  195. package/dist/bromcom-ui/p-81d1870d.entry.js +0 -5
  196. package/dist/bromcom-ui/p-99bed73b.entry.js +0 -5
  197. package/dist/bromcom-ui/p-c559e56e.entry.js +0 -5
  198. package/dist/cjs/bcm-button_9.cjs.entry.js +0 -1795
  199. package/dist/cjs/bcm-date-picker.cjs.entry.js +0 -178
  200. package/dist/cjs/bcm-old-input.cjs.entry.js +0 -411
  201. package/dist/cjs/bcm-time-picker.cjs.entry.js +0 -146
  202. package/dist/esm/bcm-button_9.entry.js +0 -1783
  203. package/dist/esm/bcm-date-picker.entry.js +0 -174
  204. package/dist/esm/bcm-old-input.entry.js +0 -407
  205. package/dist/esm/bcm-time-picker.entry.js +0 -142
@@ -8,7 +8,7 @@ Object.defineProperty(exports, '__esModule', { value: true });
8
8
 
9
9
  const index = require('./index-1fda1524.js');
10
10
  const isLoadDecorator = require('./is-load-decorator-77664890.js');
11
- const generate = require('./generate-96f85652.js');
11
+ const generate = require('./generate-444f78d8.js');
12
12
 
13
13
  const defaultCss = "@import url(\"https://fonts.googleapis.com/css?family=Roboto:400,500\");.size-1{font-size:12px;line-height:20px}.size-2{font-size:14px;line-height:22px}.size-3{font-size:16px;line-height:24px}.size-4{font-size:20px;line-height:28px}.size-5{font-size:24px;line-height:32px}.size-6{font-size:30px;line-height:38px}.size-7{font-size:38px;line-height:46px}.size-8{font-size:46px;line-height:54px}.size-9{font-size:56px;line-height:64px}.weight-regular{font-weight:400}.weight-semibold{font-weight:500}.input-size-large{height:40px}.input-size-medium{height:32px}.input-size-small{height:24px}.resize-none textarea{resize:none}.resize-vertical textarea{resize:vertical}.resize-auto textarea{height:auto;resize:none}.textarea-size-large{padding:4px 0 0 4px;min-height:40px}.textarea-size-large .bcm-input-element{min-height:calc((40px - 8px) + 2px)}.textarea-size-large .input-clear-button{height:calc( 40px - 16px );top:8px;padding:0;margin-right:8px}.textarea-size-medium{padding:4px 0 0 4px;min-height:32px}.textarea-size-medium .bcm-input-element{min-height:calc((32px - 8px) + 2px)}.textarea-size-medium .input-clear-button{height:calc( 32px - 16px );top:8px;padding:0;margin-right:8px}.textarea-size-small{padding:0px 0 0 4px;min-height:24px}.textarea-size-small .bcm-input-element{min-height:calc((24px - 8px) + 2px)}.textarea-size-small .input-clear-button{height:calc( 24px - 16px );top:8px;padding:0;margin-right:8px}:host{display:block}";
14
14
 
@@ -10,10 +10,10 @@ const index = require('./index-1fda1524.js');
10
10
  const isLoadDecorator = require('./is-load-decorator-77664890.js');
11
11
  require('./color-helper-c9882bd8.js');
12
12
  require('./datetime-helper-eaf4fadb.js');
13
- const generate = require('./generate-96f85652.js');
14
- require('./number-helper-ba86b114.js');
13
+ const generate = require('./generate-444f78d8.js');
14
+ require('./number-helper-61ad541b.js');
15
15
  require('./string-helper-df40a475.js');
16
- require('./validators-c614157e.js');
16
+ require('./validators-3a5d3be9.js');
17
17
  require('./element-dragger-a8562f82.js');
18
18
  const bcm = require('./bcm-2c51bf0c.js');
19
19
  const index$1 = require('./index-a2b50e51.js');
@@ -9,8 +9,8 @@ Object.defineProperty(exports, '__esModule', { value: true });
9
9
  const index = require('./index-1fda1524.js');
10
10
  const index$1 = require('./index-a2b50e51.js');
11
11
  const isLoadDecorator = require('./is-load-decorator-77664890.js');
12
- const jsonParseDecarator = require('./json-parse-decarator-e4fad91a.js');
13
- const generate = require('./generate-96f85652.js');
12
+ const jsonParseDecarator = require('./json-parse-decarator-1df79b49.js');
13
+ const generate = require('./generate-444f78d8.js');
14
14
  const bcm = require('./bcm-2c51bf0c.js');
15
15
  require('./_commonjsHelpers-bd20f4c0.js');
16
16
 
@@ -8,7 +8,7 @@ Object.defineProperty(exports, '__esModule', { value: true });
8
8
 
9
9
  const index = require('./index-1fda1524.js');
10
10
  const isLoadDecorator = require('./is-load-decorator-77664890.js');
11
- const generate = require('./generate-96f85652.js');
11
+ const generate = require('./generate-444f78d8.js');
12
12
  const index$1 = require('./index-a2b50e51.js');
13
13
  const stringHelper = require('./string-helper-df40a475.js');
14
14
  const colorHelper = require('./color-helper-c9882bd8.js');
@@ -8,7 +8,7 @@ Object.defineProperty(exports, '__esModule', { value: true });
8
8
 
9
9
  const index = require('./index-1fda1524.js');
10
10
  const isLoadDecorator = require('./is-load-decorator-77664890.js');
11
- const generate = require('./generate-96f85652.js');
11
+ const generate = require('./generate-444f78d8.js');
12
12
  const stringHelper = require('./string-helper-df40a475.js');
13
13
  const bcm = require('./bcm-2c51bf0c.js');
14
14
  require('./_commonjsHelpers-bd20f4c0.js');
@@ -0,0 +1,487 @@
1
+ /*!
2
+ * Built with Stencil
3
+ * Copyright (c) Bromcom.
4
+ */
5
+ 'use strict';
6
+
7
+ Object.defineProperty(exports, '__esModule', { value: true });
8
+
9
+ const index = require('./index-1fda1524.js');
10
+ const index$1 = require('./index-a2b50e51.js');
11
+ const isLoadDecorator = require('./is-load-decorator-77664890.js');
12
+ const stringHelper = require('./string-helper-df40a475.js');
13
+ const utils = require('./utils-fc077139.js');
14
+ require('./_commonjsHelpers-bd20f4c0.js');
15
+ require('./bcm-2c51bf0c.js');
16
+
17
+ // /**
18
+ // *
19
+ // * @param type
20
+ // */
21
+ // export const required = (value:any) => {
22
+ // if ( value || value != null ) {
23
+ // return true
24
+ // } else {
25
+ // return true
26
+ // }
27
+ // }
28
+ class rules {
29
+ constructor() { }
30
+ response(status, message) {
31
+ return Object.assign(Object.assign({ valid: status }, (message && { message })), (!status && { type: 'error' }));
32
+ }
33
+ required(value, componentValidation) {
34
+ let validation = this.response(true);
35
+ if (value == '' || value == "" || value == undefined || value == null || value === false) {
36
+ validation = this.response(false, 'This field is required.');
37
+ }
38
+ if (componentValidation) {
39
+ if (!componentValidation.valid) {
40
+ validation = this.response(false, componentValidation.errorText);
41
+ }
42
+ if (value instanceof Object) {
43
+ if (value.isValid) {
44
+ if (value.isValid == false)
45
+ validation = this.response(false, 'This field is required.');
46
+ }
47
+ }
48
+ }
49
+ return validation;
50
+ }
51
+ selfValidation(input) {
52
+ let validation = this.response(true);
53
+ if (input.captionError != null || input.captionType == 'error') {
54
+ validation = this.response(false, input.captionError);
55
+ }
56
+ return validation;
57
+ }
58
+ }
59
+ const validate = new rules;
60
+
61
+ const formCss = "@import url(\"https://fonts.googleapis.com/css?family=Roboto:400,500\");.size-1{font-size:12px;line-height:20px}.size-2{font-size:14px;line-height:22px}.size-3{font-size:16px;line-height:24px}.size-4{font-size:20px;line-height:28px}.size-5{font-size:24px;line-height:32px}.size-6{font-size:30px;line-height:38px}.size-7{font-size:38px;line-height:46px}.size-8{font-size:46px;line-height:54px}.size-9{font-size:56px;line-height:64px}.weight-regular{font-weight:400}.weight-semibold{font-weight:500}.input-size-large{height:40px}.input-size-medium{height:32px}.input-size-small{height:24px}.resize-none textarea{resize:none}.resize-vertical textarea{resize:vertical}.resize-auto textarea{height:auto;resize:none}.textarea-size-large{padding:4px 0 0 4px;min-height:40px}.textarea-size-large .bcm-input-element{min-height:calc((40px - 8px) + 2px)}.textarea-size-large .input-clear-button{height:calc( 40px - 16px );top:8px;padding:0;margin-right:8px}.textarea-size-medium{padding:4px 0 0 4px;min-height:32px}.textarea-size-medium .bcm-input-element{min-height:calc((32px - 8px) + 2px)}.textarea-size-medium .input-clear-button{height:calc( 32px - 16px );top:8px;padding:0;margin-right:8px}.textarea-size-small{padding:0px 0 0 4px;min-height:24px}.textarea-size-small .bcm-input-element{min-height:calc((24px - 8px) + 2px)}.textarea-size-small .input-clear-button{height:calc( 24px - 16px );top:8px;padding:0;margin-right:8px}:host{display:block;margin-bottom:8px}:host(.hidden){display:none}";
62
+
63
+ var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
64
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
65
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
66
+ r = Reflect.decorate(decorators, target, key, desc);
67
+ else
68
+ for (var i = decorators.length - 1; i >= 0; i--)
69
+ if (d = decorators[i])
70
+ r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
71
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
72
+ };
73
+ const BcmForm = class {
74
+ constructor(hostRef) {
75
+ index.registerInstance(this, hostRef);
76
+ this.bcmForm = index.createEvent(this, "bcm-form", 7);
77
+ this.formData = {};
78
+ this.inputs = [];
79
+ this.duplicateInput = [];
80
+ this.isValid = true;
81
+ this.returnCaption = [];
82
+ this.Bromcom = {
83
+ errors: {
84
+ targetFormNotExist: 'target form is not exist --> ',
85
+ },
86
+ inputComponents: {
87
+ // Birbirinin aynısı
88
+ INPUT: 'input',
89
+ TEXTAREA: 'textarea',
90
+ //çok benzer
91
+ SWITCH: 'switch',
92
+ CHECKBOX: 'checkbox',
93
+ RADIO_GROUP: 'radio-group',
94
+ CHECKBOX_GROUP: 'checkbox-group',
95
+ RANGE: 'range',
96
+ // sadece value fırlatıyor
97
+ FORM: 'form',
98
+ FORM_GROUP: 'form-group',
99
+ // *En vakit alacak => içinde select, autocomplete, listbox, treeview özellikleri var
100
+ LIST: 'list',
101
+ //
102
+ COLORPICKER: 'colorpicker',
103
+ // picker aslında tek komponent hepsi datetimepicker
104
+ DATE_PICKER: 'date-picker',
105
+ TIME_PICKER: 'time-picker',
106
+ DATETIME_PICKER: 'datetime-picker',
107
+ // silinecek komponentler
108
+ SELECT: 'select',
109
+ LISTBOX: 'listbox'
110
+ },
111
+ helpers: {
112
+ randomId: function () {
113
+ return Math.random().toString(16).slice(2, -1);
114
+ },
115
+ },
116
+ };
117
+ this._id = (Math.random() * 4).toString(16).replace('.', '');
118
+ this.hidden = false;
119
+ this.validation = false;
120
+ this.name = "";
121
+ this.value = undefined;
122
+ this.autocomplete = false;
123
+ }
124
+ handleSubmit() {
125
+ // if (lowercase(e.target.nodeName) === 'bcm-button') {
126
+ // if (e.target.type === 'submit') {
127
+ // this.submitFunction()
128
+ // }
129
+ // }
130
+ }
131
+ async submitFunction() {
132
+ this.formData = {};
133
+ this.inputs = [];
134
+ this.selector = this.el;
135
+ await this.getInputs();
136
+ await utils.delay(10);
137
+ const usrFrmData = await this.userFormData();
138
+ var formData = { isValid: true, formData: usrFrmData };
139
+ if (this.name) {
140
+ formData = Object.assign(Object.assign({}, formData), { formName: this.name });
141
+ }
142
+ if (this.isValid) {
143
+ this.bcmForm.emit(formData);
144
+ return formData;
145
+ }
146
+ else {
147
+ this.returnCaption = { isValid: false, 'message': 'Please fill in all inputs', 'errorDetails': this.returnCaption, formData: usrFrmData };
148
+ if (this.name) {
149
+ this.returnCaption = Object.assign(Object.assign({}, this.returnCaption), { formName: this.name });
150
+ }
151
+ this.bcmForm.emit(this.returnCaption);
152
+ return this.returnCaption;
153
+ }
154
+ }
155
+ async submit() {
156
+ return Promise.resolve(this.submitFunction());
157
+ }
158
+ async set(data) {
159
+ var _a;
160
+ const validate = this.validation;
161
+ this.validation = false;
162
+ // debugger
163
+ this.selector = this.el;
164
+ await this.getInputs();
165
+ if (data && ((_a = this.inputs) === null || _a === void 0 ? void 0 : _a.length) > 0) {
166
+ for (const key of Object.keys(data)) {
167
+ const item = this.inputs.find(item => item.name === key);
168
+ if (item) {
169
+ try {
170
+ await item.set(data[key]);
171
+ }
172
+ catch (error) {
173
+ console.log(item.nodeName, "set", error);
174
+ }
175
+ }
176
+ }
177
+ }
178
+ this.validation = validate;
179
+ }
180
+ async get() {
181
+ var _a;
182
+ let formData = {};
183
+ this.selector = this.el;
184
+ const inputsCache = this.inputs;
185
+ await this.getInputs();
186
+ ((_a = this.inputs) === null || _a === void 0 ? void 0 : _a.length) > 0 && this.inputs.forEach(async (item) => {
187
+ try {
188
+ const value = await item.get();
189
+ formData = Object.assign(Object.assign({}, formData), { [item.name]: value });
190
+ }
191
+ catch (error) {
192
+ console.log(`${item.nodeName} get error`);
193
+ }
194
+ });
195
+ this.inputs = inputsCache;
196
+ await utils.delay(10);
197
+ return Promise.resolve(formData);
198
+ }
199
+ async setClear() {
200
+ this.formData = {};
201
+ this.inputs = [];
202
+ this.selector = this.el;
203
+ let clear = [];
204
+ await this.getInputs();
205
+ this.inputs.forEach(async (item) => {
206
+ try {
207
+ clear.push(await item.setClear());
208
+ }
209
+ catch (error) {
210
+ console.log(error);
211
+ }
212
+ });
213
+ await Promise.all(clear).then(() => {
214
+ this.formData = {};
215
+ this.inputs = [];
216
+ this.duplicateInput = [];
217
+ this.isValid = true;
218
+ this.returnCaption = [];
219
+ });
220
+ await utils.delay(10);
221
+ return Promise.resolve(true);
222
+ }
223
+ async resetCaption() {
224
+ await utils.delay(10);
225
+ this.formData = {};
226
+ this.inputs = [];
227
+ this.selector = this.el;
228
+ await this.getInputs();
229
+ for (const item of this.inputs) {
230
+ try {
231
+ await item.resetCaption();
232
+ }
233
+ catch (error) {
234
+ console.log(item.nodeName, "rc p");
235
+ }
236
+ }
237
+ await utils.delay(10);
238
+ return Promise.resolve();
239
+ }
240
+ async config(_config) {
241
+ if (_config['validation']) {
242
+ typeof _config['validation'] == 'boolean'
243
+ ? this.validation = _config['validation']
244
+ : this.validation = false;
245
+ }
246
+ return true;
247
+ }
248
+ async getInputs() {
249
+ var form = this.selector;
250
+ if (!form) {
251
+ console.warn(this.Bromcom.errors.targetFormNotExist + this.selector);
252
+ return;
253
+ }
254
+ const inputs = Array.from(form.querySelectorAll('bcm-' + Object.values(this.Bromcom.inputComponents).join(',bcm-')));
255
+ this.duplicateInput = [];
256
+ // s-hn: Stencil private flag that contains host web component
257
+ // https://github.com/ionic-team/stencil/blob/45388e95edb46ef357eb9ae37cd32bbb5bc1ed23/src/runtime/vdom/vdom-render.ts#L116
258
+ const rootInputs = inputs.filter((input) => { var _a; return !input['s-hn'] || ((_a = input['s-hn']) === null || _a === void 0 ? void 0 : _a.nodeName) !== 'BcmForm'; });
259
+ // debugger;
260
+ for (const item of rootInputs) {
261
+ if (stringHelper.StringHelper.lowercase(item.nodeName) == "bcm-checkbox-group") {
262
+ let checkboxs = item.querySelectorAll("bcm-checkbox");
263
+ if (checkboxs) {
264
+ for (const checkbox of checkboxs) {
265
+ this.duplicateInput.push(checkbox.name);
266
+ }
267
+ }
268
+ }
269
+ if (stringHelper.StringHelper.lowercase(item.nodeName) == "bcm-form") {
270
+ const groupInputs = Array.from(item.querySelectorAll('bcm-' + Object.values(this.Bromcom.inputComponents).join(',bcm-')));
271
+ let itemObject = {};
272
+ for (const element of groupInputs) {
273
+ var name = element.name;
274
+ var value = element.value;
275
+ itemObject = Object.assign(Object.assign({}, itemObject), { [name]: value });
276
+ this.duplicateInput.push(element.name);
277
+ }
278
+ item.value = itemObject;
279
+ let checkboxs = item.querySelectorAll("bcm-checkbox");
280
+ if (checkboxs) {
281
+ for (const checkbox of checkboxs) {
282
+ this.duplicateInput.push(checkbox.name);
283
+ }
284
+ }
285
+ }
286
+ }
287
+ await utils.delay(10);
288
+ this.inputs = rootInputs;
289
+ }
290
+ getItemValue(item) {
291
+ const tagName = item.tagName.toLowerCase().replace('bcm-', '');
292
+ switch (tagName) {
293
+ /* case 'date-picker':
294
+ case 'datetime-picker':
295
+ return item.value.timestamp
296
+ case 'time-picker':
297
+ return item.value.time */
298
+ default:
299
+ return item.value;
300
+ }
301
+ }
302
+ isWrapperComponent(item) {
303
+ return ['bcm-datetime-picker', 'bcm-date-picker', 'bcm-time-picker'].includes(item.toLowerCase());
304
+ }
305
+ isGroupComponent(item) {
306
+ return ['bcm-checkbox-group'].includes(item.toLowerCase());
307
+ }
308
+ isListComponent(item) {
309
+ return ['bcm-list'].includes(item.toLowerCase());
310
+ }
311
+ async userFormData() {
312
+ this.formData = {};
313
+ this.isValid = true;
314
+ this.returnCaption = [];
315
+ for (const item of this.inputs) {
316
+ // const isListComponent = this.isListComponent(item.tagName);
317
+ const isGroupComponent = this.isGroupComponent(item.tagName);
318
+ const isWrapperComponent = this.isWrapperComponent(item.tagName);
319
+ const wrapperComponent = isWrapperComponent && item;
320
+ const input = isWrapperComponent
321
+ ? await item.getInput() && item
322
+ : item;
323
+ // input.caption = ''
324
+ // input.captionType = ''
325
+ if (this.validation) {
326
+ let valid = null;
327
+ // if (isListComponent) {
328
+ // valid = !(input.value && input.value.length > 0) && validate.required(input.value)
329
+ // } else
330
+ if (isWrapperComponent) {
331
+ const isPickerValid = await wrapperComponent.isValid();
332
+ valid = validate.required(input.value, isPickerValid);
333
+ if (valid) {
334
+ if (input.value instanceof Object) {
335
+ if (input.value["isValid"] == false) {
336
+ valid = validate.required("", isPickerValid);
337
+ }
338
+ }
339
+ else {
340
+ valid = validate.required(input.value, isPickerValid);
341
+ }
342
+ }
343
+ }
344
+ else if (isGroupComponent) {
345
+ const childsCheckbox = utils.getChildElements(input, 'bcm-checkbox:not(#bcm-indeterminate-element)');
346
+ if (childsCheckbox && childsCheckbox.length > 0) {
347
+ for (const element of childsCheckbox) {
348
+ if (element && element.required === true) {
349
+ valid = validate.required(element.checked);
350
+ if (!valid['valid']) {
351
+ element.noCaption = false;
352
+ element.captionError = valid['message'];
353
+ element.captionType = valid['type'];
354
+ }
355
+ else {
356
+ element.noCaption = input.noCaption;
357
+ element.captionError = null;
358
+ element.captionType = "default";
359
+ }
360
+ }
361
+ }
362
+ }
363
+ }
364
+ else {
365
+ valid = validate.required(input.value);
366
+ }
367
+ if (input.required) {
368
+ if (!valid['valid']) {
369
+ input.captionError = valid['message'];
370
+ input.captionType = valid['type'];
371
+ }
372
+ else {
373
+ input.captionError = null;
374
+ input.captionType = "default";
375
+ }
376
+ await utils.delay(10);
377
+ const selfValidation = validate.selfValidation(input);
378
+ if (valid['valid']) {
379
+ if (!selfValidation['valid']) {
380
+ input.captionError = selfValidation['message'];
381
+ input.captionType = selfValidation['type'];
382
+ }
383
+ }
384
+ }
385
+ let name = input.name;
386
+ let value = input.captionError;
387
+ !input.hidden && input.captionType == 'error' && (this.returnCaption = [...Array.from(this.returnCaption), { [name]: value }],
388
+ this.isValid = false);
389
+ }
390
+ if (input.name && !this.duplicateInput.includes(input.name)) {
391
+ var itemValue = this.getItemValue(input);
392
+ if (!itemValue || itemValue == undefined || itemValue == null) {
393
+ itemValue = null;
394
+ }
395
+ this.formData[input.name] = itemValue;
396
+ }
397
+ }
398
+ return this.formData;
399
+ }
400
+ async handleChange(e) {
401
+ const isWrapperComponent = this.isWrapperComponent(e.target.tagName);
402
+ const isGroupComponent = this.isGroupComponent(e.target.tagName);
403
+ let target;
404
+ if (isWrapperComponent) {
405
+ target = e.target.getInput && await e.target.getInput() || e.target;
406
+ }
407
+ else if (isGroupComponent) {
408
+ let req = false;
409
+ const childsCheckbox = utils.getChildElements(e.target, 'bcm-checkbox:not(#bcm-indeterminate-element)');
410
+ childsCheckbox.length > 0 && (childsCheckbox.forEach((element) => {
411
+ if (element && element.required === true) {
412
+ req = true;
413
+ }
414
+ }));
415
+ target = Object.assign(Object.assign({}, e.target), { required: req });
416
+ }
417
+ else {
418
+ target = e.target;
419
+ }
420
+ const value = e.target.value;
421
+ const wrapperComponent = isWrapperComponent && e.target;
422
+ var isPickerValid;
423
+ if (isWrapperComponent) {
424
+ isPickerValid = await wrapperComponent.isValid();
425
+ }
426
+ const tick = setTimeout(() => {
427
+ if (target.required) {
428
+ let valid = null;
429
+ if (isWrapperComponent) {
430
+ valid = validate.required(value, isPickerValid);
431
+ if (valid) {
432
+ if (value instanceof Object) {
433
+ if (value["isValid"] == false) {
434
+ valid = validate.required("", isPickerValid);
435
+ }
436
+ }
437
+ else {
438
+ valid = validate.required(value, isPickerValid);
439
+ }
440
+ }
441
+ }
442
+ else if (isGroupComponent) {
443
+ const childsCheckbox = utils.getChildElements(e.target, 'bcm-checkbox:not(#bcm-indeterminate-element)');
444
+ childsCheckbox.length > 0 && (childsCheckbox.forEach((element) => {
445
+ if (element && element.required === true) {
446
+ valid = validate.required(element.checked);
447
+ if (!valid['valid']) {
448
+ element.noCaption = false;
449
+ element.captionError = valid['message'];
450
+ element.captionType = valid['type'];
451
+ }
452
+ else {
453
+ element.noCaption = e.target.noCaption;
454
+ element.captionError = null;
455
+ element.captionType = "default";
456
+ }
457
+ }
458
+ }));
459
+ }
460
+ else {
461
+ valid = validate.required(value);
462
+ }
463
+ if (valid['valid']) {
464
+ target.captionError = null;
465
+ target.captionType = null;
466
+ }
467
+ else {
468
+ target.captionError = valid['message'];
469
+ target.captionType = valid['type'];
470
+ }
471
+ }
472
+ clearTimeout(tick);
473
+ });
474
+ this.value = await this.userFormData();
475
+ }
476
+ render() {
477
+ const hostClasses = index$1.classnames(this.hidden ? 'hidden' : null);
478
+ return (index.h(index.Host, { class: hostClasses, tabindex: "-1" }, index.h("form", { class: "bcm-form", autocomplete: this.autocomplete ? "on" : "off", tabindex: "-1" }, index.h("slot", null))));
479
+ }
480
+ get el() { return index.getElement(this); }
481
+ };
482
+ __decorate([
483
+ isLoadDecorator.IsLoad()
484
+ ], BcmForm.prototype, "el", void 0);
485
+ BcmForm.style = formCss;
486
+
487
+ exports.bcm_form = BcmForm;