@xplortech/apollo-core 1.0.0-beta.7 → 1.0.0-beta.9

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 (571) hide show
  1. package/dist/apollo-core/apollo-core.css +5841 -9
  2. package/dist/apollo-core/apollo-core.esm.js +163 -1
  3. package/dist/apollo-core/apollo-core.esm.js.map +1 -0
  4. package/dist/apollo-core/app-globals-0f993ce5.js +5 -0
  5. package/dist/apollo-core/app-globals-0f993ce5.js.map +1 -0
  6. package/dist/apollo-core/css-shim-6210ce77.js +6 -0
  7. package/dist/apollo-core/css-shim-6210ce77.js.map +1 -0
  8. package/dist/apollo-core/dom-423bdd70.js +75 -0
  9. package/dist/apollo-core/dom-423bdd70.js.map +1 -0
  10. package/dist/apollo-core/index-307c7018.js +3397 -0
  11. package/dist/apollo-core/index-307c7018.js.map +1 -0
  12. package/dist/apollo-core/index-912d1a21.js +586 -0
  13. package/dist/apollo-core/index-912d1a21.js.map +1 -0
  14. package/dist/apollo-core/index.esm.js +3 -0
  15. package/dist/apollo-core/index.esm.js.map +1 -0
  16. package/dist/apollo-core/p-08abab41.entry.js +2 -0
  17. package/dist/apollo-core/p-08abab41.entry.js.map +1 -0
  18. package/dist/apollo-core/p-16654189.entry.js +2 -0
  19. package/dist/apollo-core/p-16654189.entry.js.map +1 -0
  20. package/dist/apollo-core/p-2f90296c.js +3 -3
  21. package/dist/apollo-core/p-2f90296c.js.map +1 -0
  22. package/dist/apollo-core/p-315920cd.entry.js +2 -0
  23. package/dist/apollo-core/p-315920cd.entry.js.map +1 -0
  24. package/dist/apollo-core/p-3c934536.entry.js +2 -0
  25. package/dist/apollo-core/p-3c934536.entry.js.map +1 -0
  26. package/dist/apollo-core/p-47a55fa9.entry.js +2 -0
  27. package/dist/apollo-core/p-47a55fa9.entry.js.map +1 -0
  28. package/dist/apollo-core/p-485d0c40.entry.js +2 -0
  29. package/dist/apollo-core/p-485d0c40.entry.js.map +1 -0
  30. package/dist/apollo-core/p-5a038a8e.entry.js +2 -0
  31. package/dist/apollo-core/p-5a038a8e.entry.js.map +1 -0
  32. package/dist/apollo-core/p-88135928.entry.js +2 -0
  33. package/dist/apollo-core/p-88135928.entry.js.map +1 -0
  34. package/dist/apollo-core/p-91d6572c.entry.js +2 -0
  35. package/dist/apollo-core/p-91d6572c.entry.js.map +1 -0
  36. package/dist/apollo-core/p-ad90fe4d.js +2 -1
  37. package/dist/apollo-core/p-ad90fe4d.js.map +1 -0
  38. package/dist/apollo-core/p-ae99c266.entry.js +2 -0
  39. package/dist/apollo-core/p-ae99c266.entry.js.map +1 -0
  40. package/dist/apollo-core/p-aeef61dd.entry.js +2 -0
  41. package/dist/apollo-core/p-aeef61dd.entry.js.map +1 -0
  42. package/dist/apollo-core/p-c1b28f32.entry.js +2 -0
  43. package/dist/apollo-core/p-c1b28f32.entry.js.map +1 -0
  44. package/dist/apollo-core/p-ce6cb219.entry.js +2 -0
  45. package/dist/apollo-core/p-ce6cb219.entry.js.map +1 -0
  46. package/dist/apollo-core/p-cf2e6132.js +3 -0
  47. package/dist/apollo-core/p-cf2e6132.js.map +1 -0
  48. package/dist/apollo-core/p-e9cd309e.entry.js +2 -0
  49. package/dist/apollo-core/p-e9cd309e.entry.js.map +1 -0
  50. package/dist/apollo-core/p-f5561238.entry.js +2 -0
  51. package/dist/apollo-core/p-f5561238.entry.js.map +1 -0
  52. package/dist/apollo-core/p-ff46d20f.entry.js +2 -0
  53. package/dist/apollo-core/p-ff46d20f.entry.js.map +1 -0
  54. package/dist/{custom-elements/index.js → apollo-core/regular-133c23b5.js} +13 -4197
  55. package/dist/apollo-core/regular-133c23b5.js.map +1 -0
  56. package/dist/apollo-core/shadow-css-f0279020.js +389 -0
  57. package/dist/apollo-core/shadow-css-f0279020.js.map +1 -0
  58. package/dist/apollo-core/xpl-application-shell.entry.js +51 -0
  59. package/dist/apollo-core/xpl-application-shell.entry.js.map +1 -0
  60. package/dist/apollo-core/xpl-avatar.entry.js +28 -0
  61. package/dist/apollo-core/xpl-avatar.entry.js.map +1 -0
  62. package/dist/apollo-core/xpl-backdrop.entry.js +19 -0
  63. package/dist/apollo-core/xpl-backdrop.entry.js.map +1 -0
  64. package/dist/apollo-core/xpl-badge.entry.js +21 -0
  65. package/dist/apollo-core/xpl-badge.entry.js.map +1 -0
  66. package/dist/apollo-core/xpl-breadcrumb-item.entry.js +19 -0
  67. package/dist/apollo-core/xpl-breadcrumb-item.entry.js.map +1 -0
  68. package/dist/apollo-core/xpl-breadcrumbs.entry.js +14 -0
  69. package/dist/apollo-core/xpl-breadcrumbs.entry.js.map +1 -0
  70. package/dist/apollo-core/xpl-button-row.entry.js +23 -0
  71. package/dist/apollo-core/xpl-button-row.entry.js.map +1 -0
  72. package/dist/apollo-core/xpl-button.entry.js +60 -0
  73. package/dist/apollo-core/xpl-button.entry.js.map +1 -0
  74. package/dist/apollo-core/xpl-checkbox.entry.js +35 -0
  75. package/dist/apollo-core/xpl-checkbox.entry.js.map +1 -0
  76. package/dist/apollo-core/xpl-choicelist.entry.js +48 -0
  77. package/dist/apollo-core/xpl-choicelist.entry.js.map +1 -0
  78. package/dist/apollo-core/xpl-content-area.entry.js +15 -0
  79. package/dist/apollo-core/xpl-content-area.entry.js.map +1 -0
  80. package/dist/apollo-core/xpl-divider.entry.js +17 -0
  81. package/dist/apollo-core/xpl-divider.entry.js.map +1 -0
  82. package/dist/apollo-core/xpl-dropdown-group.entry.js +35 -0
  83. package/dist/apollo-core/xpl-dropdown-group.entry.js.map +1 -0
  84. package/dist/apollo-core/xpl-dropdown-heading.entry.js +15 -0
  85. package/dist/apollo-core/xpl-dropdown-heading.entry.js.map +1 -0
  86. package/dist/apollo-core/xpl-dropdown-option.entry.js +70 -0
  87. package/dist/apollo-core/xpl-dropdown-option.entry.js.map +1 -0
  88. package/dist/apollo-core/xpl-dropdown.entry.js +106 -0
  89. package/dist/apollo-core/xpl-dropdown.entry.js.map +1 -0
  90. package/dist/apollo-core/xpl-grid-item.entry.js +23 -0
  91. package/dist/apollo-core/xpl-grid-item.entry.js.map +1 -0
  92. package/dist/apollo-core/xpl-grid.entry.js +33 -0
  93. package/dist/apollo-core/xpl-grid.entry.js.map +1 -0
  94. package/dist/apollo-core/xpl-input.entry.js +2553 -0
  95. package/dist/apollo-core/xpl-input.entry.js.map +1 -0
  96. package/dist/apollo-core/xpl-list.entry.js +37 -0
  97. package/dist/apollo-core/xpl-list.entry.js.map +1 -0
  98. package/dist/apollo-core/xpl-main-nav.entry.js +25 -0
  99. package/dist/apollo-core/xpl-main-nav.entry.js.map +1 -0
  100. package/dist/apollo-core/xpl-nav-item.entry.js +25 -0
  101. package/dist/apollo-core/xpl-nav-item.entry.js.map +1 -0
  102. package/dist/apollo-core/xpl-pagination.entry.js +77 -0
  103. package/dist/apollo-core/xpl-pagination.entry.js.map +1 -0
  104. package/dist/apollo-core/xpl-radio.entry.js +34 -0
  105. package/dist/apollo-core/xpl-radio.entry.js.map +1 -0
  106. package/dist/apollo-core/xpl-secondary-nav.entry.js +14 -0
  107. package/dist/apollo-core/xpl-secondary-nav.entry.js.map +1 -0
  108. package/dist/apollo-core/xpl-select.entry.js +680 -0
  109. package/dist/apollo-core/xpl-select.entry.js.map +1 -0
  110. package/dist/apollo-core/xpl-table.entry.js +109 -0
  111. package/dist/apollo-core/xpl-table.entry.js.map +1 -0
  112. package/dist/apollo-core/xpl-tag.entry.js +19 -0
  113. package/dist/apollo-core/xpl-tag.entry.js.map +1 -0
  114. package/dist/apollo-core/xpl-toggle.entry.js +35 -0
  115. package/dist/apollo-core/xpl-toggle.entry.js.map +1 -0
  116. package/dist/apollo-core/xpl-utility-bar.entry.js +31 -0
  117. package/dist/apollo-core/xpl-utility-bar.entry.js.map +1 -0
  118. package/dist/cjs/apollo-core.cjs.js +154 -5
  119. package/dist/cjs/apollo-core.cjs.js.map +1 -0
  120. package/dist/cjs/app-globals-3a1e7e63.js +7 -0
  121. package/dist/cjs/app-globals-3a1e7e63.js.map +1 -0
  122. package/dist/cjs/css-shim-0a6fd78d.js +8 -0
  123. package/dist/cjs/css-shim-0a6fd78d.js.map +1 -0
  124. package/dist/cjs/dom-2c6adc90.js +77 -0
  125. package/dist/cjs/dom-2c6adc90.js.map +1 -0
  126. package/dist/cjs/index-0fdb260e.js +3564 -0
  127. package/dist/cjs/index-0fdb260e.js.map +1 -0
  128. package/dist/cjs/index-318d5fc7.js +588 -0
  129. package/dist/cjs/index-318d5fc7.js.map +1 -0
  130. package/dist/cjs/{index-acf3dd7a.js → index-e53b018b.js} +675 -215
  131. package/dist/cjs/index-e53b018b.js.map +1 -0
  132. package/dist/cjs/index.cjs.js +3 -0
  133. package/dist/cjs/index.cjs.js.map +1 -0
  134. package/dist/cjs/loader.cjs.js +24 -3
  135. package/dist/cjs/loader.cjs.js.map +1 -0
  136. package/dist/cjs/regular-503465f4.js +16056 -0
  137. package/dist/cjs/regular-503465f4.js.map +1 -0
  138. package/dist/cjs/regular-872f5226.js +2 -0
  139. package/dist/cjs/regular-872f5226.js.map +1 -0
  140. package/dist/cjs/shadow-css-39dfcfae.js +391 -0
  141. package/dist/cjs/shadow-css-39dfcfae.js.map +1 -0
  142. package/dist/cjs/v4-14140ff3.js +2 -0
  143. package/dist/cjs/v4-14140ff3.js.map +1 -0
  144. package/dist/cjs/xpl-application-shell.cjs.entry.js +4 -13
  145. package/dist/cjs/xpl-application-shell.cjs.entry.js.map +1 -0
  146. package/dist/cjs/xpl-avatar.cjs.entry.js +32 -0
  147. package/dist/cjs/xpl-avatar.cjs.entry.js.map +1 -0
  148. package/dist/cjs/xpl-avatar_12.cjs.entry.js +74 -38
  149. package/dist/cjs/xpl-avatar_12.cjs.entry.js.map +1 -0
  150. package/dist/cjs/xpl-backdrop.cjs.entry.js +3 -5
  151. package/dist/cjs/xpl-backdrop.cjs.entry.js.map +1 -0
  152. package/dist/cjs/xpl-badge.cjs.entry.js +25 -0
  153. package/dist/cjs/xpl-badge.cjs.entry.js.map +1 -0
  154. package/dist/cjs/xpl-breadcrumb-item.cjs.entry.js +23 -0
  155. package/dist/cjs/xpl-breadcrumb-item.cjs.entry.js.map +1 -0
  156. package/dist/cjs/xpl-breadcrumbs.cjs.entry.js +18 -0
  157. package/dist/cjs/xpl-breadcrumbs.cjs.entry.js.map +1 -0
  158. package/dist/cjs/xpl-button-row.cjs.entry.js +6 -1
  159. package/dist/cjs/xpl-button-row.cjs.entry.js.map +1 -0
  160. package/dist/cjs/xpl-button.cjs.entry.js +64 -0
  161. package/dist/cjs/xpl-button.cjs.entry.js.map +1 -0
  162. package/dist/cjs/xpl-checkbox.cjs.entry.js +39 -0
  163. package/dist/cjs/xpl-checkbox.cjs.entry.js.map +1 -0
  164. package/dist/cjs/xpl-choicelist.cjs.entry.js +10 -1
  165. package/dist/cjs/xpl-choicelist.cjs.entry.js.map +1 -0
  166. package/dist/cjs/xpl-content-area.cjs.entry.js +19 -0
  167. package/dist/cjs/xpl-content-area.cjs.entry.js.map +1 -0
  168. package/dist/cjs/xpl-divider.cjs.entry.js +4 -1
  169. package/dist/cjs/xpl-divider.cjs.entry.js.map +1 -0
  170. package/dist/cjs/xpl-dropdown-group.cjs.entry.js +39 -0
  171. package/dist/cjs/xpl-dropdown-group.cjs.entry.js.map +1 -0
  172. package/dist/cjs/xpl-dropdown-group_3.cjs.entry.js +12 -3
  173. package/dist/cjs/xpl-dropdown-group_3.cjs.entry.js.map +1 -0
  174. package/dist/cjs/xpl-dropdown-heading.cjs.entry.js +19 -0
  175. package/dist/cjs/xpl-dropdown-heading.cjs.entry.js.map +1 -0
  176. package/dist/cjs/xpl-dropdown-option.cjs.entry.js +74 -0
  177. package/dist/cjs/xpl-dropdown-option.cjs.entry.js.map +1 -0
  178. package/dist/cjs/xpl-dropdown.cjs.entry.js +110 -0
  179. package/dist/cjs/xpl-dropdown.cjs.entry.js.map +1 -0
  180. package/dist/cjs/xpl-dropdown_2.cjs.entry.js +13 -10
  181. package/dist/cjs/xpl-dropdown_2.cjs.entry.js.map +1 -0
  182. package/dist/cjs/xpl-grid-item.cjs.entry.js +3 -1
  183. package/dist/cjs/xpl-grid-item.cjs.entry.js.map +1 -0
  184. package/dist/cjs/xpl-grid.cjs.entry.js +3 -1
  185. package/dist/cjs/xpl-grid.cjs.entry.js.map +1 -0
  186. package/dist/cjs/xpl-input.cjs.entry.js +40 -17
  187. package/dist/cjs/xpl-input.cjs.entry.js.map +1 -0
  188. package/dist/cjs/xpl-list.cjs.entry.js +4 -24
  189. package/dist/cjs/xpl-list.cjs.entry.js.map +1 -0
  190. package/dist/cjs/xpl-main-nav.cjs.entry.js +3 -4
  191. package/dist/cjs/xpl-main-nav.cjs.entry.js.map +1 -0
  192. package/dist/cjs/xpl-nav-item.cjs.entry.js +29 -0
  193. package/dist/cjs/xpl-nav-item.cjs.entry.js.map +1 -0
  194. package/dist/cjs/xpl-pagination.cjs.entry.js +7 -2
  195. package/dist/cjs/xpl-pagination.cjs.entry.js.map +1 -0
  196. package/dist/cjs/xpl-radio.cjs.entry.js +38 -0
  197. package/dist/cjs/xpl-radio.cjs.entry.js.map +1 -0
  198. package/dist/cjs/xpl-secondary-nav.cjs.entry.js +18 -0
  199. package/dist/cjs/xpl-secondary-nav.cjs.entry.js.map +1 -0
  200. package/dist/cjs/xpl-select.cjs.entry.js +86 -27
  201. package/dist/cjs/xpl-select.cjs.entry.js.map +1 -0
  202. package/dist/cjs/xpl-table.cjs.entry.js +113 -0
  203. package/dist/cjs/xpl-table.cjs.entry.js.map +1 -0
  204. package/dist/cjs/xpl-tag.cjs.entry.js +23 -0
  205. package/dist/cjs/xpl-tag.cjs.entry.js.map +1 -0
  206. package/dist/cjs/xpl-toggle.cjs.entry.js +11 -6
  207. package/dist/cjs/xpl-toggle.cjs.entry.js.map +1 -0
  208. package/dist/cjs/xpl-utility-bar.cjs.entry.js +35 -0
  209. package/dist/cjs/xpl-utility-bar.cjs.entry.js.map +1 -0
  210. package/dist/collection/collection-manifest.json +2 -2
  211. package/dist/collection/components/xpl-application-shell/xpl-application-shell.js +119 -132
  212. package/dist/collection/components/xpl-application-shell/xpl-application-shell.js.map +1 -0
  213. package/dist/collection/components/xpl-avatar/xpl-avatar.js +151 -144
  214. package/dist/collection/components/xpl-avatar/xpl-avatar.js.map +1 -0
  215. package/dist/collection/components/xpl-backdrop/xpl-backdrop.js +27 -28
  216. package/dist/collection/components/xpl-backdrop/xpl-backdrop.js.map +1 -0
  217. package/dist/collection/components/xpl-badge/xpl-badge.js +44 -39
  218. package/dist/collection/components/xpl-badge/xpl-badge.js.map +1 -0
  219. package/dist/collection/components/xpl-breadcrumbs/xpl-breadcrumb-item/xpl-breadcrumb-item.js +3 -5
  220. package/dist/collection/components/xpl-breadcrumbs/xpl-breadcrumb-item/xpl-breadcrumb-item.js.map +1 -0
  221. package/dist/collection/components/xpl-breadcrumbs/xpl-breadcrumbs/xpl-breadcrumbs.js +3 -5
  222. package/dist/collection/components/xpl-breadcrumbs/xpl-breadcrumbs/xpl-breadcrumbs.js.map +1 -0
  223. package/dist/collection/components/xpl-button/xpl-button.js +205 -205
  224. package/dist/collection/components/xpl-button/xpl-button.js.map +1 -0
  225. package/dist/collection/components/xpl-button-row/xpl-button-row.js +106 -104
  226. package/dist/collection/components/xpl-button-row/xpl-button-row.js.map +1 -0
  227. package/dist/collection/components/xpl-checkbox/xpl-checkbox.js +182 -171
  228. package/dist/collection/components/xpl-checkbox/xpl-checkbox.js.map +1 -0
  229. package/dist/collection/components/xpl-choicelist/choice.js +1 -0
  230. package/dist/collection/components/xpl-choicelist/choice.js.map +1 -0
  231. package/dist/collection/components/xpl-choicelist/xpl-choicelist.js +134 -126
  232. package/dist/collection/components/xpl-choicelist/xpl-choicelist.js.map +1 -0
  233. package/dist/collection/components/xpl-content-area/xpl-content-area.js +28 -31
  234. package/dist/collection/components/xpl-content-area/xpl-content-area.js.map +1 -0
  235. package/dist/collection/components/xpl-divider/xpl-divider.js +27 -23
  236. package/dist/collection/components/xpl-divider/xpl-divider.js.map +1 -0
  237. package/dist/collection/components/xpl-dropdown/dropdownoption.js +1 -0
  238. package/dist/collection/components/xpl-dropdown/dropdownoption.js.map +1 -0
  239. package/dist/collection/components/xpl-dropdown/xpl-dropdown-group/xpl-dropdown-group.js +47 -42
  240. package/dist/collection/components/xpl-dropdown/xpl-dropdown-group/xpl-dropdown-group.js.map +1 -0
  241. package/dist/collection/components/xpl-dropdown/xpl-dropdown-heading/xpl-dropdown-heading.js +27 -22
  242. package/dist/collection/components/xpl-dropdown/xpl-dropdown-heading/xpl-dropdown-heading.js.map +1 -0
  243. package/dist/collection/components/xpl-dropdown/xpl-dropdown-option/xpl-dropdown-option.js +79 -54
  244. package/dist/collection/components/xpl-dropdown/xpl-dropdown-option/xpl-dropdown-option.js.map +1 -0
  245. package/dist/collection/components/xpl-dropdown/xpl-dropdown.js +168 -168
  246. package/dist/collection/components/xpl-dropdown/xpl-dropdown.js.map +1 -0
  247. package/dist/collection/components/xpl-grid/xpl-grid.js +2 -1
  248. package/dist/collection/components/xpl-grid/xpl-grid.js.map +1 -0
  249. package/dist/collection/components/xpl-grid-item/xpl-grid-item.js +76 -74
  250. package/dist/collection/components/xpl-grid-item/xpl-grid-item.js.map +1 -0
  251. package/dist/collection/components/xpl-input/xpl-input.js +405 -417
  252. package/dist/collection/components/xpl-input/xpl-input.js.map +1 -0
  253. package/dist/collection/components/xpl-list/listitem.js +1 -0
  254. package/dist/collection/components/xpl-list/listitem.js.map +1 -0
  255. package/dist/collection/components/xpl-list/xpl-list.js +43 -75
  256. package/dist/collection/components/xpl-list/xpl-list.js.map +1 -0
  257. package/dist/collection/components/xpl-main-nav/xpl-main-nav.js +48 -54
  258. package/dist/collection/components/xpl-main-nav/xpl-main-nav.js.map +1 -0
  259. package/dist/collection/components/xpl-nav-item/xpl-nav-item.js +48 -49
  260. package/dist/collection/components/xpl-nav-item/xpl-nav-item.js.map +1 -0
  261. package/dist/collection/components/xpl-pagination/xpl-pagination.js +117 -128
  262. package/dist/collection/components/xpl-pagination/xpl-pagination.js.map +1 -0
  263. package/dist/collection/components/xpl-radio/xpl-radio.js +158 -148
  264. package/dist/collection/components/xpl-radio/xpl-radio.js.map +1 -0
  265. package/dist/collection/components/xpl-secondary-nav/xpl-secondary-nav.js +3 -4
  266. package/dist/collection/components/xpl-secondary-nav/xpl-secondary-nav.js.map +1 -0
  267. package/dist/collection/components/xpl-select/xpl-select.js +296 -236
  268. package/dist/collection/components/xpl-select/xpl-select.js.map +1 -0
  269. package/dist/collection/components/xpl-table/xpl-table.js +169 -151
  270. package/dist/collection/components/xpl-table/xpl-table.js.map +1 -0
  271. package/dist/collection/components/xpl-tag/xpl-tag.js +25 -25
  272. package/dist/collection/components/xpl-tag/xpl-tag.js.map +1 -0
  273. package/dist/collection/components/xpl-toggle/xpl-toggle.js +138 -135
  274. package/dist/collection/components/xpl-toggle/xpl-toggle.js.map +1 -0
  275. package/dist/collection/components/xpl-utility-bar/xpl-utility-bar.js +74 -70
  276. package/dist/collection/components/xpl-utility-bar/xpl-utility-bar.js.map +1 -0
  277. package/dist/components/index.d.ts +39 -0
  278. package/dist/components/index.js +81 -0
  279. package/dist/components/index.js.map +1 -0
  280. package/dist/components/index2.js +586 -0
  281. package/dist/components/index2.js.map +1 -0
  282. package/dist/components/regular.js +16054 -0
  283. package/dist/components/regular.js.map +1 -0
  284. package/dist/components/v4.js +77 -0
  285. package/dist/components/v4.js.map +1 -0
  286. package/dist/components/xpl-application-shell.d.ts +11 -0
  287. package/dist/components/xpl-application-shell.js +80 -0
  288. package/dist/components/xpl-application-shell.js.map +1 -0
  289. package/dist/components/xpl-avatar.d.ts +11 -0
  290. package/dist/components/xpl-avatar.js +8 -0
  291. package/dist/components/xpl-avatar.js.map +1 -0
  292. package/dist/components/xpl-avatar2.js +51 -0
  293. package/dist/components/xpl-avatar2.js.map +1 -0
  294. package/dist/components/xpl-backdrop.d.ts +11 -0
  295. package/dist/components/xpl-backdrop.js +8 -0
  296. package/dist/components/xpl-backdrop.js.map +1 -0
  297. package/dist/components/xpl-backdrop2.js +35 -0
  298. package/dist/components/xpl-backdrop2.js.map +1 -0
  299. package/dist/components/xpl-badge.d.ts +11 -0
  300. package/dist/components/xpl-badge.js +8 -0
  301. package/dist/components/xpl-badge.js.map +1 -0
  302. package/dist/components/xpl-badge2.js +38 -0
  303. package/dist/components/xpl-badge2.js.map +1 -0
  304. package/dist/components/xpl-breadcrumb-item.d.ts +11 -0
  305. package/dist/components/xpl-breadcrumb-item.js +36 -0
  306. package/dist/components/xpl-breadcrumb-item.js.map +1 -0
  307. package/dist/components/xpl-breadcrumbs.d.ts +11 -0
  308. package/dist/components/xpl-breadcrumbs.js +31 -0
  309. package/dist/components/xpl-breadcrumbs.js.map +1 -0
  310. package/dist/components/xpl-button-row.d.ts +11 -0
  311. package/dist/components/xpl-button-row.js +50 -0
  312. package/dist/components/xpl-button-row.js.map +1 -0
  313. package/dist/components/xpl-button.d.ts +11 -0
  314. package/dist/components/xpl-button.js +8 -0
  315. package/dist/components/xpl-button.js.map +1 -0
  316. package/dist/components/xpl-button2.js +85 -0
  317. package/dist/components/xpl-button2.js.map +1 -0
  318. package/dist/components/xpl-checkbox.d.ts +11 -0
  319. package/dist/components/xpl-checkbox.js +8 -0
  320. package/dist/components/xpl-checkbox.js.map +1 -0
  321. package/dist/components/xpl-checkbox2.js +59 -0
  322. package/dist/components/xpl-checkbox2.js.map +1 -0
  323. package/dist/components/xpl-choicelist.d.ts +11 -0
  324. package/dist/components/xpl-choicelist.js +85 -0
  325. package/dist/components/xpl-choicelist.js.map +1 -0
  326. package/dist/components/xpl-content-area.d.ts +11 -0
  327. package/dist/components/xpl-content-area.js +34 -0
  328. package/dist/components/xpl-content-area.js.map +1 -0
  329. package/dist/components/xpl-divider.d.ts +11 -0
  330. package/dist/components/xpl-divider.js +36 -0
  331. package/dist/components/xpl-divider.js.map +1 -0
  332. package/dist/components/xpl-dropdown-group.d.ts +11 -0
  333. package/dist/components/xpl-dropdown-group.js +8 -0
  334. package/dist/components/xpl-dropdown-group.js.map +1 -0
  335. package/dist/components/xpl-dropdown-group2.js +69 -0
  336. package/dist/components/xpl-dropdown-group2.js.map +1 -0
  337. package/dist/components/xpl-dropdown-heading.d.ts +11 -0
  338. package/dist/components/xpl-dropdown-heading.js +8 -0
  339. package/dist/components/xpl-dropdown-heading.js.map +1 -0
  340. package/dist/components/xpl-dropdown-heading2.js +31 -0
  341. package/dist/components/xpl-dropdown-heading2.js.map +1 -0
  342. package/dist/components/xpl-dropdown-option.d.ts +11 -0
  343. package/dist/components/xpl-dropdown-option.js +8 -0
  344. package/dist/components/xpl-dropdown-option.js.map +1 -0
  345. package/dist/components/xpl-dropdown-option2.js +89 -0
  346. package/dist/components/xpl-dropdown-option2.js.map +1 -0
  347. package/dist/components/xpl-dropdown.d.ts +11 -0
  348. package/dist/components/xpl-dropdown.js +8 -0
  349. package/dist/components/xpl-dropdown.js.map +1 -0
  350. package/dist/components/xpl-dropdown2.js +147 -0
  351. package/dist/components/xpl-dropdown2.js.map +1 -0
  352. package/dist/components/xpl-grid-item.d.ts +11 -0
  353. package/dist/components/xpl-grid-item.js +45 -0
  354. package/dist/components/xpl-grid-item.js.map +1 -0
  355. package/dist/components/xpl-grid.d.ts +11 -0
  356. package/dist/components/xpl-grid.js +50 -0
  357. package/dist/components/xpl-grid.js.map +1 -0
  358. package/dist/components/xpl-input.d.ts +11 -0
  359. package/dist/components/xpl-input.js +2594 -0
  360. package/dist/components/xpl-input.js.map +1 -0
  361. package/dist/components/xpl-list.d.ts +11 -0
  362. package/dist/components/xpl-list.js +68 -0
  363. package/dist/components/xpl-list.js.map +1 -0
  364. package/dist/components/xpl-main-nav.d.ts +11 -0
  365. package/dist/components/xpl-main-nav.js +44 -0
  366. package/dist/components/xpl-main-nav.js.map +1 -0
  367. package/dist/components/xpl-nav-item.d.ts +11 -0
  368. package/dist/components/xpl-nav-item.js +44 -0
  369. package/dist/components/xpl-nav-item.js.map +1 -0
  370. package/dist/components/xpl-pagination.d.ts +11 -0
  371. package/dist/components/xpl-pagination.js +100 -0
  372. package/dist/components/xpl-pagination.js.map +1 -0
  373. package/dist/components/xpl-radio.d.ts +11 -0
  374. package/dist/components/xpl-radio.js +8 -0
  375. package/dist/components/xpl-radio.js.map +1 -0
  376. package/dist/components/xpl-radio2.js +57 -0
  377. package/dist/components/xpl-radio2.js.map +1 -0
  378. package/dist/components/xpl-secondary-nav.d.ts +11 -0
  379. package/dist/components/xpl-secondary-nav.js +31 -0
  380. package/dist/components/xpl-secondary-nav.js.map +1 -0
  381. package/dist/components/xpl-select.d.ts +11 -0
  382. package/dist/components/xpl-select.js +745 -0
  383. package/dist/components/xpl-select.js.map +1 -0
  384. package/dist/components/xpl-table.d.ts +11 -0
  385. package/dist/components/xpl-table.js +136 -0
  386. package/dist/components/xpl-table.js.map +1 -0
  387. package/dist/components/xpl-tag.d.ts +11 -0
  388. package/dist/components/xpl-tag.js +8 -0
  389. package/dist/components/xpl-tag.js.map +1 -0
  390. package/dist/components/xpl-tag2.js +33 -0
  391. package/dist/components/xpl-tag2.js.map +1 -0
  392. package/dist/components/xpl-toggle.d.ts +11 -0
  393. package/dist/components/xpl-toggle.js +61 -0
  394. package/dist/components/xpl-toggle.js.map +1 -0
  395. package/dist/components/xpl-utility-bar.d.ts +11 -0
  396. package/dist/components/xpl-utility-bar.js +52 -0
  397. package/dist/components/xpl-utility-bar.js.map +1 -0
  398. package/dist/esm/apollo-core.js +151 -5
  399. package/dist/esm/apollo-core.js.map +1 -0
  400. package/dist/esm/app-globals-0f993ce5.js +5 -0
  401. package/dist/esm/app-globals-0f993ce5.js.map +1 -0
  402. package/dist/esm/css-shim-6210ce77.js +6 -0
  403. package/dist/esm/css-shim-6210ce77.js.map +1 -0
  404. package/dist/esm/dom-423bdd70.js +75 -0
  405. package/dist/esm/dom-423bdd70.js.map +1 -0
  406. package/dist/esm/index-307c7018.js +3526 -0
  407. package/dist/esm/index-307c7018.js.map +1 -0
  408. package/dist/esm/index-912d1a21.js +586 -0
  409. package/dist/esm/index-912d1a21.js.map +1 -0
  410. package/dist/esm/{index-e3c4bb97.js → index-df9b48b4.js} +675 -216
  411. package/dist/esm/index-df9b48b4.js.map +1 -0
  412. package/dist/esm/index.js +2 -0
  413. package/dist/esm/index.js.map +1 -0
  414. package/dist/esm/loader.js +24 -3
  415. package/dist/esm/loader.js.map +1 -0
  416. package/dist/esm/polyfills/css-shim.js +1 -1
  417. package/dist/esm/regular-133c23b5.js +16054 -0
  418. package/dist/esm/regular-133c23b5.js.map +1 -0
  419. package/dist/esm/regular-86225e9d.js +2 -0
  420. package/dist/esm/regular-86225e9d.js.map +1 -0
  421. package/dist/esm/shadow-css-f0279020.js +389 -0
  422. package/dist/esm/shadow-css-f0279020.js.map +1 -0
  423. package/dist/esm/v4-929670b7.js +2 -0
  424. package/dist/esm/v4-929670b7.js.map +1 -0
  425. package/dist/esm/xpl-application-shell.entry.js +4 -13
  426. package/dist/esm/xpl-application-shell.entry.js.map +1 -0
  427. package/dist/esm/xpl-avatar.entry.js +28 -0
  428. package/dist/esm/xpl-avatar.entry.js.map +1 -0
  429. package/dist/esm/xpl-avatar_12.entry.js +74 -38
  430. package/dist/esm/xpl-avatar_12.entry.js.map +1 -0
  431. package/dist/esm/xpl-backdrop.entry.js +3 -5
  432. package/dist/esm/xpl-backdrop.entry.js.map +1 -0
  433. package/dist/esm/xpl-badge.entry.js +21 -0
  434. package/dist/esm/xpl-badge.entry.js.map +1 -0
  435. package/dist/esm/xpl-breadcrumb-item.entry.js +19 -0
  436. package/dist/esm/xpl-breadcrumb-item.entry.js.map +1 -0
  437. package/dist/esm/xpl-breadcrumbs.entry.js +14 -0
  438. package/dist/esm/xpl-breadcrumbs.entry.js.map +1 -0
  439. package/dist/esm/xpl-button-row.entry.js +6 -1
  440. package/dist/esm/xpl-button-row.entry.js.map +1 -0
  441. package/dist/esm/xpl-button.entry.js +60 -0
  442. package/dist/esm/xpl-button.entry.js.map +1 -0
  443. package/dist/esm/xpl-checkbox.entry.js +35 -0
  444. package/dist/esm/xpl-checkbox.entry.js.map +1 -0
  445. package/dist/esm/xpl-choicelist.entry.js +10 -1
  446. package/dist/esm/xpl-choicelist.entry.js.map +1 -0
  447. package/dist/esm/xpl-content-area.entry.js +15 -0
  448. package/dist/esm/xpl-content-area.entry.js.map +1 -0
  449. package/dist/esm/xpl-divider.entry.js +4 -1
  450. package/dist/esm/xpl-divider.entry.js.map +1 -0
  451. package/dist/esm/xpl-dropdown-group.entry.js +35 -0
  452. package/dist/esm/xpl-dropdown-group.entry.js.map +1 -0
  453. package/dist/esm/xpl-dropdown-group_3.entry.js +12 -3
  454. package/dist/esm/xpl-dropdown-group_3.entry.js.map +1 -0
  455. package/dist/esm/xpl-dropdown-heading.entry.js +15 -0
  456. package/dist/esm/xpl-dropdown-heading.entry.js.map +1 -0
  457. package/dist/esm/xpl-dropdown-option.entry.js +70 -0
  458. package/dist/esm/xpl-dropdown-option.entry.js.map +1 -0
  459. package/dist/esm/xpl-dropdown.entry.js +106 -0
  460. package/dist/esm/xpl-dropdown.entry.js.map +1 -0
  461. package/dist/esm/xpl-dropdown_2.entry.js +13 -10
  462. package/dist/esm/xpl-dropdown_2.entry.js.map +1 -0
  463. package/dist/esm/xpl-grid-item.entry.js +3 -1
  464. package/dist/esm/xpl-grid-item.entry.js.map +1 -0
  465. package/dist/esm/xpl-grid.entry.js +3 -1
  466. package/dist/esm/xpl-grid.entry.js.map +1 -0
  467. package/dist/esm/xpl-input.entry.js +39 -16
  468. package/dist/esm/xpl-input.entry.js.map +1 -0
  469. package/dist/esm/xpl-list.entry.js +4 -24
  470. package/dist/esm/xpl-list.entry.js.map +1 -0
  471. package/dist/esm/xpl-main-nav.entry.js +3 -4
  472. package/dist/esm/xpl-main-nav.entry.js.map +1 -0
  473. package/dist/esm/xpl-nav-item.entry.js +25 -0
  474. package/dist/esm/xpl-nav-item.entry.js.map +1 -0
  475. package/dist/esm/xpl-pagination.entry.js +7 -2
  476. package/dist/esm/xpl-pagination.entry.js.map +1 -0
  477. package/dist/esm/xpl-radio.entry.js +34 -0
  478. package/dist/esm/xpl-radio.entry.js.map +1 -0
  479. package/dist/esm/xpl-secondary-nav.entry.js +14 -0
  480. package/dist/esm/xpl-secondary-nav.entry.js.map +1 -0
  481. package/dist/esm/xpl-select.entry.js +85 -26
  482. package/dist/esm/xpl-select.entry.js.map +1 -0
  483. package/dist/esm/xpl-table.entry.js +109 -0
  484. package/dist/esm/xpl-table.entry.js.map +1 -0
  485. package/dist/esm/xpl-tag.entry.js +19 -0
  486. package/dist/esm/xpl-tag.entry.js.map +1 -0
  487. package/dist/esm/xpl-toggle.entry.js +10 -5
  488. package/dist/esm/xpl-toggle.entry.js.map +1 -0
  489. package/dist/esm/xpl-utility-bar.entry.js +31 -0
  490. package/dist/esm/xpl-utility-bar.entry.js.map +1 -0
  491. package/dist/stories/application-shell.stories.js +1 -0
  492. package/dist/stories/application-shell.stories.js.map +1 -0
  493. package/dist/stories/avatar.stories.js +1 -0
  494. package/dist/stories/avatar.stories.js.map +1 -0
  495. package/dist/stories/backdrop.stories.js +1 -0
  496. package/dist/stories/backdrop.stories.js.map +1 -0
  497. package/dist/stories/badge.stories.js +1 -0
  498. package/dist/stories/badge.stories.js.map +1 -0
  499. package/dist/stories/breadcrumbs.stories.js +1 -0
  500. package/dist/stories/breadcrumbs.stories.js.map +1 -0
  501. package/dist/stories/button-row.stories.js +1 -0
  502. package/dist/stories/button-row.stories.js.map +1 -0
  503. package/dist/stories/button.stories.js +1 -0
  504. package/dist/stories/button.stories.js.map +1 -0
  505. package/dist/stories/checkbox.stories.js +1 -0
  506. package/dist/stories/checkbox.stories.js.map +1 -0
  507. package/dist/stories/choicelist.stories.js +1 -0
  508. package/dist/stories/choicelist.stories.js.map +1 -0
  509. package/dist/stories/content-area.stories.js +1 -0
  510. package/dist/stories/content-area.stories.js.map +1 -0
  511. package/dist/stories/divider.stories.js +1 -0
  512. package/dist/stories/divider.stories.js.map +1 -0
  513. package/dist/stories/dropdown.stories.js +74 -65
  514. package/dist/stories/dropdown.stories.js.map +1 -0
  515. package/dist/stories/grid.stories.js +1 -0
  516. package/dist/stories/grid.stories.js.map +1 -0
  517. package/dist/stories/input.stories.js +1 -0
  518. package/dist/stories/input.stories.js.map +1 -0
  519. package/dist/stories/list.stories.js +1 -0
  520. package/dist/stories/list.stories.js.map +1 -0
  521. package/dist/stories/main-nav.stories.js +1 -0
  522. package/dist/stories/main-nav.stories.js.map +1 -0
  523. package/dist/stories/pagination.stories.js +1 -0
  524. package/dist/stories/pagination.stories.js.map +1 -0
  525. package/dist/stories/radio.stories.js +1 -0
  526. package/dist/stories/radio.stories.js.map +1 -0
  527. package/dist/stories/secondary-nav.stories.js +1 -0
  528. package/dist/stories/secondary-nav.stories.js.map +1 -0
  529. package/dist/stories/select.stories.js +109 -32
  530. package/dist/stories/select.stories.js.map +1 -0
  531. package/dist/stories/table.stories.js +1 -0
  532. package/dist/stories/table.stories.js.map +1 -0
  533. package/dist/stories/tabs.stories.js +1 -0
  534. package/dist/stories/tabs.stories.js.map +1 -0
  535. package/dist/stories/toggle.stories.js +1 -0
  536. package/dist/stories/toggle.stories.js.map +1 -0
  537. package/dist/stories/utility-bar.stories.js +1 -0
  538. package/dist/stories/utility-bar.stories.js.map +1 -0
  539. package/dist/types/Users/roc/Sites/apollo/.stencil/stories/dropdown.stories.d.ts +17 -1
  540. package/dist/types/Users/roc/Sites/apollo/.stencil/stories/select.stories.d.ts +60 -0
  541. package/dist/types/components/xpl-dropdown/dropdownoption.d.ts +2 -1
  542. package/dist/types/components/xpl-dropdown/xpl-dropdown-option/xpl-dropdown-option.d.ts +7 -1
  543. package/dist/types/components/xpl-dropdown/xpl-dropdown.d.ts +2 -2
  544. package/dist/types/components/xpl-select/xpl-select.d.ts +16 -2
  545. package/dist/types/components/xpl-table/xpl-table.d.ts +2 -0
  546. package/dist/types/components.d.ts +88 -23
  547. package/dist/types/stencil-public-runtime.d.ts +97 -23
  548. package/loader/index.d.ts +9 -1
  549. package/loader/package.json +1 -0
  550. package/package.json +7 -6
  551. package/CHANGELOG.md +0 -106
  552. package/dist/apollo-core/p-25f84d39.entry.js +0 -1
  553. package/dist/apollo-core/p-2ce2fe5c.entry.js +0 -1
  554. package/dist/apollo-core/p-3ff1ff38.entry.js +0 -1
  555. package/dist/apollo-core/p-63dd9a65.entry.js +0 -1
  556. package/dist/apollo-core/p-6c3c1e3d.entry.js +0 -1
  557. package/dist/apollo-core/p-81a6ce4c.entry.js +0 -1
  558. package/dist/apollo-core/p-918b0731.entry.js +0 -1
  559. package/dist/apollo-core/p-a43e2d1f.entry.js +0 -1
  560. package/dist/apollo-core/p-a7cc4114.entry.js +0 -1
  561. package/dist/apollo-core/p-b6d1b135.entry.js +0 -1
  562. package/dist/apollo-core/p-bc0ebed2.entry.js +0 -1
  563. package/dist/apollo-core/p-c8af4ed6.entry.js +0 -1
  564. package/dist/apollo-core/p-d4aa2fa9.js +0 -1
  565. package/dist/apollo-core/p-d4e5d3aa.entry.js +0 -1
  566. package/dist/apollo-core/p-dad11011.entry.js +0 -1
  567. package/dist/apollo-core/p-db74c99c.entry.js +0 -1
  568. package/dist/apollo-core/p-ee16942f.entry.js +0 -1
  569. package/dist/collection/components/xpl-select/selectchoice.js +0 -1
  570. package/dist/custom-elements/index.d.ts +0 -219
  571. package/dist/types/components/xpl-select/selectchoice.d.ts +0 -4
