@esri/solutions-components 0.2.6 → 0.2.7

Sign up to get free protection for your applications and to get access to all the features.
Files changed (314) hide show
  1. package/dist/cjs/deduct-calculator.cjs.entry.js +1 -1
  2. package/dist/cjs/pci-calculator.cjs.entry.js +1 -1
  3. package/dist/cjs/{pciUtils-6a806ba4.js → pciUtils-423cfc68.js} +25 -7
  4. package/dist/collection/demos/deduct-calculator.html +2 -5
  5. package/dist/collection/demos/new-public-notification.html +6 -4
  6. package/dist/collection/utils/pciUtils.js +25 -7
  7. package/dist/collection/utils/pciUtils.ts +30 -7
  8. package/dist/components/ExpandToggle.js +110 -0
  9. package/dist/components/Heading.js +22 -0
  10. package/dist/components/_commonjsHelpers.js +22 -0
  11. package/dist/components/action-bar.js +276 -0
  12. package/dist/components/action-group.js +149 -0
  13. package/dist/components/action-menu.js +356 -0
  14. package/dist/components/action.js +214 -0
  15. package/dist/components/add-record-modal.d.ts +11 -0
  16. package/dist/components/add-record-modal.js +171 -0
  17. package/dist/components/array.js +15 -0
  18. package/dist/components/block.js +272 -0
  19. package/dist/components/buffer-tools.d.ts +11 -0
  20. package/dist/components/buffer-tools.js +11 -0
  21. package/dist/components/buffer-tools2.js +262 -0
  22. package/dist/components/button.js +263 -0
  23. package/dist/components/calcite-accordion-item.js +244 -0
  24. package/dist/components/calcite-accordion.js +180 -0
  25. package/dist/components/calcite-action-bar.js +11 -0
  26. package/dist/components/calcite-action-group.js +11 -0
  27. package/dist/components/calcite-action-menu.js +11 -0
  28. package/dist/components/calcite-action-pad.js +197 -0
  29. package/dist/components/calcite-action.js +11 -0
  30. package/dist/components/calcite-alert.js +297 -0
  31. package/dist/components/calcite-avatar.js +182 -0
  32. package/dist/components/calcite-block-section.js +155 -0
  33. package/dist/components/calcite-block.js +11 -0
  34. package/dist/components/calcite-button.js +11 -0
  35. package/dist/components/calcite-card.js +187 -0
  36. package/dist/components/calcite-checkbox.js +11 -0
  37. package/dist/components/calcite-chip.js +11 -0
  38. package/dist/components/calcite-color-picker-hex-input.js +11 -0
  39. package/dist/components/calcite-color-picker-swatch.js +11 -0
  40. package/dist/components/calcite-color-picker.js +1036 -0
  41. package/dist/components/calcite-combobox-item-group.js +75 -0
  42. package/dist/components/calcite-combobox-item.js +11 -0
  43. package/dist/components/calcite-combobox.js +11 -0
  44. package/dist/components/calcite-date-picker-day.js +11 -0
  45. package/dist/components/calcite-date-picker-month-header.js +11 -0
  46. package/dist/components/calcite-date-picker-month.js +11 -0
  47. package/dist/components/calcite-date-picker.js +11 -0
  48. package/dist/components/calcite-dropdown-group.js +11 -0
  49. package/dist/components/calcite-dropdown-item.js +11 -0
  50. package/dist/components/calcite-dropdown.js +11 -0
  51. package/dist/components/calcite-fab.js +144 -0
  52. package/dist/components/calcite-filter.js +195 -0
  53. package/dist/components/calcite-flow-item.js +243 -0
  54. package/dist/components/calcite-flow.js +147 -0
  55. package/dist/components/calcite-graph.js +11 -0
  56. package/dist/components/calcite-handle.js +11 -0
  57. package/dist/components/calcite-icon.js +11 -0
  58. package/dist/components/calcite-inline-editable.js +294 -0
  59. package/dist/components/calcite-input-date-picker.js +713 -0
  60. package/dist/components/calcite-input-message.js +11 -0
  61. package/dist/components/calcite-input-number.js +637 -0
  62. package/dist/components/calcite-input-text.js +400 -0
  63. package/dist/components/calcite-input-time-picker.js +434 -0
  64. package/dist/components/calcite-input.js +11 -0
  65. package/dist/components/calcite-label.js +11 -0
  66. package/dist/components/calcite-link.js +11 -0
  67. package/dist/components/calcite-list-item-group.js +65 -0
  68. package/dist/components/calcite-list-item.js +11 -0
  69. package/dist/components/calcite-list.js +11 -0
  70. package/dist/components/calcite-loader.js +11 -0
  71. package/dist/components/calcite-modal.js +11 -0
  72. package/dist/components/calcite-notice.js +11 -0
  73. package/dist/components/calcite-option-group.js +64 -0
  74. package/dist/components/calcite-option.js +11 -0
  75. package/dist/components/calcite-pagination.js +258 -0
  76. package/dist/components/calcite-panel.js +11 -0
  77. package/dist/components/calcite-pick-list-group.js +74 -0
  78. package/dist/components/calcite-pick-list-item.js +11 -0
  79. package/dist/components/calcite-pick-list.js +11 -0
  80. package/dist/components/calcite-popover-manager.js +94 -0
  81. package/dist/components/calcite-popover.js +11 -0
  82. package/dist/components/calcite-progress.js +11 -0
  83. package/dist/components/calcite-radio-button-group.js +132 -0
  84. package/dist/components/calcite-radio-button.js +310 -0
  85. package/dist/components/calcite-radio-group-item.js +11 -0
  86. package/dist/components/calcite-radio-group.js +11 -0
  87. package/dist/components/calcite-rating.js +201 -0
  88. package/dist/components/calcite-scrim.js +11 -0
  89. package/dist/components/calcite-select.js +11 -0
  90. package/dist/components/calcite-shell-center-row.js +100 -0
  91. package/dist/components/calcite-shell-panel.js +11 -0
  92. package/dist/components/calcite-shell.js +11 -0
  93. package/dist/components/calcite-slider.js +11 -0
  94. package/dist/components/calcite-sortable-list.js +202 -0
  95. package/dist/components/calcite-split-button.js +11 -0
  96. package/dist/components/calcite-stepper-item.js +271 -0
  97. package/dist/components/calcite-stepper.js +256 -0
  98. package/dist/components/calcite-switch.js +11 -0
  99. package/dist/components/calcite-tab-nav.js +11 -0
  100. package/dist/components/calcite-tab-title.js +11 -0
  101. package/dist/components/calcite-tab.js +11 -0
  102. package/dist/components/calcite-tabs.js +11 -0
  103. package/dist/components/calcite-tile-select-group.js +65 -0
  104. package/dist/components/calcite-tile-select.js +266 -0
  105. package/dist/components/calcite-tile.js +11 -0
  106. package/dist/components/calcite-time-picker.js +11 -0
  107. package/dist/components/calcite-tip-group.js +41 -0
  108. package/dist/components/calcite-tip-manager.js +223 -0
  109. package/dist/components/calcite-tip.js +162 -0
  110. package/dist/components/calcite-tooltip-manager.js +57 -0
  111. package/dist/components/calcite-tooltip.js +11 -0
  112. package/dist/components/calcite-tree-item.js +11 -0
  113. package/dist/components/calcite-tree.js +11 -0
  114. package/dist/components/calcite-value-list-item.js +11 -0
  115. package/dist/components/calcite-value-list.js +11 -0
  116. package/dist/components/card-manager.d.ts +11 -0
  117. package/dist/components/card-manager.js +143 -0
  118. package/dist/components/check-list.d.ts +11 -0
  119. package/dist/components/check-list.js +11 -0
  120. package/dist/components/check-list2.js +131 -0
  121. package/dist/components/checkbox.js +165 -0
  122. package/dist/components/chip.js +170 -0
  123. package/dist/components/color-picker-hex-input.js +363 -0
  124. package/dist/components/color-picker-swatch.js +2034 -0
  125. package/dist/components/combobox-item.js +182 -0
  126. package/dist/components/combobox.js +912 -0
  127. package/dist/components/comment-card.d.ts +11 -0
  128. package/dist/components/comment-card.js +90 -0
  129. package/dist/components/conditionalSlot.js +50 -0
  130. package/dist/components/config-buffer-tools.d.ts +11 -0
  131. package/dist/components/config-buffer-tools.js +187 -0
  132. package/dist/components/config-draw-tools.d.ts +11 -0
  133. package/dist/components/config-draw-tools.js +121 -0
  134. package/dist/components/config-layer-picker.d.ts +11 -0
  135. package/dist/components/config-layer-picker.js +163 -0
  136. package/dist/components/config-pdf-download.d.ts +11 -0
  137. package/dist/components/config-pdf-download.js +154 -0
  138. package/dist/components/crowdsource-manager.d.ts +11 -0
  139. package/dist/components/crowdsource-manager.js +90 -0
  140. package/dist/components/crowdsource-reporter.d.ts +11 -0
  141. package/dist/components/crowdsource-reporter.js +90 -0
  142. package/dist/components/csvUtils.js +74 -0
  143. package/dist/components/date-picker-day.js +111 -0
  144. package/dist/components/date-picker-month-header.js +224 -0
  145. package/dist/components/date-picker-month.js +344 -0
  146. package/dist/components/date-picker.js +575 -0
  147. package/dist/components/date.js +180 -0
  148. package/dist/components/debounce.js +487 -0
  149. package/dist/components/deduct-calculator.d.ts +11 -0
  150. package/dist/components/deduct-calculator.js +11 -0
  151. package/dist/components/deduct-calculator2.js +1002 -0
  152. package/dist/components/dom.js +231 -0
  153. package/dist/components/dropdown-group.js +96 -0
  154. package/dist/components/dropdown-item.js +232 -0
  155. package/dist/components/dropdown.js +505 -0
  156. package/dist/components/edit-record-modal.d.ts +11 -0
  157. package/dist/components/edit-record-modal.js +11 -0
  158. package/dist/components/edit-record-modal2.js +161 -0
  159. package/dist/components/filter.js +763 -0
  160. package/dist/components/floating-ui.js +1768 -0
  161. package/dist/components/form.js +228 -0
  162. package/dist/components/graph.js +254 -0
  163. package/dist/components/guid.js +24 -0
  164. package/dist/components/handle.js +119 -0
  165. package/dist/components/icon.js +202 -0
  166. package/dist/components/index.d.ts +61 -0
  167. package/dist/components/index.js +196 -0
  168. package/dist/components/index2.js +199 -0
  169. package/dist/components/info-card.d.ts +11 -0
  170. package/dist/components/info-card.js +11 -0
  171. package/dist/components/info-card2.js +97 -0
  172. package/dist/components/input-message.js +101 -0
  173. package/dist/components/input.js +740 -0
  174. package/dist/components/interactive.js +51 -0
  175. package/dist/components/interfaces.js +19 -0
  176. package/dist/components/interfaces2.js +21 -0
  177. package/dist/components/interfaces3.js +80 -0
  178. package/dist/components/json-editor.d.ts +11 -0
  179. package/dist/components/json-editor.js +11 -0
  180. package/dist/components/json-editor2.js +441 -0
  181. package/dist/components/key.js +16 -0
  182. package/dist/components/label.js +106 -0
  183. package/dist/components/label2.js +131 -0
  184. package/dist/components/labelFormats.js +210 -0
  185. package/dist/components/layer-table.d.ts +11 -0
  186. package/dist/components/layer-table.js +453 -0
  187. package/dist/components/link.js +123 -0
  188. package/dist/components/list-item.d.ts +11 -0
  189. package/dist/components/list-item.js +90 -0
  190. package/dist/components/list-item2.js +149 -0
  191. package/dist/components/list.js +83 -0
  192. package/dist/components/loadModules.js +28 -0
  193. package/dist/components/loader.js +116 -0
  194. package/dist/components/locale.js +412 -0
  195. package/dist/components/locale2.js +413 -0
  196. package/dist/components/map-card.d.ts +11 -0
  197. package/dist/components/map-card.js +354 -0
  198. package/dist/components/map-draw-tools.d.ts +11 -0
  199. package/dist/components/map-draw-tools.js +11 -0
  200. package/dist/components/map-draw-tools2.js +228 -0
  201. package/dist/components/map-layer-picker.d.ts +11 -0
  202. package/dist/components/map-layer-picker.js +11 -0
  203. package/dist/components/map-layer-picker2.js +188 -0
  204. package/dist/components/map-search.d.ts +11 -0
  205. package/dist/components/map-search.js +155 -0
  206. package/dist/components/map-select-tools.d.ts +11 -0
  207. package/dist/components/map-select-tools.js +11 -0
  208. package/dist/components/map-select-tools2.js +588 -0
  209. package/dist/components/mapViewUtils.js +129 -0
  210. package/dist/components/math.js +24 -0
  211. package/dist/components/media-card.d.ts +11 -0
  212. package/dist/components/media-card.js +11 -0
  213. package/dist/components/media-card2.js +177 -0
  214. package/dist/components/modal.js +495 -0
  215. package/dist/components/nonChromiumPlatformUtils.js +503 -0
  216. package/dist/components/notice.js +192 -0
  217. package/dist/components/observers.js +56 -0
  218. package/dist/components/openCloseComponent.js +56 -0
  219. package/dist/components/option.js +109 -0
  220. package/dist/components/panel.js +459 -0
  221. package/dist/components/pci-calculator.d.ts +11 -0
  222. package/dist/components/pci-calculator.js +193 -0
  223. package/dist/components/pdf-download.d.ts +11 -0
  224. package/dist/components/pdf-download.js +11 -0
  225. package/dist/components/pdf-download2.js +189 -0
  226. package/dist/components/pick-list-item.js +255 -0
  227. package/dist/components/pick-list.js +170 -0
  228. package/dist/components/popover.js +500 -0
  229. package/dist/components/progress.js +60 -0
  230. package/dist/components/public-notification.d.ts +11 -0
  231. package/dist/components/public-notification.js +825 -0
  232. package/dist/components/publicNotificationStore.js +38 -0
  233. package/dist/components/queryUtils.js +187 -0
  234. package/dist/components/radio-group-item.js +101 -0
  235. package/dist/components/radio-group.js +235 -0
  236. package/dist/components/refine-selection-tools.d.ts +11 -0
  237. package/dist/components/refine-selection-tools.js +11 -0
  238. package/dist/components/refine-selection-tools2.js +492 -0
  239. package/dist/components/refine-selection.d.ts +11 -0
  240. package/dist/components/refine-selection.js +11 -0
  241. package/dist/components/refine-selection2.js +376 -0
  242. package/dist/components/resources.js +24 -0
  243. package/dist/components/resources2.js +21 -0
  244. package/dist/components/resources3.js +38 -0
  245. package/dist/components/scrim.js +83 -0
  246. package/dist/components/select.js +259 -0
  247. package/dist/components/shared-list-render.js +319 -0
  248. package/dist/components/shell-panel.js +281 -0
  249. package/dist/components/shell.js +121 -0
  250. package/dist/components/slider.js +896 -0
  251. package/dist/components/solution-configuration.d.ts +11 -0
  252. package/dist/components/solution-configuration.js +2233 -0
  253. package/dist/components/solution-contents.d.ts +11 -0
  254. package/dist/components/solution-contents.js +11 -0
  255. package/dist/components/solution-contents2.js +128 -0
  256. package/dist/components/solution-item-details.d.ts +11 -0
  257. package/dist/components/solution-item-details.js +11 -0
  258. package/dist/components/solution-item-details2.js +234 -0
  259. package/dist/components/solution-item-icon.d.ts +11 -0
  260. package/dist/components/solution-item-icon.js +11 -0
  261. package/dist/components/solution-item-icon2.js +342 -0
  262. package/dist/components/solution-item-sharing.d.ts +11 -0
  263. package/dist/components/solution-item-sharing.js +11 -0
  264. package/dist/components/solution-item-sharing2.js +167 -0
  265. package/dist/components/solution-item.d.ts +11 -0
  266. package/dist/components/solution-item.js +11 -0
  267. package/dist/components/solution-item2.js +315 -0
  268. package/dist/components/solution-organization-variables.d.ts +11 -0
  269. package/dist/components/solution-organization-variables.js +11 -0
  270. package/dist/components/solution-organization-variables2.js +132 -0
  271. package/dist/components/solution-resource-item.d.ts +11 -0
  272. package/dist/components/solution-resource-item.js +11 -0
  273. package/dist/components/solution-resource-item2.js +356 -0
  274. package/dist/components/solution-spatial-ref.d.ts +11 -0
  275. package/dist/components/solution-spatial-ref.js +11 -0
  276. package/dist/components/solution-spatial-ref2.js +21446 -0
  277. package/dist/components/solution-store.js +4092 -0
  278. package/dist/components/solution-template-data.d.ts +11 -0
  279. package/dist/components/solution-template-data.js +11 -0
  280. package/dist/components/solution-template-data2.js +233 -0
  281. package/dist/components/solution-variables.d.ts +11 -0
  282. package/dist/components/solution-variables.js +11 -0
  283. package/dist/components/solution-variables2.js +150 -0
  284. package/dist/components/sortable.esm.js +3026 -0
  285. package/dist/components/split-button.js +165 -0
  286. package/dist/components/store-manager.d.ts +11 -0
  287. package/dist/components/store-manager.js +83 -0
  288. package/dist/components/switch.js +139 -0
  289. package/dist/components/tab-nav.js +241 -0
  290. package/dist/components/tab-title.js +276 -0
  291. package/dist/components/tab.js +154 -0
  292. package/dist/components/tabs.js +188 -0
  293. package/dist/components/tile.js +129 -0
  294. package/dist/components/time-picker.js +943 -0
  295. package/dist/components/tooltip.js +399 -0
  296. package/dist/components/tree-item.js +294 -0
  297. package/dist/components/tree.js +327 -0
  298. package/dist/components/utils.js +119 -0
  299. package/dist/components/utils2.js +51 -0
  300. package/dist/components/value-list-item.js +204 -0
  301. package/dist/components/value-list.js +333 -0
  302. package/dist/esm/deduct-calculator.entry.js +1 -1
  303. package/dist/esm/pci-calculator.entry.js +1 -1
  304. package/dist/esm/{pciUtils-e3007a1c.js → pciUtils-ecda46e5.js} +25 -7
  305. package/dist/solutions-components/demos/deduct-calculator.html +2 -5
  306. package/dist/solutions-components/demos/new-public-notification.html +6 -4
  307. package/dist/solutions-components/{p-ff80ffbb.entry.js → p-0512635b.entry.js} +1 -1
  308. package/dist/solutions-components/{p-5ec407c2.entry.js → p-0c088725.entry.js} +1 -1
  309. package/dist/solutions-components/p-cc815aca.js +21 -0
  310. package/dist/solutions-components/solutions-components.esm.js +1 -1
  311. package/dist/solutions-components/utils/pciUtils.ts +30 -7
  312. package/dist/types/utils/pciUtils.d.ts +2 -1
  313. package/package.json +4 -3
  314. package/dist/solutions-components/p-647bbd18.js +0 -21
