@revolist/angular-datagrid 4.15.7 → 4.16.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.
@@ -18,12 +18,12 @@ let RevoGrid = class RevoGrid {
18
18
  proxyOutputs(this, this.el, ['contentsizechanged', 'beforeedit', 'beforerangeedit', 'afteredit', 'beforeautofill', 'beforerange', 'afterfocus', 'roworderchanged', 'beforesorting', 'beforesourcesortingapply', 'beforesortingapply', 'rowdragstart', 'headerclick', 'beforecellfocus', 'beforefocuslost', 'beforesourceset', 'beforeanysource', 'aftersourceset', 'afteranysource', 'beforecolumnsset', 'beforecolumnapplied', 'aftercolumnsset', 'beforefilterapply', 'beforefiltertrimmed', 'beforetrimmed', 'aftertrimmed', 'viewportscroll', 'beforeexport', 'beforeeditstart', 'aftercolumnresize', 'beforerowdefinition', 'filterconfigchanged', 'sortingconfigchanged', 'rowheaderschanged', 'beforegridrender', 'aftergridrender', 'aftergridinit', 'additionaldatachanged', 'afterthemechanged', 'created']);
19
19
  }
20
20
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: RevoGrid, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
21
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.1", type: RevoGrid, isStandalone: true, selector: "revo-grid", inputs: { accessible: "accessible", additionalData: "additionalData", applyOnClose: "applyOnClose", autoSizeColumn: "autoSizeColumn", canDrag: "canDrag", canFocus: "canFocus", canMoveColumns: "canMoveColumns", colSize: "colSize", columnTypes: "columnTypes", columns: "columns", disableVirtualX: "disableVirtualX", disableVirtualY: "disableVirtualY", editors: "editors", exporting: "exporting", filter: "filter", focusTemplate: "focusTemplate", frameSize: "frameSize", grouping: "grouping", hideAttribution: "hideAttribution", jobsBeforeRender: "jobsBeforeRender", pinnedBottomSource: "pinnedBottomSource", pinnedTopSource: "pinnedTopSource", plugins: "plugins", range: "range", readonly: "readonly", registerVNode: "registerVNode", resize: "resize", rowClass: "rowClass", rowDefinitions: "rowDefinitions", rowHeaders: "rowHeaders", rowSize: "rowSize", sorting: "sorting", source: "source", stretch: "stretch", theme: "theme", trimmedRows: "trimmedRows", useClipboard: "useClipboard" }, ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
21
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.1", type: RevoGrid, isStandalone: true, selector: "revo-grid", inputs: { accessible: "accessible", additionalData: "additionalData", applyOnClose: "applyOnClose", autoSizeColumn: "autoSizeColumn", canDrag: "canDrag", canFocus: "canFocus", canMoveColumns: "canMoveColumns", colSize: "colSize", columnTypes: "columnTypes", columns: "columns", disableVirtualX: "disableVirtualX", disableVirtualY: "disableVirtualY", editors: "editors", exporting: "exporting", filter: "filter", focusTemplate: "focusTemplate", frameSize: "frameSize", grouping: "grouping", hideAttribution: "hideAttribution", jobsBeforeRender: "jobsBeforeRender", pinnedBottomSource: "pinnedBottomSource", pinnedTopSource: "pinnedTopSource", plugins: "plugins", range: "range", readonly: "readonly", registerVNode: "registerVNode", resize: "resize", rowClass: "rowClass", rowDefinitions: "rowDefinitions", rowHeaders: "rowHeaders", rowSize: "rowSize", rtl: "rtl", sorting: "sorting", source: "source", stretch: "stretch", theme: "theme", trimmedRows: "trimmedRows", useClipboard: "useClipboard" }, ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
22
22
  };
23
23
  RevoGrid = __decorate([
24
24
  ProxyCmp({
25
25
  defineCustomElementFn: defineRevoGrid,
26
- inputs: ['accessible', 'additionalData', 'applyOnClose', 'autoSizeColumn', 'canDrag', 'canFocus', 'canMoveColumns', 'colSize', 'columnTypes', 'columns', 'disableVirtualX', 'disableVirtualY', 'editors', 'exporting', 'filter', 'focusTemplate', 'frameSize', 'grouping', 'hideAttribution', 'jobsBeforeRender', 'pinnedBottomSource', 'pinnedTopSource', 'plugins', 'range', 'readonly', 'registerVNode', 'resize', 'rowClass', 'rowDefinitions', 'rowHeaders', 'rowSize', 'sorting', 'source', 'stretch', 'theme', 'trimmedRows', 'useClipboard'],
26
+ inputs: ['accessible', 'additionalData', 'applyOnClose', 'autoSizeColumn', 'canDrag', 'canFocus', 'canMoveColumns', 'colSize', 'columnTypes', 'columns', 'disableVirtualX', 'disableVirtualY', 'editors', 'exporting', 'filter', 'focusTemplate', 'frameSize', 'grouping', 'hideAttribution', 'jobsBeforeRender', 'pinnedBottomSource', 'pinnedTopSource', 'plugins', 'range', 'readonly', 'registerVNode', 'resize', 'rowClass', 'rowDefinitions', 'rowHeaders', 'rowSize', 'rtl', 'sorting', 'source', 'stretch', 'theme', 'trimmedRows', 'useClipboard'],
27
27
  methods: ['refresh', 'setDataAt', 'scrollToRow', 'scrollToColumnIndex', 'scrollToColumnProp', 'updateColumns', 'addTrimmed', 'scrollToCoordinate', 'setCellEdit', 'setCellsFocus', 'getSource', 'getVisibleSource', 'getSourceStore', 'getColumnStore', 'updateColumnSorting', 'clearSorting', 'getColumns', 'clearFocus', 'getPlugins', 'getFocused', 'getContentSize', 'getSelectedRange', 'refreshExtraElements', 'getProviders']
28
28
  })
29
29
  ], RevoGrid);
@@ -35,8 +35,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImpor
35
35
  changeDetection: ChangeDetectionStrategy.OnPush,
36
36
  template: '<ng-content></ng-content>',
37
37
  // eslint-disable-next-line @angular-eslint/no-inputs-metadata-property
38
- inputs: ['accessible', 'additionalData', 'applyOnClose', 'autoSizeColumn', 'canDrag', 'canFocus', 'canMoveColumns', 'colSize', 'columnTypes', 'columns', 'disableVirtualX', 'disableVirtualY', 'editors', 'exporting', 'filter', 'focusTemplate', 'frameSize', 'grouping', 'hideAttribution', 'jobsBeforeRender', 'pinnedBottomSource', 'pinnedTopSource', 'plugins', 'range', 'readonly', 'registerVNode', 'resize', 'rowClass', 'rowDefinitions', 'rowHeaders', 'rowSize', 'sorting', 'source', 'stretch', 'theme', 'trimmedRows', 'useClipboard'],
38
+ inputs: ['accessible', 'additionalData', 'applyOnClose', 'autoSizeColumn', 'canDrag', 'canFocus', 'canMoveColumns', 'colSize', 'columnTypes', 'columns', 'disableVirtualX', 'disableVirtualY', 'editors', 'exporting', 'filter', 'focusTemplate', 'frameSize', 'grouping', 'hideAttribution', 'jobsBeforeRender', 'pinnedBottomSource', 'pinnedTopSource', 'plugins', 'range', 'readonly', 'registerVNode', 'resize', 'rowClass', 'rowDefinitions', 'rowHeaders', 'rowSize', 'rtl', 'sorting', 'source', 'stretch', 'theme', 'trimmedRows', 'useClipboard'],
39
39
  standalone: true
40
40
  }]
