@posiwise/admin-module 0.0.175 → 0.0.177

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.
@@ -4,7 +4,7 @@ import { AdminService, AppAdmin } from '@posiwise/admin-module-utils';
4
4
  import { AppBaseComponent } from '@posiwise/app-base-component';
5
5
  import { PermissionService } from '@posiwise/common-services';
6
6
  import { HelperService } from '@posiwise/helper-service';
7
- import { CustomUploaderComponent } from '@posiwise/shared-components';
7
+ import { CustomUploaderComponent } from '@posiwise/utils';
8
8
  import { ValidateForm } from '@posiwise/utils';
9
9
  import { ROUTERS } from '../../../../shared/routers/routers';
10
10
  import * as i0 from "@angular/core";
@@ -12,9 +12,10 @@ import * as i1 from "@posiwise/admin-module-utils";
12
12
  import * as i2 from "@angular/common";
13
13
  import * as i3 from "@angular/forms";
14
14
  import * as i4 from "primeng/progressspinner";
15
- import * as i5 from "@posiwise/shared-components";
16
- import * as i6 from "@posiwise/directives";
17
- import * as i7 from "@jsverse/transloco";
15
+ import * as i5 from "@posiwise/utils";
16
+ import * as i6 from "@posiwise/shared-components";
17
+ import * as i7 from "@posiwise/directives";
18
+ import * as i8 from "@jsverse/transloco";
18
19
  export class DomainConfigInterfaceComponent extends AppBaseComponent {
19
20
  constructor(injector, adminService) {
20
21
  super(injector);
@@ -126,7 +127,7 @@ export class DomainConfigInterfaceComponent extends AppBaseComponent {
126
127
  });
127
128
  }
