tango-app-ui-store-builder 1.0.20 → 1.0.22
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/fixture-overview-panel/fixture-overview-panel.component.mjs +456 -0
- package/esm2022/lib/components/fixture-template/fixture-template.component.mjs +9 -23
- package/esm2022/lib/components/manage-plano/rollout-table/rollout-table.component.mjs +179 -52
- package/esm2022/lib/components/manage-plano/verification-table/verification-table.component.mjs +200 -58
- package/esm2022/lib/components/manage-store-plano/manage-store-plano.component.mjs +71 -9
- package/esm2022/lib/components/manage-store-plano/plano-rollout/plano-rollout.component.mjs +124 -13
- package/esm2022/lib/components/manage-store-plano/rollout-feedback/rollout-feedback.component.mjs +3 -3
- package/esm2022/lib/components/manage-store-plano/verification-feedback/editable-fixture/editable-fixture.component.mjs +3 -3
- package/esm2022/lib/components/manage-store-plano/verification-feedback/verification-feedback.component.mjs +7 -6
- package/esm2022/lib/components/planogram/merch-compliance/fixture-products/fixture-products.component.mjs +3 -2
- package/esm2022/lib/components/planogram/merch-compliance/merch-compliance.component.mjs +2 -1
- package/esm2022/lib/components/planogram/plano-details-parent/plano-details-parent.component.mjs +86 -32
- package/esm2022/lib/components/planogram/plano-overview/fixture-overview/fixture-overview.component.mjs +8 -6
- package/esm2022/lib/components/planogram/plano-overview/plano-comparison/plano-comparison.component.mjs +1382 -0
- package/esm2022/lib/components/planogram/plano-overview/plano-overview.component.mjs +91 -7
- package/esm2022/lib/components/planogram/plano-table/plano-filter/plano-filter.component.mjs +9 -2
- package/esm2022/lib/components/planogram/plano-table/plano-table.component.mjs +29 -3
- package/esm2022/lib/components/popups/complete-confirmation/complete-confirmation.component.mjs +6 -3
- package/esm2022/lib/components/store-plano/store-plano.component.mjs +99 -10
- package/esm2022/lib/interfaces/planogram.interface.mjs +1 -1
- package/esm2022/lib/services/plano-data.service.mjs +6 -1
- package/esm2022/lib/services/store-builder.service.mjs +34 -1
- package/esm2022/lib/tango-store-builder.module.mjs +13 -3
- package/esm2022/lib/tango-store-plano.module.mjs +10 -4
- package/fesm2022/tango-app-ui-store-builder.mjs +3953 -1399
- package/fesm2022/tango-app-ui-store-builder.mjs.map +1 -1
- package/lib/components/fixture-overview-panel/fixture-overview-panel.component.d.ts +68 -0
- package/lib/components/fixture-template/fixture-template.component.d.ts +0 -1
- package/lib/components/manage-plano/rollout-table/rollout-table.component.d.ts +12 -10
- package/lib/components/manage-plano/verification-table/verification-table.component.d.ts +15 -13
- package/lib/components/manage-store-plano/manage-store-plano.component.d.ts +5 -0
- package/lib/components/manage-store-plano/plano-rollout/plano-rollout.component.d.ts +9 -3
- package/lib/components/planogram/plano-details-parent/plano-details-parent.component.d.ts +6 -2
- package/lib/components/planogram/plano-overview/fixture-overview/fixture-overview.component.d.ts +2 -1
- package/lib/components/planogram/plano-overview/plano-comparison/plano-comparison.component.d.ts +78 -0
- package/lib/components/planogram/plano-overview/plano-overview.component.d.ts +17 -2
- package/lib/components/planogram/plano-table/plano-filter/plano-filter.component.d.ts +2 -1
- package/lib/components/planogram/plano-table/plano-table.component.d.ts +1 -0
- package/lib/components/popups/complete-confirmation/complete-confirmation.component.d.ts +2 -1
- package/lib/components/store-plano/store-plano.component.d.ts +14 -2
- package/lib/interfaces/planogram.interface.d.ts +5 -0
- package/lib/services/plano-data.service.d.ts +3 -0
- package/lib/services/store-builder.service.d.ts +9 -0
- package/lib/tango-store-builder.module.d.ts +4 -2
- package/lib/tango-store-plano.module.d.ts +3 -1
- package/package.json +1 -1
|
@@ -0,0 +1,456 @@
|
|
|
1
|
+
import { Component, EventEmitter, inject, Input, Output, } from "@angular/core";
|
|
2
|
+
import { lastValueFrom, Subject, takeUntil } from "rxjs";
|
|
3
|
+
import { NgbActiveOffcanvas, NgbTooltip } from "@ng-bootstrap/ng-bootstrap";
|
|
4
|
+
import { SHELF_COLORS } from "../../data/fixture-template.data";
|
|
5
|
+
import { rgbToHex } from "../../functions/plano.function";
|
|
6
|
+
import { NgFor, NgIf, NgStyle } from "@angular/common";
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "../../services/store-builder.service";
|
|
9
|
+
import * as i2 from "tango-app-ui-global";
|
|
10
|
+
import * as i3 from "../../services/plano-data.service";
|
|
11
|
+
export class FixtureOverviewPanelComponent {
|
|
12
|
+
storeBuilderService;
|
|
13
|
+
gs;
|
|
14
|
+
cd;
|
|
15
|
+
dataService;
|
|
16
|
+
activeOffcanvas = inject(NgbActiveOffcanvas);
|
|
17
|
+
fixtureDetails;
|
|
18
|
+
totalFixtures = [];
|
|
19
|
+
vmList = [];
|
|
20
|
+
floorData;
|
|
21
|
+
onClose = new EventEmitter();
|
|
22
|
+
changeFixture = new EventEmitter();
|
|
23
|
+
fixtureTemplateDetails;
|
|
24
|
+
clientId;
|
|
25
|
+
imgCDN;
|
|
26
|
+
shelfColors = SHELF_COLORS;
|
|
27
|
+
fixtureImage;
|
|
28
|
+
sectionByZones = [];
|
|
29
|
+
isPageLoading = true;
|
|
30
|
+
allFixtures = [];
|
|
31
|
+
isVMInitialized = false;
|
|
32
|
+
isBCInitialized = false;
|
|
33
|
+
destroy$ = new Subject();
|
|
34
|
+
constructor(storeBuilderService, gs, cd, dataService) {
|
|
35
|
+
this.storeBuilderService = storeBuilderService;
|
|
36
|
+
this.gs = gs;
|
|
37
|
+
this.cd = cd;
|
|
38
|
+
this.dataService = dataService;
|
|
39
|
+
}
|
|
40
|
+
ngOnInit() {
|
|
41
|
+
this.gs.environment
|
|
42
|
+
.pipe(takeUntil(this.destroy$))
|
|
43
|
+
.subscribe((env) => (this.imgCDN = env.planogramCDN));
|
|
44
|
+
this.gs.dataRangeValue
|
|
45
|
+
.pipe(takeUntil(this.destroy$))
|
|
46
|
+
.subscribe(async (data) => {
|
|
47
|
+
if (data?.client) {
|
|
48
|
+
this.clientId = data?.client;
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
let headerData = JSON.parse(localStorage.getItem("header-filters"));
|
|
52
|
+
this.clientId = headerData?.client;
|
|
53
|
+
}
|
|
54
|
+
await this.getFixtureShelfDetails(this.fixtureDetails);
|
|
55
|
+
setTimeout(() => {
|
|
56
|
+
this.applyShelfColors();
|
|
57
|
+
this.handleVmPositionAndSize();
|
|
58
|
+
}, 300);
|
|
59
|
+
});
|
|
60
|
+
this.floorData?.layoutPolygon.forEach((poly) => {
|
|
61
|
+
this.allFixtures.push(...poly.fixtures);
|
|
62
|
+
});
|
|
63
|
+
this.allFixtures.push(...this.floorData?.centerFixture);
|
|
64
|
+
}
|
|
65
|
+
async ngOnChanges(changes) {
|
|
66
|
+
console.log(changes["fixtureDetails"]?.currentValue, 'changes["fixtureDetails"]?.currentValue');
|
|
67
|
+
if (changes["fixtureDetails"]?.currentValue) {
|
|
68
|
+
await this.getFixtureShelfDetails(changes["fixtureDetails"].currentValue);
|
|
69
|
+
setTimeout(() => {
|
|
70
|
+
this.applyShelfColors();
|
|
71
|
+
this.handleVmPositionAndSize();
|
|
72
|
+
}, 300);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
ngAfterViewChecked() {
|
|
76
|
+
if (!this.isBCInitialized) {
|
|
77
|
+
this.isBCInitialized = this.applyShelfColors();
|
|
78
|
+
}
|
|
79
|
+
if (!this.isVMInitialized) {
|
|
80
|
+
this.isVMInitialized = this.handleVmPositionAndSize();
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
async getFixtureShelfDetails(data) {
|
|
84
|
+
this.isPageLoading = true;
|
|
85
|
+
let payload = {
|
|
86
|
+
...(this.floorData?.revisionId) ? { revisionId: this.floorData?.revisionId } : { floorId: data?.floorId, planoId: data?.planoId },
|
|
87
|
+
fixtureId: data?._id
|
|
88
|
+
};
|
|
89
|
+
try {
|
|
90
|
+
const res = await lastValueFrom(this.storeBuilderService.getShelfDetails(payload));
|
|
91
|
+
if (res?.status === "success" && res?.data) {
|
|
92
|
+
this.fixtureTemplateDetails = {
|
|
93
|
+
...res?.data,
|
|
94
|
+
shelfConfig: res?.data?.shelves ?? [],
|
|
95
|
+
};
|
|
96
|
+
this.fixtureTemplateDetails.shelfConfig =
|
|
97
|
+
this.fixtureTemplateDetails.shelfConfig.map((s) => {
|
|
98
|
+
if (s.shelfType !== "shelf" && s.products?.length) {
|
|
99
|
+
s.distributedRows = this.distributeRoundRobin(s.products, s.trayRows);
|
|
100
|
+
}
|
|
101
|
+
return s;
|
|
102
|
+
});
|
|
103
|
+
this.fixtureImage = `${this.imgCDN}${this.fixtureTemplateDetails.fixtureImage}`;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
catch (error) {
|
|
107
|
+
console.log("@@ ~ getFixtureShelfDetails [ERR]:", error);
|
|
108
|
+
}
|
|
109
|
+
finally {
|
|
110
|
+
console.log("test");
|
|
111
|
+
this.isPageLoading = false;
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
getSelectedVM(vm) {
|
|
115
|
+
return this.vmList.find((v) => v.id === vm?.vmId);
|
|
116
|
+
}
|
|
117
|
+
handleVmPositionAndSize() {
|
|
118
|
+
const viewPort = document.getElementById("body-block-sum");
|
|
119
|
+
if (!viewPort)
|
|
120
|
+
return false;
|
|
121
|
+
const bodyWidth = viewPort.offsetWidth;
|
|
122
|
+
this.fixtureTemplateDetails?.vmConfig?.forEach((e, i) => {
|
|
123
|
+
let startShelf = e?.startYPosition ?? 1;
|
|
124
|
+
let endShelf = e?.endYPosition ??
|
|
125
|
+
this.fixtureTemplateDetails?.shelfConfig?.length ??
|
|
126
|
+
1;
|
|
127
|
+
const vm = viewPort.querySelector(`#vm${i}`);
|
|
128
|
+
if (!vm)
|
|
129
|
+
return;
|
|
130
|
+
let x = 0;
|
|
131
|
+
let y = 0;
|
|
132
|
+
let yStart = 0;
|
|
133
|
+
for (let k = 1; k < startShelf; k++) {
|
|
134
|
+
const s = getShelfDiv(k);
|
|
135
|
+
if (!s)
|
|
136
|
+
return;
|
|
137
|
+
yStart += s.offsetHeight;
|
|
138
|
+
}
|
|
139
|
+
let placementHeight = 0;
|
|
140
|
+
let placementWidth = bodyWidth;
|
|
141
|
+
for (let k = startShelf; k <= endShelf; k++) {
|
|
142
|
+
const s = getShelfDiv(k);
|
|
143
|
+
if (!s)
|
|
144
|
+
return;
|
|
145
|
+
placementHeight += s.offsetHeight;
|
|
146
|
+
}
|
|
147
|
+
let defaultW = placementWidth / 3;
|
|
148
|
+
let defaultH = placementHeight / 3;
|
|
149
|
+
let width = defaultW;
|
|
150
|
+
let height = defaultH;
|
|
151
|
+
switch (e?.xZone) {
|
|
152
|
+
case "left":
|
|
153
|
+
x = 0;
|
|
154
|
+
width = defaultW;
|
|
155
|
+
break;
|
|
156
|
+
case "right":
|
|
157
|
+
width = defaultW;
|
|
158
|
+
x = bodyWidth - width;
|
|
159
|
+
break;
|
|
160
|
+
case "middle":
|
|
161
|
+
width = defaultW;
|
|
162
|
+
x = (bodyWidth - width) / 2;
|
|
163
|
+
break;
|
|
164
|
+
case "stretch":
|
|
165
|
+
width = bodyWidth;
|
|
166
|
+
x = 0;
|
|
167
|
+
break;
|
|
168
|
+
}
|
|
169
|
+
switch (e?.yZone) {
|
|
170
|
+
case "top":
|
|
171
|
+
height = placementHeight < defaultH ? placementHeight - 20 : defaultH;
|
|
172
|
+
y = yStart;
|
|
173
|
+
break;
|
|
174
|
+
case "middle":
|
|
175
|
+
height = placementHeight < defaultH ? placementHeight - 20 : defaultH;
|
|
176
|
+
y = (placementHeight - height) / 2 + yStart;
|
|
177
|
+
break;
|
|
178
|
+
case "bottom":
|
|
179
|
+
height = placementHeight < defaultH ? placementHeight - 20 : defaultH;
|
|
180
|
+
y = placementHeight - height + yStart;
|
|
181
|
+
break;
|
|
182
|
+
case "stretch":
|
|
183
|
+
height = placementHeight;
|
|
184
|
+
y = yStart;
|
|
185
|
+
break;
|
|
186
|
+
}
|
|
187
|
+
vm.style.width = `${width}px`;
|
|
188
|
+
vm.style.height = ` ${height}px`;
|
|
189
|
+
vm.style.transform = `translate(${x}px, ${y}px)`;
|
|
190
|
+
function getShelfDiv(k) {
|
|
191
|
+
let div = viewPort.querySelector(`#shelf${k}`);
|
|
192
|
+
if (!div)
|
|
193
|
+
div = viewPort.querySelector(`#tray${k}`);
|
|
194
|
+
return div;
|
|
195
|
+
}
|
|
196
|
+
});
|
|
197
|
+
return true;
|
|
198
|
+
}
|
|
199
|
+
applyShelfColors() {
|
|
200
|
+
const bodies = document.getElementById("body-block-sum");
|
|
201
|
+
if (!bodies)
|
|
202
|
+
return false;
|
|
203
|
+
const bodyChildren = Array.from(bodies?.children ?? []);
|
|
204
|
+
const shelfDivs = bodyChildren
|
|
205
|
+
.map((div) => div)
|
|
206
|
+
.filter((d) => d?.id.includes("sumShelfContainer"));
|
|
207
|
+
if (!shelfDivs)
|
|
208
|
+
return false;
|
|
209
|
+
const adjust = 253;
|
|
210
|
+
switch (this.fixtureTemplateDetails?.productResolutionLevel) {
|
|
211
|
+
case "L1": //fixture
|
|
212
|
+
shelfDivs.forEach((d) => {
|
|
213
|
+
if (d) {
|
|
214
|
+
d.style.backgroundColor = this.shelfColors[0].bg;
|
|
215
|
+
d.style.border = `1.4px solid ${this.shelfColors[0].border}`;
|
|
216
|
+
}
|
|
217
|
+
});
|
|
218
|
+
break;
|
|
219
|
+
case "L3": //section
|
|
220
|
+
{
|
|
221
|
+
const shelves = shelfDivs
|
|
222
|
+
.map((div) => div.lastElementChild?.tagName.toLowerCase() === "div"
|
|
223
|
+
? div.lastElementChild
|
|
224
|
+
: null)
|
|
225
|
+
.filter(Boolean);
|
|
226
|
+
this.constructSequentialSection(shelves);
|
|
227
|
+
const sectionArray = this.groupShelvesByZone(this.fixtureTemplateDetails?.shelfConfig ?? []);
|
|
228
|
+
const allSectionShelves = [];
|
|
229
|
+
sectionArray.forEach((se, i) => {
|
|
230
|
+
const shelfIds = se.shelves?.map((sh) => sh.replace(/\s/g, "").toLowerCase()) ??
|
|
231
|
+
[];
|
|
232
|
+
allSectionShelves.push(...shelfIds);
|
|
233
|
+
const secDivs = shelves.filter((item) => shelfIds?.includes(item?.id ?? ""));
|
|
234
|
+
secDivs.forEach((d) => {
|
|
235
|
+
if (d) {
|
|
236
|
+
d.style.backgroundColor = this.shelfColors[i].bg;
|
|
237
|
+
d.style.border = `1.4px solid ${this.shelfColors[i].border}`;
|
|
238
|
+
}
|
|
239
|
+
});
|
|
240
|
+
});
|
|
241
|
+
const unassignedShelves = shelfDivs.filter((item) => !allSectionShelves.includes(item.id));
|
|
242
|
+
unassignedShelves.forEach((d) => (d.style.backgroundColor = "white"));
|
|
243
|
+
let sectionGroupHeight = 0;
|
|
244
|
+
setTimeout(() => {
|
|
245
|
+
this.sectionByZones.forEach((sz, i) => {
|
|
246
|
+
const currentSectionHeight = sz.section.shelfDivs.reduce((h, d) => h + (d?.offsetHeight ?? 0), 0);
|
|
247
|
+
const currentSectionWidth = sz.section.shelfDivs[0]?.offsetWidth ?? 345;
|
|
248
|
+
const bc = bodies.querySelector(`#brand-category${i}`);
|
|
249
|
+
if (bc) {
|
|
250
|
+
const secBg = rgbToHex(sz.section.shelfDivs[0]?.style.backgroundColor);
|
|
251
|
+
const color = this.shelfColors.find((c) => c.bg === secBg) ??
|
|
252
|
+
this.shelfColors[i];
|
|
253
|
+
bc.style.borderColor = color.border;
|
|
254
|
+
bc.style.backgroundColor = "#fff";
|
|
255
|
+
const bcX = (currentSectionWidth - bc.offsetWidth) / 2;
|
|
256
|
+
const bcY = (currentSectionHeight - bc.offsetHeight) / 2 +
|
|
257
|
+
sectionGroupHeight;
|
|
258
|
+
bc.style.transform = `translate(${bcX + adjust}px, ${bcY}px)`;
|
|
259
|
+
sectionGroupHeight += currentSectionHeight;
|
|
260
|
+
}
|
|
261
|
+
});
|
|
262
|
+
}, 0);
|
|
263
|
+
}
|
|
264
|
+
break;
|
|
265
|
+
case "L2": //shelf
|
|
266
|
+
{
|
|
267
|
+
shelfDivs.forEach((div, i) => {
|
|
268
|
+
div.style.backgroundColor = this.shelfColors[i].bg;
|
|
269
|
+
div.style.border = `1.4px solid ${this.shelfColors[i].border}`;
|
|
270
|
+
const bc = div.querySelector(`#brand-category${i}`);
|
|
271
|
+
if (!bc)
|
|
272
|
+
return;
|
|
273
|
+
const bcX = (div.offsetWidth - bc.offsetWidth) / 2;
|
|
274
|
+
const bcY = (div.offsetHeight - bc.offsetHeight) / 2;
|
|
275
|
+
bc.style.borderColor = this.shelfColors[i].border;
|
|
276
|
+
bc.style.backgroundColor = this.shelfColors[i].textBg;
|
|
277
|
+
bc.style.transform = `translate(${bcX + adjust}px, ${bcY}px)`;
|
|
278
|
+
});
|
|
279
|
+
}
|
|
280
|
+
break;
|
|
281
|
+
case "L4": //spot
|
|
282
|
+
{
|
|
283
|
+
shelfDivs.forEach((d) => {
|
|
284
|
+
if (d) {
|
|
285
|
+
d.style.backgroundColor = this.shelfColors[0].bg;
|
|
286
|
+
d.style.border = `1.4px solid ${this.shelfColors[0].border}`;
|
|
287
|
+
}
|
|
288
|
+
});
|
|
289
|
+
}
|
|
290
|
+
break;
|
|
291
|
+
default:
|
|
292
|
+
shelfDivs.forEach((d) => {
|
|
293
|
+
if (d) {
|
|
294
|
+
d.style.backgroundColor = this.shelfColors[0].bg;
|
|
295
|
+
d.style.border = `1.4px solid ${this.shelfColors[0].border}`;
|
|
296
|
+
}
|
|
297
|
+
});
|
|
298
|
+
break;
|
|
299
|
+
}
|
|
300
|
+
return true;
|
|
301
|
+
}
|
|
302
|
+
constructSequentialSection(shelfDivs) {
|
|
303
|
+
const newSectionByZones = [];
|
|
304
|
+
let pZone = null;
|
|
305
|
+
for (let i = 0; i < this.fixtureTemplateDetails?.shelfConfig.length; i++) {
|
|
306
|
+
const s = this.fixtureTemplateDetails?.shelfConfig[i];
|
|
307
|
+
const zone = s.zone || "";
|
|
308
|
+
const shelfId = `${s.shelfType}${s.shelfNumber}`;
|
|
309
|
+
const shelfDiv = shelfDivs.find((d) => d?.id === shelfId);
|
|
310
|
+
if (zone === "")
|
|
311
|
+
continue;
|
|
312
|
+
// const hasImproperProduct =
|
|
313
|
+
// (s?.products?.length ?? 0) === 0 ||
|
|
314
|
+
(s?.products ?? []).some((p) => p.status !== "proper");
|
|
315
|
+
const shelfCapacity = s.shelfType === "tray"
|
|
316
|
+
? s.productPerShelf * s.trayRows
|
|
317
|
+
: s.productPerShelf;
|
|
318
|
+
if (zone !== pZone) {
|
|
319
|
+
newSectionByZones.push({
|
|
320
|
+
zone,
|
|
321
|
+
section: {
|
|
322
|
+
brands: s.productBrandName ?? [],
|
|
323
|
+
categories: s.productCategory ?? [],
|
|
324
|
+
shelves: [shelfId],
|
|
325
|
+
shelfDivs: [shelfDiv],
|
|
326
|
+
capacity: shelfCapacity,
|
|
327
|
+
color: this.shelfColors[i],
|
|
328
|
+
// products: structuredClone(s?.products) ?? [],
|
|
329
|
+
// improper: hasImproperProduct,
|
|
330
|
+
},
|
|
331
|
+
});
|
|
332
|
+
pZone = zone;
|
|
333
|
+
}
|
|
334
|
+
else {
|
|
335
|
+
const section = newSectionByZones[newSectionByZones.length - 1].section;
|
|
336
|
+
section.shelves.push(shelfId);
|
|
337
|
+
section.shelfDivs.push(shelfDiv);
|
|
338
|
+
section.capacity += shelfCapacity;
|
|
339
|
+
// if (hasImproperProduct) section.improper = true;
|
|
340
|
+
}
|
|
341
|
+
}
|
|
342
|
+
this.sectionByZones = [...newSectionByZones];
|
|
343
|
+
this.cd.detectChanges();
|
|
344
|
+
}
|
|
345
|
+
groupShelvesByZone(input) {
|
|
346
|
+
const zoneMap = {};
|
|
347
|
+
for (const item of input) {
|
|
348
|
+
const zone = item?.zone ?? "";
|
|
349
|
+
const shelfLabel = `${item.shelfType} ${item.shelfNumber}`;
|
|
350
|
+
if (!zoneMap[zone]) {
|
|
351
|
+
zoneMap[zone] = {
|
|
352
|
+
shelves: [],
|
|
353
|
+
productBrandName: this.fixtureTemplateDetails?.productResolutionLevel === "L2"
|
|
354
|
+
? item.productBrandName
|
|
355
|
+
: [],
|
|
356
|
+
productCategory: this.fixtureTemplateDetails?.productResolutionLevel === "L2"
|
|
357
|
+
? item.productCategory
|
|
358
|
+
: [],
|
|
359
|
+
zone: zone,
|
|
360
|
+
};
|
|
361
|
+
}
|
|
362
|
+
zoneMap[zone]?.shelves?.push(shelfLabel);
|
|
363
|
+
}
|
|
364
|
+
return Object.values(zoneMap);
|
|
365
|
+
}
|
|
366
|
+
applySectionConfigToShelves(sections) {
|
|
367
|
+
const sectionMap = new Map();
|
|
368
|
+
for (const section of sections) {
|
|
369
|
+
for (const shelfLabel of section.shelves) {
|
|
370
|
+
sectionMap.set(shelfLabel, {
|
|
371
|
+
zone: section.zone,
|
|
372
|
+
productBrandName: section.productBrandName,
|
|
373
|
+
productCategory: section.productCategory,
|
|
374
|
+
});
|
|
375
|
+
}
|
|
376
|
+
}
|
|
377
|
+
// Apply overrides to matching shelves
|
|
378
|
+
return (this.fixtureTemplateDetails?.shelfConfig?.map((shelf) => {
|
|
379
|
+
const shelfLabel = `${shelf.shelfType} ${shelf.shelfNumber}`;
|
|
380
|
+
const override = sectionMap.get(shelfLabel);
|
|
381
|
+
return {
|
|
382
|
+
...shelf,
|
|
383
|
+
zone: override?.zone || "",
|
|
384
|
+
productBrandName: override?.productBrandName ?? [],
|
|
385
|
+
productCategory: override?.productCategory ?? [],
|
|
386
|
+
};
|
|
387
|
+
}) ?? []);
|
|
388
|
+
}
|
|
389
|
+
openZoneLevelProductModal(zoneData, level) { }
|
|
390
|
+
distributeRoundRobin(products, trayRows) {
|
|
391
|
+
const result = Array.from({ length: trayRows }, () => []);
|
|
392
|
+
products.forEach((product, index) => {
|
|
393
|
+
const trayIndex = index % trayRows;
|
|
394
|
+
result[trayIndex].push(product);
|
|
395
|
+
});
|
|
396
|
+
return result;
|
|
397
|
+
}
|
|
398
|
+
onClickClose() {
|
|
399
|
+
this.onClose.emit("");
|
|
400
|
+
}
|
|
401
|
+
async onChangeFixture(change) {
|
|
402
|
+
this.fixtureDetails = null;
|
|
403
|
+
let fixtId = this.fixtureTemplateDetails._id;
|
|
404
|
+
let indexToSelect = this.totalFixtures.findIndex((f) => f === this.fixtureTemplateDetails._id);
|
|
405
|
+
if (change === "next") {
|
|
406
|
+
if (indexToSelect == this.totalFixtures.length - 1)
|
|
407
|
+
return;
|
|
408
|
+
indexToSelect++;
|
|
409
|
+
}
|
|
410
|
+
else {
|
|
411
|
+
if (indexToSelect == 0)
|
|
412
|
+
return;
|
|
413
|
+
indexToSelect--;
|
|
414
|
+
}
|
|
415
|
+
let fixtureId = this.totalFixtures[indexToSelect];
|
|
416
|
+
let fixtureData = this.allFixtures.find((ele) => ele._id.toString() == fixtureId);
|
|
417
|
+
if (!fixtureData) {
|
|
418
|
+
return;
|
|
419
|
+
}
|
|
420
|
+
this.fixtureDetails = fixtureData;
|
|
421
|
+
await this.getFixtureShelfDetails(this.fixtureDetails);
|
|
422
|
+
setTimeout(() => {
|
|
423
|
+
this.applyShelfColors();
|
|
424
|
+
this.handleVmPositionAndSize();
|
|
425
|
+
}, 300);
|
|
426
|
+
this.dataService.emit({
|
|
427
|
+
currentFixture: fixtId,
|
|
428
|
+
action: change,
|
|
429
|
+
revisionId: `${this.floorData.revisionId} - ${fixtureId}`,
|
|
430
|
+
});
|
|
431
|
+
this.cd.detectChanges();
|
|
432
|
+
}
|
|
433
|
+
ngOnDestroy() {
|
|
434
|
+
this.destroy$.next();
|
|
435
|
+
this.destroy$.complete();
|
|
436
|
+
}
|
|
437
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FixtureOverviewPanelComponent, deps: [{ token: i1.StoreBuilderService }, { token: i2.GlobalStateService }, { token: i0.ChangeDetectorRef }, { token: i3.PlanoDataService }], target: i0.ɵɵFactoryTarget.Component });
|
|
438
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: FixtureOverviewPanelComponent, isStandalone: true, selector: "lib-fixture-overview-panel", inputs: { fixtureDetails: "fixtureDetails", totalFixtures: "totalFixtures", vmList: "vmList", floorData: "floorData" }, outputs: { onClose: "onClose", changeFixture: "changeFixture" }, usesOnChanges: true, ngImport: i0, template: "<section id=\"fixture-product-details\" *ngIf=\"!isPageLoading\">\r\n <div class=\"offcanvas-header d-flex w-100 justify-content-between p-3 align-items-center\" (click)=\"activeOffcanvas.dismiss()\">\r\n <h4 class=\"m-0\">Fixture details</h4>\r\n <svg class=\"cursor-pointer\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M18 6L6 18M6 6L18 18\" stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </div>\r\n <hr>\r\n <div class=\"offcanvas-body d-flex align-items-center gap-6 px-3\">\r\n\r\n <svg (click)=\"onChangeFixture('previous')\" class=\"cursor-pointer\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M15 6L9 12L15 18\" stroke=\"#1D2939\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n\r\n\r\n <h3 class=\"m-0\">{{fixtureTemplateDetails?.header?.label}}</h3>\r\n\r\n <h3 class=\"m-0 ms-auto\">{{totalFixtures.indexOf(fixtureTemplateDetails?._id) + 1}}/{{totalFixtures.length}}</h3>\r\n\r\n <svg (click)=\"onChangeFixture('next')\" class=\"cursor-pointer\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M9 18L15 12L9 6\" stroke=\"#1D2939\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n\r\n\r\n </div>\r\n <div class=\"hero-block\">\r\n <div class=\"row g-0 m-0 w-100\">\r\n <div class=\"col px-4\">\r\n <p>Fixture name:</p>\r\n <p>Fixture type:</p>\r\n <p>Size (Width):</p>\r\n <p>Total shelves:</p>\r\n <p>Total product capacity:</p>\r\n </div>\r\n <div class=\"col px-4\">\r\n <p><b>{{fixtureTemplateDetails?.header?.label}}</b></p>\r\n <p><b>{{fixtureTemplateDetails?.fixtureCategory}}</b></p>\r\n <p><b>{{fixtureTemplateDetails?.fixtureWidth.value}}{{fixtureTemplateDetails?.fixtureWidth.unit}}</b>\r\n </p>\r\n <p><b>{{fixtureTemplateDetails?.shelfConfig?.length}}</b></p>\r\n <p><b>{{fixtureTemplateDetails?.fixtureCapacity}}</b></p>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"px-4\">\r\n <h5>Planogram design </h5>\r\n <p>Fixture designed by the planogram team</p>\r\n </div>\r\n <div id=\"vm-products-sum\" class=\"wall-viewport px-4\">\r\n <!-- Header block -->\r\n <div class=\"header-block\"\r\n *ngIf=\"fixtureTemplateDetails?.header?.isEnabled && fixtureTemplateDetails?.fixtureType === 'wall'\">\r\n <p>{{ fixtureTemplateDetails?.header?.label }}</p>\r\n </div>\r\n\r\n <!-- Body block -->\r\n <div id=\"body-block-sum\" class=\"body-block\">\r\n <!----------------------------------[VM BLOCK]--------------------------------------->\r\n <div *ngIf=\"fixtureTemplateDetails?.vmConfig?.length\">\r\n <ng-container *ngFor=\"let vm of fixtureTemplateDetails?.vmConfig; let i = index\">\r\n <div [id]=\"'vm' + i\" class=\"vm-block\">\r\n <ng-container *ngIf=\"getSelectedVM(vm) as selectedVM\">\r\n <img *ngIf=\"selectedVM?.imgUrl; else placeholder\" [src]=\"selectedVM?.imgUrl\"\r\n alt=\"Vm Image\" />\r\n <ng-template #placeholder>\r\n <div class=\"vm-placeholder\">\r\n <h3>{{ selectedVM?.name }}</h3>\r\n </div>\r\n </ng-template>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </div>\r\n\r\n <!----------------------------------[FIXTURE LEVEL - BRAND CATEGORY]-------------------------------------->\r\n <div id=\"fixture-level\" *ngIf=\"fixtureTemplateDetails?.productResolutionLevel === 'L1'\">\r\n <div id=\"brand-category\" class=\"brand-category\" *ngIf=\"fixtureTemplateDetails?.productBrandName?.length\"\r\n [ngbTooltip]=\"brandCategoryTooltip\">\r\n <span class=\"brand\">\r\n <ng-container *ngFor=\"let b of fixtureTemplateDetails?.productBrandName; let last = last\">\r\n <span class=\"badge draft me-1\">\r\n {{ b }}\r\n </span>\r\n </ng-container>\r\n </span>\r\n <span class=\"category\" *ngIf=\"fixtureTemplateDetails?.productCategory?.length\">\r\n <ng-container *ngFor=\"let c of fixtureTemplateDetails?.productCategory; let last = last\">\r\n {{ c }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n </ng-container>\r\n </span>\r\n <span class=\"badge inactive mt-1\">\r\n Capacity {{fixtureTemplateDetails?.fixtureCapacity }}\r\n </span>\r\n </div>\r\n <ng-template #brandCategoryTooltip>\r\n <div>\r\n <p>\r\n <b>Brands: </b>\r\n <ng-container *ngFor=\"let c of fixtureTemplateDetails?.productBrandName; let last = last\">\r\n {{ c }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n </ng-container>\r\n </p>\r\n <p *ngIf=\"fixtureTemplateDetails?.productCategory?.length\">\r\n <b>Categories: </b>\r\n <ng-container *ngFor=\"let c of fixtureTemplateDetails?.productCategory; let last = last\">\r\n {{ c }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n </ng-container>\r\n </p>\r\n </div>\r\n </ng-template>\r\n </div>\r\n <!------------------------------------------------------------------------->\r\n\r\n <!-----------------------------------[SECTION LEVEL - BRAND CATEGORY]-------------------------------------->\r\n <div id=\"section-level\" *ngIf=\"fixtureTemplateDetails?.productResolutionLevel === 'L3'\">\r\n @for (item of sectionByZones; track $index) {\r\n <div [id]=\"'brand-category' + $index\" class=\"brand-category\" [ngbTooltip]=\"brandCategoryTooltip\"\r\n (click)=\"openZoneLevelProductModal(item,'section')\">\r\n <div class=\"d-flex\">\r\n <span class=\"badge me-1\"\r\n [ngStyle]=\"{'background-color':item.section.color.textBg,'color':item.section.color.text}\">\r\n {{ item.zone }}\r\n </span>\r\n <span class=\"badge inactive\">\r\n Capacity {{ item?.section?.capacity }}\r\n </span>\r\n </div>\r\n <div class=\"w-100 d-flex justify-content-center\">\r\n <span class=\"brand\" *ngIf=\"item?.section?.brands?.length\">\r\n @for (b of item?.section?.brands;track $index; let last = $last) {\r\n {{ b }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n }\r\n </span>\r\n <span *ngIf=\"item?.section?.categories?.length\" class=\"separator\"> - </span>\r\n <span class=\"category\" *ngIf=\"item?.section?.categories?.length\">\r\n @for (c of item?.section?.categories;track $index; let last = $last) {\r\n {{ c }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n }\r\n </span>\r\n </div>\r\n </div>\r\n\r\n <ng-template #brandCategoryTooltip>\r\n <div>\r\n <p>\r\n <b>Brands: </b>\r\n @for (b of item?.section?.brands;track $index; let last = $last) {\r\n {{ b }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n }\r\n </p>\r\n <p *ngIf=\"item?.section?.categories?.length\">\r\n <b>Categories: </b>\r\n @for (c of item?.section?.categories;track $index; let last = $last) {\r\n {{ c }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n }\r\n </p>\r\n </div>\r\n </ng-template>\r\n }\r\n </div>\r\n <!------------------------------------------------------------------------->\r\n\r\n <div [id]=\"'sumShelfContainer' + i\" *ngFor=\"let item of fixtureTemplateDetails?.shelfConfig; let i = index\">\r\n <!--------------------------------[SHELF LEVEL - BRAND CATEGORY]---------------------------------------->\r\n <div id=\"shelf-level\" *ngIf=\"fixtureTemplateDetails?.productResolutionLevel === 'L2'\">\r\n <div [id]=\"'brand-category' + i\" class=\"brand-category\" *ngIf=\"item.productBrandName?.length\"\r\n [ngbTooltip]=\"brandCategoryTooltip\">\r\n <span class=\"brand\" *ngIf=\"item.productBrandName?.length\">\r\n <ng-container *ngFor=\"let b of item.productBrandName; let last = last\">\r\n {{ b }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n </ng-container>\r\n </span>\r\n <span *ngIf=\"item.productCategory?.length\" class=\"separator\"> - </span>\r\n <span class=\"category\" *ngIf=\"item.productCategory?.length\">\r\n <ng-container *ngFor=\"let b of item.productCategory; let last = last\">\r\n {{ b }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n </ng-container>\r\n </span>\r\n </div>\r\n <ng-template #brandCategoryTooltip>\r\n <div>\r\n <p>\r\n <b>Brands: </b>\r\n <ng-container *ngFor=\"let c of item.productBrandName; let last = last\">\r\n {{ c }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n </ng-container>\r\n </p>\r\n <p *ngIf=\"item.productCategory?.length\">\r\n <b>Categories: </b>\r\n <ng-container *ngFor=\"let c of item.productCategory; let last = last\">\r\n {{ c }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n </ng-container>\r\n </p>\r\n <span class=\"badge inactive\">\r\n Capacity {{item?.productPerShelf }}\r\n </span>\r\n\r\n </div>\r\n </ng-template>\r\n </div>\r\n <!------------------------------------------------------------------------->\r\n\r\n <!-- @if(item.shelfType ==='shelf'){\r\n <div [id]=\"item.shelfType + (i + 1)\" class=\"block shelf\">\r\n @if(item.products.length){\r\n <div *ngFor=\"let product of item.products\" class=\"product\"\r\n [class.error]=\"product.status === 'missing' || product.status === 'misplaced'\">\r\n @if(product.status != 'missing'){\r\n <img *ngIf=\"product?.productImageUrl; else placeholder\" [src]=\"product?.productImageUrl\"\r\n alt=\"Product Image\" />\r\n <ng-template #placeholder>\r\n <div></div>\r\n </ng-template>\r\n }\r\n </div>\r\n }@else {\r\n <div *ngFor=\"let product of [].constructor(item.productPerShelf)\" class=\"product\"></div>\r\n }\r\n </div>\r\n }@else {\r\n <div [id]=\"item.shelfType! + (i + 1)\" class=\"block\">\r\n @if(item.products.length){\r\n <div *ngFor=\"let row of item.distributedRows\" class=\"tray mb-3\">\r\n <div *ngFor=\"let product of row\" class=\"product\"\r\n [class.error]=\"product.status === 'missing' || product.status === 'misplaced'\">\r\n @if(product.status != 'missing'){\r\n <img *ngIf=\"product?.productImageUrl; else placeholder\" [src]=\"product?.productImageUrl\"\r\n alt=\"Product Image\" />\r\n <ng-template #placeholder>\r\n <div></div>\r\n </ng-template>\r\n }\r\n </div>\r\n </div>\r\n }@else{\r\n <div *ngFor=\"let product of [].constructor(item.trayRows)\" class=\"tray mb-3\">\r\n <div *ngFor=\"let product of [].constructor(item.productPerShelf)\" class=\"product\"></div>\r\n </div>\r\n }\r\n </div>\r\n } -->\r\n @if(item.shelfType ==='shelf'){\r\n <div [id]=\"item.shelfType + (i + 1)\" class=\"block shelf\">\r\n <div *ngFor=\"let product of [].constructor(item.productPerShelf)\" class=\"product\"></div>\r\n </div>\r\n }@else {\r\n <div [id]=\"item.shelfType! + (i + 1)\" class=\"block\">\r\n <div *ngFor=\"let product of [].constructor(item.trayRows)\" class=\"tray mb-3\">\r\n <div *ngFor=\"let product of [].constructor(item.productPerShelf)\" class=\"product\"></div>\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n\r\n <!-- Footer block -->\r\n <div class=\"footer-block\"\r\n *ngIf=\"fixtureTemplateDetails?.footer?.isEnabled && fixtureTemplateDetails?.fixtureType === 'wall'\">\r\n <div class=\"sub-footer left-box\"></div>\r\n <div class=\"sub-footer right-box\"></div>\r\n <p>{{ fixtureTemplateDetails?.footer?.label }}</p>\r\n </div>\r\n </div>\r\n\r\n</section>\r\n\r\n<section id=\"template-summary-skeleton\" *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 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</section>", styles: [".header{background:#fff;padding:12px;border-radius:12px;display:flex;align-items:center;justify-content:space-between}.btn{padding:.775rem 1.5rem!important;font-size:1.1rem!important}.badge{font-weight:500;font-size:12px;line-height:18px;text-align:center;padding:2px 8px;border-radius:16px}.builder{height:75vh}.builder .cols{background:#fff;border-radius:12px;padding:24px 24px 12px;max-height:75vh;overflow-y:auto}.shelf-container{border-radius:8px;background:var(--Gray-50, #f9fafb);padding:8px 16px;margin-bottom:12px}.counter-container{display:flex;align-items:center;justify-content:center;border-radius:8px;background-color:#fff;padding:10px;border:.49px solid #d0d5dd}.counter-container span{margin:0 18px;font-weight:500;font-size:14px;text-align:center;vertical-align:middle;width:18px}.disable-counter{color:var(--bs-gray-500)!important;background-color:var(--bs-gray-200)!important;border-color:var(--bs-gray-300)!important;pointer-events:none;opacity:1}.disabled-click{pointer-events:none;opacity:.85}.wall-viewport{display:flex;align-items:center;justify-content:center;flex-direction:column;margin-bottom:30px;width:345px;text-align:center}.wall-viewport .wrapper{width:100%;max-width:345px}.wall-viewport .header-info,.wall-viewport .footer-info,.wall-viewport .body-info{width:100%;border:2px solid #f2f4f7;border-bottom:4px solid #ffffff;background:#f2f4f7;max-width:230px;display:flex;align-items:center;justify-content:center;justify-content:start;padding:12px;gap:4px}.wall-viewport .header-info p,.wall-viewport .footer-info p,.wall-viewport .body-info p{margin:0}.wall-viewport .header-info{margin-top:40px}.wall-viewport .sub-footer{border:1px solid #98a2b3;height:100%}.wall-viewport .header-block,.wall-viewport .footer-block{border:1px solid #98a2b3;height:95px;padding:8px;background-color:#f2f4f7;width:100%;display:flex;justify-content:center;align-items:center}.wall-viewport .header-block p,.wall-viewport .footer-block p{color:var(--Gray-600, #475467);font-size:18px;font-weight:600;white-space:normal;word-wrap:break-word;margin:0;background-color:#f2f4f7}.wall-viewport .body-block{width:100%}.wall-viewport .body-block .block{border:1px solid #98a2b3;padding:10px;width:100%;max-width:345px;overflow-x:auto;min-height:52px}.wall-viewport .body-block .tray,.wall-viewport .body-block .shelf{display:flex;gap:4px}.wall-viewport .body-block .tray .product,.wall-viewport .body-block .shelf .product{border:1px solid rgba(152,162,179,.2901960784);min-width:50px}.wall-viewport .body-block .tray .product{min-height:20px}.wall-viewport .body-block .shelf .product{min-height:30px}.wall-viewport .body-block .hide-product{border-color:transparent!important}.wall-viewport .body-block .hide-scroll{overflow-x:hidden!important}.horizontal-dimension{display:flex;align-items:center;justify-content:center;height:30px;position:relative}.horizontal-dimension .arrow{width:12px;height:12px;background-size:contain;background-repeat:no-repeat;background-position:center}.horizontal-dimension .arrow.left{transform:rotate(180deg);background-image:url(\"data:image/svg+xml,%3Csvg fill='%23EAECF0' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 330 330'%3E%3Cpath d='M250.606,154.389l-150-149.996c-5.857-5.858-15.355-5.858-21.213,0.001c-5.857,5.858-5.857,15.355,0.001,21.213l139.393,139.39L79.393,304.394c-5.857,5.858-5.857,15.355,0.001,21.213C82.322,328.536,86.161,330,90,330s7.678-1.464,10.607-4.394l149.999-150.004c2.814-2.813,4.394-6.628,4.394-10.606C255,161.018,253.42,157.202,250.606,154.389z'/%3E%3C/svg%3E\")}.horizontal-dimension .arrow.right{transform:rotate(0);background-image:url(\"data:image/svg+xml,%3Csvg fill='%23EAECF0' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 330 330'%3E%3Cpath d='M250.606,154.389l-150-149.996c-5.857-5.858-15.355-5.858-21.213,0.001c-5.857,5.858-5.857,15.355,0.001,21.213l139.393,139.39L79.393,304.394c-5.857,5.858-5.857,15.355,0.001,21.213C82.322,328.536,86.161,330,90,330s7.678-1.464,10.607-4.394l149.999-150.004c2.814-2.813,4.394-6.628,4.394-10.606C255,161.018,253.42,157.202,250.606,154.389z'/%3E%3C/svg%3E\")}.horizontal-dimension .line{flex:1;background-color:#eaecf0;position:relative;display:flex;align-items:center;justify-content:center;height:1px}.horizontal-dimension .line span{position:absolute;top:-12px;color:#667085;font-weight:500;font-size:14px;background-color:#fff;padding:0 4px}.vertical-dimension{display:flex;flex-direction:column;align-items:center;width:30px;position:relative}.vertical-dimension .arrow{width:12px;height:12px;background-size:contain;background-repeat:no-repeat;background-position:center}.vertical-dimension .arrow.up{transform:rotate(-90deg);margin-top:20px;background-image:url(\"data:image/svg+xml,%3Csvg fill='%23EAECF0' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 330 330'%3E%3Cpath d='M250.606,154.389l-150-149.996c-5.857-5.858-15.355-5.858-21.213,0.001c-5.857,5.858-5.857,15.355,0.001,21.213l139.393,139.39L79.393,304.394c-5.857,5.858-5.857,15.355,0.001,21.213C82.322,328.536,86.161,330,90,330s7.678-1.464,10.607-4.394l149.999-150.004c2.814-2.813,4.394-6.628,4.394-10.606C255,161.018,253.42,157.202,250.606,154.389z'/%3E%3C/svg%3E\")}.vertical-dimension .arrow.down{transform:rotate(90deg);margin-bottom:26px;background-image:url(\"data:image/svg+xml,%3Csvg fill='%23EAECF0' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 330 330'%3E%3Cpath d='M250.606,154.389l-150-149.996c-5.857-5.858-15.355-5.858-21.213,0.001c-5.857,5.858-5.857,15.355,0.001,21.213l139.393,139.39L79.393,304.394c-5.857,5.858-5.857,15.355,0.001,21.213C82.322,328.536,86.161,330,90,330s7.678-1.464,10.607-4.394l149.999-150.004c2.814-2.813,4.394-6.628,4.394-10.606C255,161.018,253.42,157.202,250.606,154.389z'/%3E%3C/svg%3E\")}.vertical-dimension .line{flex:1;background-color:#eaecf0;position:relative;display:flex;align-items:center;justify-content:center;width:1px}.vertical-dimension .line span{writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);color:#667085;font-weight:500;font-size:14px;background-color:#fff;padding:2px 4px}.info-card{padding:12px;background:#fff;border:1px solid #d0d5dd;border-radius:8px;box-shadow:0 1px 2px #1018280f,0 1px 3px #1018281a}.info-card h3{font-weight:600;font-size:18px;line-height:28px;vertical-align:middle}.info-card p{font-weight:500;font-size:14px;line-height:20px;color:#667085;margin:0}.checkbox input[type=checkbox]{width:16px!important;height:16px!important;margin:5px;border-radius:4px!important;-webkit-appearance:none;-moz-appearance:none;-o-appearance:none;appearance:none;outline:1px solid var(--gray-600, #d0d5dd)!important;box-shadow:none;font-size:.5em;text-align:center;line-height:1em;background:#fff}.checkbox input[type=checkbox]:checked{outline:1px solid var(--primary-600, #00a3ff)!important;background-color:var(--primary-50, #eaf8ff)}.checkbox input[type=checkbox]:checked:after{content:\"\";transform:rotate(45deg);border-bottom:2px solid #00a3ff;border-right:2px solid #00a3ff;display:inline-block;width:.5em;padding-left:3px;padding-top:10px;padding-right:0}.nav-pills{display:inline-flex;gap:4px}.nav-pills .nav-item .nav-link{border-radius:0;color:#667085;font-size:14px;font-weight:500;padding:8px 16px;border:none}.nav-pills .nav-item .nav-link:hover{background-color:#00000005}.nav-pills .nav-item .nav-link.active{background-color:#eaf8ff;color:#009bf3;border-bottom:3px solid #009bf3}.content-wrapper{background:#fff;border-radius:12px;min-height:calc(100vh - 400px);height:100%;padding:16px 24px;display:flex;flex-direction:column}.loader .shimmer{height:150px}.filter-tab{border:1px solid rgb(234,236,240);background:#fff;box-shadow:0 1px 2px #1018280d;border-radius:8px;padding:18px;transition:all ease .2s}.filter-tab:hover{cursor:pointer}.filter-tab.selected{background:#f6fcff;border:1px solid rgb(107,202,255);box-shadow:0 1px 2px #1018280d}.filter-tab h3{color:#000;font-size:20px;font-weight:600;line-height:30px;margin:0}.filter-tab p{color:var(--Gray-500, #667085);font-size:14px;font-weight:500;line-height:20px;margin:0}.nodatamaintext{font-family:Inter;font-size:16px;font-weight:600;line-height:24px;text-align:center;color:#101828}.nodatasubtext[_ngcontent-ng-c2141490359]{font-family:Inter;font-size:14px;font-weight:400;line-height:20px;text-align:center;color:#667085}.table-responsive{min-height:calc(100vh - 495px)}.download-link{color:var(--Primary-800, #008edf);font-size:14px;font-weight:500;line-height:20px;text-decoration-line:underline;text-decoration-style:solid;text-decoration-skip-ink:auto;text-decoration-thickness:auto;text-underline-offset:auto;text-underline-position:from-font;cursor:pointer}h3.card-title{color:#101828;font-size:18px;font-weight:600;line-height:28px}p.card-tagline{color:#101828;font-size:14px;font-weight:500;line-height:20px}p.card-description{color:#344054;font-size:14px;font-weight:400;line-height:20px}#list-view .thumbnail{height:40px;width:40px;background:#f2f4f7;margin-right:12px;border-radius:8px}#list-view td{vertical-align:middle}#grid-view .card{box-shadow:0 4px 10px #0000000d;border:1px solid rgb(223,225,231);background:#fff;border-radius:12px;padding:12px;height:100%;transition:all .2s ease}#grid-view .card:hover{cursor:pointer;box-shadow:0 10px 10px #0001;transition:all .2s ease}#grid-view .card-img{margin-bottom:12px;background:#d0d5dd;height:200px;border-radius:6px}#grid-view .card-action{position:absolute;top:20px;right:20px}#grid-view .card-tagline{color:#475467;font-weight:500;font-size:14px;line-height:20px}.badge{font-weight:500;font-size:12px;line-height:18px;text-align:center;color:#027a48;background:#ecfdf3}.badge.active{color:#027a48;background:#ecfdf3}.badge.inactive{background:#f2f4f7;color:#344054}.badge.draft{color:#009bf3;background:#eaf8ff}.badge.cluster{background:#f2f4f7;color:#344054}.badge.published{background:#ecfdf3;color:#027a48}.badge.yet-to-publish{background:#f8f9fc;color:#363f72}.indicator{border-radius:16px;padding:2px 8px;display:flex;justify-content:center;align-items:center;white-space:nowrap;width:fit-content;text-align:center;font-size:14px;font-weight:500}.indicator.short{height:14px!important;width:14px!important;border-radius:50%!important;padding:0!important}.indicator.yetToComplete{background:#f2f4f7;color:#667085}.indicator.yetToComplete path{fill:#667085}.indicator.yetToAssign{background:#eaecf5;color:#344054}.indicator.yetToAssign path{fill:#344054}.indicator.taskAssigned{background:#e0eaff;color:#7a5af8}.indicator.taskAssigned path{fill:#7a5af8}.indicator.reviewPending{background:#fef0c7;color:#f79009}.indicator.reviewPending path{fill:#f79009}.indicator.flagged{background:var(--Error-50, #fef3f2);color:var(--Error-700, #b42318)}.indicator.completed{background:#d1fadf;color:#12b76a}.indicator.completed path{fill:#12b76a}.toggle-button{width:40px;height:40px;display:flex;justify-content:center;align-items:center;border-radius:8px;background:#fff;border:.89px solid rgb(208,213,221);box-shadow:0 .89px 1.78px #1018280d;transition:all ease .3s}.toggle-button:hover{cursor:pointer}.toggle-button.selected{transition:all ease .3s;background:#eaf8ff;box-shadow:0 0 0 3.56px #d5effe!important;border:.89px solid rgb(234,248,255)}.disabled-click{pointer-events:none;cursor:not-allowed!important;opacity:.6}.ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);pointer-events:none;color:#888;display:flex;align-items:center;height:1.5rem}.clear-search{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;height:1.5rem;width:1.5rem}#fixture-product-details #vm-products-sum .body-block{position:relative}#fixture-product-details #vm-products-sum .body-block .block{border:none}#fixture-product-details #vm-products-sum #fixture-level .brand-category{position:absolute;width:150px;overflow:hidden;padding:4px;border-radius:8px;border:2px solid var(--Primary-200, #99daff);background:var(--White, #fff);top:50%;left:59%;transform:translate(100%,-50%);transition:all .3s ease;cursor:pointer}#fixture-product-details #vm-products-sum #fixture-level .brand,#fixture-product-details #vm-products-sum #fixture-level .category{white-space:nowrap;overflow:hidden;display:block;text-overflow:ellipsis}#fixture-product-details #vm-products-sum #fixture-level .category{margin-top:12px}#fixture-product-details #vm-products-sum #section-level .brand-category{position:absolute;width:150px;overflow:hidden;padding:4px;border-radius:8px;border:2px solid var(--Primary-200, #99daff);transition:all .3s ease;display:flex;flex-direction:column;justify-content:center;align-items:center;cursor:pointer}#fixture-product-details #vm-products-sum #section-level .brand,#fixture-product-details #vm-products-sum #section-level .category{white-space:nowrap;overflow:hidden;display:block;text-overflow:ellipsis;max-width:fit-content;width:100%}#fixture-product-details #vm-products-sum #section-level .brand{color:var(--Gray-500, #667085);font-size:12px;font-style:normal;font-weight:400;line-height:18px;margin:0}#fixture-product-details #vm-products-sum #section-level .category{color:var(--Gray-800, #1d2939);font-size:12px;font-style:normal;font-weight:600;line-height:18px;margin:0}#fixture-product-details #vm-products-sum #section-level .separator{margin:0 4px;font-weight:600}#fixture-product-details #vm-products-sum #section-level #body-loader{height:100%;width:100%;position:absolute;display:flex;justify-content:center;align-items:center;z-index:1;background:#fff3;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(10px)}#fixture-product-details #vm-products-sum #section-level #body-loader .loader{width:30px;height:30px;border:4px solid #f3f3f3;border-top:4px solid #00a3ff;border-radius:50%;animation:spin 1s linear infinite;margin:auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}#fixture-product-details #vm-products-sum #shelf-level .brand-category{position:absolute;width:150px;overflow:hidden;padding:8px 4px;border-radius:8px;border:2px solid var(--Primary-200, #99daff);transition:all .3s ease;display:flex;justify-content:center;cursor:pointer}#fixture-product-details #vm-products-sum #shelf-level .brand,#fixture-product-details #vm-products-sum #shelf-level .category{white-space:nowrap;overflow:hidden;display:block;text-overflow:ellipsis;max-width:fit-content;width:100%}#fixture-product-details #vm-products-sum #shelf-level .brand{color:var(--Gray-500, #667085);font-size:12px;font-style:normal;font-weight:400;line-height:18px;margin:0}#fixture-product-details #vm-products-sum #shelf-level .category{color:var(--Gray-800, #1d2939);font-size:12px;font-style:normal;font-weight:600;line-height:18px;margin:0}#fixture-product-details #vm-products-sum #shelf-level .separator{margin:0 4px;font-weight:600}#fixture-product-details #vm-products-sum .brand-category.proper{border:1.12px solid var(--Primary-200, #32d583)!important}#fixture-product-details #vm-products-sum .footer-block{position:relative;box-sizing:border-box;justify-content:space-between!important}#fixture-product-details #vm-products-sum .footer-block p{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background-color:#f2f4f7;z-index:1}#fixture-product-details #vm-products-sum .sub-footer{position:relative;width:48%}#fixture-product-details #vm-products-sum img{width:100%;height:100%;display:block}#fixture-product-details #vm-products-sum .vm-block{position:absolute;width:100px;height:100px;transition:all .3s ease}#fixture-product-details #vm-products-sum .vm-block h3{color:var(--Gray-700, #344054);font-size:14px;font-weight:600;margin:0;width:100%;text-overflow:ellipsis;overflow:hidden}#fixture-product-details #vm-products-sum .vm-placeholder{border:4px solid var(--Black, #101828);background:#f9fafb;width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:8px;white-space:nowrap;overflow:hidden}#fixture-product-details .hero-block{background-color:#f9fafb;display:flex;flex-direction:column;gap:6px;padding:12px;justify-content:center;align-items:center;margin:24px 12px}#fixture-product-details .hero-block h1{font-size:18px;font-weight:600;color:#101828;margin:0}#fixture-product-details .hero-block p{font-size:14px;font-weight:400;color:#475467;margin:0 0 8px}#fixture-product-details .fixture-image{margin-bottom:12px}#fixture-product-details .fixture-image img{object-fit:contain;width:100%}\n"], dependencies: [{ kind: "directive", type: NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "popperOptions", "triggers", "positionTarget", "container", "disableTooltip", "tooltipClass", "tooltipContext", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
|
|
439
|
+
}
|
|
440
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FixtureOverviewPanelComponent, decorators: [{
|
|
441
|
+
type: Component,
|
|
442
|
+
args: [{ selector: "lib-fixture-overview-panel", standalone: true, imports: [NgbTooltip, NgFor, NgIf, NgStyle], template: "<section id=\"fixture-product-details\" *ngIf=\"!isPageLoading\">\r\n <div class=\"offcanvas-header d-flex w-100 justify-content-between p-3 align-items-center\" (click)=\"activeOffcanvas.dismiss()\">\r\n <h4 class=\"m-0\">Fixture details</h4>\r\n <svg class=\"cursor-pointer\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\"\r\n xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M18 6L6 18M6 6L18 18\" stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n </div>\r\n <hr>\r\n <div class=\"offcanvas-body d-flex align-items-center gap-6 px-3\">\r\n\r\n <svg (click)=\"onChangeFixture('previous')\" class=\"cursor-pointer\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M15 6L9 12L15 18\" stroke=\"#1D2939\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n\r\n\r\n <h3 class=\"m-0\">{{fixtureTemplateDetails?.header?.label}}</h3>\r\n\r\n <h3 class=\"m-0 ms-auto\">{{totalFixtures.indexOf(fixtureTemplateDetails?._id) + 1}}/{{totalFixtures.length}}</h3>\r\n\r\n <svg (click)=\"onChangeFixture('next')\" class=\"cursor-pointer\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\"\r\n fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M9 18L15 12L9 6\" stroke=\"#1D2939\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n stroke-linejoin=\"round\" />\r\n </svg>\r\n\r\n\r\n </div>\r\n <div class=\"hero-block\">\r\n <div class=\"row g-0 m-0 w-100\">\r\n <div class=\"col px-4\">\r\n <p>Fixture name:</p>\r\n <p>Fixture type:</p>\r\n <p>Size (Width):</p>\r\n <p>Total shelves:</p>\r\n <p>Total product capacity:</p>\r\n </div>\r\n <div class=\"col px-4\">\r\n <p><b>{{fixtureTemplateDetails?.header?.label}}</b></p>\r\n <p><b>{{fixtureTemplateDetails?.fixtureCategory}}</b></p>\r\n <p><b>{{fixtureTemplateDetails?.fixtureWidth.value}}{{fixtureTemplateDetails?.fixtureWidth.unit}}</b>\r\n </p>\r\n <p><b>{{fixtureTemplateDetails?.shelfConfig?.length}}</b></p>\r\n <p><b>{{fixtureTemplateDetails?.fixtureCapacity}}</b></p>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"px-4\">\r\n <h5>Planogram design </h5>\r\n <p>Fixture designed by the planogram team</p>\r\n </div>\r\n <div id=\"vm-products-sum\" class=\"wall-viewport px-4\">\r\n <!-- Header block -->\r\n <div class=\"header-block\"\r\n *ngIf=\"fixtureTemplateDetails?.header?.isEnabled && fixtureTemplateDetails?.fixtureType === 'wall'\">\r\n <p>{{ fixtureTemplateDetails?.header?.label }}</p>\r\n </div>\r\n\r\n <!-- Body block -->\r\n <div id=\"body-block-sum\" class=\"body-block\">\r\n <!----------------------------------[VM BLOCK]--------------------------------------->\r\n <div *ngIf=\"fixtureTemplateDetails?.vmConfig?.length\">\r\n <ng-container *ngFor=\"let vm of fixtureTemplateDetails?.vmConfig; let i = index\">\r\n <div [id]=\"'vm' + i\" class=\"vm-block\">\r\n <ng-container *ngIf=\"getSelectedVM(vm) as selectedVM\">\r\n <img *ngIf=\"selectedVM?.imgUrl; else placeholder\" [src]=\"selectedVM?.imgUrl\"\r\n alt=\"Vm Image\" />\r\n <ng-template #placeholder>\r\n <div class=\"vm-placeholder\">\r\n <h3>{{ selectedVM?.name }}</h3>\r\n </div>\r\n </ng-template>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </div>\r\n\r\n <!----------------------------------[FIXTURE LEVEL - BRAND CATEGORY]-------------------------------------->\r\n <div id=\"fixture-level\" *ngIf=\"fixtureTemplateDetails?.productResolutionLevel === 'L1'\">\r\n <div id=\"brand-category\" class=\"brand-category\" *ngIf=\"fixtureTemplateDetails?.productBrandName?.length\"\r\n [ngbTooltip]=\"brandCategoryTooltip\">\r\n <span class=\"brand\">\r\n <ng-container *ngFor=\"let b of fixtureTemplateDetails?.productBrandName; let last = last\">\r\n <span class=\"badge draft me-1\">\r\n {{ b }}\r\n </span>\r\n </ng-container>\r\n </span>\r\n <span class=\"category\" *ngIf=\"fixtureTemplateDetails?.productCategory?.length\">\r\n <ng-container *ngFor=\"let c of fixtureTemplateDetails?.productCategory; let last = last\">\r\n {{ c }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n </ng-container>\r\n </span>\r\n <span class=\"badge inactive mt-1\">\r\n Capacity {{fixtureTemplateDetails?.fixtureCapacity }}\r\n </span>\r\n </div>\r\n <ng-template #brandCategoryTooltip>\r\n <div>\r\n <p>\r\n <b>Brands: </b>\r\n <ng-container *ngFor=\"let c of fixtureTemplateDetails?.productBrandName; let last = last\">\r\n {{ c }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n </ng-container>\r\n </p>\r\n <p *ngIf=\"fixtureTemplateDetails?.productCategory?.length\">\r\n <b>Categories: </b>\r\n <ng-container *ngFor=\"let c of fixtureTemplateDetails?.productCategory; let last = last\">\r\n {{ c }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n </ng-container>\r\n </p>\r\n </div>\r\n </ng-template>\r\n </div>\r\n <!------------------------------------------------------------------------->\r\n\r\n <!-----------------------------------[SECTION LEVEL - BRAND CATEGORY]-------------------------------------->\r\n <div id=\"section-level\" *ngIf=\"fixtureTemplateDetails?.productResolutionLevel === 'L3'\">\r\n @for (item of sectionByZones; track $index) {\r\n <div [id]=\"'brand-category' + $index\" class=\"brand-category\" [ngbTooltip]=\"brandCategoryTooltip\"\r\n (click)=\"openZoneLevelProductModal(item,'section')\">\r\n <div class=\"d-flex\">\r\n <span class=\"badge me-1\"\r\n [ngStyle]=\"{'background-color':item.section.color.textBg,'color':item.section.color.text}\">\r\n {{ item.zone }}\r\n </span>\r\n <span class=\"badge inactive\">\r\n Capacity {{ item?.section?.capacity }}\r\n </span>\r\n </div>\r\n <div class=\"w-100 d-flex justify-content-center\">\r\n <span class=\"brand\" *ngIf=\"item?.section?.brands?.length\">\r\n @for (b of item?.section?.brands;track $index; let last = $last) {\r\n {{ b }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n }\r\n </span>\r\n <span *ngIf=\"item?.section?.categories?.length\" class=\"separator\"> - </span>\r\n <span class=\"category\" *ngIf=\"item?.section?.categories?.length\">\r\n @for (c of item?.section?.categories;track $index; let last = $last) {\r\n {{ c }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n }\r\n </span>\r\n </div>\r\n </div>\r\n\r\n <ng-template #brandCategoryTooltip>\r\n <div>\r\n <p>\r\n <b>Brands: </b>\r\n @for (b of item?.section?.brands;track $index; let last = $last) {\r\n {{ b }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n }\r\n </p>\r\n <p *ngIf=\"item?.section?.categories?.length\">\r\n <b>Categories: </b>\r\n @for (c of item?.section?.categories;track $index; let last = $last) {\r\n {{ c }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n }\r\n </p>\r\n </div>\r\n </ng-template>\r\n }\r\n </div>\r\n <!------------------------------------------------------------------------->\r\n\r\n <div [id]=\"'sumShelfContainer' + i\" *ngFor=\"let item of fixtureTemplateDetails?.shelfConfig; let i = index\">\r\n <!--------------------------------[SHELF LEVEL - BRAND CATEGORY]---------------------------------------->\r\n <div id=\"shelf-level\" *ngIf=\"fixtureTemplateDetails?.productResolutionLevel === 'L2'\">\r\n <div [id]=\"'brand-category' + i\" class=\"brand-category\" *ngIf=\"item.productBrandName?.length\"\r\n [ngbTooltip]=\"brandCategoryTooltip\">\r\n <span class=\"brand\" *ngIf=\"item.productBrandName?.length\">\r\n <ng-container *ngFor=\"let b of item.productBrandName; let last = last\">\r\n {{ b }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n </ng-container>\r\n </span>\r\n <span *ngIf=\"item.productCategory?.length\" class=\"separator\"> - </span>\r\n <span class=\"category\" *ngIf=\"item.productCategory?.length\">\r\n <ng-container *ngFor=\"let b of item.productCategory; let last = last\">\r\n {{ b }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n </ng-container>\r\n </span>\r\n </div>\r\n <ng-template #brandCategoryTooltip>\r\n <div>\r\n <p>\r\n <b>Brands: </b>\r\n <ng-container *ngFor=\"let c of item.productBrandName; let last = last\">\r\n {{ c }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n </ng-container>\r\n </p>\r\n <p *ngIf=\"item.productCategory?.length\">\r\n <b>Categories: </b>\r\n <ng-container *ngFor=\"let c of item.productCategory; let last = last\">\r\n {{ c }}\r\n <ng-container *ngIf=\"!last\">, </ng-container>\r\n </ng-container>\r\n </p>\r\n <span class=\"badge inactive\">\r\n Capacity {{item?.productPerShelf }}\r\n </span>\r\n\r\n </div>\r\n </ng-template>\r\n </div>\r\n <!------------------------------------------------------------------------->\r\n\r\n <!-- @if(item.shelfType ==='shelf'){\r\n <div [id]=\"item.shelfType + (i + 1)\" class=\"block shelf\">\r\n @if(item.products.length){\r\n <div *ngFor=\"let product of item.products\" class=\"product\"\r\n [class.error]=\"product.status === 'missing' || product.status === 'misplaced'\">\r\n @if(product.status != 'missing'){\r\n <img *ngIf=\"product?.productImageUrl; else placeholder\" [src]=\"product?.productImageUrl\"\r\n alt=\"Product Image\" />\r\n <ng-template #placeholder>\r\n <div></div>\r\n </ng-template>\r\n }\r\n </div>\r\n }@else {\r\n <div *ngFor=\"let product of [].constructor(item.productPerShelf)\" class=\"product\"></div>\r\n }\r\n </div>\r\n }@else {\r\n <div [id]=\"item.shelfType! + (i + 1)\" class=\"block\">\r\n @if(item.products.length){\r\n <div *ngFor=\"let row of item.distributedRows\" class=\"tray mb-3\">\r\n <div *ngFor=\"let product of row\" class=\"product\"\r\n [class.error]=\"product.status === 'missing' || product.status === 'misplaced'\">\r\n @if(product.status != 'missing'){\r\n <img *ngIf=\"product?.productImageUrl; else placeholder\" [src]=\"product?.productImageUrl\"\r\n alt=\"Product Image\" />\r\n <ng-template #placeholder>\r\n <div></div>\r\n </ng-template>\r\n }\r\n </div>\r\n </div>\r\n }@else{\r\n <div *ngFor=\"let product of [].constructor(item.trayRows)\" class=\"tray mb-3\">\r\n <div *ngFor=\"let product of [].constructor(item.productPerShelf)\" class=\"product\"></div>\r\n </div>\r\n }\r\n </div>\r\n } -->\r\n @if(item.shelfType ==='shelf'){\r\n <div [id]=\"item.shelfType + (i + 1)\" class=\"block shelf\">\r\n <div *ngFor=\"let product of [].constructor(item.productPerShelf)\" class=\"product\"></div>\r\n </div>\r\n }@else {\r\n <div [id]=\"item.shelfType! + (i + 1)\" class=\"block\">\r\n <div *ngFor=\"let product of [].constructor(item.trayRows)\" class=\"tray mb-3\">\r\n <div *ngFor=\"let product of [].constructor(item.productPerShelf)\" class=\"product\"></div>\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n </div>\r\n\r\n <!-- Footer block -->\r\n <div class=\"footer-block\"\r\n *ngIf=\"fixtureTemplateDetails?.footer?.isEnabled && fixtureTemplateDetails?.fixtureType === 'wall'\">\r\n <div class=\"sub-footer left-box\"></div>\r\n <div class=\"sub-footer right-box\"></div>\r\n <p>{{ fixtureTemplateDetails?.footer?.label }}</p>\r\n </div>\r\n </div>\r\n\r\n</section>\r\n\r\n<section id=\"template-summary-skeleton\" *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 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</section>", styles: [".header{background:#fff;padding:12px;border-radius:12px;display:flex;align-items:center;justify-content:space-between}.btn{padding:.775rem 1.5rem!important;font-size:1.1rem!important}.badge{font-weight:500;font-size:12px;line-height:18px;text-align:center;padding:2px 8px;border-radius:16px}.builder{height:75vh}.builder .cols{background:#fff;border-radius:12px;padding:24px 24px 12px;max-height:75vh;overflow-y:auto}.shelf-container{border-radius:8px;background:var(--Gray-50, #f9fafb);padding:8px 16px;margin-bottom:12px}.counter-container{display:flex;align-items:center;justify-content:center;border-radius:8px;background-color:#fff;padding:10px;border:.49px solid #d0d5dd}.counter-container span{margin:0 18px;font-weight:500;font-size:14px;text-align:center;vertical-align:middle;width:18px}.disable-counter{color:var(--bs-gray-500)!important;background-color:var(--bs-gray-200)!important;border-color:var(--bs-gray-300)!important;pointer-events:none;opacity:1}.disabled-click{pointer-events:none;opacity:.85}.wall-viewport{display:flex;align-items:center;justify-content:center;flex-direction:column;margin-bottom:30px;width:345px;text-align:center}.wall-viewport .wrapper{width:100%;max-width:345px}.wall-viewport .header-info,.wall-viewport .footer-info,.wall-viewport .body-info{width:100%;border:2px solid #f2f4f7;border-bottom:4px solid #ffffff;background:#f2f4f7;max-width:230px;display:flex;align-items:center;justify-content:center;justify-content:start;padding:12px;gap:4px}.wall-viewport .header-info p,.wall-viewport .footer-info p,.wall-viewport .body-info p{margin:0}.wall-viewport .header-info{margin-top:40px}.wall-viewport .sub-footer{border:1px solid #98a2b3;height:100%}.wall-viewport .header-block,.wall-viewport .footer-block{border:1px solid #98a2b3;height:95px;padding:8px;background-color:#f2f4f7;width:100%;display:flex;justify-content:center;align-items:center}.wall-viewport .header-block p,.wall-viewport .footer-block p{color:var(--Gray-600, #475467);font-size:18px;font-weight:600;white-space:normal;word-wrap:break-word;margin:0;background-color:#f2f4f7}.wall-viewport .body-block{width:100%}.wall-viewport .body-block .block{border:1px solid #98a2b3;padding:10px;width:100%;max-width:345px;overflow-x:auto;min-height:52px}.wall-viewport .body-block .tray,.wall-viewport .body-block .shelf{display:flex;gap:4px}.wall-viewport .body-block .tray .product,.wall-viewport .body-block .shelf .product{border:1px solid rgba(152,162,179,.2901960784);min-width:50px}.wall-viewport .body-block .tray .product{min-height:20px}.wall-viewport .body-block .shelf .product{min-height:30px}.wall-viewport .body-block .hide-product{border-color:transparent!important}.wall-viewport .body-block .hide-scroll{overflow-x:hidden!important}.horizontal-dimension{display:flex;align-items:center;justify-content:center;height:30px;position:relative}.horizontal-dimension .arrow{width:12px;height:12px;background-size:contain;background-repeat:no-repeat;background-position:center}.horizontal-dimension .arrow.left{transform:rotate(180deg);background-image:url(\"data:image/svg+xml,%3Csvg fill='%23EAECF0' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 330 330'%3E%3Cpath d='M250.606,154.389l-150-149.996c-5.857-5.858-15.355-5.858-21.213,0.001c-5.857,5.858-5.857,15.355,0.001,21.213l139.393,139.39L79.393,304.394c-5.857,5.858-5.857,15.355,0.001,21.213C82.322,328.536,86.161,330,90,330s7.678-1.464,10.607-4.394l149.999-150.004c2.814-2.813,4.394-6.628,4.394-10.606C255,161.018,253.42,157.202,250.606,154.389z'/%3E%3C/svg%3E\")}.horizontal-dimension .arrow.right{transform:rotate(0);background-image:url(\"data:image/svg+xml,%3Csvg fill='%23EAECF0' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 330 330'%3E%3Cpath d='M250.606,154.389l-150-149.996c-5.857-5.858-15.355-5.858-21.213,0.001c-5.857,5.858-5.857,15.355,0.001,21.213l139.393,139.39L79.393,304.394c-5.857,5.858-5.857,15.355,0.001,21.213C82.322,328.536,86.161,330,90,330s7.678-1.464,10.607-4.394l149.999-150.004c2.814-2.813,4.394-6.628,4.394-10.606C255,161.018,253.42,157.202,250.606,154.389z'/%3E%3C/svg%3E\")}.horizontal-dimension .line{flex:1;background-color:#eaecf0;position:relative;display:flex;align-items:center;justify-content:center;height:1px}.horizontal-dimension .line span{position:absolute;top:-12px;color:#667085;font-weight:500;font-size:14px;background-color:#fff;padding:0 4px}.vertical-dimension{display:flex;flex-direction:column;align-items:center;width:30px;position:relative}.vertical-dimension .arrow{width:12px;height:12px;background-size:contain;background-repeat:no-repeat;background-position:center}.vertical-dimension .arrow.up{transform:rotate(-90deg);margin-top:20px;background-image:url(\"data:image/svg+xml,%3Csvg fill='%23EAECF0' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 330 330'%3E%3Cpath d='M250.606,154.389l-150-149.996c-5.857-5.858-15.355-5.858-21.213,0.001c-5.857,5.858-5.857,15.355,0.001,21.213l139.393,139.39L79.393,304.394c-5.857,5.858-5.857,15.355,0.001,21.213C82.322,328.536,86.161,330,90,330s7.678-1.464,10.607-4.394l149.999-150.004c2.814-2.813,4.394-6.628,4.394-10.606C255,161.018,253.42,157.202,250.606,154.389z'/%3E%3C/svg%3E\")}.vertical-dimension .arrow.down{transform:rotate(90deg);margin-bottom:26px;background-image:url(\"data:image/svg+xml,%3Csvg fill='%23EAECF0' xmlns='http://www.w3.org/2000/svg' viewBox='0 0 330 330'%3E%3Cpath d='M250.606,154.389l-150-149.996c-5.857-5.858-15.355-5.858-21.213,0.001c-5.857,5.858-5.857,15.355,0.001,21.213l139.393,139.39L79.393,304.394c-5.857,5.858-5.857,15.355,0.001,21.213C82.322,328.536,86.161,330,90,330s7.678-1.464,10.607-4.394l149.999-150.004c2.814-2.813,4.394-6.628,4.394-10.606C255,161.018,253.42,157.202,250.606,154.389z'/%3E%3C/svg%3E\")}.vertical-dimension .line{flex:1;background-color:#eaecf0;position:relative;display:flex;align-items:center;justify-content:center;width:1px}.vertical-dimension .line span{writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);color:#667085;font-weight:500;font-size:14px;background-color:#fff;padding:2px 4px}.info-card{padding:12px;background:#fff;border:1px solid #d0d5dd;border-radius:8px;box-shadow:0 1px 2px #1018280f,0 1px 3px #1018281a}.info-card h3{font-weight:600;font-size:18px;line-height:28px;vertical-align:middle}.info-card p{font-weight:500;font-size:14px;line-height:20px;color:#667085;margin:0}.checkbox input[type=checkbox]{width:16px!important;height:16px!important;margin:5px;border-radius:4px!important;-webkit-appearance:none;-moz-appearance:none;-o-appearance:none;appearance:none;outline:1px solid var(--gray-600, #d0d5dd)!important;box-shadow:none;font-size:.5em;text-align:center;line-height:1em;background:#fff}.checkbox input[type=checkbox]:checked{outline:1px solid var(--primary-600, #00a3ff)!important;background-color:var(--primary-50, #eaf8ff)}.checkbox input[type=checkbox]:checked:after{content:\"\";transform:rotate(45deg);border-bottom:2px solid #00a3ff;border-right:2px solid #00a3ff;display:inline-block;width:.5em;padding-left:3px;padding-top:10px;padding-right:0}.nav-pills{display:inline-flex;gap:4px}.nav-pills .nav-item .nav-link{border-radius:0;color:#667085;font-size:14px;font-weight:500;padding:8px 16px;border:none}.nav-pills .nav-item .nav-link:hover{background-color:#00000005}.nav-pills .nav-item .nav-link.active{background-color:#eaf8ff;color:#009bf3;border-bottom:3px solid #009bf3}.content-wrapper{background:#fff;border-radius:12px;min-height:calc(100vh - 400px);height:100%;padding:16px 24px;display:flex;flex-direction:column}.loader .shimmer{height:150px}.filter-tab{border:1px solid rgb(234,236,240);background:#fff;box-shadow:0 1px 2px #1018280d;border-radius:8px;padding:18px;transition:all ease .2s}.filter-tab:hover{cursor:pointer}.filter-tab.selected{background:#f6fcff;border:1px solid rgb(107,202,255);box-shadow:0 1px 2px #1018280d}.filter-tab h3{color:#000;font-size:20px;font-weight:600;line-height:30px;margin:0}.filter-tab p{color:var(--Gray-500, #667085);font-size:14px;font-weight:500;line-height:20px;margin:0}.nodatamaintext{font-family:Inter;font-size:16px;font-weight:600;line-height:24px;text-align:center;color:#101828}.nodatasubtext[_ngcontent-ng-c2141490359]{font-family:Inter;font-size:14px;font-weight:400;line-height:20px;text-align:center;color:#667085}.table-responsive{min-height:calc(100vh - 495px)}.download-link{color:var(--Primary-800, #008edf);font-size:14px;font-weight:500;line-height:20px;text-decoration-line:underline;text-decoration-style:solid;text-decoration-skip-ink:auto;text-decoration-thickness:auto;text-underline-offset:auto;text-underline-position:from-font;cursor:pointer}h3.card-title{color:#101828;font-size:18px;font-weight:600;line-height:28px}p.card-tagline{color:#101828;font-size:14px;font-weight:500;line-height:20px}p.card-description{color:#344054;font-size:14px;font-weight:400;line-height:20px}#list-view .thumbnail{height:40px;width:40px;background:#f2f4f7;margin-right:12px;border-radius:8px}#list-view td{vertical-align:middle}#grid-view .card{box-shadow:0 4px 10px #0000000d;border:1px solid rgb(223,225,231);background:#fff;border-radius:12px;padding:12px;height:100%;transition:all .2s ease}#grid-view .card:hover{cursor:pointer;box-shadow:0 10px 10px #0001;transition:all .2s ease}#grid-view .card-img{margin-bottom:12px;background:#d0d5dd;height:200px;border-radius:6px}#grid-view .card-action{position:absolute;top:20px;right:20px}#grid-view .card-tagline{color:#475467;font-weight:500;font-size:14px;line-height:20px}.badge{font-weight:500;font-size:12px;line-height:18px;text-align:center;color:#027a48;background:#ecfdf3}.badge.active{color:#027a48;background:#ecfdf3}.badge.inactive{background:#f2f4f7;color:#344054}.badge.draft{color:#009bf3;background:#eaf8ff}.badge.cluster{background:#f2f4f7;color:#344054}.badge.published{background:#ecfdf3;color:#027a48}.badge.yet-to-publish{background:#f8f9fc;color:#363f72}.indicator{border-radius:16px;padding:2px 8px;display:flex;justify-content:center;align-items:center;white-space:nowrap;width:fit-content;text-align:center;font-size:14px;font-weight:500}.indicator.short{height:14px!important;width:14px!important;border-radius:50%!important;padding:0!important}.indicator.yetToComplete{background:#f2f4f7;color:#667085}.indicator.yetToComplete path{fill:#667085}.indicator.yetToAssign{background:#eaecf5;color:#344054}.indicator.yetToAssign path{fill:#344054}.indicator.taskAssigned{background:#e0eaff;color:#7a5af8}.indicator.taskAssigned path{fill:#7a5af8}.indicator.reviewPending{background:#fef0c7;color:#f79009}.indicator.reviewPending path{fill:#f79009}.indicator.flagged{background:var(--Error-50, #fef3f2);color:var(--Error-700, #b42318)}.indicator.completed{background:#d1fadf;color:#12b76a}.indicator.completed path{fill:#12b76a}.toggle-button{width:40px;height:40px;display:flex;justify-content:center;align-items:center;border-radius:8px;background:#fff;border:.89px solid rgb(208,213,221);box-shadow:0 .89px 1.78px #1018280d;transition:all ease .3s}.toggle-button:hover{cursor:pointer}.toggle-button.selected{transition:all ease .3s;background:#eaf8ff;box-shadow:0 0 0 3.56px #d5effe!important;border:.89px solid rgb(234,248,255)}.disabled-click{pointer-events:none;cursor:not-allowed!important;opacity:.6}.ellipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);pointer-events:none;color:#888;display:flex;align-items:center;height:1.5rem}.clear-search{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;padding:0;cursor:pointer;display:flex;align-items:center;height:1.5rem;width:1.5rem}#fixture-product-details #vm-products-sum .body-block{position:relative}#fixture-product-details #vm-products-sum .body-block .block{border:none}#fixture-product-details #vm-products-sum #fixture-level .brand-category{position:absolute;width:150px;overflow:hidden;padding:4px;border-radius:8px;border:2px solid var(--Primary-200, #99daff);background:var(--White, #fff);top:50%;left:59%;transform:translate(100%,-50%);transition:all .3s ease;cursor:pointer}#fixture-product-details #vm-products-sum #fixture-level .brand,#fixture-product-details #vm-products-sum #fixture-level .category{white-space:nowrap;overflow:hidden;display:block;text-overflow:ellipsis}#fixture-product-details #vm-products-sum #fixture-level .category{margin-top:12px}#fixture-product-details #vm-products-sum #section-level .brand-category{position:absolute;width:150px;overflow:hidden;padding:4px;border-radius:8px;border:2px solid var(--Primary-200, #99daff);transition:all .3s ease;display:flex;flex-direction:column;justify-content:center;align-items:center;cursor:pointer}#fixture-product-details #vm-products-sum #section-level .brand,#fixture-product-details #vm-products-sum #section-level .category{white-space:nowrap;overflow:hidden;display:block;text-overflow:ellipsis;max-width:fit-content;width:100%}#fixture-product-details #vm-products-sum #section-level .brand{color:var(--Gray-500, #667085);font-size:12px;font-style:normal;font-weight:400;line-height:18px;margin:0}#fixture-product-details #vm-products-sum #section-level .category{color:var(--Gray-800, #1d2939);font-size:12px;font-style:normal;font-weight:600;line-height:18px;margin:0}#fixture-product-details #vm-products-sum #section-level .separator{margin:0 4px;font-weight:600}#fixture-product-details #vm-products-sum #section-level #body-loader{height:100%;width:100%;position:absolute;display:flex;justify-content:center;align-items:center;z-index:1;background:#fff3;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(10px)}#fixture-product-details #vm-products-sum #section-level #body-loader .loader{width:30px;height:30px;border:4px solid #f3f3f3;border-top:4px solid #00a3ff;border-radius:50%;animation:spin 1s linear infinite;margin:auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}#fixture-product-details #vm-products-sum #shelf-level .brand-category{position:absolute;width:150px;overflow:hidden;padding:8px 4px;border-radius:8px;border:2px solid var(--Primary-200, #99daff);transition:all .3s ease;display:flex;justify-content:center;cursor:pointer}#fixture-product-details #vm-products-sum #shelf-level .brand,#fixture-product-details #vm-products-sum #shelf-level .category{white-space:nowrap;overflow:hidden;display:block;text-overflow:ellipsis;max-width:fit-content;width:100%}#fixture-product-details #vm-products-sum #shelf-level .brand{color:var(--Gray-500, #667085);font-size:12px;font-style:normal;font-weight:400;line-height:18px;margin:0}#fixture-product-details #vm-products-sum #shelf-level .category{color:var(--Gray-800, #1d2939);font-size:12px;font-style:normal;font-weight:600;line-height:18px;margin:0}#fixture-product-details #vm-products-sum #shelf-level .separator{margin:0 4px;font-weight:600}#fixture-product-details #vm-products-sum .brand-category.proper{border:1.12px solid var(--Primary-200, #32d583)!important}#fixture-product-details #vm-products-sum .footer-block{position:relative;box-sizing:border-box;justify-content:space-between!important}#fixture-product-details #vm-products-sum .footer-block p{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background-color:#f2f4f7;z-index:1}#fixture-product-details #vm-products-sum .sub-footer{position:relative;width:48%}#fixture-product-details #vm-products-sum img{width:100%;height:100%;display:block}#fixture-product-details #vm-products-sum .vm-block{position:absolute;width:100px;height:100px;transition:all .3s ease}#fixture-product-details #vm-products-sum .vm-block h3{color:var(--Gray-700, #344054);font-size:14px;font-weight:600;margin:0;width:100%;text-overflow:ellipsis;overflow:hidden}#fixture-product-details #vm-products-sum .vm-placeholder{border:4px solid var(--Black, #101828);background:#f9fafb;width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:8px;white-space:nowrap;overflow:hidden}#fixture-product-details .hero-block{background-color:#f9fafb;display:flex;flex-direction:column;gap:6px;padding:12px;justify-content:center;align-items:center;margin:24px 12px}#fixture-product-details .hero-block h1{font-size:18px;font-weight:600;color:#101828;margin:0}#fixture-product-details .hero-block p{font-size:14px;font-weight:400;color:#475467;margin:0 0 8px}#fixture-product-details .fixture-image{margin-bottom:12px}#fixture-product-details .fixture-image img{object-fit:contain;width:100%}\n"] }]
|
|
443
|
+
}], ctorParameters: () => [{ type: i1.StoreBuilderService }, { type: i2.GlobalStateService }, { type: i0.ChangeDetectorRef }, { type: i3.PlanoDataService }], propDecorators: { fixtureDetails: [{
|
|
444
|
+
type: Input
|
|
445
|
+
}], totalFixtures: [{
|
|
446
|
+
type: Input
|
|
447
|
+
}], vmList: [{
|
|
448
|
+
type: Input
|
|
449
|
+
}], floorData: [{
|
|
450
|
+
type: Input
|
|
451
|
+
}], onClose: [{
|
|
452
|
+
type: Output
|
|
453
|
+
}], changeFixture: [{
|
|
454
|
+
type: Output
|
|
455
|
+
}] } });
|
|
456
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fixture-overview-panel.component.js","sourceRoot":"","sources":["../../../../../../projects/tango-store-builder/src/lib/components/fixture-overview-panel/fixture-overview-panel.component.ts","../../../../../../projects/tango-store-builder/src/lib/components/fixture-overview-panel/fixture-overview-panel.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewChecked,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  inject,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  SimpleChanges,\r\n} from \"@angular/core\";\r\nimport { VmLibraryList } from \"../../interfaces/vm-library.interface\";\r\nimport { StoreBuilderService } from \"../../services/store-builder.service\";\r\nimport { GlobalStateService } from \"tango-app-ui-global\";\r\nimport { lastValueFrom, Subject, takeUntil } from \"rxjs\";\r\nimport { NgbActiveOffcanvas, NgbTooltip } from \"@ng-bootstrap/ng-bootstrap\";\r\nimport {\r\n  ShelfConfig,\r\n  SectionConfig,\r\n} from \"../../interfaces/fixture-template.interface\";\r\nimport { SHELF_COLORS } from \"../../data/fixture-template.data\";\r\nimport { rgbToHex } from \"../../functions/plano.function\";\r\nimport { PlanoDataService } from \"../../services/plano-data.service\";\r\nimport { NgFor, NgIf, NgStyle } from \"@angular/common\";\r\n\r\n@Component({\r\n  selector: \"lib-fixture-overview-panel\",\r\n  templateUrl: \"./fixture-overview-panel.component.html\",\r\n  styleUrl: \"./fixture-overview-panel.component.scss\",\r\n  standalone: true,\r\n  imports: [NgbTooltip, NgFor, NgIf, NgStyle],\r\n})\r\nexport class FixtureOverviewPanelComponent\r\n  implements OnInit, OnChanges, AfterViewChecked, OnDestroy\r\n{\r\n  activeOffcanvas = inject(NgbActiveOffcanvas);\r\n  @Input() fixtureDetails: any;\r\n  @Input() totalFixtures: string[] = [];\r\n  @Input() vmList: VmLibraryList[] = [];\r\n  @Input() floorData: any;\r\n\r\n  @Output() onClose = new EventEmitter<any>();\r\n  @Output() changeFixture = new EventEmitter<{\r\n    currentFixture: string;\r\n    action: \"next\" | \"previous\";\r\n  }>();\r\n\r\n  fixtureTemplateDetails: any;\r\n  clientId: string;\r\n\r\n  imgCDN: string;\r\n\r\n  shelfColors = SHELF_COLORS;\r\n  fixtureImage: string;\r\n\r\n  sectionByZones: {\r\n    zone: string;\r\n    section: {\r\n      brands: string[];\r\n      categories: string[];\r\n      shelves: string[];\r\n      shelfDivs: (HTMLElement | null | undefined)[];\r\n      capacity: number;\r\n      color: any;\r\n    };\r\n  }[] = [];\r\n\r\n  isPageLoading: boolean = true;\r\n  allFixtures: any = [];\r\n\r\n  private isVMInitialized = false;\r\n  private isBCInitialized = false;\r\n  private destroy$ = new Subject<void>();\r\n\r\n  constructor(\r\n    private storeBuilderService: StoreBuilderService,\r\n    private gs: GlobalStateService,\r\n    private cd: ChangeDetectorRef,\r\n    private dataService: PlanoDataService\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.gs.environment\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe((env) => (this.imgCDN = env.planogramCDN));\r\n\r\n    this.gs.dataRangeValue\r\n      .pipe(takeUntil(this.destroy$))\r\n      .subscribe(async (data) => {\r\n        if (data?.client) {\r\n          this.clientId = data?.client;\r\n        } else {\r\n          let headerData = JSON.parse(\r\n            localStorage.getItem(\"header-filters\") as string\r\n          );\r\n          this.clientId = headerData?.client;\r\n        }\r\n        await this.getFixtureShelfDetails(this.fixtureDetails);\r\n        setTimeout(() => {\r\n          this.applyShelfColors();\r\n          this.handleVmPositionAndSize();\r\n        }, 300);\r\n      });\r\n    this.floorData?.layoutPolygon.forEach((poly: any) => {\r\n      this.allFixtures.push(...poly.fixtures);\r\n    });\r\n\r\n    this.allFixtures.push(...this.floorData?.centerFixture);\r\n  }\r\n\r\n  async ngOnChanges(changes: SimpleChanges): Promise<void> {\r\n    console.log(\r\n      changes[\"fixtureDetails\"]?.currentValue,\r\n      'changes[\"fixtureDetails\"]?.currentValue'\r\n    );\r\n    if (changes[\"fixtureDetails\"]?.currentValue) {\r\n      await this.getFixtureShelfDetails(changes[\"fixtureDetails\"].currentValue);\r\n      setTimeout(() => {\r\n        this.applyShelfColors();\r\n        this.handleVmPositionAndSize();\r\n      }, 300);\r\n    }\r\n  }\r\n\r\n  ngAfterViewChecked(): void {\r\n    if (!this.isBCInitialized) {\r\n      this.isBCInitialized = this.applyShelfColors();\r\n    }\r\n    if (!this.isVMInitialized) {\r\n      this.isVMInitialized = this.handleVmPositionAndSize();\r\n    }\r\n  }\r\n\r\n  async getFixtureShelfDetails(data: any) {\r\n    this.isPageLoading = true;\r\n    let payload = {\r\n      ...(this.floorData?.revisionId) ? {revisionId:this.floorData?.revisionId} : {floorId:data?.floorId,planoId:data?.planoId},\r\n      fixtureId: data?._id\r\n    };\r\n\r\n    try {\r\n      const res: any = await lastValueFrom(\r\n        this.storeBuilderService.getShelfDetails(payload)\r\n      );\r\n      if (res?.status === \"success\" && res?.data) {\r\n        this.fixtureTemplateDetails = {\r\n          ...res?.data,\r\n          shelfConfig: res?.data?.shelves ?? [],\r\n        };\r\n\r\n        this.fixtureTemplateDetails.shelfConfig =\r\n          this.fixtureTemplateDetails.shelfConfig.map((s: any) => {\r\n            if (s.shelfType !== \"shelf\" && s.products?.length) {\r\n              s.distributedRows = this.distributeRoundRobin(\r\n                s.products,\r\n                s.trayRows\r\n              );\r\n            }\r\n            return s;\r\n          });\r\n\r\n        this.fixtureImage = `${this.imgCDN}${this.fixtureTemplateDetails.fixtureImage}`;\r\n      }\r\n    } catch (error) {\r\n      console.log(\"@@ ~ getFixtureShelfDetails [ERR]:\", error);\r\n    } finally {\r\n      console.log(\"test\");\r\n      this.isPageLoading = false;\r\n    }\r\n  }\r\n\r\n  getSelectedVM(vm: any) {\r\n    return this.vmList.find((v) => v.id === vm?.vmId);\r\n  }\r\n\r\n  handleVmPositionAndSize() {\r\n    const viewPort = document.getElementById(\"body-block-sum\") as HTMLElement;\r\n    if (!viewPort) return false;\r\n\r\n    const bodyWidth = viewPort.offsetWidth;\r\n\r\n    this.fixtureTemplateDetails?.vmConfig?.forEach((e: any, i: number) => {\r\n      let startShelf = e?.startYPosition ?? 1;\r\n\r\n      let endShelf =\r\n        e?.endYPosition ??\r\n        this.fixtureTemplateDetails?.shelfConfig?.length ??\r\n        1;\r\n\r\n      const vm = viewPort.querySelector(`#vm${i}`) as HTMLElement;\r\n      if (!vm) return;\r\n\r\n      let x = 0;\r\n      let y = 0;\r\n\r\n      let yStart = 0;\r\n      for (let k = 1; k < startShelf; k++) {\r\n        const s = getShelfDiv(k);\r\n        if (!s) return;\r\n\r\n        yStart += s.offsetHeight;\r\n      }\r\n\r\n      let placementHeight = 0;\r\n      let placementWidth = bodyWidth;\r\n\r\n      for (let k = startShelf; k <= endShelf; k++) {\r\n        const s = getShelfDiv(k);\r\n        if (!s) return;\r\n        placementHeight += s.offsetHeight;\r\n      }\r\n\r\n      let defaultW = placementWidth / 3;\r\n      let defaultH = placementHeight / 3;\r\n\r\n      let width = defaultW;\r\n      let height = defaultH;\r\n\r\n      switch (e?.xZone) {\r\n        case \"left\":\r\n          x = 0;\r\n          width = defaultW;\r\n          break;\r\n        case \"right\":\r\n          width = defaultW;\r\n          x = bodyWidth - width;\r\n          break;\r\n        case \"middle\":\r\n          width = defaultW;\r\n          x = (bodyWidth - width) / 2;\r\n          break;\r\n        case \"stretch\":\r\n          width = bodyWidth;\r\n          x = 0;\r\n          break;\r\n      }\r\n\r\n      switch (e?.yZone) {\r\n        case \"top\":\r\n          height = placementHeight < defaultH ? placementHeight - 20 : defaultH;\r\n          y = yStart;\r\n          break;\r\n        case \"middle\":\r\n          height = placementHeight < defaultH ? placementHeight - 20 : defaultH;\r\n          y = (placementHeight - height) / 2 + yStart;\r\n          break;\r\n        case \"bottom\":\r\n          height = placementHeight < defaultH ? placementHeight - 20 : defaultH;\r\n          y = placementHeight - height + yStart;\r\n          break;\r\n        case \"stretch\":\r\n          height = placementHeight;\r\n          y = yStart;\r\n          break;\r\n      }\r\n\r\n      vm.style.width = `${width}px`;\r\n      vm.style.height = ` ${height}px`;\r\n      vm.style.transform = `translate(${x}px, ${y}px)`;\r\n\r\n      function getShelfDiv(k: number) {\r\n        let div = viewPort.querySelector(`#shelf${k}`) as HTMLElement;\r\n        if (!div) div = viewPort.querySelector(`#tray${k}`) as HTMLElement;\r\n        return div as HTMLElement;\r\n      }\r\n    });\r\n    return true;\r\n  }\r\n\r\n  applyShelfColors() {\r\n    const bodies = document.getElementById(\"body-block-sum\") as HTMLElement;\r\n    if (!bodies) return false;\r\n\r\n    const bodyChildren = Array.from(bodies?.children ?? []) as HTMLElement[];\r\n\r\n    const shelfDivs = bodyChildren\r\n      .map((div) => div as HTMLElement)\r\n      .filter((d) => d?.id.includes(\"sumShelfContainer\"));\r\n\r\n    if (!shelfDivs) return false;\r\n\r\n    const adjust = 253;\r\n    switch (this.fixtureTemplateDetails?.productResolutionLevel) {\r\n      case \"L1\": //fixture\r\n        shelfDivs.forEach((d) => {\r\n          if (d) {\r\n            d.style.backgroundColor = this.shelfColors[0].bg;\r\n            d.style.border = `1.4px solid  ${this.shelfColors[0].border}`;\r\n          }\r\n        });\r\n        break;\r\n\r\n      case \"L3\": //section\r\n        {\r\n          const shelves = shelfDivs\r\n            .map((div) =>\r\n              div.lastElementChild?.tagName.toLowerCase() === \"div\"\r\n                ? (div.lastElementChild as HTMLElement)\r\n                : null\r\n            )\r\n            .filter(Boolean);\r\n\r\n          this.constructSequentialSection(shelves);\r\n          const sectionArray = this.groupShelvesByZone(\r\n            this.fixtureTemplateDetails?.shelfConfig ?? []\r\n          );\r\n          const allSectionShelves: string[] = [];\r\n\r\n          sectionArray.forEach((se, i) => {\r\n            const shelfIds =\r\n              se.shelves?.map((sh) => sh.replace(/\\s/g, \"\").toLowerCase()) ??\r\n              [];\r\n            allSectionShelves.push(...shelfIds);\r\n            const secDivs = shelves.filter((item) =>\r\n              shelfIds?.includes(item?.id ?? \"\")\r\n            );\r\n\r\n            secDivs.forEach((d) => {\r\n              if (d) {\r\n                d.style.backgroundColor = this.shelfColors[i].bg;\r\n                d.style.border = `1.4px solid  ${this.shelfColors[i].border}`;\r\n              }\r\n            });\r\n          });\r\n\r\n          const unassignedShelves = shelfDivs.filter(\r\n            (item) => !allSectionShelves.includes(item.id)\r\n          );\r\n          unassignedShelves.forEach((d) => (d.style.backgroundColor = \"white\"));\r\n\r\n          let sectionGroupHeight = 0;\r\n          setTimeout(() => {\r\n            this.sectionByZones.forEach((sz, i) => {\r\n              const currentSectionHeight = sz.section.shelfDivs.reduce(\r\n                (h, d) => h + (d?.offsetHeight ?? 0),\r\n                0\r\n              );\r\n              const currentSectionWidth =\r\n                sz.section.shelfDivs[0]?.offsetWidth ?? 345;\r\n\r\n              const bc = bodies.querySelector<HTMLElement>(\r\n                `#brand-category${i}`\r\n              );\r\n\r\n              if (bc) {\r\n                const secBg = rgbToHex(\r\n                  sz.section.shelfDivs[0]?.style.backgroundColor\r\n                );\r\n                const color =\r\n                  this.shelfColors.find((c) => c.bg === secBg) ??\r\n                  this.shelfColors[i];\r\n\r\n                bc.style.borderColor = color.border;\r\n                bc.style.backgroundColor = \"#fff\";\r\n\r\n                const bcX = (currentSectionWidth - bc.offsetWidth) / 2;\r\n                const bcY =\r\n                  (currentSectionHeight - bc.offsetHeight) / 2 +\r\n                  sectionGroupHeight;\r\n                bc.style.transform = `translate(${bcX + adjust}px, ${bcY}px)`;\r\n\r\n                sectionGroupHeight += currentSectionHeight;\r\n              }\r\n            });\r\n          }, 0);\r\n        }\r\n\r\n        break;\r\n\r\n      case \"L2\": //shelf\r\n        {\r\n          shelfDivs.forEach((div, i) => {\r\n            div.style.backgroundColor = this.shelfColors[i].bg;\r\n            div.style.border = `1.4px solid ${this.shelfColors[i].border}`;\r\n            const bc = div.querySelector<HTMLElement>(`#brand-category${i}`);\r\n            if (!bc) return;\r\n\r\n            const bcX = (div.offsetWidth - bc.offsetWidth) / 2;\r\n            const bcY = (div.offsetHeight - bc.offsetHeight) / 2;\r\n\r\n            bc.style.borderColor = this.shelfColors[i].border;\r\n            bc.style.backgroundColor = this.shelfColors[i].textBg;\r\n            bc.style.transform = `translate(${bcX + adjust}px, ${bcY}px)`;\r\n          });\r\n        }\r\n        break;\r\n      case \"L4\": //spot\r\n        {\r\n          shelfDivs.forEach((d) => {\r\n            if (d) {\r\n              d.style.backgroundColor = this.shelfColors[0].bg;\r\n              d.style.border = `1.4px solid ${this.shelfColors[0].border}`;\r\n            }\r\n          });\r\n        }\r\n        break;\r\n      default:\r\n        shelfDivs.forEach((d) => {\r\n          if (d) {\r\n            d.style.backgroundColor = this.shelfColors[0].bg;\r\n            d.style.border = `1.4px solid ${this.shelfColors[0].border}`;\r\n          }\r\n        });\r\n        break;\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  constructSequentialSection(shelfDivs: (HTMLElement | null)[]) {\r\n    const newSectionByZones = [];\r\n    let pZone: string | null = null;\r\n\r\n    for (let i = 0; i < this.fixtureTemplateDetails?.shelfConfig.length; i++) {\r\n      const s = this.fixtureTemplateDetails?.shelfConfig[i];\r\n      const zone = s.zone || \"\";\r\n      const shelfId = `${s.shelfType}${s.shelfNumber}`;\r\n      const shelfDiv = shelfDivs.find((d) => d?.id === shelfId);\r\n\r\n      if (zone === \"\") continue;\r\n\r\n      // const hasImproperProduct =\r\n      //   (s?.products?.length ?? 0) === 0 ||\r\n      (s?.products ?? []).some((p: any) => p.status !== \"proper\");\r\n      const shelfCapacity =\r\n        s.shelfType === \"tray\"\r\n          ? s.productPerShelf * s.trayRows\r\n          : s.productPerShelf;\r\n      if (zone !== pZone) {\r\n        newSectionByZones.push({\r\n          zone,\r\n          section: {\r\n            brands: s.productBrandName ?? [],\r\n            categories: s.productCategory ?? [],\r\n            shelves: [shelfId],\r\n            shelfDivs: [shelfDiv],\r\n            capacity: shelfCapacity,\r\n            color: this.shelfColors[i],\r\n            // products: structuredClone(s?.products) ?? [],\r\n            // improper: hasImproperProduct,\r\n          },\r\n        });\r\n        pZone = zone;\r\n      } else {\r\n        const section = newSectionByZones[newSectionByZones.length - 1].section;\r\n        section.shelves.push(shelfId);\r\n        section.shelfDivs.push(shelfDiv);\r\n        section.capacity += shelfCapacity;\r\n        // if (hasImproperProduct) section.improper = true;\r\n      }\r\n    }\r\n\r\n    this.sectionByZones = [...newSectionByZones];\r\n    this.cd.detectChanges();\r\n  }\r\n\r\n  groupShelvesByZone(input: ShelfConfig[]): SectionConfig[] {\r\n    const zoneMap: { [zone: string]: SectionConfig } = {};\r\n\r\n    for (const item of input) {\r\n      const zone = item?.zone ?? \"\";\r\n      const shelfLabel = `${item.shelfType} ${item.shelfNumber}`;\r\n\r\n      if (!zoneMap[zone]) {\r\n        zoneMap[zone] = {\r\n          shelves: [],\r\n          productBrandName:\r\n            this.fixtureTemplateDetails?.productResolutionLevel === \"L2\"\r\n              ? item.productBrandName\r\n              : [],\r\n          productCategory:\r\n            this.fixtureTemplateDetails?.productResolutionLevel === \"L2\"\r\n              ? item.productCategory\r\n              : [],\r\n          zone: zone,\r\n        };\r\n      }\r\n\r\n      zoneMap[zone]?.shelves?.push(shelfLabel);\r\n    }\r\n\r\n    return Object.values(zoneMap);\r\n  }\r\n\r\n  applySectionConfigToShelves(sections: SectionConfig[]): ShelfConfig[] {\r\n    const sectionMap = new Map<\r\n      string,\r\n      Pick<SectionConfig, \"zone\" | \"productBrandName\" | \"productCategory\">\r\n    >();\r\n\r\n    for (const section of sections) {\r\n      for (const shelfLabel of section.shelves!) {\r\n        sectionMap.set(shelfLabel, {\r\n          zone: section.zone,\r\n          productBrandName: section.productBrandName,\r\n          productCategory: section.productCategory,\r\n        });\r\n      }\r\n    }\r\n\r\n    // Apply overrides to matching shelves\r\n    return (\r\n      this.fixtureTemplateDetails?.shelfConfig?.map((shelf: any) => {\r\n        const shelfLabel = `${shelf.shelfType} ${shelf.shelfNumber}`;\r\n        const override = sectionMap.get(shelfLabel);\r\n\r\n        return {\r\n          ...shelf,\r\n          zone: override?.zone || \"\",\r\n          productBrandName: override?.productBrandName ?? [],\r\n          productCategory: override?.productCategory ?? [],\r\n        };\r\n      }) ?? []\r\n    );\r\n  }\r\n\r\n  openZoneLevelProductModal(zoneData: any, level: string) {}\r\n\r\n  distributeRoundRobin(products: any, trayRows: number) {\r\n    const result: any = Array.from({ length: trayRows }, () => []);\r\n\r\n    products.forEach((product: any, index: number) => {\r\n      const trayIndex = index % trayRows;\r\n      result[trayIndex].push(product);\r\n    });\r\n\r\n    return result;\r\n  }\r\n\r\n  onClickClose() {\r\n    this.onClose.emit(\"\");\r\n  }\r\n\r\n  async onChangeFixture(change: \"next\" | \"previous\") {\r\n    this.fixtureDetails = null;\r\n    let fixtId = this.fixtureTemplateDetails._id;\r\n    let indexToSelect = this.totalFixtures.findIndex(\r\n      (f: any) => f === this.fixtureTemplateDetails._id\r\n    );\r\n\r\n    if (change === \"next\") {\r\n      if (indexToSelect == this.totalFixtures.length - 1) return;\r\n      indexToSelect++;\r\n    } else {\r\n      if (indexToSelect == 0) return;\r\n      indexToSelect--;\r\n    }\r\n    let fixtureId = this.totalFixtures[indexToSelect];\r\n\r\n    let fixtureData = this.allFixtures.find(\r\n      (ele: any) => ele._id.toString() == fixtureId\r\n    );\r\n    if (!fixtureData) {\r\n      return;\r\n    }\r\n    this.fixtureDetails = fixtureData;\r\n    await this.getFixtureShelfDetails(this.fixtureDetails);\r\n    setTimeout(() => {\r\n      this.applyShelfColors();\r\n      this.handleVmPositionAndSize();\r\n    }, 300);\r\n    this.dataService.emit({\r\n      currentFixture: fixtId,\r\n      action: change,\r\n      revisionId: `${this.floorData.revisionId} - ${fixtureId}`,\r\n    });\r\n    this.cd.detectChanges();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n}\r\n","<section id=\"fixture-product-details\" *ngIf=\"!isPageLoading\">\r\n    <div class=\"offcanvas-header d-flex w-100 justify-content-between p-3 align-items-center\" (click)=\"activeOffcanvas.dismiss()\">\r\n        <h4 class=\"m-0\">Fixture details</h4>\r\n        <svg class=\"cursor-pointer\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\"\r\n            xmlns=\"http://www.w3.org/2000/svg\">\r\n            <path d=\"M18 6L6 18M6 6L18 18\" stroke=\"#475467\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                stroke-linejoin=\"round\" />\r\n        </svg>\r\n    </div>\r\n    <hr>\r\n    <div class=\"offcanvas-body d-flex align-items-center gap-6 px-3\">\r\n\r\n        <svg (click)=\"onChangeFixture('previous')\" class=\"cursor-pointer\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\"\r\n            fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n            <path d=\"M15 6L9 12L15 18\" stroke=\"#1D2939\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                stroke-linejoin=\"round\" />\r\n        </svg>\r\n\r\n\r\n        <h3 class=\"m-0\">{{fixtureTemplateDetails?.header?.label}}</h3>\r\n\r\n        <h3 class=\"m-0 ms-auto\">{{totalFixtures.indexOf(fixtureTemplateDetails?._id) + 1}}/{{totalFixtures.length}}</h3>\r\n\r\n        <svg (click)=\"onChangeFixture('next')\" class=\"cursor-pointer\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\"\r\n            fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n            <path d=\"M9 18L15 12L9 6\" stroke=\"#1D2939\" stroke-width=\"2\" stroke-linecap=\"round\"\r\n                stroke-linejoin=\"round\" />\r\n        </svg>\r\n\r\n\r\n    </div>\r\n    <div class=\"hero-block\">\r\n        <div class=\"row g-0 m-0 w-100\">\r\n            <div class=\"col px-4\">\r\n                <p>Fixture name:</p>\r\n                <p>Fixture type:</p>\r\n                <p>Size (Width):</p>\r\n                <p>Total shelves:</p>\r\n                <p>Total product capacity:</p>\r\n            </div>\r\n            <div class=\"col px-4\">\r\n                <p><b>{{fixtureTemplateDetails?.header?.label}}</b></p>\r\n                <p><b>{{fixtureTemplateDetails?.fixtureCategory}}</b></p>\r\n                <p><b>{{fixtureTemplateDetails?.fixtureWidth.value}}{{fixtureTemplateDetails?.fixtureWidth.unit}}</b>\r\n                </p>\r\n                <p><b>{{fixtureTemplateDetails?.shelfConfig?.length}}</b></p>\r\n                <p><b>{{fixtureTemplateDetails?.fixtureCapacity}}</b></p>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div class=\"px-4\">\r\n        <h5>Planogram design </h5>\r\n        <p>Fixture designed by the planogram team</p>\r\n    </div>\r\n    <div id=\"vm-products-sum\" class=\"wall-viewport px-4\">\r\n        <!-- Header block -->\r\n        <div class=\"header-block\"\r\n            *ngIf=\"fixtureTemplateDetails?.header?.isEnabled && fixtureTemplateDetails?.fixtureType === 'wall'\">\r\n            <p>{{ fixtureTemplateDetails?.header?.label }}</p>\r\n        </div>\r\n\r\n        <!-- Body block -->\r\n        <div id=\"body-block-sum\" class=\"body-block\">\r\n            <!----------------------------------[VM BLOCK]--------------------------------------->\r\n            <div *ngIf=\"fixtureTemplateDetails?.vmConfig?.length\">\r\n                <ng-container *ngFor=\"let vm of fixtureTemplateDetails?.vmConfig; let i = index\">\r\n                    <div [id]=\"'vm' + i\" class=\"vm-block\">\r\n                        <ng-container *ngIf=\"getSelectedVM(vm) as selectedVM\">\r\n                            <img *ngIf=\"selectedVM?.imgUrl; else placeholder\" [src]=\"selectedVM?.imgUrl\"\r\n                                alt=\"Vm Image\" />\r\n                            <ng-template #placeholder>\r\n                                <div class=\"vm-placeholder\">\r\n                                    <h3>{{ selectedVM?.name }}</h3>\r\n                                </div>\r\n                            </ng-template>\r\n                        </ng-container>\r\n                    </div>\r\n                </ng-container>\r\n            </div>\r\n\r\n            <!----------------------------------[FIXTURE LEVEL - BRAND CATEGORY]-------------------------------------->\r\n            <div id=\"fixture-level\" *ngIf=\"fixtureTemplateDetails?.productResolutionLevel === 'L1'\">\r\n                <div id=\"brand-category\" class=\"brand-category\" *ngIf=\"fixtureTemplateDetails?.productBrandName?.length\"\r\n                    [ngbTooltip]=\"brandCategoryTooltip\">\r\n                    <span class=\"brand\">\r\n                        <ng-container *ngFor=\"let b of fixtureTemplateDetails?.productBrandName; let last = last\">\r\n                            <span class=\"badge draft me-1\">\r\n                                {{ b }}\r\n                            </span>\r\n                        </ng-container>\r\n                    </span>\r\n                    <span class=\"category\" *ngIf=\"fixtureTemplateDetails?.productCategory?.length\">\r\n                        <ng-container *ngFor=\"let c of fixtureTemplateDetails?.productCategory; let last = last\">\r\n                            {{ c }}\r\n                            <ng-container *ngIf=\"!last\">, </ng-container>\r\n                        </ng-container>\r\n                    </span>\r\n                    <span class=\"badge inactive mt-1\">\r\n                        Capacity {{fixtureTemplateDetails?.fixtureCapacity }}\r\n                    </span>\r\n                </div>\r\n                <ng-template #brandCategoryTooltip>\r\n                    <div>\r\n                        <p>\r\n                            <b>Brands: </b>\r\n                            <ng-container *ngFor=\"let c of fixtureTemplateDetails?.productBrandName; let last = last\">\r\n                                {{ c }}\r\n                                <ng-container *ngIf=\"!last\">, </ng-container>\r\n                            </ng-container>\r\n                        </p>\r\n                        <p *ngIf=\"fixtureTemplateDetails?.productCategory?.length\">\r\n                            <b>Categories: </b>\r\n                            <ng-container *ngFor=\"let c of fixtureTemplateDetails?.productCategory; let last = last\">\r\n                                {{ c }}\r\n                                <ng-container *ngIf=\"!last\">, </ng-container>\r\n                            </ng-container>\r\n                        </p>\r\n                    </div>\r\n                </ng-template>\r\n            </div>\r\n            <!------------------------------------------------------------------------->\r\n\r\n            <!-----------------------------------[SECTION LEVEL - BRAND CATEGORY]-------------------------------------->\r\n            <div id=\"section-level\" *ngIf=\"fixtureTemplateDetails?.productResolutionLevel === 'L3'\">\r\n                @for (item of sectionByZones; track $index) {\r\n                <div [id]=\"'brand-category' + $index\" class=\"brand-category\" [ngbTooltip]=\"brandCategoryTooltip\"\r\n                    (click)=\"openZoneLevelProductModal(item,'section')\">\r\n                    <div class=\"d-flex\">\r\n                        <span class=\"badge me-1\"\r\n                            [ngStyle]=\"{'background-color':item.section.color.textBg,'color':item.section.color.text}\">\r\n                            {{ item.zone }}\r\n                        </span>\r\n                        <span class=\"badge inactive\">\r\n                            Capacity {{ item?.section?.capacity }}\r\n                        </span>\r\n                    </div>\r\n                    <div class=\"w-100 d-flex justify-content-center\">\r\n                        <span class=\"brand\" *ngIf=\"item?.section?.brands?.length\">\r\n                            @for (b of item?.section?.brands;track $index; let last = $last) {\r\n                            {{ b }}\r\n                            <ng-container *ngIf=\"!last\">, </ng-container>\r\n                            }\r\n                        </span>\r\n                        <span *ngIf=\"item?.section?.categories?.length\" class=\"separator\"> - </span>\r\n                        <span class=\"category\" *ngIf=\"item?.section?.categories?.length\">\r\n                            @for (c of item?.section?.categories;track $index; let last = $last) {\r\n                            {{ c }}\r\n                            <ng-container *ngIf=\"!last\">, </ng-container>\r\n                            }\r\n                        </span>\r\n                    </div>\r\n                </div>\r\n\r\n                <ng-template #brandCategoryTooltip>\r\n                    <div>\r\n                        <p>\r\n                            <b>Brands: </b>\r\n                            @for (b of item?.section?.brands;track $index; let last = $last) {\r\n                            {{ b }}\r\n                            <ng-container *ngIf=\"!last\">, </ng-container>\r\n                            }\r\n                        </p>\r\n                        <p *ngIf=\"item?.section?.categories?.length\">\r\n                            <b>Categories: </b>\r\n                            @for (c of item?.section?.categories;track $index; let last = $last) {\r\n                            {{ c }}\r\n                            <ng-container *ngIf=\"!last\">, </ng-container>\r\n                            }\r\n                        </p>\r\n                    </div>\r\n                </ng-template>\r\n                }\r\n            </div>\r\n            <!------------------------------------------------------------------------->\r\n\r\n            <div [id]=\"'sumShelfContainer' + i\" *ngFor=\"let item of fixtureTemplateDetails?.shelfConfig; let i = index\">\r\n                <!--------------------------------[SHELF LEVEL - BRAND CATEGORY]---------------------------------------->\r\n                <div id=\"shelf-level\" *ngIf=\"fixtureTemplateDetails?.productResolutionLevel === 'L2'\">\r\n                    <div [id]=\"'brand-category' + i\" class=\"brand-category\" *ngIf=\"item.productBrandName?.length\"\r\n                        [ngbTooltip]=\"brandCategoryTooltip\">\r\n                        <span class=\"brand\" *ngIf=\"item.productBrandName?.length\">\r\n                            <ng-container *ngFor=\"let b of item.productBrandName; let last = last\">\r\n                                {{ b }}\r\n                                <ng-container *ngIf=\"!last\">, </ng-container>\r\n                            </ng-container>\r\n                        </span>\r\n                        <span *ngIf=\"item.productCategory?.length\" class=\"separator\"> - </span>\r\n                        <span class=\"category\" *ngIf=\"item.productCategory?.length\">\r\n                            <ng-container *ngFor=\"let b of item.productCategory; let last = last\">\r\n                                {{ b }}\r\n                                <ng-container *ngIf=\"!last\">, </ng-container>\r\n                            </ng-container>\r\n                        </span>\r\n                    </div>\r\n                    <ng-template #brandCategoryTooltip>\r\n                        <div>\r\n                            <p>\r\n                                <b>Brands: </b>\r\n                                <ng-container *ngFor=\"let c of item.productBrandName; let last = last\">\r\n                                    {{ c }}\r\n                                    <ng-container *ngIf=\"!last\">, </ng-container>\r\n                                </ng-container>\r\n                            </p>\r\n                            <p *ngIf=\"item.productCategory?.length\">\r\n                                <b>Categories: </b>\r\n                                <ng-container *ngFor=\"let c of item.productCategory; let last = last\">\r\n                                    {{ c }}\r\n                                    <ng-container *ngIf=\"!last\">, </ng-container>\r\n                                </ng-container>\r\n                            </p>\r\n                            <span class=\"badge inactive\">\r\n                                Capacity {{item?.productPerShelf }}\r\n                            </span>\r\n\r\n                        </div>\r\n                    </ng-template>\r\n                </div>\r\n                <!------------------------------------------------------------------------->\r\n\r\n                <!-- @if(item.shelfType ==='shelf'){\r\n                <div [id]=\"item.shelfType + (i + 1)\" class=\"block shelf\">\r\n                    @if(item.products.length){\r\n                    <div *ngFor=\"let product of item.products\" class=\"product\"\r\n                        [class.error]=\"product.status === 'missing' || product.status === 'misplaced'\">\r\n                        @if(product.status != 'missing'){\r\n                        <img *ngIf=\"product?.productImageUrl; else placeholder\" [src]=\"product?.productImageUrl\"\r\n                            alt=\"Product Image\" />\r\n                        <ng-template #placeholder>\r\n                            <div></div>\r\n                        </ng-template>\r\n                        }\r\n                    </div>\r\n                    }@else {\r\n                    <div *ngFor=\"let product of [].constructor(item.productPerShelf)\" class=\"product\"></div>\r\n                    }\r\n                </div>\r\n                }@else {\r\n                <div [id]=\"item.shelfType! + (i + 1)\" class=\"block\">\r\n                    @if(item.products.length){\r\n                    <div *ngFor=\"let row of item.distributedRows\" class=\"tray mb-3\">\r\n                        <div *ngFor=\"let product of row\" class=\"product\"\r\n                            [class.error]=\"product.status === 'missing' || product.status === 'misplaced'\">\r\n                            @if(product.status != 'missing'){\r\n                            <img *ngIf=\"product?.productImageUrl; else placeholder\" [src]=\"product?.productImageUrl\"\r\n                                alt=\"Product Image\" />\r\n                            <ng-template #placeholder>\r\n                                <div></div>\r\n                            </ng-template>\r\n                            }\r\n                        </div>\r\n                    </div>\r\n                    }@else{\r\n                    <div *ngFor=\"let product of [].constructor(item.trayRows)\" class=\"tray mb-3\">\r\n                        <div *ngFor=\"let product of [].constructor(item.productPerShelf)\" class=\"product\"></div>\r\n                    </div>\r\n                    }\r\n                </div>\r\n                } -->\r\n                @if(item.shelfType ==='shelf'){\r\n                <div [id]=\"item.shelfType + (i + 1)\" class=\"block shelf\">\r\n                    <div *ngFor=\"let product of [].constructor(item.productPerShelf)\" class=\"product\"></div>\r\n                </div>\r\n                }@else {\r\n                <div [id]=\"item.shelfType! + (i + 1)\" class=\"block\">\r\n                    <div *ngFor=\"let product of [].constructor(item.trayRows)\" class=\"tray mb-3\">\r\n                        <div *ngFor=\"let product of [].constructor(item.productPerShelf)\" class=\"product\"></div>\r\n                    </div>\r\n                </div>\r\n                }\r\n            </div>\r\n        </div>\r\n\r\n        <!-- Footer block -->\r\n        <div class=\"footer-block\"\r\n            *ngIf=\"fixtureTemplateDetails?.footer?.isEnabled && fixtureTemplateDetails?.fixtureType === 'wall'\">\r\n            <div class=\"sub-footer left-box\"></div>\r\n            <div class=\"sub-footer right-box\"></div>\r\n            <p>{{ fixtureTemplateDetails?.footer?.label }}</p>\r\n        </div>\r\n    </div>\r\n\r\n</section>\r\n\r\n<section id=\"template-summary-skeleton\" *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 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</section>"]}
|