tango-app-ui-store-builder 1.0.30 → 1.0.32

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.
@@ -1,5 +1,5 @@
1
1
  import { Component, Input } from "@angular/core";
2
- import { FormsModule, ReactiveFormsModule } from "@angular/forms";
2
+ import { FormsModule, ReactiveFormsModule, } from "@angular/forms";
3
3
  import { ReactiveSelectComponent } from "../../../reactive-select/reactive-select.component";
4
4
  import { firstValueFrom } from "rxjs";
5
5
  import { FileUploadComponent } from "../../../file-upload/file-upload.component";
@@ -9,10 +9,13 @@ import * as i1 from "@ng-bootstrap/ng-bootstrap";
9
9
  import * as i2 from "../../../../services/store-builder.service";
10
10
  import * as i3 from "tango-app-ui-shared";
11
11
  import * as i4 from "@angular/forms";
12
+ import * as i5 from "@angular/router";
12
13
  export class CreatePlanogramComponent {
13
14
  activeModal;
14
15
  storeBuilderService;
15
16
  toastService;
17
+ fb;
18
+ router;
16
19
  clientId;
17
20
  selectedStore;
18
21
  selectedFloor;
@@ -25,17 +28,31 @@ export class CreatePlanogramComponent {
25
28
  ];
26
29
  selectedStoreFloors = [];
27
30
  isLayoutExist = false;
28
- isProcessing = false;
31
+ isCADProcessing = false;
29
32
  isCreateStoreMode = false;
30
- constructor(activeModal, storeBuilderService, toastService) {
33
+ createStoreForm;
34
+ storeTypeList = [
35
+ { label: "High Street", value: "HighStreet" },
36
+ { label: "Mall", value: "mall" },
37
+ { label: "Kiosk", value: "kiosk" },
38
+ ];
39
+ businessTypeList = [
40
+ { label: "COCO", value: "coco" },
41
+ { label: "COFO", value: "cofo" },
42
+ { label: "FOFO", value: "fofo" },
43
+ { label: "FOCO", value: "foco" },
44
+ ];
45
+ constructor(activeModal, storeBuilderService, toastService, fb, router) {
31
46
  this.activeModal = activeModal;
32
47
  this.storeBuilderService = storeBuilderService;
33
48
  this.toastService = toastService;
49
+ this.fb = fb;
50
+ this.router = router;
34
51
  }
35
52
  async ngOnInit() {
36
53
  await this.getStoreList();
37
54
  }
38
- get isValidToCreate() {
55
+ get isValidToCreatePlano() {
39
56
  return this.selectedStore && this.selectedFloor && this.selectedFile;
40
57
  }
41
58
  async getStoreList() {
@@ -70,11 +87,11 @@ export class CreatePlanogramComponent {
70
87
  onFileChange(file) {
71
88
  this.selectedFile = file;
72
89
  }
73
- async onCreate() {
74
- if (!this.isValidToCreate)
90
+ async onCreateLayoutPlano() {
91
+ if (!this.isValidToCreatePlano)
75
92
  return;
76
93
  try {
77
- this.isProcessing = true;
94
+ this.isCADProcessing = true;
78
95
  const planoRes = await firstValueFrom(this.storeBuilderService.createPlanoFromCAD(this.selectedFile, this.selectedStore, this.selectedFloor));
79
96
  if (!planoRes?.data)
80
97
  return;
@@ -85,17 +102,37 @@ export class CreatePlanogramComponent {
85
102
  console.log("@@ ~ onCreate [ERR]:", error);
86
103
  }
87
104
  finally {
88
- this.isProcessing = false;
105
+ this.isCADProcessing = false;
89
106
  }
90
107
  }
91
- onClickCreateStore() {
92
- this.isCreateStoreMode = true;
108
+ async onCreateStore() {
109
+ // console.log("@@ ~ this.createStoreForm:", this.createStoreForm.value);
110
+ }
111
+ addNewStore() {
112
+ // this.isCreateStoreMode = true;
113
+ // this.createStoreForm = this.fb.group({
114
+ // storeName: ["", Validators.required],
115
+ // businessType: ["", Validators.required],
116
+ // storeType: ["", Validators.required],
117
+ // address: ["", Validators.required],
118
+ // country: ["", Validators.required],
119
+ // state: ["", Validators.required],
120
+ // city: ["", Validators.required],
121
+ // zipCode: ["", Validators.required],
122
+ // });
123
+ const urlTree = this.router.createUrlTree(["/manage/stores/add-single-store"]);
124
+ const url = this.router.serializeUrl(urlTree);
125
+ window.open(url, "_blank");
93
126
  }
94
127
  onCancel() {
95
128
  this.activeModal.dismiss();
96
129
  }
97
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CreatePlanogramComponent, deps: [{ token: i1.NgbActiveModal }, { token: i2.StoreBuilderService }, { token: i3.ToastService }], target: i0.ɵɵFactoryTarget.Component });
98
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CreatePlanogramComponent, isStandalone: true, selector: "app-create-planogram", inputs: { clientId: "clientId" }, ngImport: i0, template: "<div class=\"modal-wrapper\">\r\n <h3 class=\"mb-4\">Create store layout/plan from CAD</h3>\r\n <div class=\"row mb-4\">\r\n <div class=\"col-6\">\r\n <lib-reactive-select [search]=\"true\" [(ngModel)]=\"selectedStore\" [idField]=\"'value'\" [nameField]=\"'label'\"\r\n [data]=\"storeList\" [label]=\"'Select store'\" [action]=\"true\" (actionClick)=\"onClickCreateStore()\"\r\n [actionLabel]=\"'Create new store'\" (ngModelChange)=\"onStoreChange()\" [disabled]=\"isProcessing\">\r\n </lib-reactive-select>\r\n </div>\r\n <div class=\"col-6\">\r\n <lib-reactive-select [(ngModel)]=\"selectedFloor\" [idField]=\"'value'\" [nameField]=\"'label'\" [data]=\"floorList\"\r\n [label]=\"'Select floor'\" (ngModelChange)=\"onFloorChange()\" [disabled]=\"isProcessing\">\r\n </lib-reactive-select>\r\n </div>\r\n </div>\r\n <div class=\"layout-exist-wrapper\" [class.show]=\"isLayoutExist\">\r\n <div class=\"layout-exist-warning mb-4\">\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=\"M9.99965 6.66667V10M9.99965 13.3333H10.008M8.57465 2.38334L1.51632 14.1667C1.37079 14.4187 1.29379 14.7044 1.29298 14.9954C1.29216 15.2865 1.36756 15.5726 1.51167 15.8254C1.65579 16.0783 1.86359 16.289 2.11441 16.4366C2.36523 16.5841 2.65032 16.6635 2.94132 16.6667H17.058C17.349 16.6635 17.6341 16.5841 17.8849 16.4366C18.1357 16.289 18.3435 16.0783 18.4876 15.8254C18.6317 15.5726 18.7071 15.2865 18.7063 14.9954C18.7055 14.7044 18.6285 14.4187 18.483 14.1667L11.4247 2.38334C11.2761 2.13843 11.0669 1.93594 10.8173 1.79541C10.5677 1.65488 10.2861 1.58105 9.99965 1.58105C9.71321 1.58105 9.43159 1.65488 9.18199 1.79541C8.93238 1.93594 8.72321 2.13843 8.57465 2.38334Z\"\r\n stroke=\"#F04438\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n\r\n This store already has a Floor {{selectedFloor}} planogram. Overwrite it? This can\u2019t be undone.\r\n </div>\r\n </div>\r\n\r\n <div class=\"mb-4\">\r\n <file-upload [disabled]=\"isProcessing\" (fileChange)=\"onFileChange($event)\"></file-upload>\r\n\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 \" [disabled]=\"!isValidToCreate || isProcessing\" (click)=\"onCreate()\">\r\n <span *ngIf=\"!isProcessing\">\r\n {{isLayoutExist ? 'Overwrite' : 'Create'}}\r\n </span>\r\n\r\n <svg *ngIf=\"isProcessing\" 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 </button>\r\n </div>\r\n</div>", styles: [".modal-wrapper{padding:24px}.modal-actions{display:flex;justify-content:end;gap:12px}::ng-deep .counter-container{padding:10px!important;border:.49px solid #d0d5dd!important;background-color:#fff!important;justify-content:space-between!important;margin-bottom:26px!important}::ng-deep .modal-content{border-radius:12px!important}.layout-exist-warning{display:flex;align-items:center;gap:8px;padding:16px;background:#fef3f2;border:1px solid #fda29b;border-radius:8px;color:#d92d20;font-family:Inter;font-weight:600;font-size:14px;line-height:20px}.layout-exist-wrapper{overflow:hidden;max-height:0;opacity:0;transform:translateY(-8px);transition:max-height .25s ease,opacity .2s ease,transform .2s ease}.layout-exist-wrapper.show{max-height:120px;opacity:1;transform:translateY(0)}::ng-deep .create-planogram-modal .modal-dialog{max-width:700px;width:100%}.btn .spinner{height:22px;width:46px;animation:spin .9s linear infinite}.btn .spinner .path{stroke-width:6px;stroke:#fff;stroke-linecap:round;stroke-dasharray:80;stroke-dashoffset:60}@keyframes spin{to{transform:rotate(360deg)}}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "component", type: ReactiveSelectComponent, selector: "lib-reactive-select", inputs: ["idField", "nameField", "subTextField", "searchField", "label", "data", "action", "search", "prefix", "actionLabel"], outputs: ["actionClick"] }, { kind: "component", type: FileUploadComponent, selector: "file-upload", inputs: ["disabled"], outputs: ["fileChange"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
130
+ onBack() {
131
+ this.createStoreForm = null;
132
+ this.isCreateStoreMode = false;
133
+ }
134
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CreatePlanogramComponent, deps: [{ token: i1.NgbActiveModal }, { token: i2.StoreBuilderService }, { token: i3.ToastService }, { token: i4.FormBuilder }, { token: i5.Router }], target: i0.ɵɵFactoryTarget.Component });
135
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: CreatePlanogramComponent, isStandalone: true, selector: "app-create-planogram", inputs: { clientId: "clientId" }, ngImport: i0, template: "<div class=\"modal-wrapper\">\r\n <h3 class=\"mb-4\">Create store layout/plan from CAD</h3>\r\n @if(isCreateStoreMode){\r\n <form [formGroup]=\"createStoreForm\">\r\n <div class=\"row mb-4\">\r\n <div class=\"col-6 mb-4\">\r\n <label for=\"storeName\" class=\"form-label mb-1\">Store name</label>\r\n <input type=\"text\" class=\"form-control\" id=\"storeName\" formControlName=\"storeName\"\r\n placeholder=\"Type store name\" />\r\n <ng-container *ngIf=\"createStoreForm.get('storeName')?.touched && createStoreForm.get('storeName')?.invalid\">\r\n <small class=\"text-danger\" *ngIf=\"createStoreForm.get('storeName')?.hasError('required')\">\r\n Store name is required.\r\n </small>\r\n </ng-container>\r\n </div>\r\n <div class=\"col-6 mb-4\"></div>\r\n <div class=\"col-6 mb-4\">\r\n <lib-reactive-select [idField]=\"'value'\" [nameField]=\"'label'\" [data]=\"businessTypeList\"\r\n [label]=\"'Select business type'\" formControlName=\"businessType\">\r\n </lib-reactive-select>\r\n </div>\r\n <div class=\"col-6 mb-4\">\r\n <lib-reactive-select [idField]=\"'value'\" [nameField]=\"'label'\" [data]=\"storeTypeList\"\r\n [label]=\"'Select store type'\" formControlName=\"storeType\">\r\n </lib-reactive-select>\r\n </div>\r\n <div class=\"col-12 mb-4\">\r\n <label for=\"address\" class=\"form-label mb-1\">Address</label>\r\n <input type=\"text\" class=\"form-control\" id=\"address\" formControlName=\"address\"\r\n placeholder=\"Search and enter address\" />\r\n <ng-container *ngIf=\"createStoreForm.get('address')?.touched && createStoreForm.get('address')?.invalid\">\r\n <small class=\"text-danger\" *ngIf=\"createStoreForm.get('address')?.hasError('required')\">\r\n Address is required.\r\n </small>\r\n </ng-container>\r\n </div>\r\n <div class=\"col-6 mb-4\">\r\n <label for=\"country\" class=\"form-label mb-1\">Country</label>\r\n <input type=\"text\" class=\"form-control\" id=\"country\" formControlName=\"country\" placeholder=\"Enter Country\" />\r\n <ng-container *ngIf=\"createStoreForm.get('country')?.touched && createStoreForm.get('country')?.invalid\">\r\n <small class=\"text-danger\" *ngIf=\"createStoreForm.get('country')?.hasError('required')\">\r\n Country is required.\r\n </small>\r\n </ng-container>\r\n </div>\r\n <div class=\"col-6 mb-4\">\r\n <label for=\"state\" class=\"form-label mb-1\">State</label>\r\n <input type=\"text\" class=\"form-control\" id=\"state\" formControlName=\"state\" placeholder=\"Enter State\" />\r\n <ng-container *ngIf=\"createStoreForm.get('state')?.touched && createStoreForm.get('state')?.invalid\">\r\n <small class=\"text-danger\" *ngIf=\"createStoreForm.get('state')?.hasError('required')\">\r\n State is required.\r\n </small>\r\n </ng-container>\r\n </div>\r\n <div class=\"col-6 mb-4\">\r\n <label for=\"city\" class=\"form-label mb-1\">City / Town</label>\r\n <input type=\"text\" class=\"form-control\" id=\"city\" formControlName=\"city\" placeholder=\"Enter City / Town\" />\r\n <ng-container *ngIf=\"createStoreForm.get('city')?.touched && createStoreForm.get('city')?.invalid\">\r\n <small class=\"text-danger\" *ngIf=\"createStoreForm.get('city')?.hasError('required')\">\r\n City / Town is required.\r\n </small>\r\n </ng-container>\r\n </div>\r\n <div class=\"col-6 mb-4\">\r\n <label for=\"zipCode\" class=\"form-label mb-1\">Pin / Zip Code</label>\r\n <input type=\"text\" class=\"form-control\" id=\"zipCode\" formControlName=\"zipCode\"\r\n placeholder=\"Enter Pin / Zip Code\" />\r\n <ng-container *ngIf=\"createStoreForm.get('zipCode')?.touched && createStoreForm.get('zipCode')?.invalid\">\r\n <small class=\"text-danger\" *ngIf=\"createStoreForm.get('zipCode')?.hasError('required')\">\r\n Pin / Zip Code is required.\r\n </small>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </form>\r\n }\r\n @else {\r\n <div class=\"row mb-4\">\r\n <div class=\"col-6\">\r\n <lib-reactive-select [search]=\"true\" [(ngModel)]=\"selectedStore\" [idField]=\"'value'\" [nameField]=\"'label'\"\r\n [data]=\"storeList\" [label]=\"'Select store'\" [action]=\"true\" (actionClick)=\"addNewStore()\"\r\n [actionLabel]=\"'Create new store'\" (ngModelChange)=\"onStoreChange()\" [disabled]=\"isCADProcessing\">\r\n </lib-reactive-select>\r\n </div>\r\n <div class=\"col-6\">\r\n <lib-reactive-select [(ngModel)]=\"selectedFloor\" [idField]=\"'value'\" [nameField]=\"'label'\" [data]=\"floorList\"\r\n [label]=\"'Select floor'\" (ngModelChange)=\"onFloorChange()\" [disabled]=\"isCADProcessing\">\r\n </lib-reactive-select>\r\n </div>\r\n </div>\r\n <div class=\"layout-exist-wrapper\" [class.show]=\"isLayoutExist\">\r\n <div class=\"layout-exist-warning mb-4\">\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=\"M9.99965 6.66667V10M9.99965 13.3333H10.008M8.57465 2.38334L1.51632 14.1667C1.37079 14.4187 1.29379 14.7044 1.29298 14.9954C1.29216 15.2865 1.36756 15.5726 1.51167 15.8254C1.65579 16.0783 1.86359 16.289 2.11441 16.4366C2.36523 16.5841 2.65032 16.6635 2.94132 16.6667H17.058C17.349 16.6635 17.6341 16.5841 17.8849 16.4366C18.1357 16.289 18.3435 16.0783 18.4876 15.8254C18.6317 15.5726 18.7071 15.2865 18.7063 14.9954C18.7055 14.7044 18.6285 14.4187 18.483 14.1667L11.4247 2.38334C11.2761 2.13843 11.0669 1.93594 10.8173 1.79541C10.5677 1.65488 10.2861 1.58105 9.99965 1.58105C9.71321 1.58105 9.43159 1.65488 9.18199 1.79541C8.93238 1.93594 8.72321 2.13843 8.57465 2.38334Z\"\r\n stroke=\"#F04438\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n\r\n This store already has a Floor {{selectedFloor}} planogram. Overwrite it? This can\u2019t be undone.\r\n </div>\r\n </div>\r\n\r\n <div class=\"mb-4\">\r\n <file-upload [disabled]=\"isCADProcessing\" (fileChange)=\"onFileChange($event)\"></file-upload>\r\n\r\n </div>\r\n }\r\n <div class=\"modal-actions\">\r\n @if(isCreateStoreMode){\r\n <button type=\"button\" class=\"btn btn-link me-auto\" (click)=\"onBack()\">Back</button>\r\n <button type=\"button\" class=\"btn btn-outline\" (click)=\"onCancel()\">Cancel</button>\r\n <button type=\"button\" class=\"btn btn-primary \" [disabled]=\"createStoreForm.invalid\" (click)=\"onCreateStore()\">\r\n Create\r\n </button>\r\n }@else {\r\n <button type=\"button\" class=\"btn btn-outline\" (click)=\"onCancel()\">Cancel</button>\r\n <button type=\"button\" class=\"btn btn-primary \" [disabled]=\"!isValidToCreatePlano || isCADProcessing\"\r\n (click)=\"onCreateLayoutPlano()\">\r\n <span *ngIf=\"!isCADProcessing\">\r\n {{isLayoutExist ? 'Overwrite' : 'Create'}}\r\n </span>\r\n\r\n <svg *ngIf=\"isCADProcessing\" 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 </button>\r\n }\r\n </div>\r\n</div>", styles: [".modal-wrapper{padding:24px}.modal-actions{display:flex;justify-content:end;gap:12px}::ng-deep .counter-container{padding:10px!important;border:.49px solid #d0d5dd!important;background-color:#fff!important;justify-content:space-between!important;margin-bottom:26px!important}::ng-deep .modal-content{border-radius:12px!important}.layout-exist-warning{display:flex;align-items:center;gap:8px;padding:16px;background:#fef3f2;border:1px solid #fda29b;border-radius:8px;color:#d92d20;font-family:Inter;font-weight:600;font-size:14px;line-height:20px}.layout-exist-wrapper{overflow:hidden;max-height:0;opacity:0;transform:translateY(-8px);transition:max-height .25s ease,opacity .2s ease,transform .2s ease}.layout-exist-wrapper.show{max-height:120px;opacity:1;transform:translateY(0)}::ng-deep .create-planogram-modal .modal-dialog{max-width:700px;width:100%}.btn .spinner{height:22px;width:46px;animation:spin .9s linear infinite}.btn .spinner .path{stroke-width:6px;stroke:#fff;stroke-linecap:round;stroke-dasharray:80;stroke-dashoffset:60}@keyframes spin{to{transform:rotate(360deg)}}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i4.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i4.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: ReactiveSelectComponent, selector: "lib-reactive-select", inputs: ["idField", "nameField", "subTextField", "searchField", "label", "data", "action", "search", "prefix", "actionLabel"], outputs: ["actionClick"] }, { kind: "component", type: FileUploadComponent, selector: "file-upload", inputs: ["disabled"], outputs: ["fileChange"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
99
136
  }
100
137
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CreatePlanogramComponent, decorators: [{
101
138
  type: Component,
@@ -105,8 +142,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
105
142
  ReactiveSelectComponent,
106
143
  FileUploadComponent,
107
144
  NgIf,
108
- ], template: "<div class=\"modal-wrapper\">\r\n <h3 class=\"mb-4\">Create store layout/plan from CAD</h3>\r\n <div class=\"row mb-4\">\r\n <div class=\"col-6\">\r\n <lib-reactive-select [search]=\"true\" [(ngModel)]=\"selectedStore\" [idField]=\"'value'\" [nameField]=\"'label'\"\r\n [data]=\"storeList\" [label]=\"'Select store'\" [action]=\"true\" (actionClick)=\"onClickCreateStore()\"\r\n [actionLabel]=\"'Create new store'\" (ngModelChange)=\"onStoreChange()\" [disabled]=\"isProcessing\">\r\n </lib-reactive-select>\r\n </div>\r\n <div class=\"col-6\">\r\n <lib-reactive-select [(ngModel)]=\"selectedFloor\" [idField]=\"'value'\" [nameField]=\"'label'\" [data]=\"floorList\"\r\n [label]=\"'Select floor'\" (ngModelChange)=\"onFloorChange()\" [disabled]=\"isProcessing\">\r\n </lib-reactive-select>\r\n </div>\r\n </div>\r\n <div class=\"layout-exist-wrapper\" [class.show]=\"isLayoutExist\">\r\n <div class=\"layout-exist-warning mb-4\">\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=\"M9.99965 6.66667V10M9.99965 13.3333H10.008M8.57465 2.38334L1.51632 14.1667C1.37079 14.4187 1.29379 14.7044 1.29298 14.9954C1.29216 15.2865 1.36756 15.5726 1.51167 15.8254C1.65579 16.0783 1.86359 16.289 2.11441 16.4366C2.36523 16.5841 2.65032 16.6635 2.94132 16.6667H17.058C17.349 16.6635 17.6341 16.5841 17.8849 16.4366C18.1357 16.289 18.3435 16.0783 18.4876 15.8254C18.6317 15.5726 18.7071 15.2865 18.7063 14.9954C18.7055 14.7044 18.6285 14.4187 18.483 14.1667L11.4247 2.38334C11.2761 2.13843 11.0669 1.93594 10.8173 1.79541C10.5677 1.65488 10.2861 1.58105 9.99965 1.58105C9.71321 1.58105 9.43159 1.65488 9.18199 1.79541C8.93238 1.93594 8.72321 2.13843 8.57465 2.38334Z\"\r\n stroke=\"#F04438\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n\r\n This store already has a Floor {{selectedFloor}} planogram. Overwrite it? This can\u2019t be undone.\r\n </div>\r\n </div>\r\n\r\n <div class=\"mb-4\">\r\n <file-upload [disabled]=\"isProcessing\" (fileChange)=\"onFileChange($event)\"></file-upload>\r\n\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 \" [disabled]=\"!isValidToCreate || isProcessing\" (click)=\"onCreate()\">\r\n <span *ngIf=\"!isProcessing\">\r\n {{isLayoutExist ? 'Overwrite' : 'Create'}}\r\n </span>\r\n\r\n <svg *ngIf=\"isProcessing\" 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 </button>\r\n </div>\r\n</div>", styles: [".modal-wrapper{padding:24px}.modal-actions{display:flex;justify-content:end;gap:12px}::ng-deep .counter-container{padding:10px!important;border:.49px solid #d0d5dd!important;background-color:#fff!important;justify-content:space-between!important;margin-bottom:26px!important}::ng-deep .modal-content{border-radius:12px!important}.layout-exist-warning{display:flex;align-items:center;gap:8px;padding:16px;background:#fef3f2;border:1px solid #fda29b;border-radius:8px;color:#d92d20;font-family:Inter;font-weight:600;font-size:14px;line-height:20px}.layout-exist-wrapper{overflow:hidden;max-height:0;opacity:0;transform:translateY(-8px);transition:max-height .25s ease,opacity .2s ease,transform .2s ease}.layout-exist-wrapper.show{max-height:120px;opacity:1;transform:translateY(0)}::ng-deep .create-planogram-modal .modal-dialog{max-width:700px;width:100%}.btn .spinner{height:22px;width:46px;animation:spin .9s linear infinite}.btn .spinner .path{stroke-width:6px;stroke:#fff;stroke-linecap:round;stroke-dasharray:80;stroke-dashoffset:60}@keyframes spin{to{transform:rotate(360deg)}}\n"] }]
109
- }], ctorParameters: () => [{ type: i1.NgbActiveModal }, { type: i2.StoreBuilderService }, { type: i3.ToastService }], propDecorators: { clientId: [{
145
+ ], template: "<div class=\"modal-wrapper\">\r\n <h3 class=\"mb-4\">Create store layout/plan from CAD</h3>\r\n @if(isCreateStoreMode){\r\n <form [formGroup]=\"createStoreForm\">\r\n <div class=\"row mb-4\">\r\n <div class=\"col-6 mb-4\">\r\n <label for=\"storeName\" class=\"form-label mb-1\">Store name</label>\r\n <input type=\"text\" class=\"form-control\" id=\"storeName\" formControlName=\"storeName\"\r\n placeholder=\"Type store name\" />\r\n <ng-container *ngIf=\"createStoreForm.get('storeName')?.touched && createStoreForm.get('storeName')?.invalid\">\r\n <small class=\"text-danger\" *ngIf=\"createStoreForm.get('storeName')?.hasError('required')\">\r\n Store name is required.\r\n </small>\r\n </ng-container>\r\n </div>\r\n <div class=\"col-6 mb-4\"></div>\r\n <div class=\"col-6 mb-4\">\r\n <lib-reactive-select [idField]=\"'value'\" [nameField]=\"'label'\" [data]=\"businessTypeList\"\r\n [label]=\"'Select business type'\" formControlName=\"businessType\">\r\n </lib-reactive-select>\r\n </div>\r\n <div class=\"col-6 mb-4\">\r\n <lib-reactive-select [idField]=\"'value'\" [nameField]=\"'label'\" [data]=\"storeTypeList\"\r\n [label]=\"'Select store type'\" formControlName=\"storeType\">\r\n </lib-reactive-select>\r\n </div>\r\n <div class=\"col-12 mb-4\">\r\n <label for=\"address\" class=\"form-label mb-1\">Address</label>\r\n <input type=\"text\" class=\"form-control\" id=\"address\" formControlName=\"address\"\r\n placeholder=\"Search and enter address\" />\r\n <ng-container *ngIf=\"createStoreForm.get('address')?.touched && createStoreForm.get('address')?.invalid\">\r\n <small class=\"text-danger\" *ngIf=\"createStoreForm.get('address')?.hasError('required')\">\r\n Address is required.\r\n </small>\r\n </ng-container>\r\n </div>\r\n <div class=\"col-6 mb-4\">\r\n <label for=\"country\" class=\"form-label mb-1\">Country</label>\r\n <input type=\"text\" class=\"form-control\" id=\"country\" formControlName=\"country\" placeholder=\"Enter Country\" />\r\n <ng-container *ngIf=\"createStoreForm.get('country')?.touched && createStoreForm.get('country')?.invalid\">\r\n <small class=\"text-danger\" *ngIf=\"createStoreForm.get('country')?.hasError('required')\">\r\n Country is required.\r\n </small>\r\n </ng-container>\r\n </div>\r\n <div class=\"col-6 mb-4\">\r\n <label for=\"state\" class=\"form-label mb-1\">State</label>\r\n <input type=\"text\" class=\"form-control\" id=\"state\" formControlName=\"state\" placeholder=\"Enter State\" />\r\n <ng-container *ngIf=\"createStoreForm.get('state')?.touched && createStoreForm.get('state')?.invalid\">\r\n <small class=\"text-danger\" *ngIf=\"createStoreForm.get('state')?.hasError('required')\">\r\n State is required.\r\n </small>\r\n </ng-container>\r\n </div>\r\n <div class=\"col-6 mb-4\">\r\n <label for=\"city\" class=\"form-label mb-1\">City / Town</label>\r\n <input type=\"text\" class=\"form-control\" id=\"city\" formControlName=\"city\" placeholder=\"Enter City / Town\" />\r\n <ng-container *ngIf=\"createStoreForm.get('city')?.touched && createStoreForm.get('city')?.invalid\">\r\n <small class=\"text-danger\" *ngIf=\"createStoreForm.get('city')?.hasError('required')\">\r\n City / Town is required.\r\n </small>\r\n </ng-container>\r\n </div>\r\n <div class=\"col-6 mb-4\">\r\n <label for=\"zipCode\" class=\"form-label mb-1\">Pin / Zip Code</label>\r\n <input type=\"text\" class=\"form-control\" id=\"zipCode\" formControlName=\"zipCode\"\r\n placeholder=\"Enter Pin / Zip Code\" />\r\n <ng-container *ngIf=\"createStoreForm.get('zipCode')?.touched && createStoreForm.get('zipCode')?.invalid\">\r\n <small class=\"text-danger\" *ngIf=\"createStoreForm.get('zipCode')?.hasError('required')\">\r\n Pin / Zip Code is required.\r\n </small>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </form>\r\n }\r\n @else {\r\n <div class=\"row mb-4\">\r\n <div class=\"col-6\">\r\n <lib-reactive-select [search]=\"true\" [(ngModel)]=\"selectedStore\" [idField]=\"'value'\" [nameField]=\"'label'\"\r\n [data]=\"storeList\" [label]=\"'Select store'\" [action]=\"true\" (actionClick)=\"addNewStore()\"\r\n [actionLabel]=\"'Create new store'\" (ngModelChange)=\"onStoreChange()\" [disabled]=\"isCADProcessing\">\r\n </lib-reactive-select>\r\n </div>\r\n <div class=\"col-6\">\r\n <lib-reactive-select [(ngModel)]=\"selectedFloor\" [idField]=\"'value'\" [nameField]=\"'label'\" [data]=\"floorList\"\r\n [label]=\"'Select floor'\" (ngModelChange)=\"onFloorChange()\" [disabled]=\"isCADProcessing\">\r\n </lib-reactive-select>\r\n </div>\r\n </div>\r\n <div class=\"layout-exist-wrapper\" [class.show]=\"isLayoutExist\">\r\n <div class=\"layout-exist-warning mb-4\">\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=\"M9.99965 6.66667V10M9.99965 13.3333H10.008M8.57465 2.38334L1.51632 14.1667C1.37079 14.4187 1.29379 14.7044 1.29298 14.9954C1.29216 15.2865 1.36756 15.5726 1.51167 15.8254C1.65579 16.0783 1.86359 16.289 2.11441 16.4366C2.36523 16.5841 2.65032 16.6635 2.94132 16.6667H17.058C17.349 16.6635 17.6341 16.5841 17.8849 16.4366C18.1357 16.289 18.3435 16.0783 18.4876 15.8254C18.6317 15.5726 18.7071 15.2865 18.7063 14.9954C18.7055 14.7044 18.6285 14.4187 18.483 14.1667L11.4247 2.38334C11.2761 2.13843 11.0669 1.93594 10.8173 1.79541C10.5677 1.65488 10.2861 1.58105 9.99965 1.58105C9.71321 1.58105 9.43159 1.65488 9.18199 1.79541C8.93238 1.93594 8.72321 2.13843 8.57465 2.38334Z\"\r\n stroke=\"#F04438\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n\r\n This store already has a Floor {{selectedFloor}} planogram. Overwrite it? This can\u2019t be undone.\r\n </div>\r\n </div>\r\n\r\n <div class=\"mb-4\">\r\n <file-upload [disabled]=\"isCADProcessing\" (fileChange)=\"onFileChange($event)\"></file-upload>\r\n\r\n </div>\r\n }\r\n <div class=\"modal-actions\">\r\n @if(isCreateStoreMode){\r\n <button type=\"button\" class=\"btn btn-link me-auto\" (click)=\"onBack()\">Back</button>\r\n <button type=\"button\" class=\"btn btn-outline\" (click)=\"onCancel()\">Cancel</button>\r\n <button type=\"button\" class=\"btn btn-primary \" [disabled]=\"createStoreForm.invalid\" (click)=\"onCreateStore()\">\r\n Create\r\n </button>\r\n }@else {\r\n <button type=\"button\" class=\"btn btn-outline\" (click)=\"onCancel()\">Cancel</button>\r\n <button type=\"button\" class=\"btn btn-primary \" [disabled]=\"!isValidToCreatePlano || isCADProcessing\"\r\n (click)=\"onCreateLayoutPlano()\">\r\n <span *ngIf=\"!isCADProcessing\">\r\n {{isLayoutExist ? 'Overwrite' : 'Create'}}\r\n </span>\r\n\r\n <svg *ngIf=\"isCADProcessing\" 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 </button>\r\n }\r\n </div>\r\n</div>", styles: [".modal-wrapper{padding:24px}.modal-actions{display:flex;justify-content:end;gap:12px}::ng-deep .counter-container{padding:10px!important;border:.49px solid #d0d5dd!important;background-color:#fff!important;justify-content:space-between!important;margin-bottom:26px!important}::ng-deep .modal-content{border-radius:12px!important}.layout-exist-warning{display:flex;align-items:center;gap:8px;padding:16px;background:#fef3f2;border:1px solid #fda29b;border-radius:8px;color:#d92d20;font-family:Inter;font-weight:600;font-size:14px;line-height:20px}.layout-exist-wrapper{overflow:hidden;max-height:0;opacity:0;transform:translateY(-8px);transition:max-height .25s ease,opacity .2s ease,transform .2s ease}.layout-exist-wrapper.show{max-height:120px;opacity:1;transform:translateY(0)}::ng-deep .create-planogram-modal .modal-dialog{max-width:700px;width:100%}.btn .spinner{height:22px;width:46px;animation:spin .9s linear infinite}.btn .spinner .path{stroke-width:6px;stroke:#fff;stroke-linecap:round;stroke-dasharray:80;stroke-dashoffset:60}@keyframes spin{to{transform:rotate(360deg)}}\n"] }]
146
+ }], ctorParameters: () => [{ type: i1.NgbActiveModal }, { type: i2.StoreBuilderService }, { type: i3.ToastService }, { type: i4.FormBuilder }, { type: i5.Router }], propDecorators: { clientId: [{
110
147
  type: Input
111
148
  }] } });
