ngx-rs-ant 0.8.4 → 0.9.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/data-grid/data-grid.component.d.ts +4 -2
- package/data-grid/data-grid.module.d.ts +2 -1
- package/esm2020/box-container/PluginManager.mjs +2 -2
- package/esm2020/box-container/box-item/item-config/item-config.component.mjs +9 -4
- package/esm2020/data-grid/data-grid.component.mjs +97 -25
- package/esm2020/data-grid/data-grid.module.mjs +8 -4
- package/esm2020/modal/modal.component.mjs +3 -5
- package/esm2020/modal/modal.service.mjs +2 -1
- package/fesm2015/ngx-rs-ant.mjs +116 -36
- package/fesm2015/ngx-rs-ant.mjs.map +1 -1
- package/fesm2020/ngx-rs-ant.mjs +114 -36
- package/fesm2020/ngx-rs-ant.mjs.map +1 -1
- package/modal/modal.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -5,21 +5,23 @@ import { MasterDetailTemplateDirective } from "./master-detail-template.directiv
|
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export declare class DataGridComponent implements OnInit {
|
|
7
7
|
private service;
|
|
8
|
+
private locale;
|
|
8
9
|
tenant: any;
|
|
9
10
|
className: any;
|
|
10
11
|
view?: any;
|
|
11
12
|
filter?: any;
|
|
12
13
|
enableMasterDetail: boolean;
|
|
14
|
+
customColumnFn?: (columns: any[]) => void;
|
|
13
15
|
dataSource: any;
|
|
14
16
|
columns: any[];
|
|
15
17
|
typeMap: any;
|
|
16
18
|
dxDataGrid: DxDataGridComponent;
|
|
17
19
|
masterDetailTemplate: MasterDetailTemplateDirective;
|
|
18
|
-
constructor(service: DataGridService);
|
|
20
|
+
constructor(service: DataGridService, locale: string);
|
|
19
21
|
ngOnInit(): void;
|
|
20
22
|
reload(): void;
|
|
21
23
|
refresh(callback?: any): void;
|
|
22
24
|
getSelectedRowKeys(): any[] & Promise<any[]>;
|
|
23
25
|
static ɵfac: i0.ɵɵFactoryDeclaration<DataGridComponent, never>;
|
|
24
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<DataGridComponent, "rs-data-grid", never, { "tenant": "tenant"; "className": "className"; "view": "view"; "filter": "filter"; "enableMasterDetail": "enableMasterDetail"; }, {}, ["masterDetailTemplate"], never, false, never>;
|
|
26
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DataGridComponent, "rs-data-grid", never, { "tenant": "tenant"; "className": "className"; "view": "view"; "filter": "filter"; "enableMasterDetail": "enableMasterDetail"; "customColumnFn": "customColumnFn"; }, {}, ["masterDetailTemplate"], never, false, never>;
|
|
25
27
|
}
|
|
@@ -3,8 +3,9 @@ import * as i1 from "./data-grid.component";
|
|
|
3
3
|
import * as i2 from "./master-detail-template.directive";
|
|
4
4
|
import * as i3 from "@angular/common";
|
|
5
5
|
import * as i4 from "devextreme-angular";
|
|
6
|
+
import * as i5 from "ng-devui";
|
|
6
7
|
export declare class DataGridModule {
|
|
7
8
|
static ɵfac: i0.ɵɵFactoryDeclaration<DataGridModule, never>;
|
|
8
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<DataGridModule, [typeof i1.DataGridComponent, typeof i2.MasterDetailTemplateDirective], [typeof i3.CommonModule, typeof i4.DxDataGridModule], [typeof i1.DataGridComponent, typeof i2.MasterDetailTemplateDirective]>;
|
|
9
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<DataGridModule, [typeof i1.DataGridComponent, typeof i2.MasterDetailTemplateDirective], [typeof i3.CommonModule, typeof i4.DxDataGridModule, typeof i5.DevUIModule], [typeof i1.DataGridComponent, typeof i2.MasterDetailTemplateDirective]>;
|
|
9
10
|
static ɵinj: i0.ɵɵInjectorDeclaration<DataGridModule>;
|
|
10
11
|
}
|
|
@@ -83,7 +83,7 @@ export class PluginManager {
|
|
|
83
83
|
if (this.activeItems.indexOf($event.target) < 0) {
|
|
84
84
|
return;
|
|
85
85
|
}
|
|
86
|
-
this.activeItem.next({ boxItem, index, style, config: config.config });
|
|
86
|
+
this.activeItem.next({ boxItem, index, style, config: config.config, componentRef });
|
|
87
87
|
$event.target.classList.add('plugin-active');
|
|
88
88
|
});
|
|
89
89
|
activeComponentRef.instance.itemRemove.subscribe(() => {
|
|
@@ -97,4 +97,4 @@ export class PluginManager {
|
|
|
97
97
|
PluginManager.hoverItems = [];
|
|
98
98
|
PluginManager.activeItem = new Subject();
|
|
99
99
|
PluginManager.activeItems = [];
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PluginManager.js","sourceRoot":"","sources":["../../../../projects/ngx-rs-ant/src/box-container/PluginManager.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,aAAa,EAAC,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAC,qBAAqB,EAAC,MAAM,yCAAyC,CAAC;AAC9E,OAAO,EAAC,oBAAoB,EAAC,MAAM,uCAAuC,CAAC;AAC3E,OAAO,EAAC,OAAO,EAAC,MAAM,MAAM,CAAC;AAE7B,OAAO,EAAC,uBAAuB,EAAC,MAAM,+CAA+C,CAAC;AAEtF,MAAM,OAAO,aAAa;IAKxB,MAAM,CAAC,eAAe,CAAC,OAAyB,EAAE,KAAa,EAAE,KAAU,EAAE,MAAW;QACtF,IAAI,MAAM,GAAQ,aAAa,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACjD,IAAI,CAAC,MAAM,EAAE;YACX,OAAO,CAAC,KAAK,CAAC,oBAAoB,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC;YAClD,MAAM,GAAG;gBACP,SAAS,EAAE,uBAAuB;gBAClC,IAAI,EAAE,MAAM,CAAC,IAAI;gBACjB,OAAO,EAAE,MAAM,CAAC,IAAI;aACrB,CAAA;SACF;QACD,MAAM,gBAAgB,GAAQ,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,gBAAgB,CAAC;QAC7E,gBAAgB,CAAC,KAAK,EAAE,CAAC;QACzB,MAAM,YAAY,GAAG,gBAAgB,CAAC,eAAe,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACxE,MAAM,QAAQ,GAAQ,YAAY,CAAC,QAAQ,CAAC;QAC5C,MAAM,CAAC,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,YAAY,CAAC,CAAC;QAC7C,IAAI,MAAM,CAAC,IAAI,KAAK,MAAM,EAAE;YAC1B,QAAQ,CAAC,SAAS,GAAG,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC;YACpD,QAAQ,CAAC,KAAK,GAAG,OAAO,CAAC,YAAY,CAAC,KAAK,CAAC;SAC7C;QACD,QAAQ,CAAC,mBAAmB,GAAG,OAAO,CAAC,YAAY,CAAC,mBAAmB,CAAC;QACxE,IAAI,OAAO,CAAC,YAAY,CAAC,QAAQ,EAAE;YACjC,QAAQ,CAAC,QAAQ,GAAG,GAAG,EAAE;gBACvB,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,EAAE,EAAC,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,KAAK,EAAC,CAAC,CAAC;gBAC/F,OAAO,CAAC,IAAI,EAAE,CAAC;YACjB,CAAC,CAAC;YACF,YAAY,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,aAAa,GAAG,KAAK,CAAC;YAChE,KAAK,IAAI,KAAK,IAAI,YAAY,CAAC,QAAQ,CAAC,aAAa,CAAC,QAAQ,EAAE;gBAC9D,KAAK,CAAC,KAAK,CAAC,aAAa,GAAG,MAAM,CAAC;aACpC;YACD,IAAI,CAAC,oBAAoB,CAAC,gBAAgB,EAAE,YAAY,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC;YAC1E,IAAI,CAAC,qBAAqB,CAAC,OAAO,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE;gBAC9D,OAAO,EAAE,MAAM,CAAC,OAAO;gBACvB,MAAM;aACP,EAAE,IAAI,CAAC,CAAC;SACV;QACD,OAAO,YAAY,CAAC;IACtB,CAAC;IAED,MAAM,CAAC,oBAAoB,CAAC,gBAAkC,EAAE,YAA+B,EAAE,OAAe;QAC9G,MAAM,iBAAiB,GAAG,gBAAgB,CAAC,eAAe,CAAC,oBAAoB,CAAC,CAAC;QACjF,iBAAiB,CAAC,QAAQ,CAAC,IAAI,GAAG,OAAO,CAAC;QAC1C,iBAAiB,CAAC,QAAQ,CAAC,aAAa,GAAG,YAAY,CAAC,QAAQ,CAAC,aAAa,CAAC;QAC/E,MAAM,YAAY,GAAG,iBAAiB,CAAC,QAAQ,CAAC,aAAa,CAAC;QAC9D,YAAY,CAAC,QAAQ,CAAC,aAAa,CAAC,WAAW,CAAC,YAAY,CAAC,CAAC;QAC9D,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;QAC1D,YAAY,CAAC,QAAQ,CAAC,aAAa,CAAC,gBAAgB,CAAC,YAAY,EAAE,CAAC,MAAW,EAAE,EAAE;YACjF,KAAK,IAAI,SAAS,IAAI,IAAI,CAAC,UAAU,EAAE;gBACrC,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;aAC5C;YACD,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QAC9C,CAAC,CAAC,CAAC;QACH,YAAY,CAAC,QAAQ,CAAC,aAAa,CAAC,gBAAgB,CAAC,YAAY,EAAE,CAAC,MAAW,EAAE,EAAE;YACjF,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;YAC/C,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;QAC1E,CAAC,CAAC,CAAC;QACH,OAAO,iBAAiB,CAAC;IAC3B,CAAC;IAED,MAAM,CAAC,qBAAqB,CAAC,OAAyB,EAAE,KAAa,EAAE,YAA+B,EACzE,KAAU,EAAE,MAAW,EAAE,SAAkB;QACtE,MAAM,gBAAgB,GAAQ,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,gBAAgB,CAAC;QAC7E,MAAM,kBAAkB,GAAG,gBAAgB,CAAC,eAAe,CAAC,qBAAqB,CAAC,CAAC;QACnF,kBAAkB,CAAC,QAAQ,CAAC,IAAI,GAAG,MAAM,CAAC,OAAO,CAAC;QAClD,kBAAkB,CAAC,QAAQ,CAAC,SAAS,GAAG,SAAS,CAAC;QAClD,kBAAkB,CAAC,QAAQ,CAAC,QAAQ,GAAG;YACrC,IAAI,EAAE,aAAa;YACnB,OAAO;YACP,KAAK;YACL,MAAM,EAAE,MAAM,CAAC,MAAM;SACtB,CAAC;QACF,kBAAkB,CAAC,QAAQ,CAAC,aAAa,GAAG,YAAY,CAAC,QAAQ,CAAC,aAAa,CAAC;QAChF,MAAM,aAAa,GAAG,kBAAkB,CAAC,QAAQ,CAAC,aAAa,CAAC;QAChE,YAAY,CAAC,QAAQ,CAAC,aAAa,CAAC,WAAW,CAAC,aAAa,CAAC,CAAC;QAC/D,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;QAC3D,YAAY,CAAC,QAAQ,CAAC,aAAa,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC,MAAW,EAAE,EAAE;YAC5E,MAAM,CAAC,eAAe,EAAE,CAAC;YACzB,KAAK,IAAI,UAAU,IAAI,IAAI,CAAC,WAAW,EAAE;gBACvC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;aAC9C;YACD,IAAI,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE;gBAC/C,OAAO;aACR;YACD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAC,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAC,CAAC,CAAC;YACrE,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;QAC/C,CAAC,CAAC,CAAC;QACH,kBAAkB,CAAC,QAAQ,CAAC,UAAU,CAAC,SAAS,CAAC,GAAG,EAAE;YACpD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACzB,gBAAgB,CAAC,KAAK,EAAE,CAAC;YACzB,YAAY,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;QACnC,CAAC,CAAC,CAAC;QACH,OAAO,kBAAkB,CAAC;IAC5B,CAAC;;AA/FM,wBAAU,GAAU,EAAE,CAAC;AACvB,wBAAU,GAAG,IAAI,OAAO,EAAO,CAAC;AAChC,yBAAW,GAAU,EAAE,CAAC","sourcesContent":["import {ComponentRef, ViewContainerRef} from '@angular/core';\r\nimport {PluginFactory} from 'coast-plugin-register';\r\nimport {PluginActiveComponent} from './plugin-active/plugin-active.component';\r\nimport {PluginHoverComponent} from './plugin-hover/plugin-hover.component';\r\nimport {Subject} from 'rxjs';\r\nimport {BoxItemComponent} from './box-item/box-item.component';\r\nimport {PluginNotFoundComponent} from \"./plugin-not-found/plugin-not-found.component\";\r\n\r\nexport class PluginManager {\r\n  static hoverItems: any[] = [];\r\n  static activeItem = new Subject<any>();\r\n  static activeItems: any[] = [];\r\n\r\n  static createComponent(boxItem: BoxItemComponent, index: number, style: any, config: any): any {\r\n    let plugin: any = PluginFactory.get(config.name);\r\n    if (!plugin) {\r\n      console.error('undefined plugin: ' + config.name);\r\n      plugin = {\r\n        component: PluginNotFoundComponent,\r\n        name: config.name,\r\n        caption: config.name\r\n      }\r\n    }\r\n    const viewContainerRef: any = boxItem.itemHosts.get(index)?.viewContainerRef;\r\n    viewContainerRef.clear();\r\n    const componentRef = viewContainerRef.createComponent(plugin.component);\r\n    const instance: any = componentRef.instance;\r\n    Object.assign(instance, config.pluginConfig);\r\n    if (plugin.type === 'form') {\r\n      instance.formGroup = boxItem.boxContainer.formGroup;\r\n      instance.model = boxItem.boxContainer.model;\r\n    }\r\n    instance.tabViewContainerRef = boxItem.boxContainer.tabViewContainerRef;\r\n    if (boxItem.boxContainer.editMode) {\r\n      instance.onRemove = () => {\r\n        boxItem.config.list.splice(index, 1, {type: 'blank', style: boxItem.config.list[index].style});\r\n        boxItem.load();\r\n      };\r\n      componentRef.location.nativeElement.style.pointerEvents = 'all';\r\n      for (let child of componentRef.location.nativeElement.children) {\r\n        child.style.pointerEvents = 'none';\r\n      }\r\n      this.createHoverComponent(viewContainerRef, componentRef, plugin.caption);\r\n      this.createActiveComponent(boxItem, index, componentRef, style, {\r\n        caption: plugin.caption,\r\n        config\r\n      }, true);\r\n    }\r\n    return componentRef;\r\n  }\r\n\r\n  static createHoverComponent(viewContainerRef: ViewContainerRef, componentRef: ComponentRef<any>, caption: string): any {\r\n    const hoverComponentRef = viewContainerRef.createComponent(PluginHoverComponent);\r\n    hoverComponentRef.instance.name = caption;\r\n    hoverComponentRef.instance.targetElement = componentRef.location.nativeElement;\r\n    const hoverElement = hoverComponentRef.location.nativeElement;\r\n    componentRef.location.nativeElement.appendChild(hoverElement);\r\n    this.hoverItems.push(componentRef.location.nativeElement);\r\n    componentRef.location.nativeElement.addEventListener('mouseenter', ($event: any) => {\r\n      for (let hoverItem of this.hoverItems) {\r\n        hoverItem.classList.remove('plugin-hover');\r\n      }\r\n      $event.target.classList.add('plugin-hover');\r\n    });\r\n    componentRef.location.nativeElement.addEventListener('mouseleave', ($event: any) => {\r\n      $event.target.classList.remove('plugin-hover');\r\n      $event.target.parentElement.parentElement.classList.add('plugin-hover');\r\n    });\r\n    return hoverComponentRef;\r\n  }\r\n\r\n  static createActiveComponent(boxItem: BoxItemComponent, index: number, componentRef: ComponentRef<any>,\r\n                               style: any, config: any, showClose: boolean): any {\r\n    const viewContainerRef: any = boxItem.itemHosts.get(index)?.viewContainerRef;\r\n    const activeComponentRef = viewContainerRef.createComponent(PluginActiveComponent);\r\n    activeComponentRef.instance.name = config.caption;\r\n    activeComponentRef.instance.showClose = showClose;\r\n    activeComponentRef.instance.dragData = {\r\n      type: 'plugin-item',\r\n      boxItem,\r\n      index,\r\n      config: config.config\r\n    };\r\n    activeComponentRef.instance.targetElement = componentRef.location.nativeElement;\r\n    const activeElement = activeComponentRef.location.nativeElement;\r\n    componentRef.location.nativeElement.appendChild(activeElement);\r\n    this.activeItems.push(componentRef.location.nativeElement);\r\n    componentRef.location.nativeElement.addEventListener('click', ($event: any) => {\r\n      $event.stopPropagation();\r\n      for (let activeItem of this.activeItems) {\r\n        activeItem.classList.remove('plugin-active');\r\n      }\r\n      if (this.activeItems.indexOf($event.target) < 0) {\r\n        return;\r\n      }\r\n      this.activeItem.next({boxItem, index, style, config: config.config});\r\n      $event.target.classList.add('plugin-active');\r\n    });\r\n    activeComponentRef.instance.itemRemove.subscribe(() => {\r\n      this.activeItem.next('');\r\n      viewContainerRef.clear();\r\n      componentRef.instance.onRemove();\r\n    });\r\n    return activeComponentRef;\r\n  }\r\n}\r\n"]}
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PluginManager.js","sourceRoot":"","sources":["../../../../projects/ngx-rs-ant/src/box-container/PluginManager.ts"],"names":[],"mappings":"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","sourcesContent":["import {ComponentRef, ViewContainerRef} from '@angular/core';\r\nimport {PluginFactory} from 'coast-plugin-register';\r\nimport {PluginActiveComponent} from './plugin-active/plugin-active.component';\r\nimport {PluginHoverComponent} from './plugin-hover/plugin-hover.component';\r\nimport {Subject} from 'rxjs';\r\nimport {BoxItemComponent} from './box-item/box-item.component';\r\nimport {PluginNotFoundComponent} from \"./plugin-not-found/plugin-not-found.component\";\r\n\r\nexport class PluginManager {\r\n  static hoverItems: any[] = [];\r\n  static activeItem = new Subject<any>();\r\n  static activeItems: any[] = [];\r\n\r\n  static createComponent(boxItem: BoxItemComponent, index: number, style: any, config: any): any {\r\n    let plugin: any = PluginFactory.get(config.name);\r\n    if (!plugin) {\r\n      console.error('undefined plugin: ' + config.name);\r\n      plugin = {\r\n        component: PluginNotFoundComponent,\r\n        name: config.name,\r\n        caption: config.name\r\n      }\r\n    }\r\n    const viewContainerRef: any = boxItem.itemHosts.get(index)?.viewContainerRef;\r\n    viewContainerRef.clear();\r\n    const componentRef = viewContainerRef.createComponent(plugin.component);\r\n    const instance: any = componentRef.instance;\r\n    Object.assign(instance, config.pluginConfig);\r\n    if (plugin.type === 'form') {\r\n      instance.formGroup = boxItem.boxContainer.formGroup;\r\n      instance.model = boxItem.boxContainer.model;\r\n    }\r\n    instance.tabViewContainerRef = boxItem.boxContainer.tabViewContainerRef;\r\n    if (boxItem.boxContainer.editMode) {\r\n      instance.onRemove = () => {\r\n        boxItem.config.list.splice(index, 1, {type: 'blank', style: boxItem.config.list[index].style});\r\n        boxItem.load();\r\n      };\r\n      componentRef.location.nativeElement.style.pointerEvents = 'all';\r\n      for (let child of componentRef.location.nativeElement.children) {\r\n        child.style.pointerEvents = 'none';\r\n      }\r\n      this.createHoverComponent(viewContainerRef, componentRef, plugin.caption);\r\n      this.createActiveComponent(boxItem, index, componentRef, style, {\r\n        caption: plugin.caption,\r\n        config\r\n      }, true);\r\n    }\r\n    return componentRef;\r\n  }\r\n\r\n  static createHoverComponent(viewContainerRef: ViewContainerRef, componentRef: ComponentRef<any>, caption: string): any {\r\n    const hoverComponentRef = viewContainerRef.createComponent(PluginHoverComponent);\r\n    hoverComponentRef.instance.name = caption;\r\n    hoverComponentRef.instance.targetElement = componentRef.location.nativeElement;\r\n    const hoverElement = hoverComponentRef.location.nativeElement;\r\n    componentRef.location.nativeElement.appendChild(hoverElement);\r\n    this.hoverItems.push(componentRef.location.nativeElement);\r\n    componentRef.location.nativeElement.addEventListener('mouseenter', ($event: any) => {\r\n      for (let hoverItem of this.hoverItems) {\r\n        hoverItem.classList.remove('plugin-hover');\r\n      }\r\n      $event.target.classList.add('plugin-hover');\r\n    });\r\n    componentRef.location.nativeElement.addEventListener('mouseleave', ($event: any) => {\r\n      $event.target.classList.remove('plugin-hover');\r\n      $event.target.parentElement.parentElement.classList.add('plugin-hover');\r\n    });\r\n    return hoverComponentRef;\r\n  }\r\n\r\n  static createActiveComponent(boxItem: BoxItemComponent, index: number, componentRef: ComponentRef<any>,\r\n                               style: any, config: any, showClose: boolean): any {\r\n    const viewContainerRef: any = boxItem.itemHosts.get(index)?.viewContainerRef;\r\n    const activeComponentRef = viewContainerRef.createComponent(PluginActiveComponent);\r\n    activeComponentRef.instance.name = config.caption;\r\n    activeComponentRef.instance.showClose = showClose;\r\n    activeComponentRef.instance.dragData = {\r\n      type: 'plugin-item',\r\n      boxItem,\r\n      index,\r\n      config: config.config\r\n    };\r\n    activeComponentRef.instance.targetElement = componentRef.location.nativeElement;\r\n    const activeElement = activeComponentRef.location.nativeElement;\r\n    componentRef.location.nativeElement.appendChild(activeElement);\r\n    this.activeItems.push(componentRef.location.nativeElement);\r\n    componentRef.location.nativeElement.addEventListener('click', ($event: any) => {\r\n      $event.stopPropagation();\r\n      for (let activeItem of this.activeItems) {\r\n        activeItem.classList.remove('plugin-active');\r\n      }\r\n      if (this.activeItems.indexOf($event.target) < 0) {\r\n        return;\r\n      }\r\n      this.activeItem.next({boxItem, index, style, config: config.config, componentRef});\r\n      $event.target.classList.add('plugin-active');\r\n    });\r\n    activeComponentRef.instance.itemRemove.subscribe(() => {\r\n      this.activeItem.next('');\r\n      viewContainerRef.clear();\r\n      componentRef.instance.onRemove();\r\n    });\r\n    return activeComponentRef;\r\n  }\r\n}\r\n"]}
|
|
@@ -21,9 +21,14 @@ export class ItemConfigComponent {
|
|
|
21
21
|
if (pluginType === 'form') {
|
|
22
22
|
instance.fieldTree = this.fieldTree;
|
|
23
23
|
}
|
|
24
|
-
instance.configChange.subscribe(() => {
|
|
25
|
-
|
|
26
|
-
|
|
24
|
+
instance.configChange.subscribe((reload) => {
|
|
25
|
+
if (reload) {
|
|
26
|
+
const componentRef = PluginManager.createComponent(item.boxItem, item.index, item.style, item.config);
|
|
27
|
+
componentRef.location.nativeElement.click();
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
Object.assign(item.componentRef.instance, item.config.pluginConfig);
|
|
31
|
+
}
|
|
27
32
|
});
|
|
28
33
|
});
|
|
29
34
|
}
|
|
@@ -37,4 +42,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
37
42
|
type: ViewChild,
|
|
38
43
|
args: ['pageConfigContent', { static: true, read: ViewContainerRef }]
|
|
39
44
|
}] } });
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXRlbS1jb25maWcuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXJzLWFudC9zcmMvYm94LWNvbnRhaW5lci9ib3gtaXRlbS9pdGVtLWNvbmZpZy9pdGVtLWNvbmZpZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtcnMtYW50L3NyYy9ib3gtY29udGFpbmVyL2JveC1pdGVtL2l0ZW0tY29uZmlnL2l0ZW0tY29uZmlnLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQVUsU0FBUyxFQUFFLGdCQUFnQixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzdFLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUNsRCxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sdUJBQXVCLENBQUM7O0FBT3BELE1BQU0sT0FBTyxtQkFBbUI7SUFJOUIsUUFBUTtRQUNOLGFBQWEsQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFO1lBQ3hDLElBQUksQ0FBQyxJQUFJLEVBQUU7Z0JBQ1QsT0FBTzthQUNSO1lBQ0QsSUFBSSxDQUFDLGlCQUFpQixDQUFDLEtBQUssRUFBRSxDQUFDO1lBQy9CLE1BQU0sTUFBTSxHQUFHLGFBQWEsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztZQUNwRCxNQUFNLFVBQVUsR0FBRyxNQUFNLEVBQUUsSUFBSSxDQUFDO1lBQ2hDLE1BQU0sWUFBWSxHQUFHLGFBQWEsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztZQUNoRSxJQUFJLENBQUMsWUFBWSxFQUFFO2dCQUNqQixPQUFPO2FBQ1I7WUFDRCxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsaUJBQWlCLENBQUMsZUFBZSxDQUFDLFlBQVksQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUNwRixNQUFNLFFBQVEsR0FBUSxZQUFZLENBQUMsUUFBUSxDQUFDO1lBQzVDLFFBQVEsQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxZQUFZLENBQUM7WUFDM0MsSUFBSSxVQUFVLEtBQUssTUFBTSxFQUFFO2dCQUN6QixRQUFRLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7YUFDckM7WUFDRCxRQUFRLENBQUMsWUFBWSxDQUFDLFNBQVMsQ0FBQyxDQUFDLE1BQWdCLEVBQUUsRUFBRTtnQkFDbkQsSUFBSSxNQUFNLEVBQUU7b0JBQ1YsTUFBTSxZQUFZLEdBQUcsYUFBYSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7b0JBQ3RHLFlBQVksQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLEtBQUssRUFBRSxDQUFDO2lCQUM3QztxQkFBTTtvQkFDTCxNQUFNLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsWUFBWSxDQUFDLENBQUM7aUJBQ3JFO1lBQ0gsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7O2dIQS9CVSxtQkFBbUI7b0dBQW5CLG1CQUFtQix5SkFFdUIsZ0JBQWdCLDJDQ1h2RSxvREFDQTsyRkRRYSxtQkFBbUI7a0JBTC9CLFNBQVM7K0JBQ0UsZ0JBQWdCOzhCQU04QyxpQkFBaUI7c0JBQXhGLFNBQVM7dUJBQUMsbUJBQW1CLEVBQUUsRUFBQyxNQUFNLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxnQkFBZ0IsRUFBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBPbkluaXQsIFZpZXdDaGlsZCwgVmlld0NvbnRhaW5lclJlZn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1BsdWdpbk1hbmFnZXJ9IGZyb20gXCIuLi8uLi9QbHVnaW5NYW5hZ2VyXCI7XG5pbXBvcnQge1BsdWdpbkZhY3Rvcnl9IGZyb20gXCJjb2FzdC1wbHVnaW4tcmVnaXN0ZXJcIjtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncnMtaXRlbS1jb25maWcnLFxuICB0ZW1wbGF0ZVVybDogJy4vaXRlbS1jb25maWcuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9pdGVtLWNvbmZpZy5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIEl0ZW1Db25maWdDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBmaWVsZFRyZWU/OiBhbnk7XG4gIEBWaWV3Q2hpbGQoJ3BhZ2VDb25maWdDb250ZW50Jywge3N0YXRpYzogdHJ1ZSwgcmVhZDogVmlld0NvbnRhaW5lclJlZn0pIHBhZ2VDb25maWdDb250ZW50ITogVmlld0NvbnRhaW5lclJlZjtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICBQbHVnaW5NYW5hZ2VyLmFjdGl2ZUl0ZW0uc3Vic2NyaWJlKGl0ZW0gPT4ge1xuICAgICAgaWYgKCFpdGVtKSB7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cbiAgICAgIHRoaXMucGFnZUNvbmZpZ0NvbnRlbnQuY2xlYXIoKTtcbiAgICAgIGNvbnN0IHBsdWdpbiA9IFBsdWdpbkZhY3RvcnkuZ2V0KGl0ZW0uY29uZmlnPy5uYW1lKTtcbiAgICAgIGNvbnN0IHBsdWdpblR5cGUgPSBwbHVnaW4/LnR5cGU7XG4gICAgICBjb25zdCBwbHVnaW5Db25maWcgPSBQbHVnaW5GYWN0b3J5LmdldENvbmZpZyhpdGVtLmNvbmZpZz8ubmFtZSk7XG4gICAgICBpZiAoIXBsdWdpbkNvbmZpZykge1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG4gICAgICBjb25zdCBjb21wb25lbnRSZWYgPSB0aGlzLnBhZ2VDb25maWdDb250ZW50LmNyZWF0ZUNvbXBvbmVudChwbHVnaW5Db25maWcuY29tcG9uZW50KTtcbiAgICAgIGNvbnN0IGluc3RhbmNlOiBhbnkgPSBjb21wb25lbnRSZWYuaW5zdGFuY2U7XG4gICAgICBpbnN0YW5jZS5jb25maWcgPSBpdGVtLmNvbmZpZy5wbHVnaW5Db25maWc7XG4gICAgICBpZiAocGx1Z2luVHlwZSA9PT0gJ2Zvcm0nKSB7XG4gICAgICAgIGluc3RhbmNlLmZpZWxkVHJlZSA9IHRoaXMuZmllbGRUcmVlO1xuICAgICAgfVxuICAgICAgaW5zdGFuY2UuY29uZmlnQ2hhbmdlLnN1YnNjcmliZSgocmVsb2FkPzogYm9vbGVhbikgPT4ge1xuICAgICAgICBpZiAocmVsb2FkKSB7XG4gICAgICAgICAgY29uc3QgY29tcG9uZW50UmVmID0gUGx1Z2luTWFuYWdlci5jcmVhdGVDb21wb25lbnQoaXRlbS5ib3hJdGVtLCBpdGVtLmluZGV4LCBpdGVtLnN0eWxlLCBpdGVtLmNvbmZpZyk7XG4gICAgICAgICAgY29tcG9uZW50UmVmLmxvY2F0aW9uLm5hdGl2ZUVsZW1lbnQuY2xpY2soKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBPYmplY3QuYXNzaWduKGl0ZW0uY29tcG9uZW50UmVmLmluc3RhbmNlLCBpdGVtLmNvbmZpZy5wbHVnaW5Db25maWcpO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9KTtcbiAgfVxufVxuIiwiPG5nLWNvbnRhaW5lciAjcGFnZUNvbmZpZ0NvbnRlbnQ+PC9uZy1jb250YWluZXI+XG4iXX0=
|
|
@@ -1,18 +1,21 @@
|
|
|
1
|
-
import { Component, ContentChild, Input, ViewChild } from '@angular/core';
|
|
1
|
+
import { Component, ContentChild, Inject, Input, LOCALE_ID, ViewChild } from '@angular/core';
|
|
2
2
|
import CustomStore from "devextreme/data/custom_store";
|
|
3
3
|
import { lastValueFrom } from "rxjs";
|
|
4
4
|
import { DxDataGridComponent } from "devextreme-angular";
|
|
5
5
|
import { DataGridService } from "./data-grid.service";
|
|
6
6
|
import { MasterDetailTemplateDirective } from "./master-detail-template.directive";
|
|
7
|
+
import { formatDate } from "@angular/common";
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
9
|
import * as i1 from "./data-grid.service";
|
|
9
10
|
import * as i2 from "@angular/common";
|
|
10
11
|
import * as i3 from "devextreme-angular";
|
|
11
12
|
import * as i4 from "devextreme-angular/ui/nested";
|
|
12
13
|
import * as i5 from "devextreme-angular/core";
|
|
14
|
+
import * as i6 from "ng-devui/popover";
|
|
13
15
|
export class DataGridComponent {
|
|
14
|
-
constructor(service) {
|
|
16
|
+
constructor(service, locale) {
|
|
15
17
|
this.service = service;
|
|
18
|
+
this.locale = locale;
|
|
16
19
|
this.enableMasterDetail = false;
|
|
17
20
|
this.dataSource = {};
|
|
18
21
|
this.columns = [];
|
|
@@ -56,36 +59,100 @@ export class DataGridComponent {
|
|
|
56
59
|
this.dxDataGrid.instance?.state(null);
|
|
57
60
|
this.service.getMetadataByView(this.tenant, this.className, this.view || '').subscribe((response) => {
|
|
58
61
|
this.columns = [];
|
|
59
|
-
for (let
|
|
60
|
-
if (
|
|
62
|
+
for (let field of response.data.columns) {
|
|
63
|
+
if (field.type === 'FILE') {
|
|
61
64
|
this.columns.push({
|
|
62
|
-
dataField:
|
|
63
|
-
caption:
|
|
64
|
-
dataType:
|
|
65
|
+
dataField: field.name,
|
|
66
|
+
caption: field.caption,
|
|
67
|
+
dataType: 'string',
|
|
65
68
|
alignment: 'left',
|
|
66
|
-
filterOperations:
|
|
67
|
-
|
|
69
|
+
filterOperations: [],
|
|
70
|
+
visible: field.visible
|
|
68
71
|
});
|
|
69
72
|
}
|
|
70
|
-
else if (
|
|
71
|
-
|
|
72
|
-
dataField:
|
|
73
|
-
caption:
|
|
74
|
-
dataType:
|
|
73
|
+
else if (field.type === 'NORMAL') {
|
|
74
|
+
const column = {
|
|
75
|
+
dataField: field.name,
|
|
76
|
+
caption: field.caption,
|
|
77
|
+
dataType: this.typeMap[field.dataType].dataType,
|
|
75
78
|
alignment: 'left',
|
|
76
|
-
filterOperations: []
|
|
77
|
-
|
|
79
|
+
filterOperations: this.typeMap[field.dataType].filterOperations,
|
|
80
|
+
format: this.typeMap[field.dataType].format,
|
|
81
|
+
visible: field.visible
|
|
82
|
+
};
|
|
83
|
+
this.columns.push(column);
|
|
84
|
+
switch (field.dataType) {
|
|
85
|
+
case 'BOOLEAN':
|
|
86
|
+
column.alignment = 'center';
|
|
87
|
+
column.trueText = '是';
|
|
88
|
+
column.falseText = '否';
|
|
89
|
+
break;
|
|
90
|
+
case 'DATE':
|
|
91
|
+
column.calculateFilterExpression = (filterValue, selectedFilterOperation) => {
|
|
92
|
+
if (selectedFilterOperation === 'between' && Array.isArray(filterValue)) {
|
|
93
|
+
return [
|
|
94
|
+
[column.name, '>=', formatDate(filterValue[0], 'yyyy/MM/dd', this.locale, 'GMT+8')],
|
|
95
|
+
'and',
|
|
96
|
+
[column.name, '<', formatDate(filterValue[1], 'yyyy/MM/dd', this.locale, 'GMT+8')]
|
|
97
|
+
];
|
|
98
|
+
}
|
|
99
|
+
return [column.name, selectedFilterOperation, formatDate(filterValue, 'yyyy/MM/dd', this.locale, 'GMT+8')];
|
|
100
|
+
};
|
|
101
|
+
break;
|
|
102
|
+
case 'DATETIME':
|
|
103
|
+
case 'DOUBLE':
|
|
104
|
+
case 'INTEGER':
|
|
105
|
+
break;
|
|
106
|
+
case 'STRING':
|
|
107
|
+
switch (field.config.constraint.type) {
|
|
108
|
+
case 'USER':
|
|
109
|
+
column.dataField = '__' + field.name + '\u0001User_displayName';
|
|
110
|
+
column.calculateFilterExpression = (filterValue, selectedFilterOperation) => {
|
|
111
|
+
return [
|
|
112
|
+
[column.name, selectedFilterOperation, filterValue],
|
|
113
|
+
'or',
|
|
114
|
+
['__' + field.name + '\u0001User_username', selectedFilterOperation, filterValue]
|
|
115
|
+
];
|
|
116
|
+
};
|
|
117
|
+
break;
|
|
118
|
+
case 'UNIT':
|
|
119
|
+
column.dataField = '__' + field.name + '\u0001Role_displayName';
|
|
120
|
+
column.calculateFilterExpression = (filterValue, selectedFilterOperation) => {
|
|
121
|
+
return [
|
|
122
|
+
[column.name, selectedFilterOperation, filterValue],
|
|
123
|
+
'or',
|
|
124
|
+
['__' + field.name + '\u0001Role_name', selectedFilterOperation, filterValue]
|
|
125
|
+
];
|
|
126
|
+
};
|
|
127
|
+
break;
|
|
128
|
+
case 'CUSTOM':
|
|
129
|
+
column.lookup = {
|
|
130
|
+
dataSource: '',
|
|
131
|
+
valueExpr: 'store',
|
|
132
|
+
displayExpr: 'display'
|
|
133
|
+
};
|
|
134
|
+
break;
|
|
135
|
+
}
|
|
136
|
+
break;
|
|
137
|
+
case 'TEXT':
|
|
138
|
+
column.cellTemplate = 'textCellTemplate';
|
|
139
|
+
break;
|
|
140
|
+
}
|
|
78
141
|
}
|
|
79
|
-
else if (
|
|
142
|
+
else if (field.type === 'RELATION') {
|
|
80
143
|
this.columns.push({
|
|
81
|
-
dataField:
|
|
82
|
-
caption:
|
|
144
|
+
dataField: field.name,
|
|
145
|
+
caption: field.caption,
|
|
83
146
|
dataType: 'string',
|
|
84
147
|
alignment: 'left',
|
|
85
|
-
filterOperations: ['=']
|
|
148
|
+
filterOperations: ['='],
|
|
149
|
+
visible: field.visible
|
|
86
150
|
});
|
|
87
151
|
}
|
|
88
152
|
}
|
|
153
|
+
if (this.customColumnFn) {
|
|
154
|
+
this.customColumnFn(this.columns);
|
|
155
|
+
}
|
|
89
156
|
});
|
|
90
157
|
this.dataSource = new CustomStore({
|
|
91
158
|
key: 'oid',
|
|
@@ -146,12 +213,15 @@ export class DataGridComponent {
|
|
|
146
213
|
return this.dxDataGrid.instance.getSelectedRowKeys();
|
|
147
214
|
}
|
|
148
215
|
}
|
|
149
|
-
DataGridComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DataGridComponent, deps: [{ token: i1.DataGridService }], target: i0.ɵɵFactoryTarget.Component });
|
|
150
|
-
DataGridComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: DataGridComponent, selector: "rs-data-grid", inputs: { tenant: "tenant", className: "className", view: "view", filter: "filter", enableMasterDetail: "enableMasterDetail" }, providers: [DataGridService], queries: [{ propertyName: "masterDetailTemplate", first: true, predicate: MasterDetailTemplateDirective, descendants: true }], viewQueries: [{ propertyName: "dxDataGrid", first: true, predicate: DxDataGridComponent, descendants: true, static: true }], ngImport: i0, template: "<dx-data-grid [dataSource]=\"dataSource\"\n [columns]=\"columns\"\n [showBorders]=\"true\"\n [showColumnLines]=\"true\"\n [showRowLines]=\"true\"\n [hoverStateEnabled]=\"true\"\n [rowAlternationEnabled]=\"true\"\n [columnAutoWidth]=\"true\"\n [allowColumnResizing]=\"true\"\n columnResizingMode=\"widget\"\n dateSerializationFormat=\"yyyy/MM/dd HH:mm:ss\"\n (onRowExpanding)=\"$event.component.collapseAll(-1)\"\n>\n <dxo-sorting mode=\"multiple\"></dxo-sorting>\n <dxo-selection mode=\"multiple\" selectAllMode=\"page\"></dxo-selection>\n <dxo-filter-row [visible]=\"true\"></dxo-filter-row>\n <dxo-remote-operations [filtering]=\"true\"\n [sorting]=\"true\"\n [paging]=\"true\">\n </dxo-remote-operations>\n <dxo-master-detail [enabled]=\"enableMasterDetail\" template=\"masterDetailTemplate\"></dxo-master-detail>\n <dxo-paging [pageSize]=\"15\"></dxo-paging>\n <dxo-pager [visible]=\"true\"\n [showInfo]=\"true\"\n infoText=\"\u7B2C{0}\u9875\uFF0C\u5171{1}\u9875\uFF08\u5171{2}\u4E2A\u9879\u76EE\uFF09\"\n [showPageSizeSelector]=\"true\"\n [allowedPageSizes]=\"[15, 30, 50]\"\n ></dxo-pager>\n <dxo-scrolling showScrollbar=\"always\"></dxo-scrolling>\n <dxo-export [allowExportSelectedData]=\"true\"\n [fileName]=\"className\"></dxo-export>\n <div *dxTemplate=\"let rowInfo of 'masterDetailTemplate'\">\n <ng-container [ngTemplateOutlet]=\"masterDetailTemplate.templateRef\"\n [ngTemplateOutletContext]=\"{$implicit: rowInfo}\"></ng-container>\n </div>\n <div *dxTemplate=\"let cellInfo of 'rowIndexTemplate'\">\n {{cellInfo.rowIndex + 1}}\n </div>\n</dx-data-grid>\n", styles: [":host{display:flex;flex-flow:column nowrap}:host dx-data-grid{flex:auto;height:0}\n"], dependencies: [{ kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i3.DxDataGridComponent, selector: "dx-data-grid", inputs: ["accessKey", "activeStateEnabled", "allowColumnReordering", "allowColumnResizing", "autoNavigateToFocusedRow", "cacheEnabled", "cellHintEnabled", "columnAutoWidth", "columnChooser", "columnFixing", "columnHidingEnabled", "columnMinWidth", "columnResizingMode", "columns", "columnWidth", "customizeColumns", "dataRowTemplate", "dataSource", "dateSerializationFormat", "disabled", "editing", "elementAttr", "errorRowEnabled", "export", "filterBuilder", "filterBuilderPopup", "filterPanel", "filterRow", "filterSyncEnabled", "filterValue", "focusedColumnIndex", "focusedRowEnabled", "focusedRowIndex", "focusedRowKey", "grouping", "groupPanel", "headerFilter", "height", "highlightChanges", "hint", "hoverStateEnabled", "keyboardNavigation", "keyExpr", "loadPanel", "masterDetail", "noDataText", "pager", "paging", "remoteOperations", "renderAsync", "repaintChangesOnly", "rowAlternationEnabled", "rowDragging", "rowTemplate", "rtlEnabled", "scrolling", "searchPanel", "selectedRowKeys", "selection", "selectionFilter", "showBorders", "showColumnHeaders", "showColumnLines", "showRowLines", "sortByGroupSummaryInfo", "sorting", "stateStoring", "summary", "syncLookupFilterValues", "tabIndex", "toolbar", "twoWayBindingEnabled", "visible", "width", "wordWrapEnabled"], outputs: ["onAdaptiveDetailRowPreparing", "onCellClick", "onCellDblClick", "onCellHoverChanged", "onCellPrepared", "onContentReady", "onContextMenuPreparing", "onDataErrorOccurred", "onDisposing", "onEditCanceled", "onEditCanceling", "onEditingStart", "onEditorPrepared", "onEditorPreparing", "onExporting", "onFocusedCellChanged", "onFocusedCellChanging", "onFocusedRowChanged", "onFocusedRowChanging", "onInitialized", "onInitNewRow", "onKeyDown", "onOptionChanged", "onRowClick", "onRowCollapsed", "onRowCollapsing", "onRowDblClick", "onRowExpanded", "onRowExpanding", "onRowInserted", "onRowInserting", "onRowPrepared", "onRowRemoved", "onRowRemoving", "onRowUpdated", "onRowUpdating", "onRowValidating", "onSaved", "onSaving", "onSelectionChanged", "onToolbarPreparing", "accessKeyChange", "activeStateEnabledChange", "allowColumnReorderingChange", "allowColumnResizingChange", "autoNavigateToFocusedRowChange", "cacheEnabledChange", "cellHintEnabledChange", "columnAutoWidthChange", "columnChooserChange", "columnFixingChange", "columnHidingEnabledChange", "columnMinWidthChange", "columnResizingModeChange", "columnsChange", "columnWidthChange", "customizeColumnsChange", "dataRowTemplateChange", "dataSourceChange", "dateSerializationFormatChange", "disabledChange", "editingChange", "elementAttrChange", "errorRowEnabledChange", "exportChange", "filterBuilderChange", "filterBuilderPopupChange", "filterPanelChange", "filterRowChange", "filterSyncEnabledChange", "filterValueChange", "focusedColumnIndexChange", "focusedRowEnabledChange", "focusedRowIndexChange", "focusedRowKeyChange", "groupingChange", "groupPanelChange", "headerFilterChange", "heightChange", "highlightChangesChange", "hintChange", "hoverStateEnabledChange", "keyboardNavigationChange", "keyExprChange", "loadPanelChange", "masterDetailChange", "noDataTextChange", "pagerChange", "pagingChange", "remoteOperationsChange", "renderAsyncChange", "repaintChangesOnlyChange", "rowAlternationEnabledChange", "rowDraggingChange", "rowTemplateChange", "rtlEnabledChange", "scrollingChange", "searchPanelChange", "selectedRowKeysChange", "selectionChange", "selectionFilterChange", "showBordersChange", "showColumnHeadersChange", "showColumnLinesChange", "showRowLinesChange", "sortByGroupSummaryInfoChange", "sortingChange", "stateStoringChange", "summaryChange", "syncLookupFilterValuesChange", "tabIndexChange", "toolbarChange", "twoWayBindingEnabledChange", "visibleChange", "widthChange", "wordWrapEnabledChange"] }, { kind: "component", type: i4.DxoExportComponent, selector: "dxo-export", inputs: ["backgroundColor", "enabled", "fileName", "formats", "margin", "printingEnabled", "svgToCanvas", "allowExportSelectedData", "texts"] }, { kind: "component", type: i4.DxoFilterRowComponent, selector: "dxo-filter-row", inputs: ["applyFilter", "applyFilterText", "betweenEndText", "betweenStartText", "operationDescriptions", "resetOperationText", "showAllText", "showOperationChooser", "visible"] }, { kind: "component", type: i4.DxoMasterDetailComponent, selector: "dxo-master-detail", inputs: ["autoExpandAll", "enabled", "template"] }, { kind: "component", type: i4.DxoPagerComponent, selector: "dxo-pager", inputs: ["allowedPageSizes", "displayMode", "infoText", "label", "showInfo", "showNavigationButtons", "showPageSizeSelector", "visible"] }, { kind: "component", type: i4.DxoPagingComponent, selector: "dxo-paging", inputs: ["enabled", "pageIndex", "pageSize"], outputs: ["pageIndexChange", "pageSizeChange"] }, { kind: "component", type: i4.DxoRemoteOperationsComponent, selector: "dxo-remote-operations", inputs: ["filtering", "grouping", "groupPaging", "paging", "sorting", "summary"] }, { kind: "component", type: i4.DxoScrollingComponent, selector: "dxo-scrolling", inputs: ["columnRenderingMode", "mode", "preloadEnabled", "renderAsync", "rowRenderingMode", "scrollByContent", "scrollByThumb", "showScrollbar", "useNative"] }, { kind: "component", type: i4.DxoSelectionComponent, selector: "dxo-selection", inputs: ["allowSelectAll", "deferred", "mode", "selectAllMode", "showCheckBoxesMode", "recursive"] }, { kind: "component", type: i4.DxoSortingComponent, selector: "dxo-sorting", inputs: ["ascendingText", "clearText", "descendingText", "mode", "showSortIndexes"] }, { kind: "directive", type: i5.DxTemplateDirective, selector: "[dxTemplate]", inputs: ["dxTemplateOf"] }] });
|
|
216
|
+
DataGridComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DataGridComponent, deps: [{ token: i1.DataGridService }, { token: LOCALE_ID }], target: i0.ɵɵFactoryTarget.Component });
|
|
217
|
+
DataGridComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.7", type: DataGridComponent, selector: "rs-data-grid", inputs: { tenant: "tenant", className: "className", view: "view", filter: "filter", enableMasterDetail: "enableMasterDetail", customColumnFn: "customColumnFn" }, providers: [DataGridService], queries: [{ propertyName: "masterDetailTemplate", first: true, predicate: MasterDetailTemplateDirective, descendants: true }], viewQueries: [{ propertyName: "dxDataGrid", first: true, predicate: DxDataGridComponent, descendants: true, static: true }], ngImport: i0, template: "<dx-data-grid [dataSource]=\"dataSource\"\n [columns]=\"columns\"\n [showBorders]=\"true\"\n [showColumnLines]=\"true\"\n [showRowLines]=\"true\"\n [hoverStateEnabled]=\"true\"\n [rowAlternationEnabled]=\"true\"\n [columnAutoWidth]=\"true\"\n [allowColumnResizing]=\"true\"\n columnResizingMode=\"widget\"\n dateSerializationFormat=\"yyyy/MM/dd HH:mm:ss\"\n (onRowExpanding)=\"$event.component.collapseAll(-1)\"\n>\n <dxo-sorting mode=\"multiple\"></dxo-sorting>\n <dxo-selection mode=\"multiple\" selectAllMode=\"page\"></dxo-selection>\n <dxo-filter-row [visible]=\"true\"></dxo-filter-row>\n <dxo-remote-operations [filtering]=\"true\"\n [sorting]=\"true\"\n [paging]=\"true\">\n </dxo-remote-operations>\n <dxo-master-detail [enabled]=\"enableMasterDetail\" template=\"masterDetailTemplate\"></dxo-master-detail>\n <dxo-paging [pageSize]=\"15\"></dxo-paging>\n <dxo-pager [visible]=\"true\"\n [showInfo]=\"true\"\n infoText=\"\u7B2C{0}\u9875\uFF0C\u5171{1}\u9875\uFF08\u5171{2}\u4E2A\u9879\u76EE\uFF09\"\n [showPageSizeSelector]=\"true\"\n [allowedPageSizes]=\"[15, 30, 50]\"\n ></dxo-pager>\n <dxo-scrolling showScrollbar=\"always\"></dxo-scrolling>\n <dxo-export [allowExportSelectedData]=\"true\"\n [fileName]=\"className\"></dxo-export>\n <div *dxTemplate=\"let rowInfo of 'masterDetailTemplate'\">\n <ng-container [ngTemplateOutlet]=\"masterDetailTemplate.templateRef\"\n [ngTemplateOutletContext]=\"{$implicit: rowInfo}\"></ng-container>\n </div>\n <div *dxTemplate=\"let cellInfo of 'rowIndexTemplate'\">\n {{cellInfo.rowIndex + 1}}\n </div>\n <div *dxTemplate=\"let cellInfo of 'textCellTemplate'\">\n <div dPopover #textDiv\n [content]=\"cellInfo.value\"\n [controlled]=\"textDiv.clientWidth < textDiv.scrollWidth\"\n [popMaxWidth]=\"240\"\n [popoverStyle]=\"{ backgroundColor: '#fff', color: 'rgb(51, 51, 51)' }\"\n style=\"max-width: 240px; text-overflow: ellipsis; overflow: hidden;\"\n [ngStyle]=\"{ cursor: textDiv.clientWidth < textDiv.scrollWidth ? 'pointer': 'default'}\">{{cellInfo.value}}</div>\n </div>\n</dx-data-grid>\n", styles: [":host{display:flex;flex-flow:column nowrap}:host dx-data-grid{flex:auto;height:0}\n"], dependencies: [{ kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.DxDataGridComponent, selector: "dx-data-grid", inputs: ["accessKey", "activeStateEnabled", "allowColumnReordering", "allowColumnResizing", "autoNavigateToFocusedRow", "cacheEnabled", "cellHintEnabled", "columnAutoWidth", "columnChooser", "columnFixing", "columnHidingEnabled", "columnMinWidth", "columnResizingMode", "columns", "columnWidth", "customizeColumns", "dataRowTemplate", "dataSource", "dateSerializationFormat", "disabled", "editing", "elementAttr", "errorRowEnabled", "export", "filterBuilder", "filterBuilderPopup", "filterPanel", "filterRow", "filterSyncEnabled", "filterValue", "focusedColumnIndex", "focusedRowEnabled", "focusedRowIndex", "focusedRowKey", "grouping", "groupPanel", "headerFilter", "height", "highlightChanges", "hint", "hoverStateEnabled", "keyboardNavigation", "keyExpr", "loadPanel", "masterDetail", "noDataText", "pager", "paging", "remoteOperations", "renderAsync", "repaintChangesOnly", "rowAlternationEnabled", "rowDragging", "rowTemplate", "rtlEnabled", "scrolling", "searchPanel", "selectedRowKeys", "selection", "selectionFilter", "showBorders", "showColumnHeaders", "showColumnLines", "showRowLines", "sortByGroupSummaryInfo", "sorting", "stateStoring", "summary", "syncLookupFilterValues", "tabIndex", "toolbar", "twoWayBindingEnabled", "visible", "width", "wordWrapEnabled"], outputs: ["onAdaptiveDetailRowPreparing", "onCellClick", "onCellDblClick", "onCellHoverChanged", "onCellPrepared", "onContentReady", "onContextMenuPreparing", "onDataErrorOccurred", "onDisposing", "onEditCanceled", "onEditCanceling", "onEditingStart", "onEditorPrepared", "onEditorPreparing", "onExporting", "onFocusedCellChanged", "onFocusedCellChanging", "onFocusedRowChanged", "onFocusedRowChanging", "onInitialized", "onInitNewRow", "onKeyDown", "onOptionChanged", "onRowClick", "onRowCollapsed", "onRowCollapsing", "onRowDblClick", "onRowExpanded", "onRowExpanding", "onRowInserted", "onRowInserting", "onRowPrepared", "onRowRemoved", "onRowRemoving", "onRowUpdated", "onRowUpdating", "onRowValidating", "onSaved", "onSaving", "onSelectionChanged", "onToolbarPreparing", "accessKeyChange", "activeStateEnabledChange", "allowColumnReorderingChange", "allowColumnResizingChange", "autoNavigateToFocusedRowChange", "cacheEnabledChange", "cellHintEnabledChange", "columnAutoWidthChange", "columnChooserChange", "columnFixingChange", "columnHidingEnabledChange", "columnMinWidthChange", "columnResizingModeChange", "columnsChange", "columnWidthChange", "customizeColumnsChange", "dataRowTemplateChange", "dataSourceChange", "dateSerializationFormatChange", "disabledChange", "editingChange", "elementAttrChange", "errorRowEnabledChange", "exportChange", "filterBuilderChange", "filterBuilderPopupChange", "filterPanelChange", "filterRowChange", "filterSyncEnabledChange", "filterValueChange", "focusedColumnIndexChange", "focusedRowEnabledChange", "focusedRowIndexChange", "focusedRowKeyChange", "groupingChange", "groupPanelChange", "headerFilterChange", "heightChange", "highlightChangesChange", "hintChange", "hoverStateEnabledChange", "keyboardNavigationChange", "keyExprChange", "loadPanelChange", "masterDetailChange", "noDataTextChange", "pagerChange", "pagingChange", "remoteOperationsChange", "renderAsyncChange", "repaintChangesOnlyChange", "rowAlternationEnabledChange", "rowDraggingChange", "rowTemplateChange", "rtlEnabledChange", "scrollingChange", "searchPanelChange", "selectedRowKeysChange", "selectionChange", "selectionFilterChange", "showBordersChange", "showColumnHeadersChange", "showColumnLinesChange", "showRowLinesChange", "sortByGroupSummaryInfoChange", "sortingChange", "stateStoringChange", "summaryChange", "syncLookupFilterValuesChange", "tabIndexChange", "toolbarChange", "twoWayBindingEnabledChange", "visibleChange", "widthChange", "wordWrapEnabledChange"] }, { kind: "component", type: i4.DxoExportComponent, selector: "dxo-export", inputs: ["backgroundColor", "enabled", "fileName", "formats", "margin", "printingEnabled", "svgToCanvas", "allowExportSelectedData", "texts"] }, { kind: "component", type: i4.DxoFilterRowComponent, selector: "dxo-filter-row", inputs: ["applyFilter", "applyFilterText", "betweenEndText", "betweenStartText", "operationDescriptions", "resetOperationText", "showAllText", "showOperationChooser", "visible"] }, { kind: "component", type: i4.DxoMasterDetailComponent, selector: "dxo-master-detail", inputs: ["autoExpandAll", "enabled", "template"] }, { kind: "component", type: i4.DxoPagerComponent, selector: "dxo-pager", inputs: ["allowedPageSizes", "displayMode", "infoText", "label", "showInfo", "showNavigationButtons", "showPageSizeSelector", "visible"] }, { kind: "component", type: i4.DxoPagingComponent, selector: "dxo-paging", inputs: ["enabled", "pageIndex", "pageSize"], outputs: ["pageIndexChange", "pageSizeChange"] }, { kind: "component", type: i4.DxoRemoteOperationsComponent, selector: "dxo-remote-operations", inputs: ["filtering", "grouping", "groupPaging", "paging", "sorting", "summary"] }, { kind: "component", type: i4.DxoScrollingComponent, selector: "dxo-scrolling", inputs: ["columnRenderingMode", "mode", "preloadEnabled", "renderAsync", "rowRenderingMode", "scrollByContent", "scrollByThumb", "showScrollbar", "useNative"] }, { kind: "component", type: i4.DxoSelectionComponent, selector: "dxo-selection", inputs: ["allowSelectAll", "deferred", "mode", "selectAllMode", "showCheckBoxesMode", "recursive"] }, { kind: "component", type: i4.DxoSortingComponent, selector: "dxo-sorting", inputs: ["ascendingText", "clearText", "descendingText", "mode", "showSortIndexes"] }, { kind: "directive", type: i5.DxTemplateDirective, selector: "[dxTemplate]", inputs: ["dxTemplateOf"] }, { kind: "directive", type: i6.PopoverDirective, selector: "[dPopover]", inputs: ["content", "controlled", "position", "showAnimation", "showAnimate", "scrollElement", "appendToBody", "zIndex", "popType", "popMaxWidth", "trigger", "hoverToContent", "hoverDelayTime", "popoverStyle", "mouseEnterDelay", "mouseLeaveDelay", "visible"], exportAs: ["dPopover"] }] });
|
|
151
218
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DataGridComponent, decorators: [{
|
|
152
219
|
type: Component,
|
|
153
|
-
args: [{ selector: 'rs-data-grid', providers: [DataGridService], template: "<dx-data-grid [dataSource]=\"dataSource\"\n [columns]=\"columns\"\n [showBorders]=\"true\"\n [showColumnLines]=\"true\"\n [showRowLines]=\"true\"\n [hoverStateEnabled]=\"true\"\n [rowAlternationEnabled]=\"true\"\n [columnAutoWidth]=\"true\"\n [allowColumnResizing]=\"true\"\n columnResizingMode=\"widget\"\n dateSerializationFormat=\"yyyy/MM/dd HH:mm:ss\"\n (onRowExpanding)=\"$event.component.collapseAll(-1)\"\n>\n <dxo-sorting mode=\"multiple\"></dxo-sorting>\n <dxo-selection mode=\"multiple\" selectAllMode=\"page\"></dxo-selection>\n <dxo-filter-row [visible]=\"true\"></dxo-filter-row>\n <dxo-remote-operations [filtering]=\"true\"\n [sorting]=\"true\"\n [paging]=\"true\">\n </dxo-remote-operations>\n <dxo-master-detail [enabled]=\"enableMasterDetail\" template=\"masterDetailTemplate\"></dxo-master-detail>\n <dxo-paging [pageSize]=\"15\"></dxo-paging>\n <dxo-pager [visible]=\"true\"\n [showInfo]=\"true\"\n infoText=\"\u7B2C{0}\u9875\uFF0C\u5171{1}\u9875\uFF08\u5171{2}\u4E2A\u9879\u76EE\uFF09\"\n [showPageSizeSelector]=\"true\"\n [allowedPageSizes]=\"[15, 30, 50]\"\n ></dxo-pager>\n <dxo-scrolling showScrollbar=\"always\"></dxo-scrolling>\n <dxo-export [allowExportSelectedData]=\"true\"\n [fileName]=\"className\"></dxo-export>\n <div *dxTemplate=\"let rowInfo of 'masterDetailTemplate'\">\n <ng-container [ngTemplateOutlet]=\"masterDetailTemplate.templateRef\"\n [ngTemplateOutletContext]=\"{$implicit: rowInfo}\"></ng-container>\n </div>\n <div *dxTemplate=\"let cellInfo of 'rowIndexTemplate'\">\n {{cellInfo.rowIndex + 1}}\n </div>\n</dx-data-grid>\n", styles: [":host{display:flex;flex-flow:column nowrap}:host dx-data-grid{flex:auto;height:0}\n"] }]
|
|
154
|
-
}], ctorParameters: function () { return [{ type: i1.DataGridService }
|
|
220
|
+
args: [{ selector: 'rs-data-grid', providers: [DataGridService], template: "<dx-data-grid [dataSource]=\"dataSource\"\n [columns]=\"columns\"\n [showBorders]=\"true\"\n [showColumnLines]=\"true\"\n [showRowLines]=\"true\"\n [hoverStateEnabled]=\"true\"\n [rowAlternationEnabled]=\"true\"\n [columnAutoWidth]=\"true\"\n [allowColumnResizing]=\"true\"\n columnResizingMode=\"widget\"\n dateSerializationFormat=\"yyyy/MM/dd HH:mm:ss\"\n (onRowExpanding)=\"$event.component.collapseAll(-1)\"\n>\n <dxo-sorting mode=\"multiple\"></dxo-sorting>\n <dxo-selection mode=\"multiple\" selectAllMode=\"page\"></dxo-selection>\n <dxo-filter-row [visible]=\"true\"></dxo-filter-row>\n <dxo-remote-operations [filtering]=\"true\"\n [sorting]=\"true\"\n [paging]=\"true\">\n </dxo-remote-operations>\n <dxo-master-detail [enabled]=\"enableMasterDetail\" template=\"masterDetailTemplate\"></dxo-master-detail>\n <dxo-paging [pageSize]=\"15\"></dxo-paging>\n <dxo-pager [visible]=\"true\"\n [showInfo]=\"true\"\n infoText=\"\u7B2C{0}\u9875\uFF0C\u5171{1}\u9875\uFF08\u5171{2}\u4E2A\u9879\u76EE\uFF09\"\n [showPageSizeSelector]=\"true\"\n [allowedPageSizes]=\"[15, 30, 50]\"\n ></dxo-pager>\n <dxo-scrolling showScrollbar=\"always\"></dxo-scrolling>\n <dxo-export [allowExportSelectedData]=\"true\"\n [fileName]=\"className\"></dxo-export>\n <div *dxTemplate=\"let rowInfo of 'masterDetailTemplate'\">\n <ng-container [ngTemplateOutlet]=\"masterDetailTemplate.templateRef\"\n [ngTemplateOutletContext]=\"{$implicit: rowInfo}\"></ng-container>\n </div>\n <div *dxTemplate=\"let cellInfo of 'rowIndexTemplate'\">\n {{cellInfo.rowIndex + 1}}\n </div>\n <div *dxTemplate=\"let cellInfo of 'textCellTemplate'\">\n <div dPopover #textDiv\n [content]=\"cellInfo.value\"\n [controlled]=\"textDiv.clientWidth < textDiv.scrollWidth\"\n [popMaxWidth]=\"240\"\n [popoverStyle]=\"{ backgroundColor: '#fff', color: 'rgb(51, 51, 51)' }\"\n style=\"max-width: 240px; text-overflow: ellipsis; overflow: hidden;\"\n [ngStyle]=\"{ cursor: textDiv.clientWidth < textDiv.scrollWidth ? 'pointer': 'default'}\">{{cellInfo.value}}</div>\n </div>\n</dx-data-grid>\n", styles: [":host{display:flex;flex-flow:column nowrap}:host dx-data-grid{flex:auto;height:0}\n"] }]
|
|
221
|
+
}], ctorParameters: function () { return [{ type: i1.DataGridService }, { type: undefined, decorators: [{
|
|
222
|
+
type: Inject,
|
|
223
|
+
args: [LOCALE_ID]
|
|
224
|
+
}] }]; }, propDecorators: { tenant: [{
|
|
155
225
|
type: Input
|
|
156
226
|
}], className: [{
|
|
157
227
|
type: Input
|
|
@@ -161,6 +231,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
161
231
|
type: Input
|
|
162
232
|
}], enableMasterDetail: [{
|
|
163
233
|
type: Input
|
|
234
|
+
}], customColumnFn: [{
|
|
235
|
+
type: Input
|
|
164
236
|
}], dxDataGrid: [{
|
|
165
237
|
type: ViewChild,
|
|
166
238
|
args: [DxDataGridComponent, { static: true }]
|
|
@@ -168,4 +240,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
168
240
|
type: ContentChild,
|
|
169
241
|
args: [MasterDetailTemplateDirective]
|
|
170
242
|
}] } });
|
|
171
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-grid.component.js","sourceRoot":"","sources":["../../../../projects/ngx-rs-ant/src/data-grid/data-grid.component.ts","../../../../projects/ngx-rs-ant/src/data-grid/data-grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, ContentChild, Input, OnInit, ViewChild} from '@angular/core';\nimport CustomStore from \"devextreme/data/custom_store\";\nimport {lastValueFrom} from \"rxjs\";\nimport {DxDataGridComponent} from \"devextreme-angular\";\nimport {DataGridService} from \"./data-grid.service\";\nimport {MasterDetailTemplateDirective} from \"./master-detail-template.directive\";\n\n@Component({\n  selector: 'rs-data-grid',\n  templateUrl: './data-grid.component.html',\n  styleUrls: ['./data-grid.component.scss'],\n  providers: [DataGridService]\n})\nexport class DataGridComponent implements OnInit {\n  @Input()\n  tenant!: any;\n  @Input()\n  className!: any;\n  @Input()\n  view?: any;\n  @Input()\n  filter?: any;\n  @Input()\n  enableMasterDetail = false;\n  dataSource: any = {};\n  columns: any[] = [];\n  typeMap: any = {\n    STRING: {\n      dataType: 'string',\n      filterOperations: ['contains', 'startswith', 'endswith', '=', '<>']\n    },\n    TEXT: {\n      dataType: 'string',\n      filterOperations: ['contains', 'startswith', 'endswith', '=', '<>']\n    },\n    BOOLEAN: {\n      dataType: 'boolean',\n      filterOperations: []\n    },\n    INTEGER: {\n      dataType: 'number',\n      filterOperations: ['=', '<>', '>', '>=', '<', '<=', 'between']\n    },\n    DOUBLE: {\n      dataType: 'number',\n      filterOperations: ['=', '<>', '>', '>=', '<', '<=', 'between']\n    },\n    DATE: {\n      dataType: 'date',\n      filterOperations: ['=', '<>', '>', '>=', '<', '<=', 'between'],\n      format: 'yyyy/MM/dd'\n    },\n    DATETIME: {\n      dataType: 'datetime',\n      filterOperations: ['>', '<', 'between'],\n      format: 'yyyy/MM/dd HH:mm:ss'\n    }\n  };\n  @ViewChild(DxDataGridComponent, {static: true}) dxDataGrid!: DxDataGridComponent;\n  @ContentChild(MasterDetailTemplateDirective) masterDetailTemplate!: MasterDetailTemplateDirective;\n\n  constructor(private service: DataGridService) {\n  }\n\n  ngOnInit() {\n    this.reload();\n  }\n\n  reload() {\n    this.dxDataGrid.instance?.state(null);\n    this.service.getMetadataByView(this.tenant, this.className, this.view || '').subscribe((response: any) => {\n      this.columns = [];\n      for (let column of response.data.columns) {\n        if (column.type === 'NORMAL') {\n          this.columns.push({\n            dataField: column.name,\n            caption: column.caption,\n            dataType: this.typeMap[column.dataType].dataType,\n            alignment: 'left',\n            filterOperations: this.typeMap[column.dataType].filterOperations,\n            format: this.typeMap[column.dataType].format\n          });\n        } else if (column.type === 'FILE') {\n          this.columns.push({\n            dataField: column.name,\n            caption: column.caption,\n            dataType: 'string',\n            alignment: 'left',\n            filterOperations: []\n          });\n        } else if (column.type === 'RELATION') {\n          this.columns.push({\n            dataField: column.name,\n            caption: column.caption,\n            dataType: 'string',\n            alignment: 'left',\n            filterOperations: ['=']\n          });\n        }\n      }\n    });\n    this.dataSource = new CustomStore({\n      key: 'oid',\n      byKey: (key) => {\n        return lastValueFrom(this.service.getOne(this.tenant, this.className, key));\n      },\n      load: (loadOptions: any) => {\n        let params = '?';\n        if (loadOptions.skip || loadOptions.take) {\n          params += 'offset=' + loadOptions.skip;\n          params += '&limit=' + loadOptions.take;\n        } else {\n          params += 'limit=0';\n        }\n        if (loadOptions.sort) {\n          let first = true;\n          for (const thisSort of loadOptions.sort) {\n            if (first) {\n              params += '&orderBy=' + thisSort.selector;\n            } else {\n              params += ',' + thisSort.selector;\n            }\n            if (thisSort.desc) {\n              params += ' desc';\n            }\n            first = false;\n          }\n        }\n        let filter;\n        if (loadOptions.filter) {\n          filter = loadOptions.filter;\n        }\n        if (this.filter) {\n          if (filter) {\n            filter = [filter, 'and', this.filter];\n          } else {\n            filter = this.filter;\n          }\n        }\n        if (filter) {\n          params += '&filter=' + encodeURIComponent(JSON.stringify(filter));\n        }\n        return lastValueFrom(this.service.getMany(this.tenant, this.className, params + '&view=' + (this.view || '')));\n      }\n    });\n  }\n\n  refresh(callback?: any) {\n    this.dxDataGrid.instance.refresh().then(() => {\n      if (callback) {\n        callback();\n      }\n    });\n  }\n\n  getSelectedRowKeys() {\n    return this.dxDataGrid.instance.getSelectedRowKeys();\n  }\n}\n","<dx-data-grid [dataSource]=\"dataSource\"\n              [columns]=\"columns\"\n              [showBorders]=\"true\"\n              [showColumnLines]=\"true\"\n              [showRowLines]=\"true\"\n              [hoverStateEnabled]=\"true\"\n              [rowAlternationEnabled]=\"true\"\n              [columnAutoWidth]=\"true\"\n              [allowColumnResizing]=\"true\"\n              columnResizingMode=\"widget\"\n              dateSerializationFormat=\"yyyy/MM/dd HH:mm:ss\"\n              (onRowExpanding)=\"$event.component.collapseAll(-1)\"\n>\n  <dxo-sorting mode=\"multiple\"></dxo-sorting>\n  <dxo-selection mode=\"multiple\" selectAllMode=\"page\"></dxo-selection>\n  <dxo-filter-row [visible]=\"true\"></dxo-filter-row>\n  <dxo-remote-operations [filtering]=\"true\"\n                         [sorting]=\"true\"\n                         [paging]=\"true\">\n  </dxo-remote-operations>\n  <dxo-master-detail [enabled]=\"enableMasterDetail\" template=\"masterDetailTemplate\"></dxo-master-detail>\n  <dxo-paging [pageSize]=\"15\"></dxo-paging>\n  <dxo-pager [visible]=\"true\"\n             [showInfo]=\"true\"\n             infoText=\"第{0}页，共{1}页（共{2}个项目）\"\n             [showPageSizeSelector]=\"true\"\n             [allowedPageSizes]=\"[15, 30, 50]\"\n  ></dxo-pager>\n  <dxo-scrolling showScrollbar=\"always\"></dxo-scrolling>\n  <dxo-export [allowExportSelectedData]=\"true\"\n              [fileName]=\"className\"></dxo-export>\n  <div *dxTemplate=\"let rowInfo of 'masterDetailTemplate'\">\n    <ng-container [ngTemplateOutlet]=\"masterDetailTemplate.templateRef\"\n                  [ngTemplateOutletContext]=\"{$implicit: rowInfo}\"></ng-container>\n  </div>\n  <div *dxTemplate=\"let cellInfo of 'rowIndexTemplate'\">\n    {{cellInfo.rowIndex + 1}}\n  </div>\n</dx-data-grid>\n"]}
|
|
243
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-grid.component.js","sourceRoot":"","sources":["../../../../projects/ngx-rs-ant/src/data-grid/data-grid.component.ts","../../../../projects/ngx-rs-ant/src/data-grid/data-grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, ContentChild, Inject, Input, LOCALE_ID, OnInit, ViewChild} from '@angular/core';\nimport CustomStore from \"devextreme/data/custom_store\";\nimport {lastValueFrom} from \"rxjs\";\nimport {DxDataGridComponent} from \"devextreme-angular\";\nimport {DataGridService} from \"./data-grid.service\";\nimport {MasterDetailTemplateDirective} from \"./master-detail-template.directive\";\nimport {formatDate} from \"@angular/common\";\n\n@Component({\n  selector: 'rs-data-grid',\n  templateUrl: './data-grid.component.html',\n  styleUrls: ['./data-grid.component.scss'],\n  providers: [DataGridService]\n})\nexport class DataGridComponent implements OnInit {\n  @Input()\n  tenant!: any;\n  @Input()\n  className!: any;\n  @Input()\n  view?: any;\n  @Input()\n  filter?: any;\n  @Input()\n  enableMasterDetail = false;\n  @Input()\n  customColumnFn?: (columns: any[]) => void;\n  dataSource: any = {};\n  columns: any[] = [];\n  typeMap: any = {\n    STRING: {\n      dataType: 'string',\n      filterOperations: ['contains', 'startswith', 'endswith', '=', '<>']\n    },\n    TEXT: {\n      dataType: 'string',\n      filterOperations: ['contains', 'startswith', 'endswith', '=', '<>']\n    },\n    BOOLEAN: {\n      dataType: 'boolean',\n      filterOperations: []\n    },\n    INTEGER: {\n      dataType: 'number',\n      filterOperations: ['=', '<>', '>', '>=', '<', '<=', 'between']\n    },\n    DOUBLE: {\n      dataType: 'number',\n      filterOperations: ['=', '<>', '>', '>=', '<', '<=', 'between']\n    },\n    DATE: {\n      dataType: 'date',\n      filterOperations: ['=', '<>', '>', '>=', '<', '<=', 'between'],\n      format: 'yyyy/MM/dd'\n    },\n    DATETIME: {\n      dataType: 'datetime',\n      filterOperations: ['>', '<', 'between'],\n      format: 'yyyy/MM/dd HH:mm:ss'\n    }\n  };\n  @ViewChild(DxDataGridComponent, {static: true}) dxDataGrid!: DxDataGridComponent;\n  @ContentChild(MasterDetailTemplateDirective) masterDetailTemplate!: MasterDetailTemplateDirective;\n\n  constructor(private service: DataGridService, @Inject(LOCALE_ID) private locale: string) {\n  }\n\n  ngOnInit() {\n    this.reload();\n  }\n\n  reload() {\n    this.dxDataGrid.instance?.state(null);\n    this.service.getMetadataByView(this.tenant, this.className, this.view || '').subscribe((response: any) => {\n      this.columns = [];\n      for (let field of response.data.columns) {\n        if (field.type === 'FILE') {\n          this.columns.push({\n            dataField: field.name,\n            caption: field.caption,\n            dataType: 'string',\n            alignment: 'left',\n            filterOperations: [],\n            visible: field.visible\n          });\n        } else if (field.type === 'NORMAL') {\n          const column: any = {\n            dataField: field.name,\n            caption: field.caption,\n            dataType: this.typeMap[field.dataType].dataType,\n            alignment: 'left',\n            filterOperations: this.typeMap[field.dataType].filterOperations,\n            format: this.typeMap[field.dataType].format,\n            visible: field.visible\n          };\n          this.columns.push(column);\n          switch (field.dataType) {\n            case 'BOOLEAN':\n              column.alignment = 'center';\n              column.trueText = '是';\n              column.falseText = '否';\n              break;\n            case 'DATE':\n              column.calculateFilterExpression = (filterValue: any, selectedFilterOperation: any) => {\n                if (selectedFilterOperation === 'between' && Array.isArray(filterValue)) {\n                  return [\n                    [column.name, '>=', formatDate(filterValue[0], 'yyyy/MM/dd', this.locale, 'GMT+8')],\n                    'and',\n                    [column.name, '<', formatDate(filterValue[1], 'yyyy/MM/dd', this.locale, 'GMT+8')]];\n                }\n                return [column.name, selectedFilterOperation, formatDate(filterValue, 'yyyy/MM/dd', this.locale, 'GMT+8')];\n              };\n              break;\n            case 'DATETIME':\n            case 'DOUBLE':\n            case 'INTEGER':\n              break;\n            case 'STRING':\n              switch (field.config.constraint.type) {\n                case 'USER':\n                  column.dataField = '__' + field.name + '\\u0001User_displayName';\n                  column.calculateFilterExpression = (filterValue: any, selectedFilterOperation: any) => {\n                    return [\n                      [column.name, selectedFilterOperation, filterValue],\n                      'or',\n                      ['__' + field.name + '\\u0001User_username', selectedFilterOperation, filterValue]\n                    ];\n                  };\n                  break;\n                case 'UNIT':\n                  column.dataField = '__' + field.name + '\\u0001Role_displayName';\n                  column.calculateFilterExpression = (filterValue: any, selectedFilterOperation: any) => {\n                    return [\n                      [column.name, selectedFilterOperation, filterValue],\n                      'or',\n                      ['__' + field.name + '\\u0001Role_name', selectedFilterOperation, filterValue]\n                    ];\n                  };\n                  break;\n                case 'CUSTOM':\n                  column.lookup = {\n                    dataSource: '',\n                    valueExpr: 'store',\n                    displayExpr: 'display'\n                  };\n                  break;\n              }\n              break;\n            case 'TEXT':\n              column.cellTemplate = 'textCellTemplate';\n              break;\n          }\n        } else if (field.type === 'RELATION') {\n          this.columns.push({\n            dataField: field.name,\n            caption: field.caption,\n            dataType: 'string',\n            alignment: 'left',\n            filterOperations: ['='],\n            visible: field.visible\n          });\n        }\n      }\n      if (this.customColumnFn) {\n        this.customColumnFn(this.columns);\n      }\n    });\n    this.dataSource = new CustomStore({\n      key: 'oid',\n      byKey: (key) => {\n        return lastValueFrom(this.service.getOne(this.tenant, this.className, key));\n      },\n      load: (loadOptions: any) => {\n        let params = '?';\n        if (loadOptions.skip || loadOptions.take) {\n          params += 'offset=' + loadOptions.skip;\n          params += '&limit=' + loadOptions.take;\n        } else {\n          params += 'limit=0';\n        }\n        if (loadOptions.sort) {\n          let first = true;\n          for (const thisSort of loadOptions.sort) {\n            if (first) {\n              params += '&orderBy=' + thisSort.selector;\n            } else {\n              params += ',' + thisSort.selector;\n            }\n            if (thisSort.desc) {\n              params += ' desc';\n            }\n            first = false;\n          }\n        }\n        let filter;\n        if (loadOptions.filter) {\n          filter = loadOptions.filter;\n        }\n        if (this.filter) {\n          if (filter) {\n            filter = [filter, 'and', this.filter];\n          } else {\n            filter = this.filter;\n          }\n        }\n        if (filter) {\n          params += '&filter=' + encodeURIComponent(JSON.stringify(filter));\n        }\n        return lastValueFrom(this.service.getMany(this.tenant, this.className, params + '&view=' + (this.view || '')));\n      }\n    });\n  }\n\n  refresh(callback?: any) {\n    this.dxDataGrid.instance.refresh().then(() => {\n      if (callback) {\n        callback();\n      }\n    });\n  }\n\n  getSelectedRowKeys() {\n    return this.dxDataGrid.instance.getSelectedRowKeys();\n  }\n}\n","<dx-data-grid [dataSource]=\"dataSource\"\n              [columns]=\"columns\"\n              [showBorders]=\"true\"\n              [showColumnLines]=\"true\"\n              [showRowLines]=\"true\"\n              [hoverStateEnabled]=\"true\"\n              [rowAlternationEnabled]=\"true\"\n              [columnAutoWidth]=\"true\"\n              [allowColumnResizing]=\"true\"\n              columnResizingMode=\"widget\"\n              dateSerializationFormat=\"yyyy/MM/dd HH:mm:ss\"\n              (onRowExpanding)=\"$event.component.collapseAll(-1)\"\n>\n  <dxo-sorting mode=\"multiple\"></dxo-sorting>\n  <dxo-selection mode=\"multiple\" selectAllMode=\"page\"></dxo-selection>\n  <dxo-filter-row [visible]=\"true\"></dxo-filter-row>\n  <dxo-remote-operations [filtering]=\"true\"\n                         [sorting]=\"true\"\n                         [paging]=\"true\">\n  </dxo-remote-operations>\n  <dxo-master-detail [enabled]=\"enableMasterDetail\" template=\"masterDetailTemplate\"></dxo-master-detail>\n  <dxo-paging [pageSize]=\"15\"></dxo-paging>\n  <dxo-pager [visible]=\"true\"\n             [showInfo]=\"true\"\n             infoText=\"第{0}页，共{1}页（共{2}个项目）\"\n             [showPageSizeSelector]=\"true\"\n             [allowedPageSizes]=\"[15, 30, 50]\"\n  ></dxo-pager>\n  <dxo-scrolling showScrollbar=\"always\"></dxo-scrolling>\n  <dxo-export [allowExportSelectedData]=\"true\"\n              [fileName]=\"className\"></dxo-export>\n  <div *dxTemplate=\"let rowInfo of 'masterDetailTemplate'\">\n    <ng-container [ngTemplateOutlet]=\"masterDetailTemplate.templateRef\"\n                  [ngTemplateOutletContext]=\"{$implicit: rowInfo}\"></ng-container>\n  </div>\n  <div *dxTemplate=\"let cellInfo of 'rowIndexTemplate'\">\n    {{cellInfo.rowIndex + 1}}\n  </div>\n  <div *dxTemplate=\"let cellInfo of 'textCellTemplate'\">\n    <div dPopover #textDiv\n         [content]=\"cellInfo.value\"\n         [controlled]=\"textDiv.clientWidth < textDiv.scrollWidth\"\n         [popMaxWidth]=\"240\"\n         [popoverStyle]=\"{ backgroundColor: '#fff', color: 'rgb(51, 51, 51)' }\"\n         style=\"max-width: 240px; text-overflow: ellipsis; overflow: hidden;\"\n         [ngStyle]=\"{ cursor: textDiv.clientWidth < textDiv.scrollWidth ? 'pointer': 'default'}\">{{cellInfo.value}}</div>\n  </div>\n</dx-data-grid>\n"]}
|
|
@@ -3,16 +3,19 @@ import { CommonModule } from '@angular/common';
|
|
|
3
3
|
import { DataGridComponent } from './data-grid.component';
|
|
4
4
|
import { DxDataGridModule } from "devextreme-angular";
|
|
5
5
|
import { MasterDetailTemplateDirective } from './master-detail-template.directive';
|
|
6
|
+
import { DevUIModule } from "ng-devui";
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
export class DataGridModule {
|
|
8
9
|
}
|
|
9
10
|
DataGridModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DataGridModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
10
11
|
DataGridModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.7", ngImport: i0, type: DataGridModule, declarations: [DataGridComponent,
|
|
11
12
|
MasterDetailTemplateDirective], imports: [CommonModule,
|
|
12
|
-
DxDataGridModule
|
|
13
|
+
DxDataGridModule,
|
|
14
|
+
DevUIModule], exports: [DataGridComponent,
|
|
13
15
|
MasterDetailTemplateDirective] });
|
|
14
16
|
DataGridModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DataGridModule, imports: [CommonModule,
|
|
15
|
-
DxDataGridModule
|
|
17
|
+
DxDataGridModule,
|
|
18
|
+
DevUIModule] });
|
|
16
19
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DataGridModule, decorators: [{
|
|
17
20
|
type: NgModule,
|
|
18
21
|
args: [{
|
|
@@ -22,7 +25,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
22
25
|
],
|
|
23
26
|
imports: [
|
|
24
27
|
CommonModule,
|
|
25
|
-
DxDataGridModule
|
|
28
|
+
DxDataGridModule,
|
|
29
|
+
DevUIModule
|
|
26
30
|
],
|
|
27
31
|
exports: [
|
|
28
32
|
DataGridComponent,
|
|
@@ -30,4 +34,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
30
34
|
]
|
|
31
35
|
}]
|
|
32
36
|
}] });
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1ncmlkLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1ycy1hbnQvc3JjL2RhdGEtZ3JpZC9kYXRhLWdyaWQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxpQkFBaUIsRUFBQyxNQUFNLHVCQUF1QixDQUFDO0FBQ3hELE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLG9CQUFvQixDQUFDO0FBQ3BELE9BQU8sRUFBQyw2QkFBNkIsRUFBQyxNQUFNLG9DQUFvQyxDQUFDO0FBQ2pGLE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSxVQUFVLENBQUM7O0FBaUJyQyxNQUFNLE9BQU8sY0FBYzs7MkdBQWQsY0FBYzs0R0FBZCxjQUFjLGlCQWJ2QixpQkFBaUI7UUFDakIsNkJBQTZCLGFBRzdCLFlBQVk7UUFDWixnQkFBZ0I7UUFDaEIsV0FBVyxhQUdYLGlCQUFpQjtRQUNqQiw2QkFBNkI7NEdBR3BCLGNBQWMsWUFUdkIsWUFBWTtRQUNaLGdCQUFnQjtRQUNoQixXQUFXOzJGQU9GLGNBQWM7a0JBZjFCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLGlCQUFpQjt3QkFDakIsNkJBQTZCO3FCQUM5QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixnQkFBZ0I7d0JBQ2hCLFdBQVc7cUJBQ1o7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGlCQUFpQjt3QkFDakIsNkJBQTZCO3FCQUM5QjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge0RhdGFHcmlkQ29tcG9uZW50fSBmcm9tICcuL2RhdGEtZ3JpZC5jb21wb25lbnQnO1xuaW1wb3J0IHtEeERhdGFHcmlkTW9kdWxlfSBmcm9tIFwiZGV2ZXh0cmVtZS1hbmd1bGFyXCI7XG5pbXBvcnQge01hc3RlckRldGFpbFRlbXBsYXRlRGlyZWN0aXZlfSBmcm9tICcuL21hc3Rlci1kZXRhaWwtdGVtcGxhdGUuZGlyZWN0aXZlJztcbmltcG9ydCB7RGV2VUlNb2R1bGV9IGZyb20gXCJuZy1kZXZ1aVwiO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBEYXRhR3JpZENvbXBvbmVudCxcbiAgICBNYXN0ZXJEZXRhaWxUZW1wbGF0ZURpcmVjdGl2ZVxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIER4RGF0YUdyaWRNb2R1bGUsXG4gICAgRGV2VUlNb2R1bGVcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIERhdGFHcmlkQ29tcG9uZW50LFxuICAgIE1hc3RlckRldGFpbFRlbXBsYXRlRGlyZWN0aXZlXG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgRGF0YUdyaWRNb2R1bGUge1xufVxuIl19
|