@shoper/phoenix_design_system 1.0.4 → 1.1.0-10

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 (236) hide show
  1. package/build/cjs/{packages/phoenix/external → external}/classnames/index.js +10 -16
  2. package/build/{esm/packages/phoenix → cjs}/external/classnames/index.js.map +1 -1
  3. package/build/cjs/external/lit/external/lit-html/async-directive.js +18 -0
  4. package/build/{esm/packages/phoenix/src/controllers/btn_controller.js.map → cjs/external/lit/external/lit-html/async-directive.js.map} +1 -1
  5. package/build/cjs/external/lit/external/lit-html/directive-helpers.js +14 -0
  6. package/build/cjs/external/lit/external/lit-html/directive-helpers.js.map +1 -0
  7. package/build/cjs/external/lit/external/lit-html/directive.js +2 -1
  8. package/build/cjs/external/lit/external/lit-html/directive.js.map +1 -1
  9. package/build/cjs/packages/phoenix/src/components/accordion/accordion.js +1 -1
  10. package/build/cjs/packages/phoenix/src/components/accordion/accordion_content.js +1 -1
  11. package/build/cjs/packages/phoenix/src/components/accordion/accordion_group.js +2 -2
  12. package/build/cjs/packages/phoenix/src/components/accordion/accordion_toggler.js +2 -2
  13. package/build/cjs/packages/phoenix/src/components/color_swatches/color_item/color_item.js +1 -1
  14. package/build/cjs/packages/phoenix/src/components/color_swatches/show-more/show_more.js +1 -1
  15. package/build/cjs/packages/phoenix/src/components/dropdown/dropdown.js +3 -3
  16. package/build/cjs/packages/phoenix/src/components/dropdown/dropdown_toggler.js +1 -1
  17. package/build/cjs/packages/phoenix/src/components/form/checkbox/checkbox.js +1 -1
  18. package/build/cjs/packages/phoenix/src/components/form/checkbox/checkbox.js.map +1 -1
  19. package/build/cjs/packages/phoenix/src/components/form/checkbox/checkbox_control.js +2 -2
  20. package/build/cjs/packages/phoenix/src/components/form/checkbox/checkbox_control.js.map +1 -1
  21. package/build/cjs/packages/phoenix/src/components/form/color_swatches_control/color_swatches_control.js +11 -13
  22. package/build/cjs/packages/phoenix/src/components/form/color_swatches_control/color_swatches_control.js.map +1 -1
  23. package/build/cjs/packages/phoenix/src/components/form/controllers/props_synchronizing/control_props_sync_consumer_controller.js +1 -1
  24. package/build/cjs/packages/phoenix/src/components/form/controllers/props_synchronizing/control_props_sync_provider_controller.js +1 -1
  25. package/build/cjs/packages/phoenix/src/components/form/input/input.js +1 -1
  26. package/build/cjs/packages/phoenix/src/components/form/input/input.js.map +1 -1
  27. package/build/cjs/packages/phoenix/src/components/form/input/input_icon.js +1 -1
  28. package/build/cjs/packages/phoenix/src/components/form/radio/radio.js +1 -1
  29. package/build/cjs/packages/phoenix/src/components/form/radio/radio.js.map +1 -1
  30. package/build/cjs/packages/phoenix/src/components/form/select/components/option/select_option.js +62 -0
  31. package/build/cjs/packages/phoenix/src/components/form/select/components/option/select_option.js.map +1 -0
  32. package/build/cjs/packages/phoenix/src/components/form/select/components/option/select_option_constants.js +12 -0
  33. package/build/cjs/packages/phoenix/src/components/form/select/components/option/select_option_constants.js.map +1 -0
  34. package/build/cjs/packages/phoenix/src/components/form/select/components/option/select_option_content.js +21 -0
  35. package/build/cjs/packages/phoenix/src/components/form/select/components/option/select_option_content.js.map +1 -0
  36. package/build/cjs/packages/phoenix/src/components/form/select/components/search/select_search.js +52 -0
  37. package/build/cjs/packages/phoenix/src/components/form/select/components/search/select_search.js.map +1 -0
  38. package/build/cjs/packages/phoenix/src/components/form/select/components/search/select_search_constants.js +13 -0
  39. package/build/cjs/packages/phoenix/src/components/form/select/components/search/select_search_constants.js.map +1 -0
  40. package/build/cjs/packages/phoenix/src/components/form/select/components/select_components_constatns.js +33 -0
  41. package/build/cjs/packages/phoenix/src/components/form/select/components/select_components_constatns.js.map +1 -0
  42. package/build/cjs/packages/phoenix/src/components/form/select/components/select_options.js +31 -0
  43. package/build/cjs/packages/phoenix/src/components/form/select/components/select_options.js.map +1 -0
  44. package/build/cjs/packages/phoenix/src/components/form/select/components/toggler/select_toggler.js +74 -0
  45. package/build/cjs/packages/phoenix/src/components/form/select/components/toggler/select_toggler.js.map +1 -0
  46. package/build/cjs/packages/phoenix/src/components/form/select/components/toggler/select_toggler_constants.js +12 -0
  47. package/build/cjs/packages/phoenix/src/components/form/select/components/toggler/select_toggler_constants.js.map +1 -0
  48. package/build/cjs/packages/phoenix/src/components/form/select/controllers/base_select_controller.js +93 -0
  49. package/build/cjs/packages/phoenix/src/components/form/select/controllers/base_select_controller.js.map +1 -0
  50. package/build/cjs/packages/phoenix/src/components/form/select/controllers/multi_select_controller.js +22 -0
  51. package/build/cjs/packages/phoenix/src/components/form/select/controllers/multi_select_controller.js.map +1 -0
  52. package/build/cjs/packages/phoenix/src/components/form/select/controllers/select_controller.js +19 -0
  53. package/build/cjs/packages/phoenix/src/components/form/select/controllers/select_controller.js.map +1 -0
  54. package/build/cjs/packages/phoenix/src/components/form/select/model/select_option.js +19 -0
  55. package/build/cjs/packages/phoenix/src/components/form/select/model/select_option.js.map +1 -0
  56. package/build/cjs/packages/phoenix/src/components/form/select/model/select_option_mapper.js +24 -0
  57. package/build/cjs/packages/phoenix/src/components/form/select/model/select_option_mapper.js.map +1 -0
  58. package/build/cjs/packages/phoenix/src/components/form/select/select.js +228 -0
  59. package/build/cjs/packages/phoenix/src/components/form/select/select.js.map +1 -0
  60. package/build/cjs/packages/phoenix/src/components/form/select/select_constants.js +35 -0
  61. package/build/cjs/packages/phoenix/src/components/form/select/select_constants.js.map +1 -0
  62. package/build/cjs/packages/phoenix/src/components/form/select/select_utils.js +52 -0
  63. package/build/cjs/packages/phoenix/src/components/form/select/select_utils.js.map +1 -0
  64. package/build/cjs/packages/phoenix/src/components/form/switch/switch.js +1 -1
  65. package/build/cjs/packages/phoenix/src/components/form/switch/switch.js.map +1 -1
  66. package/build/cjs/packages/phoenix/src/components/form/textarea/textarea.js +1 -1
  67. package/build/cjs/packages/phoenix/src/components/form/textarea/textarea.js.map +1 -1
  68. package/build/cjs/packages/phoenix/src/components/icon/icon.js +2 -1
  69. package/build/cjs/packages/phoenix/src/components/icon/icon.js.map +1 -1
  70. package/build/cjs/packages/phoenix/src/components/messages/base_message.js +1 -1
  71. package/build/cjs/packages/phoenix/src/components/modal/modal.js +4 -4
  72. package/build/cjs/packages/phoenix/src/components/portal/portal.js +1 -1
  73. package/build/cjs/packages/phoenix/src/components/portal/portal.js.map +1 -1
  74. package/build/cjs/packages/phoenix/src/components/portal/portal_target.js +1 -1
  75. package/build/cjs/packages/phoenix/src/components/scroll_to/scroll_to.js +1 -1
  76. package/build/cjs/packages/phoenix/src/components/tabs/tab/tab.js +1 -1
  77. package/build/cjs/packages/phoenix/src/components/tag/tag.js +3 -2
  78. package/build/cjs/packages/phoenix/src/components/tag/tag.js.map +1 -1
  79. package/build/cjs/packages/phoenix/src/controllers/{btn_controller.js → btn_controller/btn_controller.js} +4 -3
  80. package/build/cjs/packages/phoenix/src/controllers/btn_controller/btn_controller.js.map +1 -0
  81. package/build/cjs/packages/phoenix/src/controllers/keystrokes_controller/keystrokes_controller.js +4 -4
  82. package/build/cjs/packages/phoenix/src/controllers/list_box_controller/list_box_controller_constants.js +11 -0
  83. package/build/cjs/packages/phoenix/src/controllers/list_box_controller/list_box_controller_constants.js.map +1 -0
  84. package/build/cjs/packages/phoenix/src/controllers/list_box_controller/list_box_keyboard_controller.js +84 -0
  85. package/build/cjs/packages/phoenix/src/controllers/list_box_controller/list_box_keyboard_controller.js.map +1 -0
  86. package/build/cjs/packages/phoenix/src/core/classes/behavior_subject/behavior_subject.js +2 -7
  87. package/build/cjs/packages/phoenix/src/core/classes/behavior_subject/behavior_subject.js.map +1 -1
  88. package/build/cjs/packages/phoenix/src/core/classes/subject/subject.js +8 -1
  89. package/build/cjs/packages/phoenix/src/core/classes/subject/subject.js.map +1 -1
  90. package/build/cjs/packages/phoenix/src/core/context/context_consumer_controller.js +1 -1
  91. package/build/cjs/packages/phoenix/src/core/phoenix_light_lit_element/phoenix_light_lit_element.js +10 -5
  92. package/build/cjs/packages/phoenix/src/core/phoenix_light_lit_element/phoenix_light_lit_element.js.map +1 -1
  93. package/build/cjs/packages/phoenix/src/directives/observable_directive.js +40 -0
  94. package/build/cjs/packages/phoenix/src/directives/observable_directive.js.map +1 -0
  95. package/build/cjs/packages/phoenix/src/index.js +80 -45
  96. package/build/cjs/packages/phoenix/src/index.js.map +1 -1
  97. package/build/esm/{packages/phoenix/external → external}/classnames/index.js +10 -16
  98. package/build/{cjs/packages/phoenix → esm}/external/classnames/index.js.map +1 -1
  99. package/build/esm/external/lit/external/lit-html/async-directive.js +12 -0
  100. package/build/esm/external/lit/external/lit-html/async-directive.js.map +1 -0
  101. package/build/esm/external/lit/external/lit-html/directive-helpers.js +10 -0
  102. package/build/esm/external/lit/external/lit-html/directive-helpers.js.map +1 -0
  103. package/build/esm/external/lit/external/lit-html/directive.js +2 -2
  104. package/build/esm/packages/phoenix/src/components/accordion/accordion.js +1 -1
  105. package/build/esm/packages/phoenix/src/components/accordion/accordion_content.js +1 -1
  106. package/build/esm/packages/phoenix/src/components/accordion/accordion_group.js +2 -2
  107. package/build/esm/packages/phoenix/src/components/accordion/accordion_toggler.js +2 -2
  108. package/build/esm/packages/phoenix/src/components/color_swatches/color_item/color_item.js +1 -1
  109. package/build/esm/packages/phoenix/src/components/color_swatches/show-more/show_more.js +1 -1
  110. package/build/esm/packages/phoenix/src/components/dropdown/dropdown.js +3 -3
  111. package/build/esm/packages/phoenix/src/components/dropdown/dropdown_toggler.js +1 -1
  112. package/build/esm/packages/phoenix/src/components/form/checkbox/checkbox.js +1 -1
  113. package/build/esm/packages/phoenix/src/components/form/checkbox/checkbox.js.map +1 -1
  114. package/build/esm/packages/phoenix/src/components/form/checkbox/checkbox_control.js +2 -2
  115. package/build/esm/packages/phoenix/src/components/form/checkbox/checkbox_control.js.map +1 -1
  116. package/build/esm/packages/phoenix/src/components/form/color_swatches_control/color_swatches_control.d.ts +2 -3
  117. package/build/esm/packages/phoenix/src/components/form/color_swatches_control/color_swatches_control.js +11 -13
  118. package/build/esm/packages/phoenix/src/components/form/color_swatches_control/color_swatches_control.js.map +1 -1
  119. package/build/esm/packages/phoenix/src/components/form/controllers/props_synchronizing/control_props_sync_consumer_controller.js +1 -1
  120. package/build/esm/packages/phoenix/src/components/form/controllers/props_synchronizing/control_props_sync_provider_controller.js +1 -1
  121. package/build/esm/packages/phoenix/src/components/form/input/input.js +1 -1
  122. package/build/esm/packages/phoenix/src/components/form/input/input.js.map +1 -1
  123. package/build/esm/packages/phoenix/src/components/form/input/input_icon.js +1 -1
  124. package/build/esm/packages/phoenix/src/components/form/radio/radio.js +1 -1
  125. package/build/esm/packages/phoenix/src/components/form/radio/radio.js.map +1 -1
  126. package/build/esm/packages/phoenix/src/components/form/select/components/option/select_option.d.ts +13 -0
  127. package/build/esm/packages/phoenix/src/components/form/select/components/option/select_option.js +60 -0
  128. package/build/esm/packages/phoenix/src/components/form/select/components/option/select_option.js.map +1 -0
  129. package/build/esm/packages/phoenix/src/components/form/select/components/option/select_option_constants.d.ts +4 -0
  130. package/build/esm/packages/phoenix/src/components/form/select/components/option/select_option_constants.js +8 -0
  131. package/build/esm/packages/phoenix/src/components/form/select/components/option/select_option_constants.js.map +1 -0
  132. package/build/esm/packages/phoenix/src/components/form/select/components/option/select_option_content.d.ts +4 -0
  133. package/build/esm/packages/phoenix/src/components/form/select/components/option/select_option_content.js +19 -0
  134. package/build/esm/packages/phoenix/src/components/form/select/components/option/select_option_content.js.map +1 -0
  135. package/build/esm/packages/phoenix/src/components/form/select/components/search/select_search.d.ts +8 -0
  136. package/build/esm/packages/phoenix/src/components/form/select/components/search/select_search.js +50 -0
  137. package/build/esm/packages/phoenix/src/components/form/select/components/search/select_search.js.map +1 -0
  138. package/build/esm/packages/phoenix/src/components/form/select/components/search/select_search_constants.d.ts +5 -0
  139. package/build/esm/packages/phoenix/src/components/form/select/components/search/select_search_constants.js +9 -0
  140. package/build/esm/packages/phoenix/src/components/form/select/components/search/select_search_constants.js.map +1 -0
  141. package/build/esm/packages/phoenix/src/components/form/select/components/select_close_btn.d.ts +8 -0
  142. package/build/esm/packages/phoenix/src/components/form/select/components/select_close_btn.js +29 -0
  143. package/build/esm/packages/phoenix/src/components/form/select/components/select_close_btn.js.map +1 -0
  144. package/build/esm/packages/phoenix/src/components/form/select/components/select_components_constatns.d.ts +22 -0
  145. package/build/esm/packages/phoenix/src/components/form/select/components/select_components_constatns.js +24 -0
  146. package/build/esm/packages/phoenix/src/components/form/select/components/select_components_constatns.js.map +1 -0
  147. package/build/esm/packages/phoenix/src/components/form/select/components/select_components_types.d.ts +4 -0
  148. package/build/esm/packages/phoenix/src/components/form/select/components/select_components_types.js +2 -0
  149. package/build/esm/packages/phoenix/src/components/form/select/components/select_components_types.js.map +1 -0
  150. package/build/esm/packages/phoenix/src/components/form/select/components/select_options.d.ts +5 -0
  151. package/build/esm/packages/phoenix/src/components/form/select/components/select_options.js +29 -0
  152. package/build/esm/packages/phoenix/src/components/form/select/components/select_options.js.map +1 -0
  153. package/build/esm/packages/phoenix/src/components/form/select/components/toggler/select_toggler.d.ts +13 -0
  154. package/build/esm/packages/phoenix/src/components/form/select/components/toggler/select_toggler.js +72 -0
  155. package/build/esm/packages/phoenix/src/components/form/select/components/toggler/select_toggler.js.map +1 -0
  156. package/build/esm/packages/phoenix/src/components/form/select/components/toggler/select_toggler_constants.d.ts +4 -0
  157. package/build/esm/packages/phoenix/src/components/form/select/components/toggler/select_toggler_constants.js +8 -0
  158. package/build/esm/packages/phoenix/src/components/form/select/components/toggler/select_toggler_constants.js.map +1 -0
  159. package/build/esm/packages/phoenix/src/components/form/select/controllers/base_select_controller.d.ts +27 -0
  160. package/build/esm/packages/phoenix/src/components/form/select/controllers/base_select_controller.js +89 -0
  161. package/build/esm/packages/phoenix/src/components/form/select/controllers/base_select_controller.js.map +1 -0
  162. package/build/esm/packages/phoenix/src/components/form/select/controllers/multi_select_controller.d.ts +7 -0
  163. package/build/esm/packages/phoenix/src/components/form/select/controllers/multi_select_controller.js +18 -0
  164. package/build/esm/packages/phoenix/src/components/form/select/controllers/multi_select_controller.js.map +1 -0
  165. package/build/esm/packages/phoenix/src/components/form/select/controllers/select_controller.d.ts +5 -0
  166. package/build/esm/packages/phoenix/src/components/form/select/controllers/select_controller.js +15 -0
  167. package/build/esm/packages/phoenix/src/components/form/select/controllers/select_controller.js.map +1 -0
  168. package/build/esm/packages/phoenix/src/components/form/select/controllers/select_controllers_types.d.ts +22 -0
  169. package/build/esm/packages/phoenix/src/components/form/select/controllers/select_controllers_types.js +5 -0
  170. package/build/esm/packages/phoenix/src/components/form/select/controllers/select_controllers_types.js.map +1 -0
  171. package/build/esm/packages/phoenix/src/components/form/select/model/select_option.d.ts +10 -0
  172. package/build/esm/packages/phoenix/src/components/form/select/model/select_option.js +15 -0
  173. package/build/esm/packages/phoenix/src/components/form/select/model/select_option.js.map +1 -0
  174. package/build/esm/packages/phoenix/src/components/form/select/model/select_option_constants.d.ts +7 -0
  175. package/build/esm/packages/phoenix/src/components/form/select/model/select_option_constants.js +2 -0
  176. package/build/esm/packages/phoenix/src/components/form/select/model/select_option_constants.js.map +1 -0
  177. package/build/esm/packages/phoenix/src/components/form/select/model/select_option_mapper.d.ts +5 -0
  178. package/build/esm/packages/phoenix/src/components/form/select/model/select_option_mapper.js +20 -0
  179. package/build/esm/packages/phoenix/src/components/form/select/model/select_option_mapper.js.map +1 -0
  180. package/build/esm/packages/phoenix/src/components/form/select/select.d.ts +36 -0
  181. package/build/esm/packages/phoenix/src/components/form/select/select.js +226 -0
  182. package/build/esm/packages/phoenix/src/components/form/select/select.js.map +1 -0
  183. package/build/esm/packages/phoenix/src/components/form/select/select_constants.d.ts +23 -0
  184. package/build/esm/packages/phoenix/src/components/form/select/select_constants.js +27 -0
  185. package/build/esm/packages/phoenix/src/components/form/select/select_constants.js.map +1 -0
  186. package/build/esm/packages/phoenix/src/components/form/select/select_utils.d.ts +9 -0
  187. package/build/esm/packages/phoenix/src/components/form/select/select_utils.js +48 -0
  188. package/build/esm/packages/phoenix/src/components/form/select/select_utils.js.map +1 -0
  189. package/build/esm/packages/phoenix/src/components/form/switch/switch.js +1 -1
  190. package/build/esm/packages/phoenix/src/components/form/switch/switch.js.map +1 -1
  191. package/build/esm/packages/phoenix/src/components/form/textarea/textarea.js +1 -1
  192. package/build/esm/packages/phoenix/src/components/form/textarea/textarea.js.map +1 -1
  193. package/build/esm/packages/phoenix/src/components/icon/icon.js +2 -1
  194. package/build/esm/packages/phoenix/src/components/icon/icon.js.map +1 -1
  195. package/build/esm/packages/phoenix/src/components/messages/base_message.js +1 -1
  196. package/build/esm/packages/phoenix/src/components/modal/modal.js +4 -4
  197. package/build/esm/packages/phoenix/src/components/portal/portal.js +1 -1
  198. package/build/esm/packages/phoenix/src/components/portal/portal.js.map +1 -1
  199. package/build/esm/packages/phoenix/src/components/portal/portal_target.js +1 -1
  200. package/build/esm/packages/phoenix/src/components/scroll_to/scroll_to.js +1 -1
  201. package/build/esm/packages/phoenix/src/components/tabs/tab/tab.js +1 -1
  202. package/build/esm/packages/phoenix/src/components/tag/tag.js +3 -2
  203. package/build/esm/packages/phoenix/src/components/tag/tag.js.map +1 -1
  204. package/build/esm/packages/phoenix/src/controllers/{btn_controller.d.ts → btn_controller/btn_controller.d.ts} +2 -1
  205. package/build/esm/packages/phoenix/src/controllers/{btn_controller.js → btn_controller/btn_controller.js} +4 -3
  206. package/build/{cjs/packages/phoenix/src/controllers → esm/packages/phoenix/src/controllers/btn_controller}/btn_controller.js.map +1 -1
  207. package/build/esm/packages/phoenix/src/controllers/btn_controller/btn_controller_types.d.ts +3 -0
  208. package/build/esm/packages/phoenix/src/controllers/btn_controller/btn_controller_types.js +2 -0
  209. package/build/esm/packages/phoenix/src/controllers/btn_controller/btn_controller_types.js.map +1 -0
  210. package/build/esm/packages/phoenix/src/controllers/keystrokes_controller/keystrokes_controller.js +4 -4
  211. package/build/esm/packages/phoenix/src/controllers/list_box_controller/list_box_controller_constants.d.ts +4 -0
  212. package/build/esm/packages/phoenix/src/controllers/list_box_controller/list_box_controller_constants.js +7 -0
  213. package/build/esm/packages/phoenix/src/controllers/list_box_controller/list_box_controller_constants.js.map +1 -0
  214. package/build/esm/packages/phoenix/src/controllers/list_box_controller/list_box_controller_types.d.ts +10 -0
  215. package/build/esm/packages/phoenix/src/controllers/list_box_controller/list_box_controller_types.js +4 -0
  216. package/build/esm/packages/phoenix/src/controllers/list_box_controller/list_box_controller_types.js.map +1 -0
  217. package/build/esm/packages/phoenix/src/controllers/list_box_controller/list_box_keyboard_controller.d.ts +10 -0
  218. package/build/esm/packages/phoenix/src/controllers/list_box_controller/list_box_keyboard_controller.js +80 -0
  219. package/build/esm/packages/phoenix/src/controllers/list_box_controller/list_box_keyboard_controller.js.map +1 -0
  220. package/build/esm/packages/phoenix/src/core/classes/behavior_subject/behavior_subject.d.ts +0 -2
  221. package/build/esm/packages/phoenix/src/core/classes/behavior_subject/behavior_subject.js +2 -7
  222. package/build/esm/packages/phoenix/src/core/classes/behavior_subject/behavior_subject.js.map +1 -1
  223. package/build/esm/packages/phoenix/src/core/classes/subject/subject.d.ts +4 -2
  224. package/build/esm/packages/phoenix/src/core/classes/subject/subject.js +8 -1
  225. package/build/esm/packages/phoenix/src/core/classes/subject/subject.js.map +1 -1
  226. package/build/esm/packages/phoenix/src/core/classes/subject/subject_types.d.ts +2 -1
  227. package/build/esm/packages/phoenix/src/core/context/context_consumer_controller.js +1 -1
  228. package/build/esm/packages/phoenix/src/core/phoenix_light_lit_element/phoenix_light_lit_element.js +10 -5
  229. package/build/esm/packages/phoenix/src/core/phoenix_light_lit_element/phoenix_light_lit_element.js.map +1 -1
  230. package/build/esm/packages/phoenix/src/directives/observable_directive.d.ts +1 -0
  231. package/build/esm/packages/phoenix/src/directives/observable_directive.js +35 -31
  232. package/build/esm/packages/phoenix/src/directives/observable_directive.js.map +1 -1
  233. package/build/esm/packages/phoenix/src/index.d.ts +6 -1
  234. package/build/esm/packages/phoenix/src/index.js +17 -12
  235. package/build/esm/packages/phoenix/src/index.js.map +1 -1
  236. package/package.json +2 -2
