@sankhyalabs/sankhyablocks 1.1.22 → 1.1.25

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 (184) hide show
  1. package/dist/cjs/ApplicationUtils-05b74ee9.js +39 -0
  2. package/dist/cjs/AssetsUtils-7e3c38f9.js +24 -0
  3. package/dist/cjs/CSSVarsUtils-75ca9c64.js +19 -0
  4. package/dist/cjs/ez-action-chip.cjs.entry.js +27 -0
  5. package/dist/cjs/ez-application.cjs.entry.js +26 -0
  6. package/dist/cjs/ez-button_4.cjs.entry.js +660 -0
  7. package/dist/cjs/ez-calendar.cjs.entry.js +223 -0
  8. package/dist/cjs/ez-collapsible-box.cjs.entry.js +47 -0
  9. package/dist/cjs/ez-combo-box.cjs.entry.js +278 -0
  10. package/dist/cjs/ez-date-input.cjs.entry.js +102 -0
  11. package/dist/cjs/ez-date-time-input.cjs.entry.js +145 -0
  12. package/dist/cjs/ez-dialog.cjs.entry.js +89 -0
  13. package/dist/cjs/ez-form.cjs.entry.js +463 -0
  14. package/dist/cjs/ez-grid.cjs.entry.js +647 -0
  15. package/dist/cjs/ez-icon.cjs.entry.js +41 -0
  16. package/dist/cjs/ez-label-chip.cjs.entry.js +104 -0
  17. package/dist/cjs/ez-modal_2.cjs.entry.js +316 -0
  18. package/dist/cjs/ez-number-input.cjs.entry.js +86 -0
  19. package/dist/cjs/ez-popover.cjs.entry.js +120 -0
  20. package/dist/cjs/ez-popup.cjs.entry.js +48 -0
  21. package/dist/cjs/ez-search.cjs.entry.js +64 -0
  22. package/dist/cjs/ez-tabselector.cjs.entry.js +198 -0
  23. package/dist/cjs/ez-text-area.cjs.entry.js +114 -0
  24. package/dist/cjs/ez-text-input.cjs.entry.js +201 -0
  25. package/dist/cjs/ez-time-input.cjs.entry.js +118 -0
  26. package/dist/cjs/ez-toast.cjs.entry.js +44 -0
  27. package/dist/cjs/ez-upload.cjs.entry.js +356 -0
  28. package/dist/cjs/index-682c98b2.js +1771 -0
  29. package/dist/cjs/loader.cjs.js +3 -3
  30. package/dist/cjs/sankhyablocks.cjs.js +3 -3
  31. package/dist/cjs/snk-application.cjs.entry.js +319 -1275
  32. package/dist/cjs/test-du.cjs.entry.js +76 -0
  33. package/dist/collection/collection-manifest.json +37 -2
  34. package/dist/collection/components/snk-application/snk-application.js +8 -4
  35. package/dist/collection/lib/http/data-fetcher/fetchers/dataunit-fetcher.js +16 -9
  36. package/dist/{collection/temp → components}/ApplicationUtils.js +37 -31
  37. package/dist/components/AssetsUtils.js +22 -0
  38. package/dist/components/CSSVarsUtils.js +17 -0
  39. package/dist/components/ez-action-chip.js +44 -0
  40. package/dist/components/ez-application.js +39 -0
  41. package/dist/components/ez-button.js +6 -0
  42. package/dist/components/ez-button2.js +105 -0
  43. package/dist/components/ez-calendar.js +6 -0
  44. package/dist/components/ez-calendar2.js +242 -0
  45. package/dist/components/ez-check.js +6 -0
  46. package/dist/components/ez-check2.js +94 -0
  47. package/dist/components/ez-collapsible-box.js +67 -0
  48. package/dist/components/ez-combo-box.js +6 -0
  49. package/dist/components/ez-combo-box2.js +311 -0
  50. package/dist/components/ez-date-input.js +135 -0
  51. package/dist/components/ez-date-time-input.js +179 -0
  52. package/dist/components/ez-dialog.js +124 -0
  53. package/dist/components/ez-form.js +6 -0
  54. package/dist/components/ez-form2.js +485 -0
  55. package/dist/components/ez-grid.js +738 -0
  56. package/dist/components/ez-icon.js +6 -0
  57. package/dist/components/ez-icon2.js +56 -0
  58. package/dist/components/ez-label-chip.js +125 -0
  59. package/dist/components/ez-list.js +6 -0
  60. package/dist/components/ez-list2.js +523 -0
  61. package/dist/components/ez-modal.js +6 -0
  62. package/dist/components/ez-modal2.js +82 -0
  63. package/dist/components/ez-number-input.js +115 -0
  64. package/dist/components/ez-popover.js +145 -0
  65. package/dist/components/ez-popup.js +67 -0
  66. package/dist/components/ez-search.js +100 -0
  67. package/dist/components/ez-tabselector.js +6 -0
  68. package/dist/components/ez-tabselector2.js +213 -0
  69. package/dist/components/ez-text-area.js +137 -0
  70. package/dist/components/ez-text-input.js +6 -0
  71. package/dist/components/ez-text-input2.js +223 -0
  72. package/dist/components/ez-time-input.js +153 -0
  73. package/dist/components/ez-toast.js +64 -0
  74. package/dist/components/ez-upload.js +382 -0
  75. package/dist/components/grid-config.js +6 -0
  76. package/dist/components/grid-config2.js +318 -0
  77. package/dist/components/select-box.js +6 -0
  78. package/dist/components/select-box2.js +47 -0
  79. package/dist/components/snk-application.js +310 -1266
  80. package/dist/components/test-du.js +101 -0
  81. package/dist/esm/ApplicationUtils-e0b6d857.js +37 -0
  82. package/dist/esm/AssetsUtils-6e6624dc.js +22 -0
  83. package/dist/esm/CSSVarsUtils-0787c3f3.js +17 -0
  84. package/dist/esm/ez-action-chip.entry.js +23 -0
  85. package/dist/esm/ez-application.entry.js +22 -0
  86. package/dist/esm/ez-button_4.entry.js +653 -0
  87. package/dist/esm/ez-calendar.entry.js +219 -0
  88. package/dist/esm/ez-collapsible-box.entry.js +43 -0
  89. package/dist/esm/ez-combo-box.entry.js +274 -0
  90. package/dist/esm/ez-date-input.entry.js +98 -0
  91. package/dist/esm/ez-date-time-input.entry.js +141 -0
  92. package/dist/esm/ez-dialog.entry.js +85 -0
  93. package/dist/esm/ez-form.entry.js +459 -0
  94. package/dist/esm/ez-grid.entry.js +643 -0
  95. package/dist/esm/ez-icon.entry.js +37 -0
  96. package/dist/esm/ez-label-chip.entry.js +100 -0
  97. package/dist/esm/ez-modal_2.entry.js +311 -0
  98. package/dist/esm/ez-number-input.entry.js +82 -0
  99. package/dist/esm/ez-popover.entry.js +116 -0
  100. package/dist/esm/ez-popup.entry.js +44 -0
  101. package/dist/esm/ez-search.entry.js +60 -0
  102. package/dist/esm/ez-tabselector.entry.js +194 -0
  103. package/dist/esm/ez-text-area.entry.js +110 -0
  104. package/dist/esm/ez-text-input.entry.js +197 -0
  105. package/dist/esm/ez-time-input.entry.js +114 -0
  106. package/dist/esm/ez-toast.entry.js +40 -0
  107. package/dist/esm/ez-upload.entry.js +352 -0
  108. package/dist/esm/index-35088a3f.js +1740 -0
  109. package/dist/esm/loader.js +3 -3
  110. package/dist/esm/sankhyablocks.js +3 -3
  111. package/dist/esm/snk-application.entry.js +311 -1267
  112. package/dist/esm/test-du.entry.js +72 -0
  113. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-action-chip/ez-action-chip.css +67 -0
  114. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-application/ez-application.css +3 -0
  115. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-button/ez-button.css +180 -0
  116. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-calendar/ez-calendar.css +319 -0
  117. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-check/ez-check.css +327 -0
  118. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-collapsible-box/ez-collapsible-box.css +162 -0
  119. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-combo-box/ez-combo-box.css +217 -0
  120. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-date-input/ez-date-input.css +49 -0
  121. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-date-time-input/ez-date-time-input.css +44 -0
  122. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-dialog/ez-dialog.css +527 -0
  123. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-form/ez-form.css +5 -0
  124. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-grid/ez-grid.css +31 -0
  125. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-grid/subcomponents/gridconfig/grid-config.css +129 -0
  126. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-grid/subcomponents/select-box/select-box.css +10 -0
  127. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-icon/ez-icon.css +176 -0
  128. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-label-chip/ez-label-chip.css +139 -0
  129. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-list/ez-list.css +335 -0
  130. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-modal/ez-modal.css +358 -0
  131. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-number-input/ez-number-input.css +4 -0
  132. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-popover/ez-popover.css +44 -0
  133. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-popup/ez-popup.css +405 -0
  134. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-search/ez-search.css +3 -0
  135. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-tabselector/ez-tabselector.css +138 -0
  136. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-text-area/ez-text-area.css +165 -0
  137. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-text-input/ez-text-input.css +196 -0
  138. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-time-input/ez-time-input.css +10 -0
  139. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-toast/ez-toast.css +127 -0
  140. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/ez-upload/ez-upload.css +568 -0
  141. package/dist/node_modules/@sankhyalabs/ezui/dist/collection/components/test-du/test-du.css +3 -0
  142. package/dist/sankhyablocks/p-0183d259.entry.js +1 -0
  143. package/dist/sankhyablocks/p-01f23a70.entry.js +1 -0
  144. package/dist/sankhyablocks/p-07c32f68.entry.js +1 -0
  145. package/dist/sankhyablocks/p-0f90499d.entry.js +1 -0
  146. package/dist/sankhyablocks/p-105724a3.entry.js +1 -0
  147. package/dist/sankhyablocks/p-2ac02d48.entry.js +1 -0
  148. package/dist/sankhyablocks/p-35364a97.entry.js +1 -0
  149. package/dist/sankhyablocks/p-3f6aa9a7.entry.js +1 -0
  150. package/dist/sankhyablocks/p-5f9af495.entry.js +1 -0
  151. package/dist/sankhyablocks/p-60967cf0.js +1 -0
  152. package/dist/sankhyablocks/p-6ce33b60.entry.js +57 -0
  153. package/dist/sankhyablocks/p-70ad6c16.entry.js +1 -0
  154. package/dist/sankhyablocks/p-710bfffe.entry.js +1 -0
  155. package/dist/sankhyablocks/p-735440c1.entry.js +1 -0
  156. package/dist/sankhyablocks/p-811b4b9d.js +1 -0
  157. package/dist/sankhyablocks/p-813fe4f7.js +1 -0
  158. package/dist/sankhyablocks/p-85a9446b.js +2 -0
  159. package/dist/sankhyablocks/p-89a1100f.entry.js +1 -0
  160. package/dist/sankhyablocks/p-8b543003.entry.js +1 -0
  161. package/dist/sankhyablocks/p-9750632b.entry.js +1 -0
  162. package/dist/sankhyablocks/p-a96272f7.entry.js +1 -0
  163. package/dist/sankhyablocks/p-ac8842e5.entry.js +1 -0
  164. package/dist/sankhyablocks/p-ba64cc41.entry.js +1 -0
  165. package/dist/sankhyablocks/p-c1ede043.entry.js +1 -0
  166. package/dist/sankhyablocks/p-d90ebb85.entry.js +1 -0
  167. package/dist/sankhyablocks/p-e17dfaae.entry.js +1 -0
  168. package/dist/sankhyablocks/p-e5355a29.entry.js +1 -0
  169. package/dist/sankhyablocks/p-ef04b633.entry.js +1 -0
  170. package/dist/sankhyablocks/p-f6db07fb.entry.js +1 -0
  171. package/dist/sankhyablocks/p-fcd9bd92.entry.js +1 -0
  172. package/dist/sankhyablocks/sankhyablocks.esm.js +1 -1
  173. package/dist/types/components/snk-application/snk-application.d.ts +1 -1
  174. package/dist/types/components.d.ts +7 -3
  175. package/dist/types/lib/http/data-fetcher/fetchers/dataunit-fetcher.d.ts +1 -0
  176. package/package.json +12 -7
  177. package/react/components.d.ts +29 -0
  178. package/react/components.js +29 -0
  179. package/react/components.js.map +1 -1
  180. package/dist/cjs/index-20a7d705.js +0 -733
  181. package/dist/esm/index-8d3572c4.js +0 -707
  182. package/dist/sankhyablocks/p-5fa264b9.js +0 -1
  183. package/dist/sankhyablocks/p-fe95f2c4.entry.js +0 -57
  184. package/dist/types/temp/ApplicationUtils.d.ts +0 -7
