@quadrel-enterprise-ui/framework 18.19.1 → 18.20.0
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/esm2022/lib/forms/switches/switch/switch.component.mjs +3 -47
- package/esm2022/lib/forms/switches/switches.component.mjs +3 -3
- package/esm2022/lib/notifications/notification/notification.component.mjs +37 -1
- package/esm2022/lib/notifications/services/notifications-http-interceptor.service.mjs +39 -7
- package/esm2022/lib/qd-ui.module.mjs +5 -4
- package/fesm2022/quadrel-ui-qd-ui.mjs +81 -55
- package/fesm2022/quadrel-ui-qd-ui.mjs.map +1 -1
- package/lib/forms/switches/switch/switch.component.d.ts +3 -12
- package/lib/notifications/notification/notification.component.d.ts +36 -0
- package/lib/notifications/services/notifications-http-interceptor.service.d.ts +5 -2
- package/lib/qd-ui.module.d.ts +1 -1
- package/package.json +1 -1
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { HTTP_INTERCEPTORS } from '@angular/common/http';
|
|
2
2
|
import { NgModule } from '@angular/core';
|
|
3
|
-
import { BACKEND_ERROR_CODES, QdNotificationsHttpInterceptorService } from './notifications/services/notifications-http-interceptor.service';
|
|
3
|
+
import { BACKEND_ERROR_CODES, WHITELIST_ERROR_CODES, QdNotificationsHttpInterceptorService } from './notifications/services/notifications-http-interceptor.service';
|
|
4
4
|
import { APP_ENVIRONMENT } from './core/model/app-enviroment.token';
|
|
5
5
|
import { QdButtonModule } from './button/button.module';
|
|
6
6
|
import { QdChipModule } from './chips/chips.module';
|
|
@@ -83,12 +83,13 @@ const QD_UI_MODULES = [
|
|
|
83
83
|
QdTreeModule
|
|
84
84
|
];
|
|
85
85
|
export class QdUiModule {
|
|
86
|
-
static forRoot(config, backendErrorCodes = {}) {
|
|
86
|
+
static forRoot(config, backendErrorCodes = {}, whitelistErrorCodes = []) {
|
|
87
87
|
return {
|
|
88
88
|
ngModule: QdUiModule,
|
|
89
89
|
providers: [
|
|
90
90
|
{ provide: APP_ENVIRONMENT, useValue: config },
|
|
91
|
-
{ provide: BACKEND_ERROR_CODES, useValue: backendErrorCodes }
|
|
91
|
+
{ provide: BACKEND_ERROR_CODES, useValue: backendErrorCodes },
|
|
92
|
+
{ provide: WHITELIST_ERROR_CODES, useValue: whitelistErrorCodes }
|
|
92
93
|
]
|
|
93
94
|
};
|
|
94
95
|
}
|
|
@@ -229,4 +230,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
229
230
|
]
|
|
230
231
|
}]
|
|
231
232
|
}] });
|
|
232
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"qd-ui.module.js","sourceRoot":"","sources":["../../../../libs/qd-ui/src/lib/qd-ui.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { HTTP_INTERCEPTORS } from '@angular/common/http';\nimport { ModuleWithProviders, NgModule } from '@angular/core';\n\nimport {\n  BACKEND_ERROR_CODES,\n  QdNotificationsHttpInterceptorService\n} from './notifications/services/notifications-http-interceptor.service';\n\nimport { QdAppEnvironment } from './core/model/app-enviroment.interface';\nimport { APP_ENVIRONMENT } from './core/model/app-enviroment.token';\n\nimport { QdButtonModule } from './button/button.module';\nimport { QdChipModule } from './chips/chips.module';\nimport { QdCommentsModule } from './comments/comments.module';\nimport { QdContactCardModule } from './contact-card/contact-card.module';\nimport { QdContainerModule } from './container/container.module';\nimport { QdContentGridModule } from './content-grid/content-grid.module';\nimport { QdCoreModule } from './core/core.module';\nimport { QdDialogModule } from './dialog/dialog.module';\nimport { QdFileCollectorModule } from './file-collector/file-collector.module';\nimport { QdFilterModule } from './filter/filter.module';\nimport { QdFormModule } from './forms/qd-form.module';\nimport { QdGridModule } from './grid/grid.module';\nimport { QdIconModule } from './icon/icon.module';\nimport { QdImageModule } from './image/image.module';\nimport { QdLayoutModule } from './layout/layout.module';\nimport { QdListModule } from './lists/list.module';\nimport { QdMasterLayoutModule } from './master-layout/master-layout.module';\nimport { QdMasterLayoutService } from './master-layout/service/master-layout.service';\nimport { QdNavigationTilesModule } from './navigation-tiles/navigation-tiles.module';\nimport { QdNotificationsModule } from './notifications/notifications.module';\nimport { QdPageModule } from './page/page.module';\nimport { QdPageStepperModule } from './page-stepper/page-stepper.module';\nimport { QdPageTabsModule } from './page-tabs/page-tabs.module';\nimport { QdPlaceHolderModule } from './place-holder/place-holder.module';\nimport { QdProgressBarModule } from './progress-bar/progress-bar.module';\nimport { QdQuickEditModule } from './quick-edit/quick-edit.module';\nimport { QdSearchModule } from './search/search.module';\nimport { QdSectionModule } from './section/section.module';\nimport { QdShellModule } from './shell/shell.module';\nimport { QdSpinnerModule } from './spinner/spinner.module';\nimport { QdStatusIndicatorModule } from './status-indicator/status-indicator.module';\nimport { QdStepperModule } from './navigation/stepper/stepper.module';\nimport { QdTabBarModule } from './navigation/tab-bar/tab-bar.module';\nimport { QdTableModule } from './table/table.module';\nimport { QdTabsModule } from './navigation/tabs/tabs.module';\nimport { QdTextSectionModule } from './text-section/text-section.module';\nimport { QdTilesModule } from './tiles/tiles.module';\nimport { QdTreeModule } from './tree/tree.module';\nimport { QdPanelSectionModule } from './panel-section/panel-section.module';\n\nconst QD_UI_MODULES = [\n  QdButtonModule,\n  QdChipModule,\n  QdCommentsModule,\n  QdContactCardModule,\n  QdContainerModule,\n  QdContentGridModule,\n  QdCoreModule,\n  QdDialogModule,\n  QdFileCollectorModule,\n  QdFilterModule,\n  QdFormModule,\n  QdGridModule,\n  QdIconModule,\n  QdImageModule,\n  QdLayoutModule,\n  QdListModule,\n  QdMasterLayoutModule,\n  QdNavigationTilesModule,\n  QdNotificationsModule,\n  QdPageModule,\n  QdPageStepperModule,\n  QdPageTabsModule,\n  QdPanelSectionModule,\n  QdPlaceHolderModule,\n  QdProgressBarModule,\n  QdQuickEditModule,\n  QdSearchModule,\n  QdSectionModule,\n  QdShellModule,\n  QdSpinnerModule,\n  QdStatusIndicatorModule,\n  QdStepperModule,\n  QdTabBarModule,\n  QdTableModule,\n  QdTabsModule,\n  QdTextSectionModule,\n  QdTilesModule,\n  QdTreeModule\n];\n\n@NgModule({\n  imports: [QD_UI_MODULES],\n  exports: QD_UI_MODULES,\n  providers: [\n    QdMasterLayoutService,\n    {\n      provide: HTTP_INTERCEPTORS,\n      useClass: QdNotificationsHttpInterceptorService,\n      multi: true\n    }\n  ]\n})\nexport class QdUiModule {\n  static forRoot(config: QdAppEnvironment, backendErrorCodes = {}): ModuleWithProviders<QdUiModule> {\n    return {\n      ngModule: QdUiModule,\n      providers: [\n        { provide: APP_ENVIRONMENT, useValue: config },\n        { provide: BACKEND_ERROR_CODES, useValue: backendErrorCodes }\n      ]\n    };\n  }\n}\n"]}
|
|
233
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"qd-ui.module.js","sourceRoot":"","sources":["../../../../libs/qd-ui/src/lib/qd-ui.module.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AACzD,OAAO,EAAuB,QAAQ,EAAE,MAAM,eAAe,CAAC;AAE9D,OAAO,EACL,mBAAmB,EACnB,qBAAqB,EACrB,qCAAqC,EACtC,MAAM,iEAAiE,CAAC;AAGzE,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AAEpE,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AACpD,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,qBAAqB,EAAE,MAAM,wCAAwC,CAAC;AAC/E,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,oBAAoB,EAAE,MAAM,sCAAsC,CAAC;AAC5E,OAAO,EAAE,qBAAqB,EAAE,MAAM,+CAA+C,CAAC;AACtF,OAAO,EAAE,uBAAuB,EAAE,MAAM,4CAA4C,CAAC;AACrF,OAAO,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAC;AAC7E,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;AAChE,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AACnE,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AACxD,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,uBAAuB,EAAE,MAAM,4CAA4C,CAAC;AACrF,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;AACtE,OAAO,EAAE,cAAc,EAAE,MAAM,qCAAqC,CAAC;AACrE,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAC7D,OAAO,EAAE,mBAAmB,EAAE,MAAM,oCAAoC,CAAC;AACzE,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,oBAAoB,EAAE,MAAM,sCAAsC,CAAC;;AAE5E,MAAM,aAAa,GAAG;IACpB,cAAc;IACd,YAAY;IACZ,gBAAgB;IAChB,mBAAmB;IACnB,iBAAiB;IACjB,mBAAmB;IACnB,YAAY;IACZ,cAAc;IACd,qBAAqB;IACrB,cAAc;IACd,YAAY;IACZ,YAAY;IACZ,YAAY;IACZ,aAAa;IACb,cAAc;IACd,YAAY;IACZ,oBAAoB;IACpB,uBAAuB;IACvB,qBAAqB;IACrB,YAAY;IACZ,mBAAmB;IACnB,gBAAgB;IAChB,oBAAoB;IACpB,mBAAmB;IACnB,mBAAmB;IACnB,iBAAiB;IACjB,cAAc;IACd,eAAe;IACf,aAAa;IACb,eAAe;IACf,uBAAuB;IACvB,eAAe;IACf,cAAc;IACd,aAAa;IACb,YAAY;IACZ,mBAAmB;IACnB,aAAa;IACb,YAAY;CACb,CAAC;AAcF,MAAM,OAAO,UAAU;IACrB,MAAM,CAAC,OAAO,CACZ,MAAwB,EACxB,iBAAiB,GAAG,EAAE,EACtB,sBAAgC,EAAE;QAElC,OAAO;YACL,QAAQ,EAAE,UAAU;YACpB,SAAS,EAAE;gBACT,EAAE,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,EAAE;gBAC9C,EAAE,OAAO,EAAE,mBAAmB,EAAE,QAAQ,EAAE,iBAAiB,EAAE;gBAC7D,EAAE,OAAO,EAAE,qBAAqB,EAAE,QAAQ,EAAE,mBAAmB,EAAE;aAClE;SACF,CAAC;IACJ,CAAC;uGAdU,UAAU;wGAAV,UAAU,YApDrB,cAAc;YACd,YAAY;YACZ,gBAAgB;YAChB,mBAAmB;YACnB,iBAAiB;YACjB,mBAAmB;YACnB,YAAY;YACZ,cAAc;YACd,qBAAqB;YACrB,cAAc;YACd,YAAY;YACZ,YAAY;YACZ,YAAY;YACZ,aAAa;YACb,cAAc;YACd,YAAY;YACZ,oBAAoB;YACpB,uBAAuB;YACvB,qBAAqB;YACrB,YAAY;YACZ,mBAAmB;YACnB,gBAAgB;YAChB,oBAAoB;YACpB,mBAAmB;YACnB,mBAAmB;YACnB,iBAAiB;YACjB,cAAc;YACd,eAAe;YACf,aAAa;YACb,eAAe;YACf,uBAAuB;YACvB,eAAe;YACf,cAAc;YACd,aAAa;YACb,YAAY;YACZ,mBAAmB;YACnB,aAAa;YACb,YAAY,aArCZ,cAAc;YACd,YAAY;YACZ,gBAAgB;YAChB,mBAAmB;YACnB,iBAAiB;YACjB,mBAAmB;YACnB,YAAY;YACZ,cAAc;YACd,qBAAqB;YACrB,cAAc;YACd,YAAY;YACZ,YAAY;YACZ,YAAY;YACZ,aAAa;YACb,cAAc;YACd,YAAY;YACZ,oBAAoB;YACpB,uBAAuB;YACvB,qBAAqB;YACrB,YAAY;YACZ,mBAAmB;YACnB,gBAAgB;YAChB,oBAAoB;YACpB,mBAAmB;YACnB,mBAAmB;YACnB,iBAAiB;YACjB,cAAc;YACd,eAAe;YACf,aAAa;YACb,eAAe;YACf,uBAAuB;YACvB,eAAe;YACf,cAAc;YACd,aAAa;YACb,YAAY;YACZ,mBAAmB;YACnB,aAAa;YACb,YAAY;wGAeD,UAAU,aATV;YACT,qBAAqB;YACrB;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,QAAQ,EAAE,qCAAqC;gBAC/C,KAAK,EAAE,IAAI;aACZ;SACF,YATS,aAAa,EAzCvB,cAAc;YACd,YAAY;YACZ,gBAAgB;YAChB,mBAAmB;YACnB,iBAAiB;YACjB,mBAAmB;YACnB,YAAY;YACZ,cAAc;YACd,qBAAqB;YACrB,cAAc;YACd,YAAY;YACZ,YAAY;YACZ,YAAY;YACZ,aAAa;YACb,cAAc;YACd,YAAY;YACZ,oBAAoB;YACpB,uBAAuB;YACvB,qBAAqB;YACrB,YAAY;YACZ,mBAAmB;YACnB,gBAAgB;YAChB,oBAAoB;YACpB,mBAAmB;YACnB,mBAAmB;YACnB,iBAAiB;YACjB,cAAc;YACd,eAAe;YACf,aAAa;YACb,eAAe;YACf,uBAAuB;YACvB,eAAe;YACf,cAAc;YACd,aAAa;YACb,YAAY;YACZ,mBAAmB;YACnB,aAAa;YACb,YAAY;;2FAeD,UAAU;kBAZtB,QAAQ;mBAAC;oBACR,OAAO,EAAE,CAAC,aAAa,CAAC;oBACxB,OAAO,EAAE,aAAa;oBACtB,SAAS,EAAE;wBACT,qBAAqB;wBACrB;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,QAAQ,EAAE,qCAAqC;4BAC/C,KAAK,EAAE,IAAI;yBACZ;qBACF;iBACF","sourcesContent":["import { HTTP_INTERCEPTORS } from '@angular/common/http';\nimport { ModuleWithProviders, NgModule } from '@angular/core';\n\nimport {\n  BACKEND_ERROR_CODES,\n  WHITELIST_ERROR_CODES,\n  QdNotificationsHttpInterceptorService\n} from './notifications/services/notifications-http-interceptor.service';\n\nimport { QdAppEnvironment } from './core/model/app-enviroment.interface';\nimport { APP_ENVIRONMENT } from './core/model/app-enviroment.token';\n\nimport { QdButtonModule } from './button/button.module';\nimport { QdChipModule } from './chips/chips.module';\nimport { QdCommentsModule } from './comments/comments.module';\nimport { QdContactCardModule } from './contact-card/contact-card.module';\nimport { QdContainerModule } from './container/container.module';\nimport { QdContentGridModule } from './content-grid/content-grid.module';\nimport { QdCoreModule } from './core/core.module';\nimport { QdDialogModule } from './dialog/dialog.module';\nimport { QdFileCollectorModule } from './file-collector/file-collector.module';\nimport { QdFilterModule } from './filter/filter.module';\nimport { QdFormModule } from './forms/qd-form.module';\nimport { QdGridModule } from './grid/grid.module';\nimport { QdIconModule } from './icon/icon.module';\nimport { QdImageModule } from './image/image.module';\nimport { QdLayoutModule } from './layout/layout.module';\nimport { QdListModule } from './lists/list.module';\nimport { QdMasterLayoutModule } from './master-layout/master-layout.module';\nimport { QdMasterLayoutService } from './master-layout/service/master-layout.service';\nimport { QdNavigationTilesModule } from './navigation-tiles/navigation-tiles.module';\nimport { QdNotificationsModule } from './notifications/notifications.module';\nimport { QdPageModule } from './page/page.module';\nimport { QdPageStepperModule } from './page-stepper/page-stepper.module';\nimport { QdPageTabsModule } from './page-tabs/page-tabs.module';\nimport { QdPlaceHolderModule } from './place-holder/place-holder.module';\nimport { QdProgressBarModule } from './progress-bar/progress-bar.module';\nimport { QdQuickEditModule } from './quick-edit/quick-edit.module';\nimport { QdSearchModule } from './search/search.module';\nimport { QdSectionModule } from './section/section.module';\nimport { QdShellModule } from './shell/shell.module';\nimport { QdSpinnerModule } from './spinner/spinner.module';\nimport { QdStatusIndicatorModule } from './status-indicator/status-indicator.module';\nimport { QdStepperModule } from './navigation/stepper/stepper.module';\nimport { QdTabBarModule } from './navigation/tab-bar/tab-bar.module';\nimport { QdTableModule } from './table/table.module';\nimport { QdTabsModule } from './navigation/tabs/tabs.module';\nimport { QdTextSectionModule } from './text-section/text-section.module';\nimport { QdTilesModule } from './tiles/tiles.module';\nimport { QdTreeModule } from './tree/tree.module';\nimport { QdPanelSectionModule } from './panel-section/panel-section.module';\n\nconst QD_UI_MODULES = [\n  QdButtonModule,\n  QdChipModule,\n  QdCommentsModule,\n  QdContactCardModule,\n  QdContainerModule,\n  QdContentGridModule,\n  QdCoreModule,\n  QdDialogModule,\n  QdFileCollectorModule,\n  QdFilterModule,\n  QdFormModule,\n  QdGridModule,\n  QdIconModule,\n  QdImageModule,\n  QdLayoutModule,\n  QdListModule,\n  QdMasterLayoutModule,\n  QdNavigationTilesModule,\n  QdNotificationsModule,\n  QdPageModule,\n  QdPageStepperModule,\n  QdPageTabsModule,\n  QdPanelSectionModule,\n  QdPlaceHolderModule,\n  QdProgressBarModule,\n  QdQuickEditModule,\n  QdSearchModule,\n  QdSectionModule,\n  QdShellModule,\n  QdSpinnerModule,\n  QdStatusIndicatorModule,\n  QdStepperModule,\n  QdTabBarModule,\n  QdTableModule,\n  QdTabsModule,\n  QdTextSectionModule,\n  QdTilesModule,\n  QdTreeModule\n];\n\n@NgModule({\n  imports: [QD_UI_MODULES],\n  exports: QD_UI_MODULES,\n  providers: [\n    QdMasterLayoutService,\n    {\n      provide: HTTP_INTERCEPTORS,\n      useClass: QdNotificationsHttpInterceptorService,\n      multi: true\n    }\n  ]\n})\nexport class QdUiModule {\n  static forRoot(\n    config: QdAppEnvironment,\n    backendErrorCodes = {},\n    whitelistErrorCodes: number[] = []\n  ): ModuleWithProviders<QdUiModule> {\n    return {\n      ngModule: QdUiModule,\n      providers: [\n        { provide: APP_ENVIRONMENT, useValue: config },\n        { provide: BACKEND_ERROR_CODES, useValue: backendErrorCodes },\n        { provide: WHITELIST_ERROR_CODES, useValue: whitelistErrorCodes }\n      ]\n    };\n  }\n}\n"]}
|
|
@@ -1700,27 +1700,54 @@ const APP_ENVIRONMENT = new InjectionToken('APP_ENVIRONMENT');
|
|
|
1700
1700
|
|
|
1701
1701
|
// @ts-strict-ignore
|
|
1702
1702
|
const BACKEND_ERROR_CODES = new InjectionToken('BACKEND_ERROR_CODES');
|
|
1703
|
+
const WHITELIST_ERROR_CODES = new InjectionToken('WHITELIST_ERROR_CODES');
|
|
1703
1704
|
/**
|
|
1704
1705
|
* The QdNotificationsHttpInterceptorService is an Angular HTTP interceptor that captures error responses from HTTP requests and generates notifications for backend errors. This Service not only intercepts error responses, but it also handles specific error codes and translates them into appropriate error messages for display.
|
|
1705
1706
|
*/
|
|
1706
1707
|
class QdNotificationsHttpInterceptorService {
|
|
1707
1708
|
appEnvironment;
|
|
1708
1709
|
backendErrorCodes;
|
|
1710
|
+
whitelistErrorCodes;
|
|
1709
1711
|
notificationService;
|
|
1710
|
-
|
|
1712
|
+
blacklistErrorCodes;
|
|
1713
|
+
constructor(appEnvironment, backendErrorCodes, whitelistErrorCodes, notificationService) {
|
|
1711
1714
|
this.appEnvironment = appEnvironment;
|
|
1712
1715
|
this.backendErrorCodes = backendErrorCodes;
|
|
1716
|
+
this.whitelistErrorCodes = whitelistErrorCodes;
|
|
1713
1717
|
this.notificationService = notificationService;
|
|
1714
1718
|
this.backendErrorCodes = this.backendErrorCodes || {};
|
|
1719
|
+
this.whitelistErrorCodes = this.whitelistErrorCodes || [];
|
|
1720
|
+
this.blacklistErrorCodes = [
|
|
1721
|
+
// 401, 402, 403
|
|
1722
|
+
HttpStatusCode.Unauthorized,
|
|
1723
|
+
HttpStatusCode.PaymentRequired,
|
|
1724
|
+
HttpStatusCode.Forbidden,
|
|
1725
|
+
// All 5xx codes
|
|
1726
|
+
HttpStatusCode.InternalServerError,
|
|
1727
|
+
HttpStatusCode.NotImplemented,
|
|
1728
|
+
HttpStatusCode.BadGateway,
|
|
1729
|
+
HttpStatusCode.ServiceUnavailable,
|
|
1730
|
+
HttpStatusCode.GatewayTimeout,
|
|
1731
|
+
HttpStatusCode.HttpVersionNotSupported,
|
|
1732
|
+
HttpStatusCode.VariantAlsoNegotiates,
|
|
1733
|
+
HttpStatusCode.InsufficientStorage,
|
|
1734
|
+
HttpStatusCode.LoopDetected,
|
|
1735
|
+
HttpStatusCode.NotExtended,
|
|
1736
|
+
HttpStatusCode.NetworkAuthenticationRequired
|
|
1737
|
+
];
|
|
1715
1738
|
}
|
|
1716
1739
|
intercept(request, next) {
|
|
1717
1740
|
if (this.appEnvironment.disableBackendNotifications)
|
|
1718
1741
|
return next.handle(request);
|
|
1719
1742
|
return next.handle(request).pipe(catchError((error) => {
|
|
1720
|
-
|
|
1721
|
-
|
|
1722
|
-
|
|
1723
|
-
|
|
1743
|
+
const isBlacklisted = this.blacklistErrorCodes.includes(error.status);
|
|
1744
|
+
const shouldShowNotification = isBlacklisted || !this.whitelistErrorCodes.includes(error.status);
|
|
1745
|
+
if (shouldShowNotification) {
|
|
1746
|
+
let i18n = this.getErrorTranslationKeyForHttpStatus(error.status);
|
|
1747
|
+
if (error.error?.errorCode && error.error.errorCode in this.backendErrorCodes)
|
|
1748
|
+
i18n = 'ERROR.' + error.error.errorCode;
|
|
1749
|
+
this.notificationService.add('qdPanel', { type: 'critical', i18n, showAsSnackbar: true });
|
|
1750
|
+
}
|
|
1724
1751
|
return throwError(() => error);
|
|
1725
1752
|
}));
|
|
1726
1753
|
}
|
|
@@ -1747,7 +1774,7 @@ class QdNotificationsHttpInterceptorService {
|
|
|
1747
1774
|
return 'UnknownError';
|
|
1748
1775
|
}
|
|
1749
1776
|
}
|
|
1750
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdNotificationsHttpInterceptorService, deps: [{ token: APP_ENVIRONMENT, optional: true }, { token: BACKEND_ERROR_CODES, optional: true }, { token: QdNotificationsService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
1777
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdNotificationsHttpInterceptorService, deps: [{ token: APP_ENVIRONMENT, optional: true }, { token: BACKEND_ERROR_CODES, optional: true }, { token: WHITELIST_ERROR_CODES, optional: true }, { token: QdNotificationsService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
1751
1778
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdNotificationsHttpInterceptorService, providedIn: 'root' });
|
|
1752
1779
|
}
|
|
1753
1780
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdNotificationsHttpInterceptorService, decorators: [{
|
|
@@ -1765,6 +1792,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
1765
1792
|
}, {
|
|
1766
1793
|
type: Inject,
|
|
1767
1794
|
args: [BACKEND_ERROR_CODES]
|
|
1795
|
+
}] }, { type: undefined, decorators: [{
|
|
1796
|
+
type: Optional
|
|
1797
|
+
}, {
|
|
1798
|
+
type: Inject,
|
|
1799
|
+
args: [WHITELIST_ERROR_CODES]
|
|
1768
1800
|
}] }, { type: QdNotificationsService }] });
|
|
1769
1801
|
|
|
1770
1802
|
// @ts-strict-ignore
|
|
@@ -15600,9 +15632,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
15600
15632
|
|
|
15601
15633
|
// @ts-strict-ignore
|
|
15602
15634
|
class QdSwitchComponent {
|
|
15603
|
-
// TODO: Refactor FormInput for better internal interface
|
|
15604
15635
|
inputData;
|
|
15605
|
-
value;
|
|
15606
15636
|
id;
|
|
15607
15637
|
disabled = false;
|
|
15608
15638
|
testId = 'switch';
|
|
@@ -15623,60 +15653,19 @@ class QdSwitchComponent {
|
|
|
15623
15653
|
get labelPosition() {
|
|
15624
15654
|
return this.inputData.labelPosition || 'right';
|
|
15625
15655
|
}
|
|
15626
|
-
_onChange = () => { };
|
|
15627
|
-
_onTouch = () => { };
|
|
15628
15656
|
ngOnInit() {
|
|
15629
15657
|
if (!this.id) {
|
|
15630
15658
|
this.id = v4();
|
|
15631
15659
|
}
|
|
15632
15660
|
}
|
|
15633
|
-
registerOnChange(fn) {
|
|
15634
|
-
this._onChange = fn;
|
|
15635
|
-
this._onChange(this.value);
|
|
15636
|
-
}
|
|
15637
|
-
registerOnTouched(fn) {
|
|
15638
|
-
this._onTouch = fn;
|
|
15639
|
-
}
|
|
15640
|
-
setDisabledState(state) {
|
|
15641
|
-
this.disabled = state;
|
|
15642
|
-
}
|
|
15643
|
-
writeValue(value) {
|
|
15644
|
-
this.value = value;
|
|
15645
|
-
this.valueChange.emit(this.value);
|
|
15646
|
-
}
|
|
15647
|
-
handleClick(value, event) {
|
|
15648
|
-
event.stopPropagation();
|
|
15649
|
-
if (this.disabled) {
|
|
15650
|
-
return;
|
|
15651
|
-
}
|
|
15652
|
-
const _value = value !== this.value ? value : null;
|
|
15653
|
-
this._onChange(_value);
|
|
15654
|
-
this._onTouch(_value);
|
|
15655
|
-
this.value = _value;
|
|
15656
|
-
this.valueChange.emit(this.value);
|
|
15657
|
-
}
|
|
15658
15661
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdSwitchComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
15659
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdSwitchComponent, selector: "qd-switch", inputs: { inputData: "inputData",
|
|
15660
|
-
{
|
|
15661
|
-
provide: NG_VALUE_ACCESSOR,
|
|
15662
|
-
useExisting: QdSwitchComponent,
|
|
15663
|
-
multi: true
|
|
15664
|
-
}
|
|
15665
|
-
], ngImport: i0, template: "<label [for]=\"toggleId\">\n <div class=\"switch-content\" *ngIf=\"labelPosition === 'left'\" [attr.data-test-id]=\"testId + '-label'\">\n {{ label | translate }}\n </div>\n <div class=\"switch-toggle-bar\">\n <input\n class=\"switch-toggle-input\"\n name=\"switch-toggle\"\n type=\"checkbox\"\n [id]=\"toggleId\"\n (click)=\"handleClick(value, $event)\"\n [value]=\"value\"\n [disabled]=\"isDisabled\"\n [attr.data-test-id]=\"testId + '-input'\"\n />\n <div class=\"switch-toggle-button\"></div>\n </div>\n <div class=\"switch-content\" *ngIf=\"labelPosition === 'right'\" [attr.data-test-id]=\"testId + '-content'\">\n {{ label | translate }}\n </div>\n</label>\n", styles: [".qd-switch label{display:flex;width:max-content;align-items:center}.qd-switch label:hover{cursor:pointer}.qd-switch .switch-toggle-bar{position:relative;width:2.5rem;height:1.25rem;border-radius:1.25rem;background-color:#e5e5e5}.qd-switch .switch-toggle-bar input{appearance:none}.qd-switch .switch-toggle-bar .switch-toggle-button{position:absolute;top:0;width:1.25rem;height:1.25rem;border-radius:1.25rem;background-color:#b4b4b4;transition:all 80ms linear;transition-property:transform}.qd-switch .switch-content{margin-right:.75rem;margin-left:.75rem;color:#171717;font-size:.875rem;font-weight:400;line-height:.875rem}.qd-switch:hover .switch-toggle-bar{background-color:#d5d5d5}.qd-switch:hover .switch-toggle-bar .switch-toggle-button{background-color:#979797}.qd-switch.qd-switch-active .switch-toggle-bar{background-color:#c3e8cd}.qd-switch.qd-switch-active .switch-toggle-bar .switch-toggle-button{background-color:#00813a;transform:translate(1.25rem)}.qd-switch.qd-switch-active:hover .switch-toggle-bar .switch-toggle-button{background-color:#006226}.qd-switch.qd-switch-disabled label:hover{cursor:initial}.qd-switch.qd-switch-disabled .switch-toggle-bar{background-color:#efefef}.qd-switch.qd-switch-disabled .switch-toggle-bar .switch-toggle-button{background-color:#d5d5d5}.qd-switch.qd-switch-disabled .switch-content{color:#757575}.qd-switch.qd-switch-disabled:hover .switch-toggle-bar{background-color:#efefef}.qd-switch.qd-switch-disabled:hover .switch-toggle-bar .switch-toggle-button{background-color:#d5d5d5}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1$2.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None });
|
|
15662
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdSwitchComponent, selector: "qd-switch", inputs: { inputData: "inputData", id: "id", disabled: "disabled", testId: ["data-test-id", "testId"] }, outputs: { valueChange: "valueChange" }, host: { properties: { "class.qd-switch-active": "this.active", "class.qd-switch-disabled": "this.isDisabled" }, classAttribute: "qd-switch" }, ngImport: i0, template: "<label [for]=\"toggleId\">\n <div class=\"switch-content\" *ngIf=\"labelPosition === 'left'\" [attr.data-test-id]=\"testId + '-label'\">\n {{ label | translate }}\n </div>\n <div class=\"switch-toggle-bar\">\n <div class=\"switch-toggle-button\"></div>\n </div>\n <div class=\"switch-content\" *ngIf=\"labelPosition === 'right'\" [attr.data-test-id]=\"testId + '-content'\">\n {{ label | translate }}\n </div>\n</label>\n", styles: [".qd-switch label{display:flex;width:max-content;align-items:center}.qd-switch label:hover{cursor:pointer}.qd-switch .switch-toggle-bar{position:relative;width:2.5rem;height:1.25rem;border-radius:1.25rem;background-color:#e5e5e5}.qd-switch .switch-toggle-bar .switch-toggle-button{position:absolute;top:0;width:1.25rem;height:1.25rem;border-radius:1.25rem;background-color:#b4b4b4;transition:all 80ms linear;transition-property:transform}.qd-switch .switch-content{margin-right:.75rem;margin-left:.75rem;color:#171717;font-size:.875rem;font-weight:400;line-height:.875rem}.qd-switch:hover .switch-toggle-bar{background-color:#d5d5d5}.qd-switch:hover .switch-toggle-bar .switch-toggle-button{background-color:#979797}.qd-switch.qd-switch-active .switch-toggle-bar{background-color:#c3e8cd}.qd-switch.qd-switch-active .switch-toggle-bar .switch-toggle-button{background-color:#00813a;transform:translate(1.25rem)}.qd-switch.qd-switch-active:hover .switch-toggle-bar .switch-toggle-button{background-color:#006226}.qd-switch.qd-switch-disabled label:hover{cursor:initial}.qd-switch.qd-switch-disabled .switch-toggle-bar{background-color:#efefef}.qd-switch.qd-switch-disabled .switch-toggle-bar .switch-toggle-button{background-color:#d5d5d5}.qd-switch.qd-switch-disabled .switch-content{color:#757575}.qd-switch.qd-switch-disabled:hover .switch-toggle-bar{background-color:#efefef}.qd-switch.qd-switch-disabled:hover .switch-toggle-bar .switch-toggle-button{background-color:#d5d5d5}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1$2.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None });
|
|
15666
15663
|
}
|
|
15667
15664
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdSwitchComponent, decorators: [{
|
|
15668
15665
|
type: Component,
|
|
15669
|
-
args: [{ selector: 'qd-switch', encapsulation: ViewEncapsulation.None,
|
|
15670
|
-
{
|
|
15671
|
-
provide: NG_VALUE_ACCESSOR,
|
|
15672
|
-
useExisting: QdSwitchComponent,
|
|
15673
|
-
multi: true
|
|
15674
|
-
}
|
|
15675
|
-
], host: { class: 'qd-switch' }, template: "<label [for]=\"toggleId\">\n <div class=\"switch-content\" *ngIf=\"labelPosition === 'left'\" [attr.data-test-id]=\"testId + '-label'\">\n {{ label | translate }}\n </div>\n <div class=\"switch-toggle-bar\">\n <input\n class=\"switch-toggle-input\"\n name=\"switch-toggle\"\n type=\"checkbox\"\n [id]=\"toggleId\"\n (click)=\"handleClick(value, $event)\"\n [value]=\"value\"\n [disabled]=\"isDisabled\"\n [attr.data-test-id]=\"testId + '-input'\"\n />\n <div class=\"switch-toggle-button\"></div>\n </div>\n <div class=\"switch-content\" *ngIf=\"labelPosition === 'right'\" [attr.data-test-id]=\"testId + '-content'\">\n {{ label | translate }}\n </div>\n</label>\n", styles: [".qd-switch label{display:flex;width:max-content;align-items:center}.qd-switch label:hover{cursor:pointer}.qd-switch .switch-toggle-bar{position:relative;width:2.5rem;height:1.25rem;border-radius:1.25rem;background-color:#e5e5e5}.qd-switch .switch-toggle-bar input{appearance:none}.qd-switch .switch-toggle-bar .switch-toggle-button{position:absolute;top:0;width:1.25rem;height:1.25rem;border-radius:1.25rem;background-color:#b4b4b4;transition:all 80ms linear;transition-property:transform}.qd-switch .switch-content{margin-right:.75rem;margin-left:.75rem;color:#171717;font-size:.875rem;font-weight:400;line-height:.875rem}.qd-switch:hover .switch-toggle-bar{background-color:#d5d5d5}.qd-switch:hover .switch-toggle-bar .switch-toggle-button{background-color:#979797}.qd-switch.qd-switch-active .switch-toggle-bar{background-color:#c3e8cd}.qd-switch.qd-switch-active .switch-toggle-bar .switch-toggle-button{background-color:#00813a;transform:translate(1.25rem)}.qd-switch.qd-switch-active:hover .switch-toggle-bar .switch-toggle-button{background-color:#006226}.qd-switch.qd-switch-disabled label:hover{cursor:initial}.qd-switch.qd-switch-disabled .switch-toggle-bar{background-color:#efefef}.qd-switch.qd-switch-disabled .switch-toggle-bar .switch-toggle-button{background-color:#d5d5d5}.qd-switch.qd-switch-disabled .switch-content{color:#757575}.qd-switch.qd-switch-disabled:hover .switch-toggle-bar{background-color:#efefef}.qd-switch.qd-switch-disabled:hover .switch-toggle-bar .switch-toggle-button{background-color:#d5d5d5}\n"] }]
|
|
15666
|
+
args: [{ selector: 'qd-switch', encapsulation: ViewEncapsulation.None, host: { class: 'qd-switch' }, template: "<label [for]=\"toggleId\">\n <div class=\"switch-content\" *ngIf=\"labelPosition === 'left'\" [attr.data-test-id]=\"testId + '-label'\">\n {{ label | translate }}\n </div>\n <div class=\"switch-toggle-bar\">\n <div class=\"switch-toggle-button\"></div>\n </div>\n <div class=\"switch-content\" *ngIf=\"labelPosition === 'right'\" [attr.data-test-id]=\"testId + '-content'\">\n {{ label | translate }}\n </div>\n</label>\n", styles: [".qd-switch label{display:flex;width:max-content;align-items:center}.qd-switch label:hover{cursor:pointer}.qd-switch .switch-toggle-bar{position:relative;width:2.5rem;height:1.25rem;border-radius:1.25rem;background-color:#e5e5e5}.qd-switch .switch-toggle-bar .switch-toggle-button{position:absolute;top:0;width:1.25rem;height:1.25rem;border-radius:1.25rem;background-color:#b4b4b4;transition:all 80ms linear;transition-property:transform}.qd-switch .switch-content{margin-right:.75rem;margin-left:.75rem;color:#171717;font-size:.875rem;font-weight:400;line-height:.875rem}.qd-switch:hover .switch-toggle-bar{background-color:#d5d5d5}.qd-switch:hover .switch-toggle-bar .switch-toggle-button{background-color:#979797}.qd-switch.qd-switch-active .switch-toggle-bar{background-color:#c3e8cd}.qd-switch.qd-switch-active .switch-toggle-bar .switch-toggle-button{background-color:#00813a;transform:translate(1.25rem)}.qd-switch.qd-switch-active:hover .switch-toggle-bar .switch-toggle-button{background-color:#006226}.qd-switch.qd-switch-disabled label:hover{cursor:initial}.qd-switch.qd-switch-disabled .switch-toggle-bar{background-color:#efefef}.qd-switch.qd-switch-disabled .switch-toggle-bar .switch-toggle-button{background-color:#d5d5d5}.qd-switch.qd-switch-disabled .switch-content{color:#757575}.qd-switch.qd-switch-disabled:hover .switch-toggle-bar{background-color:#efefef}.qd-switch.qd-switch-disabled:hover .switch-toggle-bar .switch-toggle-button{background-color:#d5d5d5}\n"] }]
|
|
15676
15667
|
}], propDecorators: { inputData: [{
|
|
15677
15668
|
type: Input
|
|
15678
|
-
}], value: [{
|
|
15679
|
-
type: Input
|
|
15680
15669
|
}], id: [{
|
|
15681
15670
|
type: Input
|
|
15682
15671
|
}], disabled: [{
|
|
@@ -15966,7 +15955,7 @@ class QdSwitchesComponent {
|
|
|
15966
15955
|
},
|
|
15967
15956
|
QdSwitchesService,
|
|
15968
15957
|
QdFormsActionEmitterService
|
|
15969
|
-
], usesOnChanges: true, ngImport: i0, template: "<qd-form-label\n [label]=\"label\"\n [readonly]=\"readonly\"\n [viewonly]=\"viewonly\"\n [control]=\"control\"\n [tooltip]=\"config?.tooltip\"\n [data-test-id]=\"testId\"\n></qd-form-label>\n\n<div class=\"qd-switches__input-section\" *ngIf=\"!readonly && !viewonly\">\n <div class=\"qd-switches__switch-section\">\n <qd-switch\n *ngFor=\"let input of switchesInputs\"\n [inputData]=\"input\"\n
|
|
15958
|
+
], usesOnChanges: true, ngImport: i0, template: "<qd-form-label\n [label]=\"label\"\n [readonly]=\"readonly\"\n [viewonly]=\"viewonly\"\n [control]=\"control\"\n [tooltip]=\"config?.tooltip\"\n [data-test-id]=\"testId\"\n></qd-form-label>\n\n<div class=\"qd-switches__input-section\" *ngIf=\"!readonly && !viewonly\">\n <div class=\"qd-switches__switch-section\">\n <qd-switch\n *ngFor=\"let input of switchesInputs\"\n [inputData]=\"input\"\n (click)=\"handleClick(input)\"\n [data-test-id]=\"testId + '-switch-' + input.index\"\n [disabled]=\"disabled\"\n ></qd-switch>\n </div>\n</div>\n\n<qd-form-hint\n *ngIf=\"!readonly && !viewonly\"\n [hint]=\"hasHint ? config.hint.i18n : ''\"\n [control]=\"control\"\n [hasError]=\"hasError\"\n [hintAction]=\"hintAction\"\n [data-test-id]=\"testId\"\n></qd-form-hint>\n\n<qd-form-readonly\n *ngIf=\"readonly\"\n [values]=\"selectedValuesTranslated\"\n [readonlyAction]=\"readonlyAction\"\n [data-test-id]=\"testId\"\n></qd-form-readonly>\n\n<qd-form-viewonly\n *ngIf=\"viewonly\"\n [values]=\"selectedValuesTranslated\"\n [viewonlyAction]=\"viewonlyAction\"\n [data-test-id]=\"testId\"\n></qd-form-viewonly>\n", styles: [".qd-switches{display:block;flex-direction:column;margin-bottom:.75rem}.qd-switches .qd-switches__input-section{display:flex;flex-direction:column;margin-bottom:.375rem}.qd-switches .qd-switches__switch-section{display:flex;flex-direction:row}.qd-switches .qd-switches__switch-section .switch-toggle-bar{margin-right:.375rem}.qd-switches .qd-switches__switch-section .switch-content{margin:0 1rem 0 0}.qd-switches qd-switch:last-child .switch-content{margin-right:0}.qd-switches.qd-switches-vertical .qd-switches__switch-section{display:flex;flex-direction:column}.qd-switches.qd-switches-vertical .qd-switches__switch-section .qd-switch:not(:last-child){margin-bottom:.5rem}.qd-switches:not(.qd-switches-vertical) .qd-switches__switch-section{align-items:center}.qd-switches:not(.qd-switches-vertical) .qd-switches__switch-section .qd-switch{display:flex;height:2.25rem}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: QdFormHintComponent, selector: "qd-form-hint", inputs: ["hint", "control", "hasError", "hintAction", "data-test-id"] }, { kind: "component", type: QdFormLabelComponent, selector: "qd-form-label", inputs: ["label", "isDisabled", "readonly", "viewonly", "control", "tooltip", "data-test-id"] }, { kind: "component", type: QdFormReadonlyComponent, selector: "qd-form-readonly", inputs: ["values", "readonlyAction", "data-test-id"] }, { kind: "component", type: QdFormViewonlyComponent, selector: "qd-form-viewonly", inputs: ["values", "viewonlyAction", "data-test-id"] }, { kind: "component", type: QdSwitchComponent, selector: "qd-switch", inputs: ["inputData", "id", "disabled", "data-test-id"], outputs: ["valueChange"] }], encapsulation: i0.ViewEncapsulation.None });
|
|
15970
15959
|
}
|
|
15971
15960
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdSwitchesComponent, decorators: [{
|
|
15972
15961
|
type: Component,
|
|
@@ -15978,7 +15967,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
15978
15967
|
},
|
|
15979
15968
|
QdSwitchesService,
|
|
15980
15969
|
QdFormsActionEmitterService
|
|
15981
|
-
], encapsulation: ViewEncapsulation.None, host: { class: 'qd-switches' }, template: "<qd-form-label\n [label]=\"label\"\n [readonly]=\"readonly\"\n [viewonly]=\"viewonly\"\n [control]=\"control\"\n [tooltip]=\"config?.tooltip\"\n [data-test-id]=\"testId\"\n></qd-form-label>\n\n<div class=\"qd-switches__input-section\" *ngIf=\"!readonly && !viewonly\">\n <div class=\"qd-switches__switch-section\">\n <qd-switch\n *ngFor=\"let input of switchesInputs\"\n [inputData]=\"input\"\n
|
|
15970
|
+
], encapsulation: ViewEncapsulation.None, host: { class: 'qd-switches' }, template: "<qd-form-label\n [label]=\"label\"\n [readonly]=\"readonly\"\n [viewonly]=\"viewonly\"\n [control]=\"control\"\n [tooltip]=\"config?.tooltip\"\n [data-test-id]=\"testId\"\n></qd-form-label>\n\n<div class=\"qd-switches__input-section\" *ngIf=\"!readonly && !viewonly\">\n <div class=\"qd-switches__switch-section\">\n <qd-switch\n *ngFor=\"let input of switchesInputs\"\n [inputData]=\"input\"\n (click)=\"handleClick(input)\"\n [data-test-id]=\"testId + '-switch-' + input.index\"\n [disabled]=\"disabled\"\n ></qd-switch>\n </div>\n</div>\n\n<qd-form-hint\n *ngIf=\"!readonly && !viewonly\"\n [hint]=\"hasHint ? config.hint.i18n : ''\"\n [control]=\"control\"\n [hasError]=\"hasError\"\n [hintAction]=\"hintAction\"\n [data-test-id]=\"testId\"\n></qd-form-hint>\n\n<qd-form-readonly\n *ngIf=\"readonly\"\n [values]=\"selectedValuesTranslated\"\n [readonlyAction]=\"readonlyAction\"\n [data-test-id]=\"testId\"\n></qd-form-readonly>\n\n<qd-form-viewonly\n *ngIf=\"viewonly\"\n [values]=\"selectedValuesTranslated\"\n [viewonlyAction]=\"viewonlyAction\"\n [data-test-id]=\"testId\"\n></qd-form-viewonly>\n", styles: [".qd-switches{display:block;flex-direction:column;margin-bottom:.75rem}.qd-switches .qd-switches__input-section{display:flex;flex-direction:column;margin-bottom:.375rem}.qd-switches .qd-switches__switch-section{display:flex;flex-direction:row}.qd-switches .qd-switches__switch-section .switch-toggle-bar{margin-right:.375rem}.qd-switches .qd-switches__switch-section .switch-content{margin:0 1rem 0 0}.qd-switches qd-switch:last-child .switch-content{margin-right:0}.qd-switches.qd-switches-vertical .qd-switches__switch-section{display:flex;flex-direction:column}.qd-switches.qd-switches-vertical .qd-switches__switch-section .qd-switch:not(:last-child){margin-bottom:.5rem}.qd-switches:not(.qd-switches-vertical) .qd-switches__switch-section{align-items:center}.qd-switches:not(.qd-switches-vertical) .qd-switches__switch-section .qd-switch{display:flex;height:2.25rem}\n"] }]
|
|
15982
15971
|
}], ctorParameters: () => [{ type: QdSwitchesService }, { type: i0.ChangeDetectorRef }, { type: QdFormsActionEmitterService }, { type: i1$4.ControlContainer, decorators: [{
|
|
15983
15972
|
type: Optional
|
|
15984
15973
|
}, {
|
|
@@ -16961,6 +16950,42 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
|
|
|
16961
16950
|
* }
|
|
16962
16951
|
* ```
|
|
16963
16952
|
*
|
|
16953
|
+
* ### Whitelisting HTTP status codes
|
|
16954
|
+
*
|
|
16955
|
+
* In some cases, you might want to prevent certain HTTP status codes from triggering error notifications. For example, a 304 Not Modified response is not actually an error and should not display an error notification. The **QdUiModule** allows you to whitelist specific HTTP status codes.
|
|
16956
|
+
*
|
|
16957
|
+
* To whitelist HTTP status codes, pass an array of status codes as the third parameter to the **QdUiModule.forRoot** method:
|
|
16958
|
+
*
|
|
16959
|
+
* ```typescript
|
|
16960
|
+
* import { HttpStatusCode } from '@angular/common/http';
|
|
16961
|
+
*
|
|
16962
|
+
* imports: [
|
|
16963
|
+
* ...
|
|
16964
|
+
* QdUiModule.forRoot(
|
|
16965
|
+
* appEnvironment,
|
|
16966
|
+
* ErrorCodes,
|
|
16967
|
+
* [HttpStatusCode.NotModified, HttpStatusCode.NoContent] // Whitelist 304 Not Modified and 204 No Content
|
|
16968
|
+
* ),
|
|
16969
|
+
* ...
|
|
16970
|
+
* ]
|
|
16971
|
+
* ```
|
|
16972
|
+
*
|
|
16973
|
+
* When a response with a whitelisted status code is received, no error notification will be displayed, even if it would normally be treated as an error by the HTTP client.
|
|
16974
|
+
*
|
|
16975
|
+
* ### Blacklisting HTTP status codes
|
|
16976
|
+
*
|
|
16977
|
+
* For critical errors, notifications are always shown, even if the status code is whitelisted. The **QdUiModule** implements a fixed blacklist that takes precedence over the whitelist.
|
|
16978
|
+
*
|
|
16979
|
+
* The following status codes are permanently blacklisted:
|
|
16980
|
+
* - 401 Unauthorized
|
|
16981
|
+
* - 402 Payment Required
|
|
16982
|
+
* - 403 Forbidden
|
|
16983
|
+
* - All 5xx server error codes (500-511)
|
|
16984
|
+
*
|
|
16985
|
+
* These critical errors will always show notifications, even if they are included in the whitelist.
|
|
16986
|
+
*
|
|
16987
|
+
* **Important**: The blacklist has higher precedence than the whitelist. If a status code appears in both the whitelist and the blacklist, it will be treated as blacklisted, and an error notification will be shown.
|
|
16988
|
+
*
|
|
16964
16989
|
* ### Component:
|
|
16965
16990
|
*
|
|
16966
16991
|
* ```typescript
|
|
@@ -37736,12 +37761,13 @@ const QD_UI_MODULES = [
|
|
|
37736
37761
|
QdTreeModule
|
|
37737
37762
|
];
|
|
37738
37763
|
class QdUiModule {
|
|
37739
|
-
static forRoot(config, backendErrorCodes = {}) {
|
|
37764
|
+
static forRoot(config, backendErrorCodes = {}, whitelistErrorCodes = []) {
|
|
37740
37765
|
return {
|
|
37741
37766
|
ngModule: QdUiModule,
|
|
37742
37767
|
providers: [
|
|
37743
37768
|
{ provide: APP_ENVIRONMENT, useValue: config },
|
|
37744
|
-
{ provide: BACKEND_ERROR_CODES, useValue: backendErrorCodes }
|
|
37769
|
+
{ provide: BACKEND_ERROR_CODES, useValue: backendErrorCodes },
|
|
37770
|
+
{ provide: WHITELIST_ERROR_CODES, useValue: whitelistErrorCodes }
|
|
37745
37771
|
]
|
|
37746
37772
|
};
|
|
37747
37773
|
}
|