tango-app-ui-store-builder 1.0.75 → 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.
- package/esm2022/lib/components/manage-plano/onboard-table/onboard-table.component.mjs +4 -2
- package/esm2022/lib/components/manage-plano/rollout-table/rollout-table.component.mjs +3 -3
- package/esm2022/lib/components/manage-store-plano/manage-store-plano.component.mjs +3 -3
- package/esm2022/lib/components/manage-store-plano/plano-rollout/plano-rollout.component.mjs +26 -8
- package/esm2022/lib/components/manage-store-plano/popups/schedule-task-popup/schedule-task-popup.component.mjs +64 -33
- package/esm2022/lib/components/manage-store-plano/template-basic-details/template-basic-details.component.mjs +3 -3
- package/esm2022/lib/components/manage-store-plano/template-vms/template-vms.component.mjs +17 -17
- package/esm2022/lib/components/onboard-store-plano/create-planogram/create-planogram.component.mjs +23 -4
- package/esm2022/lib/components/onboard-store-plano/onboard-store-plano.component.mjs +3 -6
- package/esm2022/lib/components/plano-tools/cad-render/cad-render.component.mjs +1538 -0
- package/esm2022/lib/components/plano-tools/plano-migrate/plano-migrate.component.mjs +13 -6
- package/esm2022/lib/components/plano-tools/tools-parent/tools-parent.component.mjs +3 -3
- package/esm2022/lib/services/store-builder.service.mjs +4 -1
- package/esm2022/lib/tango-store-builder-routing.module.mjs +6 -1
- package/esm2022/lib/tango-store-builder.module.mjs +4 -1
- package/fesm2022/tango-app-ui-store-builder.mjs +1850 -239
- package/fesm2022/tango-app-ui-store-builder.mjs.map +1 -1
- package/lib/components/manage-plano/onboard-table/onboard-table.component.d.ts +1 -1
- package/lib/components/manage-store-plano/popups/schedule-task-popup/schedule-task-popup.component.d.ts +4 -1
- package/lib/components/onboard-store-plano/create-planogram/create-planogram.component.d.ts +1 -0
- package/lib/components/onboard-store-plano/onboard-store-plano.component.d.ts +1 -2
- package/lib/components/plano-tools/cad-render/cad-render.component.d.ts +84 -0
- package/lib/services/store-builder.service.d.ts +1 -0
- package/lib/tango-store-builder.module.d.ts +46 -45
- package/package.json +1 -1
|
@@ -174,11 +174,13 @@ export class PlanoOnboardTableComponent {
|
|
|
174
174
|
const modelRef = this.ngbModal.open(BulkUploadPlanogramComponent);
|
|
175
175
|
}
|
|
176
176
|
onClickCreatePlanogram() {
|
|
177
|
-
|
|
177
|
+
let modelRef;
|
|
178
|
+
modelRef = this.ngbModal.open(CreatePlanogramComponent, {
|
|
178
179
|
size: "md",
|
|
179
180
|
windowClass: "create-planogram-modal",
|
|
180
181
|
centered: true,
|
|
181
182
|
backdrop: "static",
|
|
183
|
+
beforeDismiss: () => !modelRef.componentInstance?.isModalBusy,
|
|
182
184
|
});
|
|
183
185
|
modelRef.componentInstance.clientId = this.clientId;
|
|
184
186
|
modelRef.result.then((result) => {
|
|
@@ -436,4 +438,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
436
438
|
type: ViewChild,
|
|
437
439
|
args: ["planoFilterRef"]
|
|
438
440
|
}] } });
|
|
439
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"onboard-table.component.js","sourceRoot":"","sources":["../../../../../../../projects/tango-store-builder/src/lib/components/manage-plano/onboard-table/onboard-table.component.ts","../../../../../../../projects/tango-store-builder/src/lib/components/manage-plano/onboard-table/onboard-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, OnInit, ViewChild } from \"@angular/core\";\nimport { Router, ActivatedRoute } from \"@angular/router\";\r\nimport { NgbModal } from \"@ng-bootstrap/ng-bootstrap\";\r\nimport {\r\n  debounceTime,\r\n  distinctUntilChanged,\r\n  filter,\r\n  Subject,\r\n  Subscription,\r\n  takeUntil,\r\n} from \"rxjs\";\r\nimport { GlobalStateService, PageInfoService } from \"tango-app-ui-global\";\r\nimport { PlanoList } from \"../../../interfaces/planogram.interface\";\r\nimport { StoreBuilderService } from \"../../../services/store-builder.service\";\r\nimport { BulkUploadPlanogramComponent } from \"../popups/bulk-upload-planogram/bulk-upload-planogram.component\";\r\nimport {\r\n  getQueryParamNumber,\r\n  getQueryParamString,\r\n} from \"../../../functions/plano.function\";\r\nimport { CreatePlanogramComponent } from \"../../onboard-store-plano/create-planogram/create-planogram.component\";\nimport { PlanoFilterComponent } from \"../../planogram/plano-table/plano-filter/plano-filter.component\";\n\r\n@Component({\r\n  selector: \"lib-plano-onboard-table\",\r\n  templateUrl: \"./onboard-table.component.html\",\r\n  styleUrl: \"./onboard-table.component.scss\",\r\n})\r\nexport class PlanoOnboardTableComponent implements OnInit, OnDestroy {\n  @ViewChild(\"planoFilterRef\") planoFilterRef?: PlanoFilterComponent;\n\n  clientId: string;\n\r\n  cardInfo: any;\r\n  planogramsList: PlanoList[] = [];\r\n\r\n  selectedFilterTab: string = \"all\";\r\n\r\n  sortedColumn: string = \"\";\r\n  sortOrder: number = 1;\r\n\r\n  searchTerm: string = \"\";\r\n\r\n  limit: number = 10;\r\n  offset: number = 1;\r\n  totalItems: number = 0;\r\n  paginationSizes = [10, 20, 30];\r\n\r\n  filterObject = [\r\n    {\r\n      title: \"Status\",\r\n      type: \"multi\",\r\n      isOpened: false,\r\n      options: [\r\n        { name: \"Draft\", value: \"draft\", checked: false },\r\n        {\r\n          name: \"Allocation pending\",\r\n          value: \"allocationPending\",\r\n          checked: false,\r\n        },\r\n      ],\r\n    },\r\n  ];\r\n\r\n  appliedFilters: any = {\r\n    country: [],\r\n    city: [],\r\n    status: [],\r\n  };\r\n\r\n  isFilterApplied: boolean = false;\r\n\r\n  isPageLoading: boolean = true;\r\n  isButtonLoading: boolean = false;\r\n  isError: boolean = false;\r\n\r\n  private readonly destroy$ = new Subject<void>();\r\n  private planoSub?: Subscription;\r\n\r\n  constructor(\r\n    private ngbModal: NgbModal,\r\n    private router: Router,\r\n    private route: ActivatedRoute,\r\n    private storeBuilderService: StoreBuilderService,\r\n    private gs: GlobalStateService,\r\n    private pageInfo: PageInfoService,\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.setPageData();\r\n\r\n    this.gs.dataRangeValue\r\n      .pipe(\r\n        takeUntil(this.destroy$), // Subscription will be cancelled on component destroy.\r\n        debounceTime(200), // To avoid immediate frequent calls.\r\n        filter((data) => !!data), // Filtering null/undefined.\r\n        distinctUntilChanged(), // Emitting only different values. (Ignores same clientId).\r\n      )\r\n      .subscribe({\r\n        next: (data: any) => {\r\n          if (data) {\r\n            this.clientId = data.client;\r\n          } else {\r\n            let data = JSON.parse(\r\n              localStorage.getItem(\"header-filters\") as string,\r\n            );\r\n            this.clientId = data?.client;\r\n          }\r\n\r\n          this.route.queryParamMap\r\n            .pipe(takeUntil(this.destroy$))\r\n            .subscribe((params) => {\r\n              this.searchTerm = getQueryParamString({\r\n                params,\r\n                key: \"search\",\r\n                fallback: \"\",\r\n              });\r\n              this.isFilterApplied = this.searchTerm ? true : false;\r\n\r\n              this.selectedFilterTab = getQueryParamString({\r\n                params,\r\n                key: \"tab\",\r\n                fallback: \"all\",\r\n              });\r\n\r\n              this.appliedFilters.status = [this.selectedFilterTab];\r\n\r\n              this.limit = getQueryParamNumber({\r\n                params,\r\n                key: \"limit\",\r\n                fallback: 10,\r\n                min: 1,\r\n                max: 30,\r\n              });\r\n\r\n              this.offset = getQueryParamNumber({\r\n                params,\r\n                key: \"offset\",\r\n                fallback: 1,\r\n                min: 1,\r\n              });\r\n\r\n              this.getPlanoTableList();\r\n            });\r\n        },\r\n      });\r\n  }\r\n\r\n  setPageData() {\r\n    this.pageInfo.setTitle(\"Manage Planogram\");\r\n    this.pageInfo.setBreadcrumbs([\r\n      {\r\n        title: \"Planogram\",\r\n        path: \"/manage/planogram/manage-planograms\",\r\n        isActive: false,\r\n        isSeparator: false,\r\n      },\r\n      {\r\n        title: \"\",\r\n        path: \"\",\r\n        isActive: false,\r\n        isSeparator: true,\r\n      },\r\n    ]);\r\n  }\r\n\r\n  getPlanoTableList() {\r\n    this.planoSub?.unsubscribe(); // Cancel previous request\r\n\r\n    this.isPageLoading = true;\r\n    this.planogramsList = [];\r\n    let payload = {\r\n      clientId: this.clientId,\r\n      limit: this.limit,\r\n      offset: this.offset,\r\n      sortColumnName: this.sortedColumn,\r\n      sortBy: this.sortOrder,\r\n      filter: this.appliedFilters,\r\n      searchValue: this.searchTerm,\r\n      // export: false,\r\n      // emptyDownload: false\r\n    };\r\n\r\n    this.planoSub = this.storeBuilderService\r\n      .getOnboardPlanoList(payload)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if (res && res?.code == 200) {\r\n            this.totalItems = res?.data?.count;\r\n            this.planogramsList = res?.data?.data ?? [];\r\n            this.cardInfo = res?.data?.cardInfo?.[0] || [];\r\n            if (this.totalItems < 10) {\r\n              this.paginationSizes = [this.totalItems];\r\n            } else {\r\n              this.paginationSizes = [10, 20, 30];\r\n            }\r\n          }\r\n          this.isPageLoading = false;\r\n        },\r\n        error: (err) => {\r\n          this.isPageLoading = false;\r\n        },\r\n      });\r\n\r\n    this.totalItems = this.planogramsList.length;\r\n  }\r\n\r\n  openBulkUploadModal() {\r\n    const modelRef = this.ngbModal.open(BulkUploadPlanogramComponent);\r\n  }\r\n\r\n  onClickCreatePlanogram() {\r\n    const modelRef = this.ngbModal.open(CreatePlanogramComponent, {\r\n      size: \"md\",\r\n      windowClass: \"create-planogram-modal\",\r\n      centered: true,\r\n      backdrop: \"static\",\r\n    });\r\n\r\n    modelRef.componentInstance.clientId = this.clientId;\r\n    modelRef.result.then((result) => {\r\n      if (result) {\r\n        this.router.navigate([\"/manage/planogram/onboard-planogram\"], {\r\n          queryParams: { planoId: result?.planoId, floorId: result?.floorId },\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  onSearch() {\r\n    this.sortedColumn = \"\";\r\n    this.sortOrder = 1;\r\n    this.offset = 1;\r\n    this.limit = 10;\r\n\r\n    this.isFilterApplied = this.searchTerm ? true : false;\r\n    this.updateQueryParams();\r\n  }\r\n\r\n  onSortTable(column: string) {\r\n    if (this.sortedColumn === column) {\r\n      this.sortOrder = this.sortOrder === 1 ? -1 : 1;\r\n    } else {\r\n      this.sortedColumn = column;\r\n      this.sortOrder = 1;\r\n    }\r\n    this.offset = 1;\r\n    this.limit = 10;\r\n    this.getPlanoTableList();\r\n  }\r\n\r\n  filterTable(data: string) {\n    if (this.selectedFilterTab !== data) {\n      this.planoFilterRef?.onResetFilter(false);\n      this.selectedFilterTab = data;\n      this.appliedFilters = {\n        country: [],\n        city: [],\n        status: [this.selectedFilterTab],\n      };\n      this.isFilterApplied = false;\n      this.offset = 1;\n      this.limit = 10;\n      this.searchTerm = \"\";\n      this.updateQueryParams();\n    }\n  }\r\n\r\n  applyFilters(event: any) {\r\n    event.forEach((ele: any) => {\r\n      let key = ele.title.toLowerCase();\r\n      if (key === \"store category\") {\r\n        this.appliedFilters[\"planoStrategy\"] = ele.selected;\r\n      } else {\r\n        this.appliedFilters[ele.title.toLowerCase()] = ele.selected;\r\n      }\r\n    });\r\n\r\n    this.offset = 1;\r\n    this.getPlanoTableList();\r\n  }\r\n\r\n  paginationSize(): number {\r\n    return this.totalItems < 10 ? this.totalItems : this.limit;\r\n  }\r\n\r\n  onPageChange(pageOffset: number) {\r\n    this.offset = Number(pageOffset);\r\n    this.updateQueryParams();\r\n  }\r\n\r\n  onPageSizeChange(pageSize: number) {\r\n    this.offset = 1;\r\n    this.limit = Number(pageSize);\r\n    this.updateQueryParams();\r\n  }\r\n\r\n  planoFloorDetails(data: any) {\r\n    if (data.layoutDetails.length > 1) {\r\n      let completeCount = data?.taskDetails?.completeLayout || 0;\r\n      return completeCount + \"/\" + data.layoutDetails.length;\r\n    } else {\r\n      return 1;\r\n    }\r\n  }\r\n\r\n  // getTaskStatus(data: any, type: string) {\r\n  //   const statusMap: any = {\r\n  //     layout: data.taskDetails?.layoutStatus,\r\n  //     fixture: data.taskDetails?.fixtureStatus,\r\n  //     vm: data.taskDetails?.fixtureStatus,\r\n  //   };\r\n  //   if (type == \"vm\") {\r\n  //     type = \"fixture\";\r\n  //   }\r\n  //   const status = statusMap[type];\r\n\r\n  //   const taskDetails = data?.planoTask?.[0]?.taskStatus?.find(\r\n  //     (ele: any) => ele.type == type,\r\n  //   );\r\n\r\n  //   if (type == \"fixture\") {\r\n  //     let taskInfo = data?.planoTask?.[0]?.taskStatus?.filter(\r\n  //       (ele: any) => ele.status && ele.type == \"fixture\",\r\n  //     );\r\n  //     if (\r\n  //       status === \"pending\" &&\r\n  //       taskInfo?.some((task: any) => task.status == \"submit\")\r\n  //     )\r\n  //       return \"reviewPending\";\r\n  //     if (taskInfo?.length != data.layoutCount) {\r\n  //       return \"yetToAssign\";\r\n  //     }\r\n  //     if (taskInfo.includes(\"open\") || taskInfo.includes(\"inprogress\")) {\r\n  //       return \"taskAssigned\";\r\n  //     }\r\n  //   }\r\n\r\n  //   if (\r\n  //     !taskDetails ||\r\n  //     (taskDetails.status == \"submit\" && status === \"disagree\")\r\n  //   )\r\n  //     return \"yetToAssign\";\r\n\r\n  //   if (taskDetails.status !== \"submit\") return \"taskAssigned\";\r\n\r\n  //   if (status === \"complete\") return \"completed\";\r\n  // }\r\n\r\n  // getTaskTooltip(data: any, type: string) {\r\n  //   const statusMap: any = {\r\n  //     layout: data.taskDetails?.layoutStatus,\r\n  //     fixture: data.taskDetails?.fixtureStatus,\r\n  //     vm: data.taskDetails?.fixtureStatus,\r\n  //   };\r\n  //   if (type == \"vm\") {\r\n  //     type = \"fixture\";\r\n  //   }\r\n  //   const taskDetails = data?.planoTask?.[0]?.taskStatus?.find(\r\n  //     (ele: any) => ele.type == type,\r\n  //   );\r\n\r\n  //   const status = statusMap[type];\r\n\r\n  //   if (type == \"fixture\") {\r\n  //     let taskInfo = data?.planoTask?.[0]?.taskStatus?.filter(\r\n  //       (ele: any) => ele.status && ele.type == \"fixture\",\r\n  //     );\r\n  //     if (\r\n  //       status === \"pending\" &&\r\n  //       taskInfo?.some((task: any) => task.status == \"submit\")\r\n  //     )\r\n  //       return \"Review Pending\";\r\n  //     if (taskInfo?.length != data.layoutCount) {\r\n  //       return \"Yet to Assign\";\r\n  //     }\r\n  //     if (taskInfo.includes(\"open\") || taskInfo.includes(\"inprogress\")) {\r\n  //       return \"Task Assigned\";\r\n  //     }\r\n  //   }\r\n\r\n  //   if (\r\n  //     !taskDetails ||\r\n  //     (taskDetails.status == \"submit\" && status === \"disagree\")\r\n  //   )\r\n  //     return \"Yet to Assign\";\r\n\r\n  //   if (taskDetails.status !== \"submit\") return \"Task Assigned\";\r\n\r\n  //   if (status === \"complete\") return \"Completed\";\r\n  // }\r\n\r\n  getProgressValue(plano: any) {\r\n    const status = this.getStatusBadge(plano);\r\n\r\n    if (status === \"allocationPending\") {\r\n      return 25;\r\n    } else {\r\n      return 0;\r\n    }\r\n  }\r\n\r\n  getStatus(plano: any) {\r\n    const status = this.getStatusBadge(plano);\r\n\r\n    if (status === \"allocationPending\") {\r\n      return \"Allocation pending\";\r\n    } else {\r\n      return \"Draft\";\r\n    }\r\n  }\r\n\r\n  getStatusBadge(plano: any) {\r\n    const floor = this.getPriorityFloor(plano);\r\n    return floor?.status;\r\n  }\r\n\r\n  getPriorityFloor(plano: any) {\r\n    let priorityFloor = plano?.layoutDetails?.find(\r\n      (f: any) => f.status === \"allocationPending\",\r\n    );\r\n\r\n    if (!priorityFloor) {\r\n      priorityFloor = plano?.layoutDetails[0];\r\n    }\r\n\r\n    return priorityFloor;\r\n  }\r\n\r\n  getSubmit(data: any) {\r\n    const statusMap: any = {\r\n      layout: data.taskDetails?.layoutStatus,\r\n      fixture: data.taskDetails?.fixtureStatus,\r\n      vm: data.taskDetails?.vmStatus,\r\n    };\r\n    let submitTask = data?.planoTask?.[0]?.taskStatus.find(\r\n      (ele: any) => ele.status == \"submit\" && statusMap[ele.type] == \"pending\",\r\n    );\r\n    if (submitTask) {\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  updateQueryParams() {\r\n    this.router.navigate([], {\r\n      relativeTo: this.route,\r\n      queryParams: {\r\n        tab: this.selectedFilterTab,\r\n        search: this.searchTerm,\r\n        limit: this.limit,\r\n        offset: this.offset,\r\n      },\r\n      queryParamsHandling: \"merge\",\r\n      replaceUrl: true,\r\n    });\r\n  }\r\n\r\n  redirectStore(storeId: any) {\r\n    let data: any = JSON.parse(localStorage.getItem(\"header-filters\") || \"\");\r\n    data.store = storeId;\r\n    localStorage.setItem(\"header-filters\", JSON.stringify(data));\r\n    this.router.navigateByUrl(`manage/stores/plano?storeId=${storeId}`);\r\n  }\r\n\r\n  onExport() {\r\n    this.isButtonLoading = true;\r\n    let payload = {\r\n      clientId: this.clientId,\r\n      limit: this.totalItems,\r\n      offset: 1,\r\n      sortColumnName: this.sortedColumn,\r\n      sortBy: this.sortOrder,\r\n      filter: this.appliedFilters,\r\n      searchValue: this.searchTerm,\r\n      export: true,\r\n    };\r\n\r\n    this.storeBuilderService\r\n      .getOnboardPlanoListExport(payload)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if (res) {\r\n            this.storeBuilderService.saveAsExcelFile(\r\n              res,\r\n              \"Onboarding Plano List\",\r\n            );\r\n          }\r\n\r\n          this.isButtonLoading = false;\r\n        },\r\n        error: (err) => {\r\n          console.log(err, \"err\");\r\n          this.isButtonLoading = false;\r\n        },\r\n      });\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n    this.planoSub?.unsubscribe();\r\n  }\r\n}\r\n","<div class=\"row mx-0 my-5 gap-2\">\r\n  <div class=\"col filter-tab\" [ngClass]=\"{ selected: selectedFilterTab === 'all' }\" (click)=\"filterTable('all')\">\r\n    <h3>{{ cardInfo?.allStores ?? 0 }}</h3>\r\n    <p>All stores</p>\r\n  </div>\r\n  <div class=\"col filter-tab\" [ngClass]=\"{ selected: selectedFilterTab === 'allocationPending' }\"\r\n    (click)=\"filterTable('allocationPending')\">\r\n    <h3>{{ cardInfo?.allocationPendingStores ?? 0 }}</h3>\r\n    <p>Allocation pending</p>\r\n  </div>\r\n  <div class=\"col filter-tab\" [ngClass]=\"{ selected: selectedFilterTab === 'draft' }\" (click)=\"filterTable('draft')\">\r\n    <h3>{{ cardInfo?.draftStores ?? 0 }}</h3>\r\n    <p>Draft</p>\r\n  </div>\r\n</div>\r\n\r\n<div class=\"content-wrapper\">\r\n  <div [class.restrict-interaction]=\"isButtonLoading\">\r\n    <!-- Manage Planogram view header -->\r\n    <div class=\"d-flex justify-content-between align-items-center mb-5\">\r\n      <div>\r\n        <h4>Onboard stores</h4>\r\n        <span>{{ totalItems }} - Total stores</span>\r\n      </div>\r\n\r\n      <div class=\"d-flex align-items-center gap-3\">\r\n        <div style=\"position: relative\">\r\n          <input type=\"text\" [(ngModel)]=\"searchTerm\" (change)=\"onSearch()\"\r\n            style=\"padding-left: 3rem; padding-right: 3rem\" class=\"form-control\" name=\"search\" autocomplete=\"off\"\r\n            placeholder=\"Search\" />\r\n\r\n          <span class=\"search-icon\">\r\n            <svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n              <circle cx=\"8\" cy=\"8\" r=\"6\" stroke=\"currentColor\" stroke-width=\"2\" />\r\n              <line x1=\"13\" y1=\"13\" x2=\"16\" y2=\"16\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" />\r\n            </svg>\r\n          </span>\r\n\r\n          <button *ngIf=\"searchTerm\" type=\"button\" aria-label=\"Clear\" (click)=\"searchTerm = ''; onSearch()\"\r\n            class=\"clear-search\">\r\n            <svg width=\"64px\" height=\"64px\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n              <g id=\"SVGRepo_bgCarrier\" stroke-width=\"0\"></g>\r\n              <g id=\"SVGRepo_tracerCarrier\" stroke-linecap=\"round\" stroke-linejoin=\"round\"></g>\r\n              <g id=\"SVGRepo_iconCarrier\">\r\n                <path d=\"M9 9L15 15\" stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\r\n                </path>\r\n                <path d=\"M15 9L9 15\" stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\r\n                </path>\r\n                <circle cx=\"12\" cy=\"12\" r=\"9\" stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                  stroke-linejoin=\"round\"></circle>\r\n              </g>\r\n            </svg>\r\n          </button>\r\n        </div>\r\n\r\n        <!-- <button type=\"button\" (click)=\"openBulkUploadModal()\" class=\"btn btn-outline text-nowrap\">\r\n          <svg class=\"me-2\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n            <path\r\n              d=\"M17.5 12.5V15.8333C17.5 16.2754 17.3244 16.6993 17.0118 17.0118C16.6993 17.3244 16.2754 17.5 15.8333 17.5H4.16667C3.72464 17.5 3.30072 17.3244 2.98816 17.0118C2.67559 16.6993 2.5 16.2754 2.5 15.8333V12.5M14.1667 6.66667L10 2.5M10 2.5L5.83333 6.66667M10 2.5V12.5\"\r\n              stroke=\"currentColor\"\r\n              stroke-width=\"1.67\"\r\n              stroke-linecap=\"round\"\r\n              stroke-linejoin=\"round\"\r\n            />\r\n          </svg>\r\n          Bulk Upload\r\n        </button> -->\r\n\r\n        <!-- <button type=\"button\" class=\"btn btn-outline d-line-flex align-items-center text-nowrap\">\r\n          <svg width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n            <path\r\n              d=\"M5 10H15M2.5 5H17.5M7.5 15H12.5\"\r\n              stroke=\"#344054\"\r\n              stroke-width=\"2\"\r\n              stroke-linecap=\"round\"\r\n              stroke-linejoin=\"round\"\r\n            />\r\n          </svg>\r\n          Filter\r\n        </button> -->\r\n\r\n        @if(selectedFilterTab === 'all'){\n          <plano-filter #planoFilterRef [clientId]=\"clientId\" [data]=\"filterObject\" (applyFilters)=\"applyFilters($event)\"\n          (resetFilters)=\"applyFilters($event)\"\n          [config]=\"{ 'Merchandise compliance': false, 'Store category': false }\"></plano-filter>\n        }\n\r\n        <button type=\"button\" (click)=\"onExport()\" class=\"btn-outline btn align-items-end text-nowrap invheader\"\r\n          [disabled]=\"!planogramsList.length\">\r\n\r\n          <svg *ngIf=\"!isButtonLoading\" xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\"\r\n            fill=\"none\">\r\n            <path\r\n              d=\"M17.5 12.5V15.8333C17.5 16.2754 17.3244 16.6993 17.0118 17.0118C16.6993 17.3244 16.2754 17.5 15.8333 17.5H4.16667C3.72464 17.5 3.30072 17.3244 2.98816 17.0118C2.67559 16.6993 2.5 16.2754 2.5 15.8333V12.5M14.1667 6.66667L10 2.5M10 2.5L5.83333 6.66667M10 2.5V12.5\"\r\n              stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\"></path>\r\n          </svg>\r\n\r\n          <svg *ngIf=\"isButtonLoading\" 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          <span class=\"ms-2\"> Export</span>\r\n\r\n        </button>\r\n\r\n        <button type=\"button\" (click)=\"onClickCreatePlanogram()\"\r\n          class=\"btn btn-primary d-inline-flex align-items-center\">\r\n          <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n            <path d=\"M10.0001 4.16663V15.8333M4.16675 9.99996H15.8334\" stroke=\"white\" stroke-width=\"1.67\"\r\n              stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n          </svg>\r\n          <span class=\"ms-2 text-white\">Create </span>\r\n        </button>\r\n      </div>\r\n    </div>\r\n\r\n    <div *ngIf=\"isPageLoading\">\r\n      <div class=\"row loader d-flex justify-content-center align-items-center\">\r\n        <div class=\"shimmer\">\r\n          <div class=\"wrapper\">\r\n            <div class=\"stroke animate title\"></div>\r\n            <div class=\"stroke animate link\"></div>\r\n            <div class=\"stroke animate description\"></div>\r\n          </div>\r\n        </div>\r\n        <div class=\"shimmer\">\r\n          <div class=\"wrapper\">\r\n            <div class=\"stroke animate title\"></div>\r\n            <div class=\"stroke animate link\"></div>\r\n            <div class=\"stroke animate description\"></div>\r\n          </div>\r\n        </div>\r\n        <div class=\"shimmer\">\r\n          <div class=\"wrapper\">\r\n            <div class=\"stroke animate title\"></div>\r\n            <div class=\"stroke animate link\"></div>\r\n            <div class=\"stroke animate description\"></div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div class=\"card-body d-flex justify-content-center align-items-center flex-column\"\r\n      *ngIf=\"!isPageLoading && planogramsList.length === 0\">\r\n      <img class=\"img-src\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\" />\r\n      <div class=\"nodatamaintext mt-3\">No data found</div>\r\n      <div class=\"nodatasubtext\">There is no result for onboard planogram table</div>\r\n    </div>\r\n\r\n    <!-- Onboard Planogram list view -->\r\n    <section id=\"list-view\" *ngIf=\"!isPageLoading && planogramsList.length !== 0\">\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>\r\n                <span (click)=\"onSortTable('storeName')\" class=\"cursor-pointer\">\r\n                  Store Name\r\n                  <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'storeName' ? '#009BF3' : '' }\"\r\n                    [ngClass]=\"sortOrder === 1 && sortedColumn === 'storeName' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                    aria-hidden=\"true\"></i>\r\n                </span>\r\n              </th>\r\n              <th>\r\n                <span (click)=\"onSortTable('layoutName')\" class=\"cursor-pointer\">\r\n                  Plano Name\r\n                  <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'layoutName' ? '#009BF3' : '' }\"\r\n                    [ngClass]=\"sortOrder === 1 && sortedColumn === 'layoutName' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                    aria-hidden=\"true\"></i>\r\n                </span>\r\n              </th>\r\n              <th>\r\n                Country\r\n              </th>\r\n              <th>\r\n                City\r\n              </th>\r\n              <th>\r\n                <span class=\"cursor-pointer d-flex align-items-center\">\r\n                  Completion %\r\n                  <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\"\r\n                    ngbTooltip=\"% of overall planogram completion\" class=\"ms-2\">\r\n                    <g clip-path=\"url(#clip0_844_17538)\">\r\n                      <path\r\n                        d=\"M8.00065 10.6663V7.99967M8.00065 5.33301H8.00732M14.6673 7.99967C14.6673 11.6816 11.6826 14.6663 8.00065 14.6663C4.31875 14.6663 1.33398 11.6816 1.33398 7.99967C1.33398 4.31778 4.31875 1.33301 8.00065 1.33301C11.6826 1.33301 14.6673 4.31778 14.6673 7.99967Z\"\r\n                        stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                    </g>\r\n                    <defs>\r\n                      <clipPath id=\"clip0_844_17538\">\r\n                        <rect width=\"16\" height=\"16\" fill=\"white\" />\r\n                      </clipPath>\r\n                    </defs>\r\n                  </svg>\r\n                </span>\r\n              </th>\r\n              <th>\r\n                <span (click)=\"onSortTable('layoutCount')\" class=\"cursor-pointer\">\r\n                  Layout\r\n                  <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'layoutCount' ? '#009BF3' : '' }\"\r\n                    [ngClass]=\"sortOrder === 1 && sortedColumn === 'layoutCount' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                    aria-hidden=\"true\"></i>\r\n                </span>\r\n              </th>\r\n              <th class=\"text-center\">\r\n                <span (click)=\"onSortTable('fixtureCount')\" class=\"cursor-pointer\">\r\n                  #Fixtures\r\n                  <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'fixtureCount' ? '#009BF3' : '' }\"\r\n                    [ngClass]=\"sortOrder === 1 && sortedColumn === 'fixtureCount' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                    aria-hidden=\"true\"></i>\r\n                </span>\r\n              </th>\r\n              <th class=\"text-center\">\r\n                <ng-template #tooltip>\r\n                  <div class=\"w-100\">\r\n                    <h6>Total store capacity</h6>\r\n                    <span> Combining product capacity of all fixtures </span>\r\n                  </div>\r\n                </ng-template>\r\n                <span (click)=\"onSortTable('fixtureCapacity')\" class=\"cursor-pointer d-flex align-items-center\">\r\n                  Capacity\r\n                  <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'fixtureCapacity' ? '#009BF3' : '' }\"\r\n                    [ngClass]=\"sortOrder === 1 && sortedColumn === 'fixtureCapacity' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                    aria-hidden=\"true\"></i>\r\n                  <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\"\r\n                    [ngbTooltip]=\"tooltip\" class=\"ms-2\">\r\n                    <g clip-path=\"url(#clip0_844_17538)\">\r\n                      <path\r\n                        d=\"M8.00065 10.6663V7.99967M8.00065 5.33301H8.00732M14.6673 7.99967C14.6673 11.6816 11.6826 14.6663 8.00065 14.6663C4.31875 14.6663 1.33398 11.6816 1.33398 7.99967C1.33398 4.31778 4.31875 1.33301 8.00065 1.33301C11.6826 1.33301 14.6673 4.31778 14.6673 7.99967Z\"\r\n                        stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                    </g>\r\n                    <defs>\r\n                      <clipPath id=\"clip0_844_17538\">\r\n                        <rect width=\"16\" height=\"16\" fill=\"white\" />\r\n                      </clipPath>\r\n                    </defs>\r\n                  </svg>\r\n                </span>\r\n              </th>\r\n              <th class=\"text-center\">\r\n                <span (click)=\"onSortTable('lastUpdate')\" class=\"cursor-pointer\">\r\n                  Last update\r\n                  <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'lastUpdate' ? '#009BF3' : '' }\"\r\n                    [ngClass]=\"sortOrder === 1 && sortedColumn === 'lastUpdate' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                    aria-hidden=\"true\"></i>\r\n                </span>\r\n              </th>\r\n              <th>\r\n                Status\r\n              </th>\r\n            </tr>\r\n          </thead>\r\n          <tbody>\r\n            <tr *ngFor=\"let plano of planogramsList\">\r\n              <td>\r\n                <div class=\"d-flex align-items-center\">\r\n                  <a (click)=\"redirectStore(plano.storeId)\" class=\"cursor-pointer text-decoration-underline\">\r\n                    {{ plano.storeName }}</a>\r\n                </div>\r\n              </td>\r\n              <td>\r\n                <a [routerLink]=\"['/manage/planogram/onboard-planogram']\"\r\n                  [queryParams]=\"{ planoId: plano._id, floorId: getPriorityFloor(plano)?.id }\"\r\n                  class=\"text-decoration-underline\">\r\n                  {{ plano.layoutName }}\r\n                </a>\r\n              </td>\r\n              <td>\r\n                {{plano?.country}}\r\n              </td>\r\n              <td>\r\n                {{plano?.city}}\r\n              </td>\r\n              <td>\r\n                <div class=\"row align-items-center\">\r\n                  <div class=\"col-9\">\r\n                    <div class=\"progress\" style=\"height: 4px\">\r\n                      <div class=\"progress-bar\" [ngClass]=\"\r\n                          [25, 50].includes(getProgressValue(plano))\r\n                            ? 'bg-warning'\r\n                            : 'bg-success'\r\n                        \" role=\"progressbar\"\r\n                        [style]=\"  (plano) ? 'width: ' + getProgressValue(plano) + '%' : 'width:25%'\"\r\n                        [attr.aria-valuenow]=\"getProgressValue(plano)\" aria-valuemin=\"0\" aria-valuemax=\"100\"></div>\r\n                    </div>\r\n                  </div>\r\n                  <div class=\"col-3\">{{ getProgressValue(plano) }}%</div>\r\n                </div>\r\n              </td>\r\n              <td>\r\n                <div class=\"d-flex align-items-center justify-content-center gap-2\">\r\n                  <span>\r\n                    @if(plano?.layoutCount === 1){\r\n                      1\r\n                    }@else{\r\n                      {{getPriorityFloor(plano)?.floorNumber??0}}/{{plano?.layoutCount??0}}\r\n                    }\r\n                  </span>\r\n\r\n                  @if(getStatusBadge(plano) === 'allocationPending'){\r\n                    <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                      <rect width=\"14\" height=\"14\" rx=\"7\" fill=\"#D1FADF\" />\r\n                      <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                        d=\"M9.97284 4.31097L5.79617 8.3418L4.68784 7.15763C4.48367 6.96513 4.16284 6.95347 3.9295 7.1168C3.702 7.28597 3.63784 7.58347 3.77784 7.82263L5.09034 9.95763C5.21867 10.156 5.44034 10.2785 5.69117 10.2785C5.93034 10.2785 6.15784 10.156 6.28617 9.95763C6.49617 9.68347 10.5037 4.90597 10.5037 4.90597C11.0287 4.3693 10.3928 3.8968 9.97284 4.30513V4.31097Z\"\r\n                        fill=\"#12B76A\" />\r\n                    </svg>\r\n\r\n                  }@else{\r\n                    <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                      <rect width=\"14\" height=\"14\" rx=\"7\" fill=\"#F2F4F7\" />\r\n                      <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                        d=\"M9.97284 4.31097L5.79617 8.3418L4.68784 7.15763C4.48367 6.96513 4.16284 6.95347 3.9295 7.1168C3.702 7.28597 3.63784 7.58347 3.77784 7.82263L5.09034 9.95763C5.21867 10.156 5.44034 10.2785 5.69117 10.2785C5.93034 10.2785 6.15784 10.156 6.28617 9.95763C6.49617 9.68347 10.5037 4.90597 10.5037 4.90597C11.0287 4.3693 10.3928 3.8968 9.97284 4.30513V4.31097Z\"\r\n                        fill=\"#667085\" />\r\n                    </svg>\r\n                  }\r\n\r\n                </div>\r\n              </td>\r\n              <td>\r\n                <div class=\"d-flex align-items-center justify-content-center gap-2\">\r\n                  <span>\r\n                    {{ plano?.fixtureCount ?? 0 }}\r\n                    @if(getStatusBadge(plano) === 'allocationPending'){\r\n                      <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                        <rect width=\"14\" height=\"14\" rx=\"7\" fill=\"#FFFAEB\" />\r\n                        <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                          d=\"M9.97284 4.31097L5.79617 8.3418L4.68784 7.15763C4.48367 6.96513 4.16284 6.95347 3.9295 7.1168C3.702 7.28597 3.63784 7.58347 3.77784 7.82263L5.09034 9.95763C5.21867 10.156 5.44034 10.2785 5.69117 10.2785C5.93034 10.2785 6.15784 10.156 6.28617 9.95763C6.49617 9.68347 10.5037 4.90597 10.5037 4.90597C11.0287 4.3693 10.3928 3.8968 9.97284 4.30513V4.31097Z\"\r\n                          fill=\"#B54708\" />\r\n                      </svg>\r\n\r\n\r\n                    }@else{\r\n                      <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                        <rect width=\"14\" height=\"14\" rx=\"7\" fill=\"#F2F4F7\" />\r\n                        <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                          d=\"M9.97284 4.31097L5.79617 8.3418L4.68784 7.15763C4.48367 6.96513 4.16284 6.95347 3.9295 7.1168C3.702 7.28597 3.63784 7.58347 3.77784 7.82263L5.09034 9.95763C5.21867 10.156 5.44034 10.2785 5.69117 10.2785C5.93034 10.2785 6.15784 10.156 6.28617 9.95763C6.49617 9.68347 10.5037 4.90597 10.5037 4.90597C11.0287 4.3693 10.3928 3.8968 9.97284 4.30513V4.31097Z\"\r\n                          fill=\"#667085\" />\r\n                      </svg>\r\n                    }\r\n                  </span>\r\n                </div>\r\n              </td>\r\n              <td>\r\n                <div class=\"d-flex align-items-center justify-content-center gap-2\">\r\n                  <span>\r\n                    {{ plano?.fixtureCapacity ?? 0 }}\r\n                  </span>\r\n                </div>\r\n              </td>\r\n              <td class=\"text-center\">\r\n                <span [ngbTooltip]=\"plano?.lastUpdate | date : 'medium'\">\r\n                  {{ plano?.lastUpdate | date }}\r\n                </span>\r\n              </td>\r\n              <td>\r\n                <div class=\"badge\" [ngClass]=\"getStatusBadge(plano)\">\r\n                  {{ getStatus(plano) }}\r\n                </div>\r\n              </td>\r\n            </tr>\r\n          </tbody>\r\n        </table>\r\n      </div>\r\n    </section>\r\n\r\n    <!-- Pagination -->\r\n    <lib-pagination [itemsPerPage]=\"limit\" [currentPage]=\"offset\" [totalItems]=\"totalItems\"\r\n      [paginationSizes]=\"paginationSizes\" [pageSize]=\"paginationSize()\" (pageChange)=\"onPageChange($event)\"\r\n      (pageSizeChange)=\"onPageSizeChange($event)\" *ngIf=\"!isPageLoading && planogramsList.length !== 0\">\r\n    </lib-pagination>\r\n  </div>\r\n</div>\n"]}
|
|
441
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"onboard-table.component.js","sourceRoot":"","sources":["../../../../../../../projects/tango-store-builder/src/lib/components/manage-plano/onboard-table/onboard-table.component.ts","../../../../../../../projects/tango-store-builder/src/lib/components/manage-plano/onboard-table/onboard-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, OnInit, ViewChild } from \"@angular/core\";\r\nimport { Router, ActivatedRoute } from \"@angular/router\";\r\nimport { NgbModal } from \"@ng-bootstrap/ng-bootstrap\";\r\nimport {\r\n  debounceTime,\r\n  distinctUntilChanged,\r\n  filter,\r\n  Subject,\r\n  Subscription,\r\n  takeUntil,\r\n} from \"rxjs\";\r\nimport { GlobalStateService, PageInfoService } from \"tango-app-ui-global\";\r\nimport { PlanoList } from \"../../../interfaces/planogram.interface\";\r\nimport { StoreBuilderService } from \"../../../services/store-builder.service\";\r\nimport { BulkUploadPlanogramComponent } from \"../popups/bulk-upload-planogram/bulk-upload-planogram.component\";\r\nimport {\r\n  getQueryParamNumber,\r\n  getQueryParamString,\r\n} from \"../../../functions/plano.function\";\r\nimport { CreatePlanogramComponent } from \"../../onboard-store-plano/create-planogram/create-planogram.component\";\r\nimport { PlanoFilterComponent } from \"../../planogram/plano-table/plano-filter/plano-filter.component\";\r\n\r\n@Component({\r\n  selector: \"lib-plano-onboard-table\",\r\n  templateUrl: \"./onboard-table.component.html\",\r\n  styleUrl: \"./onboard-table.component.scss\",\r\n})\r\nexport class PlanoOnboardTableComponent implements OnInit, OnDestroy {\r\n  @ViewChild(\"planoFilterRef\") planoFilterRef?: PlanoFilterComponent;\r\n\r\n  clientId: string;\r\n\r\n  cardInfo: any;\r\n  planogramsList: PlanoList[] = [];\r\n\r\n  selectedFilterTab: string = \"all\";\r\n\r\n  sortedColumn: string = \"\";\r\n  sortOrder: number = 1;\r\n\r\n  searchTerm: string = \"\";\r\n\r\n  limit: number = 10;\r\n  offset: number = 1;\r\n  totalItems: number = 0;\r\n  paginationSizes = [10, 20, 30];\r\n\r\n  filterObject = [\r\n    {\r\n      title: \"Status\",\r\n      type: \"multi\",\r\n      isOpened: false,\r\n      options: [\r\n        { name: \"Draft\", value: \"draft\", checked: false },\r\n        {\r\n          name: \"Allocation pending\",\r\n          value: \"allocationPending\",\r\n          checked: false,\r\n        },\r\n      ],\r\n    },\r\n  ];\r\n\r\n  appliedFilters: any = {\r\n    country: [],\r\n    city: [],\r\n    status: [],\r\n  };\r\n\r\n  isFilterApplied: boolean = false;\r\n\r\n  isPageLoading: boolean = true;\r\n  isButtonLoading: boolean = false;\r\n  isError: boolean = false;\r\n\r\n  private readonly destroy$ = new Subject<void>();\r\n  private planoSub?: Subscription;\r\n\r\n  constructor(\r\n    private ngbModal: NgbModal,\r\n    private router: Router,\r\n    private route: ActivatedRoute,\r\n    private storeBuilderService: StoreBuilderService,\r\n    private gs: GlobalStateService,\r\n    private pageInfo: PageInfoService,\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.setPageData();\r\n\r\n    this.gs.dataRangeValue\r\n      .pipe(\r\n        takeUntil(this.destroy$), // Subscription will be cancelled on component destroy.\r\n        debounceTime(200), // To avoid immediate frequent calls.\r\n        filter((data) => !!data), // Filtering null/undefined.\r\n        distinctUntilChanged(), // Emitting only different values. (Ignores same clientId).\r\n      )\r\n      .subscribe({\r\n        next: (data: any) => {\r\n          if (data) {\r\n            this.clientId = data.client;\r\n          } else {\r\n            let data = JSON.parse(\r\n              localStorage.getItem(\"header-filters\") as string,\r\n            );\r\n            this.clientId = data?.client;\r\n          }\r\n\r\n          this.route.queryParamMap\r\n            .pipe(takeUntil(this.destroy$))\r\n            .subscribe((params) => {\r\n              this.searchTerm = getQueryParamString({\r\n                params,\r\n                key: \"search\",\r\n                fallback: \"\",\r\n              });\r\n              this.isFilterApplied = this.searchTerm ? true : false;\r\n\r\n              this.selectedFilterTab = getQueryParamString({\r\n                params,\r\n                key: \"tab\",\r\n                fallback: \"all\",\r\n              });\r\n\r\n              this.appliedFilters.status = [this.selectedFilterTab];\r\n\r\n              this.limit = getQueryParamNumber({\r\n                params,\r\n                key: \"limit\",\r\n                fallback: 10,\r\n                min: 1,\r\n                max: 30,\r\n              });\r\n\r\n              this.offset = getQueryParamNumber({\r\n                params,\r\n                key: \"offset\",\r\n                fallback: 1,\r\n                min: 1,\r\n              });\r\n\r\n              this.getPlanoTableList();\r\n            });\r\n        },\r\n      });\r\n  }\r\n\r\n  setPageData() {\r\n    this.pageInfo.setTitle(\"Manage Planogram\");\r\n    this.pageInfo.setBreadcrumbs([\r\n      {\r\n        title: \"Planogram\",\r\n        path: \"/manage/planogram/manage-planograms\",\r\n        isActive: false,\r\n        isSeparator: false,\r\n      },\r\n      {\r\n        title: \"\",\r\n        path: \"\",\r\n        isActive: false,\r\n        isSeparator: true,\r\n      },\r\n    ]);\r\n  }\r\n\r\n  getPlanoTableList() {\r\n    this.planoSub?.unsubscribe(); // Cancel previous request\r\n\r\n    this.isPageLoading = true;\r\n    this.planogramsList = [];\r\n    let payload = {\r\n      clientId: this.clientId,\r\n      limit: this.limit,\r\n      offset: this.offset,\r\n      sortColumnName: this.sortedColumn,\r\n      sortBy: this.sortOrder,\r\n      filter: this.appliedFilters,\r\n      searchValue: this.searchTerm,\r\n      // export: false,\r\n      // emptyDownload: false\r\n    };\r\n\r\n    this.planoSub = this.storeBuilderService\r\n      .getOnboardPlanoList(payload)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if (res && res?.code == 200) {\r\n            this.totalItems = res?.data?.count;\r\n            this.planogramsList = res?.data?.data ?? [];\r\n            this.cardInfo = res?.data?.cardInfo?.[0] || [];\r\n            if (this.totalItems < 10) {\r\n              this.paginationSizes = [this.totalItems];\r\n            } else {\r\n              this.paginationSizes = [10, 20, 30];\r\n            }\r\n          }\r\n          this.isPageLoading = false;\r\n        },\r\n        error: (err) => {\r\n          this.isPageLoading = false;\r\n        },\r\n      });\r\n\r\n    this.totalItems = this.planogramsList.length;\r\n  }\r\n\r\n  openBulkUploadModal() {\r\n    const modelRef = this.ngbModal.open(BulkUploadPlanogramComponent);\r\n  }\r\n\r\n  onClickCreatePlanogram() {\r\n    let modelRef: any;\r\n\r\n    modelRef = this.ngbModal.open(CreatePlanogramComponent, {\r\n      size: \"md\",\r\n      windowClass: \"create-planogram-modal\",\r\n      centered: true,\r\n      backdrop: \"static\",\r\n      beforeDismiss: () => !modelRef.componentInstance?.isModalBusy,\r\n    });\r\n\r\n    modelRef.componentInstance.clientId = this.clientId;\r\n    modelRef.result.then((result:any) => {\r\n      if (result) {\r\n        this.router.navigate([\"/manage/planogram/onboard-planogram\"], {\r\n          queryParams: { planoId: result?.planoId, floorId: result?.floorId },\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  onSearch() {\r\n    this.sortedColumn = \"\";\r\n    this.sortOrder = 1;\r\n    this.offset = 1;\r\n    this.limit = 10;\r\n\r\n    this.isFilterApplied = this.searchTerm ? true : false;\r\n    this.updateQueryParams();\r\n  }\r\n\r\n  onSortTable(column: string) {\r\n    if (this.sortedColumn === column) {\r\n      this.sortOrder = this.sortOrder === 1 ? -1 : 1;\r\n    } else {\r\n      this.sortedColumn = column;\r\n      this.sortOrder = 1;\r\n    }\r\n    this.offset = 1;\r\n    this.limit = 10;\r\n    this.getPlanoTableList();\r\n  }\r\n\r\n  filterTable(data: string) {\r\n    if (this.selectedFilterTab !== data) {\r\n      this.planoFilterRef?.onResetFilter(false);\r\n      this.selectedFilterTab = data;\r\n      this.appliedFilters = {\r\n        country: [],\r\n        city: [],\r\n        status: [this.selectedFilterTab],\r\n      };\r\n      this.isFilterApplied = false;\r\n      this.offset = 1;\r\n      this.limit = 10;\r\n      this.searchTerm = \"\";\r\n      this.updateQueryParams();\r\n    }\r\n  }\r\n\r\n  applyFilters(event: any) {\r\n    event.forEach((ele: any) => {\r\n      let key = ele.title.toLowerCase();\r\n      if (key === \"store category\") {\r\n        this.appliedFilters[\"planoStrategy\"] = ele.selected;\r\n      } else {\r\n        this.appliedFilters[ele.title.toLowerCase()] = ele.selected;\r\n      }\r\n    });\r\n\r\n    this.offset = 1;\r\n    this.getPlanoTableList();\r\n  }\r\n\r\n  paginationSize(): number {\r\n    return this.totalItems < 10 ? this.totalItems : this.limit;\r\n  }\r\n\r\n  onPageChange(pageOffset: number) {\r\n    this.offset = Number(pageOffset);\r\n    this.updateQueryParams();\r\n  }\r\n\r\n  onPageSizeChange(pageSize: number) {\r\n    this.offset = 1;\r\n    this.limit = Number(pageSize);\r\n    this.updateQueryParams();\r\n  }\r\n\r\n  planoFloorDetails(data: any) {\r\n    if (data.layoutDetails.length > 1) {\r\n      let completeCount = data?.taskDetails?.completeLayout || 0;\r\n      return completeCount + \"/\" + data.layoutDetails.length;\r\n    } else {\r\n      return 1;\r\n    }\r\n  }\r\n\r\n  // getTaskStatus(data: any, type: string) {\r\n  //   const statusMap: any = {\r\n  //     layout: data.taskDetails?.layoutStatus,\r\n  //     fixture: data.taskDetails?.fixtureStatus,\r\n  //     vm: data.taskDetails?.fixtureStatus,\r\n  //   };\r\n  //   if (type == \"vm\") {\r\n  //     type = \"fixture\";\r\n  //   }\r\n  //   const status = statusMap[type];\r\n\r\n  //   const taskDetails = data?.planoTask?.[0]?.taskStatus?.find(\r\n  //     (ele: any) => ele.type == type,\r\n  //   );\r\n\r\n  //   if (type == \"fixture\") {\r\n  //     let taskInfo = data?.planoTask?.[0]?.taskStatus?.filter(\r\n  //       (ele: any) => ele.status && ele.type == \"fixture\",\r\n  //     );\r\n  //     if (\r\n  //       status === \"pending\" &&\r\n  //       taskInfo?.some((task: any) => task.status == \"submit\")\r\n  //     )\r\n  //       return \"reviewPending\";\r\n  //     if (taskInfo?.length != data.layoutCount) {\r\n  //       return \"yetToAssign\";\r\n  //     }\r\n  //     if (taskInfo.includes(\"open\") || taskInfo.includes(\"inprogress\")) {\r\n  //       return \"taskAssigned\";\r\n  //     }\r\n  //   }\r\n\r\n  //   if (\r\n  //     !taskDetails ||\r\n  //     (taskDetails.status == \"submit\" && status === \"disagree\")\r\n  //   )\r\n  //     return \"yetToAssign\";\r\n\r\n  //   if (taskDetails.status !== \"submit\") return \"taskAssigned\";\r\n\r\n  //   if (status === \"complete\") return \"completed\";\r\n  // }\r\n\r\n  // getTaskTooltip(data: any, type: string) {\r\n  //   const statusMap: any = {\r\n  //     layout: data.taskDetails?.layoutStatus,\r\n  //     fixture: data.taskDetails?.fixtureStatus,\r\n  //     vm: data.taskDetails?.fixtureStatus,\r\n  //   };\r\n  //   if (type == \"vm\") {\r\n  //     type = \"fixture\";\r\n  //   }\r\n  //   const taskDetails = data?.planoTask?.[0]?.taskStatus?.find(\r\n  //     (ele: any) => ele.type == type,\r\n  //   );\r\n\r\n  //   const status = statusMap[type];\r\n\r\n  //   if (type == \"fixture\") {\r\n  //     let taskInfo = data?.planoTask?.[0]?.taskStatus?.filter(\r\n  //       (ele: any) => ele.status && ele.type == \"fixture\",\r\n  //     );\r\n  //     if (\r\n  //       status === \"pending\" &&\r\n  //       taskInfo?.some((task: any) => task.status == \"submit\")\r\n  //     )\r\n  //       return \"Review Pending\";\r\n  //     if (taskInfo?.length != data.layoutCount) {\r\n  //       return \"Yet to Assign\";\r\n  //     }\r\n  //     if (taskInfo.includes(\"open\") || taskInfo.includes(\"inprogress\")) {\r\n  //       return \"Task Assigned\";\r\n  //     }\r\n  //   }\r\n\r\n  //   if (\r\n  //     !taskDetails ||\r\n  //     (taskDetails.status == \"submit\" && status === \"disagree\")\r\n  //   )\r\n  //     return \"Yet to Assign\";\r\n\r\n  //   if (taskDetails.status !== \"submit\") return \"Task Assigned\";\r\n\r\n  //   if (status === \"complete\") return \"Completed\";\r\n  // }\r\n\r\n  getProgressValue(plano: any) {\r\n    const status = this.getStatusBadge(plano);\r\n\r\n    if (status === \"allocationPending\") {\r\n      return 25;\r\n    } else {\r\n      return 0;\r\n    }\r\n  }\r\n\r\n  getStatus(plano: any) {\r\n    const status = this.getStatusBadge(plano);\r\n\r\n    if (status === \"allocationPending\") {\r\n      return \"Allocation pending\";\r\n    } else {\r\n      return \"Draft\";\r\n    }\r\n  }\r\n\r\n  getStatusBadge(plano: any) {\r\n    const floor = this.getPriorityFloor(plano);\r\n    return floor?.status;\r\n  }\r\n\r\n  getPriorityFloor(plano: any) {\r\n    let priorityFloor = plano?.layoutDetails?.find(\r\n      (f: any) => f.status === \"allocationPending\",\r\n    );\r\n\r\n    if (!priorityFloor) {\r\n      priorityFloor = plano?.layoutDetails[0];\r\n    }\r\n\r\n    return priorityFloor;\r\n  }\r\n\r\n  getSubmit(data: any) {\r\n    const statusMap: any = {\r\n      layout: data.taskDetails?.layoutStatus,\r\n      fixture: data.taskDetails?.fixtureStatus,\r\n      vm: data.taskDetails?.vmStatus,\r\n    };\r\n    let submitTask = data?.planoTask?.[0]?.taskStatus.find(\r\n      (ele: any) => ele.status == \"submit\" && statusMap[ele.type] == \"pending\",\r\n    );\r\n    if (submitTask) {\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  updateQueryParams() {\r\n    this.router.navigate([], {\r\n      relativeTo: this.route,\r\n      queryParams: {\r\n        tab: this.selectedFilterTab,\r\n        search: this.searchTerm,\r\n        limit: this.limit,\r\n        offset: this.offset,\r\n      },\r\n      queryParamsHandling: \"merge\",\r\n      replaceUrl: true,\r\n    });\r\n  }\r\n\r\n  redirectStore(storeId: any) {\r\n    let data: any = JSON.parse(localStorage.getItem(\"header-filters\") || \"\");\r\n    data.store = storeId;\r\n    localStorage.setItem(\"header-filters\", JSON.stringify(data));\r\n    this.router.navigateByUrl(`manage/stores/plano?storeId=${storeId}`);\r\n  }\r\n\r\n  onExport() {\r\n    this.isButtonLoading = true;\r\n    let payload = {\r\n      clientId: this.clientId,\r\n      limit: this.totalItems,\r\n      offset: 1,\r\n      sortColumnName: this.sortedColumn,\r\n      sortBy: this.sortOrder,\r\n      filter: this.appliedFilters,\r\n      searchValue: this.searchTerm,\r\n      export: true,\r\n    };\r\n\r\n    this.storeBuilderService\r\n      .getOnboardPlanoListExport(payload)\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe({\r\n        next: (res: any) => {\r\n          if (res) {\r\n            this.storeBuilderService.saveAsExcelFile(\r\n              res,\r\n              \"Onboarding Plano List\",\r\n            );\r\n          }\r\n\r\n          this.isButtonLoading = false;\r\n        },\r\n        error: (err) => {\r\n          console.log(err, \"err\");\r\n          this.isButtonLoading = false;\r\n        },\r\n      });\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n    this.planoSub?.unsubscribe();\r\n  }\r\n}\r\n","<div class=\"row mx-0 my-5 gap-2\">\r\n  <div class=\"col filter-tab\" [ngClass]=\"{ selected: selectedFilterTab === 'all' }\" (click)=\"filterTable('all')\">\r\n    <h3>{{ cardInfo?.allStores ?? 0 }}</h3>\r\n    <p>All stores</p>\r\n  </div>\r\n  <div class=\"col filter-tab\" [ngClass]=\"{ selected: selectedFilterTab === 'allocationPending' }\"\r\n    (click)=\"filterTable('allocationPending')\">\r\n    <h3>{{ cardInfo?.allocationPendingStores ?? 0 }}</h3>\r\n    <p>Allocation pending</p>\r\n  </div>\r\n  <div class=\"col filter-tab\" [ngClass]=\"{ selected: selectedFilterTab === 'draft' }\" (click)=\"filterTable('draft')\">\r\n    <h3>{{ cardInfo?.draftStores ?? 0 }}</h3>\r\n    <p>Draft</p>\r\n  </div>\r\n</div>\r\n\r\n<div class=\"content-wrapper\">\r\n  <div [class.restrict-interaction]=\"isButtonLoading\">\r\n    <!-- Manage Planogram view header -->\r\n    <div class=\"d-flex justify-content-between align-items-center mb-5\">\r\n      <div>\r\n        <h4>Onboard stores</h4>\r\n        <span>{{ totalItems }} - Total stores</span>\r\n      </div>\r\n\r\n      <div class=\"d-flex align-items-center gap-3\">\r\n        <div style=\"position: relative\">\r\n          <input type=\"text\" [(ngModel)]=\"searchTerm\" (change)=\"onSearch()\"\r\n            style=\"padding-left: 3rem; padding-right: 3rem\" class=\"form-control\" name=\"search\" autocomplete=\"off\"\r\n            placeholder=\"Search\" />\r\n\r\n          <span class=\"search-icon\">\r\n            <svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\">\r\n              <circle cx=\"8\" cy=\"8\" r=\"6\" stroke=\"currentColor\" stroke-width=\"2\" />\r\n              <line x1=\"13\" y1=\"13\" x2=\"16\" y2=\"16\" stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" />\r\n            </svg>\r\n          </span>\r\n\r\n          <button *ngIf=\"searchTerm\" type=\"button\" aria-label=\"Clear\" (click)=\"searchTerm = ''; onSearch()\"\r\n            class=\"clear-search\">\r\n            <svg width=\"64px\" height=\"64px\" viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n              <g id=\"SVGRepo_bgCarrier\" stroke-width=\"0\"></g>\r\n              <g id=\"SVGRepo_tracerCarrier\" stroke-linecap=\"round\" stroke-linejoin=\"round\"></g>\r\n              <g id=\"SVGRepo_iconCarrier\">\r\n                <path d=\"M9 9L15 15\" stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\r\n                </path>\r\n                <path d=\"M15 9L9 15\" stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\r\n                </path>\r\n                <circle cx=\"12\" cy=\"12\" r=\"9\" stroke=\"#667085\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                  stroke-linejoin=\"round\"></circle>\r\n              </g>\r\n            </svg>\r\n          </button>\r\n        </div>\r\n\r\n        <!-- <button type=\"button\" (click)=\"openBulkUploadModal()\" class=\"btn btn-outline text-nowrap\">\r\n          <svg class=\"me-2\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n            <path\r\n              d=\"M17.5 12.5V15.8333C17.5 16.2754 17.3244 16.6993 17.0118 17.0118C16.6993 17.3244 16.2754 17.5 15.8333 17.5H4.16667C3.72464 17.5 3.30072 17.3244 2.98816 17.0118C2.67559 16.6993 2.5 16.2754 2.5 15.8333V12.5M14.1667 6.66667L10 2.5M10 2.5L5.83333 6.66667M10 2.5V12.5\"\r\n              stroke=\"currentColor\"\r\n              stroke-width=\"1.67\"\r\n              stroke-linecap=\"round\"\r\n              stroke-linejoin=\"round\"\r\n            />\r\n          </svg>\r\n          Bulk Upload\r\n        </button> -->\r\n\r\n        <!-- <button type=\"button\" class=\"btn btn-outline d-line-flex align-items-center text-nowrap\">\r\n          <svg width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n            <path\r\n              d=\"M5 10H15M2.5 5H17.5M7.5 15H12.5\"\r\n              stroke=\"#344054\"\r\n              stroke-width=\"2\"\r\n              stroke-linecap=\"round\"\r\n              stroke-linejoin=\"round\"\r\n            />\r\n          </svg>\r\n          Filter\r\n        </button> -->\r\n\r\n        @if(selectedFilterTab === 'all'){\n          <plano-filter #planoFilterRef [clientId]=\"clientId\" [data]=\"filterObject\" (applyFilters)=\"applyFilters($event)\"\n          (resetFilters)=\"applyFilters($event)\"\n          [config]=\"{ 'Merchandise compliance': false, 'Store category': false }\"></plano-filter>\n        }\n\r\n        <button type=\"button\" (click)=\"onExport()\" class=\"btn-outline btn align-items-end text-nowrap invheader\"\r\n          [disabled]=\"!planogramsList.length\">\r\n\r\n          <svg *ngIf=\"!isButtonLoading\" xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\"\r\n            fill=\"none\">\r\n            <path\r\n              d=\"M17.5 12.5V15.8333C17.5 16.2754 17.3244 16.6993 17.0118 17.0118C16.6993 17.3244 16.2754 17.5 15.8333 17.5H4.16667C3.72464 17.5 3.30072 17.3244 2.98816 17.0118C2.67559 16.6993 2.5 16.2754 2.5 15.8333V12.5M14.1667 6.66667L10 2.5M10 2.5L5.83333 6.66667M10 2.5V12.5\"\r\n              stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\"></path>\r\n          </svg>\r\n\r\n          <svg *ngIf=\"isButtonLoading\" 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          <span class=\"ms-2\"> Export</span>\r\n\r\n        </button>\r\n\r\n        <button type=\"button\" (click)=\"onClickCreatePlanogram()\"\r\n          class=\"btn btn-primary d-inline-flex align-items-center\">\r\n          <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n            <path d=\"M10.0001 4.16663V15.8333M4.16675 9.99996H15.8334\" stroke=\"white\" stroke-width=\"1.67\"\r\n              stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n          </svg>\r\n          <span class=\"ms-2 text-white\">Create </span>\r\n        </button>\r\n      </div>\r\n    </div>\r\n\r\n    <div *ngIf=\"isPageLoading\">\r\n      <div class=\"row loader d-flex justify-content-center align-items-center\">\r\n        <div class=\"shimmer\">\r\n          <div class=\"wrapper\">\r\n            <div class=\"stroke animate title\"></div>\r\n            <div class=\"stroke animate link\"></div>\r\n            <div class=\"stroke animate description\"></div>\r\n          </div>\r\n        </div>\r\n        <div class=\"shimmer\">\r\n          <div class=\"wrapper\">\r\n            <div class=\"stroke animate title\"></div>\r\n            <div class=\"stroke animate link\"></div>\r\n            <div class=\"stroke animate description\"></div>\r\n          </div>\r\n        </div>\r\n        <div class=\"shimmer\">\r\n          <div class=\"wrapper\">\r\n            <div class=\"stroke animate title\"></div>\r\n            <div class=\"stroke animate link\"></div>\r\n            <div class=\"stroke animate description\"></div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <div class=\"card-body d-flex justify-content-center align-items-center flex-column\"\r\n      *ngIf=\"!isPageLoading && planogramsList.length === 0\">\r\n      <img class=\"img-src\" src=\"./assets/tango/Icons/Nodata1.svg\" alt=\"\" />\r\n      <div class=\"nodatamaintext mt-3\">No data found</div>\r\n      <div class=\"nodatasubtext\">There is no result for onboard planogram table</div>\r\n    </div>\r\n\r\n    <!-- Onboard Planogram list view -->\r\n    <section id=\"list-view\" *ngIf=\"!isPageLoading && planogramsList.length !== 0\">\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>\r\n                <span (click)=\"onSortTable('storeName')\" class=\"cursor-pointer\">\r\n                  Store Name\r\n                  <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'storeName' ? '#009BF3' : '' }\"\r\n                    [ngClass]=\"sortOrder === 1 && sortedColumn === 'storeName' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                    aria-hidden=\"true\"></i>\r\n                </span>\r\n              </th>\r\n              <th>\r\n                <span (click)=\"onSortTable('layoutName')\" class=\"cursor-pointer\">\r\n                  Plano Name\r\n                  <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'layoutName' ? '#009BF3' : '' }\"\r\n                    [ngClass]=\"sortOrder === 1 && sortedColumn === 'layoutName' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                    aria-hidden=\"true\"></i>\r\n                </span>\r\n              </th>\r\n              <th>\r\n                Country\r\n              </th>\r\n              <th>\r\n                City\r\n              </th>\r\n              <th>\r\n                <span class=\"cursor-pointer d-flex align-items-center\">\r\n                  Completion %\r\n                  <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\"\r\n                    ngbTooltip=\"% of overall planogram completion\" class=\"ms-2\">\r\n                    <g clip-path=\"url(#clip0_844_17538)\">\r\n                      <path\r\n                        d=\"M8.00065 10.6663V7.99967M8.00065 5.33301H8.00732M14.6673 7.99967C14.6673 11.6816 11.6826 14.6663 8.00065 14.6663C4.31875 14.6663 1.33398 11.6816 1.33398 7.99967C1.33398 4.31778 4.31875 1.33301 8.00065 1.33301C11.6826 1.33301 14.6673 4.31778 14.6673 7.99967Z\"\r\n                        stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                    </g>\r\n                    <defs>\r\n                      <clipPath id=\"clip0_844_17538\">\r\n                        <rect width=\"16\" height=\"16\" fill=\"white\" />\r\n                      </clipPath>\r\n                    </defs>\r\n                  </svg>\r\n                </span>\r\n              </th>\r\n              <th>\r\n                <span (click)=\"onSortTable('layoutCount')\" class=\"cursor-pointer\">\r\n                  Layout\r\n                  <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'layoutCount' ? '#009BF3' : '' }\"\r\n                    [ngClass]=\"sortOrder === 1 && sortedColumn === 'layoutCount' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                    aria-hidden=\"true\"></i>\r\n                </span>\r\n              </th>\r\n              <th class=\"text-center\">\r\n                <span (click)=\"onSortTable('fixtureCount')\" class=\"cursor-pointer\">\r\n                  #Fixtures\r\n                  <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'fixtureCount' ? '#009BF3' : '' }\"\r\n                    [ngClass]=\"sortOrder === 1 && sortedColumn === 'fixtureCount' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                    aria-hidden=\"true\"></i>\r\n                </span>\r\n              </th>\r\n              <th class=\"text-center\">\r\n                <ng-template #tooltip>\r\n                  <div class=\"w-100\">\r\n                    <h6>Total store capacity</h6>\r\n                    <span> Combining product capacity of all fixtures </span>\r\n                  </div>\r\n                </ng-template>\r\n                <span (click)=\"onSortTable('fixtureCapacity')\" class=\"cursor-pointer d-flex align-items-center\">\r\n                  Capacity\r\n                  <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'fixtureCapacity' ? '#009BF3' : '' }\"\r\n                    [ngClass]=\"sortOrder === 1 && sortedColumn === 'fixtureCapacity' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                    aria-hidden=\"true\"></i>\r\n                  <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\"\r\n                    [ngbTooltip]=\"tooltip\" class=\"ms-2\">\r\n                    <g clip-path=\"url(#clip0_844_17538)\">\r\n                      <path\r\n                        d=\"M8.00065 10.6663V7.99967M8.00065 5.33301H8.00732M14.6673 7.99967C14.6673 11.6816 11.6826 14.6663 8.00065 14.6663C4.31875 14.6663 1.33398 11.6816 1.33398 7.99967C1.33398 4.31778 4.31875 1.33301 8.00065 1.33301C11.6826 1.33301 14.6673 4.31778 14.6673 7.99967Z\"\r\n                        stroke=\"#667085\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n                    </g>\r\n                    <defs>\r\n                      <clipPath id=\"clip0_844_17538\">\r\n                        <rect width=\"16\" height=\"16\" fill=\"white\" />\r\n                      </clipPath>\r\n                    </defs>\r\n                  </svg>\r\n                </span>\r\n              </th>\r\n              <th class=\"text-center\">\r\n                <span (click)=\"onSortTable('lastUpdate')\" class=\"cursor-pointer\">\r\n                  Last update\r\n                  <i class=\"fa ms-1 mt-1\" [ngStyle]=\"{ color: sortedColumn === 'lastUpdate' ? '#009BF3' : '' }\"\r\n                    [ngClass]=\"sortOrder === 1 && sortedColumn === 'lastUpdate' ? 'fa-arrow-up' : 'fa-arrow-down'\"\r\n                    aria-hidden=\"true\"></i>\r\n                </span>\r\n              </th>\r\n              <th>\r\n                Status\r\n              </th>\r\n            </tr>\r\n          </thead>\r\n          <tbody>\r\n            <tr *ngFor=\"let plano of planogramsList\">\r\n              <td>\r\n                <div class=\"d-flex align-items-center\">\r\n                  <a (click)=\"redirectStore(plano.storeId)\" class=\"cursor-pointer text-decoration-underline\">\r\n                    {{ plano.storeName }}</a>\r\n                </div>\r\n              </td>\r\n              <td>\r\n                <a [routerLink]=\"['/manage/planogram/onboard-planogram']\"\r\n                  [queryParams]=\"{ planoId: plano._id, floorId: getPriorityFloor(plano)?.id }\"\r\n                  class=\"text-decoration-underline\">\r\n                  {{ plano.layoutName }}\r\n                </a>\r\n              </td>\r\n              <td>\r\n                {{plano?.country}}\r\n              </td>\r\n              <td>\r\n                {{plano?.city}}\r\n              </td>\r\n              <td>\r\n                <div class=\"row align-items-center\">\r\n                  <div class=\"col-9\">\r\n                    <div class=\"progress\" style=\"height: 4px\">\r\n                      <div class=\"progress-bar\" [ngClass]=\"\r\n                          [25, 50].includes(getProgressValue(plano))\r\n                            ? 'bg-warning'\r\n                            : 'bg-success'\r\n                        \" role=\"progressbar\"\r\n                        [style]=\"  (plano) ? 'width: ' + getProgressValue(plano) + '%' : 'width:25%'\"\r\n                        [attr.aria-valuenow]=\"getProgressValue(plano)\" aria-valuemin=\"0\" aria-valuemax=\"100\"></div>\r\n                    </div>\r\n                  </div>\r\n                  <div class=\"col-3\">{{ getProgressValue(plano) }}%</div>\r\n                </div>\r\n              </td>\r\n              <td>\r\n                <div class=\"d-flex align-items-center justify-content-center gap-2\">\r\n                  <span>\r\n                    @if(plano?.layoutCount === 1){\r\n                      1\r\n                    }@else{\r\n                      {{getPriorityFloor(plano)?.floorNumber??0}}/{{plano?.layoutCount??0}}\r\n                    }\r\n                  </span>\r\n\r\n                  @if(getStatusBadge(plano) === 'allocationPending'){\r\n                    <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                      <rect width=\"14\" height=\"14\" rx=\"7\" fill=\"#D1FADF\" />\r\n                      <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                        d=\"M9.97284 4.31097L5.79617 8.3418L4.68784 7.15763C4.48367 6.96513 4.16284 6.95347 3.9295 7.1168C3.702 7.28597 3.63784 7.58347 3.77784 7.82263L5.09034 9.95763C5.21867 10.156 5.44034 10.2785 5.69117 10.2785C5.93034 10.2785 6.15784 10.156 6.28617 9.95763C6.49617 9.68347 10.5037 4.90597 10.5037 4.90597C11.0287 4.3693 10.3928 3.8968 9.97284 4.30513V4.31097Z\"\r\n                        fill=\"#12B76A\" />\r\n                    </svg>\r\n\r\n                  }@else{\r\n                    <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                      <rect width=\"14\" height=\"14\" rx=\"7\" fill=\"#F2F4F7\" />\r\n                      <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                        d=\"M9.97284 4.31097L5.79617 8.3418L4.68784 7.15763C4.48367 6.96513 4.16284 6.95347 3.9295 7.1168C3.702 7.28597 3.63784 7.58347 3.77784 7.82263L5.09034 9.95763C5.21867 10.156 5.44034 10.2785 5.69117 10.2785C5.93034 10.2785 6.15784 10.156 6.28617 9.95763C6.49617 9.68347 10.5037 4.90597 10.5037 4.90597C11.0287 4.3693 10.3928 3.8968 9.97284 4.30513V4.31097Z\"\r\n                        fill=\"#667085\" />\r\n                    </svg>\r\n                  }\r\n\r\n                </div>\r\n              </td>\r\n              <td>\r\n                <div class=\"d-flex align-items-center justify-content-center gap-2\">\r\n                  <span>\r\n                    {{ plano?.fixtureCount ?? 0 }}\r\n                    @if(getStatusBadge(plano) === 'allocationPending'){\r\n                      <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                        <rect width=\"14\" height=\"14\" rx=\"7\" fill=\"#FFFAEB\" />\r\n                        <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                          d=\"M9.97284 4.31097L5.79617 8.3418L4.68784 7.15763C4.48367 6.96513 4.16284 6.95347 3.9295 7.1168C3.702 7.28597 3.63784 7.58347 3.77784 7.82263L5.09034 9.95763C5.21867 10.156 5.44034 10.2785 5.69117 10.2785C5.93034 10.2785 6.15784 10.156 6.28617 9.95763C6.49617 9.68347 10.5037 4.90597 10.5037 4.90597C11.0287 4.3693 10.3928 3.8968 9.97284 4.30513V4.31097Z\"\r\n                          fill=\"#B54708\" />\r\n                      </svg>\r\n\r\n\r\n                    }@else{\r\n                      <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n                        <rect width=\"14\" height=\"14\" rx=\"7\" fill=\"#F2F4F7\" />\r\n                        <path fill-rule=\"evenodd\" clip-rule=\"evenodd\"\r\n                          d=\"M9.97284 4.31097L5.79617 8.3418L4.68784 7.15763C4.48367 6.96513 4.16284 6.95347 3.9295 7.1168C3.702 7.28597 3.63784 7.58347 3.77784 7.82263L5.09034 9.95763C5.21867 10.156 5.44034 10.2785 5.69117 10.2785C5.93034 10.2785 6.15784 10.156 6.28617 9.95763C6.49617 9.68347 10.5037 4.90597 10.5037 4.90597C11.0287 4.3693 10.3928 3.8968 9.97284 4.30513V4.31097Z\"\r\n                          fill=\"#667085\" />\r\n                      </svg>\r\n                    }\r\n                  </span>\r\n                </div>\r\n              </td>\r\n              <td>\r\n                <div class=\"d-flex align-items-center justify-content-center gap-2\">\r\n                  <span>\r\n                    {{ plano?.fixtureCapacity ?? 0 }}\r\n                  </span>\r\n                </div>\r\n              </td>\r\n              <td class=\"text-center\">\r\n                <span [ngbTooltip]=\"plano?.lastUpdate | date : 'medium'\">\r\n                  {{ plano?.lastUpdate | date }}\r\n                </span>\r\n              </td>\r\n              <td>\r\n                <div class=\"badge\" [ngClass]=\"getStatusBadge(plano)\">\r\n                  {{ getStatus(plano) }}\r\n                </div>\r\n              </td>\r\n            </tr>\r\n          </tbody>\r\n        </table>\r\n      </div>\r\n    </section>\r\n\r\n    <!-- Pagination -->\r\n    <lib-pagination [itemsPerPage]=\"limit\" [currentPage]=\"offset\" [totalItems]=\"totalItems\"\r\n      [paginationSizes]=\"paginationSizes\" [pageSize]=\"paginationSize()\" (pageChange)=\"onPageChange($event)\"\r\n      (pageSizeChange)=\"onPageSizeChange($event)\" *ngIf=\"!isPageLoading && planogramsList.length !== 0\">\r\n    </lib-pagination>\r\n  </div>\r\n</div>\n"]}
|