bromcom-ui 2.7.37-rc.1 → 2.7.37-rc.3

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 (713) hide show
  1. package/dist/bromcom-ui/bromcom-ui.css +1 -1
  2. package/dist/bromcom-ui/bromcom-ui.esm.js +1 -1
  3. package/dist/bromcom-ui/p-00f2b559.entry.js +5 -0
  4. package/dist/bromcom-ui/{p-0e480b7b.entry.js → p-02892da0.entry.js} +1 -1
  5. package/dist/bromcom-ui/p-034cd518.js +5 -0
  6. package/dist/bromcom-ui/{p-cc270a88.entry.js → p-0653fefc.entry.js} +1 -1
  7. package/dist/bromcom-ui/{p-ace65422.entry.js → p-087d371a.entry.js} +1 -1
  8. package/dist/bromcom-ui/{p-1a12fbd0.entry.js → p-0cd7e628.entry.js} +1 -1
  9. package/dist/bromcom-ui/{p-1115af65.entry.js → p-109d49c2.entry.js} +1 -1
  10. package/dist/bromcom-ui/{p-0ba73c30.js → p-10caf4ce.js} +1 -1
  11. package/dist/bromcom-ui/p-11d54517.entry.js +5 -0
  12. package/dist/bromcom-ui/{p-2d3c0790.entry.js → p-1507f99a.entry.js} +1 -1
  13. package/dist/bromcom-ui/{p-83317635.entry.js → p-151d7bec.entry.js} +1 -1
  14. package/dist/bromcom-ui/p-1672aa8b.js +5 -0
  15. package/dist/bromcom-ui/{p-10dfe83e.js → p-27f0db71.js} +1 -1
  16. package/dist/bromcom-ui/p-2b27570e.entry.js +5 -0
  17. package/dist/bromcom-ui/{p-6fe3bfd9.entry.js → p-2b332236.entry.js} +1 -1
  18. package/dist/bromcom-ui/{p-bfb83484.entry.js → p-2b3b55ef.entry.js} +1 -1
  19. package/dist/bromcom-ui/{p-a0352fdd.entry.js → p-2b91dab0.entry.js} +1 -1
  20. package/dist/bromcom-ui/{p-ca13fe84.entry.js → p-2c3c7265.entry.js} +1 -1
  21. package/dist/bromcom-ui/p-2cfa8d1a.js +5 -0
  22. package/dist/bromcom-ui/{p-f69302a8.js → p-30806ec7.js} +1 -1
  23. package/dist/bromcom-ui/{p-cc9ba164.entry.js → p-31bc32d4.entry.js} +1 -1
  24. package/dist/bromcom-ui/{p-20fc8571.entry.js → p-34b815f5.entry.js} +1 -1
  25. package/dist/bromcom-ui/{p-c562e4c2.entry.js → p-34f30b8b.entry.js} +1 -1
  26. package/dist/bromcom-ui/{p-f053ed80.entry.js → p-3716c24c.entry.js} +1 -1
  27. package/dist/bromcom-ui/{p-d11eccc0.entry.js → p-47fa3046.entry.js} +1 -1
  28. package/dist/bromcom-ui/p-49c83e11.entry.js +5 -0
  29. package/dist/bromcom-ui/{p-128a5956.js → p-4be4c5bf.js} +1 -1
  30. package/dist/bromcom-ui/p-522c96a2.js +5 -0
  31. package/dist/bromcom-ui/{p-125213af.entry.js → p-55cce901.entry.js} +1 -1
  32. package/dist/bromcom-ui/{p-8c4b256e.js → p-577cf8e3.js} +1 -1
  33. package/dist/bromcom-ui/{p-7fad995d.entry.js → p-591b3100.entry.js} +1 -1
  34. package/dist/bromcom-ui/{p-23d5fe0b.entry.js → p-609bc368.entry.js} +1 -1
  35. package/dist/bromcom-ui/{p-c7b9b694.entry.js → p-640244fa.entry.js} +1 -1
  36. package/dist/bromcom-ui/{p-e73e6d2b.entry.js → p-65dcaa9e.entry.js} +1 -1
  37. package/dist/bromcom-ui/{p-f9401599.entry.js → p-6768e612.entry.js} +1 -1
  38. package/dist/bromcom-ui/{p-56f22945.entry.js → p-6a3c1fb9.entry.js} +1 -1
  39. package/dist/bromcom-ui/p-6ad01d01.entry.js +5 -0
  40. package/dist/bromcom-ui/{p-de9979a6.entry.js → p-6c12e5dd.entry.js} +1 -1
  41. package/dist/bromcom-ui/{p-173ebc98.entry.js → p-6c7eb43f.entry.js} +1 -1
  42. package/dist/bromcom-ui/{p-9ecacdbb.entry.js → p-751c94dd.entry.js} +1 -1
  43. package/dist/bromcom-ui/{p-1a03334e.entry.js → p-76153673.entry.js} +1 -1
  44. package/dist/bromcom-ui/{p-51f23b60.entry.js → p-78d48636.entry.js} +1 -1
  45. package/dist/bromcom-ui/{p-81927f68.entry.js → p-7b7caea1.entry.js} +1 -1
  46. package/dist/bromcom-ui/{p-eb809fa4.entry.js → p-7c8d47f6.entry.js} +1 -1
  47. package/dist/bromcom-ui/p-7d119b6d.js +5 -0
  48. package/dist/bromcom-ui/p-7df25164.entry.js +5 -0
  49. package/dist/bromcom-ui/{p-5ae0a59b.js → p-7e44e6b5.js} +1 -1
  50. package/dist/bromcom-ui/{p-1c525c05.entry.js → p-7f065a45.entry.js} +1 -1
  51. package/dist/bromcom-ui/{p-603183c2.entry.js → p-8255f60a.entry.js} +1 -1
  52. package/dist/bromcom-ui/{p-7477b927.entry.js → p-82ad3d24.entry.js} +1 -1
  53. package/dist/bromcom-ui/{p-172edb20.entry.js → p-8513e734.entry.js} +1 -1
  54. package/dist/bromcom-ui/p-85d1183b.entry.js +5 -0
  55. package/dist/bromcom-ui/{p-3c7a0345.js → p-8c018ae0.js} +1 -1
  56. package/dist/bromcom-ui/p-99dc108e.entry.js +5 -0
  57. package/dist/bromcom-ui/{p-f4c06b78.entry.js → p-9e8eb647.entry.js} +1 -1
  58. package/dist/bromcom-ui/{p-b9f0114c.entry.js → p-9efe118a.entry.js} +1 -1
  59. package/dist/bromcom-ui/{p-6cda636f.entry.js → p-a04909f2.entry.js} +1 -1
  60. package/dist/bromcom-ui/p-a1c849e7.js +5 -0
  61. package/dist/bromcom-ui/{p-a8d1397d.js → p-a3ffcb0d.js} +1 -1
  62. package/dist/bromcom-ui/{p-d36f9b12.entry.js → p-a59a0361.entry.js} +1 -1
  63. package/dist/bromcom-ui/p-a661a9d5.entry.js +5 -0
  64. package/dist/bromcom-ui/p-a677275e.entry.js +5 -0
  65. package/dist/bromcom-ui/{p-99009fb3.entry.js → p-a98aecdf.entry.js} +1 -1
  66. package/dist/bromcom-ui/{p-5fb75161.entry.js → p-ab3f2735.entry.js} +1 -1
  67. package/dist/bromcom-ui/{p-250f52d3.entry.js → p-ad11bb72.entry.js} +1 -1
  68. package/dist/bromcom-ui/{p-6f5cff36.entry.js → p-b1d1cdb0.entry.js} +1 -1
  69. package/dist/bromcom-ui/{p-dbc48ab6.entry.js → p-b4cbf3bd.entry.js} +1 -1
  70. package/dist/bromcom-ui/p-b9421650.entry.js +5 -0
  71. package/dist/bromcom-ui/{p-236a8be4.entry.js → p-b9983e4b.entry.js} +1 -1
  72. package/dist/bromcom-ui/{p-12c97616.entry.js → p-bf30bf7f.entry.js} +1 -1
  73. package/dist/bromcom-ui/{p-20e22beb.js → p-cd0490e2.js} +1 -1
  74. package/dist/bromcom-ui/p-cd638c37.entry.js +5 -0
  75. package/dist/bromcom-ui/p-ce9f87de.entry.js +5 -0
  76. package/dist/bromcom-ui/p-d18c5524.entry.js +5 -0
  77. package/dist/bromcom-ui/{p-0540bd97.entry.js → p-d9fb53c9.entry.js} +1 -1
  78. package/dist/bromcom-ui/{p-df0a2839.entry.js → p-db7c75ac.entry.js} +1 -1
  79. package/dist/bromcom-ui/p-dbb106a4.entry.js +5 -0
  80. package/dist/bromcom-ui/{p-ac7386a1.entry.js → p-e467d49f.entry.js} +1 -1
  81. package/dist/bromcom-ui/p-e75fa6be.entry.js +5 -0
  82. package/dist/bromcom-ui/{p-1bb1ffce.entry.js → p-ea15e1f4.entry.js} +1 -1
  83. package/dist/bromcom-ui/p-ea9c10c3.js +5 -0
  84. package/dist/bromcom-ui/{p-0baf7808.entry.js → p-f9b0e4d2.entry.js} +1 -1
  85. package/dist/bromcom-ui/{p-be904c55.js → p-f9cb7ae4.js} +1 -1
  86. package/dist/bromcom-ui/{p-1b5695a9.entry.js → p-fa42b2de.entry.js} +1 -1
  87. package/dist/bromcom-ui/{p-c1253548.entry.js → p-fda9a21b.entry.js} +1 -1
  88. package/dist/bromcom-ui/p-fe3e3210.js +5 -0
  89. package/dist/bromcom-ui/{p-515f3937.entry.js → p-fef3003b.entry.js} +1 -1
  90. package/dist/cjs/_commonjsHelpers-bd20f4c0.js +29 -0
  91. package/dist/cjs/bcm-2c51bf0c.js +448 -0
  92. package/dist/cjs/bcm-accordion.cjs.entry.js +85 -0
  93. package/dist/cjs/bcm-alert.cjs.entry.js +112 -0
  94. package/dist/cjs/bcm-attendance.cjs.entry.js +50 -0
  95. package/dist/cjs/bcm-autocomplete.cjs.entry.js +155 -0
  96. package/dist/cjs/bcm-avatar_2.cjs.entry.js +156 -0
  97. package/dist/cjs/bcm-box.cjs.entry.js +35 -0
  98. package/dist/cjs/bcm-breadcrumb.cjs.entry.js +67 -0
  99. package/dist/cjs/bcm-button-group.cjs.entry.js +102 -0
  100. package/dist/cjs/bcm-button_4.cjs.entry.js +997 -0
  101. package/dist/cjs/bcm-card.cjs.entry.js +76 -0
  102. package/dist/cjs/bcm-checkbox-group.cjs.entry.js +409 -0
  103. package/dist/cjs/bcm-checkbox-lite_9.cjs.entry.js +2570 -0
  104. package/dist/cjs/bcm-checkbox_2.cjs.entry.js +203 -0
  105. package/dist/cjs/bcm-chip.cjs.entry.js +70 -0
  106. package/dist/cjs/bcm-collapse-group.cjs.entry.js +57 -0
  107. package/dist/cjs/bcm-collapse.cjs.entry.js +58 -0
  108. package/dist/cjs/bcm-colorpicker.cjs.entry.js +433 -0
  109. package/dist/cjs/bcm-date-picker.cjs.entry.js +171 -0
  110. package/dist/cjs/bcm-datetime-picker.cjs.entry.js +1432 -0
  111. package/dist/cjs/bcm-default.cjs.entry.js +40 -0
  112. package/dist/cjs/bcm-drawer.cjs.entry.js +111 -0
  113. package/dist/cjs/bcm-dropdown.cjs.entry.js +239 -0
  114. package/dist/cjs/bcm-error-layout.cjs.entry.js +78 -0
  115. package/dist/cjs/bcm-expansion-panel.cjs.entry.js +127 -0
  116. package/dist/cjs/bcm-form-2.cjs.entry.js +206 -0
  117. package/dist/cjs/bcm-form-group.cjs.entry.js +45 -0
  118. package/dist/cjs/bcm-input.cjs.entry.js +325 -0
  119. package/dist/cjs/bcm-item.cjs.entry.js +83 -0
  120. package/dist/cjs/bcm-items.cjs.entry.js +61 -0
  121. package/dist/cjs/bcm-label_2.cjs.entry.js +119 -0
  122. package/dist/cjs/bcm-link.cjs.entry.js +62 -0
  123. package/dist/cjs/bcm-linked.cjs.entry.js +179 -0
  124. package/dist/cjs/bcm-list.cjs.entry.js +1768 -0
  125. package/dist/cjs/bcm-menu.cjs.entry.js +248 -0
  126. package/dist/cjs/bcm-message.cjs.entry.js +99 -0
  127. package/dist/cjs/bcm-notification.cjs.entry.js +103 -0
  128. package/dist/cjs/bcm-old-input.cjs.entry.js +398 -0
  129. package/dist/cjs/bcm-old-tag_2.cjs.entry.js +157 -0
  130. package/dist/cjs/bcm-popconfirm-box.cjs.entry.js +122 -0
  131. package/dist/cjs/bcm-popconfirm.cjs.entry.js +112 -0
  132. package/dist/cjs/bcm-popover.cjs.entry.js +182 -0
  133. package/dist/cjs/bcm-progress.cjs.entry.js +174 -0
  134. package/dist/cjs/bcm-radio-group.cjs.entry.js +267 -0
  135. package/dist/cjs/bcm-radio.cjs.entry.js +104 -0
  136. package/dist/cjs/bcm-range.cjs.entry.js +189 -0
  137. package/dist/cjs/bcm-result.cjs.entry.js +79 -0
  138. package/dist/cjs/bcm-search.cjs.entry.js +256 -0
  139. package/dist/cjs/bcm-select-group.cjs.entry.js +31 -0
  140. package/dist/cjs/bcm-select-option.cjs.entry.js +37 -0
  141. package/dist/cjs/bcm-select.cjs.entry.js +1198 -0
  142. package/dist/cjs/bcm-skeleton.cjs.entry.js +56 -0
  143. package/dist/cjs/bcm-step.cjs.entry.js +93 -0
  144. package/dist/cjs/bcm-stepper.cjs.entry.js +211 -0
  145. package/dist/cjs/bcm-switch.cjs.entry.js +139 -0
  146. package/dist/cjs/bcm-tab-group.cjs.entry.js +172 -0
  147. package/dist/cjs/bcm-tab-pane.cjs.entry.js +70 -0
  148. package/dist/cjs/bcm-tab.cjs.entry.js +89 -0
  149. package/dist/cjs/bcm-table.cjs.entry.js +78 -0
  150. package/dist/cjs/bcm-tabs-content.cjs.entry.js +62 -0
  151. package/dist/cjs/bcm-tabs.cjs.entry.js +390 -0
  152. package/dist/cjs/bcm-tag.cjs.entry.js +101 -0
  153. package/dist/cjs/bcm-text.cjs.entry.js +60 -0
  154. package/dist/cjs/bcm-textarea.cjs.entry.js +150 -0
  155. package/dist/cjs/bcm-time-picker.cjs.entry.js +139 -0
  156. package/dist/cjs/bcm-timeline-item.cjs.entry.js +55 -0
  157. package/dist/cjs/bcm-timeline.cjs.entry.js +73 -0
  158. package/dist/cjs/bcm-treeview-group.cjs.entry.js +23 -0
  159. package/dist/cjs/bromcom-ui.cjs.js +24 -0
  160. package/dist/cjs/caption-template-954d34bc.js +34 -0
  161. package/dist/cjs/color-helper-c9882bd8.js +490 -0
  162. package/dist/cjs/colors-56282b00.js +224 -0
  163. package/dist/cjs/datetime-helper-eaf4fadb.js +11 -0
  164. package/dist/cjs/element-dragger-a8562f82.js +279 -0
  165. package/dist/cjs/floating-ui-dae608ba.js +1455 -0
  166. package/dist/cjs/generate-9444aa87.js +203 -0
  167. package/dist/cjs/global-b0d21446.js +15 -0
  168. package/dist/cjs/index-9d98aa56.js +1864 -0
  169. package/dist/cjs/index-a2b50e51.js +64 -0
  170. package/dist/cjs/index-f8547ecd.js +193 -0
  171. package/dist/cjs/index.cjs.js +6 -0
  172. package/dist/cjs/input-template-623d767d.js +86 -0
  173. package/dist/cjs/is-load-decorator-65755a67.js +56 -0
  174. package/dist/cjs/json-parse-decarator-e39af071.js +40 -0
  175. package/dist/cjs/label-template-1ed6a569.js +23 -0
  176. package/dist/cjs/loader.cjs.js +26 -0
  177. package/dist/cjs/number-helper-ba5aa459.js +20 -0
  178. package/dist/cjs/old-bcm-popover-box.cjs.entry.js +161 -0
  179. package/dist/cjs/old-bcm-popover.cjs.entry.js +104 -0
  180. package/dist/cjs/popover-placement-87901bb3.js +98 -0
  181. package/dist/cjs/property-decorators-cb2155ed.js +33 -0
  182. package/dist/cjs/slot-template-2ff0d22a.js +15 -0
  183. package/dist/cjs/stepper-states-46c5f64b.js +83 -0
  184. package/dist/cjs/string-helper-df40a475.js +134 -0
  185. package/dist/cjs/tooltip-helper-5442af2e.js +104 -0
  186. package/dist/cjs/types-3871235f.js +32 -0
  187. package/dist/cjs/types-6eb7e028.js +32 -0
  188. package/dist/cjs/types-cc4adee7.js +19 -0
  189. package/dist/cjs/utils-fc077139.js +131 -0
  190. package/dist/cjs/validators-e45ced35.js +33 -0
  191. package/dist/collection/collection-manifest.json +95 -0
  192. package/dist/collection/components/atoms/avatar/avatar.css +448 -0
  193. package/dist/collection/components/atoms/avatar/avatar.js +259 -0
  194. package/dist/collection/components/atoms/badge/badge.css +481 -0
  195. package/dist/collection/components/atoms/badge/badge.js +224 -0
  196. package/dist/collection/components/atoms/box/box.js +23 -0
  197. package/dist/collection/components/atoms/button/button.css +652 -0
  198. package/dist/collection/components/atoms/button/button.js +527 -0
  199. package/dist/collection/components/atoms/button/types.js +170 -0
  200. package/dist/collection/components/atoms/chip/chip.css +453 -0
  201. package/dist/collection/components/atoms/chip/chip.js +187 -0
  202. package/dist/collection/components/atoms/divider/divider.css +142 -0
  203. package/dist/collection/components/atoms/divider/divider.js +83 -0
  204. package/dist/collection/components/atoms/icon/icon.css +127 -0
  205. package/dist/collection/components/atoms/icon/icon.js +70 -0
  206. package/dist/collection/components/atoms/label/label.css +408 -0
  207. package/dist/collection/components/atoms/label/label.js +216 -0
  208. package/dist/collection/components/atoms/link/link.css +419 -0
  209. package/dist/collection/components/atoms/link/link.js +176 -0
  210. package/dist/collection/components/atoms/states/button.states.js +31 -0
  211. package/dist/collection/components/atoms/tag/tag.js +334 -0
  212. package/dist/collection/components/atoms/tag/types.js +30 -0
  213. package/dist/collection/components/atoms/typography/typography.js +23 -0
  214. package/dist/collection/components/molecules/accordion/accordion.css +127 -0
  215. package/dist/collection/components/molecules/accordion/accordion.js +129 -0
  216. package/dist/collection/components/molecules/alert/alert.css +191 -0
  217. package/dist/collection/components/molecules/alert/alert.js +298 -0
  218. package/dist/collection/components/molecules/alert/types.js +23 -0
  219. package/dist/collection/components/molecules/breadcrumb/breadcrumb.css +201 -0
  220. package/dist/collection/components/molecules/breadcrumb/breadcrumb.js +155 -0
  221. package/dist/collection/components/molecules/breadcrumb/types.js +5 -0
  222. package/dist/collection/components/molecules/button-group/button-group.css +423 -0
  223. package/dist/collection/components/molecules/button-group/button-group.js +235 -0
  224. package/dist/collection/components/molecules/card/card.css +408 -0
  225. package/dist/collection/components/molecules/card/card.js +128 -0
  226. package/dist/collection/components/molecules/checkbox/checkbox-lite.js +237 -0
  227. package/dist/collection/components/molecules/checkbox/checkbox.css +1280 -0
  228. package/dist/collection/components/molecules/checkbox/checkbox.js +688 -0
  229. package/dist/collection/components/molecules/checkbox/group.css +156 -0
  230. package/dist/collection/components/molecules/checkbox/group.js +779 -0
  231. package/dist/collection/components/molecules/drawer/drawer.css +502 -0
  232. package/dist/collection/components/molecules/drawer/drawer.js +272 -0
  233. package/dist/collection/components/molecules/dropdown/dropdown.css +419 -0
  234. package/dist/collection/components/molecules/dropdown/dropdown.js +857 -0
  235. package/dist/collection/components/molecules/empty/empty.js +44 -0
  236. package/dist/collection/components/molecules/error-layout/error-layout.css +396 -0
  237. package/dist/collection/components/molecules/error-layout/error-layout.js +177 -0
  238. package/dist/collection/components/molecules/error-layout/types.js +5 -0
  239. package/dist/collection/components/molecules/expansion-panel/expansion-panel.css +488 -0
  240. package/dist/collection/components/molecules/expansion-panel/expansion-panel.js +322 -0
  241. package/dist/collection/components/molecules/input/input.css +1208 -0
  242. package/dist/collection/components/molecules/input/input.js +1171 -0
  243. package/dist/collection/components/molecules/input/types.js +17 -0
  244. package/dist/collection/components/molecules/item/item.css +446 -0
  245. package/dist/collection/components/molecules/item/item.js +151 -0
  246. package/dist/collection/components/molecules/items/items.js +84 -0
  247. package/dist/collection/components/molecules/linked/linked.js +410 -0
  248. package/dist/collection/components/molecules/menu/menu.css +718 -0
  249. package/dist/collection/components/molecules/menu/menu.js +623 -0
  250. package/dist/collection/components/molecules/message/message.css +165 -0
  251. package/dist/collection/components/molecules/message/message.js +222 -0
  252. package/dist/collection/components/molecules/message/types.js +14 -0
  253. package/dist/collection/components/molecules/modal/modal.css +526 -0
  254. package/dist/collection/components/molecules/modal/modal.js +374 -0
  255. package/dist/collection/components/molecules/notification/notification.css +183 -0
  256. package/dist/collection/components/molecules/notification/notification.js +244 -0
  257. package/dist/collection/components/molecules/notification/types.js +15 -0
  258. package/dist/collection/components/molecules/popconfirm/popconfirm-box.css +563 -0
  259. package/dist/collection/components/molecules/popconfirm/popconfirm-box.js +396 -0
  260. package/dist/collection/components/molecules/popconfirm/popconfirm.css +127 -0
  261. package/dist/collection/components/molecules/popconfirm/popconfirm.js +382 -0
  262. package/dist/collection/components/molecules/popover/popover.js +254 -0
  263. package/dist/collection/components/molecules/progress/progress.css +486 -0
  264. package/dist/collection/components/molecules/progress/progress.js +404 -0
  265. package/dist/collection/components/molecules/progress/types.js +28 -0
  266. package/dist/collection/components/molecules/radio/group.css +798 -0
  267. package/dist/collection/components/molecules/radio/group.js +652 -0
  268. package/dist/collection/components/molecules/radio/radio.css +1280 -0
  269. package/dist/collection/components/molecules/radio/radio.js +291 -0
  270. package/dist/collection/components/molecules/radio/types.js +30 -0
  271. package/dist/collection/components/molecules/range/range.css +570 -0
  272. package/dist/collection/components/molecules/range/range.js +472 -0
  273. package/dist/collection/components/molecules/result/result.css +164 -0
  274. package/dist/collection/components/molecules/result/result.js +143 -0
  275. package/dist/collection/components/molecules/result/types.js +22 -0
  276. package/dist/collection/components/molecules/search/search.css +1208 -0
  277. package/dist/collection/components/molecules/search/search.js +406 -0
  278. package/dist/collection/components/molecules/skeleton/skeleton.js +94 -0
  279. package/dist/collection/components/molecules/states/alert.states.js +25 -0
  280. package/dist/collection/components/molecules/states/checkbox-group.states.js +199 -0
  281. package/dist/collection/components/molecules/states/radio-group.states.js +107 -0
  282. package/dist/collection/components/molecules/states/search.states.js +137 -0
  283. package/dist/collection/components/molecules/states/stepper-states.js +79 -0
  284. package/dist/collection/components/molecules/stepper/step.js +346 -0
  285. package/dist/collection/components/molecules/stepper/stepper.css +617 -0
  286. package/dist/collection/components/molecules/stepper/stepper.js +484 -0
  287. package/dist/collection/components/molecules/switch/switch.css +1272 -0
  288. package/dist/collection/components/molecules/switch/switch.js +716 -0
  289. package/dist/collection/components/molecules/tab-group/tab-group.js +280 -0
  290. package/dist/collection/components/molecules/textarea/textarea.css +1208 -0
  291. package/dist/collection/components/molecules/textarea/textarea.js +731 -0
  292. package/dist/collection/components/molecules/textarea/types.js +13 -0
  293. package/dist/collection/components/molecules/timeline/timeline-item.css +254 -0
  294. package/dist/collection/components/molecules/timeline/timeline-item.js +159 -0
  295. package/dist/collection/components/molecules/timeline/timeline.css +205 -0
  296. package/dist/collection/components/molecules/timeline/timeline.js +125 -0
  297. package/dist/collection/components/molecules/tooltip/tooltip.js +232 -0
  298. package/dist/collection/components/organism/autocomplete/autocomplete.css +168 -0
  299. package/dist/collection/components/organism/autocomplete/autocomplete.js +399 -0
  300. package/dist/collection/components/organism/colorpicker/colorpicker.css +313 -0
  301. package/dist/collection/components/organism/colorpicker/colorpicker.js +774 -0
  302. package/dist/collection/components/organism/colorpicker/static/chess.png +0 -0
  303. package/dist/collection/components/organism/colorpicker/static/color.svg +14 -0
  304. package/dist/collection/components/organism/colorpicker/static/colors.svg +16 -0
  305. package/dist/collection/components/organism/date-picker/date-picker.css +141 -0
  306. package/dist/collection/components/organism/date-picker/date-picker.js +780 -0
  307. package/dist/collection/components/organism/datetime-picker/datetime-picker.css +1429 -0
  308. package/dist/collection/components/organism/datetime-picker/datetime-picker.js +2166 -0
  309. package/dist/collection/components/organism/datetime-picker/types.js +39 -0
  310. package/dist/collection/components/organism/form/form-group.css +131 -0
  311. package/dist/collection/components/organism/form/form-group.js +131 -0
  312. package/dist/collection/components/organism/form/form.css +132 -0
  313. package/dist/collection/components/organism/form/form.js +680 -0
  314. package/dist/collection/components/organism/form-2/bcm-form-components.js +26 -0
  315. package/dist/collection/components/organism/form-2/form-2.css +127 -0
  316. package/dist/collection/components/organism/form-2/form-2.js +329 -0
  317. package/dist/collection/components/organism/list/list-key-control.js +125 -0
  318. package/dist/collection/components/organism/list/list-tag-control.js +172 -0
  319. package/dist/collection/components/organism/list/list.css +2047 -0
  320. package/dist/collection/components/organism/list/list.js +1894 -0
  321. package/dist/collection/components/organism/states/bcm-list2.states.js +532 -0
  322. package/dist/collection/components/organism/time-picker/time-picker.css +141 -0
  323. package/dist/collection/components/organism/time-picker/time-picker.js +627 -0
  324. package/dist/collection/components/other/attendance/attendance.css +433 -0
  325. package/dist/collection/components/other/attendance/attendance.js +87 -0
  326. package/dist/collection/components/other/data-table/table.css +130 -0
  327. package/dist/collection/components/other/data-table/table.js +92 -0
  328. package/dist/collection/components/other/default/default.css +127 -0
  329. package/dist/collection/components/other/default/default.js +54 -0
  330. package/dist/collection/components/other_deprecated/collapse/collapse.css +177 -0
  331. package/dist/collection/components/other_deprecated/collapse/collapse.js +163 -0
  332. package/dist/collection/components/other_deprecated/collapse/group.js +128 -0
  333. package/dist/collection/components/other_deprecated/listbox/listbox-group.css +139 -0
  334. package/dist/collection/components/other_deprecated/listbox/listbox-group.js +93 -0
  335. package/dist/collection/components/other_deprecated/listbox/listbox-item.css +269 -0
  336. package/dist/collection/components/other_deprecated/listbox/listbox-item.js +641 -0
  337. package/dist/collection/components/other_deprecated/listbox/listbox.css +365 -0
  338. package/dist/collection/components/other_deprecated/listbox/listbox.js +1999 -0
  339. package/dist/collection/components/other_deprecated/listbox/types.js +11 -0
  340. package/dist/collection/components/other_deprecated/old-input/old-input.css +1360 -0
  341. package/dist/collection/components/other_deprecated/old-input/old-input.js +1154 -0
  342. package/dist/collection/components/other_deprecated/old-input/types.js +17 -0
  343. package/dist/collection/components/other_deprecated/old-popover/old-popover-box.css +582 -0
  344. package/dist/collection/components/other_deprecated/old-popover/old-popover-box.js +422 -0
  345. package/dist/collection/components/other_deprecated/old-popover/old-popover.css +127 -0
  346. package/dist/collection/components/other_deprecated/old-popover/old-popover.js +296 -0
  347. package/dist/collection/components/other_deprecated/old-search/old-search.css +131 -0
  348. package/dist/collection/components/other_deprecated/old-search/old-search.js +496 -0
  349. package/dist/collection/components/other_deprecated/old-tag/old-tag.css +305 -0
  350. package/dist/collection/components/other_deprecated/old-tag/old-tag.js +326 -0
  351. package/dist/collection/components/other_deprecated/old-tag/types.js +30 -0
  352. package/dist/collection/components/other_deprecated/select/group.css +144 -0
  353. package/dist/collection/components/other_deprecated/select/group.js +88 -0
  354. package/dist/collection/components/other_deprecated/select/option.css +164 -0
  355. package/dist/collection/components/other_deprecated/select/option.js +142 -0
  356. package/dist/collection/components/other_deprecated/select/select-box.css +143 -0
  357. package/dist/collection/components/other_deprecated/select/select-box.js +104 -0
  358. package/dist/collection/components/other_deprecated/select/select.css +364 -0
  359. package/dist/collection/components/other_deprecated/select/select.js +2281 -0
  360. package/dist/collection/components/other_deprecated/tabs/tab-pane.css +142 -0
  361. package/dist/collection/components/other_deprecated/tabs/tab-pane.js +168 -0
  362. package/dist/collection/components/other_deprecated/tabs/tab.css +587 -0
  363. package/dist/collection/components/other_deprecated/tabs/tab.js +303 -0
  364. package/dist/collection/components/other_deprecated/tabs/tabs-content.css +136 -0
  365. package/dist/collection/components/other_deprecated/tabs/tabs-content.js +147 -0
  366. package/dist/collection/components/other_deprecated/tabs/tabs.css +212 -0
  367. package/dist/collection/components/other_deprecated/tabs/tabs.js +806 -0
  368. package/dist/collection/components/other_deprecated/tabs/types.js +30 -0
  369. package/dist/collection/components/other_deprecated/text/text.css +429 -0
  370. package/dist/collection/components/other_deprecated/text/text.js +159 -0
  371. package/dist/collection/components/other_deprecated/treeview/treeview-group.css +0 -0
  372. package/dist/collection/components/other_deprecated/treeview/treeview-group.js +18 -0
  373. package/dist/collection/components/other_deprecated/treeview/treeview-item.css +318 -0
  374. package/dist/collection/components/other_deprecated/treeview/treeview-item.js +977 -0
  375. package/dist/collection/components/other_deprecated/treeview/treeview.css +190 -0
  376. package/dist/collection/components/other_deprecated/treeview/treeview.js +1699 -0
  377. package/dist/collection/components/other_deprecated/treeview/types.js +11 -0
  378. package/dist/collection/decorators/id-decorator.js +18 -0
  379. package/dist/collection/decorators/index.js +8 -0
  380. package/dist/collection/decorators/is-load-decorator.js +51 -0
  381. package/dist/collection/decorators/json-parse-decarator.js +35 -0
  382. package/dist/collection/decorators/property-decorators.js +28 -0
  383. package/dist/collection/global/components/_checkbox.css +627 -0
  384. package/dist/collection/global/config.js +45 -0
  385. package/dist/collection/global/global.js +43 -0
  386. package/dist/collection/global/variables/colors.js +220 -0
  387. package/dist/collection/helper/color-helper.js +81 -0
  388. package/dist/collection/helper/datetime-helper.js +7 -0
  389. package/dist/collection/helper/generate.js +168 -0
  390. package/dist/collection/helper/index.js +12 -0
  391. package/dist/collection/helper/number-helper.js +15 -0
  392. package/dist/collection/helper/popover-helper.js +106 -0
  393. package/dist/collection/helper/string-helper.js +65 -0
  394. package/dist/collection/helper/tooltip-helper.js +95 -0
  395. package/dist/collection/helper/validators.js +28 -0
  396. package/dist/collection/index.js +5 -0
  397. package/dist/collection/models/abstract-classes/abstract-key-control.js +97 -0
  398. package/dist/collection/models/bcm-types.js +5 -0
  399. package/dist/collection/models/bcm.js +466 -0
  400. package/dist/collection/models/index.js +6 -0
  401. package/dist/collection/models/states/atoms/bcm-atoms-state.js +5 -0
  402. package/dist/collection/models/states/molecules/bcm-molecules-state.js +5 -0
  403. package/dist/collection/models/states/organisms/bcm-organisms-state.js +5 -0
  404. package/dist/collection/templates/button-template.js +22 -0
  405. package/dist/collection/templates/caption-template.js +29 -0
  406. package/dist/collection/templates/checkbox-group-template.js +10 -0
  407. package/dist/collection/templates/checkbox-template.js +31 -0
  408. package/dist/collection/templates/icon-template.js +24 -0
  409. package/dist/collection/templates/index.js +17 -0
  410. package/dist/collection/templates/info-footer-template.js +16 -0
  411. package/dist/collection/templates/input-template.js +81 -0
  412. package/dist/collection/templates/label-template.js +18 -0
  413. package/dist/collection/templates/list-item-template.js +58 -0
  414. package/dist/collection/templates/list-template.js +24 -0
  415. package/dist/collection/templates/slot-template.js +10 -0
  416. package/dist/collection/templates/step-template.js +26 -0
  417. package/dist/collection/templates/tag-template.js +45 -0
  418. package/dist/collection/types/index.js +5 -0
  419. package/dist/collection/utils/element-dragger.js +274 -0
  420. package/dist/collection/utils/floating-ui.js +95 -0
  421. package/dist/collection/utils/index.js +9 -0
  422. package/dist/collection/utils/popover-placement.js +96 -0
  423. package/dist/collection/utils/utils.js +223 -0
  424. package/dist/collection/utils/validation.js +47 -0
  425. package/dist/esm/_commonjsHelpers-3016b722.js +25 -0
  426. package/dist/esm/bcm-accordion.entry.js +81 -0
  427. package/dist/esm/bcm-alert.entry.js +108 -0
  428. package/dist/esm/bcm-attendance.entry.js +46 -0
  429. package/dist/esm/bcm-autocomplete.entry.js +151 -0
  430. package/dist/esm/bcm-avatar_2.entry.js +151 -0
  431. package/dist/esm/bcm-b8d8a236.js +446 -0
  432. package/dist/esm/bcm-box.entry.js +31 -0
  433. package/dist/esm/bcm-breadcrumb.entry.js +63 -0
  434. package/dist/esm/bcm-button-group.entry.js +98 -0
  435. package/dist/esm/bcm-button_4.entry.js +990 -0
  436. package/dist/esm/bcm-card.entry.js +72 -0
  437. package/dist/esm/bcm-checkbox-group.entry.js +405 -0
  438. package/dist/esm/bcm-checkbox-lite_9.entry.js +2558 -0
  439. package/dist/esm/bcm-checkbox_2.entry.js +198 -0
  440. package/dist/esm/bcm-chip.entry.js +66 -0
  441. package/dist/esm/bcm-collapse-group.entry.js +53 -0
  442. package/dist/esm/bcm-collapse.entry.js +54 -0
  443. package/dist/esm/bcm-colorpicker.entry.js +429 -0
  444. package/dist/esm/bcm-date-picker.entry.js +167 -0
  445. package/dist/esm/bcm-datetime-picker.entry.js +1428 -0
  446. package/dist/esm/bcm-default.entry.js +36 -0
  447. package/dist/esm/bcm-drawer.entry.js +107 -0
  448. package/dist/esm/bcm-dropdown.entry.js +235 -0
  449. package/dist/esm/bcm-error-layout.entry.js +74 -0
  450. package/dist/esm/bcm-expansion-panel.entry.js +123 -0
  451. package/dist/esm/bcm-form-2.entry.js +202 -0
  452. package/dist/esm/bcm-form-group.entry.js +41 -0
  453. package/dist/esm/bcm-input.entry.js +321 -0
  454. package/dist/esm/bcm-item.entry.js +79 -0
  455. package/dist/esm/bcm-items.entry.js +57 -0
  456. package/dist/esm/bcm-label_2.entry.js +114 -0
  457. package/dist/esm/bcm-link.entry.js +58 -0
  458. package/dist/esm/bcm-linked.entry.js +175 -0
  459. package/dist/esm/bcm-list.entry.js +1764 -0
  460. package/dist/esm/bcm-menu.entry.js +244 -0
  461. package/dist/esm/bcm-message.entry.js +95 -0
  462. package/dist/esm/bcm-notification.entry.js +99 -0
  463. package/dist/esm/bcm-old-input.entry.js +394 -0
  464. package/dist/esm/bcm-old-tag_2.entry.js +152 -0
  465. package/dist/esm/bcm-popconfirm-box.entry.js +118 -0
  466. package/dist/esm/bcm-popconfirm.entry.js +108 -0
  467. package/dist/esm/bcm-popover.entry.js +178 -0
  468. package/dist/esm/bcm-progress.entry.js +170 -0
  469. package/dist/esm/bcm-radio-group.entry.js +263 -0
  470. package/dist/esm/bcm-radio.entry.js +100 -0
  471. package/dist/esm/bcm-range.entry.js +185 -0
  472. package/dist/esm/bcm-result.entry.js +75 -0
  473. package/dist/esm/bcm-search.entry.js +252 -0
  474. package/dist/esm/bcm-select-group.entry.js +27 -0
  475. package/dist/esm/bcm-select-option.entry.js +33 -0
  476. package/dist/esm/bcm-select.entry.js +1194 -0
  477. package/dist/esm/bcm-skeleton.entry.js +52 -0
  478. package/dist/esm/bcm-step.entry.js +89 -0
  479. package/dist/esm/bcm-stepper.entry.js +207 -0
  480. package/dist/esm/bcm-switch.entry.js +135 -0
  481. package/dist/esm/bcm-tab-group.entry.js +168 -0
  482. package/dist/esm/bcm-tab-pane.entry.js +66 -0
  483. package/dist/esm/bcm-tab.entry.js +85 -0
  484. package/dist/esm/bcm-table.entry.js +74 -0
  485. package/dist/esm/bcm-tabs-content.entry.js +58 -0
  486. package/dist/esm/bcm-tabs.entry.js +386 -0
  487. package/dist/esm/bcm-tag.entry.js +97 -0
  488. package/dist/esm/bcm-text.entry.js +56 -0
  489. package/dist/esm/bcm-textarea.entry.js +146 -0
  490. package/dist/esm/bcm-time-picker.entry.js +135 -0
  491. package/dist/esm/bcm-timeline-item.entry.js +51 -0
  492. package/dist/esm/bcm-timeline.entry.js +69 -0
  493. package/dist/esm/bcm-treeview-group.entry.js +19 -0
  494. package/dist/esm/bromcom-ui.js +22 -0
  495. package/dist/esm/caption-template-d54ee0c3.js +32 -0
  496. package/dist/esm/color-helper-7e202fd8.js +488 -0
  497. package/dist/esm/colors-1d7854ea.js +222 -0
  498. package/dist/esm/datetime-helper-df25808a.js +9 -0
  499. package/dist/esm/element-dragger-89bb52fd.js +277 -0
  500. package/dist/esm/floating-ui-f03a96ce.js +1453 -0
  501. package/dist/esm/generate-d57a5f95.js +200 -0
  502. package/dist/esm/global-4fad925b.js +13 -0
  503. package/dist/esm/index-2a3eeccc.js +1833 -0
  504. package/dist/esm/index-6e950253.js +191 -0
  505. package/dist/esm/index-ba2edd32.js +62 -0
  506. package/dist/esm/index.js +4 -0
  507. package/dist/esm/input-template-2044f4f6.js +84 -0
  508. package/dist/esm/is-load-decorator-b990575a.js +54 -0
  509. package/dist/esm/json-parse-decarator-50541a21.js +38 -0
  510. package/dist/esm/label-template-e3eebfbc.js +21 -0
  511. package/dist/esm/loader.js +22 -0
  512. package/dist/esm/number-helper-75d21178.js +18 -0
  513. package/dist/esm/old-bcm-popover-box.entry.js +157 -0
  514. package/dist/esm/old-bcm-popover.entry.js +100 -0
  515. package/dist/esm/polyfills/core-js.js +11 -0
  516. package/dist/esm/polyfills/css-shim.js +1 -0
  517. package/dist/esm/polyfills/dom.js +79 -0
  518. package/dist/esm/polyfills/es5-html-element.js +1 -0
  519. package/dist/esm/polyfills/index.js +34 -0
  520. package/dist/esm/polyfills/system.js +6 -0
  521. package/dist/esm/popover-placement-9864294b.js +95 -0
  522. package/dist/esm/property-decorators-f3f1e7de.js +31 -0
  523. package/dist/esm/slot-template-877c4e01.js +13 -0
  524. package/dist/esm/stepper-states-9f66e2b4.js +81 -0
  525. package/dist/esm/string-helper-74a1648f.js +132 -0
  526. package/dist/esm/tooltip-helper-bed79484.js +102 -0
  527. package/dist/esm/types-6f06fa1a.js +19 -0
  528. package/dist/esm/types-b211a5eb.js +32 -0
  529. package/dist/esm/types-bfc3bba1.js +32 -0
  530. package/dist/esm/utils-57652744.js +123 -0
  531. package/dist/esm/validators-6af629b4.js +31 -0
  532. package/dist/index.cjs.js +1 -0
  533. package/dist/index.js +1 -0
  534. package/dist/types/components/atoms/avatar/avatar.d.ts +23 -0
  535. package/dist/types/components/atoms/badge/badge.d.ts +17 -0
  536. package/dist/types/components/atoms/box/box.d.ts +5 -0
  537. package/dist/types/components/atoms/button/button.d.ts +33 -0
  538. package/dist/types/components/atoms/button/types.d.ts +166 -0
  539. package/dist/types/components/atoms/chip/chip.d.ts +24 -0
  540. package/dist/types/components/atoms/divider/divider.d.ts +7 -0
  541. package/dist/types/components/atoms/icon/icon.d.ts +6 -0
  542. package/dist/types/components/atoms/label/label.d.ts +16 -0
  543. package/dist/types/components/atoms/link/link.d.ts +13 -0
  544. package/dist/types/components/atoms/states/button.states.d.ts +7 -0
  545. package/dist/types/components/atoms/tag/tag.d.ts +24 -0
  546. package/dist/types/components/atoms/tag/types.d.ts +29 -0
  547. package/dist/types/components/atoms/typography/typography.d.ts +5 -0
  548. package/dist/types/components/molecules/accordion/accordion.d.ts +11 -0
  549. package/dist/types/components/molecules/alert/alert.d.ts +21 -0
  550. package/dist/types/components/molecules/alert/types.d.ts +25 -0
  551. package/dist/types/components/molecules/breadcrumb/breadcrumb.d.ts +14 -0
  552. package/dist/types/components/molecules/breadcrumb/types.d.ts +10 -0
  553. package/dist/types/components/molecules/button-group/button-group.d.ts +21 -0
  554. package/dist/types/components/molecules/card/card.d.ts +11 -0
  555. package/dist/types/components/molecules/checkbox/checkbox-lite.d.ts +14 -0
  556. package/dist/types/components/molecules/checkbox/checkbox.d.ts +56 -0
  557. package/dist/types/components/molecules/checkbox/group.d.ts +56 -0
  558. package/dist/types/components/molecules/drawer/drawer.d.ts +21 -0
  559. package/dist/types/components/molecules/dropdown/dropdown.d.ts +55 -0
  560. package/dist/types/components/molecules/empty/empty.d.ts +5 -0
  561. package/dist/types/components/molecules/error-layout/error-layout.d.ts +25 -0
  562. package/dist/types/components/molecules/error-layout/types.d.ts +4 -0
  563. package/dist/types/components/molecules/expansion-panel/expansion-panel.d.ts +31 -0
  564. package/dist/types/components/molecules/input/input.d.ts +82 -0
  565. package/dist/types/components/molecules/input/types.d.ts +13 -0
  566. package/dist/types/components/molecules/item/item.d.ts +13 -0
  567. package/dist/types/components/molecules/items/items.d.ts +10 -0
  568. package/dist/types/components/molecules/linked/linked.d.ts +30 -0
  569. package/dist/types/components/molecules/menu/menu.d.ts +41 -0
  570. package/dist/types/components/molecules/message/message.d.ts +32 -0
  571. package/dist/types/components/molecules/message/types.d.ts +13 -0
  572. package/dist/types/components/molecules/modal/modal.d.ts +25 -0
  573. package/dist/types/components/molecules/notification/notification.d.ts +42 -0
  574. package/dist/types/components/molecules/notification/types.d.ts +14 -0
  575. package/dist/types/components/molecules/popconfirm/popconfirm-box.d.ts +29 -0
  576. package/dist/types/components/molecules/popconfirm/popconfirm.d.ts +28 -0
  577. package/dist/types/components/molecules/popover/popover.d.ts +20 -0
  578. package/dist/types/components/molecules/progress/progress.d.ts +25 -0
  579. package/dist/types/components/molecules/progress/types.d.ts +14 -0
  580. package/dist/types/components/molecules/radio/group.d.ts +54 -0
  581. package/dist/types/components/molecules/radio/radio.d.ts +21 -0
  582. package/dist/types/components/molecules/radio/types.d.ts +29 -0
  583. package/dist/types/components/molecules/range/range.d.ts +36 -0
  584. package/dist/types/components/molecules/result/result.d.ts +13 -0
  585. package/dist/types/components/molecules/result/types.d.ts +19 -0
  586. package/dist/types/components/molecules/search/search.d.ts +35 -0
  587. package/dist/types/components/molecules/skeleton/skeleton.d.ts +8 -0
  588. package/dist/types/components/molecules/states/alert.states.d.ts +7 -0
  589. package/dist/types/components/molecules/states/checkbox-group.states.d.ts +53 -0
  590. package/dist/types/components/molecules/states/radio-group.states.d.ts +48 -0
  591. package/dist/types/components/molecules/states/search.states.d.ts +14 -0
  592. package/dist/types/components/molecules/states/stepper-states.d.ts +13 -0
  593. package/dist/types/components/molecules/stepper/step.d.ts +25 -0
  594. package/dist/types/components/molecules/stepper/stepper.d.ts +34 -0
  595. package/dist/types/components/molecules/switch/switch.d.ts +46 -0
  596. package/dist/types/components/molecules/tab-group/tab-group.d.ts +18 -0
  597. package/dist/types/components/molecules/textarea/textarea.d.ts +53 -0
  598. package/dist/types/components/molecules/textarea/types.d.ts +9 -0
  599. package/dist/types/components/molecules/timeline/timeline-item.d.ts +16 -0
  600. package/dist/types/components/molecules/timeline/timeline.d.ts +25 -0
  601. package/dist/types/components/molecules/tooltip/tooltip.d.ts +19 -0
  602. package/dist/types/components/organism/autocomplete/autocomplete.d.ts +31 -0
  603. package/dist/types/components/organism/colorpicker/colorpicker.d.ts +176 -0
  604. package/dist/types/components/organism/date-picker/date-picker.d.ts +77 -0
  605. package/dist/types/components/organism/datetime-picker/datetime-picker.d.ts +438 -0
  606. package/dist/types/components/organism/datetime-picker/types.d.ts +54 -0
  607. package/dist/types/components/organism/form/form-group.d.ts +10 -0
  608. package/dist/types/components/organism/form/form.d.ts +34 -0
  609. package/dist/types/components/organism/form-2/bcm-form-components.d.ts +2 -0
  610. package/dist/types/components/organism/form-2/form-2.d.ts +25 -0
  611. package/dist/types/components/organism/list/list-key-control.d.ts +18 -0
  612. package/dist/types/components/organism/list/list-tag-control.d.ts +18 -0
  613. package/dist/types/components/organism/list/list.d.ts +140 -0
  614. package/dist/types/components/organism/states/bcm-list2.states.d.ts +28 -0
  615. package/dist/types/components/organism/time-picker/time-picker.d.ts +69 -0
  616. package/dist/types/components/other/attendance/attendance.d.ts +7 -0
  617. package/dist/types/components/other/data-table/table.d.ts +8 -0
  618. package/dist/types/components/other/default/default.d.ts +6 -0
  619. package/dist/types/components/other_deprecated/collapse/collapse.d.ts +12 -0
  620. package/dist/types/components/other_deprecated/collapse/group.d.ts +15 -0
  621. package/dist/types/components/other_deprecated/listbox/listbox-group.d.ts +7 -0
  622. package/dist/types/components/other_deprecated/listbox/listbox-item.d.ts +58 -0
  623. package/dist/types/components/other_deprecated/listbox/listbox.d.ts +152 -0
  624. package/dist/types/components/other_deprecated/listbox/types.d.ts +11 -0
  625. package/dist/types/components/other_deprecated/old-input/old-input.d.ts +80 -0
  626. package/dist/types/components/other_deprecated/old-input/types.d.ts +13 -0
  627. package/dist/types/components/other_deprecated/old-popover/old-popover-box.d.ts +26 -0
  628. package/dist/types/components/other_deprecated/old-popover/old-popover.d.ts +22 -0
  629. package/dist/types/components/other_deprecated/old-search/old-search.d.ts +32 -0
  630. package/dist/types/components/other_deprecated/old-tag/old-tag.d.ts +27 -0
  631. package/dist/types/components/other_deprecated/old-tag/types.d.ts +29 -0
  632. package/dist/types/components/other_deprecated/select/group.d.ts +6 -0
  633. package/dist/types/components/other_deprecated/select/option.d.ts +10 -0
  634. package/dist/types/components/other_deprecated/select/select-box.d.ts +15 -0
  635. package/dist/types/components/other_deprecated/select/select.d.ts +133 -0
  636. package/dist/types/components/other_deprecated/tabs/tab-pane.d.ts +19 -0
  637. package/dist/types/components/other_deprecated/tabs/tab.d.ts +36 -0
  638. package/dist/types/components/other_deprecated/tabs/tabs-content.d.ts +18 -0
  639. package/dist/types/components/other_deprecated/tabs/tabs.d.ts +112 -0
  640. package/dist/types/components/other_deprecated/tabs/types.d.ts +39 -0
  641. package/dist/types/components/other_deprecated/text/text.d.ts +11 -0
  642. package/dist/types/components/other_deprecated/treeview/treeview-group.d.ts +3 -0
  643. package/dist/types/components/other_deprecated/treeview/treeview-item.d.ts +119 -0
  644. package/dist/types/components/other_deprecated/treeview/treeview.d.ts +181 -0
  645. package/dist/types/components/other_deprecated/treeview/types.d.ts +11 -0
  646. package/dist/types/components.d.ts +3532 -0
  647. package/dist/types/decorators/id-decorator.d.ts +4 -0
  648. package/dist/types/decorators/index.d.ts +4 -0
  649. package/dist/types/decorators/is-load-decorator.d.ts +7 -0
  650. package/dist/types/decorators/json-parse-decarator.d.ts +4 -0
  651. package/dist/types/decorators/property-decorators.d.ts +4 -0
  652. package/dist/types/global/variables/colors.d.ts +217 -0
  653. package/dist/types/helper/color-helper.d.ts +16 -0
  654. package/dist/types/helper/datetime-helper.d.ts +3 -0
  655. package/dist/types/helper/generate.d.ts +22 -0
  656. package/dist/types/helper/index.d.ts +8 -0
  657. package/dist/types/helper/number-helper.d.ts +10 -0
  658. package/dist/types/helper/popover-helper.d.ts +31 -0
  659. package/dist/types/helper/string-helper.d.ts +27 -0
  660. package/dist/types/helper/tooltip-helper.d.ts +25 -0
  661. package/dist/types/helper/validators.d.ts +10 -0
  662. package/dist/types/index.d.ts +1 -0
  663. package/dist/types/models/abstract-classes/abstract-key-control.d.ts +31 -0
  664. package/dist/types/models/bcm-types.d.ts +21 -0
  665. package/dist/types/models/bcm.d.ts +456 -0
  666. package/dist/types/models/index.d.ts +2 -0
  667. package/dist/types/models/states/atoms/bcm-atoms-state.d.ts +34 -0
  668. package/dist/types/models/states/molecules/bcm-molecules-state.d.ts +90 -0
  669. package/dist/types/models/states/organisms/bcm-organisms-state.d.ts +78 -0
  670. package/dist/types/stencil-public-runtime.d.ts +1565 -0
  671. package/dist/types/templates/button-template.d.ts +18 -0
  672. package/dist/types/templates/caption-template.d.ts +14 -0
  673. package/dist/types/templates/checkbox-group-template.d.ts +10 -0
  674. package/dist/types/templates/checkbox-template.d.ts +13 -0
  675. package/dist/types/templates/icon-template.d.ts +7 -0
  676. package/dist/types/templates/index.d.ts +13 -0
  677. package/dist/types/templates/info-footer-template.d.ts +10 -0
  678. package/dist/types/templates/input-template.d.ts +34 -0
  679. package/dist/types/templates/label-template.d.ts +12 -0
  680. package/dist/types/templates/list-item-template.d.ts +13 -0
  681. package/dist/types/templates/list-template.d.ts +29 -0
  682. package/dist/types/templates/slot-template.d.ts +8 -0
  683. package/dist/types/templates/step-template.d.ts +17 -0
  684. package/dist/types/templates/tag-template.d.ts +21 -0
  685. package/dist/types/types/index.d.ts +12 -0
  686. package/dist/types/utils/element-dragger.d.ts +146 -0
  687. package/dist/types/utils/floating-ui.d.ts +1 -0
  688. package/dist/types/utils/index.d.ts +5 -0
  689. package/dist/types/utils/popover-placement.d.ts +3 -0
  690. package/dist/types/utils/utils.d.ts +55 -0
  691. package/dist/types/utils/validation.d.ts +19 -0
  692. package/package.json +7 -5
  693. package/dist/bromcom-ui/p-0846712b.js +0 -5
  694. package/dist/bromcom-ui/p-0f4e34e9.js +0 -5
  695. package/dist/bromcom-ui/p-1b60d9d1.entry.js +0 -5
  696. package/dist/bromcom-ui/p-2135cb11.js +0 -5
  697. package/dist/bromcom-ui/p-3c8d24f0.entry.js +0 -5
  698. package/dist/bromcom-ui/p-4958dd94.js +0 -5
  699. package/dist/bromcom-ui/p-4ee3fbcf.entry.js +0 -5
  700. package/dist/bromcom-ui/p-517bca05.entry.js +0 -5
  701. package/dist/bromcom-ui/p-73cacbce.entry.js +0 -5
  702. package/dist/bromcom-ui/p-7a34d5a4.entry.js +0 -5
  703. package/dist/bromcom-ui/p-7de55a4c.entry.js +0 -5
  704. package/dist/bromcom-ui/p-8f394771.js +0 -5
  705. package/dist/bromcom-ui/p-b66edda8.js +0 -5
  706. package/dist/bromcom-ui/p-b970549a.entry.js +0 -5
  707. package/dist/bromcom-ui/p-bb698305.js +0 -5
  708. package/dist/bromcom-ui/p-d3d143b3.entry.js +0 -5
  709. package/dist/bromcom-ui/p-d9913ea9.js +0 -5
  710. package/dist/bromcom-ui/p-dbde0dc8.entry.js +0 -5
  711. package/dist/bromcom-ui/p-e8159c40.entry.js +0 -5
  712. package/dist/bromcom-ui/p-f7589887.entry.js +0 -5
  713. package/dist/bromcom-ui/p-f932d88a.entry.js +0 -5
