@shoper/phoenix_design_system 1.0.4 → 1.1.0-1

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 (234) 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/cjs/external/lit/external/lit-html/async-directive.js.map +1 -0
  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 +57 -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/search/select_search.js +50 -0
  35. package/build/cjs/packages/phoenix/src/components/form/select/components/search/select_search.js.map +1 -0
  36. package/build/cjs/packages/phoenix/src/components/form/select/components/search/select_search_constants.js +13 -0
  37. package/build/cjs/packages/phoenix/src/components/form/select/components/search/select_search_constants.js.map +1 -0
  38. package/build/cjs/packages/phoenix/src/components/form/select/components/select_components_constatns.js +29 -0
  39. package/build/cjs/packages/phoenix/src/components/form/select/components/select_components_constatns.js.map +1 -0
  40. package/build/cjs/packages/phoenix/src/components/form/select/components/select_options.js +31 -0
  41. package/build/cjs/packages/phoenix/src/components/form/select/components/select_options.js.map +1 -0
  42. package/build/cjs/packages/phoenix/src/components/form/select/components/value/select_value.js +69 -0
  43. package/build/cjs/packages/phoenix/src/components/form/select/components/value/select_value.js.map +1 -0
  44. package/build/cjs/packages/phoenix/src/components/form/select/components/value/select_value_constants.js +10 -0
  45. package/build/cjs/packages/phoenix/src/components/form/select/components/value/select_value_constants.js.map +1 -0
  46. package/build/cjs/packages/phoenix/src/components/form/select/controllers/base_select_controller.js +93 -0
  47. package/build/cjs/packages/phoenix/src/components/form/select/controllers/base_select_controller.js.map +1 -0
  48. package/build/cjs/packages/phoenix/src/components/form/select/controllers/multi_select_controller.js +22 -0
  49. package/build/cjs/packages/phoenix/src/components/form/select/controllers/multi_select_controller.js.map +1 -0
  50. package/build/cjs/packages/phoenix/src/components/form/select/controllers/select_controller.js +19 -0
  51. package/build/cjs/packages/phoenix/src/components/form/select/controllers/select_controller.js.map +1 -0
  52. package/build/cjs/packages/phoenix/src/components/form/select/model/select_option.js +19 -0
  53. package/build/cjs/packages/phoenix/src/components/form/select/model/select_option.js.map +1 -0
  54. package/build/cjs/packages/phoenix/src/components/form/select/model/select_option_mapper.js +24 -0
  55. package/build/cjs/packages/phoenix/src/components/form/select/model/select_option_mapper.js.map +1 -0
  56. package/build/cjs/packages/phoenix/src/components/form/select/select.js +225 -0
  57. package/build/cjs/packages/phoenix/src/components/form/select/select.js.map +1 -0
  58. package/build/cjs/packages/phoenix/src/components/form/select/select_constants.js +35 -0
  59. package/build/cjs/packages/phoenix/src/components/form/select/select_constants.js.map +1 -0
  60. package/build/cjs/packages/phoenix/src/components/form/select/select_utils.js +52 -0
  61. package/build/cjs/packages/phoenix/src/components/form/select/select_utils.js.map +1 -0
  62. package/build/cjs/packages/phoenix/src/components/form/switch/switch.js +1 -1
  63. package/build/cjs/packages/phoenix/src/components/form/switch/switch.js.map +1 -1
  64. package/build/cjs/packages/phoenix/src/components/form/textarea/textarea.js +1 -1
  65. package/build/cjs/packages/phoenix/src/components/form/textarea/textarea.js.map +1 -1
  66. package/build/cjs/packages/phoenix/src/components/icon/icon.js +1 -1
  67. package/build/cjs/packages/phoenix/src/components/icon/icon.js.map +1 -1
  68. package/build/cjs/packages/phoenix/src/components/messages/base_message.js +1 -1
  69. package/build/cjs/packages/phoenix/src/components/modal/modal.js +4 -4
  70. package/build/cjs/packages/phoenix/src/components/portal/portal.js +1 -1
  71. package/build/cjs/packages/phoenix/src/components/portal/portal.js.map +1 -1
  72. package/build/cjs/packages/phoenix/src/components/portal/portal_target.js +1 -1
  73. package/build/cjs/packages/phoenix/src/components/scroll_to/scroll_to.js +1 -1
  74. package/build/cjs/packages/phoenix/src/components/tabs/tab/tab.js +1 -1
  75. package/build/cjs/packages/phoenix/src/components/tag/tag.js +3 -2
  76. package/build/cjs/packages/phoenix/src/components/tag/tag.js.map +1 -1
  77. package/build/cjs/packages/phoenix/src/controllers/{btn_controller.js → btn_controller/btn_controller.js} +4 -3
  78. package/build/cjs/packages/phoenix/src/controllers/btn_controller/btn_controller.js.map +1 -0
  79. package/build/cjs/packages/phoenix/src/controllers/keystrokes_controller/keystrokes_controller.js +4 -4
  80. package/build/cjs/packages/phoenix/src/controllers/list_box_controller/list_box_controller_constants.js +11 -0
  81. package/build/cjs/packages/phoenix/src/controllers/list_box_controller/list_box_controller_constants.js.map +1 -0
  82. package/build/cjs/packages/phoenix/src/controllers/list_box_controller/list_box_keyboard_controller.js +84 -0
  83. package/build/cjs/packages/phoenix/src/controllers/list_box_controller/list_box_keyboard_controller.js.map +1 -0
  84. package/build/cjs/packages/phoenix/src/core/classes/behavior_subject/behavior_subject.js +2 -7
  85. package/build/cjs/packages/phoenix/src/core/classes/behavior_subject/behavior_subject.js.map +1 -1
  86. package/build/cjs/packages/phoenix/src/core/classes/subject/subject.js +8 -1
  87. package/build/cjs/packages/phoenix/src/core/classes/subject/subject.js.map +1 -1
  88. package/build/cjs/packages/phoenix/src/core/context/context_consumer_controller.js +1 -1
  89. package/build/cjs/packages/phoenix/src/core/phoenix_light_lit_element/phoenix_light_lit_element.js +10 -5
  90. package/build/cjs/packages/phoenix/src/core/phoenix_light_lit_element/phoenix_light_lit_element.js.map +1 -1
  91. package/build/cjs/packages/phoenix/src/directives/observable_directive.js +40 -0
  92. package/build/cjs/packages/phoenix/src/directives/observable_directive.js.map +1 -0
  93. package/build/cjs/packages/phoenix/src/index.js +73 -45
  94. package/build/cjs/packages/phoenix/src/index.js.map +1 -1
  95. package/build/esm/{packages/phoenix/external → external}/classnames/index.js +10 -16
  96. package/build/{cjs/packages/phoenix → esm}/external/classnames/index.js.map +1 -1
  97. package/build/esm/external/lit/external/lit-html/async-directive.js +12 -0
  98. package/build/esm/external/lit/external/lit-html/async-directive.js.map +1 -0
  99. package/build/esm/external/lit/external/lit-html/directive-helpers.js +10 -0
  100. package/build/esm/external/lit/external/lit-html/directive-helpers.js.map +1 -0
  101. package/build/esm/external/lit/external/lit-html/directive.js +2 -2
  102. package/build/esm/packages/phoenix/src/components/accordion/accordion.js +1 -1
  103. package/build/esm/packages/phoenix/src/components/accordion/accordion_content.js +1 -1
  104. package/build/esm/packages/phoenix/src/components/accordion/accordion_group.js +2 -2
  105. package/build/esm/packages/phoenix/src/components/accordion/accordion_toggler.js +2 -2
  106. package/build/esm/packages/phoenix/src/components/color_swatches/color_item/color_item.js +1 -1
  107. package/build/esm/packages/phoenix/src/components/color_swatches/show-more/show_more.js +1 -1
  108. package/build/esm/packages/phoenix/src/components/dropdown/dropdown.js +3 -3
  109. package/build/esm/packages/phoenix/src/components/dropdown/dropdown_toggler.js +1 -1
  110. package/build/esm/packages/phoenix/src/components/form/checkbox/checkbox.js +1 -1
  111. package/build/esm/packages/phoenix/src/components/form/checkbox/checkbox.js.map +1 -1
  112. package/build/esm/packages/phoenix/src/components/form/checkbox/checkbox_control.js +2 -2
  113. package/build/esm/packages/phoenix/src/components/form/checkbox/checkbox_control.js.map +1 -1
  114. package/build/esm/packages/phoenix/src/components/form/color_swatches_control/color_swatches_control.d.ts +2 -3
  115. package/build/esm/packages/phoenix/src/components/form/color_swatches_control/color_swatches_control.js +11 -13
  116. package/build/esm/packages/phoenix/src/components/form/color_swatches_control/color_swatches_control.js.map +1 -1
  117. package/build/esm/packages/phoenix/src/components/form/controllers/props_synchronizing/control_props_sync_consumer_controller.js +1 -1
  118. package/build/esm/packages/phoenix/src/components/form/controllers/props_synchronizing/control_props_sync_provider_controller.js +1 -1
  119. package/build/esm/packages/phoenix/src/components/form/input/input.js +1 -1
  120. package/build/esm/packages/phoenix/src/components/form/input/input.js.map +1 -1
  121. package/build/esm/packages/phoenix/src/components/form/input/input_icon.js +1 -1
  122. package/build/esm/packages/phoenix/src/components/form/radio/radio.js +1 -1
  123. package/build/esm/packages/phoenix/src/components/form/radio/radio.js.map +1 -1
  124. package/build/esm/packages/phoenix/src/components/form/select/components/option/select_option.d.ts +11 -0
  125. package/build/esm/packages/phoenix/src/components/form/select/components/option/select_option.js +55 -0
  126. package/build/esm/packages/phoenix/src/components/form/select/components/option/select_option.js.map +1 -0
  127. package/build/esm/packages/phoenix/src/components/form/select/components/option/select_option_constants.d.ts +4 -0
  128. package/build/esm/packages/phoenix/src/components/form/select/components/option/select_option_constants.js +8 -0
  129. package/build/esm/packages/phoenix/src/components/form/select/components/option/select_option_constants.js.map +1 -0
  130. package/build/esm/packages/phoenix/src/components/form/select/components/option/select_option_content.d.ts +4 -0
  131. package/build/esm/packages/phoenix/src/components/form/select/components/option/select_option_content.js +16 -0
  132. package/build/esm/packages/phoenix/src/components/form/select/components/option/select_option_content.js.map +1 -0
  133. package/build/esm/packages/phoenix/src/components/form/select/components/search/select_search.d.ts +7 -0
  134. package/build/esm/packages/phoenix/src/components/form/select/components/search/select_search.js +48 -0
  135. package/build/esm/packages/phoenix/src/components/form/select/components/search/select_search.js.map +1 -0
  136. package/build/esm/packages/phoenix/src/components/form/select/components/search/select_search_constants.d.ts +5 -0
  137. package/build/esm/packages/phoenix/src/components/form/select/components/search/select_search_constants.js +9 -0
  138. package/build/esm/packages/phoenix/src/components/form/select/components/search/select_search_constants.js.map +1 -0
  139. package/build/esm/packages/phoenix/src/components/form/select/components/select_close_btn.d.ts +6 -0
  140. package/build/esm/packages/phoenix/src/components/form/select/components/select_close_btn.js +23 -0
  141. package/build/esm/packages/phoenix/src/components/form/select/components/select_close_btn.js.map +1 -0
  142. package/build/esm/packages/phoenix/src/components/form/select/components/select_components_constatns.d.ts +19 -0
  143. package/build/esm/packages/phoenix/src/components/form/select/components/select_components_constatns.js +21 -0
  144. package/build/esm/packages/phoenix/src/components/form/select/components/select_components_types.d.ts +4 -0
  145. package/build/esm/packages/phoenix/src/components/form/select/components/select_components_types.js +2 -0
  146. package/build/esm/packages/phoenix/src/components/form/select/components/select_components_types.js.map +1 -0
  147. package/build/esm/packages/phoenix/src/components/form/select/components/select_options.d.ts +5 -0
  148. package/build/esm/packages/phoenix/src/components/form/select/components/select_options.js +29 -0
  149. package/build/esm/packages/phoenix/src/components/form/select/components/select_options.js.map +1 -0
  150. package/build/esm/packages/phoenix/src/components/form/select/components/value/select_value.d.ts +13 -0
  151. package/build/esm/packages/phoenix/src/components/form/select/components/value/select_value.js +67 -0
  152. package/build/esm/packages/phoenix/src/components/form/select/components/value/select_value.js.map +1 -0
  153. package/build/esm/packages/phoenix/src/components/form/select/components/value/select_value_constants.d.ts +3 -0
  154. package/build/esm/packages/phoenix/src/components/form/select/components/value/select_value_constants.js +6 -0
  155. package/build/esm/packages/phoenix/src/components/form/select/components/value/select_value_constants.js.map +1 -0
  156. package/build/esm/packages/phoenix/src/components/form/select/controllers/base_select_controller.d.ts +27 -0
  157. package/build/esm/packages/phoenix/src/components/form/select/controllers/base_select_controller.js +89 -0
  158. package/build/esm/packages/phoenix/src/components/form/select/controllers/base_select_controller.js.map +1 -0
  159. package/build/esm/packages/phoenix/src/components/form/select/controllers/multi_select_controller.d.ts +7 -0
  160. package/build/esm/packages/phoenix/src/components/form/select/controllers/multi_select_controller.js +18 -0
  161. package/build/esm/packages/phoenix/src/components/form/select/controllers/multi_select_controller.js.map +1 -0
  162. package/build/esm/packages/phoenix/src/components/form/select/controllers/select_controller.d.ts +5 -0
  163. package/build/esm/packages/phoenix/src/components/form/select/controllers/select_controller.js +15 -0
  164. package/build/esm/packages/phoenix/src/components/form/select/controllers/select_controller.js.map +1 -0
  165. package/build/esm/packages/phoenix/src/components/form/select/controllers/select_controllers_types.d.ts +22 -0
  166. package/build/esm/packages/phoenix/src/components/form/select/controllers/select_controllers_types.js +5 -0
  167. package/build/esm/packages/phoenix/src/components/form/select/controllers/select_controllers_types.js.map +1 -0
  168. package/build/esm/packages/phoenix/src/components/form/select/model/select_option.d.ts +10 -0
  169. package/build/esm/packages/phoenix/src/components/form/select/model/select_option.js +15 -0
  170. package/build/esm/packages/phoenix/src/components/form/select/model/select_option.js.map +1 -0
  171. package/build/esm/packages/phoenix/src/components/form/select/model/select_option_constants.d.ts +7 -0
  172. package/build/esm/packages/phoenix/src/components/form/select/model/select_option_constants.js +2 -0
  173. package/build/esm/packages/phoenix/src/components/form/select/model/select_option_constants.js.map +1 -0
  174. package/build/esm/packages/phoenix/src/components/form/select/model/select_option_mapper.d.ts +5 -0
  175. package/build/esm/packages/phoenix/src/components/form/select/model/select_option_mapper.js +20 -0
  176. package/build/esm/packages/phoenix/src/components/form/select/model/select_option_mapper.js.map +1 -0
  177. package/build/esm/packages/phoenix/src/components/form/select/select.d.ts +37 -0
  178. package/build/esm/packages/phoenix/src/components/form/select/select.js +223 -0
  179. package/build/esm/packages/phoenix/src/components/form/select/select.js.map +1 -0
  180. package/build/esm/packages/phoenix/src/components/form/select/select_constants.d.ts +23 -0
  181. package/build/esm/packages/phoenix/src/components/form/select/select_constants.js +27 -0
  182. package/build/esm/packages/phoenix/src/components/form/select/select_constants.js.map +1 -0
  183. package/build/esm/packages/phoenix/src/components/form/select/select_utils.d.ts +9 -0
  184. package/build/esm/packages/phoenix/src/components/form/select/select_utils.js +48 -0
  185. package/build/esm/packages/phoenix/src/components/form/select/select_utils.js.map +1 -0
  186. package/build/esm/packages/phoenix/src/components/form/switch/switch.js +1 -1
  187. package/build/esm/packages/phoenix/src/components/form/switch/switch.js.map +1 -1
  188. package/build/esm/packages/phoenix/src/components/form/textarea/textarea.js +1 -1
  189. package/build/esm/packages/phoenix/src/components/form/textarea/textarea.js.map +1 -1
  190. package/build/esm/packages/phoenix/src/components/icon/icon.js +1 -1
  191. package/build/esm/packages/phoenix/src/components/icon/icon.js.map +1 -1
  192. package/build/esm/packages/phoenix/src/components/messages/base_message.js +1 -1
  193. package/build/esm/packages/phoenix/src/components/modal/modal.js +4 -4
  194. package/build/esm/packages/phoenix/src/components/portal/portal.js +1 -1
  195. package/build/esm/packages/phoenix/src/components/portal/portal.js.map +1 -1
  196. package/build/esm/packages/phoenix/src/components/portal/portal_target.js +1 -1
  197. package/build/esm/packages/phoenix/src/components/scroll_to/scroll_to.js +1 -1
  198. package/build/esm/packages/phoenix/src/components/tabs/tab/tab.js +1 -1
  199. package/build/esm/packages/phoenix/src/components/tag/tag.js +3 -2
  200. package/build/esm/packages/phoenix/src/components/tag/tag.js.map +1 -1
  201. package/build/esm/packages/phoenix/src/controllers/{btn_controller.d.ts → btn_controller/btn_controller.d.ts} +2 -1
  202. package/build/esm/packages/phoenix/src/controllers/{btn_controller.js → btn_controller/btn_controller.js} +4 -3
  203. package/build/{cjs/packages/phoenix/src/controllers → esm/packages/phoenix/src/controllers/btn_controller}/btn_controller.js.map +1 -1
  204. package/build/esm/packages/phoenix/src/controllers/btn_controller/btn_controller_types.d.ts +3 -0
  205. package/build/esm/packages/phoenix/src/controllers/btn_controller/btn_controller_types.js +2 -0
  206. package/build/esm/packages/phoenix/src/controllers/btn_controller/btn_controller_types.js.map +1 -0
  207. package/build/esm/packages/phoenix/src/controllers/keystrokes_controller/keystrokes_controller.js +4 -4
  208. package/build/esm/packages/phoenix/src/controllers/list_box_controller/list_box_controller_constants.d.ts +4 -0
  209. package/build/esm/packages/phoenix/src/controllers/list_box_controller/list_box_controller_constants.js +7 -0
  210. package/build/esm/packages/phoenix/src/controllers/list_box_controller/list_box_controller_constants.js.map +1 -0
  211. package/build/esm/packages/phoenix/src/controllers/list_box_controller/list_box_controller_types.d.ts +10 -0
  212. package/build/esm/packages/phoenix/src/controllers/list_box_controller/list_box_controller_types.js +4 -0
  213. package/build/esm/packages/phoenix/src/controllers/list_box_controller/list_box_controller_types.js.map +1 -0
  214. package/build/esm/packages/phoenix/src/controllers/list_box_controller/list_box_keyboard_controller.d.ts +10 -0
  215. package/build/esm/packages/phoenix/src/controllers/list_box_controller/list_box_keyboard_controller.js +80 -0
  216. package/build/esm/packages/phoenix/src/controllers/list_box_controller/list_box_keyboard_controller.js.map +1 -0
  217. package/build/esm/packages/phoenix/src/core/classes/behavior_subject/behavior_subject.d.ts +0 -2
  218. package/build/esm/packages/phoenix/src/core/classes/behavior_subject/behavior_subject.js +2 -7
  219. package/build/esm/packages/phoenix/src/core/classes/behavior_subject/behavior_subject.js.map +1 -1
  220. package/build/esm/packages/phoenix/src/core/classes/subject/subject.d.ts +4 -2
  221. package/build/esm/packages/phoenix/src/core/classes/subject/subject.js +8 -1
  222. package/build/esm/packages/phoenix/src/core/classes/subject/subject.js.map +1 -1
  223. package/build/esm/packages/phoenix/src/core/classes/subject/subject_types.d.ts +2 -1
  224. package/build/esm/packages/phoenix/src/core/context/context_consumer_controller.js +1 -1
  225. package/build/esm/packages/phoenix/src/core/phoenix_light_lit_element/phoenix_light_lit_element.js +10 -5
  226. package/build/esm/packages/phoenix/src/core/phoenix_light_lit_element/phoenix_light_lit_element.js.map +1 -1
  227. package/build/esm/packages/phoenix/src/directives/observable_directive.d.ts +1 -0
  228. package/build/esm/packages/phoenix/src/directives/observable_directive.js +35 -31
  229. package/build/esm/packages/phoenix/src/directives/observable_directive.js.map +1 -1
  230. package/build/esm/packages/phoenix/src/index.d.ts +5 -1
  231. package/build/esm/packages/phoenix/src/index.js +16 -12
  232. package/build/esm/packages/phoenix/src/index.js.map +1 -1
  233. package/package.json +2 -2
  234. /package/build/esm/packages/phoenix/src/{controllers/btn_controller.js.map → components/form/select/components/select_components_constatns.js.map} +0 -0