128
129
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: DomainConfigInterfaceComponent, deps: [{ token: i0.Injector }, { token: i1.AdminService }], target: i0.ɵɵFactoryTarget.Component }); }
129
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: DomainConfigInterfaceComponent, selector: "pw-domain-config-interface", viewQueries: [{ propertyName: "uploader", predicate: CustomUploaderComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<h3>Colors and Logos</h3>\n<div class=\"w-100 text-center mt-3\"\n *ngIf=\"isLoading\">\n <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n</div>\n<ng-container *ngIf=\"data?.host_name\">\n <form [formGroup]=\"form\"\n (ngSubmit)=\"onSave()\">\n <div class=\"default-color-code-section\">\n <h5>Color codes</h5>\n <a class=\"btn btn-sm btn-outline-primary float-end build-action-button\"\n data-cy=\"build-contact\"\n (click)=\"setDefaultColorCode()\">\n {{ 'Admin.DomainConfig.SetColorCodeDefault' | transloco }}\n </a>\n </div>\n <div class=\"mb-4\">\n <p>Customize the look and feel of your domain by updating the colors below.</p>\n </div>\n <div class=\"row\">\n <div class=\"col-12 col-sm-3\">\n <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeFirst' | transloco\"\n [showTooltip]=\"true\"\n [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeFirst' | transloco\"\n name=\"color_code_first\">\n <input type=\"color\"\n class=\"form-control\"\n formControlName=\"color_code_first\"\n [ngClass]=\"{ 'is-invalid': submitted && f['color_code_first'].errors }\" />\n </pw-input-container>\n </div>\n <div class=\"col-12 col-sm-3\">\n <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeSecond' | transloco\"\n [showTooltip]=\"true\"\n [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeSecond' | transloco\"\n name=\"color_code_second\">\n <input type=\"color\"\n class=\"form-control\"\n formControlName=\"color_code_second\"\n [ngClass]=\"{ 'is-invalid': submitted && f['color_code_second'].errors }\" />\n </pw-input-container>\n </div>\n <div class=\"col-12 col-sm-3\">\n <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeThird' | transloco\"\n [showTooltip]=\"true\"\n [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeThird' | transloco\"\n name=\"color_code_third\">\n <input type=\"color\"\n class=\"form-control\"\n formControlName=\"color_code_third\"\n [ngClass]=\"{ 'is-invalid': submitted && f['color_code_third'].errors }\" />\n </pw-input-container>\n </div>\n <div class=\"col-12 col-sm-3\"></div>\n <div class=\"col-12 col-sm-3\">\n <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeTitles' | transloco\"\n [showTooltip]=\"true\"\n [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeTitles' | transloco\"\n name=\"color_code_titles\">\n <input type=\"color\"\n class=\"form-control\"\n formControlName=\"color_code_titles\"\n [ngClass]=\"{ 'is-invalid': submitted && f['color_code_titles'].errors }\" />\n </pw-input-container>\n </div>\n <div class=\"col-12 col-sm-3\">\n <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeText' | transloco\"\n [showTooltip]=\"true\"\n [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeText' | transloco\"\n name=\"color_code_text\">\n <input type=\"color\"\n class=\"form-control\"\n formControlName=\"color_code_text\"\n [ngClass]=\"{ 'is-invalid': submitted && f['color_code_text'].errors }\" />\n </pw-input-container>\n </div>\n <div class=\"col-12 col-sm-3\"></div>\n <div class=\"col-12 col-sm-3\"></div>\n <div class=\"col-12 col-sm-3\">\n <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeSidebarBg' | transloco\"\n [showTooltip]=\"true\"\n [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeSidebarBg' | transloco\"\n name=\"color_code_sidebar_bg\">\n <input type=\"color\"\n class=\"form-control\"\n formControlName=\"color_code_sidebar_bg\"\n [ngClass]=\"{ 'is-invalid': submitted && f['color_code_sidebar_bg'].errors }\" />\n </pw-input-container>\n </div>\n <div class=\"col-12 col-sm-3\">\n <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeSidebarText' | transloco\"\n [showTooltip]=\"true\"\n [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeSidebarText' | transloco\"\n name=\"color_code_sidebar_text\">\n <input type=\"color\"\n class=\"form-control\"\n formControlName=\"color_code_sidebar_text\"\n [ngClass]=\"{ 'is-invalid': submitted && f['color_code_sidebar_text'].errors }\" />\n </pw-input-container>\n </div>\n <div class=\"col-12 col-sm-3\"></div>\n <div class=\"col-12 col-sm-3\"></div>\n <div class=\"col-12 col-sm-3\">\n <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeTabsBg' | transloco\"\n [showTooltip]=\"true\"\n [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeTabsBg' | transloco\"\n name=\"color_code_tabs_bg\">\n <input type=\"color\"\n class=\"form-control\"\n formControlName=\"color_code_tabs_bg\"\n [ngClass]=\"{ 'is-invalid': submitted && f['color_code_tabs_bg'].errors }\" />\n </pw-input-container>\n </div>\n <div class=\"col-12 col-sm-3\">\n <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeTabsText' | transloco\"\n [showTooltip]=\"true\"\n [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeTabsText' | transloco\"\n name=\"color_code_tabs_text\">\n <input type=\"color\"\n class=\"form-control\"\n formControlName=\"color_code_tabs_text\"\n [ngClass]=\"{ 'is-invalid': submitted && f['color_code_tabs_text'].errors }\" />\n </pw-input-container>\n </div>\n </div>\n <div class=\"col-12 text-end mt-3\">\n <button type=\"button\"\n class=\"btn btn-outline-default me-2\"\n (click)=\"back()\">\n {{ 'Button.Cancel' | transloco }}\n </button>\n <button type=\"submit\"\n [buttonBusy]=\"buttonBusy\"\n class=\"btn btn-primary\">{{ 'Button.Submit' | transloco }}</button>\n </div>\n\n <h5>Logos (required)</h5>\n <div class=\"mb-3\">\n <p>\n These logos are used across the platform on various pages, including the header on public pages and the dashboard.\n </p>\n </div>\n <div class=\"row\"\n matchHeight=\"card\">\n <div class=\"col-md-4 mt-3\">\n <label for=\"logo_main\">{{ 'Admin.DomainConfig.LogoMain' | transloco }}</label>\n <pw-custom-uploader\n [aspectRatio]=\"'fullLogo'\"\n (saveEvent)=\"saveFile($event)\"\n [title]=\"'Logo Main'\"\n [previewData]=\"data['logo_main']\"\n controlName=\"logo_main\"></pw-custom-uploader>\n </div>\n <div class=\"col-md-4 mt-3\">\n <label for=\"logo_main_dark\">{{ 'Admin.DomainConfig.LogoMainDark' | transloco }}</label>\n <pw-custom-uploader\n [aspectRatio]=\"'fullLogo'\"\n (saveEvent)=\"saveFile($event)\"\n [title]=\"'Logo Main Dark'\"\n [previewData]=\"data['logo_main_dark']\"\n controlName=\"logo_main_dark\"></pw-custom-uploader>\n </div>\n <div class=\"col-md-4 mt-3\">\n <label for=\"logo_main_contrast\">{{ 'Admin.DomainConfig.LogoMainContrast' | transloco }}</label>\n <pw-custom-uploader\n [aspectRatio]=\"'fullLogo'\"\n (saveEvent)=\"saveFile($event)\"\n [title]=\"'Logo Main Contrast'\"\n [previewData]=\"data['logo_main_contrast']\"\n controlName=\"logo_main_contrast\"></pw-custom-uploader>\n </div>\n <div class=\"col-md-4 mt-3\">\n <label for=\"logo_squared_main\">{{ 'Admin.DomainConfig.LogoSquaredMain' | transloco }}</label>\n <pw-custom-uploader\n (saveEvent)=\"saveFile($event)\"\n [title]=\"'Logo Squared Main'\"\n [previewData]=\"data['logo_squared_main']\"\n controlName=\"logo_squared_main\"></pw-custom-uploader>\n </div>\n <div class=\"col-md-4 mt-3\">\n <label for=\"logo_squared_dark\">{{ 'Admin.DomainConfig.LogoSquaredDark' | transloco }}</label>\n <pw-custom-uploader\n (saveEvent)=\"saveFile($event)\"\n [title]=\"'Logo Squared Dark'\"\n [previewData]=\"data['logo_squared_dark']\"\n controlName=\"logo_squared_dark\"></pw-custom-uploader>\n </div>\n <div class=\"col-md-4 mt-3\">\n <label for=\"logo_squared_contrast\">{{ 'Admin.DomainConfig.LogoSquaredContrast' | transloco }}</label>\n <pw-custom-uploader\n (saveEvent)=\"saveFile($event)\"\n [title]=\"'Logo Squared Contrast'\"\n [previewData]=\"data['logo_squared_contrast']\"\n controlName=\"logo_squared_contrast\"></pw-custom-uploader>\n </div>\n </div>\n </form>\n</ng-container>\n<div *ngIf=\"!data?.host_name && !isLoading\">\n <pw-no-data [withImage]=\"true\" [message]=\"'Admin.DomainConfig.EnableConfigTab' | transloco\"></pw-no-data>\n</div>\n", styles: [".default-color-code-section{gap:2em;justify-content:flex-start;display:flex;margin-bottom:1rem}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i4.ProgressSpinner, selector: "p-progressSpinner", inputs: ["styleClass", "style", "strokeWidth", "fill", "animationDuration", "ariaLabel"] }, { kind: "component", type: i5.CustomUploaderComponent, selector: "pw-custom-uploader", inputs: ["controlName", "previewData", "aspectRatio", "title"], outputs: ["saveEvent"] }, { kind: "component", type: i5.InputContainerComponent, selector: "pw-input-container", inputs: ["name", "label", "labelClass", "tooltipPosition", "required", "errorMsg", "isReadOnly", "showTooltip", "tooltipText", "showTriangle", "afterLabel", "showAfterLabel", "showTriangleText", "isLeftTooltip"] }, { kind: "component", type: i5.NoDataComponent, selector: "pw-no-data", inputs: ["message", "description", "withImage"] }, { kind: "directive", type: i6.ButtonBusyDirective, selector: "[buttonBusy]", inputs: ["buttonBusy", "busyText"] }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "pipe", type: i7.TranslocoPipe, name: "transloco" }] }); }
130
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: DomainConfigInterfaceComponent, selector: "pw-domain-config-interface", viewQueries: [{ propertyName: "uploader", predicate: CustomUploaderComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<h3>Colors and Logos</h3>\n<div class=\"w-100 text-center mt-3\"\n *ngIf=\"isLoading\">\n <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n</div>\n<ng-container *ngIf=\"data?.host_name\">\n <form [formGroup]=\"form\"\n (ngSubmit)=\"onSave()\">\n <div class=\"default-color-code-section\">\n <h5>Color codes</h5>\n <a class=\"btn btn-sm btn-outline-primary float-end build-action-button\"\n data-cy=\"build-contact\"\n (click)=\"setDefaultColorCode()\">\n {{ 'Admin.DomainConfig.SetColorCodeDefault' | transloco }}\n </a>\n </div>\n <div class=\"mb-4\">\n <p>Customize the look and feel of your domain by updating the colors below.</p>\n </div>\n <div class=\"row\">\n <div class=\"col-12 col-sm-3\">\n <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeFirst' | transloco\"\n [showTooltip]=\"true\"\n [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeFirst' | transloco\"\n name=\"color_code_first\">\n <input type=\"color\"\n class=\"form-control\"\n formControlName=\"color_code_first\"\n [ngClass]=\"{ 'is-invalid': submitted && f['color_code_first'].errors }\" />\n </pw-input-container>\n </div>\n <div class=\"col-12 col-sm-3\">\n <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeSecond' | transloco\"\n [showTooltip]=\"true\"\n [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeSecond' | transloco\"\n name=\"color_code_second\">\n <input type=\"color\"\n class=\"form-control\"\n formControlName=\"color_code_second\"\n [ngClass]=\"{ 'is-invalid': submitted && f['color_code_second'].errors }\" />\n </pw-input-container>\n </div>\n <div class=\"col-12 col-sm-3\">\n <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeThird' | transloco\"\n [showTooltip]=\"true\"\n [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeThird' | transloco\"\n name=\"color_code_third\">\n <input type=\"color\"\n class=\"form-control\"\n formControlName=\"color_code_third\"\n [ngClass]=\"{ 'is-invalid': submitted && f['color_code_third'].errors }\" />\n </pw-input-container>\n </div>\n <div class=\"col-12 col-sm-3\"></div>\n <div class=\"col-12 col-sm-3\">\n <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeTitles' | transloco\"\n [showTooltip]=\"true\"\n [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeTitles' | transloco\"\n name=\"color_code_titles\">\n <input type=\"color\"\n class=\"form-control\"\n formControlName=\"color_code_titles\"\n [ngClass]=\"{ 'is-invalid': submitted && f['color_code_titles'].errors }\" />\n </pw-input-container>\n </div>\n <div class=\"col-12 col-sm-3\">\n <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeText' | transloco\"\n [showTooltip]=\"true\"\n [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeText' | transloco\"\n name=\"color_code_text\">\n <input type=\"color\"\n class=\"form-control\"\n formControlName=\"color_code_text\"\n [ngClass]=\"{ 'is-invalid': submitted && f['color_code_text'].errors }\" />\n </pw-input-container>\n </div>\n <div class=\"col-12 col-sm-3\"></div>\n <div class=\"col-12 col-sm-3\"></div>\n <div class=\"col-12 col-sm-3\">\n <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeSidebarBg' | transloco\"\n [showTooltip]=\"true\"\n [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeSidebarBg' | transloco\"\n name=\"color_code_sidebar_bg\">\n <input type=\"color\"\n class=\"form-control\"\n formControlName=\"color_code_sidebar_bg\"\n [ngClass]=\"{ 'is-invalid': submitted && f['color_code_sidebar_bg'].errors }\" />\n </pw-input-container>\n </div>\n <div class=\"col-12 col-sm-3\">\n <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeSidebarText' | transloco\"\n [showTooltip]=\"true\"\n [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeSidebarText' | transloco\"\n name=\"color_code_sidebar_text\">\n <input type=\"color\"\n class=\"form-control\"\n formControlName=\"color_code_sidebar_text\"\n [ngClass]=\"{ 'is-invalid': submitted && f['color_code_sidebar_text'].errors }\" />\n </pw-input-container>\n </div>\n <div class=\"col-12 col-sm-3\"></div>\n <div class=\"col-12 col-sm-3\"></div>\n <div class=\"col-12 col-sm-3\">\n <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeTabsBg' | transloco\"\n [showTooltip]=\"true\"\n [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeTabsBg' | transloco\"\n name=\"color_code_tabs_bg\">\n <input type=\"color\"\n class=\"form-control\"\n formControlName=\"color_code_tabs_bg\"\n [ngClass]=\"{ 'is-invalid': submitted && f['color_code_tabs_bg'].errors }\" />\n </pw-input-container>\n </div>\n <div class=\"col-12 col-sm-3\">\n <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeTabsText' | transloco\"\n [showTooltip]=\"true\"\n [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeTabsText' | transloco\"\n name=\"color_code_tabs_text\">\n <input type=\"color\"\n class=\"form-control\"\n formControlName=\"color_code_tabs_text\"\n [ngClass]=\"{ 'is-invalid': submitted && f['color_code_tabs_text'].errors }\" />\n </pw-input-container>\n </div>\n </div>\n <div class=\"col-12 text-end mt-3\">\n <button type=\"button\"\n class=\"btn btn-outline-default me-2\"\n (click)=\"back()\">\n {{ 'Button.Cancel' | transloco }}\n </button>\n <button type=\"submit\"\n [buttonBusy]=\"buttonBusy\"\n class=\"btn btn-primary\">{{ 'Button.Submit' | transloco }}</button>\n </div>\n\n <h5>Logos (required)</h5>\n <div class=\"mb-3\">\n <p>\n These logos are used across the platform on various pages, including the header on public pages and the dashboard.\n </p>\n </div>\n <div class=\"row\"\n matchHeight=\"card\">\n <div class=\"col-md-4 mt-3\">\n <label for=\"logo_main\">{{ 'Admin.DomainConfig.LogoMain' | transloco }}</label>\n <pw-custom-uploader\n [aspectRatio]=\"'fullLogo'\"\n (saveEvent)=\"saveFile($event)\"\n [title]=\"'Logo Main'\"\n [previewData]=\"data['logo_main']\"\n controlName=\"logo_main\"></pw-custom-uploader>\n </div>\n <div class=\"col-md-4 mt-3\">\n <label for=\"logo_main_dark\">{{ 'Admin.DomainConfig.LogoMainDark' | transloco }}</label>\n <pw-custom-uploader\n [aspectRatio]=\"'fullLogo'\"\n (saveEvent)=\"saveFile($event)\"\n [title]=\"'Logo Main Dark'\"\n [previewData]=\"data['logo_main_dark']\"\n controlName=\"logo_main_dark\"></pw-custom-uploader>\n </div>\n <div class=\"col-md-4 mt-3\">\n <label for=\"logo_main_contrast\">{{ 'Admin.DomainConfig.LogoMainContrast' | transloco }}</label>\n <pw-custom-uploader\n [aspectRatio]=\"'fullLogo'\"\n (saveEvent)=\"saveFile($event)\"\n [title]=\"'Logo Main Contrast'\"\n [previewData]=\"data['logo_main_contrast']\"\n controlName=\"logo_main_contrast\"></pw-custom-uploader>\n </div>\n <div class=\"col-md-4 mt-3\">\n <label for=\"logo_squared_main\">{{ 'Admin.DomainConfig.LogoSquaredMain' | transloco }}</label>\n <pw-custom-uploader\n (saveEvent)=\"saveFile($event)\"\n [title]=\"'Logo Squared Main'\"\n [previewData]=\"data['logo_squared_main']\"\n controlName=\"logo_squared_main\"></pw-custom-uploader>\n </div>\n <div class=\"col-md-4 mt-3\">\n <label for=\"logo_squared_dark\">{{ 'Admin.DomainConfig.LogoSquaredDark' | transloco }}</label>\n <pw-custom-uploader\n (saveEvent)=\"saveFile($event)\"\n [title]=\"'Logo Squared Dark'\"\n [previewData]=\"data['logo_squared_dark']\"\n controlName=\"logo_squared_dark\"></pw-custom-uploader>\n </div>\n <div class=\"col-md-4 mt-3\">\n <label for=\"logo_squared_contrast\">{{ 'Admin.DomainConfig.LogoSquaredContrast' | transloco }}</label>\n <pw-custom-uploader\n (saveEvent)=\"saveFile($event)\"\n [title]=\"'Logo Squared Contrast'\"\n [previewData]=\"data['logo_squared_contrast']\"\n controlName=\"logo_squared_contrast\"></pw-custom-uploader>\n </div>\n </div>\n </form>\n</ng-container>\n<div *ngIf=\"!data?.host_name && !isLoading\">\n <pw-no-data [withImage]=\"true\" [message]=\"'Admin.DomainConfig.EnableConfigTab' | transloco\"></pw-no-data>\n</div>\n", styles: [".default-color-code-section{gap:2em;justify-content:flex-start;display:flex;margin-bottom:1rem}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i4.ProgressSpinner, selector: "p-progressSpinner", inputs: ["styleClass", "style", "strokeWidth", "fill", "animationDuration", "ariaLabel"] }, { kind: "component", type: i5.CustomUploaderComponent, selector: "pw-custom-uploader", inputs: ["controlName", "previewData", "aspectRatio", "title"], outputs: ["saveEvent"] }, { kind: "component", type: i6.InputContainerComponent, selector: "pw-input-container", inputs: ["name", "label", "labelClass", "tooltipPosition", "required", "errorMsg", "isReadOnly", "showTooltip", "tooltipText", "showTriangle", "afterLabel", "showAfterLabel", "showTriangleText", "isLeftTooltip"] }, { kind: "component", type: i6.NoDataComponent, selector: "pw-no-data", inputs: ["message", "description", "withImage"] }, { kind: "directive", type: i7.ButtonBusyDirective, selector: "[buttonBusy]", inputs: ["buttonBusy", "busyText"] }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "pipe", type: i8.TranslocoPipe, name: "transloco" }] }); }
130
131
  }
131
132
  __decorate([
132
133
  ValidateForm('form'),
@@ -141,4 +142,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
141
142
  type: ViewChildren,
142
143
  args: [CustomUploaderComponent]
143
144
  }], onSave: [] } });
144
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"domain-config-interface.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/admin-module/src/lib/components/domain-config/domain-config-details/domain-config-interface/domain-config-interface.component.ts","../../../../../../../../../libs/admin-module/src/lib/components/domain-config/domain-config-details/domain-config-interface/domain-config-interface.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, Injector, OnInit, QueryList, ViewChildren } from '@angular/core';\nimport { UntypedFormGroup } from '@angular/forms';\n\nimport { AdminService, AppAdmin } from '@posiwise/admin-module-utils';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { PermissionService } from '@posiwise/common-services';\nimport { HelperService } from '@posiwise/helper-service';\nimport { CustomUploaderComponent } from '@posiwise/shared-components';\nimport { ValidateForm } from '@posiwise/utils';\n\nimport { DomainConfig } from '../../../../shared/interface/domain-config.interface';\nimport { ROUTERS } from '../../../../shared/routers/routers';\n\n@Component({\n    selector: 'pw-domain-config-interface',\n    templateUrl: './domain-config-interface.component.html',\n    styleUrl: './domain-config-interface.component.scss'\n})\nexport class DomainConfigInterfaceComponent\n    extends AppBaseComponent\n    implements OnInit, AfterViewInit\n{\n    @ViewChildren(CustomUploaderComponent) uploader: QueryList<CustomUploaderComponent>;\n\n    form: UntypedFormGroup;\n\n    submitted = false;\n    buttonBusy = false;\n\n    id: number;\n    subscriptionId: number;\n    duplicateConfigId;\n\n    data: DomainConfig;\n\n    defaultColorCodes: DomainConfig;\n\n    routers = ROUTERS;\n\n    isLoading: boolean;\n\n    childList = [];\n\n    constructor(\n        injector: Injector,\n        private readonly adminService: AdminService\n    ) {\n        super(injector);\n        this.form = AppAdmin.domainConfigInterfaceForm();\n    }\n\n    ngOnInit() {\n        this.duplicateConfigId = Number(\n            this.route.snapshot.queryParams['duplicate_domain_config_id']\n        );\n        this.subscriptionId = PermissionService.selectedSubscription?.id;\n        this.getDefaultColorCodes();\n        this.route.params.subscribe(params => {\n            this.id = Number(params['id']);\n            if (this.id) {\n                this.getDomainConfigDetails();\n            }\n        });\n    }\n\n    ngAfterViewInit() {\n        this.uploader.changes.subscribe(() => {\n            this.childList = this.uploader.toArray();\n        });\n    }\n\n    get f() {\n        return this.form.controls;\n    }\n\n    private getDefaultColorCodes() {\n        this.adminService\n            .getAllDomainDefaultColorCodes(this.subscriptionId)\n            .subscribe((response: DomainConfig) => {\n                this.defaultColorCodes = response;\n            });\n    }\n\n    setDefaultColorCode() {\n        this.form.patchValue(this.defaultColorCodes);\n    }\n\n    private getDomainConfigDetails() {\n        this.isLoading = true;\n        this.adminService\n            .getDomainConfigById(\n                HelperService.effectiveConfigId(this.duplicateConfigId, this.id),\n                this.subscriptionId\n            )\n            .subscribe((response: DomainConfig) => {\n                this.data = response;\n                this.form.patchValue(this.data);\n            })\n            .add(() => {\n                this.isLoading = false;\n            });\n    }\n\n    saveFile(event) {\n        const item: CustomUploaderComponent = this.childList.find(\n            x => x.controlName === event.name\n        );\n        const formData = new FormData();\n        const data = { subscription_id: this.subscriptionId };\n        if (event.file) {\n            data[event.name] = event.file;\n        } else {\n            data[`remove_${event.name}`] = true;\n        }\n        // eslint-disable-next-line no-restricted-syntax\n        for (const key in data) {\n            if (key in data) {\n                formData.append(key, data[key]);\n            }\n        }\n        const sub$ = this.id\n            ? this.adminService.updateDomainConfig(this.id, formData)\n            : this.adminService.createDomainConfig(formData);\n\n        sub$.subscribe(() => {\n            this.adminService\n                .getDomainConfigById(this.id, this.subscriptionId)\n                .subscribe(response => {\n                    item.clearValues();\n                    this.data[event.name] = response[event.name];\n                });\n        }).add(() => {\n            item.buttonBusy = false;\n            item.onClose();\n        });\n    }\n\n    @ValidateForm('form')\n    onSave() {\n        this.submitted = true;\n        this.buttonBusy = true;\n        const data = {\n            ...this.form.value,\n            subscription_id: this.subscriptionId\n        };\n        const filteredData = Object.fromEntries(\n            Object.entries(data).filter(([_key, value]) => value !== null && value !== '')\n        );\n        const sub$ = this.id\n            ? this.adminService.updateDomainConfig(this.id, filteredData)\n            : this.adminService.createDomainConfig(filteredData);\n        sub$.subscribe({\n            next: res => {\n                this.toast.success(this.translation.translate('Admin.DomainConfig.UpdatedMessage'));\n                this.router.navigate(\n                    [`${this.routers.domainConfigDetails}${this.id ? this.id : res.id}`],\n                    {\n                        queryParams: {\n                            tabId: 'Public Pages',\n                            ...(this.duplicateConfigId\n                                ? { duplicate_domain_config_id: this.duplicateConfigId }\n                                : {})\n                        }\n                    }\n                );\n            }\n        }).add(() => {\n            this.submitted = false;\n            this.buttonBusy = false;\n        });\n    }\n}\n","<h3>Colors and Logos</h3>\n<div class=\"w-100 text-center mt-3\"\n  *ngIf=\"isLoading\">\n  <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n</div>\n<ng-container *ngIf=\"data?.host_name\">\n  <form [formGroup]=\"form\"\n    (ngSubmit)=\"onSave()\">\n  <div class=\"default-color-code-section\">\n    <h5>Color codes</h5>\n    <a class=\"btn btn-sm btn-outline-primary float-end build-action-button\"\n    data-cy=\"build-contact\"\n    (click)=\"setDefaultColorCode()\">\n    {{ 'Admin.DomainConfig.SetColorCodeDefault' | transloco }}\n  </a>\n  </div>\n    <div class=\"mb-4\">\n      <p>Customize the look and feel of your domain by updating the colors below.</p>\n    </div>\n    <div class=\"row\">\n      <div class=\"col-12 col-sm-3\">\n        <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeFirst' | transloco\"\n          [showTooltip]=\"true\"\n          [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeFirst' | transloco\"\n          name=\"color_code_first\">\n          <input type=\"color\"\n            class=\"form-control\"\n            formControlName=\"color_code_first\"\n            [ngClass]=\"{ 'is-invalid': submitted && f['color_code_first'].errors }\" />\n        </pw-input-container>\n      </div>\n      <div class=\"col-12 col-sm-3\">\n        <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeSecond' | transloco\"\n          [showTooltip]=\"true\"\n          [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeSecond' | transloco\"\n          name=\"color_code_second\">\n          <input type=\"color\"\n            class=\"form-control\"\n            formControlName=\"color_code_second\"\n            [ngClass]=\"{ 'is-invalid': submitted && f['color_code_second'].errors }\" />\n        </pw-input-container>\n      </div>\n      <div class=\"col-12 col-sm-3\">\n        <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeThird' | transloco\"\n          [showTooltip]=\"true\"\n          [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeThird' | transloco\"\n          name=\"color_code_third\">\n          <input type=\"color\"\n            class=\"form-control\"\n            formControlName=\"color_code_third\"\n            [ngClass]=\"{ 'is-invalid': submitted && f['color_code_third'].errors }\" />\n        </pw-input-container>\n      </div>\n      <div class=\"col-12 col-sm-3\"></div>\n      <div class=\"col-12 col-sm-3\">\n        <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeTitles' | transloco\"\n          [showTooltip]=\"true\"\n          [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeTitles' | transloco\"\n          name=\"color_code_titles\">\n          <input type=\"color\"\n            class=\"form-control\"\n            formControlName=\"color_code_titles\"\n            [ngClass]=\"{ 'is-invalid': submitted && f['color_code_titles'].errors }\" />\n        </pw-input-container>\n      </div>\n      <div class=\"col-12 col-sm-3\">\n        <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeText' | transloco\"\n          [showTooltip]=\"true\"\n          [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeText' | transloco\"\n          name=\"color_code_text\">\n          <input type=\"color\"\n            class=\"form-control\"\n            formControlName=\"color_code_text\"\n            [ngClass]=\"{ 'is-invalid': submitted && f['color_code_text'].errors }\" />\n        </pw-input-container>\n      </div>\n      <div class=\"col-12 col-sm-3\"></div>\n      <div class=\"col-12 col-sm-3\"></div>\n      <div class=\"col-12 col-sm-3\">\n        <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeSidebarBg' | transloco\"\n          [showTooltip]=\"true\"\n          [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeSidebarBg' | transloco\"\n          name=\"color_code_sidebar_bg\">\n          <input type=\"color\"\n            class=\"form-control\"\n            formControlName=\"color_code_sidebar_bg\"\n            [ngClass]=\"{ 'is-invalid': submitted && f['color_code_sidebar_bg'].errors }\" />\n        </pw-input-container>\n      </div>\n      <div class=\"col-12 col-sm-3\">\n        <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeSidebarText' | transloco\"\n          [showTooltip]=\"true\"\n          [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeSidebarText' | transloco\"\n          name=\"color_code_sidebar_text\">\n          <input type=\"color\"\n            class=\"form-control\"\n            formControlName=\"color_code_sidebar_text\"\n            [ngClass]=\"{ 'is-invalid': submitted && f['color_code_sidebar_text'].errors }\" />\n        </pw-input-container>\n      </div>\n      <div class=\"col-12 col-sm-3\"></div>\n      <div class=\"col-12 col-sm-3\"></div>\n      <div class=\"col-12 col-sm-3\">\n        <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeTabsBg' | transloco\"\n          [showTooltip]=\"true\"\n          [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeTabsBg' | transloco\"\n          name=\"color_code_tabs_bg\">\n          <input type=\"color\"\n            class=\"form-control\"\n            formControlName=\"color_code_tabs_bg\"\n            [ngClass]=\"{ 'is-invalid': submitted && f['color_code_tabs_bg'].errors }\" />\n        </pw-input-container>\n      </div>\n      <div class=\"col-12 col-sm-3\">\n        <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeTabsText' | transloco\"\n          [showTooltip]=\"true\"\n          [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeTabsText' | transloco\"\n          name=\"color_code_tabs_text\">\n          <input type=\"color\"\n            class=\"form-control\"\n            formControlName=\"color_code_tabs_text\"\n            [ngClass]=\"{ 'is-invalid': submitted && f['color_code_tabs_text'].errors }\" />\n        </pw-input-container>\n      </div>\n    </div>\n    <div class=\"col-12 text-end mt-3\">\n      <button type=\"button\"\n        class=\"btn btn-outline-default me-2\"\n        (click)=\"back()\">\n        {{ 'Button.Cancel' | transloco }}\n      </button>\n      <button type=\"submit\"\n        [buttonBusy]=\"buttonBusy\"\n        class=\"btn btn-primary\">{{ 'Button.Submit' | transloco }}</button>\n    </div>\n\n    <h5>Logos (required)</h5>\n    <div class=\"mb-3\">\n      <p>\n        These logos are used across the platform on various pages, including the header on public pages and the dashboard.\n      </p>\n    </div>\n    <div class=\"row\"\n      matchHeight=\"card\">\n      <div class=\"col-md-4 mt-3\">\n        <label for=\"logo_main\">{{ 'Admin.DomainConfig.LogoMain' | transloco }}</label>\n        <pw-custom-uploader\n          [aspectRatio]=\"'fullLogo'\"\n          (saveEvent)=\"saveFile($event)\"\n          [title]=\"'Logo Main'\"\n          [previewData]=\"data['logo_main']\"\n          controlName=\"logo_main\"></pw-custom-uploader>\n      </div>\n      <div class=\"col-md-4 mt-3\">\n        <label for=\"logo_main_dark\">{{ 'Admin.DomainConfig.LogoMainDark' | transloco }}</label>\n        <pw-custom-uploader\n          [aspectRatio]=\"'fullLogo'\"\n          (saveEvent)=\"saveFile($event)\"\n          [title]=\"'Logo Main Dark'\"\n          [previewData]=\"data['logo_main_dark']\"\n          controlName=\"logo_main_dark\"></pw-custom-uploader>\n      </div>\n      <div class=\"col-md-4 mt-3\">\n        <label for=\"logo_main_contrast\">{{ 'Admin.DomainConfig.LogoMainContrast' | transloco }}</label>\n        <pw-custom-uploader\n          [aspectRatio]=\"'fullLogo'\"\n          (saveEvent)=\"saveFile($event)\"\n          [title]=\"'Logo Main Contrast'\"\n          [previewData]=\"data['logo_main_contrast']\"\n          controlName=\"logo_main_contrast\"></pw-custom-uploader>\n      </div>\n      <div class=\"col-md-4 mt-3\">\n        <label for=\"logo_squared_main\">{{ 'Admin.DomainConfig.LogoSquaredMain' | transloco }}</label>\n        <pw-custom-uploader\n          (saveEvent)=\"saveFile($event)\"\n          [title]=\"'Logo Squared Main'\"\n          [previewData]=\"data['logo_squared_main']\"\n          controlName=\"logo_squared_main\"></pw-custom-uploader>\n      </div>\n      <div class=\"col-md-4 mt-3\">\n        <label for=\"logo_squared_dark\">{{ 'Admin.DomainConfig.LogoSquaredDark' | transloco }}</label>\n        <pw-custom-uploader\n          (saveEvent)=\"saveFile($event)\"\n          [title]=\"'Logo Squared Dark'\"\n          [previewData]=\"data['logo_squared_dark']\"\n          controlName=\"logo_squared_dark\"></pw-custom-uploader>\n      </div>\n      <div class=\"col-md-4 mt-3\">\n        <label for=\"logo_squared_contrast\">{{ 'Admin.DomainConfig.LogoSquaredContrast' | transloco }}</label>\n        <pw-custom-uploader\n          (saveEvent)=\"saveFile($event)\"\n          [title]=\"'Logo Squared Contrast'\"\n          [previewData]=\"data['logo_squared_contrast']\"\n          controlName=\"logo_squared_contrast\"></pw-custom-uploader>\n      </div>\n    </div>\n  </form>\n</ng-container>\n<div *ngIf=\"!data?.host_name && !isLoading\">\n  <pw-no-data [withImage]=\"true\" [message]=\"'Admin.DomainConfig.EnableConfigTab' | transloco\"></pw-no-data>\n</div>\n"]}
145
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"domain-config-interface.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/admin-module/src/lib/components/domain-config/domain-config-details/domain-config-interface/domain-config-interface.component.ts","../../../../../../../../../libs/admin-module/src/lib/components/domain-config/domain-config-details/domain-config-interface/domain-config-interface.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, Injector, OnInit, QueryList, ViewChildren } from '@angular/core';\nimport { UntypedFormGroup } from '@angular/forms';\n\nimport { AdminService, AppAdmin } from '@posiwise/admin-module-utils';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { PermissionService } from '@posiwise/common-services';\nimport { HelperService } from '@posiwise/helper-service';\nimport { CustomUploaderComponent } from '@posiwise/utils';\nimport { ValidateForm } from '@posiwise/utils';\n\nimport { DomainConfig } from '../../../../shared/interface/domain-config.interface';\nimport { ROUTERS } from '../../../../shared/routers/routers';\n\n@Component({\n    selector: 'pw-domain-config-interface',\n    templateUrl: './domain-config-interface.component.html',\n    styleUrl: './domain-config-interface.component.scss'\n})\nexport class DomainConfigInterfaceComponent\n    extends AppBaseComponent\n    implements OnInit, AfterViewInit\n{\n    @ViewChildren(CustomUploaderComponent) uploader: QueryList<CustomUploaderComponent>;\n\n    form: UntypedFormGroup;\n\n    submitted = false;\n    buttonBusy = false;\n\n    id: number;\n    subscriptionId: number;\n    duplicateConfigId;\n\n    data: DomainConfig;\n\n    defaultColorCodes: DomainConfig;\n\n    routers = ROUTERS;\n\n    isLoading: boolean;\n\n    childList = [];\n\n    constructor(\n        injector: Injector,\n        private readonly adminService: AdminService\n    ) {\n        super(injector);\n        this.form = AppAdmin.domainConfigInterfaceForm();\n    }\n\n    ngOnInit() {\n        this.duplicateConfigId = Number(\n            this.route.snapshot.queryParams['duplicate_domain_config_id']\n        );\n        this.subscriptionId = PermissionService.selectedSubscription?.id;\n        this.getDefaultColorCodes();\n        this.route.params.subscribe(params => {\n            this.id = Number(params['id']);\n            if (this.id) {\n                this.getDomainConfigDetails();\n            }\n        });\n    }\n\n    ngAfterViewInit() {\n        this.uploader.changes.subscribe(() => {\n            this.childList = this.uploader.toArray();\n        });\n    }\n\n    get f() {\n        return this.form.controls;\n    }\n\n    private getDefaultColorCodes() {\n        this.adminService\n            .getAllDomainDefaultColorCodes(this.subscriptionId)\n            .subscribe((response: DomainConfig) => {\n                this.defaultColorCodes = response;\n            });\n    }\n\n    setDefaultColorCode() {\n        this.form.patchValue(this.defaultColorCodes);\n    }\n\n    private getDomainConfigDetails() {\n        this.isLoading = true;\n        this.adminService\n            .getDomainConfigById(\n                HelperService.effectiveConfigId(this.duplicateConfigId, this.id),\n                this.subscriptionId\n            )\n            .subscribe((response: DomainConfig) => {\n                this.data = response;\n                this.form.patchValue(this.data);\n            })\n            .add(() => {\n                this.isLoading = false;\n            });\n    }\n\n    saveFile(event) {\n        const item: CustomUploaderComponent = this.childList.find(\n            x => x.controlName === event.name\n        );\n        const formData = new FormData();\n        const data = { subscription_id: this.subscriptionId };\n        if (event.file) {\n            data[event.name] = event.file;\n        } else {\n            data[`remove_${event.name}`] = true;\n        }\n        // eslint-disable-next-line no-restricted-syntax\n        for (const key in data) {\n            if (key in data) {\n                formData.append(key, data[key]);\n            }\n        }\n        const sub$ = this.id\n            ? this.adminService.updateDomainConfig(this.id, formData)\n            : this.adminService.createDomainConfig(formData);\n\n        sub$.subscribe(() => {\n            this.adminService\n                .getDomainConfigById(this.id, this.subscriptionId)\n                .subscribe(response => {\n                    item.clearValues();\n                    this.data[event.name] = response[event.name];\n                });\n        }).add(() => {\n            item.buttonBusy = false;\n            item.onClose();\n        });\n    }\n\n    @ValidateForm('form')\n    onSave() {\n        this.submitted = true;\n        this.buttonBusy = true;\n        const data = {\n            ...this.form.value,\n            subscription_id: this.subscriptionId\n        };\n        const filteredData = Object.fromEntries(\n            Object.entries(data).filter(([_key, value]) => value !== null && value !== '')\n        );\n        const sub$ = this.id\n            ? this.adminService.updateDomainConfig(this.id, filteredData)\n            : this.adminService.createDomainConfig(filteredData);\n        sub$.subscribe({\n            next: res => {\n                this.toast.success(this.translation.translate('Admin.DomainConfig.UpdatedMessage'));\n                this.router.navigate(\n                    [`${this.routers.domainConfigDetails}${this.id ? this.id : res.id}`],\n                    {\n                        queryParams: {\n                            tabId: 'Public Pages',\n                            ...(this.duplicateConfigId\n                                ? { duplicate_domain_config_id: this.duplicateConfigId }\n                                : {})\n                        }\n                    }\n                );\n            }\n        }).add(() => {\n            this.submitted = false;\n            this.buttonBusy = false;\n        });\n    }\n}\n","<h3>Colors and Logos</h3>\n<div class=\"w-100 text-center mt-3\"\n  *ngIf=\"isLoading\">\n  <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n</div>\n<ng-container *ngIf=\"data?.host_name\">\n  <form [formGroup]=\"form\"\n    (ngSubmit)=\"onSave()\">\n  <div class=\"default-color-code-section\">\n    <h5>Color codes</h5>\n    <a class=\"btn btn-sm btn-outline-primary float-end build-action-button\"\n    data-cy=\"build-contact\"\n    (click)=\"setDefaultColorCode()\">\n    {{ 'Admin.DomainConfig.SetColorCodeDefault' | transloco }}\n  </a>\n  </div>\n    <div class=\"mb-4\">\n      <p>Customize the look and feel of your domain by updating the colors below.</p>\n    </div>\n    <div class=\"row\">\n      <div class=\"col-12 col-sm-3\">\n        <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeFirst' | transloco\"\n          [showTooltip]=\"true\"\n          [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeFirst' | transloco\"\n          name=\"color_code_first\">\n          <input type=\"color\"\n            class=\"form-control\"\n            formControlName=\"color_code_first\"\n            [ngClass]=\"{ 'is-invalid': submitted && f['color_code_first'].errors }\" />\n        </pw-input-container>\n      </div>\n      <div class=\"col-12 col-sm-3\">\n        <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeSecond' | transloco\"\n          [showTooltip]=\"true\"\n          [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeSecond' | transloco\"\n          name=\"color_code_second\">\n          <input type=\"color\"\n            class=\"form-control\"\n            formControlName=\"color_code_second\"\n            [ngClass]=\"{ 'is-invalid': submitted && f['color_code_second'].errors }\" />\n        </pw-input-container>\n      </div>\n      <div class=\"col-12 col-sm-3\">\n        <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeThird' | transloco\"\n          [showTooltip]=\"true\"\n          [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeThird' | transloco\"\n          name=\"color_code_third\">\n          <input type=\"color\"\n            class=\"form-control\"\n            formControlName=\"color_code_third\"\n            [ngClass]=\"{ 'is-invalid': submitted && f['color_code_third'].errors }\" />\n        </pw-input-container>\n      </div>\n      <div class=\"col-12 col-sm-3\"></div>\n      <div class=\"col-12 col-sm-3\">\n        <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeTitles' | transloco\"\n          [showTooltip]=\"true\"\n          [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeTitles' | transloco\"\n          name=\"color_code_titles\">\n          <input type=\"color\"\n            class=\"form-control\"\n            formControlName=\"color_code_titles\"\n            [ngClass]=\"{ 'is-invalid': submitted && f['color_code_titles'].errors }\" />\n        </pw-input-container>\n      </div>\n      <div class=\"col-12 col-sm-3\">\n        <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeText' | transloco\"\n          [showTooltip]=\"true\"\n          [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeText' | transloco\"\n          name=\"color_code_text\">\n          <input type=\"color\"\n            class=\"form-control\"\n            formControlName=\"color_code_text\"\n            [ngClass]=\"{ 'is-invalid': submitted && f['color_code_text'].errors }\" />\n        </pw-input-container>\n      </div>\n      <div class=\"col-12 col-sm-3\"></div>\n      <div class=\"col-12 col-sm-3\"></div>\n      <div class=\"col-12 col-sm-3\">\n        <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeSidebarBg' | transloco\"\n          [showTooltip]=\"true\"\n          [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeSidebarBg' | transloco\"\n          name=\"color_code_sidebar_bg\">\n          <input type=\"color\"\n            class=\"form-control\"\n            formControlName=\"color_code_sidebar_bg\"\n            [ngClass]=\"{ 'is-invalid': submitted && f['color_code_sidebar_bg'].errors }\" />\n        </pw-input-container>\n      </div>\n      <div class=\"col-12 col-sm-3\">\n        <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeSidebarText' | transloco\"\n          [showTooltip]=\"true\"\n          [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeSidebarText' | transloco\"\n          name=\"color_code_sidebar_text\">\n          <input type=\"color\"\n            class=\"form-control\"\n            formControlName=\"color_code_sidebar_text\"\n            [ngClass]=\"{ 'is-invalid': submitted && f['color_code_sidebar_text'].errors }\" />\n        </pw-input-container>\n      </div>\n      <div class=\"col-12 col-sm-3\"></div>\n      <div class=\"col-12 col-sm-3\"></div>\n      <div class=\"col-12 col-sm-3\">\n        <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeTabsBg' | transloco\"\n          [showTooltip]=\"true\"\n          [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeTabsBg' | transloco\"\n          name=\"color_code_tabs_bg\">\n          <input type=\"color\"\n            class=\"form-control\"\n            formControlName=\"color_code_tabs_bg\"\n            [ngClass]=\"{ 'is-invalid': submitted && f['color_code_tabs_bg'].errors }\" />\n        </pw-input-container>\n      </div>\n      <div class=\"col-12 col-sm-3\">\n        <pw-input-container [label]=\"'Admin.DomainConfig.ColorCodeTabsText' | transloco\"\n          [showTooltip]=\"true\"\n          [tooltipText]=\"'Admin.DomainConfig.Tooltip.ColorCodeTabsText' | transloco\"\n          name=\"color_code_tabs_text\">\n          <input type=\"color\"\n            class=\"form-control\"\n            formControlName=\"color_code_tabs_text\"\n            [ngClass]=\"{ 'is-invalid': submitted && f['color_code_tabs_text'].errors }\" />\n        </pw-input-container>\n      </div>\n    </div>\n    <div class=\"col-12 text-end mt-3\">\n      <button type=\"button\"\n        class=\"btn btn-outline-default me-2\"\n        (click)=\"back()\">\n        {{ 'Button.Cancel' | transloco }}\n      </button>\n      <button type=\"submit\"\n        [buttonBusy]=\"buttonBusy\"\n        class=\"btn btn-primary\">{{ 'Button.Submit' | transloco }}</button>\n    </div>\n\n    <h5>Logos (required)</h5>\n    <div class=\"mb-3\">\n      <p>\n        These logos are used across the platform on various pages, including the header on public pages and the dashboard.\n      </p>\n    </div>\n    <div class=\"row\"\n      matchHeight=\"card\">\n      <div class=\"col-md-4 mt-3\">\n        <label for=\"logo_main\">{{ 'Admin.DomainConfig.LogoMain' | transloco }}</label>\n        <pw-custom-uploader\n          [aspectRatio]=\"'fullLogo'\"\n          (saveEvent)=\"saveFile($event)\"\n          [title]=\"'Logo Main'\"\n          [previewData]=\"data['logo_main']\"\n          controlName=\"logo_main\"></pw-custom-uploader>\n      </div>\n      <div class=\"col-md-4 mt-3\">\n        <label for=\"logo_main_dark\">{{ 'Admin.DomainConfig.LogoMainDark' | transloco }}</label>\n        <pw-custom-uploader\n          [aspectRatio]=\"'fullLogo'\"\n          (saveEvent)=\"saveFile($event)\"\n          [title]=\"'Logo Main Dark'\"\n          [previewData]=\"data['logo_main_dark']\"\n          controlName=\"logo_main_dark\"></pw-custom-uploader>\n      </div>\n      <div class=\"col-md-4 mt-3\">\n        <label for=\"logo_main_contrast\">{{ 'Admin.DomainConfig.LogoMainContrast' | transloco }}</label>\n        <pw-custom-uploader\n          [aspectRatio]=\"'fullLogo'\"\n          (saveEvent)=\"saveFile($event)\"\n          [title]=\"'Logo Main Contrast'\"\n          [previewData]=\"data['logo_main_contrast']\"\n          controlName=\"logo_main_contrast\"></pw-custom-uploader>\n      </div>\n      <div class=\"col-md-4 mt-3\">\n        <label for=\"logo_squared_main\">{{ 'Admin.DomainConfig.LogoSquaredMain' | transloco }}</label>\n        <pw-custom-uploader\n          (saveEvent)=\"saveFile($event)\"\n          [title]=\"'Logo Squared Main'\"\n          [previewData]=\"data['logo_squared_main']\"\n          controlName=\"logo_squared_main\"></pw-custom-uploader>\n      </div>\n      <div class=\"col-md-4 mt-3\">\n        <label for=\"logo_squared_dark\">{{ 'Admin.DomainConfig.LogoSquaredDark' | transloco }}</label>\n        <pw-custom-uploader\n          (saveEvent)=\"saveFile($event)\"\n          [title]=\"'Logo Squared Dark'\"\n          [previewData]=\"data['logo_squared_dark']\"\n          controlName=\"logo_squared_dark\"></pw-custom-uploader>\n      </div>\n      <div class=\"col-md-4 mt-3\">\n        <label for=\"logo_squared_contrast\">{{ 'Admin.DomainConfig.LogoSquaredContrast' | transloco }}</label>\n        <pw-custom-uploader\n          (saveEvent)=\"saveFile($event)\"\n          [title]=\"'Logo Squared Contrast'\"\n          [previewData]=\"data['logo_squared_contrast']\"\n          controlName=\"logo_squared_contrast\"></pw-custom-uploader>\n      </div>\n    </div>\n  </form>\n</ng-container>\n<div *ngIf=\"!data?.host_name && !isLoading\">\n  <pw-no-data [withImage]=\"true\" [message]=\"'Admin.DomainConfig.EnableConfigTab' | transloco\"></pw-no-data>\n</div>\n"]}
@@ -37,6 +37,7 @@ export class AddEditIncidentComponent extends AppBaseComponent {
37
37
  }