@@ -0,0 +1,60 @@
1
+ import { __decorate, __metadata } from '../../../../../../../../external/tslib/tslib.es6.js';
2
+ import { nothing } from 'lit';
3
+ import { PhoenixLightLitElement } from '../../../../../core/phoenix_light_lit_element/phoenix_light_lit_element.js';
4
+ import { phoenixCustomElement } from '../../../../../core/decorators/phoenix_custom_element.js';
5
+ import { property } from '@lit/reactive-element/decorators.js';
6
+ import { SELECT_OPTION_EVENT_NAMES, SELECT_RELATED_COMPONENTS_NAMES } from '../select_components_constatns.js';
7
+ import { BtnController } from '../../../../../controllers/btn_controller/btn_controller.js';
8
+ import { SELECT_OPTION_CSS_CLASSES } from './select_option_constants.js';
9
+ import { html } from 'lit-html';
10
+
11
+ let HOption = class HOption extends PhoenixLightLitElement {
12
+ constructor() {
13
+ super(...arguments);
14
+ this._dispatchClickedEvent = () => {
15
+ if (this.disabled)
16
+ return;
17
+ this.dispatchEvent(new CustomEvent(SELECT_OPTION_EVENT_NAMES.clicked, {
18
+ bubbles: true,
19
+ detail: {
20
+ $option: this
21
+ }
22
+ }));
23
+ };
24
+ }
25
+ connectedCallback() {
26
+ super.connectedCallback();
27
+ this._btnController = new BtnController(this, this._dispatchClickedEvent);
28
+ this.classList.add(SELECT_OPTION_CSS_CLASSES.selectOption);
29
+ this.setAttribute('role', 'option');
30
+ this._setupEvents();
31
+ }
32
+ _setupEvents() {
33
+ this.addEventListener('click', this._dispatchClickedEvent);
34
+ }
35
+ render() {
36
+ return html ` ${this.getSlot('content')} ${this.selected ? html `<h-icon icon-name="icon-check"></h-icon>` : nothing} `;
37
+ }
38
+ };
39
+ __decorate([
40
+ property({ type: String, reflect: true }),
41
+ __metadata("design:type", String)
42
+ ], HOption.prototype, "value", void 0);
43
+ __decorate([
44
+ property({ type: Boolean, reflect: true }),
45
+ __metadata("design:type", Boolean)
46
+ ], HOption.prototype, "selected", void 0);
47
+ __decorate([
48
+ property({ type: Boolean, reflect: true }),
49
+ __metadata("design:type", Boolean)
50
+ ], HOption.prototype, "disabled", void 0);
51
+ __decorate([
52
+ property({ type: Boolean, reflect: true }),
53
+ __metadata("design:type", Boolean)
54
+ ], HOption.prototype, "hidden", void 0);
55
+ HOption = __decorate([
56
+ phoenixCustomElement(SELECT_RELATED_COMPONENTS_NAMES.option)
57
+ ], HOption);
58
+
59
+ export { HOption };
60
+ //# sourceMappingURL=select_option.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":null,"sources":[null],"sourcesContent":[null],"names":[],"mappings":"AAAA,uCAAuC,qDAAyD;AAChG;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;"}
@@ -0,0 +1,4 @@
1
+ export declare const SELECT_OPTION_CSS_CLASSES: {
2
+ readonly selectOption: "select-option";
3
+ readonly selectOptionContent: "select-option__content";
4
+ };
@@ -0,0 +1,8 @@
1
+ const selectOption = 'select-option';
2
+ const SELECT_OPTION_CSS_CLASSES = {
3
+ selectOption: selectOption,
4
+ selectOptionContent: `${selectOption}__content`
5
+ };
6
+
7
+ export { SELECT_OPTION_CSS_CLASSES };
8
+ //# sourceMappingURL=select_option_constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":null,"sources":[null],"sourcesContent":[null],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;"}
@@ -0,0 +1,4 @@
1
+ import { PhoenixLightLitElement } from "../../../../../core/phoenix_light_lit_element/phoenix_light_lit_element";
2
+ export declare class HOptionContent extends PhoenixLightLitElement {
3
+ connectedCallback(): void;
4
+ }
@@ -0,0 +1,19 @@
1
+ import { __decorate } from '../../../../../../../../external/tslib/tslib.es6.js';
2
+ import { PhoenixLightLitElement } from '../../../../../core/phoenix_light_lit_element/phoenix_light_lit_element.js';
3
+ import { phoenixCustomElement } from '../../../../../core/decorators/phoenix_custom_element.js';
4
+ import { SELECT_RELATED_COMPONENTS_NAMES } from '../select_components_constatns.js';
5
+ import { SELECT_OPTION_CSS_CLASSES } from './select_option_constants.js';
6
+
7
+ let HOptionContent = class HOptionContent extends PhoenixLightLitElement {
8
+ connectedCallback() {
9
+ super.connectedCallback();
10
+ this.setAttribute('slot', 'content');
11
+ this.classList.add(SELECT_OPTION_CSS_CLASSES.selectOptionContent);
12
+ }
13
+ };
14
+ HOptionContent = __decorate([
15
+ phoenixCustomElement(SELECT_RELATED_COMPONENTS_NAMES.optionContent)
16
+ ], HOptionContent);
17
+
18
+ export { HOptionContent };
19
+ //# sourceMappingURL=select_option_content.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":null,"sources":[null],"sourcesContent":[null],"names":[],"mappings":"AAAA,2BAA2B,qDAAyD;AACpF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;"}
@@ -0,0 +1,8 @@
1
+ import { PhoenixLightLitElement } from "../../../../../core/phoenix_light_lit_element/phoenix_light_lit_element";
2
+ import { TemplateResult } from 'lit';
3
+ export declare class HSelectSearch extends PhoenixLightLitElement {
4
+ value: string;
5
+ connectedCallback(): void;
6
+ private _handleInputChange;
7
+ protected render(): TemplateResult;
8
+ }
@@ -0,0 +1,50 @@
1
+ import { __decorate, __metadata } from '../../../../../../../../external/tslib/tslib.es6.js';
2
+ import { html } from 'lit';
3
+ import { property } from 'lit/decorators';
4
+ import { PhoenixLightLitElement } from '../../../../../core/phoenix_light_lit_element/phoenix_light_lit_element.js';
5
+ import { phoenixCustomElement } from '../../../../../core/decorators/phoenix_custom_element.js';
6
+ import { SELECT_SEARCH_EVENT_NAMES, SELECT_RELATED_COMPONENTS_NAMES } from '../select_components_constatns.js';
7
+ import debounce_1 from '../../../../../../../../external/lodash/debounce.js';
8
+ import { SELECT_SEARCH_CSS_CLASSES } from './select_search_constants.js';
9
+
10
+ let HSelectSearch = class HSelectSearch extends PhoenixLightLitElement {
11
+ constructor() {
12
+ super(...arguments);
13
+ this.value = '';
14
+ this._handleInputChange = debounce_1(({ target }) => {
15
+ this.value = target.value;
16
+ this.dispatchEvent(new CustomEvent(SELECT_SEARCH_EVENT_NAMES.search, {
17
+ bubbles: true,
18
+ detail: target.value
19
+ }));
20
+ }, 200);
21
+ }
22
+ connectedCallback() {
23
+ super.connectedCallback();
24
+ this.classList.add(SELECT_SEARCH_CSS_CLASSES.selectSearch);
25
+ }
26
+ render() {
27
+ return html `
28
+ <h-icon icon-name="icon-search" class=${SELECT_SEARCH_CSS_CLASSES.selectSearchIcon}></h-icon>
29
+ <input
30
+ class=${SELECT_SEARCH_CSS_CLASSES.selectSearchInput}
31
+ type="text"
32
+ role="search"
33
+ .value=${this.value}
34
+ aria-autocomplete="list"
35
+ autocomplete="false"
36
+ @input=${this._handleInputChange}
37
+ />
38
+ `;
39
+ }
40
+ };
41
+ __decorate([
42
+ property({ type: String, reflect: true }),
43
+ __metadata("design:type", String)
44
+ ], HSelectSearch.prototype, "value", void 0);
45
+ HSelectSearch = __decorate([
46
+ phoenixCustomElement(SELECT_RELATED_COMPONENTS_NAMES.search)
47
+ ], HSelectSearch);
48
+
49
+ export { HSelectSearch };
50
+ //# sourceMappingURL=select_search.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":null,"sources":[null],"sourcesContent":[null],"names":[],"mappings":"AAAA,uCAAuC,qDAAyD;AAChG;AACA;AACA;AACA;AACA;AACA,uBAAuB,qDAAyD;AAChF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;"}
@@ -0,0 +1,5 @@
1
+ export declare const SELECT_SEARCH_CSS_CLASSES: {
2
+ readonly selectSearch: "select-search";
3
+ readonly selectSearchIcon: "select-search__icon";
4
+ readonly selectSearchInput: "select-search__input";
5
+ };
@@ -0,0 +1,9 @@
1
+ const baseClass = 'select-search';
2
+ const SELECT_SEARCH_CSS_CLASSES = {
3
+ selectSearch: baseClass,
4
+ selectSearchIcon: `${baseClass}__icon`,
5
+ selectSearchInput: `${baseClass}__input`
6
+ };
7
+
8
+ export { SELECT_SEARCH_CSS_CLASSES };
9
+ //# sourceMappingURL=select_search_constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":null,"sources":[null],"sourcesContent":[null],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;"}
@@ -0,0 +1,8 @@
1
+ import { TemplateResult } from 'lit-html';
2
+ import { PhoenixLightLitElement } from "../../../../core/phoenix_light_lit_element/phoenix_light_lit_element";
3
+ export declare class SelectCloseBtn extends PhoenixLightLitElement {
4
+ private _btnController;
5
+ connectedCallback(): void;
6
+ private _dispatchCloseEvent;
7
+ render(): TemplateResult;
8
+ }
@@ -0,0 +1,29 @@
1
+ import { __decorate } from "tslib";
2
+ import { phoenixCustomElement } from '@phoenixRoot/core/decorators/phoenix_custom_element';
3
+ import { html } from 'lit-html';
4
+ import { PhoenixLightLitElement } from '@phoenixRoot/core/phoenix_light_lit_element/phoenix_light_lit_element';
5
+ import { SELECT_CLOSE_BTN_EVENT_NAMES, SELECT_CLOSE_BUTTON_CONTENT_SLOT_NAME, SELECT_RELATED_COMPONENTS_NAMES } from '@phoenixRoot/components/form/select/components/select_components_constatns';
6
+ import { BtnController } from '@phoenixRoot/controllers/btn_controller/btn_controller';
7
+ let SelectCloseBtn = class SelectCloseBtn extends PhoenixLightLitElement {
8
+ constructor() {
9
+ super(...arguments);
10
+ this._dispatchCloseEvent = () => {
11
+ this.dispatchEvent(new CustomEvent(SELECT_CLOSE_BTN_EVENT_NAMES.close));
12
+ };
13
+ }
14
+ connectedCallback() {
15
+ super.connectedCallback();
16
+ this.setAttribute('aria-label', 'close select');
17
+ this._btnController = new BtnController(this, this._dispatchCloseEvent);
18
+ }
19
+ render() {
20
+ return html `${this.hasSlot(SELECT_CLOSE_BUTTON_CONTENT_SLOT_NAME)
21
+ ? this.getSlot(SELECT_CLOSE_BUTTON_CONTENT_SLOT_NAME)
22
+ : html `<icon iconName="icon-x"></icon>`} `;
23
+ }
24
+ };
25
+ SelectCloseBtn = __decorate([
26
+ phoenixCustomElement(SELECT_RELATED_COMPONENTS_NAMES.closeBtn)
27
+ ], SelectCloseBtn);
28
+ export { SelectCloseBtn };
29
+ //# sourceMappingURL=select_close_btn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"select_close_btn.js","sourceRoot":"","sources":["../../../../../../../../../src/components/form/select/components/select_close_btn.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,qDAAqD,CAAC;AAC3F,OAAO,EAAE,IAAI,EAAkB,MAAM,UAAU,CAAC;AAChD,OAAO,EAAE,sBAAsB,EAAE,MAAM,uEAAuE,CAAC;AAC/G,OAAO,EACH,4BAA4B,EAC5B,qCAAqC,EACrC,+BAA+B,EAClC,MAAM,4EAA4E,CAAC;AACpF,OAAO,EAAE,aAAa,EAAE,MAAM,wDAAwD,CAAC;AAGvF,IAAa,cAAc,GAA3B,MAAa,cAAe,SAAQ,sBAAsB;IAA1D;;QAWY,wBAAmB,GAAG,GAAG,EAAE;YAC/B,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,4BAA4B,CAAC,KAAK,CAAC,CAAC,CAAC;QAC5E,CAAC,CAAC;IAON,CAAC;IAjBU,iBAAiB;QACpB,KAAK,CAAC,iBAAiB,EAAE,CAAC;QAE1B,IAAI,CAAC,YAAY,CAAC,YAAY,EAAE,cAAc,CAAC,CAAC;QAEhD,IAAI,CAAC,cAAc,GAAG,IAAI,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;IAC5E,CAAC;IAMM,MAAM;QACT,OAAO,IAAI,CAAA,GAAG,IAAI,CAAC,OAAO,CAAC,qCAAqC,CAAC;YAC7D,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,qCAAqC,CAAC;YACrD,CAAC,CAAC,IAAI,CAAA,iCAAiC,GAAG,CAAC;IACnD,CAAC;CACJ,CAAA;AApBY,cAAc;IAD1B,oBAAoB,CAAC,+BAA+B,CAAC,QAAQ,CAAC;GAClD,cAAc,CAoB1B;SApBY,cAAc"}
@@ -0,0 +1,22 @@
1
+ export declare const SELECT_OPTION_EVENT_NAMES: {
2
+ readonly clicked: "selectOption.clicked";
3
+ };
4
+ export declare const SELECT_OPTIONS_EVENT_NAMES: {
5
+ readonly clicked: "selectOptions.clicked";
6
+ };
7
+ export declare const SELECT_SEARCH_EVENT_NAMES: {
8
+ readonly search: "selectSearch.search";
9
+ };
10
+ export declare const SELECT_CLOSE_BTN_EVENT_NAMES: {
11
+ readonly close: "selectCloseBtn.close";
12
+ };
13
+ export declare const SELECT_RELATED_COMPONENTS_NAMES: {
14
+ readonly option: "h-option";
15
+ readonly options: "h-options";
16
+ readonly optionContent: "h-option-content";
17
+ readonly toggler: "h-select-toggler";
18
+ readonly closeBtn: "h-select-close-btn";
19
+ readonly search: "h-select-search";
20
+ };
21
+ export declare const SELECT_CLOSE_BUTTON_CONTENT_SLOT_NAME = "content";
22
+ export declare const SELECT_INPUT_PLACEHOLDER_SLOT_NAME = "placeholder";
@@ -0,0 +1,24 @@
1
+ const SELECT_OPTION_EVENT_NAMES = {
2
+ clicked: 'selectOption.clicked'
3
+ };
4
+ const SELECT_OPTIONS_EVENT_NAMES = {
5
+ clicked: 'selectOptions.clicked'
6
+ };
7
+ const SELECT_SEARCH_EVENT_NAMES = {
8
+ search: 'selectSearch.search'
9
+ };
10
+ const SELECT_CLOSE_BTN_EVENT_NAMES = {
11
+ close: 'selectCloseBtn.close'
12
+ };
13
+ const SELECT_RELATED_COMPONENTS_NAMES = {
14
+ option: 'h-option',
15
+ options: 'h-options',
16
+ optionContent: 'h-option-content',
17
+ toggler: 'h-select-toggler',
18
+ closeBtn: 'h-select-close-btn',
19
+ search: 'h-select-search'
20
+ };
21
+ const SELECT_INPUT_PLACEHOLDER_SLOT_NAME = 'placeholder';
22
+
23
+ export { SELECT_CLOSE_BTN_EVENT_NAMES, SELECT_INPUT_PLACEHOLDER_SLOT_NAME, SELECT_OPTIONS_EVENT_NAMES, SELECT_OPTION_EVENT_NAMES, SELECT_RELATED_COMPONENTS_NAMES, SELECT_SEARCH_EVENT_NAMES };
24
+ //# sourceMappingURL=select_components_constatns.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":null,"sources":[null],"sourcesContent":[null],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;"}
@@ -0,0 +1,4 @@
1
+ import { HOption } from "./option/select_option";
2
+ export declare type TSelectOptionClickedEvent = CustomEvent<{
3
+ $option: HOption;
4
+ }>;
@@ -0,0 +1,2 @@
1
+ import '@phoenixRoot/components/form/select/components/option/select_option';
2
+ //# sourceMappingURL=select_components_types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"select_components_types.js","sourceRoot":"","sources":["../../../../../../../../../src/components/form/select/components/select_components_types.ts"],"names":[],"mappings":"AAAA,OAAwB,qEAAqE,CAAC"}
@@ -0,0 +1,5 @@
1
+ import { PhoenixLightLitElement } from "../../../../core/phoenix_light_lit_element/phoenix_light_lit_element";
2
+ export declare class HOptions extends PhoenixLightLitElement {
3
+ constructor();
4
+ private _dispatchClickedEvent;
5
+ }
@@ -0,0 +1,29 @@
1
+ import { __decorate, __metadata } from '../../../../../../../external/tslib/tslib.es6.js';
2
+ import { UiDomUtils } from '@dreamcommerce/utilities';
3
+ import { PhoenixLightLitElement } from '../../../../core/phoenix_light_lit_element/phoenix_light_lit_element.js';
4
+ import { phoenixCustomElement } from '../../../../core/decorators/phoenix_custom_element.js';
5
+ import { SELECT_OPTIONS_EVENT_NAMES, SELECT_OPTION_EVENT_NAMES, SELECT_RELATED_COMPONENTS_NAMES } from './select_components_constatns.js';
6
+
7
+ let HOptions = class HOptions extends PhoenixLightLitElement {
8
+ constructor() {
9
+ super();
10
+ this._dispatchClickedEvent = ({ detail }) => {
11
+ this.dispatchEvent(new CustomEvent(SELECT_OPTIONS_EVENT_NAMES.clicked, {
12
+ bubbles: true,
13
+ detail: {
14
+ $option: detail.$option
15
+ }
16
+ }));
17
+ };
18
+ this.setAttribute('role', 'listbox');
19
+ UiDomUtils.makeNavigable(this);
20
+ this.addEventListener(SELECT_OPTION_EVENT_NAMES.clicked, this._dispatchClickedEvent);
21
+ }
22
+ };
23
+ HOptions = __decorate([
24
+ phoenixCustomElement(SELECT_RELATED_COMPONENTS_NAMES.options),
25
+ __metadata("design:paramtypes", [])
26
+ ], HOptions);
27
+
28
+ export { HOptions };
29
+ //# sourceMappingURL=select_options.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":null,"sources":[null],"sourcesContent":[null],"names":[],"mappings":"AAAA,uCAAuC,kDAAsD;AAC7F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;"}
@@ -0,0 +1,13 @@
1
+ import { PhoenixLightLitElement } from "../../../../../core/phoenix_light_lit_element/phoenix_light_lit_element";
2
+ import { SelectOption } from "../../model/select_option";
3
+ import { TemplateResult } from 'lit-html';
4
+ import { BehaviorSubject } from "../../../../../core/classes/behavior_subject/behavior_subject";
5
+ export declare class HSelectToggler extends PhoenixLightLitElement {
6
+ selectedOptions$: BehaviorSubject<SelectOption[]> | null;
7
+ isMultiselect: boolean;
8
+ private _contextConsumer;
9
+ connectedCallback(): void;
10
+ private _subscribeObserver;
11
+ private _dispatchOptionDeselect;
12
+ render(): TemplateResult | undefined;
13
+ }
@@ -0,0 +1,72 @@
1
+ import { __decorate, __metadata } from '../../../../../../../../external/tslib/tslib.es6.js';
2
+ import { state } from 'lit/decorators';
3
+ import { PhoenixLightLitElement } from '../../../../../core/phoenix_light_lit_element/phoenix_light_lit_element.js';
4
+ import { phoenixCustomElement } from '../../../../../core/decorators/phoenix_custom_element.js';
5
+ import { SELECT_INPUT_PLACEHOLDER_SLOT_NAME, SELECT_RELATED_COMPONENTS_NAMES } from '../select_components_constatns.js';
6
+ import { html } from 'lit-html';
7
+ import { ContextConsumerController } from '../../../../../core/context/context_consumer_controller.js';
8
+ import { SELECT_EVENT_NAMES, SELECT_SLOT_NAMES, SELECT_CONTEXTS } from '../../select_constants.js';
9
+ import { observe } from '../../../../../directives/observable_directive.js';
10
+ import { SELECT_TOGGLER_CSS_CLASSES } from './select_toggler_constants.js';
11
+
12
+ let HSelectToggler = class HSelectToggler extends PhoenixLightLitElement {
13
+ constructor() {
14
+ super(...arguments);
15
+ this._contextConsumer = new ContextConsumerController(this);
16
+ this._dispatchOptionDeselect = (option) => {
17
+ this.dispatchEvent(new CustomEvent(SELECT_EVENT_NAMES.deselectOption, {
18
+ detail: option.value,
19
+ bubbles: true
20
+ }));
21
+ };
22
+ }
23
+ connectedCallback() {
24
+ super.connectedCallback();
25
+ this.setAttribute('slot', SELECT_SLOT_NAMES.input);
26
+ this.setAttribute('role', 'textbox');
27
+ this.classList.add(SELECT_TOGGLER_CSS_CLASSES.selectToggler);
28
+ this._subscribeObserver();
29
+ }
30
+ async _subscribeObserver() {
31
+ this.isMultiselect = (await this._contextConsumer.consumeAsync(SELECT_CONTEXTS.isMultiselect));
32
+ this.selectedOptions$ = (await this._contextConsumer.consumeAsync(SELECT_CONTEXTS.selectedOptions$));
33
+ }
34
+ render() {
35
+ if (!this.selectedOptions$)
36
+ return;
37
+ return html `
38
+ <ul class=${SELECT_TOGGLER_CSS_CLASSES.selectTogglerValues}>
39
+ ${observe(this.selectedOptions$, (selectOptions) => {
40
+ var _a;
41
+ if (!selectOptions.length)
42
+ return html `${(_a = this.getSlot(SELECT_INPUT_PLACEHOLDER_SLOT_NAME)) !== null && _a !== void 0 ? _a : 'Select'}`;
43
+ return this.isMultiselect
44
+ ? html `${selectOptions.map((option) => html `<li>
45
+ <h-tag @tag.remove=${() => this._dispatchOptionDeselect(option)}>
46
+ ${option.content}
47
+
48
+ <h-tag-remove-button></h-tag-remove-button>
49
+ </h-tag>
50
+ </li>`)}`
51
+ : html `<li>${selectOptions[0].content}</li>`;
52
+ })}
53
+ </ul>
54
+
55
+ <h-icon icon-name="icon-chevron-down"></h-icon>
56
+ `;
57
+ }
58
+ };
59
+ __decorate([
60
+ state(),
61
+ __metadata("design:type", Object)
62
+ ], HSelectToggler.prototype, "selectedOptions$", void 0);
63
+ __decorate([
64
+ state(),
65
+ __metadata("design:type", Boolean)
66
+ ], HSelectToggler.prototype, "isMultiselect", void 0);
67
+ HSelectToggler = __decorate([
68
+ phoenixCustomElement(SELECT_RELATED_COMPONENTS_NAMES.toggler)
69
+ ], HSelectToggler);
70
+
71
+ export { HSelectToggler };
72
+ //# sourceMappingURL=select_toggler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":null,"sources":[null],"sourcesContent":[null],"names":[],"mappings":"AAAA,uCAAuC,qDAAyD;AAChG;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;"}
@@ -0,0 +1,4 @@
1
+ export declare const SELECT_TOGGLER_CSS_CLASSES: {
2
+ readonly selectToggler: "select-toggler";
3
+ readonly selectTogglerValues: "select-toggler__values";
4
+ };
@@ -0,0 +1,8 @@
1
+ const baseClass = 'select-toggler';
2
+ const SELECT_TOGGLER_CSS_CLASSES = {
3
+ selectToggler: baseClass,
4
+ selectTogglerValues: `${baseClass}__values`
5
+ };
6
+
7
+ export { SELECT_TOGGLER_CSS_CLASSES };
8
+ //# sourceMappingURL=select_toggler_constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":null,"sources":[null],"sourcesContent":[null],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;"}
@@ -0,0 +1,27 @@
1
+ import { ReactiveController, ReactiveControllerHost } from 'lit';
2
+ import { ISelectController, SelectControllerConstructorOptions } from "./select_controllers_types";
3
+ import { SelectOption } from "../model/select_option";
4
+ import { BehaviorSubject } from "../../../../core/classes/behavior_subject/behavior_subject";
5
+ import { HSelect } from "../select";
6
+ export declare abstract class BaseSelectController implements ISelectController, ReactiveController {
7
+ options$: BehaviorSubject<SelectOption[]>;
8
+ visibleOptionsCount: number;
9
+ selectedOptionsCount: number;
10
+ selectedOptions$: BehaviorSubject<SelectOption[]>;
11
+ protected host: HSelect & ReactiveControllerHost;
12
+ private _optionsObserver;
13
+ constructor({ host }: SelectControllerConstructorOptions);
14
+ private _setupComputedStateObserver;
15
+ private _calculateValuesRelatedToOptions;
16
+ toggleOption(option: SelectOption): void;
17
+ abstract selectOption(option: SelectOption): void;
18
+ removeOption(optionValue: string): void;
19
+ addOption(option: SelectOption, position?: number): void;
20
+ replaceOptions(options: SelectOption[]): void;
21
+ deselectOptions(): void;
22
+ deselectOption(option: SelectOption): void;
23
+ filterOptions(value: string): void;
24
+ protected requestOptionsUpdate(): void;
25
+ getSelectOption(selectValue: string): SelectOption | undefined;
26
+ hostConnected(): void;
27
+ }
@@ -0,0 +1,89 @@
1
+ import 'lit';
2
+ import { SearchingUtils } from '@dreamcommerce/utilities';
3
+ import { Observer } from '../../../../core/classes/observer/observer.js';
4
+ import { BehaviorSubject } from '../../../../core/classes/behavior_subject/behavior_subject.js';
5
+
6
+ class BaseSelectController {
7
+ constructor({ host }) {
8
+ this.options$ = new BehaviorSubject([]);
9
+ this.selectedOptions$ = new BehaviorSubject([]);
10
+ this._calculateValuesRelatedToOptions = (selectOptions) => {
11
+ const { visibleCount, selectedCount } = selectOptions.reduce((acc, option) => {
12
+ return {
13
+ visibleCount: !option.hidden ? acc.visibleCount + 1 : acc.visibleCount,
14
+ selectedCount: option.selected ? acc.selectedCount + 1 : acc.selectedCount
15
+ };
16
+ }, { visibleCount: 0, selectedCount: 0 });
17
+ this.visibleOptionsCount = visibleCount;
18
+ this.selectedOptionsCount = selectedCount;
19
+ this.selectedOptions$.notify(selectOptions.filter((option) => option.selected));
20
+ };
21
+ this.host = host;
22
+ this.host.addController(this);
23
+ this._setupComputedStateObserver();
24
+ }
25
+ _setupComputedStateObserver() {
26
+ this._optionsObserver = new Observer(this._calculateValuesRelatedToOptions);
27
+ this.options$.subscribe(this._optionsObserver);
28
+ }
29
+ toggleOption(option) {
30
+ option.selected ? this.deselectOption(option) : this.selectOption(option);
31
+ }
32
+ removeOption(optionValue) {
33
+ const options = this.options$.getValue();
34
+ if (!options)
35
+ return;
36
+ this.options$.notify(options.filter((option) => option.value !== optionValue));
37
+ }
38
+ addOption(option, position) {
39
+ var _a;
40
+ const options = (_a = this.options$.getValue()) !== null && _a !== void 0 ? _a : [];
41
+ if (position === undefined) {
42
+ options.push(option);
43
+ this.options$.notify(options);
44
+ return;
45
+ }
46
+ this.options$.notify([...options.slice(0, position - 1), option, ...options.slice(position - 1)]);
47
+ }
48
+ replaceOptions(options) {
49
+ this.options$.notify(options);
50
+ }
51
+ deselectOptions() {
52
+ var _a;
53
+ (_a = this.options$.getValue()) === null || _a === void 0 ? void 0 : _a.forEach((option) => (option.selected = false));
54
+ this.requestOptionsUpdate();
55
+ }
56
+ deselectOption(option) {
57
+ var _a;
58
+ (_a = this.options$.getValue()) === null || _a === void 0 ? void 0 : _a.forEach((option) => (option.selected = false));
59
+ this.requestOptionsUpdate();
60
+ }
61
+ filterOptions(value) {
62
+ const selectOptions = this.options$.getValue();
63
+ if (!selectOptions)
64
+ return;
65
+ const filtered = SearchingUtils.fuzzySearch(value, selectOptions, 'content');
66
+ selectOptions.forEach((option) => (option.hidden = true));
67
+ filtered.forEach((option) => {
68
+ option.hidden = false;
69
+ });
70
+ this.requestOptionsUpdate();
71
+ }
72
+ requestOptionsUpdate() {
73
+ const selectOptions = this.options$.getValue();
74
+ if (!selectOptions)
75
+ return;
76
+ this.options$.notify([...selectOptions]);
77
+ this.host.requestUpdate();
78
+ }
79
+ getSelectOption(selectValue) {
80
+ var _a;
81
+ return (_a = this.options$.getValue()) === null || _a === void 0 ? void 0 : _a.find((option) => option.value === selectValue);
82
+ }
83
+ hostConnected() {
84
+ this.options$.unsubscribe(this._optionsObserver);
85
+ }
86
+ }
87
+
88
+ export { BaseSelectController };
89
+ //# sourceMappingURL=base_select_controller.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":null,"sources":[null],"sourcesContent":[null],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;"}
@@ -0,0 +1,7 @@
1
+ import { SelectOption } from "../model/select_option";
2
+ import { BaseSelectController } from "./base_select_controller";
3
+ export declare class MultiSelectController extends BaseSelectController {
4
+ toggleOption(option: SelectOption): void;
5
+ selectOption(option: SelectOption): void;
6
+ deselectOption(option: SelectOption): void;
7
+ }
@@ -0,0 +1,18 @@
1
+ import { BaseSelectController } from './base_select_controller.js';
2
+
3
+ class MultiSelectController extends BaseSelectController {
4
+ toggleOption(option) {
5
+ option.selected ? this.deselectOption(option) : this.selectOption(option);
6
+ }
7
+ selectOption(option) {
8
+ option.selected = true;
9
+ this.requestOptionsUpdate();
10
+ }
11
+ deselectOption(option) {
12
+ option.selected = false;
13
+ this.requestOptionsUpdate();
14
+ }
15
+ }
16
+
17
+ export { MultiSelectController };
18
+ //# sourceMappingURL=multi_select_controller.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":null,"sources":[null],"sourcesContent":[null],"names":[],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;"}
@@ -0,0 +1,5 @@
1
+ import { SelectOption } from "../model/select_option";
2
+ import { BaseSelectController } from "./base_select_controller";
3
+ export declare class SelectController extends BaseSelectController {
4
+ selectOption(option: SelectOption): void;
5
+ }