@sapphire-ion/framework 1.2.62 → 1.3.1
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 +43 -47
- 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 +37 -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 +62 -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/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 +72 -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 +127 -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 +104 -0
- package/src/lib/components/default/default-table/default-table.component.ts +255 -0
- package/src/lib/components/default/default-table/th-filter/th-filter.component.html +69 -0
- package/src/lib/components/default/default-table/th-filter/th-filter.component.ts +205 -0
- package/src/lib/components/default/default-view/abstract-view.ts +25 -0
- package/src/lib/components/default/default-view/default-view.component.html +111 -0
- package/src/lib/components/default/default-view/default-view.component.ts +56 -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 +62 -0
- package/src/lib/components/default/default-view/view.ts +195 -0
- package/src/lib/components/default/default.module.ts +61 -0
- package/src/lib/components/default-page/default.page.html +63 -0
- package/src/lib/components/default-page/default.page.ts +84 -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 +79 -0
- package/src/lib/components/drawer/drawer-group/drawer-group.component.ts +49 -0
- package/src/lib/components/drawer/drawer.component.html +120 -0
- package/src/lib/components/drawer/drawer.component.ts +157 -0
- package/src/lib/components/drawer/menu.ts +20 -0
- package/src/lib/components/filter/filter.component.html +43 -0
- package/src/lib/components/filter/filter.component.ts +141 -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 +94 -0
- package/src/lib/components/inputs/input-bool/input-bool.component.html +26 -0
- package/src/lib/components/inputs/input-bool/input-bool.component.ts +39 -0
- package/src/lib/components/inputs/input-bool/input-bool.configuration.ts +14 -0
- package/src/lib/components/inputs/input-cep/input-cep.component.html +27 -0
- package/src/lib/components/inputs/input-cep/input-cep.component.ts +41 -0
- package/src/lib/components/inputs/input-cep/input-cep.configuration.ts +4 -0
- package/src/lib/components/inputs/input-color/input-color.component.html +79 -0
- package/src/lib/components/inputs/input-color/input-color.component.ts +544 -0
- package/{lib/components/inputs/input-configuration.d.ts → src/lib/components/inputs/input-configuration.ts} +23 -10
- package/src/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.html +28 -0
- package/src/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.ts +99 -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 +89 -0
- package/src/lib/components/inputs/input-date/input-date.component.ts +269 -0
- package/src/lib/components/inputs/input-date/input-date.configuration.ts +8 -0
- package/src/lib/components/inputs/input-decimal/input-decimal.component.html +32 -0
- package/src/lib/components/inputs/input-decimal/input-decimal.component.ts +283 -0
- package/src/lib/components/inputs/input-decimal/input-decimal.configuration.ts +47 -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 +91 -0
- package/src/lib/components/inputs/input-file/input-file.component.html +56 -0
- package/src/lib/components/inputs/input-file/input-file.component.ts +97 -0
- package/src/lib/components/inputs/input-file/input-file.configuration.ts +25 -0
- package/src/lib/components/inputs/input-icon/fluenticons.ts +3733 -0
- package/src/lib/components/inputs/input-icon/input-icon.component.html +8 -0
- package/src/lib/components/inputs/input-icon/input-icon.component.ts +52 -0
- package/src/lib/components/inputs/input-icon/ionicons.ts +1359 -0
- package/src/lib/components/inputs/input-provider-factory.ts +12 -0
- package/src/lib/components/inputs/input-select/directives/sion-label-template.directive.ts +19 -0
- package/src/lib/components/inputs/input-select/directives/sion-option-template.directive.ts +16 -0
- package/src/lib/components/inputs/input-select/directives/sion-placeholder-template.directive.ts +19 -0
- package/src/lib/components/inputs/input-select/input-select.component.html +176 -0
- package/src/lib/components/inputs/input-select/input-select.component.ts +366 -0
- package/src/lib/components/inputs/input-select/input.select.configuration.ts +300 -0
- package/src/lib/components/inputs/input-string/input-string.component.html +27 -0
- package/src/lib/components/inputs/input-string/input-string.component.ts +31 -0
- package/src/lib/components/inputs/input-string/input-string.configuration.ts +20 -0
- package/src/lib/components/inputs/input-telefone/input-telefone.component.html +29 -0
- package/src/lib/components/inputs/input-telefone/input-telefone.component.ts +63 -0
- package/src/lib/components/inputs/input-telefone/input-telefone.configuration.ts +8 -0
- package/src/lib/components/inputs/input-textarea/input-textarea.component.html +27 -0
- package/src/lib/components/inputs/input-textarea/input-textarea.component.ts +75 -0
- package/src/lib/components/inputs/input-textarea/input-textarea.configuration.ts +7 -0
- package/src/lib/components/inputs/input-type.ts +22 -0
- package/src/lib/components/inputs/input-validators.ts +111 -0
- package/src/lib/components/inputs/inputs.module.ts +74 -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 +96 -0
- package/src/lib/components/main-content/main-content.component.html +145 -0
- package/src/lib/components/main-content/main-content.component.ts +93 -0
- package/src/lib/components/popover/sion-popover/sion-popover.component.html +21 -0
- package/src/lib/components/popover/sion-popover/sion-popover.component.ts +182 -0
- package/src/lib/components/popover/sion-popover.module.ts +12 -0
- package/src/lib/components/sion-card/sion-card.component.html +12 -0
- package/src/lib/components/sion-card/sion-card.component.ts +23 -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 +37 -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.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 +29 -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 +108 -0
- package/src/lib/guards/token.interceptor.ts +28 -0
- package/src/lib/index.ts +191 -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/generic.service.ts +85 -0
- package/src/lib/services/modal-focus-trap.service.ts +65 -0
- package/src/lib/services/navigation-context.service.ts +121 -0
- package/src/lib/services/popover-focus-trap.service.ts +65 -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 +216 -0
- package/src/lib/services/web/api-url-provider.service.ts +48 -0
- package/src/lib/services/web/http.ativo.service.ts +37 -0
- package/src/lib/services/web/http.service.ts +206 -0
- package/src/lib/services/web/storage.service.ts +210 -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 -34
- 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 -79
- 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 -95
- 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 -120
- 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 -216
- package/esm2022/lib/components/default/default-table/th-filter/th-filter.component.mjs +0 -212
- package/esm2022/lib/components/default/default-view/abstract-view.mjs +0 -22
- package/esm2022/lib/components/default/default-view/default-view.component.mjs +0 -76
- package/esm2022/lib/components/default/default-view/header-view/header-view.component.mjs +0 -78
- package/esm2022/lib/components/default/default-view/view.mjs +0 -198
- package/esm2022/lib/components/default/default.module.mjs +0 -98
- package/esm2022/lib/components/default-page/default.page.mjs +0 -75
- 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 -52
- package/esm2022/lib/components/drawer/drawer.component.mjs +0 -156
- package/esm2022/lib/components/drawer/menu.mjs +0 -15
- package/esm2022/lib/components/filter/filter.component.mjs +0 -145
- 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 -85
- package/esm2022/lib/components/inputs/input-bool/input-bool.component.mjs +0 -46
- package/esm2022/lib/components/inputs/input-bool/input-bool.configuration.mjs +0 -16
- package/esm2022/lib/components/inputs/input-cep/input-cep.component.mjs +0 -50
- package/esm2022/lib/components/inputs/input-cep/input-cep.configuration.mjs +0 -4
- package/esm2022/lib/components/inputs/input-color/input-color.component.mjs +0 -481
- package/esm2022/lib/components/inputs/input-configuration.mjs +0 -2
- package/esm2022/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.mjs +0 -116
- 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 -263
- package/esm2022/lib/components/inputs/input-date/input-date.configuration.mjs +0 -11
- package/esm2022/lib/components/inputs/input-decimal/input-decimal.component.mjs +0 -276
- package/esm2022/lib/components/inputs/input-decimal/input-decimal.configuration.mjs +0 -50
- 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 -102
- package/esm2022/lib/components/inputs/input-file/input-file.component.mjs +0 -100
- package/esm2022/lib/components/inputs/input-file/input-file.configuration.mjs +0 -24
- package/esm2022/lib/components/inputs/input-icon/fluenticons.mjs +0 -3734
- package/esm2022/lib/components/inputs/input-icon/input-icon.component.mjs +0 -60
- package/esm2022/lib/components/inputs/input-icon/ionicons.mjs +0 -1360
- package/esm2022/lib/components/inputs/input-provider-factory.mjs +0 -12
- package/esm2022/lib/components/inputs/input-select/directives/sion-label-template.directive.mjs +0 -16
- package/esm2022/lib/components/inputs/input-select/directives/sion-option-template.directive.mjs +0 -16
- package/esm2022/lib/components/inputs/input-select/directives/sion-placeholder-template.directive.mjs +0 -16
- package/esm2022/lib/components/inputs/input-select/input-select.component.mjs +0 -376
- package/esm2022/lib/components/inputs/input-select/input.select.configuration.mjs +0 -233
- package/esm2022/lib/components/inputs/input-string/input-string.component.mjs +0 -41
- package/esm2022/lib/components/inputs/input-string/input-string.configuration.mjs +0 -20
- package/esm2022/lib/components/inputs/input-telefone/input-telefone.component.mjs +0 -74
- package/esm2022/lib/components/inputs/input-telefone/input-telefone.configuration.mjs +0 -12
- package/esm2022/lib/components/inputs/input-textarea/input-textarea.component.mjs +0 -82
- package/esm2022/lib/components/inputs/input-textarea/input-textarea.configuration.mjs +0 -7
- package/esm2022/lib/components/inputs/input-type.mjs +0 -24
- package/esm2022/lib/components/inputs/input-validators.mjs +0 -121
- package/esm2022/lib/components/inputs/inputs.module.mjs +0 -133
- 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 -99
- package/esm2022/lib/components/main-content/main-content.component.mjs +0 -100
- package/esm2022/lib/components/popover/sion-popover/sion-popover.component.mjs +0 -182
- package/esm2022/lib/components/popover/sion-popover.module.mjs +0 -21
- package/esm2022/lib/components/sion-card/sion-card.component.mjs +0 -26
- 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 -38
- 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 -107
- package/esm2022/lib/guards/token.interceptor.mjs +0 -25
- package/esm2022/lib/index.mjs +0 -188
- 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/generic.service.mjs +0 -84
- package/esm2022/lib/services/modal-focus-trap.service.mjs +0 -62
- package/esm2022/lib/services/navigation-context.service.mjs +0 -112
- package/esm2022/lib/services/popover-focus-trap.service.mjs +0 -62
- 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 -190
- package/esm2022/lib/services/web/api-url-provider.service.mjs +0 -29
- package/esm2022/lib/services/web/http.ativo.service.mjs +0 -37
- package/esm2022/lib/services/web/http.service.mjs +0 -183
- package/esm2022/lib/services/web/storage.service.mjs +0 -186
- package/esm2022/public-api.mjs +0 -5
- package/esm2022/sapphire-ion-framework.mjs +0 -5
- package/fesm2022/sapphire-ion-framework.mjs +0 -12488
- 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 -14
- 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 -47
- 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 -40
- 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 -90
- package/lib/components/default/default-table/th-filter/th-filter.component.d.ts +0 -23
- package/lib/components/default/default-view/abstract-view.d.ts +0 -18
- package/lib/components/default/default-view/default-view.component.d.ts +0 -40
- package/lib/components/default/default-view/header-view/header-view.component.d.ts +0 -36
- package/lib/components/default/default-view/view.d.ts +0 -67
- package/lib/components/default/default.module.d.ts +0 -31
- 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 -31
- 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 -40
- package/lib/components/inputs/input-bool/input-bool.component.d.ts +0 -16
- package/lib/components/inputs/input-bool/input-bool.configuration.d.ts +0 -17
- package/lib/components/inputs/input-cep/input-cep.component.d.ts +0 -18
- package/lib/components/inputs/input-cep/input-cep.configuration.d.ts +0 -3
- package/lib/components/inputs/input-color/input-color.component.d.ts +0 -77
- package/lib/components/inputs/input-cpf-cnpj/input-cpf-cnpj.component.d.ts +0 -19
- 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 -61
- package/lib/components/inputs/input-date/input-date.configuration.d.ts +0 -11
- package/lib/components/inputs/input-decimal/input-decimal.component.d.ts +0 -27
- package/lib/components/inputs/input-decimal/input-decimal.configuration.d.ts +0 -28
- 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 -40
- package/lib/components/inputs/input-file/input-file.component.d.ts +0 -28
- package/lib/components/inputs/input-file/input-file.configuration.d.ts +0 -8
- package/lib/components/inputs/input-icon/fluenticons.d.ts +0 -1
- package/lib/components/inputs/input-icon/input-icon.component.d.ts +0 -20
- package/lib/components/inputs/input-icon/ionicons.d.ts +0 -1
- package/lib/components/inputs/input-provider-factory.d.ts +0 -4
- package/lib/components/inputs/input-select/directives/sion-label-template.directive.d.ts +0 -18
- package/lib/components/inputs/input-select/directives/sion-option-template.directive.d.ts +0 -14
- package/lib/components/inputs/input-select/directives/sion-placeholder-template.directive.d.ts +0 -18
- package/lib/components/inputs/input-select/input-select.component.d.ts +0 -83
- package/lib/components/inputs/input-select/input.select.configuration.d.ts +0 -127
- package/lib/components/inputs/input-string/input-string.component.d.ts +0 -14
- package/lib/components/inputs/input-string/input-string.configuration.d.ts +0 -15
- package/lib/components/inputs/input-telefone/input-telefone.component.d.ts +0 -19
- package/lib/components/inputs/input-telefone/input-telefone.configuration.d.ts +0 -9
- package/lib/components/inputs/input-textarea/input-textarea.component.d.ts +0 -17
- package/lib/components/inputs/input-textarea/input-textarea.configuration.d.ts +0 -4
- package/lib/components/inputs/input-type.d.ts +0 -22
- package/lib/components/inputs/input-validators.d.ts +0 -25
- package/lib/components/inputs/inputs.module.d.ts +0 -33
- 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 -27
- package/lib/components/popover/sion-popover/sion-popover.component.d.ts +0 -43
- package/lib/components/popover/sion-popover.module.d.ts +0 -9
- package/lib/components/sion-card/sion-card.component.d.ts +0 -11
- package/lib/components/stepper/step/step.component.d.ts +0 -15
- package/lib/components/stepper/stepper.component.d.ts +0 -14
- 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 -16
- 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 -118
- 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/generic.service.d.ts +0 -22
- package/lib/services/modal-focus-trap.service.d.ts +0 -13
- package/lib/services/navigation-context.service.d.ts +0 -14
- package/lib/services/popover-focus-trap.service.d.ts +0 -13
- 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 -53
- package/lib/services/web/api-url-provider.service.d.ts +0 -13
- package/lib/services/web/http.ativo.service.d.ts +0 -20
- package/lib/services/web/http.service.d.ts +0 -59
- package/lib/services/web/storage.service.d.ts +0 -46
- package/public-api.d.ts +0 -1
- /package/{themes → src/lib}/compiled-styles.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-cep/input-cep.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-icon/input-icon.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-string/input-string.component.scss → src/lib/components/inputs/input-icon/input-icon.component.scss} +0 -0
- /package/{themes → src/lib}/components/inputs/input-select/input-select.component.scss +0 -0
- /package/{themes/components/inputs/input-telefone/input-telefone.component.scss → src/lib/components/inputs/input-string/input-string.component.scss} +0 -0
- /package/{themes/components/loading/loading.component.scss → src/lib/components/inputs/input-telefone/input-telefone.component.scss} +0 -0
- /package/{themes → 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/sion-card/sion-card.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/popover/sion-popover/sion-popover.component.scss +0 -0
- /package/{themes/components/stepper/stepper.component.scss → src/lib/components/sion-card/sion-card.component.scss} +0 -0
- /package/{themes → src/lib}/components/stepper/step/step.component.scss +0 -0
- /package/{themes/components/tabs/tab/tab.component.scss → src/lib/components/stepper/stepper.component.scss} +0 -0
- /package/{themes/components/text-tooltip/text-tooltip.component.scss → src/lib/components/tabs/tab/tab.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/core.styles.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,56 @@
|
|
|
1
|
+
import { FormBuilder } from '@angular/forms';
|
|
2
|
+
import { Component, ElementRef, Input, OnInit } from '@angular/core';
|
|
3
|
+
import { ActivatedRoute, UrlTree } from '@angular/router';
|
|
4
|
+
import { NavController } from '@ionic/angular';
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
import { HttpServiceAtivo } from '../../../services/web/http.ativo.service';
|
|
8
|
+
import { HttpService } from '../../../services/web/http.service';
|
|
9
|
+
import { GenericService } from '../../../services/generic.service';
|
|
10
|
+
import { View } from './view';
|
|
11
|
+
import { InputType } from '../../inputs/input-type';
|
|
12
|
+
|
|
13
|
+
/** Componente View Padão */
|
|
14
|
+
@Component({
|
|
15
|
+
selector: 'default-view',
|
|
16
|
+
templateUrl: './default-view.component.html',
|
|
17
|
+
styleUrls: ['./default-view.component.scss'],
|
|
18
|
+
})
|
|
19
|
+
export class DefaultViewComponent<T extends HttpService | HttpServiceAtivo> extends View<T> implements OnInit {
|
|
20
|
+
|
|
21
|
+
/** Remove o botão de voltar */
|
|
22
|
+
@Input() noBack: boolean = false;
|
|
23
|
+
/** Remove o botão NOVO da listagem */
|
|
24
|
+
@Input() noNew : boolean = false;
|
|
25
|
+
/** Remove os breadcrumbs da listagem */
|
|
26
|
+
@Input() noBreadcrumbs: boolean = false;
|
|
27
|
+
/** Habilita/Desabilita o focus no primeiro campo da view
|
|
28
|
+
* 1 - para ativar no novo e no editar
|
|
29
|
+
* 2 - para ativar apenas no novo
|
|
30
|
+
* 3 - para desativar para os dois casos
|
|
31
|
+
* [Padrão 2]
|
|
32
|
+
*/
|
|
33
|
+
@Input() focusInFirstField: number = 2;
|
|
34
|
+
|
|
35
|
+
InputType = InputType;
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
/**
|
|
40
|
+
* Rota para voltar, caso não seja definida, o componente irá tentar usar rota do ionic
|
|
41
|
+
*/
|
|
42
|
+
@Input() backRouterLink: string | any[] | UrlTree | undefined = undefined;
|
|
43
|
+
|
|
44
|
+
constructor(
|
|
45
|
+
public override fb: FormBuilder,
|
|
46
|
+
public override elementRef: ElementRef,
|
|
47
|
+
public override activatedRoute: ActivatedRoute,
|
|
48
|
+
public override genericService: GenericService,
|
|
49
|
+
public override navController: NavController,
|
|
50
|
+
) { super(); }
|
|
51
|
+
|
|
52
|
+
override async ngOnInit() {
|
|
53
|
+
this.startInFirstField = this.focusInFirstField;
|
|
54
|
+
await super.ngOnInit()
|
|
55
|
+
}
|
|
56
|
+
}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
<div class="w-full h-7 flex">
|
|
2
|
+
<div class="w-1/2 flex items-center justify-start gap-3">
|
|
3
|
+
@if(!noBack){
|
|
4
|
+
@if(useDefaultRouting || backRouterLink){
|
|
5
|
+
<ion-button class="m-0" fill="clear" size="small" [routerLink]="backRouterLink ? backRouterLink : DefaultBackRoute">
|
|
6
|
+
<ion-icon class="text-[1.7rem]" name="chevron-back" slot="icon-only"></ion-icon>
|
|
7
|
+
<ion-text class="text-base">Voltar</ion-text>
|
|
8
|
+
</ion-button>
|
|
9
|
+
}
|
|
10
|
+
@else{
|
|
11
|
+
<ion-back-button style="--min-height: 100%;" [disabled]="loading" text="Voltar" [defaultHref]="DefaultBackRoute"></ion-back-button>
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
<!-- <ion-card button [disabled]="loading" class="h-full w-12 m-0 default-transition" style="border-color: var(--ion-color-primary)">
|
|
15
|
+
<ion-card-content class="p-0 bg-transparent">
|
|
16
|
+
@if(!useDefaultRouting){
|
|
17
|
+
<ion-back-button class="scale-75 size-full" style="--min-height: 100%;" text="" [defaultHref]="BackRoute" >
|
|
18
|
+
</ion-back-button>
|
|
19
|
+
}@else {
|
|
20
|
+
<ion-button class="size-full" size="small" fill="clear" [routerLink]="BackRoute">
|
|
21
|
+
<ion-icon name="chevron-back" slot="icon-only"></ion-icon>
|
|
22
|
+
</ion-button>
|
|
23
|
+
}
|
|
24
|
+
</ion-card-content>
|
|
25
|
+
</ion-card> -->
|
|
26
|
+
}
|
|
27
|
+
@if(!noBack){
|
|
28
|
+
<div class="h-full border-r-2 border-r-primary border-solid mask-y/50"></div>
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
<div class="relative">
|
|
32
|
+
<ion-button class="-mx-2" [disabled]="loading" fill="clear" size="small" (click)="Save()">
|
|
33
|
+
<ion-icon class="text-base" slot="start" name="save"></ion-icon>
|
|
34
|
+
<ion-text class="text-base">
|
|
35
|
+
Salvar
|
|
36
|
+
</ion-text>
|
|
37
|
+
</ion-button>
|
|
38
|
+
|
|
39
|
+
<div class="absolute w-[125%] h-[125%] -top-[12.5%] -left-[12.5%] flex flex-col items-center justify-center default-transition backdrop-blur-sm" [ngClass]="{'opacity-0 -translate-y-8': !loading}">
|
|
40
|
+
<ion-text color="success" class="text-sm mt-1"><b>
|
|
41
|
+
@if(progress){
|
|
42
|
+
{{(progress * 100) | number: '1.1-1'}}%
|
|
43
|
+
}@else {
|
|
44
|
+
{{0 | number: '1.1-1'}}%
|
|
45
|
+
}
|
|
46
|
+
</b></ion-text>
|
|
47
|
+
<ion-progress-bar [value]="progress" color="success" class="w-full default-transition"></ion-progress-bar>
|
|
48
|
+
</div>
|
|
49
|
+
</div>
|
|
50
|
+
<ng-content select="[slot=start]"></ng-content>
|
|
51
|
+
</div>
|
|
52
|
+
<div class="w-1/2 flex justify-end items-center gap-2">
|
|
53
|
+
<ng-content select="[slot=end]"></ng-content>
|
|
54
|
+
|
|
55
|
+
@if(!(noNew || novo)){
|
|
56
|
+
<ion-button #new [routerLink]="['../']" class="m-0" fill="clear" size="small">
|
|
57
|
+
<ion-icon class="text-base" name="add" slot="start"></ion-icon>
|
|
58
|
+
<ion-text class="text-base">
|
|
59
|
+
Novo
|
|
60
|
+
</ion-text>
|
|
61
|
+
</ion-button>
|
|
62
|
+
}
|
|
63
|
+
</div>
|
|
64
|
+
</div>
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { Component, ElementRef, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { IonBackButton, NavController } from '@ionic/angular';
|
|
3
|
+
import { ActivatedRoute, UrlTree } from '@angular/router';
|
|
4
|
+
import { NavigationContextService } from '../../../../services/navigation-context.service';
|
|
5
|
+
|
|
6
|
+
@Component({
|
|
7
|
+
selector: 'header-view',
|
|
8
|
+
templateUrl: './header-view.component.html',
|
|
9
|
+
styleUrls: ['./header-view.component.scss'],
|
|
10
|
+
})
|
|
11
|
+
export class HeaderViewComponent implements OnInit {
|
|
12
|
+
|
|
13
|
+
@Input() novo: boolean = false;
|
|
14
|
+
@Input() loading: boolean;
|
|
15
|
+
@Input() progress: number | null = null;
|
|
16
|
+
|
|
17
|
+
@Output('save') saveEmitter: EventEmitter<void> = new EventEmitter<void>();
|
|
18
|
+
|
|
19
|
+
/** Habilita/Desabilita o focus no primeiro campo da view */
|
|
20
|
+
@Input() focusInFirstField: boolean = false;
|
|
21
|
+
/** Remove o botão de volta */
|
|
22
|
+
@Input() noBack: boolean = false;
|
|
23
|
+
/** Remove o botão de Novo */
|
|
24
|
+
@Input() noNew : boolean = false;
|
|
25
|
+
/** Parâmetro usado em telas dentro de telas, para que o retorno sempre seja a tela anterior */
|
|
26
|
+
@Input() useDefaultRouting: boolean = false;
|
|
27
|
+
/**
|
|
28
|
+
* Rota para voltar, caso não seja definida, o componente irá tentar usar rota do ionic
|
|
29
|
+
*/
|
|
30
|
+
@Input() backRouterLink: string | any[] | UrlTree | undefined = undefined;
|
|
31
|
+
|
|
32
|
+
constructor(
|
|
33
|
+
private navController: NavController,
|
|
34
|
+
private activatedRoute: ActivatedRoute,
|
|
35
|
+
private navContext : NavigationContextService
|
|
36
|
+
) { }
|
|
37
|
+
|
|
38
|
+
ngOnInit() {}
|
|
39
|
+
|
|
40
|
+
protected get DefaultBackRoute(): string {
|
|
41
|
+
return this.navContext.getBackRoute() ?? '/';
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
@ViewChild(IonBackButton) IonBackButtonElement: IonBackButton;
|
|
45
|
+
public Back($event = null){
|
|
46
|
+
this.IonBackButtonElement.onClick($event)
|
|
47
|
+
}
|
|
48
|
+
@ViewChild('new') NewIonButtonElement: ElementRef;
|
|
49
|
+
public New(){
|
|
50
|
+
if(!this.novo){
|
|
51
|
+
this.navController.navigateForward(['../'], {
|
|
52
|
+
relativeTo: this.activatedRoute,
|
|
53
|
+
replaceUrl: true
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
Save(): void{
|
|
59
|
+
this.saveEmitter.emit();
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
}
|
|
@@ -0,0 +1,195 @@
|
|
|
1
|
+
import { Component, ElementRef, EventEmitter, HostListener, inject, Input, OnInit, Output, QueryList, ViewChild, viewChild, ViewChildren } from "@angular/core";
|
|
2
|
+
import { FormBuilder, FormGroup } from "@angular/forms";
|
|
3
|
+
import { ActivatedRoute } from "@angular/router";
|
|
4
|
+
|
|
5
|
+
import { HttpService } from "../../../services/web/http.service";
|
|
6
|
+
import { HttpServiceAtivo } from "../../../services/web/http.ativo.service";
|
|
7
|
+
import { GenericService } from "../../../services/generic.service";
|
|
8
|
+
import { TableFieldFormBuilder } from "../../../classes/inputs/table-field-form-builder";
|
|
9
|
+
import { NavController } from "@ionic/angular";
|
|
10
|
+
import { firstValueFrom, lastValueFrom } from "rxjs";
|
|
11
|
+
import { HeaderViewComponent } from "./header-view/header-view.component";
|
|
12
|
+
import { TableField } from "../../../classes/inputs/table-field";
|
|
13
|
+
import { RouteData } from "../../../classes/routes/route-data";
|
|
14
|
+
import { CustomInput } from "../../inputs/custom-input";
|
|
15
|
+
import { Timeout } from "../../../services/utils.service";
|
|
16
|
+
import { NavigationContextService } from '../../../services/navigation-context.service';
|
|
17
|
+
|
|
18
|
+
@Component({ template: '', styles: '' })
|
|
19
|
+
export abstract class View<T extends HttpService | HttpServiceAtivo> implements OnInit {
|
|
20
|
+
/** Id do dado a ser carregado */
|
|
21
|
+
@Input() id : number | null = null;
|
|
22
|
+
@Input() loading : boolean = false;
|
|
23
|
+
@Input() submitted: boolean = false;
|
|
24
|
+
/** Progresso de salvamento */
|
|
25
|
+
@Input() progress : number;
|
|
26
|
+
/** Service a ser utlizado na view */
|
|
27
|
+
@Input() service : T;
|
|
28
|
+
/** Habilita/Desabilita o focus no primeiro campo da view
|
|
29
|
+
* 1 - para ativar no novo e no editar
|
|
30
|
+
* 2 - para ativar apenas no novo
|
|
31
|
+
* 3 - para desativar para os dois casos
|
|
32
|
+
*/
|
|
33
|
+
@Input() startInFirstField : number = 2;
|
|
34
|
+
|
|
35
|
+
protected genericService: GenericService;
|
|
36
|
+
protected activatedRoute: ActivatedRoute;
|
|
37
|
+
protected elementRef: ElementRef;
|
|
38
|
+
protected fb: FormBuilder;
|
|
39
|
+
protected navContext : NavigationContextService
|
|
40
|
+
protected nested: boolean = false;
|
|
41
|
+
|
|
42
|
+
constructor(){
|
|
43
|
+
this.genericService = inject(GenericService)
|
|
44
|
+
this.activatedRoute = inject(ActivatedRoute)
|
|
45
|
+
this.elementRef = inject(ElementRef)
|
|
46
|
+
this.fb = inject(FormBuilder)
|
|
47
|
+
this.navContext = inject(NavigationContextService)
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
/** Lista de TableFields a serem invocados de acordo com sua configuração.
|
|
51
|
+
* Automaticamente preenchido com service.lstTableFieldsView ou service.lstTableFields quando não informado
|
|
52
|
+
*/
|
|
53
|
+
@Input() lstTableFields: TableField[] = [];
|
|
54
|
+
@Input() public redirectPath: string | null = "/view/:id"
|
|
55
|
+
|
|
56
|
+
|
|
57
|
+
@ViewChild('.wrapper') Wrapper: HTMLElement;
|
|
58
|
+
async ngOnInit() {
|
|
59
|
+
if(this.lstTableFields.length == 0){
|
|
60
|
+
if(this.service.lstTableFieldsView.length != 0){
|
|
61
|
+
this.lstTableFields = this.service.lstTableFieldsView;
|
|
62
|
+
}else{
|
|
63
|
+
this.lstTableFields = this.service.lstTableFields;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
if(this.id == null){
|
|
68
|
+
this.id = this.genericService.GetId(this.activatedRoute, 0);
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
if(!this.service){ console.warn("[ View service is not valid! ]"); }
|
|
72
|
+
if (instanceOfViewWillCreateForm(this)) { this.OnViewWillCreateForm() }
|
|
73
|
+
await this.CreateForm();
|
|
74
|
+
if (instanceOfViewDidCreateForm(this)) { this.OnViewDidCreateForm() }
|
|
75
|
+
|
|
76
|
+
if(this.elementRef && this.elementRef.nativeElement && this.elementRef.nativeElement.parentElement){
|
|
77
|
+
this.nested = (this.elementRef.nativeElement.parentElement.tagName as string).toUpperCase() != "ION-CONTENT";
|
|
78
|
+
}else{
|
|
79
|
+
this.nested = true;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
await this.Refresh();
|
|
83
|
+
|
|
84
|
+
if(this.startInFirstField == 1){
|
|
85
|
+
await this.FocusOnFirstField();
|
|
86
|
+
}else if (this.startInFirstField == 2){
|
|
87
|
+
if(!this.id){
|
|
88
|
+
await this.FocusOnFirstField();
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
@ViewChildren(CustomInput) lstCustomInputs: QueryList<CustomInput<any>>;
|
|
95
|
+
async FocusOnFirstField(): Promise<void> {
|
|
96
|
+
try{
|
|
97
|
+
await Timeout(100);
|
|
98
|
+
this.lstCustomInputs.first.setFocus(null);
|
|
99
|
+
}catch{}
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
@Output('ViewDidRefresh') ViewDidRefreshEmitter: EventEmitter<void> = new EventEmitter<void>();
|
|
103
|
+
async Refresh() {
|
|
104
|
+
this.loading = true;
|
|
105
|
+
try{
|
|
106
|
+
await this.Load();
|
|
107
|
+
}finally{ }
|
|
108
|
+
this.loading = false;
|
|
109
|
+
this.ViewDidRefreshEmitter.emit();
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
async Load(): Promise<void>{
|
|
113
|
+
if(!this.id){ return; }
|
|
114
|
+
const res = await firstValueFrom(this.service.Get(this.id));
|
|
115
|
+
this.frm.patchValue(res);
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
frm: FormGroup;
|
|
119
|
+
async CreateForm() {
|
|
120
|
+
this.frm = TableFieldFormBuilder.create(this.lstTableFields, this.fb);
|
|
121
|
+
await this.LoadIdComparison();
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
async LoadIdComparison(): Promise<void> {
|
|
125
|
+
try{
|
|
126
|
+
const data: RouteData = await firstValueFrom(this.activatedRoute.data) as RouteData;
|
|
127
|
+
if(!data){ return; }
|
|
128
|
+
const id = this.genericService.GetId(this.activatedRoute, data.idPreloaderConfiguration.routeDepth);
|
|
129
|
+
|
|
130
|
+
if(!id){ return; }
|
|
131
|
+
|
|
132
|
+
this.frm.controls[data.idPreloaderConfiguration.propertyName].setValue(id);
|
|
133
|
+
this.lstTableFields.find(p => p.index == data.idPreloaderConfiguration.propertyName).disabled = true;
|
|
134
|
+
}catch{ }
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
/** Emite o id da entidade salva apos o salvamento */
|
|
138
|
+
@Output('Save') SaveEmitter: EventEmitter<number> = new EventEmitter<number>();
|
|
139
|
+
async Save() {
|
|
140
|
+
await lastValueFrom(this.service.Save(this.frm, this));
|
|
141
|
+
this.SaveEmitter.emit(this.id);
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
public get BackRoute(){
|
|
145
|
+
return this.navContext.getBackRoute() ?? '/';
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
public GetCurrentRouting(): ActivatedRoute { return this.activatedRoute; }
|
|
149
|
+
|
|
150
|
+
protected navController: NavController;
|
|
151
|
+
|
|
152
|
+
protected NavigateToList(): void {
|
|
153
|
+
const back = this.navContext.getBackRoute() ?? '/';
|
|
154
|
+
this.navController.navigateBack(back);
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
|
|
158
|
+
@ViewChild(HeaderViewComponent) HeaderViewComponentElement: HeaderViewComponent;
|
|
159
|
+
|
|
160
|
+
@HostListener('window:keydown',['$event'])
|
|
161
|
+
onKeyPress($event: KeyboardEvent) {
|
|
162
|
+
if(!(this.elementRef.nativeElement.contains(document.activeElement) || document.activeElement == this.elementRef.nativeElement)){
|
|
163
|
+
return;
|
|
164
|
+
}
|
|
165
|
+
if($event.key == 'Escape'){
|
|
166
|
+
this.HeaderViewComponentElement.Back($event);
|
|
167
|
+
$event.preventDefault();
|
|
168
|
+
return;
|
|
169
|
+
}
|
|
170
|
+
if(($event.ctrlKey || $event.metaKey) && ($event.key == 'Enter')){
|
|
171
|
+
this.Save();
|
|
172
|
+
$event.preventDefault();
|
|
173
|
+
return;
|
|
174
|
+
}
|
|
175
|
+
if($event.altKey && $event.key == 'Insert'){
|
|
176
|
+
this.HeaderViewComponentElement.New();
|
|
177
|
+
$event.preventDefault();
|
|
178
|
+
return;
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
export interface ViewWillCreateForm{
|
|
184
|
+
OnViewWillCreateForm(): void | any;
|
|
185
|
+
}
|
|
186
|
+
function instanceOfViewWillCreateForm(object: any): object is ViewWillCreateForm {
|
|
187
|
+
return 'OnViewWillCreateForm' in object;
|
|
188
|
+
}
|
|
189
|
+
export interface ViewDidCreateForm {
|
|
190
|
+
OnViewDidCreateForm(): void | any;
|
|
191
|
+
}
|
|
192
|
+
function instanceOfViewDidCreateForm(object: any): object is ViewDidCreateForm {
|
|
193
|
+
return 'OnViewDidCreateForm' in object;
|
|
194
|
+
}
|
|
195
|
+
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
4
|
+
import { IonicModule } from '@ionic/angular';
|
|
5
|
+
import { RouterLink, RouterLinkWithHref, RouterModule, RouterOutlet } from '@angular/router';
|
|
6
|
+
|
|
7
|
+
import { NgVarDirective } from '../../directives/ng-var.directive';
|
|
8
|
+
import { InputsModule } from '../inputs/inputs.module';
|
|
9
|
+
|
|
10
|
+
import { LoadingComponent } from '../loading/loading.component';
|
|
11
|
+
import { DefaultListComponent } from './default-list/default-list.component';
|
|
12
|
+
import { DefaultViewComponent } from './default-view/default-view.component';
|
|
13
|
+
import { HeaderListComponent } from './default-list/header-list/header-list.component';
|
|
14
|
+
import { HeaderViewComponent } from './default-view/header-view/header-view.component';
|
|
15
|
+
import { DefaultTableComponent } from './default-table/default-table.component';
|
|
16
|
+
import { DefaultPaginationComponent } from './default-pagination/default-pagination.component';
|
|
17
|
+
import { ThFilterComponent } from './default-table/th-filter/th-filter.component';
|
|
18
|
+
import { SIonPopoverModule } from '../popover/sion-popover.module';
|
|
19
|
+
import { ContentBlockComponent } from '../content-block/content-block.component';
|
|
20
|
+
import { CdkDragPlaceholder } from "@angular/cdk/drag-drop";
|
|
21
|
+
|
|
22
|
+
const lstComponents = [
|
|
23
|
+
HeaderListComponent,
|
|
24
|
+
DefaultListComponent,
|
|
25
|
+
|
|
26
|
+
DefaultViewComponent,
|
|
27
|
+
HeaderViewComponent,
|
|
28
|
+
DefaultTableComponent,
|
|
29
|
+
DefaultPaginationComponent,
|
|
30
|
+
ThFilterComponent
|
|
31
|
+
]
|
|
32
|
+
|
|
33
|
+
/** Modulo parão, inclui os seguiintes componentes:
|
|
34
|
+
* - HeaderListComponent,
|
|
35
|
+
- DefaultListComponent,
|
|
36
|
+
- DefaultViewComponent,
|
|
37
|
+
- HeaderViewComponent,
|
|
38
|
+
- DefaultTableComponent,
|
|
39
|
+
- DefaultPaginationComponent,
|
|
40
|
+
*/
|
|
41
|
+
@NgModule({
|
|
42
|
+
declarations: [...lstComponents],
|
|
43
|
+
exports : [...lstComponents],
|
|
44
|
+
imports: [
|
|
45
|
+
IonicModule,
|
|
46
|
+
CommonModule,
|
|
47
|
+
InputsModule,
|
|
48
|
+
ReactiveFormsModule,
|
|
49
|
+
RouterLinkWithHref,
|
|
50
|
+
FormsModule,
|
|
51
|
+
RouterModule,
|
|
52
|
+
RouterOutlet,
|
|
53
|
+
RouterLink,
|
|
54
|
+
LoadingComponent,
|
|
55
|
+
NgVarDirective,
|
|
56
|
+
SIonPopoverModule,
|
|
57
|
+
ContentBlockComponent,
|
|
58
|
+
CdkDragPlaceholder
|
|
59
|
+
]
|
|
60
|
+
})
|
|
61
|
+
export class DefaultModule { }
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
<ion-content [fullscreen]="true">
|
|
2
|
+
<div class="wrapper">
|
|
3
|
+
<ion-breadcrumbs>
|
|
4
|
+
<ion-breadcrumb [routerLink]="[null]">
|
|
5
|
+
<ion-icon slot="start" name="home"></ion-icon> Inicio
|
|
6
|
+
</ion-breadcrumb>
|
|
7
|
+
</ion-breadcrumbs>
|
|
8
|
+
|
|
9
|
+
<ion-card>
|
|
10
|
+
<ion-card-content class="flex flex-col items-center justify-center !p-6">
|
|
11
|
+
<div class="w-full shrink-0 text-center">
|
|
12
|
+
@if(lstImage){
|
|
13
|
+
@for (item of lstImage; track $index) {
|
|
14
|
+
<ion-img [class]="item.classes" [src]="item.src" (ion-error)="lstImage"></ion-img>
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
@else {
|
|
18
|
+
<ion-text class="text-8xl font-poppins w-full"> {{title}} </ion-text>
|
|
19
|
+
}
|
|
20
|
+
</div>
|
|
21
|
+
|
|
22
|
+
<div class="overflow-hidden p-2 w-full relative">
|
|
23
|
+
<loading [type]="3" [loading]="loading"></loading>
|
|
24
|
+
<div class="size-full flex flex-wrap portrait:!grid gap-2">
|
|
25
|
+
@for (item of lstMenu; track item; let i = $index) {
|
|
26
|
+
@if(item.type == "Menu"){
|
|
27
|
+
<ion-button fill="outline" class="grow min-w-fit" [routerLink]="[item.route]">
|
|
28
|
+
<ion-icon slot="start" [name]="item.icon"></ion-icon>
|
|
29
|
+
{{useTranslation ? (TranslationModule.Permissao + item.id | translate) : item.title}}
|
|
30
|
+
</ion-button>
|
|
31
|
+
}
|
|
32
|
+
@if(item.type == "MenuGroup"){
|
|
33
|
+
<ion-button fill="outline" class="grow min-w-fit" (click)="popover.present($event)">
|
|
34
|
+
<ion-icon slot="start" [name]="item.icon"></ion-icon>
|
|
35
|
+
{{useTranslation ? (TranslationModule.PermissaoGrupo + item.id | translate) : item.title}}
|
|
36
|
+
</ion-button>
|
|
37
|
+
|
|
38
|
+
<ion-popover #popover class="overflow-y-auto" [dismissOnSelect]="true" triggerAction="click">
|
|
39
|
+
<ng-template>
|
|
40
|
+
<ion-list class="no-outer-border">
|
|
41
|
+
<ion-item class="bg-transparent" (click)="SetTitle(menu)" *ngFor="let menu of item.lstMenu" [routerLink]="['./' + menu.route]" lines="none" detail="false" routerLinkActive="selected">
|
|
42
|
+
<ion-icon [name]="menu.icon" slot="start"></ion-icon>
|
|
43
|
+
<ion-label>
|
|
44
|
+
{{useTranslation ? (TranslationModule.Permissao + menu.id | translate) : menu.title}}
|
|
45
|
+
</ion-label>
|
|
46
|
+
</ion-item>
|
|
47
|
+
</ion-list>
|
|
48
|
+
</ng-template>
|
|
49
|
+
</ion-popover>
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
</div>
|
|
53
|
+
</div>
|
|
54
|
+
|
|
55
|
+
<!-- <div class="!overflow-y-auto w-full portrait:grow relative">
|
|
56
|
+
<loading [type]="3" [loading]="loading"></loading>
|
|
57
|
+
<div class="flex flex-wrap items-start justify-start mt-4 portrait:!grid portrait:!grid-cols-1">
|
|
58
|
+
</div>
|
|
59
|
+
</div> -->
|
|
60
|
+
</ion-card-content>
|
|
61
|
+
</ion-card>
|
|
62
|
+
</div>
|
|
63
|
+
</ion-content>
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { ActivatedRoute, RouterLinkWithHref } from '@angular/router';
|
|
2
|
+
import { Component, OnInit } from '@angular/core';
|
|
3
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
4
|
+
import { firstValueFrom } from 'rxjs';
|
|
5
|
+
import { CommonModule } from '@angular/common';
|
|
6
|
+
import { IonicModule } from '@ionic/angular';
|
|
7
|
+
import { FormsModule } from '@angular/forms';
|
|
8
|
+
|
|
9
|
+
import { RouteProviderService } from '../../services/route/route.provider.service';
|
|
10
|
+
import { EnvironmentService } from '../../services/environment.service';
|
|
11
|
+
import { LoadingComponent } from '../loading/loading.component';
|
|
12
|
+
import { GenericService } from '../../services/generic.service';
|
|
13
|
+
import { InputsModule } from '../inputs/inputs.module';
|
|
14
|
+
import { Menu } from '../drawer/menu';
|
|
15
|
+
|
|
16
|
+
/** Pagina Default - mostra os botões de rotas horizontalmente - componente padrão */
|
|
17
|
+
@Component({
|
|
18
|
+
standalone: true,
|
|
19
|
+
selector: 'app-default',
|
|
20
|
+
imports: [
|
|
21
|
+
CommonModule,
|
|
22
|
+
FormsModule,
|
|
23
|
+
IonicModule,
|
|
24
|
+
InputsModule,
|
|
25
|
+
RouterLinkWithHref,
|
|
26
|
+
LoadingComponent,
|
|
27
|
+
TranslateModule,
|
|
28
|
+
],
|
|
29
|
+
templateUrl: './default.page.html',
|
|
30
|
+
styleUrls: ['./default.page.scss'],
|
|
31
|
+
})
|
|
32
|
+
export class DefaultPage implements OnInit {
|
|
33
|
+
|
|
34
|
+
useTranslation: boolean = false;
|
|
35
|
+
TranslationModule: any = {
|
|
36
|
+
Permissao : 'Entities.Permissao.',
|
|
37
|
+
PermissaoGrupo: 'Entities.PermissaoGrupo.'
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
constructor(
|
|
41
|
+
private route: ActivatedRoute,
|
|
42
|
+
private coreService: EnvironmentService,
|
|
43
|
+
private genericService: GenericService,
|
|
44
|
+
private routeProviderService: RouteProviderService
|
|
45
|
+
) {
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
title: string = this.coreService.environment.applicationName;
|
|
49
|
+
loading: boolean;
|
|
50
|
+
lstMenu: Menu[] = [];
|
|
51
|
+
|
|
52
|
+
lstImage: DefaultPageImage[] = null;
|
|
53
|
+
|
|
54
|
+
async ngOnInit(): Promise<void> {
|
|
55
|
+
this.loading = true;
|
|
56
|
+
|
|
57
|
+
const conf = await firstValueFrom(this.route.data) as DefaultPageConfiguration;
|
|
58
|
+
|
|
59
|
+
this.lstImage = Array.isArray(conf.image) ? conf.image :
|
|
60
|
+
conf.image ? [conf.image] : undefined;
|
|
61
|
+
|
|
62
|
+
this.lstMenu = await firstValueFrom(this.routeProviderService.GetData());
|
|
63
|
+
this.loading = false;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
SetTitle(item: Menu){
|
|
67
|
+
this.genericService.SetTitle(item.title);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
export class DefaultPageConfiguration{
|
|
72
|
+
constructor(
|
|
73
|
+
public image: DefaultPageImage | DefaultPageImage[] | null = null,
|
|
74
|
+
public useTranslation: boolean = false
|
|
75
|
+
){
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
export class DefaultPageImage {
|
|
80
|
+
constructor(
|
|
81
|
+
public src: string | null = null,
|
|
82
|
+
public classes: string = ''
|
|
83
|
+
){}
|
|
84
|
+
}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { ContentChild, Directive, ViewChild } from '@angular/core';
|
|
2
|
+
import { Output, EventEmitter, HostBinding, HostListener } from '@angular/core';
|
|
3
|
+
import { DragDropOverlayComponent } from './drag-drop-overlay/drag-drop-overlay.component';
|
|
4
|
+
|
|
5
|
+
@Directive({
|
|
6
|
+
selector: '[DragDropFile]'
|
|
7
|
+
})
|
|
8
|
+
export class DragDropFileDirective {
|
|
9
|
+
|
|
10
|
+
constructor() { }
|
|
11
|
+
|
|
12
|
+
@HostBinding('class.fileOver') fileOver: boolean;
|
|
13
|
+
@Output() fileDropped = new EventEmitter<File[]>();
|
|
14
|
+
|
|
15
|
+
@ContentChild(DragDropOverlayComponent) dragDropOverlay: DragDropOverlayComponent
|
|
16
|
+
|
|
17
|
+
// Dragover listener
|
|
18
|
+
@HostListener('dragover', ['$event']) onDragOver(evt: DragEvent) {
|
|
19
|
+
evt.preventDefault();
|
|
20
|
+
evt.stopPropagation();
|
|
21
|
+
this.fileOver = true;
|
|
22
|
+
this.dragDropOverlay.fileOver = true;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
// Dragleave listener
|
|
26
|
+
@HostListener('dragleave', ['$event']) public onDragLeave(evt: DragEvent) {
|
|
27
|
+
evt.preventDefault();
|
|
28
|
+
evt.stopPropagation();
|
|
29
|
+
this.fileOver = false;
|
|
30
|
+
this.dragDropOverlay.fileOver = false;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
// Drop listener
|
|
34
|
+
@HostListener('drop', ['$event']) public onDrop(evt: DragEvent) {
|
|
35
|
+
evt.preventDefault();
|
|
36
|
+
evt.stopPropagation();
|
|
37
|
+
this.fileOver = false;
|
|
38
|
+
this.dragDropOverlay.fileOver = false;
|
|
39
|
+
let files = evt.dataTransfer.files;
|
|
40
|
+
if (files.length > 0) {
|
|
41
|
+
this.fileDropped.emit(Array.from(files));
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { DragDropFileDirective } from './drag-drop-file.directive';
|
|
4
|
+
import { DragDropOverlayComponent } from './drag-drop-overlay/drag-drop-overlay.component';
|
|
5
|
+
import { IonicModule } from '@ionic/angular';
|
|
6
|
+
|
|
7
|
+
const values = [
|
|
8
|
+
DragDropFileDirective,
|
|
9
|
+
DragDropOverlayComponent
|
|
10
|
+
]
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
@NgModule({
|
|
14
|
+
declarations: [ ...values ],
|
|
15
|
+
exports : [ ...values ],
|
|
16
|
+
imports: [
|
|
17
|
+
CommonModule,
|
|
18
|
+
IonicModule
|
|
19
|
+
]
|
|
20
|
+
})
|
|
21
|
+
export class DragDropFileModule { }
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
<div class="absolute top-0 left-0 size-full z-50 p-4 pointer-events-none" [ngClass]="{'fileOver': fileOver}">
|
|
2
|
+
<div class="border-4 border-dashed border-transparent default-transition rounded-2xl size-full flex items-center justify-center">
|
|
3
|
+
<ion-icon class="text-9xl text-transparent" name="cloud-upload"></ion-icon>
|
|
4
|
+
</div>
|
|
5
|
+
</div>
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { Component, OnInit } from '@angular/core';
|
|
3
|
+
import { IonicModule } from '@ionic/angular';
|
|
4
|
+
|
|
5
|
+
@Component({
|
|
6
|
+
selector: 'drag-drop-overlay',
|
|
7
|
+
templateUrl: './drag-drop-overlay.component.html',
|
|
8
|
+
styleUrls: ['./drag-drop-overlay.component.scss'],
|
|
9
|
+
})
|
|
10
|
+
export class DragDropOverlayComponent implements OnInit {
|
|
11
|
+
|
|
12
|
+
constructor() { }
|
|
13
|
+
|
|
14
|
+
ngOnInit() {}
|
|
15
|
+
|
|
16
|
+
fileOver: boolean;
|
|
17
|
+
}
|