tango-app-ui-store-builder 1.0.76 → 1.0.77

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 { finalize } from "rxjs";
4
4
  import { DatePickerComponent } from "../../../date-picker/date-picker.component";
5
5
  import * as i0 from "@angular/core";
6
6
  import * as i1 from "@ng-bootstrap/ng-bootstrap";
7
- import * as i2 from "projects/tango-store-builder/src/lib/services/store-builder.service";
7
+ import * as i2 from "../../../../services/store-builder.service";
8
8
  export class ScheduleTaskPopupComponent {
9
9
  activeModal;
10
10
  apiService;
@@ -162,4 +162,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
162
162
  }], storeName: [{
163
163
  type: Input
164
164
  }] } });
165
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schedule-task-popup.component.js","sourceRoot":"","sources":["../../../../../../../../projects/tango-store-builder/src/lib/components/manage-store-plano/popups/schedule-task-popup/schedule-task-popup.component.ts","../../../../../../../../projects/tango-store-builder/src/lib/components/manage-store-plano/popups/schedule-task-popup/schedule-task-popup.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe, NgClass, NgFor, NgStyle } from \"@angular/common\";\nimport { Component, Input, OnInit } from \"@angular/core\";\nimport { NgbActiveModal } from \"@ng-bootstrap/ng-bootstrap\";\n\nimport { finalize } from \"rxjs\";\n\r\nimport { DatePickerComponent } from \"../../../date-picker/date-picker.component\";\r\nimport { StoreBuilderService } from \"projects/tango-store-builder/src/lib/services/store-builder.service\";\r\n\r\n@Component({\r\n  selector: \"schedule-task-popup\",\r\n  templateUrl: \"./schedule-task-popup.component.html\",\r\n  styleUrl: \"./schedule-task-popup.component.scss\",\r\n  standalone: true,\r\n  imports: [NgClass, NgStyle, NgFor, DatePickerComponent, DatePipe],\r\n})\r\nexport class ScheduleTaskPopupComponent implements OnInit {\r\n  @Input() fixtures: any;\r\n  @Input() storeName: string;\r\n\r\n  mbqItems: any[] = [];\r\n  zoneColumns: string[] = [];\r\n\r\n  today = new Date();\r\n  scheduledDate: string;\r\n\r\n  showInfoBanner: boolean = false;\n  isDownloadButtonLoading: boolean = false;\n\n  sortOrder: number = 1;\n  sortedColumn: string = \"\";\n  private readonly numericColumns = new Set([\"partition\", \"standardCapacity\"]);\n\r\n  constructor(\r\n    private activeModal: NgbActiveModal,\r\n    private apiService: StoreBuilderService,\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    // Collect all unique zone names across all fixtures in insertion order\r\n    const zoneSet = new Set<string>();\r\n    for (const f of this.fixtures) {\r\n      for (const s of f?.shelfConfig ?? []) {\r\n        if (s.zone) zoneSet.add(s.zone);\r\n      }\r\n    }\r\n    this.zoneColumns = Array.from(zoneSet);\r\n\r\n    for (let i = 0; i < this.fixtures.length; i++) {\r\n      const f = this.fixtures[i];\r\n      const shelfDetails: any[] = f?.shelfConfig ?? [];\r\n\r\n      // Group shelves by zone and collect unique brand names per zone\r\n      const zoneAllocations: Record<string, string[]> = {};\r\n      for (const zone of this.zoneColumns) {\r\n        const shelves = shelfDetails.filter((s: any) => s.zone === zone);\r\n        zoneAllocations[zone] = [\r\n          ...new Set(shelves.flatMap((s: any) => s.productBrandName ?? [])),\r\n        ];\r\n      }\r\n\r\n      this.mbqItems.push({\r\n        wall:\r\n          f?.associatedElementType == \"wall\"\r\n            ? `Wall ${f?.associatedElementNumber}`\r\n            : \"Floor\",\r\n        ufn: `FX - ${f?.fixtureNumber}`,\r\n        brand: f?.header?.label,\r\n        type: f?.fixtureCategory,\r\n        size: `${f?.fixtureWidth?.value}${f?.fixtureWidth?.unit}`,\r\n        partition: shelfDetails.length,\r\n        // displayPartition: shelfDetails.length,\r\n        standardCapacity: f?.fixtureCapacity ?? 0,\r\n        // actualCapacity: f?.fixtureCapacity ?? 0,\r\n        zoneAllocations,\r\n      });\r\n    }\r\n  }\r\n\r\n  downloadMBQSheet() {\n    // const headers = [\r\n    //   \"Wall/Floor\",\r\n    //   \"UFN\",\r\n    //   \"Brand Category\",\r\n    //   \"Type\",\r\n    //   \"Size\",\r\n    //   \"Partition\",\r\n    //   \"Standard Capacity\",\r\n    //   ...this.zoneColumns.map((zone) => `${zone} Zone Allocation`),\r\n    // ];\r\n\r\n    // const rows = this.mbqItems.map((item) => [\r\n    //   item?.wall ?? \"\",\r\n    //   item?.ufn ?? \"\",\r\n    //   item?.brand ?? \"\",\r\n    //   item?.type ?? \"\",\r\n    //   item?.size ?? \"\",\r\n    //   item?.partition ?? \"\",\r\n    //   item?.standardCapacity ?? \"\",\r\n    //   ...this.zoneColumns.map(\r\n    //     (zone) => item?.zoneAllocations?.[zone]?.join(\", \") || \"-\"\r\n    //   ),\r\n    // ]);\r\n\r\n    // const worksheet = XLSX.utils.aoa_to_sheet([headers, ...rows]);\r\n    // const workbook = XLSX.utils.book_new();\r\n    // XLSX.utils.book_append_sheet(workbook, worksheet, \"MBQ\");\r\n\r\n    // const safeStoreName = (this.storeName || \"store\").replace(\r\n    //   /[\\\\/:*?\"<>|]/g,\r\n    //   \"_\"\r\n    // );\r\n    // XLSX.writeFile(workbook, `${safeStoreName}_mbq.xlsx`);\r\n\r\n    // try {\r\n\r\n    // } catch (error) {\r\n    //   console.log(\"@@ ~ downloadMBQSheet [ERR]:\", error);\r\n    // }\r\n\r\n    if (this.isDownloadButtonLoading) return;\n\n    const storeName = [this.storeName];\n    this.isDownloadButtonLoading = true;\n\n    this.apiService\n      .exportMBQSheet({ storeName })\n      .pipe(\n        finalize(() => {\n          this.isDownloadButtonLoading = false;\n        }),\n      )\n      .subscribe({\n        next: (res: any) => {\n          const safeStoreName = (this.storeName || \"store\").replace(\n            /[\\\\/:*?\"<>|]/g,\n            \"_\",\n          );\n\n          this.apiService.saveAsExcelFile(res, `${safeStoreName}_mbq`);\n        },\n        error: (err) => {\n          console.log(\"@@ downloadMBQSheet [ERR]: \", err);\n        },\n      });\n  }\n\r\n  onSort(column: string) {\r\n    if (this.sortedColumn === column) {\r\n      this.sortOrder = this.sortOrder * -1;\r\n    } else {\r\n      this.sortedColumn = column;\r\n      this.sortOrder = 1;\r\n    }\r\n\r\n    this.mbqItems.sort((a, b) => {\r\n      const aValue = a?.[column];\r\n      const bValue = b?.[column];\r\n\r\n      if (this.numericColumns.has(column)) {\r\n        const aNum = Number(aValue ?? 0);\r\n        const bNum = Number(bValue ?? 0);\r\n        return (aNum - bNum) * this.sortOrder;\r\n      }\r\n\r\n      const aStr = String(aValue ?? \"\");\r\n      const bStr = String(bValue ?? \"\");\r\n      return (\r\n        aStr.localeCompare(bStr, undefined, {\r\n          numeric: true,\r\n          sensitivity: \"base\",\r\n        }) * this.sortOrder\r\n      );\r\n    });\r\n  }\r\n\r\n  scheduleTask() {\r\n    this.activeModal.close({\r\n      status: \"submit\",\r\n      scheduledDate: this.scheduledDate,\r\n    });\r\n  }\r\n\r\n  onDateSelected(data: any) {\r\n    this.scheduledDate = data;\r\n    this.showInfoBanner = true;\r\n  }\r\n\r\n  onCancel() {\r\n    this.activeModal.dismiss();\r\n  }\r\n}\r\n","<div class=\"modal-wrapper\">\r\n    <h3 class=\"mb-3\">Publish Verification Task</h3>\r\n    <p>You are about to send a verification task to <b>{{storeName}}</b>. Choose if you want to schedule the task\r\n        for later.\r\n    </p>\r\n\r\n\r\n    <div class=\"d-flex align-items-center gap-3 mb-3\">\r\n        <h4 class=\"me-auto\">MBQ for {{storeName}}</h4>\r\n\r\n        <date-picker (dateChange)=\"onDateSelected($event)\">\r\n        </date-picker>\r\n\r\n        <button type=\"button\" class=\"btn btn-outline d-flex align-items-center justify-content-center bg-white shadow-sm mbq-download-btn\"\r\n            (click)=\"downloadMBQSheet()\" [disabled]=\"isDownloadButtonLoading\" style=\"padding: 9px 12px;\">\r\n            @if (!isDownloadButtonLoading) {\r\n                <svg width=\"22\" height=\"22\" viewBox=\"0 0 26 26\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n                    stroke=\"#000000\" stroke-width=\"0.24000000000000005\">\r\n                    <g id=\"SVGRepo_bgCarrier\" stroke-width=\"0\"></g>\r\n                    <g id=\"SVGRepo_tracerCarrier\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke=\"#CCCCCC\"\r\n                        stroke-width=\"0.384\"></g>\r\n                    <g id=\"SVGRepo_iconCarrier\">\r\n                        <path\r\n                            d=\"M12.5535 16.5061C12.4114 16.6615 12.2106 16.75 12 16.75C11.7894 16.75 11.5886 16.6615 11.4465 16.5061L7.44648 12.1311C7.16698 11.8254 7.18822 11.351 7.49392 11.0715C7.79963 10.792 8.27402 10.8132 8.55352 11.1189L11.25 14.0682V3C11.25 2.58579 11.5858 2.25 12 2.25C12.4142 2.25 12.75 2.58579 12.75 3V14.0682L15.4465 11.1189C15.726 10.8132 16.2004 10.792 16.5061 11.0715C16.8118 11.351 16.833 11.8254 16.5535 12.1311L12.5535 16.5061Z\"\r\n                            fill=\"#1D2939\"></path>\r\n                        <path\r\n                            d=\"M3.75 15C3.75 14.5858 3.41422 14.25 3 14.25C2.58579 14.25 2.25 14.5858 2.25 15V15.0549C2.24998 16.4225 2.24996 17.5248 2.36652 18.3918C2.48754 19.2919 2.74643 20.0497 3.34835 20.6516C3.95027 21.2536 4.70814 21.5125 5.60825 21.6335C6.47522 21.75 7.57754 21.75 8.94513 21.75H15.0549C16.4225 21.75 17.5248 21.75 18.3918 21.6335C19.2919 21.5125 20.0497 21.2536 20.6517 20.6516C21.2536 20.0497 21.5125 19.2919 21.6335 18.3918C21.75 17.5248 21.75 16.4225 21.75 15.0549V15C21.75 14.5858 21.4142 14.25 21 14.25C20.5858 14.25 20.25 14.5858 20.25 15C20.25 16.4354 20.2484 17.4365 20.1469 18.1919C20.0482 18.9257 19.8678 19.3142 19.591 19.591C19.3142 19.8678 18.9257 20.0482 18.1919 20.1469C17.4365 20.2484 16.4354 20.25 15 20.25H9C7.56459 20.25 6.56347 20.2484 5.80812 20.1469C5.07435 20.0482 4.68577 19.8678 4.40901 19.591C4.13225 19.3142 3.9518 18.9257 3.85315 18.1919C3.75159 17.4365 3.75 16.4354 3.75 15Z\"\r\n                            fill=\"#1D2939\"></path>\r\n                    </g>\r\n                </svg>\r\n            } @else {\r\n                <svg class=\"spinner\" viewBox=\"0 0 50 50\">\r\n                    <circle class=\"path\" cx=\"25\" cy=\"25\" r=\"20\" fill=\"none\" stroke-width=\"4\"></circle>\r\n                </svg>\r\n            }\r\n        </button>\r\n    </div>\r\n\r\n    @if(showInfoBanner){\r\n        <div class=\"info-banner\">\r\n            <svg width=\"17\" height=\"19\" viewBox=\"0 0 17 19\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                <path\r\n                    d=\"M11.6693 0.834961V4.16829M5.0026 0.834961V4.16829M0.835938 7.50163H15.8359M2.5026 2.50163H14.1693C15.0897 2.50163 15.8359 3.24782 15.8359 4.16829V15.835C15.8359 16.7554 15.0897 17.5016 14.1693 17.5016H2.5026C1.58213 17.5016 0.835938 16.7554 0.835938 15.835V4.16829C0.835938 3.24782 1.58213 2.50163 2.5026 2.50163Z\"\r\n                    stroke=\"#009BF3\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n            </svg>\r\n\r\n            <span>\r\n                You are scheduling the layout verification task for <b>{{\r\n                        scheduledDate === (today | date:'yyyy-MM-dd')\r\n                            ? 'Today'\r\n                            : (scheduledDate | date:'dd MMMM, yyyy')\r\n                }}</b>\r\n            </span>\r\n\r\n            <svg class=\"ms-auto cursor-pointer\" (click)=\"showInfoBanner = false;\" width=\"18\" height=\"18\"\r\n                viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                <path d=\"M13.5 4.5L4.5 13.5M4.5 4.5L13.5 13.5\" stroke=\"#101828\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                    stroke-linejoin=\"round\" />\r\n            </svg>\r\n        </div>\r\n    }\r\n    <div class=\"table-responsive\">\r\n        <table class=\"w-100 table bottom-border text-nowrap\">\r\n            <thead>\r\n                <tr>\r\n                    <th class=\"cursor-pointer\" (click)=\"onSort('wall')\">\r\n                        Wall/Floor\r\n                        <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'wall' ? '#009BF3' : '' }\"\r\n                            [ngClass]=\"sortOrder === 1 && sortedColumn === 'wall' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                            aria-hidden=\"true\"></i>\r\n                    </th>\r\n                    <th class=\"cursor-pointer\" (click)=\"onSort('ufn')\">\r\n                        UFN\r\n                        <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'ufn' ? '#009BF3' : '' }\"\r\n                            [ngClass]=\"sortOrder === 1 && sortedColumn === 'ufn' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                            aria-hidden=\"true\"></i>\r\n                    </th>\r\n                    <th class=\"cursor-pointer\" (click)=\"onSort('brand')\">\r\n                        Brand Category\r\n                        <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'brand' ? '#009BF3' : '' }\"\r\n                            [ngClass]=\"sortOrder === 1 && sortedColumn === 'brand' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                            aria-hidden=\"true\"></i>\r\n                    </th>\r\n                    <th class=\"cursor-pointer\" (click)=\"onSort('type')\">\r\n                        Type\r\n                        <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'type' ? '#009BF3' : '' }\"\r\n                            [ngClass]=\"sortOrder === 1 && sortedColumn === 'type' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                            aria-hidden=\"true\"></i>\r\n                    </th>\r\n                    <th class=\"cursor-pointer\" (click)=\"onSort('size')\">\r\n                        Size\r\n                        <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'size' ? '#009BF3' : '' }\"\r\n                            [ngClass]=\"sortOrder === 1 && sortedColumn === 'size' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                            aria-hidden=\"true\"></i>\r\n                    </th>\r\n                    <th class=\"cursor-pointer\" (click)=\"onSort('partition')\">\r\n                        Partition\r\n                        <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'partition' ? '#009BF3' : '' }\"\r\n                            [ngClass]=\"sortOrder === 1 && sortedColumn === 'partition' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                            aria-hidden=\"true\"></i>\r\n                    </th>\r\n                    <!-- <th>\r\n                        Display Per Partition\r\n                        <i class=\"fa ms-1 mt-1\"\r\n                            [ngStyle]=\"{ color: sortedColumn === 'displayPartition' ? '#009BF3' : '' }\"\r\n                            [ngClass]=\"sortOrder === 1 && sortedColumn === 'displayPartition' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                            aria-hidden=\"true\"></i>\r\n                    </th> -->\r\n                    <th class=\"cursor-pointer\" (click)=\"onSort('standardCapacity')\">\r\n                        Standard Capacity\r\n                        <i class=\"fa ms-1 mt-1\"\r\n                            [ngStyle]=\"{ color: sortedColumn === 'standardCapacity' ? '#009BF3' : '' }\"\r\n                            [ngClass]=\"sortOrder === 1 && sortedColumn === 'standardCapacity' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                            aria-hidden=\"true\"></i>\r\n                    </th>\r\n                    <!-- <th>\r\n                        Actual Capacity\r\n                        <i class=\"fa ms-1 mt-1\"\r\n                            [ngStyle]=\"{ color: sortedColumn === 'actualCapacity' ? '#009BF3' : '' }\"\r\n                            [ngClass]=\"sortOrder === 1 && sortedColumn === 'actualCapacity' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                            aria-hidden=\"true\"></i>\r\n                    </th> -->\r\n                    <th *ngFor=\"let zone of zoneColumns\">\r\n                        {{zone}} Zone Allocation\r\n                        <i class=\"fa ms-1 mt-1\" aria-hidden=\"true\"></i>\r\n                    </th>\r\n                </tr>\r\n            </thead>\r\n\r\n            <tbody>\r\n                <tr *ngFor=\"let item of mbqItems\">\r\n                    <td>{{item?.wall}}</td>\r\n                    <td>{{item?.ufn}}</td>\r\n                    <td>{{item?.brand}}</td>\r\n                    <td>{{item?.type}}</td>\r\n                    <td>{{item?.size}}</td>\r\n                    <td>{{item?.partition}}</td>\r\n                    <!-- <td>{{item?.displayPartition}}</td> -->\r\n                    <td>{{item?.standardCapacity}}</td>\r\n                    <!-- <td>{{item?.actualCapacity}}</td> -->\r\n                    <td *ngFor=\"let zone of zoneColumns\">{{item?.zoneAllocations?.[zone]?.join(', ') || '-'}}</td>\r\n                </tr>\r\n            </tbody>\r\n        </table>\r\n    </div>\r\n\r\n    <div class=\"modal-actions\">\r\n        <button type=\"button\" class=\"btn btn-outline\" (click)=\"onCancel()\">Cancel</button>\r\n        <button type=\"button\" class=\"btn btn-primary\" (click)=\"scheduleTask()\">\r\n            Schedule Task\r\n        </button>\r\n    </div>\r\n</div>\r\n"]}
165
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schedule-task-popup.component.js","sourceRoot":"","sources":["../../../../../../../../projects/tango-store-builder/src/lib/components/manage-store-plano/popups/schedule-task-popup/schedule-task-popup.component.ts","../../../../../../../../projects/tango-store-builder/src/lib/components/manage-store-plano/popups/schedule-task-popup/schedule-task-popup.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe, NgClass, NgFor, NgStyle } from \"@angular/common\";\r\nimport { Component, Input, OnInit } from \"@angular/core\";\r\nimport { NgbActiveModal } from \"@ng-bootstrap/ng-bootstrap\";\r\n\r\nimport { finalize } from \"rxjs\";\r\n\r\nimport { DatePickerComponent } from \"../../../date-picker/date-picker.component\";\r\nimport { StoreBuilderService } from \"../../../../services/store-builder.service\";\r\n\r\n@Component({\r\n  selector: \"schedule-task-popup\",\r\n  templateUrl: \"./schedule-task-popup.component.html\",\r\n  styleUrl: \"./schedule-task-popup.component.scss\",\r\n  standalone: true,\r\n  imports: [NgClass, NgStyle, NgFor, DatePickerComponent, DatePipe],\r\n})\r\nexport class ScheduleTaskPopupComponent implements OnInit {\r\n  @Input() fixtures: any;\r\n  @Input() storeName: string;\r\n\r\n  mbqItems: any[] = [];\r\n  zoneColumns: string[] = [];\r\n\r\n  today = new Date();\r\n  scheduledDate: string;\r\n\r\n  showInfoBanner: boolean = false;\r\n  isDownloadButtonLoading: boolean = false;\r\n\r\n  sortOrder: number = 1;\r\n  sortedColumn: string = \"\";\r\n  private readonly numericColumns = new Set([\"partition\", \"standardCapacity\"]);\r\n\r\n  constructor(\r\n    private activeModal: NgbActiveModal,\r\n    private apiService: StoreBuilderService,\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    // Collect all unique zone names across all fixtures in insertion order\r\n    const zoneSet = new Set<string>();\r\n    for (const f of this.fixtures) {\r\n      for (const s of f?.shelfConfig ?? []) {\r\n        if (s.zone) zoneSet.add(s.zone);\r\n      }\r\n    }\r\n    this.zoneColumns = Array.from(zoneSet);\r\n\r\n    for (let i = 0; i < this.fixtures.length; i++) {\r\n      const f = this.fixtures[i];\r\n      const shelfDetails: any[] = f?.shelfConfig ?? [];\r\n\r\n      // Group shelves by zone and collect unique brand names per zone\r\n      const zoneAllocations: Record<string, string[]> = {};\r\n      for (const zone of this.zoneColumns) {\r\n        const shelves = shelfDetails.filter((s: any) => s.zone === zone);\r\n        zoneAllocations[zone] = [\r\n          ...new Set(shelves.flatMap((s: any) => s.productBrandName ?? [])),\r\n        ];\r\n      }\r\n\r\n      this.mbqItems.push({\r\n        wall:\r\n          f?.associatedElementType == \"wall\"\r\n            ? `Wall ${f?.associatedElementNumber}`\r\n            : \"Floor\",\r\n        ufn: `FX - ${f?.fixtureNumber}`,\r\n        brand: f?.header?.label,\r\n        type: f?.fixtureCategory,\r\n        size: `${f?.fixtureWidth?.value}${f?.fixtureWidth?.unit}`,\r\n        partition: shelfDetails.length,\r\n        // displayPartition: shelfDetails.length,\r\n        standardCapacity: f?.fixtureCapacity ?? 0,\r\n        // actualCapacity: f?.fixtureCapacity ?? 0,\r\n        zoneAllocations,\r\n      });\r\n    }\r\n  }\r\n\r\n  downloadMBQSheet() {\r\n    // const headers = [\r\n    //   \"Wall/Floor\",\r\n    //   \"UFN\",\r\n    //   \"Brand Category\",\r\n    //   \"Type\",\r\n    //   \"Size\",\r\n    //   \"Partition\",\r\n    //   \"Standard Capacity\",\r\n    //   ...this.zoneColumns.map((zone) => `${zone} Zone Allocation`),\r\n    // ];\r\n\r\n    // const rows = this.mbqItems.map((item) => [\r\n    //   item?.wall ?? \"\",\r\n    //   item?.ufn ?? \"\",\r\n    //   item?.brand ?? \"\",\r\n    //   item?.type ?? \"\",\r\n    //   item?.size ?? \"\",\r\n    //   item?.partition ?? \"\",\r\n    //   item?.standardCapacity ?? \"\",\r\n    //   ...this.zoneColumns.map(\r\n    //     (zone) => item?.zoneAllocations?.[zone]?.join(\", \") || \"-\"\r\n    //   ),\r\n    // ]);\r\n\r\n    // const worksheet = XLSX.utils.aoa_to_sheet([headers, ...rows]);\r\n    // const workbook = XLSX.utils.book_new();\r\n    // XLSX.utils.book_append_sheet(workbook, worksheet, \"MBQ\");\r\n\r\n    // const safeStoreName = (this.storeName || \"store\").replace(\r\n    //   /[\\\\/:*?\"<>|]/g,\r\n    //   \"_\"\r\n    // );\r\n    // XLSX.writeFile(workbook, `${safeStoreName}_mbq.xlsx`);\r\n\r\n    // try {\r\n\r\n    // } catch (error) {\r\n    //   console.log(\"@@ ~ downloadMBQSheet [ERR]:\", error);\r\n    // }\r\n\r\n    if (this.isDownloadButtonLoading) return;\r\n\r\n    const storeName = [this.storeName];\r\n    this.isDownloadButtonLoading = true;\r\n\r\n    this.apiService\r\n      .exportMBQSheet({ storeName })\r\n      .pipe(\r\n        finalize(() => {\r\n          this.isDownloadButtonLoading = false;\r\n        }),\r\n      )\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          const safeStoreName = (this.storeName || \"store\").replace(\r\n            /[\\\\/:*?\"<>|]/g,\r\n            \"_\",\r\n          );\r\n\r\n          this.apiService.saveAsExcelFile(res, `${safeStoreName}_mbq`);\r\n        },\r\n        error: (err) => {\r\n          console.log(\"@@ downloadMBQSheet [ERR]: \", err);\r\n        },\r\n      });\r\n  }\r\n\r\n  onSort(column: string) {\r\n    if (this.sortedColumn === column) {\r\n      this.sortOrder = this.sortOrder * -1;\r\n    } else {\r\n      this.sortedColumn = column;\r\n      this.sortOrder = 1;\r\n    }\r\n\r\n    this.mbqItems.sort((a, b) => {\r\n      const aValue = a?.[column];\r\n      const bValue = b?.[column];\r\n\r\n      if (this.numericColumns.has(column)) {\r\n        const aNum = Number(aValue ?? 0);\r\n        const bNum = Number(bValue ?? 0);\r\n        return (aNum - bNum) * this.sortOrder;\r\n      }\r\n\r\n      const aStr = String(aValue ?? \"\");\r\n      const bStr = String(bValue ?? \"\");\r\n      return (\r\n        aStr.localeCompare(bStr, undefined, {\r\n          numeric: true,\r\n          sensitivity: \"base\",\r\n        }) * this.sortOrder\r\n      );\r\n    });\r\n  }\r\n\r\n  scheduleTask() {\r\n    this.activeModal.close({\r\n      status: \"submit\",\r\n      scheduledDate: this.scheduledDate,\r\n    });\r\n  }\r\n\r\n  onDateSelected(data: any) {\r\n    this.scheduledDate = data;\r\n    this.showInfoBanner = true;\r\n  }\r\n\r\n  onCancel() {\r\n    this.activeModal.dismiss();\r\n  }\r\n}\r\n","<div class=\"modal-wrapper\">\r\n    <h3 class=\"mb-3\">Publish Verification Task</h3>\r\n    <p>You are about to send a verification task to <b>{{storeName}}</b>. Choose if you want to schedule the task\r\n        for later.\r\n    </p>\r\n\r\n\r\n    <div class=\"d-flex align-items-center gap-3 mb-3\">\r\n        <h4 class=\"me-auto\">MBQ for {{storeName}}</h4>\r\n\r\n        <date-picker (dateChange)=\"onDateSelected($event)\">\r\n        </date-picker>\r\n\r\n        <button type=\"button\" class=\"btn btn-outline d-flex align-items-center justify-content-center bg-white shadow-sm mbq-download-btn\"\r\n            (click)=\"downloadMBQSheet()\" [disabled]=\"isDownloadButtonLoading\" style=\"padding: 9px 12px;\">\r\n            @if (!isDownloadButtonLoading) {\r\n                <svg width=\"22\" height=\"22\" viewBox=\"0 0 26 26\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n                    stroke=\"#000000\" stroke-width=\"0.24000000000000005\">\r\n                    <g id=\"SVGRepo_bgCarrier\" stroke-width=\"0\"></g>\r\n                    <g id=\"SVGRepo_tracerCarrier\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke=\"#CCCCCC\"\r\n                        stroke-width=\"0.384\"></g>\r\n                    <g id=\"SVGRepo_iconCarrier\">\r\n                        <path\r\n                            d=\"M12.5535 16.5061C12.4114 16.6615 12.2106 16.75 12 16.75C11.7894 16.75 11.5886 16.6615 11.4465 16.5061L7.44648 12.1311C7.16698 11.8254 7.18822 11.351 7.49392 11.0715C7.79963 10.792 8.27402 10.8132 8.55352 11.1189L11.25 14.0682V3C11.25 2.58579 11.5858 2.25 12 2.25C12.4142 2.25 12.75 2.58579 12.75 3V14.0682L15.4465 11.1189C15.726 10.8132 16.2004 10.792 16.5061 11.0715C16.8118 11.351 16.833 11.8254 16.5535 12.1311L12.5535 16.5061Z\"\r\n                            fill=\"#1D2939\"></path>\r\n                        <path\r\n                            d=\"M3.75 15C3.75 14.5858 3.41422 14.25 3 14.25C2.58579 14.25 2.25 14.5858 2.25 15V15.0549C2.24998 16.4225 2.24996 17.5248 2.36652 18.3918C2.48754 19.2919 2.74643 20.0497 3.34835 20.6516C3.95027 21.2536 4.70814 21.5125 5.60825 21.6335C6.47522 21.75 7.57754 21.75 8.94513 21.75H15.0549C16.4225 21.75 17.5248 21.75 18.3918 21.6335C19.2919 21.5125 20.0497 21.2536 20.6517 20.6516C21.2536 20.0497 21.5125 19.2919 21.6335 18.3918C21.75 17.5248 21.75 16.4225 21.75 15.0549V15C21.75 14.5858 21.4142 14.25 21 14.25C20.5858 14.25 20.25 14.5858 20.25 15C20.25 16.4354 20.2484 17.4365 20.1469 18.1919C20.0482 18.9257 19.8678 19.3142 19.591 19.591C19.3142 19.8678 18.9257 20.0482 18.1919 20.1469C17.4365 20.2484 16.4354 20.25 15 20.25H9C7.56459 20.25 6.56347 20.2484 5.80812 20.1469C5.07435 20.0482 4.68577 19.8678 4.40901 19.591C4.13225 19.3142 3.9518 18.9257 3.85315 18.1919C3.75159 17.4365 3.75 16.4354 3.75 15Z\"\r\n                            fill=\"#1D2939\"></path>\r\n                    </g>\r\n                </svg>\r\n            } @else {\r\n                <svg class=\"spinner\" viewBox=\"0 0 50 50\">\r\n                    <circle class=\"path\" cx=\"25\" cy=\"25\" r=\"20\" fill=\"none\" stroke-width=\"4\"></circle>\r\n                </svg>\r\n            }\r\n        </button>\r\n    </div>\r\n\r\n    @if(showInfoBanner){\r\n        <div class=\"info-banner\">\r\n            <svg width=\"17\" height=\"19\" viewBox=\"0 0 17 19\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                <path\r\n                    d=\"M11.6693 0.834961V4.16829M5.0026 0.834961V4.16829M0.835938 7.50163H15.8359M2.5026 2.50163H14.1693C15.0897 2.50163 15.8359 3.24782 15.8359 4.16829V15.835C15.8359 16.7554 15.0897 17.5016 14.1693 17.5016H2.5026C1.58213 17.5016 0.835938 16.7554 0.835938 15.835V4.16829C0.835938 3.24782 1.58213 2.50163 2.5026 2.50163Z\"\r\n                    stroke=\"#009BF3\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n            </svg>\r\n\r\n            <span>\r\n                You are scheduling the layout verification task for <b>{{\r\n                        scheduledDate === (today | date:'yyyy-MM-dd')\r\n                            ? 'Today'\r\n                            : (scheduledDate | date:'dd MMMM, yyyy')\r\n                }}</b>\r\n            </span>\r\n\r\n            <svg class=\"ms-auto cursor-pointer\" (click)=\"showInfoBanner = false;\" width=\"18\" height=\"18\"\r\n                viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                <path d=\"M13.5 4.5L4.5 13.5M4.5 4.5L13.5 13.5\" stroke=\"#101828\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                    stroke-linejoin=\"round\" />\r\n            </svg>\r\n        </div>\r\n    }\r\n    <div class=\"table-responsive\">\r\n        <table class=\"w-100 table bottom-border text-nowrap\">\r\n            <thead>\r\n                <tr>\r\n                    <th class=\"cursor-pointer\" (click)=\"onSort('wall')\">\r\n                        Wall/Floor\r\n                        <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'wall' ? '#009BF3' : '' }\"\r\n                            [ngClass]=\"sortOrder === 1 && sortedColumn === 'wall' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                            aria-hidden=\"true\"></i>\r\n                    </th>\r\n                    <th class=\"cursor-pointer\" (click)=\"onSort('ufn')\">\r\n                        UFN\r\n                        <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'ufn' ? '#009BF3' : '' }\"\r\n                            [ngClass]=\"sortOrder === 1 && sortedColumn === 'ufn' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                            aria-hidden=\"true\"></i>\r\n                    </th>\r\n                    <th class=\"cursor-pointer\" (click)=\"onSort('brand')\">\r\n                        Brand Category\r\n                        <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'brand' ? '#009BF3' : '' }\"\r\n                            [ngClass]=\"sortOrder === 1 && sortedColumn === 'brand' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                            aria-hidden=\"true\"></i>\r\n                    </th>\r\n                    <th class=\"cursor-pointer\" (click)=\"onSort('type')\">\r\n                        Type\r\n                        <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'type' ? '#009BF3' : '' }\"\r\n                            [ngClass]=\"sortOrder === 1 && sortedColumn === 'type' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                            aria-hidden=\"true\"></i>\r\n                    </th>\r\n                    <th class=\"cursor-pointer\" (click)=\"onSort('size')\">\r\n                        Size\r\n                        <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'size' ? '#009BF3' : '' }\"\r\n                            [ngClass]=\"sortOrder === 1 && sortedColumn === 'size' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                            aria-hidden=\"true\"></i>\r\n                    </th>\r\n                    <th class=\"cursor-pointer\" (click)=\"onSort('partition')\">\r\n                        Partition\r\n                        <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'partition' ? '#009BF3' : '' }\"\r\n                            [ngClass]=\"sortOrder === 1 && sortedColumn === 'partition' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                            aria-hidden=\"true\"></i>\r\n                    </th>\r\n                    <!-- <th>\r\n                        Display Per Partition\r\n                        <i class=\"fa ms-1 mt-1\"\r\n                            [ngStyle]=\"{ color: sortedColumn === 'displayPartition' ? '#009BF3' : '' }\"\r\n                            [ngClass]=\"sortOrder === 1 && sortedColumn === 'displayPartition' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                            aria-hidden=\"true\"></i>\r\n                    </th> -->\r\n                    <th class=\"cursor-pointer\" (click)=\"onSort('standardCapacity')\">\r\n                        Standard Capacity\r\n                        <i class=\"fa ms-1 mt-1\"\r\n                            [ngStyle]=\"{ color: sortedColumn === 'standardCapacity' ? '#009BF3' : '' }\"\r\n                            [ngClass]=\"sortOrder === 1 && sortedColumn === 'standardCapacity' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                            aria-hidden=\"true\"></i>\r\n                    </th>\r\n                    <!-- <th>\r\n                        Actual Capacity\r\n                        <i class=\"fa ms-1 mt-1\"\r\n                            [ngStyle]=\"{ color: sortedColumn === 'actualCapacity' ? '#009BF3' : '' }\"\r\n                            [ngClass]=\"sortOrder === 1 && sortedColumn === 'actualCapacity' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                            aria-hidden=\"true\"></i>\r\n                    </th> -->\r\n                    <th *ngFor=\"let zone of zoneColumns\">\r\n                        {{zone}} Zone Allocation\r\n                        <i class=\"fa ms-1 mt-1\" aria-hidden=\"true\"></i>\r\n                    </th>\r\n                </tr>\r\n            </thead>\r\n\r\n            <tbody>\r\n                <tr *ngFor=\"let item of mbqItems\">\r\n                    <td>{{item?.wall}}</td>\r\n                    <td>{{item?.ufn}}</td>\r\n                    <td>{{item?.brand}}</td>\r\n                    <td>{{item?.type}}</td>\r\n                    <td>{{item?.size}}</td>\r\n                    <td>{{item?.partition}}</td>\r\n                    <!-- <td>{{item?.displayPartition}}</td> -->\r\n                    <td>{{item?.standardCapacity}}</td>\r\n                    <!-- <td>{{item?.actualCapacity}}</td> -->\r\n                    <td *ngFor=\"let zone of zoneColumns\">{{item?.zoneAllocations?.[zone]?.join(', ') || '-'}}</td>\r\n                </tr>\r\n            </tbody>\r\n        </table>\r\n    </div>\r\n\r\n    <div class=\"modal-actions\">\r\n        <button type=\"button\" class=\"btn btn-outline\" (click)=\"onCancel()\">Cancel</button>\r\n        <button type=\"button\" class=\"btn btn-primary\" (click)=\"scheduleTask()\">\r\n            Schedule Task\r\n        </button>\r\n    </div>\r\n</div>\r\n"]}
@@ -24,10 +24,9 @@ import JSZip from 'jszip';
24
24
  import * as fabric from 'fabric';
