angular-slickgrid 3.3.2 → 4.1.2
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 +180 -188
- package/angular-slickgrid.d.ts +1 -3
- package/app/modules/angular-slickgrid/components/angular-slickgrid.component.d.ts +9 -6
- package/app/modules/angular-slickgrid/extensions/index.d.ts +1 -1
- package/app/modules/angular-slickgrid/extensions/{rowDetailViewExtension.d.ts → slickRowDetailView.d.ts} +40 -27
- package/app/modules/angular-slickgrid/index.d.ts +1 -1
- package/app/modules/angular-slickgrid/models/angularGridInstance.interface.d.ts +1 -1
- package/app/modules/angular-slickgrid/modules/angular-slickgrid.module.d.ts +7 -0
- package/app/modules/angular-slickgrid/services/angularUtil.service.d.ts +3 -0
- package/app/modules/angular-slickgrid/services/bsDropdown.service.d.ts +3 -0
- package/app/modules/angular-slickgrid/services/container.service.d.ts +3 -0
- package/app/modules/angular-slickgrid/services/translater.service.d.ts +3 -0
- package/docs/assets/lib/multiple-select/README.md +17 -0
- package/esm2020/angular-slickgrid.mjs +5 -0
- package/esm2020/app/modules/angular-slickgrid/components/angular-slickgrid.component.mjs +1168 -0
- package/{esm2015/app/modules/angular-slickgrid/constants.js → esm2020/app/modules/angular-slickgrid/constants.mjs} +0 -0
- package/{esm2015/app/modules/angular-slickgrid/extensions/index.js → esm2020/app/modules/angular-slickgrid/extensions/index.mjs} +2 -2
- package/esm2020/app/modules/angular-slickgrid/extensions/slickRowDetailView.mjs +300 -0
- package/esm2020/app/modules/angular-slickgrid/global-grid-options.mjs +243 -0
- package/{esm2015/app/modules/angular-slickgrid/index.js → esm2020/app/modules/angular-slickgrid/index.mjs} +2 -2
- package/{esm2015/app/modules/angular-slickgrid/models/angularComponentOutput.interface.js → esm2020/app/modules/angular-slickgrid/models/angularComponentOutput.interface.mjs} +0 -0
- package/esm2020/app/modules/angular-slickgrid/models/angularGridInstance.interface.mjs +2 -0
- package/{esm2015/app/modules/angular-slickgrid/models/externalTestingDependencies.interface.js → esm2020/app/modules/angular-slickgrid/models/externalTestingDependencies.interface.mjs} +0 -0
- package/{esm2015/app/modules/angular-slickgrid/models/gridOption.interface.js → esm2020/app/modules/angular-slickgrid/models/gridOption.interface.mjs} +0 -0
- package/{esm2015/app/modules/angular-slickgrid/models/index.js → esm2020/app/modules/angular-slickgrid/models/index.mjs} +0 -0
- package/{esm2015/app/modules/angular-slickgrid/models/rowDetailView.interface.js → esm2020/app/modules/angular-slickgrid/models/rowDetailView.interface.mjs} +0 -0
- package/{esm2015/app/modules/angular-slickgrid/models/slickGrid.interface.js → esm2020/app/modules/angular-slickgrid/models/slickGrid.interface.mjs} +0 -0
- package/esm2020/app/modules/angular-slickgrid/modules/angular-slickgrid.module.mjs +46 -0
- package/esm2020/app/modules/angular-slickgrid/services/angularUtil.service.mjs +46 -0
- package/esm2020/app/modules/angular-slickgrid/services/bsDropdown.service.mjs +103 -0
- package/esm2020/app/modules/angular-slickgrid/services/container.service.mjs +26 -0
- package/{esm2015/app/modules/angular-slickgrid/services/index.js → esm2020/app/modules/angular-slickgrid/services/index.mjs} +0 -0
- package/esm2020/app/modules/angular-slickgrid/services/translater.service.mjs +43 -0
- package/{esm2015/app/modules/angular-slickgrid/services/utilities.js → esm2020/app/modules/angular-slickgrid/services/utilities.mjs} +0 -0
- package/{esm2015/app/modules/angular-slickgrid/slickgrid-config.js → esm2020/app/modules/angular-slickgrid/slickgrid-config.mjs} +0 -0
- package/{esm2015/public_api.js → esm2020/public_api.mjs} +0 -0
- package/fesm2015/{angular-slickgrid.js → angular-slickgrid.mjs} +252 -282
- package/fesm2015/angular-slickgrid.mjs.map +1 -0
- package/fesm2020/angular-slickgrid.mjs +2066 -0
- package/fesm2020/angular-slickgrid.mjs.map +1 -0
- package/package.json +38 -23
- package/angular-slickgrid.metadata.json +0 -1
- package/bundles/angular-slickgrid.umd.js +0 -2642
- package/bundles/angular-slickgrid.umd.js.map +0 -1
- package/esm2015/angular-slickgrid.js +0 -7
- package/esm2015/app/modules/angular-slickgrid/components/angular-slickgrid.component.js +0 -1202
- package/esm2015/app/modules/angular-slickgrid/extensions/rowDetailViewExtension.js +0 -342
- package/esm2015/app/modules/angular-slickgrid/global-grid-options.js +0 -243
- package/esm2015/app/modules/angular-slickgrid/models/angularGridInstance.interface.js +0 -2
- package/esm2015/app/modules/angular-slickgrid/modules/angular-slickgrid.module.js +0 -37
- package/esm2015/app/modules/angular-slickgrid/services/angularUtil.service.js +0 -48
- package/esm2015/app/modules/angular-slickgrid/services/bsDropdown.service.js +0 -103
- package/esm2015/app/modules/angular-slickgrid/services/container.service.js +0 -24
- package/esm2015/app/modules/angular-slickgrid/services/translater.service.js +0 -47
- package/fesm2015/angular-slickgrid.js.map +0 -1
|
@@ -1,342 +0,0 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import 'slickgrid/plugins/slick.rowdetailview';
|
|
3
|
-
import 'slickgrid/plugins/slick.rowselectionmodel';
|
|
4
|
-
import { ApplicationRef, Injectable } from '@angular/core';
|
|
5
|
-
import { addToArrayWhenNotExists, castObservableToPromise, RxJsFacade, SharedService, } from '@slickgrid-universal/common';
|
|
6
|
-
import { EventPubSubService } from '@slickgrid-universal/event-pub-sub';
|
|
7
|
-
import { Observable } from 'rxjs';
|
|
8
|
-
import * as DOMPurify_ from 'dompurify';
|
|
9
|
-
const DOMPurify = DOMPurify_['default'] || DOMPurify_; // patch to fix rollup to work
|
|
10
|
-
import { AngularUtilService } from '../services/angularUtil.service';
|
|
11
|
-
import { unsubscribeAllObservables } from '../services/utilities';
|
|
12
|
-
const ROW_DETAIL_CONTAINER_PREFIX = 'container_';
|
|
13
|
-
const PRELOAD_CONTAINER_PREFIX = 'container_loading';
|
|
14
|
-
export class RowDetailViewExtension {
|
|
15
|
-
constructor(angularUtilService, appRef, eventPubSubService, sharedService, rxjs) {
|
|
16
|
-
this.angularUtilService = angularUtilService;
|
|
17
|
-
this.appRef = appRef;
|
|
18
|
-
this.eventPubSubService = eventPubSubService;
|
|
19
|
-
this.sharedService = sharedService;
|
|
20
|
-
this.rxjs = rxjs;
|
|
21
|
-
this._views = [];
|
|
22
|
-
this._subscriptions = [];
|
|
23
|
-
this._eventHandler = new Slick.EventHandler();
|
|
24
|
-
}
|
|
25
|
-
get datasetIdPropName() {
|
|
26
|
-
return this.gridOptions.datasetIdPropertyName || 'id';
|
|
27
|
-
}
|
|
28
|
-
get eventHandler() {
|
|
29
|
-
return this._eventHandler;
|
|
30
|
-
}
|
|
31
|
-
get gridOptions() {
|
|
32
|
-
var _a, _b;
|
|
33
|
-
return ((_b = (_a = this.sharedService) === null || _a === void 0 ? void 0 : _a.gridOptions) !== null && _b !== void 0 ? _b : {});
|
|
34
|
-
}
|
|
35
|
-
get rowDetailViewOptions() {
|
|
36
|
-
return this.gridOptions.rowDetailView;
|
|
37
|
-
}
|
|
38
|
-
addRxJsResource(rxjs) {
|
|
39
|
-
this.rxjs = rxjs;
|
|
40
|
-
}
|
|
41
|
-
/** Dispose of the RowDetailView Extension */
|
|
42
|
-
dispose() {
|
|
43
|
-
// unsubscribe all SlickGrid events
|
|
44
|
-
this._eventHandler.unsubscribeAll();
|
|
45
|
-
if (this._addon && this._addon.destroy) {
|
|
46
|
-
this._addon.destroy();
|
|
47
|
-
}
|
|
48
|
-
this._addonOptions = null;
|
|
49
|
-
// also unsubscribe all RxJS subscriptions
|
|
50
|
-
this._subscriptions = unsubscribeAllObservables(this._subscriptions);
|
|
51
|
-
this.disposeAllViewComponents();
|
|
52
|
-
}
|
|
53
|
-
/** Dispose of all the opened Row Detail Panels Angular View Components */
|
|
54
|
-
disposeAllViewComponents() {
|
|
55
|
-
this._views.forEach((compRef) => this.disposeViewComponent(compRef));
|
|
56
|
-
this._views = [];
|
|
57
|
-
}
|
|
58
|
-
/**
|
|
59
|
-
* Create the plugin before the Grid creation, else it will behave oddly.
|
|
60
|
-
* Mostly because the column definitions might change after the grid creation
|
|
61
|
-
*/
|
|
62
|
-
create(columnDefinitions, gridOptions) {
|
|
63
|
-
var _a, _b;
|
|
64
|
-
if (columnDefinitions && gridOptions) {
|
|
65
|
-
if (!gridOptions.rowDetailView) {
|
|
66
|
-
throw new Error('The Row Detail View requires options to be passed via the "rowDetailView" property of the Grid Options');
|
|
67
|
-
}
|
|
68
|
-
if (gridOptions === null || gridOptions === void 0 ? void 0 : gridOptions.rowDetailView) {
|
|
69
|
-
if (!this._addon) {
|
|
70
|
-
if (typeof gridOptions.rowDetailView.process === 'function') {
|
|
71
|
-
// we need to keep the user "process" method and replace it with our own execution method
|
|
72
|
-
// we do this because when we get the item detail, we need to call "onAsyncResponse.notify" for the plugin to work
|
|
73
|
-
this._userProcessFn = gridOptions.rowDetailView.process; // keep user's process method
|
|
74
|
-
gridOptions.rowDetailView.process = (item) => this.onProcessing(item); // replace process method & run our internal one
|
|
75
|
-
}
|
|
76
|
-
else {
|
|
77
|
-
throw new Error('You need to provide a "process" function for the Row Detail Extension to work properly');
|
|
78
|
-
}
|
|
79
|
-
// load the Preload & RowDetail Templates (could be straight HTML or Angular View/ViewModel)
|
|
80
|
-
// when those are Angular View/ViewModel, we need to create View Component & provide the html containers to the Plugin (preTemplate/postTemplate methods)
|
|
81
|
-
if (!gridOptions.rowDetailView.preTemplate) {
|
|
82
|
-
this._preloadComponent = (_a = gridOptions === null || gridOptions === void 0 ? void 0 : gridOptions.rowDetailView) === null || _a === void 0 ? void 0 : _a.preloadComponent;
|
|
83
|
-
gridOptions.rowDetailView.preTemplate = () => DOMPurify.sanitize(`<div class="${PRELOAD_CONTAINER_PREFIX}"></div>`);
|
|
84
|
-
}
|
|
85
|
-
if (!gridOptions.rowDetailView.postTemplate) {
|
|
86
|
-
this._viewComponent = (_b = gridOptions === null || gridOptions === void 0 ? void 0 : gridOptions.rowDetailView) === null || _b === void 0 ? void 0 : _b.viewComponent;
|
|
87
|
-
gridOptions.rowDetailView.postTemplate = (itemDetail) => DOMPurify.sanitize(`<div class="${ROW_DETAIL_CONTAINER_PREFIX}${itemDetail[this.datasetIdPropName]}"></div>`);
|
|
88
|
-
}
|
|
89
|
-
// finally register the Row Detail View Plugin
|
|
90
|
-
this._addonOptions = gridOptions.rowDetailView;
|
|
91
|
-
this._addon = new Slick.Plugins.RowDetailView(this._addonOptions);
|
|
92
|
-
}
|
|
93
|
-
const iconColumn = this._addon.getColumnDefinition();
|
|
94
|
-
if (typeof iconColumn === 'object') {
|
|
95
|
-
iconColumn.excludeFromExport = true;
|
|
96
|
-
iconColumn.excludeFromColumnPicker = true;
|
|
97
|
-
iconColumn.excludeFromGridMenu = true;
|
|
98
|
-
iconColumn.excludeFromQuery = true;
|
|
99
|
-
iconColumn.excludeFromHeaderMenu = true;
|
|
100
|
-
// column index position in the grid
|
|
101
|
-
const columnPosition = gridOptions && gridOptions.rowDetailView && gridOptions.rowDetailView.columnIndexPosition || 0;
|
|
102
|
-
if (columnPosition > 0) {
|
|
103
|
-
columnDefinitions.splice(columnPosition, 0, iconColumn);
|
|
104
|
-
}
|
|
105
|
-
else {
|
|
106
|
-
columnDefinitions.unshift(iconColumn);
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
return this._addon;
|
|
111
|
-
}
|
|
112
|
-
return null;
|
|
113
|
-
}
|
|
114
|
-
/** Get the instance of the SlickGrid addon (control or plugin). */
|
|
115
|
-
getAddonInstance() {
|
|
116
|
-
return this._addon;
|
|
117
|
-
}
|
|
118
|
-
register(rowSelectionPlugin) {
|
|
119
|
-
var _a;
|
|
120
|
-
if (((_a = this.sharedService) === null || _a === void 0 ? void 0 : _a.slickGrid) && this.sharedService.gridOptions) {
|
|
121
|
-
// the plugin has to be created BEFORE the grid (else it behaves oddly), but we can only watch grid events AFTER the grid is created
|
|
122
|
-
this.sharedService.slickGrid.registerPlugin(this._addon);
|
|
123
|
-
// this also requires the Row Selection Model to be registered as well
|
|
124
|
-
if (!rowSelectionPlugin || !this.sharedService.slickGrid.getSelectionModel()) {
|
|
125
|
-
rowSelectionPlugin = new Slick.RowSelectionModel(this.sharedService.gridOptions.rowSelectionOptions || { selectActiveRow: true });
|
|
126
|
-
this.sharedService.slickGrid.setSelectionModel(rowSelectionPlugin);
|
|
127
|
-
}
|
|
128
|
-
// hook all events
|
|
129
|
-
if (this.sharedService.slickGrid && this.rowDetailViewOptions) {
|
|
130
|
-
if (this.rowDetailViewOptions.onExtensionRegistered) {
|
|
131
|
-
this.rowDetailViewOptions.onExtensionRegistered(this._addon);
|
|
132
|
-
}
|
|
133
|
-
this._eventHandler.subscribe(this._addon.onAsyncResponse, (e, args) => {
|
|
134
|
-
if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onAsyncResponse === 'function') {
|
|
135
|
-
this.rowDetailViewOptions.onAsyncResponse(e, args);
|
|
136
|
-
}
|
|
137
|
-
});
|
|
138
|
-
this._eventHandler.subscribe(this._addon.onAsyncEndUpdate, (e, args) => {
|
|
139
|
-
// triggers after backend called "onAsyncResponse.notify()"
|
|
140
|
-
this.renderViewModel(args && args.item);
|
|
141
|
-
if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onAsyncEndUpdate === 'function') {
|
|
142
|
-
this.rowDetailViewOptions.onAsyncEndUpdate(e, args);
|
|
143
|
-
}
|
|
144
|
-
});
|
|
145
|
-
this._eventHandler.subscribe(this._addon.onAfterRowDetailToggle, (e, args) => {
|
|
146
|
-
// display preload template & re-render all the other Detail Views after toggling
|
|
147
|
-
// the preload View will eventually go away once the data gets loaded after the "onAsyncEndUpdate" event
|
|
148
|
-
this.renderPreloadView();
|
|
149
|
-
this.renderAllViewComponents();
|
|
150
|
-
if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onAfterRowDetailToggle === 'function') {
|
|
151
|
-
this.rowDetailViewOptions.onAfterRowDetailToggle(e, args);
|
|
152
|
-
}
|
|
153
|
-
});
|
|
154
|
-
this._eventHandler.subscribe(this._addon.onBeforeRowDetailToggle, (e, args) => {
|
|
155
|
-
// before toggling row detail, we need to create View Component if it doesn't exist
|
|
156
|
-
this.onBeforeRowDetailToggle(e, args);
|
|
157
|
-
if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onBeforeRowDetailToggle === 'function') {
|
|
158
|
-
this.rowDetailViewOptions.onBeforeRowDetailToggle(e, args);
|
|
159
|
-
}
|
|
160
|
-
});
|
|
161
|
-
this._eventHandler.subscribe(this._addon.onRowBackToViewportRange, (e, args) => {
|
|
162
|
-
// when row is back to viewport range, we will re-render the View Component(s)
|
|
163
|
-
this.onRowBackToViewportRange(e, args);
|
|
164
|
-
if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onRowBackToViewportRange === 'function') {
|
|
165
|
-
this.rowDetailViewOptions.onRowBackToViewportRange(e, args);
|
|
166
|
-
}
|
|
167
|
-
});
|
|
168
|
-
this._eventHandler.subscribe(this._addon.onRowOutOfViewportRange, (e, args) => {
|
|
169
|
-
if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onRowOutOfViewportRange === 'function') {
|
|
170
|
-
this.rowDetailViewOptions.onRowOutOfViewportRange(e, args);
|
|
171
|
-
}
|
|
172
|
-
});
|
|
173
|
-
// --
|
|
174
|
-
// hook some events needed by the Plugin itself
|
|
175
|
-
// we need to redraw the open detail views if we change column position (column reorder)
|
|
176
|
-
this._eventHandler.subscribe(this.sharedService.slickGrid.onColumnsReordered, this.redrawAllViewComponents.bind(this));
|
|
177
|
-
// on row selection changed, we also need to redraw
|
|
178
|
-
if (this.gridOptions.enableRowSelection || this.gridOptions.enableCheckboxSelector) {
|
|
179
|
-
this._eventHandler.subscribe(this.sharedService.slickGrid.onSelectedRowsChanged, this.redrawAllViewComponents.bind(this));
|
|
180
|
-
}
|
|
181
|
-
// on sort, all row detail are collapsed so we can dispose of all the Views as well
|
|
182
|
-
this._eventHandler.subscribe(this.sharedService.slickGrid.onSort, this.disposeAllViewComponents.bind(this));
|
|
183
|
-
// on filter changed, we need to re-render all Views
|
|
184
|
-
this._subscriptions.push(this.eventPubSubService.subscribe('onFilterChanged', this.redrawAllViewComponents.bind(this)));
|
|
185
|
-
}
|
|
186
|
-
return this._addon;
|
|
187
|
-
}
|
|
188
|
-
return null;
|
|
189
|
-
}
|
|
190
|
-
/** Redraw (re-render) all the expanded row detail View Components */
|
|
191
|
-
redrawAllViewComponents() {
|
|
192
|
-
this._views.forEach((compRef) => {
|
|
193
|
-
this.redrawViewComponent(compRef);
|
|
194
|
-
});
|
|
195
|
-
}
|
|
196
|
-
/** Render all the expanded row detail View Components */
|
|
197
|
-
renderAllViewComponents() {
|
|
198
|
-
this._views.forEach((view) => {
|
|
199
|
-
if (view && view.dataContext) {
|
|
200
|
-
this.renderViewModel(view.dataContext);
|
|
201
|
-
}
|
|
202
|
-
});
|
|
203
|
-
}
|
|
204
|
-
/** Redraw the necessary View Component */
|
|
205
|
-
redrawViewComponent(createdView) {
|
|
206
|
-
const containerElements = document.getElementsByClassName(`${ROW_DETAIL_CONTAINER_PREFIX}${createdView.id}`);
|
|
207
|
-
if (containerElements && containerElements.length >= 0) {
|
|
208
|
-
this.renderViewModel(createdView.dataContext);
|
|
209
|
-
}
|
|
210
|
-
}
|
|
211
|
-
/** Render (or re-render) the View Component (Row Detail) */
|
|
212
|
-
renderPreloadView() {
|
|
213
|
-
const containerElements = document.getElementsByClassName(`${PRELOAD_CONTAINER_PREFIX}`);
|
|
214
|
-
if (containerElements && containerElements.length >= 0) {
|
|
215
|
-
this.angularUtilService.createAngularComponentAppendToDom(this._preloadComponent, containerElements[containerElements.length - 1], true);
|
|
216
|
-
}
|
|
217
|
-
}
|
|
218
|
-
/** Render (or re-render) the View Component (Row Detail) */
|
|
219
|
-
renderViewModel(item) {
|
|
220
|
-
const containerElements = document.getElementsByClassName(`${ROW_DETAIL_CONTAINER_PREFIX}${item[this.datasetIdPropName]}`);
|
|
221
|
-
if (containerElements && containerElements.length > 0) {
|
|
222
|
-
const componentOutput = this.angularUtilService.createAngularComponentAppendToDom(this._viewComponent, containerElements[containerElements.length - 1], true);
|
|
223
|
-
if (componentOutput && componentOutput.componentRef && componentOutput.componentRef.instance) {
|
|
224
|
-
// pass a few properties to the Row Detail template component
|
|
225
|
-
Object.assign(componentOutput.componentRef.instance, {
|
|
226
|
-
model: item,
|
|
227
|
-
addon: this._addon,
|
|
228
|
-
grid: this.sharedService.slickGrid,
|
|
229
|
-
dataView: this.sharedService.dataView,
|
|
230
|
-
parent: this.rowDetailViewOptions && this.rowDetailViewOptions.parent,
|
|
231
|
-
});
|
|
232
|
-
const viewObj = this._views.find(obj => obj.id === item[this.datasetIdPropName]);
|
|
233
|
-
if (viewObj) {
|
|
234
|
-
viewObj.componentRef = componentOutput.componentRef;
|
|
235
|
-
}
|
|
236
|
-
return viewObj;
|
|
237
|
-
}
|
|
238
|
-
}
|
|
239
|
-
return undefined;
|
|
240
|
-
}
|
|
241
|
-
// --
|
|
242
|
-
// private functions
|
|
243
|
-
// ------------------
|
|
244
|
-
disposeViewComponent(expandedView) {
|
|
245
|
-
const compRef = expandedView === null || expandedView === void 0 ? void 0 : expandedView.componentRef;
|
|
246
|
-
if (compRef) {
|
|
247
|
-
this.appRef.detachView(compRef.hostView);
|
|
248
|
-
if (compRef === null || compRef === void 0 ? void 0 : compRef.destroy) {
|
|
249
|
-
compRef.destroy();
|
|
250
|
-
}
|
|
251
|
-
return expandedView;
|
|
252
|
-
}
|
|
253
|
-
return null;
|
|
254
|
-
}
|
|
255
|
-
/**
|
|
256
|
-
* notify the onAsyncResponse with the "args.item" (required property)
|
|
257
|
-
* the plugin will then use item to populate the row detail panel with the "postTemplate"
|
|
258
|
-
* @param item
|
|
259
|
-
*/
|
|
260
|
-
notifyTemplate(item) {
|
|
261
|
-
if (this._addon) {
|
|
262
|
-
this._addon.onAsyncResponse.notify({ item }, undefined, this);
|
|
263
|
-
}
|
|
264
|
-
}
|
|
265
|
-
/**
|
|
266
|
-
* On Processing, we will notify the plugin with the new item detail once backend server call completes
|
|
267
|
-
* @param item
|
|
268
|
-
*/
|
|
269
|
-
onProcessing(item) {
|
|
270
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
271
|
-
if (item && typeof this._userProcessFn === 'function') {
|
|
272
|
-
let awaitedItemDetail;
|
|
273
|
-
const userProcessFn = this._userProcessFn(item);
|
|
274
|
-
// wait for the "userProcessFn", once resolved we will save it into the "collection"
|
|
275
|
-
const response = yield userProcessFn;
|
|
276
|
-
if (response.hasOwnProperty(this.datasetIdPropName)) {
|
|
277
|
-
awaitedItemDetail = response; // from Promise
|
|
278
|
-
}
|
|
279
|
-
else if (response && response instanceof Observable || response instanceof Promise) {
|
|
280
|
-
awaitedItemDetail = yield castObservableToPromise(this.rxjs, response); // from Angular-http-client
|
|
281
|
-
}
|
|
282
|
-
if (!awaitedItemDetail || !awaitedItemDetail.hasOwnProperty(this.datasetIdPropName)) {
|
|
283
|
-
throw new Error(`[Angular-Slickgrid] could not process the Row Detail, you must make sure that your "process" callback
|
|
284
|
-
(a Promise or an HttpClient call returning an Observable) returns an item object that has an "${this.datasetIdPropName}" property`);
|
|
285
|
-
}
|
|
286
|
-
// notify the plugin with the new item details
|
|
287
|
-
this.notifyTemplate(awaitedItemDetail || {});
|
|
288
|
-
}
|
|
289
|
-
});
|
|
290
|
-
}
|
|
291
|
-
/**
|
|
292
|
-
* Just before the row get expanded or collapsed we will do the following
|
|
293
|
-
* First determine if the row is expanding or collapsing,
|
|
294
|
-
* if it's expanding we will add it to our View Components reference array if we don't already have it
|
|
295
|
-
* or if it's collapsing we will remove it from our View Components reference array
|
|
296
|
-
*/
|
|
297
|
-
onBeforeRowDetailToggle(e, args) {
|
|
298
|
-
// expanding
|
|
299
|
-
if (args && args.item && args.item.__collapsed) {
|
|
300
|
-
// expanding row detail
|
|
301
|
-
const viewInfo = {
|
|
302
|
-
id: args.item[this.datasetIdPropName],
|
|
303
|
-
dataContext: args.item
|
|
304
|
-
};
|
|
305
|
-
const idPropName = this.gridOptions.datasetIdPropertyName || 'id';
|
|
306
|
-
addToArrayWhenNotExists(this._views, viewInfo, idPropName);
|
|
307
|
-
}
|
|
308
|
-
else {
|
|
309
|
-
// collapsing, so dispose of the View/Component
|
|
310
|
-
const foundViewIndex = this._views.findIndex((view) => view.id === args.item[this.datasetIdPropName]);
|
|
311
|
-
if (foundViewIndex >= 0 && this._views.hasOwnProperty(foundViewIndex)) {
|
|
312
|
-
const compRef = this._views[foundViewIndex].componentRef;
|
|
313
|
-
if (compRef) {
|
|
314
|
-
this.appRef.detachView(compRef.hostView);
|
|
315
|
-
compRef.destroy();
|
|
316
|
-
}
|
|
317
|
-
this._views.splice(foundViewIndex, 1);
|
|
318
|
-
}
|
|
319
|
-
}
|
|
320
|
-
}
|
|
321
|
-
/** When Row comes back to Viewport Range, we need to redraw the View */
|
|
322
|
-
onRowBackToViewportRange(e, args) {
|
|
323
|
-
if (args && args.item) {
|
|
324
|
-
this._views.forEach((view) => {
|
|
325
|
-
if (view.id === args.item[this.datasetIdPropName]) {
|
|
326
|
-
this.redrawViewComponent(view);
|
|
327
|
-
}
|
|
328
|
-
});
|
|
329
|
-
}
|
|
330
|
-
}
|
|
331
|
-
}
|
|
332
|
-
RowDetailViewExtension.decorators = [
|
|
333
|
-
{ type: Injectable }
|
|
334
|
-
];
|
|
335
|
-
RowDetailViewExtension.ctorParameters = () => [
|
|
336
|
-
{ type: AngularUtilService },
|
|
337
|
-
{ type: ApplicationRef },
|
|
338
|
-
{ type: EventPubSubService },
|
|
339
|
-
{ type: SharedService },
|
|
340
|
-
{ type: RxJsFacade }
|
|
341
|
-
];
|
|
342
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rowDetailViewExtension.js","sourceRoot":"","sources":["../../../../../../src/app/modules/angular-slickgrid/extensions/rowDetailViewExtension.ts"],"names":[],"mappings":"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","sourcesContent":["import 'slickgrid/plugins/slick.rowdetailview';\r\nimport 'slickgrid/plugins/slick.rowselectionmodel';\r\n\r\nimport { ApplicationRef, ComponentRef, Injectable, Type, ViewContainerRef } from '@angular/core';\r\nimport {\r\n  addToArrayWhenNotExists,\r\n  castObservableToPromise,\r\n  Column,\r\n  RowDetailViewExtension as UniversalRowDetailViewExtension,\r\n  RxJsFacade,\r\n  SharedService,\r\n  SlickEventHandler,\r\n  SlickGrid,\r\n  SlickNamespace,\r\n  SlickRowDetailView,\r\n} from '@slickgrid-universal/common';\r\nimport { EventPubSubService } from '@slickgrid-universal/event-pub-sub';\r\nimport { Observable, Subject, Subscription } from 'rxjs';\r\nimport * as DOMPurify_ from 'dompurify';\r\nconst DOMPurify = (DOMPurify_ as any)['default'] || DOMPurify_; // patch to fix rollup to work\r\n\r\nimport { GridOption, RowDetailView } from '../models/index';\r\nimport { AngularUtilService } from '../services/angularUtil.service';\r\nimport { unsubscribeAllObservables } from '../services/utilities';\r\n\r\n// using external non-typed js libraries\r\ndeclare const Slick: SlickNamespace;\r\n\r\nconst ROW_DETAIL_CONTAINER_PREFIX = 'container_';\r\nconst PRELOAD_CONTAINER_PREFIX = 'container_loading';\r\n\r\nexport interface CreatedView {\r\n  id: string | number;\r\n  dataContext: any;\r\n  componentRef?: ComponentRef<any>;\r\n}\r\n\r\n@Injectable()\r\nexport class RowDetailViewExtension implements UniversalRowDetailViewExtension {\r\n  rowDetailContainer!: ViewContainerRef;\r\n  private _addon: any;\r\n  private _addonOptions!: RowDetailView | null;\r\n  private _eventHandler: SlickEventHandler;\r\n  private _preloadComponent: Type<object> | undefined;\r\n  private _views: CreatedView[] = [];\r\n  private _viewComponent!: Type<object>;\r\n  private _subscriptions: Subscription[] = [];\r\n  private _userProcessFn!: (item: any) => Promise<any> | Observable<any> | Subject<any>;\r\n\r\n  constructor(\r\n    private readonly angularUtilService: AngularUtilService,\r\n    private readonly appRef: ApplicationRef,\r\n    private readonly eventPubSubService: EventPubSubService,\r\n    private readonly sharedService: SharedService,\r\n    private rxjs?: RxJsFacade,\r\n  ) {\r\n    this._eventHandler = new Slick.EventHandler();\r\n  }\r\n\r\n  private get datasetIdPropName(): string {\r\n    return this.gridOptions.datasetIdPropertyName || 'id';\r\n  }\r\n\r\n  get eventHandler(): SlickEventHandler {\r\n    return this._eventHandler;\r\n  }\r\n\r\n  get gridOptions(): GridOption {\r\n    return (this.sharedService?.gridOptions ?? {}) as GridOption;\r\n  }\r\n\r\n  get rowDetailViewOptions(): RowDetailView | undefined {\r\n    return this.gridOptions.rowDetailView;\r\n  }\r\n\r\n  addRxJsResource(rxjs: RxJsFacade) {\r\n    this.rxjs = rxjs;\r\n  }\r\n\r\n  /** Dispose of the RowDetailView Extension */\r\n  dispose() {\r\n    // unsubscribe all SlickGrid events\r\n    this._eventHandler.unsubscribeAll();\r\n\r\n    if (this._addon && this._addon.destroy) {\r\n      this._addon.destroy();\r\n    }\r\n    this._addonOptions = null;\r\n\r\n    // also unsubscribe all RxJS subscriptions\r\n    this._subscriptions = unsubscribeAllObservables(this._subscriptions);\r\n    this.disposeAllViewComponents();\r\n  }\r\n\r\n  /** Dispose of all the opened Row Detail Panels Angular View Components */\r\n  disposeAllViewComponents() {\r\n    this._views.forEach((compRef) => this.disposeViewComponent(compRef));\r\n    this._views = [];\r\n  }\r\n\r\n  /**\r\n   * Create the plugin before the Grid creation, else it will behave oddly.\r\n   * Mostly because the column definitions might change after the grid creation\r\n   */\r\n  create(columnDefinitions: Column[], gridOptions: GridOption): SlickRowDetailView | null {\r\n    if (columnDefinitions && gridOptions) {\r\n      if (!gridOptions.rowDetailView) {\r\n        throw new Error('The Row Detail View requires options to be passed via the \"rowDetailView\" property of the Grid Options');\r\n      }\r\n\r\n      if (gridOptions?.rowDetailView) {\r\n        if (!this._addon) {\r\n          if (typeof gridOptions.rowDetailView.process === 'function') {\r\n            // we need to keep the user \"process\" method and replace it with our own execution method\r\n            // we do this because when we get the item detail, we need to call \"onAsyncResponse.notify\" for the plugin to work\r\n            this._userProcessFn = gridOptions.rowDetailView.process as (item: any) => Observable<any>;                // keep user's process method\r\n            gridOptions.rowDetailView.process = (item) => this.onProcessing(item);  // replace process method & run our internal one\r\n          } else {\r\n            throw new Error('You need to provide a \"process\" function for the Row Detail Extension to work properly');\r\n          }\r\n\r\n          // load the Preload & RowDetail Templates (could be straight HTML or Angular View/ViewModel)\r\n          // when those are Angular View/ViewModel, we need to create View Component & provide the html containers to the Plugin (preTemplate/postTemplate methods)\r\n          if (!gridOptions.rowDetailView.preTemplate) {\r\n            this._preloadComponent = gridOptions?.rowDetailView?.preloadComponent;\r\n            gridOptions.rowDetailView.preTemplate = () => DOMPurify.sanitize(`<div class=\"${PRELOAD_CONTAINER_PREFIX}\"></div>`);\r\n          }\r\n          if (!gridOptions.rowDetailView.postTemplate) {\r\n            this._viewComponent = gridOptions?.rowDetailView?.viewComponent;\r\n            gridOptions.rowDetailView.postTemplate = (itemDetail: any) => DOMPurify.sanitize(`<div class=\"${ROW_DETAIL_CONTAINER_PREFIX}${itemDetail[this.datasetIdPropName]}\"></div>`);\r\n          }\r\n\r\n          // finally register the Row Detail View Plugin\r\n          this._addonOptions = gridOptions.rowDetailView;\r\n          this._addon = new Slick.Plugins.RowDetailView(this._addonOptions);\r\n        }\r\n        const iconColumn: Column = this._addon.getColumnDefinition();\r\n        if (typeof iconColumn === 'object') {\r\n          iconColumn.excludeFromExport = true;\r\n          iconColumn.excludeFromColumnPicker = true;\r\n          iconColumn.excludeFromGridMenu = true;\r\n          iconColumn.excludeFromQuery = true;\r\n          iconColumn.excludeFromHeaderMenu = true;\r\n\r\n          // column index position in the grid\r\n          const columnPosition = gridOptions && gridOptions.rowDetailView && gridOptions.rowDetailView.columnIndexPosition || 0;\r\n          if (columnPosition > 0) {\r\n            columnDefinitions.splice(columnPosition, 0, iconColumn);\r\n          } else {\r\n            columnDefinitions.unshift(iconColumn);\r\n          }\r\n        }\r\n      }\r\n      return this._addon;\r\n    }\r\n    return null;\r\n  }\r\n\r\n  /** Get the instance of the SlickGrid addon (control or plugin). */\r\n  getAddonInstance() {\r\n    return this._addon;\r\n  }\r\n\r\n  register(rowSelectionPlugin?: any) {\r\n    if (this.sharedService?.slickGrid && this.sharedService.gridOptions) {\r\n      // the plugin has to be created BEFORE the grid (else it behaves oddly), but we can only watch grid events AFTER the grid is created\r\n      this.sharedService.slickGrid.registerPlugin(this._addon);\r\n\r\n      // this also requires the Row Selection Model to be registered as well\r\n      if (!rowSelectionPlugin || !this.sharedService.slickGrid.getSelectionModel()) {\r\n        rowSelectionPlugin = new Slick.RowSelectionModel(this.sharedService.gridOptions.rowSelectionOptions || { selectActiveRow: true });\r\n        this.sharedService.slickGrid.setSelectionModel(rowSelectionPlugin);\r\n      }\r\n\r\n      // hook all events\r\n      if (this.sharedService.slickGrid && this.rowDetailViewOptions) {\r\n        if (this.rowDetailViewOptions.onExtensionRegistered) {\r\n          this.rowDetailViewOptions.onExtensionRegistered(this._addon);\r\n        }\r\n        this._eventHandler.subscribe(this._addon.onAsyncResponse, (e: any, args: { item: any; detailView: RowDetailView }) => {\r\n          if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onAsyncResponse === 'function') {\r\n            this.rowDetailViewOptions.onAsyncResponse(e, args);\r\n          }\r\n        });\r\n        this._eventHandler.subscribe(this._addon.onAsyncEndUpdate, (e: any, args: { grid: SlickGrid; item: any; }) => {\r\n          // triggers after backend called \"onAsyncResponse.notify()\"\r\n          this.renderViewModel(args && args.item);\r\n\r\n          if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onAsyncEndUpdate === 'function') {\r\n            this.rowDetailViewOptions.onAsyncEndUpdate(e, args);\r\n          }\r\n        });\r\n        this._eventHandler.subscribe(this._addon.onAfterRowDetailToggle, (e: any, args: { grid: SlickGrid; item: any; expandedRows: number[]; }) => {\r\n          // display preload template & re-render all the other Detail Views after toggling\r\n          // the preload View will eventually go away once the data gets loaded after the \"onAsyncEndUpdate\" event\r\n          this.renderPreloadView();\r\n          this.renderAllViewComponents();\r\n\r\n          if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onAfterRowDetailToggle === 'function') {\r\n            this.rowDetailViewOptions.onAfterRowDetailToggle(e, args);\r\n          }\r\n        });\r\n        this._eventHandler.subscribe(this._addon.onBeforeRowDetailToggle, (e: any, args: { grid: SlickGrid; item: any; }) => {\r\n          // before toggling row detail, we need to create View Component if it doesn't exist\r\n          this.onBeforeRowDetailToggle(e, args);\r\n\r\n          if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onBeforeRowDetailToggle === 'function') {\r\n            this.rowDetailViewOptions.onBeforeRowDetailToggle(e, args);\r\n          }\r\n        });\r\n        this._eventHandler.subscribe(this._addon.onRowBackToViewportRange, (e: any, args: { grid: SlickGrid; item: any; rowId: number; rowIndex: number; expandedRows: any[]; rowIdsOutOfViewport: number[]; }) => {\r\n          // when row is back to viewport range, we will re-render the View Component(s)\r\n          this.onRowBackToViewportRange(e, args);\r\n\r\n          if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onRowBackToViewportRange === 'function') {\r\n            this.rowDetailViewOptions.onRowBackToViewportRange(e, args);\r\n          }\r\n        });\r\n        this._eventHandler.subscribe(this._addon.onRowOutOfViewportRange, (e: any, args: { grid: SlickGrid; item: any; rowId: number; rowIndex: number; expandedRows: any[]; rowIdsOutOfViewport: number[]; }) => {\r\n          if (this.rowDetailViewOptions && typeof this.rowDetailViewOptions.onRowOutOfViewportRange === 'function') {\r\n            this.rowDetailViewOptions.onRowOutOfViewportRange(e, args);\r\n          }\r\n        });\r\n\r\n        // --\r\n        // hook some events needed by the Plugin itself\r\n\r\n        // we need to redraw the open detail views if we change column position (column reorder)\r\n        this._eventHandler.subscribe(this.sharedService.slickGrid.onColumnsReordered, this.redrawAllViewComponents.bind(this));\r\n\r\n        // on row selection changed, we also need to redraw\r\n        if (this.gridOptions.enableRowSelection || this.gridOptions.enableCheckboxSelector) {\r\n          this._eventHandler.subscribe(this.sharedService.slickGrid.onSelectedRowsChanged, this.redrawAllViewComponents.bind(this));\r\n        }\r\n\r\n        // on sort, all row detail are collapsed so we can dispose of all the Views as well\r\n        this._eventHandler.subscribe(this.sharedService.slickGrid.onSort, this.disposeAllViewComponents.bind(this));\r\n\r\n        // on filter changed, we need to re-render all Views\r\n        this._subscriptions.push(\r\n          this.eventPubSubService.subscribe('onFilterChanged', this.redrawAllViewComponents.bind(this))\r\n        );\r\n      }\r\n      return this._addon;\r\n    }\r\n    return null;\r\n  }\r\n\r\n  /** Redraw (re-render) all the expanded row detail View Components */\r\n  redrawAllViewComponents() {\r\n    this._views.forEach((compRef) => {\r\n      this.redrawViewComponent(compRef);\r\n    });\r\n  }\r\n\r\n  /** Render all the expanded row detail View Components */\r\n  renderAllViewComponents() {\r\n    this._views.forEach((view) => {\r\n      if (view && view.dataContext) {\r\n        this.renderViewModel(view.dataContext);\r\n      }\r\n    });\r\n  }\r\n\r\n  /** Redraw the necessary View Component */\r\n  redrawViewComponent(createdView: CreatedView) {\r\n    const containerElements = document.getElementsByClassName(`${ROW_DETAIL_CONTAINER_PREFIX}${createdView.id}`);\r\n    if (containerElements && containerElements.length >= 0) {\r\n      this.renderViewModel(createdView.dataContext);\r\n    }\r\n  }\r\n\r\n  /** Render (or re-render) the View Component (Row Detail) */\r\n  renderPreloadView() {\r\n    const containerElements = document.getElementsByClassName(`${PRELOAD_CONTAINER_PREFIX}`);\r\n    if (containerElements && containerElements.length >= 0) {\r\n      this.angularUtilService.createAngularComponentAppendToDom(this._preloadComponent, containerElements[containerElements.length - 1], true);\r\n    }\r\n  }\r\n\r\n  /** Render (or re-render) the View Component (Row Detail) */\r\n  renderViewModel(item: any): CreatedView | undefined {\r\n    const containerElements = document.getElementsByClassName(`${ROW_DETAIL_CONTAINER_PREFIX}${item[this.datasetIdPropName]}`);\r\n    if (containerElements && containerElements.length > 0) {\r\n      const componentOutput = this.angularUtilService.createAngularComponentAppendToDom(this._viewComponent, containerElements[containerElements.length - 1], true);\r\n      if (componentOutput && componentOutput.componentRef && componentOutput.componentRef.instance) {\r\n        // pass a few properties to the Row Detail template component\r\n        Object.assign(componentOutput.componentRef.instance, {\r\n          model: item,\r\n          addon: this._addon,\r\n          grid: this.sharedService.slickGrid,\r\n          dataView: this.sharedService.dataView,\r\n          parent: this.rowDetailViewOptions && this.rowDetailViewOptions.parent,\r\n        });\r\n\r\n        const viewObj = this._views.find(obj => obj.id === item[this.datasetIdPropName]);\r\n        if (viewObj) {\r\n          viewObj.componentRef = componentOutput.componentRef;\r\n        }\r\n        return viewObj;\r\n      }\r\n    }\r\n    return undefined;\r\n  }\r\n\r\n  // --\r\n  // private functions\r\n  // ------------------\r\n\r\n  private disposeViewComponent(expandedView: CreatedView) {\r\n    const compRef = expandedView?.componentRef;\r\n    if (compRef) {\r\n      this.appRef.detachView(compRef.hostView);\r\n      if (compRef?.destroy) {\r\n        compRef.destroy();\r\n      }\r\n      return expandedView;\r\n    }\r\n    return null;\r\n  }\r\n\r\n  /**\r\n   * notify the onAsyncResponse with the \"args.item\" (required property)\r\n   * the plugin will then use item to populate the row detail panel with the \"postTemplate\"\r\n   * @param item\r\n   */\r\n  private notifyTemplate(item: any) {\r\n    if (this._addon) {\r\n      this._addon.onAsyncResponse.notify({ item }, undefined, this);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * On Processing, we will notify the plugin with the new item detail once backend server call completes\r\n   * @param item\r\n   */\r\n  private async onProcessing(item: any) {\r\n    if (item && typeof this._userProcessFn === 'function') {\r\n      let awaitedItemDetail: any;\r\n      const userProcessFn = this._userProcessFn(item);\r\n\r\n      // wait for the \"userProcessFn\", once resolved we will save it into the \"collection\"\r\n      const response: any | any[] = await userProcessFn;\r\n\r\n      if (response.hasOwnProperty(this.datasetIdPropName)) {\r\n        awaitedItemDetail = response; // from Promise\r\n      } else if (response && response instanceof Observable || response instanceof Promise) {\r\n        awaitedItemDetail = await castObservableToPromise(this.rxjs as RxJsFacade, response); // from Angular-http-client\r\n      }\r\n\r\n      if (!awaitedItemDetail || !awaitedItemDetail.hasOwnProperty(this.datasetIdPropName)) {\r\n        throw new Error(`[Angular-Slickgrid] could not process the Row Detail, you must make sure that your \"process\" callback\r\n          (a Promise or an HttpClient call returning an Observable) returns an item object that has an \"${this.datasetIdPropName}\" property`);\r\n      }\r\n\r\n      // notify the plugin with the new item details\r\n      this.notifyTemplate(awaitedItemDetail || {});\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Just before the row get expanded or collapsed we will do the following\r\n   * First determine if the row is expanding or collapsing,\r\n   * if it's expanding we will add it to our View Components reference array if we don't already have it\r\n   * or if it's collapsing we will remove it from our View Components reference array\r\n   */\r\n  private onBeforeRowDetailToggle(e: Event, args: { grid: SlickGrid; item: any; }) {\r\n    // expanding\r\n    if (args && args.item && args.item.__collapsed) {\r\n      // expanding row detail\r\n      const viewInfo: CreatedView = {\r\n        id: args.item[this.datasetIdPropName],\r\n        dataContext: args.item\r\n      };\r\n      const idPropName = this.gridOptions.datasetIdPropertyName || 'id';\r\n      addToArrayWhenNotExists(this._views, viewInfo, idPropName);\r\n    } else {\r\n      // collapsing, so dispose of the View/Component\r\n      const foundViewIndex = this._views.findIndex((view: CreatedView) => view.id === args.item[this.datasetIdPropName]);\r\n      if (foundViewIndex >= 0 && this._views.hasOwnProperty(foundViewIndex)) {\r\n        const compRef = this._views[foundViewIndex].componentRef;\r\n        if (compRef) {\r\n          this.appRef.detachView(compRef.hostView);\r\n          compRef.destroy();\r\n        }\r\n        this._views.splice(foundViewIndex, 1);\r\n      }\r\n    }\r\n  }\r\n\r\n  /** When Row comes back to Viewport Range, we need to redraw the View */\r\n  private onRowBackToViewportRange(e: Event, args: { grid: SlickGrid; item: any; rowId: number; rowIndex: number; expandedRows: any[]; rowIdsOutOfViewport: number[]; }) {\r\n    if (args && args.item) {\r\n      this._views.forEach((view) => {\r\n        if (view.id === args.item[this.datasetIdPropName]) {\r\n          this.redrawViewComponent(view);\r\n        }\r\n      });\r\n    }\r\n  }\r\n}\r\n"]}
|