@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
@@ -0,0 +1,121 @@
1
+
2
+ import { Component, effect, ElementRef, Input, model, ModelSignal, OnInit } from '@angular/core';
3
+ import { RefresherCustomEvent } from "@ionic/angular";
4
+ import { Observable, firstValueFrom } from "rxjs";
5
+ import { ActivatedRoute } from '@angular/router';
6
+
7
+ import { CompileLstTableField, Comparison } from "../../../classes/comparison/comparison";
8
+ import { HttpService, ViewRetorno } from '../../../services/web/http.service';
9
+ import { GenericService } from "../../../services/generics.service";
10
+ import { ViewFiltros } from "../../../classes/filters/view-filtros";
11
+ import { TableField } from "../../../classes/inputs/table-field";
12
+ import { RouteData } from "../../../classes/routes/route-data";
13
+ import { LongProperty } from '../../../classes/comparison/properties/long-property';
14
+
15
+ //Classe de listagem, implemente carregamento e filtragem de dados
16
+ @Component({ template: '', styles: '' })
17
+ export abstract class List<T extends HttpService<V>, V = any> implements OnInit {
18
+
19
+ protected genericService: GenericService;
20
+ protected activatedRoute: ActivatedRoute;
21
+ protected elementRef: ElementRef;
22
+ @Input() service: T;
23
+
24
+ constructor() {
25
+ effect(() => {
26
+ this.SetFilters();
27
+ });
28
+ }
29
+
30
+ /** @optional Filtro a ser aplicado na busca da listagem na API */
31
+ preloadFilter: ModelSignal<Comparison[]> = model<Comparison[]>([]);
32
+
33
+ /** End-point de carregamento de dados. Deve ser uma função no service aplicado */
34
+ @Input() loadFrom: (view: ViewFiltros) => Observable<ViewRetorno>;
35
+
36
+
37
+ lstDados: V[] = [];
38
+ total : number;
39
+ nested : boolean = false;
40
+ loading : boolean = true;
41
+
42
+ originalFilters: Comparison[] = [];
43
+
44
+ /** Filtro précarregado */
45
+ @Input() frm: ViewFiltros = new ViewFiltros();
46
+
47
+ /** Lista de campos a serem substituídos pelo padrão, armazenado no service enviado como parâmetro */
48
+ @Input() lstTableFields: TableField[] = [];
49
+
50
+ async ngOnInit(): Promise<void> {
51
+ this.originalFilters = this.frm.filter;
52
+
53
+ if(this.lstTableFields.length == 0){
54
+ this.lstTableFields = this.service.lstTableFields;
55
+ }
56
+ if(!this.service.route){ console.warn("[ Warning! ] [ Url is undefined ]")}
57
+ if(!this.service.title){ console.warn("[ Warning! ] [ titulo is undefined ]")}
58
+
59
+ //[ Nested element ]
60
+ if(this.elementRef.nativeElement.parentElement){
61
+ this.nested = (this.elementRef.nativeElement.parentElement.tagName as string).toUpperCase() != "ION-CONTENT";
62
+ }else{
63
+ this.nested = true;
64
+ }
65
+
66
+ await this.SetFilters();
67
+ if(this.nested){ this.Refresh(); }
68
+ }
69
+
70
+ /** Carrega os filtros pré-carregados e os filtros compilados */
71
+ protected async SetFilters(): Promise<void>{
72
+ await this.LoadIdComparison();
73
+ const compiled = CompileLstTableField(this.lstTableFields);
74
+ const preloadFilter = this.preloadFilter();
75
+ // Adiciona os filtros pré-carregados, os filtros compilados e os filtros originais e remove os nulos
76
+ this.frm.filter = [...preloadFilter, ...compiled, ...this.originalFilters].filter(p => p);
77
+ }
78
+
79
+ async LoadIdComparison(): Promise<void>{
80
+ try{
81
+ const data: RouteData = (await firstValueFrom(this.activatedRoute.data)) as RouteData;
82
+
83
+ const id = this.genericService.GetId(this.activatedRoute, data.idPreloaderConfiguration.routeDepth);
84
+ var index: number = this.lstTableFields.indexOf(this.lstTableFields.find(p => p.index == data.idPreloaderConfiguration.propertyName));
85
+ const filter: Comparison = new LongProperty(data.idPreloaderConfiguration.propertyName).Equals(id);
86
+
87
+ filter.value = id;
88
+ filter.disableChange = data.idPreloaderConfiguration.disableChange;
89
+ this.lstTableFields[index].filter = [filter];
90
+ }finally{
91
+ return;
92
+ }
93
+ }
94
+
95
+ async Refresh(event?: RefresherCustomEvent): Promise<void> {
96
+ this.loading = true;
97
+ try{
98
+ await this.Load();
99
+ }
100
+ finally{ }
101
+
102
+ if(event){ event.target.complete(); }
103
+ this.loading = false;
104
+ }
105
+
106
+ async Load(): Promise<void>{
107
+ var vRetorno: ViewRetorno;
108
+
109
+ try{
110
+ if(this.loadFrom){
111
+ vRetorno = await firstValueFrom(this.service[this.loadFrom.name](this.frm));
112
+ }
113
+ else{
114
+ vRetorno = await firstValueFrom(this.service.List(this.frm));
115
+ }
116
+ this.lstDados = vRetorno.lstDados;
117
+ this.total = vRetorno.total;
118
+ } finally{ }
119
+ return;
120
+ }
121
+ }
@@ -0,0 +1,52 @@
1
+ <div id="pagination" class="flex items-center rounded-b-2xl px-4 py-2 portrait:flex-col">
2
+ <div class="w-full h-full items-center justify-start flex portrait:justify-center">
3
+ <ion-spinner [hidden]="!(loading && lstPages.length == 0)"></ion-spinner>
4
+ <ion-text [hidden]="loading && lstPages.length == 0">
5
+ <div class="flex">
6
+ Mostrando &nbsp;
7
+ <ion-skeleton-text *ngIf="loading" [animated]="true" style="width: 2ch"></ion-skeleton-text>
8
+ <b *ngIf="!loading">{{limit * page - limit + length}}</b> &nbsp;
9
+ de
10
+ @if (total != null) {
11
+ <b>&nbsp; {{total}} &nbsp;</b> items
12
+ }
13
+ @else{
14
+ <b>&nbsp; - &nbsp; </b> items
15
+ }
16
+ </div>
17
+ </ion-text>
18
+ </div>
19
+ <div class="w-full h-full items-center justify-end flex portrait:justify-center" *ngIf="total != null">
20
+ <button class="flex items-center" [disabled]="loading" (click)="PageSub()">
21
+ <ion-icon [ngClass]="{'opacity-20': page == 1}" name="chevron-back" class="cursor-pointer default transition"></ion-icon>
22
+ </button>
23
+
24
+ <ion-spinner *ngIf="loading && lstPages.length == 0"></ion-spinner>
25
+
26
+ <button [disabled]="loading" class="page" *ngFor="let item of lstPages" [ngClass]="{ 'selected' : page == item }" (click)="SetPage(item)"> {{item}} </button>
27
+
28
+ <button class="flex items-center" [disabled]="loading" (click)="PageAdd()">
29
+ <ion-icon [ngClass]="{'opacity-20': page == TotalPages }" name="chevron-forward" class="cursor-pointer default transition"></ion-icon>
30
+ </button>
31
+
32
+ @if (TotalPages > 5) {
33
+ <button [disabled]="loading" class="page" [id]="pop_id"><ion-icon name="search"></ion-icon></button>
34
+ <ion-popover [trigger]="pop_id" triggerAction="click">
35
+ <ng-template>
36
+ <ion-content>
37
+ <div class="grid grid-cols-10 pl-3">
38
+ <div class="col-span-8 pb-2">
39
+ <ion-input class="number-class" [(ngModel)]="_page" type="Number" labelPlacement="stacked" label="Página [Max. {{TotalPages}}]"></ion-input>
40
+ </div>
41
+ <div class="col-span-2">
42
+ <ion-button [disabled]="loading" class="size-full" size="small" (click)="SetPageManual()" style="--border-radius: 0rem">
43
+ <ion-icon class="w-4 aspect-square" slot="icon-only" name="checkmark-circle"></ion-icon>
44
+ </ion-button>
45
+ </div>
46
+ </div>
47
+ </ion-content>
48
+ </ng-template>
49
+ </ion-popover>
50
+ }
51
+ </div>
52
+ </div>
@@ -0,0 +1,118 @@
1
+ import { Component, OnInit, Input, Output, EventEmitter } from '@angular/core';
2
+ import { GenericService } from '../../../services/generics.service';
3
+ import { Utils } from '../../../services/utils.service';
4
+
5
+ /** Componente de paginação padrão */
6
+ @Component({
7
+ selector: 'default-pagination',
8
+ templateUrl: './default-pagination.component.html',
9
+ styleUrls: ['./default-pagination.component.scss'],
10
+ })
11
+ export class DefaultPaginationComponent implements OnInit {
12
+
13
+
14
+ total: number = 0;
15
+ limit: number | null = 0;
16
+ /** Valor total de dados */
17
+ @Input('total') set _total(value: number){
18
+ this.total = value;
19
+ this.TotalPages = this.GetTotalPages();
20
+ this.lstPages = this.GetlstPages();
21
+ };
22
+ /** Limite de páginas */
23
+ @Input('limit') set _limit(value: number | null){
24
+ this.limit = value;
25
+ this.TotalPages = this.GetTotalPages();
26
+ this.lstPages = this.GetlstPages();
27
+ };
28
+
29
+ /** Quantidade de dados em tela */
30
+ @Input() length: number;
31
+ @Input() loading: boolean;
32
+
33
+ /** Pagina atual (usando two way data binding) */
34
+ @Input() page: number;
35
+ @Output() pageChange: EventEmitter<number> = new EventEmitter<number>();
36
+
37
+ /** Evento emitido na mudança de valores (Pagina) */
38
+ @Output('change') changeEmitter: EventEmitter<void> = new EventEmitter<void>();
39
+
40
+ constructor(
41
+ private genericService: GenericService
42
+ ) { }
43
+
44
+ ngOnInit() {}
45
+ pop_id: string = "popover-id-" + Utils.GenerateGUID();
46
+
47
+ GetlstPages(): number[] {
48
+ if(!this.TotalPages){ return []; }
49
+ var startIndex: number;
50
+ var start: number[] = [];
51
+
52
+ startIndex = this.page - 1;
53
+
54
+ var _: number[] = [];
55
+ for(let i = this.TotalPages - 4; i <= this.TotalPages ; i++){
56
+ if(i > 0){
57
+ _.push(i);
58
+ }
59
+ }
60
+
61
+ for(let i = startIndex; i <= this.TotalPages && i < startIndex + 5; i++){
62
+ if(i > 0){
63
+ start.push(i);
64
+ }
65
+ }
66
+ if(startIndex == 0 && this.TotalPages >= 5){
67
+ start.push(5);
68
+ }
69
+
70
+ if(start[0] > _[0]){
71
+ return _;
72
+ }
73
+
74
+ return start;
75
+ }
76
+
77
+ GetTotalPages(): number{
78
+ return this.limit ? Math.ceil(this.total / this.limit) : Math.ceil(this.total / this.total)
79
+ }
80
+
81
+ lstPages : number[] = [];
82
+ TotalPages: number = 0;
83
+
84
+ PageAdd(): void{
85
+ if(this.page + 1 > this.TotalPages){ return; }
86
+ this.SetPage(this.page + 1);
87
+ }
88
+
89
+ PageSub(): void{
90
+ if(this.page - 1 < 1){ return; }
91
+ this.SetPage(this.page - 1);
92
+ }
93
+
94
+ SetPage(value: number): void{
95
+ if(value != this.page){
96
+ this.pageChange.emit(value);
97
+ this.EmitChange()
98
+
99
+ setTimeout(() => {
100
+ this.TotalPages = this.GetTotalPages();
101
+ this.lstPages = this.GetlstPages();
102
+ }, 100);
103
+ }
104
+ }
105
+
106
+ _page: number;
107
+ SetPageManual(){
108
+ if(this._page && this._page > 0 && this._page <= this.TotalPages){
109
+ this.SetPage(this._page);
110
+ }else{
111
+ this.genericService.PresentToast("Página inválida")
112
+ }
113
+ }
114
+
115
+ EmitChange(): void{
116
+ this.changeEmitter.emit();
117
+ }
118
+ }
@@ -0,0 +1,105 @@
1
+ <section class="w-full h-full rounded-2xl flex flex-col overflow-y-hidden relative" [ngClass]="{ 'loading' : loading }">
2
+
3
+ <div class="unique-conteiner default-transition" [ngClass]="{'!-z-50 !-translate-y-12 !opacity-0': !loading }">
4
+ <loading [type]="2"></loading>
5
+ </div>
6
+ <div class="unique-conteiner default-transition" [ngClass]="{'!-z-50 !-translate-y-12 !opacity-0': items.length != 0 || loading }">
7
+ <b><ion-icon class="align-sub" name="remove-circle"></ion-icon> Sem dados</b>
8
+ </div>
9
+
10
+ <div id="wrapper" class="relative overflow-y-auto w-full grow-0 mb-auto pb-2">
11
+ <table class="z-20">
12
+ <thead>
13
+ <tr>
14
+ <th scope="col" class="px-3 !h-10" *ngIf="acoesTemplate">
15
+ <span>Ações</span>
16
+ </th>
17
+ @for (field of lstTableFields; let i = $index; track i) {
18
+ @if (!field.hidden) {
19
+ <th scope="col" class="p-2 px-3" id="th-filter-select">
20
+ <div class="flex items-center justify-start h-full" style="white-space: var(--ion-table-filter-wrap);">
21
+ @if(!noFilters){
22
+ <th-filter *ngIf="(field.type != InputTypeFile) && !(field.filter && field.disabledChange()) && !noFilters"
23
+ [field]="field"
24
+ (change)="ChangeFilter()"
25
+ ></th-filter>
26
+ }
27
+ <span>{{field.header}}</span>
28
+
29
+ <a *ngIf="!(!(field.type != InputTypeFile) && !(field.filter && field.disabledChange())) && !noFilters" class="order-switch h-5 flex items-center justify-center px-1 ml-2 shrink-0 cursor-pointer rounded-2xl" (click)="SwitchOrder(field)" [ngClass]="{ 'ordering-asc' : orderByProperty == field.index && ascending, 'ordering-desc' : orderByProperty == field.index && !ascending}">
30
+ <ion-icon id="up" name="arrow-up" class="-mt-1"></ion-icon>
31
+ <ion-icon id="down" name="arrow-down" class="-ml-1 -mb-1"></ion-icon>
32
+ </a>
33
+ </div>
34
+ </th>
35
+ }
36
+ }
37
+ </tr>
38
+ </thead>
39
+ <tbody>
40
+ <tr [hidden]="loading" *ngFor="let item of items">
41
+ @if(acoesTemplate){
42
+ <td class="whitespace-nowrap py-1 px-3" [style]="GetTdStyle('Acoes', item)" >
43
+ <ng-container *ngTemplateOutlet="acoesTemplate; context: { $implicit: item }"></ng-container>
44
+ </td>
45
+ }
46
+
47
+ @for (field of lstTableFields; track $index) {
48
+ @if (!field.hidden) {
49
+ <td class="px-3 py-2"
50
+ [ngClass]="GetTdClasses(field, item)"
51
+ [style]="GetTdStyle(field, item)"
52
+ (click)="Redirect(field, item)"
53
+ style="white-space: var(--ion-table-row-wrap);"
54
+ >
55
+ @if (field.index == 'ativo') {
56
+ <div class="w-full h-full flex items-center justify-start" [routerLink]="null">
57
+ <ion-toggle [checked]="item[field.index]" [disabled]="loading" (ionChange)="Ativar(item.id)" ></ion-toggle>
58
+ </div>
59
+ } @else {
60
+ @switch (field.type) {
61
+ @case ("Bool") {
62
+ @if (field.configuration.type == "toggle") {
63
+ <div class="-full h-full flex items-center justify-start">
64
+ <ion-toggle [checked]="item[field.index]" [disabled]="true"></ion-toggle>
65
+ </div>
66
+ }
67
+ @else {
68
+ <div class="-full h-full flex items-center justify-start">
69
+ <ion-checkbox [checked]="item[field.index]" [disabled]="true"></ion-checkbox>
70
+ </div>
71
+ }
72
+ }
73
+ @case ("File") {
74
+ <download-button [(ngModel)]="item[field.index]" [configuration]="field.configuration"></download-button>
75
+ }
76
+ @case ("Select") {
77
+ {{GetSelectLabel(item, field)}}
78
+ }
79
+ @default {
80
+ {{GetField(item, field)}}
81
+ }
82
+ }
83
+ }
84
+ </td>
85
+ }
86
+ }
87
+ </tr>
88
+
89
+ <ng-content select="[slot=item-end]"></ng-content>
90
+ </tbody>
91
+ </table>
92
+ </div>
93
+ @if(!noPagination){
94
+ <div class="shrink-0 mt-auto w-full">
95
+ <default-pagination
96
+ [page]="page"
97
+ (pageChange)="EmitPage($event)"
98
+ [total]="total"
99
+ [limit]="limit"
100
+ [length]="items.length"
101
+ [loading]="loading"
102
+ ></default-pagination>
103
+ </div>
104
+ }
105
+ </section>
@@ -0,0 +1,197 @@
1
+ import { Component, EventEmitter, Input, OnInit, Output, TemplateRef } from '@angular/core';
2
+ import { ActivatedRoute, Router } from '@angular/router';
3
+ import { formatNumber } from '@angular/common';
4
+
5
+ import { Comparison, CompileLstTableField } from '../../../classes/comparison/comparison';
6
+ import { InputDecimalConfiguration } from '../../../components/inputs/input-decimal/input-decimal.configuration';
7
+ import { InputSelectConfiguration } from '../../../components/inputs/input-select/input.select.configuration';
8
+ import { StorageService } from '../../../services/web/storage.service';
9
+ import { HttpService } from '../../../services/web/http.service';
10
+ import { TableField } from '../../../classes/inputs/table-field';
11
+ import { InputType } from '../../inputs/input-type';
12
+ import { Utils } from '../../../services/utils.service';
13
+
14
+ /** Componente de tabela padrão */
15
+ @Component({
16
+ selector: 'default-table',
17
+ templateUrl: './default-table.component.html',
18
+ styleUrls: ['./default-table.component.scss'],
19
+ })
20
+ export class DefaultTableComponent<T extends HttpService> implements OnInit {
21
+
22
+ /** Service a ser utilizado na listagem */
23
+ @Input('service') defaultService: T;
24
+ /** Template de ações, deve ser um elemento ```<ng-template>``` */
25
+ @Input() acoesTemplate: TemplateRef<any>;
26
+
27
+ //#region [ Pagination ]
28
+ /** Valor total de dados */
29
+ @Input() total: number;
30
+
31
+ /** Número de páginas máximo (usando two way data binding) */
32
+ @Input() limit: number;
33
+ @Output() limitChange: EventEmitter<number> = new EventEmitter<number>();
34
+
35
+ /** Valor da pagina, setado = 1 quando troca-se o valor de limite de paginas (usando two way data binding) */
36
+ @Input() page: number;
37
+ @Output() pageChange: EventEmitter<number> = new EventEmitter<number>();
38
+
39
+ /** Propriedade de ordenação (usando two way data binding) */
40
+ @Input() orderByProperty: string | null;
41
+ @Output() orderByPropertyChange: EventEmitter<string | null> = new EventEmitter<string | null>();
42
+
43
+ /** Propriedade de ordenação
44
+ * Se = true Ordenará de menor ao maior
45
+ * Se = false Ordenará de maior ao menor (usando two way data binding) */
46
+ @Input() ascending: boolean;
47
+ @Output() ascendingChange: EventEmitter<boolean> = new EventEmitter<boolean>();
48
+ //#endregion [ Pagination ]
49
+
50
+ /** Filtros (usando two way data binding) */
51
+ @Input('filter') filter: Comparison[] = [];
52
+ @Output() filterChange: EventEmitter<Comparison[]> = new EventEmitter<Comparison[]>();
53
+
54
+ /** Evento emitido quando um dos dados é ativado. Emite o id do dado */
55
+ @Output('ativar') ativarEmitter: EventEmitter<number> = new EventEmitter<number>;
56
+ @Output('refresh') refreshEmitter: EventEmitter<void> = new EventEmitter<void>();
57
+ @Input() loading: boolean;
58
+
59
+ /** Lista de dados a ser exibidos */
60
+ @Input() items: any[] = [];
61
+
62
+ /** Lista de campos a ser exibidos */
63
+ @Input() lstTableFields: TableField[] = [];
64
+
65
+ /** Remove os filtros no cabeçalho da tabela */
66
+ @Input() noFilters: boolean = false;
67
+
68
+ /** Aplica classes de CSS na coluna de acirdo com o retorno da função passada como parametro */
69
+ @Input() columnClass: ((index:string, object: any) => string) | null = null;
70
+ /** Aplica style de CSS na coluna de acirdo com o retorno da função passada como parametro */
71
+ @Input() columnStyle: ((index:string, object: any) => string) | null = null;
72
+ /** Remove a paginação da listagem */
73
+ @Input() noPagination: boolean = false;
74
+ /** Caminho de redirecionamento do item */
75
+ @Input() itemPath: string | null = "view/:id"
76
+ InputTypeFile = InputType.File
77
+
78
+ constructor(
79
+ public storageService : StorageService,
80
+ private activatedRoute: ActivatedRoute,
81
+ private router : Router,
82
+ ) { }
83
+
84
+ @Output('ItemClick') ItemClickEventEmitter: EventEmitter<any> = new EventEmitter<any>();
85
+
86
+ Redirect(field: TableField, item: any): void{
87
+ if(field.index == 'ativo'){
88
+ return;
89
+ }else
90
+ if(field.type == 'File'){
91
+ return;
92
+ }else{
93
+ if(this.itemPath){
94
+ const id = item.id;
95
+ const path = this.itemPath.replace(":id", id.toString());
96
+ this.router.navigate([`./${path}`], { relativeTo: this.activatedRoute })
97
+ }
98
+ }
99
+ this.ItemClickEventEmitter.emit(item);
100
+ }
101
+
102
+ ngOnInit() {
103
+ if(this.defaultService && this.lstTableFields.length == 0){
104
+ this.lstTableFields = this.defaultService.lstTableFields;
105
+ }
106
+ if(this.lstTableFields.length == 0){ console.warn("[ Warning! ] [ Table configuration is empty]") }
107
+
108
+ this.lstTableFields.filter(tf => tf.configuration instanceof InputSelectConfiguration).forEach(tf => tf.configuration.loader.Refresh());
109
+ }
110
+
111
+ SwitchOrder(field: TableField): void{
112
+ if(this.orderByProperty != field.index){
113
+ this.orderByProperty = field.index;
114
+ this.ascending = true;
115
+ }
116
+ else if(this.ascending){
117
+ this.ascending = false;
118
+ }
119
+ else{ this.orderByProperty = null; }
120
+
121
+ this.orderByPropertyChange.emit(this.orderByProperty)
122
+ this.ascendingChange.emit(this.ascending);
123
+
124
+ this.EmitChange();
125
+ }
126
+
127
+ EmitPage(value: number): void{
128
+ this.pageChange.emit(value);
129
+ this.EmitChange()
130
+ }
131
+
132
+ EmitChange(): void{
133
+ this.refreshEmitter.emit();
134
+ }
135
+
136
+ GetField(item: any, field : TableField): any{
137
+ const value = item[field.index];
138
+ const type = field.type;
139
+ if(['Number','Decimal','Currency'].includes(type)){
140
+ const config: InputDecimalConfiguration = (field.configuration as InputDecimalConfiguration)
141
+ return config.prefix + ' ' + formatNumber(value, "pt-BR", `1.${config.precision}-${config.precision}`) + ' ' + config.sufix;
142
+ }else
143
+ if(type == 'DateTime'){
144
+ if(!value){ return "-"; }
145
+ return Utils.DateISOToDDMMYYYYHHMM(value);
146
+ }else
147
+ if(type == 'Date'){
148
+ if(!value){ return "-"; }
149
+ return Utils.DateISOToDDMMYYYY(value);
150
+ }
151
+ return value;
152
+ }
153
+
154
+ GetSelectLabel(item: any, tField: TableField): string{
155
+ const configuration: InputSelectConfiguration = tField.configuration;
156
+ if(!configuration.multiple){
157
+ return configuration.loader.GetLabel(this.GetField(item, tField));
158
+ }else{
159
+ const values = this.GetField(item, tField);
160
+ if(values && values.length > 0){
161
+ return values.map(v => configuration.loader.GetLabel(v)).join(", ");
162
+ }else{
163
+ return "";
164
+ }
165
+ }
166
+ }
167
+
168
+ GetTypeOf(val): string{
169
+ return typeof(val)
170
+ }
171
+
172
+ Ativar(id): void{
173
+ this.ativarEmitter.emit(id);
174
+ }
175
+
176
+ ChangeFilter(): void{
177
+ this.filterChange.emit(CompileLstTableField(this.lstTableFields));
178
+ this.refreshEmitter.emit();
179
+ }
180
+
181
+ GetTdClasses(field, item): string{
182
+ var classes : string = "";
183
+ if(['DateTime', 'Time', 'Date'].includes(field.type)){
184
+ classes += 'font-mono ';
185
+ }
186
+ if(this.columnClass){
187
+ classes += this.columnClass(field.index, item);
188
+ }
189
+ return classes;
190
+ }
191
+ GetTdStyle(field, item): string{
192
+ if(this.columnStyle){
193
+ return this.columnStyle(field, item);
194
+ }
195
+ return "";
196
+ }
197
+ }
@@ -0,0 +1,61 @@
1
+ <div class="h-5 aspect-square mr-1 flex items-center justify-center cursor-pointer">
2
+ <ion-icon id="{{guid}}-trigger" name="filter-circle" class="text-xl align-sub size-full" [color]="isFilterActive ? 'secondary' : 'medium' "></ion-icon>
3
+ </div>
4
+
5
+ <ion-popover [keepContentsMounted]="true" class="popover-filter" trigger="{{guid}}-trigger" triggerAction="click">
6
+ <ng-template>
7
+ <ion-card class="m-0 !border-0 bg-primary/30">
8
+ <ion-card-header class="bg-transparent">
9
+ <ion-card-title class="text-center text-sm">
10
+ Filtro - {{field.header}}
11
+ </ion-card-title>
12
+ </ion-card-header>
13
+ <ion-card-content [ngClass]="{'!p-0': ['Select', 'Bool', 'String', 'TextArea'].includes(field.type)}" class="!p-2 bg-light rounded-t-2xl">
14
+ @switch (field.type) {
15
+ @case ('String') {
16
+ <input-string [(ngModel)]="model" class="th-select" label="" (blur)="Change()"></input-string>
17
+ }
18
+ @case ('Number') {
19
+ <div class="grid grid-cols-1 gap-2">
20
+ <input-number (change)="Change()" [(ngModel)]="modelMinimum" label="Valor Mínimo" [configuration]="field.configuration"></input-number>
21
+ <input-number (change)="Change()" [(ngModel)]="modelMaximum" label="Valor Maximo" [configuration]="field.configuration"></input-number>
22
+ </div>
23
+ }
24
+ @case ('Decimal') {
25
+ <div class="grid grid-cols-1 gap-2">
26
+ <input-decimal (change)="Change()" [(ngModel)]="modelMinimum" label="Valor Mínimo" [configuration]="field.configuration"></input-decimal>
27
+ <input-decimal (change)="Change()" [(ngModel)]="modelMaximum" label="Valor Maximo" [configuration]="field.configuration"></input-decimal>
28
+ </div>
29
+ }
30
+ @case ('Currency') {
31
+ <div class="grid grid-cols-1 gap-2">
32
+ <input-currency (change)="Change()" [(ngModel)]="modelMinimum" label="Valor Mínimo" [configuration]="field.configuration"></input-currency>
33
+ <input-currency (change)="Change()" [(ngModel)]="modelMaximum" label="Valor Maximo" [configuration]="field.configuration"></input-currency>
34
+ </div>
35
+ }
36
+ @case ('Select') {
37
+ <input-select (change)="Change()" [(ngModel)]="model" class="th-select" label="" [configuration]="configuration"></input-select>
38
+ }
39
+ @case ('TextArea') {
40
+ <input-string (change)="Change()" [(ngModel)]="model" class="th-select" label=""></input-string>
41
+ }
42
+ @case ('Bool') {
43
+ <input-select (change)="Change()" [(ngModel)]="model" class="th-select" label="" placeholder="" [configuration]="configuration"></input-select>
44
+ }
45
+ @case ('Date') {
46
+ <div class="size-full grid grid-cols-1 gap-2">
47
+ <input-date (change)="Change()" [(ngModel)]="modelMinimum" label="Data Mínima" [configuration]="configuration"></input-date>
48
+ <input-date (change)="Change()" [(ngModel)]="modelMaximum" label="Data Maxima" [configuration]="configuration"></input-date>
49
+ </div>
50
+ }
51
+ @case ('DateTime') {
52
+ <div class="grid grid-cols-1 gap-2">
53
+ <input-date-time (change)="Change()" [(ngModel)]="modelMinimum" label="Data Mínima" [configuration]="configuration"></input-date-time>
54
+ <input-date-time (change)="Change()" [(ngModel)]="modelMaximum" label="Data Maxima" [configuration]="configuration"></input-date-time>
55
+ </div>
56
+ }
57
+ }
58
+ </ion-card-content>
59
+ </ion-card>
60
+ </ng-template>
61
+ </ion-popover>