@@ -0,0 +1,1455 @@
1
+ /*!
2
+ * Built with Stencil
3
+ * Copyright (c) Bromcom.
4
+ */
5
+ 'use strict';
6
+
7
+ const bcm = require('./bcm-2c51bf0c.js');
8
+
9
+ function getSide(placement) {
10
+ return placement.split('-')[0];
11
+ }
12
+
13
+ function getAlignment(placement) {
14
+ return placement.split('-')[1];
15
+ }
16
+
17
+ function getMainAxisFromPlacement(placement) {
18
+ return ['top', 'bottom'].includes(getSide(placement)) ? 'x' : 'y';
19
+ }
20
+
21
+ function getLengthFromAxis(axis) {
22
+ return axis === 'y' ? 'height' : 'width';
23
+ }
24
+
25
+ function computeCoordsFromPlacement(_ref, placement, rtl) {
26
+ let {
27
+ reference,
28
+ floating
29
+ } = _ref;
30
+ const commonX = reference.x + reference.width / 2 - floating.width / 2;
31
+ const commonY = reference.y + reference.height / 2 - floating.height / 2;
32
+ const mainAxis = getMainAxisFromPlacement(placement);
33
+ const length = getLengthFromAxis(mainAxis);
34
+ const commonAlign = reference[length] / 2 - floating[length] / 2;
35
+ const side = getSide(placement);
36
+ const isVertical = mainAxis === 'x';
37
+ let coords;
38
+
39
+ switch (side) {
40
+ case 'top':
41
+ coords = {
42
+ x: commonX,
43
+ y: reference.y - floating.height
44
+ };
45
+ break;
46
+
47
+ case 'bottom':
48
+ coords = {
49
+ x: commonX,
50
+ y: reference.y + reference.height
51
+ };
52
+ break;
53
+
54
+ case 'right':
55
+ coords = {
56
+ x: reference.x + reference.width,
57
+ y: commonY
58
+ };
59
+ break;
60
+
61
+ case 'left':
62
+ coords = {
63
+ x: reference.x - floating.width,
64
+ y: commonY
65
+ };
66
+ break;
67
+
68
+ default:
69
+ coords = {
70
+ x: reference.x,
71
+ y: reference.y
72
+ };
73
+ }
74
+
75
+ switch (getAlignment(placement)) {
76
+ case 'start':
77
+ coords[mainAxis] -= commonAlign * (rtl && isVertical ? -1 : 1);
78
+ break;
79
+
80
+ case 'end':
81
+ coords[mainAxis] += commonAlign * (rtl && isVertical ? -1 : 1);
82
+ break;
83
+ }
84
+
85
+ return coords;
86
+ }
87
+
88
+ /**
89
+ * Computes the `x` and `y` coordinates that will place the floating element
90
+ * next to a reference element when it is given a certain positioning strategy.
91
+ *
92
+ * This export does not have any `platform` interface logic. You will need to
93
+ * write one for the platform you are using Floating UI with.
94
+ */
95
+
96
+ const computePosition$1 = async (reference, floating, config) => {
97
+ const {
98
+ placement = 'bottom',
99
+ strategy = 'absolute',
100
+ middleware = [],
101
+ platform
102
+ } = config;
103
+ const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(floating));
104
+
105
+ let rects = await platform.getElementRects({
106
+ reference,
107
+ floating,
108
+ strategy
109
+ });
110
+ let {
111
+ x,
112
+ y
113
+ } = computeCoordsFromPlacement(rects, placement, rtl);
114
+ let statefulPlacement = placement;
115
+ let middlewareData = {};
116
+ let resetCount = 0;
117
+
118
+ for (let i = 0; i < middleware.length; i++) {
119
+ const {
120
+ name,
121
+ fn
122
+ } = middleware[i];
123
+ const {
124
+ x: nextX,
125
+ y: nextY,
126
+ data,
127
+ reset
128
+ } = await fn({
129
+ x,
130
+ y,
131
+ initialPlacement: placement,
132
+ placement: statefulPlacement,
133
+ strategy,
134
+ middlewareData,
135
+ rects,
136
+ platform,
137
+ elements: {
138
+ reference,
139
+ floating
140
+ }
141
+ });
142
+ x = nextX != null ? nextX : x;
143
+ y = nextY != null ? nextY : y;
144
+ middlewareData = { ...middlewareData,
145
+ [name]: { ...middlewareData[name],
146
+ ...data
147
+ }
148
+ };
149
+
150
+ if (reset && resetCount <= 50) {
151
+ resetCount++;
152
+
153
+ if (typeof reset === 'object') {
154
+ if (reset.placement) {
155
+ statefulPlacement = reset.placement;
156
+ }
157
+
158
+ if (reset.rects) {
159
+ rects = reset.rects === true ? await platform.getElementRects({
160
+ reference,
161
+ floating,
162
+ strategy
163
+ }) : reset.rects;
164
+ }
165
+
166
+ ({
167
+ x,
168
+ y
169
+ } = computeCoordsFromPlacement(rects, statefulPlacement, rtl));
170
+ }
171
+
172
+ i = -1;
173
+ continue;
174
+ }
175
+ }
176
+
177
+ return {
178
+ x,
179
+ y,
180
+ placement: statefulPlacement,
181
+ strategy,
182
+ middlewareData
183
+ };
184
+ };
185
+
186
+ function expandPaddingObject(padding) {
187
+ return {
188
+ top: 0,
189
+ right: 0,
190
+ bottom: 0,
191
+ left: 0,
192
+ ...padding
193
+ };
194
+ }
195
+
196
+ function getSideObjectFromPadding(padding) {
197
+ return typeof padding !== 'number' ? expandPaddingObject(padding) : {
198
+ top: padding,
199
+ right: padding,
200
+ bottom: padding,
201
+ left: padding
202
+ };
203
+ }
204
+
205
+ function rectToClientRect(rect) {
206
+ return { ...rect,
207
+ top: rect.y,
208
+ left: rect.x,
209
+ right: rect.x + rect.width,
210
+ bottom: rect.y + rect.height
211
+ };
212
+ }
213
+
214
+ /**
215
+ * Resolves with an object of overflow side offsets that determine how much the
216
+ * element is overflowing a given clipping boundary.
217
+ * - positive = overflowing the boundary by that number of pixels
218
+ * - negative = how many pixels left before it will overflow
219
+ * - 0 = lies flush with the boundary
220
+ * @see https://floating-ui.com/docs/detectOverflow
221
+ */
222
+ async function detectOverflow(middlewareArguments, options) {
223
+ var _await$platform$isEle;
224
+
225
+ if (options === void 0) {
226
+ options = {};
227
+ }
228
+
229
+ const {
230
+ x,
231
+ y,
232
+ platform,
233
+ rects,
234
+ elements,
235
+ strategy
236
+ } = middlewareArguments;
237
+ const {
238
+ boundary = 'clippingAncestors',
239
+ rootBoundary = 'viewport',
240
+ elementContext = 'floating',
241
+ altBoundary = false,
242
+ padding = 0
243
+ } = options;
244
+ const paddingObject = getSideObjectFromPadding(padding);
245
+ const altContext = elementContext === 'floating' ? 'reference' : 'floating';
246
+ const element = elements[altBoundary ? altContext : elementContext];
247
+ const clippingClientRect = rectToClientRect(await platform.getClippingRect({
248
+ element: ((_await$platform$isEle = await (platform.isElement == null ? void 0 : platform.isElement(element))) != null ? _await$platform$isEle : true) ? element : element.contextElement || (await (platform.getDocumentElement == null ? void 0 : platform.getDocumentElement(elements.floating))),
249
+ boundary,
250
+ rootBoundary,
251
+ strategy
252
+ }));
253
+ const elementClientRect = rectToClientRect(platform.convertOffsetParentRelativeRectToViewportRelativeRect ? await platform.convertOffsetParentRelativeRectToViewportRelativeRect({
254
+ rect: elementContext === 'floating' ? { ...rects.floating,
255
+ x,
256
+ y
257
+ } : rects.reference,
258
+ offsetParent: await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(elements.floating)),
259
+ strategy
260
+ }) : rects[elementContext]);
261
+ return {
262
+ top: clippingClientRect.top - elementClientRect.top + paddingObject.top,
263
+ bottom: elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom,
264
+ left: clippingClientRect.left - elementClientRect.left + paddingObject.left,
265
+ right: elementClientRect.right - clippingClientRect.right + paddingObject.right
266
+ };
267
+ }
268
+
269
+ const min$1 = Math.min;
270
+ const max$1 = Math.max;
271
+
272
+ function within(min$1$1, value, max$1$1) {
273
+ return max$1(min$1$1, min$1(value, max$1$1));
274
+ }
275
+
276
+ /**
277
+ * Positions an inner element of the floating element such that it is centered
278
+ * to the reference element.
279
+ * @see https://floating-ui.com/docs/arrow
280
+ */
281
+ const arrow = options => ({
282
+ name: 'arrow',
283
+ options,
284
+
285
+ async fn(middlewareArguments) {
286
+ // Since `element` is required, we don't Partial<> the type
287
+ const {
288
+ element,
289
+ padding = 0
290
+ } = options != null ? options : {};
291
+ const {
292
+ x,
293
+ y,
294
+ placement,
295
+ rects,
296
+ platform
297
+ } = middlewareArguments;
298
+
299
+ if (element == null) {
300
+
301
+ return {};
302
+ }
303
+
304
+ const paddingObject = getSideObjectFromPadding(padding);
305
+ const coords = {
306
+ x,
307
+ y
308
+ };
309
+ const axis = getMainAxisFromPlacement(placement);
310
+ const alignment = getAlignment(placement);
311
+ const length = getLengthFromAxis(axis);
312
+ const arrowDimensions = await platform.getDimensions(element);
313
+ const minProp = axis === 'y' ? 'top' : 'left';
314
+ const maxProp = axis === 'y' ? 'bottom' : 'right';
315
+ const endDiff = rects.reference[length] + rects.reference[axis] - coords[axis] - rects.floating[length];
316
+ const startDiff = coords[axis] - rects.reference[axis];
317
+ const arrowOffsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(element));
318
+ let clientSize = arrowOffsetParent ? axis === 'y' ? arrowOffsetParent.clientHeight || 0 : arrowOffsetParent.clientWidth || 0 : 0;
319
+
320
+ if (clientSize === 0) {
321
+ clientSize = rects.floating[length];
322
+ }
323
+
324
+ const centerToReference = endDiff / 2 - startDiff / 2; // Make sure the arrow doesn't overflow the floating element if the center
325
+ // point is outside the floating element's bounds
326
+
327
+ const min = paddingObject[minProp];
328
+ const max = clientSize - arrowDimensions[length] - paddingObject[maxProp];
329
+ const center = clientSize / 2 - arrowDimensions[length] / 2 + centerToReference;
330
+ const offset = within(min, center, max); // Make sure that arrow points at the reference
331
+
332
+ const alignmentPadding = alignment === 'start' ? paddingObject[minProp] : paddingObject[maxProp];
333
+ const shouldAddOffset = alignmentPadding > 0 && center !== offset && rects.reference[length] <= rects.floating[length];
334
+ const alignmentOffset = shouldAddOffset ? center < min ? min - center : max - center : 0;
335
+ return {
336
+ [axis]: coords[axis] - alignmentOffset,
337
+ data: {
338
+ [axis]: offset,
339
+ centerOffset: center - offset
340
+ }
341
+ };
342
+ }
343
+
344
+ });
345
+
346
+ const hash$1 = {
347
+ left: 'right',
348
+ right: 'left',
349
+ bottom: 'top',
350
+ top: 'bottom'
351
+ };
352
+ function getOppositePlacement(placement) {
353
+ return placement.replace(/left|right|bottom|top/g, matched => hash$1[matched]);
354
+ }
355
+
356
+ function getAlignmentSides(placement, rects, rtl) {
357
+ if (rtl === void 0) {
358
+ rtl = false;
359
+ }
360
+
361
+ const alignment = getAlignment(placement);
362
+ const mainAxis = getMainAxisFromPlacement(placement);
363
+ const length = getLengthFromAxis(mainAxis);
364
+ let mainAlignmentSide = mainAxis === 'x' ? alignment === (rtl ? 'end' : 'start') ? 'right' : 'left' : alignment === 'start' ? 'bottom' : 'top';
365
+
366
+ if (rects.reference[length] > rects.floating[length]) {
367
+ mainAlignmentSide = getOppositePlacement(mainAlignmentSide);
368
+ }
369
+
370
+ return {
371
+ main: mainAlignmentSide,
372
+ cross: getOppositePlacement(mainAlignmentSide)
373
+ };
374
+ }
375
+
376
+ const hash = {
377
+ start: 'end',
378
+ end: 'start'
379
+ };
380
+ function getOppositeAlignmentPlacement(placement) {
381
+ return placement.replace(/start|end/g, matched => hash[matched]);
382
+ }
383
+
384
+ const sides = ['top', 'right', 'bottom', 'left'];
385
+
386
+ function getExpandedPlacements(placement) {
387
+ const oppositePlacement = getOppositePlacement(placement);
388
+ return [getOppositeAlignmentPlacement(placement), oppositePlacement, getOppositeAlignmentPlacement(oppositePlacement)];
389
+ }
390
+
391
+ /**
392
+ * Changes the placement of the floating element to one that will fit if the
393
+ * initially specified `placement` does not.
394
+ * @see https://floating-ui.com/docs/flip
395
+ */
396
+ const flip = function (options) {
397
+ if (options === void 0) {
398
+ options = {};
399
+ }
400
+
401
+ return {
402
+ name: 'flip',
403
+ options,
404
+
405
+ async fn(middlewareArguments) {
406
+ var _middlewareData$flip;
407
+
408
+ const {
409
+ placement,
410
+ middlewareData,
411
+ rects,
412
+ initialPlacement,
413
+ platform,
414
+ elements
415
+ } = middlewareArguments;
416
+ const {
417
+ mainAxis: checkMainAxis = true,
418
+ crossAxis: checkCrossAxis = true,
419
+ fallbackPlacements: specifiedFallbackPlacements,
420
+ fallbackStrategy = 'bestFit',
421
+ flipAlignment = true,
422
+ ...detectOverflowOptions
423
+ } = options;
424
+ const side = getSide(placement);
425
+ const isBasePlacement = side === initialPlacement;
426
+ const fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipAlignment ? [getOppositePlacement(initialPlacement)] : getExpandedPlacements(initialPlacement));
427
+ const placements = [initialPlacement, ...fallbackPlacements];
428
+ const overflow = await detectOverflow(middlewareArguments, detectOverflowOptions);
429
+ const overflows = [];
430
+ let overflowsData = ((_middlewareData$flip = middlewareData.flip) == null ? void 0 : _middlewareData$flip.overflows) || [];
431
+
432
+ if (checkMainAxis) {
433
+ overflows.push(overflow[side]);
434
+ }
435
+
436
+ if (checkCrossAxis) {
437
+ const {
438
+ main,
439
+ cross
440
+ } = getAlignmentSides(placement, rects, await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating)));
441
+ overflows.push(overflow[main], overflow[cross]);
442
+ }
443
+
444
+ overflowsData = [...overflowsData, {
445
+ placement,
446
+ overflows
447
+ }]; // One or more sides is overflowing
448
+
449
+ if (!overflows.every(side => side <= 0)) {
450
+ var _middlewareData$flip$, _middlewareData$flip2;
451
+
452
+ const nextIndex = ((_middlewareData$flip$ = (_middlewareData$flip2 = middlewareData.flip) == null ? void 0 : _middlewareData$flip2.index) != null ? _middlewareData$flip$ : 0) + 1;
453
+ const nextPlacement = placements[nextIndex];
454
+
455
+ if (nextPlacement) {
456
+ // Try next placement and re-run the lifecycle
457
+ return {
458
+ data: {
459
+ index: nextIndex,
460
+ overflows: overflowsData
461
+ },
462
+ reset: {
463
+ placement: nextPlacement
464
+ }
465
+ };
466
+ }
467
+
468
+ let resetPlacement = 'bottom';
469
+
470
+ switch (fallbackStrategy) {
471
+ case 'bestFit':
472
+ {
473
+ var _overflowsData$map$so;
474
+
475
+ const placement = (_overflowsData$map$so = overflowsData.map(d => [d, d.overflows.filter(overflow => overflow > 0).reduce((acc, overflow) => acc + overflow, 0)]).sort((a, b) => a[1] - b[1])[0]) == null ? void 0 : _overflowsData$map$so[0].placement;
476
+
477
+ if (placement) {
478
+ resetPlacement = placement;
479
+ }
480
+
481
+ break;
482
+ }
483
+
484
+ case 'initialPlacement':
485
+ resetPlacement = initialPlacement;
486
+ break;
487
+ }
488
+
489
+ if (placement !== resetPlacement) {
490
+ return {
491
+ reset: {
492
+ placement: resetPlacement
493
+ }
494
+ };
495
+ }
496
+ }
497
+
498
+ return {};
499
+ }
500
+
501
+ };
502
+ };
503
+
504
+ function getSideOffsets(overflow, rect) {
505
+ return {
506
+ top: overflow.top - rect.height,
507
+ right: overflow.right - rect.width,
508
+ bottom: overflow.bottom - rect.height,
509
+ left: overflow.left - rect.width
510
+ };
511
+ }
512
+
513
+ function isAnySideFullyClipped(overflow) {
514
+ return sides.some(side => overflow[side] >= 0);
515
+ }
516
+
517
+ /**
518
+ * Provides data to hide the floating element in applicable situations, such as
519
+ * when it is not in the same clipping context as the reference element.
520
+ * @see https://floating-ui.com/docs/hide
521
+ */
522
+ const hide = function (_temp) {
523
+ let {
524
+ strategy = 'referenceHidden',
525
+ ...detectOverflowOptions
526
+ } = _temp === void 0 ? {} : _temp;
527
+ return {
528
+ name: 'hide',
529
+
530
+ async fn(middlewareArguments) {
531
+ const {
532
+ rects
533
+ } = middlewareArguments;
534
+
535
+ switch (strategy) {
536
+ case 'referenceHidden':
537
+ {
538
+ const overflow = await detectOverflow(middlewareArguments, { ...detectOverflowOptions,
539
+ elementContext: 'reference'
540
+ });
541
+ const offsets = getSideOffsets(overflow, rects.reference);
542
+ return {
543
+ data: {
544
+ referenceHiddenOffsets: offsets,
545
+ referenceHidden: isAnySideFullyClipped(offsets)
546
+ }
547
+ };
548
+ }
549
+
550
+ case 'escaped':
551
+ {
552
+ const overflow = await detectOverflow(middlewareArguments, { ...detectOverflowOptions,
553
+ altBoundary: true
554
+ });
555
+ const offsets = getSideOffsets(overflow, rects.floating);
556
+ return {
557
+ data: {
558
+ escapedOffsets: offsets,
559
+ escaped: isAnySideFullyClipped(offsets)
560
+ }
561
+ };
562
+ }
563
+
564
+ default:
565
+ {
566
+ return {};
567
+ }
568
+ }
569
+ }
570
+
571
+ };
572
+ };
573
+
574
+ async function convertValueToCoords(middlewareArguments, value) {
575
+ const {
576
+ placement,
577
+ platform,
578
+ elements
579
+ } = middlewareArguments;
580
+ const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));
581
+ const side = getSide(placement);
582
+ const alignment = getAlignment(placement);
583
+ const isVertical = getMainAxisFromPlacement(placement) === 'x';
584
+ const mainAxisMulti = ['left', 'top'].includes(side) ? -1 : 1;
585
+ const crossAxisMulti = rtl && isVertical ? -1 : 1;
586
+ const rawValue = typeof value === 'function' ? value(middlewareArguments) : value; // eslint-disable-next-line prefer-const
587
+
588
+ let {
589
+ mainAxis,
590
+ crossAxis,
591
+ alignmentAxis
592
+ } = typeof rawValue === 'number' ? {
593
+ mainAxis: rawValue,
594
+ crossAxis: 0,
595
+ alignmentAxis: null
596
+ } : {
597
+ mainAxis: 0,
598
+ crossAxis: 0,
599
+ alignmentAxis: null,
600
+ ...rawValue
601
+ };
602
+
603
+ if (alignment && typeof alignmentAxis === 'number') {
604
+ crossAxis = alignment === 'end' ? alignmentAxis * -1 : alignmentAxis;
605
+ }
606
+
607
+ return isVertical ? {
608
+ x: crossAxis * crossAxisMulti,
609
+ y: mainAxis * mainAxisMulti
610
+ } : {
611
+ x: mainAxis * mainAxisMulti,
612
+ y: crossAxis * crossAxisMulti
613
+ };
614
+ }
615
+ /**
616
+ * Displaces the floating element from its reference element.
617
+ * @see https://floating-ui.com/docs/offset
618
+ */
619
+
620
+ const offset = function (value) {
621
+ if (value === void 0) {
622
+ value = 0;
623
+ }
624
+
625
+ return {
626
+ name: 'offset',
627
+ options: value,
628
+
629
+ async fn(middlewareArguments) {
630
+ const {
631
+ x,
632
+ y
633
+ } = middlewareArguments;
634
+ const diffCoords = await convertValueToCoords(middlewareArguments, value);
635
+ return {
636
+ x: x + diffCoords.x,
637
+ y: y + diffCoords.y,
638
+ data: diffCoords
639
+ };
640
+ }
641
+
642
+ };
643
+ };
644
+
645
+ function getCrossAxis(axis) {
646
+ return axis === 'x' ? 'y' : 'x';
647
+ }
648
+
649
+ /**
650
+ * Shifts the floating element in order to keep it in view when it will overflow
651
+ * a clipping boundary.
652
+ * @see https://floating-ui.com/docs/shift
653
+ */
654
+ const shift = function (options) {
655
+ if (options === void 0) {
656
+ options = {};
657
+ }
658
+
659
+ return {
660
+ name: 'shift',
661
+ options,
662
+
663
+ async fn(middlewareArguments) {
664
+ const {
665
+ x,
666
+ y,
667
+ placement
668
+ } = middlewareArguments;
669
+ const {
670
+ mainAxis: checkMainAxis = true,
671
+ crossAxis: checkCrossAxis = false,
672
+ limiter = {
673
+ fn: _ref => {
674
+ let {
675
+ x,
676
+ y
677
+ } = _ref;
678
+ return {
679
+ x,
680
+ y
681
+ };
682
+ }
683
+ },
684
+ ...detectOverflowOptions
685
+ } = options;
686
+ const coords = {
687
+ x,
688
+ y
689
+ };
690
+ const overflow = await detectOverflow(middlewareArguments, detectOverflowOptions);
691
+ const mainAxis = getMainAxisFromPlacement(getSide(placement));
692
+ const crossAxis = getCrossAxis(mainAxis);
693
+ let mainAxisCoord = coords[mainAxis];
694
+ let crossAxisCoord = coords[crossAxis];
695
+
696
+ if (checkMainAxis) {
697
+ const minSide = mainAxis === 'y' ? 'top' : 'left';
698
+ const maxSide = mainAxis === 'y' ? 'bottom' : 'right';
699
+ const min = mainAxisCoord + overflow[minSide];
700
+ const max = mainAxisCoord - overflow[maxSide];
701
+ mainAxisCoord = within(min, mainAxisCoord, max);
702
+ }
703
+
704
+ if (checkCrossAxis) {
705
+ const minSide = crossAxis === 'y' ? 'top' : 'left';
706
+ const maxSide = crossAxis === 'y' ? 'bottom' : 'right';
707
+ const min = crossAxisCoord + overflow[minSide];
708
+ const max = crossAxisCoord - overflow[maxSide];
709
+ crossAxisCoord = within(min, crossAxisCoord, max);
710
+ }
711
+
712
+ const limitedCoords = limiter.fn({ ...middlewareArguments,
713
+ [mainAxis]: mainAxisCoord,
714
+ [crossAxis]: crossAxisCoord
715
+ });
716
+ return { ...limitedCoords,
717
+ data: {
718
+ x: limitedCoords.x - x,
719
+ y: limitedCoords.y - y
720
+ }
721
+ };
722
+ }
723
+
724
+ };
725
+ };
726
+
727
+ /**
728
+ * Provides data to change the size of the floating element. For instance,
729
+ * prevent it from overflowing its clipping boundary or match the width of the
730
+ * reference element.
731
+ * @see https://floating-ui.com/docs/size
732
+ */
733
+ const size = function (options) {
734
+ if (options === void 0) {
735
+ options = {};
736
+ }
737
+
738
+ return {
739
+ name: 'size',
740
+ options,
741
+
742
+ async fn(middlewareArguments) {
743
+ const {
744
+ placement,
745
+ rects,
746
+ platform,
747
+ elements
748
+ } = middlewareArguments;
749
+ const {
750
+ apply = () => {},
751
+ ...detectOverflowOptions
752
+ } = options;
753
+ const overflow = await detectOverflow(middlewareArguments, detectOverflowOptions);
754
+ const side = getSide(placement);
755
+ const alignment = getAlignment(placement);
756
+ let heightSide;
757
+ let widthSide;
758
+
759
+ if (side === 'top' || side === 'bottom') {
760
+ heightSide = side;
761
+ widthSide = alignment === ((await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating))) ? 'start' : 'end') ? 'left' : 'right';
762
+ } else {
763
+ widthSide = side;
764
+ heightSide = alignment === 'end' ? 'top' : 'bottom';
765
+ }
766
+
767
+ const xMin = max$1(overflow.left, 0);
768
+ const xMax = max$1(overflow.right, 0);
769
+ const yMin = max$1(overflow.top, 0);
770
+ const yMax = max$1(overflow.bottom, 0);
771
+ const dimensions = {
772
+ availableHeight: rects.floating.height - (['left', 'right'].includes(placement) ? 2 * (yMin !== 0 || yMax !== 0 ? yMin + yMax : max$1(overflow.top, overflow.bottom)) : overflow[heightSide]),
773
+ availableWidth: rects.floating.width - (['top', 'bottom'].includes(placement) ? 2 * (xMin !== 0 || xMax !== 0 ? xMin + xMax : max$1(overflow.left, overflow.right)) : overflow[widthSide])
774
+ };
775
+ await apply({ ...middlewareArguments,
776
+ ...dimensions
777
+ });
778
+ const nextDimensions = await platform.getDimensions(elements.floating);
779
+
780
+ if (rects.floating.width !== nextDimensions.width || rects.floating.height !== nextDimensions.height) {
781
+ return {
782
+ reset: {
783
+ rects: true
784
+ }
785
+ };
786
+ }
787
+
788
+ return {};
789
+ }
790
+
791
+ };
792
+ };
793
+
794
+ function isWindow(value) {
795
+ return value && value.document && value.location && value.alert && value.setInterval;
796
+ }
797
+ function getWindow(node) {
798
+ if (node == null) {
799
+ return window;
800
+ }
801
+
802
+ if (!isWindow(node)) {
803
+ const ownerDocument = node.ownerDocument;
804
+ return ownerDocument ? ownerDocument.defaultView || window : window;
805
+ }
806
+
807
+ return node;
808
+ }
809
+
810
+ function getComputedStyle(element) {
811
+ return getWindow(element).getComputedStyle(element);
812
+ }
813
+
814
+ function getNodeName(node) {
815
+ return isWindow(node) ? '' : node ? (node.nodeName || '').toLowerCase() : '';
816
+ }
817
+
818
+ function getUAString() {
819
+ const uaData = navigator.userAgentData;
820
+
821
+ if (uaData != null && uaData.brands) {
822
+ return uaData.brands.map(item => item.brand + "/" + item.version).join(' ');
823
+ }
824
+
825
+ return navigator.userAgent;
826
+ }
827
+
828
+ function isHTMLElement(value) {
829
+ return value instanceof getWindow(value).HTMLElement;
830
+ }
831
+ function isElement(value) {
832
+ return value instanceof getWindow(value).Element;
833
+ }
834
+ function isNode(value) {
835
+ return value instanceof getWindow(value).Node;
836
+ }
837
+ function isShadowRoot(node) {
838
+ // Browsers without `ShadowRoot` support
839
+ if (typeof ShadowRoot === 'undefined') {
840
+ return false;
841
+ }
842
+
843
+ const OwnElement = getWindow(node).ShadowRoot;
844
+ return node instanceof OwnElement || node instanceof ShadowRoot;
845
+ }
846
+ function isOverflowElement(element) {
847
+ // Firefox wants us to check `-x` and `-y` variations as well
848
+ const {
849
+ overflow,
850
+ overflowX,
851
+ overflowY
852
+ } = getComputedStyle(element);
853
+ return /auto|scroll|overlay|hidden/.test(overflow + overflowY + overflowX);
854
+ }
855
+ function isTableElement(element) {
856
+ return ['table', 'td', 'th'].includes(getNodeName(element));
857
+ }
858
+ function isContainingBlock(element) {
859
+ // TODO: Try and use feature detection here instead
860
+ const isFirefox = /firefox/i.test(getUAString());
861
+ const css = getComputedStyle(element); // This is non-exhaustive but covers the most common CSS properties that
862
+ // create a containing block.
863
+ // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block
864
+
865
+ return css.transform !== 'none' || css.perspective !== 'none' || // @ts-ignore (TS 4.1 compat)
866
+ css.contain === 'paint' || ['transform', 'perspective'].includes(css.willChange) || isFirefox && css.willChange === 'filter' || isFirefox && (css.filter ? css.filter !== 'none' : false);
867
+ }
868
+ function isLayoutViewport() {
869
+ // Not Safari
870
+ return !/^((?!chrome|android).)*safari/i.test(getUAString()); // Feature detection for this fails in various ways
871
+ // • Always-visible scrollbar or not
872
+ // • Width of <html>, etc.
873
+ // const vV = win.visualViewport;
874
+ // return vV ? Math.abs(win.innerWidth / vV.scale - vV.width) < 0.5 : true;
875
+ }
876
+
877
+ const min = Math.min;
878
+ const max = Math.max;
879
+ const round = Math.round;
880
+
881
+ function getBoundingClientRect(element, includeScale, isFixedStrategy) {
882
+ var _win$visualViewport$o, _win$visualViewport, _win$visualViewport$o2, _win$visualViewport2;
883
+
884
+ if (includeScale === void 0) {
885
+ includeScale = false;
886
+ }
887
+
888
+ if (isFixedStrategy === void 0) {
889
+ isFixedStrategy = false;
890
+ }
891
+
892
+ const clientRect = element.getBoundingClientRect();
893
+ let scaleX = 1;
894
+ let scaleY = 1;
895
+
896
+ if (includeScale && isHTMLElement(element)) {
897
+ scaleX = element.offsetWidth > 0 ? round(clientRect.width) / element.offsetWidth || 1 : 1;
898
+ scaleY = element.offsetHeight > 0 ? round(clientRect.height) / element.offsetHeight || 1 : 1;
899
+ }
900
+
901
+ const win = isElement(element) ? getWindow(element) : window;
902
+ const addVisualOffsets = !isLayoutViewport() && isFixedStrategy;
903
+ const x = (clientRect.left + (addVisualOffsets ? (_win$visualViewport$o = (_win$visualViewport = win.visualViewport) == null ? void 0 : _win$visualViewport.offsetLeft) != null ? _win$visualViewport$o : 0 : 0)) / scaleX;
904
+ const y = (clientRect.top + (addVisualOffsets ? (_win$visualViewport$o2 = (_win$visualViewport2 = win.visualViewport) == null ? void 0 : _win$visualViewport2.offsetTop) != null ? _win$visualViewport$o2 : 0 : 0)) / scaleY;
905
+ const width = clientRect.width / scaleX;
906
+ const height = clientRect.height / scaleY;
907
+ return {
908
+ width,
909
+ height,
910
+ top: y,
911
+ right: x + width,
912
+ bottom: y + height,
913
+ left: x,
914
+ x,
915
+ y
916
+ };
917
+ }
918
+
919
+ function getDocumentElement(node) {
920
+ return ((isNode(node) ? node.ownerDocument : node.document) || window.document).documentElement;
921
+ }
922
+
923
+ function getNodeScroll(element) {
924
+ if (isElement(element)) {
925
+ return {
926
+ scrollLeft: element.scrollLeft,
927
+ scrollTop: element.scrollTop
928
+ };
929
+ }
930
+
931
+ return {
932
+ scrollLeft: element.pageXOffset,
933
+ scrollTop: element.pageYOffset
934
+ };
935
+ }
936
+
937
+ function getWindowScrollBarX(element) {
938
+ // If <html> has a CSS width greater than the viewport, then this will be
939
+ // incorrect for RTL.
940
+ return getBoundingClientRect(getDocumentElement(element)).left + getNodeScroll(element).scrollLeft;
941
+ }
942
+
943
+ function isScaled(element) {
944
+ const rect = getBoundingClientRect(element);
945
+ return round(rect.width) !== element.offsetWidth || round(rect.height) !== element.offsetHeight;
946
+ }
947
+
948
+ function getRectRelativeToOffsetParent(element, offsetParent, strategy) {
949
+ const isOffsetParentAnElement = isHTMLElement(offsetParent);
950
+ const documentElement = getDocumentElement(offsetParent);
951
+ const rect = getBoundingClientRect(element, // @ts-ignore - checked above (TS 4.1 compat)
952
+ isOffsetParentAnElement && isScaled(offsetParent), strategy === 'fixed');
953
+ let scroll = {
954
+ scrollLeft: 0,
955
+ scrollTop: 0
956
+ };
957
+ const offsets = {
958
+ x: 0,
959
+ y: 0
960
+ };
961
+
962
+ if (isOffsetParentAnElement || !isOffsetParentAnElement && strategy !== 'fixed') {
963
+ if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {
964
+ scroll = getNodeScroll(offsetParent);
965
+ }
966
+
967
+ if (isHTMLElement(offsetParent)) {
968
+ const offsetRect = getBoundingClientRect(offsetParent, true);
969
+ offsets.x = offsetRect.x + offsetParent.clientLeft;
970
+ offsets.y = offsetRect.y + offsetParent.clientTop;
971
+ } else if (documentElement) {
972
+ offsets.x = getWindowScrollBarX(documentElement);
973
+ }
974
+ }
975
+
976
+ return {
977
+ x: rect.left + scroll.scrollLeft - offsets.x,
978
+ y: rect.top + scroll.scrollTop - offsets.y,
979
+ width: rect.width,
980
+ height: rect.height
981
+ };
982
+ }
983
+
984
+ function getParentNode(node) {
985
+ if (getNodeName(node) === 'html') {
986
+ return node;
987
+ }
988
+
989
+ return (// this is a quicker (but less type safe) way to save quite some bytes from the bundle
990
+ // @ts-ignore
991
+ node.assignedSlot || // step into the shadow DOM of the parent of a slotted node
992
+ node.parentNode || ( // DOM Element detected
993
+ isShadowRoot(node) ? node.host : null) || // ShadowRoot detected
994
+ getDocumentElement(node) // fallback
995
+
996
+ );
997
+ }
998
+
999
+ function getTrueOffsetParent(element) {
1000
+ if (!isHTMLElement(element) || getComputedStyle(element).position === 'fixed') {
1001
+ return null;
1002
+ }
1003
+
1004
+ return composedOffsetParent(element);
1005
+ }
1006
+ /**
1007
+ * Polyfills the old offsetParent behavior from before the spec was changed:
1008
+ * https://github.com/w3c/csswg-drafts/issues/159
1009
+ */
1010
+
1011
+
1012
+ function composedOffsetParent(element) {
1013
+ let {
1014
+ offsetParent
1015
+ } = element;
1016
+ let ancestor = element;
1017
+ let foundInsideSlot = false;
1018
+
1019
+ while (ancestor && ancestor !== offsetParent) {
1020
+ const {
1021
+ assignedSlot
1022
+ } = ancestor;
1023
+
1024
+ if (assignedSlot) {
1025
+ let newOffsetParent = assignedSlot.offsetParent;
1026
+
1027
+ if (getComputedStyle(assignedSlot).display === 'contents') {
1028
+ const hadStyleAttribute = assignedSlot.hasAttribute('style');
1029
+ const oldDisplay = assignedSlot.style.display;
1030
+ assignedSlot.style.display = getComputedStyle(ancestor).display;
1031
+ newOffsetParent = assignedSlot.offsetParent;
1032
+ assignedSlot.style.display = oldDisplay;
1033
+
1034
+ if (!hadStyleAttribute) {
1035
+ assignedSlot.removeAttribute('style');
1036
+ }
1037
+ }
1038
+
1039
+ ancestor = assignedSlot;
1040
+
1041
+ if (offsetParent !== newOffsetParent) {
1042
+ offsetParent = newOffsetParent;
1043
+ foundInsideSlot = true;
1044
+ }
1045
+ } else if (isShadowRoot(ancestor) && ancestor.host && foundInsideSlot) {
1046
+ break;
1047
+ }
1048
+
1049
+ ancestor = isShadowRoot(ancestor) && ancestor.host || ancestor.parentNode;
1050
+ }
1051
+
1052
+ return offsetParent;
1053
+ }
1054
+
1055
+ function getContainingBlock(element) {
1056
+ let currentNode = getParentNode(element);
1057
+
1058
+ if (isShadowRoot(currentNode)) {
1059
+ currentNode = currentNode.host;
1060
+ }
1061
+
1062
+ while (isHTMLElement(currentNode) && !['html', 'body'].includes(getNodeName(currentNode))) {
1063
+ if (isContainingBlock(currentNode)) {
1064
+ return currentNode;
1065
+ } else {
1066
+ const parent = currentNode.parentNode;
1067
+ currentNode = isShadowRoot(parent) ? parent.host : parent;
1068
+ }
1069
+ }
1070
+
1071
+ return null;
1072
+ } // Gets the closest ancestor positioned element. Handles some edge cases,
1073
+ // such as table ancestors and cross browser bugs.
1074
+
1075
+
1076
+ function getOffsetParent(element) {
1077
+ const window = getWindow(element);
1078
+ let offsetParent = getTrueOffsetParent(element);
1079
+
1080
+ while (offsetParent && isTableElement(offsetParent) && getComputedStyle(offsetParent).position === 'static') {
1081
+ offsetParent = getTrueOffsetParent(offsetParent);
1082
+ }
1083
+
1084
+ if (offsetParent && (getNodeName(offsetParent) === 'html' || getNodeName(offsetParent) === 'body' && getComputedStyle(offsetParent).position === 'static' && !isContainingBlock(offsetParent))) {
1085
+ return window;
1086
+ }
1087
+
1088
+ return offsetParent || getContainingBlock(element) || window;
1089
+ }
1090
+
1091
+ function getDimensions(element) {
1092
+ if (isHTMLElement(element)) {
1093
+ return {
1094
+ width: element.offsetWidth,
1095
+ height: element.offsetHeight
1096
+ };
1097
+ }
1098
+
1099
+ const rect = getBoundingClientRect(element);
1100
+ return {
1101
+ width: rect.width,
1102
+ height: rect.height
1103
+ };
1104
+ }
1105
+
1106
+ function convertOffsetParentRelativeRectToViewportRelativeRect(_ref) {
1107
+ let {
1108
+ rect,
1109
+ offsetParent,
1110
+ strategy
1111
+ } = _ref;
1112
+ const isOffsetParentAnElement = isHTMLElement(offsetParent);
1113
+ const documentElement = getDocumentElement(offsetParent);
1114
+
1115
+ if (offsetParent === documentElement) {
1116
+ return rect;
1117
+ }
1118
+
1119
+ let scroll = {
1120
+ scrollLeft: 0,
1121
+ scrollTop: 0
1122
+ };
1123
+ const offsets = {
1124
+ x: 0,
1125
+ y: 0
1126
+ };
1127
+
1128
+ if (isOffsetParentAnElement || !isOffsetParentAnElement && strategy !== 'fixed') {
1129
+ if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {
1130
+ scroll = getNodeScroll(offsetParent);
1131
+ }
1132
+
1133
+ if (isHTMLElement(offsetParent)) {
1134
+ const offsetRect = getBoundingClientRect(offsetParent, true);
1135
+ offsets.x = offsetRect.x + offsetParent.clientLeft;
1136
+ offsets.y = offsetRect.y + offsetParent.clientTop;
1137
+ } // This doesn't appear to be need to be negated.
1138
+ // else if (documentElement) {
1139
+ // offsets.x = getWindowScrollBarX(documentElement);
1140
+ // }
1141
+
1142
+ }
1143
+
1144
+ return { ...rect,
1145
+ x: rect.x - scroll.scrollLeft + offsets.x,
1146
+ y: rect.y - scroll.scrollTop + offsets.y
1147
+ };
1148
+ }
1149
+
1150
+ function getViewportRect(element, strategy) {
1151
+ const win = getWindow(element);
1152
+ const html = getDocumentElement(element);
1153
+ const visualViewport = win.visualViewport;
1154
+ let width = html.clientWidth;
1155
+ let height = html.clientHeight;
1156
+ let x = 0;
1157
+ let y = 0;
1158
+
1159
+ if (visualViewport) {
1160
+ width = visualViewport.width;
1161
+ height = visualViewport.height;
1162
+ const layoutViewport = isLayoutViewport();
1163
+
1164
+ if (layoutViewport || !layoutViewport && strategy === 'fixed') {
1165
+ x = visualViewport.offsetLeft;
1166
+ y = visualViewport.offsetTop;
1167
+ }
1168
+ }
1169
+
1170
+ return {
1171
+ width,
1172
+ height,
1173
+ x,
1174
+ y
1175
+ };
1176
+ }
1177
+
1178
+ // of the `<html>` and `<body>` rect bounds if horizontally scrollable
1179
+
1180
+ function getDocumentRect(element) {
1181
+ var _element$ownerDocumen;
1182
+
1183
+ const html = getDocumentElement(element);
1184
+ const scroll = getNodeScroll(element);
1185
+ const body = (_element$ownerDocumen = element.ownerDocument) == null ? void 0 : _element$ownerDocumen.body;
1186
+ const width = max(html.scrollWidth, html.clientWidth, body ? body.scrollWidth : 0, body ? body.clientWidth : 0);
1187
+ const height = max(html.scrollHeight, html.clientHeight, body ? body.scrollHeight : 0, body ? body.clientHeight : 0);
1188
+ let x = -scroll.scrollLeft + getWindowScrollBarX(element);
1189
+ const y = -scroll.scrollTop;
1190
+
1191
+ if (getComputedStyle(body || html).direction === 'rtl') {
1192
+ x += max(html.clientWidth, body ? body.clientWidth : 0) - width;
1193
+ }
1194
+
1195
+ return {
1196
+ width,
1197
+ height,
1198
+ x,
1199
+ y
1200
+ };
1201
+ }
1202
+
1203
+ function getNearestOverflowAncestor(node) {
1204
+ const parentNode = getParentNode(node);
1205
+
1206
+ if (['html', 'body', '#document'].includes(getNodeName(parentNode))) {
1207
+ // @ts-ignore assume body is always available
1208
+ return node.ownerDocument.body;
1209
+ }
1210
+
1211
+ if (isHTMLElement(parentNode) && isOverflowElement(parentNode)) {
1212
+ return parentNode;
1213
+ }
1214
+
1215
+ return getNearestOverflowAncestor(parentNode);
1216
+ }
1217
+
1218
+ function getOverflowAncestors(node, list) {
1219
+ var _node$ownerDocument;
1220
+
1221
+ if (list === void 0) {
1222
+ list = [];
1223
+ }
1224
+
1225
+ const scrollableAncestor = getNearestOverflowAncestor(node);
1226
+ const isBody = scrollableAncestor === ((_node$ownerDocument = node.ownerDocument) == null ? void 0 : _node$ownerDocument.body);
1227
+ const win = getWindow(scrollableAncestor);
1228
+ const target = isBody ? [win].concat(win.visualViewport || [], isOverflowElement(scrollableAncestor) ? scrollableAncestor : []) : scrollableAncestor;
1229
+ const updatedList = list.concat(target);
1230
+ return isBody ? updatedList : // @ts-ignore: isBody tells us target will be an HTMLElement here
1231
+ updatedList.concat(getOverflowAncestors(target));
1232
+ }
1233
+
1234
+ function contains(parent, child) {
1235
+ const rootNode = child.getRootNode == null ? void 0 : child.getRootNode(); // First, attempt with faster native method
1236
+
1237
+ if (parent.contains(child)) {
1238
+ return true;
1239
+ } // then fallback to custom implementation with Shadow DOM support
1240
+ else if (rootNode && isShadowRoot(rootNode)) {
1241
+ let next = child;
1242
+
1243
+ do {
1244
+ // use `===` replace node.isSameNode()
1245
+ if (next && parent === next) {
1246
+ return true;
1247
+ } // @ts-ignore: need a better way to handle this...
1248
+
1249
+
1250
+ next = next.parentNode || next.host;
1251
+ } while (next);
1252
+ }
1253
+
1254
+ return false;
1255
+ }
1256
+
1257
+ function getInnerBoundingClientRect(element, strategy) {
1258
+ const clientRect = getBoundingClientRect(element, false, strategy === 'fixed');
1259
+ const top = clientRect.top + element.clientTop;
1260
+ const left = clientRect.left + element.clientLeft;
1261
+ return {
1262
+ top,
1263
+ left,
1264
+ x: left,
1265
+ y: top,
1266
+ right: left + element.clientWidth,
1267
+ bottom: top + element.clientHeight,
1268
+ width: element.clientWidth,
1269
+ height: element.clientHeight
1270
+ };
1271
+ }
1272
+
1273
+ function getClientRectFromClippingAncestor(element, clippingParent, strategy) {
1274
+ if (clippingParent === 'viewport') {
1275
+ return rectToClientRect(getViewportRect(element, strategy));
1276
+ }
1277
+
1278
+ if (isElement(clippingParent)) {
1279
+ return getInnerBoundingClientRect(clippingParent, strategy);
1280
+ }
1281
+
1282
+ return rectToClientRect(getDocumentRect(getDocumentElement(element)));
1283
+ } // A "clipping ancestor" is an overflowable container with the characteristic of
1284
+ // clipping (or hiding) overflowing elements with a position different from
1285
+ // `initial`
1286
+
1287
+
1288
+ function getClippingAncestors(element) {
1289
+ const clippingAncestors = getOverflowAncestors(element);
1290
+ const canEscapeClipping = ['absolute', 'fixed'].includes(getComputedStyle(element).position);
1291
+ const clipperElement = canEscapeClipping && isHTMLElement(element) ? getOffsetParent(element) : element;
1292
+
1293
+ if (!isElement(clipperElement)) {
1294
+ return [];
1295
+ } // @ts-ignore isElement check ensures we return Array<Element>
1296
+
1297
+
1298
+ return clippingAncestors.filter(clippingAncestors => isElement(clippingAncestors) && contains(clippingAncestors, clipperElement) && getNodeName(clippingAncestors) !== 'body');
1299
+ } // Gets the maximum area that the element is visible in due to any number of
1300
+ // clipping ancestors
1301
+
1302
+
1303
+ function getClippingRect(_ref) {
1304
+ let {
1305
+ element,
1306
+ boundary,
1307
+ rootBoundary,
1308
+ strategy
1309
+ } = _ref;
1310
+ const mainClippingAncestors = boundary === 'clippingAncestors' ? getClippingAncestors(element) : [].concat(boundary);
1311
+ const clippingAncestors = [...mainClippingAncestors, rootBoundary];
1312
+ const firstClippingAncestor = clippingAncestors[0];
1313
+ const clippingRect = clippingAncestors.reduce((accRect, clippingAncestor) => {
1314
+ const rect = getClientRectFromClippingAncestor(element, clippingAncestor, strategy);
1315
+ accRect.top = max(rect.top, accRect.top);
1316
+ accRect.right = min(rect.right, accRect.right);
1317
+ accRect.bottom = min(rect.bottom, accRect.bottom);
1318
+ accRect.left = max(rect.left, accRect.left);
1319
+ return accRect;
1320
+ }, getClientRectFromClippingAncestor(element, firstClippingAncestor, strategy));
1321
+ return {
1322
+ width: clippingRect.right - clippingRect.left,
1323
+ height: clippingRect.bottom - clippingRect.top,
1324
+ x: clippingRect.left,
1325
+ y: clippingRect.top
1326
+ };
1327
+ }
1328
+
1329
+ const platform = {
1330
+ getClippingRect,
1331
+ convertOffsetParentRelativeRectToViewportRelativeRect,
1332
+ isElement,
1333
+ getDimensions,
1334
+ getOffsetParent,
1335
+ getDocumentElement,
1336
+ getElementRects: _ref => {
1337
+ let {
1338
+ reference,
1339
+ floating,
1340
+ strategy
1341
+ } = _ref;
1342
+ return {
1343
+ reference: getRectRelativeToOffsetParent(reference, getOffsetParent(floating), strategy),
1344
+ floating: { ...getDimensions(floating),
1345
+ x: 0,
1346
+ y: 0
1347
+ }
1348
+ };
1349
+ },
1350
+ getClientRects: element => Array.from(element.getClientRects()),
1351
+ isRTL: element => getComputedStyle(element).direction === 'rtl'
1352
+ };
1353
+
1354
+ /**
1355
+ * Computes the `x` and `y` coordinates that will place the floating element
1356
+ * next to a reference element when it is given a certain CSS positioning
1357
+ * strategy.
1358
+ */
1359
+
1360
+ const computePosition = (reference, floating, options) => computePosition$1(reference, floating, {
1361
+ platform,
1362
+ ...options
1363
+ });
1364
+
1365
+ const FloatingUI = (
1366
+ // el,
1367
+ // component,
1368
+ // options = {
1369
+ // placement: Bcm.Placement.bottom as PlacementTypes,
1370
+ // offset: 0,
1371
+ // arrow: false,
1372
+ // arrowColor: 'tw-bg-slate-700',
1373
+ // },
1374
+ // autoHidden = true,
1375
+ // autoSize = false,
1376
+ // style: any = {},
1377
+ args) => {
1378
+ const { ref, floating, placement: _placement = bcm.Bcm$1.Placement.bottom, offset: _offset = 0, arrow: _arrow = false, arrowColor = 'tw-bg-slate-700', autoHidden = true, autoSize = false, style = {}, } = args;
1379
+ // const { placement: _placement, offset: _offset, arrow: _arrow, arrowColor } = options;
1380
+ // let _middleware = [offset(_offset), flip(), shift({ padding: 5 }), hide({ padding: 10 })];
1381
+ let _middleware = [offset(_offset), flip(), shift({ padding: 5 })];
1382
+ if (autoHidden) {
1383
+ _middleware.push(hide({ padding: 10 }));
1384
+ }
1385
+ style &&
1386
+ Object.assign(floating.style, Object.assign(Object.assign({}, (style.height && { height: style.height })), (style.minHeight && { minHeight: style.minHeight })));
1387
+ if (autoSize && !(style === null || style === void 0 ? void 0 : style.height)) {
1388
+ _middleware.push(size({
1389
+ apply({ availableHeight }) {
1390
+ const maxHeight = `${availableHeight > window.innerHeight ? window.innerHeight - 10 : availableHeight}px`;
1391
+ Object.assign(floating.style, {
1392
+ maxHeight: `${style.maxHeight && maxHeight >= style.maxHeight ? style.maxHeight : maxHeight}`,
1393
+ });
1394
+ },
1395
+ padding: 5,
1396
+ }));
1397
+ }
1398
+ let arrowElement = document.getElementById(`${floating.id}-arrow`);
1399
+ if (_arrow) {
1400
+ if (!arrowElement) {
1401
+ arrowElement = document.createElement('div');
1402
+ arrowElement.setAttribute('id', `${floating.id}-arrow`);
1403
+ }
1404
+ arrowElement.setAttribute('class', `tw-absolute tw-w-2 tw-h-2 ${arrowColor} tw-transform tw-z-[-1] tw-opacity-0 tw-transition-opacity tw-duration-300
1405
+ tw-shadow
1406
+ `);
1407
+ floating.prepend(arrowElement);
1408
+ _middleware.push(arrow({ element: arrowElement, padding: 4 }));
1409
+ }
1410
+ computePosition(ref, floating, { placement: _placement, middleware: _middleware }).then(({ x, y, placement, middlewareData }) => {
1411
+ const { referenceHidden } = autoHidden ? middlewareData.hide : { referenceHidden: false };
1412
+ Object.assign(floating.style, {
1413
+ top: '0',
1414
+ left: '0',
1415
+ transform: `translate(${Math.round(x)}px,${Math.round(y)}px)`,
1416
+ opacity: referenceHidden ? '0' : '1',
1417
+ visibility: referenceHidden ? 'hidden' : 'visible',
1418
+ });
1419
+ if (referenceHidden) {
1420
+ const isHideEvent = new CustomEvent('bcm-floating-is-hide', { detail: { id: floating.id } });
1421
+ document.dispatchEvent(isHideEvent);
1422
+ floating.getAttribute('outside-of-the-screen') !== 'true' && floating.setAttribute('outside-of-the-screen', 'true');
1423
+ }
1424
+ else {
1425
+ floating.getAttribute('outside-of-the-screen') === 'true' && floating.removeAttribute('outside-of-the-screen');
1426
+ }
1427
+ if (_arrow) {
1428
+ const { x: arrowX, y: arrowY } = middlewareData.arrow;
1429
+ const staticSide = {
1430
+ top: 'bottom',
1431
+ right: 'left',
1432
+ bottom: 'top',
1433
+ left: 'right',
1434
+ }[placement.split('-')[0]];
1435
+ const arrowStyle = {
1436
+ top: 'rotate(45deg)',
1437
+ right: 'rotate(135deg)',
1438
+ bottom: 'rotate(-135deg)',
1439
+ left: 'rotate(-45deg)',
1440
+ }[placement.split('-')[0]];
1441
+ Object.assign(arrowElement.style, {
1442
+ left: arrowX != null ? `${arrowX}px` : '',
1443
+ top: arrowY != null ? `${arrowY}px` : '',
1444
+ right: '',
1445
+ bottom: '',
1446
+ [staticSide]: '-4px',
1447
+ opacity: 1,
1448
+ visibility: referenceHidden ? 'hidden' : 'visible',
1449
+ transform: arrowStyle,
1450
+ });
1451
+ }
1452
+ });
1453
+ };
1454
+
1455
+ exports.FloatingUI = FloatingUI;