@sapphire-ion/framework 0.30.27 → 0.30.28

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 (469) hide show
  1. package/build.ps1 +39 -0
  2. package/ng-package.json +10 -0
  3. package/package.json +37 -41
  4. package/src/lib/classes/comparison/comparison-operator.ts +17 -0
  5. package/src/lib/classes/comparison/comparison-value-type.ts +34 -0
  6. package/src/lib/classes/comparison/comparison.ts +45 -0
  7. package/src/lib/classes/comparison/properties/bool-property.ts +16 -0
  8. package/src/lib/classes/comparison/properties/date-property.ts +28 -0
  9. package/src/lib/classes/comparison/properties/datetime-property.ts +28 -0
  10. package/src/lib/classes/comparison/properties/decimal-property.ts +28 -0
  11. package/src/lib/classes/comparison/properties/enum-property.ts +28 -0
  12. package/src/lib/classes/comparison/properties/implicit-property.ts +13 -0
  13. package/src/lib/classes/comparison/properties/int-property.ts +28 -0
  14. package/src/lib/classes/comparison/properties/long-property.ts +28 -0
  15. package/src/lib/classes/comparison/properties/string-property.ts +16 -0
  16. package/src/lib/classes/comparison/properties/time-property.ts +28 -0
  17. package/{lib/classes/credentials.d.ts → src/lib/classes/credentials.ts} +5 -5
  18. package/src/lib/classes/environment.ts +35 -0
  19. package/src/lib/classes/filters/view-filtros.ts +18 -0
  20. package/src/lib/classes/infinite-scroll.ts +112 -0
  21. package/src/lib/classes/inputs/table-field-form-builder.ts +12 -0
  22. package/src/lib/classes/inputs/table-field.ts +58 -0
  23. package/src/lib/classes/page-option.ts +8 -0
  24. package/src/lib/classes/routes/default-routing-factory.ts +24 -0
  25. package/src/lib/classes/routes/id-preloader-configuration.ts +21 -0
  26. package/src/lib/classes/routes/route-data.ts +9 -0
  27. package/{themes → src/lib}/compiled-styles.scss +2338 -2338
  28. package/src/lib/components/_inputs_new/classes/input-control-base.ts +85 -0
  29. package/src/lib/components/_inputs_new/classes/input-provider-factory.ts +16 -0
  30. package/src/lib/components/_inputs_new/input-string/input-string.component.html +4 -0
  31. package/src/lib/components/_inputs_new/input-string/input-string.component.ts +15 -0
  32. package/src/lib/components/_inputs_new/inputs.module.ts +16 -0
  33. package/src/lib/components/carousel/carousel-image/carousel-image.component.html +4 -0
  34. package/src/lib/components/carousel/carousel-image/carousel-image.component.ts +15 -0
  35. package/src/lib/components/carousel/carousel-item/carousel-item.component.html +3 -0
  36. package/src/lib/components/carousel/carousel-item/carousel-item.component.ts +14 -0
  37. package/src/lib/components/carousel/carousel.component.html +22 -0
  38. package/src/lib/components/carousel/carousel.component.ts +83 -0
  39. package/src/lib/components/carousel/carousel.module.ts +20 -0
  40. package/src/lib/components/carousel/i-carousel-item.component.ts +8 -0
  41. package/src/lib/components/content-block/content-block.component.html +6 -0
  42. package/src/lib/components/content-block/content-block.component.ts +25 -0
  43. package/src/lib/components/default/default-list/abstract-list.ts +56 -0
  44. package/src/lib/components/default/default-list/default-list.component.html +60 -0
  45. package/src/lib/components/default/default-list/default-list.component.ts +71 -0
  46. package/src/lib/components/default/default-list/header-list/header-list.component.html +32 -0
  47. package/src/lib/components/default/default-list/header-list/header-list.component.ts +85 -0
  48. package/src/lib/components/default/default-list/list.ts +121 -0
  49. package/src/lib/components/default/default-pagination/default-pagination.component.html +52 -0
  50. package/src/lib/components/default/default-pagination/default-pagination.component.ts +118 -0
  51. package/src/lib/components/default/default-table/default-table.component.html +105 -0
  52. package/src/lib/components/default/default-table/default-table.component.ts +197 -0
  53. package/src/lib/components/default/default-table/th-filter/th-filter.component.html +61 -0
  54. package/src/lib/components/default/default-table/th-filter/th-filter.component.ts +178 -0
  55. package/src/lib/components/default/default-view/abstract-view.ts +25 -0
  56. package/src/lib/components/default/default-view/default-view.component.html +81 -0
  57. package/src/lib/components/default/default-view/default-view.component.ts +34 -0
  58. package/src/lib/components/default/default-view/header-view/header-view.component.html +64 -0
  59. package/src/lib/components/default/default-view/header-view/header-view.component.ts +54 -0
  60. package/src/lib/components/default/default-view/view.ts +171 -0
  61. package/src/lib/components/default/default.module.ts +55 -0
  62. package/src/lib/components/default-page/default.page.html +53 -0
  63. package/src/lib/components/default-page/default.page.ts +77 -0
  64. package/src/lib/components/drag-drop-file/drag-drop-file.directive.ts +44 -0
  65. package/src/lib/components/drag-drop-file/drag-drop-file.module.ts +21 -0
  66. package/src/lib/components/drag-drop-file/drag-drop-overlay/drag-drop-overlay.component.html +5 -0
  67. package/src/lib/components/drag-drop-file/drag-drop-overlay/drag-drop-overlay.component.ts +17 -0
  68. package/src/lib/components/drawer/default-drawer-end/default-drawer-end.component.html +12 -0
  69. package/src/lib/components/drawer/default-drawer-end/default-drawer-end.component.ts +35 -0
  70. package/src/lib/components/drawer/drawer-group/drawer-group.component.html +61 -0
  71. package/src/lib/components/drawer/drawer-group/drawer-group.component.ts +44 -0
  72. package/src/lib/components/drawer/drawer.component.html +56 -0
  73. package/src/lib/components/drawer/drawer.component.ts +119 -0
  74. package/src/lib/components/drawer/menu.ts +20 -0
  75. package/src/lib/components/filter/filter.component.html +31 -0
  76. package/src/lib/components/filter/filter.component.ts +133 -0
  77. package/src/lib/components/http-responses-pages/forbidden-403/forbidden-403.component.html +35 -0
  78. package/src/lib/components/http-responses-pages/forbidden-403/forbidden-403.component.ts +19 -0
  79. package/src/lib/components/image/image.component.html +17 -0
  80. package/src/lib/components/image/image.component.ts +95 -0
  81. package/src/lib/components/info-popover/info-popover.component.html +23 -0
  82. package/src/lib/components/info-popover/info-popover.component.ts +75 -0
  83. package/src/lib/components/inputs/custom-input.ts +67 -0
  84. package/src/lib/components/inputs/custom-signal-input.ts +70 -0
  85. package/src/lib/components/inputs/input-bool/input-bool.component.html +18 -0
  86. package/src/lib/components/inputs/input-bool/input-bool.component.ts +36 -0
  87. package/src/lib/components/inputs/input-bool/input-bool.configuration.ts +14 -0
  88. package/src/lib/components/inputs/input-color/input-color.component.html +132 -0
  89. package/src/lib/components/inputs/input-color/input-color.component.ts +561 -0
  90. package/{lib/components/inputs/input-configuration.d.ts → src/lib/components/inputs/input-configuration.ts} +18 -8
  91. package/src/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.html +26 -0
  92. package/src/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.ts +78 -0
  93. package/src/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.configuration.ts +4 -0
  94. package/src/lib/components/inputs/input-date/input-date.component.html +40 -0
  95. package/src/lib/components/inputs/input-date/input-date.component.ts +98 -0
  96. package/src/lib/components/inputs/input-date/input-date.configuration.ts +6 -0
  97. package/src/lib/components/inputs/input-decimal/input-decimal.component.html +24 -0
  98. package/src/lib/components/inputs/input-decimal/input-decimal.component.ts +296 -0
  99. package/src/lib/components/inputs/input-decimal/input-decimal.configuration.ts +42 -0
  100. package/src/lib/components/inputs/input-default-configurations.ts +15 -0
  101. package/src/lib/components/inputs/input-file/download-button/download-button.component.html +56 -0
  102. package/src/lib/components/inputs/input-file/download-button/download-button.component.ts +85 -0
  103. package/src/lib/components/inputs/input-file/input-file.component.html +101 -0
  104. package/src/lib/components/inputs/input-file/input-file.component.ts +120 -0
  105. package/src/lib/components/inputs/input-file/input-file.configuration.ts +8 -0
  106. package/src/lib/components/inputs/input-loading/input-loading.component.html +3 -0
  107. package/src/lib/components/inputs/input-loading/input-loading.component.ts +13 -0
  108. package/src/lib/components/inputs/input-provider-factory.ts +15 -0
  109. package/src/lib/components/inputs/input-select/ISelect.ts +26 -0
  110. package/src/lib/components/inputs/input-select/input-select-internal-option/input-select-internal-option.component.html +16 -0
  111. package/src/lib/components/inputs/input-select/input-select-internal-option/input-select-internal-option.component.ts +38 -0
  112. package/src/lib/components/inputs/input-select/input-select-option/input-select-option.component.html +15 -0
  113. package/src/lib/components/inputs/input-select/input-select-option/input-select-option.component.ts +47 -0
  114. package/src/lib/components/inputs/input-select/input-select-template.directive.ts +8 -0
  115. package/src/lib/components/inputs/input-select/input-select.component.html +66 -0
  116. package/src/lib/components/inputs/input-select/input-select.component.ts +323 -0
  117. package/src/lib/components/inputs/input-select/input.select.configuration.ts +188 -0
  118. package/src/lib/components/inputs/input-string/input-string.component.html +22 -0
  119. package/src/lib/components/inputs/input-string/input-string.component.ts +36 -0
  120. package/src/lib/components/inputs/input-string/input-string.configuration.ts +18 -0
  121. package/src/lib/components/inputs/input-textarea/input-textarea.component.html +25 -0
  122. package/src/lib/components/inputs/input-textarea/input-textarea.component.ts +35 -0
  123. package/src/lib/components/inputs/input-type.ts +16 -0
  124. package/src/lib/components/inputs/input-validators.ts +76 -0
  125. package/src/lib/components/inputs/inputs.module.ts +64 -0
  126. package/src/lib/components/loading/loading.component.html +28 -0
  127. package/src/lib/components/loading/loading.component.ts +29 -0
  128. package/src/lib/components/login/login-admin/login-admin.component.html +28 -0
  129. package/src/lib/components/login/login-admin/login-admin.component.ts +51 -0
  130. package/src/lib/components/login/login.component.html +104 -0
  131. package/src/lib/components/login/login.component.ts +97 -0
  132. package/src/lib/components/main-content/main-content.component.html +61 -0
  133. package/src/lib/components/main-content/main-content.component.ts +55 -0
  134. package/src/lib/components/stepper/step/step.component.html +11 -0
  135. package/src/lib/components/stepper/step/step.component.ts +44 -0
  136. package/src/lib/components/stepper/stepper.component.html +3 -0
  137. package/src/lib/components/stepper/stepper.component.ts +36 -0
  138. package/src/lib/components/stepper/stepper.module.ts +15 -0
  139. package/src/lib/components/tabs/tab/tab.component.html +8 -0
  140. package/src/lib/components/tabs/tab/tab.component.scss +0 -0
  141. package/src/lib/components/tabs/tab/tab.component.ts +28 -0
  142. package/src/lib/components/tabs/tabs/tabs.component.html +14 -0
  143. package/src/lib/components/tabs/tabs/tabs.component.ts +42 -0
  144. package/src/lib/components/tabs/tabs.module.ts +15 -0
  145. package/src/lib/components/text-tooltip/text-tooltip.component.html +8 -0
  146. package/src/lib/components/text-tooltip/text-tooltip.component.scss +0 -0
  147. package/src/lib/components/text-tooltip/text-tooltip.component.ts +45 -0
  148. package/src/lib/components/tooltip/tooltip.component.html +53 -0
  149. package/src/lib/components/tooltip/tooltip.component.ts +16 -0
  150. package/src/lib/core.module.ts +26 -0
  151. package/src/lib/directives/ng-var.directive.ts +26 -0
  152. package/src/lib/guards/auth.guard.ts +19 -0
  153. package/src/lib/guards/error.interceptor.ts +107 -0
  154. package/src/lib/guards/token.interceptor.ts +28 -0
  155. package/src/lib/index.ts +175 -0
  156. package/src/lib/pipes/secure.pipe.ts +39 -0
  157. package/src/lib/services/auth.service.ts +150 -0
  158. package/src/lib/services/crypto.service.ts +164 -0
  159. package/src/lib/services/environment.service.ts +17 -0
  160. package/src/lib/services/generics.service.ts +85 -0
  161. package/src/lib/services/route/route.cache.service.ts +17 -0
  162. package/src/lib/services/route/route.provider.service.ts +49 -0
  163. package/src/lib/services/usuario.service.ts +44 -0
  164. package/src/lib/services/utils.service.ts +161 -0
  165. package/src/lib/services/web/api-url-provider.service.ts +48 -0
  166. package/src/lib/services/web/http.ativo.service.ts +52 -0
  167. package/src/lib/services/web/http.service.ts +184 -0
  168. package/src/lib/services/web/storage.service.ts +131 -0
  169. package/{themes → src/lib}/styles/core.styles.scss +4 -0
  170. package/src/public-api.ts +5 -0
  171. package/tailwind.config.js +27 -0
  172. package/tsconfig.lib.json +29 -0
  173. package/tsconfig.lib.prod.json +23 -0
  174. package/tsconfig.spec.json +27 -0
  175. package/esm2022/lib/classes/comparison/comparison-operator.mjs +0 -18
  176. package/esm2022/lib/classes/comparison/comparison-value-type.mjs +0 -25
  177. package/esm2022/lib/classes/comparison/comparison.mjs +0 -41
  178. package/esm2022/lib/classes/comparison/properties/bool-property.mjs +0 -15
  179. package/esm2022/lib/classes/comparison/properties/date-property.mjs +0 -27
  180. package/esm2022/lib/classes/comparison/properties/datetime-property.mjs +0 -27
  181. package/esm2022/lib/classes/comparison/properties/decimal-property.mjs +0 -27
  182. package/esm2022/lib/classes/comparison/properties/enum-property.mjs +0 -27
  183. package/esm2022/lib/classes/comparison/properties/implicit-property.mjs +0 -12
  184. package/esm2022/lib/classes/comparison/properties/int-property.mjs +0 -27
  185. package/esm2022/lib/classes/comparison/properties/long-property.mjs +0 -27
  186. package/esm2022/lib/classes/comparison/properties/string-property.mjs +0 -15
  187. package/esm2022/lib/classes/comparison/properties/time-property.mjs +0 -27
  188. package/esm2022/lib/classes/credentials.mjs +0 -2
  189. package/esm2022/lib/classes/environment.mjs +0 -32
  190. package/esm2022/lib/classes/filters/view-filtros.mjs +0 -18
  191. package/esm2022/lib/classes/infinite-scroll.mjs +0 -90
  192. package/esm2022/lib/classes/inputs/table-field-form-builder.mjs +0 -10
  193. package/esm2022/lib/classes/inputs/table-field.mjs +0 -69
  194. package/esm2022/lib/classes/page-option.mjs +0 -2
  195. package/esm2022/lib/classes/routes/default-routing-factory.mjs +0 -23
  196. package/esm2022/lib/classes/routes/id-preloader-configuration.mjs +0 -22
  197. package/esm2022/lib/classes/routes/route-data.mjs +0 -9
  198. package/esm2022/lib/components/carousel/carousel-image/carousel-image.component.mjs +0 -18
  199. package/esm2022/lib/components/carousel/carousel-item/carousel-item.component.mjs +0 -15
  200. package/esm2022/lib/components/carousel/carousel.component.mjs +0 -79
  201. package/esm2022/lib/components/carousel/carousel.module.mjs +0 -31
  202. package/esm2022/lib/components/carousel/i-carousel-item.component.mjs +0 -16
  203. package/esm2022/lib/components/content-block/content-block.component.mjs +0 -27
  204. package/esm2022/lib/components/default/default-list/abstract-list.mjs +0 -49
  205. package/esm2022/lib/components/default/default-list/default-list.component.mjs +0 -99
  206. package/esm2022/lib/components/default/default-list/header-list/header-list.component.mjs +0 -98
  207. package/esm2022/lib/components/default/default-list/list.mjs +0 -110
  208. package/esm2022/lib/components/default/default-pagination/default-pagination.component.mjs +0 -123
  209. package/esm2022/lib/components/default/default-table/default-table.component.mjs +0 -222
  210. package/esm2022/lib/components/default/default-table/th-filter/th-filter.component.mjs +0 -186
  211. package/esm2022/lib/components/default/default-view/abstract-view.mjs +0 -22
  212. package/esm2022/lib/components/default/default-view/default-view.component.mjs +0 -51
  213. package/esm2022/lib/components/default/default-view/header-view/header-view.component.mjs +0 -75
  214. package/esm2022/lib/components/default/default-view/view.mjs +0 -175
  215. package/esm2022/lib/components/default/default.module.mjs +0 -87
  216. package/esm2022/lib/components/default-page/default.page.mjs +0 -73
  217. package/esm2022/lib/components/drag-drop-file/drag-drop-file.directive.mjs +0 -60
  218. package/esm2022/lib/components/drag-drop-file/drag-drop-file.module.mjs +0 -31
  219. package/esm2022/lib/components/drag-drop-file/drag-drop-overlay/drag-drop-overlay.component.mjs +0 -15
  220. package/esm2022/lib/components/drawer/default-drawer-end/default-drawer-end.component.mjs +0 -34
  221. package/esm2022/lib/components/drawer/drawer-group/drawer-group.component.mjs +0 -49
  222. package/esm2022/lib/components/drawer/drawer.component.mjs +0 -117
  223. package/esm2022/lib/components/drawer/menu.mjs +0 -15
  224. package/esm2022/lib/components/filter/filter.component.mjs +0 -127
  225. package/esm2022/lib/components/http-responses-pages/forbidden-403/forbidden-403.component.mjs +0 -17
  226. package/esm2022/lib/components/image/image.component.mjs +0 -91
  227. package/esm2022/lib/components/info-popover/info-popover.component.mjs +0 -91
  228. package/esm2022/lib/components/inputs/custom-input.mjs +0 -77
  229. package/esm2022/lib/components/inputs/custom-signal-input.mjs +0 -74
  230. package/esm2022/lib/components/inputs/input-bool/input-bool.component.mjs +0 -43
  231. package/esm2022/lib/components/inputs/input-bool/input-bool.configuration.mjs +0 -16
  232. package/esm2022/lib/components/inputs/input-color/input-color.component.mjs +0 -487
  233. package/esm2022/lib/components/inputs/input-configuration.mjs +0 -2
  234. package/esm2022/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.mjs +0 -93
  235. package/esm2022/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.configuration.mjs +0 -6
  236. package/esm2022/lib/components/inputs/input-date/input-date.component.mjs +0 -122
  237. package/esm2022/lib/components/inputs/input-date/input-date.configuration.mjs +0 -8
  238. package/esm2022/lib/components/inputs/input-decimal/input-decimal.component.mjs +0 -269
  239. package/esm2022/lib/components/inputs/input-decimal/input-decimal.configuration.mjs +0 -45
  240. package/esm2022/lib/components/inputs/input-default-configurations.mjs +0 -14
  241. package/esm2022/lib/components/inputs/input-file/download-button/download-button.component.mjs +0 -94
  242. package/esm2022/lib/components/inputs/input-file/input-file.component.mjs +0 -131
  243. package/esm2022/lib/components/inputs/input-file/input-file.configuration.mjs +0 -11
  244. package/esm2022/lib/components/inputs/input-loading/input-loading.component.mjs +0 -16
  245. package/esm2022/lib/components/inputs/input-provider-factory.mjs +0 -15
  246. package/esm2022/lib/components/inputs/input-select/ISelect.mjs +0 -11
  247. package/esm2022/lib/components/inputs/input-select/input-select-internal-option/input-select-internal-option.component.mjs +0 -42
  248. package/esm2022/lib/components/inputs/input-select/input-select-option/input-select-option.component.mjs +0 -46
  249. package/esm2022/lib/components/inputs/input-select/input-select-template.directive.mjs +0 -16
  250. package/esm2022/lib/components/inputs/input-select/input-select.component.mjs +0 -322
  251. package/esm2022/lib/components/inputs/input-select/input.select.configuration.mjs +0 -164
  252. package/esm2022/lib/components/inputs/input-string/input-string.component.mjs +0 -50
  253. package/esm2022/lib/components/inputs/input-string/input-string.configuration.mjs +0 -18
  254. package/esm2022/lib/components/inputs/input-textarea/input-textarea.component.mjs +0 -47
  255. package/esm2022/lib/components/inputs/input-type.mjs +0 -18
  256. package/esm2022/lib/components/inputs/input-validators.mjs +0 -90
  257. package/esm2022/lib/components/inputs/inputs.module.mjs +0 -105
  258. package/esm2022/lib/components/loading/loading.component.mjs +0 -34
  259. package/esm2022/lib/components/login/login-admin/login-admin.component.mjs +0 -52
  260. package/esm2022/lib/components/login/login.component.mjs +0 -102
  261. package/esm2022/lib/components/main-content/main-content.component.mjs +0 -62
  262. package/esm2022/lib/components/stepper/step/step.component.mjs +0 -43
  263. package/esm2022/lib/components/stepper/stepper.component.mjs +0 -36
  264. package/esm2022/lib/components/stepper/stepper.module.mjs +0 -25
  265. package/esm2022/lib/components/tabs/tab/tab.component.mjs +0 -41
  266. package/esm2022/lib/components/tabs/tabs/tabs.component.mjs +0 -56
  267. package/esm2022/lib/components/tabs/tabs.module.mjs +0 -22
  268. package/esm2022/lib/components/text-tooltip/text-tooltip.component.mjs +0 -51
  269. package/esm2022/lib/components/tooltip/tooltip.component.mjs +0 -21
  270. package/esm2022/lib/core.module.mjs +0 -29
  271. package/esm2022/lib/directives/ng-var.directive.mjs +0 -29
  272. package/esm2022/lib/guards/auth.guard.mjs +0 -26
  273. package/esm2022/lib/guards/error.interceptor.mjs +0 -106
  274. package/esm2022/lib/guards/token.interceptor.mjs +0 -25
  275. package/esm2022/lib/index.mjs +0 -173
  276. package/esm2022/lib/pipes/secure.pipe.mjs +0 -42
  277. package/esm2022/lib/services/auth.service.mjs +0 -146
  278. package/esm2022/lib/services/environment.service.mjs +0 -26
  279. package/esm2022/lib/services/generics.service.mjs +0 -84
  280. package/esm2022/lib/services/route/route.cache.service.mjs +0 -15
  281. package/esm2022/lib/services/route/route.provider.service.mjs +0 -42
  282. package/esm2022/lib/services/usuario.service.mjs +0 -49
  283. package/esm2022/lib/services/utils.service.mjs +0 -149
  284. package/esm2022/lib/services/web/api-url-provider.service.mjs +0 -29
  285. package/esm2022/lib/services/web/http.ativo.service.mjs +0 -55
  286. package/esm2022/lib/services/web/http.service.mjs +0 -169
  287. package/esm2022/lib/services/web/storage.service.mjs +0 -128
  288. package/esm2022/public-api.mjs +0 -5
  289. package/esm2022/sapphire-ion-framework.mjs +0 -5
  290. package/fesm2022/sapphire-ion-framework.mjs +0 -6240
  291. package/fesm2022/sapphire-ion-framework.mjs.map +0 -1
  292. package/index.d.ts +0 -5
  293. package/lib/classes/comparison/comparison-operator.d.ts +0 -9
  294. package/lib/classes/comparison/comparison-value-type.d.ts +0 -23
  295. package/lib/classes/comparison/comparison.d.ts +0 -25
  296. package/lib/classes/comparison/properties/bool-property.d.ts +0 -7
  297. package/lib/classes/comparison/properties/date-property.d.ts +0 -11
  298. package/lib/classes/comparison/properties/datetime-property.d.ts +0 -11
  299. package/lib/classes/comparison/properties/decimal-property.d.ts +0 -11
  300. package/lib/classes/comparison/properties/enum-property.d.ts +0 -11
  301. package/lib/classes/comparison/properties/implicit-property.d.ts +0 -6
  302. package/lib/classes/comparison/properties/int-property.d.ts +0 -11
  303. package/lib/classes/comparison/properties/long-property.d.ts +0 -11
  304. package/lib/classes/comparison/properties/string-property.d.ts +0 -7
  305. package/lib/classes/comparison/properties/time-property.d.ts +0 -11
  306. package/lib/classes/environment.d.ts +0 -13
  307. package/lib/classes/filters/view-filtros.d.ts +0 -10
  308. package/lib/classes/infinite-scroll.d.ts +0 -26
  309. package/lib/classes/inputs/table-field-form-builder.d.ts +0 -5
  310. package/lib/classes/inputs/table-field.d.ts +0 -20
  311. package/lib/classes/page-option.d.ts +0 -7
  312. package/lib/classes/routes/default-routing-factory.d.ts +0 -8
  313. package/lib/classes/routes/id-preloader-configuration.d.ts +0 -28
  314. package/lib/classes/routes/route-data.d.ts +0 -5
  315. package/lib/components/carousel/carousel-image/carousel-image.component.d.ts +0 -10
  316. package/lib/components/carousel/carousel-item/carousel-item.component.d.ts +0 -9
  317. package/lib/components/carousel/carousel.component.d.ts +0 -32
  318. package/lib/components/carousel/carousel.module.d.ts +0 -12
  319. package/lib/components/carousel/i-carousel-item.component.d.ts +0 -9
  320. package/lib/components/content-block/content-block.component.d.ts +0 -15
  321. package/lib/components/default/default-list/abstract-list.d.ts +0 -21
  322. package/lib/components/default/default-list/default-list.component.d.ts +0 -44
  323. package/lib/components/default/default-list/header-list/header-list.component.d.ts +0 -45
  324. package/lib/components/default/default-list/list.d.ts +0 -38
  325. package/lib/components/default/default-pagination/default-pagination.component.d.ts +0 -36
  326. package/lib/components/default/default-table/default-table.component.d.ts +0 -72
  327. package/lib/components/default/default-table/th-filter/th-filter.component.d.ts +0 -20
  328. package/lib/components/default/default-view/abstract-view.d.ts +0 -18
  329. package/lib/components/default/default-view/default-view.component.d.ts +0 -26
  330. package/lib/components/default/default-view/header-view/header-view.component.d.ts +0 -26
  331. package/lib/components/default/default-view/view.d.ts +0 -56
  332. package/lib/components/default/default.module.d.ts +0 -28
  333. package/lib/components/default-page/default.page.d.ts +0 -35
  334. package/lib/components/drag-drop-file/drag-drop-file.directive.d.ts +0 -14
  335. package/lib/components/drag-drop-file/drag-drop-file.module.d.ts +0 -10
  336. package/lib/components/drag-drop-file/drag-drop-overlay/drag-drop-overlay.component.d.ts +0 -9
  337. package/lib/components/drawer/default-drawer-end/default-drawer-end.component.d.ts +0 -13
  338. package/lib/components/drawer/drawer-group/drawer-group.component.d.ts +0 -22
  339. package/lib/components/drawer/drawer.component.d.ts +0 -23
  340. package/lib/components/drawer/menu.d.ts +0 -9
  341. package/lib/components/filter/filter.component.d.ts +0 -29
  342. package/lib/components/http-responses-pages/forbidden-403/forbidden-403.component.d.ts +0 -8
  343. package/lib/components/image/image.component.d.ts +0 -23
  344. package/lib/components/info-popover/info-popover.component.d.ts +0 -15
  345. package/lib/components/inputs/custom-input.d.ts +0 -36
  346. package/lib/components/inputs/custom-signal-input.d.ts +0 -38
  347. package/lib/components/inputs/input-bool/input-bool.component.d.ts +0 -19
  348. package/lib/components/inputs/input-bool/input-bool.configuration.d.ts +0 -17
  349. package/lib/components/inputs/input-color/input-color.component.d.ts +0 -80
  350. package/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.d.ts +0 -24
  351. package/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.configuration.d.ts +0 -5
  352. package/lib/components/inputs/input-date/input-date.component.d.ts +0 -30
  353. package/lib/components/inputs/input-date/input-date.configuration.d.ts +0 -7
  354. package/lib/components/inputs/input-decimal/input-decimal.component.d.ts +0 -41
  355. package/lib/components/inputs/input-decimal/input-decimal.configuration.d.ts +0 -25
  356. package/lib/components/inputs/input-default-configurations.d.ts +0 -13
  357. package/lib/components/inputs/input-file/download-button/download-button.component.d.ts +0 -37
  358. package/lib/components/inputs/input-file/input-file.component.d.ts +0 -39
  359. package/lib/components/inputs/input-file/input-file.configuration.d.ts +0 -11
  360. package/lib/components/inputs/input-loading/input-loading.component.d.ts +0 -7
  361. package/lib/components/inputs/input-provider-factory.d.ts +0 -4
  362. package/lib/components/inputs/input-select/ISelect.d.ts +0 -21
  363. package/lib/components/inputs/input-select/input-select-internal-option/input-select-internal-option.component.d.ts +0 -18
  364. package/lib/components/inputs/input-select/input-select-option/input-select-option.component.d.ts +0 -24
  365. package/lib/components/inputs/input-select/input-select-template.directive.d.ts +0 -8
  366. package/lib/components/inputs/input-select/input-select.component.d.ts +0 -66
  367. package/lib/components/inputs/input-select/input.select.configuration.d.ts +0 -87
  368. package/lib/components/inputs/input-string/input-string.component.d.ts +0 -19
  369. package/lib/components/inputs/input-string/input-string.configuration.d.ts +0 -14
  370. package/lib/components/inputs/input-textarea/input-textarea.component.d.ts +0 -18
  371. package/lib/components/inputs/input-type.d.ts +0 -16
  372. package/lib/components/inputs/input-validators.d.ts +0 -19
  373. package/lib/components/inputs/inputs.module.d.ts +0 -29
  374. package/lib/components/loading/loading.component.d.ts +0 -18
  375. package/lib/components/login/login-admin/login-admin.component.d.ts +0 -20
  376. package/lib/components/login/login.component.d.ts +0 -29
  377. package/lib/components/main-content/main-content.component.d.ts +0 -17
  378. package/lib/components/stepper/step/step.component.d.ts +0 -15
  379. package/lib/components/stepper/stepper.component.d.ts +0 -17
  380. package/lib/components/stepper/stepper.module.d.ts +0 -10
  381. package/lib/components/tabs/tab/tab.component.d.ts +0 -19
  382. package/lib/components/tabs/tabs/tabs.component.d.ts +0 -18
  383. package/lib/components/tabs/tabs.module.d.ts +0 -12
  384. package/lib/components/text-tooltip/text-tooltip.component.d.ts +0 -16
  385. package/lib/components/tooltip/tooltip.component.d.ts +0 -7
  386. package/lib/core.module.d.ts +0 -11
  387. package/lib/directives/ng-var.directive.d.ts +0 -12
  388. package/lib/guards/auth.guard.d.ts +0 -11
  389. package/lib/guards/error.interceptor.d.ts +0 -32
  390. package/lib/guards/token.interceptor.d.ts +0 -11
  391. package/lib/index.d.ts +0 -109
  392. package/lib/pipes/secure.pipe.d.ts +0 -15
  393. package/lib/services/auth.service.d.ts +0 -47
  394. package/lib/services/environment.service.d.ts +0 -10
  395. package/lib/services/generics.service.d.ts +0 -22
  396. package/lib/services/route/route.cache.service.d.ts +0 -7
  397. package/lib/services/route/route.provider.service.d.ts +0 -13
  398. package/lib/services/usuario.service.d.ts +0 -21
  399. package/lib/services/utils.service.d.ts +0 -36
  400. package/lib/services/web/api-url-provider.service.d.ts +0 -13
  401. package/lib/services/web/http.ativo.service.d.ts +0 -31
  402. package/lib/services/web/http.service.d.ts +0 -50
  403. package/lib/services/web/storage.service.d.ts +0 -25
  404. package/public-api.d.ts +0 -1
  405. /package/{themes → src/lib}/components/_inputs_new/input-string/input-string.component.scss +0 -0
  406. /package/{themes → src/lib}/components/_inputs_new/inputs.scss +0 -0
  407. /package/{themes → src/lib}/components/carousel/carousel-image/carousel-image.component.scss +0 -0
  408. /package/{themes → src/lib}/components/carousel/carousel-item/carousel-item.component.scss +0 -0
  409. /package/{themes → src/lib}/components/carousel/carousel.component.scss +0 -0
  410. /package/{themes → src/lib}/components/content-block/content-block.component.scss +0 -0
  411. /package/{themes → src/lib}/components/default/default-list/default-list.component.scss +0 -0
  412. /package/{themes → src/lib}/components/default/default-list/header-list/header-list.component.scss +0 -0
  413. /package/{themes → src/lib}/components/default/default-pagination/default-pagination.component.scss +0 -0
  414. /package/{themes → src/lib}/components/default/default-table/default-table.component.scss +0 -0
  415. /package/{themes → src/lib}/components/default/default-table/th-filter/th-filter.component.scss +0 -0
  416. /package/{themes → src/lib}/components/default/default-view/default-view.component.scss +0 -0
  417. /package/{themes → src/lib}/components/default/default-view/header-view/header-view.component.scss +0 -0
  418. /package/{themes → src/lib}/components/default-page/default.page.scss +0 -0
  419. /package/{themes → src/lib}/components/drag-drop-file/drag-drop-overlay/drag-drop-overlay.component.scss +0 -0
  420. /package/{themes → src/lib}/components/drawer/default-drawer-end/default-drawer-end.component.scss +0 -0
  421. /package/{themes → src/lib}/components/drawer/drawer-group/drawer-group.component.scss +0 -0
  422. /package/{themes → src/lib}/components/drawer/drawer.component.scss +0 -0
  423. /package/{themes → src/lib}/components/filter/filter.component.scss +0 -0
  424. /package/{themes → src/lib}/components/http-responses-pages/forbidden-403/forbidden-403.component.scss +0 -0
  425. /package/{themes → src/lib}/components/image/image.component.scss +0 -0
  426. /package/{themes → src/lib}/components/info-popover/info-popover.component.scss +0 -0
  427. /package/{themes → src/lib}/components/inputs/input-bool/input-bool.component.scss +0 -0
  428. /package/{themes → src/lib}/components/inputs/input-color/input-color.component.scss +0 -0
  429. /package/{themes/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.scss → src/lib/components/inputs/input-color/input-color.configuration.ts} +0 -0
  430. /package/{themes/components/inputs/input-loading/input-loading.component.scss → src/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.scss} +0 -0
  431. /package/{themes → src/lib}/components/inputs/input-date/input-date.component.scss +0 -0
  432. /package/{themes → src/lib}/components/inputs/input-decimal/input-decimal.component.scss +0 -0
  433. /package/{themes → src/lib}/components/inputs/input-file/download-button/download-button.component.scss +0 -0
  434. /package/{themes → src/lib}/components/inputs/input-file/input-file.component.scss +0 -0
  435. /package/{themes/components/inputs/input-select/input-select-internal-option/input-select-internal-option.component.scss → src/lib/components/inputs/input-loading/input-bool.configuration.ts} +0 -0
  436. /package/{themes/components/inputs/input-select/input-select-option/input-select-option.component.scss → src/lib/components/inputs/input-loading/input-loading.component.scss} +0 -0
  437. /package/{themes/components/inputs/input-string/input-string.component.scss → src/lib/components/inputs/input-select/input-select-internal-option/input-select-internal-option.component.scss} +0 -0
  438. /package/{themes/components/inputs/input-textarea/input-textarea.component.scss → src/lib/components/inputs/input-select/input-select-option/input-select-option.component.scss} +0 -0
  439. /package/{themes → src/lib}/components/inputs/input-select/input-select.component.scss +0 -0
  440. /package/{themes/components/loading/loading.component.scss → src/lib/components/inputs/input-string/input-string.component.scss} +0 -0
  441. /package/{themes/components/stepper/stepper.component.scss → src/lib/components/inputs/input-textarea/input-textarea.component.scss} +0 -0
  442. /package/{themes → src/lib}/components/inputs/inputs.scss +0 -0
  443. /package/{themes/components/tabs/tab/tab.component.scss → src/lib/components/loading/loading.component.scss} +0 -0
  444. /package/{themes → src/lib}/components/login/login-admin/login-admin.component.scss +0 -0
  445. /package/{themes → src/lib}/components/login/login.component.scss +0 -0
  446. /package/{themes → src/lib}/components/main-content/main-content.component.scss +0 -0
  447. /package/{themes → src/lib}/components/stepper/step/step.component.scss +0 -0
  448. /package/{themes/components/text-tooltip/text-tooltip.component.scss → src/lib/components/stepper/stepper.component.scss} +0 -0
  449. /package/{themes → src/lib}/components/tabs/tabs/tabs.component.scss +0 -0
  450. /package/{themes → src/lib}/components/tooltip/tooltip.component.scss +0 -0
  451. /package/{themes → src/lib}/styles/components.scss +0 -0
  452. /package/{themes → src/lib}/styles/ionic/ion-action-sheet.scss +0 -0
  453. /package/{themes → src/lib}/styles/ionic/ion-alert.scss +0 -0
  454. /package/{themes → src/lib}/styles/ionic/ion-button.scss +0 -0
  455. /package/{themes → src/lib}/styles/ionic/ion-card.scss +0 -0
  456. /package/{themes → src/lib}/styles/ionic/ion-content.scss +0 -0
  457. /package/{themes → src/lib}/styles/ionic/ion-datetime.scss +0 -0
  458. /package/{themes → src/lib}/styles/ionic/ion-item.scss +0 -0
  459. /package/{themes → src/lib}/styles/ionic/ion-list.scss +0 -0
  460. /package/{themes → src/lib}/styles/ionic/ion-modal.scss +0 -0
  461. /package/{themes → src/lib}/styles/ionic/ion-popover.scss +0 -0
  462. /package/{themes → src/lib}/styles/ionic/ion-progress-bar.scss +0 -0
  463. /package/{themes → src/lib}/styles/ionic/ion-searchbar.scss +0 -0
  464. /package/{themes → src/lib}/styles/ionic/ion-toast.scss +0 -0
  465. /package/{themes → src/lib}/styles/ionic.scss +0 -0
  466. /package/{themes → src/lib}/styles/login-default.scss +0 -0
  467. /package/{themes → src/lib}/styles/mixins.scss +0 -0
  468. /package/{themes → src/lib}/styles/styles.scss +0 -0
  469. /package/{themes → src/lib}/styles/translucid.scss +0 -0