@@ -0,0 +1,48 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-682c98b2.js');
6
+
7
+ const ezPopupCss = ":host{display:flex;--ez-popup-z-index:var(--most-visible, 3);--ez-popup__container--color:var(--title--primary, #2b3a54);--ez-popup__container--padding:var(--space--large, 24px);--ez-popup__header--padding-bottom:var(--space--medium, 12px);--ez-popup__title--font-family:var(--font-pattern, \"'Sora', 'Algerian'\");--ez-popup__title--font-size:var(--title--extra-large, 24px);--ez-popup__title--color:var(--title--primary, #2b3a54);--ez-popup__title--font-weight:var(--text-weight--large, 600);--ez-popup__btn__close--icon-color:var(--title--primary, #2b3a54);--ez-popup__btn__close--icon:url('data:image/svg+xml;utf8,<svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M 8.2421753,6.9944578 13.743748,1.4930784 C 13.907781,1.3290628 14,1.1065946 14,0.87462511 14,0.64266712 13.907782,0.42019873 13.743748,0.25617155 13.579712,0.09215597 13.35727,6.48e-8 13.125266,6.48e-8 12.89338,6.48e-8 12.670821,0.09215634 12.506787,0.25617155 L 7.005215,5.7575508 1.5035972,0.25617155 C 1.3395631,0.09215597 1.1170968,6.48e-8 0.88511716,6.48e-8 0.65314917,6.48e-8 0.4306712,0.09215597 0.26663695,0.25617155 0.10260271,0.42019873 0.01045441,0.64266712 0.01045441,0.87462511 c 0,0.23196949 0.0921483,0.45443769 0.25618254,0.61845329 L 5.7682546,6.9944578 0.26663695,12.497027 c -0.0834745,0.08067 -0.15003245,0.1772 -0.19581514,0.283871 C 0.02505077,12.887561 9.831648e-4,13.002399 2.950369e-5,13.118395 -9.2415746e-4,13.234504 0.02125019,13.349689 0.06527245,13.457057 c 0.04401053,0.107479 0.10898307,0.205064 0.1911168,0.287137 0.0821454,0.08208 0.17979645,0.146888 0.28727561,0.190839 0.10747906,0.04395 0.22262954,0.06598 0.33872417,0.06493 0.116095,-10e-4 0.23082547,-0.0253 0.33747687,-0.07112 0.1066637,-0.04593 0.2031133,-0.112615 0.2837313,-0.196086 L 7.005215,8.2313646 12.506787,13.732768 c 0.164034,0.164027 0.386593,0.256125 0.618479,0.256125 0.232004,0 0.454446,-0.09209 0.618482,-0.256125 C 13.907781,13.568741 14,13.346308 14,13.114315 14,12.882323 13.90779,12.659888 13.743748,12.495861 Z\"/></svg>')}.overlay{position:fixed;display:flex;top:0px;z-index:var(--ez-popup-z-index);left:0px;width:100%;align-items:center;justify-content:center;box-sizing:border-box;height:100vh;backdrop-filter:blur(4px);background:rgba(0, 4, 12, 0.4)}.popup{display:flex;height:100%;align-items:center;justify-content:center;box-sizing:border-box}.popup__container{width:100%;max-height:90%;height:100%;display:flex;flex-wrap:wrap;overflow:hidden;background:#FFFF;color:var(--ez-popup__container--color);border-radius:12px;box-shadow:0px 0px 16px rgba(0, 38, 111, 0.122);box-sizing:border-box;padding:var(--ez-popup__container--padding)}.popup__content{box-sizing:border-box;max-height:100%;width:100%;display:grid;grid-template-rows:auto 1fr}.popup__expandable-content{box-sizing:border-box;overflow-y:auto;height:100%;width:100%}.popup__header{padding-bottom:var(--ez-popup__header--padding-bottom);width:100%;display:flex}.popup__title{display:flex;margin:0;width:100%;font-family:var(--ez-popup__title--font-family);font-size:var(--ez-popup__title--font-size);font-weight:var(--ez-popup__title--font-weight);color:var(--ez-popup__title--color);line-height:1.3}.btn-close{justify-content:flex-end;align-self:flex-start;align-items:flex-start;display:flex;outline:none;border:none;background-color:unset;cursor:pointer}.btn-close::after{content:'';display:flex;background-color:var(--ez-popup__btn__close--icon-color);width:14px;height:14px;-webkit-mask-image:var(--ez-popup__btn__close--icon);mask-image:var(--ez-popup__btn__close--icon)}.btn-close--solo{width:100%}.row{width:100%;display:flex;flex-wrap:wrap}.col{display:flex;flex-wrap:wrap;align-self:flex-start;box-sizing:border-box}.col--stretch{align-self:stretch}.col--undefined{width:unset}.col--nowrap{flex-wrap:nowrap}@media screen and (min-width: 320px){.col--sd-1{width:8.33333%}.col--sd-2{width:16.66667%}.col--sd-3{width:25%}.col--sd-4{width:33.33333%}.col--sd-5{width:41.66667%}.col--sd-6{width:50%}.col--sd-7{width:58.33333%}.col--sd-8{width:66.66667%}.col--sd-9{width:75%}.col--sd-10{width:83.33333%}.col--sd-11{width:91.66667%}.col--sd-12{width:100%}}@media screen and (min-width: 480px){.col--pn-1{width:8.33333%}.col--pn-2{width:16.66667%}.col--pn-3{width:25%}.col--pn-4{width:33.33333%}.col--pn-5{width:41.66667%}.col--pn-6{width:50%}.col--pn-7{width:58.33333%}.col--pn-8{width:66.66667%}.col--pn-9{width:75%}.col--pn-10{width:83.33333%}.col--pn-11{width:91.66667%}.col--pn-12{width:100%}}@media screen and (min-width: 768px){.col--tb-1{width:8.33333%}.col--tb-2{width:16.66667%}.col--tb-3{width:25%}.col--tb-4{width:33.33333%}.col--tb-5{width:41.66667%}.col--tb-6{width:50%}.col--tb-7{width:58.33333%}.col--tb-8{width:66.66667%}.col--tb-9{width:75%}.col--tb-10{width:83.33333%}.col--tb-11{width:91.66667%}.col--tb-12{width:100%}}@media screen and (min-width: 992px){.col--md-1{width:8.33333%}.col--md-2{width:16.66667%}.col--md-3{width:25%}.col--md-4{width:33.33333%}.col--md-5{width:41.66667%}.col--md-6{width:50%}.col--md-7{width:58.33333%}.col--md-8{width:66.66667%}.col--md-9{width:75%}.col--md-10{width:83.33333%}.col--md-11{width:91.66667%}.col--md-12{width:100%}}@media screen and (min-width: 1200px){.col--ld-1{width:8.33333%}.col--ld-2{width:16.66667%}.col--ld-3{width:25%}.col--ld-4{width:33.33333%}.col--ld-5{width:41.66667%}.col--ld-6{width:50%}.col--ld-7{width:58.33333%}.col--ld-8{width:66.66667%}.col--ld-9{width:75%}.col--ld-10{width:83.33333%}.col--ld-11{width:91.66667%}.col--ld-12{width:100%}}";
8
+
9
+ const EzPopup = class {
10
+ constructor(hostRef) {
11
+ index.registerInstance(this, hostRef);
12
+ this.ezClosePopup = index.createEvent(this, "ezClosePopup", 7);
13
+ this.sizeClasses = {
14
+ "x-small": "col--sd-3",
15
+ "small": "col--sd-5",
16
+ "medium": "col--sd-6",
17
+ "large": "col--sd-9",
18
+ "x-large": "col--sd-11"
19
+ };
20
+ /**
21
+ * Define o width que o componente deve ter, seguindo o grid system. Os valores devem estar
22
+ * compreendidos em [x-small | small | medium | large | x-large].
23
+ */
24
+ this.size = "medium";
25
+ /**
26
+ * Controla a exibição do componente.
27
+ */
28
+ this.opened = false;
29
+ /**
30
+ * Define se o componente utilizará um cabeçalho com botão de fechamento.
31
+ */
32
+ this.useHeader = false;
33
+ }
34
+ getGridSize() {
35
+ return this.sizeClasses[this.size] || this.sizeClasses["medium"];
36
+ }
37
+ render() {
38
+ if (this.opened) {
39
+ return (index.h(index.Host, null, index.h("div", { class: "overlay" }, index.h("div", { class: "popup col " + this.getGridSize() }, index.h("div", { class: "popup__container" }, index.h("div", { class: "popup__content" }, index.h("div", { class: "popup__header" }, this.ezTitle ?
40
+ index.h("div", { class: "popup__title" }, this.ezTitle)
41
+ : undefined, index.h("button", { class: this.ezTitle ? "btn-close" : "btn-close btn-close--solo", onClick: () => { this.opened = false; this.ezClosePopup.emit(); } })), index.h("div", { class: "popup__expandable-content" }, index.h("slot", null))))))));
42
+ }
43
+ return null;
44
+ }
45
+ };
46
+ EzPopup.style = ezPopupCss;
47
+
48
+ exports.ez_popup = EzPopup;
@@ -0,0 +1,64 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-682c98b2.js');
6
+ const CSSVarsUtils = require('./CSSVarsUtils-75ca9c64.js');
7
+
8
+ const ezSearchCss = ":host{width:100%}";
9
+
10
+ const EzSearch = class {
11
+ constructor(hostRef) {
12
+ index.registerInstance(this, hostRef);
13
+ this.ezChange = index.createEvent(this, "ezChange", 7);
14
+ this.showPopup = index.createEvent(this, "showPopup", 7);
15
+ /**
16
+ * Deixa o campo disponível ou não.
17
+ */
18
+ this.enabled = true;
19
+ /**
20
+ * Ajusta a opção de mostrar o "value" ao selecionar uma opção.
21
+ */
22
+ this.showSelectedValue = true;
23
+ /**
24
+ * Ajusta a opção de mostrar o "value" para cada opção.
25
+ */
26
+ this.showOptionValue = true;
27
+ }
28
+ updateValue() {
29
+ if (this._comboElement) {
30
+ this._comboElement.value = this.value;
31
+ }
32
+ }
33
+ /**
34
+ * Realiza o foco no componente de pesquisa
35
+ */
36
+ async setFocus() {
37
+ this._comboElement.setFocus();
38
+ }
39
+ /**
40
+ * Remove o foco no componente de pesquisa
41
+ */
42
+ async setBlur() {
43
+ this._comboElement.setBlur();
44
+ }
45
+ onComboChange(evt) {
46
+ evt.stopPropagation();
47
+ this.value = evt.detail;
48
+ this.ezChange.emit(evt.detail);
49
+ }
50
+ componentDidLoad() {
51
+ CSSVarsUtils.CSSVarsUtils.applyVarsTextInput(this._elem, this._comboElement);
52
+ }
53
+ render() {
54
+ return (index.h("ez-combo-box", { ref: elem => this._comboElement = elem, value: this.value, label: this.label, enabled: this.enabled, errorMessage: this.errorMessage, optionLoader: this.optionLoader, searchMode: true, onEzChange: evt => this.onComboChange(evt), showSelectedValue: this.showSelectedValue, showOptionValue: this.showOptionValue }));
55
+ }
56
+ ;
57
+ get _elem() { return index.getElement(this); }
58
+ static get watchers() { return {
59
+ "value": ["updateValue"]
60
+ }; }
61
+ };
62
+ EzSearch.style = ezSearchCss;
63
+
64
+ exports.ez_search = EzSearch;
@@ -0,0 +1,198 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-682c98b2.js');
6
+
7
+ const ezTabselectorCss = "@keyframes activate{0%{clip-path:inset(calc(100% - 3px) 50% 0px 50%)}100%{clip-path:inset(calc(100% - 3px) 0px 0px 0px)}}:host{display:flex;position:relative;width:100%;overflow:hidden;--tabselector--backward-icon:url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\" height=\"16px\" width=\"10px\"><path d=\"M 9.7808475,13.860393 3.9204526,8.0000004 9.7808475,2.0624965 7.9301965,0.28895552 0.21915255,8.0000004 7.9301965,15.711044 Z\"/></svg>');--tabselector--forward-icon:url('data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\" height=\"16px\" width=\"10px\"><path d=\"M 0.21915251,13.860393 6.0795475,8.0000007 0.21915251,2.0624968 2.0698036,0.28895588 9.7808475,8.0000007 2.0698036,15.711044 Z\"/></svg>')}.scroll{display:flex;width:100%;scroll-behavior:smooth;overflow-x:auto;scrollbar-width:none}.scroll.startHidden{-webkit-mask-image:linear-gradient(90deg, transparent 20px, #000 48px)}.scroll.midle{-webkit-mask-image:linear-gradient(90deg, transparent 20px, #000 48px, #000 calc(100% - 48px), transparent calc(100% - 20px))}.scroll.endHidden{-webkit-mask-image:linear-gradient(90deg, #000 calc(100% - 48px), transparent calc(100% - 20px))}.tab{display:flex;border:none;min-width:100px;background-color:unset;cursor:pointer;padding:6px 12px;align-items:center;justify-content:center;color:var(--text--primary, #626e82);font-family:var(--font-pattern, \"Sora, Algerian\");font-size:var(--title--small, 14px)}.tab:focus,.forward-button,.backward-button{outline:none}.is-active{position:relative;color:var(--color--primary, #008561)}.is-active::after{content:\"\";position:absolute;width:100%;height:100%;background-color:var(--color--primary, #008561);clip-path:inset(calc(100% - 3px) 0px 0px 0px);animation:activate 0.25s ease-in-out}.is-focused{border:1px dashed var(--color--primary, #000000c5)}.tab-label{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;text-shadow:var(--text-shadow);margin-bottom:var(--space--extra-small, 3px)}.forward-button,.backward-button{position:absolute;z-index:1;display:flex;box-sizing:border-box;padding:0px;top:0px;right:0px;width:16px;height:100%;border:none;background-color:unset;cursor:pointer;justify-content:center;align-items:center}.backward-button{left:0px}.forward-button::after,.backward-button::after{content:'';display:flex;background-color:var(--text--primary, #008561);width:10px;height:16px}.forward-button::after{-webkit-mask-image:var(--tabselector--forward-icon);mask-image:var(--tabselector--forward-icon)}.backward-button::after{-webkit-mask-image:var(--tabselector--backward-icon);mask-image:var(--tabselector--backward-icon)}.forward-button:hover::after,.backward-button:hover::after{background-color:var(--color--primary, #4e4e4e)}.hidden{display:none}.scroll::-webkit-scrollbar{display:none}";
8
+
9
+ const EzTabselector = class {
10
+ constructor(hostRef) {
11
+ index.registerInstance(this, hostRef);
12
+ this.ezChange = index.createEvent(this, "ezChange", 7);
13
+ this.setFocusedParam = (ev) => {
14
+ if (ev.key === "Enter") {
15
+ const selectedTab = this._processedTabs[this._focusedIndex];
16
+ this.handleTabClick(selectedTab);
17
+ ev.preventDefault();
18
+ this.setFocusedTab(selectedTab.index);
19
+ }
20
+ else if (ev.key === "ArrowLeft" || ev.key === "ArrowRight") {
21
+ let operator = undefined;
22
+ if (ev.key === "ArrowLeft") {
23
+ operator = false;
24
+ }
25
+ else if (ev.key === "ArrowRight") {
26
+ operator = true;
27
+ }
28
+ else {
29
+ return;
30
+ }
31
+ if (this._focusedIndex === undefined) {
32
+ if (operator === false) {
33
+ this._focusedIndex = this.selectedIndex !== undefined ? this.selectedIndex - 1 : undefined;
34
+ }
35
+ else {
36
+ this._focusedIndex = this.selectedIndex !== undefined ? this.selectedIndex + 1 : undefined;
37
+ }
38
+ }
39
+ else {
40
+ if (operator === false) {
41
+ this._focusedIndex = this._focusedIndex - 1;
42
+ }
43
+ else {
44
+ this._focusedIndex = this._focusedIndex + 1;
45
+ }
46
+ }
47
+ if (this._focusedIndex < 0) {
48
+ this._focusedIndex = 0;
49
+ }
50
+ else if (this._focusedIndex > this._processedTabs.length - 1) {
51
+ this._focusedIndex = this._processedTabs.length - 1;
52
+ }
53
+ this.setFocusedBtn(true, this._focusedIndex);
54
+ this.setFocusedTab(this._focusedIndex);
55
+ }
56
+ else if (ev.key === "Tab" || ev.key === "Escape") {
57
+ const currentTab = this._processedTabs[this.selectedIndex];
58
+ this._focusedIndex = undefined;
59
+ this.handleTabClick(currentTab);
60
+ ev.preventDefault();
61
+ this.setFocusedTab(this.selectedIndex);
62
+ }
63
+ };
64
+ }
65
+ handleTabClick(tab) {
66
+ this.selectedIndex = tab.index;
67
+ this._focusedIndex = undefined;
68
+ this.selectedTab = tab.tabKey;
69
+ this.ezChange.emit(tab);
70
+ this.setFocusedBtn(false, tab.index);
71
+ }
72
+ componentWillRender() {
73
+ if (!this._processedTabs) {
74
+ this._processedTabs = [];
75
+ if (this.tabs) {
76
+ this.tabs.split(",").forEach((label) => {
77
+ label = label.trim();
78
+ this._processedTabs.push({ label, tabKey: label, index: this._processedTabs.length });
79
+ });
80
+ }
81
+ this._hostElem.querySelectorAll("ez-tab").forEach((elem) => {
82
+ const tabKey = elem.getAttribute("tabKey");
83
+ const label = elem.getAttribute("label");
84
+ const t = { label, tabKey, index: this._processedTabs.length };
85
+ const content = elem.firstChild;
86
+ if (content) {
87
+ content.setAttribute("slot", "tab" + t.index);
88
+ this._hostElem.appendChild(content);
89
+ }
90
+ this._processedTabs.push(t);
91
+ });
92
+ }
93
+ }
94
+ handleSlotChange(ev) {
95
+ const slot = ev.target;
96
+ const content = slot.assignedElements()[0];
97
+ if (content) {
98
+ content.style.marginLeft = "6px";
99
+ }
100
+ }
101
+ scrollBackward() {
102
+ const container = this._scrollContainer;
103
+ if (container) {
104
+ container.scrollLeft -= container.clientWidth;
105
+ }
106
+ }
107
+ scrollFoward() {
108
+ const container = this._scrollContainer;
109
+ if (container) {
110
+ let lastTab = null;
111
+ container.querySelectorAll(".tab").forEach((tab) => {
112
+ if (tab.getBoundingClientRect().right < container.clientWidth) {
113
+ lastTab = tab;
114
+ }
115
+ });
116
+ container.scrollLeft = lastTab.offsetLeft + lastTab.offsetWidth;
117
+ }
118
+ }
119
+ componentDidRender() {
120
+ this.updateScroll();
121
+ }
122
+ updateScroll() {
123
+ const container = this._scrollContainer;
124
+ if (container) {
125
+ const { scrollWidth, clientWidth, scrollLeft } = container;
126
+ const remainingScroll = scrollWidth - clientWidth - Math.ceil(scrollLeft);
127
+ this._startHidden = container.scrollLeft > 0;
128
+ this._endHidden = remainingScroll > 0;
129
+ if (this._startHidden) {
130
+ this._backwardButton.classList.remove("hidden");
131
+ }
132
+ else {
133
+ this._backwardButton.classList.add("hidden");
134
+ }
135
+ if (this._endHidden) {
136
+ this._forwardButton.classList.remove("hidden");
137
+ }
138
+ else {
139
+ this._forwardButton.classList.add("hidden");
140
+ }
141
+ const classNames = ["", "startHidden", "endHidden", "midle"];
142
+ const currentClass = classNames[Number(this._startHidden) | Number(this._endHidden) << 1];
143
+ classNames.forEach((name) => {
144
+ if (name !== currentClass && container.classList.contains(name)) {
145
+ container.classList.remove(name);
146
+ }
147
+ });
148
+ if (currentClass && !container.classList.contains(currentClass)) {
149
+ container.classList.add(currentClass);
150
+ }
151
+ }
152
+ }
153
+ domScrollHandler() {
154
+ window.clearTimeout(this._scrollCallBack);
155
+ this._scrollCallBack = window.setTimeout(() => { this.updateScroll(); }, 200);
156
+ }
157
+ setFocusedTab(index) {
158
+ window.clearTimeout(this._scrollCallBackTest);
159
+ this._scrollCallBackTest = window.setTimeout(() => {
160
+ const tabtoscroll = this._scrollContainer.querySelector(`#tab${index}`);
161
+ tabtoscroll.scrollIntoView();
162
+ }, 200);
163
+ }
164
+ getTextWidth(text) {
165
+ if (this._textMesurement === undefined) {
166
+ this._textMesurement = this._hostElem.shadowRoot.ownerDocument.createElement("canvas");
167
+ }
168
+ const context = this._textMesurement.getContext("2d");
169
+ context.font = "14px Sora, Algerian";
170
+ return Math.min(220, 24 + context.measureText(text).width) + "px";
171
+ }
172
+ ;
173
+ setFocusedBtn(visible, parameter) {
174
+ const tabsButtons = this._scrollContainer.querySelectorAll(".tab");
175
+ tabsButtons.forEach((el) => {
176
+ el.classList.remove("is-focused");
177
+ if (el.id === "tab" + parameter && visible) {
178
+ el.classList.add("is-focused");
179
+ }
180
+ });
181
+ }
182
+ render() {
183
+ return (index.h(index.Host, null, index.h("button", { class: "backward-button", ref: (el) => this._backwardButton = el, onClick: () => this.scrollBackward() }), index.h("div", { class: "scroll", ref: (el) => this._scrollContainer = el, onScroll: () => this.domScrollHandler(), onKeyDown: (ev) => this.setFocusedParam(ev) }, this._processedTabs.map((tab, index$1) => {
184
+ const labelStyle = { "min-width": this.getTextWidth(tab.label) };
185
+ const tabId = "tab" + index$1;
186
+ const isSelected = index$1 === this.selectedIndex || (this.selectedTab && tab.tabKey === this.selectedTab);
187
+ if (isSelected) {
188
+ this.selectedTab = tab.tabKey;
189
+ this.selectedIndex = index$1;
190
+ }
191
+ return index.h("button", { id: tabId, class: `tab${isSelected ? " is-active" : ""}`, onClick: () => this.handleTabClick(tab), style: labelStyle }, index.h("span", { class: "tab-label", title: tab.label }, tab.label), index.h("slot", { name: tabId, onSlotchange: (ev) => { this.handleSlotChange(ev); } }));
192
+ })), index.h("button", { class: "forward-button", ref: (el) => this._forwardButton = el, onClick: () => this.scrollFoward() })));
193
+ }
194
+ get _hostElem() { return index.getElement(this); }
195
+ };
196
+ EzTabselector.style = ezTabselectorCss;
197
+
198
+ exports.ez_tabselector = EzTabselector;
@@ -0,0 +1,114 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-682c98b2.js');
6
+
7
+ const ezTextAreaCss = ":host{--text-area--width:100%;--text-area--border-radius:var(--border--radius-medium, 12px);--text-area--font-size:var(--text--medium, 14px);--text-area--font-family:var(--font-pattern, Arial);--text-area--font-weight:var(--text-weight--large, 500);--text-area--color:var(--title--primary, #000);--text-area__input--background-color:var(--background--medium, #e0e0e0);--text-area__input--border:var(--border--medium, 2px solid);--text-area__input--border-color:var(--text-area__input--background-color);--text-area__input--focus--border-color:var(--color--primary, #008561);--text-area__input--disabled--background-color:var(--color--disable-secondary, #F2F5F8);--text-area__input--disabled--color:var(--text--disable, #AFB6C0);--text-area__input--error--border-color:#CC2936;--text-area__message_box--font-size:var(--text--small, 12px);--text-area__message_box--info--color:var(--color--success, #22085d);--text-area__message_box--error--color:var(--color--error, #FF0000);--text-area__label--floating--top:6px;--text-area__label--padding-top:12px;--text-area__label--padding-left:14px;--text-area__label--padding-right:12px;display:flex;flex-wrap:wrap;position:relative;width:var(--text-area--width)}textarea{box-sizing:border-box;border:none;resize:none;margin-top:calc(var(--space--medium, 12px) + 4px);width:100%;font-weight:var(--text-weight--large, 600);font-family:var(--text-area--font-family);font-size:var(--text-area--font-size);color:var(--text-area--color);padding:0;background:none}textarea:focus{outline:none}textarea:disabled{background-color:transparent;color:var(--text-area__input--disabled--color)}.textarea{width:100%;box-sizing:border-box;padding-left:var(--space--medium);padding-right:var(--space--extra-small);border-radius:var(--text-area--border-radius);border:var(--text-area__input--border);border-color:var(--text-area__input--border-color);background-color:var(--text-area__input--background-color)}.textarea--focus{border-color:var(--text-area__input--focus--border-color)}.textarea.hasError{color:var(--text-area--color);border-color:var(--text-area__input--error--border-color)}.message-box{min-height:16px;min-width:100%;margin-top:3px;line-height:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--text-area--font-family);font-size:var(--text-area__message_box--font-size);color:var(--text-area__message_box--info--color)}.hasError{color:var(--text-area__message_box--error--color)}.textarea__label{box-sizing:border-box;position:absolute;z-index:var(--visible);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;-webkit-transition:font-size .05s, top .05s;transition:font-size .05s, top .05s;width:calc(100% - var(--text-area__label--padding-right));left:var(--text-area--space--medium);font-family:var(--text-area--font-family);font-size:var(--text-area--font-size);font-weight:var(--text-area--font-weight);color:var(--text-area--color);top:var(--text-area__label--padding-top);left:var(--text-area__label--padding-left);padding-right:var(--text-area__label--padding-right)}.textarea__label--floated{font-family:var(--text-area--font-family);font-size:var(--text--extra-small);color:var(--text--primary);top:var(--text-area__label--floating--top)}.textarea__label--disabled{color:var(--text-area__input--disabled--color)}";
8
+
9
+ const EzTextArea = class {
10
+ constructor(hostRef) {
11
+ index.registerInstance(this, hostRef);
12
+ this.ezChange = index.createEvent(this, "ezChange", 7);
13
+ /**
14
+ * Deixa o campo disponível ou não para digitação.
15
+ */
16
+ this.enabled = true;
17
+ /**
18
+ * Ajusta o número de linhas e consequentemente o height do textarea. Valor default: 4
19
+ */
20
+ this.rows = 4;
21
+ }
22
+ showError() {
23
+ const hasError = typeof this.errorMessage === 'string' && this.errorMessage !== '';
24
+ if (hasError) {
25
+ this._container.classList.add('hasError');
26
+ this._messageBoxElem.classList.add('hasError');
27
+ }
28
+ else {
29
+ this._container.classList.remove('hasError');
30
+ this._messageBoxElem.classList.remove('hasError');
31
+ }
32
+ }
33
+ updateInputValue() {
34
+ this._inputElem.value = this.value === undefined ? "" : this.value;
35
+ this.handleChange();
36
+ this.adjustFloatingLabel();
37
+ this.ezChange.emit(this.value);
38
+ }
39
+ adjustFloatingLabel() {
40
+ if (this.label) {
41
+ const hasValue = this.value && this.value.toString().length > 0;
42
+ const containsFloatedClass = this._labelElem.classList.contains("textarea__label--floated");
43
+ if (hasValue || this.isFocused()) {
44
+ if (!containsFloatedClass) {
45
+ this._labelElem.classList.add("textarea__label--floated");
46
+ }
47
+ }
48
+ else {
49
+ if (containsFloatedClass) {
50
+ this._labelElem.classList.remove("textarea__label--floated");
51
+ }
52
+ }
53
+ }
54
+ }
55
+ isFocused() {
56
+ return this._hostElement.shadowRoot.activeElement !== null;
57
+ }
58
+ //---------------------------------------------
59
+ // Public methods
60
+ //---------------------------------------------
61
+ /**
62
+ * Faz o foco no componente de input
63
+ */
64
+ async setFocus() {
65
+ this._inputElem.focus();
66
+ }
67
+ /**
68
+ * Remove o foco no componente de input
69
+ */
70
+ async setBlur() {
71
+ this._inputElem.blur();
72
+ }
73
+ //---------------------------------------------
74
+ // Event handlers
75
+ //---------------------------------------------
76
+ handleFocusout() {
77
+ this.adjustFloatingLabel();
78
+ if (this._container && this._container.classList.contains("textarea--focus")) {
79
+ this._container.classList.remove("textarea--focus");
80
+ }
81
+ }
82
+ handleChange() {
83
+ this.errorMessage = "";
84
+ this.value = this._inputElem.value;
85
+ }
86
+ handleFocus() {
87
+ if (this.label && this._labelElem && !this._labelElem.classList.contains("textarea__label--floated")) {
88
+ this._labelElem.classList.add("textarea__label--floated");
89
+ }
90
+ if (this._container && !this._container.classList.contains("textarea--focus")) {
91
+ this._container.classList.add("textarea--focus");
92
+ }
93
+ }
94
+ //---------------------------------------------
95
+ // Lifecycle web component
96
+ //---------------------------------------------
97
+ componentDidLoad() {
98
+ this.showError();
99
+ this.adjustFloatingLabel();
100
+ }
101
+ render() {
102
+ return (index.h(index.Host, null, index.h("div", { class: "textarea", ref: (el) => this._container = el }, this.label ?
103
+ index.h("label", { ref: (el) => this._labelElem = el, class: this.enabled ? "textarea__label" : "textarea__label textarea__label--disabled", onClick: () => this._inputElem.focus(), title: this.label }, this.label)
104
+ : null, index.h("textarea", { onFocus: () => this.handleFocus(), ref: (el) => this._inputElem = el, value: this.value, disabled: !this.enabled, onInput: () => { this.handleChange(); }, onFocusout: () => { this.handleFocusout(); }, onKeyDown: event => event.stopPropagation(), rows: this.rows })), index.h("span", { class: "message-box", ref: (el) => this._messageBoxElem = el, title: this.errorMessage }, this.errorMessage)));
105
+ }
106
+ get _hostElement() { return index.getElement(this); }
107
+ static get watchers() { return {
108
+ "errorMessage": ["showError"],
109
+ "value": ["updateInputValue"]
110
+ }; }
111
+ };
112
+ EzTextArea.style = ezTextAreaCss;
113
+
114
+ exports.ez_text_area = EzTextArea;
@@ -0,0 +1,201 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-682c98b2.js');
6
+ const core = require('@sankhyalabs/core');
7
+
8
+ const ezTextInputCss = ":host{--ez-text-input--height:42px;--ez-text-input--width:100%;--ez-text-input__icon--width:48px;--ez-text-input--border-radius:var(--border--radius-medium, 12px);--ez-text-input--font-size:var(--text--medium, 14px);--ez-text-input--font-family:var(--font-pattern, Arial);--ez-text-input--font-weight:var(--text-weight--medium, 400);--ez-text-input--color:var(--title--primary, #000);--ez-text-input__input--background-color:var(--background--medium, #e0e0e0);--ez-text-input__input--border:var(--border--medium, 2px solid);--ez-text-input__input--border-color:var(--ez-text-input__input--background-color);--ez-text-input__input--focus--border-color:var(--color--primary, #008561);--ez-text-input__input--disabled--background-color:var(--color--disable-secondary, #F2F5F8);--ez-text-input__input--disabled--color:var(--text--disable, #AFB6C0);--ez-text-input__input--error--border-color:#CC2936;--ez-text-input__message_box--font-size:var(--text--small, 12px);--ez-text-input__message_box--info--color:var(--color--success, #22085d);--ez-text-input__message_box--error--color:var(--color--error, #FF0000);--ez-text-input__label--floating--top:6px;--ez-text-input__label--padding-top:12px;--ez-text-input__label--padding-left:14px;--ez-text-input__label--padding-right:12px;display:flex;flex-wrap:wrap;position:relative;width:var(--ez-text-input--width)}input{width:100%;box-sizing:border-box;padding:var(--space--medium, 6px);font-weight:var(--text-weight--large, 600);height:var(--ez-text-input--height);border-radius:var(--ez-text-input--border-radius);font-family:var(--ez-text-input--font-family);font-size:var(--ez-text-input--font-size);border:var(--ez-text-input__input--border);border-color:var(--ez-text-input__input--border-color);background-color:var(--ez-text-input__input--background-color);color:var(--ez-text-input--color)}input:disabled{background-color:var(--ez-text-input__input--disabled--background-color);color:var(--ez-text-input__input--disabled--color)}input:focus{outline:none;border-color:var(--ez-text-input__input--focus--border-color)}input.icon--left{padding-left:var(--ez-text-input__icon--width)}input.icon--right{padding-right:var(--ez-text-input__icon--width)}input.hasError{color:var(--ez-text-input--color);border-color:var(--ez-text-input__input--error--border-color)}input.text--right{text-align:right}.message-box{min-height:16px;min-width:100%;margin-top:3px;line-height:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-family:var(--ez-text-input--font-family);font-size:var(--ez-text-input__message_box--font-size);color:var(--ez-text-input__message_box--info--color)}.hasError{color:var(--ez-text-input__message_box--error--color)}.input__label{box-sizing:border-box;position:absolute;z-index:var(--visible);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;-webkit-transition:font-size .05s, top .05s;transition:font-size .05s, top .05s;width:calc(100% - var(--ez-text-input__label--padding-right));left:var(--ez-text-input--space--medium);font-family:var(--ez-text-input--font-family);font-size:var(--ez-text-input--font-size);font-weight:var(--ez-text-input--font-weight);color:var(--ez-text-input--color);top:var(--ez-text-input__label--padding-top);left:var(--ez-text-input__label--padding-left);padding-right:var(--ez-text-input__label--padding-right)}.input__label--floated{font-family:var(--ez-text-input--font-family);font-size:var(--text--extra-small);color:var(--text--primary);top:var(--ez-text-input__label--floating--top)}.input__label--disabled{color:var(--ez-text-input__input--disabled--color)}.input__label--left{text-align:left;left:calc(var(--ez-text-input__icon--width) + 2px);width:calc(100% - var(--ez-text-input__icon--width))}.input__label--right{right:var(--ez-text-input__icon--width);width:calc(100% - var(--ez-text-input__icon--width))}.input__label--left.input__label--right{left:calc(var(--ez-text-input__icon--width) + 2px);width:calc(100% - var(--ez-text-input__icon--width) * 2)}.input--with--label{padding-bottom:0}";
9
+
10
+ const EzTextInput = class {
11
+ constructor(hostRef) {
12
+ index.registerInstance(this, hostRef);
13
+ this.ezChange = index.createEvent(this, "ezChange", 7);
14
+ /**
15
+ * Deixa o campo disponível ou não para digitação.
16
+ */
17
+ this.enabled = true;
18
+ /**
19
+ * Permite exibir a mensagem de erro.
20
+ */
21
+ this.canShowError = true;
22
+ }
23
+ showError() {
24
+ const hasError = typeof this.errorMessage === "string" && this.errorMessage !== "";
25
+ if (hasError) {
26
+ this._inputElem.classList.add("hasError");
27
+ this._messageBoxElem.classList.add("hasError");
28
+ }
29
+ else {
30
+ this._inputElem.classList.remove("hasError");
31
+ this._messageBoxElem.classList.remove("hasError");
32
+ }
33
+ }
34
+ prepareMask() {
35
+ if (this.mask) {
36
+ if (this._maskFormatter == undefined) {
37
+ this._maskFormatter = new core.MaskFormatter(this.mask);
38
+ }
39
+ else {
40
+ this._maskFormatter.mask = this.mask;
41
+ }
42
+ }
43
+ }
44
+ updateInputValue() {
45
+ if (this._inputElem) {
46
+ this._inputElem.value = this.value;
47
+ }
48
+ this.handleChange();
49
+ this.errorMessage = "";
50
+ this.ezChange.emit(this.value);
51
+ this.adjustFloatingLabel();
52
+ }
53
+ adjustFloatingLabel() {
54
+ if (this.label && this._labelElem) {
55
+ if (this._inputElem && !this._inputElem.classList.contains("input--with--label")) {
56
+ this._inputElem.classList.add("input--with--label");
57
+ }
58
+ const hasValue = this.value && this.value.toString().length > 0;
59
+ const containsFloatedClass = this._labelElem.classList.contains("input__label--floated");
60
+ if (hasValue || this.isFocused()) {
61
+ if (!containsFloatedClass) {
62
+ this._labelElem.classList.add("input__label--floated");
63
+ }
64
+ }
65
+ else {
66
+ if (containsFloatedClass) {
67
+ this._labelElem.classList.remove("input__label--floated");
68
+ }
69
+ }
70
+ }
71
+ }
72
+ isFocused() {
73
+ return this._hostElement.shadowRoot.activeElement !== null;
74
+ }
75
+ //---------------------------------------------
76
+ // Public methods
77
+ //---------------------------------------------
78
+ /**
79
+ * Faz o foco no componente de input
80
+ */
81
+ async setFocus() {
82
+ this._inputElem.focus();
83
+ }
84
+ /**
85
+ * Remove o foco no componente de input
86
+ */
87
+ async setBlur() {
88
+ this._inputElem.blur();
89
+ }
90
+ //---------------------------------------------
91
+ // Event handlers
92
+ //---------------------------------------------
93
+ handleFocusout() {
94
+ const value = this._inputElem.value;
95
+ if (value && this._maskFormatter) {
96
+ try {
97
+ this._inputElem.value = this._maskFormatter.format(value);
98
+ }
99
+ catch (e) {
100
+ this.errorMessage = e.message;
101
+ }
102
+ }
103
+ this.value = this._inputElem.value;
104
+ this.adjustFloatingLabel();
105
+ }
106
+ isValidValue(value) {
107
+ if (this.restrict) {
108
+ return Array.from(value).reduce((valid, c) => valid && this.restrict.indexOf(c) > -1, true);
109
+ }
110
+ return true;
111
+ }
112
+ handleChange() {
113
+ if (!this._inputElem) {
114
+ return;
115
+ }
116
+ const value = this._inputElem.value;
117
+ if (this.isValidValue(value)) {
118
+ this._lastValidValue = value;
119
+ }
120
+ else {
121
+ this._inputElem.value = this._lastValidValue === undefined ? "" : this._lastValidValue;
122
+ }
123
+ this.value = this._inputElem.value;
124
+ }
125
+ handleSlotChange(ev) {
126
+ const slot = ev.target;
127
+ const content = slot.assignedElements()[0];
128
+ if (content) {
129
+ content.style.position = "absolute";
130
+ content.style.display = "flex";
131
+ content.style.alignItems = "center";
132
+ content.style.justifyContent = "center";
133
+ content.style.overflow = "hidden";
134
+ content.style.top = "0px";
135
+ content.style.width = "var(--ez-text-input__icon--width)";
136
+ content.style.height = "var(--ez-text-input--height)";
137
+ if (slot.name == "leftIcon") {
138
+ content.style.left = "0px";
139
+ content.style.borderRadius = "var(--ez-text-input--border-radius) 0 0 var(--ez-text-input--border-radius)";
140
+ this._inputElem.classList.add("icon--left");
141
+ if (this._labelElem) {
142
+ this._labelElem.classList.add("input__label--left");
143
+ }
144
+ }
145
+ else if (slot.name == "rightIcon") {
146
+ content.style.right = "0px";
147
+ content.style.borderRadius = "0 var(--ez-text-input--border-radius) var(--ez-text-input--border-radius) 0";
148
+ this._inputElem.classList.add("icon--right");
149
+ if (this._labelElem) {
150
+ this._labelElem.classList.add("input__label--right");
151
+ }
152
+ }
153
+ }
154
+ this.showError();
155
+ }
156
+ doFocus() {
157
+ if (this.label && this._labelElem && !this._labelElem.classList.contains("input__label--floated")) {
158
+ this._labelElem.classList.add("input__label--floated");
159
+ }
160
+ }
161
+ //---------------------------------------------
162
+ // Lifecycle web component
163
+ //---------------------------------------------
164
+ componentDidLoad() {
165
+ this.showError();
166
+ this.prepareMask();
167
+ this.adjustFloatingLabel();
168
+ }
169
+ componentWillLoad() {
170
+ this.prepareMask();
171
+ if (this.value) {
172
+ if (this._maskFormatter) {
173
+ try {
174
+ this.value = this._maskFormatter.format(this.value);
175
+ }
176
+ catch (e) {
177
+ this.errorMessage = e.message;
178
+ }
179
+ }
180
+ if (!this.isValidValue(this.value)) {
181
+ this._lastValidValue = "";
182
+ this.value = "";
183
+ }
184
+ }
185
+ }
186
+ render() {
187
+ return (index.h(index.Host, null, index.h("slot", { name: "leftIcon", onSlotchange: (ev) => { this.handleSlotChange(ev); } }), this.label ?
188
+ index.h("label", { ref: (el) => this._labelElem = el, class: this.enabled ? "input__label" : "input__label input__label--disabled", onClick: () => this._inputElem.focus(), title: this.label }, this.label)
189
+ : null, index.h("input", { onFocus: () => this.doFocus(), ref: (el) => this._inputElem = el, type: "text", value: this.value, disabled: !this.enabled, onInput: () => { this.handleChange(); }, onFocusout: () => { this.handleFocusout(); } }), index.h("slot", { name: "rightIcon", onSlotchange: (ev) => { this.handleSlotChange(ev); } }), this.canShowError &&
190
+ index.h("span", { class: "message-box", ref: (el) => this._messageBoxElem = el, title: this.errorMessage }, this.errorMessage)));
191
+ }
192
+ get _hostElement() { return index.getElement(this); }
193
+ static get watchers() { return {
194
+ "errorMessage": ["showError"],
195
+ "mask": ["prepareMask"],
196
+ "value": ["updateInputValue"]
197
+ }; }
198
+ };
199
+ EzTextInput.style = ezTextInputCss;
200
+
201
+ exports.ez_text_input = EzTextInput;