@dropi/ui 0.1.36 → 0.1.41

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 (426) hide show
  1. package/assets/icons/symbol/svg/sprite.css.svg +1 -1
  2. package/dist/cjs/dropi-accordion-item.cjs.entry.js +1 -1
  3. package/dist/cjs/dropi-alert.cjs.entry.js +1 -1
  4. package/dist/cjs/dropi-banner-external.cjs.entry.js +1 -1
  5. package/dist/cjs/dropi-breadcrumb.cjs.entry.js +2 -2
  6. package/dist/cjs/dropi-button.cjs.entry.js +1 -1
  7. package/dist/cjs/dropi-card-product.cjs.entry.js +2 -2
  8. package/dist/cjs/dropi-card-section.cjs.entry.js +1 -1
  9. package/dist/cjs/dropi-checkbox-selection-list.cjs.entry.js +2 -2
  10. package/dist/cjs/dropi-chips.cjs.entry.js +1 -1
  11. package/dist/cjs/dropi-city-selector.cjs.entry.js +2 -2
  12. package/dist/cjs/dropi-country-selector.cjs.entry.js +1 -1
  13. package/dist/cjs/dropi-date-picker.cjs.entry.js +3 -3
  14. package/dist/cjs/dropi-drawer.cjs.entry.js +1 -1
  15. package/dist/cjs/dropi-favorite-button.cjs.entry.js +1 -1
  16. package/dist/cjs/dropi-file-upload-progress-bar.cjs.entry.js +1 -1
  17. package/dist/cjs/dropi-file-upload.cjs.entry.js +2 -2
  18. package/dist/cjs/dropi-icon.cjs.entry.js +18 -20
  19. package/dist/cjs/dropi-ilustration-icon.cjs.entry.js +1 -1
  20. package/dist/cjs/dropi-image-miniature.cjs.entry.js +1 -1
  21. package/dist/cjs/dropi-image-overlay.cjs.entry.js +1 -1
  22. package/dist/cjs/dropi-input_3.cjs.entry.js +11 -9
  23. package/dist/cjs/dropi-languages-selector.cjs.entry.js +1 -1
  24. package/dist/cjs/dropi-media-player.cjs.entry.js +2 -2
  25. package/dist/cjs/dropi-modal.cjs.entry.js +2 -2
  26. package/dist/cjs/dropi-navbar.cjs.entry.js +2 -2
  27. package/dist/cjs/dropi-otp-send-code.cjs.entry.js +14 -6
  28. package/dist/cjs/dropi-phone-input.cjs.entry.js +1 -1
  29. package/dist/cjs/dropi-radio-selection-list.cjs.entry.js +2 -2
  30. package/dist/cjs/dropi-search.cjs.entry.js +2 -2
  31. package/dist/cjs/dropi-select.cjs.entry.js +7 -7
  32. package/dist/cjs/dropi-sidebar.cjs.entry.js +2 -2
  33. package/dist/cjs/dropi-steps.cjs.entry.js +1 -1
  34. package/dist/cjs/dropi-table.cjs.entry.js +5 -5
  35. package/dist/cjs/dropi-tabs.cjs.entry.js +1 -1
  36. package/dist/cjs/dropi-text-area.cjs.entry.js +1 -1
  37. package/dist/cjs/dropi-time-line.cjs.entry.js +1 -1
  38. package/dist/cjs/dropi-toast.cjs.entry.js +1 -1
  39. package/dist/cjs/dropi-tooltip-v2.cjs.entry.js +2 -2
  40. package/dist/cjs/dropi-ui.cjs.js +1 -1
  41. package/dist/cjs/dropi-vertical-steps.cjs.entry.js +1 -1
  42. package/dist/cjs/dropi-youtube-lazy-video.cjs.entry.js +1 -1
  43. package/dist/cjs/loader.cjs.js +1 -1
  44. package/dist/collection/assets/icons/symbol/svg/sprite.css.svg +1 -1
  45. package/dist/collection/components/dropi-accordion/dropi-accordion-item.js +1 -1
  46. package/dist/collection/components/dropi-alert/dropi-alert.js +1 -1
  47. package/dist/collection/components/dropi-banner-external/dropi-banner-external.js +1 -1
  48. package/dist/collection/components/dropi-breadcrumb/dropi-breadcrumb.js +2 -2
  49. package/dist/collection/components/dropi-button/dropi-button.js +1 -1
  50. package/dist/collection/components/dropi-card-product/dropi-card-product.js +2 -2
  51. package/dist/collection/components/dropi-card-section/dropi-card-section.js +1 -1
  52. package/dist/collection/components/dropi-checkbox-selection-list/dropi-checkbox-selection-list.js +2 -2
  53. package/dist/collection/components/dropi-chips/dropi-chips.js +1 -1
  54. package/dist/collection/components/dropi-city-selector/dropi-city-selector.js +2 -2
  55. package/dist/collection/components/dropi-country-selector/dropi-country-selector.js +1 -1
  56. package/dist/collection/components/dropi-date-picker/dropi-date-picker.js +3 -3
  57. package/dist/collection/components/dropi-drawer/dropi-drawer.js +1 -1
  58. package/dist/collection/components/dropi-favorite-button/dropi-favorite-button.js +1 -1
  59. package/dist/collection/components/dropi-file-upload/dropi-file-upload.js +2 -2
  60. package/dist/collection/components/dropi-file-upload-progress-bar/dropi-file-upload-progress-bar.js +1 -1
  61. package/dist/collection/components/dropi-icon/dropi-icon.css +0 -2
  62. package/dist/collection/components/dropi-icon/dropi-icon.js +25 -27
  63. package/dist/collection/components/dropi-ilustration-icon/dropi-ilustration-icon.js +1 -1
  64. package/dist/collection/components/dropi-image-miniature/dropi-image-miniature.js +1 -1
  65. package/dist/collection/components/dropi-image-overlay/dropi-image-overlay.js +1 -1
  66. package/dist/collection/components/dropi-input/dropi-input.css +13 -5
  67. package/dist/collection/components/dropi-input/dropi-input.js +9 -7
  68. package/dist/collection/components/dropi-languages-selector/dropi-languages-selector.js +1 -1
  69. package/dist/collection/components/dropi-media-player/dropi-media-player.js +2 -2
  70. package/dist/collection/components/dropi-modal/dropi-modal.js +4 -4
  71. package/dist/collection/components/dropi-navbar/dropi-navbar.js +2 -2
  72. package/dist/collection/components/dropi-otp-send-code/dropi-otp-send-code.js +29 -7
  73. package/dist/collection/components/dropi-paginator/dropi-paginator.js +2 -2
  74. package/dist/collection/components/dropi-phone-input/dropi-phone-input.js +1 -1
  75. package/dist/collection/components/dropi-radio-selection-list/dropi-radio-selection-list.js +2 -2
  76. package/dist/collection/components/dropi-search/dropi-search.js +2 -2
  77. package/dist/collection/components/dropi-select/dropi-select.js +7 -7
  78. package/dist/collection/components/dropi-sidebar/dropi-sidebar.js +2 -2
  79. package/dist/collection/components/dropi-steps/dropi-steps.js +1 -1
  80. package/dist/collection/components/dropi-table/dropi-table.js +7 -7
  81. package/dist/collection/components/dropi-tabs/dropi-tabs.js +1 -1
  82. package/dist/collection/components/dropi-tag/dropi-tag.js +1 -1
  83. package/dist/collection/components/dropi-text-area/dropi-text-area.js +1 -1
  84. package/dist/collection/components/dropi-time-line/dropi-time-line.js +1 -1
  85. package/dist/collection/components/dropi-toast/dropi-toast.js +1 -1
  86. package/dist/collection/components/dropi-tooltip-v2/dropi-tooltip.js +2 -2
  87. package/dist/collection/components/dropi-vertical-steps/dropi-vertical-steps.js +1 -1
  88. package/dist/collection/components/dropi-youtube-lazy-video/dropi-youtube-lazy-video.js +1 -1
  89. package/dist/components/dropi-accordion-item.js +1 -1
  90. package/dist/components/dropi-alert-modal.js +1 -1
  91. package/dist/components/dropi-alert.js +1 -1
  92. package/dist/components/dropi-banner-external.js +1 -1
  93. package/dist/components/dropi-breadcrumb.js +1 -1
  94. package/dist/components/dropi-button.js +1 -1
  95. package/dist/components/dropi-card-product.js +1 -1
  96. package/dist/components/dropi-card-section.js +1 -1
  97. package/dist/components/dropi-checkbox-selection-list.js +1 -1
  98. package/dist/components/dropi-chips.js +1 -1
  99. package/dist/components/dropi-city-selector.js +1 -1
  100. package/dist/components/dropi-country-selector.js +1 -1
  101. package/dist/components/dropi-date-picker.js +1 -1
  102. package/dist/components/dropi-drawer.js +1 -1
  103. package/dist/components/dropi-empty-state.js +1 -1
  104. package/dist/components/dropi-favorite-button.js +1 -1
  105. package/dist/components/dropi-file-upload-progress-bar.js +1 -1
  106. package/dist/components/dropi-file-upload.js +1 -1
  107. package/dist/components/dropi-icon.js +1 -1
  108. package/dist/components/dropi-ilustration-icon.js +1 -1
  109. package/dist/components/dropi-image-miniature.js +1 -1
  110. package/dist/components/dropi-image-overlay.js +1 -1
  111. package/dist/components/dropi-input.js +1 -1
  112. package/dist/components/dropi-languages-selector.js +1 -1
  113. package/dist/components/dropi-media-player.js +1 -1
  114. package/dist/components/dropi-modal.js +1 -1
  115. package/dist/components/dropi-navbar.js +1 -1
  116. package/dist/components/dropi-otp-send-code.js +1 -1
  117. package/dist/components/dropi-paginator.js +1 -1
  118. package/dist/components/dropi-phone-input.js +1 -1
  119. package/dist/components/dropi-radio-selection-list.js +1 -1
  120. package/dist/components/dropi-search.js +1 -1
  121. package/dist/components/dropi-select.js +1 -1
  122. package/dist/components/dropi-sidebar.js +1 -1
  123. package/dist/components/dropi-steps.js +1 -1
  124. package/dist/components/dropi-table.js +1 -1
  125. package/dist/components/dropi-tabs.js +1 -1
  126. package/dist/components/dropi-tag.js +1 -1
  127. package/dist/components/dropi-text-area.js +1 -1
  128. package/dist/components/dropi-time-line.js +1 -1
  129. package/dist/components/dropi-toast.js +1 -1
  130. package/dist/components/dropi-tooltip-v2.js +1 -1
  131. package/dist/components/dropi-vertical-steps.js +1 -1
  132. package/dist/components/dropi-youtube-lazy-video.js +1 -1
  133. package/dist/components/p-2YgFOle2.js +1 -0
  134. package/dist/components/p-BDYn1JDe.js +1 -0
  135. package/dist/components/p-BKTMBQVw.js +1 -0
  136. package/dist/components/p-Btsw7sPN.js +1 -0
  137. package/dist/components/p-CgRY3n1J.js +1 -0
  138. package/dist/components/p-Cjq4FTif.js +1 -0
  139. package/dist/components/p-DfdhNT9F.js +1 -0
  140. package/dist/components/p-DvLWbKsf.js +1 -0
  141. package/dist/components/p-Dz9uN5Nw.js +1 -0
  142. package/dist/components/p-FAhcOdS-.js +1 -0
  143. package/dist/dropi-ui/dropi-accordion-item.entry.js +58 -0
  144. package/dist/dropi-ui/dropi-accordion-item.entry.js.map +1 -0
  145. package/dist/dropi-ui/dropi-accordion.entry.js +20 -0
  146. package/dist/dropi-ui/dropi-accordion.entry.js.map +1 -0
  147. package/dist/dropi-ui/dropi-alert-legacy.entry.js +40 -0
  148. package/dist/dropi-ui/dropi-alert-legacy.entry.js.map +1 -0
  149. package/dist/dropi-ui/dropi-alert-modal.entry.js +129 -0
  150. package/dist/dropi-ui/dropi-alert-modal.entry.js.map +1 -0
  151. package/dist/dropi-ui/dropi-alert.entry.js +65 -0
  152. package/dist/dropi-ui/dropi-alert.entry.js.map +1 -0
  153. package/dist/dropi-ui/dropi-avatars.entry.js +32 -0
  154. package/dist/dropi-ui/dropi-avatars.entry.js.map +1 -0
  155. package/dist/dropi-ui/dropi-badge-legacy.entry.js +31 -0
  156. package/dist/dropi-ui/dropi-badge-legacy.entry.js.map +1 -0
  157. package/dist/dropi-ui/dropi-badge.entry.js +38 -0
  158. package/dist/dropi-ui/dropi-badge.entry.js.map +1 -0
  159. package/dist/dropi-ui/dropi-banner-external.entry.js +64 -0
  160. package/dist/dropi-ui/dropi-banner-external.entry.js.map +1 -0
  161. package/dist/dropi-ui/dropi-breadcrumb.entry.js +49 -0
  162. package/dist/dropi-ui/dropi-breadcrumb.entry.js.map +1 -0
  163. package/dist/dropi-ui/dropi-button.entry.js +88 -0
  164. package/dist/dropi-ui/dropi-button.entry.js.map +1 -0
  165. package/dist/dropi-ui/dropi-card-checkbox.entry.js +49 -0
  166. package/dist/dropi-ui/dropi-card-checkbox.entry.js.map +1 -0
  167. package/dist/dropi-ui/dropi-card-product.entry.js +79 -0
  168. package/dist/dropi-ui/dropi-card-product.entry.js.map +1 -0
  169. package/dist/dropi-ui/dropi-card-section.entry.js +39 -0
  170. package/dist/dropi-ui/dropi-card-section.entry.js.map +1 -0
  171. package/dist/dropi-ui/dropi-carousel.entry.js +154 -0
  172. package/dist/dropi-ui/dropi-carousel.entry.js.map +1 -0
  173. package/dist/dropi-ui/dropi-checkbox-selection-list.entry.js +74 -0
  174. package/dist/dropi-ui/dropi-checkbox-selection-list.entry.js.map +1 -0
  175. package/dist/dropi-ui/dropi-checkbox.entry.js +37 -0
  176. package/dist/dropi-ui/dropi-checkbox.entry.js.map +1 -0
  177. package/dist/dropi-ui/dropi-chips.entry.js +31 -0
  178. package/dist/dropi-ui/dropi-chips.entry.js.map +1 -0
  179. package/dist/dropi-ui/dropi-city-selector.entry.js +105 -0
  180. package/dist/dropi-ui/dropi-city-selector.entry.js.map +1 -0
  181. package/dist/dropi-ui/dropi-color-picker.entry.js +320 -0
  182. package/dist/dropi-ui/dropi-color-picker.entry.js.map +1 -0
  183. package/dist/dropi-ui/dropi-country-flags.entry.js +38 -0
  184. package/dist/dropi-ui/dropi-country-flags.entry.js.map +1 -0
  185. package/dist/dropi-ui/dropi-country-selector.entry.js +198 -0
  186. package/dist/dropi-ui/dropi-country-selector.entry.js.map +1 -0
  187. package/dist/dropi-ui/dropi-date-picker-range.entry.js +116 -0
  188. package/dist/dropi-ui/dropi-date-picker-range.entry.js.map +1 -0
  189. package/dist/dropi-ui/dropi-date-picker.entry.js +224 -0
  190. package/dist/dropi-ui/dropi-date-picker.entry.js.map +1 -0
  191. package/dist/dropi-ui/dropi-drawer.entry.js +80 -0
  192. package/dist/dropi-ui/dropi-drawer.entry.js.map +1 -0
  193. package/dist/dropi-ui/dropi-dropdown.entry.js +66 -0
  194. package/dist/dropi-ui/dropi-dropdown.entry.js.map +1 -0
  195. package/dist/dropi-ui/dropi-empty-state.entry.js +37 -0
  196. package/dist/dropi-ui/dropi-empty-state.entry.js.map +1 -0
  197. package/dist/dropi-ui/dropi-favorite-button.entry.js +28 -0
  198. package/dist/dropi-ui/dropi-favorite-button.entry.js.map +1 -0
  199. package/dist/dropi-ui/dropi-file-upload-progress-bar.entry.js +78 -0
  200. package/dist/dropi-ui/dropi-file-upload-progress-bar.entry.js.map +1 -0
  201. package/dist/dropi-ui/dropi-file-upload.entry.js +238 -0
  202. package/dist/dropi-ui/dropi-file-upload.entry.js.map +1 -0
  203. package/dist/dropi-ui/dropi-icon.entry.js +66 -0
  204. package/dist/dropi-ui/dropi-icon.entry.js.map +1 -0
  205. package/dist/dropi-ui/dropi-ilustration-icon.entry.js +40 -0
  206. package/dist/dropi-ui/dropi-ilustration-icon.entry.js.map +1 -0
  207. package/dist/dropi-ui/dropi-image-miniature.entry.js +45 -0
  208. package/dist/dropi-ui/dropi-image-miniature.entry.js.map +1 -0
  209. package/dist/dropi-ui/dropi-image-overlay.entry.js +64 -0
  210. package/dist/dropi-ui/dropi-image-overlay.entry.js.map +1 -0
  211. package/dist/dropi-ui/dropi-input.entry.js +266 -0
  212. package/dist/dropi-ui/dropi-input.entry.js.map +1 -0
  213. package/dist/dropi-ui/dropi-languages-selector.entry.js +62 -0
  214. package/dist/dropi-ui/dropi-languages-selector.entry.js.map +1 -0
  215. package/dist/dropi-ui/dropi-logo.entry.js +38 -0
  216. package/dist/dropi-ui/dropi-logo.entry.js.map +1 -0
  217. package/dist/dropi-ui/dropi-lottie-loader.entry.js +28 -0
  218. package/dist/dropi-ui/dropi-lottie-loader.entry.js.map +1 -0
  219. package/dist/dropi-ui/dropi-media-player.entry.js +193 -0
  220. package/dist/dropi-ui/dropi-media-player.entry.js.map +1 -0
  221. package/dist/dropi-ui/dropi-modal.entry.js +143 -0
  222. package/dist/dropi-ui/dropi-modal.entry.js.map +1 -0
  223. package/dist/dropi-ui/dropi-navbar.entry.js +55 -0
  224. package/dist/dropi-ui/dropi-navbar.entry.js.map +1 -0
  225. package/dist/dropi-ui/dropi-otp-send-code.entry.js +101 -0
  226. package/dist/dropi-ui/dropi-otp-send-code.entry.js.map +1 -0
  227. package/dist/dropi-ui/dropi-paginator.entry.js +70 -0
  228. package/dist/dropi-ui/dropi-paginator.entry.js.map +1 -0
  229. package/dist/dropi-ui/dropi-phone-input.entry.js +198 -0
  230. package/dist/dropi-ui/dropi-phone-input.entry.js.map +1 -0
  231. package/dist/dropi-ui/dropi-radio-button.entry.js +48 -0
  232. package/dist/dropi-ui/dropi-radio-button.entry.js.map +1 -0
  233. package/dist/dropi-ui/dropi-radio-selection-list.entry.js +61 -0
  234. package/dist/dropi-ui/dropi-radio-selection-list.entry.js.map +1 -0
  235. package/dist/dropi-ui/dropi-read-more.entry.js +41 -0
  236. package/dist/dropi-ui/dropi-read-more.entry.js.map +1 -0
  237. package/dist/dropi-ui/dropi-search.entry.js +125 -0
  238. package/dist/dropi-ui/dropi-search.entry.js.map +1 -0
  239. package/dist/dropi-ui/dropi-select.entry.js +383 -0
  240. package/dist/dropi-ui/dropi-select.entry.js.map +1 -0
  241. package/dist/dropi-ui/dropi-sidebar.entry.js +79 -0
  242. package/dist/dropi-ui/dropi-sidebar.entry.js.map +1 -0
  243. package/dist/dropi-ui/dropi-simple-stepper.entry.js +54 -0
  244. package/dist/dropi-ui/dropi-simple-stepper.entry.js.map +1 -0
  245. package/dist/dropi-ui/dropi-skeleton.entry.js +58 -0
  246. package/dist/dropi-ui/dropi-skeleton.entry.js.map +1 -0
  247. package/dist/dropi-ui/dropi-steps.entry.js +53 -0
  248. package/dist/dropi-ui/dropi-steps.entry.js.map +1 -0
  249. package/dist/dropi-ui/dropi-switch.entry.js +31 -0
  250. package/dist/dropi-ui/dropi-switch.entry.js.map +1 -0
  251. package/dist/dropi-ui/dropi-table.entry.js +300 -0
  252. package/dist/dropi-ui/dropi-table.entry.js.map +1 -0
  253. package/dist/dropi-ui/dropi-tabs.entry.js +52 -0
  254. package/dist/dropi-ui/dropi-tabs.entry.js.map +1 -0
  255. package/dist/dropi-ui/dropi-tag-type-product.entry.js +20 -0
  256. package/dist/dropi-ui/dropi-tag-type-product.entry.js.map +1 -0
  257. package/dist/dropi-ui/dropi-tag.entry.js +69 -0
  258. package/dist/dropi-ui/dropi-tag.entry.js.map +1 -0
  259. package/dist/dropi-ui/dropi-text-area.entry.js +135 -0
  260. package/dist/dropi-ui/dropi-text-area.entry.js.map +1 -0
  261. package/dist/dropi-ui/dropi-time-line.entry.js +35 -0
  262. package/dist/dropi-ui/dropi-time-line.entry.js.map +1 -0
  263. package/dist/dropi-ui/dropi-toast.entry.js +57 -0
  264. package/dist/dropi-ui/dropi-toast.entry.js.map +1 -0
  265. package/dist/dropi-ui/dropi-tooltip-v2.entry.js +132 -0
  266. package/dist/dropi-ui/dropi-tooltip-v2.entry.js.map +1 -0
  267. package/dist/dropi-ui/dropi-tooltip.entry.js +22 -0
  268. package/dist/dropi-ui/dropi-tooltip.entry.js.map +1 -0
  269. package/dist/dropi-ui/dropi-ui.css +311 -1
  270. package/dist/dropi-ui/dropi-ui.esm.js +50 -1
  271. package/dist/dropi-ui/dropi-ui.esm.js.map +1 -0
  272. package/dist/dropi-ui/dropi-vertical-steps.entry.js +56 -0
  273. package/dist/dropi-ui/dropi-vertical-steps.entry.js.map +1 -0
  274. package/dist/dropi-ui/dropi-youtube-lazy-video.entry.js +34 -0
  275. package/dist/dropi-ui/dropi-youtube-lazy-video.entry.js.map +1 -0
  276. package/dist/dropi-ui/index-Cvp2LQOM.js +4585 -0
  277. package/dist/dropi-ui/index-Cvp2LQOM.js.map +1 -0
  278. package/dist/dropi-ui/index.esm.js +4 -0
  279. package/dist/dropi-ui/index.esm.js.map +1 -0
  280. package/dist/dropi-ui/{p-db38bf16.entry.js → p-01e4fe42.entry.js} +1 -1
  281. package/dist/dropi-ui/p-099f4475.entry.js +1 -0
  282. package/dist/dropi-ui/p-17b16a74.entry.js +1 -0
  283. package/dist/dropi-ui/p-1a07b3a6.entry.js +1 -0
  284. package/dist/dropi-ui/p-1cd4d630.entry.js +1 -0
  285. package/dist/dropi-ui/p-1d75dff6.entry.js +1 -0
  286. package/dist/dropi-ui/p-20a6a2aa.entry.js +1 -0
  287. package/dist/dropi-ui/p-256bf069.entry.js +1 -0
  288. package/dist/dropi-ui/p-25f0c2c9.entry.js +1 -0
  289. package/dist/dropi-ui/p-2d9978c1.entry.js +1 -0
  290. package/dist/dropi-ui/p-35b37d1a.entry.js +1 -0
  291. package/dist/dropi-ui/p-38ea66e4.entry.js +1 -0
  292. package/dist/dropi-ui/p-4e401fbc.entry.js +1 -0
  293. package/dist/dropi-ui/p-53d2905c.entry.js +1 -0
  294. package/dist/dropi-ui/p-54bfb072.entry.js +1 -0
  295. package/dist/dropi-ui/p-5915d227.entry.js +1 -0
  296. package/dist/dropi-ui/p-650a7679.entry.js +1 -0
  297. package/dist/dropi-ui/p-719a01cb.entry.js +1 -0
  298. package/dist/dropi-ui/p-7369b3b4.entry.js +1 -0
  299. package/dist/dropi-ui/{p-e3ad21f8.entry.js → p-77cd2fcb.entry.js} +1 -1
  300. package/dist/dropi-ui/p-7a18b7a0.entry.js +1 -0
  301. package/dist/dropi-ui/p-83887880.entry.js +1 -0
  302. package/dist/dropi-ui/p-83dbc407.entry.js +1 -0
  303. package/dist/dropi-ui/p-85c637bd.entry.js +1 -0
  304. package/dist/dropi-ui/{p-e6e766ed.entry.js → p-87cc4dcd.entry.js} +1 -1
  305. package/dist/dropi-ui/p-899089f0.entry.js +1 -0
  306. package/dist/dropi-ui/p-8c107dbe.entry.js +1 -0
  307. package/dist/dropi-ui/p-929bc2b6.entry.js +1 -0
  308. package/dist/dropi-ui/p-9ac8caea.entry.js +1 -0
  309. package/dist/dropi-ui/p-9b24e8fd.entry.js +1 -0
  310. package/dist/dropi-ui/p-9c73b4ce.entry.js +1 -0
  311. package/dist/dropi-ui/p-a580e8c8.entry.js +1 -0
  312. package/dist/dropi-ui/p-a9f93e82.entry.js +1 -0
  313. package/dist/dropi-ui/p-aa0f5964.entry.js +1 -0
  314. package/dist/dropi-ui/p-aadd5863.entry.js +1 -0
  315. package/dist/dropi-ui/p-b25faf92.entry.js +1 -0
  316. package/dist/dropi-ui/p-b605d3d9.entry.js +1 -0
  317. package/dist/dropi-ui/p-bbb5e0ae.entry.js +1 -0
  318. package/dist/dropi-ui/p-c4d2881d.entry.js +1 -0
  319. package/dist/dropi-ui/p-d1aeb373.entry.js +1 -0
  320. package/dist/dropi-ui/p-d724ced4.entry.js +1 -0
  321. package/dist/dropi-ui/p-dc53a798.entry.js +1 -0
  322. package/dist/dropi-ui/p-e1b3c9a3.entry.js +1 -0
  323. package/dist/dropi-ui/p-e3c120ba.entry.js +1 -0
  324. package/dist/dropi-ui/p-edf796ee.entry.js +1 -0
  325. package/dist/dropi-ui/p-f2527a45.entry.js +1 -0
  326. package/dist/dropi-ui/p-f6c9057d.entry.js +1 -0
  327. package/dist/dropi-ui/p-f7fd7832.entry.js +1 -0
  328. package/dist/dropi-ui/p-f9888cea.entry.js +1 -0
  329. package/dist/dropi-ui/p-ffd415a2.entry.js +1 -0
  330. package/dist/esm/dropi-accordion-item.entry.js +1 -1
  331. package/dist/esm/dropi-alert.entry.js +1 -1
  332. package/dist/esm/dropi-banner-external.entry.js +1 -1
  333. package/dist/esm/dropi-breadcrumb.entry.js +2 -2
  334. package/dist/esm/dropi-button.entry.js +1 -1
  335. package/dist/esm/dropi-card-product.entry.js +2 -2
  336. package/dist/esm/dropi-card-section.entry.js +1 -1
  337. package/dist/esm/dropi-checkbox-selection-list.entry.js +2 -2
  338. package/dist/esm/dropi-chips.entry.js +1 -1
  339. package/dist/esm/dropi-city-selector.entry.js +2 -2
  340. package/dist/esm/dropi-country-selector.entry.js +1 -1
  341. package/dist/esm/dropi-date-picker.entry.js +3 -3
  342. package/dist/esm/dropi-drawer.entry.js +1 -1
  343. package/dist/esm/dropi-favorite-button.entry.js +1 -1
  344. package/dist/esm/dropi-file-upload-progress-bar.entry.js +1 -1
  345. package/dist/esm/dropi-file-upload.entry.js +2 -2
  346. package/dist/esm/dropi-icon.entry.js +18 -20
  347. package/dist/esm/dropi-ilustration-icon.entry.js +1 -1
  348. package/dist/esm/dropi-image-miniature.entry.js +1 -1
  349. package/dist/esm/dropi-image-overlay.entry.js +1 -1
  350. package/dist/esm/dropi-input_3.entry.js +11 -9
  351. package/dist/esm/dropi-languages-selector.entry.js +1 -1
  352. package/dist/esm/dropi-media-player.entry.js +2 -2
  353. package/dist/esm/dropi-modal.entry.js +2 -2
  354. package/dist/esm/dropi-navbar.entry.js +2 -2
  355. package/dist/esm/dropi-otp-send-code.entry.js +14 -6
  356. package/dist/esm/dropi-phone-input.entry.js +1 -1
  357. package/dist/esm/dropi-radio-selection-list.entry.js +2 -2
  358. package/dist/esm/dropi-search.entry.js +2 -2
  359. package/dist/esm/dropi-select.entry.js +7 -7
  360. package/dist/esm/dropi-sidebar.entry.js +2 -2
  361. package/dist/esm/dropi-steps.entry.js +1 -1
  362. package/dist/esm/dropi-table.entry.js +5 -5
  363. package/dist/esm/dropi-tabs.entry.js +1 -1
  364. package/dist/esm/dropi-text-area.entry.js +1 -1
  365. package/dist/esm/dropi-time-line.entry.js +1 -1
  366. package/dist/esm/dropi-toast.entry.js +1 -1
  367. package/dist/esm/dropi-tooltip-v2.entry.js +2 -2
  368. package/dist/esm/dropi-ui.js +1 -1
  369. package/dist/esm/dropi-vertical-steps.entry.js +1 -1
  370. package/dist/esm/dropi-youtube-lazy-video.entry.js +1 -1
  371. package/dist/esm/loader.js +1 -1
  372. package/dist/types/components/dropi-icon/dropi-icon.d.ts +4 -9
  373. package/dist/types/components/dropi-input/dropi-input.d.ts +1 -1
  374. package/dist/types/components/dropi-modal/dropi-modal.d.ts +1 -1
  375. package/dist/types/components/dropi-otp-send-code/dropi-otp-send-code.d.ts +3 -1
  376. package/dist/types/components/dropi-table/dropi-table.d.ts +1 -1
  377. package/dist/types/components.d.ts +39 -38
  378. package/hydrate/index.js +109 -101
  379. package/hydrate/index.mjs +109 -101
  380. package/package.json +1 -1
  381. package/scripts/setup.js +27 -5
  382. package/dist/components/p-B_Ace02i.js +0 -1
  383. package/dist/components/p-BrjO_JXp.js +0 -1
  384. package/dist/components/p-BwhxWL4p.js +0 -1
  385. package/dist/components/p-Bz2jXX3R.js +0 -1
  386. package/dist/components/p-D-vQQQNz.js +0 -1
  387. package/dist/components/p-D13d88W3.js +0 -1
  388. package/dist/components/p-I3w7xF7Q.js +0 -1
  389. package/dist/components/p-o5gyrbbD.js +0 -1
  390. package/dist/dropi-ui/p-00e5a2de.entry.js +0 -1
  391. package/dist/dropi-ui/p-0188e07a.entry.js +0 -1
  392. package/dist/dropi-ui/p-02710049.entry.js +0 -1
  393. package/dist/dropi-ui/p-18adf694.entry.js +0 -1
  394. package/dist/dropi-ui/p-1a3619c3.entry.js +0 -1
  395. package/dist/dropi-ui/p-25640777.entry.js +0 -1
  396. package/dist/dropi-ui/p-2674d901.entry.js +0 -1
  397. package/dist/dropi-ui/p-2af538b9.entry.js +0 -1
  398. package/dist/dropi-ui/p-3013f3b8.entry.js +0 -1
  399. package/dist/dropi-ui/p-3321ca70.entry.js +0 -1
  400. package/dist/dropi-ui/p-33d242ec.entry.js +0 -1
  401. package/dist/dropi-ui/p-39af6478.entry.js +0 -1
  402. package/dist/dropi-ui/p-446a481d.entry.js +0 -1
  403. package/dist/dropi-ui/p-50e0d44f.entry.js +0 -1
  404. package/dist/dropi-ui/p-5c0bd7c2.entry.js +0 -1
  405. package/dist/dropi-ui/p-5ddf6e93.entry.js +0 -1
  406. package/dist/dropi-ui/p-5fb33ae4.entry.js +0 -1
  407. package/dist/dropi-ui/p-665ef7ba.entry.js +0 -1
  408. package/dist/dropi-ui/p-66b80371.entry.js +0 -1
  409. package/dist/dropi-ui/p-7bfc1c27.entry.js +0 -1
  410. package/dist/dropi-ui/p-7c0d2edf.entry.js +0 -1
  411. package/dist/dropi-ui/p-7eb27836.entry.js +0 -1
  412. package/dist/dropi-ui/p-8bf5d8ee.entry.js +0 -1
  413. package/dist/dropi-ui/p-9212f544.entry.js +0 -1
  414. package/dist/dropi-ui/p-955e52f8.entry.js +0 -1
  415. package/dist/dropi-ui/p-976a15e3.entry.js +0 -1
  416. package/dist/dropi-ui/p-a1c93e55.entry.js +0 -1
  417. package/dist/dropi-ui/p-a232c6a7.entry.js +0 -1
  418. package/dist/dropi-ui/p-a822a23e.entry.js +0 -1
  419. package/dist/dropi-ui/p-af8e2157.entry.js +0 -1
  420. package/dist/dropi-ui/p-c3614c4a.entry.js +0 -1
  421. package/dist/dropi-ui/p-cc527d91.entry.js +0 -1
  422. package/dist/dropi-ui/p-cdde481b.entry.js +0 -1
  423. package/dist/dropi-ui/p-dd5d8b1b.entry.js +0 -1
  424. package/dist/dropi-ui/p-efc2fc35.entry.js +0 -1
  425. package/dist/dropi-ui/p-f41cd9b5.entry.js +0 -1
  426. package/dist/dropi-ui/p-fa3d0267.entry.js +0 -1