112
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-planogram.component.js","sourceRoot":"","sources":["../../../../../../../../projects/tango-store-builder/src/lib/components/manage-plano/popups/create-planogram/create-planogram.component.ts","../../../../../../../../projects/tango-store-builder/src/lib/components/manage-plano/popups/create-planogram/create-planogram.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from \"@angular/core\";\r\nimport { NgbActiveModal } from \"@ng-bootstrap/ng-bootstrap\";\r\nimport { FormsModule, ReactiveFormsModule } from \"@angular/forms\";\r\nimport { ReactiveSelectComponent } from \"../../../reactive-select/reactive-select.component\";\r\nimport { StoreBuilderService } from \"../../../../services/store-builder.service\";\r\nimport { firstValueFrom } from \"rxjs\";\r\nimport { FileUploadComponent } from \"../../../file-upload/file-upload.component\";\r\nimport { NgIf } from \"@angular/common\";\r\nimport { ToastService } from \"tango-app-ui-shared\";\r\n\r\n@Component({\r\n  selector: \"app-create-planogram\",\r\n  templateUrl: \"./create-planogram.component.html\",\r\n  styleUrl: \"./create-planogram.component.scss\",\r\n  standalone: true,\r\n  imports: [\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    ReactiveSelectComponent,\r\n    FileUploadComponent,\r\n    NgIf,\r\n  ],\r\n})\r\nexport class CreatePlanogramComponent implements OnInit {\r\n  @Input() clientId: string;\r\n  selectedStore: string;\r\n  selectedFloor: number;\r\n  selectedFile: File | null = null;\r\n\r\n  storeList: {\r\n    label: string;\r\n    value: string;\r\n  }[] = [];\r\n\r\n  floorList: {\r\n    label: string;\r\n    value: number;\r\n  }[] = [\r\n    { label: \"Floor 1\", value: 1 },\r\n    { label: \"Floor 2\", value: 2 },\r\n    { label: \"Floor 3\", value: 3 },\r\n  ];\r\n\r\n  selectedStoreFloors: any = [];\r\n\r\n  isLayoutExist: boolean = false;\r\n  isProcessing: boolean = false;\r\n  isCreateStoreMode: boolean = false;\r\n\r\n  constructor(\r\n    private activeModal: NgbActiveModal,\r\n    private storeBuilderService: StoreBuilderService,\r\n    private toastService: ToastService\r\n  ) {}\r\n\r\n  async ngOnInit(): Promise<void> {\r\n    await this.getStoreList();\r\n  }\r\n\r\n  get isValidToCreate() {\r\n    return this.selectedStore && this.selectedFloor && this.selectedFile;\r\n  }\r\n\r\n  async getStoreList() {\r\n    try {\r\n      const stores: any = await firstValueFrom(\r\n        this.storeBuilderService.getAllStores(this.clientId)\r\n      );\r\n      this.storeList = stores?.data?.map((s: any) => {\r\n        return { label: s.storeName, value: s.storeId };\r\n      });\r\n    } catch (error) {\r\n      console.log(\"@@ ~ getStoreList [ERR]:\", error);\r\n    }\r\n  }\r\n\r\n  async onStoreChange() {\r\n    try {\r\n      const floors: any = await firstValueFrom(\r\n        this.storeBuilderService.getStoreFloorsList(this.selectedStore)\r\n      );\r\n      this.selectedStoreFloors = floors?.data ?? [];\r\n      this.onFloorChange();\r\n    } catch (error) {\r\n      console.log(\"@@ ~ getStoreList [ERR]:\", error);\r\n    }\r\n  }\r\n\r\n  onFloorChange() {\r\n    if (this.selectedFloor) {\r\n      this.isLayoutExist = this.selectedStoreFloors.some(\r\n        (f: any) => f.floorNumber === this.selectedFloor\r\n      );\r\n    } else {\r\n      this.isLayoutExist = false;\r\n    }\r\n  }\r\n\r\n  onFileChange(file: File | null) {\r\n    this.selectedFile = file;\r\n  }\r\n\r\n  async onCreate() {\r\n    if (!this.isValidToCreate) return;\r\n\r\n    try {\r\n      this.isProcessing = true;\r\n\r\n      const planoRes: any = await firstValueFrom(\r\n        this.storeBuilderService.createPlanoFromCAD(\r\n          this.selectedFile!,\r\n          this.selectedStore,\r\n          this.selectedFloor\r\n        )\r\n      );\r\n\r\n      if (!planoRes?.data) return;\r\n\r\n      this.activeModal.close(planoRes?.data);\r\n    } catch (error: any) {\r\n      this.toastService.getErrorToast(\r\n        error?.error?.error?.errMsg ?? \"Failed to extract plano from CAD file.\"\r\n      );\r\n      console.log(\"@@ ~ onCreate [ERR]:\", error);\r\n    } finally {\r\n      this.isProcessing = false;\r\n    }\r\n  }\r\n\r\n  onClickCreateStore() {\r\n    this.isCreateStoreMode = 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-4\">Create store layout/plan from CAD</h3>\r\n  <div class=\"row mb-4\">\r\n    <div class=\"col-6\">\r\n      <lib-reactive-select [search]=\"true\" [(ngModel)]=\"selectedStore\" [idField]=\"'value'\" [nameField]=\"'label'\"\r\n        [data]=\"storeList\" [label]=\"'Select store'\" [action]=\"true\" (actionClick)=\"onClickCreateStore()\"\r\n        [actionLabel]=\"'Create new store'\" (ngModelChange)=\"onStoreChange()\" [disabled]=\"isProcessing\">\r\n      </lib-reactive-select>\r\n    </div>\r\n    <div class=\"col-6\">\r\n      <lib-reactive-select [(ngModel)]=\"selectedFloor\" [idField]=\"'value'\" [nameField]=\"'label'\" [data]=\"floorList\"\r\n        [label]=\"'Select floor'\" (ngModelChange)=\"onFloorChange()\" [disabled]=\"isProcessing\">\r\n      </lib-reactive-select>\r\n    </div>\r\n  </div>\r\n  <div class=\"layout-exist-wrapper\" [class.show]=\"isLayoutExist\">\r\n    <div class=\"layout-exist-warning mb-4\">\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=\"M9.99965 6.66667V10M9.99965 13.3333H10.008M8.57465 2.38334L1.51632 14.1667C1.37079 14.4187 1.29379 14.7044 1.29298 14.9954C1.29216 15.2865 1.36756 15.5726 1.51167 15.8254C1.65579 16.0783 1.86359 16.289 2.11441 16.4366C2.36523 16.5841 2.65032 16.6635 2.94132 16.6667H17.058C17.349 16.6635 17.6341 16.5841 17.8849 16.4366C18.1357 16.289 18.3435 16.0783 18.4876 15.8254C18.6317 15.5726 18.7071 15.2865 18.7063 14.9954C18.7055 14.7044 18.6285 14.4187 18.483 14.1667L11.4247 2.38334C11.2761 2.13843 11.0669 1.93594 10.8173 1.79541C10.5677 1.65488 10.2861 1.58105 9.99965 1.58105C9.71321 1.58105 9.43159 1.65488 9.18199 1.79541C8.93238 1.93594 8.72321 2.13843 8.57465 2.38334Z\"\r\n          stroke=\"#F04438\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n      </svg>\r\n\r\n      This store already has a Floor {{selectedFloor}} planogram. Overwrite it? This can’t be undone.\r\n    </div>\r\n  </div>\r\n\r\n  <div class=\"mb-4\">\r\n    <file-upload [disabled]=\"isProcessing\" (fileChange)=\"onFileChange($event)\"></file-upload>\r\n\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 \" [disabled]=\"!isValidToCreate || isProcessing\" (click)=\"onCreate()\">\r\n      <span *ngIf=\"!isProcessing\">\r\n        {{isLayoutExist ?  'Overwrite' : 'Create'}}\r\n      </span>\r\n\r\n      <svg *ngIf=\"isProcessing\" 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    </button>\r\n  </div>\r\n</div>"]}
149
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-planogram.component.js","sourceRoot":"","sources":["../../../../../../../../projects/tango-store-builder/src/lib/components/manage-plano/popups/create-planogram/create-planogram.component.ts","../../../../../../../../projects/tango-store-builder/src/lib/components/manage-plano/popups/create-planogram/create-planogram.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AAEzD,OAAO,EAEL,WAAW,EACX,mBAAmB,GAEpB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,uBAAuB,EAAE,MAAM,oDAAoD,CAAC;AAE7F,OAAO,EAAE,cAAc,EAAE,MAAM,MAAM,CAAC;AACtC,OAAO,EAAE,mBAAmB,EAAE,MAAM,4CAA4C,CAAC;AACjF,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;;;;;;;AAiBvC,MAAM,OAAO,wBAAwB;IA+CzB;IACA;IACA;IACA;IACA;IAlDD,QAAQ,CAAS;IAC1B,aAAa,CAAS;IACtB,aAAa,CAAS;IACtB,YAAY,GAAgB,IAAI,CAAC;IAEjC,SAAS,GAGH,EAAE,CAAC;IAET,SAAS,GAGH;QACJ,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE;QAC9B,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE;QAC9B,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE;KAC/B,CAAC;IAEF,mBAAmB,GAAQ,EAAE,CAAC;IAE9B,aAAa,GAAY,KAAK,CAAC;IAC/B,eAAe,GAAY,KAAK,CAAC;IACjC,iBAAiB,GAAY,KAAK,CAAC;IAEnC,eAAe,CAAM;IACrB,aAAa,GAGP;QACJ,EAAE,KAAK,EAAE,aAAa,EAAE,KAAK,EAAE,YAAY,EAAE;QAC7C,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE;QAChC,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE;KACnC,CAAC;IAEF,gBAAgB,GAGV;QACJ,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE;QAChC,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE;QAChC,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE;QAChC,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE;KACjC,CAAC;IAEF,YACU,WAA2B,EAC3B,mBAAwC,EACxC,YAA0B,EAC1B,EAAe,EACf,MAAa;QAJb,gBAAW,GAAX,WAAW,CAAgB;QAC3B,wBAAmB,GAAnB,mBAAmB,CAAqB;QACxC,iBAAY,GAAZ,YAAY,CAAc;QAC1B,OAAE,GAAF,EAAE,CAAa;QACf,WAAM,GAAN,MAAM,CAAO;IACpB,CAAC;IAEJ,KAAK,CAAC,QAAQ;QACZ,MAAM,IAAI,CAAC,YAAY,EAAE,CAAC;IAC5B,CAAC;IAED,IAAI,oBAAoB;QACtB,OAAO,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,YAAY,CAAC;IACvE,CAAC;IAED,KAAK,CAAC,YAAY;QAChB,IAAI;YACF,MAAM,MAAM,GAAQ,MAAM,cAAc,CACtC,IAAI,CAAC,mBAAmB,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CACrD,CAAC;YACF,IAAI,CAAC,SAAS,GAAG,MAAM,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC,CAAM,EAAE,EAAE;gBAC5C,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC;YAClD,CAAC,CAAC,CAAC;SACJ;QAAC,OAAO,KAAK,EAAE;YACd,OAAO,CAAC,GAAG,CAAC,0BAA0B,EAAE,KAAK,CAAC,CAAC;SAChD;IACH,CAAC;IAED,KAAK,CAAC,aAAa;QACjB,IAAI;YACF,MAAM,MAAM,GAAQ,MAAM,cAAc,CACtC,IAAI,CAAC,mBAAmB,CAAC,kBAAkB,CAAC,IAAI,CAAC,aAAa,CAAC,CAChE,CAAC;YACF,IAAI,CAAC,mBAAmB,GAAG,MAAM,EAAE,IAAI,IAAI,EAAE,CAAC;YAC9C,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;QAAC,OAAO,KAAK,EAAE;YACd,OAAO,CAAC,GAAG,CAAC,0BAA0B,EAAE,KAAK,CAAC,CAAC;SAChD;IACH,CAAC;IAED,aAAa;QACX,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAChD,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,KAAK,IAAI,CAAC,aAAa,CACjD,CAAC;SACH;aAAM;YACL,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;SAC5B;IACH,CAAC;IAED,YAAY,CAAC,IAAiB;QAC5B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;IAC3B,CAAC;IAED,KAAK,CAAC,mBAAmB;QACvB,IAAI,CAAC,IAAI,CAAC,oBAAoB;YAAE,OAAO;QAEvC,IAAI;YACF,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;YAE5B,MAAM,QAAQ,GAAQ,MAAM,cAAc,CACxC,IAAI,CAAC,mBAAmB,CAAC,kBAAkB,CACzC,IAAI,CAAC,YAAa,EAClB,IAAI,CAAC,aAAa,EAClB,IAAI,CAAC,aAAa,CACnB,CACF,CAAC;YAEF,IAAI,CAAC,QAAQ,EAAE,IAAI;gBAAE,OAAO;YAE5B,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;SACxC;QAAC,OAAO,KAAU,EAAE;YACnB,IAAI,CAAC,YAAY,CAAC,aAAa,CAC7B,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,IAAI,wCAAwC,CACxE,CAAC;YACF,OAAO,CAAC,GAAG,CAAC,sBAAsB,EAAE,KAAK,CAAC,CAAC;SAC5C;gBAAS;YACR,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;SAC9B;IACH,CAAC;IAED,KAAK,CAAC,aAAa;QACjB,yEAAyE;IAC3E,CAAC;IAED,WAAW;QACT,iCAAiC;QACjC,yCAAyC;QACzC,0CAA0C;QAC1C,6CAA6C;QAC7C,0CAA0C;QAC1C,wCAAwC;QACxC,wCAAwC;QACxC,sCAAsC;QACtC,qCAAqC;QACrC,wCAAwC;QACxC,MAAM;QAEN,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,iCAAiC,CAAC,CAAC,CAAC;QAE/E,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;QAC9C,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;IAC7B,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;IAC7B,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC5B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;IACjC,CAAC;wGA9JU,wBAAwB;4FAAxB,wBAAwB,kHC7BrC,ijPAgIM,snCD1GF,WAAW,m3BACX,mBAAmB,gVACnB,uBAAuB,yNACvB,mBAAmB,uGACnB,IAAI;;4FAGK,wBAAwB;kBAbpC,SAAS;+BACE,sBAAsB,cAGpB,IAAI,WACP;wBACP,WAAW;wBACX,mBAAmB;wBACnB,uBAAuB;wBACvB,mBAAmB;wBACnB,IAAI;qBACL;+LAGQ,QAAQ;sBAAhB,KAAK","sourcesContent":["import { Component, Input, OnInit } from \"@angular/core\";\r\nimport { NgbActiveModal } from \"@ng-bootstrap/ng-bootstrap\";\r\nimport {\r\n  FormBuilder,\r\n  FormsModule,\r\n  ReactiveFormsModule,\r\n  Validators,\r\n} from \"@angular/forms\";\r\nimport { ReactiveSelectComponent } from \"../../../reactive-select/reactive-select.component\";\r\nimport { StoreBuilderService } from \"../../../../services/store-builder.service\";\r\nimport { firstValueFrom } from \"rxjs\";\r\nimport { FileUploadComponent } from \"../../../file-upload/file-upload.component\";\r\nimport { NgIf } from \"@angular/common\";\r\nimport { ToastService } from \"tango-app-ui-shared\";\r\nimport { Router } from \"@angular/router\";\r\n\r\n@Component({\r\n  selector: \"app-create-planogram\",\r\n  templateUrl: \"./create-planogram.component.html\",\r\n  styleUrl: \"./create-planogram.component.scss\",\r\n  standalone: true,\r\n  imports: [\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    ReactiveSelectComponent,\r\n    FileUploadComponent,\r\n    NgIf,\r\n  ],\r\n})\r\nexport class CreatePlanogramComponent implements OnInit {\r\n  @Input() clientId: string;\r\n  selectedStore: string;\r\n  selectedFloor: number;\r\n  selectedFile: File | null = null;\r\n\r\n  storeList: {\r\n    label: string;\r\n    value: string;\r\n  }[] = [];\r\n\r\n  floorList: {\r\n    label: string;\r\n    value: number;\r\n  }[] = [\r\n    { label: \"Floor 1\", value: 1 },\r\n    { label: \"Floor 2\", value: 2 },\r\n    { label: \"Floor 3\", value: 3 },\r\n  ];\r\n\r\n  selectedStoreFloors: any = [];\r\n\r\n  isLayoutExist: boolean = false;\r\n  isCADProcessing: boolean = false;\r\n  isCreateStoreMode: boolean = false;\r\n\r\n  createStoreForm: any;\r\n  storeTypeList: {\r\n    label: string;\r\n    value: string;\r\n  }[] = [\r\n    { label: \"High Street\", value: \"HighStreet\" },\r\n    { label: \"Mall\", value: \"mall\" },\r\n    { label: \"Kiosk\", value: \"kiosk\" },\r\n  ];\r\n\r\n  businessTypeList: {\r\n    label: string;\r\n    value: string;\r\n  }[] = [\r\n    { label: \"COCO\", value: \"coco\" },\r\n    { label: \"COFO\", value: \"cofo\" },\r\n    { label: \"FOFO\", value: \"fofo\" },\r\n    { label: \"FOCO\", value: \"foco\" },\r\n  ];\r\n\r\n  constructor(\r\n    private activeModal: NgbActiveModal,\r\n    private storeBuilderService: StoreBuilderService,\r\n    private toastService: ToastService,\r\n    private fb: FormBuilder,\r\n    private router:Router,\r\n  ) {}\r\n\r\n  async ngOnInit(): Promise<void> {\r\n    await this.getStoreList();\r\n  }\r\n\r\n  get isValidToCreatePlano() {\r\n    return this.selectedStore && this.selectedFloor && this.selectedFile;\r\n  }\r\n\r\n  async getStoreList() {\r\n    try {\r\n      const stores: any = await firstValueFrom(\r\n        this.storeBuilderService.getAllStores(this.clientId)\r\n      );\r\n      this.storeList = stores?.data?.map((s: any) => {\r\n        return { label: s.storeName, value: s.storeId };\r\n      });\r\n    } catch (error) {\r\n      console.log(\"@@ ~ getStoreList [ERR]:\", error);\r\n    }\r\n  }\r\n\r\n  async onStoreChange() {\r\n    try {\r\n      const floors: any = await firstValueFrom(\r\n        this.storeBuilderService.getStoreFloorsList(this.selectedStore)\r\n      );\r\n      this.selectedStoreFloors = floors?.data ?? [];\r\n      this.onFloorChange();\r\n    } catch (error) {\r\n      console.log(\"@@ ~ getStoreList [ERR]:\", error);\r\n    }\r\n  }\r\n\r\n  onFloorChange() {\r\n    if (this.selectedFloor) {\r\n      this.isLayoutExist = this.selectedStoreFloors.some(\r\n        (f: any) => f.floorNumber === this.selectedFloor\r\n      );\r\n    } else {\r\n      this.isLayoutExist = false;\r\n    }\r\n  }\r\n\r\n  onFileChange(file: File | null) {\r\n    this.selectedFile = file;\r\n  }\r\n\r\n  async onCreateLayoutPlano() {\r\n    if (!this.isValidToCreatePlano) return;\r\n\r\n    try {\r\n      this.isCADProcessing = true;\r\n\r\n      const planoRes: any = await firstValueFrom(\r\n        this.storeBuilderService.createPlanoFromCAD(\r\n          this.selectedFile!,\r\n          this.selectedStore,\r\n          this.selectedFloor\r\n        )\r\n      );\r\n\r\n      if (!planoRes?.data) return;\r\n\r\n      this.activeModal.close(planoRes?.data);\r\n    } catch (error: any) {\r\n      this.toastService.getErrorToast(\r\n        error?.error?.error?.errMsg ?? \"Failed to extract plano from CAD file.\"\r\n      );\r\n      console.log(\"@@ ~ onCreate [ERR]:\", error);\r\n    } finally {\r\n      this.isCADProcessing = false;\r\n    }\r\n  }\r\n\r\n  async onCreateStore() {\r\n    // console.log(\"@@ ~ this.createStoreForm:\", this.createStoreForm.value);\r\n  }\r\n\r\n  addNewStore() {\r\n    // this.isCreateStoreMode = true;\r\n    // this.createStoreForm = this.fb.group({\r\n    //   storeName: [\"\", Validators.required],\r\n    //   businessType: [\"\", Validators.required],\r\n    //   storeType: [\"\", Validators.required],\r\n    //   address: [\"\", Validators.required],\r\n    //   country: [\"\", Validators.required],\r\n    //   state: [\"\", Validators.required],\r\n    //   city: [\"\", Validators.required],\r\n    //   zipCode: [\"\", Validators.required],\r\n    // });\r\n\r\n    const urlTree = this.router.createUrlTree([\"/manage/stores/add-single-store\"]);\r\n\r\n    const url = this.router.serializeUrl(urlTree);\r\n    window.open(url, \"_blank\");\r\n  }\r\n\r\n  onCancel() {\r\n    this.activeModal.dismiss();\r\n  }\r\n\r\n  onBack(){\r\n    this.createStoreForm = null;\r\n    this.isCreateStoreMode = false;\r\n  }\r\n}\r\n","<div class=\"modal-wrapper\">\r\n  <h3 class=\"mb-4\">Create store layout/plan from CAD</h3>\r\n  @if(isCreateStoreMode){\r\n    <form [formGroup]=\"createStoreForm\">\r\n      <div class=\"row mb-4\">\r\n        <div class=\"col-6 mb-4\">\r\n          <label for=\"storeName\" class=\"form-label mb-1\">Store name</label>\r\n          <input type=\"text\" class=\"form-control\" id=\"storeName\" formControlName=\"storeName\"\r\n            placeholder=\"Type store name\" />\r\n          <ng-container *ngIf=\"createStoreForm.get('storeName')?.touched && createStoreForm.get('storeName')?.invalid\">\r\n            <small class=\"text-danger\" *ngIf=\"createStoreForm.get('storeName')?.hasError('required')\">\r\n              Store name is required.\r\n            </small>\r\n          </ng-container>\r\n        </div>\r\n        <div class=\"col-6 mb-4\"></div>\r\n        <div class=\"col-6 mb-4\">\r\n          <lib-reactive-select [idField]=\"'value'\" [nameField]=\"'label'\" [data]=\"businessTypeList\"\r\n            [label]=\"'Select business type'\" formControlName=\"businessType\">\r\n          </lib-reactive-select>\r\n        </div>\r\n        <div class=\"col-6 mb-4\">\r\n          <lib-reactive-select [idField]=\"'value'\" [nameField]=\"'label'\" [data]=\"storeTypeList\"\r\n            [label]=\"'Select store type'\" formControlName=\"storeType\">\r\n          </lib-reactive-select>\r\n        </div>\r\n        <div class=\"col-12 mb-4\">\r\n          <label for=\"address\" class=\"form-label mb-1\">Address</label>\r\n          <input type=\"text\" class=\"form-control\" id=\"address\" formControlName=\"address\"\r\n            placeholder=\"Search and enter address\" />\r\n          <ng-container *ngIf=\"createStoreForm.get('address')?.touched && createStoreForm.get('address')?.invalid\">\r\n            <small class=\"text-danger\" *ngIf=\"createStoreForm.get('address')?.hasError('required')\">\r\n              Address is required.\r\n            </small>\r\n          </ng-container>\r\n        </div>\r\n        <div class=\"col-6 mb-4\">\r\n          <label for=\"country\" class=\"form-label mb-1\">Country</label>\r\n          <input type=\"text\" class=\"form-control\" id=\"country\" formControlName=\"country\" placeholder=\"Enter Country\" />\r\n          <ng-container *ngIf=\"createStoreForm.get('country')?.touched && createStoreForm.get('country')?.invalid\">\r\n            <small class=\"text-danger\" *ngIf=\"createStoreForm.get('country')?.hasError('required')\">\r\n              Country is required.\r\n            </small>\r\n          </ng-container>\r\n        </div>\r\n        <div class=\"col-6 mb-4\">\r\n          <label for=\"state\" class=\"form-label mb-1\">State</label>\r\n          <input type=\"text\" class=\"form-control\" id=\"state\" formControlName=\"state\" placeholder=\"Enter State\" />\r\n          <ng-container *ngIf=\"createStoreForm.get('state')?.touched && createStoreForm.get('state')?.invalid\">\r\n            <small class=\"text-danger\" *ngIf=\"createStoreForm.get('state')?.hasError('required')\">\r\n              State is required.\r\n            </small>\r\n          </ng-container>\r\n        </div>\r\n        <div class=\"col-6 mb-4\">\r\n          <label for=\"city\" class=\"form-label mb-1\">City / Town</label>\r\n          <input type=\"text\" class=\"form-control\" id=\"city\" formControlName=\"city\" placeholder=\"Enter City / Town\" />\r\n          <ng-container *ngIf=\"createStoreForm.get('city')?.touched && createStoreForm.get('city')?.invalid\">\r\n            <small class=\"text-danger\" *ngIf=\"createStoreForm.get('city')?.hasError('required')\">\r\n              City / Town is required.\r\n            </small>\r\n          </ng-container>\r\n        </div>\r\n        <div class=\"col-6 mb-4\">\r\n          <label for=\"zipCode\" class=\"form-label mb-1\">Pin / Zip Code</label>\r\n          <input type=\"text\" class=\"form-control\" id=\"zipCode\" formControlName=\"zipCode\"\r\n            placeholder=\"Enter Pin / Zip Code\" />\r\n          <ng-container *ngIf=\"createStoreForm.get('zipCode')?.touched && createStoreForm.get('zipCode')?.invalid\">\r\n            <small class=\"text-danger\" *ngIf=\"createStoreForm.get('zipCode')?.hasError('required')\">\r\n              Pin / Zip Code is required.\r\n            </small>\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n    </form>\r\n  }\r\n  @else {\r\n    <div class=\"row mb-4\">\r\n      <div class=\"col-6\">\r\n        <lib-reactive-select [search]=\"true\" [(ngModel)]=\"selectedStore\" [idField]=\"'value'\" [nameField]=\"'label'\"\r\n          [data]=\"storeList\" [label]=\"'Select store'\" [action]=\"true\" (actionClick)=\"addNewStore()\"\r\n          [actionLabel]=\"'Create new store'\" (ngModelChange)=\"onStoreChange()\" [disabled]=\"isCADProcessing\">\r\n        </lib-reactive-select>\r\n      </div>\r\n      <div class=\"col-6\">\r\n        <lib-reactive-select [(ngModel)]=\"selectedFloor\" [idField]=\"'value'\" [nameField]=\"'label'\" [data]=\"floorList\"\r\n          [label]=\"'Select floor'\" (ngModelChange)=\"onFloorChange()\" [disabled]=\"isCADProcessing\">\r\n        </lib-reactive-select>\r\n      </div>\r\n    </div>\r\n    <div class=\"layout-exist-wrapper\" [class.show]=\"isLayoutExist\">\r\n      <div class=\"layout-exist-warning mb-4\">\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=\"M9.99965 6.66667V10M9.99965 13.3333H10.008M8.57465 2.38334L1.51632 14.1667C1.37079 14.4187 1.29379 14.7044 1.29298 14.9954C1.29216 15.2865 1.36756 15.5726 1.51167 15.8254C1.65579 16.0783 1.86359 16.289 2.11441 16.4366C2.36523 16.5841 2.65032 16.6635 2.94132 16.6667H17.058C17.349 16.6635 17.6341 16.5841 17.8849 16.4366C18.1357 16.289 18.3435 16.0783 18.4876 15.8254C18.6317 15.5726 18.7071 15.2865 18.7063 14.9954C18.7055 14.7044 18.6285 14.4187 18.483 14.1667L11.4247 2.38334C11.2761 2.13843 11.0669 1.93594 10.8173 1.79541C10.5677 1.65488 10.2861 1.58105 9.99965 1.58105C9.71321 1.58105 9.43159 1.65488 9.18199 1.79541C8.93238 1.93594 8.72321 2.13843 8.57465 2.38334Z\"\r\n            stroke=\"#F04438\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n        </svg>\r\n\r\n        This store already has a Floor {{selectedFloor}} planogram. Overwrite it? This can’t be undone.\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"mb-4\">\r\n      <file-upload [disabled]=\"isCADProcessing\" (fileChange)=\"onFileChange($event)\"></file-upload>\r\n\r\n    </div>\r\n  }\r\n  <div class=\"modal-actions\">\r\n    @if(isCreateStoreMode){\r\n      <button type=\"button\" class=\"btn btn-link me-auto\" (click)=\"onBack()\">Back</button>\r\n      <button type=\"button\" class=\"btn btn-outline\" (click)=\"onCancel()\">Cancel</button>\r\n      <button type=\"button\" class=\"btn btn-primary \" [disabled]=\"createStoreForm.invalid\" (click)=\"onCreateStore()\">\r\n        Create\r\n      </button>\r\n    }@else {\r\n      <button type=\"button\" class=\"btn btn-outline\" (click)=\"onCancel()\">Cancel</button>\r\n      <button type=\"button\" class=\"btn btn-primary \" [disabled]=\"!isValidToCreatePlano || isCADProcessing\"\r\n        (click)=\"onCreateLayoutPlano()\">\r\n        <span *ngIf=\"!isCADProcessing\">\r\n          {{isLayoutExist ?  'Overwrite' : 'Create'}}\r\n        </span>\r\n\r\n        <svg *ngIf=\"isCADProcessing\" 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      </button>\r\n    }\r\n  </div>\r\n</div>"]}