41
41
  }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i0.NgZone }] });
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItZGF0YWdyaWQvc3JjL2xpYi9jb21wb25lbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLG9CQUFvQjtBQUNwQiw4Q0FBOEM7QUFDOUMsT0FBTyxFQUFFLHVCQUF1QixFQUFxQixTQUFTLEVBQW9DLE1BQU0sZUFBZSxDQUFDO0FBRXhILE9BQU8sRUFBRSxRQUFRLEVBQUUsWUFBWSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFJdkUsT0FBTyxFQUFFLG1CQUFtQixJQUFJLGNBQWMsRUFBRSxNQUFNLDRDQUE0QyxDQUFDOztBQWM1RixJQUFNLFFBQVEsR0FBZCxNQUFNLFFBQVE7SUFFbkIsWUFBWSxDQUFvQixFQUFFLENBQWEsRUFBWSxDQUFTO1FBQVQsTUFBQyxHQUFELENBQUMsQ0FBUTtRQUNsRSxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDWCxJQUFJLENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQyxhQUFhLENBQUM7UUFDMUIsWUFBWSxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFLENBQUMsb0JBQW9CLEVBQUUsWUFBWSxFQUFFLGlCQUFpQixFQUFFLFdBQVcsRUFBRSxnQkFBZ0IsRUFBRSxhQUFhLEVBQUUsWUFBWSxFQUFFLGlCQUFpQixFQUFFLGVBQWUsRUFBRSwwQkFBMEIsRUFBRSxvQkFBb0IsRUFBRSxjQUFjLEVBQUUsYUFBYSxFQUFFLGlCQUFpQixFQUFFLGlCQUFpQixFQUFFLGlCQUFpQixFQUFFLGlCQUFpQixFQUFFLGdCQUFnQixFQUFFLGdCQUFnQixFQUFFLGtCQUFrQixFQUFFLHFCQUFxQixFQUFFLGlCQUFpQixFQUFFLG1CQUFtQixFQUFFLHFCQUFxQixFQUFFLGVBQWUsRUFBRSxjQUFjLEVBQUUsZ0JBQWdCLEVBQUUsY0FBYyxFQUFFLGlCQUFpQixFQUFFLG1CQUFtQixFQUFFLHFCQUFxQixFQUFFLHFCQUFxQixFQUFFLHNCQUFzQixFQUFFLG1CQUFtQixFQUFFLGtCQUFrQixFQUFFLGlCQUFpQixFQUFFLGVBQWUsRUFBRSx1QkFBdUIsRUFBRSxtQkFBbUIsRUFBRSxTQUFTLENBQUMsQ0FBQyxDQUFDO0lBQ3p4QixDQUFDOzhHQU5VLFFBQVE7a0dBQVIsUUFBUSwraENBTFQsMkJBQTJCOztBQUsxQixRQUFRO0lBYnBCLFFBQVEsQ0FBQztRQUNSLHFCQUFxQixFQUFFLGNBQWM7UUFDckMsTUFBTSxFQUFFLENBQUMsWUFBWSxFQUFFLGdCQUFnQixFQUFFLGNBQWMsRUFBRSxnQkFBZ0IsRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLGdCQUFnQixFQUFFLFNBQVMsRUFBRSxhQUFhLEVBQUUsU0FBUyxFQUFFLGlCQUFpQixFQUFFLGlCQUFpQixFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsUUFBUSxFQUFFLGVBQWUsRUFBRSxXQUFXLEVBQUUsVUFBVSxFQUFFLGlCQUFpQixFQUFFLGtCQUFrQixFQUFFLG9CQUFvQixFQUFFLGlCQUFpQixFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLGVBQWUsRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFFLGdCQUFnQixFQUFFLFlBQVksRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxTQUFTLEVBQUUsT0FBTyxFQUFFLGFBQWEsRUFBRSxjQUFjLENBQUM7UUFDcGhCLE9BQU8sRUFBRSxDQUFDLFNBQVMsRUFBRSxXQUFXLEVBQUUsYUFBYSxFQUFFLHFCQUFxQixFQUFFLG9CQUFvQixFQUFFLGVBQWUsRUFBRSxZQUFZLEVBQUUsb0JBQW9CLEVBQUUsYUFBYSxFQUFFLGVBQWUsRUFBRSxXQUFXLEVBQUUsa0JBQWtCLEVBQUUsZ0JBQWdCLEVBQUUsZ0JBQWdCLEVBQUUscUJBQXFCLEVBQUUsY0FBYyxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxnQkFBZ0IsRUFBRSxrQkFBa0IsRUFBRSxzQkFBc0IsRUFBRSxjQUFjLENBQUM7S0FDcmEsQ0FBQztHQVNXLFFBQVEsQ0FPcEI7OzJGQVBZLFFBQVE7a0JBUnBCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLFdBQVc7b0JBQ3JCLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO29CQUMvQyxRQUFRLEVBQUUsMkJBQTJCO29CQUNyQyx1RUFBdUU7b0JBQ3ZFLE1BQU0sRUFBRSxDQUFDLFlBQVksRUFBRSxnQkFBZ0IsRUFBRSxjQUFjLEVBQUUsZ0JBQWdCLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxnQkFBZ0IsRUFBRSxTQUFTLEVBQUUsYUFBYSxFQUFFLFNBQVMsRUFBRSxpQkFBaUIsRUFBRSxpQkFBaUIsRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLFFBQVEsRUFBRSxlQUFlLEVBQUUsV0FBVyxFQUFFLFVBQVUsRUFBRSxpQkFBaUIsRUFBRSxrQkFBa0IsRUFBRSxvQkFBb0IsRUFBRSxpQkFBaUIsRUFBRSxTQUFTLEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBRSxlQUFlLEVBQUUsUUFBUSxFQUFFLFVBQVUsRUFBRSxnQkFBZ0IsRUFBRSxZQUFZLEVBQUUsU0FBUyxFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRSxhQUFhLEVBQUUsY0FBYyxDQUFDO29CQUNwaEIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiLyogdHNsaW50OmRpc2FibGUgKi9cbi8qIGF1dG8tZ2VuZXJhdGVkIGFuZ3VsYXIgZGlyZWN0aXZlIHByb3hpZXMgKi9cbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDaGFuZ2VEZXRlY3RvclJlZiwgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBFdmVudEVtaXR0ZXIsIE5nWm9uZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBQcm94eUNtcCwgcHJveHlPdXRwdXRzIH0gZnJvbSAnLi9hbmd1bGFyLWNvbXBvbmVudC1saWIvdXRpbHMnO1xuXG5pbXBvcnQgdHlwZSB7IENvbXBvbmVudHMgfSBmcm9tICdAcmV2b2xpc3QvcmV2b2dyaWQvc3RhbmRhbG9uZSc7XG5cbmltcG9ydCB7IGRlZmluZUN1c3RvbUVsZW1lbnQgYXMgZGVmaW5lUmV2b0dyaWQgfSBmcm9tICdAcmV2b2xpc3QvcmV2b2dyaWQvc3RhbmRhbG9uZS9yZXZvLWdyaWQuanMnO1xuQFByb3h5Q21wKHtcbiAgZGVmaW5lQ3VzdG9tRWxlbWVudEZuOiBkZWZpbmVSZXZvR3JpZCxcbiAgaW5wdXRzOiBbJ2FjY2Vzc2libGUnLCAnYWRkaXRpb25hbERhdGEnLCAnYXBwbHlPbkNsb3NlJywgJ2F1dG9TaXplQ29sdW1uJywgJ2NhbkRyYWcnLCAnY2FuRm9jdXMnLCAnY2FuTW92ZUNvbHVtbnMnLCAnY29sU2l6ZScsICdjb2x1bW5UeXBlcycsICdjb2x1bW5zJywgJ2Rpc2FibGVWaXJ0dWFsWCcsICdkaXNhYmxlVmlydHVhbFknLCAnZWRpdG9ycycsICdleHBvcnRpbmcnLCAnZmlsdGVyJywgJ2ZvY3VzVGVtcGxhdGUnLCAnZnJhbWVTaXplJywgJ2dyb3VwaW5nJywgJ2hpZGVBdHRyaWJ1dGlvbicsICdqb2JzQmVmb3JlUmVuZGVyJywgJ3Bpbm5lZEJvdHRvbVNvdXJjZScsICdwaW5uZWRUb3BTb3VyY2UnLCAncGx1Z2lucycsICdyYW5nZScsICdyZWFkb25seScsICdyZWdpc3RlclZOb2RlJywgJ3Jlc2l6ZScsICdyb3dDbGFzcycsICdyb3dEZWZpbml0aW9ucycsICdyb3dIZWFkZXJzJywgJ3Jvd1NpemUnLCAnc29ydGluZycsICdzb3VyY2UnLCAnc3RyZXRjaCcsICd0aGVtZScsICd0cmltbWVkUm93cycsICd1c2VDbGlwYm9hcmQnXSxcbiAgbWV0aG9kczogWydyZWZyZXNoJywgJ3NldERhdGFBdCcsICdzY3JvbGxUb1JvdycsICdzY3JvbGxUb0NvbHVtbkluZGV4JywgJ3Njcm9sbFRvQ29sdW1uUHJvcCcsICd1cGRhdGVDb2x1bW5zJywgJ2FkZFRyaW1tZWQnLCAnc2Nyb2xsVG9Db29yZGluYXRlJywgJ3NldENlbGxFZGl0JywgJ3NldENlbGxzRm9jdXMnLCAnZ2V0U291cmNlJywgJ2dldFZpc2libGVTb3VyY2UnLCAnZ2V0U291cmNlU3RvcmUnLCAnZ2V0Q29sdW1uU3RvcmUnLCAndXBkYXRlQ29sdW1uU29ydGluZycsICdjbGVhclNvcnRpbmcnLCAnZ2V0Q29sdW1ucycsICdjbGVhckZvY3VzJywgJ2dldFBsdWdpbnMnLCAnZ2V0Rm9jdXNlZCcsICdnZXRDb250ZW50U2l6ZScsICdnZXRTZWxlY3RlZFJhbmdlJywgJ3JlZnJlc2hFeHRyYUVsZW1lbnRzJywgJ2dldFByb3ZpZGVycyddXG59KVxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncmV2by1ncmlkJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHRlbXBsYXRlOiAnPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PicsXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAYW5ndWxhci1lc2xpbnQvbm8taW5wdXRzLW1ldGFkYXRhLXByb3BlcnR5XG4gIGlucHV0czogWydhY2Nlc3NpYmxlJywgJ2FkZGl0aW9uYWxEYXRhJywgJ2FwcGx5T25DbG9zZScsICdhdXRvU2l6ZUNvbHVtbicsICdjYW5EcmFnJywgJ2NhbkZvY3VzJywgJ2Nhbk1vdmVDb2x1bW5zJywgJ2NvbFNpemUnLCAnY29sdW1uVHlwZXMnLCAnY29sdW1ucycsICdkaXNhYmxlVmlydHVhbFgnLCAnZGlzYWJsZVZpcnR1YWxZJywgJ2VkaXRvcnMnLCAnZXhwb3J0aW5nJywgJ2ZpbHRlcicsICdmb2N1c1RlbXBsYXRlJywgJ2ZyYW1lU2l6ZScsICdncm91cGluZycsICdoaWRlQXR0cmlidXRpb24nLCAnam9ic0JlZm9yZVJlbmRlcicsICdwaW5uZWRCb3R0b21Tb3VyY2UnLCAncGlubmVkVG9wU291cmNlJywgJ3BsdWdpbnMnLCAncmFuZ2UnLCAncmVhZG9ubHknLCAncmVnaXN0ZXJWTm9kZScsICdyZXNpemUnLCAncm93Q2xhc3MnLCAncm93RGVmaW5pdGlvbnMnLCAncm93SGVhZGVycycsICdyb3dTaXplJywgJ3NvcnRpbmcnLCAnc291cmNlJywgJ3N0cmV0Y2gnLCAndGhlbWUnLCAndHJpbW1lZFJvd3MnLCAndXNlQ2xpcGJvYXJkJ10sXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgUmV2b0dyaWQge1xuICBwcm90ZWN0ZWQgZWw6IEhUTUxFbGVtZW50O1xuICBjb25zdHJ1Y3RvcihjOiBDaGFuZ2VEZXRlY3RvclJlZiwgcjogRWxlbWVudFJlZiwgcHJvdGVjdGVkIHo6IE5nWm9uZSkge1xuICAgIGMuZGV0YWNoKCk7XG4gICAgdGhpcy5lbCA9IHIubmF0aXZlRWxlbWVudDtcbiAgICBwcm94eU91dHB1dHModGhpcywgdGhpcy5lbCwgWydjb250ZW50c2l6ZWNoYW5nZWQnLCAnYmVmb3JlZWRpdCcsICdiZWZvcmVyYW5nZWVkaXQnLCAnYWZ0ZXJlZGl0JywgJ2JlZm9yZWF1dG9maWxsJywgJ2JlZm9yZXJhbmdlJywgJ2FmdGVyZm9jdXMnLCAncm93b3JkZXJjaGFuZ2VkJywgJ2JlZm9yZXNvcnRpbmcnLCAnYmVmb3Jlc291cmNlc29ydGluZ2FwcGx5JywgJ2JlZm9yZXNvcnRpbmdhcHBseScsICdyb3dkcmFnc3RhcnQnLCAnaGVhZGVyY2xpY2snLCAnYmVmb3JlY2VsbGZvY3VzJywgJ2JlZm9yZWZvY3VzbG9zdCcsICdiZWZvcmVzb3VyY2VzZXQnLCAnYmVmb3JlYW55c291cmNlJywgJ2FmdGVyc291cmNlc2V0JywgJ2FmdGVyYW55c291cmNlJywgJ2JlZm9yZWNvbHVtbnNzZXQnLCAnYmVmb3JlY29sdW1uYXBwbGllZCcsICdhZnRlcmNvbHVtbnNzZXQnLCAnYmVmb3JlZmlsdGVyYXBwbHknLCAnYmVmb3JlZmlsdGVydHJpbW1lZCcsICdiZWZvcmV0cmltbWVkJywgJ2FmdGVydHJpbW1lZCcsICd2aWV3cG9ydHNjcm9sbCcsICdiZWZvcmVleHBvcnQnLCAnYmVmb3JlZWRpdHN0YXJ0JywgJ2FmdGVyY29sdW1ucmVzaXplJywgJ2JlZm9yZXJvd2RlZmluaXRpb24nLCAnZmlsdGVyY29uZmlnY2hhbmdlZCcsICdzb3J0aW5nY29uZmlnY2hhbmdlZCcsICdyb3doZWFkZXJzY2hhbmdlZCcsICdiZWZvcmVncmlkcmVuZGVyJywgJ2FmdGVyZ3JpZHJlbmRlcicsICdhZnRlcmdyaWRpbml0JywgJ2FkZGl0aW9uYWxkYXRhY2hhbmdlZCcsICdhZnRlcnRoZW1lY2hhbmdlZCcsICdjcmVhdGVkJ10pO1xuICB9XG59XG5cblxuaW1wb3J0IHR5cGUgeyBNdWx0aURpbWVuc2lvblR5cGUgYXMgSVJldm9HcmlkTXVsdGlEaW1lbnNpb25UeXBlIH0gZnJvbSAnQHJldm9saXN0L3Jldm9ncmlkL3N0YW5kYWxvbmUnO1xuaW1wb3J0IHR5cGUgeyBCZWZvcmVTYXZlRGF0YURldGFpbHMgYXMgSVJldm9HcmlkQmVmb3JlU2F2ZURhdGFEZXRhaWxzIH0gZnJvbSAnQHJldm9saXN0L3Jldm9ncmlkL3N0YW5kYWxvbmUnO1xuaW1wb3J0IHR5cGUgeyBCZWZvcmVSYW5nZVNhdmVEYXRhRGV0YWlscyBhcyBJUmV2b0dyaWRCZWZvcmVSYW5nZVNhdmVEYXRhRGV0YWlscyB9IGZyb20gJ0ByZXZvbGlzdC9yZXZvZ3JpZC9zdGFuZGFsb25lJztcbmltcG9ydCB0eXBlIHsgQWZ0ZXJFZGl0RXZlbnQgYXMgSVJldm9HcmlkQWZ0ZXJFZGl0RXZlbnQgfSBmcm9tICdAcmV2b2xpc3QvcmV2b2dyaWQvc3RhbmRhbG9uZSc7XG5pbXBvcnQgdHlwZSB7IENoYW5nZWRSYW5nZSBhcyBJUmV2b0dyaWRDaGFuZ2VkUmFuZ2UgfSBmcm9tICdAcmV2b2xpc3QvcmV2b2dyaWQvc3RhbmRhbG9uZSc7XG5pbXBvcnQgdHlwZSB7IEZvY3VzQWZ0ZXJSZW5kZXJFdmVudCBhcyBJUmV2b0dyaWRGb2N1c0FmdGVyUmVuZGVyRXZlbnQgfSBmcm9tICdAcmV2b2xpc3QvcmV2b2dyaWQvc3RhbmRhbG9uZSc7XG5pbXBvcnQgdHlwZSB7IENvbHVtblJlZ3VsYXIgYXMgSVJldm9HcmlkQ29sdW1uUmVndWxhciB9IGZyb20gJ0ByZXZvbGlzdC9yZXZvZ3JpZC9zdGFuZGFsb25lJztcbmltcG9ydCB0eXBlIHsgRGltZW5zaW9uUm93cyBhcyBJUmV2b0dyaWREaW1lbnNpb25Sb3dzIH0gZnJvbSAnQHJldm9saXN0L3Jldm9ncmlkL3N0YW5kYWxvbmUnO1xuaW1wb3J0IHR5cGUgeyBTb3J0aW5nT3JkZXIgYXMgSVJldm9HcmlkU29ydGluZ09yZGVyIH0gZnJvbSAnQHJldm9saXN0L3Jldm9ncmlkL3N0YW5kYWxvbmUnO1xuaW1wb3J0IHR5cGUgeyBSb3dEcmFnU3RhcnREZXRhaWxzIGFzIElSZXZvR3JpZFJvd0RyYWdTdGFydERldGFpbHMgfSBmcm9tICdAcmV2b2xpc3QvcmV2b2dyaWQvc3RhbmRhbG9uZSc7XG5pbXBvcnQgdHlwZSB7IEZvY3VzZWREYXRhIGFzIElSZXZvR3JpZEZvY3VzZWREYXRhIH0gZnJvbSAnQHJldm9saXN0L3Jldm9ncmlkL3N0YW5kYWxvbmUnO1xuaW1wb3J0IHR5cGUgeyBEYXRhVHlwZSBhcyBJUmV2b0dyaWREYXRhVHlwZSB9IGZyb20gJ0ByZXZvbGlzdC9yZXZvZ3JpZC9zdGFuZGFsb25lJztcbmltcG9ydCB0eXBlIHsgQ29sdW1uQ29sbGVjdGlvbiBhcyBJUmV2b0dyaWRDb2x1bW5Db2xsZWN0aW9uIH0gZnJvbSAnQHJldm9saXN0L3Jldm9ncmlkL3N0YW5kYWxvbmUnO1xuaW1wb3J0IHR5cGUgeyBDb2x1bW5Qcm9wIGFzIElSZXZvR3JpZENvbHVtblByb3AgfSBmcm9tICdAcmV2b2xpc3QvcmV2b2dyaWQvc3RhbmRhbG9uZSc7XG5pbXBvcnQgdHlwZSB7IEZpbHRlckNvbGxlY3Rpb25JdGVtIGFzIElSZXZvR3JpZEZpbHRlckNvbGxlY3Rpb25JdGVtIH0gZnJvbSAnQHJldm9saXN0L3Jldm9ncmlkL3N0YW5kYWxvbmUnO1xuaW1wb3J0IHR5cGUgeyBWaWV3UG9ydFNjcm9sbEV2ZW50IGFzIElSZXZvR3JpZFZpZXdQb3J0U2Nyb2xsRXZlbnQgfSBmcm9tICdAcmV2b2xpc3QvcmV2b2dyaWQvc3RhbmRhbG9uZSc7XG5pbXBvcnQgdHlwZSB7IERhdGFJbnB1dCBhcyBJUmV2b0dyaWREYXRhSW5wdXQgfSBmcm9tICdAcmV2b2xpc3QvcmV2b2dyaWQvc3RhbmRhbG9uZSc7XG5pbXBvcnQgdHlwZSB7IFNvcnRpbmdDb25maWcgYXMgSVJldm9HcmlkU29ydGluZ0NvbmZpZyB9IGZyb20gJ0ByZXZvbGlzdC9yZXZvZ3JpZC9zdGFuZGFsb25lJztcbmltcG9ydCB0eXBlIHsgVGhlbWUgYXMgSVJldm9HcmlkVGhlbWUgfSBmcm9tICdAcmV2b2xpc3QvcmV2b2dyaWQvc3RhbmRhbG9uZSc7XG5cbmV4cG9ydCBkZWNsYXJlIGludGVyZmFjZSBSZXZvR3JpZCBleHRlbmRzIENvbXBvbmVudHMuUmV2b0dyaWQge1xuICAvKipcbiAgICogTmV3IGNvbnRlbnQgc2l6ZSBoYXMgYmVlbiBhcHBsaWVkLiBUaGUgc2l6ZSBleGNsdWRlcyB0aGUgaGVhZGVyLlxuQ3VycmVudGx5LCB0aGUgZXZlbnQgcmVzcG9uc2libGUgZm9yIGFwcGx5aW5nIHRoZSBuZXcgY29udGVudCBzaXplIGRvZXMgbm90IHByb3ZpZGUgdGhlIGFjdHVhbCBzaXplLlxuVG8gcmV0cmlldmUgdGhlIGFjdHVhbCBjb250ZW50IHNpemUsIHlvdSBjYW4gdXRpbGl6ZSB0aGUgYGdldENvbnRlbnRTaXplYCBmdW5jdGlvbiBhZnRlciB0aGUgZXZlbnQgaGFzIGJlZW4gdHJpZ2dlcmVkLlxuICAgKi9cbiAgY29udGVudHNpemVjaGFuZ2VkOiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8SVJldm9HcmlkTXVsdGlEaW1lbnNpb25UeXBlPj47XG4gIC8qKlxuICAgKiBCZWZvcmUgdGhlIGRhdGEgaXMgZWRpdGVkLlxuVG8gcHJldmVudCB0aGUgZGVmYXVsdCBiZWhhdmlvciBvZiBlZGl0aW5nIGRhdGEgYW5kIHVzZSB5b3VyIG93biBpbXBsZW1lbnRhdGlvbiwgY2FsbCBgZS5wcmV2ZW50RGVmYXVsdCgpYC5cblRvIG92ZXJyaWRlIHRoZSBlZGl0IHJlc3VsdCB3aXRoIHlvdXIgb3duIHZhbHVlLCBzZXQgdGhlIGBlLnZhbGAgcHJvcGVydHkgdG8geW91ciBkZXNpcmVkIHZhbHVlLlxuICAgKi9cbiAgYmVmb3JlZWRpdDogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PElSZXZvR3JpZEJlZm9yZVNhdmVEYXRhRGV0YWlscz4+O1xuICAvKipcbiAgICogQmVmb3JlIGFwcGx5aW5nIHJhbmdlIGRhdGEsIHNwZWNpZmljYWxseSB3aGVuIGEgcmFuZ2Ugc2VsZWN0aW9uIG9jY3Vycy5cblRvIGN1c3RvbWl6ZSB0aGUgZGF0YSBhbmQgcHJldmVudCB0aGUgZGVmYXVsdCBlZGl0IGRhdGEgZnJvbSBiZWluZyBzZXQsIHlvdSBjYW4gY2FsbCBgZS5wcmV2ZW50RGVmYXVsdCgpYC5cbiAgICovXG4gIGJlZm9yZXJhbmdlZWRpdDogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PElSZXZvR3JpZEJlZm9yZVJhbmdlU2F2ZURhdGFEZXRhaWxzPj47XG4gIC8qKlxuICAgKiBBZnRlciBkYXRhIGFwcGxpZWQgb3IgcmFuZ2UgY2hhbmdlZC5cbiAgICovXG4gIGFmdGVyZWRpdDogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PElSZXZvR3JpZEFmdGVyRWRpdEV2ZW50Pj47XG4gIC8qKlxuICAgKiBCZWZvcmUgYXV0b2ZpbGwgaXMgYXBwbGllZC5cblRvIHByZXZlbnQgdGhlIGRlZmF1bHQgYmVoYXZpb3Igb2YgYXBwbHlpbmcgdGhlIGVkaXQgZGF0YSwgeW91IGNhbiBjYWxsIGBlLnByZXZlbnREZWZhdWx0KClgLlxuICAgKi9cbiAgYmVmb3JlYXV0b2ZpbGw6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDxJUmV2b0dyaWRDaGFuZ2VkUmFuZ2U+PjtcbiAgLyoqXG4gICAqIEJlZm9yZSBhdXRvZmlsbCBpcyBhcHBsaWVkLiBSdW5zIGJlZm9yZSBiZWZvcmVhdXRvZmlsbCBldmVudC5cblVzZSBlLnByZXZlbnREZWZhdWx0KCkgdG8gcHJldmVudCByYW5nZS5cbiAgICovXG4gIGJlZm9yZXJhbmdlOiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8SVJldm9HcmlkQ2hhbmdlZFJhbmdlPj47XG4gIC8qKlxuICAgKiBBZnRlciBmb2N1cyByZW5kZXIgZmluaXNoZWQuXG5DYW4gYmUgdXNlZCB0byBhY2Nlc3MgYSBmb2N1cyBlbGVtZW50IHRocm91Z2ggYGV2ZW50LnRhcmdldGAuXG5UaGlzIGlzIGp1c3QgYSBkdXBsaWNhdGUgb2YgYGFmdGVyZm9jdXNgIGZyb20gYHJldm9nci1mb2N1cy50c3hgLlxuICAgKi9cbiAgYWZ0ZXJmb2N1czogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PElSZXZvR3JpZEZvY3VzQWZ0ZXJSZW5kZXJFdmVudD4+O1xuICAvKipcbiAgICogQmVmb3JlIHRoZSBvcmRlciBvZiBgcmdSb3dgIGlzIGFwcGxpZWQuXG5UbyBwcmV2ZW50IHRoZSBkZWZhdWx0IGJlaGF2aW9yIG9mIGNoYW5naW5nIHRoZSBvcmRlciBvZiBgcmdSb3dgLCB5b3UgY2FuIGNhbGwgYGUucHJldmVudERlZmF1bHQoKWAuXG4gICAqL1xuICByb3dvcmRlcmNoYW5nZWQ6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDx7IGZyb206IG51bWJlcjsgdG86IG51bWJlciB9Pj47XG4gIC8qKlxuICAgKiBCeSBgU29ydGluZ1BsdWdpbmBcbjxicj5UcmlnZ2VyZWQgaW1tZWRpYXRlbHkgYWZ0ZXIgaGVhZGVyIGNsaWNrLlxuPGJyPkZpcnN0IGluIHNvcnRpbmcgZXZlbnQgc2VxdWVuY2UuIEZmIHRoaXMgZXZlbnQgc3RvcHMgbm8gb3RoZXIgZXZlbnQgY2FsbGVkLlxuPGJyPlVzZSBgZS5wcmV2ZW50RGVmYXVsdCgpYCB0byBwcmV2ZW50IHNvcnRpbmcuXG4gICAqL1xuICBiZWZvcmVzb3J0aW5nOiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8eyBjb2x1bW46IElSZXZvR3JpZENvbHVtblJlZ3VsYXI7IG9yZGVyOiAnZGVzYycgfCAnYXNjJzsgYWRkaXRpdmU6IGJvb2xlYW47IH0+PjtcbiAgLyoqXG4gICAqIEJ5IGBTb3J0aW5nUGx1Z2luYFxuPGJyPlNhbWUgYXMgYGJlZm9yZXNvcnRpbmdgIGJ1dCB0cmlnZ2VyZWQgYWZ0ZXIgYGJlZm9yZWFueXNvdXJjZWAgKHdoZW4gc291cmNlIGlzIGNoYW5nZWQpLlxuPGJyPlVzZSBgZS5wcmV2ZW50RGVmYXVsdCgpYCB0byBwcmV2ZW50IHNvcnRpbmcgZGF0YSBjaGFuZ2UuXG4gICAqL1xuICBiZWZvcmVzb3VyY2Vzb3J0aW5nYXBwbHk6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDx7IHR5cGU6IElSZXZvR3JpZERpbWVuc2lvblJvd3M7IHNvcnRpbmc/OiBJUmV2b0dyaWRTb3J0aW5nT3JkZXI7IH0+PjtcbiAgLyoqXG4gICAqIEJ5IGBTb3J0aW5nUGx1Z2luYFxuPGJyPiBBZnRlciBgYmVmb3Jlc29ydGluZ2Bcbjxicj5UcmlnZ2VyZWQgYWZ0ZXIgY29sdW1uIGRhdGEgdXBkYXRlZCB3aXRoIG5ldyBzb3J0aW5nIG9yZGVyLlxuPGJyPlVzZSBgZS5wcmV2ZW50RGVmYXVsdCgpYCB0byBwcmV2ZW50IHNvcnRpbmcgZGF0YSBjaGFuZ2UuXG4gICAqL1xuICBiZWZvcmVzb3J0aW5nYXBwbHk6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDx7IGNvbHVtbjogSVJldm9HcmlkQ29sdW1uUmVndWxhcjsgb3JkZXI6ICdkZXNjJyB8ICdhc2MnOyBhZGRpdGl2ZTogYm9vbGVhbjsgfT4+O1xuICAvKipcbiAgICogVGhpcyBldmVudCBpcyB0cmlnZ2VyZWQgd2hlbiB0aGUgcm93IG9yZGVyIGNoYW5nZSBpcyBzdGFydGVkLlxuVG8gcHJldmVudCB0aGUgZGVmYXVsdCBiZWhhdmlvciBvZiBjaGFuZ2luZyB0aGUgcm93IG9yZGVyLCB5b3UgY2FuIGNhbGwgYGUucHJldmVudERlZmF1bHQoKWAuXG5UbyBjaGFuZ2UgdGhlIGl0ZW0gbmFtZSBhdCB0aGUgc3RhcnQgb2YgdGhlIHJvdyBvcmRlciBjaGFuZ2UsIHlvdSBjYW4gc2V0IGBlLnRleHRgIHRvIHRoZSBkZXNpcmVkIG5ldyBuYW1lLlxuICAgKi9cbiAgcm93ZHJhZ3N0YXJ0OiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8SVJldm9HcmlkUm93RHJhZ1N0YXJ0RGV0YWlscz4+O1xuICAvKipcbiAgICogT24gaGVhZGVyIGNsaWNrLlxuICAgKi9cbiAgaGVhZGVyY2xpY2s6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDxJUmV2b0dyaWRDb2x1bW5SZWd1bGFyPj47XG4gIC8qKlxuICAgKiBCZWZvcmUgdGhlIGNlbGwgZm9jdXMgaXMgY2hhbmdlZC5cblRvIHByZXZlbnQgdGhlIGRlZmF1bHQgYmVoYXZpb3Igb2YgY2hhbmdpbmcgdGhlIGNlbGwgZm9jdXMsIHlvdSBjYW4gY2FsbCBgZS5wcmV2ZW50RGVmYXVsdCgpYC5cbiAgICovXG4gIGJlZm9yZWNlbGxmb2N1czogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PElSZXZvR3JpZEJlZm9yZVNhdmVEYXRhRGV0YWlscz4+O1xuICAvKipcbiAgICogQmVmb3JlIHRoZSBncmlkIGZvY3VzIGlzIGxvc3QuXG5UbyBwcmV2ZW50IHRoZSBkZWZhdWx0IGJlaGF2aW9yIG9mIGNoYW5naW5nIHRoZSBjZWxsIGZvY3VzLCB5b3UgY2FuIGNhbGwgYGUucHJldmVudERlZmF1bHQoKWAuXG4gICAqL1xuICBiZWZvcmVmb2N1c2xvc3Q6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDxJUmV2b0dyaWRGb2N1c2VkRGF0YSB8IG51bGw+PjtcbiAgLyoqXG4gICAqIEJlZm9yZSBtYWluIHNvdXJjZS9yb3dzIGRhdGEgYXBwbHkuXG5Zb3UgY2FuIG92ZXJyaWRlIGRhdGEgc291cmNlIGhlcmVcbiAgICovXG4gIGJlZm9yZXNvdXJjZXNldDogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PHsgdHlwZTogSVJldm9HcmlkRGltZW5zaW9uUm93czsgc291cmNlOiBJUmV2b0dyaWREYXRhVHlwZVtdOyB9Pj47XG4gIC8qKlxuICAgKiBCZWZvcmUgZGF0YSBhcHBseSBvbiBhbnkgc291cmNlIHR5cGUuIENhbiBiZSBzb3VyY2UgZnJvbSBwaW5uZWQgYW5kIG1haW4gdmlld3BvcnQuXG5Zb3UgY2FuIG92ZXJyaWRlIGRhdGEgc291cmNlIGhlcmVcbiAgICovXG4gIGJlZm9yZWFueXNvdXJjZTogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PHsgdHlwZTogSVJldm9HcmlkRGltZW5zaW9uUm93czsgc291cmNlOiBJUmV2b0dyaWREYXRhVHlwZVtdOyB9Pj47XG4gIC8qKlxuICAgKiBBZnRlciBtYWluIHNvdXJjZS9yb3dzIHVwZGF0ZWRcbiAgICovXG4gIGFmdGVyc291cmNlc2V0OiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8eyB0eXBlOiBJUmV2b0dyaWREaW1lbnNpb25Sb3dzOyBzb3VyY2U6IElSZXZvR3JpZERhdGFUeXBlW107IH0+PjtcbiAgLyoqXG4gICAqIEVtaXR0ZWQgYWZ0ZXIgZWFjaCBzb3VyY2UgdXBkYXRlLCB3aGV0aGVyIGZyb20gdGhlIHBpbm5lZCBvciBtYWluIHZpZXdwb3J0LlxuVXNlZnVsIGZvciB0cmFja2luZyBhbGwgY2hhbmdlcyBvcmlnaW5hdGluZyBmcm9tIHNvdXJjZXMgaW4gYm90aCB0aGUgcGlubmVkIGFuZCBtYWluIHZpZXdwb3J0cy5cbiAgICovXG4gIGFmdGVyYW55c291cmNlOiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8eyB0eXBlOiBJUmV2b0dyaWREaW1lbnNpb25Sb3dzOyBzb3VyY2U6IElSZXZvR3JpZERhdGFUeXBlW107IH0+PjtcbiAgLyoqXG4gICAqIEVtaXR0ZWQgYmVmb3JlIGEgY29sdW1uIHVwZGF0ZSBpcyBhcHBsaWVkLlxuTGlzdGVuZXJzIGNhbiB1c2UgdGhpcyBldmVudCB0byBwZXJmb3JtIGFueSBuZWNlc3NhcnkgYWN0aW9ucyBvciBtb2RpZmljYXRpb25zIGJlZm9yZSB0aGUgY29sdW1uIHVwZGF0ZSBpcyBmaW5hbGl6ZWQuXG4gICAqL1xuICBiZWZvcmVjb2x1bW5zc2V0OiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8SVJldm9HcmlkQ29sdW1uQ29sbGVjdGlvbj4+O1xuICAvKipcbiAgICogRW1pdHRlZCBiZWZvcmUgYSBjb2x1bW4gdXBkYXRlIGlzIGFwcGxpZWQsIGFmdGVyIHRoZSBjb2x1bW4gc2V0IGlzIGdhdGhlcmVkIGFuZCB0aGUgdmlld3BvcnQgaXMgdXBkYXRlZC5cblVzZWZ1bCBmb3IgcGVyZm9ybWluZyBhY3Rpb25zIG9yIG1vZGlmaWNhdGlvbnMgYmVmb3JlIHRoZSBmaW5hbCBhcHBsaWNhdGlvbiBvZiB0aGUgY29sdW1uIHVwZGF0ZS5cbiAgICovXG4gIGJlZm9yZWNvbHVtbmFwcGxpZWQ6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDxJUmV2b0dyaWRDb2x1bW5Db2xsZWN0aW9uPj47XG4gIC8qKlxuICAgKiBDb2x1bW4gdXBkYXRlZFxuICAgKi9cbiAgYWZ0ZXJjb2x1bW5zc2V0OiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8eyBjb2x1bW5zOiBJUmV2b0dyaWRDb2x1bW5Db2xsZWN0aW9uOyBvcmRlcjogSVJldm9HcmlkU29ydGluZ09yZGVyOyB9Pj47XG4gIC8qKlxuICAgKiBFbWl0dGVkIGJlZm9yZSBhcHBseWluZyBhIGZpbHRlciB0byB0aGUgZGF0YSBzb3VyY2UuXG5Vc2UgZS5wcmV2ZW50RGVmYXVsdCgpIHRvIHByZXZlbnQgY2VsbCBmb2N1cyBjaGFuZ2UuXG5Nb2RpZnkgaWYgeW91IG5lZWQgdG8gY2hhbmdlIGZpbHRlcnMuXG4gICAqL1xuICBiZWZvcmVmaWx0ZXJhcHBseTogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PHsgY29sbGVjdGlvbjogUmVjb3JkPElSZXZvR3JpZENvbHVtblByb3AsIElSZXZvR3JpZEZpbHRlckNvbGxlY3Rpb25JdGVtPiB9Pj47XG4gIC8qKlxuICAgKiBFbWl0dGVkIGJlZm9yZSBhcHBseWluZyBhIGZpbHRlciB0byB0aGUgZGF0YSBzb3VyY2UuXG5Vc2UgZS5wcmV2ZW50RGVmYXVsdCgpIHRvIHByZXZlbnQgdGhlIGRlZmF1bHQgYmVoYXZpb3Igb2YgdHJpbW1pbmcgdmFsdWVzIGFuZCBhcHBseWluZyB0aGUgZmlsdGVyLlxuTW9kaWZ5IHRoZSBgY29sbGVjdGlvbmAgcHJvcGVydHkgaWYgeW91IHdhbnQgdG8gY2hhbmdlIHRoZSBmaWx0ZXJzLlxuTW9kaWZ5IHRoZSBgaXRlbXNUb0ZpbHRlcmAgcHJvcGVydHkgaWYgeW91IHdhbnQgdG8gZmlsdGVyIHRoZSBpbmRleGVzIGZvciB0cmltbWluZy5cbiAgICovXG4gIGJlZm9yZWZpbHRlcnRyaW1tZWQ6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDx7IGNvbGxlY3Rpb246IFJlY29yZDxJUmV2b0dyaWRDb2x1bW5Qcm9wLCBJUmV2b0dyaWRGaWx0ZXJDb2xsZWN0aW9uSXRlbT47IGl0ZW1zVG9GaWx0ZXI6IFJlY29yZDxudW1iZXIsIGJvb2xlYW4+OyB9Pj47XG4gIC8qKlxuICAgKiBFbWl0dGVkIGJlZm9yZSB0cmltbWluZyB2YWx1ZXMuXG5Vc2UgZS5wcmV2ZW50RGVmYXVsdCgpIHRvIHByZXZlbnQgdGhlIGRlZmF1bHQgYmVoYXZpb3Igb2YgdHJpbW1pbmcgdmFsdWVzLlxuTW9kaWZ5IHRoZSBgdHJpbW1lZGAgcHJvcGVydHkgaWYgeW91IHdhbnQgdG8gZmlsdGVyIHRoZSBpbmRleGVzIGZvciB0cmltbWluZy5cbiAgICovXG4gIGJlZm9yZXRyaW1tZWQ6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDx7IHRyaW1tZWQ6IFJlY29yZDxudW1iZXIsIGJvb2xlYW4+OyB0cmltbWVkVHlwZTogc3RyaW5nOyB0eXBlOiBzdHJpbmc7IH0+PjtcbiAgLyoqXG4gICAqIEVtaXR0ZWQgYWZ0ZXIgdHJpbW1lZCB2YWx1ZXMgaGF2ZSBiZWVuIGFwcGxpZWQuXG5Vc2VmdWwgZm9yIG5vdGlmeWluZyB3aGVuIHRyaW1taW5nIG9mIHZhbHVlcyBoYXMgdGFrZW4gcGxhY2UuXG4gICAqL1xuICBhZnRlcnRyaW1tZWQ6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDxhbnk+PjtcbiAgLyoqXG4gICAqIEVtaXR0ZWQgd2hlbiB0aGUgdmlld3BvcnQgaXMgc2Nyb2xsZWQuXG5Vc2VmdWwgZm9yIHRyYWNraW5nIHZpZXdwb3J0IHNjcm9sbGluZyBldmVudHMuXG4gICAqL1xuICB2aWV3cG9ydHNjcm9sbDogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PElSZXZvR3JpZFZpZXdQb3J0U2Nyb2xsRXZlbnQ+PjtcbiAgLyoqXG4gICAqIEJlZm9yZSBleHBvcnRcblVzZSBlLnByZXZlbnREZWZhdWx0KCkgdG8gcHJldmVudCBleHBvcnRcblJlcGxhY2UgZGF0YSBpbiBFdmVudCBpbiBjYXNlIHlvdSB3YW50IHRvIG1vZGlmeSBpdCBpbiBleHBvcnRcbiAgICovXG4gIGJlZm9yZWV4cG9ydDogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PElSZXZvR3JpZERhdGFJbnB1dD4+O1xuICAvKipcbiAgICogRW1pdHRlZCBiZWZvcmUgZWRpdGluZyBzdGFydHMuXG5Vc2UgZS5wcmV2ZW50RGVmYXVsdCgpIHRvIHByZXZlbnQgdGhlIGRlZmF1bHQgZWRpdCBiZWhhdmlvci5cbiAgICovXG4gIGJlZm9yZWVkaXRzdGFydDogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PElSZXZvR3JpZEJlZm9yZVNhdmVEYXRhRGV0YWlscz4+O1xuICAvKipcbiAgICogRW1pdHRlZCBhZnRlciBjb2x1bW4gcmVzaXppbmcuXG5Vc2VmdWwgZm9yIHJldHJpZXZpbmcgdGhlIHJlc2l6ZWQgY29sdW1ucy5cbiAgICovXG4gIGFmdGVyY29sdW1ucmVzaXplOiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8eyBbaW5kZXg6IG51bWJlcl06IElSZXZvR3JpZENvbHVtblJlZ3VsYXI7IH0+PjtcbiAgLyoqXG4gICAqIEVtaXR0ZWQgYmVmb3JlIHRoZSByb3cgZGVmaW5pdGlvbiBpcyBhcHBsaWVkLlxuVXNlZnVsIGZvciBtb2RpZnlpbmcgb3IgcHJldmVudGluZyB0aGUgZGVmYXVsdCByb3cgZGVmaW5pdGlvbiBiZWhhdmlvci5cbiAgICovXG4gIGJlZm9yZXJvd2RlZmluaXRpb246IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDx7IHZhbHM6IGFueTsgb2xkVmFsczogYW55IH0+PjtcbiAgLyoqXG4gICAqIEVtaXR0ZWQgd2hlbiB0aGUgZmlsdGVyIGNvbmZpZ3VyYXRpb24gaXMgY2hhbmdlZFxuICAgKi9cbiAgZmlsdGVyY29uZmlnY2hhbmdlZDogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PGFueT4+O1xuICAvKipcbiAgICogRW1pdHRlZCB3aGVuIHRoZSBzb3J0aW5nIGNvbmZpZ3VyYXRpb24gaXMgY2hhbmdlZFxuU29ydGluZ1BsdWdpbiBzdWJzcmliZWQgdG8gdGhpcyBldmVudFxuICAgKi9cbiAgc29ydGluZ2NvbmZpZ2NoYW5nZWQ6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDxJUmV2b0dyaWRTb3J0aW5nQ29uZmlnPj47XG4gIC8qKlxuICAgKiBFbW1pdGVkIHdoZW4gdGhlIHJvdyBoZWFkZXJzIGFyZSBjaGFuZ2VkLlxuICAgKi9cbiAgcm93aGVhZGVyc2NoYW5nZWQ6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDxhbnk+PjtcbiAgLyoqXG4gICAqIEVtbWl0ZWQgYmVmb3JlIHRoZSBncmlkIGlzIHJlbmRlcmVkLlxuICAgKi9cbiAgYmVmb3JlZ3JpZHJlbmRlcjogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PGFueT4+O1xuICAvKipcbiAgICogRW1taXRlZCBhZnRlciB0aGUgZ3JpZCBpcyByZW5kZXJlZC5cbiAgICovXG4gIGFmdGVyZ3JpZHJlbmRlcjogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PGFueT4+O1xuICAvKipcbiAgICogRW1taXRlZCBhZnRlciB0aGUgZ3JpZCBpcyBpbml0aWFsaXplZC4gQ29ubmVjdGVkIHRvIHRoZSBET00uXG4gICAqL1xuICBhZnRlcmdyaWRpbml0OiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8YW55Pj47XG4gIC8qKlxuICAgKiBFbW1pdGVkIGFmdGVyIHRoZSBhZGRpdGlvbmFsIGRhdGEgaXMgY2hhbmdlZFxuICAgKi9cbiAgYWRkaXRpb25hbGRhdGFjaGFuZ2VkOiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8YW55Pj47XG4gIC8qKlxuICAgKiBFbW1pdGVkIGFmdGVyIHRoZSB0aGVtZSBpcyBjaGFuZ2VkXG4gICAqL1xuICBhZnRlcnRoZW1lY2hhbmdlZDogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PElSZXZvR3JpZFRoZW1lPj47XG4gIC8qKlxuICAgKiBFbW1pdGVkIGFmdGVyIGdyaWQgY3JlYXRlZFxuICAgKi9cbiAgY3JlYXRlZDogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PGFueT4+O1xufVxuXG5cbiJdfQ==
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItZGF0YWdyaWQvc3JjL2xpYi9jb21wb25lbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLG9CQUFvQjtBQUNwQiw4Q0FBOEM7QUFDOUMsT0FBTyxFQUFFLHVCQUF1QixFQUFxQixTQUFTLEVBQW9DLE1BQU0sZUFBZSxDQUFDO0FBRXhILE9BQU8sRUFBRSxRQUFRLEVBQUUsWUFBWSxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFJdkUsT0FBTyxFQUFFLG1CQUFtQixJQUFJLGNBQWMsRUFBRSxNQUFNLDRDQUE0QyxDQUFDOztBQWM1RixJQUFNLFFBQVEsR0FBZCxNQUFNLFFBQVE7SUFFbkIsWUFBWSxDQUFvQixFQUFFLENBQWEsRUFBWSxDQUFTO1FBQVQsTUFBQyxHQUFELENBQUMsQ0FBUTtRQUNsRSxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDWCxJQUFJLENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQyxhQUFhLENBQUM7UUFDMUIsWUFBWSxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsRUFBRSxFQUFFLENBQUMsb0JBQW9CLEVBQUUsWUFBWSxFQUFFLGlCQUFpQixFQUFFLFdBQVcsRUFBRSxnQkFBZ0IsRUFBRSxhQUFhLEVBQUUsWUFBWSxFQUFFLGlCQUFpQixFQUFFLGVBQWUsRUFBRSwwQkFBMEIsRUFBRSxvQkFBb0IsRUFBRSxjQUFjLEVBQUUsYUFBYSxFQUFFLGlCQUFpQixFQUFFLGlCQUFpQixFQUFFLGlCQUFpQixFQUFFLGlCQUFpQixFQUFFLGdCQUFnQixFQUFFLGdCQUFnQixFQUFFLGtCQUFrQixFQUFFLHFCQUFxQixFQUFFLGlCQUFpQixFQUFFLG1CQUFtQixFQUFFLHFCQUFxQixFQUFFLGVBQWUsRUFBRSxjQUFjLEVBQUUsZ0JBQWdCLEVBQUUsY0FBYyxFQUFFLGlCQUFpQixFQUFFLG1CQUFtQixFQUFFLHFCQUFxQixFQUFFLHFCQUFxQixFQUFFLHNCQUFzQixFQUFFLG1CQUFtQixFQUFFLGtCQUFrQixFQUFFLGlCQUFpQixFQUFFLGVBQWUsRUFBRSx1QkFBdUIsRUFBRSxtQkFBbUIsRUFBRSxTQUFTLENBQUMsQ0FBQyxDQUFDO0lBQ3p4QixDQUFDOzhHQU5VLFFBQVE7a0dBQVIsUUFBUSwyaUNBTFQsMkJBQTJCOztBQUsxQixRQUFRO0lBYnBCLFFBQVEsQ0FBQztRQUNSLHFCQUFxQixFQUFFLGNBQWM7UUFDckMsTUFBTSxFQUFFLENBQUMsWUFBWSxFQUFFLGdCQUFnQixFQUFFLGNBQWMsRUFBRSxnQkFBZ0IsRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLGdCQUFnQixFQUFFLFNBQVMsRUFBRSxhQUFhLEVBQUUsU0FBUyxFQUFFLGlCQUFpQixFQUFFLGlCQUFpQixFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsUUFBUSxFQUFFLGVBQWUsRUFBRSxXQUFXLEVBQUUsVUFBVSxFQUFFLGlCQUFpQixFQUFFLGtCQUFrQixFQUFFLG9CQUFvQixFQUFFLGlCQUFpQixFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLGVBQWUsRUFBRSxRQUFRLEVBQUUsVUFBVSxFQUFFLGdCQUFnQixFQUFFLFlBQVksRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRSxhQUFhLEVBQUUsY0FBYyxDQUFDO1FBQzNoQixPQUFPLEVBQUUsQ0FBQyxTQUFTLEVBQUUsV0FBVyxFQUFFLGFBQWEsRUFBRSxxQkFBcUIsRUFBRSxvQkFBb0IsRUFBRSxlQUFlLEVBQUUsWUFBWSxFQUFFLG9CQUFvQixFQUFFLGFBQWEsRUFBRSxlQUFlLEVBQUUsV0FBVyxFQUFFLGtCQUFrQixFQUFFLGdCQUFnQixFQUFFLGdCQUFnQixFQUFFLHFCQUFxQixFQUFFLGNBQWMsRUFBRSxZQUFZLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxZQUFZLEVBQUUsZ0JBQWdCLEVBQUUsa0JBQWtCLEVBQUUsc0JBQXNCLEVBQUUsY0FBYyxDQUFDO0tBQ3JhLENBQUM7R0FTVyxRQUFRLENBT3BCOzsyRkFQWSxRQUFRO2tCQVJwQixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxXQUFXO29CQUNyQixlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtvQkFDL0MsUUFBUSxFQUFFLDJCQUEyQjtvQkFDckMsdUVBQXVFO29CQUN2RSxNQUFNLEVBQUUsQ0FBQyxZQUFZLEVBQUUsZ0JBQWdCLEVBQUUsY0FBYyxFQUFFLGdCQUFnQixFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsZ0JBQWdCLEVBQUUsU0FBUyxFQUFFLGFBQWEsRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsaUJBQWlCLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxRQUFRLEVBQUUsZUFBZSxFQUFFLFdBQVcsRUFBRSxVQUFVLEVBQUUsaUJBQWlCLEVBQUUsa0JBQWtCLEVBQUUsb0JBQW9CLEVBQUUsaUJBQWlCLEVBQUUsU0FBUyxFQUFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsZUFBZSxFQUFFLFFBQVEsRUFBRSxVQUFVLEVBQUUsZ0JBQWdCLEVBQUUsWUFBWSxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxTQUFTLEVBQUUsT0FBTyxFQUFFLGFBQWEsRUFBRSxjQUFjLENBQUM7b0JBQzNoQixVQUFVLEVBQUUsSUFBSTtpQkFDakIiLCJzb3VyY2VzQ29udGVudCI6WyIvKiB0c2xpbnQ6ZGlzYWJsZSAqL1xuLyogYXV0by1nZW5lcmF0ZWQgYW5ndWxhciBkaXJlY3RpdmUgcHJveGllcyAqL1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQsIEVsZW1lbnRSZWYsIEV2ZW50RW1pdHRlciwgTmdab25lIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IFByb3h5Q21wLCBwcm94eU91dHB1dHMgfSBmcm9tICcuL2FuZ3VsYXItY29tcG9uZW50LWxpYi91dGlscyc7XG5cbmltcG9ydCB0eXBlIHsgQ29tcG9uZW50cyB9IGZyb20gJ0ByZXZvbGlzdC9yZXZvZ3JpZC9zdGFuZGFsb25lJztcblxuaW1wb3J0IHsgZGVmaW5lQ3VzdG9tRWxlbWVudCBhcyBkZWZpbmVSZXZvR3JpZCB9IGZyb20gJ0ByZXZvbGlzdC9yZXZvZ3JpZC9zdGFuZGFsb25lL3Jldm8tZ3JpZC5qcyc7XG5AUHJveHlDbXAoe1xuICBkZWZpbmVDdXN0b21FbGVtZW50Rm46IGRlZmluZVJldm9HcmlkLFxuICBpbnB1dHM6IFsnYWNjZXNzaWJsZScsICdhZGRpdGlvbmFsRGF0YScsICdhcHBseU9uQ2xvc2UnLCAnYXV0b1NpemVDb2x1bW4nLCAnY2FuRHJhZycsICdjYW5Gb2N1cycsICdjYW5Nb3ZlQ29sdW1ucycsICdjb2xTaXplJywgJ2NvbHVtblR5cGVzJywgJ2NvbHVtbnMnLCAnZGlzYWJsZVZpcnR1YWxYJywgJ2Rpc2FibGVWaXJ0dWFsWScsICdlZGl0b3JzJywgJ2V4cG9ydGluZycsICdmaWx0ZXInLCAnZm9jdXNUZW1wbGF0ZScsICdmcmFtZVNpemUnLCAnZ3JvdXBpbmcnLCAnaGlkZUF0dHJpYnV0aW9uJywgJ2pvYnNCZWZvcmVSZW5kZXInLCAncGlubmVkQm90dG9tU291cmNlJywgJ3Bpbm5lZFRvcFNvdXJjZScsICdwbHVnaW5zJywgJ3JhbmdlJywgJ3JlYWRvbmx5JywgJ3JlZ2lzdGVyVk5vZGUnLCAncmVzaXplJywgJ3Jvd0NsYXNzJywgJ3Jvd0RlZmluaXRpb25zJywgJ3Jvd0hlYWRlcnMnLCAncm93U2l6ZScsICdydGwnLCAnc29ydGluZycsICdzb3VyY2UnLCAnc3RyZXRjaCcsICd0aGVtZScsICd0cmltbWVkUm93cycsICd1c2VDbGlwYm9hcmQnXSxcbiAgbWV0aG9kczogWydyZWZyZXNoJywgJ3NldERhdGFBdCcsICdzY3JvbGxUb1JvdycsICdzY3JvbGxUb0NvbHVtbkluZGV4JywgJ3Njcm9sbFRvQ29sdW1uUHJvcCcsICd1cGRhdGVDb2x1bW5zJywgJ2FkZFRyaW1tZWQnLCAnc2Nyb2xsVG9Db29yZGluYXRlJywgJ3NldENlbGxFZGl0JywgJ3NldENlbGxzRm9jdXMnLCAnZ2V0U291cmNlJywgJ2dldFZpc2libGVTb3VyY2UnLCAnZ2V0U291cmNlU3RvcmUnLCAnZ2V0Q29sdW1uU3RvcmUnLCAndXBkYXRlQ29sdW1uU29ydGluZycsICdjbGVhclNvcnRpbmcnLCAnZ2V0Q29sdW1ucycsICdjbGVhckZvY3VzJywgJ2dldFBsdWdpbnMnLCAnZ2V0Rm9jdXNlZCcsICdnZXRDb250ZW50U2l6ZScsICdnZXRTZWxlY3RlZFJhbmdlJywgJ3JlZnJlc2hFeHRyYUVsZW1lbnRzJywgJ2dldFByb3ZpZGVycyddXG59KVxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncmV2by1ncmlkJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHRlbXBsYXRlOiAnPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PicsXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAYW5ndWxhci1lc2xpbnQvbm8taW5wdXRzLW1ldGFkYXRhLXByb3BlcnR5XG4gIGlucHV0czogWydhY2Nlc3NpYmxlJywgJ2FkZGl0aW9uYWxEYXRhJywgJ2FwcGx5T25DbG9zZScsICdhdXRvU2l6ZUNvbHVtbicsICdjYW5EcmFnJywgJ2NhbkZvY3VzJywgJ2Nhbk1vdmVDb2x1bW5zJywgJ2NvbFNpemUnLCAnY29sdW1uVHlwZXMnLCAnY29sdW1ucycsICdkaXNhYmxlVmlydHVhbFgnLCAnZGlzYWJsZVZpcnR1YWxZJywgJ2VkaXRvcnMnLCAnZXhwb3J0aW5nJywgJ2ZpbHRlcicsICdmb2N1c1RlbXBsYXRlJywgJ2ZyYW1lU2l6ZScsICdncm91cGluZycsICdoaWRlQXR0cmlidXRpb24nLCAnam9ic0JlZm9yZVJlbmRlcicsICdwaW5uZWRCb3R0b21Tb3VyY2UnLCAncGlubmVkVG9wU291cmNlJywgJ3BsdWdpbnMnLCAncmFuZ2UnLCAncmVhZG9ubHknLCAncmVnaXN0ZXJWTm9kZScsICdyZXNpemUnLCAncm93Q2xhc3MnLCAncm93RGVmaW5pdGlvbnMnLCAncm93SGVhZGVycycsICdyb3dTaXplJywgJ3J0bCcsICdzb3J0aW5nJywgJ3NvdXJjZScsICdzdHJldGNoJywgJ3RoZW1lJywgJ3RyaW1tZWRSb3dzJywgJ3VzZUNsaXBib2FyZCddLFxuICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIFJldm9HcmlkIHtcbiAgcHJvdGVjdGVkIGVsOiBIVE1MRWxlbWVudDtcbiAgY29uc3RydWN0b3IoYzogQ2hhbmdlRGV0ZWN0b3JSZWYsIHI6IEVsZW1lbnRSZWYsIHByb3RlY3RlZCB6OiBOZ1pvbmUpIHtcbiAgICBjLmRldGFjaCgpO1xuICAgIHRoaXMuZWwgPSByLm5hdGl2ZUVsZW1lbnQ7XG4gICAgcHJveHlPdXRwdXRzKHRoaXMsIHRoaXMuZWwsIFsnY29udGVudHNpemVjaGFuZ2VkJywgJ2JlZm9yZWVkaXQnLCAnYmVmb3JlcmFuZ2VlZGl0JywgJ2FmdGVyZWRpdCcsICdiZWZvcmVhdXRvZmlsbCcsICdiZWZvcmVyYW5nZScsICdhZnRlcmZvY3VzJywgJ3Jvd29yZGVyY2hhbmdlZCcsICdiZWZvcmVzb3J0aW5nJywgJ2JlZm9yZXNvdXJjZXNvcnRpbmdhcHBseScsICdiZWZvcmVzb3J0aW5nYXBwbHknLCAncm93ZHJhZ3N0YXJ0JywgJ2hlYWRlcmNsaWNrJywgJ2JlZm9yZWNlbGxmb2N1cycsICdiZWZvcmVmb2N1c2xvc3QnLCAnYmVmb3Jlc291cmNlc2V0JywgJ2JlZm9yZWFueXNvdXJjZScsICdhZnRlcnNvdXJjZXNldCcsICdhZnRlcmFueXNvdXJjZScsICdiZWZvcmVjb2x1bW5zc2V0JywgJ2JlZm9yZWNvbHVtbmFwcGxpZWQnLCAnYWZ0ZXJjb2x1bW5zc2V0JywgJ2JlZm9yZWZpbHRlcmFwcGx5JywgJ2JlZm9yZWZpbHRlcnRyaW1tZWQnLCAnYmVmb3JldHJpbW1lZCcsICdhZnRlcnRyaW1tZWQnLCAndmlld3BvcnRzY3JvbGwnLCAnYmVmb3JlZXhwb3J0JywgJ2JlZm9yZWVkaXRzdGFydCcsICdhZnRlcmNvbHVtbnJlc2l6ZScsICdiZWZvcmVyb3dkZWZpbml0aW9uJywgJ2ZpbHRlcmNvbmZpZ2NoYW5nZWQnLCAnc29ydGluZ2NvbmZpZ2NoYW5nZWQnLCAncm93aGVhZGVyc2NoYW5nZWQnLCAnYmVmb3JlZ3JpZHJlbmRlcicsICdhZnRlcmdyaWRyZW5kZXInLCAnYWZ0ZXJncmlkaW5pdCcsICdhZGRpdGlvbmFsZGF0YWNoYW5nZWQnLCAnYWZ0ZXJ0aGVtZWNoYW5nZWQnLCAnY3JlYXRlZCddKTtcbiAgfVxufVxuXG5cbmltcG9ydCB0eXBlIHsgTXVsdGlEaW1lbnNpb25UeXBlIGFzIElSZXZvR3JpZE11bHRpRGltZW5zaW9uVHlwZSB9IGZyb20gJ0ByZXZvbGlzdC9yZXZvZ3JpZC9zdGFuZGFsb25lJztcbmltcG9ydCB0eXBlIHsgQmVmb3JlU2F2ZURhdGFEZXRhaWxzIGFzIElSZXZvR3JpZEJlZm9yZVNhdmVEYXRhRGV0YWlscyB9IGZyb20gJ0ByZXZvbGlzdC9yZXZvZ3JpZC9zdGFuZGFsb25lJztcbmltcG9ydCB0eXBlIHsgQmVmb3JlUmFuZ2VTYXZlRGF0YURldGFpbHMgYXMgSVJldm9HcmlkQmVmb3JlUmFuZ2VTYXZlRGF0YURldGFpbHMgfSBmcm9tICdAcmV2b2xpc3QvcmV2b2dyaWQvc3RhbmRhbG9uZSc7XG5pbXBvcnQgdHlwZSB7IEFmdGVyRWRpdEV2ZW50IGFzIElSZXZvR3JpZEFmdGVyRWRpdEV2ZW50IH0gZnJvbSAnQHJldm9saXN0L3Jldm9ncmlkL3N0YW5kYWxvbmUnO1xuaW1wb3J0IHR5cGUgeyBDaGFuZ2VkUmFuZ2UgYXMgSVJldm9HcmlkQ2hhbmdlZFJhbmdlIH0gZnJvbSAnQHJldm9saXN0L3Jldm9ncmlkL3N0YW5kYWxvbmUnO1xuaW1wb3J0IHR5cGUgeyBGb2N1c0FmdGVyUmVuZGVyRXZlbnQgYXMgSVJldm9HcmlkRm9jdXNBZnRlclJlbmRlckV2ZW50IH0gZnJvbSAnQHJldm9saXN0L3Jldm9ncmlkL3N0YW5kYWxvbmUnO1xuaW1wb3J0IHR5cGUgeyBDb2x1bW5SZWd1bGFyIGFzIElSZXZvR3JpZENvbHVtblJlZ3VsYXIgfSBmcm9tICdAcmV2b2xpc3QvcmV2b2dyaWQvc3RhbmRhbG9uZSc7XG5pbXBvcnQgdHlwZSB7IERpbWVuc2lvblJvd3MgYXMgSVJldm9HcmlkRGltZW5zaW9uUm93cyB9IGZyb20gJ0ByZXZvbGlzdC9yZXZvZ3JpZC9zdGFuZGFsb25lJztcbmltcG9ydCB0eXBlIHsgU29ydGluZ09yZGVyIGFzIElSZXZvR3JpZFNvcnRpbmdPcmRlciB9IGZyb20gJ0ByZXZvbGlzdC9yZXZvZ3JpZC9zdGFuZGFsb25lJztcbmltcG9ydCB0eXBlIHsgUm93RHJhZ1N0YXJ0RGV0YWlscyBhcyBJUmV2b0dyaWRSb3dEcmFnU3RhcnREZXRhaWxzIH0gZnJvbSAnQHJldm9saXN0L3Jldm9ncmlkL3N0YW5kYWxvbmUnO1xuaW1wb3J0IHR5cGUgeyBGb2N1c2VkRGF0YSBhcyBJUmV2b0dyaWRGb2N1c2VkRGF0YSB9IGZyb20gJ0ByZXZvbGlzdC9yZXZvZ3JpZC9zdGFuZGFsb25lJztcbmltcG9ydCB0eXBlIHsgRGF0YVR5cGUgYXMgSVJldm9HcmlkRGF0YVR5cGUgfSBmcm9tICdAcmV2b2xpc3QvcmV2b2dyaWQvc3RhbmRhbG9uZSc7XG5pbXBvcnQgdHlwZSB7IENvbHVtbkNvbGxlY3Rpb24gYXMgSVJldm9HcmlkQ29sdW1uQ29sbGVjdGlvbiB9IGZyb20gJ0ByZXZvbGlzdC9yZXZvZ3JpZC9zdGFuZGFsb25lJztcbmltcG9ydCB0eXBlIHsgQ29sdW1uUHJvcCBhcyBJUmV2b0dyaWRDb2x1bW5Qcm9wIH0gZnJvbSAnQHJldm9saXN0L3Jldm9ncmlkL3N0YW5kYWxvbmUnO1xuaW1wb3J0IHR5cGUgeyBGaWx0ZXJDb2xsZWN0aW9uSXRlbSBhcyBJUmV2b0dyaWRGaWx0ZXJDb2xsZWN0aW9uSXRlbSB9IGZyb20gJ0ByZXZvbGlzdC9yZXZvZ3JpZC9zdGFuZGFsb25lJztcbmltcG9ydCB0eXBlIHsgVmlld1BvcnRTY3JvbGxFdmVudCBhcyBJUmV2b0dyaWRWaWV3UG9ydFNjcm9sbEV2ZW50IH0gZnJvbSAnQHJldm9saXN0L3Jldm9ncmlkL3N0YW5kYWxvbmUnO1xuaW1wb3J0IHR5cGUgeyBEYXRhSW5wdXQgYXMgSVJldm9HcmlkRGF0YUlucHV0IH0gZnJvbSAnQHJldm9saXN0L3Jldm9ncmlkL3N0YW5kYWxvbmUnO1xuaW1wb3J0IHR5cGUgeyBTb3J0aW5nQ29uZmlnIGFzIElSZXZvR3JpZFNvcnRpbmdDb25maWcgfSBmcm9tICdAcmV2b2xpc3QvcmV2b2dyaWQvc3RhbmRhbG9uZSc7XG5pbXBvcnQgdHlwZSB7IFRoZW1lIGFzIElSZXZvR3JpZFRoZW1lIH0gZnJvbSAnQHJldm9saXN0L3Jldm9ncmlkL3N0YW5kYWxvbmUnO1xuXG5leHBvcnQgZGVjbGFyZSBpbnRlcmZhY2UgUmV2b0dyaWQgZXh0ZW5kcyBDb21wb25lbnRzLlJldm9HcmlkIHtcbiAgLyoqXG4gICAqIE5ldyBjb250ZW50IHNpemUgaGFzIGJlZW4gYXBwbGllZC4gVGhlIHNpemUgZXhjbHVkZXMgdGhlIGhlYWRlci5cbkN1cnJlbnRseSwgdGhlIGV2ZW50IHJlc3BvbnNpYmxlIGZvciBhcHBseWluZyB0aGUgbmV3IGNvbnRlbnQgc2l6ZSBkb2VzIG5vdCBwcm92aWRlIHRoZSBhY3R1YWwgc2l6ZS5cblRvIHJldHJpZXZlIHRoZSBhY3R1YWwgY29udGVudCBzaXplLCB5b3UgY2FuIHV0aWxpemUgdGhlIGBnZXRDb250ZW50U2l6ZWAgZnVuY3Rpb24gYWZ0ZXIgdGhlIGV2ZW50IGhhcyBiZWVuIHRyaWdnZXJlZC5cbiAgICovXG4gIGNvbnRlbnRzaXplY2hhbmdlZDogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PElSZXZvR3JpZE11bHRpRGltZW5zaW9uVHlwZT4+O1xuICAvKipcbiAgICogQmVmb3JlIHRoZSBkYXRhIGlzIGVkaXRlZC5cblRvIHByZXZlbnQgdGhlIGRlZmF1bHQgYmVoYXZpb3Igb2YgZWRpdGluZyBkYXRhIGFuZCB1c2UgeW91ciBvd24gaW1wbGVtZW50YXRpb24sIGNhbGwgYGUucHJldmVudERlZmF1bHQoKWAuXG5UbyBvdmVycmlkZSB0aGUgZWRpdCByZXN1bHQgd2l0aCB5b3VyIG93biB2YWx1ZSwgc2V0IHRoZSBgZS52YWxgIHByb3BlcnR5IHRvIHlvdXIgZGVzaXJlZCB2YWx1ZS5cbiAgICovXG4gIGJlZm9yZWVkaXQ6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDxJUmV2b0dyaWRCZWZvcmVTYXZlRGF0YURldGFpbHM+PjtcbiAgLyoqXG4gICAqIEJlZm9yZSBhcHBseWluZyByYW5nZSBkYXRhLCBzcGVjaWZpY2FsbHkgd2hlbiBhIHJhbmdlIHNlbGVjdGlvbiBvY2N1cnMuXG5UbyBjdXN0b21pemUgdGhlIGRhdGEgYW5kIHByZXZlbnQgdGhlIGRlZmF1bHQgZWRpdCBkYXRhIGZyb20gYmVpbmcgc2V0LCB5b3UgY2FuIGNhbGwgYGUucHJldmVudERlZmF1bHQoKWAuXG4gICAqL1xuICBiZWZvcmVyYW5nZWVkaXQ6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDxJUmV2b0dyaWRCZWZvcmVSYW5nZVNhdmVEYXRhRGV0YWlscz4+O1xuICAvKipcbiAgICogQWZ0ZXIgZGF0YSBhcHBsaWVkIG9yIHJhbmdlIGNoYW5nZWQuXG4gICAqL1xuICBhZnRlcmVkaXQ6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDxJUmV2b0dyaWRBZnRlckVkaXRFdmVudD4+O1xuICAvKipcbiAgICogQmVmb3JlIGF1dG9maWxsIGlzIGFwcGxpZWQuXG5UbyBwcmV2ZW50IHRoZSBkZWZhdWx0IGJlaGF2aW9yIG9mIGFwcGx5aW5nIHRoZSBlZGl0IGRhdGEsIHlvdSBjYW4gY2FsbCBgZS5wcmV2ZW50RGVmYXVsdCgpYC5cbiAgICovXG4gIGJlZm9yZWF1dG9maWxsOiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8SVJldm9HcmlkQ2hhbmdlZFJhbmdlPj47XG4gIC8qKlxuICAgKiBCZWZvcmUgYXV0b2ZpbGwgaXMgYXBwbGllZC4gUnVucyBiZWZvcmUgYmVmb3JlYXV0b2ZpbGwgZXZlbnQuXG5Vc2UgZS5wcmV2ZW50RGVmYXVsdCgpIHRvIHByZXZlbnQgcmFuZ2UuXG4gICAqL1xuICBiZWZvcmVyYW5nZTogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PElSZXZvR3JpZENoYW5nZWRSYW5nZT4+O1xuICAvKipcbiAgICogQWZ0ZXIgZm9jdXMgcmVuZGVyIGZpbmlzaGVkLlxuQ2FuIGJlIHVzZWQgdG8gYWNjZXNzIGEgZm9jdXMgZWxlbWVudCB0aHJvdWdoIGBldmVudC50YXJnZXRgLlxuVGhpcyBpcyBqdXN0IGEgZHVwbGljYXRlIG9mIGBhZnRlcmZvY3VzYCBmcm9tIGByZXZvZ3ItZm9jdXMudHN4YC5cbiAgICovXG4gIGFmdGVyZm9jdXM6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDxJUmV2b0dyaWRGb2N1c0FmdGVyUmVuZGVyRXZlbnQ+PjtcbiAgLyoqXG4gICAqIEJlZm9yZSB0aGUgb3JkZXIgb2YgYHJnUm93YCBpcyBhcHBsaWVkLlxuVG8gcHJldmVudCB0aGUgZGVmYXVsdCBiZWhhdmlvciBvZiBjaGFuZ2luZyB0aGUgb3JkZXIgb2YgYHJnUm93YCwgeW91IGNhbiBjYWxsIGBlLnByZXZlbnREZWZhdWx0KClgLlxuICAgKi9cbiAgcm93b3JkZXJjaGFuZ2VkOiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8eyBmcm9tOiBudW1iZXI7IHRvOiBudW1iZXIgfT4+O1xuICAvKipcbiAgICogQnkgYFNvcnRpbmdQbHVnaW5gXG48YnI+VHJpZ2dlcmVkIGltbWVkaWF0ZWx5IGFmdGVyIGhlYWRlciBjbGljay5cbjxicj5GaXJzdCBpbiBzb3J0aW5nIGV2ZW50IHNlcXVlbmNlLiBGZiB0aGlzIGV2ZW50IHN0b3BzIG5vIG90aGVyIGV2ZW50IGNhbGxlZC5cbjxicj5Vc2UgYGUucHJldmVudERlZmF1bHQoKWAgdG8gcHJldmVudCBzb3J0aW5nLlxuICAgKi9cbiAgYmVmb3Jlc29ydGluZzogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PHsgY29sdW1uOiBJUmV2b0dyaWRDb2x1bW5SZWd1bGFyOyBvcmRlcjogJ2Rlc2MnIHwgJ2FzYyc7IGFkZGl0aXZlOiBib29sZWFuOyB9Pj47XG4gIC8qKlxuICAgKiBCeSBgU29ydGluZ1BsdWdpbmBcbjxicj5TYW1lIGFzIGBiZWZvcmVzb3J0aW5nYCBidXQgdHJpZ2dlcmVkIGFmdGVyIGBiZWZvcmVhbnlzb3VyY2VgICh3aGVuIHNvdXJjZSBpcyBjaGFuZ2VkKS5cbjxicj5Vc2UgYGUucHJldmVudERlZmF1bHQoKWAgdG8gcHJldmVudCBzb3J0aW5nIGRhdGEgY2hhbmdlLlxuICAgKi9cbiAgYmVmb3Jlc291cmNlc29ydGluZ2FwcGx5OiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8eyB0eXBlOiBJUmV2b0dyaWREaW1lbnNpb25Sb3dzOyBzb3J0aW5nPzogSVJldm9HcmlkU29ydGluZ09yZGVyOyB9Pj47XG4gIC8qKlxuICAgKiBCeSBgU29ydGluZ1BsdWdpbmBcbjxicj4gQWZ0ZXIgYGJlZm9yZXNvcnRpbmdgXG48YnI+VHJpZ2dlcmVkIGFmdGVyIGNvbHVtbiBkYXRhIHVwZGF0ZWQgd2l0aCBuZXcgc29ydGluZyBvcmRlci5cbjxicj5Vc2UgYGUucHJldmVudERlZmF1bHQoKWAgdG8gcHJldmVudCBzb3J0aW5nIGRhdGEgY2hhbmdlLlxuICAgKi9cbiAgYmVmb3Jlc29ydGluZ2FwcGx5OiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8eyBjb2x1bW46IElSZXZvR3JpZENvbHVtblJlZ3VsYXI7IG9yZGVyOiAnZGVzYycgfCAnYXNjJzsgYWRkaXRpdmU6IGJvb2xlYW47IH0+PjtcbiAgLyoqXG4gICAqIFRoaXMgZXZlbnQgaXMgdHJpZ2dlcmVkIHdoZW4gdGhlIHJvdyBvcmRlciBjaGFuZ2UgaXMgc3RhcnRlZC5cblRvIHByZXZlbnQgdGhlIGRlZmF1bHQgYmVoYXZpb3Igb2YgY2hhbmdpbmcgdGhlIHJvdyBvcmRlciwgeW91IGNhbiBjYWxsIGBlLnByZXZlbnREZWZhdWx0KClgLlxuVG8gY2hhbmdlIHRoZSBpdGVtIG5hbWUgYXQgdGhlIHN0YXJ0IG9mIHRoZSByb3cgb3JkZXIgY2hhbmdlLCB5b3UgY2FuIHNldCBgZS50ZXh0YCB0byB0aGUgZGVzaXJlZCBuZXcgbmFtZS5cbiAgICovXG4gIHJvd2RyYWdzdGFydDogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PElSZXZvR3JpZFJvd0RyYWdTdGFydERldGFpbHM+PjtcbiAgLyoqXG4gICAqIE9uIGhlYWRlciBjbGljay5cbiAgICovXG4gIGhlYWRlcmNsaWNrOiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8SVJldm9HcmlkQ29sdW1uUmVndWxhcj4+O1xuICAvKipcbiAgICogQmVmb3JlIHRoZSBjZWxsIGZvY3VzIGlzIGNoYW5nZWQuXG5UbyBwcmV2ZW50IHRoZSBkZWZhdWx0IGJlaGF2aW9yIG9mIGNoYW5naW5nIHRoZSBjZWxsIGZvY3VzLCB5b3UgY2FuIGNhbGwgYGUucHJldmVudERlZmF1bHQoKWAuXG4gICAqL1xuICBiZWZvcmVjZWxsZm9jdXM6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDxJUmV2b0dyaWRCZWZvcmVTYXZlRGF0YURldGFpbHM+PjtcbiAgLyoqXG4gICAqIEJlZm9yZSB0aGUgZ3JpZCBmb2N1cyBpcyBsb3N0LlxuVG8gcHJldmVudCB0aGUgZGVmYXVsdCBiZWhhdmlvciBvZiBjaGFuZ2luZyB0aGUgY2VsbCBmb2N1cywgeW91IGNhbiBjYWxsIGBlLnByZXZlbnREZWZhdWx0KClgLlxuICAgKi9cbiAgYmVmb3JlZm9jdXNsb3N0OiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8SVJldm9HcmlkRm9jdXNlZERhdGEgfCBudWxsPj47XG4gIC8qKlxuICAgKiBCZWZvcmUgbWFpbiBzb3VyY2Uvcm93cyBkYXRhIGFwcGx5LlxuWW91IGNhbiBvdmVycmlkZSBkYXRhIHNvdXJjZSBoZXJlXG4gICAqL1xuICBiZWZvcmVzb3VyY2VzZXQ6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDx7IHR5cGU6IElSZXZvR3JpZERpbWVuc2lvblJvd3M7IHNvdXJjZTogSVJldm9HcmlkRGF0YVR5cGVbXTsgfT4+O1xuICAvKipcbiAgICogQmVmb3JlIGRhdGEgYXBwbHkgb24gYW55IHNvdXJjZSB0eXBlLiBDYW4gYmUgc291cmNlIGZyb20gcGlubmVkIGFuZCBtYWluIHZpZXdwb3J0LlxuWW91IGNhbiBvdmVycmlkZSBkYXRhIHNvdXJjZSBoZXJlXG4gICAqL1xuICBiZWZvcmVhbnlzb3VyY2U6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDx7IHR5cGU6IElSZXZvR3JpZERpbWVuc2lvblJvd3M7IHNvdXJjZTogSVJldm9HcmlkRGF0YVR5cGVbXTsgfT4+O1xuICAvKipcbiAgICogQWZ0ZXIgbWFpbiBzb3VyY2Uvcm93cyB1cGRhdGVkXG4gICAqL1xuICBhZnRlcnNvdXJjZXNldDogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PHsgdHlwZTogSVJldm9HcmlkRGltZW5zaW9uUm93czsgc291cmNlOiBJUmV2b0dyaWREYXRhVHlwZVtdOyB9Pj47XG4gIC8qKlxuICAgKiBFbWl0dGVkIGFmdGVyIGVhY2ggc291cmNlIHVwZGF0ZSwgd2hldGhlciBmcm9tIHRoZSBwaW5uZWQgb3IgbWFpbiB2aWV3cG9ydC5cblVzZWZ1bCBmb3IgdHJhY2tpbmcgYWxsIGNoYW5nZXMgb3JpZ2luYXRpbmcgZnJvbSBzb3VyY2VzIGluIGJvdGggdGhlIHBpbm5lZCBhbmQgbWFpbiB2aWV3cG9ydHMuXG4gICAqL1xuICBhZnRlcmFueXNvdXJjZTogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PHsgdHlwZTogSVJldm9HcmlkRGltZW5zaW9uUm93czsgc291cmNlOiBJUmV2b0dyaWREYXRhVHlwZVtdOyB9Pj47XG4gIC8qKlxuICAgKiBFbWl0dGVkIGJlZm9yZSBhIGNvbHVtbiB1cGRhdGUgaXMgYXBwbGllZC5cbkxpc3RlbmVycyBjYW4gdXNlIHRoaXMgZXZlbnQgdG8gcGVyZm9ybSBhbnkgbmVjZXNzYXJ5IGFjdGlvbnMgb3IgbW9kaWZpY2F0aW9ucyBiZWZvcmUgdGhlIGNvbHVtbiB1cGRhdGUgaXMgZmluYWxpemVkLlxuICAgKi9cbiAgYmVmb3JlY29sdW1uc3NldDogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PElSZXZvR3JpZENvbHVtbkNvbGxlY3Rpb24+PjtcbiAgLyoqXG4gICAqIEVtaXR0ZWQgYmVmb3JlIGEgY29sdW1uIHVwZGF0ZSBpcyBhcHBsaWVkLCBhZnRlciB0aGUgY29sdW1uIHNldCBpcyBnYXRoZXJlZCBhbmQgdGhlIHZpZXdwb3J0IGlzIHVwZGF0ZWQuXG5Vc2VmdWwgZm9yIHBlcmZvcm1pbmcgYWN0aW9ucyBvciBtb2RpZmljYXRpb25zIGJlZm9yZSB0aGUgZmluYWwgYXBwbGljYXRpb24gb2YgdGhlIGNvbHVtbiB1cGRhdGUuXG4gICAqL1xuICBiZWZvcmVjb2x1bW5hcHBsaWVkOiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8SVJldm9HcmlkQ29sdW1uQ29sbGVjdGlvbj4+O1xuICAvKipcbiAgICogQ29sdW1uIHVwZGF0ZWRcbiAgICovXG4gIGFmdGVyY29sdW1uc3NldDogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PHsgY29sdW1uczogSVJldm9HcmlkQ29sdW1uQ29sbGVjdGlvbjsgb3JkZXI6IElSZXZvR3JpZFNvcnRpbmdPcmRlcjsgfT4+O1xuICAvKipcbiAgICogRW1pdHRlZCBiZWZvcmUgYXBwbHlpbmcgYSBmaWx0ZXIgdG8gdGhlIGRhdGEgc291cmNlLlxuVXNlIGUucHJldmVudERlZmF1bHQoKSB0byBwcmV2ZW50IGNlbGwgZm9jdXMgY2hhbmdlLlxuTW9kaWZ5IGlmIHlvdSBuZWVkIHRvIGNoYW5nZSBmaWx0ZXJzLlxuICAgKi9cbiAgYmVmb3JlZmlsdGVyYXBwbHk6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDx7IGNvbGxlY3Rpb246IFJlY29yZDxJUmV2b0dyaWRDb2x1bW5Qcm9wLCBJUmV2b0dyaWRGaWx0ZXJDb2xsZWN0aW9uSXRlbT4gfT4+O1xuICAvKipcbiAgICogRW1pdHRlZCBiZWZvcmUgYXBwbHlpbmcgYSBmaWx0ZXIgdG8gdGhlIGRhdGEgc291cmNlLlxuVXNlIGUucHJldmVudERlZmF1bHQoKSB0byBwcmV2ZW50IHRoZSBkZWZhdWx0IGJlaGF2aW9yIG9mIHRyaW1taW5nIHZhbHVlcyBhbmQgYXBwbHlpbmcgdGhlIGZpbHRlci5cbk1vZGlmeSB0aGUgYGNvbGxlY3Rpb25gIHByb3BlcnR5IGlmIHlvdSB3YW50IHRvIGNoYW5nZSB0aGUgZmlsdGVycy5cbk1vZGlmeSB0aGUgYGl0ZW1zVG9GaWx0ZXJgIHByb3BlcnR5IGlmIHlvdSB3YW50IHRvIGZpbHRlciB0aGUgaW5kZXhlcyBmb3IgdHJpbW1pbmcuXG4gICAqL1xuICBiZWZvcmVmaWx0ZXJ0cmltbWVkOiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8eyBjb2xsZWN0aW9uOiBSZWNvcmQ8SVJldm9HcmlkQ29sdW1uUHJvcCwgSVJldm9HcmlkRmlsdGVyQ29sbGVjdGlvbkl0ZW0+OyBpdGVtc1RvRmlsdGVyOiBSZWNvcmQ8bnVtYmVyLCBib29sZWFuPjsgfT4+O1xuICAvKipcbiAgICogRW1pdHRlZCBiZWZvcmUgdHJpbW1pbmcgdmFsdWVzLlxuVXNlIGUucHJldmVudERlZmF1bHQoKSB0byBwcmV2ZW50IHRoZSBkZWZhdWx0IGJlaGF2aW9yIG9mIHRyaW1taW5nIHZhbHVlcy5cbk1vZGlmeSB0aGUgYHRyaW1tZWRgIHByb3BlcnR5IGlmIHlvdSB3YW50IHRvIGZpbHRlciB0aGUgaW5kZXhlcyBmb3IgdHJpbW1pbmcuXG4gICAqL1xuICBiZWZvcmV0cmltbWVkOiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8eyB0cmltbWVkOiBSZWNvcmQ8bnVtYmVyLCBib29sZWFuPjsgdHJpbW1lZFR5cGU6IHN0cmluZzsgdHlwZTogc3RyaW5nOyB9Pj47XG4gIC8qKlxuICAgKiBFbWl0dGVkIGFmdGVyIHRyaW1tZWQgdmFsdWVzIGhhdmUgYmVlbiBhcHBsaWVkLlxuVXNlZnVsIGZvciBub3RpZnlpbmcgd2hlbiB0cmltbWluZyBvZiB2YWx1ZXMgaGFzIHRha2VuIHBsYWNlLlxuICAgKi9cbiAgYWZ0ZXJ0cmltbWVkOiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8YW55Pj47XG4gIC8qKlxuICAgKiBFbWl0dGVkIHdoZW4gdGhlIHZpZXdwb3J0IGlzIHNjcm9sbGVkLlxuVXNlZnVsIGZvciB0cmFja2luZyB2aWV3cG9ydCBzY3JvbGxpbmcgZXZlbnRzLlxuICAgKi9cbiAgdmlld3BvcnRzY3JvbGw6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDxJUmV2b0dyaWRWaWV3UG9ydFNjcm9sbEV2ZW50Pj47XG4gIC8qKlxuICAgKiBCZWZvcmUgZXhwb3J0XG5Vc2UgZS5wcmV2ZW50RGVmYXVsdCgpIHRvIHByZXZlbnQgZXhwb3J0XG5SZXBsYWNlIGRhdGEgaW4gRXZlbnQgaW4gY2FzZSB5b3Ugd2FudCB0byBtb2RpZnkgaXQgaW4gZXhwb3J0XG4gICAqL1xuICBiZWZvcmVleHBvcnQ6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDxJUmV2b0dyaWREYXRhSW5wdXQ+PjtcbiAgLyoqXG4gICAqIEVtaXR0ZWQgYmVmb3JlIGVkaXRpbmcgc3RhcnRzLlxuVXNlIGUucHJldmVudERlZmF1bHQoKSB0byBwcmV2ZW50IHRoZSBkZWZhdWx0IGVkaXQgYmVoYXZpb3IuXG4gICAqL1xuICBiZWZvcmVlZGl0c3RhcnQ6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDxJUmV2b0dyaWRCZWZvcmVTYXZlRGF0YURldGFpbHM+PjtcbiAgLyoqXG4gICAqIEVtaXR0ZWQgYWZ0ZXIgY29sdW1uIHJlc2l6aW5nLlxuVXNlZnVsIGZvciByZXRyaWV2aW5nIHRoZSByZXNpemVkIGNvbHVtbnMuXG4gICAqL1xuICBhZnRlcmNvbHVtbnJlc2l6ZTogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PHsgW2luZGV4OiBudW1iZXJdOiBJUmV2b0dyaWRDb2x1bW5SZWd1bGFyOyB9Pj47XG4gIC8qKlxuICAgKiBFbWl0dGVkIGJlZm9yZSB0aGUgcm93IGRlZmluaXRpb24gaXMgYXBwbGllZC5cblVzZWZ1bCBmb3IgbW9kaWZ5aW5nIG9yIHByZXZlbnRpbmcgdGhlIGRlZmF1bHQgcm93IGRlZmluaXRpb24gYmVoYXZpb3IuXG4gICAqL1xuICBiZWZvcmVyb3dkZWZpbml0aW9uOiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8eyB2YWxzOiBhbnk7IG9sZFZhbHM6IGFueSB9Pj47XG4gIC8qKlxuICAgKiBFbWl0dGVkIHdoZW4gdGhlIGZpbHRlciBjb25maWd1cmF0aW9uIGlzIGNoYW5nZWRcbiAgICovXG4gIGZpbHRlcmNvbmZpZ2NoYW5nZWQ6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDxhbnk+PjtcbiAgLyoqXG4gICAqIEVtaXR0ZWQgd2hlbiB0aGUgc29ydGluZyBjb25maWd1cmF0aW9uIGlzIGNoYW5nZWRcblNvcnRpbmdQbHVnaW4gc3Vic3JpYmVkIHRvIHRoaXMgZXZlbnRcbiAgICovXG4gIHNvcnRpbmdjb25maWdjaGFuZ2VkOiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8SVJldm9HcmlkU29ydGluZ0NvbmZpZz4+O1xuICAvKipcbiAgICogRW1taXRlZCB3aGVuIHRoZSByb3cgaGVhZGVycyBhcmUgY2hhbmdlZC5cbiAgICovXG4gIHJvd2hlYWRlcnNjaGFuZ2VkOiBFdmVudEVtaXR0ZXI8Q3VzdG9tRXZlbnQ8YW55Pj47XG4gIC8qKlxuICAgKiBFbW1pdGVkIGJlZm9yZSB0aGUgZ3JpZCBpcyByZW5kZXJlZC5cbiAgICovXG4gIGJlZm9yZWdyaWRyZW5kZXI6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDxhbnk+PjtcbiAgLyoqXG4gICAqIEVtbWl0ZWQgYWZ0ZXIgdGhlIGdyaWQgaXMgcmVuZGVyZWQuXG4gICAqL1xuICBhZnRlcmdyaWRyZW5kZXI6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDxhbnk+PjtcbiAgLyoqXG4gICAqIEVtbWl0ZWQgYWZ0ZXIgdGhlIGdyaWQgaXMgaW5pdGlhbGl6ZWQuIENvbm5lY3RlZCB0byB0aGUgRE9NLlxuICAgKi9cbiAgYWZ0ZXJncmlkaW5pdDogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PGFueT4+O1xuICAvKipcbiAgICogRW1taXRlZCBhZnRlciB0aGUgYWRkaXRpb25hbCBkYXRhIGlzIGNoYW5nZWRcbiAgICovXG4gIGFkZGl0aW9uYWxkYXRhY2hhbmdlZDogRXZlbnRFbWl0dGVyPEN1c3RvbUV2ZW50PGFueT4+O1xuICAvKipcbiAgICogRW1taXRlZCBhZnRlciB0aGUgdGhlbWUgaXMgY2hhbmdlZFxuICAgKi9cbiAgYWZ0ZXJ0aGVtZWNoYW5nZWQ6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDxJUmV2b0dyaWRUaGVtZT4+O1xuICAvKipcbiAgICogRW1taXRlZCBhZnRlciBncmlkIGNyZWF0ZWRcbiAgICovXG4gIGNyZWF0ZWQ6IEV2ZW50RW1pdHRlcjxDdXN0b21FdmVudDxhbnk+Pjtcbn1cblxuXG4iXX0=
@@ -77,12 +77,12 @@ let RevoGrid = class RevoGrid {
77
77
  proxyOutputs(this, this.el, ['contentsizechanged', 'beforeedit', 'beforerangeedit', 'afteredit', 'beforeautofill', 'beforerange', 'afterfocus', 'roworderchanged', 'beforesorting', 'beforesourcesortingapply', 'beforesortingapply', 'rowdragstart', 'headerclick', 'beforecellfocus', 'beforefocuslost', 'beforesourceset', 'beforeanysource', 'aftersourceset', 'afteranysource', 'beforecolumnsset', 'beforecolumnapplied', 'aftercolumnsset', 'beforefilterapply', 'beforefiltertrimmed', 'beforetrimmed', 'aftertrimmed', 'viewportscroll', 'beforeexport', 'beforeeditstart', 'aftercolumnresize', 'beforerowdefinition', 'filterconfigchanged', 'sortingconfigchanged', 'rowheaderschanged', 'beforegridrender', 'aftergridrender', 'aftergridinit', 'additionaldatachanged', 'afterthemechanged', 'created']);
78
78
  }