25
25
  import * as i2$2 from 'ngx-daterangepicker-material';
26
26
  import { NgxDaterangepickerMd } from 'ngx-daterangepicker-material';
27
- import * as i2$3 from 'projects/tango-store-builder/src/lib/services/store-builder.service';
28
27
  import * as i9 from 'ngx-drag-drop';
29
28
  import { DndModule } from 'ngx-drag-drop';
30
- import * as i2$4 from '@angular/platform-browser';
29
+ import * as i2$3 from '@angular/platform-browser';
31
30
  import { map, filter, distinctUntilChanged } from 'rxjs/operators';
32
31
  import 'dayjs/locale/en';
33
32
  import { Loader } from '@googlemaps/js-api-loader';
@@ -7088,13 +7087,13 @@ class ScheduleTaskPopupComponent {
7088
7087
  onCancel() {
7089
7088
  this.activeModal.dismiss();
7090
7089
  }
7091
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ScheduleTaskPopupComponent, deps: [{ token: i1$1.NgbActiveModal }, { token: i2$3.StoreBuilderService }], target: i0.ɵɵFactoryTarget.Component });
7090
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ScheduleTaskPopupComponent, deps: [{ token: i1$1.NgbActiveModal }, { token: StoreBuilderService }], target: i0.ɵɵFactoryTarget.Component });
7092
7091
  static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: ScheduleTaskPopupComponent, isStandalone: true, selector: "schedule-task-popup", inputs: { fixtures: "fixtures", storeName: "storeName" }, ngImport: i0, template: "<div class=\"modal-wrapper\">\r\n <h3 class=\"mb-3\">Publish Verification Task</h3>\r\n <p>You are about to send a verification task to <b>{{storeName}}</b>. Choose if you want to schedule the task\r\n for later.\r\n </p>\r\n\r\n\r\n <div class=\"d-flex align-items-center gap-3 mb-3\">\r\n <h4 class=\"me-auto\">MBQ for {{storeName}}</h4>\r\n\r\n <date-picker (dateChange)=\"onDateSelected($event)\">\r\n </date-picker>\r\n\r\n <button type=\"button\" class=\"btn btn-outline d-flex align-items-center justify-content-center bg-white shadow-sm mbq-download-btn\"\r\n (click)=\"downloadMBQSheet()\" [disabled]=\"isDownloadButtonLoading\" style=\"padding: 9px 12px;\">\r\n @if (!isDownloadButtonLoading) {\r\n <svg width=\"22\" height=\"22\" viewBox=\"0 0 26 26\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n stroke=\"#000000\" stroke-width=\"0.24000000000000005\">\r\n <g id=\"SVGRepo_bgCarrier\" stroke-width=\"0\"></g>\r\n <g id=\"SVGRepo_tracerCarrier\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke=\"#CCCCCC\"\r\n stroke-width=\"0.384\"></g>\r\n <g id=\"SVGRepo_iconCarrier\">\r\n <path\r\n d=\"M12.5535 16.5061C12.4114 16.6615 12.2106 16.75 12 16.75C11.7894 16.75 11.5886 16.6615 11.4465 16.5061L7.44648 12.1311C7.16698 11.8254 7.18822 11.351 7.49392 11.0715C7.79963 10.792 8.27402 10.8132 8.55352 11.1189L11.25 14.0682V3C11.25 2.58579 11.5858 2.25 12 2.25C12.4142 2.25 12.75 2.58579 12.75 3V14.0682L15.4465 11.1189C15.726 10.8132 16.2004 10.792 16.5061 11.0715C16.8118 11.351 16.833 11.8254 16.5535 12.1311L12.5535 16.5061Z\"\r\n fill=\"#1D2939\"></path>\r\n <path\r\n d=\"M3.75 15C3.75 14.5858 3.41422 14.25 3 14.25C2.58579 14.25 2.25 14.5858 2.25 15V15.0549C2.24998 16.4225 2.24996 17.5248 2.36652 18.3918C2.48754 19.2919 2.74643 20.0497 3.34835 20.6516C3.95027 21.2536 4.70814 21.5125 5.60825 21.6335C6.47522 21.75 7.57754 21.75 8.94513 21.75H15.0549C16.4225 21.75 17.5248 21.75 18.3918 21.6335C19.2919 21.5125 20.0497 21.2536 20.6517 20.6516C21.2536 20.0497 21.5125 19.2919 21.6335 18.3918C21.75 17.5248 21.75 16.4225 21.75 15.0549V15C21.75 14.5858 21.4142 14.25 21 14.25C20.5858 14.25 20.25 14.5858 20.25 15C20.25 16.4354 20.2484 17.4365 20.1469 18.1919C20.0482 18.9257 19.8678 19.3142 19.591 19.591C19.3142 19.8678 18.9257 20.0482 18.1919 20.1469C17.4365 20.2484 16.4354 20.25 15 20.25H9C7.56459 20.25 6.56347 20.2484 5.80812 20.1469C5.07435 20.0482 4.68577 19.8678 4.40901 19.591C4.13225 19.3142 3.9518 18.9257 3.85315 18.1919C3.75159 17.4365 3.75 16.4354 3.75 15Z\"\r\n fill=\"#1D2939\"></path>\r\n </g>\r\n </svg>\r\n } @else {\r\n <svg class=\"spinner\" viewBox=\"0 0 50 50\">\r\n <circle class=\"path\" cx=\"25\" cy=\"25\" r=\"20\" fill=\"none\" stroke-width=\"4\"></circle>\r\n </svg>\r\n }\r\n </button>\r\n </div>\r\n\r\n @if(showInfoBanner){\r\n <div class=\"info-banner\">\r\n <svg width=\"17\" height=\"19\" viewBox=\"0 0 17 19\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M11.6693 0.834961V4.16829M5.0026 0.834961V4.16829M0.835938 7.50163H15.8359M2.5026 2.50163H14.1693C15.0897 2.50163 15.8359 3.24782 15.8359 4.16829V15.835C15.8359 16.7554 15.0897 17.5016 14.1693 17.5016H2.5026C1.58213 17.5016 0.835938 16.7554 0.835938 15.835V4.16829C0.835938 3.24782 1.58213 2.50163 2.5026 2.50163Z\"\r\n stroke=\"#009BF3\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n\r\n <span>\r\n You are scheduling the layout verification task for <b>{{\r\n scheduledDate === (today | date:'yyyy-MM-dd')\r\n ? 'Today'\r\n : (scheduledDate | date:'dd MMMM, yyyy')\r\n }}</b>\r\n </span>\r\n\r\n <svg class=\"ms-auto cursor-pointer\" (click)=\"showInfoBanner = false;\" width=\"18\" height=\"18\"\r\n viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M13.5 4.5L4.5 13.5M4.5 4.5L13.5 13.5\" stroke=\"#101828\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </div>\r\n }\r\n <div class=\"table-responsive\">\r\n <table class=\"w-100 table bottom-border text-nowrap\">\r\n <thead>\r\n <tr>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('wall')\">\r\n Wall/Floor\r\n <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'wall' ? '#009BF3' : '' }\"\r\n [ngClass]=\"sortOrder === 1 && sortedColumn === 'wall' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n aria-hidden=\"true\"></i>\r\n </th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('ufn')\">\r\n UFN\r\n <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'ufn' ? '#009BF3' : '' }\"\r\n [ngClass]=\"sortOrder === 1 && sortedColumn === 'ufn' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n aria-hidden=\"true\"></i>\r\n </th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('brand')\">\r\n Brand Category\r\n <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'brand' ? '#009BF3' : '' }\"\r\n [ngClass]=\"sortOrder === 1 && sortedColumn === 'brand' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n aria-hidden=\"true\"></i>\r\n </th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('type')\">\r\n Type\r\n <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'type' ? '#009BF3' : '' }\"\r\n [ngClass]=\"sortOrder === 1 && sortedColumn === 'type' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n aria-hidden=\"true\"></i>\r\n </th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('size')\">\r\n Size\r\n <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'size' ? '#009BF3' : '' }\"\r\n [ngClass]=\"sortOrder === 1 && sortedColumn === 'size' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n aria-hidden=\"true\"></i>\r\n </th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('partition')\">\r\n Partition\r\n <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'partition' ? '#009BF3' : '' }\"\r\n [ngClass]=\"sortOrder === 1 && sortedColumn === 'partition' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n aria-hidden=\"true\"></i>\r\n </th>\r\n <!-- <th>\r\n Display Per Partition\r\n <i class=\"fa ms-1 mt-1\"\r\n [ngStyle]=\"{ color: sortedColumn === 'displayPartition' ? '#009BF3' : '' }\"\r\n [ngClass]=\"sortOrder === 1 && sortedColumn === 'displayPartition' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n aria-hidden=\"true\"></i>\r\n </th> -->\r\n <th class=\"cursor-pointer\" (click)=\"onSort('standardCapacity')\">\r\n Standard Capacity\r\n <i class=\"fa ms-1 mt-1\"\r\n [ngStyle]=\"{ color: sortedColumn === 'standardCapacity' ? '#009BF3' : '' }\"\r\n [ngClass]=\"sortOrder === 1 && sortedColumn === 'standardCapacity' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n aria-hidden=\"true\"></i>\r\n </th>\r\n <!-- <th>\r\n Actual Capacity\r\n <i class=\"fa ms-1 mt-1\"\r\n [ngStyle]=\"{ color: sortedColumn === 'actualCapacity' ? '#009BF3' : '' }\"\r\n [ngClass]=\"sortOrder === 1 && sortedColumn === 'actualCapacity' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n aria-hidden=\"true\"></i>\r\n </th> -->\r\n <th *ngFor=\"let zone of zoneColumns\">\r\n {{zone}} Zone Allocation\r\n <i class=\"fa ms-1 mt-1\" aria-hidden=\"true\"></i>\r\n </th>\r\n </tr>\r\n </thead>\r\n\r\n <tbody>\r\n <tr *ngFor=\"let item of mbqItems\">\r\n <td>{{item?.wall}}</td>\r\n <td>{{item?.ufn}}</td>\r\n <td>{{item?.brand}}</td>\r\n <td>{{item?.type}}</td>\r\n <td>{{item?.size}}</td>\r\n <td>{{item?.partition}}</td>\r\n <!-- <td>{{item?.displayPartition}}</td> -->\r\n <td>{{item?.standardCapacity}}</td>\r\n <!-- <td>{{item?.actualCapacity}}</td> -->\r\n <td *ngFor=\"let zone of zoneColumns\">{{item?.zoneAllocations?.[zone]?.join(', ') || '-'}}</td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n\r\n <div class=\"modal-actions\">\r\n <button type=\"button\" class=\"btn btn-outline\" (click)=\"onCancel()\">Cancel</button>\r\n <button type=\"button\" class=\"btn btn-primary\" (click)=\"scheduleTask()\">\r\n Schedule Task\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [".modal-wrapper{padding:24px}.table-responsive{max-height:58vh}.info-banner{background:#f6fcff;margin-bottom:12px;border:1px solid #6bcaff;border-radius:4px;padding:12px;display:flex;align-items:center;gap:10px;font-weight:400;font-size:14px;line-height:20px;letter-spacing:0%;color:#1d2939}.modal-actions{display:flex;justify-content:end;gap:12px}::ng-deep .modal-content{border-radius:12px!important}.btn .spinner{height:22px;width:22px;animation:spin .9s linear infinite}.btn .spinner .path{stroke-width:6px;stroke:currentColor;stroke-linecap:round;stroke-dasharray:80;stroke-dashoffset:60}@keyframes spin{to{transform:rotate(360deg)}}.mbq-download-btn{min-width:38px}::ng-deep .schedule-task-modal .modal-dialog{max-width:700px;width:100%}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: DatePickerComponent, selector: "date-picker", outputs: ["dateChange"] }, { kind: "pipe", type: DatePipe, name: "date" }] });
7093
7092
  }