38
38
  ngAfterViewInit() {
39
39
  HelperService.subscribeToEditorChanges(this.form, 'description');
40
+ HelperService.subscribeToEditorChanges(this.form, 'internal_description');
40
41
  }
41
42
  ngOnInit() {
42
43
  this.logo = this.appConfig?.company?.logos?.main?.url;
@@ -55,8 +56,10 @@ export class AddEditIncidentComponent extends AppBaseComponent {
55
56
  return this.form.controls;
56
57
  }
57
58
  onSubmit() {
58
- const rawHtml = HelperService.SaveRawHTML();
59
+ const rawHtml = HelperService.SaveRawHTML('#descriptionEditor');
59
60
  this.form.controls['description'].setValue(rawHtml);
61
+ const rawInternalHtml = HelperService.SaveRawHTML('#internalDescriptionEditor');
62
+ this.form.controls['internal_description'].setValue(rawInternalHtml);
60
63
  this.form.markAllAsTouched();
61
64
  if (this.form.valid) {
62
65
  if (this.id) {
@@ -75,6 +78,7 @@ export class AddEditIncidentComponent extends AppBaseComponent {
75
78
  this.form.setValue({
76
79
  id: response.id,
77
80
  description: response?.description,
81
+ internal_description: response?.internal_description || '',
78
82
  service_impacted: response?.service_impacted,
79
83
  url_impacted: response?.url_impacted,
80
84
  resolved_at: response?.resolved_at ? new Date(response?.resolved_at) : '',
@@ -136,13 +140,13 @@ export class AddEditIncidentComponent extends AppBaseComponent {
136
140
  this.router.navigate([`${this.routers.incidentConfig}`]);
137
141
  }
138
142
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: AddEditIncidentComponent, deps: [{ token: i0.Injector }, { token: i1.CommonService }], target: i0.ɵɵFactoryTarget.Component }); }
139
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: AddEditIncidentComponent, selector: "pw-admin-add-edit-incident", viewQueries: [{ propertyName: "editForm", first: true, predicate: ["editForm"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"container-fluid pw-tab overflow-hidden\">\n <div class=\"dashboard\">\n <div class=\"dashboard-body\">\n <div class=\"me-auto col-xs-6 mt-4\">\n <a aria-label=\"Navigate to Target\" routerLink=\"/admin/incident/list\" class=\"previous\"><i\n class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n <h3 class=\"mt-3\">{{ id ? 'Edit' : 'Add New' }} Incident</h3>\n </div>\n <div class=\"w-100 text-center mt-3\"\n *ngIf=\"isLoading\">\n <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n </div>\n <div class=\"p-2 mt-3\">\n <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\" *ngIf=\"!isLoading\">\n <div class=\"row\">\n <pw-input-container class=\"col-lg-6\" [label]=\"'Admin.Incident.UrlImpacted' | transloco\"\n name=\"url_impacted\" [errorMsg]=\"'Admin.Incident.Validation.UrlImpacted' | transloco\">\n <input type=\"text\" formControlName=\"url_impacted\" class=\"form-control\"\n [ngClass]=\"{ 'is-invalid': submitted && f['url_impacted'].errors }\" />\n </pw-input-container>\n <pw-input-container class=\"col-lg-6\" [label]=\"'Admin.Incident.ServiceImpacted' | transloco\"\n name=\"service_impacted\"\n [errorMsg]=\"'Admin.Incident.Validation.ServiceImpacted' | transloco\">\n <input type=\"text\" formControlName=\"service_impacted\" class=\"form-control\"\n [ngClass]=\"{ 'is-invalid': submitted && f['service_impacted'].errors }\" />\n </pw-input-container>\n <div class=\"col-lg-12\">\n <pw-input-container class=\"col-12 quill-editor\"\n [label]=\"'Admin.Incident.Description' | transloco\" name=\"description\"\n [errorMsg]=\"'Admin.Incident.Validation.Description' | transloco\">\n <quill-editor [styles]=\"{ height: '200px'}\" formControlName=\"description\" [modules]=\"editorConfig\"\n class=\"quillEditor d-block\"\n [ngClass]=\"{ 'is-invalid': submitted && f['description'].errors, 'quill-container': true }\">\n </quill-editor>\n </pw-input-container>\n </div>\n <div class=\"row\">\n <div class=\"col-xs-12 col-sm-4 col-md-4 col-lg-4\">\n <pw-input-container [label]=\"'Admin.Incident.StartedAt' | transloco\" name=\"started_at\"\n [errorMsg]=\"'Admin.Incident.Validation.Date' | transloco\">\n <p-calendar class=\"addEditincident\" formControlName=\"started_at\" [showIcon]=\"true\" [placeholder]=\"'Admin.Incident.calender.placeholder' | transloco\"\n [showTime]=\"true\" [appendTo]=\"'body'\" dateFormat=\"dd-M-yy\">\n </p-calendar>\n </pw-input-container>\n </div>\n <div class=\"col-xs-12 col-sm-4 col-md-4 col-lg-4\">\n <pw-input-container [label]=\"'Admin.Incident.ResolvedAt' | transloco\" name=\"resolved_at\"\n [errorMsg]=\"'Admin.Incident.Validation.Date' | transloco\">\n <p-calendar class=\"addEditincident\" formControlName=\"resolved_at\" [showIcon]=\"true\" [placeholder]=\"'Admin.Incident.calender.placeholder' | transloco\"\n [showTime]=\"true\" [appendTo]=\"'body'\" dateFormat=\"dd-M-yy\">\n </p-calendar>\n </pw-input-container>\n </div>\n <div class=\"col-xs-12 col-sm-4 col-md-4 col-lg-4\">\n <pw-input-container [label]=\"'Admin.Incident.LastCheckedAt' | transloco\"\n name=\"last_check_at\" [errorMsg]=\"'Admin.Incident.Validation.Date' | transloco\">\n <p-calendar class=\"addEditincident\" formControlName=\"last_check_at\"[placeholder]=\"'Admin.Incident.calender.placeholder' | transloco\"\n [showIcon]=\"true\" [showTime]=\"true\" [appendTo]=\"'body'\" dateFormat=\"dd-M-yy\">\n </p-calendar>\n </pw-input-container>\n </div>\n </div>\n </div>\n <div class=\"row\">\n <div class=\"col-12 mt-4\">\n <div class=\"mb-3 text-end\">\n <button type=\"button\" class=\"btn btn-outline-default me-2\" data-bs-toggle=\"collapse\"\n (keydown.enter)=\"onCancel()\" (click)=\"onCancel()\" aria-expanded=\"false\"\n aria-controls=\"incidentCollapse\"> {{ 'Button.Cancel' | transloco }} </button>\n <button class=\"btn btn-primary\" [buttonBusy]=\"buttonBusy\">{{\n 'Button.Save' | transloco }}</button>\n </div>\n </div>\n </div>\n </form>\n </div>\n </div>\n </div>\n</div>\n", styles: [":root{--first: rgb(23 105 225);--second: rgb(54 194 131);--third: rgb(255 171 0);--text: rgb(34 34 34);--tabs_bg: rgb(23 105 225);--tabs_sub_bg: rgb(70, 136, 236);--tabs_text: rgb(255 255 255);--titles: rgb(34 34 34);--sidebar_bg: rgb(0, 48, 63);--sidebar_text: rgb(255 255 255)}\n"], dependencies: [{ kind: "component", type: i2.Calendar, selector: "p-calendar", inputs: ["iconDisplay", "style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "ariaLabel", "iconAriaLabel", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "stepYearPicker", "stepHour", "stepMinute", "stepSecond", "showSeconds", "required", "showOnFocus", "showWeek", "startWeekFromFirstDayOfYear", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autofocus", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "variant", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "locale", "view", "defaultDate"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i5.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i6.ProgressSpinner, selector: "p-progressSpinner", inputs: ["styleClass", "style", "strokeWidth", "fill", "animationDuration", "ariaLabel"] }, { kind: "component", type: i7.InputContainerComponent, selector: "pw-input-container", inputs: ["name", "label", "labelClass", "tooltipPosition", "required", "errorMsg", "isReadOnly", "showTooltip", "tooltipText", "showTriangle", "afterLabel", "showAfterLabel", "showTriangleText", "isLeftTooltip"] }, { kind: "directive", type: i8.ButtonBusyDirective, selector: "[buttonBusy]", inputs: ["buttonBusy", "busyText"] }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i9.QuillEditorComponent, selector: "quill-editor" }, { kind: "pipe", type: i10.TranslocoPipe, name: "transloco" }] }); }
143
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: AddEditIncidentComponent, selector: "pw-admin-add-edit-incident", viewQueries: [{ propertyName: "editForm", first: true, predicate: ["editForm"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"container-fluid pw-tab overflow-hidden\">\n <div class=\"dashboard\">\n <div class=\"dashboard-body\">\n <div class=\"me-auto col-xs-6 mt-4\">\n <a aria-label=\"Navigate to Target\" routerLink=\"/admin/incident/list\" class=\"previous\"><i\n class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n <h3 class=\"mt-3\">{{ id ? 'Edit' : 'Add New' }} Incident</h3>\n </div>\n <div class=\"w-100 text-center mt-3\"\n *ngIf=\"isLoading\">\n <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n </div>\n <div class=\"p-2 mt-3\">\n <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\" *ngIf=\"!isLoading\">\n <div class=\"row\">\n <pw-input-container class=\"col-lg-6\" [label]=\"'Admin.Incident.UrlImpacted' | transloco\"\n name=\"url_impacted\" [errorMsg]=\"'Admin.Incident.Validation.UrlImpacted' | transloco\">\n <input type=\"text\" formControlName=\"url_impacted\" class=\"form-control\"\n [ngClass]=\"{ 'is-invalid': submitted && f['url_impacted'].errors }\" />\n </pw-input-container>\n <pw-input-container class=\"col-lg-6\" [label]=\"'Admin.Incident.ServiceImpacted' | transloco\"\n name=\"service_impacted\"\n [errorMsg]=\"'Admin.Incident.Validation.ServiceImpacted' | transloco\">\n <input type=\"text\" formControlName=\"service_impacted\" class=\"form-control\"\n [ngClass]=\"{ 'is-invalid': submitted && f['service_impacted'].errors }\" />\n </pw-input-container>\n <div class=\"col-lg-12\">\n <pw-input-container class=\"col-12 quill-editor\" id=\"descriptionEditor\"\n [label]=\"'Admin.Incident.Description' | transloco\" name=\"description\"\n [errorMsg]=\"'Admin.Incident.Validation.Description' | transloco\">\n <quill-editor [styles]=\"{ height: '200px'}\" formControlName=\"description\" [modules]=\"editorConfig\"\n class=\"quillEditor d-block\"\n [ngClass]=\"{ 'is-invalid': submitted && f['description'].errors, 'quill-container': true }\">\n </quill-editor>\n </pw-input-container>\n </div>\n <div class=\"col-lg-12\">\n <pw-input-container class=\"col-12 quill-editor\" id=\"internalDescriptionEditor\"\n [label]=\"'Admin.Incident.InternalDescription' | transloco\" name=\"internal_description\"\n [errorMsg]=\"'Admin.Incident.Validation.InternalDescription' | transloco\">\n <quill-editor [styles]=\"{ height: '200px'}\" formControlName=\"internal_description\" [modules]=\"editorConfig\"\n class=\"quillEditor d-block\"\n [ngClass]=\"{ 'is-invalid': submitted && f['internal_description'].errors, 'quill-container': true }\">\n </quill-editor>\n </pw-input-container>\n </div>\n <div class=\"row\">\n <div class=\"col-xs-12 col-sm-4 col-md-4 col-lg-4\">\n <pw-input-container [label]=\"'Admin.Incident.StartedAt' | transloco\" name=\"started_at\"\n [errorMsg]=\"'Admin.Incident.Validation.Date' | transloco\">\n <p-calendar class=\"addEditincident\" formControlName=\"started_at\" [showIcon]=\"true\" [placeholder]=\"'Admin.Incident.calender.placeholder' | transloco\"\n [showTime]=\"true\" [appendTo]=\"'body'\" dateFormat=\"dd-M-yy\">\n </p-calendar>\n </pw-input-container>\n </div>\n <div class=\"col-xs-12 col-sm-4 col-md-4 col-lg-4\">\n <pw-input-container [label]=\"'Admin.Incident.ResolvedAt' | transloco\" name=\"resolved_at\"\n [errorMsg]=\"'Admin.Incident.Validation.Date' | transloco\">\n <p-calendar class=\"addEditincident\" formControlName=\"resolved_at\" [showIcon]=\"true\" [placeholder]=\"'Admin.Incident.calender.placeholder' | transloco\"\n [showTime]=\"true\" [appendTo]=\"'body'\" dateFormat=\"dd-M-yy\">\n </p-calendar>\n </pw-input-container>\n </div>\n <div class=\"col-xs-12 col-sm-4 col-md-4 col-lg-4\">\n <pw-input-container [label]=\"'Admin.Incident.LastCheckedAt' | transloco\"\n name=\"last_check_at\" [errorMsg]=\"'Admin.Incident.Validation.Date' | transloco\">\n <p-calendar class=\"addEditincident\" formControlName=\"last_check_at\"[placeholder]=\"'Admin.Incident.calender.placeholder' | transloco\"\n [showIcon]=\"true\" [showTime]=\"true\" [appendTo]=\"'body'\" dateFormat=\"dd-M-yy\">\n </p-calendar>\n </pw-input-container>\n </div>\n </div>\n </div>\n <div class=\"row\">\n <div class=\"col-12 mt-4\">\n <div class=\"mb-3 text-end\">\n <button type=\"button\" class=\"btn btn-outline-default me-2\" data-bs-toggle=\"collapse\"\n (keydown.enter)=\"onCancel()\" (click)=\"onCancel()\" aria-expanded=\"false\"\n aria-controls=\"incidentCollapse\"> {{ 'Button.Cancel' | transloco }} </button>\n <button class=\"btn btn-primary\" [buttonBusy]=\"buttonBusy\">{{\n 'Button.Save' | transloco }}</button>\n </div>\n </div>\n </div>\n </form>\n </div>\n </div>\n </div>\n</div>\n", styles: [":root{--first: rgb(23 105 225);--second: rgb(54 194 131);--third: rgb(255 171 0);--text: rgb(34 34 34);--tabs_bg: rgb(23 105 225);--tabs_sub_bg: rgb(70, 136, 236);--tabs_text: rgb(255 255 255);--titles: rgb(34 34 34);--sidebar_bg: rgb(0, 48, 63);--sidebar_text: rgb(255 255 255)}\n"], dependencies: [{ kind: "component", type: i2.Calendar, selector: "p-calendar", inputs: ["iconDisplay", "style", "styleClass", "inputStyle", "inputId", "name", "inputStyleClass", "placeholder", "ariaLabelledBy", "ariaLabel", "iconAriaLabel", "disabled", "dateFormat", "multipleSeparator", "rangeSeparator", "inline", "showOtherMonths", "selectOtherMonths", "showIcon", "icon", "appendTo", "readonlyInput", "shortYearCutoff", "monthNavigator", "yearNavigator", "hourFormat", "timeOnly", "stepYearPicker", "stepHour", "stepMinute", "stepSecond", "showSeconds", "required", "showOnFocus", "showWeek", "startWeekFromFirstDayOfYear", "showClear", "dataType", "selectionMode", "maxDateCount", "showButtonBar", "todayButtonStyleClass", "clearButtonStyleClass", "autofocus", "autoZIndex", "baseZIndex", "panelStyleClass", "panelStyle", "keepInvalid", "hideOnDateTimeSelect", "touchUI", "timeSeparator", "focusTrap", "showTransitionOptions", "hideTransitionOptions", "tabindex", "variant", "minDate", "maxDate", "disabledDates", "disabledDays", "yearRange", "showTime", "responsiveOptions", "numberOfMonths", "firstDayOfWeek", "locale", "view", "defaultDate"], outputs: ["onFocus", "onBlur", "onClose", "onSelect", "onClear", "onInput", "onTodayClick", "onClearClick", "onMonthChange", "onYearChange", "onClickOutside", "onShow"] }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i5.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i6.ProgressSpinner, selector: "p-progressSpinner", inputs: ["styleClass", "style", "strokeWidth", "fill", "animationDuration", "ariaLabel"] }, { kind: "component", type: i7.InputContainerComponent, selector: "pw-input-container", inputs: ["name", "label", "labelClass", "tooltipPosition", "required", "errorMsg", "isReadOnly", "showTooltip", "tooltipText", "showTriangle", "afterLabel", "showAfterLabel", "showTriangleText", "isLeftTooltip"] }, { kind: "directive", type: i8.ButtonBusyDirective, selector: "[buttonBusy]", inputs: ["buttonBusy", "busyText"] }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i9.QuillEditorComponent, selector: "quill-editor" }, { kind: "pipe", type: i10.TranslocoPipe, name: "transloco" }] }); }
140
144
  }
141
145
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: AddEditIncidentComponent, decorators: [{
142
146
  type: Component,
143
- args: [{ selector: 'pw-admin-add-edit-incident', template: "<div class=\"container-fluid pw-tab overflow-hidden\">\n <div class=\"dashboard\">\n <div class=\"dashboard-body\">\n <div class=\"me-auto col-xs-6 mt-4\">\n <a aria-label=\"Navigate to Target\" routerLink=\"/admin/incident/list\" class=\"previous\"><i\n class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n <h3 class=\"mt-3\">{{ id ? 'Edit' : 'Add New' }} Incident</h3>\n </div>\n <div class=\"w-100 text-center mt-3\"\n *ngIf=\"isLoading\">\n <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n </div>\n <div class=\"p-2 mt-3\">\n <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\" *ngIf=\"!isLoading\">\n <div class=\"row\">\n <pw-input-container class=\"col-lg-6\" [label]=\"'Admin.Incident.UrlImpacted' | transloco\"\n name=\"url_impacted\" [errorMsg]=\"'Admin.Incident.Validation.UrlImpacted' | transloco\">\n <input type=\"text\" formControlName=\"url_impacted\" class=\"form-control\"\n [ngClass]=\"{ 'is-invalid': submitted && f['url_impacted'].errors }\" />\n </pw-input-container>\n <pw-input-container class=\"col-lg-6\" [label]=\"'Admin.Incident.ServiceImpacted' | transloco\"\n name=\"service_impacted\"\n [errorMsg]=\"'Admin.Incident.Validation.ServiceImpacted' | transloco\">\n <input type=\"text\" formControlName=\"service_impacted\" class=\"form-control\"\n [ngClass]=\"{ 'is-invalid': submitted && f['service_impacted'].errors }\" />\n </pw-input-container>\n <div class=\"col-lg-12\">\n <pw-input-container class=\"col-12 quill-editor\"\n [label]=\"'Admin.Incident.Description' | transloco\" name=\"description\"\n [errorMsg]=\"'Admin.Incident.Validation.Description' | transloco\">\n <quill-editor [styles]=\"{ height: '200px'}\" formControlName=\"description\" [modules]=\"editorConfig\"\n class=\"quillEditor d-block\"\n [ngClass]=\"{ 'is-invalid': submitted && f['description'].errors, 'quill-container': true }\">\n </quill-editor>\n </pw-input-container>\n </div>\n <div class=\"row\">\n <div class=\"col-xs-12 col-sm-4 col-md-4 col-lg-4\">\n <pw-input-container [label]=\"'Admin.Incident.StartedAt' | transloco\" name=\"started_at\"\n [errorMsg]=\"'Admin.Incident.Validation.Date' | transloco\">\n <p-calendar class=\"addEditincident\" formControlName=\"started_at\" [showIcon]=\"true\" [placeholder]=\"'Admin.Incident.calender.placeholder' | transloco\"\n [showTime]=\"true\" [appendTo]=\"'body'\" dateFormat=\"dd-M-yy\">\n </p-calendar>\n </pw-input-container>\n </div>\n <div class=\"col-xs-12 col-sm-4 col-md-4 col-lg-4\">\n <pw-input-container [label]=\"'Admin.Incident.ResolvedAt' | transloco\" name=\"resolved_at\"\n [errorMsg]=\"'Admin.Incident.Validation.Date' | transloco\">\n <p-calendar class=\"addEditincident\" formControlName=\"resolved_at\" [showIcon]=\"true\" [placeholder]=\"'Admin.Incident.calender.placeholder' | transloco\"\n [showTime]=\"true\" [appendTo]=\"'body'\" dateFormat=\"dd-M-yy\">\n </p-calendar>\n </pw-input-container>\n </div>\n <div class=\"col-xs-12 col-sm-4 col-md-4 col-lg-4\">\n <pw-input-container [label]=\"'Admin.Incident.LastCheckedAt' | transloco\"\n name=\"last_check_at\" [errorMsg]=\"'Admin.Incident.Validation.Date' | transloco\">\n <p-calendar class=\"addEditincident\" formControlName=\"last_check_at\"[placeholder]=\"'Admin.Incident.calender.placeholder' | transloco\"\n [showIcon]=\"true\" [showTime]=\"true\" [appendTo]=\"'body'\" dateFormat=\"dd-M-yy\">\n </p-calendar>\n </pw-input-container>\n </div>\n </div>\n </div>\n <div class=\"row\">\n <div class=\"col-12 mt-4\">\n <div class=\"mb-3 text-end\">\n <button type=\"button\" class=\"btn btn-outline-default me-2\" data-bs-toggle=\"collapse\"\n (keydown.enter)=\"onCancel()\" (click)=\"onCancel()\" aria-expanded=\"false\"\n aria-controls=\"incidentCollapse\"> {{ 'Button.Cancel' | transloco }} </button>\n <button class=\"btn btn-primary\" [buttonBusy]=\"buttonBusy\">{{\n 'Button.Save' | transloco }}</button>\n </div>\n </div>\n </div>\n </form>\n </div>\n </div>\n </div>\n</div>\n", styles: [":root{--first: rgb(23 105 225);--second: rgb(54 194 131);--third: rgb(255 171 0);--text: rgb(34 34 34);--tabs_bg: rgb(23 105 225);--tabs_sub_bg: rgb(70, 136, 236);--tabs_text: rgb(255 255 255);--titles: rgb(34 34 34);--sidebar_bg: rgb(0, 48, 63);--sidebar_text: rgb(255 255 255)}\n"] }]
147
+ args: [{ selector: 'pw-admin-add-edit-incident', template: "<div class=\"container-fluid pw-tab overflow-hidden\">\n <div class=\"dashboard\">\n <div class=\"dashboard-body\">\n <div class=\"me-auto col-xs-6 mt-4\">\n <a aria-label=\"Navigate to Target\" routerLink=\"/admin/incident/list\" class=\"previous\"><i\n class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n <h3 class=\"mt-3\">{{ id ? 'Edit' : 'Add New' }} Incident</h3>\n </div>\n <div class=\"w-100 text-center mt-3\"\n *ngIf=\"isLoading\">\n <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n </div>\n <div class=\"p-2 mt-3\">\n <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\" *ngIf=\"!isLoading\">\n <div class=\"row\">\n <pw-input-container class=\"col-lg-6\" [label]=\"'Admin.Incident.UrlImpacted' | transloco\"\n name=\"url_impacted\" [errorMsg]=\"'Admin.Incident.Validation.UrlImpacted' | transloco\">\n <input type=\"text\" formControlName=\"url_impacted\" class=\"form-control\"\n [ngClass]=\"{ 'is-invalid': submitted && f['url_impacted'].errors }\" />\n </pw-input-container>\n <pw-input-container class=\"col-lg-6\" [label]=\"'Admin.Incident.ServiceImpacted' | transloco\"\n name=\"service_impacted\"\n [errorMsg]=\"'Admin.Incident.Validation.ServiceImpacted' | transloco\">\n <input type=\"text\" formControlName=\"service_impacted\" class=\"form-control\"\n [ngClass]=\"{ 'is-invalid': submitted && f['service_impacted'].errors }\" />\n </pw-input-container>\n <div class=\"col-lg-12\">\n <pw-input-container class=\"col-12 quill-editor\" id=\"descriptionEditor\"\n [label]=\"'Admin.Incident.Description' | transloco\" name=\"description\"\n [errorMsg]=\"'Admin.Incident.Validation.Description' | transloco\">\n <quill-editor [styles]=\"{ height: '200px'}\" formControlName=\"description\" [modules]=\"editorConfig\"\n class=\"quillEditor d-block\"\n [ngClass]=\"{ 'is-invalid': submitted && f['description'].errors, 'quill-container': true }\">\n </quill-editor>\n </pw-input-container>\n </div>\n <div class=\"col-lg-12\">\n <pw-input-container class=\"col-12 quill-editor\" id=\"internalDescriptionEditor\"\n [label]=\"'Admin.Incident.InternalDescription' | transloco\" name=\"internal_description\"\n [errorMsg]=\"'Admin.Incident.Validation.InternalDescription' | transloco\">\n <quill-editor [styles]=\"{ height: '200px'}\" formControlName=\"internal_description\" [modules]=\"editorConfig\"\n class=\"quillEditor d-block\"\n [ngClass]=\"{ 'is-invalid': submitted && f['internal_description'].errors, 'quill-container': true }\">\n </quill-editor>\n </pw-input-container>\n </div>\n <div class=\"row\">\n <div class=\"col-xs-12 col-sm-4 col-md-4 col-lg-4\">\n <pw-input-container [label]=\"'Admin.Incident.StartedAt' | transloco\" name=\"started_at\"\n [errorMsg]=\"'Admin.Incident.Validation.Date' | transloco\">\n <p-calendar class=\"addEditincident\" formControlName=\"started_at\" [showIcon]=\"true\" [placeholder]=\"'Admin.Incident.calender.placeholder' | transloco\"\n [showTime]=\"true\" [appendTo]=\"'body'\" dateFormat=\"dd-M-yy\">\n </p-calendar>\n </pw-input-container>\n </div>\n <div class=\"col-xs-12 col-sm-4 col-md-4 col-lg-4\">\n <pw-input-container [label]=\"'Admin.Incident.ResolvedAt' | transloco\" name=\"resolved_at\"\n [errorMsg]=\"'Admin.Incident.Validation.Date' | transloco\">\n <p-calendar class=\"addEditincident\" formControlName=\"resolved_at\" [showIcon]=\"true\" [placeholder]=\"'Admin.Incident.calender.placeholder' | transloco\"\n [showTime]=\"true\" [appendTo]=\"'body'\" dateFormat=\"dd-M-yy\">\n </p-calendar>\n </pw-input-container>\n </div>\n <div class=\"col-xs-12 col-sm-4 col-md-4 col-lg-4\">\n <pw-input-container [label]=\"'Admin.Incident.LastCheckedAt' | transloco\"\n name=\"last_check_at\" [errorMsg]=\"'Admin.Incident.Validation.Date' | transloco\">\n <p-calendar class=\"addEditincident\" formControlName=\"last_check_at\"[placeholder]=\"'Admin.Incident.calender.placeholder' | transloco\"\n [showIcon]=\"true\" [showTime]=\"true\" [appendTo]=\"'body'\" dateFormat=\"dd-M-yy\">\n </p-calendar>\n </pw-input-container>\n </div>\n </div>\n </div>\n <div class=\"row\">\n <div class=\"col-12 mt-4\">\n <div class=\"mb-3 text-end\">\n <button type=\"button\" class=\"btn btn-outline-default me-2\" data-bs-toggle=\"collapse\"\n (keydown.enter)=\"onCancel()\" (click)=\"onCancel()\" aria-expanded=\"false\"\n aria-controls=\"incidentCollapse\"> {{ 'Button.Cancel' | transloco }} </button>\n <button class=\"btn btn-primary\" [buttonBusy]=\"buttonBusy\">{{\n 'Button.Save' | transloco }}</button>\n </div>\n </div>\n </div>\n </form>\n </div>\n </div>\n </div>\n</div>\n", styles: [":root{--first: rgb(23 105 225);--second: rgb(54 194 131);--third: rgb(255 171 0);--text: rgb(34 34 34);--tabs_bg: rgb(23 105 225);--tabs_sub_bg: rgb(70, 136, 236);--tabs_text: rgb(255 255 255);--titles: rgb(34 34 34);--sidebar_bg: rgb(0, 48, 63);--sidebar_text: rgb(255 255 255)}\n"] }]
144
148
  }], ctorParameters: () => [{ type: i0.Injector }, { type: i1.CommonService }], propDecorators: { editForm: [{
145
149
  type: ViewChild,
146
150
  args: ['editForm', { static: false }]
147
151
  }] } });
