@sankhyalabs/ezui 7.2.0-dev.2 → 7.2.0-dev.20

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 (259) hide show
  1. package/dist/cjs/{ApplicationUtils-006ca96f.js → ApplicationUtils-88dfe345.js} +1 -1
  2. package/dist/cjs/{app-globals-5cb12916.js → app-globals-c1d07d68.js} +1 -1
  3. package/dist/cjs/classic-search-list_7.cjs.entry.js +9 -4
  4. package/dist/cjs/ez-actions-button.cjs.entry.js +2 -2
  5. package/dist/cjs/ez-alert-list.cjs.entry.js +1 -1
  6. package/dist/cjs/ez-avatar.cjs.entry.js +1 -1
  7. package/dist/cjs/ez-calendar.cjs.entry.js +1 -1
  8. package/dist/cjs/ez-classic-combo-box.cjs.entry.js +2 -1
  9. package/dist/cjs/ez-classic-date-input.cjs.entry.js +2 -2
  10. package/dist/cjs/ez-classic-date-time-input.cjs.entry.js +1 -1
  11. package/dist/cjs/ez-classic-input.cjs.entry.js +49 -3
  12. package/dist/cjs/ez-classic-number-input.cjs.entry.js +1 -1
  13. package/dist/cjs/ez-classic-search-plus.cjs.entry.js +26 -13
  14. package/dist/cjs/ez-classic-search.cjs.entry.js +2 -2
  15. package/dist/cjs/ez-classic-time-input.cjs.entry.js +4 -3
  16. package/dist/cjs/ez-collapsible-box.cjs.entry.js +2 -2
  17. package/dist/cjs/ez-combo-box.cjs.entry.js +2 -2
  18. package/dist/cjs/ez-date-input.cjs.entry.js +1 -1
  19. package/dist/cjs/ez-date-time-input.cjs.entry.js +1 -1
  20. package/dist/cjs/ez-dialog.cjs.entry.js +1 -1
  21. package/dist/cjs/ez-double-list.cjs.entry.js +1 -1
  22. package/dist/cjs/ez-dropdown.cjs.entry.js +1 -1
  23. package/dist/cjs/ez-empty-card.cjs.entry.js +1 -1
  24. package/dist/cjs/ez-file-item.cjs.entry.js +1 -1
  25. package/dist/cjs/ez-form-view.cjs.entry.js +1 -1
  26. package/dist/cjs/ez-form.cjs.entry.js +3 -3
  27. package/dist/cjs/ez-grid-pagination.cjs.entry.js +227 -0
  28. package/dist/cjs/ez-grid.cjs.entry.js +45 -162
  29. package/dist/cjs/ez-guide-navigator.cjs.entry.js +1 -1
  30. package/dist/cjs/ez-icon.cjs.entry.js +1 -1
  31. package/dist/cjs/ez-link-builder_6.cjs.entry.js +1 -1
  32. package/dist/cjs/ez-list.cjs.entry.js +1 -1
  33. package/dist/cjs/ez-modal-container.cjs.entry.js +1 -1
  34. package/dist/cjs/ez-modal.cjs.entry.js +1 -1
  35. package/dist/cjs/ez-multi-selection-list.cjs.entry.js +1 -1
  36. package/dist/cjs/ez-number-input.cjs.entry.js +1 -1
  37. package/dist/cjs/ez-pagination.cjs.entry.js +1 -1
  38. package/dist/cjs/ez-popover-core.cjs.entry.js +1 -1
  39. package/dist/cjs/ez-popup.cjs.entry.js +4 -4
  40. package/dist/cjs/ez-record-navigation.cjs.entry.js +121 -0
  41. package/dist/cjs/ez-scroller_2.cjs.entry.js +81 -14
  42. package/dist/cjs/ez-search-plus.cjs.entry.js +13 -4
  43. package/dist/cjs/ez-search-result-list.cjs.entry.js +1 -1
  44. package/dist/cjs/ez-search.cjs.entry.js +3 -3
  45. package/dist/cjs/ez-sidebar-navigator.cjs.entry.js +1 -1
  46. package/dist/cjs/ez-skeleton.cjs.entry.js +1 -1
  47. package/dist/cjs/ez-sortable-list.cjs.entry.js +2 -2
  48. package/dist/cjs/ez-spinner.cjs.entry.js +1 -1
  49. package/dist/cjs/ez-split-button.cjs.entry.js +4 -4
  50. package/dist/cjs/ez-split-item.cjs.entry.js +2 -2
  51. package/dist/cjs/ez-text-input.cjs.entry.js +21 -15
  52. package/dist/cjs/ez-time-input.cjs.entry.js +1 -1
  53. package/dist/cjs/ez-tooltip.cjs.entry.js +1 -1
  54. package/dist/cjs/ez-tree.cjs.entry.js +1 -1
  55. package/dist/cjs/ez-upload.cjs.entry.js +2 -2
  56. package/dist/cjs/ezui.cjs.js +3 -3
  57. package/dist/cjs/filter-column.cjs.entry.js +2 -1
  58. package/dist/cjs/{floating-ui.dom.esm-f4d87617.js → floating-ui.dom.esm-bea31048.js} +165 -119
  59. package/dist/cjs/{index-350d0fa0.js → index-9739c242.js} +91 -30
  60. package/dist/cjs/index-a7b0c73d.js +8 -0
  61. package/dist/cjs/loader.cjs.js +3 -3
  62. package/dist/cjs/{search-column-fbf680d7.js → search-column-6e90fb19.js} +18 -9
  63. package/dist/collection/collection-manifest.json +7 -0
  64. package/dist/collection/components/ez-classic-combo-box/ez-classic-combo-box.js +2 -1
  65. package/dist/collection/components/ez-classic-date-input/ez-classic-date-input.js +1 -1
  66. package/dist/collection/components/ez-classic-input/ez-classic-input.js +47 -2
  67. package/dist/collection/components/ez-classic-input/utils/maskFormatter.js +2 -1
  68. package/dist/collection/components/ez-classic-search-plus/ez-classic-search-plus.css +22 -0
  69. package/dist/collection/components/ez-classic-search-plus/ez-classic-search-plus.js +26 -11
  70. package/dist/collection/components/ez-classic-time-input/ez-classic-time-input.js +3 -2
  71. package/dist/collection/components/ez-dropdown/ez-dropdown.css +1 -1
  72. package/dist/collection/components/ez-empty-card/ez-empty-card.js +7 -7
  73. package/dist/collection/components/ez-grid/controller/ag-grid/AgGridController.js +25 -14
  74. package/dist/collection/components/ez-grid/ez-grid.css +1 -60
  75. package/dist/collection/components/ez-grid/ez-grid.js +52 -150
  76. package/dist/collection/components/ez-grid/subcomponents/filter-column.js +1 -0
  77. package/dist/collection/components/ez-grid-pagination/ez-grid-pagination.css +111 -0
  78. package/dist/collection/components/ez-grid-pagination/ez-grid-pagination.js +410 -0
  79. package/dist/collection/components/ez-icon/ez-icon.css +1152 -1145
  80. package/dist/collection/components/ez-image-input/ez-image-input.css +24 -8
  81. package/dist/collection/components/ez-image-input/ez-image-input.js +6 -1
  82. package/dist/collection/components/ez-popup/ez-popup.js +3 -3
  83. package/dist/collection/components/ez-record-navigation/ez-record-navigation.css +51 -0
  84. package/dist/collection/components/ez-record-navigation/ez-record-navigation.js +246 -0
  85. package/dist/collection/components/ez-scroller/EzScrollNavigationMode.js +5 -0
  86. package/dist/collection/components/ez-scroller/ez-scroller.css +117 -11
  87. package/dist/collection/components/ez-scroller/ez-scroller.js +118 -13
  88. package/dist/collection/components/ez-search/ez-search.css +4 -0
  89. package/dist/collection/components/ez-search-plus/ez-search-plus.js +11 -2
  90. package/dist/collection/components/ez-sortable-list/ez-sortable-list.css +1 -1
  91. package/dist/collection/components/ez-split-button/ez-split-button.css +1 -1
  92. package/dist/collection/components/ez-split-button/ez-split-button.js +2 -2
  93. package/dist/collection/components/ez-text-input/ez-text-input.js +21 -15
  94. package/dist/collection/utils/i18n/locales/en-us.js +27 -4
  95. package/dist/collection/utils/i18n/locales/es-es.js +27 -4
  96. package/dist/collection/utils/i18n/locales/pt-br.js +27 -4
  97. package/dist/collection/utils/interfaces/AbstractFieldMetadata.js +14 -2
  98. package/dist/collection/utils/searchColumn/search-column.js +2 -5
  99. package/dist/custom-elements/index.d.ts +12 -0
  100. package/dist/custom-elements/index.js +856 -371
  101. package/dist/esm/{ApplicationUtils-0c5cb207.js → ApplicationUtils-f7721533.js} +1 -1
  102. package/dist/esm/{app-globals-1db10325.js → app-globals-6e258867.js} +1 -1
  103. package/dist/esm/classic-search-list_7.entry.js +9 -4
  104. package/dist/esm/ez-actions-button.entry.js +2 -2
  105. package/dist/esm/ez-alert-list.entry.js +1 -1
  106. package/dist/esm/ez-avatar.entry.js +1 -1
  107. package/dist/esm/ez-calendar.entry.js +1 -1
  108. package/dist/esm/ez-classic-combo-box.entry.js +2 -1
  109. package/dist/esm/ez-classic-date-input.entry.js +2 -2
  110. package/dist/esm/ez-classic-date-time-input.entry.js +1 -1
  111. package/dist/esm/ez-classic-input.entry.js +49 -3
  112. package/dist/esm/ez-classic-number-input.entry.js +1 -1
  113. package/dist/esm/ez-classic-search-plus.entry.js +26 -13
  114. package/dist/esm/ez-classic-search.entry.js +2 -2
  115. package/dist/esm/ez-classic-time-input.entry.js +4 -3
  116. package/dist/esm/ez-collapsible-box.entry.js +2 -2
  117. package/dist/esm/ez-combo-box.entry.js +2 -2
  118. package/dist/esm/ez-date-input.entry.js +1 -1
  119. package/dist/esm/ez-date-time-input.entry.js +1 -1
  120. package/dist/esm/ez-dialog.entry.js +1 -1
  121. package/dist/esm/ez-double-list.entry.js +1 -1
  122. package/dist/esm/ez-dropdown.entry.js +1 -1
  123. package/dist/esm/ez-empty-card.entry.js +1 -1
  124. package/dist/esm/ez-file-item.entry.js +1 -1
  125. package/dist/esm/ez-form-view.entry.js +1 -1
  126. package/dist/esm/ez-form.entry.js +3 -3
  127. package/dist/esm/ez-grid-pagination.entry.js +223 -0
  128. package/dist/esm/ez-grid.entry.js +46 -163
  129. package/dist/esm/ez-guide-navigator.entry.js +1 -1
  130. package/dist/esm/ez-icon.entry.js +1 -1
  131. package/dist/esm/ez-link-builder_6.entry.js +1 -1
  132. package/dist/esm/ez-list.entry.js +1 -1
  133. package/dist/esm/ez-modal-container.entry.js +1 -1
  134. package/dist/esm/ez-modal.entry.js +1 -1
  135. package/dist/esm/ez-multi-selection-list.entry.js +1 -1
  136. package/dist/esm/ez-number-input.entry.js +1 -1
  137. package/dist/esm/ez-pagination.entry.js +1 -1
  138. package/dist/esm/ez-popover-core.entry.js +1 -1
  139. package/dist/esm/ez-popup.entry.js +4 -4
  140. package/dist/esm/ez-record-navigation.entry.js +117 -0
  141. package/dist/esm/ez-scroller_2.entry.js +81 -14
  142. package/dist/esm/ez-search-plus.entry.js +13 -4
  143. package/dist/esm/ez-search-result-list.entry.js +1 -1
  144. package/dist/esm/ez-search.entry.js +3 -3
  145. package/dist/esm/ez-sidebar-navigator.entry.js +1 -1
  146. package/dist/esm/ez-skeleton.entry.js +1 -1
  147. package/dist/esm/ez-sortable-list.entry.js +2 -2
  148. package/dist/esm/ez-spinner.entry.js +1 -1
  149. package/dist/esm/ez-split-button.entry.js +4 -4
  150. package/dist/esm/ez-split-item.entry.js +2 -2
  151. package/dist/esm/ez-text-input.entry.js +21 -15
  152. package/dist/esm/ez-time-input.entry.js +1 -1
  153. package/dist/esm/ez-tooltip.entry.js +1 -1
  154. package/dist/esm/ez-tree.entry.js +1 -1
  155. package/dist/esm/ez-upload.entry.js +2 -2
  156. package/dist/esm/ezui.js +3 -3
  157. package/dist/esm/filter-column.entry.js +2 -1
  158. package/dist/esm/{floating-ui.dom.esm-ad30f2f0.js → floating-ui.dom.esm-2964eae1.js} +165 -119
  159. package/dist/esm/{index-225aa0c3.js → index-9e6dab5b.js} +91 -30
  160. package/dist/esm/index-baa5e267.js +8 -0
  161. package/dist/esm/loader.js +3 -3
  162. package/dist/esm/{search-column-40a78cac.js → search-column-7d7f0331.js} +18 -9
  163. package/dist/ezui/ezui.esm.js +1 -1
  164. package/dist/ezui/p-0592535f.entry.js +1 -0
  165. package/dist/ezui/{p-544605c4.entry.js → p-063bb342.entry.js} +1 -1
  166. package/dist/ezui/{p-c56ee8c0.entry.js → p-0ac8bd66.entry.js} +1 -1
  167. package/dist/ezui/p-0d80e3ec.entry.js +1 -0
  168. package/dist/ezui/{p-729bd1be.entry.js → p-108503ed.entry.js} +1 -1
  169. package/dist/ezui/{p-e3cd5080.entry.js → p-1166b2d5.entry.js} +1 -1
  170. package/dist/ezui/p-15873627.js +1 -0
  171. package/dist/ezui/p-178cb9df.entry.js +1 -0
  172. package/dist/ezui/p-1d253dd5.entry.js +1 -0
  173. package/dist/ezui/p-2856c545.entry.js +1 -0
  174. package/dist/ezui/{p-bea06aae.entry.js → p-28601589.entry.js} +46 -46
  175. package/dist/ezui/{p-df802548.entry.js → p-2ae127bc.entry.js} +1 -1
  176. package/dist/ezui/{p-556bf329.entry.js → p-2ebd7383.entry.js} +1 -1
  177. package/dist/ezui/{p-b36475f9.entry.js → p-30c5f48a.entry.js} +1 -1
  178. package/dist/ezui/{p-62c149cb.entry.js → p-3fae7072.entry.js} +1 -1
  179. package/dist/ezui/p-42e1e733.js +1 -0
  180. package/dist/ezui/{p-4e869617.entry.js → p-45245c32.entry.js} +1 -1
  181. package/dist/ezui/{p-a872c642.entry.js → p-46b1b2ac.entry.js} +1 -1
  182. package/dist/ezui/{p-5abb220b.entry.js → p-54af1af0.entry.js} +1 -1
  183. package/dist/ezui/p-55434123.entry.js +1 -0
  184. package/dist/ezui/{p-a4351519.entry.js → p-66455069.entry.js} +1 -1
  185. package/dist/ezui/p-6791d05f.entry.js +1 -0
  186. package/dist/ezui/p-72e77b45.entry.js +1 -0
  187. package/dist/ezui/{p-7edc3ef7.entry.js → p-73461028.entry.js} +1 -1
  188. package/dist/ezui/{p-f5552540.entry.js → p-7424d520.entry.js} +1 -1
  189. package/dist/ezui/{p-b705b342.entry.js → p-7a07c50f.entry.js} +1 -1
  190. package/dist/ezui/p-7b078125.entry.js +1 -0
  191. package/dist/ezui/{p-d5dc6b01.entry.js → p-7dad8018.entry.js} +1 -1
  192. package/dist/ezui/{p-b0a716ef.entry.js → p-881abc22.entry.js} +1 -1
  193. package/dist/ezui/{p-7953ecb9.entry.js → p-97fe3252.entry.js} +1 -1
  194. package/dist/ezui/{p-7134726a.entry.js → p-99556756.entry.js} +1 -1
  195. package/dist/ezui/{p-97312709.entry.js → p-9bd78d39.entry.js} +1 -1
  196. package/dist/ezui/{p-351fb12f.entry.js → p-a4735a12.entry.js} +1 -1
  197. package/dist/ezui/{p-9825c1d2.js → p-ad5e263d.js} +1 -1
  198. package/dist/ezui/{p-26cd4c2e.entry.js → p-b06294c9.entry.js} +1 -1
  199. package/dist/ezui/{p-2da9faf1.entry.js → p-b8cd501a.entry.js} +1 -1
  200. package/dist/ezui/{p-bf2a7f94.entry.js → p-b986da95.entry.js} +2 -2
  201. package/dist/ezui/{p-4c2a4435.entry.js → p-c25a4d30.entry.js} +1 -1
  202. package/dist/ezui/{p-4f7ad3ee.entry.js → p-c37fb359.entry.js} +1 -1
  203. package/dist/ezui/{p-e2972977.entry.js → p-cb00863d.entry.js} +1 -1
  204. package/dist/ezui/{p-4d30b703.entry.js → p-cf66ace0.entry.js} +1 -1
  205. package/dist/ezui/{p-e493ad57.entry.js → p-cfe41b07.entry.js} +1 -1
  206. package/dist/ezui/p-d2601b25.js +1 -0
  207. package/dist/ezui/{p-e3a42f47.entry.js → p-d5684cdc.entry.js} +1 -1
  208. package/dist/ezui/{p-6ac056d7.entry.js → p-d70805e4.entry.js} +1 -1
  209. package/dist/ezui/{p-a3bad8f8.entry.js → p-d75f583b.entry.js} +1 -1
  210. package/dist/ezui/p-d8b69419.entry.js +1 -0
  211. package/dist/ezui/p-df6173c8.entry.js +1 -0
  212. package/dist/ezui/{p-56565777.entry.js → p-dfced8c7.entry.js} +1 -1
  213. package/dist/ezui/{p-0248846f.entry.js → p-e3d6b544.entry.js} +1 -1
  214. package/dist/ezui/p-e63a0479.js +1 -0
  215. package/dist/ezui/{p-4c76b365.entry.js → p-e692c2a7.entry.js} +1 -1
  216. package/dist/ezui/{p-8e5f1c74.entry.js → p-e8cd003b.entry.js} +1 -1
  217. package/dist/ezui/p-ed790867.entry.js +1 -0
  218. package/dist/ezui/p-f2e0acf5.entry.js +1 -0
  219. package/dist/ezui/{p-34d459e4.entry.js → p-f498f6b5.entry.js} +1 -1
  220. package/dist/ezui/{p-4af745e1.entry.js → p-fb27b98d.entry.js} +1 -1
  221. package/dist/ezui/{p-987185c4.entry.js → p-fc11f5b9.entry.js} +1 -1
  222. package/dist/ezui/{p-ef8bd3e8.entry.js → p-fc72aeb8.entry.js} +1 -1
  223. package/dist/types/components/ez-classic-input/ez-classic-input.d.ts +6 -0
  224. package/dist/types/components/ez-classic-search-plus/ez-classic-search-plus.d.ts +3 -0
  225. package/dist/types/components/ez-empty-card/ez-empty-card.d.ts +2 -2
  226. package/dist/types/components/ez-grid/controller/ag-grid/AgGridController.d.ts +2 -0
  227. package/dist/types/components/ez-grid/ez-grid.d.ts +10 -27
  228. package/dist/types/components/ez-grid-pagination/ez-grid-pagination.d.ts +75 -0
  229. package/dist/types/components/ez-image-input/ez-image-input.d.ts +1 -0
  230. package/dist/types/components/ez-popup/ez-popup.d.ts +1 -0
  231. package/dist/types/components/ez-record-navigation/ez-record-navigation.d.ts +43 -0
  232. package/dist/types/components/ez-scroller/EzScrollNavigationMode.d.ts +4 -0
  233. package/dist/types/components/ez-scroller/ez-scroller.d.ts +16 -2
  234. package/dist/types/components/ez-search-plus/ez-search-plus.d.ts +1 -0
  235. package/dist/types/components/ez-text-input/ez-text-input.d.ts +1 -0
  236. package/dist/types/components.d.ts +154 -6
  237. package/dist/types/utils/i18n/locales/en-us.d.ts +26 -3
  238. package/dist/types/utils/i18n/locales/es-es.d.ts +26 -3
  239. package/dist/types/utils/i18n/locales/pt-br.d.ts +26 -3
  240. package/dist/types/utils/i18n/translations.d.ts +78 -9
  241. package/package.json +5 -5
  242. package/react/components.d.ts +2 -0
  243. package/react/components.js +2 -0
  244. package/react/components.js.map +1 -1
  245. package/dist/ezui/p-0625743b.entry.js +0 -1
  246. package/dist/ezui/p-07fb22c3.entry.js +0 -1
  247. package/dist/ezui/p-288631d1.entry.js +0 -1
  248. package/dist/ezui/p-2a806303.js +0 -1
  249. package/dist/ezui/p-2de94faf.entry.js +0 -1
  250. package/dist/ezui/p-44183c39.entry.js +0 -1
  251. package/dist/ezui/p-619225ce.entry.js +0 -1
  252. package/dist/ezui/p-6a794336.js +0 -1
  253. package/dist/ezui/p-a0f51b99.entry.js +0 -1
  254. package/dist/ezui/p-a813a748.entry.js +0 -1
  255. package/dist/ezui/p-c0ae79fa.entry.js +0 -1
  256. package/dist/ezui/p-c178730b.js +0 -1
  257. package/dist/ezui/p-d2645bdf.entry.js +0 -1
  258. package/dist/ezui/p-f969b65d.entry.js +0 -1
  259. package/dist/ezui/p-ff4312d5.js +0 -1
