ms-data-grid 0.0.41 → 0.0.42
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/data-grid/data-grid.component.mjs +1322 -387
- package/esm2022/lib/data-grid/statuses.mjs +3 -2
- package/esm2022/lib/data-grid.module.mjs +7 -7
- package/esm2022/lib/pipes/filter.pipe.mjs +1 -1
- package/esm2022/lib/services/common.service.mjs +37 -8
- package/esm2022/lib/services/copy-service.service.mjs +3 -3
- package/esm2022/lib/services/export.service.mjs +149 -0
- package/esm2022/public-api.mjs +1 -3
- package/fesm2022/ms-data-grid.mjs +1511 -670
- package/fesm2022/ms-data-grid.mjs.map +1 -1
- package/lib/data-grid/data-grid.component.d.ts +96 -35
- package/lib/data-grid.module.d.ts +6 -7
- package/lib/services/export.service.d.ts +24 -0
- package/package.json +8 -2
- package/public-api.d.ts +0 -2
- package/esm2022/lib/data-grid.service.mjs +0 -14
- package/esm2022/lib/directives/draggable-header.directive.mjs +0 -145
- package/esm2022/lib/services/swap-columns.service.mjs +0 -118
- package/lib/data-grid.service.d.ts +0 -6
- package/lib/directives/draggable-header.directive.d.ts +0 -31
- package/lib/services/swap-columns.service.d.ts +0 -19
|
@@ -1,20 +1,23 @@
|
|
|
1
|
-
import { OnChanges, SimpleChanges, ElementRef, AfterViewInit, ChangeDetectorRef, EventEmitter, NgZone } from '@angular/core';
|
|
1
|
+
import { OnInit, OnChanges, SimpleChanges, ElementRef, AfterViewInit, ChangeDetectorRef, EventEmitter, NgZone, Renderer2, AfterViewChecked, TemplateRef } from '@angular/core';
|
|
2
2
|
import { SplitColumnsService } from '../services/split-columns.service';
|
|
3
3
|
import { CommonService } from '../services/common.service';
|
|
4
|
-
import { SwapColumnsService } from '../services/swap-columns.service';
|
|
5
4
|
import { CdkDrag, CdkDragDrop, CdkDragEnter, CdkDragExit, CdkDragMove, CdkDragSortEvent } from '@angular/cdk/drag-drop';
|
|
6
5
|
import { CdkDropList } from '@angular/cdk/drag-drop';
|
|
7
6
|
import { CopyServiceService } from '../services/copy-service.service';
|
|
7
|
+
import { DomSanitizer, SafeHtml } from '@angular/platform-browser';
|
|
8
|
+
import { ExportService } from '../services/export.service';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
10
|
export declare const sortingAnimation: import("@angular/animations").AnimationTriggerMetadata;
|
|
10
|
-
export declare class DataGridComponent implements OnChanges, AfterViewInit {
|
|
11
|
+
export declare class DataGridComponent implements OnChanges, AfterViewInit, OnInit, AfterViewChecked {
|
|
11
12
|
private columnService;
|
|
12
13
|
cdr: ChangeDetectorRef;
|
|
13
14
|
commonSevice: CommonService;
|
|
14
|
-
private swapColumnService;
|
|
15
15
|
private elementRef;
|
|
16
16
|
private ngZone;
|
|
17
17
|
private copyService;
|
|
18
|
+
private renderer;
|
|
19
|
+
private sanitizer;
|
|
20
|
+
private exportService;
|
|
18
21
|
paginationConfig: any;
|
|
19
22
|
dataSet: any[];
|
|
20
23
|
columns: any[];
|
|
@@ -33,12 +36,14 @@ export declare class DataGridComponent implements OnChanges, AfterViewInit {
|
|
|
33
36
|
sidemenuBackgroundColor: string | undefined;
|
|
34
37
|
bodyTextColor: string | undefined;
|
|
35
38
|
headerTextColor: string | undefined;
|
|
39
|
+
checkboxesColor: string | undefined;
|
|
36
40
|
headerTextFontsSize: number | undefined;
|
|
37
41
|
bodyTextFontsSize: number | undefined;
|
|
38
42
|
headerFontWeight: number | undefined;
|
|
39
43
|
bodyFontWeight: number | undefined;
|
|
40
44
|
checkedRowBackgroundColor: string | undefined;
|
|
41
45
|
dropdownsBackgroundColor: string | undefined;
|
|
46
|
+
footerRowBackgroundColor: string | undefined;
|
|
42
47
|
footerRowHeight: number;
|
|
43
48
|
topGroupedBadgesBackgroundColor: string | undefined;
|
|
44
49
|
showRowsGrouping: boolean | undefined;
|
|
@@ -87,12 +92,24 @@ export declare class DataGridComponent implements OnChanges, AfterViewInit {
|
|
|
87
92
|
leftPinnedBoxshadow: string;
|
|
88
93
|
rightPinnedBoxshadow: string;
|
|
89
94
|
selectedRowsBackgroundColor: string;
|
|
90
|
-
|
|
95
|
+
nestedTableHeaderBackgroundColor: string;
|
|
96
|
+
nestedTableRowBackgroundColor: string;
|
|
91
97
|
tableView: any[];
|
|
98
|
+
buttons: {
|
|
99
|
+
name: string;
|
|
100
|
+
is_showIcon: boolean;
|
|
101
|
+
icon: string;
|
|
102
|
+
}[];
|
|
92
103
|
keepMultipleExpandedDetails: boolean;
|
|
93
104
|
showTotalAmountRow: boolean;
|
|
105
|
+
enableGlobalSearch: boolean;
|
|
94
106
|
tableType: string;
|
|
95
|
-
|
|
107
|
+
enableExport: boolean;
|
|
108
|
+
enableCut: boolean;
|
|
109
|
+
tabs: string[];
|
|
110
|
+
resetAllFilters: {
|
|
111
|
+
resetAll: boolean;
|
|
112
|
+
};
|
|
96
113
|
columnThreedotsMunuConfig: {
|
|
97
114
|
showPinleft: boolean;
|
|
98
115
|
showPinright: boolean;
|
|
@@ -111,6 +128,7 @@ export declare class DataGridComponent implements OnChanges, AfterViewInit {
|
|
|
111
128
|
tablePresetConfig: EventEmitter<any>;
|
|
112
129
|
sortingOrderOptions: EventEmitter<any>;
|
|
113
130
|
createUpdateConfigListing: EventEmitter<any>;
|
|
131
|
+
activeTab: string | null;
|
|
114
132
|
groupedColumns: any[];
|
|
115
133
|
activeCol: any;
|
|
116
134
|
activeFilterCell: any;
|
|
@@ -126,22 +144,29 @@ export declare class DataGridComponent implements OnChanges, AfterViewInit {
|
|
|
126
144
|
filterColumnsList: any[];
|
|
127
145
|
groupBoxPadding: number;
|
|
128
146
|
presetName: string;
|
|
129
|
-
presetFilter:
|
|
147
|
+
presetFilter: boolean;
|
|
130
148
|
searchTextPresetTable: string;
|
|
131
149
|
addFilterColumnInput: string;
|
|
132
150
|
searchInDropdown: string;
|
|
133
151
|
addFilterDropdownSearch: string;
|
|
134
152
|
topShowHideColumns: string;
|
|
135
153
|
choseColumnsSearch: string;
|
|
154
|
+
sideNestedFilterSearch: string;
|
|
136
155
|
editinDropdownSearch: string;
|
|
137
156
|
isThreeDotsFilterOpen: boolean;
|
|
138
157
|
confirmDelete: boolean;
|
|
139
158
|
fontFamilies: string[];
|
|
140
159
|
fontSizes: string[];
|
|
141
|
-
|
|
160
|
+
hasScroll: boolean;
|
|
161
|
+
constructor(columnService: SplitColumnsService, cdr: ChangeDetectorRef, commonSevice: CommonService, elementRef: ElementRef, ngZone: NgZone, copyService: CopyServiceService, renderer: Renderer2, sanitizer: DomSanitizer, exportService: ExportService);
|
|
142
162
|
cellText: ElementRef;
|
|
143
|
-
|
|
163
|
+
nestedHeader: ElementRef;
|
|
164
|
+
ngAfterViewInit(): void;
|
|
165
|
+
ngAfterViewChecked(): void;
|
|
166
|
+
ngOnInit(): void;
|
|
144
167
|
ngOnChanges(changes: SimpleChanges): Promise<void>;
|
|
168
|
+
applyRowsSelectionState(): void;
|
|
169
|
+
clearSelectionState(tableType: string): void;
|
|
145
170
|
applyFilteroptionList(): Promise<void>;
|
|
146
171
|
leftPinnedColumns: any[];
|
|
147
172
|
centerColumns: any[];
|
|
@@ -150,6 +175,8 @@ export declare class DataGridComponent implements OnChanges, AfterViewInit {
|
|
|
150
175
|
previewCenterColumns: any[];
|
|
151
176
|
previewRightPinnedColumns: any[];
|
|
152
177
|
dataGridContainer: ElementRef<HTMLDivElement>;
|
|
178
|
+
taskManagementContainer: ElementRef<HTMLDivElement>;
|
|
179
|
+
nestedTableContainer: ElementRef<HTMLDivElement>;
|
|
153
180
|
leftPinnedBody: ElementRef<HTMLDivElement>;
|
|
154
181
|
centerPinnedBody: ElementRef<HTMLDivElement>;
|
|
155
182
|
rightPinnedBody: ElementRef<HTMLDivElement>;
|
|
@@ -162,16 +189,15 @@ export declare class DataGridComponent implements OnChanges, AfterViewInit {
|
|
|
162
189
|
refreshPreviewColumns(columns?: any): Promise<void>;
|
|
163
190
|
SetColumnsDefaultWidth(): Promise<void>;
|
|
164
191
|
setSectionsWidth(): void;
|
|
165
|
-
onLeftBodyScroll(): void;
|
|
166
|
-
onRightBodyScroll(): void;
|
|
167
192
|
fakeScrollbarScrollLeft: number;
|
|
168
|
-
onFakeScroll(event: Event): void;
|
|
169
193
|
getNestedValue(obj: any, field: string): any;
|
|
170
194
|
isNestedValueArray(obj: any, field: string): boolean;
|
|
171
195
|
onResizeGroup(event: MouseEvent, col: any, isRightPinned?: boolean): void;
|
|
172
196
|
private updateColumnWidthInSourceByField;
|
|
197
|
+
cleanColumns(columns: any[]): any[];
|
|
173
198
|
onResizeColumn(event: MouseEvent, col: any): void;
|
|
174
199
|
onResizeGroupBox(event: MouseEvent): void;
|
|
200
|
+
onPasteInFilterRowSearch(event: ClipboardEvent, col: any): void;
|
|
175
201
|
onFilterChange(col: any): void;
|
|
176
202
|
get bodyWrapperHeight(): string;
|
|
177
203
|
hoveredRowId: string | number | null;
|
|
@@ -182,11 +208,11 @@ export declare class DataGridComponent implements OnChanges, AfterViewInit {
|
|
|
182
208
|
closeFilterDropdowns(event: MouseEvent): void;
|
|
183
209
|
private hasParentWithClass;
|
|
184
210
|
isMenueHidden: boolean;
|
|
185
|
-
openThreeDotsMenu(event: MouseEvent, child: any): void;
|
|
211
|
+
openThreeDotsMenu(event: MouseEvent, child: any, keepOriginalPosition?: boolean): void;
|
|
186
212
|
sortAsc(col: any): void;
|
|
187
213
|
sortDesc(col: any): void;
|
|
188
214
|
resetSort(col: any): void;
|
|
189
|
-
updateColumnPinInSourceByField(column: any, pinned: 'left' | 'right' | null): Promise<void>;
|
|
215
|
+
updateColumnPinInSourceByField(column: any, pinned: 'left' | 'right' | null, isNestedTable?: any, columns?: any): Promise<void>;
|
|
190
216
|
autosizeColumn(cols: any | any[]): void;
|
|
191
217
|
getGroupWidth(group: any): number;
|
|
192
218
|
autosizeAllColumns(): void;
|
|
@@ -256,10 +282,10 @@ export declare class DataGridComponent implements OnChanges, AfterViewInit {
|
|
|
256
282
|
private fakeScrollRaf;
|
|
257
283
|
translateY: number;
|
|
258
284
|
lastScrollTop: number;
|
|
285
|
+
pendingAnimationFrame: number | null;
|
|
259
286
|
onMainScroll(event: Event): void;
|
|
260
287
|
get isScrollbarVisible(): boolean;
|
|
261
288
|
toggleExpand(row: any): void;
|
|
262
|
-
onMainFakeScroll(event: Event): void;
|
|
263
289
|
viewportRows: number;
|
|
264
290
|
firstIndex: number;
|
|
265
291
|
renderStart: number;
|
|
@@ -268,19 +294,17 @@ export declare class DataGridComponent implements OnChanges, AfterViewInit {
|
|
|
268
294
|
mainScroll: ElementRef<HTMLDivElement>;
|
|
269
295
|
fakeScroll: ElementRef<HTMLDivElement>;
|
|
270
296
|
horizintalFakeScroll: ElementRef<HTMLDivElement>;
|
|
271
|
-
centerScrollableBody: ElementRef<
|
|
297
|
+
centerScrollableBody: ElementRef<HTMLDivElement>;
|
|
272
298
|
private overscan;
|
|
273
299
|
computeViewportRows(): void;
|
|
274
|
-
|
|
300
|
+
onHorizontalFakeScroll(event: Event): void;
|
|
275
301
|
onCenterBodyScroll(event: Event): void;
|
|
276
302
|
onCenterHeaderScroll(event: Event): void;
|
|
277
303
|
draggingColumn: any;
|
|
278
304
|
dragStartIndex: any;
|
|
279
305
|
canEnterToRowsGrouping: (drag: CdkDrag<any>, drop: CdkDropList<any>) => any;
|
|
280
|
-
onDragMoved(event: CdkDragMove<any>): void;
|
|
281
306
|
enterToTopRowGrouping(dropList: CdkDragEnter<any>): void;
|
|
282
307
|
onDropListEnter(dropList: CdkDragEnter<any>, section: 'left' | 'center' | 'right'): void;
|
|
283
|
-
enterToTopGroupingRow(dropList: CdkDragEnter<any>): void;
|
|
284
308
|
exitedFromTheTopRow(dropList: CdkDragExit<any>): void;
|
|
285
309
|
shouldDisableDroplistSorting: boolean;
|
|
286
310
|
isDisableColumnGrouping: boolean;
|
|
@@ -290,11 +314,9 @@ export declare class DataGridComponent implements OnChanges, AfterViewInit {
|
|
|
290
314
|
onSortGroup: (event: CdkDragSortEvent<any>, section: string) => Promise<void>;
|
|
291
315
|
onDropGroup(): void;
|
|
292
316
|
onDropTopGroup(event: CdkDragDrop<any>): Promise<void>;
|
|
317
|
+
onGroupReorder(event: CdkDragDrop<any[]>): Promise<void>;
|
|
293
318
|
ungroupColumn(column: any): Promise<void>;
|
|
294
319
|
shouldTheGroupHeaderShow(group: any): any;
|
|
295
|
-
onChildDragStart(): void;
|
|
296
|
-
dropListIds: string[];
|
|
297
|
-
generateDropListIds(): void;
|
|
298
320
|
onChildDroplistSorted: (event: CdkDragSortEvent<any>, section: string) => Promise<void>;
|
|
299
321
|
onChildDroplistDroped(cdkDragDropevent: CdkDragDrop<any>): void;
|
|
300
322
|
groupData(data: any[], groupFields: string[]): any[];
|
|
@@ -320,11 +342,12 @@ export declare class DataGridComponent implements OnChanges, AfterViewInit {
|
|
|
320
342
|
isFilterOpen: boolean;
|
|
321
343
|
selectedColumnForFilter: any;
|
|
322
344
|
showFilters: boolean;
|
|
345
|
+
openFilterFromDisabledSearchedInput(col: any): void;
|
|
323
346
|
openFilter(col: any): void;
|
|
324
347
|
firstValue: any;
|
|
325
348
|
firstCondition: string;
|
|
326
349
|
secondValue: any;
|
|
327
|
-
secondCondition:
|
|
350
|
+
secondCondition: null;
|
|
328
351
|
condition: string;
|
|
329
352
|
resetTextFilterChanges(): void;
|
|
330
353
|
toggleAllValusSelectionInDropdownFilter(column: any): void;
|
|
@@ -339,7 +362,9 @@ export declare class DataGridComponent implements OnChanges, AfterViewInit {
|
|
|
339
362
|
onOptionToggle(col: any, option: any): void;
|
|
340
363
|
resetSideFilter(col: any): void;
|
|
341
364
|
clearAllFilters(): void;
|
|
342
|
-
applySideFilter(): void;
|
|
365
|
+
applySideFilter(column: any): void;
|
|
366
|
+
removeSideFilter(column: any): void;
|
|
367
|
+
collapseAllExpandedCells(): void;
|
|
343
368
|
trackByField(index: number, col: any): string;
|
|
344
369
|
get activeFilteredColumns(): any[];
|
|
345
370
|
toggleOpenFilter(): void;
|
|
@@ -347,6 +372,7 @@ export declare class DataGridComponent implements OnChanges, AfterViewInit {
|
|
|
347
372
|
activeCell: string | null;
|
|
348
373
|
setActiveCell(row: any, column: any): void;
|
|
349
374
|
isActiveCell(row: any, col: any): boolean;
|
|
375
|
+
textAreadInput: ElementRef<HTMLTextAreaElement>;
|
|
350
376
|
enableEdit(row: any, column: any, clickedFromDetailsBox?: boolean, cellContainer?: HTMLElement): void;
|
|
351
377
|
disableEdit(row: any, column: any, control?: any): void;
|
|
352
378
|
emailRegex: RegExp;
|
|
@@ -358,9 +384,14 @@ export declare class DataGridComponent implements OnChanges, AfterViewInit {
|
|
|
358
384
|
goToPage(page: any): void;
|
|
359
385
|
onPageSizeChange(): void;
|
|
360
386
|
actionPreset(data: any, type: any): void;
|
|
361
|
-
|
|
387
|
+
currentIdForUpdatePreset: string;
|
|
388
|
+
curretaTablePresetForUpdate: any;
|
|
389
|
+
temp_state: {
|
|
390
|
+
id: string;
|
|
391
|
+
is_temp: boolean;
|
|
392
|
+
};
|
|
393
|
+
selectFilter(data: any): Promise<void>;
|
|
362
394
|
savePreset(control?: any): void;
|
|
363
|
-
getFilterHeaders(filters: any[], columns: any[]): string;
|
|
364
395
|
toggleRowShading(): void;
|
|
365
396
|
trackByTable(index: number): number;
|
|
366
397
|
activeRow: any;
|
|
@@ -368,10 +399,9 @@ export declare class DataGridComponent implements OnChanges, AfterViewInit {
|
|
|
368
399
|
getCellKey(row: any, col: any): string;
|
|
369
400
|
expandedCells: Map<string, number>;
|
|
370
401
|
private zCounter;
|
|
371
|
-
toggleExpandOfLongCellText(row: any, col: any, columns: any[], expandWholeRow?: boolean): void;
|
|
372
402
|
showDetailsBox: boolean;
|
|
403
|
+
toggleExpandOfLongCellText(row: any, col: any, columns: any[], expandWholeRow?: boolean): void;
|
|
373
404
|
isOpenToTop(row: any, col: any): boolean;
|
|
374
|
-
collapseAllExpandedCells(): void;
|
|
375
405
|
isExpanded(row: any, col: any): boolean;
|
|
376
406
|
getZIndex(row: any, col: any): number;
|
|
377
407
|
isOverflowing(element: HTMLElement | null): boolean;
|
|
@@ -391,10 +421,11 @@ export declare class DataGridComponent implements OnChanges, AfterViewInit {
|
|
|
391
421
|
getCellClasses(column: any, value: any): string;
|
|
392
422
|
removeColumnFilterFromColumn(column: any): void;
|
|
393
423
|
onSideMenuColumnsVisibilityChange(): void;
|
|
394
|
-
|
|
424
|
+
cleanFilterdColumns(): any[];
|
|
425
|
+
downloadCsv(type: 'csv' | 'xlsx'): void;
|
|
395
426
|
onFontChange(): void;
|
|
396
427
|
onGlobalSearch(): void;
|
|
397
|
-
|
|
428
|
+
onSearchInput(event: Event): void;
|
|
398
429
|
checkFilterChangesEffect(): any;
|
|
399
430
|
selectedCells: any[];
|
|
400
431
|
selectedKeys: Set<string>;
|
|
@@ -449,6 +480,7 @@ export declare class DataGridComponent implements OnChanges, AfterViewInit {
|
|
|
449
480
|
performCut(selectedData: any[][]): void;
|
|
450
481
|
getSelectedDataForCopy(): any[][];
|
|
451
482
|
onKeyDown(event: KeyboardEvent): void;
|
|
483
|
+
selectAllCells(): void;
|
|
452
484
|
undo(): void;
|
|
453
485
|
redo(): void;
|
|
454
486
|
onPaste: (event: ClipboardEvent) => Promise<void>;
|
|
@@ -461,16 +493,45 @@ export declare class DataGridComponent implements OnChanges, AfterViewInit {
|
|
|
461
493
|
toggleMenu(i: number, event?: MouseEvent): void;
|
|
462
494
|
nestedTable: ElementRef<HTMLDivElement>;
|
|
463
495
|
get hasVerticalScroll(): boolean;
|
|
496
|
+
get hasHorizontalScroll(): boolean;
|
|
464
497
|
getTotalAmount(column: any): string | undefined;
|
|
465
498
|
dropColumn(event: CdkDragDrop<any[]>, row: any): void;
|
|
466
499
|
currentSubSortColumn: string | null;
|
|
467
500
|
currentSortDirection: 'asc' | 'desc';
|
|
468
|
-
sortNestedCol(col: any,
|
|
501
|
+
sortNestedCol(col: any, row: any): void;
|
|
469
502
|
getColumnWidthPx(row: any, col: any): string;
|
|
470
503
|
fullscreenImage: string | null;
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
504
|
+
pinUnpinColum(col: any, value: 'left' | 'right' | null, columns: any[]): void;
|
|
505
|
+
getLeftPinnedCount(columns: any[]): number;
|
|
506
|
+
getRightPinnedCount(columns: any[]): number;
|
|
507
|
+
getStickyLeft(columns: any[], index: number): string;
|
|
508
|
+
previewNestedCols: any[];
|
|
509
|
+
onNestedColSort(event: CdkDragSortEvent<any[]>, columns: any[]): void;
|
|
510
|
+
saveSelection(selectedIds: string[], tableType: string): void;
|
|
511
|
+
restoreSelection(tableType: string): Set<string>;
|
|
512
|
+
isOutsideContainer: boolean;
|
|
513
|
+
private containerRect;
|
|
514
|
+
onDragStarted(col: any): void;
|
|
515
|
+
onDragMoved(event: CdkDragMove): void;
|
|
516
|
+
onDragEnded(): void;
|
|
517
|
+
getStartIndex(): number;
|
|
518
|
+
hasAnyDefaultView(): boolean;
|
|
519
|
+
get isTablePresetNotChanged(): any;
|
|
520
|
+
onActionButtonClick(button: string): void;
|
|
521
|
+
setActiveTab(tab: string): void;
|
|
522
|
+
getBackgroundColor(row: any, isEven: boolean, section: 'left' | 'center' | 'right'): string | undefined;
|
|
523
|
+
hasHorizontalScrollbar(): boolean;
|
|
524
|
+
getSafeComment(description: string): SafeHtml;
|
|
525
|
+
cleanEditorContent(content: string): SafeHtml;
|
|
526
|
+
getExtention(url: string | string[] | null | undefined): string | undefined;
|
|
527
|
+
downloadAttchment(url: any, file?: any): void;
|
|
528
|
+
fullImageSrc: string | null;
|
|
529
|
+
openFullImage(event: Event): void;
|
|
530
|
+
addStylesToImages(): void;
|
|
531
|
+
onImageClick(src: string): void;
|
|
532
|
+
fullscreenImageTemplate: TemplateRef<any>;
|
|
533
|
+
private fullscreenViewRef;
|
|
534
|
+
iconMap: Record<string, (row: any, col: any) => string>;
|
|
474
535
|
static ɵfac: i0.ɵɵFactoryDeclaration<DataGridComponent, never>;
|
|
475
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<DataGridComponent, "data-grid", never, { "paginationConfig": { "alias": "paginationConfig"; "required": false; }; "dataSet": { "alias": "dataSet"; "required": false; }; "columns": { "alias": "columns"; "required": false; }; "rowHeight": { "alias": "rowHeight"; "required": false; }; "headerRowHeight": { "alias": "headerRowHeight"; "required": false; }; "showVerticalBorder": { "alias": "showVerticalBorder"; "required": false; }; "evenRowsBackgroundColor": { "alias": "evenRowsBackgroundColor"; "required": false; }; "oddRowsBackgroundColor": { "alias": "oddRowsBackgroundColor"; "required": false; }; "headerBackgroundColor": { "alias": "headerBackgroundColor"; "required": false; }; "checkboxesBackgroundColor": { "alias": "checkboxesBackgroundColor"; "required": false; }; "showColumnsGrouping": { "alias": "showColumnsGrouping"; "required": false; }; "rowHoverColor": { "alias": "rowHoverColor"; "required": false; }; "leftPinnedBackgroundColor": { "alias": "leftPinnedBackgroundColor"; "required": false; }; "bodyBackgroundColor": { "alias": "bodyBackgroundColor"; "required": false; }; "rightPinnedBackgroundColor": { "alias": "rightPinnedBackgroundColor"; "required": false; }; "sidemenuBackgroundColor": { "alias": "sidemenuBackgroundColor"; "required": false; }; "bodyTextColor": { "alias": "bodyTextColor"; "required": false; }; "headerTextColor": { "alias": "headerTextColor"; "required": false; }; "headerTextFontsSize": { "alias": "headerTextFontsSize"; "required": false; }; "bodyTextFontsSize": { "alias": "bodyTextFontsSize"; "required": false; }; "headerFontWeight": { "alias": "headerFontWeight"; "required": false; }; "bodyFontWeight": { "alias": "bodyFontWeight"; "required": false; }; "checkedRowBackgroundColor": { "alias": "checkedRowBackgroundColor"; "required": false; }; "dropdownsBackgroundColor": { "alias": "dropdownsBackgroundColor"; "required": false; }; "footerRowHeight": { "alias": "footerRowHeight"; "required": false; }; "topGroupedBadgesBackgroundColor": { "alias": "topGroupedBadgesBackgroundColor"; "required": false; }; "showRowsGrouping": { "alias": "showRowsGrouping"; "required": false; }; "showFilterRow": { "alias": "showFilterRow"; "required": false; }; "fontFaimly": { "alias": "fontFaimly"; "required": false; }; "showSideMenu": { "alias": "showSideMenu"; "required": false; }; "footerPadding": { "alias": "footerPadding"; "required": false; }; "topFilterRowHeight": { "alias": "topFilterRowHeight"; "required": false; }; "rowShadingEnabled": { "alias": "rowShadingEnabled"; "required": false; }; "showSerialNumber": { "alias": "showSerialNumber"; "required": false; }; "singleSpaAssetsPath": { "alias": "singleSpaAssetsPath"; "required": false; }; "filtersConfig": { "alias": "filtersConfig"; "required": false; }; "loading": { "alias": "loading"; "required": false; }; "verticalScrollbarWidth": { "alias": "verticalScrollbarWidth"; "required": false; }; "horizintalScrollbarWidth": { "alias": "horizintalScrollbarWidth"; "required": false; }; "showCellDetailsBox": { "alias": "showCellDetailsBox"; "required": false; }; "dateFormat": { "alias": "dateFormat"; "required": false; }; "tableSearch": { "alias": "tableSearch"; "required": false; }; "actions": { "alias": "actions"; "required": false; }; "config": { "alias": "config"; "required": false; }; "showTaskbar": { "alias": "showTaskbar"; "required": false; }; "tableName": { "alias": "tableName"; "required": false; }; "listingType": { "alias": "listingType"; "required": false; }; "checkboxState": { "alias": "checkboxState"; "required": false; }; "taskbarActions": { "alias": "taskbarActions"; "required": false; }; "sortingConfig": { "alias": "sortingConfig"; "required": false; }; "tableFilterViewId": { "alias": "tableFilterViewId"; "required": false; }; "selectedTableLayout": { "alias": "selectedTableLayout"; "required": false; }; "closeDropdown": { "alias": "closeDropdown"; "required": false; }; "globalSearchText": { "alias": "globalSearchText"; "required": false; }; "nestedTablerowFontsize": { "alias": "nestedTablerowFontsize"; "required": false; }; "nestedTableHeaderRowHeight": { "alias": "nestedTableHeaderRowHeight"; "required": false; }; "nestedTablerowHeight": { "alias": "nestedTablerowHeight"; "required": false; }; "gridType": { "alias": "gridType"; "required": false; }; "currencySymbol": { "alias": "currencySymbol"; "required": false; }; "leftPinnedBoxshadow": { "alias": "leftPinnedBoxshadow"; "required": false; }; "rightPinnedBoxshadow": { "alias": "rightPinnedBoxshadow"; "required": false; }; "selectedRowsBackgroundColor": { "alias": "selectedRowsBackgroundColor"; "required": false; }; "
|
|
536
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DataGridComponent, "data-grid", never, { "paginationConfig": { "alias": "paginationConfig"; "required": false; }; "dataSet": { "alias": "dataSet"; "required": false; }; "columns": { "alias": "columns"; "required": false; }; "rowHeight": { "alias": "rowHeight"; "required": false; }; "headerRowHeight": { "alias": "headerRowHeight"; "required": false; }; "showVerticalBorder": { "alias": "showVerticalBorder"; "required": false; }; "evenRowsBackgroundColor": { "alias": "evenRowsBackgroundColor"; "required": false; }; "oddRowsBackgroundColor": { "alias": "oddRowsBackgroundColor"; "required": false; }; "headerBackgroundColor": { "alias": "headerBackgroundColor"; "required": false; }; "checkboxesBackgroundColor": { "alias": "checkboxesBackgroundColor"; "required": false; }; "showColumnsGrouping": { "alias": "showColumnsGrouping"; "required": false; }; "rowHoverColor": { "alias": "rowHoverColor"; "required": false; }; "leftPinnedBackgroundColor": { "alias": "leftPinnedBackgroundColor"; "required": false; }; "bodyBackgroundColor": { "alias": "bodyBackgroundColor"; "required": false; }; "rightPinnedBackgroundColor": { "alias": "rightPinnedBackgroundColor"; "required": false; }; "sidemenuBackgroundColor": { "alias": "sidemenuBackgroundColor"; "required": false; }; "bodyTextColor": { "alias": "bodyTextColor"; "required": false; }; "headerTextColor": { "alias": "headerTextColor"; "required": false; }; "checkboxesColor": { "alias": "checkboxesColor"; "required": false; }; "headerTextFontsSize": { "alias": "headerTextFontsSize"; "required": false; }; "bodyTextFontsSize": { "alias": "bodyTextFontsSize"; "required": false; }; "headerFontWeight": { "alias": "headerFontWeight"; "required": false; }; "bodyFontWeight": { "alias": "bodyFontWeight"; "required": false; }; "checkedRowBackgroundColor": { "alias": "checkedRowBackgroundColor"; "required": false; }; "dropdownsBackgroundColor": { "alias": "dropdownsBackgroundColor"; "required": false; }; "footerRowBackgroundColor": { "alias": "footerRowBackgroundColor"; "required": false; }; "footerRowHeight": { "alias": "footerRowHeight"; "required": false; }; "topGroupedBadgesBackgroundColor": { "alias": "topGroupedBadgesBackgroundColor"; "required": false; }; "showRowsGrouping": { "alias": "showRowsGrouping"; "required": false; }; "showFilterRow": { "alias": "showFilterRow"; "required": false; }; "fontFaimly": { "alias": "fontFaimly"; "required": false; }; "showSideMenu": { "alias": "showSideMenu"; "required": false; }; "footerPadding": { "alias": "footerPadding"; "required": false; }; "topFilterRowHeight": { "alias": "topFilterRowHeight"; "required": false; }; "rowShadingEnabled": { "alias": "rowShadingEnabled"; "required": false; }; "showSerialNumber": { "alias": "showSerialNumber"; "required": false; }; "singleSpaAssetsPath": { "alias": "singleSpaAssetsPath"; "required": false; }; "filtersConfig": { "alias": "filtersConfig"; "required": false; }; "loading": { "alias": "loading"; "required": false; }; "verticalScrollbarWidth": { "alias": "verticalScrollbarWidth"; "required": false; }; "horizintalScrollbarWidth": { "alias": "horizintalScrollbarWidth"; "required": false; }; "showCellDetailsBox": { "alias": "showCellDetailsBox"; "required": false; }; "dateFormat": { "alias": "dateFormat"; "required": false; }; "tableSearch": { "alias": "tableSearch"; "required": false; }; "actions": { "alias": "actions"; "required": false; }; "config": { "alias": "config"; "required": false; }; "showTaskbar": { "alias": "showTaskbar"; "required": false; }; "tableName": { "alias": "tableName"; "required": false; }; "listingType": { "alias": "listingType"; "required": false; }; "checkboxState": { "alias": "checkboxState"; "required": false; }; "taskbarActions": { "alias": "taskbarActions"; "required": false; }; "sortingConfig": { "alias": "sortingConfig"; "required": false; }; "tableFilterViewId": { "alias": "tableFilterViewId"; "required": false; }; "selectedTableLayout": { "alias": "selectedTableLayout"; "required": false; }; "closeDropdown": { "alias": "closeDropdown"; "required": false; }; "globalSearchText": { "alias": "globalSearchText"; "required": false; }; "nestedTablerowFontsize": { "alias": "nestedTablerowFontsize"; "required": false; }; "nestedTableHeaderRowHeight": { "alias": "nestedTableHeaderRowHeight"; "required": false; }; "nestedTablerowHeight": { "alias": "nestedTablerowHeight"; "required": false; }; "gridType": { "alias": "gridType"; "required": false; }; "currencySymbol": { "alias": "currencySymbol"; "required": false; }; "leftPinnedBoxshadow": { "alias": "leftPinnedBoxshadow"; "required": false; }; "rightPinnedBoxshadow": { "alias": "rightPinnedBoxshadow"; "required": false; }; "selectedRowsBackgroundColor": { "alias": "selectedRowsBackgroundColor"; "required": false; }; "nestedTableHeaderBackgroundColor": { "alias": "nestedTableHeaderBackgroundColor"; "required": false; }; "nestedTableRowBackgroundColor": { "alias": "nestedTableRowBackgroundColor"; "required": false; }; "tableView": { "alias": "tableView"; "required": false; }; "buttons": { "alias": "buttons"; "required": false; }; "keepMultipleExpandedDetails": { "alias": "keepMultipleExpandedDetails"; "required": false; }; "showTotalAmountRow": { "alias": "showTotalAmountRow"; "required": false; }; "enableGlobalSearch": { "alias": "enableGlobalSearch"; "required": false; }; "tableType": { "alias": "tableType"; "required": false; }; "enableExport": { "alias": "enableExport"; "required": false; }; "enableCut": { "alias": "enableCut"; "required": false; }; "tabs": { "alias": "tabs"; "required": false; }; "resetAllFilters": { "alias": "resetAllFilters"; "required": false; }; "columnThreedotsMunuConfig": { "alias": "columnThreedotsMunuConfig"; "required": false; }; }, { "changeLayout": "changeLayout"; "filterOptions": "filterOptions"; "genericEvent": "genericEvent"; "tablePresetConfig": "tablePresetConfig"; "sortingOrderOptions": "sortingOrderOptions"; "createUpdateConfigListing": "createUpdateConfigListing"; }, never, never, false, never>;
|
|
476
537
|
}
|
|
@@ -1,14 +1,13 @@
|
|
|
1
1
|
import * as i0 from "@angular/core";
|
|
2
2
|
import * as i1 from "./data-grid/data-grid.component";
|
|
3
3
|
import * as i2 from "./pipes/filter.pipe";
|
|
4
|
-
import * as i3 from "
|
|
5
|
-
import * as i4 from "@angular/
|
|
6
|
-
import * as i5 from "@angular/
|
|
7
|
-
import * as i6 from "
|
|
8
|
-
import * as i7 from "
|
|
9
|
-
import * as i8 from "@angular/cdk/scrolling";
|
|
4
|
+
import * as i3 from "@angular/common";
|
|
5
|
+
import * as i4 from "@angular/forms";
|
|
6
|
+
import * as i5 from "@angular/cdk/drag-drop";
|
|
7
|
+
import * as i6 from "ng-inline-svg";
|
|
8
|
+
import * as i7 from "@angular/cdk/scrolling";
|
|
10
9
|
export declare class DataGridModule {
|
|
11
10
|
static ɵfac: i0.ɵɵFactoryDeclaration<DataGridModule, never>;
|
|
12
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<DataGridModule, [typeof i1.DataGridComponent, typeof i2.FilterPipe
|
|
11
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<DataGridModule, [typeof i1.DataGridComponent, typeof i2.FilterPipe], [typeof i3.CommonModule, typeof i4.FormsModule, typeof i5.DragDropModule, typeof i6.InlineSVGModule, typeof i7.ScrollingModule], [typeof i1.DataGridComponent]>;
|
|
13
12
|
static ɵinj: i0.ɵɵInjectorDeclaration<DataGridModule>;
|
|
14
13
|
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
export declare class ExportService {
|
|
3
|
+
constructor();
|
|
4
|
+
/**
|
|
5
|
+
* Exports data to CSV or Excel.
|
|
6
|
+
* @param columns List of column definitions (each having name/key/is_visible)
|
|
7
|
+
* @param data The array of data objects
|
|
8
|
+
* @param fileName Name of the exported file (without extension)
|
|
9
|
+
* @param format 'csv' | 'xlsx'
|
|
10
|
+
*/
|
|
11
|
+
exportData(columns: any[], data: any[], fileName: string, format?: 'csv' | 'xlsx', rowSelectedIndexes?: Set<number> | null, styleConfig?: {
|
|
12
|
+
headerBgColor?: string;
|
|
13
|
+
headerTextColor?: string;
|
|
14
|
+
bodyTextColor?: string;
|
|
15
|
+
fontFamily?: string;
|
|
16
|
+
fontWeight?: 'normal' | 'bold';
|
|
17
|
+
zoomScale?: number;
|
|
18
|
+
headerRowHeight?: number;
|
|
19
|
+
selectedRowBgColor?: string;
|
|
20
|
+
}): void;
|
|
21
|
+
private getNestedValue;
|
|
22
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ExportService, never>;
|
|
23
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<ExportService>;
|
|
24
|
+
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "ms-data-grid",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.42",
|
|
4
4
|
"description": "A powerful, customizable Angular data grid component with advanced features like sorting, filtering, pagination, column pinning, and taskbar actions. Perfect for enterprise applications.",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"angular",
|
|
@@ -26,7 +26,13 @@
|
|
|
26
26
|
"@angular/core": "^16.2.0"
|
|
27
27
|
},
|
|
28
28
|
"dependencies": {
|
|
29
|
-
"
|
|
29
|
+
"xlsx-js-style": "^1.2.0",
|
|
30
|
+
"ng-inline-svg": "^13.1.1",
|
|
31
|
+
"ngx-bootstrap": "^20.0.0",
|
|
32
|
+
"bootstrap": "^5.3.7",
|
|
33
|
+
"tslib": "^2.3.0",
|
|
34
|
+
"file-saver": "^2.0.5",
|
|
35
|
+
"zone.js": "~0.13.0"
|
|
30
36
|
},
|
|
31
37
|
"sideEffects": false,
|
|
32
38
|
"module": "fesm2022/ms-data-grid.mjs",
|
package/public-api.d.ts
CHANGED
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export class DataGridService {
|
|
4
|
-
constructor() { }
|
|
5
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataGridService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
6
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataGridService, providedIn: 'root' }); }
|
|
7
|
-
}
|
|
8
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DataGridService, decorators: [{
|
|
9
|
-
type: Injectable,
|
|
10
|
-
args: [{
|
|
11
|
-
providedIn: 'root'
|
|
12
|
-
}]
|
|
13
|
-
}], ctorParameters: function () { return []; } });
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1ncmlkLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhLWdyaWQvc3JjL2xpYi9kYXRhLWdyaWQuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUszQyxNQUFNLE9BQU8sZUFBZTtJQUUxQixnQkFBZ0IsQ0FBQzsrR0FGTixlQUFlO21IQUFmLGVBQWUsY0FGZCxNQUFNOzs0RkFFUCxlQUFlO2tCQUgzQixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCdcclxufSlcclxuZXhwb3J0IGNsYXNzIERhdGFHcmlkU2VydmljZSB7XHJcblxyXG4gIGNvbnN0cnVjdG9yKCkgeyB9XHJcbn1cclxuIl19
|
|
@@ -1,145 +0,0 @@
|
|
|
1
|
-
import { Directive, EventEmitter, HostListener, Input, Output, } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export class DraggableHeaderDirective {
|
|
4
|
-
constructor(el, renderer) {
|
|
5
|
-
this.el = el;
|
|
6
|
-
this.renderer = renderer;
|
|
7
|
-
this.headerName = '';
|
|
8
|
-
this.dragStart = new EventEmitter();
|
|
9
|
-
this.dragMove = new EventEmitter();
|
|
10
|
-
this.dragEnd = new EventEmitter();
|
|
11
|
-
this.isDragging = false;
|
|
12
|
-
this.placeholderEl = null;
|
|
13
|
-
this.previewEl = null;
|
|
14
|
-
this.startX = 0;
|
|
15
|
-
this.startY = 0;
|
|
16
|
-
this.onMouseMove = (event) => {
|
|
17
|
-
debugger;
|
|
18
|
-
const moveX = Math.abs(event.clientX - this.startX - 10);
|
|
19
|
-
const moveY = Math.abs(event.clientY - this.startY - 10);
|
|
20
|
-
if (!this.isDragging && (moveX > 1 || moveY > 1)) {
|
|
21
|
-
this.startDragging(event);
|
|
22
|
-
}
|
|
23
|
-
if (this.isDragging && this.previewEl) {
|
|
24
|
-
this.renderer.setStyle(this.previewEl, 'top', `${event.pageY + 10}px`);
|
|
25
|
-
this.renderer.setStyle(this.previewEl, 'left', `${event.pageX + 10}px`);
|
|
26
|
-
// Find the element under cursor (hovered element)
|
|
27
|
-
const hoveredElement = document.elementFromPoint(event.clientX, event.clientY);
|
|
28
|
-
this.dragMove.emit({
|
|
29
|
-
event,
|
|
30
|
-
column: this.column,
|
|
31
|
-
hoveredElement,
|
|
32
|
-
});
|
|
33
|
-
}
|
|
34
|
-
};
|
|
35
|
-
this.onMouseUp = (event) => {
|
|
36
|
-
if (!this.isDragging)
|
|
37
|
-
return;
|
|
38
|
-
this.isDragging = false;
|
|
39
|
-
this.dragEnd.emit({ column: this.column, event });
|
|
40
|
-
if (this.previewEl) {
|
|
41
|
-
this.renderer.removeChild(document.body, this.previewEl);
|
|
42
|
-
this.previewEl = null;
|
|
43
|
-
}
|
|
44
|
-
if (this.placeholderEl) {
|
|
45
|
-
const parent = this.placeholderEl.parentNode;
|
|
46
|
-
if (parent) {
|
|
47
|
-
parent.replaceChild(this.el.nativeElement, this.placeholderEl);
|
|
48
|
-
}
|
|
49
|
-
this.placeholderEl = null;
|
|
50
|
-
}
|
|
51
|
-
// Reset the cursor
|
|
52
|
-
this.resetCursor();
|
|
53
|
-
document.removeEventListener('mousemove', this.onMouseMove);
|
|
54
|
-
document.removeEventListener('mouseup', this.onMouseUp);
|
|
55
|
-
};
|
|
56
|
-
this.originalCursor = null;
|
|
57
|
-
}
|
|
58
|
-
onMouseDown(event) {
|
|
59
|
-
if (event.button !== 0)
|
|
60
|
-
return;
|
|
61
|
-
let target = event.target;
|
|
62
|
-
const classes = target.classList;
|
|
63
|
-
debugger;
|
|
64
|
-
if (event.target.classList.contains('three-dots'))
|
|
65
|
-
return;
|
|
66
|
-
this.startX = event.clientX;
|
|
67
|
-
this.startY = event.clientY;
|
|
68
|
-
this.isDragging = false;
|
|
69
|
-
document.addEventListener('mousemove', this.onMouseMove);
|
|
70
|
-
document.addEventListener('mouseup', this.onMouseUp);
|
|
71
|
-
}
|
|
72
|
-
setCursor(cursorStyle) {
|
|
73
|
-
this.renderer.setStyle(document.body, 'cursor', cursorStyle);
|
|
74
|
-
}
|
|
75
|
-
resetCursor() {
|
|
76
|
-
this.renderer.setStyle(document.body, 'cursor', this.originalCursor || '');
|
|
77
|
-
}
|
|
78
|
-
startDragging(event) {
|
|
79
|
-
this.isDragging = true;
|
|
80
|
-
// Store original cursor (optional fallback)
|
|
81
|
-
this.originalCursor = getComputedStyle(document.body).cursor;
|
|
82
|
-
// Set cursor to grabbing
|
|
83
|
-
this.setCursor('move');
|
|
84
|
-
// --- Clone the element as a placeholder ---
|
|
85
|
-
this.placeholderEl = this.el.nativeElement.cloneNode(true);
|
|
86
|
-
this.renderer.setStyle(this.placeholderEl, 'opacity', '0.5');
|
|
87
|
-
this.renderer.setStyle(this.placeholderEl, 'pointer-events', 'none');
|
|
88
|
-
this.renderer.addClass(this.placeholderEl, 'drag-placeholder');
|
|
89
|
-
const parent = this.el.nativeElement.parentNode;
|
|
90
|
-
parent.replaceChild(this.placeholderEl, this.el.nativeElement);
|
|
91
|
-
// --- Create floating preview ---
|
|
92
|
-
this.previewEl = this.renderer.createElement('div');
|
|
93
|
-
this.renderer.setStyle(this.previewEl, 'position', 'absolute');
|
|
94
|
-
this.renderer.setStyle(this.previewEl, 'top', `${event.pageY + 10}px`);
|
|
95
|
-
this.renderer.setStyle(this.previewEl, 'left', `${event.pageX + 10}px`);
|
|
96
|
-
this.renderer.setStyle(this.previewEl, 'pointer-events', 'none');
|
|
97
|
-
this.renderer.setStyle(this.previewEl, 'z-index', '1000');
|
|
98
|
-
this.renderer.setStyle(this.previewEl, 'max-width', '200px');
|
|
99
|
-
this.renderer.setStyle(this.previewEl, 'padding', '8px');
|
|
100
|
-
this.renderer.setStyle(this.previewEl, 'border', '1px solid #ccc');
|
|
101
|
-
this.renderer.setStyle(this.previewEl, 'background-color', '#fff');
|
|
102
|
-
this.renderer.setStyle(this.previewEl, 'box-shadow', '0 2px 6px rgba(0,0,0,0.2)');
|
|
103
|
-
this.renderer.setStyle(this.previewEl, 'border-radius', '4px');
|
|
104
|
-
this.renderer.setStyle(this.previewEl, 'display', 'flex');
|
|
105
|
-
this.renderer.setStyle(this.previewEl, 'align-items', 'center');
|
|
106
|
-
this.renderer.setStyle(this.previewEl, 'gap', '8px');
|
|
107
|
-
this.renderer.setStyle(this.previewEl, 'font-weight', '500');
|
|
108
|
-
this.renderer.setStyle(this.previewEl, 'white-space', 'nowrap');
|
|
109
|
-
const icon = this.renderer.createElement('span');
|
|
110
|
-
this.renderer.setStyle(icon, 'font-size', '16px');
|
|
111
|
-
this.renderer.setStyle(icon, 'user-select', 'none');
|
|
112
|
-
this.renderer.setProperty(icon, 'innerText', '≡');
|
|
113
|
-
const text = this.renderer.createElement('span');
|
|
114
|
-
this.renderer.setProperty(text, 'innerText', this.headerName || 'Dragging');
|
|
115
|
-
this.renderer.appendChild(this.previewEl, icon);
|
|
116
|
-
this.renderer.appendChild(this.previewEl, text);
|
|
117
|
-
this.renderer.appendChild(document.body, this.previewEl);
|
|
118
|
-
this.dragStart.emit({ column: this.column, event });
|
|
119
|
-
}
|
|
120
|
-
overrideCursor(style) {
|
|
121
|
-
this.setCursor(style);
|
|
122
|
-
}
|
|
123
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DraggableHeaderDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
124
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: DraggableHeaderDirective, selector: "[appDraggableHeader]", inputs: { column: "column", headerName: "headerName" }, outputs: { dragStart: "dragStart", dragMove: "dragMove", dragEnd: "dragEnd" }, host: { listeners: { "mousedown": "onMouseDown($event)" } }, ngImport: i0 }); }
|
|
125
|
-
}
|
|
126
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DraggableHeaderDirective, decorators: [{
|
|
127
|
-
type: Directive,
|
|
128
|
-
args: [{
|
|
129
|
-
selector: '[appDraggableHeader]',
|
|
130
|
-
}]
|
|
131
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { column: [{
|
|
132
|
-
type: Input
|
|
133
|
-
}], headerName: [{
|
|
134
|
-
type: Input
|
|
135
|
-
}], dragStart: [{
|
|
136
|
-
type: Output
|
|
137
|
-
}], dragMove: [{
|
|
138
|
-
type: Output
|
|
139
|
-
}], dragEnd: [{
|
|
140
|
-
type: Output
|
|
141
|
-
}], onMouseDown: [{
|
|
142
|
-
type: HostListener,
|
|
143
|
-
args: ['mousedown', ['$event']]
|
|
144
|
-
}] } });
|
|
145
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"draggable-header.directive.js","sourceRoot":"","sources":["../../../../../projects/data-grid/src/lib/directives/draggable-header.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  Output,\r\n  Renderer2,\r\n} from '@angular/core';\r\n\r\nexport interface DragMoveEvent {\r\n  event: MouseEvent;\r\n  data: any;\r\n}\r\n\r\n@Directive({\r\n  selector: '[appDraggableHeader]',\r\n})\r\nexport class DraggableHeaderDirective {\r\n  @Input() column: any;\r\n  @Input() headerName: string = '';\r\n\r\n  @Output() dragStart = new EventEmitter<any>();\r\n  @Output() dragMove = new EventEmitter<any>();\r\n  @Output() dragEnd = new EventEmitter<any>();\r\n\r\n  private isDragging = false;\r\n  private placeholderEl: HTMLElement | null = null;\r\n  private previewEl: HTMLElement | null = null;\r\n\r\n  constructor(private el: ElementRef, private renderer: Renderer2) {}\r\n\r\n  startX = 0;\r\n  startY = 0;\r\n\r\n  @HostListener('mousedown', ['$event'])\r\n  onMouseDown(event: MouseEvent) {\r\n    if (event.button !== 0) return;\r\n    let target = event.target as HTMLElement;\r\n    const classes = target.classList;\r\n    debugger\r\n    if ((event.target as HTMLElement).classList.contains('three-dots')) return;\r\n      this.startX = event.clientX;\r\n    this.startY = event.clientY;\r\n    this.isDragging = false;\r\n\r\n    document.addEventListener('mousemove', this.onMouseMove);\r\n    document.addEventListener('mouseup', this.onMouseUp);\r\n  }\r\n\r\n  onMouseMove = (event: MouseEvent) => {\r\n    debugger\r\n    const moveX = Math.abs(event.clientX - this.startX - 10);\r\n    const moveY = Math.abs(event.clientY - this.startY - 10);\r\n    if (!this.isDragging && (moveX > 1 || moveY > 1)) {\r\n      this.startDragging(event);\r\n    }\r\n\r\n    if (this.isDragging && this.previewEl) {\r\n      this.renderer.setStyle(this.previewEl, 'top', `${event.pageY + 10}px`);\r\n      this.renderer.setStyle(this.previewEl, 'left', `${event.pageX + 10}px`);\r\n\r\n      // Find the element under cursor (hovered element)\r\n      const hoveredElement = document.elementFromPoint(\r\n        event.clientX,\r\n        event.clientY\r\n      );\r\n\r\n      this.dragMove.emit({\r\n        event,\r\n        column: this.column,\r\n        hoveredElement,\r\n      });\r\n    }\r\n  };\r\n\r\n  onMouseUp = (event: MouseEvent) => {\r\n    if (!this.isDragging) return;\r\n    this.isDragging = false;\r\n\r\n    this.dragEnd.emit({ column: this.column, event });\r\n\r\n    if (this.previewEl) {\r\n      this.renderer.removeChild(document.body, this.previewEl);\r\n      this.previewEl = null;\r\n    }\r\n\r\n    if (this.placeholderEl) {\r\n      const parent = this.placeholderEl.parentNode;\r\n      if (parent) {\r\n        parent.replaceChild(this.el.nativeElement, this.placeholderEl);\r\n      }\r\n      this.placeholderEl = null;\r\n    }\r\n\r\n    // Reset the cursor\r\n    this.resetCursor();\r\n\r\n    document.removeEventListener('mousemove', this.onMouseMove);\r\n    document.removeEventListener('mouseup', this.onMouseUp);\r\n  };\r\n\r\n  private originalCursor: string | null = null;\r\n\r\n  private setCursor(cursorStyle: string) {\r\n    this.renderer.setStyle(document.body, 'cursor', cursorStyle);\r\n  }\r\n\r\n  private resetCursor() {\r\n    this.renderer.setStyle(document.body, 'cursor', this.originalCursor || '');\r\n  }\r\n\r\n  private startDragging(event: MouseEvent) {\r\n    this.isDragging = true;\r\n\r\n    // Store original cursor (optional fallback)\r\n    this.originalCursor = getComputedStyle(document.body).cursor;\r\n\r\n    // Set cursor to grabbing\r\n    this.setCursor('move');\r\n\r\n    // --- Clone the element as a placeholder ---\r\n    this.placeholderEl = this.el.nativeElement.cloneNode(true) as HTMLElement;\r\n    this.renderer.setStyle(this.placeholderEl, 'opacity', '0.5');\r\n    this.renderer.setStyle(this.placeholderEl, 'pointer-events', 'none');\r\n    this.renderer.addClass(this.placeholderEl, 'drag-placeholder');\r\n\r\n    const parent = this.el.nativeElement.parentNode;\r\n    parent.replaceChild(this.placeholderEl, this.el.nativeElement);\r\n\r\n    // --- Create floating preview ---\r\n    this.previewEl = this.renderer.createElement('div');\r\n    this.renderer.setStyle(this.previewEl, 'position', 'absolute');\r\n    this.renderer.setStyle(this.previewEl, 'top', `${event.pageY + 10}px`);\r\n    this.renderer.setStyle(this.previewEl, 'left', `${event.pageX + 10}px`);\r\n    this.renderer.setStyle(this.previewEl, 'pointer-events', 'none');\r\n    this.renderer.setStyle(this.previewEl, 'z-index', '1000');\r\n    this.renderer.setStyle(this.previewEl, 'max-width', '200px');\r\n    this.renderer.setStyle(this.previewEl, 'padding', '8px');\r\n    this.renderer.setStyle(this.previewEl, 'border', '1px solid #ccc');\r\n    this.renderer.setStyle(this.previewEl, 'background-color', '#fff');\r\n    this.renderer.setStyle(\r\n      this.previewEl,\r\n      'box-shadow',\r\n      '0 2px 6px rgba(0,0,0,0.2)'\r\n    );\r\n    this.renderer.setStyle(this.previewEl, 'border-radius', '4px');\r\n    this.renderer.setStyle(this.previewEl, 'display', 'flex');\r\n    this.renderer.setStyle(this.previewEl, 'align-items', 'center');\r\n    this.renderer.setStyle(this.previewEl, 'gap', '8px');\r\n    this.renderer.setStyle(this.previewEl, 'font-weight', '500');\r\n    this.renderer.setStyle(this.previewEl, 'white-space', 'nowrap');\r\n\r\n    const icon = this.renderer.createElement('span');\r\n    this.renderer.setStyle(icon, 'font-size', '16px');\r\n    this.renderer.setStyle(icon, 'user-select', 'none');\r\n    this.renderer.setProperty(icon, 'innerText', '≡');\r\n\r\n    const text = this.renderer.createElement('span');\r\n    this.renderer.setProperty(text, 'innerText', this.headerName || 'Dragging');\r\n\r\n    this.renderer.appendChild(this.previewEl, icon);\r\n    this.renderer.appendChild(this.previewEl, text);\r\n    this.renderer.appendChild(document.body, this.previewEl);\r\n\r\n    this.dragStart.emit({ column: this.column, event });\r\n  }\r\n\r\n  public overrideCursor(style: string) {\r\n    this.setCursor(style);\r\n  }\r\n}\r\n"]}
|