79
79
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: RevoGrid, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
80
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.1", type: RevoGrid, isStandalone: true, selector: "revo-grid", inputs: { accessible: "accessible", additionalData: "additionalData", applyOnClose: "applyOnClose", autoSizeColumn: "autoSizeColumn", canDrag: "canDrag", canFocus: "canFocus", canMoveColumns: "canMoveColumns", colSize: "colSize", columnTypes: "columnTypes", columns: "columns", disableVirtualX: "disableVirtualX", disableVirtualY: "disableVirtualY", editors: "editors", exporting: "exporting", filter: "filter", focusTemplate: "focusTemplate", frameSize: "frameSize", grouping: "grouping", hideAttribution: "hideAttribution", jobsBeforeRender: "jobsBeforeRender", pinnedBottomSource: "pinnedBottomSource", pinnedTopSource: "pinnedTopSource", plugins: "plugins", range: "range", readonly: "readonly", registerVNode: "registerVNode", resize: "resize", rowClass: "rowClass", rowDefinitions: "rowDefinitions", rowHeaders: "rowHeaders", rowSize: "rowSize", sorting: "sorting", source: "source", stretch: "stretch", theme: "theme", trimmedRows: "trimmedRows", useClipboard: "useClipboard" }, ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
80
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.1", type: RevoGrid, isStandalone: true, selector: "revo-grid", inputs: { accessible: "accessible", additionalData: "additionalData", applyOnClose: "applyOnClose", autoSizeColumn: "autoSizeColumn", canDrag: "canDrag", canFocus: "canFocus", canMoveColumns: "canMoveColumns", colSize: "colSize", columnTypes: "columnTypes", columns: "columns", disableVirtualX: "disableVirtualX", disableVirtualY: "disableVirtualY", editors: "editors", exporting: "exporting", filter: "filter", focusTemplate: "focusTemplate", frameSize: "frameSize", grouping: "grouping", hideAttribution: "hideAttribution", jobsBeforeRender: "jobsBeforeRender", pinnedBottomSource: "pinnedBottomSource", pinnedTopSource: "pinnedTopSource", plugins: "plugins", range: "range", readonly: "readonly", registerVNode: "registerVNode", resize: "resize", rowClass: "rowClass", rowDefinitions: "rowDefinitions", rowHeaders: "rowHeaders", rowSize: "rowSize", rtl: "rtl", sorting: "sorting", source: "source", stretch: "stretch", theme: "theme", trimmedRows: "trimmedRows", useClipboard: "useClipboard" }, ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
81
81
  };