148
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-edit-incident.component.js","sourceRoot":"","sources":["../../../../../../../../libs/admin-module/src/lib/components/incidents/add-edit-incident/add-edit-incident.component.ts","../../../../../../../../libs/admin-module/src/lib/components/incidents/add-edit-incident/add-edit-incident.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, Injector, OnDestroy, OnInit, ViewChild } from '@angular/core';\nimport { NgForm, UntypedFormGroup } from '@angular/forms';\nimport { SafeHtml } from '@angular/platform-browser';\n\nimport { AppAdmin } from '@posiwise/admin-module-utils';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { CommonService, PermissionService } from '@posiwise/common-services';\nimport { HelperService } from '@posiwise/helper-service';\nimport { QuillHelper } from '@posiwise/utils';\n\nimport { Incident } from '../../../shared/interface/admin-module-shared.interface';\nimport { ROUTERS } from '../../../shared/routers/routers';\n\n@Component({\n    selector: 'pw-admin-add-edit-incident',\n    templateUrl: './add-edit-incident.component.html',\n    styleUrls: ['./add-edit-incident.component.scss']\n})\nexport class AddEditIncidentComponent\n    extends AppBaseComponent\n    implements OnInit, OnDestroy, AfterViewInit\n{\n    @ViewChild('editForm', { static: false }) editForm: NgForm;\n\n    form: UntypedFormGroup;\n\n    sanitizedHtml: SafeHtml;\n\n    routers = ROUTERS;\n    editorConfig;\n\n    landing = false;\n\n    logo: string;\n\n    openIncidents = [];\n    pastIncidents = [];\n\n    isLoading = true;\n\n    p1: number;\n    p: number;\n    subscriptionId: number;\n    id: number;\n\n    companyName = this.appConfig.company.name;\n\n    currentIncident: Incident;\n\n    isSuperAdmin = this.permissionService.isSuperAdmin();\n\n    submitted = false;\n    buttonBusy = false;\n\n    constructor(\n        injector: Injector,\n        private readonly commonService: CommonService\n    ) {\n        super(injector);\n        QuillHelper.init();\n        this.editorConfig = QuillHelper.getEditorConfig();\n        this.subscriptionId = PermissionService.selectedSubscription?.id;\n        this.form = AppAdmin.getIncidentForm();\n    }\n\n    ngAfterViewInit() {\n        HelperService.subscribeToEditorChanges(this.form, 'description');\n    }\n\n    ngOnInit(): void {\n        this.logo = this.appConfig?.company?.logos?.main?.url;\n        this.route.params.subscribe(params => {\n            this.id = +params['id'] || 0;\n        });\n        this.currentIncident = history.state?.data;\n        if (this.currentIncident || this.id) {\n            this.getIncidentById();\n        } else {\n            this.isLoading = false;\n        }\n    }\n\n    get f() {\n        return this.form.controls;\n    }\n\n    onSubmit() {\n        const rawHtml = HelperService.SaveRawHTML();\n        this.form.controls['description'].setValue(rawHtml);\n        this.form.markAllAsTouched();\n        if (this.form.valid) {\n            if (this.id) {\n                this.onUpdate();\n            } else {\n                this.onAdd();\n            }\n            this.submitted = true;\n        }\n    }\n\n    public getIncidentById() {\n        this.commonService\n            .getIncidentById(this.id, this.subscriptionId)\n            .subscribe(response => {\n                this.form.setValue({\n                    id: response.id,\n                    description: response?.description,\n                    service_impacted: response?.service_impacted,\n                    url_impacted: response?.url_impacted,\n                    resolved_at: response?.resolved_at ? new Date(response?.resolved_at) : '',\n                    started_at: response?.started_at ? new Date(response?.started_at) : '',\n                    last_check_at: response?.last_check_at ? new Date(response?.last_check_at) : ''\n                });\n            })\n            .add(() => {\n                this.isLoading = false;\n            });\n    }\n    onAdd() {\n        this.buttonBusy = true;\n        try {\n            const data = {\n                ...this.form.value,\n                subscription_id: this.subscriptionId\n                // last_check_at: HelperService.dateFormat(this.form.value.started_at),\n                // started_at: HelperService.dateFormat(this.form.value.started_at),\n                // resolved_at: HelperService.dateFormat(this.form.value.resolved_at)\n            };\n            this.commonService\n                .addIncident(data)\n                .subscribe(() => {\n                    this.toast.success(this.translation.translate('Admin.Incident.AddMessage'));\n                    this.router.navigate([`${this.routers.incidentConfig}`]);\n                })\n                .add(() => (this.buttonBusy = false));\n        } catch (error) {\n            this.buttonBusy = false;\n            console.log(error);\n        }\n    }\n\n    onUpdate() {\n        this.buttonBusy = true;\n        try {\n            const data = {\n                ...this.form.value,\n                subscription_id: this.subscriptionId\n                // last_check_at: HelperService.dateFormat(this.form.value.started_at),\n                // started_at: HelperService.dateFormat(this.form.value.started_at),\n                // resolved_at: HelperService.dateFormat(this.form.value.resolved_at)\n            };\n            this.commonService\n                .editIncident(this.id, data)\n                .subscribe(() => {\n                    this.toast.success(this.translation.translate('Admin.Incident.UpdateMessage'));\n                    this.router.navigate([`${this.routers.incidentConfig}`]);\n                })\n                .add(() => (this.buttonBusy = false));\n        } catch (error) {\n            this.buttonBusy = false;\n            console.log(error);\n        }\n    }\n\n    onCancel() {\n        this.router.navigate([`${this.routers.incidentConfig}`]);\n    }\n}\n","<div class=\"container-fluid pw-tab overflow-hidden\">\n    <div class=\"dashboard\">\n        <div class=\"dashboard-body\">\n            <div class=\"me-auto col-xs-6 mt-4\">\n                <a aria-label=\"Navigate to Target\" routerLink=\"/admin/incident/list\" class=\"previous\"><i\n                        class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n                <h3 class=\"mt-3\">{{ id ? 'Edit' : 'Add New' }} Incident</h3>\n            </div>\n            <div class=\"w-100 text-center mt-3\"\n            *ngIf=\"isLoading\">\n            <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n            </div>\n            <div class=\"p-2 mt-3\">\n                <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\" *ngIf=\"!isLoading\">\n                    <div class=\"row\">\n                        <pw-input-container class=\"col-lg-6\" [label]=\"'Admin.Incident.UrlImpacted' | transloco\"\n                            name=\"url_impacted\" [errorMsg]=\"'Admin.Incident.Validation.UrlImpacted' | transloco\">\n                            <input type=\"text\" formControlName=\"url_impacted\" class=\"form-control\"\n                                [ngClass]=\"{ 'is-invalid': submitted && f['url_impacted'].errors }\" />\n                        </pw-input-container>\n                        <pw-input-container class=\"col-lg-6\" [label]=\"'Admin.Incident.ServiceImpacted' | transloco\"\n                            name=\"service_impacted\"\n                            [errorMsg]=\"'Admin.Incident.Validation.ServiceImpacted' | transloco\">\n                            <input type=\"text\" formControlName=\"service_impacted\" class=\"form-control\"\n                                [ngClass]=\"{ 'is-invalid': submitted && f['service_impacted'].errors }\" />\n                        </pw-input-container>\n                        <div class=\"col-lg-12\">\n                            <pw-input-container class=\"col-12 quill-editor\"\n                                [label]=\"'Admin.Incident.Description' | transloco\" name=\"description\"\n                                [errorMsg]=\"'Admin.Incident.Validation.Description' | transloco\">\n                                <quill-editor [styles]=\"{ height: '200px'}\" formControlName=\"description\" [modules]=\"editorConfig\"\n                                    class=\"quillEditor d-block\"\n                                    [ngClass]=\"{ 'is-invalid': submitted && f['description'].errors, 'quill-container': true  }\">\n                                </quill-editor>\n                            </pw-input-container>\n                        </div>\n                        <div class=\"row\">\n                            <div class=\"col-xs-12 col-sm-4 col-md-4 col-lg-4\">\n                                <pw-input-container [label]=\"'Admin.Incident.StartedAt' | transloco\" name=\"started_at\"\n                                    [errorMsg]=\"'Admin.Incident.Validation.Date' | transloco\">\n                                    <p-calendar class=\"addEditincident\" formControlName=\"started_at\" [showIcon]=\"true\" [placeholder]=\"'Admin.Incident.calender.placeholder' | transloco\"\n                                        [showTime]=\"true\" [appendTo]=\"'body'\" dateFormat=\"dd-M-yy\">\n                                    </p-calendar>\n                                </pw-input-container>\n                            </div>\n                            <div class=\"col-xs-12 col-sm-4 col-md-4 col-lg-4\">\n                                <pw-input-container [label]=\"'Admin.Incident.ResolvedAt' | transloco\" name=\"resolved_at\"\n                                    [errorMsg]=\"'Admin.Incident.Validation.Date' | transloco\">\n                                    <p-calendar class=\"addEditincident\" formControlName=\"resolved_at\" [showIcon]=\"true\" [placeholder]=\"'Admin.Incident.calender.placeholder' | transloco\"\n                                        [showTime]=\"true\" [appendTo]=\"'body'\" dateFormat=\"dd-M-yy\">\n                                    </p-calendar>\n                                </pw-input-container>\n                            </div>\n                            <div class=\"col-xs-12 col-sm-4 col-md-4 col-lg-4\">\n                                <pw-input-container [label]=\"'Admin.Incident.LastCheckedAt' | transloco\"\n                                    name=\"last_check_at\" [errorMsg]=\"'Admin.Incident.Validation.Date' | transloco\">\n                                    <p-calendar class=\"addEditincident\" formControlName=\"last_check_at\"[placeholder]=\"'Admin.Incident.calender.placeholder' | transloco\"\n                                        [showIcon]=\"true\" [showTime]=\"true\" [appendTo]=\"'body'\" dateFormat=\"dd-M-yy\">\n                                    </p-calendar>\n                                </pw-input-container>\n                            </div>\n                        </div>\n                    </div>\n                    <div class=\"row\">\n                        <div class=\"col-12 mt-4\">\n                            <div class=\"mb-3 text-end\">\n                                <button type=\"button\" class=\"btn btn-outline-default me-2\" data-bs-toggle=\"collapse\"\n                                    (keydown.enter)=\"onCancel()\" (click)=\"onCancel()\"  aria-expanded=\"false\"\n                                    aria-controls=\"incidentCollapse\"> {{ 'Button.Cancel' | transloco }} </button>\n                                <button class=\"btn btn-primary\" [buttonBusy]=\"buttonBusy\">{{\n                                    'Button.Save' | transloco }}</button>\n                            </div>\n                        </div>\n                    </div>\n                </form>\n            </div>\n        </div>\n    </div>\n</div>\n"]}
152
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-edit-incident.component.js","sourceRoot":"","sources":["../../../../../../../../libs/admin-module/src/lib/components/incidents/add-edit-incident/add-edit-incident.component.ts","../../../../../../../../libs/admin-module/src/lib/components/incidents/add-edit-incident/add-edit-incident.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, Injector, OnDestroy, OnInit, ViewChild } from '@angular/core';\nimport { NgForm, UntypedFormGroup } from '@angular/forms';\nimport { SafeHtml } from '@angular/platform-browser';\n\nimport { AppAdmin } from '@posiwise/admin-module-utils';\nimport { AppBaseComponent } from '@posiwise/app-base-component';\nimport { CommonService, PermissionService } from '@posiwise/common-services';\nimport { HelperService } from '@posiwise/helper-service';\nimport { QuillHelper } from '@posiwise/utils';\n\nimport { Incident } from '../../../shared/interface/admin-module-shared.interface';\nimport { ROUTERS } from '../../../shared/routers/routers';\n\n@Component({\n    selector: 'pw-admin-add-edit-incident',\n    templateUrl: './add-edit-incident.component.html',\n    styleUrls: ['./add-edit-incident.component.scss']\n})\nexport class AddEditIncidentComponent\n    extends AppBaseComponent\n    implements OnInit, OnDestroy, AfterViewInit\n{\n    @ViewChild('editForm', { static: false }) editForm: NgForm;\n\n    form: UntypedFormGroup;\n\n    sanitizedHtml: SafeHtml;\n\n    routers = ROUTERS;\n    editorConfig;\n\n    landing = false;\n\n    logo: string;\n\n    openIncidents = [];\n    pastIncidents = [];\n\n    isLoading = true;\n\n    p1: number;\n    p: number;\n    subscriptionId: number;\n    id: number;\n\n    companyName = this.appConfig.company.name;\n\n    currentIncident: Incident;\n\n    isSuperAdmin = this.permissionService.isSuperAdmin();\n\n    submitted = false;\n    buttonBusy = false;\n\n    constructor(\n        injector: Injector,\n        private readonly commonService: CommonService\n    ) {\n        super(injector);\n        QuillHelper.init();\n        this.editorConfig = QuillHelper.getEditorConfig();\n        this.subscriptionId = PermissionService.selectedSubscription?.id;\n        this.form = AppAdmin.getIncidentForm();\n    }\n\n    ngAfterViewInit() {\n        HelperService.subscribeToEditorChanges(this.form, 'description');\n        HelperService.subscribeToEditorChanges(this.form, 'internal_description');\n    }\n\n    ngOnInit(): void {\n        this.logo = this.appConfig?.company?.logos?.main?.url;\n        this.route.params.subscribe(params => {\n            this.id = +params['id'] || 0;\n        });\n        this.currentIncident = history.state?.data;\n        if (this.currentIncident || this.id) {\n            this.getIncidentById();\n        } else {\n            this.isLoading = false;\n        }\n    }\n\n    get f() {\n        return this.form.controls;\n    }\n\n    onSubmit() {\n        const rawHtml = HelperService.SaveRawHTML('#descriptionEditor');\n        this.form.controls['description'].setValue(rawHtml);\n        const rawInternalHtml = HelperService.SaveRawHTML('#internalDescriptionEditor');\n        this.form.controls['internal_description'].setValue(rawInternalHtml);\n        this.form.markAllAsTouched();\n        if (this.form.valid) {\n            if (this.id) {\n                this.onUpdate();\n            } else {\n                this.onAdd();\n            }\n            this.submitted = true;\n        }\n    }\n\n    public getIncidentById() {\n        this.commonService\n            .getIncidentById(this.id, this.subscriptionId)\n            .subscribe(response => {\n                this.form.setValue({\n                    id: response.id,\n                    description: response?.description,\n                    internal_description: response?.internal_description || '',\n                    service_impacted: response?.service_impacted,\n                    url_impacted: response?.url_impacted,\n                    resolved_at: response?.resolved_at ? new Date(response?.resolved_at) : '',\n                    started_at: response?.started_at ? new Date(response?.started_at) : '',\n                    last_check_at: response?.last_check_at ? new Date(response?.last_check_at) : ''\n                });\n            })\n            .add(() => {\n                this.isLoading = false;\n            });\n    }\n    onAdd() {\n        this.buttonBusy = true;\n        try {\n            const data = {\n                ...this.form.value,\n                subscription_id: this.subscriptionId\n                // last_check_at: HelperService.dateFormat(this.form.value.started_at),\n                // started_at: HelperService.dateFormat(this.form.value.started_at),\n                // resolved_at: HelperService.dateFormat(this.form.value.resolved_at)\n            };\n            this.commonService\n                .addIncident(data)\n                .subscribe(() => {\n                    this.toast.success(this.translation.translate('Admin.Incident.AddMessage'));\n                    this.router.navigate([`${this.routers.incidentConfig}`]);\n                })\n                .add(() => (this.buttonBusy = false));\n        } catch (error) {\n            this.buttonBusy = false;\n            console.log(error);\n        }\n    }\n\n    onUpdate() {\n        this.buttonBusy = true;\n        try {\n            const data = {\n                ...this.form.value,\n                subscription_id: this.subscriptionId\n                // last_check_at: HelperService.dateFormat(this.form.value.started_at),\n                // started_at: HelperService.dateFormat(this.form.value.started_at),\n                // resolved_at: HelperService.dateFormat(this.form.value.resolved_at)\n            };\n            this.commonService\n                .editIncident(this.id, data)\n                .subscribe(() => {\n                    this.toast.success(this.translation.translate('Admin.Incident.UpdateMessage'));\n                    this.router.navigate([`${this.routers.incidentConfig}`]);\n                })\n                .add(() => (this.buttonBusy = false));\n        } catch (error) {\n            this.buttonBusy = false;\n            console.log(error);\n        }\n    }\n\n    onCancel() {\n        this.router.navigate([`${this.routers.incidentConfig}`]);\n    }\n}\n","<div class=\"container-fluid pw-tab overflow-hidden\">\n    <div class=\"dashboard\">\n        <div class=\"dashboard-body\">\n            <div class=\"me-auto col-xs-6 mt-4\">\n                <a aria-label=\"Navigate to Target\" routerLink=\"/admin/incident/list\" class=\"previous\"><i\n                        class=\"fa fa-arrow-alt-circle-left\" aria-hidden=\"true\"></i></a>\n                <h3 class=\"mt-3\">{{ id ? 'Edit' : 'Add New' }} Incident</h3>\n            </div>\n            <div class=\"w-100 text-center mt-3\"\n            *ngIf=\"isLoading\">\n            <p-progressSpinner strokeWidth=\"2\"> </p-progressSpinner>\n            </div>\n            <div class=\"p-2 mt-3\">\n                <form (ngSubmit)=\"onSubmit()\" [formGroup]=\"form\" *ngIf=\"!isLoading\">\n                    <div class=\"row\">\n                        <pw-input-container class=\"col-lg-6\" [label]=\"'Admin.Incident.UrlImpacted' | transloco\"\n                            name=\"url_impacted\" [errorMsg]=\"'Admin.Incident.Validation.UrlImpacted' | transloco\">\n                            <input type=\"text\" formControlName=\"url_impacted\" class=\"form-control\"\n                                [ngClass]=\"{ 'is-invalid': submitted && f['url_impacted'].errors }\" />\n                        </pw-input-container>\n                        <pw-input-container class=\"col-lg-6\" [label]=\"'Admin.Incident.ServiceImpacted' | transloco\"\n                            name=\"service_impacted\"\n                            [errorMsg]=\"'Admin.Incident.Validation.ServiceImpacted' | transloco\">\n                            <input type=\"text\" formControlName=\"service_impacted\" class=\"form-control\"\n                                [ngClass]=\"{ 'is-invalid': submitted && f['service_impacted'].errors }\" />\n                        </pw-input-container>\n                        <div class=\"col-lg-12\">\n                            <pw-input-container class=\"col-12 quill-editor\" id=\"descriptionEditor\"\n                                [label]=\"'Admin.Incident.Description' | transloco\" name=\"description\"\n                                [errorMsg]=\"'Admin.Incident.Validation.Description' | transloco\">\n                                <quill-editor [styles]=\"{ height: '200px'}\" formControlName=\"description\" [modules]=\"editorConfig\"\n                                    class=\"quillEditor d-block\"\n                                    [ngClass]=\"{ 'is-invalid': submitted && f['description'].errors, 'quill-container': true  }\">\n                                </quill-editor>\n                            </pw-input-container>\n                        </div>\n                        <div class=\"col-lg-12\">\n                            <pw-input-container class=\"col-12 quill-editor\" id=\"internalDescriptionEditor\"\n                                [label]=\"'Admin.Incident.InternalDescription' | transloco\" name=\"internal_description\"\n                                [errorMsg]=\"'Admin.Incident.Validation.InternalDescription' | transloco\">\n                                <quill-editor [styles]=\"{ height: '200px'}\" formControlName=\"internal_description\" [modules]=\"editorConfig\"\n                                    class=\"quillEditor d-block\"\n                                    [ngClass]=\"{ 'is-invalid': submitted && f['internal_description'].errors, 'quill-container': true  }\">\n                                </quill-editor>\n                            </pw-input-container>\n                        </div>\n                        <div class=\"row\">\n                            <div class=\"col-xs-12 col-sm-4 col-md-4 col-lg-4\">\n                                <pw-input-container [label]=\"'Admin.Incident.StartedAt' | transloco\" name=\"started_at\"\n                                    [errorMsg]=\"'Admin.Incident.Validation.Date' | transloco\">\n                                    <p-calendar class=\"addEditincident\" formControlName=\"started_at\" [showIcon]=\"true\" [placeholder]=\"'Admin.Incident.calender.placeholder' | transloco\"\n                                        [showTime]=\"true\" [appendTo]=\"'body'\" dateFormat=\"dd-M-yy\">\n                                    </p-calendar>\n                                </pw-input-container>\n                            </div>\n                            <div class=\"col-xs-12 col-sm-4 col-md-4 col-lg-4\">\n                                <pw-input-container [label]=\"'Admin.Incident.ResolvedAt' | transloco\" name=\"resolved_at\"\n                                    [errorMsg]=\"'Admin.Incident.Validation.Date' | transloco\">\n                                    <p-calendar class=\"addEditincident\" formControlName=\"resolved_at\" [showIcon]=\"true\" [placeholder]=\"'Admin.Incident.calender.placeholder' | transloco\"\n                                        [showTime]=\"true\" [appendTo]=\"'body'\" dateFormat=\"dd-M-yy\">\n                                    </p-calendar>\n                                </pw-input-container>\n                            </div>\n                            <div class=\"col-xs-12 col-sm-4 col-md-4 col-lg-4\">\n                                <pw-input-container [label]=\"'Admin.Incident.LastCheckedAt' | transloco\"\n                                    name=\"last_check_at\" [errorMsg]=\"'Admin.Incident.Validation.Date' | transloco\">\n                                    <p-calendar class=\"addEditincident\" formControlName=\"last_check_at\"[placeholder]=\"'Admin.Incident.calender.placeholder' | transloco\"\n                                        [showIcon]=\"true\" [showTime]=\"true\" [appendTo]=\"'body'\" dateFormat=\"dd-M-yy\">\n                                    </p-calendar>\n                                </pw-input-container>\n                            </div>\n                        </div>\n                    </div>\n                    <div class=\"row\">\n                        <div class=\"col-12 mt-4\">\n                            <div class=\"mb-3 text-end\">\n                                <button type=\"button\" class=\"btn btn-outline-default me-2\" data-bs-toggle=\"collapse\"\n                                    (keydown.enter)=\"onCancel()\" (click)=\"onCancel()\"  aria-expanded=\"false\"\n                                    aria-controls=\"incidentCollapse\"> {{ 'Button.Cancel' | transloco }} </button>\n                                <button class=\"btn btn-primary\" [buttonBusy]=\"buttonBusy\">{{\n                                    'Button.Save' | transloco }}</button>\n                            </div>\n                        </div>\n                    </div>\n                </form>\n            </div>\n        </div>\n    </div>\n</div>\n"]}