@sankhyalabs/ezui 5.22.0-dev.90 → 5.22.0-dev.91

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 (193) hide show
  1. package/dist/cjs/ez-actions-button.cjs.entry.js +1 -1
  2. package/dist/cjs/ez-alert-list.cjs.entry.js +1 -1
  3. package/dist/cjs/ez-alert.cjs.entry.js +1 -1
  4. package/dist/cjs/ez-application.cjs.entry.js +1 -1
  5. package/dist/cjs/ez-badge.cjs.entry.js +1 -1
  6. package/dist/cjs/ez-breadcrumb.cjs.entry.js +1 -1
  7. package/dist/cjs/ez-button.cjs.entry.js +1 -1
  8. package/dist/cjs/ez-calendar.cjs.entry.js +1 -1
  9. package/dist/cjs/ez-card-item_2.cjs.entry.js +1 -1
  10. package/dist/cjs/ez-chart.cjs.entry.js +1 -1
  11. package/dist/cjs/ez-check.cjs.entry.js +1 -1
  12. package/dist/cjs/ez-chip.cjs.entry.js +1 -1
  13. package/dist/cjs/ez-collapsible-box.cjs.entry.js +1 -1
  14. package/dist/cjs/ez-combo-box-list_3.cjs.entry.js +366 -0
  15. package/dist/cjs/ez-combo-box.cjs.entry.js +59 -185
  16. package/dist/cjs/ez-date-input.cjs.entry.js +1 -1
  17. package/dist/cjs/ez-date-time-input.cjs.entry.js +1 -1
  18. package/dist/cjs/ez-dialog.cjs.entry.js +1 -1
  19. package/dist/cjs/ez-double-list.cjs.entry.js +1 -1
  20. package/dist/cjs/ez-dropdown_2.cjs.entry.js +1 -1
  21. package/dist/cjs/ez-file-item.cjs.entry.js +1 -1
  22. package/dist/cjs/ez-filter-input.cjs.entry.js +1 -1
  23. package/dist/cjs/ez-form-view.cjs.entry.js +1 -1
  24. package/dist/cjs/ez-form.cjs.entry.js +1 -1
  25. package/dist/cjs/ez-grid.cjs.entry.js +1 -1
  26. package/dist/cjs/ez-guide-navigator.cjs.entry.js +1 -1
  27. package/dist/cjs/ez-icon.cjs.entry.js +1 -1
  28. package/dist/cjs/ez-list.cjs.entry.js +1 -1
  29. package/dist/cjs/ez-loading-bar.cjs.entry.js +1 -1
  30. package/dist/cjs/ez-modal-container.cjs.entry.js +1 -1
  31. package/dist/cjs/ez-modal.cjs.entry.js +1 -1
  32. package/dist/cjs/ez-multi-selection-list.cjs.entry.js +186 -0
  33. package/dist/cjs/ez-number-input.cjs.entry.js +1 -1
  34. package/dist/cjs/{ez-multi-selection-list_2.cjs.entry.js → ez-popover-core_2.cjs.entry.js} +116 -197
  35. package/dist/cjs/ez-popover.cjs.entry.js +1 -1
  36. package/dist/cjs/ez-popup.cjs.entry.js +1 -1
  37. package/dist/cjs/ez-radio-button.cjs.entry.js +1 -1
  38. package/dist/cjs/ez-scroller_2.cjs.entry.js +1 -1
  39. package/dist/cjs/ez-search.cjs.entry.js +1 -1
  40. package/dist/cjs/ez-sidebar-navigator.cjs.entry.js +1 -1
  41. package/dist/cjs/ez-split-button.cjs.entry.js +1 -1
  42. package/dist/cjs/ez-split-item.cjs.entry.js +1 -1
  43. package/dist/cjs/ez-split-panel.cjs.entry.js +1 -1
  44. package/dist/cjs/ez-tabselector.cjs.entry.js +1 -1
  45. package/dist/cjs/ez-text-area.cjs.entry.js +1 -1
  46. package/dist/cjs/ez-text-input.cjs.entry.js +1 -1
  47. package/dist/cjs/ez-time-input.cjs.entry.js +1 -1
  48. package/dist/cjs/ez-toast.cjs.entry.js +1 -1
  49. package/dist/cjs/ez-tooltip.cjs.entry.js +1 -1
  50. package/dist/cjs/ez-tree.cjs.entry.js +1 -1
  51. package/dist/cjs/ez-upload.cjs.entry.js +1 -1
  52. package/dist/cjs/ez-view-stack.cjs.entry.js +1 -1
  53. package/dist/cjs/ezui.cjs.js +2 -2
  54. package/dist/cjs/filter-column.cjs.entry.js +1 -1
  55. package/dist/cjs/{index-9e5554cb.js → index-a7b0c73d.js} +8 -7
  56. package/dist/cjs/loader.cjs.js +2 -2
  57. package/dist/collection/collection-manifest.json +2 -0
  58. package/dist/collection/components/ez-combo-box/ez-combo-box-list/ez-combo-box-list.css +205 -0
  59. package/dist/collection/components/ez-combo-box/ez-combo-box-list/ez-combo-box-list.js +405 -0
  60. package/dist/collection/components/ez-combo-box/ez-combo-box.css +0 -250
  61. package/dist/collection/components/ez-combo-box/ez-combo-box.js +61 -194
  62. package/dist/collection/components/ez-popover-plus/ez-popover-plus.css +0 -64
  63. package/dist/collection/components/ez-popover-plus/ez-popover-plus.js +47 -127
  64. package/dist/collection/components/ez-popover-plus/subcomponent/ez-popover-core.css +67 -0
  65. package/dist/collection/components/ez-popover-plus/subcomponent/ez-popover-core.js +468 -0
  66. package/dist/custom-elements/index.d.ts +12 -0
  67. package/dist/custom-elements/index.js +312 -203
  68. package/dist/esm/ez-actions-button.entry.js +1 -1
  69. package/dist/esm/ez-alert-list.entry.js +1 -1
  70. package/dist/esm/ez-alert.entry.js +1 -1
  71. package/dist/esm/ez-application.entry.js +1 -1
  72. package/dist/esm/ez-badge.entry.js +1 -1
  73. package/dist/esm/ez-breadcrumb.entry.js +1 -1
  74. package/dist/esm/ez-button.entry.js +1 -1
  75. package/dist/esm/ez-calendar.entry.js +1 -1
  76. package/dist/esm/ez-card-item_2.entry.js +1 -1
  77. package/dist/esm/ez-chart.entry.js +1 -1
  78. package/dist/esm/ez-check.entry.js +1 -1
  79. package/dist/esm/ez-chip.entry.js +1 -1
  80. package/dist/esm/ez-collapsible-box.entry.js +1 -1
  81. package/dist/esm/ez-combo-box-list_3.entry.js +360 -0
  82. package/dist/esm/ez-combo-box.entry.js +60 -186
  83. package/dist/esm/ez-date-input.entry.js +1 -1
  84. package/dist/esm/ez-date-time-input.entry.js +1 -1
  85. package/dist/esm/ez-dialog.entry.js +1 -1
  86. package/dist/esm/ez-double-list.entry.js +1 -1
  87. package/dist/esm/ez-dropdown_2.entry.js +1 -1
  88. package/dist/esm/ez-file-item.entry.js +1 -1
  89. package/dist/esm/ez-filter-input.entry.js +1 -1
  90. package/dist/esm/ez-form-view.entry.js +1 -1
  91. package/dist/esm/ez-form.entry.js +1 -1
  92. package/dist/esm/ez-grid.entry.js +1 -1
  93. package/dist/esm/ez-guide-navigator.entry.js +1 -1
  94. package/dist/esm/ez-icon.entry.js +1 -1
  95. package/dist/esm/ez-list.entry.js +1 -1
  96. package/dist/esm/ez-loading-bar.entry.js +1 -1
  97. package/dist/esm/ez-modal-container.entry.js +1 -1
  98. package/dist/esm/ez-modal.entry.js +1 -1
  99. package/dist/esm/ez-multi-selection-list.entry.js +182 -0
  100. package/dist/esm/ez-number-input.entry.js +1 -1
  101. package/dist/esm/{ez-multi-selection-list_2.entry.js → ez-popover-core_2.entry.js} +116 -197
  102. package/dist/esm/ez-popover.entry.js +1 -1
  103. package/dist/esm/ez-popup.entry.js +1 -1
  104. package/dist/esm/ez-radio-button.entry.js +1 -1
  105. package/dist/esm/ez-scroller_2.entry.js +1 -1
  106. package/dist/esm/ez-search.entry.js +1 -1
  107. package/dist/esm/ez-sidebar-navigator.entry.js +1 -1
  108. package/dist/esm/ez-split-button.entry.js +1 -1
  109. package/dist/esm/ez-split-item.entry.js +1 -1
  110. package/dist/esm/ez-split-panel.entry.js +1 -1
  111. package/dist/esm/ez-tabselector.entry.js +1 -1
  112. package/dist/esm/ez-text-area.entry.js +1 -1
  113. package/dist/esm/ez-text-input.entry.js +1 -1
  114. package/dist/esm/ez-time-input.entry.js +1 -1
  115. package/dist/esm/ez-toast.entry.js +1 -1
  116. package/dist/esm/ez-tooltip.entry.js +1 -1
  117. package/dist/esm/ez-tree.entry.js +1 -1
  118. package/dist/esm/ez-upload.entry.js +1 -1
  119. package/dist/esm/ez-view-stack.entry.js +1 -1
  120. package/dist/esm/ezui.js +3 -3
  121. package/dist/esm/filter-column.entry.js +1 -1
  122. package/dist/esm/{index-5a720e56.js → index-baa5e267.js} +9 -7
  123. package/dist/esm/loader.js +3 -3
  124. package/dist/ezui/ezui.esm.js +1 -1
  125. package/dist/ezui/{p-e6b38ade.entry.js → p-0306dff7.entry.js} +1 -1
  126. package/dist/ezui/{p-91ccae0c.entry.js → p-09de35a2.entry.js} +1 -1
  127. package/dist/ezui/{p-88c615f0.entry.js → p-0fa52b0f.entry.js} +1 -1
  128. package/dist/ezui/{p-92fbaf2b.entry.js → p-0faf71c5.entry.js} +1 -1
  129. package/dist/ezui/p-15134d97.entry.js +1 -0
  130. package/dist/ezui/{p-b2f6bc0a.entry.js → p-17be134a.entry.js} +1 -1
  131. package/dist/ezui/{p-c96fbbef.entry.js → p-17de16e5.entry.js} +1 -1
  132. package/dist/ezui/{p-24b42f3d.entry.js → p-17eabf46.entry.js} +1 -1
  133. package/dist/ezui/{p-3885e66e.entry.js → p-1ad6c61b.entry.js} +1 -1
  134. package/dist/ezui/{p-81461d2f.entry.js → p-1e7a8633.entry.js} +1 -1
  135. package/dist/ezui/{p-6b51c9cc.entry.js → p-1f50fa05.entry.js} +1 -1
  136. package/dist/ezui/{p-cf33bc48.entry.js → p-20c024f7.entry.js} +1 -1
  137. package/dist/ezui/{p-e4c7eb39.js → p-23a36bb6.js} +2 -2
  138. package/dist/ezui/{p-6d31c43c.entry.js → p-2bb2a0c4.entry.js} +1 -1
  139. package/dist/ezui/{p-ca8936df.entry.js → p-2f45506d.entry.js} +1 -1
  140. package/dist/ezui/{p-9fc250d4.entry.js → p-3195a7a7.entry.js} +1 -1
  141. package/dist/ezui/{p-23dab72f.entry.js → p-31b71e50.entry.js} +1 -1
  142. package/dist/ezui/{p-b22889ea.entry.js → p-3429080c.entry.js} +1 -1
  143. package/dist/ezui/{p-0378416a.entry.js → p-44caad9a.entry.js} +1 -1
  144. package/dist/ezui/{p-9e5bbe25.entry.js → p-463be973.entry.js} +1 -1
  145. package/dist/ezui/{p-7567ccdd.entry.js → p-555c9018.entry.js} +1 -1
  146. package/dist/ezui/{p-3791d9c8.entry.js → p-556468d9.entry.js} +1 -1
  147. package/dist/ezui/{p-9066b0b0.entry.js → p-56fe5341.entry.js} +1 -1
  148. package/dist/ezui/{p-cf3b60fd.entry.js → p-58783dcf.entry.js} +1 -1
  149. package/dist/ezui/{p-044d46d5.entry.js → p-5b205c80.entry.js} +1 -1
  150. package/dist/ezui/{p-6fc26622.entry.js → p-5ed81457.entry.js} +1 -1
  151. package/dist/ezui/{p-f1c2c19e.entry.js → p-650e4b6d.entry.js} +1 -1
  152. package/dist/ezui/{p-03b0ed5a.entry.js → p-65f471bc.entry.js} +1 -1
  153. package/dist/ezui/{p-6d8b3298.entry.js → p-6cdd3e0a.entry.js} +1 -1
  154. package/dist/ezui/{p-fc194825.entry.js → p-6e429cff.entry.js} +1 -1
  155. package/dist/ezui/{p-11bfeca3.entry.js → p-77a4bd35.entry.js} +1 -1
  156. package/dist/ezui/p-7bd15498.entry.js +1 -0
  157. package/dist/ezui/{p-2069c78a.entry.js → p-7e677b7b.entry.js} +1 -1
  158. package/dist/ezui/{p-e18d9e6a.entry.js → p-7fdd479f.entry.js} +1 -1
  159. package/dist/ezui/{p-82fa4b09.entry.js → p-8df1ca33.entry.js} +1 -1
  160. package/dist/ezui/{p-a921e3e7.entry.js → p-990b4318.entry.js} +1 -1
  161. package/dist/ezui/{p-c2b20f78.entry.js → p-9f5fa3f9.entry.js} +1 -1
  162. package/dist/ezui/{p-0cfbbe82.entry.js → p-a4cee65d.entry.js} +1 -1
  163. package/dist/ezui/{p-dfca5946.entry.js → p-a80b1287.entry.js} +1 -1
  164. package/dist/ezui/{p-f30e0590.entry.js → p-b26f6c5b.entry.js} +1 -1
  165. package/dist/ezui/p-bc2f844e.entry.js +1 -0
  166. package/dist/ezui/{p-92748142.entry.js → p-c0d9c4f8.entry.js} +1 -1
  167. package/dist/ezui/{p-4818b8ce.entry.js → p-c1527804.entry.js} +1 -1
  168. package/dist/ezui/{p-b9282c79.entry.js → p-cb1535f7.entry.js} +1 -1
  169. package/dist/ezui/{p-f4da7e1e.entry.js → p-cf87aacb.entry.js} +1 -1
  170. package/dist/ezui/{p-5010315a.entry.js → p-d9548bdf.entry.js} +1 -1
  171. package/dist/ezui/{p-708b196e.entry.js → p-da1b4a38.entry.js} +1 -1
  172. package/dist/ezui/p-dc73e1fe.entry.js +1 -0
  173. package/dist/ezui/{p-bef7daac.entry.js → p-e347df9c.entry.js} +1 -1
  174. package/dist/ezui/{p-9e95bfeb.entry.js → p-e6a9041d.entry.js} +1 -1
  175. package/dist/ezui/{p-68b2e579.entry.js → p-ea54d056.entry.js} +1 -1
  176. package/dist/ezui/p-f5931caa.entry.js +1 -0
  177. package/dist/ezui/{p-44b39e81.entry.js → p-fa6732f2.entry.js} +1 -1
  178. package/dist/ezui/{p-e3f8660b.entry.js → p-fd0a19d6.entry.js} +1 -1
  179. package/dist/types/components/ez-combo-box/ez-combo-box-list/ez-combo-box-list.d.ts +104 -0
  180. package/dist/types/components/ez-combo-box/ez-combo-box.d.ts +7 -16
  181. package/dist/types/components/ez-popover-plus/ez-popover-plus.d.ts +6 -19
  182. package/dist/types/components/ez-popover-plus/subcomponent/ez-popover-core.d.ts +81 -0
  183. package/dist/types/components.d.ts +218 -3
  184. package/package.json +1 -1
  185. package/react/components.d.ts +2 -0
  186. package/react/components.js +2 -0
  187. package/react/components.js.map +1 -1
  188. package/dist/cjs/ez-custom-form-input_2.cjs.entry.js +0 -236
  189. package/dist/esm/ez-custom-form-input_2.entry.js +0 -231
  190. package/dist/ezui/p-3af64edd.entry.js +0 -1
  191. package/dist/ezui/p-6ec40dec.entry.js +0 -1
  192. package/dist/ezui/p-cba34702.entry.js +0 -1
  193. package/dist/ezui/p-fcc78b7f.entry.js +0 -1