@@ -1,8 +1,18 @@
1
- import { InputCurrencyConfiguration, InputDecimalConfiguration, InputNumberConfiguration } from "./input-decimal/input-decimal.configuration";
2
- import { InputCpfCnpjConfiguration } from "./input-cpf-cnpj/input-cpf-cnpj.configuration";
3
- import { InputSelectConfiguration } from "./input-select/input.select.configuration";
4
- import { InputStringConfiguration } from "./input-string/input-string.configuration";
5
- import { InputBoolConfiguration } from "./input-bool/input-bool.configuration";
6
- import { InputDateConfiguration } from "./input-date/input-date.configuration";
7
- import { InputFileConfiguration } from "./input-file/input-file.configuration";
8
- export type InputConfiguration = InputFileConfiguration | InputSelectConfiguration | InputBoolConfiguration | InputDateConfiguration | InputDecimalConfiguration | InputNumberConfiguration | InputCurrencyConfiguration | InputCpfCnpjConfiguration | InputStringConfiguration | any;
1
+ import { InputCurrencyConfiguration, InputDecimalConfiguration, InputNumberConfiguration } from "./input-decimal/input-decimal.configuration";
2
+ import { InputCpfCnpjConfiguration } from "./input-cpf-cnpj/input-cpf-cnpj.configuration";
3
+ import { InputSelectConfiguration } from "./input-select/input.select.configuration";
4
+ import { InputStringConfiguration } from "./input-string/input-string.configuration";
5
+ import { InputBoolConfiguration } from "./input-bool/input-bool.configuration";
6
+ import { InputDateConfiguration } from "./input-date/input-date.configuration";
7
+ import { InputFileConfiguration } from "./input-file/input-file.configuration";
8
+
9
+ export type InputConfiguration =
10
+ InputFileConfiguration |
11
+ InputSelectConfiguration |
12
+ InputBoolConfiguration |
13
+ InputDateConfiguration |
14
+ InputDecimalConfiguration |
15
+ InputNumberConfiguration |
16
+ InputCurrencyConfiguration |
17
+ InputCpfCnpjConfiguration |
18
+ InputStringConfiguration | any;
@@ -0,0 +1,26 @@
1
+ <div class="flex relative overflow-hidden">
2
+ <ion-card class="focus-within:on-focus ion-card-input" [disabled]="loading || disabled"
3
+ [ngClass]="{
4
+ 'invalid' : invalid,
5
+ 'submitted': submitted,
6
+ 'disabled' : disabled,
7
+ }"
8
+ >
9
+ <ion-card-content>
10
+ <div class="flex">
11
+ <ion-item class="w-full" [ngClass]="{'submitted': submitted, 'invalid': invalid, 'required': required}" lines="none">
12
+ <ion-input
13
+ [(ngModel)]="model"
14
+ labelPlacement="stacked"
15
+
16
+ [maskito]="mask"
17
+ [maskitoElement]="maskPredicate"
18
+ >
19
+ <ion-text id="label" [ngClass]="{'required': required}" slot="label"> {{label}} </ion-text>
20
+ </ion-input>
21
+ </ion-item>
22
+ </div>
23
+ </ion-card-content>
24
+ </ion-card>
25
+ <input-loading [loading]="loading"></input-loading>
26
+ </div>
@@ -0,0 +1,78 @@
1
+ import { Component, ElementRef, Host, Input, OnInit, Optional, SkipSelf } from '@angular/core';
2
+ import { ControlContainer } from '@angular/forms';
3
+
4
+ import { MaskitoOptions, MaskitoElementPredicate, maskitoTransform } from '@maskito/core';
5
+ import { MaskitoMaskExpression } from '@maskito/core/src/lib/types';
6
+
7
+ import { InputCpfCnpjConfiguration } from './input-cpf-cnpj.configuration';
8
+ import { InputProviderFactory } from '../input-provider-factory';
9
+ import { CustomInput } from '../custom-input';
10
+
11
+ @Component({
12
+ selector: 'input-cpf-cnpj, input-cpf, input-cnpj',
13
+ templateUrl: './input-cpf-cnpj.component.html',
14
+ styleUrls: ['./input-cpf-cnpj.component.scss', '../inputs.scss'],
15
+ providers: InputProviderFactory.GetProvider(InputCpfCnpjComponent)
16
+ })
17
+ export class InputCpfCnpjComponent extends CustomInput<string> implements OnInit {
18
+
19
+ @Input() configuration: InputCpfCnpjConfiguration = new InputCpfCnpjConfiguration('CPF/CNPJ')
20
+
21
+ constructor(
22
+ @Optional() @Host() @SkipSelf()
23
+ override controlContainer: ControlContainer,
24
+ override elementRef: ElementRef
25
+ ) { super(); }
26
+
27
+ override async ngOnInit() {
28
+ super.ngOnInit();
29
+
30
+ if(this.elementRef.nativeElement.tagName.toLowerCase() == 'input-cpf-cnpj'){
31
+ this.configuration = new InputCpfCnpjConfiguration();
32
+ }else{
33
+ const selector: string = this.elementRef.nativeElement.tagName.toLowerCase().split('-')[1];
34
+ if(selector == 'cpf' ){ this.configuration = new InputCpfCnpjConfiguration('CPF') } else
35
+ if(selector == 'cnpj'){ this.configuration = new InputCpfCnpjConfiguration('CNPJ') }
36
+ }
37
+ }
38
+
39
+ override writeValue(value: string){ this.setModel(value) }
40
+ override get model(): string { return this._model; }
41
+ override set model(value: string) { this.setModel(value); this.propagateChange(this._model.replaceAll('.', '').replaceAll('-', '').replaceAll('/', '')); }
42
+
43
+ setModel(value){
44
+ if(value == null){
45
+ this._model = ''
46
+ } else {
47
+ this._model = maskitoTransform(value, this.mask);
48
+ }
49
+ }
50
+
51
+ readonly cpfMask : MaskitoMaskExpression = [ /\d/, /\d/, /\d/, '.', /\d/, /\d/, /\d/, '.', /\d/, /\d/, /\d/, '-', /\d/, /\d/ ];
52
+ readonly cnpjMask: MaskitoMaskExpression = [ /\d/, /\d/, '.', /\d/, /\d/, /\d/, '.', /\d/, /\d/, /\d/, '/', /\d/, /\d/, /\d/, /\d/, '-', /\d/, /\d/];
53
+
54
+ readonly mask: MaskitoOptions = {
55
+ mask: (elementState) => {
56
+ if(this.configuration.type == 'CPF/CNPJ'){
57
+ if(!elementState.value){
58
+ return this.cpfMask;
59
+ }else{
60
+ if(elementState.value.includes('.')){
61
+ if(elementState.value.length <= 14) {
62
+ return this.cpfMask;
63
+ }
64
+ return this.cnpjMask;
65
+ }else{
66
+ if(elementState.value.length <= 11) {
67
+ return this.cpfMask;
68
+ }
69
+ return this.cnpjMask;
70
+ }
71
+ }
72
+ }
73
+ if(this.configuration.type == 'CNPJ'){ return this.cnpjMask; }
74
+ if(this.configuration.type == 'CPF' ){ return this.cpfMask; }
75
+ },
76
+ };
77
+ readonly maskPredicate: MaskitoElementPredicate = async (el) => (el as HTMLIonInputElement).getInputElement();
78
+ }
@@ -0,0 +1,4 @@
1
+ export type CPFCnpj = 'CPF' | 'CNPJ' | 'CPF/CNPJ'
2
+ export class InputCpfCnpjConfiguration {
3
+ constructor(public type: CPFCnpj = 'CPF/CNPJ'){}
4
+ }
@@ -0,0 +1,40 @@
1
+ <div class="flex relative overflow-hidden">
2
+ <ion-card class="focus-within:on-focus ion-card-input" [disabled]="loading || disabled"
3
+ [ngClass]="{
4
+ 'invalid' : invalid,
5
+ 'submitted': submitted,
6
+ 'disabled' : disabled,
7
+ '!border-r-0 !rounded-r-none': configuration.clearable
8
+ }"
9
+ >
10
+ <ion-card-content>
11
+ <ion-item lines="none" class="w-full default-transition">
12
+ <ion-input (click)="Open()" [readonly]="true" labelPlacement="stacked" class="!opacity-100" [(ngModel)]="_val">
13
+ <ion-text id="label" [ngClass]="{'required': required}" slot="label"> {{label}}</ion-text>
14
+ </ion-input>
15
+ </ion-item>
16
+ </ion-card-content>
17
+ </ion-card>
18
+ <div class="w-12 shrink-0" [hidden]="!configuration.clearable">
19
+ <ion-button (click)="Clear()"[disabled]="loading || disabled" class="m-0 h-full w-full rounded-r-2xl on-hover" style="--border-width: 1px 1px 2px 1px;" size="small" color="medium" fill="outline">
20
+ <ion-icon slot="icon-only" name="backspace"></ion-icon>
21
+ </ion-button>
22
+ </div>
23
+ <input-loading [loading]="loading"></input-loading>
24
+ </div>
25
+
26
+ <ion-modal [id]="id_modal" [keepContentsMounted]="true" class="bg-transparent">
27
+ <ng-template>
28
+ <ion-datetime [presentation]="presentation" #datetime id="{{id_modal}}-datetime" locale="pt-BR" [(ngModel)]="dateModel" (ngModelChange)="DateTimeChange()">
29
+ <ion-buttons slot="buttons">
30
+ <ion-button color="primary" fill="clear" (click)="datetime.cancel(); modal.dismiss()">
31
+ <ion-icon slot="icon-only" name="close-circle"></ion-icon>
32
+ </ion-button>
33
+ <ion-button color="primary" fill="clear" (click)="datetime.confirm(); modal.dismiss()">
34
+ <ion-icon slot="icon-only" name="checkmark-circle"></ion-icon>
35
+ </ion-button>
36
+ </ion-buttons>
37
+ </ion-datetime>
38
+ </ng-template>
39
+ </ion-modal>
40
+ <ion-datetime-button class="hidden" datetime="{{id_modal}}-datetime"></ion-datetime-button>
@@ -0,0 +1,98 @@
1
+ import { Component, ElementRef, Host, Input, OnInit, Optional, SkipSelf } from '@angular/core';
2
+ import { ControlContainer } from '@angular/forms';
3
+ import { IonModal } from '@ionic/angular';
4
+ import moment from 'moment';
5
+
6
+ import { InputDateConfiguration } from './input-date.configuration';
7
+ import { InputProviderFactory } from '../input-provider-factory';
8
+ import { CustomInput } from '../custom-input';
9
+ import { Utils } from '../../../services/utils.service';
10
+
11
+ @Component({
12
+ selector: 'input-date, input-date-time, input-time',
13
+ templateUrl: './input-date.component.html',
14
+ styleUrls: ['./input-date.component.scss', '../inputs.scss'],
15
+ providers: InputProviderFactory.GetProvider(InputDateComponent)
16
+ })
17
+ export class InputDateComponent extends CustomInput<string> implements OnInit {
18
+
19
+ @Input() configuration: InputDateConfiguration = new InputDateConfiguration();
20
+
21
+ constructor(
22
+ @Optional() @Host() @SkipSelf()
23
+ override controlContainer : ControlContainer,
24
+ override elementRef : ElementRef,
25
+ ) { super(); this.HandleSelector(); }
26
+
27
+ public presentation: "date-time" | "date" | "time" | string = "date-time"
28
+ private transform: Function = ((v) => { console.warn("[ Component isn't ready ]"); })
29
+
30
+ HandleSelector(){
31
+ const selector: string = (this.elementRef.nativeElement.tagName.toLowerCase() as string).replace('input-', '');
32
+ this.presentation = selector;
33
+
34
+ if(selector == "date-time"){ this.transform = Utils.DateISOToDDMMYYYYHHMM }
35
+ if(selector == "date") { this.transform = Utils.DateISOToDDMMYYYY }
36
+ if(selector == "time") { this.transform = TimeTransform }
37
+ }
38
+
39
+ id_modal: string = "";
40
+ override async ngOnInit() {
41
+ super.ngOnInit();
42
+ this.id_modal = `${this.formControlName}${this.id}${Utils.GenerateGUID()}${this.elementRef.nativeElement.tagName.toLowerCase()}`
43
+ }
44
+
45
+ dateModel: string | null = new Date().toISOString();
46
+ override writeValue(value: string | null){
47
+ if (value !== undefined && value != null) {
48
+ if(['date-time', 'date'].includes(this.presentation)){
49
+ this.dateModel = moment(value).toISOString();
50
+ this.setModel(value);
51
+ }else{
52
+ this.dateModel = this.transform(value);
53
+ this.setModel(this.transform(value));
54
+ }
55
+ }else{
56
+ this.dateModel = null;
57
+ this.setModel(null)
58
+ }
59
+ }
60
+ override get model(): string { if(this._model != null){ return this.transform(this._model); } else return null; }
61
+ override set model(value: string) { this._model = value; this.propagateChange(this._model); }
62
+ setModel(value: string){
63
+ this._model = value;
64
+ }
65
+
66
+ get _val() { return this.model; }
67
+ set _val(v) { }
68
+
69
+ get modal(){ return document.getElementById(this.id_modal) as any as IonModal}
70
+ Open(){ if(!this.disabled){ this.modal.present(); } }
71
+
72
+ Clear(){
73
+ this.dateModel = null;
74
+ this.DateTimeChange();
75
+ }
76
+ DateTimeChange(): void{
77
+ if(this.dateModel){
78
+ if(this.presentation == 'time') {
79
+ if(this.dateModel.includes('T')){
80
+ this.dateModel = this.dateModel.split('T')[1];
81
+ }
82
+ this.model = this.dateModel;
83
+ } else
84
+ if(this.presentation == 'date') { this.model = this.dateModel.split('T')[0] + "T00:00:00" } else { this.model = this.dateModel }
85
+ }else{
86
+ this.model = this.dateModel
87
+ }
88
+ }
89
+ }
90
+
91
+ const TimeTransform: Function = ((v: string): string => {
92
+ if(!v){ return null; }
93
+ if(v.split(':').length == 2){
94
+ return v;
95
+ }else{
96
+ return v.split(':')[0] + ":" + v.split(':')[1]
97
+ }
98
+ })
@@ -0,0 +1,6 @@
1
+ export class InputDateConfiguration{
2
+ constructor(
3
+ /** Habilita o botão de limpar os dados */
4
+ public clearable: boolean = false
5
+ ){}
6
+ }
@@ -0,0 +1,24 @@
1
+ <div class="flex relative overflow-hidden">
2
+ <ion-card class="focus-within:on-focus ion-card-input" [disabled]="loading || disabled"
3
+ [ngClass]="{
4
+ 'invalid' : invalid,
5
+ 'submitted': submitted,
6
+ 'disabled': disabled,
7
+ }"
8
+ >
9
+ <ion-card-content>
10
+ <div class="relative flex">
11
+ <ion-item class="w-full shrink-0" [ngClass]="{'required' : required}" lines="none">
12
+ <ion-input
13
+ class="default-transition" [value]="model" labelPlacement="stacked"
14
+ >
15
+ <ion-text [ngClass]="{'required': required}" slot="label"> {{label}} </ion-text>
16
+ <span *ngIf="configuration.prefix" slot="start">{{configuration.prefix}}</span>
17
+ <span *ngIf="configuration.sufix" slot="end" >{{configuration.sufix}}</span>
18
+ </ion-input>
19
+ </ion-item>
20
+ </div>
21
+ </ion-card-content>
22
+ </ion-card>
23
+ <input-loading [loading]="loading"></input-loading>
24
+ </div>
@@ -0,0 +1,296 @@
1
+ import { Component, ElementRef, Host, HostListener, Input, OnInit, Optional, SkipSelf } from '@angular/core';
2
+ import { ControlContainer } from '@angular/forms';
3
+ import { formatNumber } from '@angular/common';
4
+
5
+ import { InputCurrencyConfiguration, InputDecimalConfiguration, InputNumberConfiguration } from './input-decimal.configuration';
6
+ import { InputProviderFactory } from '../input-provider-factory';
7
+ import { Timeout } from '../../../services/utils.service';
8
+ import { CustomInput } from '../custom-input';
9
+
10
+ @Component({
11
+ selector: 'input-decimal, input-number, input-currency, inout-percentage',
12
+ templateUrl: './input-decimal.component.html',
13
+ styleUrls: ['./input-decimal.component.scss', '../inputs.scss'],
14
+ providers: InputProviderFactory.GetProvider(InputDecimalComponent)
15
+ })
16
+ export class InputDecimalComponent extends CustomInput<number> implements OnInit {
17
+
18
+ @Input() configuration: InputDecimalConfiguration | InputNumberConfiguration | InputCurrencyConfiguration;
19
+
20
+ constructor(
21
+ @Optional() @Host() @SkipSelf()
22
+ override controlContainer: ControlContainer,
23
+ override elementRef: ElementRef
24
+ ) { super(); this._model = 0; }
25
+
26
+ override async ngOnInit() {
27
+ super.ngOnInit();
28
+
29
+ this.HandleSelector();
30
+ this.setDivider();
31
+ }
32
+
33
+ digitsInfo: string = "1.2-2";
34
+ setDigitsInfo(): void { this.digitsInfo = `1.${this.configuration.precision}-${this.configuration.precision}`; }
35
+ HandleSelector(): void{
36
+ const selector: string = this.elementRef.nativeElement.tagName.toLowerCase().split('-')[1];
37
+
38
+ if(selector == "number" && !this.configuration){ this.configuration = new InputNumberConfiguration(); } else
39
+ if(selector == "decimal" && !this.configuration){ this.configuration = new InputDecimalConfiguration(); } else
40
+ if(selector == "currency" && !this.configuration){ this.configuration = new InputCurrencyConfiguration(); }
41
+ this.setDigitsInfo();
42
+ }
43
+
44
+ override writeValue(value: number){ this._model = value; }
45
+
46
+ override get model(): string {
47
+ var formated = formatNumber(this._model, "pt-BR", this.digitsInfo);
48
+ if(this.configuration.thousandSeparator){
49
+ return formated;
50
+ }else{
51
+ return formated.replaceAll(thousandSeparator, '')
52
+ }
53
+ }
54
+ override set model(value: number) { this._model = value; this.propagateChange(this._model); }
55
+
56
+ //#region [ Event Handler ]
57
+ @HostListener('keydown', ['$event'])
58
+ onKeyDown(event: any) {
59
+ this.eventType = 0;
60
+ this.event = event;
61
+ this.key = event.key;
62
+
63
+ this.altKey = this.event.altKey;
64
+ this.ctrlKey = this.event.ctrlKey;
65
+ this.shiftKey = this.event.shiftKey;
66
+
67
+ this.startPosition = event.target.selectionStart;
68
+ this.endPosition = event.target.selectionEnd;
69
+
70
+ this.value = event.target.value;
71
+
72
+ this.HandleBrowser();
73
+ }
74
+
75
+ @HostListener('paste', ['$event'])
76
+ onPaste(event: any) {
77
+ this.event.preventDefault();
78
+
79
+ let clipboardData = event.clipboardData || window['clipboardData'];
80
+ let pastedText = clipboardData.getData('text');
81
+
82
+ const s = pastedText.replaceAll('.', '').replaceAll(',', '.');
83
+ const n = Number(s);
84
+
85
+ if(Number(s) && isFinite(n)){
86
+ this.model = n;
87
+ } else{
88
+
89
+ }
90
+ event.preventDefault();
91
+ }
92
+
93
+ key: string | null | undefined;
94
+
95
+ altKey : boolean = false;
96
+ ctrlKey : boolean = false;
97
+ shiftKey: boolean = false;
98
+
99
+ startPosition : number;
100
+ endPosition : number;
101
+
102
+ value: string;
103
+
104
+ event : any;
105
+ eventType: number;
106
+
107
+ atLeft: string;
108
+ atRight: string;
109
+
110
+ HandleBrowser(){
111
+ this.atLeft = this.value.slice(0, this.startPosition);
112
+ this.atRight = this.value.slice(this.endPosition, this.value.length);
113
+ if(["-"].includes(this.key)){
114
+ return this.HandleNegative();
115
+ }else
116
+ if(["V", "v"].includes(this.key) && this.ctrlKey){
117
+ //@HostListener('paste', ['$event'])
118
+ }else
119
+ if(lstNumbers.includes(this.key)){
120
+ return this.HandleNumber();
121
+ }else
122
+ if(lstEspecialCases.includes(this.key)){
123
+ return this.HandleEspecial();
124
+ }else
125
+ if(["A", "a"].includes(this.key) && this.ctrlKey){
126
+ return;
127
+ }else
128
+ if(["C", "c"].includes(this.key) && this.ctrlKey){
129
+ return this.HandleCopy();
130
+ }else
131
+ if(lstIgnoreNotPrevent.includes(this.key)){
132
+ return;
133
+ }else
134
+ this.event.preventDefault();
135
+ }
136
+
137
+ divider: number;
138
+ setDivider(){
139
+ var d = "1";
140
+ for(let i = 0; i < this.configuration.precision; i++){
141
+ d += "0";
142
+ }
143
+ this.divider = Number(d);
144
+ }
145
+
146
+ async HandleNumber(){
147
+ this.event.preventDefault();
148
+
149
+ var focusEnd = this.startPosition == 0 && this.endPosition == this.model.length;
150
+ /** [ Remove decimalSeparator & thousandSeparator ] */
151
+ const f = this.atLeft + this.key + this.atRight;
152
+ const CurrentValue: number = this.SanitizeValue(f);
153
+ if(CurrentValue == this._model){ return false; }
154
+ if(CurrentValue > decimalMaxValue){
155
+ return false;
156
+ }
157
+
158
+ //[ Handle Set Cursor Position]
159
+ this.model = CurrentValue;
160
+ const newPos = this.startPosition + 1 + this.model.split('.').length - this.value.split('.').length;
161
+
162
+ //Horrivel, mas nao sem uma alternativa boa, https://stackoverflow.com/questions/511088/use-javascript-to-place-cursor-at-end-of-text-in-text-input-element
163
+ await Timeout(0);
164
+ this.event.target.setSelectionRange(newPos, newPos);
165
+ if(focusEnd){
166
+ this.event.target.setSelectionRange(this.model.length, this.model.length);
167
+ }
168
+
169
+ return false;
170
+ }
171
+
172
+ async HandleNegative(){
173
+ this.event.preventDefault();
174
+
175
+ var focusEnd = this.startPosition == 0 && this.endPosition == this.model.length;
176
+ /** [ Remove decimalSeparator & thousandSeparator ] */
177
+ var f;
178
+ if(!this.atLeft.includes('-')){
179
+ f = this.key + this.atLeft + this.atRight;
180
+ }else{
181
+ f = (this.atLeft + this.atRight).replace('-', '')
182
+ }
183
+ if(f == "-"){
184
+ if(this.value.includes('-')){
185
+ f = this.value.replace('-', '');
186
+ }
187
+ else{
188
+ f = `-${this.value}`;
189
+ }
190
+ }
191
+
192
+ const CurrentValue: number = this.SanitizeValue(f);
193
+ if(CurrentValue == this._model){ return false; }
194
+
195
+ //[ Handle Set Cursor Position]
196
+ this.model = CurrentValue;
197
+ const newPos = this.startPosition + 1 + this.model.split('.').length - this.value.split('.').length;
198
+
199
+ //Horrivel, mas nao sem uma alternativa boa, https://stackoverflow.com/questions/511088/use-javascript-to-place-cursor-at-end-of-text-in-text-input-element
200
+ await Timeout(0);
201
+ this.event.target.setSelectionRange(newPos, newPos);
202
+ if(focusEnd){
203
+ this.event.target.setSelectionRange(this.model.length, this.model.length);
204
+ }
205
+ return false;
206
+ }
207
+
208
+ async HandleEspecial(){
209
+ this.event.preventDefault();
210
+ if(this.startPosition == this.endPosition){
211
+ if(this.key == "Backspace"){
212
+ if(this.startPosition == this.endPosition && this.startPosition == 0){ return false; }
213
+
214
+ const previousChar: string = this.atLeft[this.atLeft.length - 1];
215
+ const isNumber = lstNumbers.includes(previousChar);
216
+ const f = this.atLeft.slice(0, this.atLeft.length - (isNumber ? 1 : 2)) + this.atRight;
217
+ const CurrentValue = this.SanitizeValue(f);
218
+
219
+ //[ Handle Set Cursor Position]
220
+ this.model = CurrentValue;
221
+ await Timeout(0);
222
+ this.event.target.setSelectionRange(this.startPosition, this.startPosition);
223
+
224
+ return false;
225
+ }else
226
+ if(this.key == "Delete"){
227
+ const nextChar: string = this.atRight[0];
228
+ const isNumber = lstNumbers.includes(nextChar);
229
+ const f = this.atLeft + this.atRight.slice(isNumber ? 1 : 2);
230
+ const CurrentValue = this.SanitizeValue(f);
231
+
232
+ //[ Handle Set Cursor Position]
233
+ this.model = CurrentValue;
234
+ var newPos: number = this.startPosition - 1
235
+ if(newPos <= -1){ newPos = 0; }
236
+
237
+ await Timeout(0);
238
+ this.event.target.setSelectionRange(newPos, newPos);
239
+
240
+ return false;
241
+ }
242
+ }else{
243
+ const f = this.atLeft + this.atRight;
244
+ const CurrentValue = this.SanitizeValue(f);
245
+ this.model = CurrentValue;
246
+
247
+ await Timeout(0);
248
+ this.event.target.setSelectionRange(this.model.length, this.model.length);
249
+
250
+ return false;
251
+ }
252
+ }
253
+
254
+ async HandleCopy(){
255
+ //[ Not necessary, default behaviour might work ]
256
+ // this.event.preventDefault();
257
+
258
+ // var str = this.model;
259
+ // var lst = str.split('');
260
+ // lst.splice(this.endPosition, str.length - this.endPosition);
261
+ // lst.splice(0, this.startPosition)
262
+ // var copy = lst.join('').replaceAll(this.configuration.thousandSeparator, '').replace(this.configuration.decimalSeparator, '.');
263
+ // console.log(copy)
264
+ // Clipboard.write({string: copy}).catch(() => {
265
+ // navigator.clipboard.writeText(copy);
266
+ // });
267
+ }
268
+
269
+ SanitizeValue(f: string): number{
270
+ var CurrentValue: number = Number(Sanitize(f)) / this.divider;
271
+ //[ Cancela se o valor for muito alto ]
272
+ if(CurrentValue >= decimalMaxValue){
273
+ return this._model;
274
+ }
275
+ return CurrentValue;
276
+ }
277
+ //#endregion [ Event Handler ]
278
+ }
279
+
280
+ const decimalMaxValue = 9_000_000_000_000.00
281
+
282
+ const decimalSeparator : string = ",";
283
+ const thousandSeparator: string = ".";
284
+
285
+ const Sanitize: Function = ((v: string): string => {
286
+ return v.replaceAll(thousandSeparator, '')
287
+ .replace (decimalSeparator , '')
288
+ });
289
+
290
+ const lstNumbers = ["0","1","2","3","4","5","6","7","8","9"];
291
+ const lstIgnoreNotPrevent = [
292
+ "Tab", "CapsLock", "Shift", "Control", "Alt", "ArrowRight", "ArrowUp", "ArrowDown", "ArrowLeft"
293
+ ];
294
+ const lstEspecialCases = [
295
+ "Backspace", "Delete"
296
+ ];
@@ -0,0 +1,42 @@
1
+ export class InputDecimalConfiguration{
2
+ prefix : string;
3
+ sufix : string;
4
+ placeholder : string;
5
+
6
+ constructor(
7
+ /** Declara a quantidade de numeros apos o ponto */
8
+ public precision: number = 2,
9
+ /** Texto no inicio do input */
10
+ prefix: string | null = null,
11
+ /** Texto no fim do input */
12
+ sufix: string | null = null,
13
+ /** Se = false não aplica virgulas no lugar do separador a cada 3 unidades */
14
+ public thousandSeparator: string = '.',
15
+ public decimalSeparator : string = ','
16
+ ){
17
+ if(!prefix){ this.prefix = ''; }else{ this.prefix = prefix; }
18
+ if(!sufix ){ this.sufix = ''; }else{ this.sufix = sufix; }
19
+
20
+ this.placeholder = "-";
21
+ if(precision > 0){
22
+ this.placeholder += this.decimalSeparator;
23
+ for(let i = precision; i > 0; i--){
24
+ this.placeholder += "-";
25
+ }
26
+ }
27
+ }
28
+ }
29
+ export class InputNumberConfiguration extends InputDecimalConfiguration {
30
+ constructor(
31
+ prefix: string = "",
32
+ sufix : string = "",
33
+ thousandSeparator: string = '.'
34
+ ){
35
+ super(0, prefix, sufix, thousandSeparator);
36
+ }
37
+ }
38
+ export class InputCurrencyConfiguration extends InputDecimalConfiguration {
39
+ constructor(prefix: string = "R$", sufix: string = "", thousandSeparator: string = '.'){
40
+ super(2, prefix, sufix, thousandSeparator);
41
+ }
42
+ }
@@ -0,0 +1,15 @@
1
+ import { InputDecimalConfiguration, InputNumberConfiguration } from "./input-decimal/input-decimal.configuration";
2
+
3
+ export class InputsDefaultConfigurations {
4
+ static readonly configurationDecimalPercentage: InputDecimalConfiguration = new InputDecimalConfiguration(2, null, '%');
5
+ static readonly configurationDecimalDegree : InputDecimalConfiguration = new InputDecimalConfiguration(2, null, "°C");
6
+ static readonly configurationDecimalM3H : InputDecimalConfiguration = new InputDecimalConfiguration(2, null, "m³/h");
7
+ static readonly configurationDecimalMeters : InputDecimalConfiguration = new InputDecimalConfiguration(2, null, "m");
8
+ static readonly configurationDecimalMilimeters: InputDecimalConfiguration = new InputDecimalConfiguration(2, null, "mm");
9
+
10
+ static readonly configurationNumberPercentage: InputNumberConfiguration = new InputNumberConfiguration(null, '%');
11
+ static readonly configurationNumberDegree : InputNumberConfiguration = new InputNumberConfiguration(null, "°C");
12
+ static readonly configurationNumberM3H : InputNumberConfiguration = new InputNumberConfiguration(null, "m³/h");
13
+ static readonly configurationNumberMeters : InputNumberConfiguration = new InputNumberConfiguration(null, "m");
14
+ static readonly configurationNumberMilimeters: InputNumberConfiguration = new InputNumberConfiguration(null, "mm");
15
+ }