7094
7093
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ScheduleTaskPopupComponent, decorators: [{
7095
7094
  type: Component,
7096
7095
  args: [{ selector: "schedule-task-popup", standalone: true, imports: [NgClass, NgStyle, NgFor, DatePickerComponent, DatePipe], template: "<div class=\"modal-wrapper\">\r\n <h3 class=\"mb-3\">Publish Verification Task</h3>\r\n <p>You are about to send a verification task to <b>{{storeName}}</b>. Choose if you want to schedule the task\r\n for later.\r\n </p>\r\n\r\n\r\n <div class=\"d-flex align-items-center gap-3 mb-3\">\r\n <h4 class=\"me-auto\">MBQ for {{storeName}}</h4>\r\n\r\n <date-picker (dateChange)=\"onDateSelected($event)\">\r\n </date-picker>\r\n\r\n <button type=\"button\" class=\"btn btn-outline d-flex align-items-center justify-content-center bg-white shadow-sm mbq-download-btn\"\r\n (click)=\"downloadMBQSheet()\" [disabled]=\"isDownloadButtonLoading\" style=\"padding: 9px 12px;\">\r\n @if (!isDownloadButtonLoading) {\r\n <svg width=\"22\" height=\"22\" viewBox=\"0 0 26 26\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"\r\n stroke=\"#000000\" stroke-width=\"0.24000000000000005\">\r\n <g id=\"SVGRepo_bgCarrier\" stroke-width=\"0\"></g>\r\n <g id=\"SVGRepo_tracerCarrier\" stroke-linecap=\"round\" stroke-linejoin=\"round\" stroke=\"#CCCCCC\"\r\n stroke-width=\"0.384\"></g>\r\n <g id=\"SVGRepo_iconCarrier\">\r\n <path\r\n d=\"M12.5535 16.5061C12.4114 16.6615 12.2106 16.75 12 16.75C11.7894 16.75 11.5886 16.6615 11.4465 16.5061L7.44648 12.1311C7.16698 11.8254 7.18822 11.351 7.49392 11.0715C7.79963 10.792 8.27402 10.8132 8.55352 11.1189L11.25 14.0682V3C11.25 2.58579 11.5858 2.25 12 2.25C12.4142 2.25 12.75 2.58579 12.75 3V14.0682L15.4465 11.1189C15.726 10.8132 16.2004 10.792 16.5061 11.0715C16.8118 11.351 16.833 11.8254 16.5535 12.1311L12.5535 16.5061Z\"\r\n fill=\"#1D2939\"></path>\r\n <path\r\n d=\"M3.75 15C3.75 14.5858 3.41422 14.25 3 14.25C2.58579 14.25 2.25 14.5858 2.25 15V15.0549C2.24998 16.4225 2.24996 17.5248 2.36652 18.3918C2.48754 19.2919 2.74643 20.0497 3.34835 20.6516C3.95027 21.2536 4.70814 21.5125 5.60825 21.6335C6.47522 21.75 7.57754 21.75 8.94513 21.75H15.0549C16.4225 21.75 17.5248 21.75 18.3918 21.6335C19.2919 21.5125 20.0497 21.2536 20.6517 20.6516C21.2536 20.0497 21.5125 19.2919 21.6335 18.3918C21.75 17.5248 21.75 16.4225 21.75 15.0549V15C21.75 14.5858 21.4142 14.25 21 14.25C20.5858 14.25 20.25 14.5858 20.25 15C20.25 16.4354 20.2484 17.4365 20.1469 18.1919C20.0482 18.9257 19.8678 19.3142 19.591 19.591C19.3142 19.8678 18.9257 20.0482 18.1919 20.1469C17.4365 20.2484 16.4354 20.25 15 20.25H9C7.56459 20.25 6.56347 20.2484 5.80812 20.1469C5.07435 20.0482 4.68577 19.8678 4.40901 19.591C4.13225 19.3142 3.9518 18.9257 3.85315 18.1919C3.75159 17.4365 3.75 16.4354 3.75 15Z\"\r\n fill=\"#1D2939\"></path>\r\n </g>\r\n </svg>\r\n } @else {\r\n <svg class=\"spinner\" viewBox=\"0 0 50 50\">\r\n <circle class=\"path\" cx=\"25\" cy=\"25\" r=\"20\" fill=\"none\" stroke-width=\"4\"></circle>\r\n </svg>\r\n }\r\n </button>\r\n </div>\r\n\r\n @if(showInfoBanner){\r\n <div class=\"info-banner\">\r\n <svg width=\"17\" height=\"19\" viewBox=\"0 0 17 19\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path\r\n d=\"M11.6693 0.834961V4.16829M5.0026 0.834961V4.16829M0.835938 7.50163H15.8359M2.5026 2.50163H14.1693C15.0897 2.50163 15.8359 3.24782 15.8359 4.16829V15.835C15.8359 16.7554 15.0897 17.5016 14.1693 17.5016H2.5026C1.58213 17.5016 0.835938 16.7554 0.835938 15.835V4.16829C0.835938 3.24782 1.58213 2.50163 2.5026 2.50163Z\"\r\n stroke=\"#009BF3\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n\r\n <span>\r\n You are scheduling the layout verification task for <b>{{\r\n scheduledDate === (today | date:'yyyy-MM-dd')\r\n ? 'Today'\r\n : (scheduledDate | date:'dd MMMM, yyyy')\r\n }}</b>\r\n </span>\r\n\r\n <svg class=\"ms-auto cursor-pointer\" (click)=\"showInfoBanner = false;\" width=\"18\" height=\"18\"\r\n viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M13.5 4.5L4.5 13.5M4.5 4.5L13.5 13.5\" stroke=\"#101828\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </div>\r\n }\r\n <div class=\"table-responsive\">\r\n <table class=\"w-100 table bottom-border text-nowrap\">\r\n <thead>\r\n <tr>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('wall')\">\r\n Wall/Floor\r\n <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'wall' ? '#009BF3' : '' }\"\r\n [ngClass]=\"sortOrder === 1 && sortedColumn === 'wall' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n aria-hidden=\"true\"></i>\r\n </th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('ufn')\">\r\n UFN\r\n <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'ufn' ? '#009BF3' : '' }\"\r\n [ngClass]=\"sortOrder === 1 && sortedColumn === 'ufn' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n aria-hidden=\"true\"></i>\r\n </th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('brand')\">\r\n Brand Category\r\n <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'brand' ? '#009BF3' : '' }\"\r\n [ngClass]=\"sortOrder === 1 && sortedColumn === 'brand' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n aria-hidden=\"true\"></i>\r\n </th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('type')\">\r\n Type\r\n <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'type' ? '#009BF3' : '' }\"\r\n [ngClass]=\"sortOrder === 1 && sortedColumn === 'type' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n aria-hidden=\"true\"></i>\r\n </th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('size')\">\r\n Size\r\n <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'size' ? '#009BF3' : '' }\"\r\n [ngClass]=\"sortOrder === 1 && sortedColumn === 'size' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n aria-hidden=\"true\"></i>\r\n </th>\r\n <th class=\"cursor-pointer\" (click)=\"onSort('partition')\">\r\n Partition\r\n <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'partition' ? '#009BF3' : '' }\"\r\n [ngClass]=\"sortOrder === 1 && sortedColumn === 'partition' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n aria-hidden=\"true\"></i>\r\n </th>\r\n <!-- <th>\r\n Display Per Partition\r\n <i class=\"fa ms-1 mt-1\"\r\n [ngStyle]=\"{ color: sortedColumn === 'displayPartition' ? '#009BF3' : '' }\"\r\n [ngClass]=\"sortOrder === 1 && sortedColumn === 'displayPartition' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n aria-hidden=\"true\"></i>\r\n </th> -->\r\n <th class=\"cursor-pointer\" (click)=\"onSort('standardCapacity')\">\r\n Standard Capacity\r\n <i class=\"fa ms-1 mt-1\"\r\n [ngStyle]=\"{ color: sortedColumn === 'standardCapacity' ? '#009BF3' : '' }\"\r\n [ngClass]=\"sortOrder === 1 && sortedColumn === 'standardCapacity' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n aria-hidden=\"true\"></i>\r\n </th>\r\n <!-- <th>\r\n Actual Capacity\r\n <i class=\"fa ms-1 mt-1\"\r\n [ngStyle]=\"{ color: sortedColumn === 'actualCapacity' ? '#009BF3' : '' }\"\r\n [ngClass]=\"sortOrder === 1 && sortedColumn === 'actualCapacity' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n aria-hidden=\"true\"></i>\r\n </th> -->\r\n <th *ngFor=\"let zone of zoneColumns\">\r\n {{zone}} Zone Allocation\r\n <i class=\"fa ms-1 mt-1\" aria-hidden=\"true\"></i>\r\n </th>\r\n </tr>\r\n </thead>\r\n\r\n <tbody>\r\n <tr *ngFor=\"let item of mbqItems\">\r\n <td>{{item?.wall}}</td>\r\n <td>{{item?.ufn}}</td>\r\n <td>{{item?.brand}}</td>\r\n <td>{{item?.type}}</td>\r\n <td>{{item?.size}}</td>\r\n <td>{{item?.partition}}</td>\r\n <!-- <td>{{item?.displayPartition}}</td> -->\r\n <td>{{item?.standardCapacity}}</td>\r\n <!-- <td>{{item?.actualCapacity}}</td> -->\r\n <td *ngFor=\"let zone of zoneColumns\">{{item?.zoneAllocations?.[zone]?.join(', ') || '-'}}</td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n\r\n <div class=\"modal-actions\">\r\n <button type=\"button\" class=\"btn btn-outline\" (click)=\"onCancel()\">Cancel</button>\r\n <button type=\"button\" class=\"btn btn-primary\" (click)=\"scheduleTask()\">\r\n Schedule Task\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [".modal-wrapper{padding:24px}.table-responsive{max-height:58vh}.info-banner{background:#f6fcff;margin-bottom:12px;border:1px solid #6bcaff;border-radius:4px;padding:12px;display:flex;align-items:center;gap:10px;font-weight:400;font-size:14px;line-height:20px;letter-spacing:0%;color:#1d2939}.modal-actions{display:flex;justify-content:end;gap:12px}::ng-deep .modal-content{border-radius:12px!important}.btn .spinner{height:22px;width:22px;animation:spin .9s linear infinite}.btn .spinner .path{stroke-width:6px;stroke:currentColor;stroke-linecap:round;stroke-dasharray:80;stroke-dashoffset:60}@keyframes spin{to{transform:rotate(360deg)}}.mbq-download-btn{min-width:38px}::ng-deep .schedule-task-modal .modal-dialog{max-width:700px;width:100%}\n"] }]
7097
- }], ctorParameters: () => [{ type: i1$1.NgbActiveModal }, { type: i2$3.StoreBuilderService }], propDecorators: { fixtures: [{
7096
+ }], ctorParameters: () => [{ type: i1$1.NgbActiveModal }, { type: StoreBuilderService }], propDecorators: { fixtures: [{
7098
7097
  type: Input
7099
7098
  }], storeName: [{
7100
7099
  type: Input
@@ -10703,13 +10702,13 @@ class ActionConfirmPopupComponent {
10703
10702
  onOk() {
10704
10703
  this.activeModal.close({ action: "ok", remark: this.remark });
10705
10704
  }
10706
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ActionConfirmPopupComponent, deps: [{ token: i1$1.NgbActiveModal }, { token: i2$4.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component });
10705
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ActionConfirmPopupComponent, deps: [{ token: i1$1.NgbActiveModal }, { token: i2$3.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component });
10707
10706
  static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ActionConfirmPopupComponent, selector: "lib-action-confirm-popup", inputs: { type: "type" }, ngImport: i0, template: "<div class=\"modal-wrapper\">\r\n <div class=\"d-flex gap-3 align-items-center mb-5\">\r\n <div *ngIf=\"safeIcon\" [innerHTML]=\"safeIcon\"></div>\r\n <h3 class=\"title\">{{ title }}</h3>\r\n </div>\r\n\r\n <p class=\"description\">{{ description }}</p>\r\n\r\n <div *ngIf=\"type != 'deleteVM'\" class=\"d-flex flex-column gap-2 mb-4\">\r\n <label for=\"remark\">Remarks</label>\r\n <textarea class=\"form-control\" id=\"remark\" [(ngModel)]=\"remark\" rows=\"3\"\r\n placeholder=\"Enter your remark here...\"></textarea>\r\n </div>\r\n\r\n <div class=\"modal-actions mt-5\">\r\n <button type=\"button\" class=\"btn btn-outline\" (click)=\"onCancel()\">Cancel</button>\r\n <button type=\"button\" class=\"btn btn-primary px-4\" (click)=\"onOk()\">\r\n {{btnText}}\r\n </button>\r\n </div>\r\n</div>", styles: [".modal-wrapper{padding:24px}.modal-wrapper .title{font-family:Inter;font-weight:600;font-size:18px;line-height:28px;color:#1d2939;margin:0}.modal-wrapper .description{font-family:Inter;font-weight:400;font-size:16px;line-height:24px;color:#1d2939;margin-bottom:18px}.modal-actions{display:flex;justify-content:end;gap:12px}::ng-deep .modal-content{border-radius:12px!important}\n"], dependencies: [{ kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1$2.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: i1$2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
10708
10707
  }
10709
10708
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ActionConfirmPopupComponent, decorators: [{
10710
10709
  type: Component,
10711
10710
  args: [{ selector: "lib-action-confirm-popup", template: "<div class=\"modal-wrapper\">\r\n <div class=\"d-flex gap-3 align-items-center mb-5\">\r\n <div *ngIf=\"safeIcon\" [innerHTML]=\"safeIcon\"></div>\r\n <h3 class=\"title\">{{ title }}</h3>\r\n </div>\r\n\r\n <p class=\"description\">{{ description }}</p>\r\n\r\n <div *ngIf=\"type != 'deleteVM'\" class=\"d-flex flex-column gap-2 mb-4\">\r\n <label for=\"remark\">Remarks</label>\r\n <textarea class=\"form-control\" id=\"remark\" [(ngModel)]=\"remark\" rows=\"3\"\r\n placeholder=\"Enter your remark here...\"></textarea>\r\n </div>\r\n\r\n <div class=\"modal-actions mt-5\">\r\n <button type=\"button\" class=\"btn btn-outline\" (click)=\"onCancel()\">Cancel</button>\r\n <button type=\"button\" class=\"btn btn-primary px-4\" (click)=\"onOk()\">\r\n {{btnText}}\r\n </button>\r\n </div>\r\n</div>", styles: [".modal-wrapper{padding:24px}.modal-wrapper .title{font-family:Inter;font-weight:600;font-size:18px;line-height:28px;color:#1d2939;margin:0}.modal-wrapper .description{font-family:Inter;font-weight:400;font-size:16px;line-height:24px;color:#1d2939;margin-bottom:18px}.modal-actions{display:flex;justify-content:end;gap:12px}::ng-deep .modal-content{border-radius:12px!important}\n"] }]
10712
- }], ctorParameters: () => [{ type: i1$1.NgbActiveModal }, { type: i2$4.DomSanitizer }], propDecorators: { type: [{
10711
+ }], ctorParameters: () => [{ type: i1$1.NgbActiveModal }, { type: i2$3.DomSanitizer }], propDecorators: { type: [{
10713
10712
  type: Input
10714
10713
  }] } });
10715
10714