@@ -0,0 +1,205 @@
1
+ :host {
2
+ /* general */
3
+ /*@doc Define o raio da borda do input. */
4
+ --ez-combo-box--border-radius: var(--border--radius-medium, 12px);
5
+ /*@doc Define o tamanho da fonte dentro do input. */
6
+ --ez-combo-box--font-size: var(--text--medium, 14px);
7
+ /*@doc Define a família da fonte dentro do input. */
8
+ --ez-combo-box--font-family: var(--font-pattern, Arial);
9
+ /*@doc Define o peso da fonte dentro do input quando pesada. */
10
+ --ez-combo-box--font-weight--large: var(--text-weight--large, 500);
11
+ /*@doc Define o peso da fonte dentro do input quando média. */
12
+ --ez-combo-box--font-weight--medium: var(--text-weight--medium, 400);
13
+ /*@doc Define a cor de fundo da lista de opções. */
14
+ --ez-combo-box--background-color--xlight: var(--background--xlight, #fff);
15
+ /*@doc Define a cor de fundo dos itens da lista de opções. */
16
+ --ez-combo-box--background-medium: var(--background--medium, #f0f3f7);
17
+ /*@doc Define a altura da linha do texto dentro do input. */
18
+ --ez-combo-box--line-height: calc(var(--text--medium, 14px) + 4px);
19
+
20
+ /* list */
21
+ /*@doc Define a cor do texto da lista de opções. */
22
+ --ez-combo-box__list-title--primary: var(--title--primary, #2B3A54);
23
+ /*@doc Define a cor do texto do value da lista de opções. */
24
+ --ez-combo-box__list-text--primary: var(--text--primary, #626e82);
25
+ /*@doc Define a altura do box da lista de opções. */
26
+ --ez-combo-box__list-height: calc(var(--ez-combo-box--font-size) + var(--ez-combo-box--space--medium) + 4px);
27
+
28
+ /* espaçamento */
29
+ /*@doc Define um espaçamento mediano entre elementos do componente. */
30
+ --ez-combo-box--space--medium: var(--space--medium, 12px);
31
+ /*@doc Define um espaçamento pequeno entre elementos do componente. */
32
+ --ez-combo-box--space--small: var(--space--small, 6px);
33
+
34
+ /* scrollbar */
35
+ /*@doc Define a cor da barra de rolagem do componente. */
36
+ --ez-combo-box__scrollbar--color-default: var(--scrollbar--default, #626e82);
37
+ /*@doc Define a cor de fundo da barra de rolagem do componente. */
38
+ --ez-combo-box__scrollbar--color-background: var(--scrollbar--background, #E5EAF0);
39
+ /*@doc Define a cor do hover na barra de rolagem do componente. */
40
+ --ez-combo-box__scrollbar--color-hover: var(--scrollbar--hover, #2B3A54);
41
+ /*@doc Define a cor do active na barra de rolagem do componente. */
42
+ --ez-combo-box__scrollbar--color-clicked: var(--scrollbar--clicked, #a2abb9);
43
+ /*@doc Define o raio da borda da barra de rolagem do componente. */
44
+ --ez-combo-box__scrollbar--border-radius: var(--border--radius-small, 6px);
45
+ /*@doc Define a largura da barra de rolagem do componente. */
46
+ --ez-combo-box__scrollbar--width: var(--space--medium, 12px);
47
+
48
+ /* list-container */
49
+ /*@doc Define o padding do container da lista. */
50
+ --ez-combo-box__list-container--padding: var(--space--extra-small, 3px);
51
+ }
52
+
53
+ .list-container {
54
+ /*public*/
55
+ padding-top: var(--ez-combo-box__list-container--padding);
56
+ }
57
+
58
+ .list-wrapper {
59
+ display: flex;
60
+ flex-direction: column;
61
+ box-sizing: border-box;
62
+ width: 0;
63
+ z-index: var(--more-visible, 2);
64
+ max-height: calc(4*var(--ez-combo-box__list-height) + 2*var(--ez-combo-box--space--small) + 9px);
65
+ background-color: var(--ez-combo-box--background-color--xlight);
66
+ border-radius: var(--ez-combo-box--border-radius);
67
+ box-shadow: var(--shadow--medium, 0 8px 24px 0 rgba(43, 58, 84, 0.10));
68
+ padding: var(--ez-combo-box--space--small);
69
+ }
70
+
71
+ .list-options {
72
+ box-sizing: border-box;
73
+ width: 100%;
74
+ height: 100%;
75
+ padding: 0;
76
+ display: flex;
77
+ flex-direction: column;
78
+ scroll-behavior: smooth;
79
+ overflow: auto;
80
+ scrollbar-width: thin;
81
+ gap: 3px;
82
+ scrollbar-color: var(--ez-combo-box__scrollbar--color-clicked) var(--ez-combo-box__scrollbar--color-background);
83
+ }
84
+
85
+ .list-options::-webkit-scrollbar {
86
+ background-color: var(--ez-combo-box__scrollbar--color-background);
87
+ width: var(--ez-combo-box__scrollbar--width);
88
+ max-width: var(--ez-combo-box__scrollbar--width);
89
+ min-width: var(--ez-combo-box__scrollbar--width);
90
+ }
91
+
92
+ .list-options::-webkit-scrollbar-track {
93
+ background-color: var(--ez-combo-box__scrollbar--color-background);
94
+ border-radius: var(--ez-combo-box__scrollbar--border-radius);
95
+ }
96
+
97
+ .list-options::-webkit-scrollbar-thumb {
98
+ background-color: var(--ez-combo-box__scrollbar--color-default);
99
+ border-radius: var(--ez-combo-box__scrollbar--border-radius);
100
+ }
101
+
102
+ .list-options::-webkit-scrollbar-thumb:vertical:hover,
103
+ .list-options::-webkit-scrollbar-thumb:horizontal:hover {
104
+ background-color: var(--ez-combo-box__scrollbar--color-hover);
105
+ }
106
+
107
+ .list-options::-webkit-scrollbar-thumb:vertical:active,
108
+ .list-options::-webkit-scrollbar-thumb:horizontal:active {
109
+ background-color: var(--ez-combo-box__scrollbar--color-clicked);
110
+ }
111
+
112
+ .item {
113
+ display: flex;
114
+ align-items: center;
115
+ width: 100%;
116
+ box-sizing: border-box;
117
+ list-style-type: none;
118
+ cursor: pointer;
119
+ border-radius: var(--ez-combo-box--border-radius-small);
120
+ padding: var(--ez-combo-box--space--small);
121
+ min-height: var(--ez-combo-box__list-height);
122
+ gap: var(--space--small, 6px);
123
+ }
124
+
125
+ .item__value,
126
+ .item__label {
127
+ flex-basis: auto;
128
+ white-space: nowrap;
129
+ overflow: hidden;
130
+ text-overflow: ellipsis;
131
+ color: var(--ez-combo-box__list-title--primary);
132
+ font-family: var(--ez-combo-box--font-family);
133
+ font-size: var(--ez-combo-box--font-size);
134
+ line-height: var(--ez-combo-box--line-height);
135
+ }
136
+
137
+ .item__label {
138
+ font-weight: var(--ez-combo-box--font-weight--medium);
139
+ }
140
+
141
+ .item__label--bold {
142
+ font-weight: var(--ez-combo-box--font-weight--large);
143
+ }
144
+
145
+ .item__value {
146
+ text-align: center;
147
+ color: var(--ez-combo-box__list-text--primary);
148
+ font-weight: var(--ez-combo-box--font-weight--large);
149
+ }
150
+
151
+ .item__value--hidden {
152
+ visibility: hidden;
153
+ position: absolute;
154
+ white-space: nowrap;
155
+ z-index: -1;
156
+ top: 0;
157
+ left: 0;
158
+ }
159
+
160
+ .item__label {
161
+ text-align: left;
162
+ }
163
+
164
+ .message {
165
+ text-align: center;
166
+ display: flex;
167
+ justify-content: center;
168
+ align-items: center;
169
+ list-style-type: none;
170
+ min-height: var(--ez-combo-box__list-height);
171
+ }
172
+
173
+ .message__no-result {
174
+ color: var(--ez-combo-box__list-title--primary);
175
+ font-family: var(--ez-combo-box--font-family);
176
+ font-size: var(--ez-combo-box--font-size);
177
+ }
178
+
179
+ .message__loading {
180
+ border-radius: 50%;
181
+ width: 14px;
182
+ height: 14px;
183
+ -webkit-animation: spin 1s linear infinite;
184
+ animation: spin 1s linear infinite;
185
+ border: 3px solid var(--ez-combo-box__list-title--primary);
186
+ border-top: 3px solid transparent;
187
+ }
188
+
189
+ li:hover {
190
+ background-color: var(--ez-combo-box--background-medium);
191
+ }
192
+
193
+ .preselected {
194
+ background-color: var(--background--medium);
195
+ }
196
+
197
+ @-webkit-keyframes spin {
198
+ 0% { -webkit-transform: rotate(0deg); }
199
+ 100% { -webkit-transform: rotate(360deg); }
200
+ }
201
+
202
+ @keyframes spin {
203
+ 0% { transform: rotate(0deg); }
204
+ 100% { transform: rotate(360deg); }
205
+ }
@@ -0,0 +1,405 @@
1
+ import { h } from "@stencil/core";
2
+ import { ElementIDUtils } from "@sankhyalabs/core";
3
+ export class EzComboBoxList {
4
+ constructor() {
5
+ this.showLoading = undefined;
6
+ this.visibleOptions = undefined;
7
+ this.textEmptyList = "Nenhum resultado encontrado";
8
+ this.showOptionValue = undefined;
9
+ this.preSelection = undefined;
10
+ this.maxWidth = undefined;
11
+ this.width = undefined;
12
+ this.onOptionSelect = undefined;
13
+ this.onOptionHover = undefined;
14
+ }
15
+ /**
16
+ * Move a seleção para a próxima opção na lista.
17
+ */
18
+ async nextOption() {
19
+ this.preSelection = this.preSelection === undefined ? 0 : Math.min(this.preSelection + 1, this.visibleOptions.length - 1);
20
+ this.scrollToOption(this.visibleOptions[this.preSelection]);
21
+ }
22
+ /**
23
+ * Move a seleção para a opção anterior na lista.
24
+ */
25
+ async previousOption() {
26
+ this.preSelection = this.preSelection === undefined ? 0 : Math.max(this.preSelection - 1, 0);
27
+ this.scrollToOption(this.visibleOptions[this.preSelection]);
28
+ }
29
+ /**
30
+ * Seleciona a opção atualmente pré-selecionada.
31
+ */
32
+ async selectCurrentOption() {
33
+ if (this.preSelection !== undefined) {
34
+ this.onOptionSelect(this.visibleOptions[this.preSelection]);
35
+ this.preSelection = undefined;
36
+ }
37
+ }
38
+ /**
39
+ * Observa mudanças na propriedade `width` e ajusta a largura da lista.
40
+ *
41
+ * @param newValue O novo valor da largura.
42
+ * @param oldValue O valor anterior da largura.
43
+ */
44
+ observeWidth(newValue, oldValue) {
45
+ if (newValue === oldValue)
46
+ return;
47
+ if (!this._listWrapper)
48
+ return;
49
+ this._listWrapper.style.width = `${this.width}px`;
50
+ }
51
+ /**
52
+ * Observa mudanças na propriedade `maxWidth` e ajusta a largura máxima da lista.
53
+ *
54
+ * @param newValue O novo valor da largura máxima.
55
+ * @param oldValue O valor anterior da largura máxima.
56
+ */
57
+ observeMaxWidth(newValue, oldValue) {
58
+ if (newValue === oldValue)
59
+ return;
60
+ if (!this._listWrapper)
61
+ return;
62
+ this._listWrapper.style.maxWidth = this.maxWidth ? `${this.maxWidth}px` : '';
63
+ }
64
+ /**
65
+ * Gerencia a navegação por teclado na lista do combo box.
66
+ *
67
+ * - `ArrowDown`: Move para a próxima opção.
68
+ * - `ArrowUp`: Move para a opção anterior.
69
+ * - `Enter`: Seleciona a opção atual.
70
+ * - `Escape`: Limpa a pré-seleção.
71
+ *
72
+ * @param event O evento de teclado.
73
+ */
74
+ handleKeyDown(event) {
75
+ switch (event.key) {
76
+ case "ArrowDown":
77
+ event.preventDefault();
78
+ event.stopPropagation();
79
+ this.nextOption();
80
+ break;
81
+ case "ArrowUp":
82
+ event.preventDefault();
83
+ event.stopPropagation();
84
+ this.previousOption();
85
+ break;
86
+ case "Enter":
87
+ this.selectCurrentOption();
88
+ break;
89
+ case "Escape":
90
+ this.preSelection = undefined;
91
+ break;
92
+ }
93
+ }
94
+ buildItem(opt, index) {
95
+ const widthValue = this.showOptionValue && this.maxWidth > 0 ? `${this.maxWidth}px` : '';
96
+ opt.label = opt.label || opt.value;
97
+ return h("li", { class: index === this.preSelection ? "item preselected" : "item", id: `item_${opt.value}`, onMouseDown: () => this.onOptionSelect(opt), onMouseOver: () => this.preSelection = index }, this.showOptionValue
98
+ ? h("span", { class: "item__value", title: opt.value, style: { width: widthValue, minWidth: widthValue, maxWidth: widthValue } }, opt.value)
99
+ : undefined, h("span", { class: "item__label " + (this.showOptionValue ? "item__label--bold" : ""), title: opt.label }, opt.label));
100
+ }
101
+ scrollToOption(opt) {
102
+ window.requestAnimationFrame(() => {
103
+ const liElem = (opt === null || opt === void 0 ? void 0 : opt.value) ? this._optionsList.querySelector(`li#item_${opt.value.replace(/[ <>\[\]#=]/g, '\\$&').replace(/:/g, '\\:')}`) : undefined;
104
+ if (liElem)
105
+ liElem.scrollIntoView({ behavior: "smooth", block: "nearest" });
106
+ });
107
+ }
108
+ componentDidLoad() {
109
+ this._listWrapper.style.width = `${this.width}px`;
110
+ this._listWrapper.style.maxWidth = this.maxWidth ? `${this.maxWidth}px` : '';
111
+ }
112
+ componentDidRender() {
113
+ var _a;
114
+ (_a = this._optionsList) === null || _a === void 0 ? void 0 : _a.querySelectorAll(".item").forEach((elem) => {
115
+ ElementIDUtils.addIDInfoIfNotExists(elem, "itemComboBox");
116
+ });
117
+ }
118
+ render() {
119
+ return (h("section", { class: "list-container" }, h("div", { class: "list-wrapper", ref: elem => this._listWrapper = elem }, h("ul", { class: "list-options", ref: elem => this._optionsList = elem }, !this.showLoading && this.visibleOptions.length === 0 && (h("div", { class: "message" }, h("span", { class: "message__no-result" }, this.textEmptyList))), this.showLoading && (h("div", { class: "message" }, h("div", { class: "message__loading" }))), this.showOptionValue && (h("span", { class: "item__value item__value--hidden" })), !this.showLoading && this.visibleOptions.length > 0 &&
120
+ this.visibleOptions.map((opt, index) => this.buildItem(opt, index))))));
121
+ }
122
+ static get is() { return "ez-combo-box-list"; }
123
+ static get encapsulation() { return "shadow"; }
124
+ static get originalStyleUrls() {
125
+ return {
126
+ "$": ["ez-combo-box-list.css"]
127
+ };
128
+ }
129
+ static get styleUrls() {
130
+ return {
131
+ "$": ["ez-combo-box-list.css"]
132
+ };
133
+ }
134
+ static get properties() {
135
+ return {
136
+ "showLoading": {
137
+ "type": "boolean",
138
+ "mutable": false,
139
+ "complexType": {
140
+ "original": "boolean",
141
+ "resolved": "boolean",
142
+ "references": {}
143
+ },
144
+ "required": false,
145
+ "optional": false,
146
+ "docs": {
147
+ "tags": [{
148
+ "name": "tipo",
149
+ "text": "{boolean}"
150
+ }],
151
+ "text": "Indica se o indicador de carregamento deve ser exibido."
152
+ },
153
+ "attribute": "show-loading",
154
+ "reflect": false
155
+ },
156
+ "visibleOptions": {
157
+ "type": "unknown",
158
+ "mutable": false,
159
+ "complexType": {
160
+ "original": "Array<IOption>",
161
+ "resolved": "IOption[]",
162
+ "references": {
163
+ "Array": {
164
+ "location": "global"
165
+ },
166
+ "IOption": {
167
+ "location": "import",
168
+ "path": "../ez-combo-box"
169
+ }
170
+ }
171
+ },
172
+ "required": false,
173
+ "optional": false,
174
+ "docs": {
175
+ "tags": [{
176
+ "name": "tipo",
177
+ "text": "{Array<IOption>}"
178
+ }],
179
+ "text": "Lista de op\u00E7\u00F5es vis\u00EDveis que ser\u00E3o exibidas no componente."
180
+ }
181
+ },
182
+ "textEmptyList": {
183
+ "type": "string",
184
+ "mutable": false,
185
+ "complexType": {
186
+ "original": "string",
187
+ "resolved": "string",
188
+ "references": {}
189
+ },
190
+ "required": false,
191
+ "optional": false,
192
+ "docs": {
193
+ "tags": [{
194
+ "name": "padr\u00E3o",
195
+ "text": "\"Nenhum resultado encontrado\""
196
+ }, {
197
+ "name": "tipo",
198
+ "text": "{string}"
199
+ }],
200
+ "text": "Mensagem exibida quando a lista de op\u00E7\u00F5es est\u00E1 vazia."
201
+ },
202
+ "attribute": "text-empty-list",
203
+ "reflect": false,
204
+ "defaultValue": "\"Nenhum resultado encontrado\""
205
+ },
206
+ "showOptionValue": {
207
+ "type": "boolean",
208
+ "mutable": false,
209
+ "complexType": {
210
+ "original": "boolean",
211
+ "resolved": "boolean",
212
+ "references": {}
213
+ },
214
+ "required": false,
215
+ "optional": false,
216
+ "docs": {
217
+ "tags": [{
218
+ "name": "tipo",
219
+ "text": "{boolean}"
220
+ }],
221
+ "text": "Indica se o valor de cada op\u00E7\u00E3o deve ser exibido junto com o r\u00F3tulo."
222
+ },
223
+ "attribute": "show-option-value",
224
+ "reflect": false
225
+ },
226
+ "preSelection": {
227
+ "type": "number",
228
+ "mutable": false,
229
+ "complexType": {
230
+ "original": "number",
231
+ "resolved": "number",
232
+ "references": {}
233
+ },
234
+ "required": false,
235
+ "optional": false,
236
+ "docs": {
237
+ "tags": [{
238
+ "name": "tipo",
239
+ "text": "{number}"
240
+ }],
241
+ "text": "\u00CDndice da op\u00E7\u00E3o pr\u00E9-selecionada na lista."
242
+ },
243
+ "attribute": "pre-selection",
244
+ "reflect": false
245
+ },
246
+ "maxWidth": {
247
+ "type": "number",
248
+ "mutable": false,
249
+ "complexType": {
250
+ "original": "number",
251
+ "resolved": "number",
252
+ "references": {}
253
+ },
254
+ "required": false,
255
+ "optional": false,
256
+ "docs": {
257
+ "tags": [{
258
+ "name": "tipo",
259
+ "text": "{number}"
260
+ }],
261
+ "text": "Largura m\u00E1xima da lista, em pixels."
262
+ },
263
+ "attribute": "max-width",
264
+ "reflect": false
265
+ },
266
+ "width": {
267
+ "type": "number",
268
+ "mutable": false,
269
+ "complexType": {
270
+ "original": "number",
271
+ "resolved": "number",
272
+ "references": {}
273
+ },
274
+ "required": false,
275
+ "optional": false,
276
+ "docs": {
277
+ "tags": [{
278
+ "name": "tipo",
279
+ "text": "{number}"
280
+ }],
281
+ "text": "Largura fixa da lista, em pixels."
282
+ },
283
+ "attribute": "width",
284
+ "reflect": false
285
+ },
286
+ "onOptionSelect": {
287
+ "type": "unknown",
288
+ "mutable": false,
289
+ "complexType": {
290
+ "original": "(option: IOption) => void",
291
+ "resolved": "(option: IOption) => void",
292
+ "references": {
293
+ "IOption": {
294
+ "location": "import",
295
+ "path": "../ez-combo-box"
296
+ }
297
+ }
298
+ },
299
+ "required": false,
300
+ "optional": false,
301
+ "docs": {
302
+ "tags": [{
303
+ "name": "param",
304
+ "text": "option A op\u00E7\u00E3o selecionada."
305
+ }, {
306
+ "name": "tipo",
307
+ "text": "{(option: IOption) => void}"
308
+ }],
309
+ "text": "Callback chamado quando uma op\u00E7\u00E3o \u00E9 selecionada."
310
+ }
311
+ },
312
+ "onOptionHover": {
313
+ "type": "unknown",
314
+ "mutable": false,
315
+ "complexType": {
316
+ "original": "(index: number) => void",
317
+ "resolved": "(index: number) => void",
318
+ "references": {}
319
+ },
320
+ "required": false,
321
+ "optional": false,
322
+ "docs": {
323
+ "tags": [{
324
+ "name": "param",
325
+ "text": "index O \u00EDndice da op\u00E7\u00E3o em foco."
326
+ }, {
327
+ "name": "tipo",
328
+ "text": "{(index: number) => void}"
329
+ }],
330
+ "text": "Callback chamado quando o mouse passa sobre uma op\u00E7\u00E3o."
331
+ }
332
+ }
333
+ };
334
+ }
335
+ static get methods() {
336
+ return {
337
+ "nextOption": {
338
+ "complexType": {
339
+ "signature": "() => Promise<void>",
340
+ "parameters": [],
341
+ "references": {
342
+ "Promise": {
343
+ "location": "global"
344
+ }
345
+ },
346
+ "return": "Promise<void>"
347
+ },
348
+ "docs": {
349
+ "text": "Move a sele\u00E7\u00E3o para a pr\u00F3xima op\u00E7\u00E3o na lista.",
350
+ "tags": []
351
+ }
352
+ },
353
+ "previousOption": {
354
+ "complexType": {
355
+ "signature": "() => Promise<void>",
356
+ "parameters": [],
357
+ "references": {
358
+ "Promise": {
359
+ "location": "global"
360
+ }
361
+ },
362
+ "return": "Promise<void>"
363
+ },
364
+ "docs": {
365
+ "text": "Move a sele\u00E7\u00E3o para a op\u00E7\u00E3o anterior na lista.",
366
+ "tags": []
367
+ }
368
+ },
369
+ "selectCurrentOption": {
370
+ "complexType": {
371
+ "signature": "() => Promise<void>",
372
+ "parameters": [],
373
+ "references": {
374
+ "Promise": {
375
+ "location": "global"
376
+ }
377
+ },
378
+ "return": "Promise<void>"
379
+ },
380
+ "docs": {
381
+ "text": "Seleciona a op\u00E7\u00E3o atualmente pr\u00E9-selecionada.",
382
+ "tags": []
383
+ }
384
+ }
385
+ };
386
+ }
387
+ static get watchers() {
388
+ return [{
389
+ "propName": "width",
390
+ "methodName": "observeWidth"
391
+ }, {
392
+ "propName": "maxWidth",
393
+ "methodName": "observeMaxWidth"
394
+ }];
395
+ }
396
+ static get listeners() {
397
+ return [{
398
+ "name": "keydown",
399
+ "method": "handleKeyDown",
400
+ "target": undefined,
401
+ "capture": false,
402
+ "passive": false
403
+ }];
404
+ }
405
+ }