@@ -0,0 +1,320 @@
1
+ import { r as registerInstance, d as createEvent, a as getElement, h } from './index-Cvp2LQOM.js';
2
+
3
+ const dropiColorPickerCss = () => `:host{display:block}.general-container{position:relative;width:fit-content}.main-input-container{display:flex;flex-wrap:nowrap;justify-content:flex-start;align-items:center;gap:var(--Size-3);position:relative;width:fit-content}.main-input-container .overlay{position:absolute;top:0;left:0;width:100%;height:100%;z-index:100;cursor:pointer}.line-color-preview{width:40px;height:40px;border-radius:50%;border:1px solid var(--Gray-Gray-200);display:flex;justify-content:center;align-items:center;padding:5px}.line-color-preview .color-preview{width:100%;height:100%;border-radius:50%;border:1px solid var(--Gray-Gray-200)}.position-right{top:0;left:250px}.position-left{top:0;right:200px}.position-top{bottom:55px}.position-bottom{top:55px}.position-bottom::before{transform:rotate(90deg);left:50%;top:-15px}.position-right::before{left:-6px;top:10px}.position-top::before{transform:rotate(270deg);left:50%;bottom:-15px}.position-left::before{transform:rotate(180deg);right:-9px}.color-picker-container::before{content:'';position:absolute;width:0;height:0;border-top:10px solid transparent;border-bottom:10px solid transparent;border-right:10px solid var(--Neutral-White);z-index:1}.color-picker-container{width:280px;padding:var(--Size-4);background:var(--Neutral-White);border-radius:var(--Size-2);box-shadow:var(--Shadow-large);position:absolute;z-index:100;transform-origin:top left;opacity:0;transition:transform 0.2s ease-out, opacity 0.2s ease-out;pointer-events:none}.color-picker-container .main-color-canvas-container{position:relative;margin-bottom:var(--Size-4);border:1px solid var(--Gray-Gray-200);border-radius:var(--Size-1);display:flex;justify-self:center;align-items:center}.color-picker-container .main-color-canvas-container canvas{display:block;border-radius:var(--Size-1)}.color-picker-container .main-color-canvas-container .color-selector-pointer{position:absolute;width:var(--Size-3);height:var(--Size-3);border:2px solid var(--Neutral-White);border-radius:50%;transform:translate(-6px, -6px);pointer-events:none}.color-picker-container .slider-container{display:flex;flex-direction:column;gap:var(--Size-3)}.color-picker-container .slider-container .slider-group{display:flex;flex-direction:column;gap:var(--Size-1)}.color-picker-container .slider-container .slider-group label{font-size:var(--font-size-xs);color:var(--Gray-Gray-500);font-weight:var(--font-weight-bold)}.color-picker-container .slider-container .slider-group .hue-slider-container,.color-picker-container .slider-container .slider-group .opacity-slider-container{position:relative;height:var(--Size-3);border-radius:var(--Size-4);overflow:hidden}.color-picker-container .slider-container .slider-group .hue-slider-container canvas,.color-picker-container .slider-container .slider-group .opacity-slider-container canvas{display:block;width:100%;height:100%}.color-picker-container .slider-container .slider-group .hue-slider-container .slider-pointer,.color-picker-container .slider-container .slider-group .opacity-slider-container .slider-pointer{position:absolute;top:0;height:var(--Size-3);width:var(--Size-3);background:transparent;border:2px solid var(--Neutral-White);border-radius:50%;pointer-events:none}.color-picker-container.show{transform:scale(1);opacity:1;pointer-events:auto}.color-info .color-label{font-size:var(--font-size-xs);color:var(--Gray-Gray-500);font-weight:var(--font-weight-bold);text-transform:uppercase;margin-bottom:var(--Size-2)}.color-info .color-input{border:1px solid var(--Gray-Gray-200, #ddd);border-radius:var(--Size-1);padding:6px 8px;font-size:var(--font-size-s);width:100%;font-family:monospace;text-transform:uppercase;background-color:var(--Neutral-White, #ffffff);color:var(--Gray-Gray-800, #1f2433);outline:none}`;
4
+
5
+ const DropiColorPicker = class {
6
+ constructor(hostRef) {
7
+ registerInstance(this, hostRef);
8
+ this.colorChange = createEvent(this, "colorChange", 7);
9
+ }
10
+ get el() { return getElement(this); }
11
+ currentColor = '#ffffff';
12
+ position = 'right';
13
+ colorChange;
14
+ color = '';
15
+ hue = 0;
16
+ saturation = 0;
17
+ currentVal = 0;
18
+ opacity = 100;
19
+ showEdit = false;
20
+ isDragging = false;
21
+ isHueDragging = false;
22
+ isOpacityDragging = false;
23
+ colorCanvas;
24
+ hueCanvas;
25
+ opacityCanvas;
26
+ onValueChange(newValue) {
27
+ if (!this.showEdit) {
28
+ this.color = newValue;
29
+ this.syncFromHex();
30
+ }
31
+ }
32
+ componentWillLoad() {
33
+ this.color = this.currentColor;
34
+ this.syncFromHex();
35
+ }
36
+ componentDidLoad() {
37
+ document.addEventListener('mousemove', this.onMouseMove.bind(this));
38
+ document.addEventListener('mouseup', this.onMouseUp.bind(this));
39
+ document.addEventListener('click', this.handleClickOutside.bind(this));
40
+ // Defer canvas drawing slightly to ensure elements are rendered
41
+ setTimeout(() => {
42
+ if (this.hueCanvas)
43
+ this.drawHueCanvas();
44
+ if (this.colorCanvas)
45
+ this.drawColorCanvas();
46
+ if (this.opacityCanvas)
47
+ this.drawOpacityCanvas();
48
+ }, 50);
49
+ }
50
+ disconnectedCallback() {
51
+ document.removeEventListener('mousemove', this.onMouseMove.bind(this));
52
+ document.removeEventListener('mouseup', this.onMouseUp.bind(this));
53
+ document.removeEventListener('click', this.handleClickOutside.bind(this));
54
+ }
55
+ onMouseMove(event) {
56
+ if (this.isDragging) {
57
+ this.updateColorFromPosition(event);
58
+ return;
59
+ }
60
+ if (this.isHueDragging) {
61
+ this.updateHueFromPosition(event);
62
+ return;
63
+ }
64
+ if (this.isOpacityDragging) {
65
+ this.updateOpacityFromPosition(event);
66
+ return;
67
+ }
68
+ }
69
+ onMouseUp() {
70
+ this.isDragging = false;
71
+ this.isHueDragging = false;
72
+ this.isOpacityDragging = false;
73
+ }
74
+ handleClickOutside(event) {
75
+ // Determine if the click target is outside the host element
76
+ const clickedInside = event.composedPath().includes(this.el);
77
+ if (!clickedInside && this.showEdit) {
78
+ this.showEdit = false;
79
+ this.currentColor = this.color;
80
+ this.colorChange.emit(this.color);
81
+ }
82
+ }
83
+ drawColorCanvas() {
84
+ if (!this.colorCanvas)
85
+ return;
86
+ const ctx = this.colorCanvas.getContext('2d');
87
+ const width = this.colorCanvas.width;
88
+ const height = this.colorCanvas.height;
89
+ const saturationGradient = ctx.createLinearGradient(0, 0, width, 0);
90
+ saturationGradient.addColorStop(0, '#FFFFFF');
91
+ saturationGradient.addColorStop(1, `hsl(${this.hue ?? 0}, 100%, 50%)`);
92
+ const valueGradient = ctx.createLinearGradient(0, 0, 0, height);
93
+ valueGradient.addColorStop(0, 'rgba(0, 0, 0, 0)');
94
+ valueGradient.addColorStop(1, '#000000');
95
+ ctx.fillStyle = saturationGradient;
96
+ ctx.fillRect(0, 0, width, height);
97
+ ctx.fillStyle = valueGradient;
98
+ ctx.fillRect(0, 0, width, height);
99
+ }
100
+ drawHueCanvas() {
101
+ if (!this.hueCanvas)
102
+ return;
103
+ const ctx = this.hueCanvas.getContext('2d');
104
+ const width = this.hueCanvas.width;
105
+ const height = this.hueCanvas.height;
106
+ const hueGradient = ctx.createLinearGradient(0, 0, width, 0);
107
+ for (let i = 0; i <= 360; i += 60) {
108
+ hueGradient.addColorStop(i / 360, `hsl(${i}, 100%, 50%)`);
109
+ }
110
+ ctx.fillStyle = hueGradient;
111
+ ctx.fillRect(0, 0, width, height);
112
+ }
113
+ drawOpacityCanvas() {
114
+ if (!this.opacityCanvas)
115
+ return;
116
+ const ctx = this.opacityCanvas.getContext('2d');
117
+ const width = this.opacityCanvas.width;
118
+ const height = this.opacityCanvas.height;
119
+ ctx.clearRect(0, 0, width, height);
120
+ ctx.fillStyle = '#FFFFFF';
121
+ ctx.fillRect(0, 0, width, height);
122
+ const rgb = this.hsvToRgb(this.hue, this.saturation, this.currentVal);
123
+ const opacityGradient = ctx.createLinearGradient(0, 0, width, 0);
124
+ opacityGradient.addColorStop(0, `rgba(${rgb.r}, ${rgb.g}, ${rgb.b}, 0)`);
125
+ opacityGradient.addColorStop(1, `rgba(${rgb.r}, ${rgb.g}, ${rgb.b}, 1)`);
126
+ ctx.fillStyle = opacityGradient;
127
+ ctx.fillRect(0, 0, width, height);
128
+ }
129
+ updateColor() {
130
+ const rgb = this.hsvToRgb(this.hue, this.saturation, this.currentVal);
131
+ const hex = this.rgbToHex(rgb.r, rgb.g, rgb.b, this.opacity);
132
+ this.color = hex;
133
+ this.drawColorCanvas();
134
+ this.drawOpacityCanvas();
135
+ this.currentColor = hex;
136
+ this.colorChange.emit(this.color);
137
+ }
138
+ hsvToRgb(h, s, v) {
139
+ s /= 100;
140
+ v /= 100;
141
+ const c = v * s;
142
+ const x = c * (1 - Math.abs(((h / 60) % 2) - 1));
143
+ const m = v - c;
144
+ let r = 0, g = 0, b = 0;
145
+ if (h >= 0 && h < 60) {
146
+ r = c;
147
+ g = x;
148
+ b = 0;
149
+ }
150
+ else if (h >= 60 && h < 120) {
151
+ r = x;
152
+ g = c;
153
+ b = 0;
154
+ }
155
+ else if (h >= 120 && h < 180) {
156
+ r = 0;
157
+ g = c;
158
+ b = x;
159
+ }
160
+ else if (h >= 180 && h < 240) {
161
+ r = 0;
162
+ g = x;
163
+ b = c;
164
+ }
165
+ else if (h >= 240 && h < 300) {
166
+ r = x;
167
+ g = 0;
168
+ b = c;
169
+ }
170
+ else if (h >= 300 && h <= 360) {
171
+ r = c;
172
+ g = 0;
173
+ b = x;
174
+ }
175
+ return {
176
+ r: Math.round((r + m) * 255),
177
+ g: Math.round((g + m) * 255),
178
+ b: Math.round((b + m) * 255),
179
+ };
180
+ }
181
+ rgbToHex(red, green, black, opacity = 100) {
182
+ const toHex = (val) => {
183
+ const hex = Math.round(val).toString(16);
184
+ return hex.padStart(2, '0');
185
+ };
186
+ const rHex = toHex(red);
187
+ const gHex = toHex(green);
188
+ const bHex = toHex(black);
189
+ const alpha = Math.round((opacity / 100) * 255);
190
+ const aHex = toHex(alpha);
191
+ return `#${rHex}${gHex}${bHex}${aHex}`;
192
+ }
193
+ syncFromHex() {
194
+ if (/^#?[0-9A-F]{6}([0-9A-F]{2})?$/i.test(this.color)) {
195
+ if (!this.color.startsWith('#')) {
196
+ this.color = '#' + this.color;
197
+ }
198
+ const hex = this.color.substring(1);
199
+ const r = parseInt(hex.substring(0, 2), 16);
200
+ const g = parseInt(hex.substring(2, 4), 16);
201
+ const b = parseInt(hex.substring(4, 6), 16);
202
+ const a = hex.length === 8 ? parseInt(hex.substring(6, 8), 16) / 255 : 1;
203
+ const hsv = this.rgbToHsv(r, g, b, a);
204
+ this.hue = hsv.h;
205
+ this.saturation = hsv.s;
206
+ this.currentVal = hsv.v;
207
+ this.opacity = a * 100;
208
+ this.drawColorCanvas();
209
+ this.drawOpacityCanvas();
210
+ }
211
+ }
212
+ onHexInputChange(event) {
213
+ this.color = event.target.value;
214
+ this.syncFromHex();
215
+ }
216
+ rgbToHsv(r, g, b, a = 1) {
217
+ r /= 255;
218
+ g /= 255;
219
+ b /= 255;
220
+ const max = Math.max(r, g, b);
221
+ const min = Math.min(r, g, b);
222
+ const delta = max - min;
223
+ let h = 0;
224
+ if (delta !== 0) {
225
+ if (max === r)
226
+ h = 60 * (((g - b) / delta) % 6);
227
+ else if (max === g)
228
+ h = 60 * ((b - r) / delta + 2);
229
+ else if (max === b)
230
+ h = 60 * ((r - g) / delta + 4);
231
+ }
232
+ if (h < 0)
233
+ h += 360;
234
+ const s = max === 0 ? 0 : (delta / max) * 100;
235
+ const v = max * 100;
236
+ return {
237
+ h: Math.round(h),
238
+ s: Math.round(s),
239
+ v: Math.round(v),
240
+ a: parseFloat(a.toFixed(3)),
241
+ };
242
+ }
243
+ getCanvasPosition(canvas, event) {
244
+ const rect = canvas.getBoundingClientRect();
245
+ const scaleX = canvas.width / rect.width;
246
+ const scaleY = canvas.height / rect.height;
247
+ return {
248
+ x: (event.clientX - rect.left) * scaleX,
249
+ y: (event.clientY - rect.top) * scaleY,
250
+ };
251
+ }
252
+ onColorMouseDown(event) {
253
+ this.isDragging = true;
254
+ this.updateColorFromPosition(event);
255
+ }
256
+ onHueMouseDown(event) {
257
+ this.isHueDragging = true;
258
+ this.updateHueFromPosition(event);
259
+ }
260
+ onOpacityMouseDown(event) {
261
+ this.isOpacityDragging = true;
262
+ this.updateOpacityFromPosition(event);
263
+ }
264
+ updateColorFromPosition(event) {
265
+ if (!this.colorCanvas)
266
+ return;
267
+ const pos = this.getCanvasPosition(this.colorCanvas, event);
268
+ const x = Math.max(0, Math.min(pos.x, 256));
269
+ const y = Math.max(0, Math.min(pos.y, 150));
270
+ this.saturation = Math.round((x / 256) * 100);
271
+ this.currentVal = 100 - Math.round((y / 150) * 100);
272
+ this.updateColor();
273
+ }
274
+ updateHueFromPosition(event) {
275
+ if (!this.hueCanvas)
276
+ return;
277
+ const pos = this.getCanvasPosition(this.hueCanvas, event);
278
+ const x = Math.max(0, Math.min(pos.x, 256));
279
+ this.hue = Math.round((x / 256) * 360);
280
+ this.drawColorCanvas();
281
+ this.updateColor();
282
+ }
283
+ updateOpacityFromPosition(event) {
284
+ if (!this.opacityCanvas)
285
+ return;
286
+ const pos = this.getCanvasPosition(this.opacityCanvas, event);
287
+ const x = Math.max(0, Math.min(pos.x, 256));
288
+ this.opacity = Math.round((x / 256) * 100);
289
+ this.updateColor();
290
+ }
291
+ showEditor() {
292
+ this.showEdit = !this.showEdit;
293
+ this.color = this.currentColor;
294
+ if (this.showEdit) {
295
+ setTimeout(() => {
296
+ this.drawHueCanvas();
297
+ this.drawColorCanvas();
298
+ this.drawOpacityCanvas();
299
+ this.syncFromHex();
300
+ }, 100);
301
+ }
302
+ }
303
+ render() {
304
+ return (h("div", { key: '2ee2bd6abd837388d8169961f6b1024da228b453', class: "general-container" }, h("div", { key: '15416c1a844daf774dda53f1c08bbe6b15435b64', class: "main-input-container" }, h("div", { key: 'e08aacd3ebb059a8467cf6f597d2b3bb3419e286', class: "overlay", onClick: () => this.showEditor() }), h("div", { key: 'dda8addee7afb351fb1f6c18dda516d29259220d', class: "line-color-preview" }, h("div", { key: 'b242eac802dc0c1d0a9965fb6fc9b6f010408ae2', class: "color-preview", style: { background: this.currentColor } })), h("div", { key: '8dddc6632dddae52cc58d964ee50cae1e6460b12', class: "color-info" }, h("input", { key: '7181e30bddae8005260d285653425cd5cad2386e', type: "text", class: "color-input", value: this.currentColor, maxLength: 9, readOnly: true }))), h("div", { key: '0ad3b547299fc1a4ccab9ddb7efebd7962fd7855', class: `color-picker-container position-${this.position} ${this.showEdit ? 'show' : ''}` }, h("div", { key: 'c49847d5a6ca7a90f27889afe26f6c30c1959676', class: "main-color-canvas-container" }, h("canvas", { key: '44531a25415492782d70d070aacf17797f9e3818', ref: (el) => this.colorCanvas = el, width: 256, height: 150, onMouseDown: (e) => this.onColorMouseDown(e) }), h("div", { key: '325bc14afacafa6dddd0a9bc837c6448ff803bd8', class: "color-selector-pointer", style: {
305
+ left: `${(this.saturation / 100) * 256}px`,
306
+ top: `${((100 - this.currentVal) / 100) * 150}px`
307
+ } })), h("div", { key: 'ab6d2a987b4c317fa218e70a1602ea829505fe0a', class: "slider-container" }, h("div", { key: 'fe9ae897de10c04322653870cb9e5b79f61a2b86', class: "slider-group" }, h("div", { key: 'f39f1935c0410509f6ecbf69b718730201d70be7', class: "hue-slider-container" }, h("canvas", { key: '6a08c8dd36f3c9d70aa0f0438006bc4efa4df401', ref: (el) => this.hueCanvas = el, width: 256, height: 20, onMouseDown: (e) => this.onHueMouseDown(e) }), h("div", { key: 'a91a4f4469e3152b24bf1e7dfd3d4738eb17f661', class: "slider-pointer", style: { left: `${(this.hue / 360) * 234}px` } }))), h("div", { key: '2a45b1e24dcb447e515d8dbfac2ecd4032661af8', class: "slider-group" }, h("div", { key: 'ec945cd912ecf046ca16e7520bae48d3e998f8fd', class: "opacity-slider-container" }, h("canvas", { key: 'f181f9a8b16274d94377f3dd300c3bff231088df', ref: (el) => this.opacityCanvas = el, width: 256, height: 20, onMouseDown: (e) => this.onOpacityMouseDown(e) }), h("div", { key: '2e246b9e62991569c60024ac4f8b1ae32543e03e', class: "slider-pointer", style: { left: `${(this.opacity / 100) * 234}px` } }))), h("div", { key: 'c8c539dda06f8ce70b4c669a32e56cb693132f49', class: "color-info" }, h("div", { key: '5939e97e1331e57a5837e868ea6088b069e3c3eb', class: "color-label" }, "HEX"), h("input", { key: '321cebcb041223d4cb6c072f310720edcdb2391c', type: "text", class: "color-input", value: this.color, onInput: (e) => this.onHexInputChange(e), maxLength: 9 }))))));
308
+ }
309
+ static get watchers() { return {
310
+ "value": [{
311
+ "onValueChange": 0
312
+ }]
313
+ }; }
314
+ };
315
+ DropiColorPicker.style = dropiColorPickerCss();
316
+
317
+ export { DropiColorPicker as dropi_color_picker };
318
+ //# sourceMappingURL=dropi-color-picker.entry.esm.js.map
319
+
320
+ //# sourceMappingURL=dropi-color-picker.entry.js.map
@@ -0,0 +1 @@
1
+ {"file":"dropi-color-picker.entry.js","mappings":"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","names":[],"sources":["src/components/dropi-color-picker/dropi-color-picker.css?tag=dropi-color-picker&encapsulation=shadow","src/components/dropi-color-picker/dropi-color-picker.tsx"],"sourcesContent":[":host {\n display: block;\n}\n\n.general-container {\n position: relative;\n width: fit-content;\n}\n\n.main-input-container {\n display: flex;\n flex-wrap: nowrap;\n justify-content: flex-start;\n align-items: center;\n gap: var(--Size-3);\n position: relative;\n width: fit-content;\n}\n\n.main-input-container .overlay {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n z-index: 100;\n cursor: pointer;\n}\n\n.line-color-preview {\n width: 40px;\n height: 40px;\n border-radius: 50%;\n border: 1px solid var(--Gray-Gray-200);\n display: flex;\n justify-content: center;\n align-items: center;\n padding: 5px;\n}\n\n.line-color-preview .color-preview {\n width: 100%;\n height: 100%;\n border-radius: 50%;\n border: 1px solid var(--Gray-Gray-200);\n}\n\n.position-right {\n top: 0;\n left: 250px;\n}\n\n.position-left {\n top: 0;\n right: 200px;\n}\n\n.position-top {\n bottom: 55px;\n}\n\n.position-bottom {\n top: 55px;\n}\n\n.position-bottom::before {\n transform: rotate(90deg);\n left: 50%;\n top: -15px;\n}\n\n.position-right::before {\n left: -6px;\n top: 10px;\n}\n\n.position-top::before {\n transform: rotate(270deg);\n left: 50%;\n bottom: -15px;\n}\n\n.position-left::before {\n transform: rotate(180deg);\n right: -9px;\n}\n\n.color-picker-container::before {\n content: '';\n position: absolute;\n width: 0;\n height: 0;\n border-top: 10px solid transparent;\n border-bottom: 10px solid transparent;\n border-right: 10px solid var(--Neutral-White);\n z-index: 1;\n}\n\n.color-picker-container {\n width: 280px;\n padding: var(--Size-4);\n background: var(--Neutral-White);\n border-radius: var(--Size-2);\n box-shadow: var(--Shadow-large);\n position: absolute;\n z-index: 100;\n transform-origin: top left;\n opacity: 0;\n transition:\n transform 0.2s ease-out,\n opacity 0.2s ease-out;\n pointer-events: none;\n}\n\n.color-picker-container .main-color-canvas-container {\n position: relative;\n margin-bottom: var(--Size-4);\n border: 1px solid var(--Gray-Gray-200);\n border-radius: var(--Size-1);\n display: flex;\n justify-self: center;\n align-items: center;\n}\n\n.color-picker-container .main-color-canvas-container canvas {\n display: block;\n border-radius: var(--Size-1);\n}\n\n.color-picker-container .main-color-canvas-container .color-selector-pointer {\n position: absolute;\n width: var(--Size-3);\n height: var(--Size-3);\n border: 2px solid var(--Neutral-White);\n border-radius: 50%;\n transform: translate(-6px, -6px);\n pointer-events: none;\n}\n\n.color-picker-container .slider-container {\n display: flex;\n flex-direction: column;\n gap: var(--Size-3);\n}\n\n.color-picker-container .slider-container .slider-group {\n display: flex;\n flex-direction: column;\n gap: var(--Size-1);\n}\n\n.color-picker-container .slider-container .slider-group label {\n font-size: var(--font-size-xs);\n color: var(--Gray-Gray-500);\n font-weight: var(--font-weight-bold);\n}\n\n.color-picker-container .slider-container .slider-group .hue-slider-container,\n.color-picker-container .slider-container .slider-group .opacity-slider-container {\n position: relative;\n height: var(--Size-3);\n border-radius: var(--Size-4);\n overflow: hidden;\n}\n\n.color-picker-container .slider-container .slider-group .hue-slider-container canvas,\n.color-picker-container .slider-container .slider-group .opacity-slider-container canvas {\n display: block;\n width: 100%;\n height: 100%;\n}\n\n.color-picker-container .slider-container .slider-group .hue-slider-container .slider-pointer,\n.color-picker-container .slider-container .slider-group .opacity-slider-container .slider-pointer {\n position: absolute;\n top: 0;\n height: var(--Size-3);\n width: var(--Size-3);\n background: transparent;\n border: 2px solid var(--Neutral-White);\n border-radius: 50%;\n pointer-events: none;\n}\n\n.color-picker-container.show {\n transform: scale(1);\n opacity: 1;\n pointer-events: auto;\n}\n\n.color-info .color-label {\n font-size: var(--font-size-xs);\n color: var(--Gray-Gray-500);\n font-weight: var(--font-weight-bold);\n text-transform: uppercase;\n margin-bottom: var(--Size-2);\n}\n\n.color-info .color-input {\n border: 1px solid var(--Gray-Gray-200, #ddd);\n border-radius: var(--Size-1);\n padding: 6px 8px;\n font-size: var(--font-size-s);\n width: 100%;\n font-family: monospace;\n text-transform: uppercase;\n background-color: var(--Neutral-White, #ffffff);\n color: var(--Gray-Gray-800, #1f2433);\n outline: none;\n}\n","import { Component, Prop, State, Event, EventEmitter, h, Element, Watch } from '@stencil/core';\n\n@Component({\n tag: 'dropi-color-picker',\n styleUrl: 'dropi-color-picker.css',\n shadow: true,\n})\nexport class DropiColorPicker {\n @Element() el!: HTMLElement;\n\n @Prop({ mutable: true }) currentColor: string = '#ffffff';\n @Prop() position: 'top' | 'bottom' | 'left' | 'right' = 'right';\n\n @Event() colorChange: EventEmitter<string>;\n\n @State() private color: string = '';\n @State() private hue: number = 0;\n @State() private saturation: number = 0;\n @State() private currentVal: number = 0;\n @State() private opacity: number = 100;\n \n @State() private showEdit: boolean = false;\n\n private isDragging: boolean = false;\n private isHueDragging: boolean = false;\n private isOpacityDragging: boolean = false;\n\n private colorCanvas!: HTMLCanvasElement;\n private hueCanvas!: HTMLCanvasElement;\n private opacityCanvas!: HTMLCanvasElement;\n\n @Watch('value')\n onValueChange(newValue: string) {\n if (!this.showEdit) {\n this.color = newValue;\n this.syncFromHex();\n }\n }\n\n componentWillLoad() {\n this.color = this.currentColor;\n this.syncFromHex();\n }\n\n componentDidLoad() {\n document.addEventListener('mousemove', this.onMouseMove.bind(this));\n document.addEventListener('mouseup', this.onMouseUp.bind(this));\n document.addEventListener('click', this.handleClickOutside.bind(this));\n \n // Defer canvas drawing slightly to ensure elements are rendered\n setTimeout(() => {\n if (this.hueCanvas) this.drawHueCanvas();\n if (this.colorCanvas) this.drawColorCanvas();\n if (this.opacityCanvas) this.drawOpacityCanvas();\n }, 50);\n }\n\n disconnectedCallback() {\n document.removeEventListener('mousemove', this.onMouseMove.bind(this));\n document.removeEventListener('mouseup', this.onMouseUp.bind(this));\n document.removeEventListener('click', this.handleClickOutside.bind(this));\n }\n\n onMouseMove(event: MouseEvent) {\n if (this.isDragging) {\n this.updateColorFromPosition(event);\n return;\n }\n if (this.isHueDragging) {\n this.updateHueFromPosition(event);\n return;\n }\n if (this.isOpacityDragging) {\n this.updateOpacityFromPosition(event);\n return;\n }\n }\n\n onMouseUp() {\n this.isDragging = false;\n this.isHueDragging = false;\n this.isOpacityDragging = false;\n }\n\n handleClickOutside(event: MouseEvent) {\n // Determine if the click target is outside the host element\n const clickedInside = event.composedPath().includes(this.el);\n if (!clickedInside && this.showEdit) {\n this.showEdit = false;\n this.currentColor = this.color;\n this.colorChange.emit(this.color);\n }\n }\n\n drawColorCanvas() {\n if (!this.colorCanvas) return;\n const ctx = this.colorCanvas.getContext('2d')!;\n const width = this.colorCanvas.width;\n const height = this.colorCanvas.height;\n\n const saturationGradient = ctx.createLinearGradient(0, 0, width, 0);\n saturationGradient.addColorStop(0, '#FFFFFF');\n saturationGradient.addColorStop(1, `hsl(${this.hue ?? 0}, 100%, 50%)`);\n\n const valueGradient = ctx.createLinearGradient(0, 0, 0, height);\n valueGradient.addColorStop(0, 'rgba(0, 0, 0, 0)');\n valueGradient.addColorStop(1, '#000000');\n\n ctx.fillStyle = saturationGradient;\n ctx.fillRect(0, 0, width, height);\n ctx.fillStyle = valueGradient;\n ctx.fillRect(0, 0, width, height);\n }\n\n drawHueCanvas() {\n if (!this.hueCanvas) return;\n const ctx = this.hueCanvas.getContext('2d')!;\n const width = this.hueCanvas.width;\n const height = this.hueCanvas.height;\n\n const hueGradient = ctx.createLinearGradient(0, 0, width, 0);\n for (let i = 0; i <= 360; i += 60) {\n hueGradient.addColorStop(i / 360, `hsl(${i}, 100%, 50%)`);\n }\n\n ctx.fillStyle = hueGradient;\n ctx.fillRect(0, 0, width, height);\n }\n\n drawOpacityCanvas() {\n if (!this.opacityCanvas) return;\n const ctx = this.opacityCanvas.getContext('2d')!;\n const width = this.opacityCanvas.width;\n const height = this.opacityCanvas.height;\n\n ctx.clearRect(0, 0, width, height);\n ctx.fillStyle = '#FFFFFF';\n ctx.fillRect(0, 0, width, height);\n\n const rgb = this.hsvToRgb(this.hue, this.saturation, this.currentVal);\n\n const opacityGradient = ctx.createLinearGradient(0, 0, width, 0);\n opacityGradient.addColorStop(0, `rgba(${rgb.r}, ${rgb.g}, ${rgb.b}, 0)`);\n opacityGradient.addColorStop(1, `rgba(${rgb.r}, ${rgb.g}, ${rgb.b}, 1)`);\n\n ctx.fillStyle = opacityGradient;\n ctx.fillRect(0, 0, width, height);\n }\n\n updateColor() {\n const rgb = this.hsvToRgb(this.hue, this.saturation, this.currentVal);\n const hex = this.rgbToHex(rgb.r, rgb.g, rgb.b, this.opacity);\n this.color = hex;\n this.drawColorCanvas();\n this.drawOpacityCanvas();\n this.currentColor = hex;\n this.colorChange.emit(this.color);\n }\n\n hsvToRgb(h: number, s: number, v: number): { r: number; g: number; b: number } {\n s /= 100;\n v /= 100;\n\n const c = v * s;\n const x = c * (1 - Math.abs(((h / 60) % 2) - 1));\n const m = v - c;\n\n let r = 0, g = 0, b = 0;\n\n if (h >= 0 && h < 60) { r = c; g = x; b = 0; }\n else if (h >= 60 && h < 120) { r = x; g = c; b = 0; }\n else if (h >= 120 && h < 180) { r = 0; g = c; b = x; }\n else if (h >= 180 && h < 240) { r = 0; g = x; b = c; }\n else if (h >= 240 && h < 300) { r = x; g = 0; b = c; }\n else if (h >= 300 && h <= 360) { r = c; g = 0; b = x; }\n\n return {\n r: Math.round((r + m) * 255),\n g: Math.round((g + m) * 255),\n b: Math.round((b + m) * 255),\n };\n }\n\n rgbToHex(red: number, green: number, black: number, opacity = 100) {\n const toHex = (val: number) => {\n const hex = Math.round(val).toString(16);\n return hex.padStart(2, '0');\n };\n\n const rHex = toHex(red);\n const gHex = toHex(green);\n const bHex = toHex(black);\n const alpha = Math.round((opacity / 100) * 255);\n const aHex = toHex(alpha);\n\n return `#${rHex}${gHex}${bHex}${aHex}`;\n }\n\n syncFromHex() {\n if (/^#?[0-9A-F]{6}([0-9A-F]{2})?$/i.test(this.color)) {\n if (!this.color.startsWith('#')) {\n this.color = '#' + this.color;\n }\n\n const hex = this.color.substring(1);\n const r = parseInt(hex.substring(0, 2), 16);\n const g = parseInt(hex.substring(2, 4), 16);\n const b = parseInt(hex.substring(4, 6), 16);\n const a = hex.length === 8 ? parseInt(hex.substring(6, 8), 16) / 255 : 1;\n\n const hsv = this.rgbToHsv(r, g, b, a);\n this.hue = hsv.h;\n this.saturation = hsv.s;\n this.currentVal = hsv.v;\n this.opacity = a * 100;\n\n this.drawColorCanvas();\n this.drawOpacityCanvas();\n }\n }\n\n onHexInputChange(event: Event) {\n this.color = (event.target as HTMLInputElement).value;\n this.syncFromHex();\n }\n\n rgbToHsv(r: number, g: number, b: number, a: number = 1): { h: number; s: number; v: number; a: number } {\n r /= 255;\n g /= 255;\n b /= 255;\n\n const max = Math.max(r, g, b);\n const min = Math.min(r, g, b);\n const delta = max - min;\n\n let h = 0;\n if (delta !== 0) {\n if (max === r) h = 60 * (((g - b) / delta) % 6);\n else if (max === g) h = 60 * ((b - r) / delta + 2);\n else if (max === b) h = 60 * ((r - g) / delta + 4);\n }\n\n if (h < 0) h += 360;\n\n const s = max === 0 ? 0 : (delta / max) * 100;\n const v = max * 100;\n\n return {\n h: Math.round(h),\n s: Math.round(s),\n v: Math.round(v),\n a: parseFloat(a.toFixed(3)),\n };\n }\n\n getCanvasPosition(canvas: HTMLCanvasElement, event: MouseEvent): { x: number; y: number } {\n const rect = canvas.getBoundingClientRect();\n const scaleX = canvas.width / rect.width;\n const scaleY = canvas.height / rect.height;\n\n return {\n x: (event.clientX - rect.left) * scaleX,\n y: (event.clientY - rect.top) * scaleY,\n };\n }\n\n onColorMouseDown(event: MouseEvent) {\n this.isDragging = true;\n this.updateColorFromPosition(event);\n }\n\n onHueMouseDown(event: MouseEvent) {\n this.isHueDragging = true;\n this.updateHueFromPosition(event);\n }\n\n onOpacityMouseDown(event: MouseEvent) {\n this.isOpacityDragging = true;\n this.updateOpacityFromPosition(event);\n }\n\n updateColorFromPosition(event: MouseEvent) {\n if (!this.colorCanvas) return;\n const pos = this.getCanvasPosition(this.colorCanvas, event);\n\n const x = Math.max(0, Math.min(pos.x, 256));\n const y = Math.max(0, Math.min(pos.y, 150));\n\n this.saturation = Math.round((x / 256) * 100);\n this.currentVal = 100 - Math.round((y / 150) * 100);\n this.updateColor();\n }\n\n updateHueFromPosition(event: MouseEvent) {\n if (!this.hueCanvas) return;\n const pos = this.getCanvasPosition(this.hueCanvas, event);\n const x = Math.max(0, Math.min(pos.x, 256));\n this.hue = Math.round((x / 256) * 360);\n this.drawColorCanvas();\n this.updateColor();\n }\n\n updateOpacityFromPosition(event: MouseEvent) {\n if (!this.opacityCanvas) return;\n const pos = this.getCanvasPosition(this.opacityCanvas, event);\n const x = Math.max(0, Math.min(pos.x, 256));\n\n this.opacity = Math.round((x / 256) * 100);\n this.updateColor();\n }\n\n showEditor() {\n this.showEdit = !this.showEdit;\n this.color = this.currentColor;\n if (this.showEdit) {\n setTimeout(() => {\n this.drawHueCanvas();\n this.drawColorCanvas();\n this.drawOpacityCanvas();\n this.syncFromHex();\n }, 100);\n }\n }\n\n render() {\n return (\n <div class=\"general-container\">\n <div class=\"main-input-container\">\n <div class=\"overlay\" onClick={() => this.showEditor()}></div>\n <div class=\"line-color-preview\">\n <div class=\"color-preview\" style={{ background: this.currentColor }}></div>\n </div>\n <div class=\"color-info\">\n <input \n type=\"text\" \n class=\"color-input\" \n value={this.currentColor} \n maxLength={9} \n readOnly \n />\n </div>\n </div>\n\n <div class={`color-picker-container position-${this.position} ${this.showEdit ? 'show' : ''}`}>\n <div class=\"main-color-canvas-container\">\n <canvas \n ref={(el) => this.colorCanvas = el as HTMLCanvasElement} \n width={256} \n height={150} \n onMouseDown={(e) => this.onColorMouseDown(e)}\n ></canvas>\n <div\n class=\"color-selector-pointer\"\n style={{\n left: `${(this.saturation / 100) * 256}px`,\n top: `${((100 - this.currentVal) / 100) * 150}px`\n }}\n ></div>\n </div>\n\n <div class=\"slider-container\">\n <div class=\"slider-group\">\n <div class=\"hue-slider-container\">\n <canvas \n ref={(el) => this.hueCanvas = el as HTMLCanvasElement} \n width={256} \n height={20} \n onMouseDown={(e) => this.onHueMouseDown(e)}\n ></canvas>\n <div class=\"slider-pointer\" style={{ left: `${(this.hue / 360) * 234}px` }}></div>\n </div>\n </div>\n\n <div class=\"slider-group\">\n <div class=\"opacity-slider-container\">\n <canvas\n ref={(el) => this.opacityCanvas = el as HTMLCanvasElement}\n width={256}\n height={20}\n onMouseDown={(e) => this.onOpacityMouseDown(e)}\n ></canvas>\n <div class=\"slider-pointer\" style={{ left: `${(this.opacity / 100) * 234}px` }}></div>\n </div>\n </div>\n\n <div class=\"color-info\">\n <div class=\"color-label\">HEX</div>\n <input\n type=\"text\"\n class=\"color-input\"\n value={this.color}\n onInput={(e) => this.onHexInputChange(e)}\n maxLength={9}\n />\n </div>\n </div>\n </div>\n </div>\n );\n }\n}\n"],"version":3}
@@ -0,0 +1,38 @@
1
+ import { r as registerInstance, h } from './index-Cvp2LQOM.js';
2
+
3
+ const dropiCountryFlagsCss = () => `:host{display:inline-flex}.flag{max-width:40px;max-height:40px;margin:0;display:flex;align-items:center;justify-content:center}.flag img{width:100%;height:100%;object-fit:cover}.circle{border-radius:50%;overflow:hidden}.rectangle{border-radius:4px;overflow:hidden;max-width:32px !important;max-height:24px !important}`;
4
+
5
+ const DropiCountryFlags = class {
6
+ constructor(hostRef) {
7
+ registerInstance(this, hostRef);
8
+ }
9
+ /** ISO 3166-1 alpha-2 country code (e.g. "CO", "US") */
10
+ country = '';
11
+ /** Visual style: circle uses circle-flags CDN, rectangle/flat uses flagsapi */
12
+ customStyle = 'flat';
13
+ /** Width in px */
14
+ width = '';
15
+ /** Height in px */
16
+ height = '';
17
+ get src() {
18
+ const code = (this.country || '').toUpperCase();
19
+ if (this.customStyle === 'circle') {
20
+ return `https://hatscripts.github.io/circle-flags/flags/${code.toLowerCase()}.svg`;
21
+ }
22
+ return `https://flagsapi.com/${code}/flat/64.png`;
23
+ }
24
+ render() {
25
+ const style = {};
26
+ if (this.width)
27
+ style['width'] = this.width.includes('px') ? this.width : `${this.width}px`;
28
+ if (this.height)
29
+ style['height'] = this.height.includes('px') ? this.height : `${this.height}px`;
30
+ return (h("figure", { key: '924adeb5372e2c02ce1c0471a162b57fc53616bd', class: `flag ${this.customStyle ?? 'flat'}` }, h("img", { key: '8433b69bbfc51aa5e72f8bd7166382e1d7907cfa', src: this.src, style: style, alt: `flag-${this.country}` })));
31
+ }
32
+ };
33
+ DropiCountryFlags.style = dropiCountryFlagsCss();
34
+
35
+ export { DropiCountryFlags as dropi_country_flags };
36
+ //# sourceMappingURL=dropi-country-flags.entry.esm.js.map
37
+
38
+ //# sourceMappingURL=dropi-country-flags.entry.js.map
@@ -0,0 +1 @@
1
+ {"file":"dropi-country-flags.entry.js","mappings":";;AAAA,MAAM,oBAAoB,GAAG,MAAM,CAAC,6TAA6T,CAAC;;MCcrV,iBAAiB,GAAA,MAAA;;;;;IAEpB,OAAO,GAAW,EAAE;;IAEpB,WAAW,GAAoC,MAAM;;IAErD,KAAK,GAAW,EAAE;;IAElB,MAAM,GAAW,EAAE;AAE3B,IAAA,IAAY,GAAG,GAAA;AACb,QAAA,MAAM,IAAI,GAAG,CAAC,IAAI,CAAC,OAAO,IAAI,EAAE,EAAE,WAAW,EAAE;AAC/C,QAAA,IAAI,IAAI,CAAC,WAAW,KAAK,QAAQ,EAAE;AACjC,YAAA,OAAO,mDAAmD,IAAI,CAAC,WAAW,EAAE,MAAM;;QAEpF,OAAO,CAAA,qBAAA,EAAwB,IAAI,CAAA,YAAA,CAAc;;IAGnD,MAAM,GAAA;QACJ,MAAM,KAAK,GAA2B,EAAE;QACxC,IAAI,IAAI,CAAC,KAAK;YAAE,KAAK,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,KAAK,GAAG,CAAA,EAAG,IAAI,CAAC,KAAK,CAAA,EAAA,CAAI;QAC3F,IAAI,IAAI,CAAC,MAAM;YAAE,KAAK,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,MAAM,GAAG,CAAA,EAAG,IAAI,CAAC,MAAM,CAAA,EAAA,CAAI;QAEhG,QACE,CAAA,CAAA,QAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAQ,KAAK,EAAE,CAAA,KAAA,EAAQ,IAAI,CAAC,WAAW,IAAI,MAAM,EAAE,EAAA,EACjD,CAAA,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAK,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,KAAK,EAAE,KAAK,EAAE,GAAG,EAAE,CAAA,KAAA,EAAQ,IAAI,CAAC,OAAO,EAAE,EAAA,CAAI,CAC1D;;;;;;;","names":[],"sources":["src/components/dropi-country-flags/dropi-country-flags.css?tag=dropi-country-flags&encapsulation=shadow","src/components/dropi-country-flags/dropi-country-flags.tsx"],"sourcesContent":[":host {\n display: inline-flex;\n}\n\n.flag {\n max-width: 40px;\n max-height: 40px;\n margin: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n}\n\n.flag img {\n width: 100%;\n height: 100%;\n object-fit: cover;\n}\n\n.circle {\n border-radius: 50%;\n overflow: hidden;\n}\n\n.rectangle {\n border-radius: 4px;\n overflow: hidden;\n max-width: 32px !important;\n max-height: 24px !important;\n}\n","import { Component, Prop, h } from '@stencil/core';\n\n/**\n * @component dropi-country-flags\n * Displays a country flag image. Supports circle, rectangle, and flat styles.\n *\n * @example\n * <dropi-country-flags country=\"CO\" style=\"circle\"></dropi-country-flags>\n */\n@Component({\n tag: 'dropi-country-flags',\n styleUrl: 'dropi-country-flags.css',\n shadow: true,\n})\nexport class DropiCountryFlags {\n /** ISO 3166-1 alpha-2 country code (e.g. \"CO\", \"US\") */\n @Prop() country: string = '';\n /** Visual style: circle uses circle-flags CDN, rectangle/flat uses flagsapi */\n @Prop() customStyle: 'circle' | 'rectangle' | 'flat' = 'flat';\n /** Width in px */\n @Prop() width: string = '';\n /** Height in px */\n @Prop() height: string = '';\n\n private get src(): string {\n const code = (this.country || '').toUpperCase();\n if (this.customStyle === 'circle') {\n return `https://hatscripts.github.io/circle-flags/flags/${code.toLowerCase()}.svg`;\n }\n return `https://flagsapi.com/${code}/flat/64.png`;\n }\n\n render() {\n const style: Record<string, string> = {};\n if (this.width) style['width'] = this.width.includes('px') ? this.width : `${this.width}px`;\n if (this.height) style['height'] = this.height.includes('px') ? this.height : `${this.height}px`;\n\n return (\n <figure class={`flag ${this.customStyle ?? 'flat'}`}>\n <img src={this.src} style={style} alt={`flag-${this.country}`} />\n </figure>\n );\n }\n}\n"],"version":3}