@@ -1,5 +1,5 @@
1
1
  import { v4 as uuid } from 'uuid';
2
- import { Component, Host, h, Prop, State } from '@stencil/core';
2
+ import { Host, h, } from '@stencil/core';
3
3
  import throttle from 'lodash.throttle';
4
4
  function tagWidth(text) {
5
5
  const context = document.createElement('canvas').getContext('2d');
@@ -9,35 +9,22 @@ function tagWidth(text) {
9
9
  }
10
10
  export class XplSelect {
11
11
  constructor() {
12
- /**
13
- * An array of choices for the user to choose from.
14
- * Each choice should be of the form:
15
- * {
16
- * label: string;
17
- * href?: string;
18
- * value?: string;
19
- * isGroupHeading?: boolean;
20
- * }
21
- */
22
12
  this.choices = [];
23
- /**
24
- * Whether to allow a single choice or multiple choices.
25
- */
13
+ this.description = undefined;
14
+ this.disabled = undefined;
15
+ this.error = undefined;
16
+ this.label = undefined;
26
17
  this.mode = 'single';
27
- /**
28
- * Only used in multi-choice selects. If `true`,
29
- * badges representing selections that would overflow the
30
- * container are replaced with "+x more" (where x is the
31
- * number not shown). If `false`, the container's height will
32
- * adjust to show all badges representing selections.
33
- */
18
+ this.name = undefined;
19
+ this.placeholder = undefined;
34
20
  this.truncate = true;
21
+ this.selectedValues = undefined;
35
22
  this.active = false;
36
23
  this.id = uuid();
37
24
  this.keepFocus = false;
25
+ this.selected = undefined;
38
26
  this.value = '';
39
27
  this.displayValue = '';
40
- // infinity isn't real, it's just a mathematical construct, it can't hurt you
41
28
  this.visibleChoices = Infinity;
42
29
  }
43
30
  componentWillLoad() {
@@ -45,6 +32,27 @@ export class XplSelect {
45
32
  this.choices && this.choices.length > 0
46
33
  ? this.choices.map(() => false)
47
34
  : [];
35
+ if (this.selectedValues) {
36
+ const isSingleMode = this.mode === 'single';
37
+ if (isSingleMode) {
38
+ this.choices.forEach((choice) => {
39
+ const shouldBeSelected = choice.value.includes(this.selectedValues) ||
40
+ choice.label.includes(this.selectedValues);
41
+ if (shouldBeSelected)
42
+ choice.isSelected = true;
43
+ });
44
+ }
45
+ else {
46
+ this.choices.forEach(({ options }) => {
47
+ options.forEach((option) => {
48
+ const shouldBeSelected = this.selectedValues.includes(option.value || option.label);
49
+ if (shouldBeSelected)
50
+ option.isSelected = true;
51
+ });
52
+ });
53
+ }
54
+ this.update();
55
+ }
48
56
  window.addEventListener('click', (e) => {
49
57
  const el = e.target;
50
58
  const select = el.closest('.xpl-select');
@@ -107,6 +115,9 @@ export class XplSelect {
107
115
  .join('|');
108
116
  }
109
117
  }
118
+ handleValueStateChange(newValue) {
119
+ this.selectChange.emit(newValue);
120
+ }
110
121
  render() {
111
122
  let visibleChoices = 0;
112
123
  return (h(Host, { class: {
@@ -116,230 +127,279 @@ export class XplSelect {
116
127
  }, onKeyDown: (e) => {
117
128
  if (e.key === 'Escape')
118
129
  this.active = false;
119
- }, ref: (el) => (this.container = el) },
120
- this.label || this.description ? (h("label", { class: {
121
- 'xpl-label': true,
122
- 'xpl-label--disabled': this.disabled,
123
- }, htmlFor: this.id },
124
- this.label,
125
- this.description && (h("small", { class: {
126
- 'xpl-description': true,
127
- 'xpl-description--disabled': this.disabled,
128
- } }, this.description)))) : null,
129
- h("div", { class: {
130
- 'xpl-input': true,
131
- 'xpl-input--disabled': this.disabled,
132
- 'xpl-input--error': this.error !== undefined,
133
- } },
134
- h("div", { class: "xpl-input-wrapper" },
135
- h("div", { class: {
136
- 'xpl-select-value': true,
137
- 'xpl-select-value--active': this.mode === 'multi' &&
138
- this.value.length > 0,
139
- 'has-value': this.value.length > 0,
140
- } },
141
- this.mode === 'single'
142
- ? this.displayValue || this.placeholder
143
- : this.value.length > 0
144
- ? this.selected.map((v, i) => {
145
- if (!v)
146
- return null;
147
- if (visibleChoices >= this.visibleChoices)
148
- return null;
149
- visibleChoices++;
150
- return (h("xpl-tag", { onClose: () => {
151
- this.flattenChoices().forEach((v, j) => {
152
- if (i === j)
153
- v.isSelected =
154
- false;
155
- });
156
- const mapOptions = (option) => {
157
- option.options =
158
- option.groupName
159
- ? option.options.map(mapOptions)
160
- : undefined;
161
- return option;
162
- };
163
- this.choices =
164
- this.choices.map(mapOptions);
165
- this.update();
166
- this.maybeTruncateChoices();
167
- } }, this.getDisplayValue(i)));
168
- })
169
- : this.placeholder,
170
- this.visibleChoices < Infinity &&
171
- `+ ${this.selected.filter((a) => a).length -
172
- this.visibleChoices} more`),
173
- h("button", { disabled: this.disabled, id: this.id, onKeyDown: (e) => {
174
- if (e.key === 'Tab')
175
- this.keepFocus = true;
176
- }, onClick: () => {
177
- const { dropdown } = this;
178
- if (!this.disabled)
179
- dropdown.isOpen = !dropdown.isOpen;
180
- } })),
181
- !this.disabled && (h("xpl-dropdown", { options: this.choices, mode: this.mode, triggerId: this.id, update: () => {
182
- this.update();
183
- this.maybeTruncateChoices();
184
- } })),
185
- this.error !== undefined && this.error.length > 0 && (h("label", { class: "xpl-input-error", htmlFor: this.id },
186
- h("svg", { width: "10", height: "11", viewBox: "0 0 10 11", fill: "none", xmlns: "http://www.w3.org/2000/svg" },
187
- h("path", { d: "M9.84375 5.25C9.84375 2.59375 7.65625 0.40625 5 0.40625C2.32422 0.40625 0.15625 2.59375 0.15625 5.25C0.15625 7.92578 2.32422 10.0938 5 10.0938C7.65625 10.0938 9.84375 7.92578 9.84375 5.25ZM5 6.22656C5.48828 6.22656 5.89844 6.63672 5.89844 7.125C5.89844 7.63281 5.48828 8.02344 5 8.02344C4.49219 8.02344 4.10156 7.63281 4.10156 7.125C4.10156 6.63672 4.49219 6.22656 5 6.22656ZM4.14062 3.00391C4.12109 2.86719 4.23828 2.75 4.375 2.75H5.60547C5.74219 2.75 5.85938 2.86719 5.83984 3.00391L5.70312 5.66016C5.68359 5.79688 5.58594 5.875 5.46875 5.875H4.51172C4.39453 5.875 4.29688 5.79688 4.27734 5.66016L4.14062 3.00391Z" })),
188
- this.error))),
189
- h("input", { type: "hidden", value: this.value })));
130
+ }, ref: (el) => (this.container = el) }, this.label || this.description ? (h("label", { class: {
131
+ 'xpl-label': true,
132
+ 'xpl-label--disabled': this.disabled,
133
+ }, htmlFor: this.id }, this.label, this.description && (h("small", { class: {
134
+ 'xpl-description': true,
135
+ 'xpl-description--disabled': this.disabled,
136
+ } }, this.description)))) : null, h("div", { class: {
137
+ 'xpl-input': true,
138
+ 'xpl-input--disabled': this.disabled,
139
+ 'xpl-input--error': this.error !== undefined,
140
+ } }, h("div", { class: "xpl-input-wrapper" }, h("div", { class: {
141
+ 'xpl-select-value': true,
142
+ 'xpl-select-value--active': this.mode === 'multi' &&
143
+ this.value.length > 0,
144
+ 'has-value': this.value.length > 0,
145
+ } }, this.mode === 'single'
146
+ ? this.displayValue || this.placeholder
147
+ : this.value.length > 0
148
+ ? this.selected.map((v, i) => {
149
+ if (!v)
150
+ return null;
151
+ if (visibleChoices >= this.visibleChoices) {
152
+ return null;
153
+ }
154
+ visibleChoices++;
155
+ return (h("xpl-tag", { onClose: () => {
156
+ this.flattenChoices().forEach((v, j) => {
157
+ if (i === j)
158
+ v.isSelected =
159
+ false;
160
+ });
161
+ const mapOptions = (option) => {
162
+ option.options =
163
+ option.groupName
164
+ ? option.options.map(mapOptions)
165
+ : undefined;
166
+ return option;
167
+ };
168
+ this.choices =
169
+ this.choices.map(mapOptions);
170
+ this.update();
171
+ this.maybeTruncateChoices();
172
+ } }, this.getDisplayValue(i)));
173
+ })
174
+ : this.placeholder, this.visibleChoices < Infinity &&
175
+ `+ ${this.selected.filter((a) => a).length -
176
+ this.visibleChoices} more`), h("button", { disabled: this.disabled, id: this.id, onKeyDown: (e) => {
177
+ if (e.key === 'Tab')
178
+ this.keepFocus = true;
179
+ }, onClick: () => {
180
+ const { dropdown } = this;
181
+ if (!this.disabled)
182
+ dropdown.isOpen = !dropdown.isOpen;
183
+ }, type: "button" })), !this.disabled && (h("xpl-dropdown", { options: this.choices, mode: this.mode, triggerId: this.id, update: () => {
184
+ this.update();
185
+ this.maybeTruncateChoices();
186
+ } })), this.error !== undefined && this.error.length > 0 && (h("label", { class: "xpl-input-error", htmlFor: this.id }, h("svg", { width: "10", height: "11", viewBox: "0 0 10 11", fill: "none", xmlns: "http://www.w3.org/2000/svg" }, h("path", { d: "M9.84375 5.25C9.84375 2.59375 7.65625 0.40625 5 0.40625C2.32422 0.40625 0.15625 2.59375 0.15625 5.25C0.15625 7.92578 2.32422 10.0938 5 10.0938C7.65625 10.0938 9.84375 7.92578 9.84375 5.25ZM5 6.22656C5.48828 6.22656 5.89844 6.63672 5.89844 7.125C5.89844 7.63281 5.48828 8.02344 5 8.02344C4.49219 8.02344 4.10156 7.63281 4.10156 7.125C4.10156 6.63672 4.49219 6.22656 5 6.22656ZM4.14062 3.00391C4.12109 2.86719 4.23828 2.75 4.375 2.75H5.60547C5.74219 2.75 5.85938 2.86719 5.83984 3.00391L5.70312 5.66016C5.68359 5.79688 5.58594 5.875 5.46875 5.875H4.51172C4.39453 5.875 4.29688 5.79688 4.27734 5.66016L4.14062 3.00391Z" })), this.error))), h("input", { type: "hidden", name: this.name, value: this.value })));
190
187
  }
191
188
  static get is() { return "xpl-select"; }
192
- static get properties() { return {
193
- "choices": {
194
- "type": "unknown",
195
- "mutable": false,
196
- "complexType": {
197
- "original": "SelectChoice[]",
198
- "resolved": "SelectChoice[]",
199
- "references": {
200
- "SelectChoice": {
201
- "location": "import",
202
- "path": "./selectchoice"
189
+ static get properties() {
190
+ return {
191
+ "choices": {
192
+ "type": "unknown",
193
+ "mutable": false,
194
+ "complexType": {
195
+ "original": "DropdownItem[]",
196
+ "resolved": "Partial<DropdownOption & DropdownOptionGroup>[]",
197
+ "references": {
198
+ "DropdownItem": {
199
+ "location": "import",
200
+ "path": "../xpl-dropdown/dropdownoption"
201
+ }
203
202
  }
204
- }
205
- },
206
- "required": false,
207
- "optional": true,
208
- "docs": {
209
- "tags": [],
210
- "text": "An array of choices for the user to choose from.\nEach choice should be of the form:\n{\n label: string;\n href?: string;\n value?: string;\n isGroupHeading?: boolean;\n}"
211
- },
212
- "defaultValue": "[]"
213
- },
214
- "description": {
215
- "type": "string",
216
- "mutable": false,
217
- "complexType": {
218
- "original": "string",
219
- "resolved": "string",
220
- "references": {}
221
- },
222
- "required": false,
223
- "optional": true,
224
- "docs": {
225
- "tags": [],
226
- "text": "Optional text that appears below the input label."
227
- },
228
- "attribute": "description",
229
- "reflect": false
230
- },
231
- "disabled": {
232
- "type": "boolean",
233
- "mutable": false,
234
- "complexType": {
235
- "original": "boolean",
236
- "resolved": "boolean",
237
- "references": {}
203
+ },
204
+ "required": false,
205
+ "optional": true,
206
+ "docs": {
207
+ "tags": [],
208
+ "text": "An array of choices for the user to choose from.\nEach choice should be of the form:\n{\n label: string;\n href?: string;\n value?: string;\n isGroupHeading?: boolean;\n}"
209
+ },
210
+ "defaultValue": "[]"
238
211
  },
239
- "required": false,
240
- "optional": true,
241
- "docs": {
242
- "tags": [],
243
- "text": ""
212
+ "description": {
213
+ "type": "string",
214
+ "mutable": false,
215
+ "complexType": {
216
+ "original": "string",
217
+ "resolved": "string",
218
+ "references": {}
219
+ },
220
+ "required": false,
221
+ "optional": true,
222
+ "docs": {
223
+ "tags": [],
224
+ "text": "Optional text that appears below the input label."
225
+ },
226
+ "attribute": "description",
227
+ "reflect": false
244
228
  },
245
- "attribute": "disabled",
246
- "reflect": false
247
- },
248
- "error": {
249
- "type": "string",
250
- "mutable": false,
251
- "complexType": {
252
- "original": "string",
253
- "resolved": "string",
254
- "references": {}
229
+ "disabled": {
230
+ "type": "boolean",
231
+ "mutable": false,
232
+ "complexType": {
233
+ "original": "boolean",
234
+ "resolved": "boolean",
235
+ "references": {}
236
+ },
237
+ "required": false,
238
+ "optional": true,
239
+ "docs": {
240
+ "tags": [],
241
+ "text": ""
242
+ },
243
+ "attribute": "disabled",
244
+ "reflect": false
255
245
  },
256
- "required": false,
257
- "optional": true,
258
- "docs": {
259
- "tags": [],
260
- "text": "If an empty string (attribute present with no value),\nwill display visually as an error. If a string is\nincluded, will display visually as an error and include\nthe value as an error message."
246
+ "error": {
247
+ "type": "string",
248
+ "mutable": false,
249
+ "complexType": {
250
+ "original": "string",
251
+ "resolved": "string",
252
+ "references": {}
253
+ },
254
+ "required": false,
255
+ "optional": true,
256
+ "docs": {
257
+ "tags": [],
258
+ "text": "If an empty string (attribute present with no value),\nwill display visually as an error. If a string is\nincluded, will display visually as an error and include\nthe value as an error message."
259
+ },
260
+ "attribute": "error",
261
+ "reflect": false
261
262
  },
262
- "attribute": "error",
263
- "reflect": false
264
- },
265
- "label": {
266
- "type": "string",
267
- "mutable": false,
268
- "complexType": {
269
- "original": "string",
270
- "resolved": "string",
271
- "references": {}
263
+ "label": {
264
+ "type": "string",
265
+ "mutable": false,
266
+ "complexType": {
267
+ "original": "string",
268
+ "resolved": "string",
269
+ "references": {}
270
+ },
271
+ "required": false,
272
+ "optional": true,
273
+ "docs": {
274
+ "tags": [],
275
+ "text": "The label that appears above the select dropdown"
276
+ },
277
+ "attribute": "label",
278
+ "reflect": false
272
279
  },
273
- "required": false,
274
- "optional": true,
275
- "docs": {
276
- "tags": [],
277
- "text": ""
280
+ "mode": {
281
+ "type": "string",
282
+ "mutable": false,
283
+ "complexType": {
284
+ "original": "'single' | 'multi'",
285
+ "resolved": "\"multi\" | \"single\"",
286
+ "references": {}
287
+ },
288
+ "required": false,
289
+ "optional": true,
290
+ "docs": {
291
+ "tags": [],
292
+ "text": "Whether to allow a single choice or multiple choices."
293
+ },
294
+ "attribute": "mode",
295
+ "reflect": false,
296
+ "defaultValue": "'single'"
278
297
  },
279
- "attribute": "label",
280
- "reflect": false
281
- },
282
- "mode": {
283
- "type": "string",
284
- "mutable": false,
285
- "complexType": {
286
- "original": "'single' | 'multi'",
287
- "resolved": "\"multi\" | \"single\"",
288
- "references": {}
298
+ "name": {
299
+ "type": "string",
300
+ "mutable": false,
301
+ "complexType": {
302
+ "original": "string",
303
+ "resolved": "string",
304
+ "references": {}
305
+ },
306
+ "required": false,
307
+ "optional": true,
308
+ "docs": {
309
+ "tags": [],
310
+ "text": "The name of the hidden input field that contains the selected option's value(s)"
311
+ },
312
+ "attribute": "name",
313
+ "reflect": false
289
314
  },
290
- "required": false,
291
- "optional": true,
292
- "docs": {
293
- "tags": [],
294
- "text": "Whether to allow a single choice or multiple choices."
315
+ "placeholder": {
316
+ "type": "string",
317
+ "mutable": false,
318
+ "complexType": {
319
+ "original": "string",
320
+ "resolved": "string",
321
+ "references": {}
322
+ },
323
+ "required": false,
324
+ "optional": false,
325
+ "docs": {
326
+ "tags": [],
327
+ "text": ""
328
+ },
329
+ "attribute": "placeholder",
330
+ "reflect": false
295
331
  },
296
- "attribute": "mode",
297
- "reflect": false,
298
- "defaultValue": "'single'"
299
- },
300
- "placeholder": {
301
- "type": "string",
302
- "mutable": false,
303
- "complexType": {
304
- "original": "string",
305
- "resolved": "string",
306
- "references": {}
332
+ "truncate": {
333
+ "type": "boolean",
334
+ "mutable": false,
335
+ "complexType": {
336
+ "original": "boolean",
337
+ "resolved": "boolean",
338
+ "references": {}
339
+ },
340
+ "required": false,
341
+ "optional": true,
342
+ "docs": {
343
+ "tags": [],
344
+ "text": "Only used in multi-choice selects. If `true`,\nbadges representing selections that would overflow the\ncontainer are replaced with \"+x more\" (where x is the\nnumber not shown). If `false`, the container's height will\nadjust to show all badges representing selections."
345
+ },
346
+ "attribute": "truncate",
347
+ "reflect": false,
348
+ "defaultValue": "true"
307
349
  },
308
- "required": false,
309
- "optional": false,
310
- "docs": {
311
- "tags": [],
312
- "text": ""
313
- },
314
- "attribute": "placeholder",
315
- "reflect": false
316
- },
317
- "truncate": {
318
- "type": "boolean",
319
- "mutable": false,
320
- "complexType": {
321
- "original": "boolean",
322
- "resolved": "boolean",
323
- "references": {}
324
- },
325
- "required": false,
326
- "optional": true,
327
- "docs": {
328
- "tags": [],
329
- "text": "Only used in multi-choice selects. If `true`,\nbadges representing selections that would overflow the\ncontainer are replaced with \"+x more\" (where x is the\nnumber not shown). If `false`, the container's height will\nadjust to show all badges representing selections."
330
- },
331
- "attribute": "truncate",
332
- "reflect": false,
333
- "defaultValue": "true"
334
- }
335
- }; }
336
- static get states() { return {
337
- "active": {},
338
- "id": {},
339
- "keepFocus": {},
340
- "selected": {},
341
- "value": {},
342
- "displayValue": {},
343
- "visibleChoices": {}
344
- }; }
350
+ "selectedValues": {
351
+ "type": "string",
352
+ "mutable": false,
353
+ "complexType": {
354
+ "original": "string | string[]",
355
+ "resolved": "string | string[]",
356
+ "references": {}
357
+ },
358
+ "required": false,
359
+ "optional": true,
360
+ "docs": {
361
+ "tags": [],
362
+ "text": ""
363
+ },
364
+ "attribute": "selected-values",
365
+ "reflect": false
366
+ }
367
+ };
368
+ }
369
+ static get states() {
370
+ return {
371
+ "active": {},
372
+ "id": {},
373
+ "keepFocus": {},
374
+ "selected": {},
375
+ "value": {},
376
+ "displayValue": {},
377
+ "visibleChoices": {}
378
+ };
379
+ }
380
+ static get events() {
381
+ return [{
382
+ "method": "selectChange",
383
+ "name": "selectChange",
384
+ "bubbles": true,
385
+ "cancelable": true,
386
+ "composed": true,
387
+ "docs": {
388
+ "tags": [],
389
+ "text": "Emits the value of the selected option in the select menu on change"
390
+ },
391
+ "complexType": {
392
+ "original": "string",
393
+ "resolved": "string",
394
+ "references": {}
395
+ }
396
+ }];
397
+ }
398
+ static get watchers() {
399
+ return [{
400
+ "propName": "value",
401
+ "methodName": "handleValueStateChange"
402
+ }];
403
+ }
345
404
  }
405
+ //# sourceMappingURL=xpl-select.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"xpl-select.js","sourceRoot":"","sources":["../../../../src/components/components/xpl-select/xpl-select.tsx"],"names":[],"mappings":"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","sourcesContent":["import { v4 as uuid } from 'uuid';\nimport {\n Component,\n Host,\n h,\n Prop,\n State,\n Event,\n EventEmitter,\n Watch,\n} from '@stencil/core';\nimport throttle from 'lodash.throttle';\nimport type { DropdownItem } from '../xpl-dropdown/dropdownoption';\n\nfunction tagWidth(text: string): number {\n const context = document.createElement('canvas').getContext('2d');\n context.font =\n \"14px apple-system, system-ui, 'Segoe UI', Arial, Helvetica, Roboto, sans-serif\";\n return context.measureText(text).width + 44; // = text + l/r padding + margin-right\n}\n\n@Component({\n tag: 'xpl-select',\n})\nexport class XplSelect {\n /**\n * An array of choices for the user to choose from.\n * Each choice should be of the form:\n * {\n * label: string;\n * href?: string;\n * value?: string;\n * isGroupHeading?: boolean;\n * }\n */\n @Prop() choices?: DropdownItem[] = [];\n /**\n * Optional text that appears below the input label.\n */\n @Prop() description?: string;\n @Prop() disabled?: boolean;\n /**\n * If an empty string (attribute present with no value),\n * will display visually as an error. If a string is\n * included, will display visually as an error and include\n * the value as an error message.\n */\n @Prop() error?: string;\n\n /**\n * The label that appears above the select dropdown\n */\n @Prop() label?: string;\n /**\n * Whether to allow a single choice or multiple choices.\n */\n @Prop() mode?: 'single' | 'multi' = 'single';\n\n /**\n * The name of the hidden input field that contains the selected option's value(s)\n */\n @Prop() name?: string;\n\n @Prop() placeholder: string;\n /**\n * Only used in multi-choice selects. If `true`,\n * badges representing selections that would overflow the\n * container are replaced with \"+x more\" (where x is the\n * number not shown). If `false`, the container's height will\n * adjust to show all badges representing selections.\n */\n @Prop() truncate?: boolean = true;\n\n @Prop() selectedValues?: string | string[];\n\n /**\n * Emits the value of the selected option in the select menu on change\n */\n @Event() selectChange: EventEmitter<string>;\n\n @State() active: boolean = false;\n @State() id: string = uuid();\n @State() keepFocus: boolean = false;\n @State() selected: boolean[];\n @State() value: string = '';\n @State() displayValue: string = '';\n // infinity isn't real, it's just a mathematical construct, it can't hurt you\n @State() visibleChoices: number = Infinity;\n\n private container!: HTMLElement;\n\n private dropdown: HTMLXplDropdownElement;\n\n componentWillLoad() {\n this.selected =\n this.choices && this.choices.length > 0\n ? this.choices.map(() => false)\n : [];\n\n if (this.selectedValues) {\n const isSingleMode = this.mode === 'single';\n\n if (isSingleMode) {\n this.choices.forEach((choice) => {\n const shouldBeSelected =\n choice.value.includes(this.selectedValues as string) ||\n choice.label.includes(this.selectedValues as string);\n\n if (shouldBeSelected) choice.isSelected = true;\n });\n } else {\n this.choices.forEach(({ options }) => {\n options.forEach((option) => {\n const shouldBeSelected = this.selectedValues.includes(\n option.value || option.label\n );\n\n if (shouldBeSelected) option.isSelected = true;\n });\n });\n }\n\n this.update();\n }\n\n window.addEventListener('click', (e: MouseEvent) => {\n const el = e.target as HTMLElement;\n const select = el.closest('.xpl-select');\n if (select === null || select !== this.container) {\n this.active = false;\n }\n });\n\n window.addEventListener(\n 'resize',\n throttle(() => {\n this.maybeTruncateChoices();\n }, 250)\n );\n }\n componentDidLoad() {\n this.dropdown = this.container.querySelector('xpl-dropdown');\n }\n\n private maybeTruncateChoices(): void {\n if (this.mode === 'single' || !this.truncate) return;\n\n const containerWidth = this.container.getBoundingClientRect().width;\n\n let visibleChoices = 0;\n let visibleChoicesWidth = 0;\n\n const actualNumSelected = this.selected.filter((a) => a).length;\n for (let i = 0; i < actualNumSelected; i++) {\n visibleChoicesWidth += tagWidth(this.getDisplayValue(i));\n if (visibleChoicesWidth > containerWidth - 140) break;\n visibleChoices++;\n }\n\n if (visibleChoices >= actualNumSelected) visibleChoices = Infinity;\n if (visibleChoices < 1) visibleChoices = 1;\n\n this.visibleChoices = visibleChoices;\n }\n\n private flattenChoices(): DropdownItem[] {\n return this.choices.reduce(\n (acc, curr) => [\n ...acc,\n ...(curr.groupName ? curr.options : [curr]),\n ],\n []\n );\n }\n private getDisplayValue(i: number): string {\n return this.flattenChoices()[i].label || this.flattenChoices()[i].value;\n }\n\n private getActualValue(i: number): string {\n return this.flattenChoices()[i].value || this.flattenChoices()[i].label;\n }\n\n private update() {\n this.selected = this.flattenChoices().map(\n ({ isSelected }) => isSelected\n );\n\n if (this.mode === 'single') {\n const selected = this.selected.findIndex((v) => v);\n this.value = selected >= 0 ? this.getActualValue(selected) : '';\n this.displayValue =\n selected >= 0 ? this.getDisplayValue(selected) : '';\n } else if (this.mode === 'multi') {\n this.value = this.selected\n .map((v, i) => {\n return v ? this.getActualValue(i) : '';\n })\n .filter((v) => v.length > 0)\n .join('|');\n }\n }\n\n @Watch('value')\n handleValueStateChange(newValue) {\n this.selectChange.emit(newValue);\n }\n\n render() {\n let visibleChoices = 0;\n return (\n <Host\n class={{\n 'xpl-select': true,\n 'xpl-select--disabled': this.disabled,\n 'xpl-select--no-truncate': !this.truncate,\n }}\n onKeyDown={(e: KeyboardEvent) => {\n if (e.key === 'Escape') this.active = false;\n }}\n ref={(el) => (this.container = el as HTMLElement)}\n >\n {this.label || this.description ? (\n <label\n class={{\n 'xpl-label': true,\n 'xpl-label--disabled': this.disabled,\n }}\n htmlFor={this.id}\n >\n {this.label}\n {this.description && (\n <small\n class={{\n 'xpl-description': true,\n 'xpl-description--disabled': this.disabled,\n }}\n >\n {this.description}\n </small>\n )}\n </label>\n ) : null}\n <div\n class={{\n 'xpl-input': true,\n 'xpl-input--disabled': this.disabled,\n 'xpl-input--error': this.error !== undefined,\n }}\n >\n <div class=\"xpl-input-wrapper\">\n <div\n class={{\n 'xpl-select-value': true,\n 'xpl-select-value--active':\n this.mode === 'multi' &&\n this.value.length > 0,\n 'has-value': this.value.length > 0,\n }}\n >\n {this.mode === 'single'\n ? this.displayValue || this.placeholder\n : this.value.length > 0\n ? this.selected.map((v, i) => {\n if (!v) return null;\n if (\n visibleChoices >= this.visibleChoices\n ) {\n return null;\n }\n visibleChoices++;\n return (\n <xpl-tag\n onClose={() => {\n this.flattenChoices().forEach(\n (v, j) => {\n if (i === j)\n v.isSelected =\n false;\n }\n );\n const mapOptions = (\n option: DropdownItem\n ): DropdownItem => {\n option.options =\n option.groupName\n ? option.options.map(\n mapOptions\n )\n : undefined;\n return option;\n };\n this.choices =\n this.choices.map(\n mapOptions\n );\n\n this.update();\n this.maybeTruncateChoices();\n }}\n >\n {this.getDisplayValue(i)}\n </xpl-tag>\n );\n })\n : this.placeholder}\n {this.visibleChoices < Infinity &&\n `+ ${\n this.selected.filter((a) => a).length -\n this.visibleChoices\n } more`}\n </div>\n <button\n disabled={this.disabled}\n id={this.id}\n onKeyDown={(e: KeyboardEvent) => {\n if (e.key === 'Tab') this.keepFocus = true;\n }}\n onClick={() => {\n const { dropdown } = this;\n if (!this.disabled)\n dropdown.isOpen = !dropdown.isOpen;\n }}\n type=\"button\"\n ></button>\n </div>\n {!this.disabled && (\n <xpl-dropdown\n options={this.choices}\n mode={this.mode}\n triggerId={this.id}\n update={() => {\n this.update();\n this.maybeTruncateChoices();\n }}\n ></xpl-dropdown>\n )}\n {this.error !== undefined && this.error.length > 0 && (\n <label class=\"xpl-input-error\" htmlFor={this.id}>\n <svg\n width=\"10\"\n height=\"11\"\n viewBox=\"0 0 10 11\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path d=\"M9.84375 5.25C9.84375 2.59375 7.65625 0.40625 5 0.40625C2.32422 0.40625 0.15625 2.59375 0.15625 5.25C0.15625 7.92578 2.32422 10.0938 5 10.0938C7.65625 10.0938 9.84375 7.92578 9.84375 5.25ZM5 6.22656C5.48828 6.22656 5.89844 6.63672 5.89844 7.125C5.89844 7.63281 5.48828 8.02344 5 8.02344C4.49219 8.02344 4.10156 7.63281 4.10156 7.125C4.10156 6.63672 4.49219 6.22656 5 6.22656ZM4.14062 3.00391C4.12109 2.86719 4.23828 2.75 4.375 2.75H5.60547C5.74219 2.75 5.85938 2.86719 5.83984 3.00391L5.70312 5.66016C5.68359 5.79688 5.58594 5.875 5.46875 5.875H4.51172C4.39453 5.875 4.29688 5.79688 4.27734 5.66016L4.14062 3.00391Z\" />\n </svg>\n {this.error}\n </label>\n )}\n </div>\n <input type=\"hidden\" name={this.name} value={this.value} />\n </Host>\n );\n }\n}\n"]}