@koalarx/ui 14.0.7 → 14.0.9
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/alert/esm2020/index.mjs +6 -6
- package/alert/esm2020/koalarx-ui-alert.mjs +4 -4
- package/alert/esm2020/lib/dialog-alert.component.mjs +48 -48
- package/alert/esm2020/lib/koala.alert-config.interface.mjs +1 -1
- package/alert/esm2020/lib/koala.alert.enum.mjs +8 -8
- package/alert/esm2020/lib/koala.alert.module.mjs +46 -46
- package/alert/esm2020/lib/koala.alert.service.mjs +19 -19
- package/alert/esm2020/lib/koala.request-code-to-alert-enum.translate.mjs +17 -17
- package/alert/fesm2015/koalarx-ui-alert.mjs +111 -111
- package/alert/fesm2015/koalarx-ui-alert.mjs.map +1 -1
- package/alert/fesm2020/koalarx-ui-alert.mjs +109 -109
- package/alert/fesm2020/koalarx-ui-alert.mjs.map +1 -1
- package/alert/index.d.ts +6 -6
- package/alert/lib/dialog-alert.component.d.ts +10 -10
- package/alert/lib/koala.alert-config.interface.d.ts +14 -14
- package/alert/lib/koala.alert.enum.d.ts +7 -7
- package/alert/lib/koala.alert.module.d.ts +12 -12
- package/alert/lib/koala.alert.service.d.ts +10 -10
- package/alert/lib/koala.request-code-to-alert-enum.translate.d.ts +4 -4
- package/button/esm2020/index.mjs +2 -2
- package/button/esm2020/koalarx-ui-button.mjs +4 -4
- package/button/esm2020/lib/button.component.mjs +44 -44
- package/button/esm2020/lib/koala.button.module.mjs +40 -40
- package/button/fesm2015/koalarx-ui-button.mjs +67 -67
- package/button/fesm2015/koalarx-ui-button.mjs.map +1 -1
- package/button/fesm2020/koalarx-ui-button.mjs +67 -67
- package/button/fesm2020/koalarx-ui-button.mjs.map +1 -1
- package/button/index.d.ts +2 -2
- package/button/lib/button.component.d.ts +18 -18
- package/button/lib/koala.button.module.d.ts +12 -12
- package/common/esm2020/index.mjs +4 -4
- package/common/esm2020/koalarx-ui-common.mjs +4 -4
- package/common/esm2020/lib/mask-options.mjs +3 -3
- package/common/esm2020/lib/services/csv/koala.csv.service.mjs +36 -36
- package/common/esm2020/lib/services/xlsx/koala.xlsx-config.interface.mjs +1 -1
- package/common/esm2020/lib/services/xlsx/koala.xlsx.service.mjs +127 -127
- package/common/fesm2015/koalarx-ui-common.mjs +160 -160
- package/common/fesm2015/koalarx-ui-common.mjs.map +1 -1
- package/common/fesm2020/koalarx-ui-common.mjs +155 -155
- package/common/fesm2020/koalarx-ui-common.mjs.map +1 -1
- package/common/index.d.ts +4 -4
- package/common/lib/mask-options.d.ts +2 -2
- package/common/lib/services/csv/koala.csv.service.d.ts +10 -10
- package/common/lib/services/xlsx/koala.xlsx-config.interface.d.ts +11 -11
- package/common/lib/services/xlsx/koala.xlsx.service.d.ts +12 -12
- package/core/esm2020/index.mjs +36 -36
- package/core/esm2020/koalarx-ui-core.mjs +4 -4
- package/core/esm2020/lib/environments/koalaEnvironment.mjs +3 -3
- package/core/esm2020/lib/helpers/mat-form-field.helper.mjs +16 -16
- package/core/esm2020/lib/loader/loader-bar-page.component.mjs +24 -24
- package/core/esm2020/lib/loader/loader-bar-page.interface.mjs +1 -1
- package/core/esm2020/lib/loader/loader-config.interface.mjs +1 -1
- package/core/esm2020/lib/ngx-koala.module.mjs +47 -47
- package/core/esm2020/lib/page/koala-language.helper.mjs +113 -113
- package/core/esm2020/lib/page/koala-page-pallet-colors.interface.mjs +1 -1
- package/core/esm2020/lib/page/koala.page.module.mjs +76 -76
- package/core/esm2020/lib/page/koala.user-menu-options.interface.mjs +1 -1
- package/core/esm2020/lib/page/notifications/koala.notification.interface.mjs +1 -1
- package/core/esm2020/lib/page/notifications/notification.component.mjs +43 -43
- package/core/esm2020/lib/page/page.component.mjs +302 -302
- package/core/esm2020/lib/router/koala.parameter-hash-location-stategy.mjs +18 -18
- package/core/esm2020/lib/services/api-requester/factory/koala.response.factory.mjs +43 -43
- package/core/esm2020/lib/services/api-requester/helpers/error/koala.client.error.mjs +2 -2
- package/core/esm2020/lib/services/api-requester/helpers/error/koala.errors.helper.mjs +45 -45
- package/core/esm2020/lib/services/api-requester/helpers/error/koala.not-found.error.mjs +2 -2
- package/core/esm2020/lib/services/api-requester/helpers/error/koala.success.error.mjs +2 -2
- package/core/esm2020/lib/services/api-requester/helpers/error/koala.unhautorized.error.mjs +2 -2
- package/core/esm2020/lib/services/api-requester/helpers/service/koala.request-header.helper.mjs +14 -14
- package/core/esm2020/lib/services/api-requester/koala.api-requester.base.mjs +86 -86
- package/core/esm2020/lib/services/api-requester/koala.api-requester.cache.mjs +37 -37
- package/core/esm2020/lib/services/api-requester/koala.api-requester.service.mjs +158 -158
- package/core/esm2020/lib/services/loader/koala.loader.service.mjs +34 -34
- package/core/esm2020/lib/services/openid/koala-oauth2-config.interface.mjs +1 -1
- package/core/esm2020/lib/services/openid/koala.oauth.config.mjs +29 -29
- package/core/esm2020/lib/services/openid/koala.oauth2.service.mjs +188 -188
- package/core/esm2020/lib/services/request/koala.request.service.mjs +52 -52
- package/core/esm2020/lib/services/token/koala.token.service.mjs +55 -55
- package/core/esm2020/lib/services/token/token.factory.mjs +26 -26
- package/core/fesm2015/koalarx-ui-core.mjs +1294 -1294
- package/core/fesm2015/koalarx-ui-core.mjs.map +1 -1
- package/core/fesm2020/koalarx-ui-core.mjs +1256 -1256
- package/core/fesm2020/koalarx-ui-core.mjs.map +1 -1
- package/core/index.d.ts +30 -30
- package/core/lib/environments/koalaEnvironment.d.ts +15 -15
- package/core/lib/helpers/mat-form-field.helper.d.ts +3 -3
- package/core/lib/loader/loader-bar-page.component.d.ts +9 -9
- package/core/lib/loader/loader-bar-page.interface.d.ts +5 -5
- package/core/lib/loader/loader-config.interface.d.ts +7 -7
- package/core/lib/ngx-koala.module.d.ts +12 -12
- package/core/lib/page/koala-language.helper.d.ts +19 -19
- package/core/lib/page/koala-page-pallet-colors.interface.d.ts +38 -38
- package/core/lib/page/koala.page.module.d.ts +21 -21
- package/core/lib/page/koala.user-menu-options.interface.d.ts +5 -5
- package/core/lib/page/notifications/koala.notification.interface.d.ts +6 -6
- package/core/lib/page/notifications/notification.component.d.ts +15 -15
- package/core/lib/page/page.component.d.ts +58 -58
- package/core/lib/router/koala.parameter-hash-location-stategy.d.ts +7 -7
- package/core/lib/services/api-requester/factory/koala.response.factory.d.ts +5 -5
- package/core/lib/services/api-requester/helpers/error/koala.client.error.d.ts +2 -2
- package/core/lib/services/api-requester/helpers/error/koala.errors.helper.d.ts +13 -13
- package/core/lib/services/api-requester/helpers/error/koala.not-found.error.d.ts +2 -2
- package/core/lib/services/api-requester/helpers/error/koala.success.error.d.ts +2 -2
- package/core/lib/services/api-requester/helpers/error/koala.unhautorized.error.d.ts +2 -2
- package/core/lib/services/api-requester/helpers/service/koala.request-header.helper.d.ts +4 -4
- package/core/lib/services/api-requester/koala.api-requester.base.d.ts +19 -19
- package/core/lib/services/api-requester/koala.api-requester.cache.d.ts +13 -13
- package/core/lib/services/api-requester/koala.api-requester.service.d.ts +24 -24
- package/core/lib/services/loader/koala.loader.service.d.ts +14 -14
- package/core/lib/services/openid/koala-oauth2-config.interface.d.ts +11 -11
- package/core/lib/services/openid/koala.oauth.config.d.ts +9 -9
- package/core/lib/services/openid/koala.oauth2.service.d.ts +82 -82
- package/core/lib/services/request/koala.request.service.d.ts +11 -11
- package/core/lib/services/token/koala.token.service.d.ts +26 -26
- package/core/lib/services/token/token.factory.d.ts +9 -9
- package/dialog/esm2020/index.mjs +3 -3
- package/dialog/esm2020/koalarx-ui-dialog.mjs +4 -4
- package/dialog/esm2020/lib/dialog.component.mjs +25 -25
- package/dialog/esm2020/lib/koala.dialog-template.interface.mjs +1 -1
- package/dialog/esm2020/lib/koala.dialog.module.mjs +36 -36
- package/dialog/esm2020/lib/koala.dialog.service.mjs +57 -57
- package/dialog/fesm2015/koalarx-ui-dialog.mjs +96 -96
- package/dialog/fesm2015/koalarx-ui-dialog.mjs.map +1 -1
- package/dialog/fesm2020/koalarx-ui-dialog.mjs +96 -96
- package/dialog/fesm2020/koalarx-ui-dialog.mjs.map +1 -1
- package/dialog/index.d.ts +3 -3
- package/dialog/lib/dialog.component.d.ts +11 -11
- package/dialog/lib/koala.dialog-template.interface.d.ts +9 -9
- package/dialog/lib/koala.dialog.module.d.ts +11 -11
- package/dialog/lib/koala.dialog.service.d.ts +14 -14
- package/dynamic-component/esm2020/index.mjs +5 -5
- package/dynamic-component/esm2020/koalarx-ui-dynamic-component.mjs +4 -4
- package/dynamic-component/esm2020/lib/koala-dynamic-component.component.mjs +1 -1
- package/dynamic-component/esm2020/lib/koala-dynamic-component.directive.mjs +16 -16
- package/dynamic-component/esm2020/lib/koala-dynamic-component.factory.mjs +40 -40
- package/dynamic-component/esm2020/lib/koala-dynamic-component.mjs +6 -6
- package/dynamic-component/esm2020/lib/koala-dynamic-component.module.mjs +23 -23
- package/dynamic-component/fesm2015/koalarx-ui-dynamic-component.mjs +71 -71
- package/dynamic-component/fesm2015/koalarx-ui-dynamic-component.mjs.map +1 -1
- package/dynamic-component/fesm2020/koalarx-ui-dynamic-component.mjs +70 -70
- package/dynamic-component/fesm2020/koalarx-ui-dynamic-component.mjs.map +1 -1
- package/dynamic-component/index.d.ts +5 -5
- package/dynamic-component/lib/koala-dynamic-component.component.d.ts +3 -3
- package/dynamic-component/lib/koala-dynamic-component.d.ts +6 -6
- package/dynamic-component/lib/koala-dynamic-component.directive.d.ts +8 -8
- package/dynamic-component/lib/koala-dynamic-component.factory.d.ts +14 -14
- package/dynamic-component/lib/koala-dynamic-component.module.d.ts +8 -8
- package/file-button/esm2020/index.mjs +4 -4
- package/file-button/esm2020/koalarx-ui-file-button.mjs +4 -4
- package/file-button/esm2020/lib/file-button.component.mjs +125 -125
- package/file-button/esm2020/lib/koala.btn-file.service.mjs +25 -25
- package/file-button/esm2020/lib/koala.file-button.module.mjs +36 -36
- package/file-button/esm2020/lib/koala.file.interface.mjs +1 -1
- package/file-button/fesm2015/koalarx-ui-file-button.mjs +174 -174
- package/file-button/fesm2015/koalarx-ui-file-button.mjs.map +1 -1
- package/file-button/fesm2020/koalarx-ui-file-button.mjs +165 -165
- package/file-button/fesm2020/koalarx-ui-file-button.mjs.map +1 -1
- package/file-button/index.d.ts +4 -4
- package/file-button/lib/file-button.component.d.ts +29 -29
- package/file-button/lib/koala.btn-file.service.d.ts +11 -11
- package/file-button/lib/koala.file-button.module.d.ts +11 -11
- package/file-button/lib/koala.file.interface.d.ts +5 -5
- package/folder-page/esm2020/index.mjs +3 -3
- package/folder-page/esm2020/koalarx-ui-folder-page.mjs +4 -4
- package/folder-page/esm2020/lib/folder.component.mjs +70 -70
- package/folder-page/esm2020/lib/koala-navigate-history.interface.mjs +1 -1
- package/folder-page/esm2020/lib/koala.folder-page.module.mjs +40 -40
- package/folder-page/fesm2015/koalarx-ui-folder-page.mjs +95 -95
- package/folder-page/fesm2015/koalarx-ui-folder-page.mjs.map +1 -1
- package/folder-page/fesm2020/koalarx-ui-folder-page.mjs +94 -94
- package/folder-page/fesm2020/koalarx-ui-folder-page.mjs.map +1 -1
- package/folder-page/index.d.ts +3 -3
- package/folder-page/lib/folder.component.d.ts +21 -21
- package/folder-page/lib/koala-navigate-history.interface.d.ts +4 -4
- package/folder-page/lib/koala.folder-page.module.d.ts +12 -12
- package/form/esm2020/index.mjs +19 -19
- package/form/esm2020/koalarx-ui-form.mjs +4 -4
- package/form/esm2020/lib/btn-submit/btn-submit.component.mjs +49 -49
- package/form/esm2020/lib/directives/koala-autofocus.directive.mjs +25 -25
- package/form/esm2020/lib/dynamic-form/builder/dynamic-form.builder.mjs +139 -138
- package/form/esm2020/lib/dynamic-form/builder/fields/autocomplete.builder.mjs +37 -37
- package/form/esm2020/lib/dynamic-form/builder/fields/field.base.mjs +147 -147
- package/form/esm2020/lib/dynamic-form/builder/fields/field.builder.mjs +6 -6
- package/form/esm2020/lib/dynamic-form/builder/fields/more-items.builder.mjs +56 -56
- package/form/esm2020/lib/dynamic-form/dynamic-form.component.mjs +598 -598
- package/form/esm2020/lib/dynamic-form/enums/dynamic-form-type-field.enum.mjs +34 -34
- package/form/esm2020/lib/dynamic-form/interfaces/koala-custom-validator-fn.interface.mjs +1 -1
- package/form/esm2020/lib/dynamic-form/interfaces/koala.dynamic-autocomplete-options.interface.mjs +1 -1
- package/form/esm2020/lib/dynamic-form/interfaces/koala.dynamic-form-autocomplete-multiple-config.interface.mjs +1 -1
- package/form/esm2020/lib/dynamic-form/interfaces/koala.dynamic-form-config.interface.mjs +2 -2
- package/form/esm2020/lib/dynamic-form/interfaces/koala.dynamic-form-field.interface.mjs +1 -1
- package/form/esm2020/lib/dynamic-form/interfaces/koala.dynamic-form-more-itens-show-field-config.interface.mjs +1 -1
- package/form/esm2020/lib/dynamic-form/interfaces/koala.dynamic-form-show-field.interface.mjs +1 -1
- package/form/esm2020/lib/dynamic-form/interfaces/koala.dynamic-set-value.interface.mjs +1 -1
- package/form/esm2020/lib/dynamic-form/koala.dynamic-form.service.mjs +212 -212
- package/form/esm2020/lib/dynamic-form/validators/autocomplete-selected.validator.mjs +9 -9
- package/form/esm2020/lib/dynamic-form/validators/cnpj.validator.mjs +9 -9
- package/form/esm2020/lib/dynamic-form/validators/cpf.validator.mjs +9 -9
- package/form/esm2020/lib/dynamic-form/validators/date-max.validator.mjs +10 -10
- package/form/esm2020/lib/dynamic-form/validators/date-min.validator.mjs +10 -10
- package/form/esm2020/lib/dynamic-form/validators/koala-dynamic-form-validator-result.helper.mjs +9 -9
- package/form/esm2020/lib/dynamic-form/validators/validation.helper.mjs +85 -85
- package/form/esm2020/lib/form.abstract.mjs +41 -41
- package/form/esm2020/lib/koala.form.module.mjs +132 -132
- package/form/esm2020/lib/show-invalid-fields/show-invalid-fields.mjs +8 -8
- package/form/fesm2015/koalarx-ui-form.mjs +1517 -1516
- package/form/fesm2015/koalarx-ui-form.mjs.map +1 -1
- package/form/fesm2020/koalarx-ui-form.mjs +1499 -1498
- package/form/fesm2020/koalarx-ui-form.mjs.map +1 -1
- package/form/index.d.ts +19 -19
- package/form/lib/btn-submit/btn-submit.component.d.ts +20 -20
- package/form/lib/directives/koala-autofocus.directive.d.ts +10 -10
- package/form/lib/dynamic-form/builder/dynamic-form.builder.d.ts +21 -21
- package/form/lib/dynamic-form/builder/fields/autocomplete.builder.d.ts +16 -16
- package/form/lib/dynamic-form/builder/fields/field.base.d.ts +42 -42
- package/form/lib/dynamic-form/builder/fields/field.builder.d.ts +8 -8
- package/form/lib/dynamic-form/builder/fields/more-items.builder.d.ts +17 -17
- package/form/lib/dynamic-form/dynamic-form.component.d.ts +54 -54
- package/form/lib/dynamic-form/enums/dynamic-form-type-field.enum.d.ts +33 -33
- package/form/lib/dynamic-form/interfaces/koala-custom-validator-fn.interface.d.ts +4 -4
- package/form/lib/dynamic-form/interfaces/koala.dynamic-autocomplete-options.interface.d.ts +4 -4
- package/form/lib/dynamic-form/interfaces/koala.dynamic-form-autocomplete-multiple-config.interface.d.ts +4 -4
- package/form/lib/dynamic-form/interfaces/koala.dynamic-form-config.interface.d.ts +12 -11
- package/form/lib/dynamic-form/interfaces/koala.dynamic-form-field.interface.d.ts +69 -69
- package/form/lib/dynamic-form/interfaces/koala.dynamic-form-more-itens-show-field-config.interface.d.ts +8 -8
- package/form/lib/dynamic-form/interfaces/koala.dynamic-form-show-field.interface.d.ts +5 -5
- package/form/lib/dynamic-form/interfaces/koala.dynamic-set-value.interface.d.ts +4 -4
- package/form/lib/dynamic-form/koala.dynamic-form.service.d.ts +28 -28
- package/form/lib/dynamic-form/validators/autocomplete-selected.validator.d.ts +4 -4
- package/form/lib/dynamic-form/validators/cnpj.validator.d.ts +4 -4
- package/form/lib/dynamic-form/validators/cpf.validator.d.ts +4 -4
- package/form/lib/dynamic-form/validators/date-max.validator.d.ts +2 -2
- package/form/lib/dynamic-form/validators/date-min.validator.d.ts +2 -2
- package/form/lib/dynamic-form/validators/koala-dynamic-form-validator-result.helper.d.ts +7 -7
- package/form/lib/dynamic-form/validators/validation.helper.d.ts +4 -4
- package/form/lib/form.abstract.d.ts +16 -16
- package/form/lib/koala.form.module.d.ts +25 -25
- package/form/lib/show-invalid-fields/show-invalid-fields.d.ts +6 -6
- package/icon/esm2020/index.mjs +3 -3
- package/icon/esm2020/koalarx-ui-icon.mjs +4 -4
- package/icon/esm2020/lib/icon.component.mjs +41 -41
- package/icon/esm2020/lib/koala.icon.module.mjs +24 -24
- package/icon/esm2020/lib/koala.icon.type.mjs +1 -1
- package/icon/fesm2015/koalarx-ui-icon.mjs +56 -56
- package/icon/fesm2015/koalarx-ui-icon.mjs.map +1 -1
- package/icon/fesm2020/koalarx-ui-icon.mjs +55 -55
- package/icon/fesm2020/koalarx-ui-icon.mjs.map +1 -1
- package/icon/index.d.ts +3 -3
- package/icon/lib/icon.component.d.ts +14 -14
- package/icon/lib/koala.icon.module.d.ts +8 -8
- package/icon/lib/koala.icon.type.d.ts +1 -1
- package/icons-animated/esm2020/index.mjs +4 -4
- package/icons-animated/esm2020/koalarx-ui-icons-animated.mjs +4 -4
- package/icons-animated/esm2020/lib/icons/downloading/downloading-icon-animated.component.mjs +23 -23
- package/icons-animated/esm2020/lib/icons/loading/loading-icon-animated.component.mjs +23 -23
- package/icons-animated/esm2020/lib/icons-animated.component.mjs +20 -20
- package/icons-animated/esm2020/lib/icons-animated.service.mjs +27 -27
- package/icons-animated/esm2020/lib/koala-icons-animated.module.mjs +30 -30
- package/icons-animated/fesm2015/koalarx-ui-icons-animated.mjs +95 -95
- package/icons-animated/fesm2015/koalarx-ui-icons-animated.mjs.map +1 -1
- package/icons-animated/fesm2020/koalarx-ui-icons-animated.mjs +93 -93
- package/icons-animated/fesm2020/koalarx-ui-icons-animated.mjs.map +1 -1
- package/icons-animated/index.d.ts +4 -4
- package/icons-animated/lib/icons/downloading/downloading-icon-animated.component.d.ts +12 -12
- package/icons-animated/lib/icons/loading/loading-icon-animated.component.d.ts +12 -12
- package/icons-animated/lib/icons-animated.component.d.ts +8 -8
- package/icons-animated/lib/icons-animated.service.d.ts +9 -9
- package/icons-animated/lib/koala-icons-animated.module.d.ts +10 -10
- package/list/esm2020/index.mjs +11 -11
- package/list/esm2020/koalarx-ui-list.mjs +4 -4
- package/list/esm2020/lib/koala-list-btn-collapse-sub-list-config.interface.mjs +1 -1
- package/list/esm2020/lib/koala-list-filter.interface.mjs +1 -1
- package/list/esm2020/lib/koala-list-form-filter.interface.mjs +1 -1
- package/list/esm2020/lib/koala-list-item-menu-option.interface.mjs +1 -1
- package/list/esm2020/lib/koala-list-item.interface.mjs +1 -1
- package/list/esm2020/lib/koala.list-config.interface.mjs +1 -1
- package/list/esm2020/lib/koala.list.module.mjs +68 -68
- package/list/esm2020/lib/koala.list.service.mjs +15 -15
- package/list/esm2020/lib/list-builder/list.builder.mjs +104 -104
- package/list/esm2020/lib/list.abstract.mjs +163 -163
- package/list/esm2020/lib/list.component.mjs +172 -172
- package/list/esm2020/lib/providers/pagination/pagination.provider.mjs +32 -32
- package/list/fesm2015/koalarx-ui-list.mjs +521 -521
- package/list/fesm2015/koalarx-ui-list.mjs.map +1 -1
- package/list/fesm2020/koalarx-ui-list.mjs +491 -491
- package/list/fesm2020/koalarx-ui-list.mjs.map +1 -1
- package/list/index.d.ts +11 -11
- package/list/lib/koala-list-btn-collapse-sub-list-config.interface.d.ts +8 -8
- package/list/lib/koala-list-filter.interface.d.ts +10 -10
- package/list/lib/koala-list-form-filter.interface.d.ts +8 -8
- package/list/lib/koala-list-item-menu-option.interface.d.ts +7 -7
- package/list/lib/koala-list-item.interface.d.ts +13 -13
- package/list/lib/koala.list-config.interface.d.ts +37 -37
- package/list/lib/koala.list.module.d.ts +17 -17
- package/list/lib/koala.list.service.d.ts +7 -7
- package/list/lib/list-builder/list.builder.d.ts +32 -32
- package/list/lib/list.abstract.d.ts +44 -44
- package/list/lib/list.component.d.ts +54 -54
- package/list/lib/providers/pagination/pagination.provider.d.ts +9 -9
- package/menu/esm2020/index.mjs +5 -5
- package/menu/esm2020/koalarx-ui-menu.mjs +4 -4
- package/menu/esm2020/lib/koala.menu-module.interface.mjs +1 -1
- package/menu/esm2020/lib/koala.menu-tool.interface.mjs +1 -1
- package/menu/esm2020/lib/koala.menu.module.mjs +36 -36
- package/menu/esm2020/lib/koala.menu.service.mjs +24 -24
- package/menu/esm2020/lib/menu.component.mjs +100 -100
- package/menu/fesm2015/koalarx-ui-menu.mjs +139 -139
- package/menu/fesm2015/koalarx-ui-menu.mjs.map +1 -1
- package/menu/fesm2020/koalarx-ui-menu.mjs +135 -135
- package/menu/fesm2020/koalarx-ui-menu.mjs.map +1 -1
- package/menu/index.d.ts +5 -5
- package/menu/lib/koala.menu-module.interface.d.ts +12 -12
- package/menu/lib/koala.menu-tool.interface.d.ts +6 -6
- package/menu/lib/koala.menu.module.d.ts +11 -11
- package/menu/lib/koala.menu.service.d.ts +10 -10
- package/menu/lib/menu.component.d.ts +22 -22
- package/package.json +1 -1
- package/question/esm2020/index.mjs +4 -4
- package/question/esm2020/koalarx-ui-question.mjs +4 -4
- package/question/esm2020/lib/dialog-question.component.mjs +25 -25
- package/question/esm2020/lib/koala-question-config.interface.mjs +1 -1
- package/question/esm2020/lib/koala.question.module.mjs +40 -40
- package/question/esm2020/lib/koala.question.service.mjs +26 -26
- package/question/fesm2015/koalarx-ui-question.mjs +68 -68
- package/question/fesm2015/koalarx-ui-question.mjs.map +1 -1
- package/question/fesm2020/koalarx-ui-question.mjs +66 -66
- package/question/fesm2020/koalarx-ui-question.mjs.map +1 -1
- package/question/index.d.ts +4 -4
- package/question/lib/dialog-question.component.d.ts +10 -10
- package/question/lib/koala-question-config.interface.d.ts +5 -5
- package/question/lib/koala.question.module.d.ts +12 -12
- package/question/lib/koala.question.service.d.ts +10 -10
- package/snackbar/esm2020/index.mjs +4 -4
- package/snackbar/esm2020/koalarx-ui-snackbar.mjs +4 -4
- package/snackbar/esm2020/lib/koala.snackbar.component.mjs +22 -22
- package/snackbar/esm2020/lib/koala.snackbar.interface.mjs +1 -1
- package/snackbar/esm2020/lib/koala.snackbar.module.mjs +36 -36
- package/snackbar/esm2020/lib/koala.snackbar.service.mjs +35 -35
- package/snackbar/fesm2015/koalarx-ui-snackbar.mjs +74 -74
- package/snackbar/fesm2015/koalarx-ui-snackbar.mjs.map +1 -1
- package/snackbar/fesm2020/koalarx-ui-snackbar.mjs +72 -72
- package/snackbar/fesm2020/koalarx-ui-snackbar.mjs.map +1 -1
- package/snackbar/index.d.ts +4 -4
- package/snackbar/lib/koala.snackbar.component.d.ts +10 -10
- package/snackbar/lib/koala.snackbar.interface.d.ts +4 -4
- package/snackbar/lib/koala.snackbar.module.d.ts +10 -10
- package/snackbar/lib/koala.snackbar.service.d.ts +12 -12
|
@@ -1,209 +1,209 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
-
import { NavigationCancel, NavigationEnd, NavigationError, NavigationStart } from '@angular/router';
|
|
3
|
-
import { BehaviorSubject } from 'rxjs';
|
|
4
|
-
import { KoalaTokenService } from '../services/token/koala.token.service';
|
|
5
|
-
import { menuStateSubject } from '@koalarx/ui/menu';
|
|
6
|
-
import jwtEncode from "jwt-encode";
|
|
7
|
-
import { TokenFactory } from "../services/token/token.factory";
|
|
8
|
-
import { KoalaEnvironment } from "../environments/koalaEnvironment";
|
|
9
|
-
import { KoalaOauthConfig } from "../services/openid/koala.oauth.config";
|
|
10
|
-
import { KoalaLanguageHelper } from "./koala-language.helper";
|
|
11
|
-
import * as i0 from "@angular/core";
|
|
12
|
-
import * as i1 from "../services/token/koala.token.service";
|
|
13
|
-
import * as i2 from "@angular/router";
|
|
14
|
-
import * as i3 from "../services/loader/koala.loader.service";
|
|
15
|
-
import * as i4 from "@koalarx/ui/menu";
|
|
16
|
-
import * as i5 from "../services/openid/koala.oauth2.service";
|
|
17
|
-
import * as i6 from "ngx-device-detector";
|
|
18
|
-
import * as i7 from "@angular/common";
|
|
19
|
-
import * as i8 from "@angular/material/badge";
|
|
20
|
-
import * as i9 from "@angular/material/progress-spinner";
|
|
21
|
-
import * as i10 from "@angular/material/toolbar";
|
|
22
|
-
import * as i11 from "@angular/material/button";
|
|
23
|
-
import * as i12 from "@angular/material/icon";
|
|
24
|
-
import * as i13 from "@angular/material/sidenav";
|
|
25
|
-
import * as i14 from "@angular/material/menu";
|
|
26
|
-
import * as i15 from "./notifications/notification.component";
|
|
27
|
-
import * as i16 from "../loader/loader-bar-page.component";
|
|
28
|
-
export class PageComponent {
|
|
29
|
-
constructor(tokenService, router, loaderService, menuService, oauth2Service, deviceService) {
|
|
30
|
-
this.tokenService = tokenService;
|
|
31
|
-
this.router = router;
|
|
32
|
-
this.loaderService = loaderService;
|
|
33
|
-
this.menuService = menuService;
|
|
34
|
-
this.oauth2Service = oauth2Service;
|
|
35
|
-
this.deviceService = deviceService;
|
|
36
|
-
this.showMenu = true;
|
|
37
|
-
this.startMenuOpened = true;
|
|
38
|
-
this.userMenuOptions = [];
|
|
39
|
-
this.language = 'ptBr';
|
|
40
|
-
this.validatingScope = new EventEmitter(false);
|
|
41
|
-
this.logoutEmitter = new EventEmitter(false);
|
|
42
|
-
this.deleteAllNotifications = new EventEmitter(false);
|
|
43
|
-
this.deleteNotification = new EventEmitter(null);
|
|
44
|
-
this.username$ = new BehaviorSubject('');
|
|
45
|
-
this.firstUserLetter$ = new BehaviorSubject('');
|
|
46
|
-
this.logged$ = new BehaviorSubject(false);
|
|
47
|
-
this.validationScope$ = new BehaviorSubject(false);
|
|
48
|
-
this.isMobile = this.deviceService.isMobile();
|
|
49
|
-
this.defaultPalletColors = {
|
|
50
|
-
scrollbarColor: '#1976D2',
|
|
51
|
-
scrollbarColorHover: '#1565C0',
|
|
52
|
-
userPresentationBackground: '#f1f1f1',
|
|
53
|
-
userPresentationUserBackground: '#1976D2',
|
|
54
|
-
userPresentationUserFontColor: '#fff',
|
|
55
|
-
firstColor: '#fff',
|
|
56
|
-
secondColor: '#F1F1F1',
|
|
57
|
-
bodyBackground: '#eeeeee',
|
|
58
|
-
checkboxBackground: '#1976d2',
|
|
59
|
-
checkboxColor: '#ffffff',
|
|
60
|
-
fontColor: '#1976D2',
|
|
61
|
-
fontHoverColor: '#1976D2',
|
|
62
|
-
fontActiveColor: '#1565C0',
|
|
63
|
-
menuTitleBackground: 'rgba(0,0,0,.1)',
|
|
64
|
-
menuTitleColor: 'rgba(0,0,0,.3)',
|
|
65
|
-
menuBackground: '#fafafa',
|
|
66
|
-
menuOptionsBackground: '#eaeaea',
|
|
67
|
-
menuOptionsColor: '#a5a5a5',
|
|
68
|
-
menuOptionsColorHover: '#1976D2',
|
|
69
|
-
menuOptionsColorActive: '#1565c0',
|
|
70
|
-
toolbarBackground: '#ffffff',
|
|
71
|
-
toolbarColor: '#1976d2',
|
|
72
|
-
listBackground: '#fff',
|
|
73
|
-
listContentBackground: '#fff',
|
|
74
|
-
listTitleItemColor: '#838383',
|
|
75
|
-
listItemColor: '#3e3e3e',
|
|
76
|
-
listItemBackgroudHover: '#F1F1F1',
|
|
77
|
-
listItemBackgroundActive: '#EEE',
|
|
78
|
-
shadowColorTableList: 'rgba(25, 118, 210, .4)'
|
|
79
|
-
};
|
|
80
|
-
this.loaderSubject = loaderService.getLoaderSubject();
|
|
81
|
-
}
|
|
82
|
-
ngOnInit() {
|
|
83
|
-
KoalaLanguageHelper.setLanguage(this.language);
|
|
84
|
-
this.initOAuth2();
|
|
85
|
-
if (this.openPages) {
|
|
86
|
-
if (this.openPages.indexOf('/') < 0) {
|
|
87
|
-
this.openPages.push('/');
|
|
88
|
-
}
|
|
89
|
-
if (this.openPages.indexOf('/login') < 0) {
|
|
90
|
-
this.openPages.push('/login');
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
else {
|
|
94
|
-
this.openPages = [
|
|
95
|
-
'/',
|
|
96
|
-
'/login'
|
|
97
|
-
];
|
|
98
|
-
}
|
|
99
|
-
this.tokenService.getToken()?.subscribe(token => {
|
|
100
|
-
this.logged$.next(!!token);
|
|
101
|
-
if (this.logged$.getValue()) {
|
|
102
|
-
const decodedToken = this.tokenService.getDecodedToken();
|
|
103
|
-
this.username$.next(decodedToken.login);
|
|
104
|
-
this.firstUserLetter$.next(decodedToken.login.charAt(0).toUpperCase());
|
|
105
|
-
if (!this.isMobile) {
|
|
106
|
-
this.menuService.open();
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
if (this.logged$.getValue() && this.openPages?.indexOf(this.currentUrl) >= 0 && this.defaultPage) {
|
|
110
|
-
this.router.navigate([this.defaultPage]).then();
|
|
111
|
-
}
|
|
112
|
-
else if (!this.logged$.getValue() && this.currentUrl && this.openPages?.indexOf(this.currentUrl) < 0) {
|
|
113
|
-
this.router.navigate(['login']).then();
|
|
114
|
-
return false;
|
|
115
|
-
}
|
|
116
|
-
});
|
|
117
|
-
this.router.events.subscribe(event => {
|
|
118
|
-
switch (true) {
|
|
119
|
-
case event instanceof NavigationStart: {
|
|
120
|
-
this.loaderService.create({ typeLoader: 'indeterminate' });
|
|
121
|
-
break;
|
|
122
|
-
}
|
|
123
|
-
case event instanceof NavigationEnd:
|
|
124
|
-
case event instanceof NavigationCancel:
|
|
125
|
-
case event instanceof NavigationError: {
|
|
126
|
-
this.loaderService.dismiss();
|
|
127
|
-
if (event instanceof NavigationEnd) {
|
|
128
|
-
if (this.isMobile) {
|
|
129
|
-
this.menuService.close();
|
|
130
|
-
}
|
|
131
|
-
this.currentUrl = event.url.split('?')[0];
|
|
132
|
-
if (event.url.indexOf('/login?clientId=') < 0) {
|
|
133
|
-
if (this.logged$.getValue() && this.defaultPage && this.openPages?.indexOf(this.currentUrl) >= 0) {
|
|
134
|
-
this.router.navigate([this.defaultPage]).then();
|
|
135
|
-
return false;
|
|
136
|
-
}
|
|
137
|
-
else if (!this.logged$.getValue() && this.openPages?.indexOf(this.currentUrl) < 0) {
|
|
138
|
-
this.router.navigate(['login']).then();
|
|
139
|
-
return false;
|
|
140
|
-
}
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
break;
|
|
144
|
-
}
|
|
145
|
-
default: {
|
|
146
|
-
break;
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
});
|
|
150
|
-
if (this.palletColors) {
|
|
151
|
-
Object.keys(this.defaultPalletColors).forEach(indexName => {
|
|
152
|
-
if (!this.palletColors.hasOwnProperty(indexName) ||
|
|
153
|
-
!this.palletColors[indexName]) {
|
|
154
|
-
this.palletColors[indexName] = this.defaultPalletColors[indexName];
|
|
155
|
-
}
|
|
156
|
-
});
|
|
157
|
-
}
|
|
158
|
-
else {
|
|
159
|
-
this.palletColors = this.defaultPalletColors;
|
|
160
|
-
}
|
|
161
|
-
this.defineColor();
|
|
162
|
-
if (this.showMenu) {
|
|
163
|
-
menuStateSubject.subscribe(async (state) => {
|
|
164
|
-
if (this.menu) {
|
|
165
|
-
if (state === 'close') {
|
|
166
|
-
if (this.menu.opened) {
|
|
167
|
-
await this.menu.close();
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
else if (state === 'open') {
|
|
171
|
-
if (!this.menu.opened) {
|
|
172
|
-
await this.menu.open();
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
});
|
|
177
|
-
if (this.startMenuOpened && this.logged$.getValue()) {
|
|
178
|
-
if (!this.isMobile) {
|
|
179
|
-
this.menuService.open();
|
|
180
|
-
}
|
|
181
|
-
}
|
|
182
|
-
else {
|
|
183
|
-
this.menuService.close();
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
else {
|
|
187
|
-
this.menuService.close();
|
|
188
|
-
}
|
|
189
|
-
this.validationScope$.subscribe(scope => this.validatingScope.emit(scope));
|
|
190
|
-
}
|
|
191
|
-
async toogleMenu() {
|
|
192
|
-
this.menuService.clearConfig();
|
|
193
|
-
if (this.menu) {
|
|
194
|
-
await this.menu.toggle();
|
|
195
|
-
}
|
|
196
|
-
}
|
|
197
|
-
async logout() {
|
|
198
|
-
if (KoalaEnvironment.environment?.oauthConfig) {
|
|
199
|
-
this.oauth2Service.logout();
|
|
200
|
-
}
|
|
201
|
-
this.menuService.close();
|
|
202
|
-
this.tokenService.removeToken();
|
|
203
|
-
this.tokenService.getToken().next(null);
|
|
204
|
-
this.logoutEmitter.emit(true);
|
|
205
|
-
}
|
|
206
|
-
defineColor() {
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { NavigationCancel, NavigationEnd, NavigationError, NavigationStart } from '@angular/router';
|
|
3
|
+
import { BehaviorSubject } from 'rxjs';
|
|
4
|
+
import { KoalaTokenService } from '../services/token/koala.token.service';
|
|
5
|
+
import { menuStateSubject } from '@koalarx/ui/menu';
|
|
6
|
+
import jwtEncode from "jwt-encode";
|
|
7
|
+
import { TokenFactory } from "../services/token/token.factory";
|
|
8
|
+
import { KoalaEnvironment } from "../environments/koalaEnvironment";
|
|
9
|
+
import { KoalaOauthConfig } from "../services/openid/koala.oauth.config";
|
|
10
|
+
import { KoalaLanguageHelper } from "./koala-language.helper";
|
|
11
|
+
import * as i0 from "@angular/core";
|
|
12
|
+
import * as i1 from "../services/token/koala.token.service";
|
|
13
|
+
import * as i2 from "@angular/router";
|
|
14
|
+
import * as i3 from "../services/loader/koala.loader.service";
|
|
15
|
+
import * as i4 from "@koalarx/ui/menu";
|
|
16
|
+
import * as i5 from "../services/openid/koala.oauth2.service";
|
|
17
|
+
import * as i6 from "ngx-device-detector";
|
|
18
|
+
import * as i7 from "@angular/common";
|
|
19
|
+
import * as i8 from "@angular/material/badge";
|
|
20
|
+
import * as i9 from "@angular/material/progress-spinner";
|
|
21
|
+
import * as i10 from "@angular/material/toolbar";
|
|
22
|
+
import * as i11 from "@angular/material/button";
|
|
23
|
+
import * as i12 from "@angular/material/icon";
|
|
24
|
+
import * as i13 from "@angular/material/sidenav";
|
|
25
|
+
import * as i14 from "@angular/material/menu";
|
|
26
|
+
import * as i15 from "./notifications/notification.component";
|
|
27
|
+
import * as i16 from "../loader/loader-bar-page.component";
|
|
28
|
+
export class PageComponent {
|
|
29
|
+
constructor(tokenService, router, loaderService, menuService, oauth2Service, deviceService) {
|
|
30
|
+
this.tokenService = tokenService;
|
|
31
|
+
this.router = router;
|
|
32
|
+
this.loaderService = loaderService;
|
|
33
|
+
this.menuService = menuService;
|
|
34
|
+
this.oauth2Service = oauth2Service;
|
|
35
|
+
this.deviceService = deviceService;
|
|
36
|
+
this.showMenu = true;
|
|
37
|
+
this.startMenuOpened = true;
|
|
38
|
+
this.userMenuOptions = [];
|
|
39
|
+
this.language = 'ptBr';
|
|
40
|
+
this.validatingScope = new EventEmitter(false);
|
|
41
|
+
this.logoutEmitter = new EventEmitter(false);
|
|
42
|
+
this.deleteAllNotifications = new EventEmitter(false);
|
|
43
|
+
this.deleteNotification = new EventEmitter(null);
|
|
44
|
+
this.username$ = new BehaviorSubject('');
|
|
45
|
+
this.firstUserLetter$ = new BehaviorSubject('');
|
|
46
|
+
this.logged$ = new BehaviorSubject(false);
|
|
47
|
+
this.validationScope$ = new BehaviorSubject(false);
|
|
48
|
+
this.isMobile = this.deviceService.isMobile();
|
|
49
|
+
this.defaultPalletColors = {
|
|
50
|
+
scrollbarColor: '#1976D2',
|
|
51
|
+
scrollbarColorHover: '#1565C0',
|
|
52
|
+
userPresentationBackground: '#f1f1f1',
|
|
53
|
+
userPresentationUserBackground: '#1976D2',
|
|
54
|
+
userPresentationUserFontColor: '#fff',
|
|
55
|
+
firstColor: '#fff',
|
|
56
|
+
secondColor: '#F1F1F1',
|
|
57
|
+
bodyBackground: '#eeeeee',
|
|
58
|
+
checkboxBackground: '#1976d2',
|
|
59
|
+
checkboxColor: '#ffffff',
|
|
60
|
+
fontColor: '#1976D2',
|
|
61
|
+
fontHoverColor: '#1976D2',
|
|
62
|
+
fontActiveColor: '#1565C0',
|
|
63
|
+
menuTitleBackground: 'rgba(0,0,0,.1)',
|
|
64
|
+
menuTitleColor: 'rgba(0,0,0,.3)',
|
|
65
|
+
menuBackground: '#fafafa',
|
|
66
|
+
menuOptionsBackground: '#eaeaea',
|
|
67
|
+
menuOptionsColor: '#a5a5a5',
|
|
68
|
+
menuOptionsColorHover: '#1976D2',
|
|
69
|
+
menuOptionsColorActive: '#1565c0',
|
|
70
|
+
toolbarBackground: '#ffffff',
|
|
71
|
+
toolbarColor: '#1976d2',
|
|
72
|
+
listBackground: '#fff',
|
|
73
|
+
listContentBackground: '#fff',
|
|
74
|
+
listTitleItemColor: '#838383',
|
|
75
|
+
listItemColor: '#3e3e3e',
|
|
76
|
+
listItemBackgroudHover: '#F1F1F1',
|
|
77
|
+
listItemBackgroundActive: '#EEE',
|
|
78
|
+
shadowColorTableList: 'rgba(25, 118, 210, .4)'
|
|
79
|
+
};
|
|
80
|
+
this.loaderSubject = loaderService.getLoaderSubject();
|
|
81
|
+
}
|
|
82
|
+
ngOnInit() {
|
|
83
|
+
KoalaLanguageHelper.setLanguage(this.language);
|
|
84
|
+
this.initOAuth2();
|
|
85
|
+
if (this.openPages) {
|
|
86
|
+
if (this.openPages.indexOf('/') < 0) {
|
|
87
|
+
this.openPages.push('/');
|
|
88
|
+
}
|
|
89
|
+
if (this.openPages.indexOf('/login') < 0) {
|
|
90
|
+
this.openPages.push('/login');
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
this.openPages = [
|
|
95
|
+
'/',
|
|
96
|
+
'/login'
|
|
97
|
+
];
|
|
98
|
+
}
|
|
99
|
+
this.tokenService.getToken()?.subscribe(token => {
|
|
100
|
+
this.logged$.next(!!token);
|
|
101
|
+
if (this.logged$.getValue()) {
|
|
102
|
+
const decodedToken = this.tokenService.getDecodedToken();
|
|
103
|
+
this.username$.next(decodedToken.login);
|
|
104
|
+
this.firstUserLetter$.next(decodedToken.login.charAt(0).toUpperCase());
|
|
105
|
+
if (!this.isMobile) {
|
|
106
|
+
this.menuService.open();
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
if (this.logged$.getValue() && this.openPages?.indexOf(this.currentUrl) >= 0 && this.defaultPage) {
|
|
110
|
+
this.router.navigate([this.defaultPage]).then();
|
|
111
|
+
}
|
|
112
|
+
else if (!this.logged$.getValue() && this.currentUrl && this.openPages?.indexOf(this.currentUrl) < 0) {
|
|
113
|
+
this.router.navigate(['login']).then();
|
|
114
|
+
return false;
|
|
115
|
+
}
|
|
116
|
+
});
|
|
117
|
+
this.router.events.subscribe(event => {
|
|
118
|
+
switch (true) {
|
|
119
|
+
case event instanceof NavigationStart: {
|
|
120
|
+
this.loaderService.create({ typeLoader: 'indeterminate' });
|
|
121
|
+
break;
|
|
122
|
+
}
|
|
123
|
+
case event instanceof NavigationEnd:
|
|
124
|
+
case event instanceof NavigationCancel:
|
|
125
|
+
case event instanceof NavigationError: {
|
|
126
|
+
this.loaderService.dismiss();
|
|
127
|
+
if (event instanceof NavigationEnd) {
|
|
128
|
+
if (this.isMobile) {
|
|
129
|
+
this.menuService.close();
|
|
130
|
+
}
|
|
131
|
+
this.currentUrl = event.url.split('?')[0];
|
|
132
|
+
if (event.url.indexOf('/login?clientId=') < 0) {
|
|
133
|
+
if (this.logged$.getValue() && this.defaultPage && this.openPages?.indexOf(this.currentUrl) >= 0) {
|
|
134
|
+
this.router.navigate([this.defaultPage]).then();
|
|
135
|
+
return false;
|
|
136
|
+
}
|
|
137
|
+
else if (!this.logged$.getValue() && this.openPages?.indexOf(this.currentUrl) < 0) {
|
|
138
|
+
this.router.navigate(['login']).then();
|
|
139
|
+
return false;
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
break;
|
|
144
|
+
}
|
|
145
|
+
default: {
|
|
146
|
+
break;
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
});
|
|
150
|
+
if (this.palletColors) {
|
|
151
|
+
Object.keys(this.defaultPalletColors).forEach(indexName => {
|
|
152
|
+
if (!this.palletColors.hasOwnProperty(indexName) ||
|
|
153
|
+
!this.palletColors[indexName]) {
|
|
154
|
+
this.palletColors[indexName] = this.defaultPalletColors[indexName];
|
|
155
|
+
}
|
|
156
|
+
});
|
|
157
|
+
}
|
|
158
|
+
else {
|
|
159
|
+
this.palletColors = this.defaultPalletColors;
|
|
160
|
+
}
|
|
161
|
+
this.defineColor();
|
|
162
|
+
if (this.showMenu) {
|
|
163
|
+
menuStateSubject.subscribe(async (state) => {
|
|
164
|
+
if (this.menu) {
|
|
165
|
+
if (state === 'close') {
|
|
166
|
+
if (this.menu.opened) {
|
|
167
|
+
await this.menu.close();
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
else if (state === 'open') {
|
|
171
|
+
if (!this.menu.opened) {
|
|
172
|
+
await this.menu.open();
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
});
|
|
177
|
+
if (this.startMenuOpened && this.logged$.getValue()) {
|
|
178
|
+
if (!this.isMobile) {
|
|
179
|
+
this.menuService.open();
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
else {
|
|
183
|
+
this.menuService.close();
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
else {
|
|
187
|
+
this.menuService.close();
|
|
188
|
+
}
|
|
189
|
+
this.validationScope$.subscribe(scope => this.validatingScope.emit(scope));
|
|
190
|
+
}
|
|
191
|
+
async toogleMenu() {
|
|
192
|
+
this.menuService.clearConfig();
|
|
193
|
+
if (this.menu) {
|
|
194
|
+
await this.menu.toggle();
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
async logout() {
|
|
198
|
+
if (KoalaEnvironment.environment?.oauthConfig) {
|
|
199
|
+
this.oauth2Service.logout();
|
|
200
|
+
}
|
|
201
|
+
this.menuService.close();
|
|
202
|
+
this.tokenService.removeToken();
|
|
203
|
+
this.tokenService.getToken().next(null);
|
|
204
|
+
this.logoutEmitter.emit(true);
|
|
205
|
+
}
|
|
206
|
+
defineColor() {
|
|
207
207
|
const css = `
|
|
208
208
|
*::-webkit-scrollbar-thumb {background: ${this.palletColors.scrollbarColor};width: 2px;}
|
|
209
209
|
*::-webkit-scrollbar-thumb:hover {background: ${this.palletColors.scrollbarColorHover};}
|
|
@@ -306,99 +306,99 @@ koala-menu ul li li.active a koala-icon * {fill: ${this.palletColors.menuOptions
|
|
|
306
306
|
.mat-table {background: ${this.palletColors.listBackground};color: ${this.palletColors.fontColor};}
|
|
307
307
|
.mat-table th {color: ${this.palletColors.listTitleItemColor}!important;}
|
|
308
308
|
.mat-sort-header-arrow {color: ${this.palletColors.listItemColor}!important;}
|
|
309
|
-
.mat-table td {color: ${this.palletColors.listItemColor}!important;}`;
|
|
310
|
-
const head = document.head || document.getElementsByTagName('head')[0];
|
|
311
|
-
const style = document.createElement('style');
|
|
312
|
-
head.appendChild(style);
|
|
313
|
-
style.appendChild(document.createTextNode(css));
|
|
314
|
-
}
|
|
315
|
-
initOAuth2() {
|
|
316
|
-
KoalaOauthConfig.config.subscribe(config => this.startConfig(config));
|
|
317
|
-
if (KoalaOauthConfig.hasConfig()) {
|
|
318
|
-
KoalaOauthConfig.setConfig(KoalaOauthConfig.getConfig());
|
|
319
|
-
}
|
|
320
|
-
}
|
|
321
|
-
startConfig(config) {
|
|
322
|
-
if (config.clientId) {
|
|
323
|
-
this.oauth2Service.configure({
|
|
324
|
-
redirectUri: window.location.origin,
|
|
325
|
-
redirectUriAfterAuth: this.defaultPage,
|
|
326
|
-
responseType: 'code',
|
|
327
|
-
clientId: config.clientId,
|
|
328
|
-
scope: config.scope,
|
|
329
|
-
issuer: config.domain,
|
|
330
|
-
customQueryParams: config.customQueryParams,
|
|
331
|
-
endpointToken: config.endpointToken ?? null,
|
|
332
|
-
endpointClaims: config.endpointClaims ?? null
|
|
333
|
-
});
|
|
334
|
-
this.oauth2Service.loadDiscoveryDocumentAndTryLogin().then();
|
|
335
|
-
if (this.oauthEventsSubscription) {
|
|
336
|
-
this.oauthEventsSubscription.unsubscribe();
|
|
337
|
-
}
|
|
338
|
-
this.oauthEventsSubscription = this.oauth2Service.events.subscribe(event => {
|
|
339
|
-
if (event === 'userAuthenticated' || event === 'refreshToken') {
|
|
340
|
-
const claims = this.oauth2Service.getIdentityClaims();
|
|
341
|
-
if (claims && (!TokenFactory.hasToken() ||
|
|
342
|
-
(TokenFactory.hasToken() && event === 'refreshToken'))) {
|
|
343
|
-
this.tokenService.setToken(jwtEncode({
|
|
344
|
-
accessToken: this.oauth2Service.getAccessToken(),
|
|
345
|
-
idToken: this.oauth2Service.getIdToken(),
|
|
346
|
-
refreshToken: this.oauth2Service.getRefreshToken(),
|
|
347
|
-
login: claims[config.indexLoginName] ?? 'Undefined',
|
|
348
|
-
expired: this.oauth2Service.getAccessTokenExpiration(),
|
|
349
|
-
code: this.oauth2Service.getCode()
|
|
350
|
-
}, 'secret'));
|
|
351
|
-
}
|
|
352
|
-
if (event === 'userAuthenticated') {
|
|
353
|
-
setTimeout(() => this.validationScope$.next(false), 300);
|
|
354
|
-
}
|
|
355
|
-
}
|
|
356
|
-
else if (event === 'getToken') {
|
|
357
|
-
this.validationScope$.next(true);
|
|
358
|
-
}
|
|
359
|
-
});
|
|
360
|
-
}
|
|
361
|
-
}
|
|
362
|
-
}
|
|
363
|
-
PageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.
|
|
364
|
-
PageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.
|
|
365
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.
|
|
366
|
-
type: Component,
|
|
367
|
-
args: [{ selector: 'koala-page', providers: [KoalaTokenService], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngIf=\"showLoaderPage | async\" class=\"koala-loader-pg\">\n <div class=\"loader-content\">\n <figure>\n <img [src]=\"logo\" alt=\"Logotipo\"/>\n <figcaption *ngIf=\"(messageLoaderPage | async) as messageLoader\" [innerHTML]=\"messageLoader\"></figcaption>\n </figure>\n <mat-spinner></mat-spinner>\n </div>\n</div>\n<app-loader-page *ngIf=\"(loaderSubject | async) as loader\" [progress]=\"loader.progress\" [show]=\"loader.show\"\n [typeLoader]=\"loader.typeLoader\"></app-loader-page>\n<mat-drawer-container autosize class=\"menu-container\">\n <mat-drawer #drawer class=\"menu-options\" [mode]=\"isMobile ? 'push' : 'side'\">\n <img [src]=\"logo\" alt=\"Logotipo\" id=\"logotipo\"/>\n <ng-content *ngIf=\"showMenu\" select=\"[menu-options]\"></ng-content>\n </mat-drawer>\n\n <mat-toolbar *ngIf=\"!!(logged$ | async) && (username$ | async)\" class=\"toolbar\">\n <img *ngIf=\"!showMenu\" [src]=\"logo\" alt=\"Logotipo Toolbar\" id=\"logotipo-toolbar\"/>\n <button (click)=\"toogleMenu()\" *ngIf=\"showMenu\" [color]=\"color\" class=\"btn-collapse-menu\" mat-icon-button>\n <mat-icon>menu</mat-icon>\n </button>\n <span class=\"spacer\"></span>\n\t <div class=\"menu-toolbar\">\n\t\t <ng-content select=\"[menu-toolbar]\"></ng-content>\n\t </div>\n <div *ngIf=\"(notifications | async) as notificationList\">\n <button *ngIf=\"notifications\" [color]=\"color\" [matMenuTriggerFor]=\"notificationsMenu\" class=\"btn-toolbar\"\n mat-icon-button>\n <mat-icon\n\t [matBadgeHidden]=\"notificationList.length === 0\"\n\t [matBadge]=\"notificationList.length.toString()\"\n\t matBadgeColor=\"warn\">notifications\n </mat-icon>\n </button>\n <mat-menu #notificationsMenu=\"matMenu\" class=\"menu-list\" yPosition=\"below\">\n <koala-notification-list\n (delete)=\"deleteNotification.emit($event)\"\n (deleteAll)=\"deleteAllNotifications.emit($event)\"\n [notifications]=\"notificationList\">\n </koala-notification-list>\n </mat-menu>\n </div>\n <button [color]=\"color\" [matMenuTriggerFor]=\"userOptions\" class=\"btn-toolbar\" mat-button>\n <span>{{username$ | async}}</span>\n <span class=\"icon-user\">{{firstUserLetter$ | async}}</span>\n </button>\n <mat-menu #userOptions=\"matMenu\" class=\"user-menu menu-list\" yPosition=\"below\">\n <div class=\"user-presentation\">\n <span class=\"icon-user\">{{firstUserLetter$ | async}}</span><br/>\n <span class=\"username\">{{username$ | async}}</span>\n </div>\n <button (click)=\"btn.action()\" *ngFor=\"let btn of userMenuOptions\" mat-menu-item>\n <mat-icon>{{btn.icon}}</mat-icon>\n <span>{{btn.name}}</span>\n </button>\n <button (click)=\"logout()\" mat-menu-item>\n <mat-icon>exit_to_app</mat-icon>\n <span>{{language === 'ptBr' ? 'Sair' : 'Logout'}}</span>\n </button>\n </mat-menu>\n </mat-toolbar>\n\n <ng-content class=\"page-content\" select=\"[page-content]\"></ng-content>\n\n</mat-drawer-container>\n\n<ng-content class=\"loading-info-content\" select=\"[loading-info-content]\"></ng-content>\n", styles: [".menu-container{height:100vh;width:100vw}.menu-options{border:none;padding:20px 0 0;width:250px}.page-content{align-items:center;display:flex;height:100%;justify-content:center}img#logotipo,img#logotipo-toolbar{display:block;height:auto;margin:0 auto 25px;position:relative;width:120px}.toolbar{box-shadow:none;padding:0 7px 0 13px}.toolbar img#logotipo-toolbar{margin:0;padding:0 10px}.menu-toolbar{margin:0 10px}.spacer{flex:1 1 auto}.btn-toolbar{display:inline-block;margin-right:10px;position:relative}.btn-toolbar span{padding:0 10px 0 0}.btn-toolbar span.icon-user,.user-presentation span.icon-user{border-radius:50%;display:inline-block;height:10px;line-height:10px;padding:5px;width:10px}.user-presentation{min-width:260px;padding:50px 10px;text-align:center}.user-presentation span.icon-user{font-size:30px;height:30px;line-height:30px;margin-bottom:10px;width:30px}.user-presentation span.username{font-family:OpenSansLight,sans-serif;word-break:break-all}@media (max-width: 900px){.btn-toolbar span:first-child{display:none}.btn-toolbar span.icon-user,.user-presentation span.icon-user{height:20px;line-height:20px;width:20px}}\n"] }]
|
|
368
|
-
}], ctorParameters: function () { return [{ type: i1.KoalaTokenService }, { type: i2.Router }, { type: i3.KoalaLoaderService }, { type: i4.KoalaMenuService }, { type: i5.KoalaOAuth2Service }, { type: i6.DeviceDetectorService }]; }, propDecorators: { showMenu: [{
|
|
369
|
-
type: Input
|
|
370
|
-
}], color: [{
|
|
371
|
-
type: Input
|
|
372
|
-
}], logo: [{
|
|
373
|
-
type: Input
|
|
374
|
-
}], startMenuOpened: [{
|
|
375
|
-
type: Input
|
|
376
|
-
}], showLoaderPage: [{
|
|
377
|
-
type: Input
|
|
378
|
-
}], messageLoaderPage: [{
|
|
379
|
-
type: Input
|
|
380
|
-
}], defaultPage: [{
|
|
381
|
-
type: Input
|
|
382
|
-
}], openPages: [{
|
|
383
|
-
type: Input
|
|
384
|
-
}], notifications: [{
|
|
385
|
-
type: Input
|
|
386
|
-
}], userMenuOptions: [{
|
|
387
|
-
type: Input
|
|
388
|
-
}], palletColors: [{
|
|
389
|
-
type: Input
|
|
390
|
-
}], language: [{
|
|
391
|
-
type: Input
|
|
392
|
-
}], validatingScope: [{
|
|
393
|
-
type: Output
|
|
394
|
-
}], logoutEmitter: [{
|
|
395
|
-
type: Output
|
|
396
|
-
}], deleteAllNotifications: [{
|
|
397
|
-
type: Output
|
|
398
|
-
}], deleteNotification: [{
|
|
399
|
-
type: Output
|
|
400
|
-
}], menu: [{
|
|
401
|
-
type: ViewChild,
|
|
402
|
-
args: ['drawer', { static: true }]
|
|
403
|
-
}] } });
|
|
404
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page.component.js","sourceRoot":"","sources":["../../../../../projects/core/src/lib/page/page.component.ts","../../../../../projects/core/src/lib/page/page.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\nimport { ThemePalette } from '@angular/material/core';\nimport { NavigationCancel, NavigationEnd, NavigationError, NavigationStart, Router } from '@angular/router';\nimport { LoaderBarPageInterface } from '../loader/loader-bar-page.interface';\nimport { BehaviorSubject, Subscription } from 'rxjs';\nimport { KoalaTokenService } from '../services/token/koala.token.service';\nimport { KoalaLoaderService } from '../services/loader/koala.loader.service';\nimport { KoalaNotificationInterface } from './notifications/koala.notification.interface';\nimport { KoalaUserMenuOptionsInterface } from './koala.user-menu-options.interface';\nimport { KoalaPagePalletColorsInterface } from './koala-page-pallet-colors.interface';\nimport { MatDrawer } from '@angular/material/sidenav';\nimport { KoalaMenuService, menuStateSubject } from '@koalarx/ui/menu';\nimport jwtEncode from \"jwt-encode\";\nimport { TokenFactory } from \"../services/token/token.factory\";\nimport { KoalaOAuth2Service } from \"../services/openid/koala.oauth2.service\";\nimport { KoalaEnvironment } from \"../environments/koalaEnvironment\";\nimport { KoalaOauthConfig } from \"../services/openid/koala.oauth.config\";\nimport { KoalaOauth2ConfigInterface } from \"../services/openid/koala-oauth2-config.interface\";\nimport { KoalaLanguageHelper, KoalaLanguageType } from \"./koala-language.helper\";\nimport { DeviceDetectorService } from \"ngx-device-detector\";\n\n@Component({\n  selector: 'koala-page',\n  templateUrl: 'page.component.html',\n  styleUrls: ['page.component.css'],\n  providers: [KoalaTokenService],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PageComponent implements OnInit {\n  @Input() showMenu: boolean = true;\n  @Input() color: ThemePalette;\n  @Input() logo: string;\n  @Input() startMenuOpened = true;\n  @Input() showLoaderPage: BehaviorSubject<boolean>;\n  @Input() messageLoaderPage: BehaviorSubject<string>;\n  @Input() defaultPage: string;\n  @Input() openPages: string[];\n  @Input() notifications: BehaviorSubject<KoalaNotificationInterface[]>;\n  @Input() userMenuOptions: KoalaUserMenuOptionsInterface[] = [];\n  @Input() palletColors: KoalaPagePalletColorsInterface;\n  @Input() language: KoalaLanguageType = 'ptBr';\n  @Output() validatingScope = new EventEmitter<boolean>(false);\n  @Output() logoutEmitter = new EventEmitter<boolean>(false);\n  @Output() deleteAllNotifications = new EventEmitter<boolean>(false);\n  @Output() deleteNotification = new EventEmitter<KoalaNotificationInterface>(null);\n\n  public loaderSubject: BehaviorSubject<LoaderBarPageInterface>;\n  public username$ = new BehaviorSubject<string>('');\n  public firstUserLetter$ = new BehaviorSubject<string>('');\n  public currentUrl: string;\n  public logged$ = new BehaviorSubject<boolean>(false);\n  public validationScope$ = new BehaviorSubject<boolean>(false);\n  public isMobile: boolean = this.deviceService.isMobile();\n\n  private defaultPalletColors: KoalaPagePalletColorsInterface = {\n    scrollbarColor: '#1976D2',\n    scrollbarColorHover: '#1565C0',\n    userPresentationBackground: '#f1f1f1',\n    userPresentationUserBackground: '#1976D2',\n    userPresentationUserFontColor: '#fff',\n    firstColor: '#fff',\n    secondColor: '#F1F1F1',\n    bodyBackground: '#eeeeee',\n    checkboxBackground: '#1976d2',\n    checkboxColor: '#ffffff',\n    fontColor: '#1976D2',\n    fontHoverColor: '#1976D2',\n    fontActiveColor: '#1565C0',\n    menuTitleBackground: 'rgba(0,0,0,.1)',\n    menuTitleColor: 'rgba(0,0,0,.3)',\n    menuBackground: '#fafafa',\n    menuOptionsBackground: '#eaeaea',\n    menuOptionsColor: '#a5a5a5',\n    menuOptionsColorHover: '#1976D2',\n    menuOptionsColorActive: '#1565c0',\n    toolbarBackground: '#ffffff',\n    toolbarColor: '#1976d2',\n    listBackground: '#fff',\n    listContentBackground: '#fff',\n    listTitleItemColor: '#838383',\n    listItemColor: '#3e3e3e',\n    listItemBackgroudHover: '#F1F1F1',\n    listItemBackgroundActive: '#EEE',\n    shadowColorTableList: 'rgba(25, 118, 210, .4)'\n  };\n  private oauthEventsSubscription: Subscription;\n\n  @ViewChild('drawer', {static: true}) private menu: MatDrawer;\n\n  constructor(\n    private tokenService: KoalaTokenService,\n    private router: Router,\n    private loaderService: KoalaLoaderService,\n    private menuService: KoalaMenuService,\n    private oauth2Service: KoalaOAuth2Service,\n    private deviceService: DeviceDetectorService,\n  ) {\n    this.loaderSubject = loaderService.getLoaderSubject();\n  }\n\n  ngOnInit() {\n    KoalaLanguageHelper.setLanguage(this.language);\n    this.initOAuth2();\n    if (this.openPages) {\n      if (this.openPages.indexOf('/') < 0) {\n        this.openPages.push('/');\n      }\n      if (this.openPages.indexOf('/login') < 0) {\n        this.openPages.push('/login');\n      }\n    } else {\n      this.openPages = [\n        '/',\n        '/login'\n      ];\n    }\n\n    this.tokenService.getToken()?.subscribe(token => {\n      this.logged$.next(!!token);\n      if (this.logged$.getValue()) {\n        const decodedToken = this.tokenService.getDecodedToken<{ login: string }>();\n        this.username$.next(decodedToken.login);\n        this.firstUserLetter$.next(decodedToken.login.charAt(0).toUpperCase());\n        if (!this.isMobile) {\n          this.menuService.open();\n        }\n      }\n      if (this.logged$.getValue() && this.openPages?.indexOf(this.currentUrl) >= 0 && this.defaultPage) {\n        this.router.navigate([this.defaultPage]).then();\n      } else if (!this.logged$.getValue() && this.currentUrl && this.openPages?.indexOf(this.currentUrl) < 0) {\n        this.router.navigate(['login']).then();\n        return false;\n      }\n    });\n    this.router.events.subscribe(event => {\n      switch (true) {\n        case event instanceof NavigationStart: {\n          this.loaderService.create({typeLoader: 'indeterminate'});\n          break;\n        }\n\n        case event instanceof NavigationEnd:\n        case event instanceof NavigationCancel:\n        case event instanceof NavigationError: {\n          this.loaderService.dismiss();\n          if (event instanceof NavigationEnd) {\n            if (this.isMobile) {\n              this.menuService.close();\n            }\n\n            this.currentUrl = event.url.split('?')[0];\n\n            if (event.url.indexOf('/login?clientId=') < 0) {\n              if (this.logged$.getValue() && this.defaultPage && this.openPages?.indexOf(this.currentUrl) >= 0) {\n                this.router.navigate([this.defaultPage]).then();\n                return false;\n              } else if (!this.logged$.getValue() && this.openPages?.indexOf(this.currentUrl) < 0) {\n                this.router.navigate(['login']).then();\n                return false;\n              }\n            }\n          }\n          break;\n        }\n        default: {\n          break;\n        }\n      }\n    });\n    if (this.palletColors) {\n      Object.keys(this.defaultPalletColors).forEach(indexName => {\n        if (\n          !this.palletColors.hasOwnProperty(indexName) ||\n          !this.palletColors[indexName]\n        ) {\n          this.palletColors[indexName] = this.defaultPalletColors[indexName];\n        }\n      });\n    } else {\n      this.palletColors = this.defaultPalletColors;\n    }\n    this.defineColor();\n\n    if (this.showMenu) {\n      menuStateSubject.subscribe(async (state) => {\n        if (this.menu) {\n          if (state === 'close') {\n            if (this.menu.opened) {\n              await this.menu.close();\n            }\n          } else if (state === 'open') {\n            if (!this.menu.opened) {\n              await this.menu.open();\n            }\n          }\n        }\n      });\n      if (this.startMenuOpened && this.logged$.getValue()) {\n        if (!this.isMobile) {\n          this.menuService.open();\n        }\n      } else {\n        this.menuService.close();\n      }\n    } else {\n      this.menuService.close();\n    }\n\n    this.validationScope$.subscribe(scope => this.validatingScope.emit(scope));\n  }\n\n  public async toogleMenu() {\n    this.menuService.clearConfig();\n    if (this.menu) {\n      await this.menu.toggle();\n    }\n  }\n\n  public async logout() {\n    if (KoalaEnvironment.environment?.oauthConfig) {\n      this.oauth2Service.logout();\n    }\n    this.menuService.close();\n    this.tokenService.removeToken();\n    this.tokenService.getToken().next(null);\n    this.logoutEmitter.emit(true);\n  }\n\n  public defineColor() {\n    const css = `\n*::-webkit-scrollbar-thumb {background: ${this.palletColors.scrollbarColor};width: 2px;}\n*::-webkit-scrollbar-thumb:hover {background: ${this.palletColors.scrollbarColorHover};}\ninput:-webkit-autofill, input:-webkit-autofill:focus, input:-webkit-autofill:hover {color: ${this.palletColors.fontColor}!important;}\n.menu-container,\nbody {background: ${this.palletColors.bodyBackground}!important;}\ninput:-webkit-autofill, input:-webkit-autofill:focus, input:-webkit-autofill:hover {-webkit-box-shadow: 0 0 0 1000px ${this.palletColors.firstColor} inset !important;}\n.mat-button-disabled,\ninput::placeholder,\n.mat-form-field-appearance-outline .mat-form-field-outline {color: ${this.palletColors.fontColor}!important;opacity: .6;}\n.mat-hint,\n.mat-expansion-indicator::after,\n.more-items-content .items .titleForm,\nfieldset legend,\n.mat-paginator-container,\n.mat-form-field-flex mat-icon {color: ${this.palletColors.fontColor}!important;}\n.mat-paginator-container,\n.mat-card,\n.mat-expansion-panel,\n.mat-select-panel,\n.mat-autocomplete-panel,\n.mat-menu-panel {background: ${this.palletColors.firstColor}}\n.mat-selected {background-color: rgba(0,0,0,.3)!important;}\n.question p,\n.alert-message,\n.mat-action-row,\n.mat-option,\n.mat-menu-item,\n.mat-menu-item mat-icon {color: ${this.palletColors.fontColor}!important}\n.mat-select-value,\n.mat-select-arrow,\n.mat-form-field input,\n.mat-form-field textarea,\n.mat-form-field-appearance-outline:not(.mat-form-field-invalid) .mat-form-field-outline-thick,\n.mat-form-field label,\n.select-multiple-native select {color: ${this.palletColors.fontColor}!important;caret-color: ${this.palletColors.fontColor}!important;}\n.mat-form-field-underline,\n.mat-form-field-appearance-fill .mat-form-field-underline::before,\n.mat-form-field-ripple {background: ${this.palletColors.fontColor}!important;}\n.mat-checkbox-checked.mat-accent .mat-checkbox-background, .mat-checkbox-indeterminate.mat-accent .mat-checkbox-background,\n.mat-checkbox:not(.mat-checkbox-disabled).mat-accent .mat-checkbox-ripple .mat-ripple-element {background-color: ${this.palletColors.checkboxBackground} !important;}\n.mat-checkbox-checkmark-path {stroke: ${this.palletColors.checkboxColor} !important;}\n.mat-checkbox-checkmark {fill: ${this.palletColors.checkboxColor} !important;}\n.mat-checkbox-mixedmark {background-color: ${this.palletColors.checkboxColor} !important;}\n.mat-checkbox-frame {border-color: ${this.palletColors.checkboxOutlineColor}!important;}\n.mat-checkbox-label {color: ${this.palletColors.fontColor}!important;}\n.mat-radio-outer-circle {border-color: ${this.palletColors.checkboxBackground}!important;}\n.mat-radio-ripple .mat-ripple-element, .mat-radio-inner-circle {background-color: ${this.palletColors.checkboxBackground} !important;}\n.home-list-cards .list .mat-list-item-content .mat-icon {color: ${this.palletColors.fontColor};}\n.home-list-cards .list button .mat-badge-content {background: ${this.palletColors.fontColor};}\n.koala-dialog .mat-dialog-title h2 {color: ${this.palletColors.fontColor};}\n.koala-dialog .mat-dialog-title mat-icon {color: ${this.palletColors.fontColor}!important;}\n.koala-dialog .mat-dialog-container {background: ${this.palletColors.firstColor}}\n.list-filter mat-icon {color: ${this.palletColors.filterIconColor}!important;}\nkoala-page .menu-options {background: ${this.palletColors.menuBackground};}\nkoala-page .toolbar {background: ${this.palletColors.toolbarBackground};}\nkoala-page .toolbar .btn-collapse-menu,\nkoala-page .btn-toolbar span{color: ${this.palletColors.toolbarColor};}\nkoala-page .btn-toolbar span.icon-user,\n.user-presentation span.icon-user {background: ${this.palletColors.userPresentationUserBackground};color: ${this.palletColors.userPresentationUserFontColor};}\n.user-presentation {background: ${this.palletColors.userPresentationBackground};}\n.user-presentation span.username {color: ${this.palletColors.toolbarColor};}\n.mat-drawer.mat-drawer-push {background-color: ${this.palletColors.bodyBackground};}\nkoala-menu .title {background: ${this.palletColors.menuTitleBackground};color: ${this.palletColors.menuTitleColor};}\nkoala-menu ul li,\nkoala-menu ul li a {color: ${this.palletColors.menuOptionsColor};}\nkoala-menu ul li:hover,\nkoala-menu ul li:hover a {color: ${this.palletColors.menuOptionsColorHover} !important;}\nkoala-menu ul li.active,\nkoala-menu ul li.expanded {color: ${this.palletColors.menuOptionsColorActive} !important;border-left: 4px solid ${this.palletColors.menuOptionsColorActive} !important;background: ${this.palletColors.menuOptionsBackground} !important;}\nkoala-menu ul li.active a,\nkoala-menu ul li.expanded a {color: ${this.palletColors.menuOptionsColorActive} !important;background: ${this.palletColors.menuOptionsBackground} !important;}\nkoala-menu ul li li:hover,\nkoala-menu ul li li:hover a {color: ${this.palletColors.menuOptionsColorHover} !important;}\nkoala-menu ul li li.active,\nkoala-menu ul li li.active a {color: ${this.palletColors.menuOptionsColorActive} !important;}\nkoala-menu ul li koala-icon svg *,\nkoala-menu ul li a koala-icon svg * {fill: ${this.palletColors.menuOptionsColor};}\nkoala-menu ul li:hover koala-icon svg *,\nkoala-menu ul li:hover a koala-icon svg * {fill: ${this.palletColors.menuOptionsColorHover} !important;}\nkoala-menu ul li.active koala-icon *,\nkoala-menu ul li.expanded koala-icon * {fill: ${this.palletColors.menuOptionsColorActive} !important;}\nkoala-menu ul li li:hover koala-icon *,\nkoala-menu ul li li:hover a koala-icon * {fill: ${this.palletColors.menuOptionsColorHover} !important;}\nkoala-menu ul li li.active koala-icon *,\nkoala-menu ul li li.active a koala-icon * {fill: ${this.palletColors.menuOptionsColorActive}!important;}\n.notifications-content .title {color: ${this.palletColors.notificationTitleColor}!important;}\n.notifications-content .empty,\n.notifications-content .titleList {color: ${this.palletColors.notificationContentTitleColor}!important;}\n.notifications-content .iconList {color: ${this.palletColors.notificationContentIconColor}!important;}\n.notifications-content .textList {color: ${this.palletColors.notificationTitleColor}!important;}\n.list-container {box-shadow: 0 1px 3px ${this.palletColors.shadowColorTableList};}\n.list-container .list table.table-hover tr:hover {background: ${this.palletColors.listItemBackgroudHover};}\n.list-container .list table.table-hover tr:active {background: ${this.palletColors.listItemBackgroundActive};}\n.list-container .list-filter .advanced {background: ${this.palletColors.firstColor};}\n.list-container nav.menu-list {background: ${this.palletColors.firstColor};color: rgba(25, 118, 210, .3);}\n.content {background: ${this.palletColors.listContentBackground};}\n.mat-tab-group .mat-tab-label {color: ${this.palletColors.fontColor};}\n.mat-tab-group .mat-ink-bar {background-color: ${this.palletColors.fontColor}!important;}\n.mat-table {background: ${this.palletColors.listBackground};color: ${this.palletColors.fontColor};}\n.mat-table th {color: ${this.palletColors.listTitleItemColor}!important;}\n.mat-sort-header-arrow {color: ${this.palletColors.listItemColor}!important;}\n.mat-table td {color: ${this.palletColors.listItemColor}!important;}`;\n    const head = document.head || document.getElementsByTagName('head')[0];\n    const style = document.createElement('style');\n    head.appendChild(style);\n    style.appendChild(document.createTextNode(css));\n  }\n\n  private initOAuth2() {\n    KoalaOauthConfig.config.subscribe(config => this.startConfig(config));\n    if (KoalaOauthConfig.hasConfig()) {\n      KoalaOauthConfig.setConfig(KoalaOauthConfig.getConfig());\n    }\n  }\n\n  private startConfig(config: KoalaOauth2ConfigInterface) {\n    if (config.clientId) {\n      this.oauth2Service.configure({\n        redirectUri: window.location.origin,\n        redirectUriAfterAuth: this.defaultPage,\n        responseType: 'code',\n        clientId: config.clientId,\n        scope: config.scope,\n        issuer: config.domain,\n        customQueryParams: config.customQueryParams,\n        endpointToken: config.endpointToken ?? null,\n        endpointClaims: config.endpointClaims ?? null\n      });\n      this.oauth2Service.loadDiscoveryDocumentAndTryLogin().then();\n\n      if (this.oauthEventsSubscription) {\n        this.oauthEventsSubscription.unsubscribe();\n      }\n      this.oauthEventsSubscription = this.oauth2Service.events.subscribe(event => {\n        if (event === 'userAuthenticated' || event === 'refreshToken') {\n          const claims = this.oauth2Service.getIdentityClaims();\n          if (claims && (\n            !TokenFactory.hasToken() ||\n            (TokenFactory.hasToken() && event === 'refreshToken')\n          )) {\n            this.tokenService.setToken(jwtEncode({\n              accessToken: this.oauth2Service.getAccessToken(),\n              idToken: this.oauth2Service.getIdToken(),\n              refreshToken: this.oauth2Service.getRefreshToken(),\n              login: claims[config.indexLoginName] ?? 'Undefined',\n              expired: this.oauth2Service.getAccessTokenExpiration(),\n              code: this.oauth2Service.getCode()\n            }, 'secret'))\n          }\n\n          if (event === 'userAuthenticated') {\n            setTimeout(() => this.validationScope$.next(false), 300);\n          }\n        } else if (event === 'getToken') {\n          this.validationScope$.next(true);\n        }\n      });\n    }\n  }\n}\n","<div *ngIf=\"showLoaderPage | async\" class=\"koala-loader-pg\">\n  <div class=\"loader-content\">\n    <figure>\n      <img [src]=\"logo\" alt=\"Logotipo\"/>\n      <figcaption *ngIf=\"(messageLoaderPage | async) as messageLoader\" [innerHTML]=\"messageLoader\"></figcaption>\n    </figure>\n    <mat-spinner></mat-spinner>\n  </div>\n</div>\n<app-loader-page *ngIf=\"(loaderSubject | async) as loader\" [progress]=\"loader.progress\" [show]=\"loader.show\"\n                 [typeLoader]=\"loader.typeLoader\"></app-loader-page>\n<mat-drawer-container autosize class=\"menu-container\">\n  <mat-drawer #drawer class=\"menu-options\" [mode]=\"isMobile ? 'push' : 'side'\">\n    <img [src]=\"logo\" alt=\"Logotipo\" id=\"logotipo\"/>\n    <ng-content *ngIf=\"showMenu\" select=\"[menu-options]\"></ng-content>\n  </mat-drawer>\n\n  <mat-toolbar *ngIf=\"!!(logged$ | async) && (username$ | async)\" class=\"toolbar\">\n    <img *ngIf=\"!showMenu\" [src]=\"logo\" alt=\"Logotipo Toolbar\" id=\"logotipo-toolbar\"/>\n    <button (click)=\"toogleMenu()\" *ngIf=\"showMenu\" [color]=\"color\" class=\"btn-collapse-menu\" mat-icon-button>\n      <mat-icon>menu</mat-icon>\n    </button>\n    <span class=\"spacer\"></span>\n\t  <div class=\"menu-toolbar\">\n\t\t  <ng-content select=\"[menu-toolbar]\"></ng-content>\n\t  </div>\n    <div *ngIf=\"(notifications | async) as notificationList\">\n      <button *ngIf=\"notifications\" [color]=\"color\" [matMenuTriggerFor]=\"notificationsMenu\" class=\"btn-toolbar\"\n              mat-icon-button>\n        <mat-icon\n\t        [matBadgeHidden]=\"notificationList.length === 0\"\n\t        [matBadge]=\"notificationList.length.toString()\"\n\t        matBadgeColor=\"warn\">notifications\n        </mat-icon>\n      </button>\n      <mat-menu #notificationsMenu=\"matMenu\" class=\"menu-list\" yPosition=\"below\">\n        <koala-notification-list\n          (delete)=\"deleteNotification.emit($event)\"\n          (deleteAll)=\"deleteAllNotifications.emit($event)\"\n          [notifications]=\"notificationList\">\n        </koala-notification-list>\n      </mat-menu>\n    </div>\n    <button [color]=\"color\" [matMenuTriggerFor]=\"userOptions\" class=\"btn-toolbar\" mat-button>\n      <span>{{username$ | async}}</span>\n      <span class=\"icon-user\">{{firstUserLetter$ | async}}</span>\n    </button>\n    <mat-menu #userOptions=\"matMenu\" class=\"user-menu menu-list\" yPosition=\"below\">\n      <div class=\"user-presentation\">\n        <span class=\"icon-user\">{{firstUserLetter$ | async}}</span><br/>\n        <span class=\"username\">{{username$ | async}}</span>\n      </div>\n      <button (click)=\"btn.action()\" *ngFor=\"let btn of userMenuOptions\" mat-menu-item>\n        <mat-icon>{{btn.icon}}</mat-icon>\n        <span>{{btn.name}}</span>\n      </button>\n      <button (click)=\"logout()\" mat-menu-item>\n        <mat-icon>exit_to_app</mat-icon>\n        <span>{{language === 'ptBr' ? 'Sair' : 'Logout'}}</span>\n      </button>\n    </mat-menu>\n  </mat-toolbar>\n\n  <ng-content class=\"page-content\" select=\"[page-content]\"></ng-content>\n\n</mat-drawer-container>\n\n<ng-content class=\"loading-info-content\" select=\"[loading-info-content]\"></ng-content>\n"]}
|
|
309
|
+
.mat-table td {color: ${this.palletColors.listItemColor}!important;}`;
|
|
310
|
+
const head = document.head || document.getElementsByTagName('head')[0];
|
|
311
|
+
const style = document.createElement('style');
|
|
312
|
+
head.appendChild(style);
|
|
313
|
+
style.appendChild(document.createTextNode(css));
|
|
314
|
+
}
|
|
315
|
+
initOAuth2() {
|
|
316
|
+
KoalaOauthConfig.config.subscribe(config => this.startConfig(config));
|
|
317
|
+
if (KoalaOauthConfig.hasConfig()) {
|
|
318
|
+
KoalaOauthConfig.setConfig(KoalaOauthConfig.getConfig());
|
|
319
|
+
}
|
|
320
|
+
}
|
|
321
|
+
startConfig(config) {
|
|
322
|
+
if (config.clientId) {
|
|
323
|
+
this.oauth2Service.configure({
|
|
324
|
+
redirectUri: window.location.origin,
|
|
325
|
+
redirectUriAfterAuth: this.defaultPage,
|
|
326
|
+
responseType: 'code',
|
|
327
|
+
clientId: config.clientId,
|
|
328
|
+
scope: config.scope,
|
|
329
|
+
issuer: config.domain,
|
|
330
|
+
customQueryParams: config.customQueryParams,
|
|
331
|
+
endpointToken: config.endpointToken ?? null,
|
|
332
|
+
endpointClaims: config.endpointClaims ?? null
|
|
333
|
+
});
|
|
334
|
+
this.oauth2Service.loadDiscoveryDocumentAndTryLogin().then();
|
|
335
|
+
if (this.oauthEventsSubscription) {
|
|
336
|
+
this.oauthEventsSubscription.unsubscribe();
|
|
337
|
+
}
|
|
338
|
+
this.oauthEventsSubscription = this.oauth2Service.events.subscribe(event => {
|
|
339
|
+
if (event === 'userAuthenticated' || event === 'refreshToken') {
|
|
340
|
+
const claims = this.oauth2Service.getIdentityClaims();
|
|
341
|
+
if (claims && (!TokenFactory.hasToken() ||
|
|
342
|
+
(TokenFactory.hasToken() && event === 'refreshToken'))) {
|
|
343
|
+
this.tokenService.setToken(jwtEncode({
|
|
344
|
+
accessToken: this.oauth2Service.getAccessToken(),
|
|
345
|
+
idToken: this.oauth2Service.getIdToken(),
|
|
346
|
+
refreshToken: this.oauth2Service.getRefreshToken(),
|
|
347
|
+
login: claims[config.indexLoginName] ?? 'Undefined',
|
|
348
|
+
expired: this.oauth2Service.getAccessTokenExpiration(),
|
|
349
|
+
code: this.oauth2Service.getCode()
|
|
350
|
+
}, 'secret'));
|
|
351
|
+
}
|
|
352
|
+
if (event === 'userAuthenticated') {
|
|
353
|
+
setTimeout(() => this.validationScope$.next(false), 300);
|
|
354
|
+
}
|
|
355
|
+
}
|
|
356
|
+
else if (event === 'getToken') {
|
|
357
|
+
this.validationScope$.next(true);
|
|
358
|
+
}
|
|
359
|
+
});
|
|
360
|
+
}
|
|
361
|
+
}
|
|
362
|
+
}
|
|
363
|
+
PageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PageComponent, deps: [{ token: i1.KoalaTokenService }, { token: i2.Router }, { token: i3.KoalaLoaderService }, { token: i4.KoalaMenuService }, { token: i5.KoalaOAuth2Service }, { token: i6.DeviceDetectorService }], target: i0.ɵɵFactoryTarget.Component });
|
|
364
|
+
PageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: PageComponent, selector: "koala-page", inputs: { showMenu: "showMenu", color: "color", logo: "logo", startMenuOpened: "startMenuOpened", showLoaderPage: "showLoaderPage", messageLoaderPage: "messageLoaderPage", defaultPage: "defaultPage", openPages: "openPages", notifications: "notifications", userMenuOptions: "userMenuOptions", palletColors: "palletColors", language: "language" }, outputs: { validatingScope: "validatingScope", logoutEmitter: "logoutEmitter", deleteAllNotifications: "deleteAllNotifications", deleteNotification: "deleteNotification" }, providers: [KoalaTokenService], viewQueries: [{ propertyName: "menu", first: true, predicate: ["drawer"], descendants: true, static: true }], ngImport: i0, template: "<div *ngIf=\"showLoaderPage | async\" class=\"koala-loader-pg\">\n <div class=\"loader-content\">\n <figure>\n <img [src]=\"logo\" alt=\"Logotipo\"/>\n <figcaption *ngIf=\"(messageLoaderPage | async) as messageLoader\" [innerHTML]=\"messageLoader\"></figcaption>\n </figure>\n <mat-spinner></mat-spinner>\n </div>\n</div>\n<app-loader-page *ngIf=\"(loaderSubject | async) as loader\" [progress]=\"loader.progress\" [show]=\"loader.show\"\n [typeLoader]=\"loader.typeLoader\"></app-loader-page>\n<mat-drawer-container autosize class=\"menu-container\">\n <mat-drawer #drawer class=\"menu-options\" [mode]=\"isMobile ? 'push' : 'side'\">\n <img [src]=\"logo\" alt=\"Logotipo\" id=\"logotipo\"/>\n <ng-content *ngIf=\"showMenu\" select=\"[menu-options]\"></ng-content>\n </mat-drawer>\n\n <mat-toolbar *ngIf=\"!!(logged$ | async) && (username$ | async)\" class=\"toolbar\">\n <img *ngIf=\"!showMenu\" [src]=\"logo\" alt=\"Logotipo Toolbar\" id=\"logotipo-toolbar\"/>\n <button (click)=\"toogleMenu()\" *ngIf=\"showMenu\" [color]=\"color\" class=\"btn-collapse-menu\" mat-icon-button>\n <mat-icon>menu</mat-icon>\n </button>\n <span class=\"spacer\"></span>\n\t <div class=\"menu-toolbar\">\n\t\t <ng-content select=\"[menu-toolbar]\"></ng-content>\n\t </div>\n <div *ngIf=\"(notifications | async) as notificationList\">\n <button *ngIf=\"notifications\" [color]=\"color\" [matMenuTriggerFor]=\"notificationsMenu\" class=\"btn-toolbar\"\n mat-icon-button>\n <mat-icon\n\t [matBadgeHidden]=\"notificationList.length === 0\"\n\t [matBadge]=\"notificationList.length.toString()\"\n\t matBadgeColor=\"warn\">notifications\n </mat-icon>\n </button>\n <mat-menu #notificationsMenu=\"matMenu\" class=\"menu-list\" yPosition=\"below\">\n <koala-notification-list\n (delete)=\"deleteNotification.emit($event)\"\n (deleteAll)=\"deleteAllNotifications.emit($event)\"\n [notifications]=\"notificationList\">\n </koala-notification-list>\n </mat-menu>\n </div>\n <button [color]=\"color\" [matMenuTriggerFor]=\"userOptions\" class=\"btn-toolbar\" mat-button>\n <span>{{username$ | async}}</span>\n <span class=\"icon-user\">{{firstUserLetter$ | async}}</span>\n </button>\n <mat-menu #userOptions=\"matMenu\" class=\"user-menu menu-list\" yPosition=\"below\">\n <div class=\"user-presentation\">\n <span class=\"icon-user\">{{firstUserLetter$ | async}}</span><br/>\n <span class=\"username\">{{username$ | async}}</span>\n </div>\n <button (click)=\"btn.action()\" *ngFor=\"let btn of userMenuOptions\" mat-menu-item>\n <mat-icon>{{btn.icon}}</mat-icon>\n <span>{{btn.name}}</span>\n </button>\n <button (click)=\"logout()\" mat-menu-item>\n <mat-icon>exit_to_app</mat-icon>\n <span>{{language === 'ptBr' ? 'Sair' : 'Logout'}}</span>\n </button>\n </mat-menu>\n </mat-toolbar>\n\n <ng-content class=\"page-content\" select=\"[page-content]\"></ng-content>\n\n</mat-drawer-container>\n\n<ng-content class=\"loading-info-content\" select=\"[loading-info-content]\"></ng-content>\n", styles: [".menu-container{height:100vh;width:100vw}.menu-options{border:none;padding:20px 0 0;width:250px}.page-content{align-items:center;display:flex;height:100%;justify-content:center}img#logotipo,img#logotipo-toolbar{display:block;height:auto;margin:0 auto 25px;position:relative;width:120px}.toolbar{box-shadow:none;padding:0 7px 0 13px}.toolbar img#logotipo-toolbar{margin:0;padding:0 10px}.menu-toolbar{margin:0 10px}.spacer{flex:1 1 auto}.btn-toolbar{display:inline-block;margin-right:10px;position:relative}.btn-toolbar span{padding:0 10px 0 0}.btn-toolbar span.icon-user,.user-presentation span.icon-user{border-radius:50%;display:inline-block;height:10px;line-height:10px;padding:5px;width:10px}.user-presentation{min-width:260px;padding:50px 10px;text-align:center}.user-presentation span.icon-user{font-size:30px;height:30px;line-height:30px;margin-bottom:10px;width:30px}.user-presentation span.username{font-family:OpenSansLight,sans-serif;word-break:break-all}@media (max-width: 900px){.btn-toolbar span:first-child{display:none}.btn-toolbar span.icon-user,.user-presentation span.icon-user{height:20px;line-height:20px;width:20px}}\n"], dependencies: [{ kind: "directive", type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i8.MatBadge, selector: "[matBadge]", inputs: ["matBadgeDisabled", "matBadgeColor", "matBadgeOverlap", "matBadgePosition", "matBadge", "matBadgeDescription", "matBadgeSize", "matBadgeHidden"] }, { kind: "component", type: i9.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "diameter", "strokeWidth", "mode", "value"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: i10.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "component", type: i11.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i12.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i13.MatDrawer, selector: "mat-drawer", inputs: ["position", "mode", "disableClose", "autoFocus", "opened"], outputs: ["openedChange", "opened", "openedStart", "closed", "closedStart", "positionChanged"], exportAs: ["matDrawer"] }, { kind: "component", type: i13.MatDrawerContainer, selector: "mat-drawer-container", inputs: ["autosize", "hasBackdrop"], outputs: ["backdropClick"], exportAs: ["matDrawerContainer"] }, { kind: "component", type: i14.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i14.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i14.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "component", type: i15.NotificationComponent, selector: "koala-notification-list", inputs: ["notifications"], outputs: ["deleteAll", "delete"] }, { kind: "component", type: i16.LoaderBarPageComponent, selector: "app-loader-page", inputs: ["show", "progress", "typeLoader"] }, { kind: "pipe", type: i7.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
365
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PageComponent, decorators: [{
|
|
366
|
+
type: Component,
|
|
367
|
+
args: [{ selector: 'koala-page', providers: [KoalaTokenService], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngIf=\"showLoaderPage | async\" class=\"koala-loader-pg\">\n <div class=\"loader-content\">\n <figure>\n <img [src]=\"logo\" alt=\"Logotipo\"/>\n <figcaption *ngIf=\"(messageLoaderPage | async) as messageLoader\" [innerHTML]=\"messageLoader\"></figcaption>\n </figure>\n <mat-spinner></mat-spinner>\n </div>\n</div>\n<app-loader-page *ngIf=\"(loaderSubject | async) as loader\" [progress]=\"loader.progress\" [show]=\"loader.show\"\n [typeLoader]=\"loader.typeLoader\"></app-loader-page>\n<mat-drawer-container autosize class=\"menu-container\">\n <mat-drawer #drawer class=\"menu-options\" [mode]=\"isMobile ? 'push' : 'side'\">\n <img [src]=\"logo\" alt=\"Logotipo\" id=\"logotipo\"/>\n <ng-content *ngIf=\"showMenu\" select=\"[menu-options]\"></ng-content>\n </mat-drawer>\n\n <mat-toolbar *ngIf=\"!!(logged$ | async) && (username$ | async)\" class=\"toolbar\">\n <img *ngIf=\"!showMenu\" [src]=\"logo\" alt=\"Logotipo Toolbar\" id=\"logotipo-toolbar\"/>\n <button (click)=\"toogleMenu()\" *ngIf=\"showMenu\" [color]=\"color\" class=\"btn-collapse-menu\" mat-icon-button>\n <mat-icon>menu</mat-icon>\n </button>\n <span class=\"spacer\"></span>\n\t <div class=\"menu-toolbar\">\n\t\t <ng-content select=\"[menu-toolbar]\"></ng-content>\n\t </div>\n <div *ngIf=\"(notifications | async) as notificationList\">\n <button *ngIf=\"notifications\" [color]=\"color\" [matMenuTriggerFor]=\"notificationsMenu\" class=\"btn-toolbar\"\n mat-icon-button>\n <mat-icon\n\t [matBadgeHidden]=\"notificationList.length === 0\"\n\t [matBadge]=\"notificationList.length.toString()\"\n\t matBadgeColor=\"warn\">notifications\n </mat-icon>\n </button>\n <mat-menu #notificationsMenu=\"matMenu\" class=\"menu-list\" yPosition=\"below\">\n <koala-notification-list\n (delete)=\"deleteNotification.emit($event)\"\n (deleteAll)=\"deleteAllNotifications.emit($event)\"\n [notifications]=\"notificationList\">\n </koala-notification-list>\n </mat-menu>\n </div>\n <button [color]=\"color\" [matMenuTriggerFor]=\"userOptions\" class=\"btn-toolbar\" mat-button>\n <span>{{username$ | async}}</span>\n <span class=\"icon-user\">{{firstUserLetter$ | async}}</span>\n </button>\n <mat-menu #userOptions=\"matMenu\" class=\"user-menu menu-list\" yPosition=\"below\">\n <div class=\"user-presentation\">\n <span class=\"icon-user\">{{firstUserLetter$ | async}}</span><br/>\n <span class=\"username\">{{username$ | async}}</span>\n </div>\n <button (click)=\"btn.action()\" *ngFor=\"let btn of userMenuOptions\" mat-menu-item>\n <mat-icon>{{btn.icon}}</mat-icon>\n <span>{{btn.name}}</span>\n </button>\n <button (click)=\"logout()\" mat-menu-item>\n <mat-icon>exit_to_app</mat-icon>\n <span>{{language === 'ptBr' ? 'Sair' : 'Logout'}}</span>\n </button>\n </mat-menu>\n </mat-toolbar>\n\n <ng-content class=\"page-content\" select=\"[page-content]\"></ng-content>\n\n</mat-drawer-container>\n\n<ng-content class=\"loading-info-content\" select=\"[loading-info-content]\"></ng-content>\n", styles: [".menu-container{height:100vh;width:100vw}.menu-options{border:none;padding:20px 0 0;width:250px}.page-content{align-items:center;display:flex;height:100%;justify-content:center}img#logotipo,img#logotipo-toolbar{display:block;height:auto;margin:0 auto 25px;position:relative;width:120px}.toolbar{box-shadow:none;padding:0 7px 0 13px}.toolbar img#logotipo-toolbar{margin:0;padding:0 10px}.menu-toolbar{margin:0 10px}.spacer{flex:1 1 auto}.btn-toolbar{display:inline-block;margin-right:10px;position:relative}.btn-toolbar span{padding:0 10px 0 0}.btn-toolbar span.icon-user,.user-presentation span.icon-user{border-radius:50%;display:inline-block;height:10px;line-height:10px;padding:5px;width:10px}.user-presentation{min-width:260px;padding:50px 10px;text-align:center}.user-presentation span.icon-user{font-size:30px;height:30px;line-height:30px;margin-bottom:10px;width:30px}.user-presentation span.username{font-family:OpenSansLight,sans-serif;word-break:break-all}@media (max-width: 900px){.btn-toolbar span:first-child{display:none}.btn-toolbar span.icon-user,.user-presentation span.icon-user{height:20px;line-height:20px;width:20px}}\n"] }]
|
|
368
|
+
}], ctorParameters: function () { return [{ type: i1.KoalaTokenService }, { type: i2.Router }, { type: i3.KoalaLoaderService }, { type: i4.KoalaMenuService }, { type: i5.KoalaOAuth2Service }, { type: i6.DeviceDetectorService }]; }, propDecorators: { showMenu: [{
|
|
369
|
+
type: Input
|
|
370
|
+
}], color: [{
|
|
371
|
+
type: Input
|
|
372
|
+
}], logo: [{
|
|
373
|
+
type: Input
|
|
374
|
+
}], startMenuOpened: [{
|
|
375
|
+
type: Input
|
|
376
|
+
}], showLoaderPage: [{
|
|
377
|
+
type: Input
|
|
378
|
+
}], messageLoaderPage: [{
|
|
379
|
+
type: Input
|
|
380
|
+
}], defaultPage: [{
|
|
381
|
+
type: Input
|
|
382
|
+
}], openPages: [{
|
|
383
|
+
type: Input
|
|
384
|
+
}], notifications: [{
|
|
385
|
+
type: Input
|
|
386
|
+
}], userMenuOptions: [{
|
|
387
|
+
type: Input
|
|
388
|
+
}], palletColors: [{
|
|
389
|
+
type: Input
|
|
390
|
+
}], language: [{
|
|
391
|
+
type: Input
|
|
392
|
+
}], validatingScope: [{
|
|
393
|
+
type: Output
|
|
394
|
+
}], logoutEmitter: [{
|
|
395
|
+
type: Output
|
|
396
|
+
}], deleteAllNotifications: [{
|
|
397
|
+
type: Output
|
|
398
|
+
}], deleteNotification: [{
|
|
399
|
+
type: Output
|
|
400
|
+
}], menu: [{
|
|
401
|
+
type: ViewChild,
|
|
402
|
+
args: ['drawer', { static: true }]
|
|
403
|
+
}] } });
|
|
404
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page.component.js","sourceRoot":"","sources":["../../../../../projects/core/src/lib/page/page.component.ts","../../../../../projects/core/src/lib/page/page.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\nimport { ThemePalette } from '@angular/material/core';\nimport { NavigationCancel, NavigationEnd, NavigationError, NavigationStart, Router } from '@angular/router';\nimport { LoaderBarPageInterface } from '../loader/loader-bar-page.interface';\nimport { BehaviorSubject, Subscription } from 'rxjs';\nimport { KoalaTokenService } from '../services/token/koala.token.service';\nimport { KoalaLoaderService } from '../services/loader/koala.loader.service';\nimport { KoalaNotificationInterface } from './notifications/koala.notification.interface';\nimport { KoalaUserMenuOptionsInterface } from './koala.user-menu-options.interface';\nimport { KoalaPagePalletColorsInterface } from './koala-page-pallet-colors.interface';\nimport { MatDrawer } from '@angular/material/sidenav';\nimport { KoalaMenuService, menuStateSubject } from '@koalarx/ui/menu';\nimport jwtEncode from \"jwt-encode\";\nimport { TokenFactory } from \"../services/token/token.factory\";\nimport { KoalaOAuth2Service } from \"../services/openid/koala.oauth2.service\";\nimport { KoalaEnvironment } from \"../environments/koalaEnvironment\";\nimport { KoalaOauthConfig } from \"../services/openid/koala.oauth.config\";\nimport { KoalaOauth2ConfigInterface } from \"../services/openid/koala-oauth2-config.interface\";\nimport { KoalaLanguageHelper, KoalaLanguageType } from \"./koala-language.helper\";\nimport { DeviceDetectorService } from \"ngx-device-detector\";\n\n@Component({\n  selector: 'koala-page',\n  templateUrl: 'page.component.html',\n  styleUrls: ['page.component.css'],\n  providers: [KoalaTokenService],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class PageComponent implements OnInit {\n  @Input() showMenu: boolean = true;\n  @Input() color: ThemePalette;\n  @Input() logo: string;\n  @Input() startMenuOpened = true;\n  @Input() showLoaderPage: BehaviorSubject<boolean>;\n  @Input() messageLoaderPage: BehaviorSubject<string>;\n  @Input() defaultPage: string;\n  @Input() openPages: string[];\n  @Input() notifications: BehaviorSubject<KoalaNotificationInterface[]>;\n  @Input() userMenuOptions: KoalaUserMenuOptionsInterface[] = [];\n  @Input() palletColors: KoalaPagePalletColorsInterface;\n  @Input() language: KoalaLanguageType = 'ptBr';\n  @Output() validatingScope = new EventEmitter<boolean>(false);\n  @Output() logoutEmitter = new EventEmitter<boolean>(false);\n  @Output() deleteAllNotifications = new EventEmitter<boolean>(false);\n  @Output() deleteNotification = new EventEmitter<KoalaNotificationInterface>(null);\n\n  public loaderSubject: BehaviorSubject<LoaderBarPageInterface>;\n  public username$ = new BehaviorSubject<string>('');\n  public firstUserLetter$ = new BehaviorSubject<string>('');\n  public currentUrl: string;\n  public logged$ = new BehaviorSubject<boolean>(false);\n  public validationScope$ = new BehaviorSubject<boolean>(false);\n  public isMobile: boolean = this.deviceService.isMobile();\n\n  private defaultPalletColors: KoalaPagePalletColorsInterface = {\n    scrollbarColor: '#1976D2',\n    scrollbarColorHover: '#1565C0',\n    userPresentationBackground: '#f1f1f1',\n    userPresentationUserBackground: '#1976D2',\n    userPresentationUserFontColor: '#fff',\n    firstColor: '#fff',\n    secondColor: '#F1F1F1',\n    bodyBackground: '#eeeeee',\n    checkboxBackground: '#1976d2',\n    checkboxColor: '#ffffff',\n    fontColor: '#1976D2',\n    fontHoverColor: '#1976D2',\n    fontActiveColor: '#1565C0',\n    menuTitleBackground: 'rgba(0,0,0,.1)',\n    menuTitleColor: 'rgba(0,0,0,.3)',\n    menuBackground: '#fafafa',\n    menuOptionsBackground: '#eaeaea',\n    menuOptionsColor: '#a5a5a5',\n    menuOptionsColorHover: '#1976D2',\n    menuOptionsColorActive: '#1565c0',\n    toolbarBackground: '#ffffff',\n    toolbarColor: '#1976d2',\n    listBackground: '#fff',\n    listContentBackground: '#fff',\n    listTitleItemColor: '#838383',\n    listItemColor: '#3e3e3e',\n    listItemBackgroudHover: '#F1F1F1',\n    listItemBackgroundActive: '#EEE',\n    shadowColorTableList: 'rgba(25, 118, 210, .4)'\n  };\n  private oauthEventsSubscription: Subscription;\n\n  @ViewChild('drawer', {static: true}) private menu: MatDrawer;\n\n  constructor(\n    private tokenService: KoalaTokenService,\n    private router: Router,\n    private loaderService: KoalaLoaderService,\n    private menuService: KoalaMenuService,\n    private oauth2Service: KoalaOAuth2Service,\n    private deviceService: DeviceDetectorService,\n  ) {\n    this.loaderSubject = loaderService.getLoaderSubject();\n  }\n\n  ngOnInit() {\n    KoalaLanguageHelper.setLanguage(this.language);\n    this.initOAuth2();\n    if (this.openPages) {\n      if (this.openPages.indexOf('/') < 0) {\n        this.openPages.push('/');\n      }\n      if (this.openPages.indexOf('/login') < 0) {\n        this.openPages.push('/login');\n      }\n    } else {\n      this.openPages = [\n        '/',\n        '/login'\n      ];\n    }\n\n    this.tokenService.getToken()?.subscribe(token => {\n      this.logged$.next(!!token);\n      if (this.logged$.getValue()) {\n        const decodedToken = this.tokenService.getDecodedToken<{ login: string }>();\n        this.username$.next(decodedToken.login);\n        this.firstUserLetter$.next(decodedToken.login.charAt(0).toUpperCase());\n        if (!this.isMobile) {\n          this.menuService.open();\n        }\n      }\n      if (this.logged$.getValue() && this.openPages?.indexOf(this.currentUrl) >= 0 && this.defaultPage) {\n        this.router.navigate([this.defaultPage]).then();\n      } else if (!this.logged$.getValue() && this.currentUrl && this.openPages?.indexOf(this.currentUrl) < 0) {\n        this.router.navigate(['login']).then();\n        return false;\n      }\n    });\n    this.router.events.subscribe(event => {\n      switch (true) {\n        case event instanceof NavigationStart: {\n          this.loaderService.create({typeLoader: 'indeterminate'});\n          break;\n        }\n\n        case event instanceof NavigationEnd:\n        case event instanceof NavigationCancel:\n        case event instanceof NavigationError: {\n          this.loaderService.dismiss();\n          if (event instanceof NavigationEnd) {\n            if (this.isMobile) {\n              this.menuService.close();\n            }\n\n            this.currentUrl = event.url.split('?')[0];\n\n            if (event.url.indexOf('/login?clientId=') < 0) {\n              if (this.logged$.getValue() && this.defaultPage && this.openPages?.indexOf(this.currentUrl) >= 0) {\n                this.router.navigate([this.defaultPage]).then();\n                return false;\n              } else if (!this.logged$.getValue() && this.openPages?.indexOf(this.currentUrl) < 0) {\n                this.router.navigate(['login']).then();\n                return false;\n              }\n            }\n          }\n          break;\n        }\n        default: {\n          break;\n        }\n      }\n    });\n    if (this.palletColors) {\n      Object.keys(this.defaultPalletColors).forEach(indexName => {\n        if (\n          !this.palletColors.hasOwnProperty(indexName) ||\n          !this.palletColors[indexName]\n        ) {\n          this.palletColors[indexName] = this.defaultPalletColors[indexName];\n        }\n      });\n    } else {\n      this.palletColors = this.defaultPalletColors;\n    }\n    this.defineColor();\n\n    if (this.showMenu) {\n      menuStateSubject.subscribe(async (state) => {\n        if (this.menu) {\n          if (state === 'close') {\n            if (this.menu.opened) {\n              await this.menu.close();\n            }\n          } else if (state === 'open') {\n            if (!this.menu.opened) {\n              await this.menu.open();\n            }\n          }\n        }\n      });\n      if (this.startMenuOpened && this.logged$.getValue()) {\n        if (!this.isMobile) {\n          this.menuService.open();\n        }\n      } else {\n        this.menuService.close();\n      }\n    } else {\n      this.menuService.close();\n    }\n\n    this.validationScope$.subscribe(scope => this.validatingScope.emit(scope));\n  }\n\n  public async toogleMenu() {\n    this.menuService.clearConfig();\n    if (this.menu) {\n      await this.menu.toggle();\n    }\n  }\n\n  public async logout() {\n    if (KoalaEnvironment.environment?.oauthConfig) {\n      this.oauth2Service.logout();\n    }\n    this.menuService.close();\n    this.tokenService.removeToken();\n    this.tokenService.getToken().next(null);\n    this.logoutEmitter.emit(true);\n  }\n\n  public defineColor() {\n    const css = `\n*::-webkit-scrollbar-thumb {background: ${this.palletColors.scrollbarColor};width: 2px;}\n*::-webkit-scrollbar-thumb:hover {background: ${this.palletColors.scrollbarColorHover};}\ninput:-webkit-autofill, input:-webkit-autofill:focus, input:-webkit-autofill:hover {color: ${this.palletColors.fontColor}!important;}\n.menu-container,\nbody {background: ${this.palletColors.bodyBackground}!important;}\ninput:-webkit-autofill, input:-webkit-autofill:focus, input:-webkit-autofill:hover {-webkit-box-shadow: 0 0 0 1000px ${this.palletColors.firstColor} inset !important;}\n.mat-button-disabled,\ninput::placeholder,\n.mat-form-field-appearance-outline .mat-form-field-outline {color: ${this.palletColors.fontColor}!important;opacity: .6;}\n.mat-hint,\n.mat-expansion-indicator::after,\n.more-items-content .items .titleForm,\nfieldset legend,\n.mat-paginator-container,\n.mat-form-field-flex mat-icon {color: ${this.palletColors.fontColor}!important;}\n.mat-paginator-container,\n.mat-card,\n.mat-expansion-panel,\n.mat-select-panel,\n.mat-autocomplete-panel,\n.mat-menu-panel {background: ${this.palletColors.firstColor}}\n.mat-selected {background-color: rgba(0,0,0,.3)!important;}\n.question p,\n.alert-message,\n.mat-action-row,\n.mat-option,\n.mat-menu-item,\n.mat-menu-item mat-icon {color: ${this.palletColors.fontColor}!important}\n.mat-select-value,\n.mat-select-arrow,\n.mat-form-field input,\n.mat-form-field textarea,\n.mat-form-field-appearance-outline:not(.mat-form-field-invalid) .mat-form-field-outline-thick,\n.mat-form-field label,\n.select-multiple-native select {color: ${this.palletColors.fontColor}!important;caret-color: ${this.palletColors.fontColor}!important;}\n.mat-form-field-underline,\n.mat-form-field-appearance-fill .mat-form-field-underline::before,\n.mat-form-field-ripple {background: ${this.palletColors.fontColor}!important;}\n.mat-checkbox-checked.mat-accent .mat-checkbox-background, .mat-checkbox-indeterminate.mat-accent .mat-checkbox-background,\n.mat-checkbox:not(.mat-checkbox-disabled).mat-accent .mat-checkbox-ripple .mat-ripple-element {background-color: ${this.palletColors.checkboxBackground} !important;}\n.mat-checkbox-checkmark-path {stroke: ${this.palletColors.checkboxColor} !important;}\n.mat-checkbox-checkmark {fill: ${this.palletColors.checkboxColor} !important;}\n.mat-checkbox-mixedmark {background-color: ${this.palletColors.checkboxColor} !important;}\n.mat-checkbox-frame {border-color: ${this.palletColors.checkboxOutlineColor}!important;}\n.mat-checkbox-label {color: ${this.palletColors.fontColor}!important;}\n.mat-radio-outer-circle {border-color: ${this.palletColors.checkboxBackground}!important;}\n.mat-radio-ripple .mat-ripple-element, .mat-radio-inner-circle {background-color: ${this.palletColors.checkboxBackground} !important;}\n.home-list-cards .list .mat-list-item-content .mat-icon {color: ${this.palletColors.fontColor};}\n.home-list-cards .list button .mat-badge-content {background: ${this.palletColors.fontColor};}\n.koala-dialog .mat-dialog-title h2 {color: ${this.palletColors.fontColor};}\n.koala-dialog .mat-dialog-title mat-icon {color: ${this.palletColors.fontColor}!important;}\n.koala-dialog .mat-dialog-container {background: ${this.palletColors.firstColor}}\n.list-filter mat-icon {color: ${this.palletColors.filterIconColor}!important;}\nkoala-page .menu-options {background: ${this.palletColors.menuBackground};}\nkoala-page .toolbar {background: ${this.palletColors.toolbarBackground};}\nkoala-page .toolbar .btn-collapse-menu,\nkoala-page .btn-toolbar span{color: ${this.palletColors.toolbarColor};}\nkoala-page .btn-toolbar span.icon-user,\n.user-presentation span.icon-user {background: ${this.palletColors.userPresentationUserBackground};color: ${this.palletColors.userPresentationUserFontColor};}\n.user-presentation {background: ${this.palletColors.userPresentationBackground};}\n.user-presentation span.username {color: ${this.palletColors.toolbarColor};}\n.mat-drawer.mat-drawer-push {background-color: ${this.palletColors.bodyBackground};}\nkoala-menu .title {background: ${this.palletColors.menuTitleBackground};color: ${this.palletColors.menuTitleColor};}\nkoala-menu ul li,\nkoala-menu ul li a {color: ${this.palletColors.menuOptionsColor};}\nkoala-menu ul li:hover,\nkoala-menu ul li:hover a {color: ${this.palletColors.menuOptionsColorHover} !important;}\nkoala-menu ul li.active,\nkoala-menu ul li.expanded {color: ${this.palletColors.menuOptionsColorActive} !important;border-left: 4px solid ${this.palletColors.menuOptionsColorActive} !important;background: ${this.palletColors.menuOptionsBackground} !important;}\nkoala-menu ul li.active a,\nkoala-menu ul li.expanded a {color: ${this.palletColors.menuOptionsColorActive} !important;background: ${this.palletColors.menuOptionsBackground} !important;}\nkoala-menu ul li li:hover,\nkoala-menu ul li li:hover a {color: ${this.palletColors.menuOptionsColorHover} !important;}\nkoala-menu ul li li.active,\nkoala-menu ul li li.active a {color: ${this.palletColors.menuOptionsColorActive} !important;}\nkoala-menu ul li koala-icon svg *,\nkoala-menu ul li a koala-icon svg * {fill: ${this.palletColors.menuOptionsColor};}\nkoala-menu ul li:hover koala-icon svg *,\nkoala-menu ul li:hover a koala-icon svg * {fill: ${this.palletColors.menuOptionsColorHover} !important;}\nkoala-menu ul li.active koala-icon *,\nkoala-menu ul li.expanded koala-icon * {fill: ${this.palletColors.menuOptionsColorActive} !important;}\nkoala-menu ul li li:hover koala-icon *,\nkoala-menu ul li li:hover a koala-icon * {fill: ${this.palletColors.menuOptionsColorHover} !important;}\nkoala-menu ul li li.active koala-icon *,\nkoala-menu ul li li.active a koala-icon * {fill: ${this.palletColors.menuOptionsColorActive}!important;}\n.notifications-content .title {color: ${this.palletColors.notificationTitleColor}!important;}\n.notifications-content .empty,\n.notifications-content .titleList {color: ${this.palletColors.notificationContentTitleColor}!important;}\n.notifications-content .iconList {color: ${this.palletColors.notificationContentIconColor}!important;}\n.notifications-content .textList {color: ${this.palletColors.notificationTitleColor}!important;}\n.list-container {box-shadow: 0 1px 3px ${this.palletColors.shadowColorTableList};}\n.list-container .list table.table-hover tr:hover {background: ${this.palletColors.listItemBackgroudHover};}\n.list-container .list table.table-hover tr:active {background: ${this.palletColors.listItemBackgroundActive};}\n.list-container .list-filter .advanced {background: ${this.palletColors.firstColor};}\n.list-container nav.menu-list {background: ${this.palletColors.firstColor};color: rgba(25, 118, 210, .3);}\n.content {background: ${this.palletColors.listContentBackground};}\n.mat-tab-group .mat-tab-label {color: ${this.palletColors.fontColor};}\n.mat-tab-group .mat-ink-bar {background-color: ${this.palletColors.fontColor}!important;}\n.mat-table {background: ${this.palletColors.listBackground};color: ${this.palletColors.fontColor};}\n.mat-table th {color: ${this.palletColors.listTitleItemColor}!important;}\n.mat-sort-header-arrow {color: ${this.palletColors.listItemColor}!important;}\n.mat-table td {color: ${this.palletColors.listItemColor}!important;}`;\n    const head = document.head || document.getElementsByTagName('head')[0];\n    const style = document.createElement('style');\n    head.appendChild(style);\n    style.appendChild(document.createTextNode(css));\n  }\n\n  private initOAuth2() {\n    KoalaOauthConfig.config.subscribe(config => this.startConfig(config));\n    if (KoalaOauthConfig.hasConfig()) {\n      KoalaOauthConfig.setConfig(KoalaOauthConfig.getConfig());\n    }\n  }\n\n  private startConfig(config: KoalaOauth2ConfigInterface) {\n    if (config.clientId) {\n      this.oauth2Service.configure({\n        redirectUri: window.location.origin,\n        redirectUriAfterAuth: this.defaultPage,\n        responseType: 'code',\n        clientId: config.clientId,\n        scope: config.scope,\n        issuer: config.domain,\n        customQueryParams: config.customQueryParams,\n        endpointToken: config.endpointToken ?? null,\n        endpointClaims: config.endpointClaims ?? null\n      });\n      this.oauth2Service.loadDiscoveryDocumentAndTryLogin().then();\n\n      if (this.oauthEventsSubscription) {\n        this.oauthEventsSubscription.unsubscribe();\n      }\n      this.oauthEventsSubscription = this.oauth2Service.events.subscribe(event => {\n        if (event === 'userAuthenticated' || event === 'refreshToken') {\n          const claims = this.oauth2Service.getIdentityClaims();\n          if (claims && (\n            !TokenFactory.hasToken() ||\n            (TokenFactory.hasToken() && event === 'refreshToken')\n          )) {\n            this.tokenService.setToken(jwtEncode({\n              accessToken: this.oauth2Service.getAccessToken(),\n              idToken: this.oauth2Service.getIdToken(),\n              refreshToken: this.oauth2Service.getRefreshToken(),\n              login: claims[config.indexLoginName] ?? 'Undefined',\n              expired: this.oauth2Service.getAccessTokenExpiration(),\n              code: this.oauth2Service.getCode()\n            }, 'secret'))\n          }\n\n          if (event === 'userAuthenticated') {\n            setTimeout(() => this.validationScope$.next(false), 300);\n          }\n        } else if (event === 'getToken') {\n          this.validationScope$.next(true);\n        }\n      });\n    }\n  }\n}\n","<div *ngIf=\"showLoaderPage | async\" class=\"koala-loader-pg\">\n  <div class=\"loader-content\">\n    <figure>\n      <img [src]=\"logo\" alt=\"Logotipo\"/>\n      <figcaption *ngIf=\"(messageLoaderPage | async) as messageLoader\" [innerHTML]=\"messageLoader\"></figcaption>\n    </figure>\n    <mat-spinner></mat-spinner>\n  </div>\n</div>\n<app-loader-page *ngIf=\"(loaderSubject | async) as loader\" [progress]=\"loader.progress\" [show]=\"loader.show\"\n                 [typeLoader]=\"loader.typeLoader\"></app-loader-page>\n<mat-drawer-container autosize class=\"menu-container\">\n  <mat-drawer #drawer class=\"menu-options\" [mode]=\"isMobile ? 'push' : 'side'\">\n    <img [src]=\"logo\" alt=\"Logotipo\" id=\"logotipo\"/>\n    <ng-content *ngIf=\"showMenu\" select=\"[menu-options]\"></ng-content>\n  </mat-drawer>\n\n  <mat-toolbar *ngIf=\"!!(logged$ | async) && (username$ | async)\" class=\"toolbar\">\n    <img *ngIf=\"!showMenu\" [src]=\"logo\" alt=\"Logotipo Toolbar\" id=\"logotipo-toolbar\"/>\n    <button (click)=\"toogleMenu()\" *ngIf=\"showMenu\" [color]=\"color\" class=\"btn-collapse-menu\" mat-icon-button>\n      <mat-icon>menu</mat-icon>\n    </button>\n    <span class=\"spacer\"></span>\n\t  <div class=\"menu-toolbar\">\n\t\t  <ng-content select=\"[menu-toolbar]\"></ng-content>\n\t  </div>\n    <div *ngIf=\"(notifications | async) as notificationList\">\n      <button *ngIf=\"notifications\" [color]=\"color\" [matMenuTriggerFor]=\"notificationsMenu\" class=\"btn-toolbar\"\n              mat-icon-button>\n        <mat-icon\n\t        [matBadgeHidden]=\"notificationList.length === 0\"\n\t        [matBadge]=\"notificationList.length.toString()\"\n\t        matBadgeColor=\"warn\">notifications\n        </mat-icon>\n      </button>\n      <mat-menu #notificationsMenu=\"matMenu\" class=\"menu-list\" yPosition=\"below\">\n        <koala-notification-list\n          (delete)=\"deleteNotification.emit($event)\"\n          (deleteAll)=\"deleteAllNotifications.emit($event)\"\n          [notifications]=\"notificationList\">\n        </koala-notification-list>\n      </mat-menu>\n    </div>\n    <button [color]=\"color\" [matMenuTriggerFor]=\"userOptions\" class=\"btn-toolbar\" mat-button>\n      <span>{{username$ | async}}</span>\n      <span class=\"icon-user\">{{firstUserLetter$ | async}}</span>\n    </button>\n    <mat-menu #userOptions=\"matMenu\" class=\"user-menu menu-list\" yPosition=\"below\">\n      <div class=\"user-presentation\">\n        <span class=\"icon-user\">{{firstUserLetter$ | async}}</span><br/>\n        <span class=\"username\">{{username$ | async}}</span>\n      </div>\n      <button (click)=\"btn.action()\" *ngFor=\"let btn of userMenuOptions\" mat-menu-item>\n        <mat-icon>{{btn.icon}}</mat-icon>\n        <span>{{btn.name}}</span>\n      </button>\n      <button (click)=\"logout()\" mat-menu-item>\n        <mat-icon>exit_to_app</mat-icon>\n        <span>{{language === 'ptBr' ? 'Sair' : 'Logout'}}</span>\n      </button>\n    </mat-menu>\n  </mat-toolbar>\n\n  <ng-content class=\"page-content\" select=\"[page-content]\"></ng-content>\n\n</mat-drawer-container>\n\n<ng-content class=\"loading-info-content\" select=\"[loading-info-content]\"></ng-content>\n"]}
|