tango-app-ui-store-builder 1.0.1-beta-1
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/README.md +24 -0
- package/esm2022/lib/components/create-layout/create-layout.component.mjs +1815 -0
- package/esm2022/lib/components/create-layout/popups/add-floor/add-floor.component.mjs +40 -0
- package/esm2022/lib/components/create-layout/popups/clear-all-steps/clear-all-steps.component.mjs +16 -0
- package/esm2022/lib/components/create-layout/popups/delete-layout/delete-layout.component.mjs +16 -0
- package/esm2022/lib/components/custom-select/custom-select.component.mjs +155 -0
- package/esm2022/lib/components/layout-builder/layout-builder.component.mjs +56 -0
- package/esm2022/lib/components/layout-summary/layout-summary.component.mjs +809 -0
- package/esm2022/lib/components/layout-summary/popups/complete-layout/complete-layout.component.mjs +16 -0
- package/esm2022/lib/components/reactive-select/reactive-select.component.mjs +87 -0
- package/esm2022/lib/components/store-layout-table/store-layout-table.component.mjs +709 -0
- package/esm2022/lib/components/store-offcanvas-component/store-offcanvas-component.component.mjs +99 -0
- package/esm2022/lib/interfaces/layout-builder.interface.mjs +2 -0
- package/esm2022/lib/services/store-builder.service.mjs +99 -0
- package/esm2022/lib/tango-store-builder-routing.module.mjs +41 -0
- package/esm2022/lib/tango-store-builder.module.mjs +71 -0
- package/esm2022/public-api.mjs +5 -0
- package/esm2022/tango-app-ui-store-builder.mjs +5 -0
- package/esm2022/tango-store-builder.mjs +5 -0
- package/fesm2022/tango-app-ui-store-builder.mjs +3947 -0
- package/fesm2022/tango-app-ui-store-builder.mjs.map +1 -0
- package/fesm2022/tango-store-builder.mjs +3947 -0
- package/fesm2022/tango-store-builder.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/components/create-layout/create-layout.component.d.ts +197 -0
- package/lib/components/create-layout/popups/add-floor/add-floor.component.d.ts +16 -0
- package/lib/components/create-layout/popups/clear-all-steps/clear-all-steps.component.d.ts +8 -0
- package/lib/components/create-layout/popups/delete-layout/delete-layout.component.d.ts +8 -0
- package/lib/components/custom-select/custom-select.component.d.ts +33 -0
- package/lib/components/layout-builder/layout-builder.component.d.ts +18 -0
- package/lib/components/layout-summary/layout-summary.component.d.ts +92 -0
- package/lib/components/layout-summary/popups/complete-layout/complete-layout.component.d.ts +8 -0
- package/lib/components/reactive-select/reactive-select.component.d.ts +26 -0
- package/lib/components/store-layout-table/store-layout-table.component.d.ts +73 -0
- package/lib/components/store-offcanvas-component/store-offcanvas-component.component.d.ts +26 -0
- package/lib/interfaces/layout-builder.interface.d.ts +23 -0
- package/lib/services/store-builder.service.d.ts +33 -0
- package/lib/tango-store-builder-routing.module.d.ts +7 -0
- package/lib/tango-store-builder.module.d.ts +22 -0
- package/package.json +25 -0
- package/public-api.d.ts +1 -0
package/index.d.ts
ADDED
|
@@ -0,0 +1,197 @@
|
|
|
1
|
+
import { FormControl } from '@angular/forms';
|
|
2
|
+
import { CdkDragDrop } from '@angular/cdk/drag-drop';
|
|
3
|
+
import { ActivatedRoute, Router } from '@angular/router';
|
|
4
|
+
import { StoreBuilderService } from '../../services/store-builder.service';
|
|
5
|
+
import { HeaderFilter } from '../../interfaces/layout-builder.interface';
|
|
6
|
+
import { NgbModal, NgbOffcanvas } from '@ng-bootstrap/ng-bootstrap';
|
|
7
|
+
import { ChangeDetectorRef, ElementRef, OnDestroy, OnInit, Renderer2 } from '@angular/core';
|
|
8
|
+
import { ToastService } from 'tango-app-ui-shared';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
export declare class CreateLayoutComponent implements OnInit, OnDestroy {
|
|
11
|
+
private cd;
|
|
12
|
+
private renderer;
|
|
13
|
+
private route;
|
|
14
|
+
private apiService;
|
|
15
|
+
private router;
|
|
16
|
+
private offcanvasService;
|
|
17
|
+
private toastService;
|
|
18
|
+
private modalDef;
|
|
19
|
+
floorsInput: FormControl<any>;
|
|
20
|
+
canvasRef: ElementRef<HTMLCanvasElement>;
|
|
21
|
+
widgetCanvasRef: ElementRef<HTMLCanvasElement>;
|
|
22
|
+
scrollContainerRef: ElementRef;
|
|
23
|
+
gridWidth: number;
|
|
24
|
+
gridHeight: number;
|
|
25
|
+
private ctx;
|
|
26
|
+
private canvas;
|
|
27
|
+
private widgetCtx;
|
|
28
|
+
private widgetCanvas;
|
|
29
|
+
elementType: 'wall' | 'facade' | 'opening' | 'entrance';
|
|
30
|
+
layoutPolygon: any[];
|
|
31
|
+
popupVisible: boolean;
|
|
32
|
+
popupPosition: any;
|
|
33
|
+
selectedLine: any;
|
|
34
|
+
selectedLineIndex: number | null;
|
|
35
|
+
movePixels: number;
|
|
36
|
+
moveAngle: number;
|
|
37
|
+
unit: 'ft';
|
|
38
|
+
moveDirection: 'left' | 'right' | 'up' | 'down';
|
|
39
|
+
layoutMode: 'full' | 'half';
|
|
40
|
+
elementSelect: {
|
|
41
|
+
show: boolean;
|
|
42
|
+
index: number;
|
|
43
|
+
};
|
|
44
|
+
directionSelect: {
|
|
45
|
+
show: boolean;
|
|
46
|
+
index: number;
|
|
47
|
+
};
|
|
48
|
+
lineOptionsSelect: {
|
|
49
|
+
show: boolean;
|
|
50
|
+
index: number;
|
|
51
|
+
};
|
|
52
|
+
widgetElementSelect: {
|
|
53
|
+
show: boolean;
|
|
54
|
+
};
|
|
55
|
+
layoutOptionSelect: {
|
|
56
|
+
show: boolean;
|
|
57
|
+
};
|
|
58
|
+
floorSelect: {
|
|
59
|
+
show: boolean;
|
|
60
|
+
deleteIndex: number | null;
|
|
61
|
+
};
|
|
62
|
+
private scale;
|
|
63
|
+
panOffset: {
|
|
64
|
+
x: number;
|
|
65
|
+
y: number;
|
|
66
|
+
};
|
|
67
|
+
breakpoints: number[];
|
|
68
|
+
circleRef: ElementRef;
|
|
69
|
+
pointerRef: ElementRef;
|
|
70
|
+
lines: {
|
|
71
|
+
transform: string;
|
|
72
|
+
highlight: boolean;
|
|
73
|
+
invisible: boolean;
|
|
74
|
+
}[];
|
|
75
|
+
private minAngle;
|
|
76
|
+
private maxAngle;
|
|
77
|
+
private destroy$;
|
|
78
|
+
headerData: HeaderFilter | null | undefined;
|
|
79
|
+
planoStoreList: any[];
|
|
80
|
+
selectedStore: any;
|
|
81
|
+
selectedFloor: any;
|
|
82
|
+
undoStack: any[];
|
|
83
|
+
redoStack: any[];
|
|
84
|
+
planoIds: string[];
|
|
85
|
+
itemsPerPage: number;
|
|
86
|
+
currentPage: number;
|
|
87
|
+
totalItems: number;
|
|
88
|
+
paginationSizes: number[];
|
|
89
|
+
pageSize: number;
|
|
90
|
+
pixelPerMetre: number;
|
|
91
|
+
cumulativeRotation: number;
|
|
92
|
+
onPageChange(val: number): void;
|
|
93
|
+
saveStateToUndo(): void;
|
|
94
|
+
undo(): void;
|
|
95
|
+
redo(): void;
|
|
96
|
+
constructor(cd: ChangeDetectorRef, renderer: Renderer2, route: ActivatedRoute, apiService: StoreBuilderService, router: Router, offcanvasService: NgbOffcanvas, toastService: ToastService, modalDef: NgbModal);
|
|
97
|
+
initializeLayout(): void;
|
|
98
|
+
ngOnInit(): void;
|
|
99
|
+
onFloorSelect(floorId: string): void;
|
|
100
|
+
ngOnDestroy(): void;
|
|
101
|
+
onStoreChange(event: any): void;
|
|
102
|
+
openOffCanva(): void;
|
|
103
|
+
getPlanoData(): void;
|
|
104
|
+
updateFloorLayout(): void;
|
|
105
|
+
deleteFloor(index: number): void;
|
|
106
|
+
addFloor(planoId: string, floorCount: number): void;
|
|
107
|
+
onSaveAsDraft(): void;
|
|
108
|
+
onConfigure(): void;
|
|
109
|
+
drawWidgetRing(): void;
|
|
110
|
+
private updateWidgetPointer;
|
|
111
|
+
drawGrid(): void;
|
|
112
|
+
drawPolygon(polygon?: any[]): void;
|
|
113
|
+
onMouseWheel(event: WheelEvent): void;
|
|
114
|
+
adjustZoom(event: MouseEvent, scaleFactor: number): void;
|
|
115
|
+
resetZoom(): void;
|
|
116
|
+
transformPoint(point: {
|
|
117
|
+
x: number;
|
|
118
|
+
y: number;
|
|
119
|
+
}): {
|
|
120
|
+
x: number;
|
|
121
|
+
y: number;
|
|
122
|
+
};
|
|
123
|
+
drawLine(ctx: CanvasRenderingContext2D, line: {
|
|
124
|
+
x: number;
|
|
125
|
+
y: number;
|
|
126
|
+
}[]): void;
|
|
127
|
+
redrawCanvas(): void;
|
|
128
|
+
onOutsideClick(event: MouseEvent): void;
|
|
129
|
+
toggleLineOptionsSelect(index: number): void;
|
|
130
|
+
toggleDirectionSelect(index: number): void;
|
|
131
|
+
toggleElementSelect(index: number): void;
|
|
132
|
+
toggleWidgetElementSelect(): void;
|
|
133
|
+
toggleLayoutOptionSelect(): void;
|
|
134
|
+
toggleFloorSelect(): void;
|
|
135
|
+
drop(event: CdkDragDrop<any[]>): void;
|
|
136
|
+
snapToGrid(value: number, gridSize: number): number;
|
|
137
|
+
isPointInPolygon(point: any, polygon: any[]): boolean;
|
|
138
|
+
movePointWithAngle(): void;
|
|
139
|
+
getMaxElementNumber(data: any, elementType: string): number;
|
|
140
|
+
onMouseDown(event: MouseEvent): void;
|
|
141
|
+
selectLine(line: any, index: number): void;
|
|
142
|
+
openWidget(position: {
|
|
143
|
+
x: number;
|
|
144
|
+
y: number;
|
|
145
|
+
}, offset?: {
|
|
146
|
+
up: number;
|
|
147
|
+
right: number;
|
|
148
|
+
down: number;
|
|
149
|
+
left: number;
|
|
150
|
+
}): void;
|
|
151
|
+
closeWidget(): void;
|
|
152
|
+
onMouseMove(event: MouseEvent): void;
|
|
153
|
+
drawLineWithLength(start: any, end: any): void;
|
|
154
|
+
layoutLengthPreview(): void;
|
|
155
|
+
rotatePolygons(): void;
|
|
156
|
+
resetOrientation(): void;
|
|
157
|
+
isLineEqual(start1: {
|
|
158
|
+
x: number;
|
|
159
|
+
y: number;
|
|
160
|
+
}, end1: {
|
|
161
|
+
x: number;
|
|
162
|
+
y: number;
|
|
163
|
+
}, start2: {
|
|
164
|
+
x: number;
|
|
165
|
+
y: number;
|
|
166
|
+
}, end2: {
|
|
167
|
+
x: number;
|
|
168
|
+
y: number;
|
|
169
|
+
}, tolerance: number): boolean;
|
|
170
|
+
convertToPixels(value: number, unit: 'ft' | 'm'): number;
|
|
171
|
+
onElementTypeChange(type: string, index: number): void;
|
|
172
|
+
onDistanceChange(value: 'increment' | 'decrement', index: number): void;
|
|
173
|
+
onWidgetDistanceChange(value: 'increment' | 'decrement'): void;
|
|
174
|
+
onWidgetAngleChange(value: 'increment' | 'decrement'): void;
|
|
175
|
+
onWidgetDirectionChange(direction: 'left' | 'right' | 'up' | 'down'): void;
|
|
176
|
+
onDirectionChange(value: 'up' | 'left' | 'down' | 'right', index: number): void;
|
|
177
|
+
onLineDelete(index: number): void;
|
|
178
|
+
onAddStep(index: number): void;
|
|
179
|
+
onDuplicateStep(index: number): void;
|
|
180
|
+
scrollToCanvasPosition(coordinates: {
|
|
181
|
+
x: number;
|
|
182
|
+
y: number;
|
|
183
|
+
}): void;
|
|
184
|
+
onClearAll(): void;
|
|
185
|
+
onDeleteLayout(): void;
|
|
186
|
+
exportAsPng(): Promise<void>;
|
|
187
|
+
generateLayoutPolygon(layoutInstructions: any): void;
|
|
188
|
+
normalizedPixelPerMetre(polygon: any): number;
|
|
189
|
+
isFloorCompleted(layoutInstructions: any, thresholdInFeet?: number): boolean;
|
|
190
|
+
validateAngleInput(event: Event, index: number): void;
|
|
191
|
+
onAngleChange(index: number): void;
|
|
192
|
+
openAddFloorModal(): void;
|
|
193
|
+
findPolygonCenterAndScroll(polygon?: any): void;
|
|
194
|
+
exportToExcel(): void;
|
|
195
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<CreateLayoutComponent, never>;
|
|
196
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CreateLayoutComponent, "lib-create-layout", never, {}, {}, never, never, false, never>;
|
|
197
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { OnDestroy, OnInit } from '@angular/core';
|
|
2
|
+
import { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class AddFloorComponent implements OnInit, OnDestroy {
|
|
5
|
+
modal: NgbActiveModal;
|
|
6
|
+
floorNo: number;
|
|
7
|
+
private destroy$;
|
|
8
|
+
constructor(modal: NgbActiveModal);
|
|
9
|
+
ngOnInit(): void;
|
|
10
|
+
ngOnDestroy(): void;
|
|
11
|
+
floorDec(): void;
|
|
12
|
+
floorInc(): void;
|
|
13
|
+
createLayout(): void;
|
|
14
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<AddFloorComponent, never>;
|
|
15
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<AddFloorComponent, "lib-add-floor", never, {}, {}, never, never, false, never>;
|
|
16
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class ClearAllStepsComponent {
|
|
4
|
+
modal: NgbActiveModal;
|
|
5
|
+
constructor(modal: NgbActiveModal);
|
|
6
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ClearAllStepsComponent, never>;
|
|
7
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<ClearAllStepsComponent, "lib-clear-all-steps", never, {}, {}, never, never, false, never>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class DeleteLayoutComponent {
|
|
4
|
+
modal: NgbActiveModal;
|
|
5
|
+
constructor(modal: NgbActiveModal);
|
|
6
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<DeleteLayoutComponent, never>;
|
|
7
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DeleteLayoutComponent, "lib-delete-layout", never, {}, {}, never, never, false, never>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { ChangeDetectorRef, EventEmitter, OnChanges, OnInit, SimpleChanges } from '@angular/core';
|
|
2
|
+
import { StoreBuilderService } from '../../services/store-builder.service';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class CustomSelectComponent implements OnChanges, OnInit {
|
|
5
|
+
private cd;
|
|
6
|
+
private authService;
|
|
7
|
+
onClick(event: MouseEvent): void;
|
|
8
|
+
items: any;
|
|
9
|
+
searchField: string;
|
|
10
|
+
multi: boolean;
|
|
11
|
+
idField: string;
|
|
12
|
+
selectedValues: any;
|
|
13
|
+
disabled: boolean | undefined;
|
|
14
|
+
label: string;
|
|
15
|
+
selected: EventEmitter<any>;
|
|
16
|
+
filteredValues: any;
|
|
17
|
+
showDropdown: boolean;
|
|
18
|
+
searchValue: string;
|
|
19
|
+
instanceId: any;
|
|
20
|
+
constructor(cd: ChangeDetectorRef, authService: StoreBuilderService);
|
|
21
|
+
ngOnInit(): void;
|
|
22
|
+
ngOnChanges(changes: SimpleChanges): void;
|
|
23
|
+
initializeItems(): void;
|
|
24
|
+
updateSelectedValues(): void;
|
|
25
|
+
openDropdown(event: any): void;
|
|
26
|
+
onInput(event: any): void;
|
|
27
|
+
onSelect(event: any, item: any): void;
|
|
28
|
+
onSelectAll(event: any): void;
|
|
29
|
+
emitSelectedValues(values: any[]): void;
|
|
30
|
+
checkIfAllSelected(): any;
|
|
31
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<CustomSelectComponent, never>;
|
|
32
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CustomSelectComponent, "lib-select-plano", never, { "items": { "alias": "items"; "required": false; }; "searchField": { "alias": "searchField"; "required": false; }; "multi": { "alias": "multi"; "required": false; }; "idField": { "alias": "idField"; "required": false; }; "selectedValues": { "alias": "selectedValues"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "label": { "alias": "label"; "required": false; }; }, { "selected": "selected"; }, never, never, false, never>;
|
|
33
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { OnDestroy, OnInit } from '@angular/core';
|
|
2
|
+
import { Router } from '@angular/router';
|
|
3
|
+
import { Subscription } from 'rxjs';
|
|
4
|
+
import { PageInfoService } from 'tango-app-ui-global';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export declare class LayoutBuilderComponent implements OnInit, OnDestroy {
|
|
7
|
+
private router;
|
|
8
|
+
private pageInfo;
|
|
9
|
+
currentRoute: string;
|
|
10
|
+
routerSub: Subscription;
|
|
11
|
+
type: 'create' | 'summary';
|
|
12
|
+
constructor(router: Router, pageInfo: PageInfoService);
|
|
13
|
+
ngOnDestroy(): void;
|
|
14
|
+
ngOnInit(): void;
|
|
15
|
+
setPageData(): void;
|
|
16
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<LayoutBuilderComponent, never>;
|
|
17
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<LayoutBuilderComponent, "lib-layout-builder", never, {}, {}, never, never, false, never>;
|
|
18
|
+
}
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
import { AfterViewInit, ElementRef, OnDestroy, OnInit } from '@angular/core';
|
|
2
|
+
import { FormControl } from '@angular/forms';
|
|
3
|
+
import { ActivatedRoute, Router } from '@angular/router';
|
|
4
|
+
import { HeaderFilter } from '../../interfaces/layout-builder.interface';
|
|
5
|
+
import { StoreBuilderService } from '../../services/store-builder.service';
|
|
6
|
+
import { NgbModal, NgbOffcanvas } from '@ng-bootstrap/ng-bootstrap';
|
|
7
|
+
import { ToastService } from 'tango-app-ui-shared';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
export declare class LayoutSummaryComponent implements OnInit, AfterViewInit, OnDestroy {
|
|
10
|
+
private route;
|
|
11
|
+
private apiService;
|
|
12
|
+
private modalService;
|
|
13
|
+
private offcanvasService;
|
|
14
|
+
private router;
|
|
15
|
+
private modalDef;
|
|
16
|
+
private toastService;
|
|
17
|
+
floorsInput: FormControl<any>;
|
|
18
|
+
canvasRef: ElementRef<HTMLCanvasElement>;
|
|
19
|
+
scrollContainerRef: ElementRef;
|
|
20
|
+
completeLayout: ElementRef;
|
|
21
|
+
gridWidth: number;
|
|
22
|
+
gridHeight: number;
|
|
23
|
+
private ctx;
|
|
24
|
+
private canvas;
|
|
25
|
+
layoutPolygon: any[];
|
|
26
|
+
private scale;
|
|
27
|
+
private destroy$;
|
|
28
|
+
headerData: HeaderFilter | null | undefined;
|
|
29
|
+
planoStoreList: any[];
|
|
30
|
+
selectedStore: any;
|
|
31
|
+
selectedFloor: any;
|
|
32
|
+
wallCapacity: number;
|
|
33
|
+
facadeCapacity: number;
|
|
34
|
+
floorCapacity: number;
|
|
35
|
+
floorSelect: {
|
|
36
|
+
show: boolean;
|
|
37
|
+
deleteIndex: number | null;
|
|
38
|
+
};
|
|
39
|
+
markAsCompleteType: 'single' | 'multiple';
|
|
40
|
+
itemsPerPage: number;
|
|
41
|
+
currentPage: number;
|
|
42
|
+
totalItems: number;
|
|
43
|
+
paginationSizes: number[];
|
|
44
|
+
pageSize: number;
|
|
45
|
+
pixelPerMetre: number;
|
|
46
|
+
onFloorSelect(floorId: string): void;
|
|
47
|
+
onOutsideClick(event: MouseEvent): void;
|
|
48
|
+
toggleFloorSelect(): void;
|
|
49
|
+
constructor(route: ActivatedRoute, apiService: StoreBuilderService, modalService: NgbModal, offcanvasService: NgbOffcanvas, router: Router, modalDef: NgbModal, toastService: ToastService);
|
|
50
|
+
ngAfterViewInit(): void;
|
|
51
|
+
initializeLayout(): void;
|
|
52
|
+
ngOnInit(): void;
|
|
53
|
+
ngOnDestroy(): void;
|
|
54
|
+
onStoreChange(event: any): void;
|
|
55
|
+
getPlanoData(planoId: string[]): void;
|
|
56
|
+
updateFloorLayout(): void;
|
|
57
|
+
onComplete(): void;
|
|
58
|
+
drawGrid(): void;
|
|
59
|
+
drawPolygon(polygon?: any[]): void;
|
|
60
|
+
zoomIn(): void;
|
|
61
|
+
zoomOut(): void;
|
|
62
|
+
redrawCanvas(): void;
|
|
63
|
+
snapToGrid(value: number, gridSize: number): number;
|
|
64
|
+
rotatePolygons(): void;
|
|
65
|
+
convertToPixels(value: number, unit: 'ft' | 'm'): number;
|
|
66
|
+
scrollToCanvasPosition(coordinates: {
|
|
67
|
+
x: number;
|
|
68
|
+
y: number;
|
|
69
|
+
}): void;
|
|
70
|
+
calculatePolygonArea(elements: any[]): number;
|
|
71
|
+
generateLayoutPolygon(layoutInstructions: any): void;
|
|
72
|
+
isFloorCompleted(layoutInstructions: any, thresholdInFeet?: number): boolean;
|
|
73
|
+
openWidget(position: {
|
|
74
|
+
x: number;
|
|
75
|
+
y: number;
|
|
76
|
+
}, offset?: {
|
|
77
|
+
up: number;
|
|
78
|
+
right: number;
|
|
79
|
+
down: number;
|
|
80
|
+
left: number;
|
|
81
|
+
}): void;
|
|
82
|
+
openOffCanva(): void;
|
|
83
|
+
onModalSelectAll(event: any): void;
|
|
84
|
+
get isAllStoreSelected(): boolean;
|
|
85
|
+
onModalTypeChange(event: 'single' | 'multiple'): void;
|
|
86
|
+
updatePlanoStatus(): void;
|
|
87
|
+
onPageChange(val: number): void;
|
|
88
|
+
normalizedPixelPerMetre(polygon: any): number;
|
|
89
|
+
findPolygonCenterAndScroll(polygon?: any): void;
|
|
90
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<LayoutSummaryComponent, never>;
|
|
91
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<LayoutSummaryComponent, "lib-layout-summary", never, {}, {}, never, never, false, never>;
|
|
92
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class CompleteLayoutComponent {
|
|
4
|
+
modal: NgbActiveModal;
|
|
5
|
+
constructor(modal: NgbActiveModal);
|
|
6
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<CompleteLayoutComponent, never>;
|
|
7
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CompleteLayoutComponent, "lib-complete-layout", never, {}, {}, never, never, false, never>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { ChangeDetectorRef } from '@angular/core';
|
|
2
|
+
import { ControlValueAccessor } from '@angular/forms';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class ReactiveSelectComponent implements ControlValueAccessor {
|
|
5
|
+
private cd;
|
|
6
|
+
private onTouched;
|
|
7
|
+
private onChanged;
|
|
8
|
+
protected isDisabled: boolean;
|
|
9
|
+
idField: string;
|
|
10
|
+
nameField: string;
|
|
11
|
+
label: string;
|
|
12
|
+
data: any;
|
|
13
|
+
protected isOpened: boolean;
|
|
14
|
+
protected selected: Record<string, any> | null;
|
|
15
|
+
protected selectedId: string | number;
|
|
16
|
+
constructor(cd: ChangeDetectorRef);
|
|
17
|
+
writeValue(val: string | number): void;
|
|
18
|
+
registerOnChange(fn: any): void;
|
|
19
|
+
registerOnTouched(fn: any): void;
|
|
20
|
+
setDisabledState?(isDisabled: boolean): void;
|
|
21
|
+
onSelect(item: Record<string, any>): void;
|
|
22
|
+
onClick(event: MouseEvent): void;
|
|
23
|
+
isComponentClicked(targetElement: HTMLElement): boolean;
|
|
24
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ReactiveSelectComponent, never>;
|
|
25
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<ReactiveSelectComponent, "lib-reactive-select", never, { "idField": { "alias": "idField"; "required": false; }; "nameField": { "alias": "nameField"; "required": false; }; "label": { "alias": "label"; "required": false; }; "data": { "alias": "data"; "required": false; }; }, {}, never, never, false, never>;
|
|
26
|
+
}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { OnDestroy, OnInit, ElementRef } from '@angular/core';
|
|
2
|
+
import { NgbModal } from '@ng-bootstrap/ng-bootstrap';
|
|
3
|
+
import { GlobalStateService, PageInfoService } from 'tango-app-ui-global';
|
|
4
|
+
import { ToastService } from 'tango-app-ui-shared';
|
|
5
|
+
import { StoreBuilderService } from '../../services/store-builder.service';
|
|
6
|
+
import { Router } from '@angular/router';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
export declare class StoreLayoutTableComponent implements OnInit, OnDestroy {
|
|
9
|
+
private modalDef;
|
|
10
|
+
private pageInfo;
|
|
11
|
+
private toast;
|
|
12
|
+
private gs;
|
|
13
|
+
private builderService;
|
|
14
|
+
private Router;
|
|
15
|
+
fileInput: ElementRef;
|
|
16
|
+
loading: boolean;
|
|
17
|
+
selectedTab: string;
|
|
18
|
+
floorNo: number;
|
|
19
|
+
searchStore: string;
|
|
20
|
+
storeList: any[];
|
|
21
|
+
store: any[];
|
|
22
|
+
paginationSizes: any;
|
|
23
|
+
selectedStore: any;
|
|
24
|
+
showDropDown: boolean;
|
|
25
|
+
totalItems: number;
|
|
26
|
+
dynamicData: any;
|
|
27
|
+
layoutList: any;
|
|
28
|
+
pageSize: any;
|
|
29
|
+
dataObject: any;
|
|
30
|
+
error: any;
|
|
31
|
+
excelData: any;
|
|
32
|
+
showNoData: boolean;
|
|
33
|
+
private destroy$;
|
|
34
|
+
private scale;
|
|
35
|
+
gridWidth: number;
|
|
36
|
+
gridHeight: number;
|
|
37
|
+
pixelSize: any;
|
|
38
|
+
createBuilder: any;
|
|
39
|
+
uploadBuilder: any;
|
|
40
|
+
constructor(modalDef: NgbModal, pageInfo: PageInfoService, toast: ToastService, gs: GlobalStateService, builderService: StoreBuilderService, Router: Router);
|
|
41
|
+
ngOnInit(): void;
|
|
42
|
+
ngOnDestroy(): void;
|
|
43
|
+
setPageData(): void;
|
|
44
|
+
getLayoutList(): void;
|
|
45
|
+
getStoreList(): void;
|
|
46
|
+
applyFilters(event: any): void;
|
|
47
|
+
BuilderCreate(): void;
|
|
48
|
+
floorDec(): void;
|
|
49
|
+
floorInc(): void;
|
|
50
|
+
filterSearch(): void;
|
|
51
|
+
updateSelectedStore(index: number): void;
|
|
52
|
+
closeDropDown(): void;
|
|
53
|
+
toggleDropDown(): void;
|
|
54
|
+
createLayout(): void;
|
|
55
|
+
onPageChange(event: any): void;
|
|
56
|
+
onPageSizeChange(event: any): void;
|
|
57
|
+
search(): void;
|
|
58
|
+
onSort(data: any): void;
|
|
59
|
+
getHeadersFromSheet(sheet: any): string[];
|
|
60
|
+
onFileUpload(event: any): void;
|
|
61
|
+
Reupload(): void;
|
|
62
|
+
showDeleteDropDown(i: any): void;
|
|
63
|
+
deleteLayout(id: any): void;
|
|
64
|
+
normalizedPixelPerMetre(polygon: any): number;
|
|
65
|
+
convertToPixels(value: number, unit: 'ft' | 'm'): number;
|
|
66
|
+
snapToGrid(value: number, gridSize: number): number;
|
|
67
|
+
download(data: any): void;
|
|
68
|
+
onExportAsZip(store: String, data: any): Promise<void>;
|
|
69
|
+
onOutsideClick(event: MouseEvent): void;
|
|
70
|
+
clickOutside(event: MouseEvent): void;
|
|
71
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<StoreLayoutTableComponent, never>;
|
|
72
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<StoreLayoutTableComponent, "lib-store-layout-table", never, {}, {}, never, never, false, never>;
|
|
73
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { ChangeDetectorRef, ElementRef, OnDestroy, OnInit } from '@angular/core';
|
|
2
|
+
import { NgbActiveOffcanvas } from '@ng-bootstrap/ng-bootstrap';
|
|
3
|
+
import { StoreBuilderService } from '../../services/store-builder.service';
|
|
4
|
+
import { ToastService } from 'tango-app-ui-shared';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export declare class StoreOffcanvasComponentComponent implements OnInit, OnDestroy {
|
|
7
|
+
private builderService;
|
|
8
|
+
private toast;
|
|
9
|
+
private cd;
|
|
10
|
+
activeOffcanvas: NgbActiveOffcanvas;
|
|
11
|
+
store: any;
|
|
12
|
+
id: any;
|
|
13
|
+
clientId: string;
|
|
14
|
+
private destroy$;
|
|
15
|
+
fileInput: ElementRef;
|
|
16
|
+
dayjs: any;
|
|
17
|
+
storeDetails: any;
|
|
18
|
+
constructor(builderService: StoreBuilderService, toast: ToastService, cd: ChangeDetectorRef);
|
|
19
|
+
ngOnInit(): void;
|
|
20
|
+
ngOnDestroy(): void;
|
|
21
|
+
timeFormat(time: string): any;
|
|
22
|
+
onFileUpload(event: any): void;
|
|
23
|
+
deleteFile(index: any): void;
|
|
24
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<StoreOffcanvasComponentComponent, never>;
|
|
25
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<StoreOffcanvasComponentComponent, "lib-store-offcanvas-component", never, { "store": { "alias": "store"; "required": false; }; "id": { "alias": "id"; "required": false; }; "clientId": { "alias": "clientId"; "required": false; }; }, {}, never, never, false, never>;
|
|
26
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
interface DateRange {
|
|
2
|
+
startDate: string;
|
|
3
|
+
endDate: string;
|
|
4
|
+
}
|
|
5
|
+
interface Store {
|
|
6
|
+
storeId: string;
|
|
7
|
+
storeName: string;
|
|
8
|
+
checked: boolean;
|
|
9
|
+
}
|
|
10
|
+
interface Group {
|
|
11
|
+
city: string;
|
|
12
|
+
checked: boolean;
|
|
13
|
+
}
|
|
14
|
+
export interface HeaderFilter {
|
|
15
|
+
client: string;
|
|
16
|
+
clientName: string;
|
|
17
|
+
clients: string[];
|
|
18
|
+
store: null | string;
|
|
19
|
+
date: DateRange;
|
|
20
|
+
stores: Store[];
|
|
21
|
+
group: Group[];
|
|
22
|
+
}
|
|
23
|
+
export {};
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { HttpClient } from '@angular/common/http';
|
|
2
|
+
import { OnDestroy } from '@angular/core';
|
|
3
|
+
import { GlobalStateService } from 'tango-app-ui-global';
|
|
4
|
+
import { BehaviorSubject, Observable } from 'rxjs';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export declare class StoreBuilderService implements OnDestroy {
|
|
7
|
+
private http;
|
|
8
|
+
private gs;
|
|
9
|
+
storeBuilderUrl: string;
|
|
10
|
+
storeUrl: string;
|
|
11
|
+
private readonly destroy$;
|
|
12
|
+
dropDownTrigger: BehaviorSubject<null>;
|
|
13
|
+
constructor(http: HttpClient, gs: GlobalStateService);
|
|
14
|
+
exportAsExcelFile(json: any[], excelFileName: string): void;
|
|
15
|
+
saveAsExcelFile(buffer: any, fileName: string): void;
|
|
16
|
+
saveAsTemplate(buffer: any, fileName: string): void;
|
|
17
|
+
ngOnDestroy(): void;
|
|
18
|
+
layoutList(data: any): Observable<Object>;
|
|
19
|
+
getStoreList(data: any): Observable<Object>;
|
|
20
|
+
createLayout(data: any): Observable<Object>;
|
|
21
|
+
BulkUpload(data: any): Observable<Object>;
|
|
22
|
+
getPlano(data: any): Observable<Object>;
|
|
23
|
+
deleteFloor(data: any): Observable<Object>;
|
|
24
|
+
addFloor(data: any): Observable<Object>;
|
|
25
|
+
updateFloorLayout(data: any): Observable<Object>;
|
|
26
|
+
getStoreDetails(data: any): Observable<Object>;
|
|
27
|
+
uploadFile(data: any): Observable<Object>;
|
|
28
|
+
deleteFile(data: any): Observable<Object>;
|
|
29
|
+
updatePlanoStatus(data: any): Observable<Object>;
|
|
30
|
+
deleteLayout(data: any): Observable<Object>;
|
|
31
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<StoreBuilderService, never>;
|
|
32
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<StoreBuilderService>;
|
|
33
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
import * as i1 from "@angular/router";
|
|
3
|
+
export declare class TangoStoreBuilderRoutingModule {
|
|
4
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TangoStoreBuilderRoutingModule, never>;
|
|
5
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<TangoStoreBuilderRoutingModule, never, [typeof i1.RouterModule], [typeof i1.RouterModule]>;
|
|
6
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<TangoStoreBuilderRoutingModule>;
|
|
7
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
import * as i1 from "./components/layout-builder/layout-builder.component";
|
|
3
|
+
import * as i2 from "./components/create-layout/create-layout.component";
|
|
4
|
+
import * as i3 from "./components/layout-summary/layout-summary.component";
|
|
5
|
+
import * as i4 from "./components/store-layout-table/store-layout-table.component";
|
|
6
|
+
import * as i5 from "./components/reactive-select/reactive-select.component";
|
|
7
|
+
import * as i6 from "./components/custom-select/custom-select.component";
|
|
8
|
+
import * as i7 from "./components/store-offcanvas-component/store-offcanvas-component.component";
|
|
9
|
+
import * as i8 from "./components/create-layout/popups/add-floor/add-floor.component";
|
|
10
|
+
import * as i9 from "./components/create-layout/popups/clear-all-steps/clear-all-steps.component";
|
|
11
|
+
import * as i10 from "./components/create-layout/popups/delete-layout/delete-layout.component";
|
|
12
|
+
import * as i11 from "./components/layout-summary/popups/complete-layout/complete-layout.component";
|
|
13
|
+
import * as i12 from "./tango-store-builder-routing.module";
|
|
14
|
+
import * as i13 from "@angular/common";
|
|
15
|
+
import * as i14 from "@angular/forms";
|
|
16
|
+
import * as i15 from "tango-app-ui-shared";
|
|
17
|
+
import * as i16 from "@angular/cdk/drag-drop";
|
|
18
|
+
export declare class TangoStoreBuilderModule {
|
|
19
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TangoStoreBuilderModule, never>;
|
|
20
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<TangoStoreBuilderModule, [typeof i1.LayoutBuilderComponent, typeof i2.CreateLayoutComponent, typeof i3.LayoutSummaryComponent, typeof i4.StoreLayoutTableComponent, typeof i5.ReactiveSelectComponent, typeof i6.CustomSelectComponent, typeof i7.StoreOffcanvasComponentComponent, typeof i8.AddFloorComponent, typeof i9.ClearAllStepsComponent, typeof i10.DeleteLayoutComponent, typeof i11.CompleteLayoutComponent], [typeof i12.TangoStoreBuilderRoutingModule, typeof i13.CommonModule, typeof i14.FormsModule, typeof i15.CommonSharedModule, typeof i14.ReactiveFormsModule, typeof i16.DragDropModule], never>;
|
|
21
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<TangoStoreBuilderModule>;
|
|
22
|
+
}
|
package/package.json
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "tango-app-ui-store-builder",
|
|
3
|
+
"version": "1.0.1-beta-1",
|
|
4
|
+
"peerDependencies": {
|
|
5
|
+
"@angular/common": "^17.3.0",
|
|
6
|
+
"@angular/core": "^17.3.0"
|
|
7
|
+
},
|
|
8
|
+
"dependencies": {
|
|
9
|
+
"tslib": "^2.3.0"
|
|
10
|
+
},
|
|
11
|
+
"sideEffects": false,
|
|
12
|
+
"module": "fesm2022/tango-app-ui-store-builder.mjs",
|
|
13
|
+
"typings": "index.d.ts",
|
|
14
|
+
"exports": {
|
|
15
|
+
"./package.json": {
|
|
16
|
+
"default": "./package.json"
|
|
17
|
+
},
|
|
18
|
+
".": {
|
|
19
|
+
"types": "./index.d.ts",
|
|
20
|
+
"esm2022": "./esm2022/tango-app-ui-store-builder.mjs",
|
|
21
|
+
"esm": "./esm2022/tango-app-ui-store-builder.mjs",
|
|
22
|
+
"default": "./fesm2022/tango-app-ui-store-builder.mjs"
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
}
|
package/public-api.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './lib/tango-store-builder.module';
|