@@ -0,0 +1,259 @@
1
+ /*!
2
+ * Copyright 2022 Esri
3
+ * Licensed under the Apache License, Version 2.0
4
+ * http://www.apache.org/licenses/LICENSE-2.0
5
+ */
6
+ import { proxyCustomElement, HTMLElement, createEvent, h, Fragment } from '@stencil/core/internal/client';
7
+ import { f as focusElement } from './dom.js';
8
+ import { c as connectLabel, d as disconnectLabel } from './label2.js';
9
+ import { c as connectForm, d as disconnectForm, a as afterConnectDefaultValueSet, H as HiddenFormInputSlot } from './form.js';
10
+ import { c as createObserver } from './observers.js';
11
+ import { u as updateHostInteraction } from './interactive.js';
12
+ import { d as defineCustomElement$1 } from './icon.js';
13
+
14
+ /*!
15
+ * All material copyright ESRI, All Rights Reserved, unless otherwise specified.
16
+ * See https://github.com/Esri/calcite-components/blob/master/LICENSE.md for details.
17
+ * v1.0.0-beta.97
18
+ */
19
+ const CSS = {
20
+ icon: "icon",
21
+ iconContainer: "icon-container",
22
+ select: "select"
23
+ };
24
+
25
+ const selectCss = "@keyframes in{0%{opacity:0}100%{opacity:1}}@keyframes in-down{0%{opacity:0;transform:translate3D(0, -5px, 0)}100%{opacity:1;transform:translate3D(0, 0, 0)}}@keyframes in-up{0%{opacity:0;transform:translate3D(0, 5px, 0)}100%{opacity:1;transform:translate3D(0, 0, 0)}}@keyframes in-scale{0%{opacity:0;transform:scale3D(0.95, 0.95, 1)}100%{opacity:1;transform:scale3D(1, 1, 1)}}:root{--calcite-animation-timing:calc(150ms * var(--calcite-internal-duration-factor));--calcite-internal-duration-factor:var(--calcite-duration-factor, 1);--calcite-internal-animation-timing-fast:calc(100ms * var(--calcite-internal-duration-factor));--calcite-internal-animation-timing-medium:calc(200ms * var(--calcite-internal-duration-factor));--calcite-internal-animation-timing-slow:calc(300ms * var(--calcite-internal-duration-factor))}.calcite-animate{opacity:0;animation-fill-mode:both;animation-duration:var(--calcite-animation-timing)}.calcite-animate__in{animation-name:in}.calcite-animate__in-down{animation-name:in-down}.calcite-animate__in-up{animation-name:in-up}.calcite-animate__in-scale{animation-name:in-scale}@media (prefers-reduced-motion: reduce){:root{--calcite-internal-duration-factor:0.01}}:host{--calcite-icon-size:1rem;--calcite-spacing-eighth:0.125rem;--calcite-spacing-quarter:0.25rem;--calcite-spacing-half:0.5rem;--calcite-spacing-three-quarters:0.75rem;--calcite-spacing:1rem;--calcite-spacing-plus-quarter:1.25rem;--calcite-spacing-plus-half:1.5rem;--calcite-spacing-double:2rem;--calcite-menu-min-width:10rem;--calcite-header-min-height:3rem;--calcite-footer-min-height:3rem}:root{--calcite-floating-ui-transition:var(--calcite-animation-timing)}:host([hidden]){display:none}:host([disabled]){pointer-events:none;cursor:default;-webkit-user-select:none;-moz-user-select:none;user-select:none;opacity:var(--calcite-ui-opacity-disabled)}:host{position:relative;display:flex;align-items:stretch;inline-size:var(--select-width)}:host([disabled]) ::slotted([calcite-hydrated][disabled]),:host([disabled]) [calcite-hydrated][disabled]{opacity:1}:host([scale=s]){block-size:1.5rem;--calcite-select-font-size:var(--calcite-font-size--2);--calcite-select-spacing-inline:0.5rem 2rem}:host([scale=s]) .icon-container{padding-inline:0.5rem}:host([scale=m]){block-size:2rem;--calcite-select-font-size:var(--calcite-font-size--1);--calcite-select-spacing-inline:0.75rem 2.5rem}:host([scale=m]) .icon-container{padding-inline:0.75rem}:host([scale=l]){block-size:44px;--calcite-select-font-size:var(--calcite-font-size-0);--calcite-select-spacing-inline:1rem 3rem}:host([scale=l]) .icon-container{padding-inline:1rem}:host([width=auto]){inline-size:auto}:host([width=half]){inline-size:50%}:host([width=full]){inline-size:100%}.select{margin:0px;box-sizing:border-box;inline-size:100%;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-radius:0px;border-width:1px;border-style:solid;border-color:var(--calcite-ui-border-input);background-color:var(--calcite-ui-foreground-1);font-family:inherit;color:var(--calcite-ui-text-2);outline-color:transparent;font-size:var(--calcite-select-font-size);padding-inline:var(--calcite-select-spacing-inline);border-inline-end-width:0px}.select:focus{outline:2px solid var(--calcite-ui-brand);outline-offset:-2px}.select:hover{background-color:var(--calcite-ui-foreground-2)}select:disabled{border-color:var(--calcite-ui-border-input);--tw-bg-opacity:1}.icon-container{pointer-events:none;position:absolute;inset-block:0px;display:flex;align-items:center;border-width:0px;border-style:solid;border-color:var(--calcite-ui-border-input);background-color:transparent;color:var(--calcite-ui-text-2);inset-inline-end:0px;border-inline-width:0px 1px}.select:focus~.icon-container{border-color:transparent}::slotted(input[slot=hidden-form-input]){margin:0 !important;opacity:0 !important;outline:none !important;padding:0 !important;position:absolute !important;inset:0 !important;transform:none !important;-webkit-appearance:none !important;z-index:-1 !important}";
26
+
27
+ function isOption(optionOrGroup) {
28
+ return optionOrGroup.tagName === "CALCITE-OPTION";
29
+ }
30
+ function isOptionGroup(optionOrGroup) {
31
+ return optionOrGroup.tagName === "CALCITE-OPTION-GROUP";
32
+ }
33
+ const Select = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
34
+ constructor() {
35
+ super();
36
+ this.__registerHost();
37
+ this.__attachShadow();
38
+ this.calciteSelectChange = createEvent(this, "calciteSelectChange", 6);
39
+ //--------------------------------------------------------------------------
40
+ //
41
+ // Properties
42
+ //
43
+ //--------------------------------------------------------------------------
44
+ /**
45
+ * When `true`, interaction is prevented and the component is displayed with lower opacity.
46
+ */
47
+ this.disabled = false;
48
+ /**
49
+ * When `true`, the component must have a value in order for the form to submit.
50
+ *
51
+ * @internal
52
+ */
53
+ this.required = false;
54
+ /**
55
+ * Specifies the size of the component.
56
+ */
57
+ this.scale = "m";
58
+ /** The component's `selectedOption` value. */
59
+ this.value = null;
60
+ /**
61
+ * Specifies the width of the component.
62
+ */
63
+ this.width = "auto";
64
+ this.componentToNativeEl = new Map();
65
+ this.mutationObserver = createObserver("mutation", () => this.populateInternalSelect());
66
+ this.handleInternalSelectChange = () => {
67
+ const selected = this.selectEl.selectedOptions[0];
68
+ this.selectFromNativeOption(selected);
69
+ requestAnimationFrame(() => this.emitChangeEvent());
70
+ };
71
+ this.populateInternalSelect = () => {
72
+ const optionsAndGroups = Array.from(this.el.children).filter((child) => child.tagName === "CALCITE-OPTION" || child.tagName === "CALCITE-OPTION-GROUP");
73
+ this.clearInternalSelect();
74
+ optionsAndGroups.forEach((optionOrGroup) => { var _a; return (_a = this.selectEl) === null || _a === void 0 ? void 0 : _a.append(this.toNativeElement(optionOrGroup)); });
75
+ };
76
+ this.storeSelectRef = (node) => {
77
+ this.selectEl = node;
78
+ this.populateInternalSelect();
79
+ const selected = this.selectEl.selectedOptions[0];
80
+ this.selectFromNativeOption(selected);
81
+ };
82
+ this.emitChangeEvent = () => {
83
+ this.calciteSelectChange.emit();
84
+ };
85
+ }
86
+ valueHandler(value) {
87
+ const items = this.el.querySelectorAll("calcite-option");
88
+ items.forEach((item) => (item.selected = item.value === value));
89
+ }
90
+ selectedOptionHandler(selectedOption) {
91
+ this.value = selectedOption === null || selectedOption === void 0 ? void 0 : selectedOption.value;
92
+ }
93
+ //--------------------------------------------------------------------------
94
+ //
95
+ // Lifecycle
96
+ //
97
+ //--------------------------------------------------------------------------
98
+ connectedCallback() {
99
+ var _a;
100
+ const { el } = this;
101
+ (_a = this.mutationObserver) === null || _a === void 0 ? void 0 : _a.observe(el, {
102
+ subtree: true,
103
+ childList: true
104
+ });
105
+ connectLabel(this);
106
+ connectForm(this);
107
+ }
108
+ disconnectedCallback() {
109
+ var _a;
110
+ (_a = this.mutationObserver) === null || _a === void 0 ? void 0 : _a.disconnect();
111
+ disconnectLabel(this);
112
+ disconnectForm(this);
113
+ }
114
+ componentDidLoad() {
115
+ var _a, _b;
116
+ afterConnectDefaultValueSet(this, (_b = (_a = this.selectedOption) === null || _a === void 0 ? void 0 : _a.value) !== null && _b !== void 0 ? _b : "");
117
+ }
118
+ componentDidRender() {
119
+ updateHostInteraction(this);
120
+ }
121
+ //--------------------------------------------------------------------------
122
+ //
123
+ // Public Methods
124
+ //
125
+ //--------------------------------------------------------------------------
126
+ /** Sets focus on the component. */
127
+ async setFocus() {
128
+ focusElement(this.selectEl);
129
+ }
130
+ handleOptionOrGroupChange(event) {
131
+ event.stopPropagation();
132
+ const optionOrGroup = event.target;
133
+ const nativeEl = this.componentToNativeEl.get(optionOrGroup);
134
+ if (!nativeEl) {
135
+ return;
136
+ }
137
+ this.updateNativeElement(optionOrGroup, nativeEl);
138
+ if (isOption(optionOrGroup) && optionOrGroup.selected) {
139
+ this.deselectAllExcept(optionOrGroup);
140
+ this.selectedOption = optionOrGroup;
141
+ }
142
+ }
143
+ //--------------------------------------------------------------------------
144
+ //
145
+ // Private Methods
146
+ //
147
+ //--------------------------------------------------------------------------
148
+ onLabelClick() {
149
+ this.setFocus();
150
+ }
151
+ updateNativeElement(optionOrGroup, nativeOptionOrGroup) {
152
+ nativeOptionOrGroup.disabled = optionOrGroup.disabled;
153
+ nativeOptionOrGroup.label = optionOrGroup.label;
154
+ if (isOption(optionOrGroup)) {
155
+ const option = nativeOptionOrGroup;
156
+ option.selected = optionOrGroup.selected;
157
+ option.value = optionOrGroup.value;
158
+ // need to set innerText for mobile
159
+ // see https://stackoverflow.com/questions/35021620/ios-safari-not-showing-all-options-for-select-menu/41749701
160
+ option.innerText = optionOrGroup.label;
161
+ }
162
+ }
163
+ clearInternalSelect() {
164
+ this.componentToNativeEl.forEach((value) => value.remove());
165
+ this.componentToNativeEl.clear();
166
+ }
167
+ selectFromNativeOption(nativeOption) {
168
+ if (!nativeOption) {
169
+ return;
170
+ }
171
+ let futureSelected;
172
+ this.componentToNativeEl.forEach((nativeOptionOrGroup, optionOrGroup) => {
173
+ if (isOption(optionOrGroup) && nativeOptionOrGroup === nativeOption) {
174
+ optionOrGroup.selected = true;
175
+ futureSelected = optionOrGroup;
176
+ this.deselectAllExcept(optionOrGroup);
177
+ }
178
+ });
179
+ if (futureSelected) {
180
+ this.selectedOption = futureSelected;
181
+ }
182
+ }
183
+ toNativeElement(optionOrGroup) {
184
+ if (isOption(optionOrGroup)) {
185
+ const option = document.createElement("option");
186
+ this.updateNativeElement(optionOrGroup, option);
187
+ this.componentToNativeEl.set(optionOrGroup, option);
188
+ return option;
189
+ }
190
+ if (isOptionGroup(optionOrGroup)) {
191
+ const group = document.createElement("optgroup");
192
+ this.updateNativeElement(optionOrGroup, group);
193
+ Array.from(optionOrGroup.children).forEach((option) => {
194
+ const nativeOption = this.toNativeElement(option);
195
+ group.append(nativeOption);
196
+ this.componentToNativeEl.set(optionOrGroup, nativeOption);
197
+ });
198
+ this.componentToNativeEl.set(optionOrGroup, group);
199
+ return group;
200
+ }
201
+ throw new Error("unsupported element child provided");
202
+ }
203
+ deselectAllExcept(except) {
204
+ this.el.querySelectorAll("calcite-option").forEach((option) => {
205
+ if (option === except) {
206
+ return;
207
+ }
208
+ option.selected = false;
209
+ });
210
+ }
211
+ //--------------------------------------------------------------------------
212
+ //
213
+ // Render Methods
214
+ //
215
+ //--------------------------------------------------------------------------
216
+ renderChevron() {
217
+ return (h("div", { class: CSS.iconContainer }, h("calcite-icon", { class: CSS.icon, icon: "chevron-down", scale: "s" })));
218
+ }
219
+ render() {
220
+ return (h(Fragment, null, h("select", { "aria-label": this.label, class: CSS.select, disabled: this.disabled, onChange: this.handleInternalSelectChange, ref: this.storeSelectRef }, h("slot", null)), this.renderChevron(), h(HiddenFormInputSlot, { component: this })));
221
+ }
222
+ get el() { return this; }
223
+ static get watchers() { return {
224
+ "value": ["valueHandler"],
225
+ "selectedOption": ["selectedOptionHandler"]
226
+ }; }
227
+ static get style() { return selectCss; }
228
+ }, [1, "calcite-select", {
229
+ "disabled": [516],
230
+ "label": [1],
231
+ "name": [513],
232
+ "required": [516],
233
+ "scale": [513],
234
+ "value": [1025],
235
+ "selectedOption": [1040],
236
+ "width": [513],
237
+ "setFocus": [64]
238
+ }, [[0, "calciteInternalOptionChange", "handleOptionOrGroupChange"], [0, "calciteInternalOptionGroupChange", "handleOptionOrGroupChange"]]]);
239
+ function defineCustomElement() {
240
+ if (typeof customElements === "undefined") {
241
+ return;
242
+ }
243
+ const components = ["calcite-select", "calcite-icon"];
244
+ components.forEach(tagName => { switch (tagName) {
245
+ case "calcite-select":
246
+ if (!customElements.get(tagName)) {
247
+ customElements.define(tagName, Select);
248
+ }
249
+ break;
250
+ case "calcite-icon":
251
+ if (!customElements.get(tagName)) {
252
+ defineCustomElement$1();
253
+ }
254
+ break;
255
+ } });
256
+ }
257
+ defineCustomElement();
258
+
259
+ export { Select as S, defineCustomElement as d };
@@ -0,0 +1,319 @@
1
+ /*!
2
+ * Copyright 2022 Esri
3
+ * Licensed under the Apache License, Version 2.0
4
+ * http://www.apache.org/licenses/LICENSE-2.0
5
+ */
6
+ import { f as focusElement, b as getSlotted, t as toAriaBoolean } from './dom.js';
7
+ import { g as getRoundRobinIndex } from './array.js';
8
+ import { S as SLOTS } from './resources2.js';
9
+ import { d as debounce } from './debounce.js';
10
+ import { h, Host } from '@stencil/core/internal/client';
11
+ import { C as CSS, S as SLOTS$1 } from './resources.js';
12
+
13
+ /*!
14
+ * All material copyright ESRI, All Rights Reserved, unless otherwise specified.
15
+ * See https://github.com/Esri/calcite-components/blob/master/LICENSE.md for details.
16
+ * v1.0.0-beta.97
17
+ */
18
+ function mutationObserverCallback() {
19
+ this.setUpItems();
20
+ this.setUpFilter();
21
+ this.deselectRemovedItems();
22
+ }
23
+ const SUPPORTED_ARROW_KEYS = ["ArrowUp", "ArrowDown"];
24
+ // --------------------------------------------------------------------------
25
+ //
26
+ // Lifecycle
27
+ //
28
+ // --------------------------------------------------------------------------
29
+ function initialize() {
30
+ this.setUpItems();
31
+ this.setUpFilter();
32
+ this.emitCalciteListChange = debounce(internalCalciteListChangeEvent.bind(this), 0);
33
+ }
34
+ function initializeObserver() {
35
+ var _a;
36
+ (_a = this.mutationObserver) === null || _a === void 0 ? void 0 : _a.observe(this.el, { childList: true, subtree: true });
37
+ }
38
+ function cleanUpObserver() {
39
+ var _a;
40
+ (_a = this.mutationObserver) === null || _a === void 0 ? void 0 : _a.disconnect();
41
+ }
42
+ // --------------------------------------------------------------------------
43
+ //
44
+ // Listeners
45
+ //
46
+ // --------------------------------------------------------------------------
47
+ function calciteListItemChangeHandler(event) {
48
+ const { selectedValues } = this;
49
+ const { item, value, selected, shiftPressed } = event.detail;
50
+ if (selected) {
51
+ if (this.multiple && shiftPressed) {
52
+ this.selectSiblings(item);
53
+ }
54
+ if (!this.multiple) {
55
+ this.deselectSiblingItems(item);
56
+ }
57
+ selectedValues.set(value, item);
58
+ }
59
+ else {
60
+ selectedValues.delete(value);
61
+ if (this.multiple && shiftPressed) {
62
+ this.selectSiblings(item, true);
63
+ }
64
+ }
65
+ if (!this.multiple) {
66
+ toggleSingleSelectItemTabbing(item, selected);
67
+ if (selected) {
68
+ focusElement(item);
69
+ }
70
+ }
71
+ this.lastSelectedItem = item;
72
+ this.emitCalciteListChange();
73
+ }
74
+ function calciteInternalListItemValueChangeHandler(event) {
75
+ const oldValue = event.detail.oldValue;
76
+ const selectedValues = this.selectedValues;
77
+ if (selectedValues.has(oldValue)) {
78
+ const item = selectedValues.get(oldValue);
79
+ selectedValues.delete(oldValue);
80
+ selectedValues.set(event.detail.newValue, item);
81
+ }
82
+ event.stopPropagation();
83
+ }
84
+ // --------------------------------------------------------------------------
85
+ //
86
+ // Private Methods
87
+ //
88
+ // --------------------------------------------------------------------------
89
+ function isValidNavigationKey(key) {
90
+ return !!SUPPORTED_ARROW_KEYS.find((k) => k === key);
91
+ }
92
+ function calciteListFocusOutHandler(event) {
93
+ const { el, items, multiple, selectedValues } = this;
94
+ if (multiple) {
95
+ return;
96
+ }
97
+ const focusedInside = el.contains(event.relatedTarget);
98
+ if (focusedInside) {
99
+ return;
100
+ }
101
+ filterOutDisabled(items).forEach((item) => {
102
+ toggleSingleSelectItemTabbing(item, selectedValues.size === 0 ? item.contains(event.target) || event.target === item : item.selected);
103
+ });
104
+ }
105
+ function keyDownHandler(event) {
106
+ const { key, target } = event;
107
+ if (!isValidNavigationKey(key)) {
108
+ return;
109
+ }
110
+ const { items, multiple, selectionFollowsFocus } = this;
111
+ const { length: totalItems } = items;
112
+ const currentIndex = items.indexOf(target);
113
+ if (!totalItems || currentIndex === -1) {
114
+ return;
115
+ }
116
+ event.preventDefault();
117
+ const index = moveItemIndex(this, target, key === "ArrowUp" ? "up" : "down");
118
+ const item = items[index];
119
+ items.forEach((i) => toggleSingleSelectItemTabbing(i, i === item));
120
+ if (!multiple && selectionFollowsFocus) {
121
+ item.selected = true;
122
+ }
123
+ focusElement(item);
124
+ }
125
+ function moveItemIndex(list, item, direction) {
126
+ const { items } = list;
127
+ const { length: totalItems } = items;
128
+ const currentIndex = items.indexOf(item);
129
+ const directionFactor = direction === "up" ? -1 : 1;
130
+ let moveOffset = 1;
131
+ let index = getRoundRobinIndex(currentIndex + directionFactor * moveOffset++, totalItems);
132
+ const firstMovedIndex = index;
133
+ while (items[index].disabled) {
134
+ index = getRoundRobinIndex(currentIndex + directionFactor * moveOffset++, totalItems);
135
+ if (index === firstMovedIndex) {
136
+ break;
137
+ }
138
+ }
139
+ return index;
140
+ }
141
+ function getItemIndex(list, item) {
142
+ const { items } = list;
143
+ return items.indexOf(item);
144
+ }
145
+ function filterOutDisabled(items) {
146
+ return items.filter((item) => !item.disabled);
147
+ }
148
+ function internalCalciteListChangeEvent() {
149
+ this.calciteListChange.emit(this.selectedValues);
150
+ }
151
+ function removeItem(event) {
152
+ if (event.defaultPrevented) {
153
+ return;
154
+ }
155
+ const item = event.target;
156
+ const selectedValues = this.selectedValues;
157
+ if (item.parentElement.tagName === "CALCITE-PICK-LIST-GROUP" && item.slot === SLOTS.parentItem) {
158
+ item.parentElement.remove();
159
+ Array.from(item.parentElement.children).forEach((item) => selectedValues.delete(item.value));
160
+ }
161
+ else {
162
+ item.remove();
163
+ selectedValues.delete(item.value);
164
+ }
165
+ this.emitCalciteListChange();
166
+ }
167
+ function toggleSingleSelectItemTabbing(item, selectable) {
168
+ if (item.disabled) {
169
+ return;
170
+ }
171
+ // using attribute intentionally
172
+ if (selectable) {
173
+ item.removeAttribute("tabindex");
174
+ }
175
+ else {
176
+ item.setAttribute("tabindex", "-1");
177
+ }
178
+ }
179
+ async function setFocus(focusId) {
180
+ var _a;
181
+ if (this.filterEnabled && focusId === "filter") {
182
+ await focusElement(this.filterEl);
183
+ return;
184
+ }
185
+ const { items, multiple, selectionFollowsFocus } = this;
186
+ if (items.length === 0) {
187
+ return;
188
+ }
189
+ if (multiple) {
190
+ return (_a = filterOutDisabled(items)[0]) === null || _a === void 0 ? void 0 : _a.setFocus();
191
+ }
192
+ const filtered = filterOutDisabled(items);
193
+ const focusTarget = filtered.find((item) => item.selected) || filtered[0];
194
+ if (selectionFollowsFocus && focusTarget) {
195
+ focusTarget.selected = true;
196
+ }
197
+ return focusTarget.setFocus();
198
+ }
199
+ function setUpItems(tagName) {
200
+ this.items = Array.from(this.el.querySelectorAll(tagName));
201
+ let hasSelected = false;
202
+ const { items } = this;
203
+ items.forEach((item) => {
204
+ item.icon = this.getIconType();
205
+ if (!this.multiple) {
206
+ item.disableDeselect = true;
207
+ toggleSingleSelectItemTabbing(item, false);
208
+ }
209
+ if (item.selected) {
210
+ hasSelected = true;
211
+ toggleSingleSelectItemTabbing(item, true);
212
+ this.selectedValues.set(item.value, item);
213
+ }
214
+ });
215
+ const [first] = items;
216
+ if (!hasSelected && first && !first.disabled) {
217
+ toggleSingleSelectItemTabbing(first, true);
218
+ }
219
+ }
220
+ function deselectRemovedItems() {
221
+ const selectedValues = this.selectedValues;
222
+ const itemValues = this.items.map(({ value }) => value);
223
+ selectedValues.forEach((selectedItem) => {
224
+ if (!itemValues.includes(selectedItem.value)) {
225
+ this.selectedValues.delete(selectedItem.value);
226
+ }
227
+ });
228
+ }
229
+ function deselectSiblingItems(item) {
230
+ this.items.forEach((currentItem) => {
231
+ if (currentItem.value !== item.value) {
232
+ currentItem.toggleSelected(false);
233
+ if (this.selectedValues.has(currentItem.value)) {
234
+ this.selectedValues.delete(currentItem.value);
235
+ }
236
+ }
237
+ });
238
+ }
239
+ function selectSiblings(item, deselect = false) {
240
+ if (!this.lastSelectedItem) {
241
+ return;
242
+ }
243
+ const { items } = this;
244
+ const start = items.findIndex((currentItem) => {
245
+ return currentItem.value === this.lastSelectedItem.value;
246
+ });
247
+ const end = items.findIndex((currentItem) => {
248
+ return currentItem.value === item.value;
249
+ });
250
+ items.slice(Math.min(start, end), Math.max(start, end)).forEach((currentItem) => {
251
+ currentItem.toggleSelected(!deselect);
252
+ if (!deselect) {
253
+ this.selectedValues.set(currentItem.value, currentItem);
254
+ }
255
+ else {
256
+ this.selectedValues.delete(currentItem.value);
257
+ }
258
+ });
259
+ }
260
+ let groups;
261
+ function handleFilter(event) {
262
+ const { filteredItems } = event.currentTarget;
263
+ const values = filteredItems.map((item) => item.value);
264
+ let hasSelectedMatch = false;
265
+ if (!groups) {
266
+ groups = new Set();
267
+ }
268
+ const matchedItems = this.items.filter((item) => {
269
+ const parent = item.parentElement;
270
+ const grouped = parent.matches("calcite-pick-list-group");
271
+ if (grouped) {
272
+ groups.add(parent);
273
+ }
274
+ const matches = values.includes(item.value);
275
+ item.hidden = !matches;
276
+ if (!hasSelectedMatch) {
277
+ hasSelectedMatch = matches && item.selected;
278
+ }
279
+ return matches;
280
+ });
281
+ groups.forEach((group) => {
282
+ const hasAtLeastOneMatch = matchedItems.some((item) => group.contains(item));
283
+ group.hidden = !hasAtLeastOneMatch;
284
+ if (!hasAtLeastOneMatch) {
285
+ return;
286
+ }
287
+ const parentItem = getSlotted(group, "parent-item");
288
+ if (parentItem) {
289
+ parentItem.hidden = false;
290
+ if (matchedItems.includes(parentItem)) {
291
+ Array.from(group.children).forEach((child) => (child.hidden = false));
292
+ }
293
+ }
294
+ });
295
+ groups.clear();
296
+ if (matchedItems.length > 0 && !hasSelectedMatch && !this.multiple) {
297
+ toggleSingleSelectItemTabbing(matchedItems[0], true);
298
+ }
299
+ }
300
+ function getItemData() {
301
+ return this.items.map((item) => ({
302
+ label: item.label,
303
+ description: item.description,
304
+ metadata: item.metadata,
305
+ value: item.value
306
+ }));
307
+ }
308
+
309
+ /*!
310
+ * All material copyright ESRI, All Rights Reserved, unless otherwise specified.
311
+ * See https://github.com/Esri/calcite-components/blob/master/LICENSE.md for details.
312
+ * v1.0.0-beta.97
313
+ */
314
+ const List = ({ props: { disabled, loading, filterEnabled, dataForFilter, handleFilter, filterPlaceholder, setFilterEl, dragEnabled, storeAssistiveEl }, ...rest }) => {
315
+ const defaultSlot = h("slot", null);
316
+ return (h(Host, { "aria-busy": toAriaBoolean(loading), role: "menu", ...rest }, h("section", null, dragEnabled ? (h("span", { "aria-live": "assertive", class: "assistive-text", ref: storeAssistiveEl })) : null, h("header", { class: { [CSS.sticky]: true } }, filterEnabled ? (h("calcite-filter", { "aria-label": filterPlaceholder, disabled: loading || disabled, items: dataForFilter, onCalciteFilterChange: handleFilter, placeholder: filterPlaceholder, ref: setFilterEl })) : null, h("slot", { name: SLOTS$1.menuActions })), loading ? h("calcite-scrim", { loading: loading }) : null, defaultSlot)));
317
+ };
318
+
319
+ export { List as L, deselectSiblingItems as a, initializeObserver as b, cleanUpObserver as c, deselectRemovedItems as d, calciteListItemChangeHandler as e, calciteInternalListItemValueChangeHandler as f, getItemData as g, handleFilter as h, initialize as i, calciteListFocusOutHandler as j, keyDownHandler as k, setUpItems as l, mutationObserverCallback as m, setFocus as n, getItemIndex as o, moveItemIndex as p, removeItem as r, selectSiblings as s };