@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.
- package/build.ps1 +39 -0
- package/ng-package.json +10 -0
- package/package.json +37 -41
- package/src/lib/classes/comparison/comparison-operator.ts +17 -0
- package/src/lib/classes/comparison/comparison-value-type.ts +34 -0
- package/src/lib/classes/comparison/comparison.ts +45 -0
- package/src/lib/classes/comparison/properties/bool-property.ts +16 -0
- package/src/lib/classes/comparison/properties/date-property.ts +28 -0
- package/src/lib/classes/comparison/properties/datetime-property.ts +28 -0
- package/src/lib/classes/comparison/properties/decimal-property.ts +28 -0
- package/src/lib/classes/comparison/properties/enum-property.ts +28 -0
- package/src/lib/classes/comparison/properties/implicit-property.ts +13 -0
- package/src/lib/classes/comparison/properties/int-property.ts +28 -0
- package/src/lib/classes/comparison/properties/long-property.ts +28 -0
- package/src/lib/classes/comparison/properties/string-property.ts +16 -0
- package/src/lib/classes/comparison/properties/time-property.ts +28 -0
- package/{lib/classes/credentials.d.ts → src/lib/classes/credentials.ts} +5 -5
- package/src/lib/classes/environment.ts +35 -0
- package/src/lib/classes/filters/view-filtros.ts +18 -0
- package/src/lib/classes/infinite-scroll.ts +112 -0
- package/src/lib/classes/inputs/table-field-form-builder.ts +12 -0
- package/src/lib/classes/inputs/table-field.ts +58 -0
- package/src/lib/classes/page-option.ts +8 -0
- package/src/lib/classes/routes/default-routing-factory.ts +24 -0
- package/src/lib/classes/routes/id-preloader-configuration.ts +21 -0
- package/src/lib/classes/routes/route-data.ts +9 -0
- package/{themes → src/lib}/compiled-styles.scss +2338 -2338
- package/src/lib/components/_inputs_new/classes/input-control-base.ts +85 -0
- package/src/lib/components/_inputs_new/classes/input-provider-factory.ts +16 -0
- package/src/lib/components/_inputs_new/input-string/input-string.component.html +4 -0
- package/src/lib/components/_inputs_new/input-string/input-string.component.ts +15 -0
- package/src/lib/components/_inputs_new/inputs.module.ts +16 -0
- package/src/lib/components/carousel/carousel-image/carousel-image.component.html +4 -0
- package/src/lib/components/carousel/carousel-image/carousel-image.component.ts +15 -0
- package/src/lib/components/carousel/carousel-item/carousel-item.component.html +3 -0
- package/src/lib/components/carousel/carousel-item/carousel-item.component.ts +14 -0
- package/src/lib/components/carousel/carousel.component.html +22 -0
- package/src/lib/components/carousel/carousel.component.ts +83 -0
- package/src/lib/components/carousel/carousel.module.ts +20 -0
- package/src/lib/components/carousel/i-carousel-item.component.ts +8 -0
- package/src/lib/components/content-block/content-block.component.html +6 -0
- package/src/lib/components/content-block/content-block.component.ts +25 -0
- package/src/lib/components/default/default-list/abstract-list.ts +56 -0
- package/src/lib/components/default/default-list/default-list.component.html +60 -0
- package/src/lib/components/default/default-list/default-list.component.ts +71 -0
- package/src/lib/components/default/default-list/header-list/header-list.component.html +32 -0
- package/src/lib/components/default/default-list/header-list/header-list.component.ts +85 -0
- package/src/lib/components/default/default-list/list.ts +121 -0
- package/src/lib/components/default/default-pagination/default-pagination.component.html +52 -0
- package/src/lib/components/default/default-pagination/default-pagination.component.ts +118 -0
- package/src/lib/components/default/default-table/default-table.component.html +105 -0
- package/src/lib/components/default/default-table/default-table.component.ts +197 -0
- package/src/lib/components/default/default-table/th-filter/th-filter.component.html +61 -0
- package/src/lib/components/default/default-table/th-filter/th-filter.component.ts +178 -0
- package/src/lib/components/default/default-view/abstract-view.ts +25 -0
- package/src/lib/components/default/default-view/default-view.component.html +81 -0
- package/src/lib/components/default/default-view/default-view.component.ts +34 -0
- package/src/lib/components/default/default-view/header-view/header-view.component.html +64 -0
- package/src/lib/components/default/default-view/header-view/header-view.component.ts +54 -0
- package/src/lib/components/default/default-view/view.ts +171 -0
- package/src/lib/components/default/default.module.ts +55 -0
- package/src/lib/components/default-page/default.page.html +53 -0
- package/src/lib/components/default-page/default.page.ts +77 -0
- package/src/lib/components/drag-drop-file/drag-drop-file.directive.ts +44 -0
- package/src/lib/components/drag-drop-file/drag-drop-file.module.ts +21 -0
- package/src/lib/components/drag-drop-file/drag-drop-overlay/drag-drop-overlay.component.html +5 -0
- package/src/lib/components/drag-drop-file/drag-drop-overlay/drag-drop-overlay.component.ts +17 -0
- package/src/lib/components/drawer/default-drawer-end/default-drawer-end.component.html +12 -0
- package/src/lib/components/drawer/default-drawer-end/default-drawer-end.component.ts +35 -0
- package/src/lib/components/drawer/drawer-group/drawer-group.component.html +61 -0
- package/src/lib/components/drawer/drawer-group/drawer-group.component.ts +44 -0
- package/src/lib/components/drawer/drawer.component.html +56 -0
- package/src/lib/components/drawer/drawer.component.ts +119 -0
- package/src/lib/components/drawer/menu.ts +20 -0
- package/src/lib/components/filter/filter.component.html +31 -0
- package/src/lib/components/filter/filter.component.ts +133 -0
- package/src/lib/components/http-responses-pages/forbidden-403/forbidden-403.component.html +35 -0
- package/src/lib/components/http-responses-pages/forbidden-403/forbidden-403.component.ts +19 -0
- package/src/lib/components/image/image.component.html +17 -0
- package/src/lib/components/image/image.component.ts +95 -0
- package/src/lib/components/info-popover/info-popover.component.html +23 -0
- package/src/lib/components/info-popover/info-popover.component.ts +75 -0
- package/src/lib/components/inputs/custom-input.ts +67 -0
- package/src/lib/components/inputs/custom-signal-input.ts +70 -0
- package/src/lib/components/inputs/input-bool/input-bool.component.html +18 -0
- package/src/lib/components/inputs/input-bool/input-bool.component.ts +36 -0
- package/src/lib/components/inputs/input-bool/input-bool.configuration.ts +14 -0
- package/src/lib/components/inputs/input-color/input-color.component.html +132 -0
- package/src/lib/components/inputs/input-color/input-color.component.ts +561 -0
- package/{lib/components/inputs/input-configuration.d.ts → src/lib/components/inputs/input-configuration.ts} +18 -8
- package/src/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.html +26 -0
- package/src/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.ts +78 -0
- package/src/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.configuration.ts +4 -0
- package/src/lib/components/inputs/input-date/input-date.component.html +40 -0
- package/src/lib/components/inputs/input-date/input-date.component.ts +98 -0
- package/src/lib/components/inputs/input-date/input-date.configuration.ts +6 -0
- package/src/lib/components/inputs/input-decimal/input-decimal.component.html +24 -0
- package/src/lib/components/inputs/input-decimal/input-decimal.component.ts +296 -0
- package/src/lib/components/inputs/input-decimal/input-decimal.configuration.ts +42 -0
- package/src/lib/components/inputs/input-default-configurations.ts +15 -0
- package/src/lib/components/inputs/input-file/download-button/download-button.component.html +56 -0
- package/src/lib/components/inputs/input-file/download-button/download-button.component.ts +85 -0
- package/src/lib/components/inputs/input-file/input-file.component.html +101 -0
- package/src/lib/components/inputs/input-file/input-file.component.ts +120 -0
- package/src/lib/components/inputs/input-file/input-file.configuration.ts +8 -0
- package/src/lib/components/inputs/input-loading/input-loading.component.html +3 -0
- package/src/lib/components/inputs/input-loading/input-loading.component.ts +13 -0
- package/src/lib/components/inputs/input-provider-factory.ts +15 -0
- package/src/lib/components/inputs/input-select/ISelect.ts +26 -0
- package/src/lib/components/inputs/input-select/input-select-internal-option/input-select-internal-option.component.html +16 -0
- package/src/lib/components/inputs/input-select/input-select-internal-option/input-select-internal-option.component.ts +38 -0
- package/src/lib/components/inputs/input-select/input-select-option/input-select-option.component.html +15 -0
- package/src/lib/components/inputs/input-select/input-select-option/input-select-option.component.ts +47 -0
- package/src/lib/components/inputs/input-select/input-select-template.directive.ts +8 -0
- package/src/lib/components/inputs/input-select/input-select.component.html +66 -0
- package/src/lib/components/inputs/input-select/input-select.component.ts +323 -0
- package/src/lib/components/inputs/input-select/input.select.configuration.ts +188 -0
- package/src/lib/components/inputs/input-string/input-string.component.html +22 -0
- package/src/lib/components/inputs/input-string/input-string.component.ts +36 -0
- package/src/lib/components/inputs/input-string/input-string.configuration.ts +18 -0
- package/src/lib/components/inputs/input-textarea/input-textarea.component.html +25 -0
- package/src/lib/components/inputs/input-textarea/input-textarea.component.ts +35 -0
- package/src/lib/components/inputs/input-type.ts +16 -0
- package/src/lib/components/inputs/input-validators.ts +76 -0
- package/src/lib/components/inputs/inputs.module.ts +64 -0
- package/src/lib/components/loading/loading.component.html +28 -0
- package/src/lib/components/loading/loading.component.ts +29 -0
- package/src/lib/components/login/login-admin/login-admin.component.html +28 -0
- package/src/lib/components/login/login-admin/login-admin.component.ts +51 -0
- package/src/lib/components/login/login.component.html +104 -0
- package/src/lib/components/login/login.component.ts +97 -0
- package/src/lib/components/main-content/main-content.component.html +61 -0
- package/src/lib/components/main-content/main-content.component.ts +55 -0
- package/src/lib/components/stepper/step/step.component.html +11 -0
- package/src/lib/components/stepper/step/step.component.ts +44 -0
- package/src/lib/components/stepper/stepper.component.html +3 -0
- package/src/lib/components/stepper/stepper.component.ts +36 -0
- package/src/lib/components/stepper/stepper.module.ts +15 -0
- package/src/lib/components/tabs/tab/tab.component.html +8 -0
- package/src/lib/components/tabs/tab/tab.component.scss +0 -0
- package/src/lib/components/tabs/tab/tab.component.ts +28 -0
- package/src/lib/components/tabs/tabs/tabs.component.html +14 -0
- package/src/lib/components/tabs/tabs/tabs.component.ts +42 -0
- package/src/lib/components/tabs/tabs.module.ts +15 -0
- package/src/lib/components/text-tooltip/text-tooltip.component.html +8 -0
- package/src/lib/components/text-tooltip/text-tooltip.component.scss +0 -0
- package/src/lib/components/text-tooltip/text-tooltip.component.ts +45 -0
- package/src/lib/components/tooltip/tooltip.component.html +53 -0
- package/src/lib/components/tooltip/tooltip.component.ts +16 -0
- package/src/lib/core.module.ts +26 -0
- package/src/lib/directives/ng-var.directive.ts +26 -0
- package/src/lib/guards/auth.guard.ts +19 -0
- package/src/lib/guards/error.interceptor.ts +107 -0
- package/src/lib/guards/token.interceptor.ts +28 -0
- package/src/lib/index.ts +175 -0
- package/src/lib/pipes/secure.pipe.ts +39 -0
- package/src/lib/services/auth.service.ts +150 -0
- package/src/lib/services/crypto.service.ts +164 -0
- package/src/lib/services/environment.service.ts +17 -0
- package/src/lib/services/generics.service.ts +85 -0
- package/src/lib/services/route/route.cache.service.ts +17 -0
- package/src/lib/services/route/route.provider.service.ts +49 -0
- package/src/lib/services/usuario.service.ts +44 -0
- package/src/lib/services/utils.service.ts +161 -0
- package/src/lib/services/web/api-url-provider.service.ts +48 -0
- package/src/lib/services/web/http.ativo.service.ts +52 -0
- package/src/lib/services/web/http.service.ts +184 -0
- package/src/lib/services/web/storage.service.ts +131 -0
- package/{themes → src/lib}/styles/core.styles.scss +4 -0
- package/src/public-api.ts +5 -0
- package/tailwind.config.js +27 -0
- package/tsconfig.lib.json +29 -0
- package/tsconfig.lib.prod.json +23 -0
- package/tsconfig.spec.json +27 -0
- package/esm2022/lib/classes/comparison/comparison-operator.mjs +0 -18
- package/esm2022/lib/classes/comparison/comparison-value-type.mjs +0 -25
- package/esm2022/lib/classes/comparison/comparison.mjs +0 -41
- package/esm2022/lib/classes/comparison/properties/bool-property.mjs +0 -15
- package/esm2022/lib/classes/comparison/properties/date-property.mjs +0 -27
- package/esm2022/lib/classes/comparison/properties/datetime-property.mjs +0 -27
- package/esm2022/lib/classes/comparison/properties/decimal-property.mjs +0 -27
- package/esm2022/lib/classes/comparison/properties/enum-property.mjs +0 -27
- package/esm2022/lib/classes/comparison/properties/implicit-property.mjs +0 -12
- package/esm2022/lib/classes/comparison/properties/int-property.mjs +0 -27
- package/esm2022/lib/classes/comparison/properties/long-property.mjs +0 -27
- package/esm2022/lib/classes/comparison/properties/string-property.mjs +0 -15
- package/esm2022/lib/classes/comparison/properties/time-property.mjs +0 -27
- package/esm2022/lib/classes/credentials.mjs +0 -2
- package/esm2022/lib/classes/environment.mjs +0 -32
- package/esm2022/lib/classes/filters/view-filtros.mjs +0 -18
- package/esm2022/lib/classes/infinite-scroll.mjs +0 -90
- package/esm2022/lib/classes/inputs/table-field-form-builder.mjs +0 -10
- package/esm2022/lib/classes/inputs/table-field.mjs +0 -69
- package/esm2022/lib/classes/page-option.mjs +0 -2
- package/esm2022/lib/classes/routes/default-routing-factory.mjs +0 -23
- package/esm2022/lib/classes/routes/id-preloader-configuration.mjs +0 -22
- package/esm2022/lib/classes/routes/route-data.mjs +0 -9
- package/esm2022/lib/components/carousel/carousel-image/carousel-image.component.mjs +0 -18
- package/esm2022/lib/components/carousel/carousel-item/carousel-item.component.mjs +0 -15
- package/esm2022/lib/components/carousel/carousel.component.mjs +0 -79
- package/esm2022/lib/components/carousel/carousel.module.mjs +0 -31
- package/esm2022/lib/components/carousel/i-carousel-item.component.mjs +0 -16
- package/esm2022/lib/components/content-block/content-block.component.mjs +0 -27
- package/esm2022/lib/components/default/default-list/abstract-list.mjs +0 -49
- package/esm2022/lib/components/default/default-list/default-list.component.mjs +0 -99
- package/esm2022/lib/components/default/default-list/header-list/header-list.component.mjs +0 -98
- package/esm2022/lib/components/default/default-list/list.mjs +0 -110
- package/esm2022/lib/components/default/default-pagination/default-pagination.component.mjs +0 -123
- package/esm2022/lib/components/default/default-table/default-table.component.mjs +0 -222
- package/esm2022/lib/components/default/default-table/th-filter/th-filter.component.mjs +0 -186
- package/esm2022/lib/components/default/default-view/abstract-view.mjs +0 -22
- package/esm2022/lib/components/default/default-view/default-view.component.mjs +0 -51
- package/esm2022/lib/components/default/default-view/header-view/header-view.component.mjs +0 -75
- package/esm2022/lib/components/default/default-view/view.mjs +0 -175
- package/esm2022/lib/components/default/default.module.mjs +0 -87
- package/esm2022/lib/components/default-page/default.page.mjs +0 -73
- package/esm2022/lib/components/drag-drop-file/drag-drop-file.directive.mjs +0 -60
- package/esm2022/lib/components/drag-drop-file/drag-drop-file.module.mjs +0 -31
- package/esm2022/lib/components/drag-drop-file/drag-drop-overlay/drag-drop-overlay.component.mjs +0 -15
- package/esm2022/lib/components/drawer/default-drawer-end/default-drawer-end.component.mjs +0 -34
- package/esm2022/lib/components/drawer/drawer-group/drawer-group.component.mjs +0 -49
- package/esm2022/lib/components/drawer/drawer.component.mjs +0 -117
- package/esm2022/lib/components/drawer/menu.mjs +0 -15
- package/esm2022/lib/components/filter/filter.component.mjs +0 -127
- package/esm2022/lib/components/http-responses-pages/forbidden-403/forbidden-403.component.mjs +0 -17
- package/esm2022/lib/components/image/image.component.mjs +0 -91
- package/esm2022/lib/components/info-popover/info-popover.component.mjs +0 -91
- package/esm2022/lib/components/inputs/custom-input.mjs +0 -77
- package/esm2022/lib/components/inputs/custom-signal-input.mjs +0 -74
- package/esm2022/lib/components/inputs/input-bool/input-bool.component.mjs +0 -43
- package/esm2022/lib/components/inputs/input-bool/input-bool.configuration.mjs +0 -16
- package/esm2022/lib/components/inputs/input-color/input-color.component.mjs +0 -487
- package/esm2022/lib/components/inputs/input-configuration.mjs +0 -2
- package/esm2022/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.mjs +0 -93
- package/esm2022/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.configuration.mjs +0 -6
- package/esm2022/lib/components/inputs/input-date/input-date.component.mjs +0 -122
- package/esm2022/lib/components/inputs/input-date/input-date.configuration.mjs +0 -8
- package/esm2022/lib/components/inputs/input-decimal/input-decimal.component.mjs +0 -269
- package/esm2022/lib/components/inputs/input-decimal/input-decimal.configuration.mjs +0 -45
- package/esm2022/lib/components/inputs/input-default-configurations.mjs +0 -14
- package/esm2022/lib/components/inputs/input-file/download-button/download-button.component.mjs +0 -94
- package/esm2022/lib/components/inputs/input-file/input-file.component.mjs +0 -131
- package/esm2022/lib/components/inputs/input-file/input-file.configuration.mjs +0 -11
- package/esm2022/lib/components/inputs/input-loading/input-loading.component.mjs +0 -16
- package/esm2022/lib/components/inputs/input-provider-factory.mjs +0 -15
- package/esm2022/lib/components/inputs/input-select/ISelect.mjs +0 -11
- package/esm2022/lib/components/inputs/input-select/input-select-internal-option/input-select-internal-option.component.mjs +0 -42
- package/esm2022/lib/components/inputs/input-select/input-select-option/input-select-option.component.mjs +0 -46
- package/esm2022/lib/components/inputs/input-select/input-select-template.directive.mjs +0 -16
- package/esm2022/lib/components/inputs/input-select/input-select.component.mjs +0 -322
- package/esm2022/lib/components/inputs/input-select/input.select.configuration.mjs +0 -164
- package/esm2022/lib/components/inputs/input-string/input-string.component.mjs +0 -50
- package/esm2022/lib/components/inputs/input-string/input-string.configuration.mjs +0 -18
- package/esm2022/lib/components/inputs/input-textarea/input-textarea.component.mjs +0 -47
- package/esm2022/lib/components/inputs/input-type.mjs +0 -18
- package/esm2022/lib/components/inputs/input-validators.mjs +0 -90
- package/esm2022/lib/components/inputs/inputs.module.mjs +0 -105
- package/esm2022/lib/components/loading/loading.component.mjs +0 -34
- package/esm2022/lib/components/login/login-admin/login-admin.component.mjs +0 -52
- package/esm2022/lib/components/login/login.component.mjs +0 -102
- package/esm2022/lib/components/main-content/main-content.component.mjs +0 -62
- package/esm2022/lib/components/stepper/step/step.component.mjs +0 -43
- package/esm2022/lib/components/stepper/stepper.component.mjs +0 -36
- package/esm2022/lib/components/stepper/stepper.module.mjs +0 -25
- package/esm2022/lib/components/tabs/tab/tab.component.mjs +0 -41
- package/esm2022/lib/components/tabs/tabs/tabs.component.mjs +0 -56
- package/esm2022/lib/components/tabs/tabs.module.mjs +0 -22
- package/esm2022/lib/components/text-tooltip/text-tooltip.component.mjs +0 -51
- package/esm2022/lib/components/tooltip/tooltip.component.mjs +0 -21
- package/esm2022/lib/core.module.mjs +0 -29
- package/esm2022/lib/directives/ng-var.directive.mjs +0 -29
- package/esm2022/lib/guards/auth.guard.mjs +0 -26
- package/esm2022/lib/guards/error.interceptor.mjs +0 -106
- package/esm2022/lib/guards/token.interceptor.mjs +0 -25
- package/esm2022/lib/index.mjs +0 -173
- package/esm2022/lib/pipes/secure.pipe.mjs +0 -42
- package/esm2022/lib/services/auth.service.mjs +0 -146
- package/esm2022/lib/services/environment.service.mjs +0 -26
- package/esm2022/lib/services/generics.service.mjs +0 -84
- package/esm2022/lib/services/route/route.cache.service.mjs +0 -15
- package/esm2022/lib/services/route/route.provider.service.mjs +0 -42
- package/esm2022/lib/services/usuario.service.mjs +0 -49
- package/esm2022/lib/services/utils.service.mjs +0 -149
- package/esm2022/lib/services/web/api-url-provider.service.mjs +0 -29
- package/esm2022/lib/services/web/http.ativo.service.mjs +0 -55
- package/esm2022/lib/services/web/http.service.mjs +0 -169
- package/esm2022/lib/services/web/storage.service.mjs +0 -128
- package/esm2022/public-api.mjs +0 -5
- package/esm2022/sapphire-ion-framework.mjs +0 -5
- package/fesm2022/sapphire-ion-framework.mjs +0 -6240
- package/fesm2022/sapphire-ion-framework.mjs.map +0 -1
- package/index.d.ts +0 -5
- package/lib/classes/comparison/comparison-operator.d.ts +0 -9
- package/lib/classes/comparison/comparison-value-type.d.ts +0 -23
- package/lib/classes/comparison/comparison.d.ts +0 -25
- package/lib/classes/comparison/properties/bool-property.d.ts +0 -7
- package/lib/classes/comparison/properties/date-property.d.ts +0 -11
- package/lib/classes/comparison/properties/datetime-property.d.ts +0 -11
- package/lib/classes/comparison/properties/decimal-property.d.ts +0 -11
- package/lib/classes/comparison/properties/enum-property.d.ts +0 -11
- package/lib/classes/comparison/properties/implicit-property.d.ts +0 -6
- package/lib/classes/comparison/properties/int-property.d.ts +0 -11
- package/lib/classes/comparison/properties/long-property.d.ts +0 -11
- package/lib/classes/comparison/properties/string-property.d.ts +0 -7
- package/lib/classes/comparison/properties/time-property.d.ts +0 -11
- package/lib/classes/environment.d.ts +0 -13
- package/lib/classes/filters/view-filtros.d.ts +0 -10
- package/lib/classes/infinite-scroll.d.ts +0 -26
- package/lib/classes/inputs/table-field-form-builder.d.ts +0 -5
- package/lib/classes/inputs/table-field.d.ts +0 -20
- package/lib/classes/page-option.d.ts +0 -7
- package/lib/classes/routes/default-routing-factory.d.ts +0 -8
- package/lib/classes/routes/id-preloader-configuration.d.ts +0 -28
- package/lib/classes/routes/route-data.d.ts +0 -5
- package/lib/components/carousel/carousel-image/carousel-image.component.d.ts +0 -10
- package/lib/components/carousel/carousel-item/carousel-item.component.d.ts +0 -9
- package/lib/components/carousel/carousel.component.d.ts +0 -32
- package/lib/components/carousel/carousel.module.d.ts +0 -12
- package/lib/components/carousel/i-carousel-item.component.d.ts +0 -9
- package/lib/components/content-block/content-block.component.d.ts +0 -15
- package/lib/components/default/default-list/abstract-list.d.ts +0 -21
- package/lib/components/default/default-list/default-list.component.d.ts +0 -44
- package/lib/components/default/default-list/header-list/header-list.component.d.ts +0 -45
- package/lib/components/default/default-list/list.d.ts +0 -38
- package/lib/components/default/default-pagination/default-pagination.component.d.ts +0 -36
- package/lib/components/default/default-table/default-table.component.d.ts +0 -72
- package/lib/components/default/default-table/th-filter/th-filter.component.d.ts +0 -20
- package/lib/components/default/default-view/abstract-view.d.ts +0 -18
- package/lib/components/default/default-view/default-view.component.d.ts +0 -26
- package/lib/components/default/default-view/header-view/header-view.component.d.ts +0 -26
- package/lib/components/default/default-view/view.d.ts +0 -56
- package/lib/components/default/default.module.d.ts +0 -28
- package/lib/components/default-page/default.page.d.ts +0 -35
- package/lib/components/drag-drop-file/drag-drop-file.directive.d.ts +0 -14
- package/lib/components/drag-drop-file/drag-drop-file.module.d.ts +0 -10
- package/lib/components/drag-drop-file/drag-drop-overlay/drag-drop-overlay.component.d.ts +0 -9
- package/lib/components/drawer/default-drawer-end/default-drawer-end.component.d.ts +0 -13
- package/lib/components/drawer/drawer-group/drawer-group.component.d.ts +0 -22
- package/lib/components/drawer/drawer.component.d.ts +0 -23
- package/lib/components/drawer/menu.d.ts +0 -9
- package/lib/components/filter/filter.component.d.ts +0 -29
- package/lib/components/http-responses-pages/forbidden-403/forbidden-403.component.d.ts +0 -8
- package/lib/components/image/image.component.d.ts +0 -23
- package/lib/components/info-popover/info-popover.component.d.ts +0 -15
- package/lib/components/inputs/custom-input.d.ts +0 -36
- package/lib/components/inputs/custom-signal-input.d.ts +0 -38
- package/lib/components/inputs/input-bool/input-bool.component.d.ts +0 -19
- package/lib/components/inputs/input-bool/input-bool.configuration.d.ts +0 -17
- package/lib/components/inputs/input-color/input-color.component.d.ts +0 -80
- package/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.d.ts +0 -24
- package/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.configuration.d.ts +0 -5
- package/lib/components/inputs/input-date/input-date.component.d.ts +0 -30
- package/lib/components/inputs/input-date/input-date.configuration.d.ts +0 -7
- package/lib/components/inputs/input-decimal/input-decimal.component.d.ts +0 -41
- package/lib/components/inputs/input-decimal/input-decimal.configuration.d.ts +0 -25
- package/lib/components/inputs/input-default-configurations.d.ts +0 -13
- package/lib/components/inputs/input-file/download-button/download-button.component.d.ts +0 -37
- package/lib/components/inputs/input-file/input-file.component.d.ts +0 -39
- package/lib/components/inputs/input-file/input-file.configuration.d.ts +0 -11
- package/lib/components/inputs/input-loading/input-loading.component.d.ts +0 -7
- package/lib/components/inputs/input-provider-factory.d.ts +0 -4
- package/lib/components/inputs/input-select/ISelect.d.ts +0 -21
- package/lib/components/inputs/input-select/input-select-internal-option/input-select-internal-option.component.d.ts +0 -18
- package/lib/components/inputs/input-select/input-select-option/input-select-option.component.d.ts +0 -24
- package/lib/components/inputs/input-select/input-select-template.directive.d.ts +0 -8
- package/lib/components/inputs/input-select/input-select.component.d.ts +0 -66
- package/lib/components/inputs/input-select/input.select.configuration.d.ts +0 -87
- package/lib/components/inputs/input-string/input-string.component.d.ts +0 -19
- package/lib/components/inputs/input-string/input-string.configuration.d.ts +0 -14
- package/lib/components/inputs/input-textarea/input-textarea.component.d.ts +0 -18
- package/lib/components/inputs/input-type.d.ts +0 -16
- package/lib/components/inputs/input-validators.d.ts +0 -19
- package/lib/components/inputs/inputs.module.d.ts +0 -29
- package/lib/components/loading/loading.component.d.ts +0 -18
- package/lib/components/login/login-admin/login-admin.component.d.ts +0 -20
- package/lib/components/login/login.component.d.ts +0 -29
- package/lib/components/main-content/main-content.component.d.ts +0 -17
- package/lib/components/stepper/step/step.component.d.ts +0 -15
- package/lib/components/stepper/stepper.component.d.ts +0 -17
- package/lib/components/stepper/stepper.module.d.ts +0 -10
- package/lib/components/tabs/tab/tab.component.d.ts +0 -19
- package/lib/components/tabs/tabs/tabs.component.d.ts +0 -18
- package/lib/components/tabs/tabs.module.d.ts +0 -12
- package/lib/components/text-tooltip/text-tooltip.component.d.ts +0 -16
- package/lib/components/tooltip/tooltip.component.d.ts +0 -7
- package/lib/core.module.d.ts +0 -11
- package/lib/directives/ng-var.directive.d.ts +0 -12
- package/lib/guards/auth.guard.d.ts +0 -11
- package/lib/guards/error.interceptor.d.ts +0 -32
- package/lib/guards/token.interceptor.d.ts +0 -11
- package/lib/index.d.ts +0 -109
- package/lib/pipes/secure.pipe.d.ts +0 -15
- package/lib/services/auth.service.d.ts +0 -47
- package/lib/services/environment.service.d.ts +0 -10
- package/lib/services/generics.service.d.ts +0 -22
- package/lib/services/route/route.cache.service.d.ts +0 -7
- package/lib/services/route/route.provider.service.d.ts +0 -13
- package/lib/services/usuario.service.d.ts +0 -21
- package/lib/services/utils.service.d.ts +0 -36
- package/lib/services/web/api-url-provider.service.d.ts +0 -13
- package/lib/services/web/http.ativo.service.d.ts +0 -31
- package/lib/services/web/http.service.d.ts +0 -50
- package/lib/services/web/storage.service.d.ts +0 -25
- package/public-api.d.ts +0 -1
- /package/{themes → src/lib}/components/_inputs_new/input-string/input-string.component.scss +0 -0
- /package/{themes → src/lib}/components/_inputs_new/inputs.scss +0 -0
- /package/{themes → src/lib}/components/carousel/carousel-image/carousel-image.component.scss +0 -0
- /package/{themes → src/lib}/components/carousel/carousel-item/carousel-item.component.scss +0 -0
- /package/{themes → src/lib}/components/carousel/carousel.component.scss +0 -0
- /package/{themes → src/lib}/components/content-block/content-block.component.scss +0 -0
- /package/{themes → src/lib}/components/default/default-list/default-list.component.scss +0 -0
- /package/{themes → src/lib}/components/default/default-list/header-list/header-list.component.scss +0 -0
- /package/{themes → src/lib}/components/default/default-pagination/default-pagination.component.scss +0 -0
- /package/{themes → src/lib}/components/default/default-table/default-table.component.scss +0 -0
- /package/{themes → src/lib}/components/default/default-table/th-filter/th-filter.component.scss +0 -0
- /package/{themes → src/lib}/components/default/default-view/default-view.component.scss +0 -0
- /package/{themes → src/lib}/components/default/default-view/header-view/header-view.component.scss +0 -0
- /package/{themes → src/lib}/components/default-page/default.page.scss +0 -0
- /package/{themes → src/lib}/components/drag-drop-file/drag-drop-overlay/drag-drop-overlay.component.scss +0 -0
- /package/{themes → src/lib}/components/drawer/default-drawer-end/default-drawer-end.component.scss +0 -0
- /package/{themes → src/lib}/components/drawer/drawer-group/drawer-group.component.scss +0 -0
- /package/{themes → src/lib}/components/drawer/drawer.component.scss +0 -0
- /package/{themes → src/lib}/components/filter/filter.component.scss +0 -0
- /package/{themes → src/lib}/components/http-responses-pages/forbidden-403/forbidden-403.component.scss +0 -0
- /package/{themes → src/lib}/components/image/image.component.scss +0 -0
- /package/{themes → src/lib}/components/info-popover/info-popover.component.scss +0 -0
- /package/{themes → src/lib}/components/inputs/input-bool/input-bool.component.scss +0 -0
- /package/{themes → src/lib}/components/inputs/input-color/input-color.component.scss +0 -0
- /package/{themes/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.scss → src/lib/components/inputs/input-color/input-color.configuration.ts} +0 -0
- /package/{themes/components/inputs/input-loading/input-loading.component.scss → src/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.scss} +0 -0
- /package/{themes → src/lib}/components/inputs/input-date/input-date.component.scss +0 -0
- /package/{themes → src/lib}/components/inputs/input-decimal/input-decimal.component.scss +0 -0
- /package/{themes → src/lib}/components/inputs/input-file/download-button/download-button.component.scss +0 -0
- /package/{themes → src/lib}/components/inputs/input-file/input-file.component.scss +0 -0
- /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
- /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
- /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
- /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
- /package/{themes → src/lib}/components/inputs/input-select/input-select.component.scss +0 -0
- /package/{themes/components/loading/loading.component.scss → src/lib/components/inputs/input-string/input-string.component.scss} +0 -0
- /package/{themes/components/stepper/stepper.component.scss → src/lib/components/inputs/input-textarea/input-textarea.component.scss} +0 -0
- /package/{themes → src/lib}/components/inputs/inputs.scss +0 -0
- /package/{themes/components/tabs/tab/tab.component.scss → src/lib/components/loading/loading.component.scss} +0 -0
- /package/{themes → src/lib}/components/login/login-admin/login-admin.component.scss +0 -0
- /package/{themes → src/lib}/components/login/login.component.scss +0 -0
- /package/{themes → src/lib}/components/main-content/main-content.component.scss +0 -0
- /package/{themes → src/lib}/components/stepper/step/step.component.scss +0 -0
- /package/{themes/components/text-tooltip/text-tooltip.component.scss → src/lib/components/stepper/stepper.component.scss} +0 -0
- /package/{themes → src/lib}/components/tabs/tabs/tabs.component.scss +0 -0
- /package/{themes → src/lib}/components/tooltip/tooltip.component.scss +0 -0
- /package/{themes → src/lib}/styles/components.scss +0 -0
- /package/{themes → src/lib}/styles/ionic/ion-action-sheet.scss +0 -0
- /package/{themes → src/lib}/styles/ionic/ion-alert.scss +0 -0
- /package/{themes → src/lib}/styles/ionic/ion-button.scss +0 -0
- /package/{themes → src/lib}/styles/ionic/ion-card.scss +0 -0
- /package/{themes → src/lib}/styles/ionic/ion-content.scss +0 -0
- /package/{themes → src/lib}/styles/ionic/ion-datetime.scss +0 -0
- /package/{themes → src/lib}/styles/ionic/ion-item.scss +0 -0
- /package/{themes → src/lib}/styles/ionic/ion-list.scss +0 -0
- /package/{themes → src/lib}/styles/ionic/ion-modal.scss +0 -0
- /package/{themes → src/lib}/styles/ionic/ion-popover.scss +0 -0
- /package/{themes → src/lib}/styles/ionic/ion-progress-bar.scss +0 -0
- /package/{themes → src/lib}/styles/ionic/ion-searchbar.scss +0 -0
- /package/{themes → src/lib}/styles/ionic/ion-toast.scss +0 -0
- /package/{themes → src/lib}/styles/ionic.scss +0 -0
- /package/{themes → src/lib}/styles/login-default.scss +0 -0
- /package/{themes → src/lib}/styles/mixins.scss +0 -0
- /package/{themes → src/lib}/styles/styles.scss +0 -0
- /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
|
|
7
|
+
<ion-skeleton-text *ngIf="loading" [animated]="true" style="width: 2ch"></ion-skeleton-text>
|
|
8
|
+
<b *ngIf="!loading">{{limit * page - limit + length}}</b>
|
|
9
|
+
de
|
|
10
|
+
@if (total != null) {
|
|
11
|
+
<b> {{total}} </b> items
|
|
12
|
+
}
|
|
13
|
+
@else{
|
|
14
|
+
<b> - </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>
|