@@ -50,6 +50,7 @@
50
50
  "./components/ez-form-view/ez-form-view.js",
51
51
  "./components/ez-form-view/custom-input/ez-custom-form-input.js",
52
52
  "./components/ez-grid/ez-grid.js",
53
+ "./components/ez-grid-pagination/ez-grid-pagination.js",
53
54
  "./components/ez-grid-view/ez-grid-view.js",
54
55
  "./components/ez-guide-navigator/ez-guide-navigator.js",
55
56
  "./components/ez-icon/ez-icon.js",
@@ -65,6 +66,7 @@
65
66
  "./components/ez-popover-plus/subcomponent/ez-popover-core.js",
66
67
  "./components/ez-popup/ez-popup.js",
67
68
  "./components/ez-progress-bar/ez-progress-bar.js",
69
+ "./components/ez-record-navigation/ez-record-navigation.js",
68
70
  "./components/ez-rich-text/ez-rich-text.js",
69
71
  "./components/ez-rich-text/ez-link-builder/ez-link-builder.js",
70
72
  "./components/ez-rich-text/ez-rich-toolbar/ez-rich-toolbar.js",
@@ -218,6 +220,11 @@
218
220
  "ez-grid"
219
221
  ]
220
222
  },
223
+ {
224
+ "components": [
225
+ "ez-grid-pagination"
226
+ ]
227
+ },
221
228
  {
222
229
  "components": [
223
230
  "ez-grid-view"
@@ -110,12 +110,13 @@ export class EzClassicComboBox {
110
110
  this.filterOptions('');
111
111
  }
112
112
  async valueChanged(newValue, oldValue) {
113
+ var _a;
113
114
  if (this.compareOptionValues(newValue, oldValue)) {
114
115
  return;
115
116
  }
116
117
  if (newValue) {
117
118
  this.value = this.getFullOption(newValue);
118
- this.inputValue = this.value.label;
119
+ this.inputValue = (_a = this.value) === null || _a === void 0 ? void 0 : _a.label;
119
120
  this.setHighlightedIndexToValue();
120
121
  }
121
122
  else {
@@ -175,7 +175,7 @@ export class EzClassicDateInput {
175
175
  }
176
176
  render() {
177
177
  ElementIDUtils.addIDInfoIfNotExists(this._elem, 'input');
178
- return (h(Host, null, h("ez-classic-input", { "data-element-id": ElementIDUtils.getInternalIDInfo("textInput"), ref: (elem) => this._textInput = elem, "data-slave-mode": "true", label: this.label, onBlur: () => this.handleBlur(), onInput: (evt) => this.handleInput(evt), restrict: "0123456789/", enabled: this.enabled, errorMessage: this.errorMessage, mode: this.mode, size: this.size, canShowError: this.canShowError, alternativePlaceholder: this.alternativePlaceholder, required: this.required, leftIconName: "calendar", leftIconClickable: this.enabled, onIconClick: () => { var _a; return (_a = this._popover) === null || _a === void 0 ? void 0 : _a.showUnder(this._textInput); }, onEzChange: (event) => event.stopPropagation() }), h("ez-popover-plus", { ref: elem => this._popover = elem, anchorElement: this._textInput, autoClose: true, boxWidth: 'fit-content', overlayType: 'none', "data-element-id": this._elem.getAttribute("data-element-id"), onEzVisibilityChange: (event) => event.stopPropagation() }, h("ez-calendar", { ref: elem => this._calendar = elem, "data-element-id": ElementIDUtils.getInternalIDInfo("calendar"), onEzChange: (event) => this.handleChangeCalendar(event), value: this.value }))));
178
+ return (h(Host, null, h("ez-classic-input", { "data-element-id": ElementIDUtils.getInternalIDInfo("textInput"), ref: (elem) => this._textInput = elem, "data-slave-mode": "true", label: this.label, onBlur: () => this.handleBlur(), onInput: (evt) => this.handleInput(evt), mask: "##/##/####", enabled: this.enabled, errorMessage: this.errorMessage, mode: this.mode, size: this.size, canShowError: this.canShowError, alternativePlaceholder: this.alternativePlaceholder, required: this.required, leftIconName: "calendar", leftIconClickable: this.enabled, onIconClick: () => { var _a; return (_a = this._popover) === null || _a === void 0 ? void 0 : _a.showUnder(this._textInput); }, onEzChange: (event) => event.stopPropagation() }), h("ez-popover-plus", { ref: elem => this._popover = elem, anchorElement: this._textInput, autoClose: true, boxWidth: 'fit-content', overlayType: 'none', "data-element-id": this._elem.getAttribute("data-element-id"), onEzVisibilityChange: (event) => event.stopPropagation() }, h("ez-calendar", { ref: elem => this._calendar = elem, "data-element-id": ElementIDUtils.getInternalIDInfo("calendar"), onEzChange: (event) => this.handleChangeCalendar(event), value: this.value }))));
179
179
  }
180
180
  static get is() { return "ez-classic-date-input"; }
181
181
  static get encapsulation() { return "shadow"; }
@@ -107,12 +107,57 @@ export class EzClassicInput {
107
107
  const cleanValue = this._maskFormatter.removeMask(formattedValue);
108
108
  return { formattedValue, cleanValue };
109
109
  }
110
+ isDataChar(char) {
111
+ return /[a-zA-Z0-9]/.test(char);
112
+ }
113
+ countDataCharsBefore(value, pos) {
114
+ let count = 0;
115
+ for (let i = 0; i < pos && i < value.length; i++) {
116
+ if (this.isDataChar(value[i]))
117
+ count++;
118
+ }
119
+ return count;
120
+ }
121
+ skipLeadingSeparators(value, pos) {
122
+ while (pos < value.length && !this.isDataChar(value[pos])) {
123
+ pos++;
124
+ }
125
+ return pos;
126
+ }
127
+ findPositionAfterDataChars(formattedValue, targetCount) {
128
+ let count = 0;
129
+ for (let i = 0; i <= formattedValue.length; i++) {
130
+ if (count === targetCount) {
131
+ return this.skipLeadingSeparators(formattedValue, i);
132
+ }
133
+ if (i < formattedValue.length && this.isDataChar(formattedValue[i])) {
134
+ count++;
135
+ }
136
+ }
137
+ return formattedValue.length;
138
+ }
139
+ getCursorPositionAfterFormat(rawValue, formattedValue, cursorPos) {
140
+ const dataCharCount = this.countDataCharsBefore(rawValue, cursorPos);
141
+ return this.findPositionAfterDataChars(formattedValue, dataCharCount);
142
+ }
143
+ restoreCursorSelection(inputElement, rawValue, formattedValue, savedStart, savedEnd) {
144
+ const newStart = this.getCursorPositionAfterFormat(rawValue, formattedValue, savedStart);
145
+ const newEnd = savedStart === savedEnd
146
+ ? newStart
147
+ : this.getCursorPositionAfterFormat(rawValue, formattedValue, savedEnd);
148
+ inputElement.setSelectionRange(newStart, newEnd);
149
+ }
110
150
  updateInputValue(inputElement, formattedValue, cleanValue) {
151
+ const rawValue = inputElement.value;
152
+ const savedStart = inputElement.selectionStart;
153
+ const savedEnd = inputElement.selectionEnd;
111
154
  inputElement.value = formattedValue;
155
+ if (savedStart !== null && savedEnd !== null) {
156
+ this.restoreCursorSelection(inputElement, rawValue, formattedValue, savedStart, savedEnd);
157
+ }
112
158
  this._internalValueChange = true;
113
159
  this.value = cleanValue;
114
- const emitValue = this.emitMaskedValue ? formattedValue : cleanValue;
115
- this.ezChange.emit(emitValue);
160
+ this.ezChange.emit(this.emitMaskedValue ? formattedValue : cleanValue);
116
161
  }
117
162
  updateInputValueWithoutMask(inputValue) {
118
163
  this._internalValueChange = true;
@@ -6,6 +6,7 @@ export class MaskFormatter {
6
6
  'U': (char) => /[a-zA-Z]/.test(char),
7
7
  'L': (char) => /[a-zA-Z]/.test(char),
8
8
  'A': (char) => /[a-zA-Z0-9]/.test(char),
9
+ 'Z': (char) => /[a-zA-Z0-9]/.test(char),
9
10
  '?': (char) => /[a-zA-Z]/.test(char),
10
11
  '*': () => true
11
12
  };
@@ -35,7 +36,7 @@ export class MaskFormatter {
35
36
  }
36
37
  if (this.maskChars[maskChar]) {
37
38
  if (this.maskChars[maskChar](inputChar)) {
38
- if (maskChar === 'U') {
39
+ if (maskChar === 'U' || maskChar === 'Z') {
39
40
  formattedValue += inputChar.toUpperCase();
40
41
  }
41
42
  else if (maskChar === 'L') {
@@ -86,6 +86,9 @@
86
86
  /*@doc Define a largura da barra de rolagem do componente.*/
87
87
  --ez-classic-search__scrollbar--width: var(--space--medium, 12px);
88
88
 
89
+ /*@doc Define a cor do texto de ajuda do input.*/
90
+ --ez-classic-input--helptext-color: var(--color--ocean-green-1000, #00281D);
91
+
89
92
  /***************
90
93
  host style
91
94
  ***************/
@@ -96,6 +99,7 @@
96
99
 
97
100
  /*public*/
98
101
  width: var(--ez-classic-search--width);
102
+ font-family: var(--font--pattern, Arial, sans-serif);
99
103
  }
100
104
 
101
105
  ez-icon {
@@ -403,4 +407,22 @@ ez-classic-input:hover .btn__close, ez-c-input:focus .btn__close {
403
407
  color: var(--color--red-600, #BD0025);
404
408
  margin-left: var(--space--4, 4px);
405
409
  vertical-align: top;
410
+ }
411
+
412
+ .ez-classic-search-plus__error-container {
413
+ display: flex;
414
+ flex-grow: 1;
415
+ gap: 3px;
416
+ overflow: hidden;
417
+ }
418
+
419
+ .ez-classic-search-plus__error-container span {
420
+ font-size: var(--font-size--xsmall, 10px);
421
+ line-height: var(--line-height--16, 16px);
422
+ overflow: hidden;
423
+ text-overflow: ellipsis;
424
+ animation: ez-helptext-fadein 0.3s ease;
425
+
426
+ /* public */
427
+ color: var(--ez-classic-input--helptext-color);
406
428
  }
@@ -38,6 +38,8 @@ export class EzClassicSearchPlus {
38
38
  this.searchDescriptionIsOpen = false;
39
39
  this.visibleOptions = undefined;
40
40
  this.showLoading = true;
41
+ this.canShowClearButton = false;
42
+ this.isHoveringDescription = false;
41
43
  }
42
44
  async observeValue(newValue, oldValue) {
43
45
  var _a;
@@ -51,11 +53,11 @@ export class EzClassicSearchPlus {
51
53
  return;
52
54
  }
53
55
  if (newNormalizedValue === undefined) {
54
- this.codeValue = undefined;
55
- this.descriptionValue = undefined;
56
+ this.clearSearch();
56
57
  this.ezChange.emit(undefined);
57
58
  return;
58
59
  }
60
+ this.canShowClearButton = this.getClearButtonStatus();
59
61
  this.codeValue = newNormalizedValue;
60
62
  try {
61
63
  this.descriptionValue = await this.normalizeCodeToDescriptionValue(newValue);
@@ -149,12 +151,14 @@ export class EzClassicSearchPlus {
149
151
  }
150
152
  }
151
153
  clearSearch() {
152
- this.value = null;
153
- this.codeValue = null;
154
- this.descriptionValue = null;
154
+ this._textInputCodeValue.value = null;
155
155
  if (!this.hideDescriptionInput) {
156
156
  this._textInputDescriptionValue.value = null;
157
157
  }
158
+ this.value = null;
159
+ this.codeValue = null;
160
+ this.descriptionValue = null;
161
+ this.canShowClearButton = false;
158
162
  }
159
163
  async normalizeCodeToDescriptionValue(valueToNormalize) {
160
164
  if (!valueToNormalize) {
@@ -198,7 +202,7 @@ export class EzClassicSearchPlus {
198
202
  }
199
203
  async loadDescriptionValueByCode(codeValue) {
200
204
  if (!this.optionLoader) {
201
- console.warn(this.i18n("ez-search-plus.optionLoaderNotDefined"));
205
+ console.warn(this.i18n("ez-classic-search-plus.optionLoaderNotDefined"));
202
206
  return "";
203
207
  }
204
208
  try {
@@ -228,7 +232,7 @@ export class EzClassicSearchPlus {
228
232
  }
229
233
  async loadAdvancedSearch() {
230
234
  if (!this.optionLoader) {
231
- console.warn(this.i18n("ez-search-plus.optionLoaderNotDefined"));
235
+ console.warn(this.i18n("ez-classic-search-plus.optionLoaderNotDefined"));
232
236
  return;
233
237
  }
234
238
  const searchArgument = { mode: SearchMode.ADVANCED, argument: "" };
@@ -255,6 +259,7 @@ export class EzClassicSearchPlus {
255
259
  this._popover.showUnder(this.el);
256
260
  }
257
261
  const argument = event.target.value;
262
+ this.canShowClearButton = this.getClearButtonStatus();
258
263
  await this.debounceLoaderOptions(argument);
259
264
  }
260
265
  async debounceLoaderOptions(argument) {
@@ -373,15 +378,23 @@ export class EzClassicSearchPlus {
373
378
  event.stopPropagation();
374
379
  this.searchDescriptionIsOpen = event.detail;
375
380
  }
376
- render() {
381
+ getClearButtonStatus() {
377
382
  var _a, _b;
383
+ if (this.ensureClearButtonVisible) {
384
+ return true;
385
+ }
386
+ if (((_a = this._textInputCodeValue) === null || _a === void 0 ? void 0 : _a.value) || ((_b = this._textInputDescriptionValue) === null || _b === void 0 ? void 0 : _b.value)) {
387
+ return true;
388
+ }
389
+ return !!this.value;
390
+ }
391
+ render() {
378
392
  ElementIDUtils.addIDInfoIfNotExists(this.el, 'input');
379
- const canShowClearButton = !this.ensureClearButtonVisible && (!this.value && !((_a = this._textInputCodeValue) === null || _a === void 0 ? void 0 : _a.value) && !((_b = this._textInputDescriptionValue) === null || _b === void 0 ? void 0 : _b.value));
380
393
  return (h(Host, null, h("div", { class: "ez-classic-search-plus__wrapper" }, h("div", { class: "ez-classic-search-plus__label-container" }, h("label", { title: this.label }, this.label), this.required && h("span", { class: "required-indicator" }, "*")), h("div", { class: "ez-classic-search-plus__container" }, h("ez-classic-input", { ref: (elem) => this._textInputCodeValue = elem, class: {
381
394
  "ez-classic-search-plus__code-input": !this.hideDescriptionInput,
382
395
  "ez-classic-search-plus__code-input-no-border": !this.hideDescriptionInput,
383
396
  "ez-classic-search-plus__code-input-full": this.hideDescriptionInput
384
- }, "data-element-id": ElementIDUtils.getInternalIDInfo("codeInput"), "data-slave-mode": "true", enabled: !this.disableCodeInput && this.enabled, size: this.size, label: null, errorMessage: this.hideDescriptionInput ? this.errorMessage : "", value: this.codeValue, onFocusout: () => this.handleCodeInputFocusOut(), onFocus: () => this.handleCodeInputFocus(), leftIconName: "search", leftIconClickable: this.enabled, onIconClick: () => this.handleSearchClick(), onEzChange: (event) => event.stopPropagation() }), !this.hideDescriptionInput && (h("div", { class: "description-input-container" }, h("ez-classic-input", { ref: (elem) => this._textInputDescriptionValue = elem, tabIndex: -1, class: { "ez-classic-search-plus__text-input": true }, "data-element-id": ElementIDUtils.getInternalIDInfo("textInput"), "data-slave-mode": "true", enabled: !this.disableDescriptionInput && this.enabled, label: null, errorMessage: this.errorMessage, size: this.size, value: this.descriptionValue, onInput: (event) => this.handleTextInputChangeHandler(event), onFocus: () => this.handleDescriptionInputFocus(), rightIconName: canShowClearButton ? "close" : null, rightIconClickable: this.enabled, onIconClick: () => this.clearSearch(), onEzChange: (event) => event.stopPropagation() }), h("ez-popover-plus", { ref: elem => this._popover = elem, anchorElement: this.el, autoClose: true, boxWidth: 'fit-content', overlayType: 'none', useAnchorSize: true, onEzVisibilityChange: (event) => this.handleOnEzVisibilityChange(event), "data-element-id": this.el.getAttribute("data-element-id") }, h("ez-classic-search-result-list", { ref: (ref) => this._classicSearchList = ref, showLoading: this.showLoading, visibleOptions: this.visibleOptions, value: this.value, showOptionValue: this.showOptionValue, onChangeValue: (evt) => this.handleSelectItem(evt) }))))))));
397
+ }, "data-element-id": ElementIDUtils.getInternalIDInfo("codeInput"), "data-slave-mode": "true", enabled: !this.disableCodeInput && this.enabled, size: this.size, label: null, errorMessage: this.hideDescriptionInput ? this.errorMessage : "", value: this.codeValue, onFocusout: () => this.handleCodeInputFocusOut(), onFocus: () => this.handleCodeInputFocus(), leftIconName: "search", leftIconClickable: this.enabled, onIconClick: () => this.handleSearchClick(), onEzChange: (event) => event.stopPropagation(), state: this.errorMessage && this.canShowError ? "error" : "default" }), !this.hideDescriptionInput && (h("div", { class: "description-input-container", onMouseEnter: () => this.isHoveringDescription = true, onMouseLeave: () => this.isHoveringDescription = false }, h("ez-classic-input", { ref: (elem) => this._textInputDescriptionValue = elem, tabIndex: -1, class: { "ez-classic-search-plus__text-input": true }, "data-element-id": ElementIDUtils.getInternalIDInfo("textInput"), "data-slave-mode": "true", enabled: !this.disableDescriptionInput && this.enabled, label: null, size: this.size, value: this.descriptionValue, onInput: (event) => this.handleTextInputChangeHandler(event), onFocus: () => this.handleDescriptionInputFocus(), rightIconName: this.canShowClearButton && this.isHoveringDescription ? "close" : null, rightIconClickable: this.enabled, onIconClick: () => this.clearSearch(), onEzChange: (event) => event.stopPropagation(), rightIconTooltip: this.i18n("ez-classic-search-plus.clearValue"), state: this.errorMessage && this.canShowError ? "error" : "default" }), h("ez-popover-plus", { ref: elem => this._popover = elem, anchorElement: this.el, autoClose: true, boxWidth: 'fit-content', overlayType: 'none', useAnchorSize: true, onEzVisibilityChange: (event) => this.handleOnEzVisibilityChange(event), "data-element-id": this.el.getAttribute("data-element-id") }, h("ez-classic-search-result-list", { ref: (ref) => this._classicSearchList = ref, showLoading: this.showLoading, visibleOptions: this.visibleOptions, value: this.value, showOptionValue: this.showOptionValue, onChangeValue: (evt) => this.handleSelectItem(evt) }))))), h("div", { class: "ez-classic-search-plus__error-container" }, h("span", null, this.errorMessage)))));
385
398
  }
386
399
  static get is() { return "ez-classic-search-plus"; }
387
400
  static get encapsulation() { return "shadow"; }
@@ -859,7 +872,9 @@ export class EzClassicSearchPlus {
859
872
  "isLoadingDescription": {},
860
873
  "searchDescriptionIsOpen": {},
861
874
  "visibleOptions": {},
862
- "showLoading": {}
875
+ "showLoading": {},
876
+ "canShowClearButton": {},
877
+ "isHoveringDescription": {}
863
878
  };
864
879
  }
865
880
  static get events() {
@@ -161,7 +161,7 @@ export class EzClassicTimeInput {
161
161
  value: this._viewValue,
162
162
  enabled: this.enabled,
163
163
  label: this.label,
164
- restrict: "0123456789:",
164
+ mask: this.showSeconds ? "##:##:##" : "##:##",
165
165
  onBlur: () => this.handleBlur(),
166
166
  onInput: () => this.handleInput(),
167
167
  errorMessage: this.errorMessage,
@@ -169,7 +169,8 @@ export class EzClassicTimeInput {
169
169
  size: this.size,
170
170
  canShowError: this.canShowError,
171
171
  alternativePlaceholder: this.alternativePlaceholder,
172
- required: this.required
172
+ required: this.required,
173
+ onEzChange: (event) => event.stopPropagation()
173
174
  };
174
175
  return (h(Host, null, h("ez-classic-input", Object.assign({}, inputProps, { leftIconName: "timer-outline" }))));
175
176
  }
@@ -3,7 +3,7 @@
3
3
  /*@doc Define a posição do componente.*/
4
4
  --ez-dropdown--z-index: var(--more-visible, 2);
5
5
  /*@doc Define o espaçamento interno do componente.*/
6
- --ez-dropdown--padding: var(--space--small, 6px);
6
+ --ez-dropdown--padding: var(--space--16, 16px);
7
7
  /*@doc Define a sombra externa do componente.*/
8
8
  --ez-dropdown--box-shadow: var(--shadow--medium, 0px 8px 24px rgba(0, 38, 111, 0.1));
9
9
  /*@doc Define o raio da borda do componente.*/
@@ -16,7 +16,7 @@ export class EzEmptyCard {
16
16
  }
17
17
  }
18
18
  render() {
19
- const customStyleVars = Object.assign(Object.assign({}, (this.height ? { '--ez-empty-card--custom-height': `${this.height}px` } : {})), (this.width ? { '--ez-empty-card--custom-width': `${this.width}px` } : {}));
19
+ const customStyleVars = Object.assign(Object.assign({}, (this.height ? { '--ez-empty-card--custom-height': `${this.height}${typeof this.height == "number" ? 'px' : ''}` } : {})), (this.width ? { '--ez-empty-card--custom-width': `${this.width}${typeof this.width == "number" ? 'px' : ''}` } : {}));
20
20
  return (h(Host, { style: customStyleVars }, h("div", { ref: element => this._container = element, class: `card_container ${this.color}` }, h("slot", null))));
21
21
  }
22
22
  static get is() { return "ez-empty-card"; }
@@ -52,11 +52,11 @@ export class EzEmptyCard {
52
52
  "defaultValue": "\"default\""
53
53
  },
54
54
  "height": {
55
- "type": "number",
55
+ "type": "any",
56
56
  "mutable": false,
57
57
  "complexType": {
58
- "original": "number",
59
- "resolved": "number",
58
+ "original": "number | string",
59
+ "resolved": "number | string",
60
60
  "references": {}
61
61
  },
62
62
  "required": false,
@@ -69,11 +69,11 @@ export class EzEmptyCard {
69
69
  "reflect": true
70
70
  },
71
71
  "width": {
72
- "type": "number",
72
+ "type": "any",
73
73
  "mutable": false,
74
74
  "complexType": {
75
- "original": "number",
76
- "resolved": "number",
75
+ "original": "number | string",
76
+ "resolved": "number | string",
77
77
  "references": {}
78
78
  },
79
79
  "required": false,
@@ -48,6 +48,7 @@ export default class AgGridController {
48
48
  this.DEFAULT_FONT_SIZE_HTML5 = 32;
49
49
  this.DEFAULT_ICON_SIZE = 40;
50
50
  this.DEFAULT_MAX_SIZE = 300;
51
+ this.MULTI_VALUES_PROP = '__multiValues';
51
52
  this._menuItems = [];
52
53
  this._idAttribName = '__record__id__';
53
54
  this._gridConfig = [];
@@ -126,21 +127,24 @@ export default class AgGridController {
126
127
  const params = [];
127
128
  let isNullIncluded;
128
129
  checkedOptions.forEach(option => {
129
- const paramName = `PARAM_${column}_${params.length + 1}`;
130
- params.push({
131
- dataType: dataType === DataType.OBJECT ? DataType.TEXT : dataType,
132
- name: paramName,
133
- value: option.value,
134
- });
135
- if (option.value == undefined) {
136
- isNullIncluded = true;
137
- }
138
- else {
139
- if (placeholders.length > 0) {
140
- placeholders = placeholders + ',';
130
+ const optionValues = this.resolveColumnFilterValues(option);
131
+ optionValues.forEach(value => {
132
+ const paramName = `PARAM_${column}_${params.length + 1}`;
133
+ params.push({
134
+ dataType: dataType === DataType.OBJECT ? DataType.TEXT : dataType,
135
+ name: paramName,
136
+ value,
137
+ });
138
+ if (value == undefined) {
139
+ isNullIncluded = true;
141
140
  }
142
- placeholders = `${placeholders}:${paramName}`;
143
- }
141
+ else {
142
+ if (placeholders.length > 0) {
143
+ placeholders = placeholders + ',';
144
+ }
145
+ placeholders = `${placeholders}:${paramName}`;
146
+ }
147
+ });
144
148
  });
145
149
  return {
146
150
  name: `${DISTINCT_FILTER_NAME_PREFIX}${column}`,
@@ -162,6 +166,13 @@ export default class AgGridController {
162
166
  }
163
167
  return `${columnExpression} in (${placeholders})`;
164
168
  }
169
+ resolveColumnFilterValues(option) {
170
+ const multiValues = option === null || option === void 0 ? void 0 : option[this.MULTI_VALUES_PROP];
171
+ if (Array.isArray(multiValues) && multiValues.length > 0) {
172
+ return multiValues;
173
+ }
174
+ return [option.value];
175
+ }
165
176
  initDatagrid(container, options) {
166
177
  var _a;
167
178
  this._options = options;
@@ -59,10 +59,8 @@
59
59
  outline: none;
60
60
 
61
61
  /*public*/
62
- box-shadow: var(--ez-grid__container--shadow);
63
62
  background-color: var(--ez-grid__header--background-color);
64
- border: var(--border--small) var(--color--strokes);
65
- border-radius: var(--border--radius-small);
63
+ border-radius: var(--border--radius-12, 12px) var(--border--radius-12, 12px) 0 0;
66
64
  }
67
65
 
68
66
  .grid__container.no-scroll{
@@ -142,30 +140,10 @@
142
140
  padding: 0;
143
141
  }
144
142
 
145
- .grid-header__pagination{
146
- justify-content: flex-end;
147
- flex-wrap: nowrap;
148
- flex-shrink: 1;
149
- flex-grow: 1;
150
- }
151
-
152
- .grid-header__pagination-label {
153
- width: 100%;
154
- white-space: nowrap
155
- }
156
-
157
143
  .overflowed {
158
144
  display: none;
159
145
  }
160
146
 
161
- .pagination-contracted {
162
- width: 100px;
163
- }
164
-
165
- .pagination-expanded{
166
- min-width: 150px;
167
- }
168
-
169
147
  .left__header-contracted {
170
148
  width: auto;
171
149
  }
@@ -176,41 +154,4 @@
176
154
 
177
155
  .grid__footer{
178
156
  background-color: var(--background--xlight, #FFF);
179
- border-radius: 0 0 var(--border--radius-medium) var(--border--radius-medium);
180
- box-shadow: var(--shadow--small);
181
- }
182
-
183
- .cancel-pagination{
184
- display: flex;
185
- flex-direction: row;
186
- align-items: center;
187
- justify-content: space-between;
188
- gap: 4px;
189
- padding: 8px;
190
- width: 180px;
191
- }
192
-
193
- .cancel-pagination-btn{
194
- color: var(--color--error);
195
- font-size: var(--text--medium);
196
- font-weight: var(--text-weight--large);
197
- font-family: var(--font-pattern, Roboto);
198
- text-wrap: nowrap;
199
- cursor: pointer;
200
- }
201
-
202
- .spin {
203
- animation-name: spin;
204
- animation-duration: 5000ms;
205
- animation-iteration-count: infinite;
206
- animation-timing-function: linear;
207
- }
208
-
209
- @keyframes spin {
210
- from {
211
- transform:rotate(0deg);
212
- }
213
- to {
214
- transform:rotate(360deg);
215
- }
216
157
  }