82
82
  RevoGrid = __decorate([
83
83
  ProxyCmp({
84
84
  defineCustomElementFn: defineCustomElement$1,
85
- inputs: ['accessible', 'additionalData', 'applyOnClose', 'autoSizeColumn', 'canDrag', 'canFocus', 'canMoveColumns', 'colSize', 'columnTypes', 'columns', 'disableVirtualX', 'disableVirtualY', 'editors', 'exporting', 'filter', 'focusTemplate', 'frameSize', 'grouping', 'hideAttribution', 'jobsBeforeRender', 'pinnedBottomSource', 'pinnedTopSource', 'plugins', 'range', 'readonly', 'registerVNode', 'resize', 'rowClass', 'rowDefinitions', 'rowHeaders', 'rowSize', 'sorting', 'source', 'stretch', 'theme', 'trimmedRows', 'useClipboard'],
85
+ inputs: ['accessible', 'additionalData', 'applyOnClose', 'autoSizeColumn', 'canDrag', 'canFocus', 'canMoveColumns', 'colSize', 'columnTypes', 'columns', 'disableVirtualX', 'disableVirtualY', 'editors', 'exporting', 'filter', 'focusTemplate', 'frameSize', 'grouping', 'hideAttribution', 'jobsBeforeRender', 'pinnedBottomSource', 'pinnedTopSource', 'plugins', 'range', 'readonly', 'registerVNode', 'resize', 'rowClass', 'rowDefinitions', 'rowHeaders', 'rowSize', 'rtl', 'sorting', 'source', 'stretch', 'theme', 'trimmedRows', 'useClipboard'],
86
86
  methods: ['refresh', 'setDataAt', 'scrollToRow', 'scrollToColumnIndex', 'scrollToColumnProp', 'updateColumns', 'addTrimmed', 'scrollToCoordinate', 'setCellEdit', 'setCellsFocus', 'getSource', 'getVisibleSource', 'getSourceStore', 'getColumnStore', 'updateColumnSorting', 'clearSorting', 'getColumns', 'clearFocus', 'getPlugins', 'getFocused', 'getContentSize', 'getSelectedRange', 'refreshExtraElements', 'getProviders']
87
87
  })
88
88
  ], RevoGrid);
