jebamo 0.0.1 → 0.0.2

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 (437) hide show
  1. package/LICENSE +21 -0
  2. package/dist/cjs/app-globals-3a1e7e63.js +7 -0
  3. package/dist/cjs/app-globals-3a1e7e63.js.map +1 -0
  4. package/dist/cjs/index-d5fa9014.js +1722 -0
  5. package/dist/cjs/index-d5fa9014.js.map +1 -0
  6. package/dist/cjs/index.cjs.js +4 -0
  7. package/dist/cjs/index.cjs.js.map +1 -0
  8. package/dist/cjs/je-alert_31.cjs.entry.js +4772 -0
  9. package/dist/cjs/je-alert_31.cjs.entry.js.map +1 -0
  10. package/dist/cjs/je-branch.cjs.entry.js +22 -0
  11. package/dist/cjs/je-branch.cjs.entry.js.map +1 -0
  12. package/dist/cjs/je-column-group.cjs.entry.js +29 -0
  13. package/dist/cjs/je-column-group.cjs.entry.js.map +1 -0
  14. package/dist/cjs/je-column.cjs.entry.js +73 -0
  15. package/dist/cjs/je-column.cjs.entry.js.map +1 -0
  16. package/dist/cjs/je-infinite.cjs.entry.js +45 -0
  17. package/dist/cjs/je-infinite.cjs.entry.js.map +1 -0
  18. package/dist/cjs/je-menu-option.cjs.entry.js +22 -0
  19. package/dist/cjs/je-menu-option.cjs.entry.js.map +1 -0
  20. package/dist/cjs/je-menu.cjs.entry.js +22 -0
  21. package/dist/cjs/je-menu.cjs.entry.js.map +1 -0
  22. package/dist/cjs/je-tab.cjs.entry.js +22 -0
  23. package/dist/cjs/je-tab.cjs.entry.js.map +1 -0
  24. package/dist/cjs/je-tabs.cjs.entry.js +22 -0
  25. package/dist/cjs/je-tabs.cjs.entry.js.map +1 -0
  26. package/dist/cjs/je-toast.cjs.entry.js +22 -0
  27. package/dist/cjs/je-toast.cjs.entry.js.map +1 -0
  28. package/dist/cjs/je-tree.cjs.entry.js +22 -0
  29. package/dist/cjs/je-tree.cjs.entry.js.map +1 -0
  30. package/dist/cjs/jebamo.cjs.js +27 -0
  31. package/dist/cjs/jebamo.cjs.js.map +1 -0
  32. package/dist/cjs/loader.cjs.js +17 -0
  33. package/dist/cjs/loader.cjs.js.map +1 -0
  34. package/dist/collection/collection-manifest.json +52 -0
  35. package/dist/collection/components/checkbox-group/je-checkbox-group/je-checkbox-group.css +10 -0
  36. package/dist/collection/components/checkbox-group/je-checkbox-group/je-checkbox-group.js +141 -0
  37. package/dist/collection/components/checkbox-group/je-checkbox-group/je-checkbox-group.js.map +1 -0
  38. package/dist/collection/components/checkbox-group/je-checkbox-option/je-checkbox-option.css +13 -0
  39. package/dist/collection/components/checkbox-group/je-checkbox-option/je-checkbox-option.js +153 -0
  40. package/dist/collection/components/checkbox-group/je-checkbox-option/je-checkbox-option.js.map +1 -0
  41. package/dist/collection/components/column/je-column/je-column.css +10 -0
  42. package/dist/collection/components/column/je-column/je-column.js +187 -0
  43. package/dist/collection/components/column/je-column/je-column.js.map +1 -0
  44. package/dist/collection/components/column/je-column-group/je-column-group.css +4 -0
  45. package/dist/collection/components/column/je-column-group/je-column-group.js +49 -0
  46. package/dist/collection/components/column/je-column-group/je-column-group.js.map +1 -0
  47. package/dist/collection/components/je-alert/je-alert.css +84 -0
  48. package/dist/collection/components/je-alert/je-alert.js +339 -0
  49. package/dist/collection/components/je-alert/je-alert.js.map +1 -0
  50. package/dist/collection/components/je-button/je-button.css +180 -0
  51. package/dist/collection/components/je-button/je-button.js +252 -0
  52. package/dist/collection/components/je-button/je-button.js.map +1 -0
  53. package/dist/collection/components/je-card/je-card.css +113 -0
  54. package/dist/collection/components/je-card/je-card.js +67 -0
  55. package/dist/collection/components/je-card/je-card.js.map +1 -0
  56. package/dist/collection/components/je-checkbox/je-checkbox.css +14 -0
  57. package/dist/collection/components/je-checkbox/je-checkbox.js +191 -0
  58. package/dist/collection/components/je-checkbox/je-checkbox.js.map +1 -0
  59. package/dist/collection/components/je-color/je-color.css +39 -0
  60. package/dist/collection/components/je-color/je-color.js +116 -0
  61. package/dist/collection/components/je-color/je-color.js.map +1 -0
  62. package/dist/collection/components/je-datepicker/je-datepicker.css +56 -0
  63. package/dist/collection/components/je-datepicker/je-datepicker.js +129 -0
  64. package/dist/collection/components/je-datepicker/je-datepicker.js.map +1 -0
  65. package/dist/collection/components/je-details/je-details.css +39 -0
  66. package/dist/collection/components/je-details/je-details.js +63 -0
  67. package/dist/collection/components/je-details/je-details.js.map +1 -0
  68. package/dist/collection/components/je-divider/je-divider.css +32 -0
  69. package/dist/collection/components/je-divider/je-divider.js +63 -0
  70. package/dist/collection/components/je-divider/je-divider.js.map +1 -0
  71. package/dist/collection/components/je-drawer/je-drawer.css +51 -0
  72. package/dist/collection/components/je-drawer/je-drawer.js +71 -0
  73. package/dist/collection/components/je-drawer/je-drawer.js.map +1 -0
  74. package/dist/collection/components/je-dropzone/je-dropzone.css +21 -0
  75. package/dist/collection/components/je-dropzone/je-dropzone.js +86 -0
  76. package/dist/collection/components/je-dropzone/je-dropzone.js.map +1 -0
  77. package/dist/collection/components/je-form/je-form.css +12 -0
  78. package/dist/collection/components/je-form/je-form.js +95 -0
  79. package/dist/collection/components/je-form/je-form.js.map +1 -0
  80. package/dist/collection/components/je-icon/je-icon.css +60 -0
  81. package/dist/collection/components/je-icon/je-icon.js +122 -0
  82. package/dist/collection/components/je-icon/je-icon.js.map +1 -0
  83. package/dist/collection/components/je-infinite/je-infinite.css +18 -0
  84. package/dist/collection/components/je-infinite/je-infinite.js +119 -0
  85. package/dist/collection/components/je-infinite/je-infinite.js.map +1 -0
  86. package/dist/collection/components/je-input/je-input.css +96 -0
  87. package/dist/collection/components/je-input/je-input.js +862 -0
  88. package/dist/collection/components/je-input/je-input.js.map +1 -0
  89. package/dist/collection/components/je-link/je-link.css +15 -0
  90. package/dist/collection/components/je-link/je-link.js +207 -0
  91. package/dist/collection/components/je-link/je-link.js.map +1 -0
  92. package/dist/collection/components/je-loading/je-loading.css +50 -0
  93. package/dist/collection/components/je-loading/je-loading.js +48 -0
  94. package/dist/collection/components/je-loading/je-loading.js.map +1 -0
  95. package/dist/collection/components/je-modal/je-modal.css +75 -0
  96. package/dist/collection/components/je-modal/je-modal.js +220 -0
  97. package/dist/collection/components/je-modal/je-modal.js.map +1 -0
  98. package/dist/collection/components/je-page/je-page.css +202 -0
  99. package/dist/collection/components/je-page/je-page.js +129 -0
  100. package/dist/collection/components/je-page/je-page.js.map +1 -0
  101. package/dist/collection/components/je-pill/je-pill.css +43 -0
  102. package/dist/collection/components/je-pill/je-pill.js +82 -0
  103. package/dist/collection/components/je-pill/je-pill.js.map +1 -0
  104. package/dist/collection/components/je-placeholder/je-placeholder.css +39 -0
  105. package/dist/collection/components/je-placeholder/je-placeholder.js +44 -0
  106. package/dist/collection/components/je-placeholder/je-placeholder.js.map +1 -0
  107. package/dist/collection/components/je-popover/je-popover.css +60 -0
  108. package/dist/collection/components/je-popover/je-popover.js +499 -0
  109. package/dist/collection/components/je-popover/je-popover.js.map +1 -0
  110. package/dist/collection/components/je-textarea/je-textarea.css +59 -0
  111. package/dist/collection/components/je-textarea/je-textarea.js +171 -0
  112. package/dist/collection/components/je-textarea/je-textarea.js.map +1 -0
  113. package/dist/collection/components/je-toast/je-toast.css +3 -0
  114. package/dist/collection/components/je-toast/je-toast.js +19 -0
  115. package/dist/collection/components/je-toast/je-toast.js.map +1 -0
  116. package/dist/collection/components/je-toggle/je-toggle.css +48 -0
  117. package/dist/collection/components/je-toggle/je-toggle.js +105 -0
  118. package/dist/collection/components/je-toggle/je-toggle.js.map +1 -0
  119. package/dist/collection/components/je-toolbar/je-toolbar.css +16 -0
  120. package/dist/collection/components/je-toolbar/je-toolbar.js +19 -0
  121. package/dist/collection/components/je-toolbar/je-toolbar.js.map +1 -0
  122. package/dist/collection/components/menu/je-menu/je-menu.css +3 -0
  123. package/dist/collection/components/menu/je-menu/je-menu.js +19 -0
  124. package/dist/collection/components/menu/je-menu/je-menu.js.map +1 -0
  125. package/dist/collection/components/menu/je-menu-option/je-menu-option.css +3 -0
  126. package/dist/collection/components/menu/je-menu-option/je-menu-option.js +19 -0
  127. package/dist/collection/components/menu/je-menu-option/je-menu-option.js.map +1 -0
  128. package/dist/collection/components/multiselect/je-multiselect/je-multiselect.css +79 -0
  129. package/dist/collection/components/multiselect/je-multiselect/je-multiselect.js +244 -0
  130. package/dist/collection/components/multiselect/je-multiselect/je-multiselect.js.map +1 -0
  131. package/dist/collection/components/multiselect/je-multiselect-option/je-multiselect-option.css +31 -0
  132. package/dist/collection/components/multiselect/je-multiselect-option/je-multiselect-option.js +122 -0
  133. package/dist/collection/components/multiselect/je-multiselect-option/je-multiselect-option.js.map +1 -0
  134. package/dist/collection/components/radio/je-radio/je-radio.css +13 -0
  135. package/dist/collection/components/radio/je-radio/je-radio.js +128 -0
  136. package/dist/collection/components/radio/je-radio/je-radio.js.map +1 -0
  137. package/dist/collection/components/radio/je-radio-group/je-radio-group.css +10 -0
  138. package/dist/collection/components/radio/je-radio-group/je-radio-group.js +172 -0
  139. package/dist/collection/components/radio/je-radio-group/je-radio-group.js.map +1 -0
  140. package/dist/collection/components/select/je-select/je-select.css +20 -0
  141. package/dist/collection/components/select/je-select/je-select.js +289 -0
  142. package/dist/collection/components/select/je-select/je-select.js.map +1 -0
  143. package/dist/collection/components/select/je-select-option/je-select-option.css +31 -0
  144. package/dist/collection/components/select/je-select-option/je-select-option.js +102 -0
  145. package/dist/collection/components/select/je-select-option/je-select-option.js.map +1 -0
  146. package/dist/collection/components/tabs/je-tab/je-tab.css +3 -0
  147. package/dist/collection/components/tabs/je-tab/je-tab.js +19 -0
  148. package/dist/collection/components/tabs/je-tab/je-tab.js.map +1 -0
  149. package/dist/collection/components/tabs/je-tabs/je-tabs.css +3 -0
  150. package/dist/collection/components/tabs/je-tabs/je-tabs.js +19 -0
  151. package/dist/collection/components/tabs/je-tabs/je-tabs.js.map +1 -0
  152. package/dist/collection/components/tree/je-branch/je-branch.css +3 -0
  153. package/dist/collection/components/tree/je-branch/je-branch.js +19 -0
  154. package/dist/collection/components/tree/je-branch/je-branch.js.map +1 -0
  155. package/dist/collection/components/tree/je-tree/je-tree.css +3 -0
  156. package/dist/collection/components/tree/je-tree/je-tree.js +19 -0
  157. package/dist/collection/components/tree/je-tree/je-tree.js.map +1 -0
  158. package/dist/collection/index.js +2 -0
  159. package/dist/collection/index.js.map +1 -0
  160. package/dist/collection/utils/utils.js +18 -0
  161. package/dist/collection/utils/utils.js.map +1 -0
  162. package/dist/components/index.d.ts +33 -0
  163. package/dist/components/index.js +3 -0
  164. package/dist/components/index.js.map +1 -0
  165. package/dist/components/je-alert.d.ts +11 -0
  166. package/dist/components/je-alert.js +146 -0
  167. package/dist/components/je-alert.js.map +1 -0
  168. package/dist/components/je-branch.d.ts +11 -0
  169. package/dist/components/je-branch.js +37 -0
  170. package/dist/components/je-branch.js.map +1 -0
  171. package/dist/components/je-button.d.ts +11 -0
  172. package/dist/components/je-button.js +8 -0
  173. package/dist/components/je-button.js.map +1 -0
  174. package/dist/components/je-card.d.ts +11 -0
  175. package/dist/components/je-card.js +8 -0
  176. package/dist/components/je-card.js.map +1 -0
  177. package/dist/components/je-checkbox-group.d.ts +11 -0
  178. package/dist/components/je-checkbox-group.js +90 -0
  179. package/dist/components/je-checkbox-group.js.map +1 -0
  180. package/dist/components/je-checkbox-option.d.ts +11 -0
  181. package/dist/components/je-checkbox-option.js +65 -0
  182. package/dist/components/je-checkbox-option.js.map +1 -0
  183. package/dist/components/je-checkbox.d.ts +11 -0
  184. package/dist/components/je-checkbox.js +83 -0
  185. package/dist/components/je-checkbox.js.map +1 -0
  186. package/dist/components/je-color.d.ts +11 -0
  187. package/dist/components/je-color.js +8 -0
  188. package/dist/components/je-color.js.map +1 -0
  189. package/dist/components/je-column-group.d.ts +11 -0
  190. package/dist/components/je-column-group.js +46 -0
  191. package/dist/components/je-column-group.js.map +1 -0
  192. package/dist/components/je-column.d.ts +11 -0
  193. package/dist/components/je-column.js +95 -0
  194. package/dist/components/je-column.js.map +1 -0
  195. package/dist/components/je-datepicker.d.ts +11 -0
  196. package/dist/components/je-datepicker.js +3249 -0
  197. package/dist/components/je-datepicker.js.map +1 -0
  198. package/dist/components/je-details.d.ts +11 -0
  199. package/dist/components/je-details.js +49 -0
  200. package/dist/components/je-details.js.map +1 -0
  201. package/dist/components/je-divider.d.ts +11 -0
  202. package/dist/components/je-divider.js +42 -0
  203. package/dist/components/je-divider.js.map +1 -0
  204. package/dist/components/je-drawer.d.ts +11 -0
  205. package/dist/components/je-drawer.js +60 -0
  206. package/dist/components/je-drawer.js.map +1 -0
  207. package/dist/components/je-dropzone.d.ts +11 -0
  208. package/dist/components/je-dropzone.js +55 -0
  209. package/dist/components/je-dropzone.js.map +1 -0
  210. package/dist/components/je-form.d.ts +11 -0
  211. package/dist/components/je-form.js +8 -0
  212. package/dist/components/je-form.js.map +1 -0
  213. package/dist/components/je-icon.d.ts +11 -0
  214. package/dist/components/je-icon.js +8 -0
  215. package/dist/components/je-icon.js.map +1 -0
  216. package/dist/components/je-infinite.d.ts +11 -0
  217. package/dist/components/je-infinite.js +64 -0
  218. package/dist/components/je-infinite.js.map +1 -0
  219. package/dist/components/je-input.d.ts +11 -0
  220. package/dist/components/je-input.js +8 -0
  221. package/dist/components/je-input.js.map +1 -0
  222. package/dist/components/je-link.d.ts +11 -0
  223. package/dist/components/je-link.js +62 -0
  224. package/dist/components/je-link.js.map +1 -0
  225. package/dist/components/je-loading.d.ts +11 -0
  226. package/dist/components/je-loading.js +66 -0
  227. package/dist/components/je-loading.js.map +1 -0
  228. package/dist/components/je-menu-option.d.ts +11 -0
  229. package/dist/components/je-menu-option.js +37 -0
  230. package/dist/components/je-menu-option.js.map +1 -0
  231. package/dist/components/je-menu.d.ts +11 -0
  232. package/dist/components/je-menu.js +37 -0
  233. package/dist/components/je-menu.js.map +1 -0
  234. package/dist/components/je-modal.d.ts +11 -0
  235. package/dist/components/je-modal.js +104 -0
  236. package/dist/components/je-modal.js.map +1 -0
  237. package/dist/components/je-multiselect-option.d.ts +11 -0
  238. package/dist/components/je-multiselect-option.js +62 -0
  239. package/dist/components/je-multiselect-option.js.map +1 -0
  240. package/dist/components/je-multiselect.d.ts +11 -0
  241. package/dist/components/je-multiselect.js +146 -0
  242. package/dist/components/je-multiselect.js.map +1 -0
  243. package/dist/components/je-page.d.ts +11 -0
  244. package/dist/components/je-page.js +61 -0
  245. package/dist/components/je-page.js.map +1 -0
  246. package/dist/components/je-pill.d.ts +11 -0
  247. package/dist/components/je-pill.js +8 -0
  248. package/dist/components/je-pill.js.map +1 -0
  249. package/dist/components/je-placeholder.d.ts +11 -0
  250. package/dist/components/je-placeholder.js +40 -0
  251. package/dist/components/je-placeholder.js.map +1 -0
  252. package/dist/components/je-popover.d.ts +11 -0
  253. package/dist/components/je-popover.js +8 -0
  254. package/dist/components/je-popover.js.map +1 -0
  255. package/dist/components/je-radio-group.d.ts +11 -0
  256. package/dist/components/je-radio-group.js +92 -0
  257. package/dist/components/je-radio-group.js.map +1 -0
  258. package/dist/components/je-radio.d.ts +11 -0
  259. package/dist/components/je-radio.js +68 -0
  260. package/dist/components/je-radio.js.map +1 -0
  261. package/dist/components/je-select-option.d.ts +11 -0
  262. package/dist/components/je-select-option.js +56 -0
  263. package/dist/components/je-select-option.js.map +1 -0
  264. package/dist/components/je-select.d.ts +11 -0
  265. package/dist/components/je-select.js +208 -0
  266. package/dist/components/je-select.js.map +1 -0
  267. package/dist/components/je-tab.d.ts +11 -0
  268. package/dist/components/je-tab.js +37 -0
  269. package/dist/components/je-tab.js.map +1 -0
  270. package/dist/components/je-tabs.d.ts +11 -0
  271. package/dist/components/je-tabs.js +37 -0
  272. package/dist/components/je-tabs.js.map +1 -0
  273. package/dist/components/je-textarea.d.ts +11 -0
  274. package/dist/components/je-textarea.js +55 -0
  275. package/dist/components/je-textarea.js.map +1 -0
  276. package/dist/components/je-toast.d.ts +11 -0
  277. package/dist/components/je-toast.js +37 -0
  278. package/dist/components/je-toast.js.map +1 -0
  279. package/dist/components/je-toggle.d.ts +11 -0
  280. package/dist/components/je-toggle.js +57 -0
  281. package/dist/components/je-toggle.js.map +1 -0
  282. package/dist/components/je-toolbar.d.ts +11 -0
  283. package/dist/components/je-toolbar.js +37 -0
  284. package/dist/components/je-toolbar.js.map +1 -0
  285. package/dist/components/je-tree.d.ts +11 -0
  286. package/dist/components/je-tree.js +37 -0
  287. package/dist/components/je-tree.js.map +1 -0
  288. package/dist/components/p-1f3759e7.js +41 -0
  289. package/dist/components/p-1f3759e7.js.map +1 -0
  290. package/dist/components/p-243cc91b.js +50 -0
  291. package/dist/components/p-243cc91b.js.map +1 -0
  292. package/dist/components/p-2df369c4.js +265 -0
  293. package/dist/components/p-2df369c4.js.map +1 -0
  294. package/dist/components/p-41492a72.js +1514 -0
  295. package/dist/components/p-41492a72.js.map +1 -0
  296. package/dist/components/p-4b8ae8ef.js +51 -0
  297. package/dist/components/p-4b8ae8ef.js.map +1 -0
  298. package/dist/components/p-5dee004d.js +246 -0
  299. package/dist/components/p-5dee004d.js.map +1 -0
  300. package/dist/components/p-8401b4e4.js +48 -0
  301. package/dist/components/p-8401b4e4.js.map +1 -0
  302. package/dist/components/p-94327b0d.js +39 -0
  303. package/dist/components/p-94327b0d.js.map +1 -0
  304. package/dist/components/p-aa4caa39.js +76 -0
  305. package/dist/components/p-aa4caa39.js.map +1 -0
  306. package/dist/esm/app-globals-0f993ce5.js +5 -0
  307. package/dist/esm/app-globals-0f993ce5.js.map +1 -0
  308. package/dist/esm/index-a65634db.js +1692 -0
  309. package/dist/esm/index-a65634db.js.map +1 -0
  310. package/dist/esm/index.js +3 -0
  311. package/dist/esm/index.js.map +1 -0
  312. package/dist/esm/je-alert_31.entry.js +4738 -0
  313. package/dist/esm/je-alert_31.entry.js.map +1 -0
  314. package/dist/esm/je-branch.entry.js +18 -0
  315. package/dist/esm/je-branch.entry.js.map +1 -0
  316. package/dist/esm/je-column-group.entry.js +25 -0
  317. package/dist/esm/je-column-group.entry.js.map +1 -0
  318. package/dist/esm/je-column.entry.js +69 -0
  319. package/dist/esm/je-column.entry.js.map +1 -0
  320. package/dist/esm/je-infinite.entry.js +41 -0
  321. package/dist/esm/je-infinite.entry.js.map +1 -0
  322. package/dist/esm/je-menu-option.entry.js +18 -0
  323. package/dist/esm/je-menu-option.entry.js.map +1 -0
  324. package/dist/esm/je-menu.entry.js +18 -0
  325. package/dist/esm/je-menu.entry.js.map +1 -0
  326. package/dist/esm/je-tab.entry.js +18 -0
  327. package/dist/esm/je-tab.entry.js.map +1 -0
  328. package/dist/esm/je-tabs.entry.js +18 -0
  329. package/dist/esm/je-tabs.entry.js.map +1 -0
  330. package/dist/esm/je-toast.entry.js +18 -0
  331. package/dist/esm/je-toast.entry.js.map +1 -0
  332. package/dist/esm/je-tree.entry.js +18 -0
  333. package/dist/esm/je-tree.entry.js.map +1 -0
  334. package/dist/esm/jebamo.js +22 -0
  335. package/dist/esm/jebamo.js.map +1 -0
  336. package/dist/esm/loader.js +13 -0
  337. package/dist/esm/loader.js.map +1 -0
  338. package/dist/index.cjs.js +1 -0
  339. package/dist/index.js +1 -0
  340. package/dist/jebamo/index.esm.js +2 -0
  341. package/dist/jebamo/index.esm.js.map +1 -0
  342. package/dist/jebamo/jebamo.esm.js +2 -0
  343. package/dist/jebamo/jebamo.esm.js.map +1 -0
  344. package/dist/jebamo/p-0d0cb311.entry.js +2 -0
  345. package/dist/jebamo/p-0d0cb311.entry.js.map +1 -0
  346. package/dist/jebamo/p-254ac389.entry.js +2 -0
  347. package/dist/jebamo/p-254ac389.entry.js.map +1 -0
  348. package/dist/jebamo/p-286807aa.entry.js +2 -0
  349. package/dist/jebamo/p-286807aa.entry.js.map +1 -0
  350. package/dist/jebamo/p-44735e2f.entry.js +2 -0
  351. package/dist/jebamo/p-44735e2f.entry.js.map +1 -0
  352. package/dist/jebamo/p-456b52ee.js +3 -0
  353. package/dist/jebamo/p-456b52ee.js.map +1 -0
  354. package/dist/jebamo/p-5b8d9daf.entry.js +2 -0
  355. package/dist/jebamo/p-5b8d9daf.entry.js.map +1 -0
  356. package/dist/jebamo/p-c519a7a4.entry.js +2 -0
  357. package/dist/jebamo/p-c519a7a4.entry.js.map +1 -0
  358. package/dist/jebamo/p-c6111d19.entry.js +2 -0
  359. package/dist/jebamo/p-c6111d19.entry.js.map +1 -0
  360. package/dist/jebamo/p-c8615128.entry.js +2 -0
  361. package/dist/jebamo/p-c8615128.entry.js.map +1 -0
  362. package/dist/jebamo/p-e1255160.js +2 -0
  363. package/dist/jebamo/p-e1255160.js.map +1 -0
  364. package/dist/jebamo/p-e330c9bb.entry.js +2 -0
  365. package/dist/jebamo/p-e330c9bb.entry.js.map +1 -0
  366. package/dist/jebamo/p-f6e777be.entry.js +2 -0
  367. package/dist/jebamo/p-f6e777be.entry.js.map +1 -0
  368. package/dist/jebamo/p-ff27b55f.entry.js +2 -0
  369. package/dist/jebamo/p-ff27b55f.entry.js.map +1 -0
  370. package/dist/types/components/checkbox-group/je-checkbox-group/je-checkbox-group.d.ts +25 -0
  371. package/dist/types/components/checkbox-group/je-checkbox-option/je-checkbox-option.d.ts +30 -0
  372. package/dist/types/components/column/je-column/je-column.d.ts +31 -0
  373. package/dist/types/components/column/je-column-group/je-column-group.d.ts +9 -0
  374. package/dist/types/components/je-alert/je-alert.d.ts +77 -0
  375. package/dist/types/components/je-button/je-button.d.ts +28 -0
  376. package/dist/types/components/je-card/je-card.d.ts +6 -0
  377. package/dist/types/components/je-checkbox/je-checkbox.d.ts +38 -0
  378. package/dist/types/components/je-color/je-color.d.ts +12 -0
  379. package/dist/types/components/je-datepicker/je-datepicker.d.ts +18 -0
  380. package/dist/types/components/je-details/je-details.d.ts +6 -0
  381. package/dist/types/components/je-divider/je-divider.d.ts +5 -0
  382. package/dist/types/components/je-drawer/je-drawer.d.ts +10 -0
  383. package/dist/types/components/je-dropzone/je-dropzone.d.ts +10 -0
  384. package/dist/types/components/je-form/je-form.d.ts +12 -0
  385. package/dist/types/components/je-icon/je-icon.d.ts +15 -0
  386. package/dist/types/components/je-infinite/je-infinite.d.ts +25 -0
  387. package/dist/types/components/je-input/je-input.d.ts +155 -0
  388. package/dist/types/components/je-link/je-link.d.ts +22 -0
  389. package/dist/types/components/je-loading/je-loading.d.ts +22 -0
  390. package/dist/types/components/je-modal/je-modal.d.ts +28 -0
  391. package/dist/types/components/je-page/je-page.d.ts +12 -0
  392. package/dist/types/components/je-pill/je-pill.d.ts +6 -0
  393. package/dist/types/components/je-placeholder/je-placeholder.d.ts +7 -0
  394. package/dist/types/components/je-popover/je-popover.d.ts +70 -0
  395. package/dist/types/components/je-textarea/je-textarea.d.ts +11 -0
  396. package/dist/types/components/je-toast/je-toast.d.ts +3 -0
  397. package/dist/types/components/je-toggle/je-toggle.d.ts +18 -0
  398. package/dist/types/components/je-toolbar/je-toolbar.d.ts +3 -0
  399. package/dist/types/components/menu/je-menu/je-menu.d.ts +3 -0
  400. package/dist/types/components/menu/je-menu-option/je-menu-option.d.ts +3 -0
  401. package/dist/types/components/multiselect/je-multiselect/je-multiselect.d.ts +27 -0
  402. package/dist/types/components/multiselect/je-multiselect-option/je-multiselect-option.d.ts +11 -0
  403. package/dist/types/components/radio/je-radio/je-radio.d.ts +25 -0
  404. package/dist/types/components/radio/je-radio-group/je-radio-group.d.ts +32 -0
  405. package/dist/types/components/select/je-select/je-select.d.ts +23 -0
  406. package/dist/types/components/select/je-select-option/je-select-option.d.ts +10 -0
  407. package/dist/types/components/tabs/je-tab/je-tab.d.ts +3 -0
  408. package/dist/types/components/tabs/je-tabs/je-tabs.d.ts +3 -0
  409. package/dist/types/components/tree/je-branch/je-branch.d.ts +3 -0
  410. package/dist/types/components/tree/je-tree/je-tree.d.ts +3 -0
  411. package/dist/types/components.d.ts +1846 -0
  412. package/dist/types/index.d.ts +10 -0
  413. package/dist/types/stencil-public-runtime.d.ts +1674 -0
  414. package/dist/types/utils/utils.d.ts +4 -0
  415. package/loader/cdn.js +1 -0
  416. package/loader/index.cjs.js +1 -0
  417. package/loader/index.d.ts +24 -0
  418. package/loader/index.es2017.js +1 -0
  419. package/loader/index.js +2 -0
  420. package/loader/package.json +11 -0
  421. package/package.json +31 -26
  422. package/readme.md +114 -0
  423. package/README.md +0 -24
  424. package/esm2020/jebamo.mjs +0 -5
  425. package/esm2020/lib/jebamo.component.mjs +0 -19
  426. package/esm2020/lib/jebamo.module.mjs +0 -21
  427. package/esm2020/lib/jebamo.service.mjs +0 -14
  428. package/esm2020/public-api.mjs +0 -7
  429. package/fesm2015/jebamo.mjs +0 -60
  430. package/fesm2015/jebamo.mjs.map +0 -1
  431. package/fesm2020/jebamo.mjs +0 -60
  432. package/fesm2020/jebamo.mjs.map +0 -1
  433. package/index.d.ts +0 -5
  434. package/lib/jebamo.component.d.ts +0 -5
  435. package/lib/jebamo.module.d.ts +0 -7
  436. package/lib/jebamo.service.d.ts +0 -6
  437. package/public-api.d.ts +0 -3
