angular-slickgrid 3.2.0 → 4.0.0
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 +26 -28
- package/angular-slickgrid.d.ts +1 -3
- package/app/modules/angular-slickgrid/components/angular-slickgrid.component.d.ts +8 -4
- 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 +301 -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} +247 -279
- package/fesm2015/angular-slickgrid.mjs.map +1 -0
- package/fesm2020/angular-slickgrid.mjs +2065 -0
- package/fesm2020/angular-slickgrid.mjs.map +1 -0
- package/package.json +41 -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
|
@@ -0,0 +1,243 @@
|
|
|
1
|
+
import { DelimiterType, EventNamingStyle, FileType, Filters, OperatorType } from '@slickgrid-universal/common';
|
|
2
|
+
/** Global Grid Options Defaults */
|
|
3
|
+
export const GlobalGridOptions = {
|
|
4
|
+
alwaysShowVerticalScroll: true,
|
|
5
|
+
autoEdit: false,
|
|
6
|
+
asyncEditorLoading: false,
|
|
7
|
+
autoFitColumnsOnFirstLoad: true,
|
|
8
|
+
autoResize: {
|
|
9
|
+
applyResizeToContainer: true,
|
|
10
|
+
calculateAvailableSizeBy: 'window',
|
|
11
|
+
bottomPadding: 20,
|
|
12
|
+
minHeight: 180,
|
|
13
|
+
minWidth: 300,
|
|
14
|
+
rightPadding: 0
|
|
15
|
+
},
|
|
16
|
+
cellHighlightCssClass: 'slick-cell-modified',
|
|
17
|
+
checkboxSelector: {
|
|
18
|
+
cssClass: 'slick-cell-checkboxsel'
|
|
19
|
+
},
|
|
20
|
+
columnPicker: {
|
|
21
|
+
fadeSpeed: 0,
|
|
22
|
+
hideForceFitButton: false,
|
|
23
|
+
hideSyncResizeButton: true,
|
|
24
|
+
headerColumnValueExtractor: pickerHeaderColumnValueExtractor
|
|
25
|
+
},
|
|
26
|
+
cellMenu: {
|
|
27
|
+
autoAdjustDrop: true,
|
|
28
|
+
autoAlignSide: true,
|
|
29
|
+
hideCloseButton: true,
|
|
30
|
+
hideCommandSection: false,
|
|
31
|
+
hideOptionSection: false,
|
|
32
|
+
},
|
|
33
|
+
contextMenu: {
|
|
34
|
+
autoAdjustDrop: true,
|
|
35
|
+
autoAlignSide: true,
|
|
36
|
+
hideCloseButton: true,
|
|
37
|
+
hideClearAllGrouping: false,
|
|
38
|
+
hideCollapseAllGroups: false,
|
|
39
|
+
hideCommandSection: false,
|
|
40
|
+
hideCopyCellValueCommand: false,
|
|
41
|
+
hideExpandAllGroups: false,
|
|
42
|
+
hideExportCsvCommand: false,
|
|
43
|
+
hideExportExcelCommand: false,
|
|
44
|
+
hideExportTextDelimitedCommand: true,
|
|
45
|
+
hideMenuOnScroll: true,
|
|
46
|
+
hideOptionSection: false,
|
|
47
|
+
iconCopyCellValueCommand: 'fa fa-clone',
|
|
48
|
+
iconExportCsvCommand: 'fa fa-download',
|
|
49
|
+
iconExportExcelCommand: 'fa fa-file-excel-o text-success',
|
|
50
|
+
iconExportTextDelimitedCommand: 'fa fa-download',
|
|
51
|
+
},
|
|
52
|
+
customFooterOptions: {
|
|
53
|
+
dateFormat: 'YYYY-MM-DD, hh:mm a',
|
|
54
|
+
hideRowSelectionCount: false,
|
|
55
|
+
hideTotalItemCount: false,
|
|
56
|
+
hideLastUpdateTimestamp: true,
|
|
57
|
+
footerHeight: 25,
|
|
58
|
+
leftContainerClass: 'col-xs-12 col-sm-5',
|
|
59
|
+
rightContainerClass: 'col-xs-6 col-sm-7',
|
|
60
|
+
metricSeparator: '|',
|
|
61
|
+
metricTexts: {
|
|
62
|
+
items: 'items',
|
|
63
|
+
itemsKey: 'ITEMS',
|
|
64
|
+
itemsSelected: 'items selected',
|
|
65
|
+
itemsSelectedKey: 'ITEMS_SELECTED',
|
|
66
|
+
of: 'of',
|
|
67
|
+
ofKey: 'OF',
|
|
68
|
+
}
|
|
69
|
+
},
|
|
70
|
+
dataView: {
|
|
71
|
+
syncGridSelection: true,
|
|
72
|
+
syncGridSelectionWithBackendService: false, // but disable it when using backend services
|
|
73
|
+
},
|
|
74
|
+
datasetIdPropertyName: 'id',
|
|
75
|
+
defaultFilter: Filters.input,
|
|
76
|
+
defaultBackendServiceFilterTypingDebounce: 500,
|
|
77
|
+
defaultColumnSortFieldId: 'id',
|
|
78
|
+
defaultFilterPlaceholder: '🔎︎',
|
|
79
|
+
defaultFilterRangeOperator: OperatorType.rangeInclusive,
|
|
80
|
+
editable: false,
|
|
81
|
+
enableAutoResize: true,
|
|
82
|
+
enableAutoSizeColumns: true,
|
|
83
|
+
enableCellNavigation: false,
|
|
84
|
+
enableColumnPicker: true,
|
|
85
|
+
enableColumnReorder: true,
|
|
86
|
+
enableColumnResizeOnDoubleClick: true,
|
|
87
|
+
enableContextMenu: true,
|
|
88
|
+
enableExcelExport: true,
|
|
89
|
+
enableExport: false,
|
|
90
|
+
enableFilterTrimWhiteSpace: false,
|
|
91
|
+
enableGridMenu: true,
|
|
92
|
+
enableHeaderMenu: true,
|
|
93
|
+
enableEmptyDataWarningMessage: true,
|
|
94
|
+
emptyDataWarning: {
|
|
95
|
+
className: 'slick-empty-data-warning',
|
|
96
|
+
message: 'No data to display.',
|
|
97
|
+
messageKey: 'EMPTY_DATA_WARNING_MESSAGE',
|
|
98
|
+
hideFrozenLeftWarning: false,
|
|
99
|
+
hideFrozenRightWarning: false,
|
|
100
|
+
leftViewportMarginLeft: '40%',
|
|
101
|
+
rightViewportMarginLeft: '40%',
|
|
102
|
+
frozenLeftViewportMarginLeft: '0px',
|
|
103
|
+
frozenRightViewportMarginLeft: '40%',
|
|
104
|
+
},
|
|
105
|
+
enableMouseHoverHighlightRow: true,
|
|
106
|
+
enableSorting: true,
|
|
107
|
+
enableTextSelectionOnCells: true,
|
|
108
|
+
eventNamingStyle: EventNamingStyle.camelCase,
|
|
109
|
+
explicitInitialization: true,
|
|
110
|
+
excelExportOptions: {
|
|
111
|
+
addGroupIndentation: true,
|
|
112
|
+
exportWithFormatter: false,
|
|
113
|
+
filename: 'export',
|
|
114
|
+
format: FileType.xlsx,
|
|
115
|
+
groupingColumnHeaderTitle: 'Group By',
|
|
116
|
+
groupCollapsedSymbol: '⮞',
|
|
117
|
+
groupExpandedSymbol: '⮟',
|
|
118
|
+
groupingAggregatorRowText: '',
|
|
119
|
+
sanitizeDataExport: false,
|
|
120
|
+
},
|
|
121
|
+
exportOptions: {
|
|
122
|
+
delimiter: DelimiterType.comma,
|
|
123
|
+
exportWithFormatter: false,
|
|
124
|
+
filename: 'export',
|
|
125
|
+
format: FileType.csv,
|
|
126
|
+
groupingColumnHeaderTitle: 'Group By',
|
|
127
|
+
groupingAggregatorRowText: '',
|
|
128
|
+
sanitizeDataExport: false,
|
|
129
|
+
useUtf8WithBom: true
|
|
130
|
+
},
|
|
131
|
+
filterTypingDebounce: 0,
|
|
132
|
+
forceFitColumns: false,
|
|
133
|
+
frozenHeaderWidthCalcDifferential: 0,
|
|
134
|
+
gridMenu: {
|
|
135
|
+
dropSide: 'left',
|
|
136
|
+
commandLabels: {
|
|
137
|
+
clearAllFiltersCommandKey: 'CLEAR_ALL_FILTERS',
|
|
138
|
+
clearAllSortingCommandKey: 'CLEAR_ALL_SORTING',
|
|
139
|
+
clearFrozenColumnsCommandKey: 'CLEAR_PINNING',
|
|
140
|
+
exportCsvCommandKey: 'EXPORT_TO_CSV',
|
|
141
|
+
exportExcelCommandKey: 'EXPORT_TO_EXCEL',
|
|
142
|
+
exportTextDelimitedCommandKey: 'EXPORT_TO_TAB_DELIMITED',
|
|
143
|
+
refreshDatasetCommandKey: 'REFRESH_DATASET',
|
|
144
|
+
toggleFilterCommandKey: 'TOGGLE_FILTER_ROW',
|
|
145
|
+
togglePreHeaderCommandKey: 'TOGGLE_PRE_HEADER_ROW',
|
|
146
|
+
},
|
|
147
|
+
hideClearAllFiltersCommand: false,
|
|
148
|
+
hideClearAllSortingCommand: false,
|
|
149
|
+
hideClearFrozenColumnsCommand: true,
|
|
150
|
+
hideExportCsvCommand: false,
|
|
151
|
+
hideExportExcelCommand: false,
|
|
152
|
+
hideExportTextDelimitedCommand: true,
|
|
153
|
+
hideForceFitButton: false,
|
|
154
|
+
hideRefreshDatasetCommand: false,
|
|
155
|
+
hideSyncResizeButton: true,
|
|
156
|
+
hideToggleFilterCommand: false,
|
|
157
|
+
hideTogglePreHeaderCommand: false,
|
|
158
|
+
iconCssClass: 'fa fa-bars',
|
|
159
|
+
iconClearAllFiltersCommand: 'fa fa-filter text-danger',
|
|
160
|
+
iconClearAllSortingCommand: 'fa fa-unsorted text-danger',
|
|
161
|
+
iconClearFrozenColumnsCommand: 'fa fa-times',
|
|
162
|
+
iconExportCsvCommand: 'fa fa-download',
|
|
163
|
+
iconExportExcelCommand: 'fa fa-file-excel-o text-success',
|
|
164
|
+
iconExportTextDelimitedCommand: 'fa fa-download',
|
|
165
|
+
iconRefreshDatasetCommand: 'fa fa-refresh',
|
|
166
|
+
iconToggleFilterCommand: 'fa fa-random',
|
|
167
|
+
iconTogglePreHeaderCommand: 'fa fa-random',
|
|
168
|
+
menuWidth: 16,
|
|
169
|
+
resizeOnShowHeaderRow: true,
|
|
170
|
+
headerColumnValueExtractor: pickerHeaderColumnValueExtractor
|
|
171
|
+
},
|
|
172
|
+
headerMenu: {
|
|
173
|
+
autoAlign: true,
|
|
174
|
+
autoAlignOffset: 12,
|
|
175
|
+
minWidth: 140,
|
|
176
|
+
iconClearFilterCommand: 'fa fa-filter text-danger',
|
|
177
|
+
iconClearSortCommand: 'fa fa-unsorted',
|
|
178
|
+
iconFreezeColumns: 'fa fa-thumb-tack',
|
|
179
|
+
iconSortAscCommand: 'fa fa-sort-amount-asc',
|
|
180
|
+
iconSortDescCommand: 'fa fa-sort-amount-desc',
|
|
181
|
+
iconColumnHideCommand: 'fa fa-times',
|
|
182
|
+
iconColumnResizeByContentCommand: 'fa fa-arrows-h',
|
|
183
|
+
hideColumnResizeByContentCommand: false,
|
|
184
|
+
hideColumnHideCommand: false,
|
|
185
|
+
hideClearFilterCommand: false,
|
|
186
|
+
hideClearSortCommand: false,
|
|
187
|
+
hideFreezeColumnsCommand: true,
|
|
188
|
+
hideSortCommands: false
|
|
189
|
+
},
|
|
190
|
+
headerRowHeight: 35,
|
|
191
|
+
multiColumnSort: true,
|
|
192
|
+
numberedMultiColumnSort: true,
|
|
193
|
+
tristateMultiColumnSort: false,
|
|
194
|
+
sortColNumberInSeparateSpan: true,
|
|
195
|
+
suppressActiveCellChangeOnEdit: true,
|
|
196
|
+
pagination: {
|
|
197
|
+
pageSizes: [10, 15, 20, 25, 30, 40, 50, 75, 100],
|
|
198
|
+
pageSize: 25,
|
|
199
|
+
totalItems: 0
|
|
200
|
+
},
|
|
201
|
+
// technically speaking the Row Detail requires the process & viewComponent but we'll ignore it just to set certain options
|
|
202
|
+
rowDetailView: {
|
|
203
|
+
collapseAllOnSort: true,
|
|
204
|
+
cssClass: 'detail-view-toggle',
|
|
205
|
+
panelRows: 1,
|
|
206
|
+
keyPrefix: '__',
|
|
207
|
+
useRowClick: false,
|
|
208
|
+
useSimpleViewportCalc: true,
|
|
209
|
+
saveDetailViewOnScroll: false,
|
|
210
|
+
},
|
|
211
|
+
rowHeight: 35,
|
|
212
|
+
topPanelHeight: 35,
|
|
213
|
+
translationNamespaceSeparator: ':',
|
|
214
|
+
resetFilterSearchValueAfterOnBeforeCancellation: true,
|
|
215
|
+
resizeByContentOnlyOnFirstLoad: true,
|
|
216
|
+
resizeByContentOptions: {
|
|
217
|
+
alwaysRecalculateColumnWidth: false,
|
|
218
|
+
cellCharWidthInPx: 7.8,
|
|
219
|
+
cellPaddingWidthInPx: 14,
|
|
220
|
+
defaultRatioForStringType: 0.88,
|
|
221
|
+
formatterPaddingWidthInPx: 0,
|
|
222
|
+
maxItemToInspectCellContentWidth: 1000,
|
|
223
|
+
maxItemToInspectSingleColumnWidthByContent: 5000,
|
|
224
|
+
widthToRemoveFromExceededWidthReadjustment: 50,
|
|
225
|
+
},
|
|
226
|
+
treeDataOptions: {
|
|
227
|
+
exportIndentMarginLeft: 5,
|
|
228
|
+
exportIndentationLeadingChar: '͏͏͏͏͏͏͏͏͏·',
|
|
229
|
+
}
|
|
230
|
+
};
|
|
231
|
+
/**
|
|
232
|
+
* Value Extractor for both ColumnPicker & GridMenu Picker
|
|
233
|
+
* when using Column Header Grouping, we'll prefix the column group title
|
|
234
|
+
* else we'll simply return the column name title
|
|
235
|
+
*/
|
|
236
|
+
function pickerHeaderColumnValueExtractor(column) {
|
|
237
|
+
const headerGroup = column && column.columnGroup || '';
|
|
238
|
+
if (headerGroup) {
|
|
239
|
+
return headerGroup + ' - ' + column.name;
|
|
240
|
+
}
|
|
241
|
+
return column && column.name || '';
|
|
242
|
+
}
|
|
243
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"global-grid-options.js","sourceRoot":"","sources":["../../../../../src/app/modules/angular-slickgrid/global-grid-options.ts"],"names":[],"mappings":"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","sourcesContent":["import { Column, DelimiterType, EventNamingStyle, FileType, Filters, GridAutosizeColsMode, OperatorType, TreeDataOption } from '@slickgrid-universal/common';\r\nimport { GridOption, RowDetailView } from './models/index';\r\n\r\n/** Global Grid Options Defaults */\r\nexport const GlobalGridOptions: Partial<GridOption> = {\r\n  alwaysShowVerticalScroll: true,\r\n  autoEdit: false,\r\n  asyncEditorLoading: false,\r\n  autoFitColumnsOnFirstLoad: true,\r\n  autoResize: {\r\n    applyResizeToContainer: true,\r\n    calculateAvailableSizeBy: 'window',\r\n    bottomPadding: 20,\r\n    minHeight: 180,\r\n    minWidth: 300,\r\n    rightPadding: 0\r\n  },\r\n  cellHighlightCssClass: 'slick-cell-modified',\r\n  checkboxSelector: {\r\n    cssClass: 'slick-cell-checkboxsel'\r\n  },\r\n  columnPicker: {\r\n    fadeSpeed: 0,\r\n    hideForceFitButton: false,\r\n    hideSyncResizeButton: true,\r\n    headerColumnValueExtractor: pickerHeaderColumnValueExtractor\r\n  },\r\n  cellMenu: {\r\n    autoAdjustDrop: true,\r\n    autoAlignSide: true,\r\n    hideCloseButton: true,\r\n    hideCommandSection: false,\r\n    hideOptionSection: false,\r\n  },\r\n  contextMenu: {\r\n    autoAdjustDrop: true,\r\n    autoAlignSide: true,\r\n    hideCloseButton: true,\r\n    hideClearAllGrouping: false,\r\n    hideCollapseAllGroups: false,\r\n    hideCommandSection: false,\r\n    hideCopyCellValueCommand: false,\r\n    hideExpandAllGroups: false,\r\n    hideExportCsvCommand: false,\r\n    hideExportExcelCommand: false,\r\n    hideExportTextDelimitedCommand: true,\r\n    hideMenuOnScroll: true,\r\n    hideOptionSection: false,\r\n    iconCopyCellValueCommand: 'fa fa-clone',\r\n    iconExportCsvCommand: 'fa fa-download',\r\n    iconExportExcelCommand: 'fa fa-file-excel-o text-success',\r\n    iconExportTextDelimitedCommand: 'fa fa-download',\r\n  },\r\n  customFooterOptions: {\r\n    dateFormat: 'YYYY-MM-DD, hh:mm a',\r\n    hideRowSelectionCount: false,\r\n    hideTotalItemCount: false,\r\n    hideLastUpdateTimestamp: true,\r\n    footerHeight: 25,\r\n    leftContainerClass: 'col-xs-12 col-sm-5',\r\n    rightContainerClass: 'col-xs-6 col-sm-7',\r\n    metricSeparator: '|',\r\n    metricTexts: {\r\n      items: 'items',\r\n      itemsKey: 'ITEMS',\r\n      itemsSelected: 'items selected',\r\n      itemsSelectedKey: 'ITEMS_SELECTED',\r\n      of: 'of',\r\n      ofKey: 'OF',\r\n    }\r\n  },\r\n  dataView: {\r\n    syncGridSelection: true, // when enabled, this will preserve the row selection even after filtering/sorting/grouping\r\n    syncGridSelectionWithBackendService: false, // but disable it when using backend services\r\n  },\r\n  datasetIdPropertyName: 'id',\r\n  defaultFilter: Filters.input,\r\n  defaultBackendServiceFilterTypingDebounce: 500,\r\n  defaultColumnSortFieldId: 'id',\r\n  defaultFilterPlaceholder: '🔎︎',\r\n  defaultFilterRangeOperator: OperatorType.rangeInclusive,\r\n  editable: false,\r\n  enableAutoResize: true,\r\n  enableAutoSizeColumns: true,\r\n  enableCellNavigation: false,\r\n  enableColumnPicker: true,\r\n  enableColumnReorder: true,\r\n  enableColumnResizeOnDoubleClick: true,\r\n  enableContextMenu: true,\r\n  enableExcelExport: true, // Excel Export is the new default,\r\n  enableExport: false, // CSV/Text with Tab Delimited\r\n  enableFilterTrimWhiteSpace: false, // do we want to trim white spaces on all Filters?\r\n  enableGridMenu: true,\r\n  enableHeaderMenu: true,\r\n  enableEmptyDataWarningMessage: true,\r\n  emptyDataWarning: {\r\n    className: 'slick-empty-data-warning',\r\n    message: 'No data to display.',\r\n    messageKey: 'EMPTY_DATA_WARNING_MESSAGE',\r\n    hideFrozenLeftWarning: false,\r\n    hideFrozenRightWarning: false,\r\n    leftViewportMarginLeft: '40%',\r\n    rightViewportMarginLeft: '40%',\r\n    frozenLeftViewportMarginLeft: '0px',\r\n    frozenRightViewportMarginLeft: '40%',\r\n  },\r\n  enableMouseHoverHighlightRow: true,\r\n  enableSorting: true,\r\n  enableTextSelectionOnCells: true,\r\n  eventNamingStyle: EventNamingStyle.camelCase,\r\n  explicitInitialization: true,\r\n  excelExportOptions: {\r\n    addGroupIndentation: true,\r\n    exportWithFormatter: false,\r\n    filename: 'export',\r\n    format: FileType.xlsx,\r\n    groupingColumnHeaderTitle: 'Group By',\r\n    groupCollapsedSymbol: '⮞',\r\n    groupExpandedSymbol: '⮟',\r\n    groupingAggregatorRowText: '',\r\n    sanitizeDataExport: false,\r\n  },\r\n  exportOptions: {\r\n    delimiter: DelimiterType.comma,\r\n    exportWithFormatter: false,\r\n    filename: 'export',\r\n    format: FileType.csv,\r\n    groupingColumnHeaderTitle: 'Group By',\r\n    groupingAggregatorRowText: '',\r\n    sanitizeDataExport: false,\r\n    useUtf8WithBom: true\r\n  },\r\n  filterTypingDebounce: 0,\r\n  forceFitColumns: false,\r\n  frozenHeaderWidthCalcDifferential: 0,\r\n  gridMenu: {\r\n    dropSide: 'left',\r\n    commandLabels: {\r\n      clearAllFiltersCommandKey: 'CLEAR_ALL_FILTERS',\r\n      clearAllSortingCommandKey: 'CLEAR_ALL_SORTING',\r\n      clearFrozenColumnsCommandKey: 'CLEAR_PINNING',\r\n      exportCsvCommandKey: 'EXPORT_TO_CSV',\r\n      exportExcelCommandKey: 'EXPORT_TO_EXCEL',\r\n      exportTextDelimitedCommandKey: 'EXPORT_TO_TAB_DELIMITED',\r\n      refreshDatasetCommandKey: 'REFRESH_DATASET',\r\n      toggleFilterCommandKey: 'TOGGLE_FILTER_ROW',\r\n      togglePreHeaderCommandKey: 'TOGGLE_PRE_HEADER_ROW',\r\n    },\r\n    hideClearAllFiltersCommand: false,\r\n    hideClearAllSortingCommand: false,\r\n    hideClearFrozenColumnsCommand: true, // opt-in command\r\n    hideExportCsvCommand: false,\r\n    hideExportExcelCommand: false,\r\n    hideExportTextDelimitedCommand: true,\r\n    hideForceFitButton: false,\r\n    hideRefreshDatasetCommand: false,\r\n    hideSyncResizeButton: true,\r\n    hideToggleFilterCommand: false,\r\n    hideTogglePreHeaderCommand: false,\r\n    iconCssClass: 'fa fa-bars',\r\n    iconClearAllFiltersCommand: 'fa fa-filter text-danger',\r\n    iconClearAllSortingCommand: 'fa fa-unsorted text-danger',\r\n    iconClearFrozenColumnsCommand: 'fa fa-times',\r\n    iconExportCsvCommand: 'fa fa-download',\r\n    iconExportExcelCommand: 'fa fa-file-excel-o text-success',\r\n    iconExportTextDelimitedCommand: 'fa fa-download',\r\n    iconRefreshDatasetCommand: 'fa fa-refresh',\r\n    iconToggleFilterCommand: 'fa fa-random',\r\n    iconTogglePreHeaderCommand: 'fa fa-random',\r\n    menuWidth: 16,\r\n    resizeOnShowHeaderRow: true,\r\n    headerColumnValueExtractor: pickerHeaderColumnValueExtractor\r\n  },\r\n  headerMenu: {\r\n    autoAlign: true,\r\n    autoAlignOffset: 12,\r\n    minWidth: 140,\r\n    iconClearFilterCommand: 'fa fa-filter text-danger',\r\n    iconClearSortCommand: 'fa fa-unsorted',\r\n    iconFreezeColumns: 'fa fa-thumb-tack',\r\n    iconSortAscCommand: 'fa fa-sort-amount-asc',\r\n    iconSortDescCommand: 'fa fa-sort-amount-desc',\r\n    iconColumnHideCommand: 'fa fa-times',\r\n    iconColumnResizeByContentCommand: 'fa fa-arrows-h',\r\n    hideColumnResizeByContentCommand: false,\r\n    hideColumnHideCommand: false,\r\n    hideClearFilterCommand: false,\r\n    hideClearSortCommand: false,\r\n    hideFreezeColumnsCommand: true, // opt-in command\r\n    hideSortCommands: false\r\n  },\r\n  headerRowHeight: 35,\r\n  multiColumnSort: true,\r\n  numberedMultiColumnSort: true,\r\n  tristateMultiColumnSort: false,\r\n  sortColNumberInSeparateSpan: true,\r\n  suppressActiveCellChangeOnEdit: true,\r\n  pagination: {\r\n    pageSizes: [10, 15, 20, 25, 30, 40, 50, 75, 100],\r\n    pageSize: 25,\r\n    totalItems: 0\r\n  },\r\n  // technically speaking the Row Detail requires the process & viewComponent but we'll ignore it just to set certain options\r\n  rowDetailView: {\r\n    collapseAllOnSort: true,\r\n    cssClass: 'detail-view-toggle',\r\n    panelRows: 1,\r\n    keyPrefix: '__',\r\n    useRowClick: false,\r\n    useSimpleViewportCalc: true,\r\n    saveDetailViewOnScroll: false,\r\n  } as RowDetailView,\r\n  rowHeight: 35,\r\n  topPanelHeight: 35,\r\n  translationNamespaceSeparator: ':',\r\n  resetFilterSearchValueAfterOnBeforeCancellation: true,\r\n  resizeByContentOnlyOnFirstLoad: true,\r\n  resizeByContentOptions: {\r\n    alwaysRecalculateColumnWidth: false,\r\n    cellCharWidthInPx: 7.8,\r\n    cellPaddingWidthInPx: 14,\r\n    defaultRatioForStringType: 0.88,\r\n    formatterPaddingWidthInPx: 0,\r\n    maxItemToInspectCellContentWidth: 1000,\r\n    maxItemToInspectSingleColumnWidthByContent: 5000,\r\n    widthToRemoveFromExceededWidthReadjustment: 50,\r\n  },\r\n  treeDataOptions: {\r\n    exportIndentMarginLeft: 5,\r\n    exportIndentationLeadingChar: '͏͏͏͏͏͏͏͏͏·',\r\n  } as unknown as TreeDataOption\r\n};\r\n\r\n/**\r\n * Value Extractor for both ColumnPicker & GridMenu Picker\r\n * when using Column Header Grouping, we'll prefix the column group title\r\n * else we'll simply return the column name title\r\n */\r\nfunction pickerHeaderColumnValueExtractor(column: Column) {\r\n  const headerGroup = column && column.columnGroup || '';\r\n  if (headerGroup) {\r\n    return headerGroup + ' - ' + column.name;\r\n  }\r\n  return column && column.name || '';\r\n}\r\n"]}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
export * from '@slickgrid-universal/common';
|
|
2
2
|
export { AngularUtilService, BsDropDownService, unsubscribeAllObservables } from './services/index';
|
|
3
|
-
export {
|
|
3
|
+
export { SlickRowDetailView } from './extensions/index';
|
|
4
4
|
// components & module
|
|
5
5
|
export { SlickgridConfig } from './slickgrid-config';
|
|
6
6
|
export { AngularSlickgridComponent } from './components/angular-slickgrid.component';
|
|
7
7
|
export { AngularSlickgridModule } from './modules/angular-slickgrid.module';
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvYXBwL21vZHVsZXMvYW5ndWxhci1zbGlja2dyaWQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw2QkFBNkIsQ0FBQztBQUk1QyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsaUJBQWlCLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNwRyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUV4RCxzQkFBc0I7QUFDdEIsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3JELE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLDBDQUEwQyxDQUFDO0FBQ3JGLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLG9DQUFvQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnQHNsaWNrZ3JpZC11bml2ZXJzYWwvY29tbW9uJztcclxuXHJcbi8vIFB1YmxpYyBjbGFzc2VzLlxyXG5leHBvcnQgeyBBbmd1bGFyQ29tcG9uZW50T3V0cHV0LCBBbmd1bGFyR3JpZEluc3RhbmNlLCBHcmlkT3B0aW9uLCBTbGlja0dyaWQsIFJvd0RldGFpbFZpZXcgfSBmcm9tICcuL21vZGVscy9pbmRleCc7XHJcbmV4cG9ydCB7IEFuZ3VsYXJVdGlsU2VydmljZSwgQnNEcm9wRG93blNlcnZpY2UsIHVuc3Vic2NyaWJlQWxsT2JzZXJ2YWJsZXMgfSBmcm9tICcuL3NlcnZpY2VzL2luZGV4JztcclxuZXhwb3J0IHsgU2xpY2tSb3dEZXRhaWxWaWV3IH0gZnJvbSAnLi9leHRlbnNpb25zL2luZGV4JztcclxuXHJcbi8vIGNvbXBvbmVudHMgJiBtb2R1bGVcclxuZXhwb3J0IHsgU2xpY2tncmlkQ29uZmlnIH0gZnJvbSAnLi9zbGlja2dyaWQtY29uZmlnJztcclxuZXhwb3J0IHsgQW5ndWxhclNsaWNrZ3JpZENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9hbmd1bGFyLXNsaWNrZ3JpZC5jb21wb25lbnQnO1xyXG5leHBvcnQgeyBBbmd1bGFyU2xpY2tncmlkTW9kdWxlIH0gZnJvbSAnLi9tb2R1bGVzL2FuZ3VsYXItc2xpY2tncmlkLm1vZHVsZSc7XHJcbiJdfQ==
|
|
File without changes
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhckdyaWRJbnN0YW5jZS5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBwL21vZHVsZXMvYW5ndWxhci1zbGlja2dyaWQvbW9kZWxzL2FuZ3VsYXJHcmlkSW5zdGFuY2UuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIEJhY2tlbmRTZXJ2aWNlLFxyXG4gIEV4dGVuc2lvbkxpc3QsXHJcbiAgRXh0ZW5zaW9uU2VydmljZSxcclxuICBGaWx0ZXJTZXJ2aWNlLFxyXG4gIEdyaWRFdmVudFNlcnZpY2UsXHJcbiAgR3JpZFNlcnZpY2UsXHJcbiAgR3JpZFN0YXRlU2VydmljZSxcclxuICBHcm91cGluZ0FuZENvbHNwYW5TZXJ2aWNlLFxyXG4gIFBhZ2luYXRpb25TZXJ2aWNlLFxyXG4gIFJlc2l6ZXJTZXJ2aWNlLFxyXG4gIFNsaWNrRGF0YVZpZXcsXHJcbiAgU2xpY2tHcmlkLFxyXG4gIFNvcnRTZXJ2aWNlLFxyXG4gIFRyZWVEYXRhU2VydmljZVxyXG59IGZyb20gJ0BzbGlja2dyaWQtdW5pdmVyc2FsL2NvbW1vbic7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIEFuZ3VsYXJHcmlkSW5zdGFuY2Uge1xyXG4gIC8qKiBTbGljayBEYXRhVmlldyBvYmplY3QgKi9cclxuICBkYXRhVmlldzogU2xpY2tEYXRhVmlldztcclxuXHJcbiAgLyoqIFNsaWNrIEdyaWQgb2JqZWN0ICovXHJcbiAgc2xpY2tHcmlkOiBTbGlja0dyaWQ7XHJcblxyXG4gIC8qKiBTbGlja0dyaWQgZXh0ZW5zaW9ucyAoZXh0ZXJuYWwgY29udHJvbHMvcGx1Z2lucykgKi9cclxuICBleHRlbnNpb25zOiBFeHRlbnNpb25MaXN0PGFueT47XHJcblxyXG4gIC8vIC0tXHJcbiAgLy8gTWV0aG9kc1xyXG4gIC8qKiBEaXNwb3NlIG9mIHRoZSBncmlkIGFuZCBvcHRpb25hbGx5IGVtcHR5IHRoZSBET00gZWxlbWVudCBncmlkIGNvbnRhaW5lciBhcyB3ZWxsICovXHJcbiAgZGVzdHJveTogKGVtcHR5RG9tRWxlbWVudENvbnRhaW5lcj86IGJvb2xlYW4pID0+IHZvaWQ7XHJcblxyXG4gIC8vIC0tXHJcbiAgLy8gU2VydmljZXNcclxuXHJcbiAgLyoqIEJhY2tlbmQgU2VydmljZSwgd2hlbiBhdmFpbGFibGUgKi9cclxuICBiYWNrZW5kU2VydmljZT86IEJhY2tlbmRTZXJ2aWNlO1xyXG5cclxuICAvKiogRXh0ZW5zaW9uIChQbHVnaW5zICYgQ29udHJvbHMpIFNlcnZpY2UgKi9cclxuICBleHRlbnNpb25TZXJ2aWNlOiBFeHRlbnNpb25TZXJ2aWNlO1xyXG5cclxuICAvKiogRmlsdGVyIFNlcnZpY2UgKi9cclxuICBmaWx0ZXJTZXJ2aWNlOiBGaWx0ZXJTZXJ2aWNlO1xyXG5cclxuICAvKiogR3JpZCBTZXJ2aWNlIChncmlkIGV4dHJhIGZ1bmN0aW9uYWxpdGllcykgKi9cclxuICBncmlkU2VydmljZTogR3JpZFNlcnZpY2U7XHJcblxyXG4gIC8qKiBHcmlkIEV2ZW50cyBTZXJ2aWNlICovXHJcbiAgZ3JpZEV2ZW50U2VydmljZTogR3JpZEV2ZW50U2VydmljZTtcclxuXHJcbiAgLyoqIEdyaWQgU3RhdGUgU2VydmljZSAqL1xyXG4gIGdyaWRTdGF0ZVNlcnZpY2U6IEdyaWRTdGF0ZVNlcnZpY2U7XHJcblxyXG4gIC8qKiBHcm91cGluZyAoYW5kIGNvbHNwYW4pIFNlcnZpY2UgKi9cclxuICBncm91cGluZ1NlcnZpY2U6IEdyb3VwaW5nQW5kQ29sc3BhblNlcnZpY2U7XHJcblxyXG4gIC8qKiBQYWdpbmF0aW9uIFNlcnZpY2UgKGFsbG93cyB5b3UgdG8gcHJvZ3JhbW1hdGljYWxseSBnbyB0byBmaXJzdC9sYXN0IHBhZ2UsIGV0Yy4uLikgKi9cclxuICBwYWdpbmF0aW9uU2VydmljZT86IFBhZ2luYXRpb25TZXJ2aWNlO1xyXG5cclxuICAvKiogUmVzaXplciBTZXJ2aWNlIChpbmNsdWRpbmcgYXV0by1yZXNpemUpICovXHJcbiAgcmVzaXplclNlcnZpY2U6IFJlc2l6ZXJTZXJ2aWNlO1xyXG5cclxuICAvKiogU29ydCBTZXJ2aWNlICovXHJcbiAgc29ydFNlcnZpY2U6IFNvcnRTZXJ2aWNlO1xyXG5cclxuICAvKiogVHJlZSBEYXRhIFZpZXcgU2VydmljZSAqL1xyXG4gIHRyZWVEYXRhU2VydmljZTogVHJlZURhdGFTZXJ2aWNlO1xyXG59XHJcbiJdfQ==
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
4
|
+
import { AngularSlickgridComponent } from './../components/angular-slickgrid.component';
|
|
5
|
+
import { AngularUtilService } from '../services/angularUtil.service';
|
|
6
|
+
import { BsDropDownService } from '../services/bsDropdown.service';
|
|
7
|
+
import { ContainerService } from '../services/container.service';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
export class AngularSlickgridModule {
|
|
10
|
+
static forRoot(config = {}) {
|
|
11
|
+
return {
|
|
12
|
+
ngModule: AngularSlickgridModule,
|
|
13
|
+
providers: [
|
|
14
|
+
{ provide: 'config', useValue: config },
|
|
15
|
+
{ provide: 'externalService', useValue: null },
|
|
16
|
+
AngularUtilService,
|
|
17
|
+
BsDropDownService,
|
|
18
|
+
ContainerService,
|
|
19
|
+
]
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
AngularSlickgridModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: AngularSlickgridModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
24
|
+
AngularSlickgridModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: AngularSlickgridModule, declarations: [AngularSlickgridComponent], imports: [CommonModule,
|
|
25
|
+
TranslateModule], exports: [AngularSlickgridComponent] });
|
|
26
|
+
AngularSlickgridModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: AngularSlickgridModule, imports: [[
|
|
27
|
+
CommonModule,
|
|
28
|
+
TranslateModule
|
|
29
|
+
]] });
|
|
30
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: AngularSlickgridModule, decorators: [{
|
|
31
|
+
type: NgModule,
|
|
32
|
+
args: [{
|
|
33
|
+
imports: [
|
|
34
|
+
CommonModule,
|
|
35
|
+
TranslateModule
|
|
36
|
+
],
|
|
37
|
+
declarations: [
|
|
38
|
+
AngularSlickgridComponent,
|
|
39
|
+
],
|
|
40
|
+
exports: [
|
|
41
|
+
AngularSlickgridComponent,
|
|
42
|
+
],
|
|
43
|
+
entryComponents: [AngularSlickgridComponent]
|
|
44
|
+
}]
|
|
45
|
+
}] });
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1zbGlja2dyaWQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2FwcC9tb2R1bGVzL2FuZ3VsYXItc2xpY2tncmlkL21vZHVsZXMvYW5ndWxhci1zbGlja2dyaWQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQXVCLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFFdEQsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFFeEYsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDckUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDbkUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sK0JBQStCLENBQUM7O0FBZWpFLE1BQU0sT0FBTyxzQkFBc0I7SUFDakMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxTQUFxQixFQUFFO1FBQ3BDLE9BQU87WUFDTCxRQUFRLEVBQUUsc0JBQXNCO1lBQ2hDLFNBQVMsRUFBRTtnQkFDVCxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLE1BQU0sRUFBRTtnQkFDdkMsRUFBRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsUUFBUSxFQUFFLElBQUksRUFBRTtnQkFDOUMsa0JBQWtCO2dCQUNsQixpQkFBaUI7Z0JBQ2pCLGdCQUFnQjthQUNqQjtTQUNGLENBQUM7SUFDSixDQUFDOzttSEFaVSxzQkFBc0I7b0hBQXRCLHNCQUFzQixpQkFQL0IseUJBQXlCLGFBSnpCLFlBQVk7UUFDWixlQUFlLGFBTWYseUJBQXlCO29IQUloQixzQkFBc0IsWUFaeEI7WUFDUCxZQUFZO1lBQ1osZUFBZTtTQUNoQjsyRkFTVSxzQkFBc0I7a0JBYmxDLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osZUFBZTtxQkFDaEI7b0JBQ0QsWUFBWSxFQUFFO3dCQUNaLHlCQUF5QjtxQkFDMUI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLHlCQUF5QjtxQkFDMUI7b0JBQ0QsZUFBZSxFQUFFLENBQUMseUJBQXlCLENBQUM7aUJBQzdDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgTW9kdWxlV2l0aFByb3ZpZGVycywgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgVHJhbnNsYXRlTW9kdWxlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XHJcblxyXG5pbXBvcnQgeyBBbmd1bGFyU2xpY2tncmlkQ29tcG9uZW50IH0gZnJvbSAnLi8uLi9jb21wb25lbnRzL2FuZ3VsYXItc2xpY2tncmlkLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEdyaWRPcHRpb24gfSBmcm9tICcuLy4uL21vZGVscy9ncmlkT3B0aW9uLmludGVyZmFjZSc7XHJcbmltcG9ydCB7IEFuZ3VsYXJVdGlsU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2FuZ3VsYXJVdGlsLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBCc0Ryb3BEb3duU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2JzRHJvcGRvd24uc2VydmljZSc7XHJcbmltcG9ydCB7IENvbnRhaW5lclNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9jb250YWluZXIuc2VydmljZSc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIFRyYW5zbGF0ZU1vZHVsZVxyXG4gIF0sXHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBBbmd1bGFyU2xpY2tncmlkQ29tcG9uZW50LFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgQW5ndWxhclNsaWNrZ3JpZENvbXBvbmVudCxcclxuICBdLFxyXG4gIGVudHJ5Q29tcG9uZW50czogW0FuZ3VsYXJTbGlja2dyaWRDb21wb25lbnRdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBbmd1bGFyU2xpY2tncmlkTW9kdWxlIHtcclxuICBzdGF0aWMgZm9yUm9vdChjb25maWc6IEdyaWRPcHRpb24gPSB7fSk6IE1vZHVsZVdpdGhQcm92aWRlcnM8QW5ndWxhclNsaWNrZ3JpZE1vZHVsZT4ge1xyXG4gICAgcmV0dXJuIHtcclxuICAgICAgbmdNb2R1bGU6IEFuZ3VsYXJTbGlja2dyaWRNb2R1bGUsXHJcbiAgICAgIHByb3ZpZGVyczogW1xyXG4gICAgICAgIHsgcHJvdmlkZTogJ2NvbmZpZycsIHVzZVZhbHVlOiBjb25maWcgfSxcclxuICAgICAgICB7IHByb3ZpZGU6ICdleHRlcm5hbFNlcnZpY2UnLCB1c2VWYWx1ZTogbnVsbCB9LFxyXG4gICAgICAgIEFuZ3VsYXJVdGlsU2VydmljZSxcclxuICAgICAgICBCc0Ryb3BEb3duU2VydmljZSxcclxuICAgICAgICBDb250YWluZXJTZXJ2aWNlLFxyXG4gICAgICBdXHJcbiAgICB9O1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class AngularUtilService {
|
|
4
|
+
constructor(compFactoryResolver, appRef, injector) {
|
|
5
|
+
this.compFactoryResolver = compFactoryResolver;
|
|
6
|
+
this.appRef = appRef;
|
|
7
|
+
this.injector = injector;
|
|
8
|
+
}
|
|
9
|
+
// ref https://hackernoon.com/angular-pro-tip-how-to-dynamically-create-components-in-body-ba200cc289e6
|
|
10
|
+
createAngularComponent(component) {
|
|
11
|
+
// Create a component reference from the component
|
|
12
|
+
const componentRef = this.compFactoryResolver
|
|
13
|
+
.resolveComponentFactory(component)
|
|
14
|
+
.create(this.injector);
|
|
15
|
+
// Attach component to the appRef so that it's inside the ng component tree
|
|
16
|
+
this.appRef.attachView(componentRef.hostView);
|
|
17
|
+
// Get DOM element from component
|
|
18
|
+
let domElem;
|
|
19
|
+
const viewRef = componentRef.hostView;
|
|
20
|
+
if (viewRef && Array.isArray(viewRef.rootNodes) && viewRef.rootNodes[0]) {
|
|
21
|
+
domElem = viewRef.rootNodes[0];
|
|
22
|
+
}
|
|
23
|
+
return { componentRef, domElement: domElem };
|
|
24
|
+
}
|
|
25
|
+
// ref https://hackernoon.com/angular-pro-tip-how-to-dynamically-create-components-in-body-ba200cc289e6
|
|
26
|
+
createAngularComponentAppendToDom(component, targetElement, clearTargetContent = false) {
|
|
27
|
+
const componentOutput = this.createAngularComponent(component);
|
|
28
|
+
// Append DOM element to the HTML element specified
|
|
29
|
+
if (targetElement && targetElement.appendChild) {
|
|
30
|
+
if (clearTargetContent && targetElement.innerHTML) {
|
|
31
|
+
targetElement.innerHTML = '';
|
|
32
|
+
}
|
|
33
|
+
targetElement.appendChild(componentOutput.domElement);
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
document.body.appendChild(componentOutput.domElement); // when no target provided, we'll simply add it to the HTML Body
|
|
37
|
+
}
|
|
38
|
+
return componentOutput;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
AngularUtilService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: AngularUtilService, deps: [{ token: i0.ComponentFactoryResolver }, { token: i0.ApplicationRef }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
42
|
+
AngularUtilService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: AngularUtilService });
|
|
43
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: AngularUtilService, decorators: [{
|
|
44
|
+
type: Injectable
|
|
45
|
+
}], ctorParameters: function () { return [{ type: i0.ComponentFactoryResolver }, { type: i0.ApplicationRef }, { type: i0.Injector }]; } });
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhclV0aWwuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9hcHAvbW9kdWxlcy9hbmd1bGFyLXNsaWNrZ3JpZC9zZXJ2aWNlcy9hbmd1bGFyVXRpbC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBNkQsVUFBVSxFQUFZLE1BQU0sZUFBZSxDQUFDOztBQUdoSCxNQUFNLE9BQU8sa0JBQWtCO0lBQzdCLFlBQ1UsbUJBQTZDLEVBQzdDLE1BQXNCLEVBQ3RCLFFBQWtCO1FBRmxCLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBMEI7UUFDN0MsV0FBTSxHQUFOLE1BQU0sQ0FBZ0I7UUFDdEIsYUFBUSxHQUFSLFFBQVEsQ0FBVTtJQUN4QixDQUFDO0lBRUwsdUdBQXVHO0lBQ3ZHLHNCQUFzQixDQUFDLFNBQWM7UUFDbkMsa0RBQWtEO1FBQ2xELE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxtQkFBbUI7YUFDMUMsdUJBQXVCLENBQUMsU0FBUyxDQUFDO2FBQ2xDLE1BQU0sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFFekIsMkVBQTJFO1FBQzNFLElBQUksQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUU5QyxpQ0FBaUM7UUFDakMsSUFBSSxPQUFPLENBQUM7UUFDWixNQUFNLE9BQU8sR0FBSSxZQUFZLENBQUMsUUFBaUMsQ0FBQztRQUNoRSxJQUFJLE9BQU8sSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFO1lBQ3ZFLE9BQU8sR0FBRyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBZ0IsQ0FBQztTQUMvQztRQUVELE9BQU8sRUFBRSxZQUFZLEVBQUUsVUFBVSxFQUFFLE9BQXNCLEVBQUUsQ0FBQztJQUM5RCxDQUFDO0lBRUQsdUdBQXVHO0lBQ3ZHLGlDQUFpQyxDQUFDLFNBQWMsRUFBRSxhQUFxQyxFQUFFLGtCQUFrQixHQUFHLEtBQUs7UUFDakgsTUFBTSxlQUFlLEdBQUcsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBRS9ELG1EQUFtRDtRQUNuRCxJQUFJLGFBQWEsSUFBSSxhQUFhLENBQUMsV0FBVyxFQUFFO1lBQzlDLElBQUksa0JBQWtCLElBQUksYUFBYSxDQUFDLFNBQVMsRUFBRTtnQkFDakQsYUFBYSxDQUFDLFNBQVMsR0FBRyxFQUFFLENBQUM7YUFDOUI7WUFDRCxhQUFhLENBQUMsV0FBVyxDQUFDLGVBQWUsQ0FBQyxVQUFVLENBQUMsQ0FBQztTQUN2RDthQUFNO1lBQ0wsUUFBUSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsZUFBZSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsZ0VBQWdFO1NBQ3hIO1FBRUQsT0FBTyxlQUFlLENBQUM7SUFDekIsQ0FBQzs7K0dBMUNVLGtCQUFrQjttSEFBbEIsa0JBQWtCOzJGQUFsQixrQkFBa0I7a0JBRDlCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBbmd1bGFyQ29tcG9uZW50T3V0cHV0IH0gZnJvbSAnLi4vbW9kZWxzL2FuZ3VsYXJDb21wb25lbnRPdXRwdXQuaW50ZXJmYWNlJztcclxuaW1wb3J0IHsgQXBwbGljYXRpb25SZWYsIENvbXBvbmVudEZhY3RvcnlSZXNvbHZlciwgRW1iZWRkZWRWaWV3UmVmLCBJbmplY3RhYmxlLCBJbmplY3RvciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgQW5ndWxhclV0aWxTZXJ2aWNlIHtcclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgY29tcEZhY3RvcnlSZXNvbHZlcjogQ29tcG9uZW50RmFjdG9yeVJlc29sdmVyLFxyXG4gICAgcHJpdmF0ZSBhcHBSZWY6IEFwcGxpY2F0aW9uUmVmLFxyXG4gICAgcHJpdmF0ZSBpbmplY3RvcjogSW5qZWN0b3IsXHJcbiAgKSB7IH1cclxuXHJcbiAgLy8gcmVmIGh0dHBzOi8vaGFja2Vybm9vbi5jb20vYW5ndWxhci1wcm8tdGlwLWhvdy10by1keW5hbWljYWxseS1jcmVhdGUtY29tcG9uZW50cy1pbi1ib2R5LWJhMjAwY2MyODllNlxyXG4gIGNyZWF0ZUFuZ3VsYXJDb21wb25lbnQoY29tcG9uZW50OiBhbnkpOiBBbmd1bGFyQ29tcG9uZW50T3V0cHV0IHtcclxuICAgIC8vIENyZWF0ZSBhIGNvbXBvbmVudCByZWZlcmVuY2UgZnJvbSB0aGUgY29tcG9uZW50XHJcbiAgICBjb25zdCBjb21wb25lbnRSZWYgPSB0aGlzLmNvbXBGYWN0b3J5UmVzb2x2ZXJcclxuICAgICAgLnJlc29sdmVDb21wb25lbnRGYWN0b3J5KGNvbXBvbmVudClcclxuICAgICAgLmNyZWF0ZSh0aGlzLmluamVjdG9yKTtcclxuXHJcbiAgICAvLyBBdHRhY2ggY29tcG9uZW50IHRvIHRoZSBhcHBSZWYgc28gdGhhdCBpdCdzIGluc2lkZSB0aGUgbmcgY29tcG9uZW50IHRyZWVcclxuICAgIHRoaXMuYXBwUmVmLmF0dGFjaFZpZXcoY29tcG9uZW50UmVmLmhvc3RWaWV3KTtcclxuXHJcbiAgICAvLyBHZXQgRE9NIGVsZW1lbnQgZnJvbSBjb21wb25lbnRcclxuICAgIGxldCBkb21FbGVtO1xyXG4gICAgY29uc3Qgdmlld1JlZiA9IChjb21wb25lbnRSZWYuaG9zdFZpZXcgYXMgRW1iZWRkZWRWaWV3UmVmPGFueT4pO1xyXG4gICAgaWYgKHZpZXdSZWYgJiYgQXJyYXkuaXNBcnJheSh2aWV3UmVmLnJvb3ROb2RlcykgJiYgdmlld1JlZi5yb290Tm9kZXNbMF0pIHtcclxuICAgICAgZG9tRWxlbSA9IHZpZXdSZWYucm9vdE5vZGVzWzBdIGFzIEhUTUxFbGVtZW50O1xyXG4gICAgfVxyXG5cclxuICAgIHJldHVybiB7IGNvbXBvbmVudFJlZiwgZG9tRWxlbWVudDogZG9tRWxlbSBhcyBIVE1MRWxlbWVudCB9O1xyXG4gIH1cclxuXHJcbiAgLy8gcmVmIGh0dHBzOi8vaGFja2Vybm9vbi5jb20vYW5ndWxhci1wcm8tdGlwLWhvdy10by1keW5hbWljYWxseS1jcmVhdGUtY29tcG9uZW50cy1pbi1ib2R5LWJhMjAwY2MyODllNlxyXG4gIGNyZWF0ZUFuZ3VsYXJDb21wb25lbnRBcHBlbmRUb0RvbShjb21wb25lbnQ6IGFueSwgdGFyZ2V0RWxlbWVudD86IEhUTUxFbGVtZW50IHwgRWxlbWVudCwgY2xlYXJUYXJnZXRDb250ZW50ID0gZmFsc2UpOiBBbmd1bGFyQ29tcG9uZW50T3V0cHV0IHtcclxuICAgIGNvbnN0IGNvbXBvbmVudE91dHB1dCA9IHRoaXMuY3JlYXRlQW5ndWxhckNvbXBvbmVudChjb21wb25lbnQpO1xyXG5cclxuICAgIC8vIEFwcGVuZCBET00gZWxlbWVudCB0byB0aGUgSFRNTCBlbGVtZW50IHNwZWNpZmllZFxyXG4gICAgaWYgKHRhcmdldEVsZW1lbnQgJiYgdGFyZ2V0RWxlbWVudC5hcHBlbmRDaGlsZCkge1xyXG4gICAgICBpZiAoY2xlYXJUYXJnZXRDb250ZW50ICYmIHRhcmdldEVsZW1lbnQuaW5uZXJIVE1MKSB7XHJcbiAgICAgICAgdGFyZ2V0RWxlbWVudC5pbm5lckhUTUwgPSAnJztcclxuICAgICAgfVxyXG4gICAgICB0YXJnZXRFbGVtZW50LmFwcGVuZENoaWxkKGNvbXBvbmVudE91dHB1dC5kb21FbGVtZW50KTtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIGRvY3VtZW50LmJvZHkuYXBwZW5kQ2hpbGQoY29tcG9uZW50T3V0cHV0LmRvbUVsZW1lbnQpOyAvLyB3aGVuIG5vIHRhcmdldCBwcm92aWRlZCwgd2UnbGwgc2ltcGx5IGFkZCBpdCB0byB0aGUgSFRNTCBCb2R5XHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIGNvbXBvbmVudE91dHB1dDtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "./angularUtil.service";
|
|
4
|
+
// Boostrap dropdown service
|
|
5
|
+
export class BsDropDownService {
|
|
6
|
+
constructor(angularUtilService) {
|
|
7
|
+
this.angularUtilService = angularUtilService;
|
|
8
|
+
}
|
|
9
|
+
get domElement() {
|
|
10
|
+
return this._domElement;
|
|
11
|
+
}
|
|
12
|
+
get domContainerElement() {
|
|
13
|
+
return this._domContainerElement;
|
|
14
|
+
}
|
|
15
|
+
get gridViewport() {
|
|
16
|
+
return $('.slick-viewport');
|
|
17
|
+
}
|
|
18
|
+
dispose() {
|
|
19
|
+
if (this._domElement && this._domElement.remove) {
|
|
20
|
+
this._domElement.remove();
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
dropContainerShow() {
|
|
24
|
+
if (this._domContainerElement && this._domContainerElement.show) {
|
|
25
|
+
this._domContainerElement.show();
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
render(dropdownParams) {
|
|
29
|
+
return new Promise((resolve) => {
|
|
30
|
+
const { component, args, parent, offsetTop, offsetLeft, offsetDropupBottom } = dropdownParams;
|
|
31
|
+
const cell = args.cell;
|
|
32
|
+
const row = args.row;
|
|
33
|
+
this._domContainerElement = $(`#myDrop-r${row}-c${cell}`);
|
|
34
|
+
if (this._domContainerElement) {
|
|
35
|
+
// hide the dropdown we created as a formatter Component, we'll redisplay it later
|
|
36
|
+
const cellPos = this._domContainerElement.offset();
|
|
37
|
+
const componentOutput = this.angularUtilService.createAngularComponent(component);
|
|
38
|
+
const componentInstance = componentOutput && componentOutput.componentRef && componentOutput.componentRef.instance;
|
|
39
|
+
if (componentInstance) {
|
|
40
|
+
const myDropId = componentInstance.dropdownId || 'myDrop';
|
|
41
|
+
const dropDownToggleId = componentInstance.dropDownToggleId || 'dropdownMenu1';
|
|
42
|
+
this._domElement = $(`#${myDropId}`);
|
|
43
|
+
if (this._domElement) {
|
|
44
|
+
// make sure to remove any previous Action dropdown elements, to avoid having multiple element of the same on top of each other
|
|
45
|
+
this.dispose();
|
|
46
|
+
// assign the row data to the dropdown component instance
|
|
47
|
+
Object.assign(componentInstance, { parent, row: args.row, dataContext: args.grid.getDataItem(args.row) });
|
|
48
|
+
// use a delay to make sure Angular ran at least a full cycle and make sure it finished rendering the Component before using it
|
|
49
|
+
setTimeout(() => {
|
|
50
|
+
// create a new dropdown element
|
|
51
|
+
this._domElement = $(componentOutput.domElement);
|
|
52
|
+
const topPos = (cellPos && cellPos.top || 0) + 30 + (offsetTop || 0);
|
|
53
|
+
const leftPos = (cellPos && cellPos.left || 0) + (offsetLeft || 0);
|
|
54
|
+
this._domElement.appendTo('body');
|
|
55
|
+
this._domElement.css('position', 'absolute');
|
|
56
|
+
this._domElement.css('top', topPos);
|
|
57
|
+
this._domElement.css('left', leftPos);
|
|
58
|
+
$(`#${myDropId}`).addClass('open');
|
|
59
|
+
$(`#${dropDownToggleId}`).hide();
|
|
60
|
+
// check if it should drop Up or Down
|
|
61
|
+
const offset = 35;
|
|
62
|
+
const iElement = $('.dropdown-menu');
|
|
63
|
+
const iElementWrapper = iElement.parent();
|
|
64
|
+
const iElementWrapperOffset = iElementWrapper.offset() || {};
|
|
65
|
+
const iElementWrapperOffsetTop = iElementWrapperOffset.top || iElementWrapper && iElementWrapper.length > 0 && iElementWrapper[0].offsetTop;
|
|
66
|
+
const iElementHeight = iElement.height();
|
|
67
|
+
const windowHeight = window.innerHeight;
|
|
68
|
+
const shouldDropUp = (windowHeight - iElementHeight - offset) < iElementWrapperOffsetTop;
|
|
69
|
+
let menuMarginTop = '0px';
|
|
70
|
+
if (shouldDropUp) {
|
|
71
|
+
const offsetBottom = offsetDropupBottom || 0;
|
|
72
|
+
menuMarginTop = '-'.concat(`${iElementHeight + offset + offsetBottom + 5}`, 'px');
|
|
73
|
+
}
|
|
74
|
+
this._domElement.css({ 'margin-top': menuMarginTop });
|
|
75
|
+
// set dropdown margin left according to the document width
|
|
76
|
+
const parentOffset = iElementWrapperOffset.left;
|
|
77
|
+
const leftMargin = parentOffset - $(document).width();
|
|
78
|
+
this._domElement.css({ 'margin-left': (this._domElement.width() + leftMargin + 60) + 'px' });
|
|
79
|
+
try {
|
|
80
|
+
this._domElement.dropdown('show'); // required for Bootstrap 4 only
|
|
81
|
+
}
|
|
82
|
+
catch (e) {
|
|
83
|
+
// Bootstrap 3 wil throw an error since that method doesn't exist, we can safely disregard it
|
|
84
|
+
}
|
|
85
|
+
this._domElement.on('hidden.bs.dropdown', () => this.dropContainerShow());
|
|
86
|
+
// hide dropdown menu on grid scroll
|
|
87
|
+
this.gridViewport.on('scroll', () => this.dispose());
|
|
88
|
+
// hide on dropdown click
|
|
89
|
+
this._domElement.on('click', () => this.dispose());
|
|
90
|
+
resolve(true);
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
BsDropDownService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: BsDropDownService, deps: [{ token: i1.AngularUtilService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
99
|
+
BsDropDownService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: BsDropDownService });
|
|
100
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: BsDropDownService, decorators: [{
|
|
101
|
+
type: Injectable
|
|
102
|
+
}], ctorParameters: function () { return [{ type: i1.AngularUtilService }]; } });
|
|
103
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bsDropdown.service.js","sourceRoot":"","sources":["../../../../../../src/app/modules/angular-slickgrid/services/bsDropdown.service.ts"],"names":[],"mappings":"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","sourcesContent":["\r\nimport { Injectable } from '@angular/core';\r\nimport { AngularUtilService } from './angularUtil.service';\r\n\r\ninterface DropDownServiceParams {\r\n  /** the custom action formatter component that contains the dropdown */\r\n  component: any;\r\n\r\n  /** help to get the data context */\r\n  args: any;\r\n\r\n  /** parent container */\r\n  parent: any;\r\n\r\n  /** Offset bottom when using a Drop Up, if we need to reposition the dropdown component */\r\n  offsetDropupBottom?: number;\r\n\r\n  /** Offset left if we need to reposition the dropdown component */\r\n  offsetLeft?: number;\r\n\r\n  /** Offset top if we need to reposition the dropdown component */\r\n  offsetTop?: number;\r\n}\r\n\r\n// using external non-typed js libraries\r\ndeclare const $: any;\r\n\r\n// Boostrap dropdown service\r\n@Injectable()\r\nexport class BsDropDownService {\r\n  private _domContainerElement: any;\r\n  private _domElement: any;\r\n\r\n  constructor(private angularUtilService: AngularUtilService) { }\r\n\r\n  get domElement() {\r\n    return this._domElement;\r\n  }\r\n\r\n  get domContainerElement() {\r\n    return this._domContainerElement;\r\n  }\r\n\r\n  get gridViewport() {\r\n    return $('.slick-viewport');\r\n  }\r\n\r\n  dispose() {\r\n    if (this._domElement && this._domElement.remove) {\r\n      this._domElement.remove();\r\n    }\r\n  }\r\n\r\n  dropContainerShow() {\r\n    if (this._domContainerElement && this._domContainerElement.show) {\r\n      this._domContainerElement.show();\r\n    }\r\n  }\r\n\r\n  render(dropdownParams: DropDownServiceParams) {\r\n    return new Promise((resolve) => {\r\n      const { component, args, parent, offsetTop, offsetLeft, offsetDropupBottom } = dropdownParams;\r\n\r\n      const cell = args.cell;\r\n      const row = args.row;\r\n\r\n      this._domContainerElement = $(`#myDrop-r${row}-c${cell}`);\r\n\r\n      if (this._domContainerElement) {\r\n        // hide the dropdown we created as a formatter Component, we'll redisplay it later\r\n        const cellPos = this._domContainerElement.offset();\r\n\r\n        const componentOutput = this.angularUtilService.createAngularComponent(component);\r\n        const componentInstance = componentOutput && componentOutput.componentRef && componentOutput.componentRef.instance;\r\n\r\n        if (componentInstance) {\r\n          const myDropId = componentInstance.dropdownId || 'myDrop';\r\n          const dropDownToggleId = componentInstance.dropDownToggleId || 'dropdownMenu1';\r\n          this._domElement = $(`#${myDropId}`);\r\n\r\n          if (this._domElement) {\r\n            // make sure to remove any previous Action dropdown elements, to avoid having multiple element of the same on top of each other\r\n            this.dispose();\r\n\r\n            // assign the row data to the dropdown component instance\r\n            Object.assign(componentInstance, { parent, row: args.row, dataContext: args.grid.getDataItem(args.row) });\r\n\r\n            // use a delay to make sure Angular ran at least a full cycle and make sure it finished rendering the Component before using it\r\n            setTimeout(() => {\r\n              // create a new dropdown element\r\n              this._domElement = $(componentOutput.domElement);\r\n              const topPos = (cellPos && cellPos.top || 0) + 30 + (offsetTop || 0);\r\n              const leftPos = (cellPos && cellPos.left || 0) + (offsetLeft || 0);\r\n              this._domElement.appendTo('body');\r\n              this._domElement.css('position', 'absolute');\r\n              this._domElement.css('top', topPos);\r\n              this._domElement.css('left', leftPos);\r\n              $(`#${myDropId}`).addClass('open');\r\n              $(`#${dropDownToggleId}`).hide();\r\n\r\n              // check if it should drop Up or Down\r\n              const offset = 35;\r\n              const iElement = $('.dropdown-menu');\r\n              const iElementWrapper = iElement.parent();\r\n              const iElementWrapperOffset = iElementWrapper.offset() || {};\r\n              const iElementWrapperOffsetTop = iElementWrapperOffset.top || iElementWrapper && iElementWrapper.length > 0 && iElementWrapper[0].offsetTop;\r\n              const iElementHeight = iElement.height();\r\n              const windowHeight = window.innerHeight;\r\n              const shouldDropUp = (windowHeight - iElementHeight - offset) < iElementWrapperOffsetTop;\r\n              let menuMarginTop = '0px';\r\n              if (shouldDropUp) {\r\n                const offsetBottom = offsetDropupBottom || 0;\r\n                menuMarginTop = '-'.concat(`${iElementHeight + offset + offsetBottom + 5}`, 'px');\r\n              }\r\n              this._domElement.css({ 'margin-top': menuMarginTop });\r\n\r\n              // set dropdown margin left according to the document width\r\n              const parentOffset = iElementWrapperOffset.left;\r\n              const leftMargin = parentOffset - $(document).width();\r\n              this._domElement.css({ 'margin-left': (this._domElement.width() + leftMargin + 60) + 'px' });\r\n\r\n              try {\r\n                this._domElement.dropdown('show'); // required for Bootstrap 4 only\r\n              } catch (e) {\r\n                // Bootstrap 3 wil throw an error since that method doesn't exist, we can safely disregard it\r\n              }\r\n\r\n              this._domElement.on('hidden.bs.dropdown', () => this.dropContainerShow());\r\n\r\n              // hide dropdown menu on grid scroll\r\n              this.gridViewport.on('scroll', () => this.dispose());\r\n\r\n              // hide on dropdown click\r\n              this._domElement.on('click', () => this.dispose());\r\n              resolve(true);\r\n            });\r\n          }\r\n        }\r\n      }\r\n    });\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class ContainerService {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.dependencies = [];
|
|
6
|
+
}
|
|
7
|
+
get(key) {
|
|
8
|
+
const dependency = this.dependencies.find(dep => dep.key === key);
|
|
9
|
+
if (dependency?.instance) {
|
|
10
|
+
return dependency.instance;
|
|
11
|
+
}
|
|
12
|
+
return null;
|
|
13
|
+
}
|
|
14
|
+
registerInstance(key, instance) {
|
|
15
|
+
const dependency = this.dependencies.some(dep => dep.key === key);
|
|
16
|
+
if (!dependency) {
|
|
17
|
+
this.dependencies.push({ key, instance });
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
ContainerService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: ContainerService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
22
|
+
ContainerService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: ContainerService });
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.0", ngImport: i0, type: ContainerService, decorators: [{
|
|
24
|
+
type: Injectable
|
|
25
|
+
}], ctorParameters: function () { return []; } });
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFpbmVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvYXBwL21vZHVsZXMvYW5ndWxhci1zbGlja2dyaWQvc2VydmljZXMvY29udGFpbmVyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFJM0MsTUFBTSxPQUFPLGdCQUFnQjtJQUczQjtRQUZBLGlCQUFZLEdBQXdCLEVBQUUsQ0FBQztJQUV2QixDQUFDO0lBRWpCLEdBQUcsQ0FBVSxHQUFXO1FBQ3RCLE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLEdBQUcsS0FBSyxHQUFHLENBQUMsQ0FBQztRQUNsRSxJQUFJLFVBQVUsRUFBRSxRQUFRLEVBQUU7WUFDeEIsT0FBTyxVQUFVLENBQUMsUUFBUSxDQUFDO1NBQzVCO1FBQ0QsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsZ0JBQWdCLENBQUMsR0FBVyxFQUFFLFFBQWE7UUFDekMsTUFBTSxVQUFVLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsR0FBRyxLQUFLLEdBQUcsQ0FBQyxDQUFDO1FBQ2xFLElBQUksQ0FBQyxVQUFVLEVBQUU7WUFDZixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxFQUFFLEdBQUcsRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO1NBQzNDO0lBQ0gsQ0FBQzs7NkdBbEJVLGdCQUFnQjtpSEFBaEIsZ0JBQWdCOzJGQUFoQixnQkFBZ0I7a0JBRDVCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbnRhaW5lckluc3RhbmNlLCBDb250YWluZXJTZXJ2aWNlIGFzIFVuaXZlcnNhbENvbnRhaW5lclNlcnZpY2UgfSBmcm9tICdAc2xpY2tncmlkLXVuaXZlcnNhbC9jb21tb24nO1xyXG5cclxuQEluamVjdGFibGUoKVxyXG5leHBvcnQgY2xhc3MgQ29udGFpbmVyU2VydmljZSBpbXBsZW1lbnRzIFVuaXZlcnNhbENvbnRhaW5lclNlcnZpY2Uge1xyXG4gIGRlcGVuZGVuY2llczogQ29udGFpbmVySW5zdGFuY2VbXSA9IFtdO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG5cclxuICBnZXQ8VCA9IGFueT4oa2V5OiBzdHJpbmcpOiBUIHwgbnVsbCB7XHJcbiAgICBjb25zdCBkZXBlbmRlbmN5ID0gdGhpcy5kZXBlbmRlbmNpZXMuZmluZChkZXAgPT4gZGVwLmtleSA9PT0ga2V5KTtcclxuICAgIGlmIChkZXBlbmRlbmN5Py5pbnN0YW5jZSkge1xyXG4gICAgICByZXR1cm4gZGVwZW5kZW5jeS5pbnN0YW5jZTtcclxuICAgIH1cclxuICAgIHJldHVybiBudWxsO1xyXG4gIH1cclxuXHJcbiAgcmVnaXN0ZXJJbnN0YW5jZShrZXk6IHN0cmluZywgaW5zdGFuY2U6IGFueSkge1xyXG4gICAgY29uc3QgZGVwZW5kZW5jeSA9IHRoaXMuZGVwZW5kZW5jaWVzLnNvbWUoZGVwID0+IGRlcC5rZXkgPT09IGtleSk7XHJcbiAgICBpZiAoIWRlcGVuZGVuY3kpIHtcclxuICAgICAgdGhpcy5kZXBlbmRlbmNpZXMucHVzaCh7IGtleSwgaW5zdGFuY2UgfSk7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
|