@@ -93,7 +93,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImpor
93
93
  changeDetection: ChangeDetectionStrategy.OnPush,
94
94
  template: '<ng-content></ng-content>',
95
95
  // eslint-disable-next-line @angular-eslint/no-inputs-metadata-property
96
- inputs: ['accessible', 'additionalData', 'applyOnClose', 'autoSizeColumn', 'canDrag', 'canFocus', 'canMoveColumns', 'colSize', 'columnTypes', 'columns', 'disableVirtualX', 'disableVirtualY', 'editors', 'exporting', 'filter', 'focusTemplate', 'frameSize', 'grouping', 'hideAttribution', 'jobsBeforeRender', 'pinnedBottomSource', 'pinnedTopSource', 'plugins', 'range', 'readonly', 'registerVNode', 'resize', 'rowClass', 'rowDefinitions', 'rowHeaders', 'rowSize', 'sorting', 'source', 'stretch', 'theme', 'trimmedRows', 'useClipboard'],
96
+ inputs: ['accessible', 'additionalData', 'applyOnClose', 'autoSizeColumn', 'canDrag', 'canFocus', 'canMoveColumns', 'colSize', 'columnTypes', 'columns', 'disableVirtualX', 'disableVirtualY', 'editors', 'exporting', 'filter', 'focusTemplate', 'frameSize', 'grouping', 'hideAttribution', 'jobsBeforeRender', 'pinnedBottomSource', 'pinnedTopSource', 'plugins', 'range', 'readonly', 'registerVNode', 'resize', 'rowClass', 'rowDefinitions', 'rowHeaders', 'rowSize', 'rtl', 'sorting', 'source', 'stretch', 'theme', 'trimmedRows', 'useClipboard'],
97
97
  standalone: true