@@ -0,0 +1,499 @@
1
+ import { Host, h } from "@stencil/core";
2
+ import { animationUpdate } from "../../utils/utils";
3
+ export class JePopover {
4
+ constructor() {
5
+ this.handleContentClick = () => {
6
+ if (this.isOpen && this.dismissOnClick) {
7
+ this.dismiss('contentClickDismiss');
8
+ }
9
+ };
10
+ this.handleBackdropClick = () => {
11
+ if (this.isOpen && this.backdropDismiss) {
12
+ this.dismiss('backdropDismiss');
13
+ }
14
+ };
15
+ this.isOpen = false;
16
+ this.trigger = undefined;
17
+ this.showBackdrop = false;
18
+ this.backdropDismiss = true;
19
+ this.dismissOnClick = false;
20
+ this.position = 'element';
21
+ this.offsetX = 10;
22
+ this.offsetY = 10;
23
+ this.triggerAction = 'click';
24
+ }
25
+ componentDidLoad() {
26
+ this.pagEl = this.el.closest('je-page');
27
+ this.parentEl = this.el.parentElement;
28
+ if (this.trigger) {
29
+ this.triggerElement = document.getElementById(this.trigger);
30
+ if (this.triggerElement && this.triggerAction == 'click') {
31
+ this.triggerElement.addEventListener("click", () => this.present(this.position));
32
+ }
33
+ else if (this.triggerElement && this.triggerAction == 'hover') {
34
+ this.triggerElement.addEventListener("mouseover", async (ev) => {
35
+ await this.present(this.position, ev);
36
+ this.triggerElement.addEventListener("mouseleave", () => this.dismiss('hoverDismiss'), { once: true });
37
+ });
38
+ }
39
+ else if (this.triggerElement && this.triggerAction == 'context-menu') {
40
+ this.triggerElement.addEventListener("contextmenu", ev => {
41
+ ev.preventDefault();
42
+ this.present(this.position, ev);
43
+ });
44
+ }
45
+ else {
46
+ console.error('Failed to find popover trigger element:', this.trigger);
47
+ }
48
+ }
49
+ }
50
+ handleThemeChange(e) {
51
+ this.el.toggleAttribute('darkmode', e.detail == 'dark');
52
+ }
53
+ handleWindowClick(ev) {
54
+ this.mouseEvent = ev;
55
+ }
56
+ /**
57
+ * Used internally to present the popover. Can also be used to manually
58
+ * present it if needed. Will auto position itself using the specified
59
+ * position strategy. If no target is provided, it will use the last mouse
60
+ * event on the window or the trigger element.
61
+ * @param positionStrategy The strategy to use when positioning the popover
62
+ * @param target Can optionally override the target the popover bases it's position off of
63
+ */
64
+ async present(positionStrategy, target) {
65
+ var _a;
66
+ if (!this.isOpen) {
67
+ if (this.parentEl) {
68
+ if (this.pagEl) {
69
+ this.pagEl.append(this.el);
70
+ }
71
+ else {
72
+ document.body.append(this.el);
73
+ }
74
+ }
75
+ this.isOpen = true;
76
+ if (positionStrategy !== 'none') {
77
+ this.contentEl.removeAttribute('style');
78
+ await animationUpdate();
79
+ const { offsetX, offsetY } = this;
80
+ const contentHeight = this.contentEl.clientHeight;
81
+ const rightThreshold = window.innerWidth / 2;
82
+ const bottomThreshold = window.innerHeight - 20 - contentHeight;
83
+ if (positionStrategy == 'click') {
84
+ target !== null && target !== void 0 ? target : (target = this.mouseEvent);
85
+ const { pageX, pageY } = target;
86
+ const isNearRight = pageX > rightThreshold;
87
+ const isNearBottom = pageY > bottomThreshold;
88
+ const isNearTop = pageY - offsetY - contentHeight < 0;
89
+ if (isNearRight) {
90
+ this.contentEl.style.left = `${pageX - offsetX - this.contentEl.clientWidth}px`;
91
+ }
92
+ else {
93
+ this.contentEl.style.left = `${pageX + offsetX}px`;
94
+ }
95
+ if (isNearBottom && !isNearTop) {
96
+ this.contentEl.style.top = `${pageY - offsetY - contentHeight}px`;
97
+ }
98
+ else if (isNearBottom && isNearTop) {
99
+ this.contentEl.style.overflowY = 'auto';
100
+ if (pageY > window.innerHeight - pageY) {
101
+ this.contentEl.style.top = `${offsetY}px`;
102
+ this.contentEl.style.maxHeight = `${pageY}px`;
103
+ }
104
+ else {
105
+ this.contentEl.style.top = `${pageY + offsetY}px`;
106
+ this.contentEl.style.maxHeight = `${window.innerHeight - 20 - pageY}px`;
107
+ }
108
+ }
109
+ else {
110
+ this.contentEl.style.top = `${pageY + offsetY}px`;
111
+ }
112
+ }
113
+ else {
114
+ target !== null && target !== void 0 ? target : (target = ((_a = this.triggerElement) !== null && _a !== void 0 ? _a : this.mouseEvent.target));
115
+ const boundingRect = target.getBoundingClientRect();
116
+ const { x: pageX, y: pageY } = boundingRect;
117
+ const isNearRight = pageX > rightThreshold;
118
+ const isNearBottom = pageY > bottomThreshold;
119
+ const isNearTop = pageY - offsetY - contentHeight < 0;
120
+ const triggerElement = target;
121
+ const { left, bottom, top, right } = triggerElement.getBoundingClientRect();
122
+ this.contentEl.style.boxSizing = 'border-box';
123
+ if (isNearRight) {
124
+ this.contentEl.style.left = `${right - this.contentEl.clientWidth}px`;
125
+ }
126
+ else {
127
+ this.contentEl.style.left = `${left}px`;
128
+ }
129
+ if (isNearBottom && !isNearTop) {
130
+ this.contentEl.style.top = `${top - offsetY - contentHeight}px`;
131
+ }
132
+ else if (isNearBottom && isNearTop) {
133
+ this.contentEl.style.overflowY = 'auto';
134
+ if (pageY > window.innerHeight - pageY) {
135
+ this.contentEl.style.top = `${offsetY}px`;
136
+ this.contentEl.style.maxHeight = `${top}px`;
137
+ }
138
+ else {
139
+ this.contentEl.style.top = `${bottom + offsetY}px`;
140
+ this.contentEl.style.maxHeight = `${window.innerHeight - 20 - bottom}px`;
141
+ }
142
+ }
143
+ else {
144
+ this.contentEl.style.top = `${bottom + offsetY}px`;
145
+ }
146
+ }
147
+ }
148
+ return new Promise(resolve => {
149
+ this.contentEl.addEventListener('transitionend', () => {
150
+ this.didPresent.emit();
151
+ resolve();
152
+ }, { once: true });
153
+ if (this.triggerAction !== 'hover') {
154
+ this.backdropEl.classList.add('fade');
155
+ }
156
+ this.contentEl.classList.add('open');
157
+ });
158
+ }
159
+ }
160
+ /** Manually dismisses the popover. Role and data get passed to the didDismiss event. */
161
+ async dismiss(role = 'manualDismiss', data) {
162
+ if (this.isOpen) {
163
+ return new Promise(resolve => {
164
+ this.contentEl.addEventListener('transitionend', () => {
165
+ if (this.parentEl) {
166
+ this.el.remove();
167
+ this.parentEl.append(this.el);
168
+ }
169
+ this.isOpen = false;
170
+ this.didDismiss.emit({ role: role, data: data });
171
+ resolve();
172
+ }, { once: true });
173
+ if (this.triggerAction !== 'hover') {
174
+ this.backdropEl.classList.remove('fade');
175
+ }
176
+ this.contentEl.classList.remove('open');
177
+ });
178
+ }
179
+ }
180
+ render() {
181
+ return (h(Host, { key: '1de5a4aef076c6296b9c64b96028cc6f4998a40a', slot: "overlay" }, h("div", { key: '845a3c97b059371422707c785707aa499146f2dd', part: "content", ref: el => this.contentEl = el, onClick: this.handleContentClick, class: { 'content-transition': true, content: this.isOpen } }, this.isOpen && h("slot", { key: '436d0ed78d49a6471760da0057fcc75cfbd0dd44' })), this.triggerAction !== 'hover' &&
182
+ h("div", { key: '1ec70ebb3246b78533e7250eda5d200212b795ad', ref: el => this.backdropEl = el, onClick: this.handleBackdropClick, class: {
183
+ 'backdrop-transition': true,
184
+ backdrop: this.isOpen,
185
+ clear: !this.showBackdrop && this.isOpen
186
+ } })));
187
+ }
188
+ static get is() { return "je-popover"; }
189
+ static get encapsulation() { return "shadow"; }
190
+ static get originalStyleUrls() {
191
+ return {
192
+ "$": ["je-popover.scss"]
193
+ };
194
+ }
195
+ static get styleUrls() {
196
+ return {
197
+ "$": ["je-popover.css"]
198
+ };
199
+ }
200
+ static get properties() {
201
+ return {
202
+ "trigger": {
203
+ "type": "string",
204
+ "mutable": false,
205
+ "complexType": {
206
+ "original": "string",
207
+ "resolved": "string",
208
+ "references": {}
209
+ },
210
+ "required": false,
211
+ "optional": true,
212
+ "docs": {
213
+ "tags": [],
214
+ "text": "The id of the element that will present the menu on click.\nIf not provided, you will have to manually present the popover\nusing present()."
215
+ },
216
+ "attribute": "trigger",
217
+ "reflect": false
218
+ },
219
+ "showBackdrop": {
220
+ "type": "boolean",
221
+ "mutable": false,
222
+ "complexType": {
223
+ "original": "boolean",
224
+ "resolved": "boolean",
225
+ "references": {}
226
+ },
227
+ "required": false,
228
+ "optional": false,
229
+ "docs": {
230
+ "tags": [],
231
+ "text": "Whether or not the backdrop will be visible to the user"
232
+ },
233
+ "attribute": "show-backdrop",
234
+ "reflect": false,
235
+ "defaultValue": "false"
236
+ },
237
+ "backdropDismiss": {
238
+ "type": "boolean",
239
+ "mutable": false,
240
+ "complexType": {
241
+ "original": "boolean",
242
+ "resolved": "boolean",
243
+ "references": {}
244
+ },
245
+ "required": false,
246
+ "optional": false,
247
+ "docs": {
248
+ "tags": [],
249
+ "text": "Backdrop will dismiss the popover on click when enabled"
250
+ },
251
+ "attribute": "backdrop-dismiss",
252
+ "reflect": false,
253
+ "defaultValue": "true"
254
+ },
255
+ "dismissOnClick": {
256
+ "type": "boolean",
257
+ "mutable": false,
258
+ "complexType": {
259
+ "original": "boolean",
260
+ "resolved": "boolean",
261
+ "references": {}
262
+ },
263
+ "required": false,
264
+ "optional": false,
265
+ "docs": {
266
+ "tags": [],
267
+ "text": "Popover will automatically dismiss itself when something is\nclicked in the popover when enabled"
268
+ },
269
+ "attribute": "dismiss-on-click",
270
+ "reflect": false,
271
+ "defaultValue": "false"
272
+ },
273
+ "position": {
274
+ "type": "string",
275
+ "mutable": false,
276
+ "complexType": {
277
+ "original": "PositionStrategy",
278
+ "resolved": "\"click\" | \"element\" | \"none\"",
279
+ "references": {
280
+ "PositionStrategy": {
281
+ "location": "local",
282
+ "path": "/Users/psg/src/jebamo/packages/core/src/components/je-popover/je-popover.tsx",
283
+ "id": "src/components/je-popover/je-popover.tsx::PositionStrategy"
284
+ }
285
+ }
286
+ },
287
+ "required": false,
288
+ "optional": false,
289
+ "docs": {
290
+ "tags": [],
291
+ "text": "If the popover should auto position itself using the mouse event or\nthe triggerElement."
292
+ },
293
+ "attribute": "position",
294
+ "reflect": false,
295
+ "defaultValue": "'element'"
296
+ },
297
+ "offsetX": {
298
+ "type": "number",
299
+ "mutable": false,
300
+ "complexType": {
301
+ "original": "number",
302
+ "resolved": "number",
303
+ "references": {}
304
+ },
305
+ "required": false,
306
+ "optional": false,
307
+ "docs": {
308
+ "tags": [],
309
+ "text": "Horizontal offset used when auto positioning the popover content"
310
+ },
311
+ "attribute": "offset-x",
312
+ "reflect": false,
313
+ "defaultValue": "10"
314
+ },
315
+ "offsetY": {
316
+ "type": "number",
317
+ "mutable": false,
318
+ "complexType": {
319
+ "original": "number",
320
+ "resolved": "number",
321
+ "references": {}
322
+ },
323
+ "required": false,
324
+ "optional": false,
325
+ "docs": {
326
+ "tags": [],
327
+ "text": "Vertical offset used when auto positioning the popover content"
328
+ },
329
+ "attribute": "offset-y",
330
+ "reflect": false,
331
+ "defaultValue": "10"
332
+ },
333
+ "triggerAction": {
334
+ "type": "string",
335
+ "mutable": false,
336
+ "complexType": {
337
+ "original": "'click' | 'hover' | 'context-menu'",
338
+ "resolved": "\"click\" | \"context-menu\" | \"hover\"",
339
+ "references": {}
340
+ },
341
+ "required": false,
342
+ "optional": false,
343
+ "docs": {
344
+ "tags": [{
345
+ "name": "click",
346
+ "text": "Popover will show on left click or tap on mobile."
347
+ }, {
348
+ "name": "context-menu",
349
+ "text": "Popover will show on right click or press on mobile."
350
+ }, {
351
+ "name": "hover",
352
+ "text": "Popover will show on hover or tap on mobile. No backdrop will be rendered."
353
+ }],
354
+ "text": ""
355
+ },
356
+ "attribute": "trigger-action",
357
+ "reflect": false,
358
+ "defaultValue": "'click'"
359
+ }
360
+ };
361
+ }
362
+ static get states() {
363
+ return {
364
+ "isOpen": {}
365
+ };
366
+ }
367
+ static get events() {
368
+ return [{
369
+ "method": "didPresent",
370
+ "name": "didPresent",
371
+ "bubbles": true,
372
+ "cancelable": true,
373
+ "composed": true,
374
+ "docs": {
375
+ "tags": [],
376
+ "text": "Emits whenever the popover has presented. Does not emit any data"
377
+ },
378
+ "complexType": {
379
+ "original": "any",
380
+ "resolved": "any",
381
+ "references": {}
382
+ }
383
+ }, {
384
+ "method": "didDismiss",
385
+ "name": "didDismiss",
386
+ "bubbles": true,
387
+ "cancelable": true,
388
+ "composed": true,
389
+ "docs": {
390
+ "tags": [],
391
+ "text": "Emits whenever the popover has finished dismissing. Emits the role\nand optional data object passed to the dismiss() method."
392
+ },
393
+ "complexType": {
394
+ "original": "{ role?: string, data?: any }",
395
+ "resolved": "{ role?: string; data?: any; }",
396
+ "references": {}
397
+ }
398
+ }];
399
+ }
400
+ static get methods() {
401
+ return {
402
+ "present": {
403
+ "complexType": {
404
+ "signature": "<T extends PositionStrategy>(positionStrategy: T, target?: Target<T>) => Promise<void>",
405
+ "parameters": [{
406
+ "name": "positionStrategy",
407
+ "type": "T",
408
+ "docs": "The strategy to use when positioning the popover"
409
+ }, {
410
+ "name": "target",
411
+ "type": "T extends \"click\" ? MouseEvent : T extends \"element\" ? HTMLElement : never",
412
+ "docs": "Can optionally override the target the popover bases it's position off of"
413
+ }],
414
+ "references": {
415
+ "Promise": {
416
+ "location": "global",
417
+ "id": "global::Promise"
418
+ },
419
+ "PositionStrategy": {
420
+ "location": "local",
421
+ "path": "/Users/psg/src/jebamo/packages/core/src/components/je-popover/je-popover.tsx",
422
+ "id": "src/components/je-popover/je-popover.tsx::PositionStrategy"
423
+ },
424
+ "T": {
425
+ "location": "global",
426
+ "id": "global::T"
427
+ },
428
+ "Target": {
429
+ "location": "local",
430
+ "path": "/Users/psg/src/jebamo/packages/core/src/components/je-popover/je-popover.tsx",
431
+ "id": "src/components/je-popover/je-popover.tsx::Target"
432
+ },
433
+ "MouseEvent": {
434
+ "location": "global",
435
+ "id": "global::MouseEvent"
436
+ },
437
+ "HTMLElement": {
438
+ "location": "global",
439
+ "id": "global::HTMLElement"
440
+ }
441
+ },
442
+ "return": "Promise<void>"
443
+ },
444
+ "docs": {
445
+ "text": "Used internally to present the popover. Can also be used to manually\npresent it if needed. Will auto position itself using the specified\nposition strategy. If no target is provided, it will use the last mouse\nevent on the window or the trigger element.",
446
+ "tags": [{
447
+ "name": "param",
448
+ "text": "positionStrategy The strategy to use when positioning the popover"
449
+ }, {
450
+ "name": "param",
451
+ "text": "target Can optionally override the target the popover bases it's position off of"
452
+ }]
453
+ }
454
+ },
455
+ "dismiss": {
456
+ "complexType": {
457
+ "signature": "(role?: string, data?: any) => Promise<void>",
458
+ "parameters": [{
459
+ "name": "role",
460
+ "type": "string",
461
+ "docs": ""
462
+ }, {
463
+ "name": "data",
464
+ "type": "any",
465
+ "docs": ""
466
+ }],
467
+ "references": {
468
+ "Promise": {
469
+ "location": "global",
470
+ "id": "global::Promise"
471
+ }
472
+ },
473
+ "return": "Promise<void>"
474
+ },
475
+ "docs": {
476
+ "text": "Manually dismisses the popover. Role and data get passed to the didDismiss event.",
477
+ "tags": []
478
+ }
479
+ }
480
+ };
481
+ }
482
+ static get elementRef() { return "el"; }
483
+ static get listeners() {
484
+ return [{
485
+ "name": "themeChange",
486
+ "method": "handleThemeChange",
487
+ "target": "body",
488
+ "capture": false,
489
+ "passive": false
490
+ }, {
491
+ "name": "click",
492
+ "method": "handleWindowClick",
493
+ "target": "window",
494
+ "capture": true,
495
+ "passive": false
496
+ }];
497
+ }
498
+ }
499
+ //# sourceMappingURL=je-popover.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"je-popover.js","sourceRoot":"","sources":["../../../src/components/je-popover/je-popover.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Host, h, Element, EventEmitter, Listen, Method, Prop, State, Event } from '@stencil/core';\nimport { animationUpdate } from '../../utils/utils';\n\nexport type PositionStrategy = 'none' | 'click' | 'element';\nexport type Target<T extends PositionStrategy> = T extends 'click' ? MouseEvent | undefined : T extends 'element' ? HTMLElement | undefined : never;\n\n@Component({\n tag: 'je-popover',\n styleUrl: 'je-popover.scss',\n shadow: true,\n})\nexport class JePopover {\n @Element() el!: HTMLJePopoverElement;\n\n protected parentEl!: HTMLElement;\n\n protected triggerElement!: HTMLElement;\n\n protected contentEl!: HTMLElement;\n\n protected backdropEl!: HTMLElement;\n\n protected pagEl!: HTMLElement;\n\n private mouseEvent?: MouseEvent;\n\n @State() isOpen = false;\n\n /**\n * The id of the element that will present the menu on click.\n * If not provided, you will have to manually present the popover\n * using present().\n */\n @Prop() trigger?: string;\n\n /** Whether or not the backdrop will be visible to the user */\n @Prop() showBackdrop = false;\n\n /** Backdrop will dismiss the popover on click when enabled */\n @Prop() backdropDismiss = true;\n\n /**\n * Popover will automatically dismiss itself when something is\n * clicked in the popover when enabled\n */\n @Prop() dismissOnClick = false;\n\n /**\n * If the popover should auto position itself using the mouse event or\n * the triggerElement.\n */\n @Prop() position: PositionStrategy = 'element';\n\n /** Horizontal offset used when auto positioning the popover content */\n @Prop() offsetX = 10;\n\n /** Vertical offset used when auto positioning the popover content */\n @Prop() offsetY = 10;\n\n /**\n * @click Popover will show on left click or tap on mobile.\n * @context-menu Popover will show on right click or press on mobile.\n * @hover Popover will show on hover or tap on mobile. No backdrop will be rendered.\n */\n @Prop() triggerAction: 'click' | 'hover' | 'context-menu' = 'click';\n\n /** Emits whenever the popover has presented. Does not emit any data */\n @Event() didPresent: EventEmitter;\n\n /**\n * Emits whenever the popover has finished dismissing. Emits the role\n * and optional data object passed to the dismiss() method.\n */\n @Event() didDismiss: EventEmitter<{ role?: string, data?: any }>;\n\n componentDidLoad() {\n this.pagEl = this.el.closest('je-page') as HTMLElement;\n this.parentEl = this.el.parentElement;\n if (this.trigger) {\n this.triggerElement = document.getElementById(this.trigger);\n if (this.triggerElement && this.triggerAction == 'click') {\n this.triggerElement.addEventListener(\"click\", () => this.present(this.position));\n } else if (this.triggerElement && this.triggerAction == 'hover') {\n this.triggerElement.addEventListener(\"mouseover\", async ev => {\n await this.present(this.position, ev);\n this.triggerElement.addEventListener(\n \"mouseleave\",\n () => this.dismiss('hoverDismiss'),\n { once: true });\n });\n } else if (this.triggerElement && this.triggerAction == 'context-menu') {\n this.triggerElement.addEventListener(\"contextmenu\", ev => {\n ev.preventDefault();\n this.present(this.position, ev);\n });\n } else {\n console.error('Failed to find popover trigger element:', this.trigger);\n }\n }\n }\n\n private handleContentClick = () => {\n if (this.isOpen && this.dismissOnClick) {\n this.dismiss('contentClickDismiss');\n }\n }\n\n @Listen('themeChange', { target: 'body' })\n handleThemeChange(e: CustomEvent<'light' | 'dark'>) {\n this.el.toggleAttribute('darkmode', e.detail == 'dark')\n }\n\n @Listen('click', { capture: true, target: 'window' })\n protected handleWindowClick(ev: MouseEvent) {\n this.mouseEvent = ev;\n }\n\n /**\n * Used internally to present the popover. Can also be used to manually\n * present it if needed. Will auto position itself using the specified\n * position strategy. If no target is provided, it will use the last mouse\n * event on the window or the trigger element.\n * @param positionStrategy The strategy to use when positioning the popover\n * @param target Can optionally override the target the popover bases it's position off of\n */\n @Method()\n async present<T extends PositionStrategy>(positionStrategy: T, target?: Target<T>) {\n if (!this.isOpen) {\n if (this.parentEl) {\n if (this.pagEl) {\n this.pagEl.append(this.el)\n } else {\n document.body.append(this.el);\n }\n }\n this.isOpen = true;\n\n if (positionStrategy !== 'none') {\n this.contentEl.removeAttribute('style');\n await animationUpdate();\n const { offsetX, offsetY } = this;\n const contentHeight = this.contentEl.clientHeight;\n const rightThreshold = window.innerWidth / 2;\n const bottomThreshold = window.innerHeight - 20 - contentHeight;\n\n if (positionStrategy == 'click') {\n target ??= this.mouseEvent as Target<T>;\n const { pageX, pageY } = target as MouseEvent;\n const isNearRight = pageX > rightThreshold;\n const isNearBottom = pageY > bottomThreshold;\n const isNearTop = pageY - offsetY - contentHeight < 0;\n if (isNearRight) {\n this.contentEl.style.left = `${pageX - offsetX - this.contentEl.clientWidth}px`;\n } else {\n this.contentEl.style.left = `${pageX + offsetX}px`;\n }\n\n if (isNearBottom && !isNearTop) {\n this.contentEl.style.top = `${pageY - offsetY - contentHeight}px`;\n } else if (isNearBottom && isNearTop) {\n this.contentEl.style.overflowY = 'auto';\n if (pageY > window.innerHeight - pageY) {\n this.contentEl.style.top = `${offsetY}px`;\n this.contentEl.style.maxHeight = `${pageY}px`;\n } else {\n this.contentEl.style.top = `${pageY + offsetY}px`;\n this.contentEl.style.maxHeight = `${window.innerHeight - 20 - pageY}px`;\n }\n } else {\n this.contentEl.style.top = `${pageY + offsetY}px`;\n }\n } else {\n target ??= (this.triggerElement ?? this.mouseEvent.target) as Target<T>;\n const boundingRect = (target as HTMLElement).getBoundingClientRect();\n const { x: pageX, y: pageY } = boundingRect;\n const isNearRight = pageX > rightThreshold;\n const isNearBottom = pageY > bottomThreshold;\n const isNearTop = pageY - offsetY - contentHeight < 0;\n const triggerElement = target as HTMLElement;\n const { left, bottom, top, right } = triggerElement.getBoundingClientRect();\n this.contentEl.style.boxSizing = 'border-box';\n if (isNearRight) {\n this.contentEl.style.left = `${right - this.contentEl.clientWidth}px`;\n } else {\n this.contentEl.style.left = `${left}px`;\n }\n\n if (isNearBottom && !isNearTop) {\n this.contentEl.style.top = `${top - offsetY - contentHeight}px`;\n } else if (isNearBottom && isNearTop) {\n this.contentEl.style.overflowY = 'auto';\n if (pageY > window.innerHeight - pageY) {\n this.contentEl.style.top = `${offsetY}px`;\n this.contentEl.style.maxHeight = `${top}px`;\n } else {\n this.contentEl.style.top = `${bottom + offsetY}px`;\n this.contentEl.style.maxHeight = `${window.innerHeight - 20 - bottom}px`;\n }\n } else {\n this.contentEl.style.top = `${bottom + offsetY}px`;\n }\n }\n }\n\n return new Promise<void>(resolve => {\n this.contentEl.addEventListener('transitionend', () => {\n this.didPresent.emit();\n resolve();\n }, { once: true });\n if (this.triggerAction !== 'hover') {\n this.backdropEl.classList.add('fade');\n }\n this.contentEl.classList.add('open');\n });\n }\n }\n\n /** Manually dismisses the popover. Role and data get passed to the didDismiss event. */\n @Method()\n async dismiss(role = 'manualDismiss', data?: any) {\n if (this.isOpen) {\n return new Promise<void>(resolve => {\n this.contentEl.addEventListener('transitionend', () => {\n if (this.parentEl) {\n this.el.remove();\n this.parentEl.append(this.el);\n }\n this.isOpen = false;\n this.didDismiss.emit({ role: role, data: data });\n resolve();\n }, { once: true });\n if (this.triggerAction !== 'hover') {\n this.backdropEl.classList.remove('fade');\n }\n this.contentEl.classList.remove('open');\n });\n }\n }\n\n private handleBackdropClick = () => {\n if (this.isOpen && this.backdropDismiss) {\n this.dismiss('backdropDismiss');\n }\n }\n\n render() {\n return (\n <Host slot=\"overlay\">\n <div part=\"content\" ref={el => this.contentEl = el} onClick={this.handleContentClick} class={{ 'content-transition': true, content: this.isOpen }}>\n {this.isOpen && <slot></slot>}\n </div>\n {this.triggerAction !== 'hover' &&\n <div ref={el => this.backdropEl = el} onClick={this.handleBackdropClick}\n class={{\n 'backdrop-transition': true,\n backdrop: this.isOpen,\n clear: !this.showBackdrop && this.isOpen\n }}\n ></div>\n }\n </Host>\n );\n }\n}\n"]}
@@ -0,0 +1,59 @@
1
+ :host {
2
+ position: relative;
3
+ display: flex;
4
+ align-items: baseline;
5
+ gap: var(--je-spacing-2xs, 8px);
6
+ background-color: var(--je-input-background, field);
7
+ color: var(--je-input-color, fieldtext);
8
+ padding: var(--je-spacing-xs, 10px);
9
+ border-radius: var(--je-border-radius, 2px);
10
+ border: solid 1px var(--je-border-color);
11
+ transition: border 125ms ease-in-out;
12
+ --je-height: 84px;
13
+ --je-border-color: transparent;
14
+ --je-input-background: var(--je-medium-100);
15
+ --je-input-color: var(--je-medium-900);
16
+ }
17
+
18
+ :host([darkmode]) {
19
+ --je-input-background: var(--je-medium-850);
20
+ --je-input-color: var(--je-medium-50);
21
+ }
22
+
23
+ ::slotted([slot=top-right]) {
24
+ top: 0;
25
+ right: 0;
26
+ position: absolute;
27
+ transform: translate(50%, -50%);
28
+ }
29
+
30
+ textarea {
31
+ height: var(--je-height);
32
+ font-family: var(--je-font-family, inherit);
33
+ font-size: var(--je-font-size, 1rem);
34
+ background: transparent;
35
+ color: inherit;
36
+ flex: 1;
37
+ border: none;
38
+ padding-top: 0;
39
+ padding-bottom: 0;
40
+ padding-left: 0;
41
+ padding-right: 0;
42
+ margin-top: 0;
43
+ margin-bottom: 0;
44
+ margin-left: 0;
45
+ margin-right: 0;
46
+ width: inherit;
47
+ }
48
+ textarea::placeholder {
49
+ font-family: var(--je-font-family, inherit);
50
+ font-size: var(--je-font-size, 1rem);
51
+ color: var(--je-medium-600);
52
+ }
53
+ textarea:focus {
54
+ outline: 0;
55
+ }
56
+
57
+ label {
58
+ font-weight: var(--je-font-semi-bold);
59
+ }