@@ -0,0 +1,55 @@
1
+ import { __decorate, __metadata } 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 { property } from '@lit/reactive-element/decorators.js';
5
+ import { SELECT_OPTION_EVENT_NAMES, SELECT_RELATED_COMPONENTS_NAMES } from '../select_components_constatns.js';
6
+ import { BtnController } from '../../../../../controllers/btn_controller/btn_controller.js';
7
+ import { SELECT_OPTION_CSS_CLASSES } from './select_option_constants.js';
8
+
9
+ let HOption = class HOption extends PhoenixLightLitElement {
10
+ constructor() {
11
+ super(...arguments);
12
+ this._dispatchClickedEvent = () => {
13
+ if (this.disabled)
14
+ return;
15
+ this.dispatchEvent(new CustomEvent(SELECT_OPTION_EVENT_NAMES.clicked, {
16
+ bubbles: true,
17
+ detail: {
18
+ $option: this
19
+ }
20
+ }));
21
+ };
22
+ }
23
+ connectedCallback() {
24
+ super.connectedCallback();
25
+ this._btnController = new BtnController(this, this._dispatchClickedEvent);
26
+ this.classList.add(SELECT_OPTION_CSS_CLASSES.selectOption);
27
+ this.setAttribute('role', 'option');
28
+ this._setupEvents();
29
+ }
30
+ _setupEvents() {
31
+ this.addEventListener('click', this._dispatchClickedEvent);
32
+ }
33
+ };
34
+ __decorate([
35
+ property({ type: String, reflect: true }),
36
+ __metadata("design:type", String)
37
+ ], HOption.prototype, "value", void 0);
38
+ __decorate([
39
+ property({ type: Boolean, reflect: true }),
40
+ __metadata("design:type", Boolean)
41
+ ], HOption.prototype, "selected", void 0);
42
+ __decorate([
43
+ property({ type: Boolean, reflect: true }),
44
+ __metadata("design:type", Boolean)
45
+ ], HOption.prototype, "disabled", void 0);
46
+ __decorate([
47
+ property({ type: Boolean, reflect: true }),
48
+ __metadata("design:type", Boolean)
49
+ ], HOption.prototype, "hidden", void 0);
50
+ HOption = __decorate([
51
+ phoenixCustomElement(SELECT_RELATED_COMPONENTS_NAMES.option)
52
+ ], HOption);
53
+
54
+ export { HOption };
55
+ //# 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;"}
@@ -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 HSelectOptionContent extends PhoenixLightLitElement {
3
+ connectedCallback(): void;
4
+ }
@@ -0,0 +1,16 @@
1
+ import { __decorate } from "tslib";
2
+ import { phoenixCustomElement } from '@phoenixRoot/core/decorators/phoenix_custom_element';
3
+ import { SELECT_RELATED_COMPONENTS_NAMES } from '@phoenixRoot/components/form/select/components/select_components_constatns';
4
+ import { SELECT_OPTION_CSS_CLASSES } from '@phoenixRoot/components/form/select/components/option/select_option_constants';
5
+ import { PhoenixLightLitElement } from '@phoenixRoot/core/phoenix_light_lit_element/phoenix_light_lit_element';
6
+ let HSelectOptionContent = class HSelectOptionContent extends PhoenixLightLitElement {
7
+ connectedCallback() {
8
+ super.connectedCallback();
9
+ this.classList.add(SELECT_OPTION_CSS_CLASSES.selectOptionContent);
10
+ }
11
+ };
12
+ HSelectOptionContent = __decorate([
13
+ phoenixCustomElement(SELECT_RELATED_COMPONENTS_NAMES.optionContent)
14
+ ], HSelectOptionContent);
15
+ export { HSelectOptionContent };
16
+ //# sourceMappingURL=select_option_content.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"select_option_content.js","sourceRoot":"","sources":["../../../../../../../../../../src/components/form/select/components/option/select_option_content.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,qDAAqD,CAAC;AAC3F,OAAO,EAAE,+BAA+B,EAAE,MAAM,4EAA4E,CAAC;AAC7H,OAAO,EAAE,yBAAyB,EAAE,MAAM,+EAA+E,CAAC;AAC1H,OAAO,EAAE,sBAAsB,EAAE,MAAM,uEAAuE,CAAC;AAG/G,IAAa,oBAAoB,GAAjC,MAAa,oBAAqB,SAAQ,sBAAsB;IACrD,iBAAiB;QACpB,KAAK,CAAC,iBAAiB,EAAE,CAAC;QAE1B,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,yBAAyB,CAAC,mBAAmB,CAAC,CAAC;IACtE,CAAC;CACJ,CAAA;AANY,oBAAoB;IADhC,oBAAoB,CAAC,+BAA+B,CAAC,aAAa,CAAC;GACvD,oBAAoB,CAMhC;SANY,oBAAoB"}
@@ -0,0 +1,7 @@
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
+ private _handleInputChange;
6
+ protected render(): TemplateResult;
7
+ }
@@ -0,0 +1,48 @@
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
+ render() {
23
+ return html `
24
+ <div class=${SELECT_SEARCH_CSS_CLASSES.selectSearch}>
25
+ <h-icon icon-name="icon-search" class=${SELECT_SEARCH_CSS_CLASSES.selectSearchIcon}></h-icon>
26
+ <input
27
+ class=${SELECT_SEARCH_CSS_CLASSES.selectSearchInput}
28
+ type="text"
29
+ role="search"
30
+ .value=${this.value}
31
+ aria-autocomplete="list"
32
+ autocomplete="false"
33
+ @input=${this._handleInputChange}
34
+ />
35
+ </div>
36
+ `;
37
+ }
38
+ };
39
+ __decorate([
40
+ property({ type: String, reflect: true }),
41
+ __metadata("design:type", String)
42
+ ], HSelectSearch.prototype, "value", void 0);
43
+ HSelectSearch = __decorate([
44
+ phoenixCustomElement(SELECT_RELATED_COMPONENTS_NAMES.search)
45
+ ], HSelectSearch);
46
+
47
+ export { HSelectSearch };
48
+ //# 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;"}
@@ -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,6 @@
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
+ connectedCallback(): void;
5
+ render(): TemplateResult;
6
+ }
@@ -0,0 +1,23 @@
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_BUTTON_CONTENT_SLOT_NAME, SELECT_RELATED_COMPONENTS_NAMES } from '@phoenixRoot/components/form/select/components/select_components_constatns';
6
+ let SelectCloseBtn = class SelectCloseBtn extends PhoenixLightLitElement {
7
+ connectedCallback() {
8
+ super.connectedCallback();
9
+ this.setAttribute('role', 'presentation');
10
+ }
11
+ render() {
12
+ return html `<button aria-label="close select">
13
+ ${this.hasSlot(SELECT_CLOSE_BUTTON_CONTENT_SLOT_NAME)
14
+ ? this.getSlot(SELECT_CLOSE_BUTTON_CONTENT_SLOT_NAME)
15
+ : html `<icon iconName="icon-x"></icon>`}
16
+ </button> `;
17
+ }
18
+ };
19
+ SelectCloseBtn = __decorate([
20
+ phoenixCustomElement(SELECT_RELATED_COMPONENTS_NAMES.closeBtn)
21
+ ], SelectCloseBtn);
22
+ export { SelectCloseBtn };
23
+ //# 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,qCAAqC,EACrC,+BAA+B,EAClC,MAAM,4EAA4E,CAAC;AAGpF,IAAa,cAAc,GAA3B,MAAa,cAAe,SAAQ,sBAAsB;IAC/C,iBAAiB;QACpB,KAAK,CAAC,iBAAiB,EAAE,CAAC;QAE1B,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;IAC9C,CAAC;IAEM,MAAM;QACT,OAAO,IAAI,CAAA;cACL,IAAI,CAAC,OAAO,CAAC,qCAAqC,CAAC;YACjD,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,qCAAqC,CAAC;YACrD,CAAC,CAAC,IAAI,CAAA,iCAAiC;mBACpC,CAAC;IAChB,CAAC;CACJ,CAAA;AAdY,cAAc;IAD1B,oBAAoB,CAAC,+BAA+B,CAAC,QAAQ,CAAC;GAClD,cAAc,CAc1B;SAdY,cAAc"}
@@ -0,0 +1,19 @@
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_RELATED_COMPONENTS_NAMES: {
11
+ readonly option: "h-option";
12
+ readonly options: "h-select-options";
13
+ readonly optionContent: "h-option-content";
14
+ readonly value: "h-select-value";
15
+ readonly closeBtn: "h-select-close-btn";
16
+ readonly search: "h-select-search";
17
+ };
18
+ export declare const SELECT_CLOSE_BUTTON_CONTENT_SLOT_NAME = "content";
19
+ export declare const SELECT_INPUT_PLACEHOLDER_SLOT_NAME = "placeholder";
@@ -0,0 +1,21 @@
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_RELATED_COMPONENTS_NAMES = {
11
+ option: 'h-option',
12
+ options: 'h-select-options',
13
+ optionContent: 'h-option-content',
14
+ value: 'h-select-value',
15
+ closeBtn: 'h-select-close-btn',
16
+ search: 'h-select-search'
17
+ };
18
+ const SELECT_INPUT_PLACEHOLDER_SLOT_NAME = 'placeholder';
19
+
20
+ export { SELECT_INPUT_PLACEHOLDER_SLOT_NAME, SELECT_OPTIONS_EVENT_NAMES, SELECT_OPTION_EVENT_NAMES, SELECT_RELATED_COMPONENTS_NAMES, SELECT_SEARCH_EVENT_NAMES };
21
+ //# sourceMappingURL=select_components_constatns.js.map
@@ -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 HSelectOptions 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 HSelectOptions = class HSelectOptions 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
+ HSelectOptions = __decorate([
24
+ phoenixCustomElement(SELECT_RELATED_COMPONENTS_NAMES.options),
25
+ __metadata("design:paramtypes", [])
26
+ ], HSelectOptions);
27
+
28
+ export { HSelectOptions };
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 HSelectValue 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,67 @@
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_VALUE_CSS_CLASSES } from './select_value_constants.js';
11
+
12
+ let HSelectValue = class HSelectValue 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._subscribeObserver();
28
+ }
29
+ async _subscribeObserver() {
30
+ this.isMultiselect = (await this._contextConsumer.consumeAsync(SELECT_CONTEXTS.isMultiselect));
31
+ this.selectedOptions$ = (await this._contextConsumer.consumeAsync(SELECT_CONTEXTS.selectedOptions$));
32
+ }
33
+ render() {
34
+ if (!this.selectedOptions$)
35
+ return;
36
+ return html `
37
+ <div class=${SELECT_VALUE_CSS_CLASSES.selectValue}>
38
+ ${observe(this.selectedOptions$, (selectOptions) => {
39
+ var _a;
40
+ if (!selectOptions.length)
41
+ return html `${(_a = this.getSlot(SELECT_INPUT_PLACEHOLDER_SLOT_NAME)) !== null && _a !== void 0 ? _a : 'Select'}`;
42
+ return this.isMultiselect
43
+ ? html `${selectOptions.map((option) => html `<h-tag @tag.remove=${() => this._dispatchOptionDeselect(option)}>
44
+ ${option.content}
45
+
46
+ <h-tag-remove-button>x</h-tag-remove-button>
47
+ </h-tag>`)}`
48
+ : selectOptions[0].content;
49
+ })}
50
+ </div>
51
+ `;
52
+ }
53
+ };
54
+ __decorate([
55
+ state(),
56
+ __metadata("design:type", Object)
57
+ ], HSelectValue.prototype, "selectedOptions$", void 0);
58
+ __decorate([
59
+ state(),
60
+ __metadata("design:type", Boolean)
61
+ ], HSelectValue.prototype, "isMultiselect", void 0);
62
+ HSelectValue = __decorate([
63
+ phoenixCustomElement(SELECT_RELATED_COMPONENTS_NAMES.value)
64
+ ], HSelectValue);
65
+
66
+ export { HSelectValue };
67
+ //# sourceMappingURL=select_value.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;"}
@@ -0,0 +1,3 @@
1
+ export declare const SELECT_VALUE_CSS_CLASSES: {
2
+ readonly selectValue: "select-value";
3
+ };
@@ -0,0 +1,6 @@
1
+ const SELECT_VALUE_CSS_CLASSES = {
2
+ selectValue: 'select-value'
3
+ };
4
+
5
+ export { SELECT_VALUE_CSS_CLASSES };
6
+ //# sourceMappingURL=select_value_constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":null,"sources":[null],"sourcesContent":[null],"names":[],"mappings":"AAAA;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
+ }
@@ -0,0 +1,15 @@
1
+ import { BaseSelectController } from './base_select_controller.js';
2
+
3
+ class SelectController extends BaseSelectController {
4
+ selectOption(option) {
5
+ var _a;
6
+ const selectedOptions = (_a = this.options$.getValue()) !== null && _a !== void 0 ? _a : [];
7
+ selectedOptions.forEach((option) => (option.selected = false));
8
+ option.selected = true;
9
+ this.selectedOptions$.notify([option]);
10
+ this.requestOptionsUpdate();
11
+ }
12
+ }
13
+
14
+ export { SelectController };
15
+ //# sourceMappingURL=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;"}
@@ -0,0 +1,22 @@
1
+ import { ReactiveControllerHost } from 'lit';
2
+ import { SelectOption } from "../model/select_option";
3
+ import { BehaviorSubject } from "../../../../core/classes/behavior_subject/behavior_subject";
4
+ import { HSelect } from "../select";
5
+ export declare type SelectControllerConstructorOptions = {
6
+ host: HSelect & ReactiveControllerHost;
7
+ };
8
+ export interface ISelectController {
9
+ selectedOptions$: BehaviorSubject<SelectOption[]>;
10
+ options$: BehaviorSubject<SelectOption[]>;
11
+ visibleOptionsCount: number;
12
+ selectedOptionsCount: number;
13
+ deselectOptions(): void;
14
+ deselectOption(option: SelectOption): void;
15
+ filterOptions(value: string): void;
16
+ toggleOption(option: SelectOption): void;
17
+ selectOption(option: SelectOption): void;
18
+ getSelectOption(selectValue: string): SelectOption | undefined;
19
+ removeOption(optionValue: string): void;
20
+ addOption(option: SelectOption, position?: number): void;
21
+ replaceOptions(options: SelectOption[]): void;
22
+ }