98
98
  }]
99
99
  }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i0.NgZone }] });
@@ -1 +1 @@
1
- {"version":3,"file":"revolist-angular-datagrid.mjs","sources":["../../../projects/angular-datagrid/src/lib/angular-component-lib/utils.ts","../../../projects/angular-datagrid/src/lib/components.ts","../../../projects/angular-datagrid/src/lib/renderer.ts","../../../projects/angular-datagrid/src/lib/editor.adapter.ts","../../../projects/angular-datagrid/src/lib/editor.ts","../../../projects/angular-datagrid/src/public-api.ts","../../../projects/angular-datagrid/src/revolist-angular-datagrid.ts"],"sourcesContent":["/* eslint-disable */\n/* tslint:disable */\nimport { fromEvent } from 'rxjs';\n\nexport const proxyInputs = (Cmp: any, inputs: string[]) => {\n const Prototype = Cmp.prototype;\n inputs.forEach((item) => {\n Object.defineProperty(Prototype, item, {\n get() {\n return this.el[item];\n },\n set(val: any) {\n this.z.runOutsideAngular(() => (this.el[item] = val));\n },\n /**\n * In the event that proxyInputs is called\n * multiple times re-defining these inputs\n * will cause an error to be thrown. As a result\n * we set configurable: true to indicate these\n * properties can be changed.\n */\n configurable: true,\n });\n });\n};\n\nexport const proxyMethods = (Cmp: any, methods: string[]) => {\n const Prototype = Cmp.prototype;\n methods.forEach((methodName) => {\n Prototype[methodName] = function () {\n const args = arguments;\n return this.z.runOutsideAngular(() => this.el[methodName].apply(this.el, args));\n };\n });\n};\n\nexport const proxyOutputs = (instance: any, el: any, events: string[]) => {\n events.forEach((eventName) => (instance[eventName] = fromEvent(el, eventName)));\n};\n\nexport const defineCustomElement = (tagName: string, customElement: any) => {\n if (customElement !== undefined && typeof customElements !== 'undefined' && !customElements.get(tagName)) {\n customElements.define(tagName, customElement);\n }\n};\n\n// tslint:disable-next-line: only-arrow-functions\nexport function ProxyCmp(opts: { defineCustomElementFn?: () => void; inputs?: any; methods?: any }) {\n const decorator = function (cls: any) {\n const { defineCustomElementFn, inputs, methods } = opts;\n\n if (defineCustomElementFn !== undefined) {\n defineCustomElementFn();\n }\n\n if (inputs) {\n proxyInputs(cls, inputs);\n }\n if (methods) {\n proxyMethods(cls, methods);\n }\n return cls;\n };\n return decorator;\n}\n","/* tslint:disable */\n/* auto-generated angular directive proxies */\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, NgZone } from '@angular/core';\n\nimport { ProxyCmp, proxyOutputs } from './angular-component-lib/utils';\n\nimport type { Components } from '@revolist/revogrid/standalone';\n\nimport { defineCustomElement as defineRevoGrid } from '@revolist/revogrid/standalone/revo-grid.js';\n@ProxyCmp({\n defineCustomElementFn: defineRevoGrid,\n inputs: ['accessible', 'additionalData', 'applyOnClose', 'autoSizeColumn', 'canDrag', 'canFocus', 'canMoveColumns', 'colSize', 'columnTypes', 'columns', 'disableVirtualX', 'disableVirtualY', 'editors', 'exporting', 'filter', 'focusTemplate', 'frameSize', 'grouping', 'hideAttribution', 'jobsBeforeRender', 'pinnedBottomSource', 'pinnedTopSource', 'plugins', 'range', 'readonly', 'registerVNode', 'resize', 'rowClass', 'rowDefinitions', 'rowHeaders', 'rowSize', 'sorting', 'source', 'stretch', 'theme', 'trimmedRows', 'useClipboard'],\n methods: ['refresh', 'setDataAt', 'scrollToRow', 'scrollToColumnIndex', 'scrollToColumnProp', 'updateColumns', 'addTrimmed', 'scrollToCoordinate', 'setCellEdit', 'setCellsFocus', 'getSource', 'getVisibleSource', 'getSourceStore', 'getColumnStore', 'updateColumnSorting', 'clearSorting', 'getColumns', 'clearFocus', 'getPlugins', 'getFocused', 'getContentSize', 'getSelectedRange', 'refreshExtraElements', 'getProviders']\n})\n@Component({\n selector: 'revo-grid',\n changeDetection: ChangeDetectionStrategy.OnPush,\n template: '<ng-content></ng-content>',\n // eslint-disable-next-line @angular-eslint/no-inputs-metadata-property\n inputs: ['accessible', 'additionalData', 'applyOnClose', 'autoSizeColumn', 'canDrag', 'canFocus', 'canMoveColumns', 'colSize', 'columnTypes', 'columns', 'disableVirtualX', 'disableVirtualY', 'editors', 'exporting', 'filter', 'focusTemplate', 'frameSize', 'grouping', 'hideAttribution', 'jobsBeforeRender', 'pinnedBottomSource', 'pinnedTopSource', 'plugins', 'range', 'readonly', 'registerVNode', 'resize', 'rowClass', 'rowDefinitions', 'rowHeaders', 'rowSize', 'sorting', 'source', 'stretch', 'theme', 'trimmedRows', 'useClipboard'],\n standalone: true\n})\nexport class RevoGrid {\n protected el: HTMLElement;\n constructor(c: ChangeDetectorRef, r: ElementRef, protected z: NgZone) {\n c.detach();\n this.el = r.nativeElement;\n proxyOutputs(this, this.el, ['contentsizechanged', 'beforeedit', 'beforerangeedit', 'afteredit', 'beforeautofill', 'beforerange', 'afterfocus', 'roworderchanged', 'beforesorting', 'beforesourcesortingapply', 'beforesortingapply', 'rowdragstart', 'headerclick', 'beforecellfocus', 'beforefocuslost', 'beforesourceset', 'beforeanysource', 'aftersourceset', 'afteranysource', 'beforecolumnsset', 'beforecolumnapplied', 'aftercolumnsset', 'beforefilterapply', 'beforefiltertrimmed', 'beforetrimmed', 'aftertrimmed', 'viewportscroll', 'beforeexport', 'beforeeditstart', 'aftercolumnresize', 'beforerowdefinition', 'filterconfigchanged', 'sortingconfigchanged', 'rowheaderschanged', 'beforegridrender', 'aftergridrender', 'aftergridinit', 'additionaldatachanged', 'afterthemechanged', 'created']);\n }\n}\n\n\nimport type { MultiDimensionType as IRevoGridMultiDimensionType } from '@revolist/revogrid/standalone';\nimport type { BeforeSaveDataDetails as IRevoGridBeforeSaveDataDetails } from '@revolist/revogrid/standalone';\nimport type { BeforeRangeSaveDataDetails as IRevoGridBeforeRangeSaveDataDetails } from '@revolist/revogrid/standalone';\nimport type { AfterEditEvent as IRevoGridAfterEditEvent } from '@revolist/revogrid/standalone';\nimport type { ChangedRange as IRevoGridChangedRange } from '@revolist/revogrid/standalone';\nimport type { FocusAfterRenderEvent as IRevoGridFocusAfterRenderEvent } from '@revolist/revogrid/standalone';\nimport type { ColumnRegular as IRevoGridColumnRegular } from '@revolist/revogrid/standalone';\nimport type { DimensionRows as IRevoGridDimensionRows } from '@revolist/revogrid/standalone';\nimport type { SortingOrder as IRevoGridSortingOrder } from '@revolist/revogrid/standalone';\nimport type { RowDragStartDetails as IRevoGridRowDragStartDetails } from '@revolist/revogrid/standalone';\nimport type { FocusedData as IRevoGridFocusedData } from '@revolist/revogrid/standalone';\nimport type { DataType as IRevoGridDataType } from '@revolist/revogrid/standalone';\nimport type { ColumnCollection as IRevoGridColumnCollection } from '@revolist/revogrid/standalone';\nimport type { ColumnProp as IRevoGridColumnProp } from '@revolist/revogrid/standalone';\nimport type { FilterCollectionItem as IRevoGridFilterCollectionItem } from '@revolist/revogrid/standalone';\nimport type { ViewPortScrollEvent as IRevoGridViewPortScrollEvent } from '@revolist/revogrid/standalone';\nimport type { DataInput as IRevoGridDataInput } from '@revolist/revogrid/standalone';\nimport type { SortingConfig as IRevoGridSortingConfig } from '@revolist/revogrid/standalone';\nimport type { Theme as IRevoGridTheme } from '@revolist/revogrid/standalone';\n\nexport declare interface RevoGrid extends Components.RevoGrid {\n /**\n * New content size has been applied. The size excludes the header.\nCurrently, the event responsible for applying the new content size does not provide the actual size.\nTo retrieve the actual content size, you can utilize the `getContentSize` function after the event has been triggered.\n */\n contentsizechanged: EventEmitter<CustomEvent<IRevoGridMultiDimensionType>>;\n /**\n * Before the data is edited.\nTo prevent the default behavior of editing data and use your own implementation, call `e.preventDefault()`.\nTo override the edit result with your own value, set the `e.val` property to your desired value.\n */\n beforeedit: EventEmitter<CustomEvent<IRevoGridBeforeSaveDataDetails>>;\n /**\n * Before applying range data, specifically when a range selection occurs.\nTo customize the data and prevent the default edit data from being set, you can call `e.preventDefault()`.\n */\n beforerangeedit: EventEmitter<CustomEvent<IRevoGridBeforeRangeSaveDataDetails>>;\n /**\n * After data applied or range changed.\n */\n afteredit: EventEmitter<CustomEvent<IRevoGridAfterEditEvent>>;\n /**\n * Before autofill is applied.\nTo prevent the default behavior of applying the edit data, you can call `e.preventDefault()`.\n */\n beforeautofill: EventEmitter<CustomEvent<IRevoGridChangedRange>>;\n /**\n * Before autofill is applied. Runs before beforeautofill event.\nUse e.preventDefault() to prevent range.\n */\n beforerange: EventEmitter<CustomEvent<IRevoGridChangedRange>>;\n /**\n * After focus render finished.\nCan be used to access a focus element through `event.target`.\nThis is just a duplicate of `afterfocus` from `revogr-focus.tsx`.\n */\n afterfocus: EventEmitter<CustomEvent<IRevoGridFocusAfterRenderEvent>>;\n /**\n * Before the order of `rgRow` is applied.\nTo prevent the default behavior of changing the order of `rgRow`, you can call `e.preventDefault()`.\n */\n roworderchanged: EventEmitter<CustomEvent<{ from: number; to: number }>>;\n /**\n * By `SortingPlugin`\n<br>Triggered immediately after header click.\n<br>First in sorting event sequence. Ff this event stops no other event called.\n<br>Use `e.preventDefault()` to prevent sorting.\n */\n beforesorting: EventEmitter<CustomEvent<{ column: IRevoGridColumnRegular; order: 'desc' | 'asc'; additive: boolean; }>>;\n /**\n * By `SortingPlugin`\n<br>Same as `beforesorting` but triggered after `beforeanysource` (when source is changed).\n<br>Use `e.preventDefault()` to prevent sorting data change.\n */\n beforesourcesortingapply: EventEmitter<CustomEvent<{ type: IRevoGridDimensionRows; sorting?: IRevoGridSortingOrder; }>>;\n /**\n * By `SortingPlugin`\n<br> After `beforesorting`\n<br>Triggered after column data updated with new sorting order.\n<br>Use `e.preventDefault()` to prevent sorting data change.\n */\n beforesortingapply: EventEmitter<CustomEvent<{ column: IRevoGridColumnRegular; order: 'desc' | 'asc'; additive: boolean; }>>;\n /**\n * This event is triggered when the row order change is started.\nTo prevent the default behavior of changing the row order, you can call `e.preventDefault()`.\nTo change the item name at the start of the row order change, you can set `e.text` to the desired new name.\n */\n rowdragstart: EventEmitter<CustomEvent<IRevoGridRowDragStartDetails>>;\n /**\n * On header click.\n */\n headerclick: EventEmitter<CustomEvent<IRevoGridColumnRegular>>;\n /**\n * Before the cell focus is changed.\nTo prevent the default behavior of changing the cell focus, you can call `e.preventDefault()`.\n */\n beforecellfocus: EventEmitter<CustomEvent<IRevoGridBeforeSaveDataDetails>>;\n /**\n * Before the grid focus is lost.\nTo prevent the default behavior of changing the cell focus, you can call `e.preventDefault()`.\n */\n beforefocuslost: EventEmitter<CustomEvent<IRevoGridFocusedData | null>>;\n /**\n * Before main source/rows data apply.\nYou can override data source here\n */\n beforesourceset: EventEmitter<CustomEvent<{ type: IRevoGridDimensionRows; source: IRevoGridDataType[]; }>>;\n /**\n * Before data apply on any source type. Can be source from pinned and main viewport.\nYou can override data source here\n */\n beforeanysource: EventEmitter<CustomEvent<{ type: IRevoGridDimensionRows; source: IRevoGridDataType[]; }>>;\n /**\n * After main source/rows updated\n */\n aftersourceset: EventEmitter<CustomEvent<{ type: IRevoGridDimensionRows; source: IRevoGridDataType[]; }>>;\n /**\n * Emitted after each source update, whether from the pinned or main viewport.\nUseful for tracking all changes originating from sources in both the pinned and main viewports.\n */\n afteranysource: EventEmitter<CustomEvent<{ type: IRevoGridDimensionRows; source: IRevoGridDataType[]; }>>;\n /**\n * Emitted before a column update is applied.\nListeners can use this event to perform any necessary actions or modifications before the column update is finalized.\n */\n beforecolumnsset: EventEmitter<CustomEvent<IRevoGridColumnCollection>>;\n /**\n * Emitted before a column update is applied, after the column set is gathered and the viewport is updated.\nUseful for performing actions or modifications before the final application of the column update.\n */\n beforecolumnapplied: EventEmitter<CustomEvent<IRevoGridColumnCollection>>;\n /**\n * Column updated\n */\n aftercolumnsset: EventEmitter<CustomEvent<{ columns: IRevoGridColumnCollection; order: IRevoGridSortingOrder; }>>;\n /**\n * Emitted before applying a filter to the data source.\nUse e.preventDefault() to prevent cell focus change.\nModify if you need to change filters.\n */\n beforefilterapply: EventEmitter<CustomEvent<{ collection: Record<IRevoGridColumnProp, IRevoGridFilterCollectionItem> }>>;\n /**\n * Emitted before applying a filter to the data source.\nUse e.preventDefault() to prevent the default behavior of trimming values and applying the filter.\nModify the `collection` property if you want to change the filters.\nModify the `itemsToFilter` property if you want to filter the indexes for trimming.\n */\n beforefiltertrimmed: EventEmitter<CustomEvent<{ collection: Record<IRevoGridColumnProp, IRevoGridFilterCollectionItem>; itemsToFilter: Record<number, boolean>; }>>;\n /**\n * Emitted before trimming values.\nUse e.preventDefault() to prevent the default behavior of trimming values.\nModify the `trimmed` property if you want to filter the indexes for trimming.\n */\n beforetrimmed: EventEmitter<CustomEvent<{ trimmed: Record<number, boolean>; trimmedType: string; type: string; }>>;\n /**\n * Emitted after trimmed values have been applied.\nUseful for notifying when trimming of values has taken place.\n */\n aftertrimmed: EventEmitter<CustomEvent<any>>;\n /**\n * Emitted when the viewport is scrolled.\nUseful for tracking viewport scrolling events.\n */\n viewportscroll: EventEmitter<CustomEvent<IRevoGridViewPortScrollEvent>>;\n /**\n * Before export\nUse e.preventDefault() to prevent export\nReplace data in Event in case you want to modify it in export\n */\n beforeexport: EventEmitter<CustomEvent<IRevoGridDataInput>>;\n /**\n * Emitted before editing starts.\nUse e.preventDefault() to prevent the default edit behavior.\n */\n beforeeditstart: EventEmitter<CustomEvent<IRevoGridBeforeSaveDataDetails>>;\n /**\n * Emitted after column resizing.\nUseful for retrieving the resized columns.\n */\n aftercolumnresize: EventEmitter<CustomEvent<{ [index: number]: IRevoGridColumnRegular; }>>;\n /**\n * Emitted before the row definition is applied.\nUseful for modifying or preventing the default row definition behavior.\n */\n beforerowdefinition: EventEmitter<CustomEvent<{ vals: any; oldVals: any }>>;\n /**\n * Emitted when the filter configuration is changed\n */\n filterconfigchanged: EventEmitter<CustomEvent<any>>;\n /**\n * Emitted when the sorting configuration is changed\nSortingPlugin subsribed to this event\n */\n sortingconfigchanged: EventEmitter<CustomEvent<IRevoGridSortingConfig>>;\n /**\n * Emmited when the row headers are changed.\n */\n rowheaderschanged: EventEmitter<CustomEvent<any>>;\n /**\n * Emmited before the grid is rendered.\n */\n beforegridrender: EventEmitter<CustomEvent<any>>;\n /**\n * Emmited after the grid is rendered.\n */\n aftergridrender: EventEmitter<CustomEvent<any>>;\n /**\n * Emmited after the grid is initialized. Connected to the DOM.\n */\n aftergridinit: EventEmitter<CustomEvent<any>>;\n /**\n * Emmited after the additional data is changed\n */\n additionaldatachanged: EventEmitter<CustomEvent<any>>;\n /**\n * Emmited after the theme is changed\n */\n afterthemechanged: EventEmitter<CustomEvent<IRevoGridTheme>>;\n /**\n * Emmited after grid created\n */\n created: EventEmitter<CustomEvent<any>>;\n}\n\n\n","/**\n * Angular Adapter Function:\n * Handles the rendering and lifecycle of Angular components within StencilJS using updated Angular APIs.\n */\nimport { Injector, ComponentRef, Type, ApplicationRef, createComponent, EnvironmentInjector, inject } from '@angular/core';\nimport { ColumnDataSchemaModel, ColumnTemplateProp } from '@revolist/revogrid';\n\nexport interface AngularElement extends HTMLElement {\n componentRef?: ComponentRef<any>; // Reference to the Angular component\n}\n\nexport interface RenderedComponent<T> {\n update: (newProps: T) => void; // Function to update component with new props\n destroy: () => void; // Function to destroy the component\n}\n\nfunction updateProps<T extends object>(el: AngularElement, newProps: T) {\n if (!el.componentRef?.instance) {\n return;\n }\n \n \n // Update both ways to ensure it works with different component implementations\n el.componentRef.instance.props = newProps;\n el.componentRef.setInput('props', newProps);\n \n // Handle ngOnChanges if component implements it\n if (el.componentRef.instance.ngOnChanges) {\n const previousValue = el.componentRef.instance.props;\n const simpleChanges = {\n props: {\n previousValue,\n currentValue: newProps,\n firstChange: previousValue === undefined,\n isFirstChange: () => previousValue === undefined\n }\n };\n el.componentRef.instance.ngOnChanges(simpleChanges);\n }\n \n // Force component to check for updates\n el.componentRef.changeDetectorRef.markForCheck();\n el.componentRef.changeDetectorRef.detectChanges();\n}\n\nexport function TemplateConstructor<T extends Object>(\n el: AngularElement | null,\n AngularComponent: Type<any>,\n initialProps: T = {} as T,\n injector: Injector,\n lastEl: RenderedComponent<T> | null = null,\n): RenderedComponent<T> | null {\n if (!el) {\n lastEl?.destroy?.(); // Destroy last component if element is null\n return null;\n }\n\n if (!el.componentRef) {\n const applicationRef = injector.get(ApplicationRef);\n const environmentInjector = injector.get(EnvironmentInjector);\n const componentRef = createComponent(AngularComponent, { environmentInjector });\n applicationRef.attachView(componentRef.hostView);\n componentRef.instance.props = initialProps;\n componentRef.changeDetectorRef.detectChanges();\n el.componentRef = componentRef; // Store the component reference\n el.appendChild(componentRef.location.nativeElement);\n } else if (el.componentRef.instance) {\n updateProps(el, initialProps);\n }\n\n // Function to update component props\n const update = (newProps: T) => updateProps(el, newProps);\n\n // Function to destroy the component\n const destroy = () => {\n el.componentRef?.destroy();\n el.componentRef = undefined;\n };\n\n return { update, destroy };\n}\n\n// Function to create template for Angular component\nexport const Template = (\n AngularComponent: Type<any>,\n customProps?: any,\n injector = inject(Injector)\n) => {\n return (h: any, p: ColumnDataSchemaModel | ColumnTemplateProp, addition?: any) => {\n const props = customProps ? { ...customProps, ...p } : p;\n props.addition = addition;\n let lastEl: RenderedComponent<any> | null = null;\n return h('span', {\n key: `${p.prop}-${p.rowIndex || 0}`,\n ref: (el: AngularElement | null) => {\n lastEl = TemplateConstructor(el, AngularComponent, props, injector, lastEl);\n }\n });\n };\n};\n","import type { EditCell, ColumnDataSchemaModel, HyperFunc, VNode, EditorBase } from '@revolist/revogrid';\nimport { Injector, Type } from '@angular/core';\nimport { TemplateConstructor, RenderedComponent, AngularElement } from './renderer';\n/**\n * Data passed to editor\n */\nexport type EditorType = {\n column: ColumnDataSchemaModel;\n save: (value: any, preventFocus?: boolean) => void;\n close: (focusNext?: boolean) => void;\n} & Partial<EditCell>;\n\nexport class EditorAdapter implements EditorBase {\n public element: AngularElement | null = null;\n public editCell?: EditCell;\n private renderedComponent: RenderedComponent<any> | null = null;\n\n constructor(\n private EditorComponent: Type<any>,\n private injector: Injector,\n public column: ColumnDataSchemaModel,\n private save: (value: any, preventFocus?: boolean) => void,\n private close: (focusNext?: boolean) => void,\n ) {}\n\n // optional, called after editor rendered\n componentDidRender() {}\n\n // optional, called after editor destroyed\n disconnectedCallback() {\n this.renderedComponent?.destroy();\n this.renderedComponent = null;\n }\n\n render(h: HyperFunc<VNode>) {\n return h('span', {\n key: `${this.column.prop}-${this.editCell?.rowIndex || 0}`,\n ref: (el: AngularElement) => \n this.renderedComponent = TemplateConstructor(\n el,\n this.EditorComponent,\n {\n ...this.editCell,\n column: this.column,\n save: this.save,\n close: this.close,\n },\n this.injector,\n ),\n });\n }\n}\n","import type { ColumnDataSchemaModel, EditorCtr } from '@revolist/revogrid';\nimport { Injector, Type, inject } from '@angular/core';\nimport { EditorAdapter } from './editor.adapter';\n/**\n * Create editor constructor.\n * This function creates editor constructor by wrapping it with EditorAdapter\n * which is responsible for connecting editor with grid.\n */\nexport const Editor = (\n EditorComponent: Type<any>,\n injector = inject(Injector),\n): EditorCtr => {\n /**\n * Editor constructor wrapper\n * @param column column data to which editor is bound\n * @param save function to save data\n * @param close function to close editor\n * @returns editor instance\n */\n return function (\n column: ColumnDataSchemaModel,\n save: (value: any, preventFocus?: boolean) => void,\n close: (focusNext?: boolean) => void,\n ) {\n return new EditorAdapter(EditorComponent, injector, column, save, close);\n };\n};\n","/*\n * Public API Surface of angular-datagrid\n */\nimport { defineCustomElement as defineFilterPanel } from '@revolist/revogrid/standalone/revogr-filter-panel.js';\n// Filter is defined as a standalone component plugin and should be imported here\ndefineFilterPanel?.();\n\nexport * from '@revolist/revogrid';\nexport * from './lib/components';\nexport * from './lib/editor.adapter';\nexport * from './lib/editor';\nexport * from './lib/renderer';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["defineRevoGrid","defineFilterPanel"],"mappings":"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"}
1
+ {"version":3,"file":"revolist-angular-datagrid.mjs","sources":["../../../projects/angular-datagrid/src/lib/angular-component-lib/utils.ts","../../../projects/angular-datagrid/src/lib/components.ts","../../../projects/angular-datagrid/src/lib/renderer.ts","../../../projects/angular-datagrid/src/lib/editor.adapter.ts","../../../projects/angular-datagrid/src/lib/editor.ts","../../../projects/angular-datagrid/src/public-api.ts","../../../projects/angular-datagrid/src/revolist-angular-datagrid.ts"],"sourcesContent":["/* eslint-disable */\n/* tslint:disable */\nimport { fromEvent } from 'rxjs';\n\nexport const proxyInputs = (Cmp: any, inputs: string[]) => {\n const Prototype = Cmp.prototype;\n inputs.forEach((item) => {\n Object.defineProperty(Prototype, item, {\n get() {\n return this.el[item];\n },\n set(val: any) {\n this.z.runOutsideAngular(() => (this.el[item] = val));\n },\n /**\n * In the event that proxyInputs is called\n * multiple times re-defining these inputs\n * will cause an error to be thrown. As a result\n * we set configurable: true to indicate these\n * properties can be changed.\n */\n configurable: true,\n });\n });\n};\n\nexport const proxyMethods = (Cmp: any, methods: string[]) => {\n const Prototype = Cmp.prototype;\n methods.forEach((methodName) => {\n Prototype[methodName] = function () {\n const args = arguments;\n return this.z.runOutsideAngular(() => this.el[methodName].apply(this.el, args));\n };\n });\n};\n\nexport const proxyOutputs = (instance: any, el: any, events: string[]) => {\n events.forEach((eventName) => (instance[eventName] = fromEvent(el, eventName)));\n};\n\nexport const defineCustomElement = (tagName: string, customElement: any) => {\n if (customElement !== undefined && typeof customElements !== 'undefined' && !customElements.get(tagName)) {\n customElements.define(tagName, customElement);\n }\n};\n\n// tslint:disable-next-line: only-arrow-functions\nexport function ProxyCmp(opts: { defineCustomElementFn?: () => void; inputs?: any; methods?: any }) {\n const decorator = function (cls: any) {\n const { defineCustomElementFn, inputs, methods } = opts;\n\n if (defineCustomElementFn !== undefined) {\n defineCustomElementFn();\n }\n\n if (inputs) {\n proxyInputs(cls, inputs);\n }\n if (methods) {\n proxyMethods(cls, methods);\n }\n return cls;\n };\n return decorator;\n}\n","/* tslint:disable */\n/* auto-generated angular directive proxies */\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, NgZone } from '@angular/core';\n\nimport { ProxyCmp, proxyOutputs } from './angular-component-lib/utils';\n\nimport type { Components } from '@revolist/revogrid/standalone';\n\nimport { defineCustomElement as defineRevoGrid } from '@revolist/revogrid/standalone/revo-grid.js';\n@ProxyCmp({\n defineCustomElementFn: defineRevoGrid,\n inputs: ['accessible', 'additionalData', 'applyOnClose', 'autoSizeColumn', 'canDrag', 'canFocus', 'canMoveColumns', 'colSize', 'columnTypes', 'columns', 'disableVirtualX', 'disableVirtualY', 'editors', 'exporting', 'filter', 'focusTemplate', 'frameSize', 'grouping', 'hideAttribution', 'jobsBeforeRender', 'pinnedBottomSource', 'pinnedTopSource', 'plugins', 'range', 'readonly', 'registerVNode', 'resize', 'rowClass', 'rowDefinitions', 'rowHeaders', 'rowSize', 'rtl', 'sorting', 'source', 'stretch', 'theme', 'trimmedRows', 'useClipboard'],\n methods: ['refresh', 'setDataAt', 'scrollToRow', 'scrollToColumnIndex', 'scrollToColumnProp', 'updateColumns', 'addTrimmed', 'scrollToCoordinate', 'setCellEdit', 'setCellsFocus', 'getSource', 'getVisibleSource', 'getSourceStore', 'getColumnStore', 'updateColumnSorting', 'clearSorting', 'getColumns', 'clearFocus', 'getPlugins', 'getFocused', 'getContentSize', 'getSelectedRange', 'refreshExtraElements', 'getProviders']\n})\n@Component({\n selector: 'revo-grid',\n changeDetection: ChangeDetectionStrategy.OnPush,\n template: '<ng-content></ng-content>',\n // eslint-disable-next-line @angular-eslint/no-inputs-metadata-property\n inputs: ['accessible', 'additionalData', 'applyOnClose', 'autoSizeColumn', 'canDrag', 'canFocus', 'canMoveColumns', 'colSize', 'columnTypes', 'columns', 'disableVirtualX', 'disableVirtualY', 'editors', 'exporting', 'filter', 'focusTemplate', 'frameSize', 'grouping', 'hideAttribution', 'jobsBeforeRender', 'pinnedBottomSource', 'pinnedTopSource', 'plugins', 'range', 'readonly', 'registerVNode', 'resize', 'rowClass', 'rowDefinitions', 'rowHeaders', 'rowSize', 'rtl', 'sorting', 'source', 'stretch', 'theme', 'trimmedRows', 'useClipboard'],\n standalone: true\n})\nexport class RevoGrid {\n protected el: HTMLElement;\n constructor(c: ChangeDetectorRef, r: ElementRef, protected z: NgZone) {\n c.detach();\n this.el = r.nativeElement;\n proxyOutputs(this, this.el, ['contentsizechanged', 'beforeedit', 'beforerangeedit', 'afteredit', 'beforeautofill', 'beforerange', 'afterfocus', 'roworderchanged', 'beforesorting', 'beforesourcesortingapply', 'beforesortingapply', 'rowdragstart', 'headerclick', 'beforecellfocus', 'beforefocuslost', 'beforesourceset', 'beforeanysource', 'aftersourceset', 'afteranysource', 'beforecolumnsset', 'beforecolumnapplied', 'aftercolumnsset', 'beforefilterapply', 'beforefiltertrimmed', 'beforetrimmed', 'aftertrimmed', 'viewportscroll', 'beforeexport', 'beforeeditstart', 'aftercolumnresize', 'beforerowdefinition', 'filterconfigchanged', 'sortingconfigchanged', 'rowheaderschanged', 'beforegridrender', 'aftergridrender', 'aftergridinit', 'additionaldatachanged', 'afterthemechanged', 'created']);\n }\n}\n\n\nimport type { MultiDimensionType as IRevoGridMultiDimensionType } from '@revolist/revogrid/standalone';\nimport type { BeforeSaveDataDetails as IRevoGridBeforeSaveDataDetails } from '@revolist/revogrid/standalone';\nimport type { BeforeRangeSaveDataDetails as IRevoGridBeforeRangeSaveDataDetails } from '@revolist/revogrid/standalone';\nimport type { AfterEditEvent as IRevoGridAfterEditEvent } from '@revolist/revogrid/standalone';\nimport type { ChangedRange as IRevoGridChangedRange } from '@revolist/revogrid/standalone';\nimport type { FocusAfterRenderEvent as IRevoGridFocusAfterRenderEvent } from '@revolist/revogrid/standalone';\nimport type { ColumnRegular as IRevoGridColumnRegular } from '@revolist/revogrid/standalone';\nimport type { DimensionRows as IRevoGridDimensionRows } from '@revolist/revogrid/standalone';\nimport type { SortingOrder as IRevoGridSortingOrder } from '@revolist/revogrid/standalone';\nimport type { RowDragStartDetails as IRevoGridRowDragStartDetails } from '@revolist/revogrid/standalone';\nimport type { FocusedData as IRevoGridFocusedData } from '@revolist/revogrid/standalone';\nimport type { DataType as IRevoGridDataType } from '@revolist/revogrid/standalone';\nimport type { ColumnCollection as IRevoGridColumnCollection } from '@revolist/revogrid/standalone';\nimport type { ColumnProp as IRevoGridColumnProp } from '@revolist/revogrid/standalone';\nimport type { FilterCollectionItem as IRevoGridFilterCollectionItem } from '@revolist/revogrid/standalone';\nimport type { ViewPortScrollEvent as IRevoGridViewPortScrollEvent } from '@revolist/revogrid/standalone';\nimport type { DataInput as IRevoGridDataInput } from '@revolist/revogrid/standalone';\nimport type { SortingConfig as IRevoGridSortingConfig } from '@revolist/revogrid/standalone';\nimport type { Theme as IRevoGridTheme } from '@revolist/revogrid/standalone';\n\nexport declare interface RevoGrid extends Components.RevoGrid {\n /**\n * New content size has been applied. The size excludes the header.\nCurrently, the event responsible for applying the new content size does not provide the actual size.\nTo retrieve the actual content size, you can utilize the `getContentSize` function after the event has been triggered.\n */\n contentsizechanged: EventEmitter<CustomEvent<IRevoGridMultiDimensionType>>;\n /**\n * Before the data is edited.\nTo prevent the default behavior of editing data and use your own implementation, call `e.preventDefault()`.\nTo override the edit result with your own value, set the `e.val` property to your desired value.\n */\n beforeedit: EventEmitter<CustomEvent<IRevoGridBeforeSaveDataDetails>>;\n /**\n * Before applying range data, specifically when a range selection occurs.\nTo customize the data and prevent the default edit data from being set, you can call `e.preventDefault()`.\n */\n beforerangeedit: EventEmitter<CustomEvent<IRevoGridBeforeRangeSaveDataDetails>>;\n /**\n * After data applied or range changed.\n */\n afteredit: EventEmitter<CustomEvent<IRevoGridAfterEditEvent>>;\n /**\n * Before autofill is applied.\nTo prevent the default behavior of applying the edit data, you can call `e.preventDefault()`.\n */\n beforeautofill: EventEmitter<CustomEvent<IRevoGridChangedRange>>;\n /**\n * Before autofill is applied. Runs before beforeautofill event.\nUse e.preventDefault() to prevent range.\n */\n beforerange: EventEmitter<CustomEvent<IRevoGridChangedRange>>;\n /**\n * After focus render finished.\nCan be used to access a focus element through `event.target`.\nThis is just a duplicate of `afterfocus` from `revogr-focus.tsx`.\n */\n afterfocus: EventEmitter<CustomEvent<IRevoGridFocusAfterRenderEvent>>;\n /**\n * Before the order of `rgRow` is applied.\nTo prevent the default behavior of changing the order of `rgRow`, you can call `e.preventDefault()`.\n */\n roworderchanged: EventEmitter<CustomEvent<{ from: number; to: number }>>;\n /**\n * By `SortingPlugin`\n<br>Triggered immediately after header click.\n<br>First in sorting event sequence. Ff this event stops no other event called.\n<br>Use `e.preventDefault()` to prevent sorting.\n */\n beforesorting: EventEmitter<CustomEvent<{ column: IRevoGridColumnRegular; order: 'desc' | 'asc'; additive: boolean; }>>;\n /**\n * By `SortingPlugin`\n<br>Same as `beforesorting` but triggered after `beforeanysource` (when source is changed).\n<br>Use `e.preventDefault()` to prevent sorting data change.\n */\n beforesourcesortingapply: EventEmitter<CustomEvent<{ type: IRevoGridDimensionRows; sorting?: IRevoGridSortingOrder; }>>;\n /**\n * By `SortingPlugin`\n<br> After `beforesorting`\n<br>Triggered after column data updated with new sorting order.\n<br>Use `e.preventDefault()` to prevent sorting data change.\n */\n beforesortingapply: EventEmitter<CustomEvent<{ column: IRevoGridColumnRegular; order: 'desc' | 'asc'; additive: boolean; }>>;\n /**\n * This event is triggered when the row order change is started.\nTo prevent the default behavior of changing the row order, you can call `e.preventDefault()`.\nTo change the item name at the start of the row order change, you can set `e.text` to the desired new name.\n */\n rowdragstart: EventEmitter<CustomEvent<IRevoGridRowDragStartDetails>>;\n /**\n * On header click.\n */\n headerclick: EventEmitter<CustomEvent<IRevoGridColumnRegular>>;\n /**\n * Before the cell focus is changed.\nTo prevent the default behavior of changing the cell focus, you can call `e.preventDefault()`.\n */\n beforecellfocus: EventEmitter<CustomEvent<IRevoGridBeforeSaveDataDetails>>;\n /**\n * Before the grid focus is lost.\nTo prevent the default behavior of changing the cell focus, you can call `e.preventDefault()`.\n */\n beforefocuslost: EventEmitter<CustomEvent<IRevoGridFocusedData | null>>;\n /**\n * Before main source/rows data apply.\nYou can override data source here\n */\n beforesourceset: EventEmitter<CustomEvent<{ type: IRevoGridDimensionRows; source: IRevoGridDataType[]; }>>;\n /**\n * Before data apply on any source type. Can be source from pinned and main viewport.\nYou can override data source here\n */\n beforeanysource: EventEmitter<CustomEvent<{ type: IRevoGridDimensionRows; source: IRevoGridDataType[]; }>>;\n /**\n * After main source/rows updated\n */\n aftersourceset: EventEmitter<CustomEvent<{ type: IRevoGridDimensionRows; source: IRevoGridDataType[]; }>>;\n /**\n * Emitted after each source update, whether from the pinned or main viewport.\nUseful for tracking all changes originating from sources in both the pinned and main viewports.\n */\n afteranysource: EventEmitter<CustomEvent<{ type: IRevoGridDimensionRows; source: IRevoGridDataType[]; }>>;\n /**\n * Emitted before a column update is applied.\nListeners can use this event to perform any necessary actions or modifications before the column update is finalized.\n */\n beforecolumnsset: EventEmitter<CustomEvent<IRevoGridColumnCollection>>;\n /**\n * Emitted before a column update is applied, after the column set is gathered and the viewport is updated.\nUseful for performing actions or modifications before the final application of the column update.\n */\n beforecolumnapplied: EventEmitter<CustomEvent<IRevoGridColumnCollection>>;\n /**\n * Column updated\n */\n aftercolumnsset: EventEmitter<CustomEvent<{ columns: IRevoGridColumnCollection; order: IRevoGridSortingOrder; }>>;\n /**\n * Emitted before applying a filter to the data source.\nUse e.preventDefault() to prevent cell focus change.\nModify if you need to change filters.\n */\n beforefilterapply: EventEmitter<CustomEvent<{ collection: Record<IRevoGridColumnProp, IRevoGridFilterCollectionItem> }>>;\n /**\n * Emitted before applying a filter to the data source.\nUse e.preventDefault() to prevent the default behavior of trimming values and applying the filter.\nModify the `collection` property if you want to change the filters.\nModify the `itemsToFilter` property if you want to filter the indexes for trimming.\n */\n beforefiltertrimmed: EventEmitter<CustomEvent<{ collection: Record<IRevoGridColumnProp, IRevoGridFilterCollectionItem>; itemsToFilter: Record<number, boolean>; }>>;\n /**\n * Emitted before trimming values.\nUse e.preventDefault() to prevent the default behavior of trimming values.\nModify the `trimmed` property if you want to filter the indexes for trimming.\n */\n beforetrimmed: EventEmitter<CustomEvent<{ trimmed: Record<number, boolean>; trimmedType: string; type: string; }>>;\n /**\n * Emitted after trimmed values have been applied.\nUseful for notifying when trimming of values has taken place.\n */\n aftertrimmed: EventEmitter<CustomEvent<any>>;\n /**\n * Emitted when the viewport is scrolled.\nUseful for tracking viewport scrolling events.\n */\n viewportscroll: EventEmitter<CustomEvent<IRevoGridViewPortScrollEvent>>;\n /**\n * Before export\nUse e.preventDefault() to prevent export\nReplace data in Event in case you want to modify it in export\n */\n beforeexport: EventEmitter<CustomEvent<IRevoGridDataInput>>;\n /**\n * Emitted before editing starts.\nUse e.preventDefault() to prevent the default edit behavior.\n */\n beforeeditstart: EventEmitter<CustomEvent<IRevoGridBeforeSaveDataDetails>>;\n /**\n * Emitted after column resizing.\nUseful for retrieving the resized columns.\n */\n aftercolumnresize: EventEmitter<CustomEvent<{ [index: number]: IRevoGridColumnRegular; }>>;\n /**\n * Emitted before the row definition is applied.\nUseful for modifying or preventing the default row definition behavior.\n */\n beforerowdefinition: EventEmitter<CustomEvent<{ vals: any; oldVals: any }>>;\n /**\n * Emitted when the filter configuration is changed\n */\n filterconfigchanged: EventEmitter<CustomEvent<any>>;\n /**\n * Emitted when the sorting configuration is changed\nSortingPlugin subsribed to this event\n */\n sortingconfigchanged: EventEmitter<CustomEvent<IRevoGridSortingConfig>>;\n /**\n * Emmited when the row headers are changed.\n */\n rowheaderschanged: EventEmitter<CustomEvent<any>>;\n /**\n * Emmited before the grid is rendered.\n */\n beforegridrender: EventEmitter<CustomEvent<any>>;\n /**\n * Emmited after the grid is rendered.\n */\n aftergridrender: EventEmitter<CustomEvent<any>>;\n /**\n * Emmited after the grid is initialized. Connected to the DOM.\n */\n aftergridinit: EventEmitter<CustomEvent<any>>;\n /**\n * Emmited after the additional data is changed\n */\n additionaldatachanged: EventEmitter<CustomEvent<any>>;\n /**\n * Emmited after the theme is changed\n */\n afterthemechanged: EventEmitter<CustomEvent<IRevoGridTheme>>;\n /**\n * Emmited after grid created\n */\n created: EventEmitter<CustomEvent<any>>;\n}\n\n\n","/**\n * Angular Adapter Function:\n * Handles the rendering and lifecycle of Angular components within StencilJS using updated Angular APIs.\n */\nimport { Injector, ComponentRef, Type, ApplicationRef, createComponent, EnvironmentInjector, inject } from '@angular/core';\nimport { ColumnDataSchemaModel, ColumnTemplateProp } from '@revolist/revogrid';\n\nexport interface AngularElement extends HTMLElement {\n componentRef?: ComponentRef<any>; // Reference to the Angular component\n}\n\nexport interface RenderedComponent<T> {\n update: (newProps: T) => void; // Function to update component with new props\n destroy: () => void; // Function to destroy the component\n}\n\nfunction updateProps<T extends object>(el: AngularElement, newProps: T) {\n if (!el.componentRef?.instance) {\n return;\n }\n \n \n // Update both ways to ensure it works with different component implementations\n el.componentRef.instance.props = newProps;\n el.componentRef.setInput('props', newProps);\n \n // Handle ngOnChanges if component implements it\n if (el.componentRef.instance.ngOnChanges) {\n const previousValue = el.componentRef.instance.props;\n const simpleChanges = {\n props: {\n previousValue,\n currentValue: newProps,\n firstChange: previousValue === undefined,\n isFirstChange: () => previousValue === undefined\n }\n };\n el.componentRef.instance.ngOnChanges(simpleChanges);\n }\n \n // Force component to check for updates\n el.componentRef.changeDetectorRef.markForCheck();\n el.componentRef.changeDetectorRef.detectChanges();\n}\n\nexport function TemplateConstructor<T extends Object>(\n el: AngularElement | null,\n AngularComponent: Type<any>,\n initialProps: T = {} as T,\n injector: Injector,\n lastEl: RenderedComponent<T> | null = null,\n): RenderedComponent<T> | null {\n if (!el) {\n lastEl?.destroy?.(); // Destroy last component if element is null\n return null;\n }\n\n if (!el.componentRef) {\n const applicationRef = injector.get(ApplicationRef);\n const environmentInjector = injector.get(EnvironmentInjector);\n const componentRef = createComponent(AngularComponent, { environmentInjector });\n applicationRef.attachView(componentRef.hostView);\n componentRef.instance.props = initialProps;\n componentRef.changeDetectorRef.detectChanges();\n el.componentRef = componentRef; // Store the component reference\n el.appendChild(componentRef.location.nativeElement);\n } else if (el.componentRef.instance) {\n updateProps(el, initialProps);\n }\n\n // Function to update component props\n const update = (newProps: T) => updateProps(el, newProps);\n\n // Function to destroy the component\n const destroy = () => {\n el.componentRef?.destroy();\n el.componentRef = undefined;\n };\n\n return { update, destroy };\n}\n\n// Function to create template for Angular component\nexport const Template = (\n AngularComponent: Type<any>,\n customProps?: any,\n injector = inject(Injector)\n) => {\n return (h: any, p: ColumnDataSchemaModel | ColumnTemplateProp, addition?: any) => {\n const props = customProps ? { ...customProps, ...p } : p;\n props.addition = addition;\n let lastEl: RenderedComponent<any> | null = null;\n return h('span', {\n key: `${p.prop}-${p.rowIndex || 0}`,\n ref: (el: AngularElement | null) => {\n lastEl = TemplateConstructor(el, AngularComponent, props, injector, lastEl);\n }\n });\n };\n};\n","import type { EditCell, ColumnDataSchemaModel, HyperFunc, VNode, EditorBase } from '@revolist/revogrid';\nimport { Injector, Type } from '@angular/core';\nimport { TemplateConstructor, RenderedComponent, AngularElement } from './renderer';\n/**\n * Data passed to editor\n */\nexport type EditorType = {\n column: ColumnDataSchemaModel;\n save: (value: any, preventFocus?: boolean) => void;\n close: (focusNext?: boolean) => void;\n} & Partial<EditCell>;\n\nexport class EditorAdapter implements EditorBase {\n public element: AngularElement | null = null;\n public editCell?: EditCell;\n private renderedComponent: RenderedComponent<any> | null = null;\n\n constructor(\n private EditorComponent: Type<any>,\n private injector: Injector,\n public column: ColumnDataSchemaModel,\n private save: (value: any, preventFocus?: boolean) => void,\n private close: (focusNext?: boolean) => void,\n ) {}\n\n // optional, called after editor rendered\n componentDidRender() {}\n\n // optional, called after editor destroyed\n disconnectedCallback() {\n this.renderedComponent?.destroy();\n this.renderedComponent = null;\n }\n\n render(h: HyperFunc<VNode>) {\n return h('span', {\n key: `${this.column.prop}-${this.editCell?.rowIndex || 0}`,\n ref: (el: AngularElement) => \n this.renderedComponent = TemplateConstructor(\n el,\n this.EditorComponent,\n {\n ...this.editCell,\n column: this.column,\n save: this.save,\n close: this.close,\n },\n this.injector,\n ),\n });\n }\n}\n","import type { ColumnDataSchemaModel, EditorCtr } from '@revolist/revogrid';\nimport { Injector, Type, inject } from '@angular/core';\nimport { EditorAdapter } from './editor.adapter';\n/**\n * Create editor constructor.\n * This function creates editor constructor by wrapping it with EditorAdapter\n * which is responsible for connecting editor with grid.\n */\nexport const Editor = (\n EditorComponent: Type<any>,\n injector = inject(Injector),\n): EditorCtr => {\n /**\n * Editor constructor wrapper\n * @param column column data to which editor is bound\n * @param save function to save data\n * @param close function to close editor\n * @returns editor instance\n */\n return function (\n column: ColumnDataSchemaModel,\n save: (value: any, preventFocus?: boolean) => void,\n close: (focusNext?: boolean) => void,\n ) {\n return new EditorAdapter(EditorComponent, injector, column, save, close);\n };\n};\n","/*\n * Public API Surface of angular-datagrid\n */\nimport { defineCustomElement as defineFilterPanel } from '@revolist/revogrid/standalone/revogr-filter-panel.js';\n// Filter is defined as a standalone component plugin and should be imported here\ndefineFilterPanel?.();\n\nexport * from '@revolist/revogrid';\nexport * from './lib/components';\nexport * from './lib/editor.adapter';\nexport * from './lib/editor';\nexport * from './lib/renderer';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["defineRevoGrid","defineFilterPanel"],"mappings":"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"}
@@ -25,7 +25,7 @@ export declare class RevoGrid {
25
25
  protected el: HTMLElement;
26
26
  constructor(c: ChangeDetectorRef, r: ElementRef, z: NgZone);
27
27
  static ɵfac: i0.ɵɵFactoryDeclaration<RevoGrid, never>;
28
- static ɵcmp: i0.ɵɵComponentDeclaration<RevoGrid, "revo-grid", never, { "accessible": { "alias": "accessible"; "required": false; }; "additionalData": { "alias": "additionalData"; "required": false; }; "applyOnClose": { "alias": "applyOnClose"; "required": false; }; "autoSizeColumn": { "alias": "autoSizeColumn"; "required": false; }; "canDrag": { "alias": "canDrag"; "required": false; }; "canFocus": { "alias": "canFocus"; "required": false; }; "canMoveColumns": { "alias": "canMoveColumns"; "required": false; }; "colSize": { "alias": "colSize"; "required": false; }; "columnTypes": { "alias": "columnTypes"; "required": false; }; "columns": { "alias": "columns"; "required": false; }; "disableVirtualX": { "alias": "disableVirtualX"; "required": false; }; "disableVirtualY": { "alias": "disableVirtualY"; "required": false; }; "editors": { "alias": "editors"; "required": false; }; "exporting": { "alias": "exporting"; "required": false; }; "filter": { "alias": "filter"; "required": false; }; "focusTemplate": { "alias": "focusTemplate"; "required": false; }; "frameSize": { "alias": "frameSize"; "required": false; }; "grouping": { "alias": "grouping"; "required": false; }; "hideAttribution": { "alias": "hideAttribution"; "required": false; }; "jobsBeforeRender": { "alias": "jobsBeforeRender"; "required": false; }; "pinnedBottomSource": { "alias": "pinnedBottomSource"; "required": false; }; "pinnedTopSource": { "alias": "pinnedTopSource"; "required": false; }; "plugins": { "alias": "plugins"; "required": false; }; "range": { "alias": "range"; "required": false; }; "readonly": { "alias": "readonly"; "required": false; }; "registerVNode": { "alias": "registerVNode"; "required": false; }; "resize": { "alias": "resize"; "required": false; }; "rowClass": { "alias": "rowClass"; "required": false; }; "rowDefinitions": { "alias": "rowDefinitions"; "required": false; }; "rowHeaders": { "alias": "rowHeaders"; "required": false; }; "rowSize": { "alias": "rowSize"; "required": false; }; "sorting": { "alias": "sorting"; "required": false; }; "source": { "alias": "source"; "required": false; }; "stretch": { "alias": "stretch"; "required": false; }; "theme": { "alias": "theme"; "required": false; }; "trimmedRows": { "alias": "trimmedRows"; "required": false; }; "useClipboard": { "alias": "useClipboard"; "required": false; }; }, {}, never, ["*"], true, never>;
28
+ static ɵcmp: i0.ɵɵComponentDeclaration<RevoGrid, "revo-grid", never, { "accessible": { "alias": "accessible"; "required": false; }; "additionalData": { "alias": "additionalData"; "required": false; }; "applyOnClose": { "alias": "applyOnClose"; "required": false; }; "autoSizeColumn": { "alias": "autoSizeColumn"; "required": false; }; "canDrag": { "alias": "canDrag"; "required": false; }; "canFocus": { "alias": "canFocus"; "required": false; }; "canMoveColumns": { "alias": "canMoveColumns"; "required": false; }; "colSize": { "alias": "colSize"; "required": false; }; "columnTypes": { "alias": "columnTypes"; "required": false; }; "columns": { "alias": "columns"; "required": false; }; "disableVirtualX": { "alias": "disableVirtualX"; "required": false; }; "disableVirtualY": { "alias": "disableVirtualY"; "required": false; }; "editors": { "alias": "editors"; "required": false; }; "exporting": { "alias": "exporting"; "required": false; }; "filter": { "alias": "filter"; "required": false; }; "focusTemplate": { "alias": "focusTemplate"; "required": false; }; "frameSize": { "alias": "frameSize"; "required": false; }; "grouping": { "alias": "grouping"; "required": false; }; "hideAttribution": { "alias": "hideAttribution"; "required": false; }; "jobsBeforeRender": { "alias": "jobsBeforeRender"; "required": false; }; "pinnedBottomSource": { "alias": "pinnedBottomSource"; "required": false; }; "pinnedTopSource": { "alias": "pinnedTopSource"; "required": false; }; "plugins": { "alias": "plugins"; "required": false; }; "range": { "alias": "range"; "required": false; }; "readonly": { "alias": "readonly"; "required": false; }; "registerVNode": { "alias": "registerVNode"; "required": false; }; "resize": { "alias": "resize"; "required": false; }; "rowClass": { "alias": "rowClass"; "required": false; }; "rowDefinitions": { "alias": "rowDefinitions"; "required": false; }; "rowHeaders": { "alias": "rowHeaders"; "required": false; }; "rowSize": { "alias": "rowSize"; "required": false; }; "rtl": { "alias": "rtl"; "required": false; }; "sorting": { "alias": "sorting"; "required": false; }; "source": { "alias": "source"; "required": false; }; "stretch": { "alias": "stretch"; "required": false; }; "theme": { "alias": "theme"; "required": false; }; "trimmedRows": { "alias": "trimmedRows"; "required": false; }; "useClipboard": { "alias": "useClipboard"; "required": false; }; }, {}, never, ["*"], true, never>;
29
29
  }
30
30
  export declare interface RevoGrid extends Components.RevoGrid {
31
31
  /**
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@revolist/angular-datagrid",
3
- "version": "4.15.7",
3
+ "version": "4.16.0",
4
4
  "description": "Angular DataGrid Spreadsheet component with native cell render support",
5
5
  "keywords": [
6
6
  "revo-grid",
@@ -43,7 +43,7 @@
43
43
  "homepage": "https://github.com/revolist/revogrid#readme",
44
44
  "license": "MIT",
45
45
  "dependencies": {
46
- "@revolist/revogrid": "4.15.7",
46
+ "@revolist/revogrid": "4.16.0",
47
47
  "@stencil/core": "^4.19.2",
48
48
  "tslib": "^2.6.3"
49
49
  },