ngx-rs-ant 2.4.1 → 2.4.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { EventEmitter,
|
|
1
|
+
import { EventEmitter, ViewContainerRef } from '@angular/core';
|
|
2
2
|
import { DataGridService } from "./data-grid.service";
|
|
3
3
|
import { RowButtonsTemplateDirective } from "./row-buttons-template.directive";
|
|
4
4
|
import { DataGridFactory } from "./data-grid.factory";
|
|
5
5
|
import { CustomTemplateDirective } from "./custom-template.directive";
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
|
-
export declare class DataGridComponent
|
|
7
|
+
export declare class DataGridComponent {
|
|
8
8
|
protected service: DataGridService;
|
|
9
9
|
private factory;
|
|
10
10
|
private viewContainerRef;
|
|
@@ -39,9 +39,9 @@ export declare class DataGridComponent implements OnInit {
|
|
|
39
39
|
private dxDataGrid;
|
|
40
40
|
protected rowButtonsTemplate: RowButtonsTemplateDirective;
|
|
41
41
|
protected customTemplate: CustomTemplateDirective;
|
|
42
|
-
columns: any[];
|
|
42
|
+
protected columns: any[];
|
|
43
43
|
constructor(service: DataGridService, factory: DataGridFactory, viewContainerRef: ViewContainerRef);
|
|
44
|
-
|
|
44
|
+
ngAfterViewInit(): void;
|
|
45
45
|
ngOnDestroy(): void;
|
|
46
46
|
reload(): void;
|
|
47
47
|
getSelectedRowKeys(): any[] & Promise<any[]>;
|
|
@@ -43,7 +43,7 @@ export class DataGridComponent {
|
|
|
43
43
|
this.onSelectionChanged = new EventEmitter();
|
|
44
44
|
this.columns = [];
|
|
45
45
|
}
|
|
46
|
-
|
|
46
|
+
ngAfterViewInit() {
|
|
47
47
|
if (this.pageSize && !this.allowedPageSizes.includes(this.pageSize)) {
|
|
48
48
|
this.pageSize = 20;
|
|
49
49
|
}
|
|
@@ -56,6 +56,7 @@ export class DataGridComponent {
|
|
|
56
56
|
this.service.cellTemplateLoaded$.unsubscribe();
|
|
57
57
|
}
|
|
58
58
|
reload() {
|
|
59
|
+
this.dxDataGrid.instance.beginUpdate();
|
|
59
60
|
this.columns.length = 0;
|
|
60
61
|
this.factory.makeDataGridColumns(this.tenant, this.className, this.view, this.dxDataGrid).subscribe(columns => {
|
|
61
62
|
if (this.customColumnFn) {
|
|
@@ -99,6 +100,7 @@ export class DataGridComponent {
|
|
|
99
100
|
else {
|
|
100
101
|
this.dataSource = this.factory.makeDataGridDataSource(this.tenant, this.className, this.view, this.filter, this.keyExpr, this.dataGridName);
|
|
101
102
|
}
|
|
103
|
+
this.dxDataGrid.instance.endUpdate();
|
|
102
104
|
}
|
|
103
105
|
getSelectedRowKeys() {
|
|
104
106
|
return this.dxDataGrid.instance.getSelectedRowKeys();
|
|
@@ -207,4 +209,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
207
209
|
type: ContentChild,
|
|
208
210
|
args: [CustomTemplateDirective]
|
|
209
211
|
}] } });
|
|
210
|
-
//# 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, EventEmitter, Input, OnInit, Output, ViewChild, ViewContainerRef} from '@angular/core';\r\nimport {DxDataGridComponent} from \"devextreme-angular\";\r\nimport {DataGridService} from \"./data-grid.service\";\r\nimport {RowButtonsTemplateDirective} from \"./row-buttons-template.directive\";\r\nimport {DataGridFactory} from \"./data-grid.factory\";\r\nimport {debounceTime} from \"rxjs\";\r\nimport {notifyError} from \"../util/utils\";\r\nimport {CustomTemplateDirective} from \"./custom-template.directive\";\r\n\r\n@Component({\r\n  selector: 'rs-data-grid',\r\n  templateUrl: './data-grid.component.html',\r\n  styleUrls: ['./data-grid.component.scss'],\r\n  providers: [DataGridService, DataGridFactory]\r\n})\r\nexport class DataGridComponent implements OnInit {\r\n  @Input()\r\n  tenant?: any = 'T';\r\n  @Input()\r\n  className!: any;\r\n  @Input()\r\n  view?: any;\r\n  @Input()\r\n  filter?: Array<any> | string;\r\n  @Input()\r\n  customColumnFn?: (columns: any[]) => void;\r\n  @Input()\r\n  keyExpr: string = ''; // 用于实例属性选择器，加载组件值时以选中字段为主键获取选中行数据\r\n  @Input()\r\n  dataGridName?: string; // 用于在获取数据时同时获取台账配置的行内按钮\r\n  @Input()\r\n  height: any;\r\n  @Input()\r\n  onlyFrontEnd: boolean = false; // 仅前端，需指定dataSource，不自动获取表格数据\r\n  @Input()\r\n  pageSize: number = 20;\r\n  @Input()\r\n  allowedPageSizes: any[] = [10, 20, 30, 40, 50, 100, 'all'];\r\n  @Input()\r\n  disablePage: boolean = false;\r\n  @Input()\r\n  dataSource: any = {};\r\n  @Input()\r\n  selectionMode: 'none' | 'multiple' | 'single' = 'none';\r\n  @Input()\r\n  selectedRowKeys: any[] = [];\r\n  @Output()\r\n  selectedRowKeysChange = new EventEmitter<any[]>();\r\n  @Input()\r\n  showRowNum: boolean = true;\r\n  @Input()\r\n  instanceLinkType: 'tab' | 'drawer' | 'none' = 'tab';\r\n  @Input()\r\n  drawerInstanceLinkViewContainerRef: any = this.viewContainerRef;\r\n  @Input()\r\n  drawerInstanceLinkSize: 'default' | 'large' | string = 'default';\r\n  @Input()\r\n  drawerInstanceLinkShowHeader: boolean = false;\r\n  @Input()\r\n  drawerInstanceLinkFormTemplate: any;\r\n  @Output()\r\n  onCellPrepared = new EventEmitter<any>();\r\n  @Output()\r\n  onContentReady = new EventEmitter<any>();\r\n  @Output()\r\n  onEditorPreparing = new EventEmitter<any>();\r\n  @Output()\r\n  onRowClick = new EventEmitter<any>();\r\n  @Output()\r\n  onRowDblClick = new EventEmitter<any>();\r\n  @Output()\r\n  onSelectionChanged = new EventEmitter<any>();\r\n  @ViewChild(DxDataGridComponent, {static: true}) private dxDataGrid!: DxDataGridComponent;\r\n  @ContentChild(RowButtonsTemplateDirective) protected rowButtonsTemplate!: RowButtonsTemplateDirective;\r\n  @ContentChild(CustomTemplateDirective) protected customTemplate!: CustomTemplateDirective;\r\n  columns: any[] = [];\r\n\r\n  constructor(protected service: DataGridService, private factory: DataGridFactory, private viewContainerRef: ViewContainerRef) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.pageSize && !this.allowedPageSizes.includes(this.pageSize)) {\r\n      this.pageSize = 20;\r\n    }\r\n    this.reload();\r\n    this.service.cellTemplateLoaded$.pipe(debounceTime(100)).subscribe(() => {\r\n      (<any>this.dxDataGrid.instance).resize();\r\n    });\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.service.cellTemplateLoaded$.unsubscribe();\r\n  }\r\n\r\n  reload() {\r\n    this.columns.length = 0;\r\n    this.factory.makeDataGridColumns(this.tenant, this.className, this.view, this.dxDataGrid).subscribe(columns => {\r\n      if (this.customColumnFn) {\r\n        this.customColumnFn(columns);\r\n      }\r\n      if (this.instanceLinkType === 'tab' || this.instanceLinkType === 'drawer') {\r\n        columns.unshift({\r\n          caption: '详情',\r\n          fixed: true,\r\n          width: 48,\r\n          alignment: 'center',\r\n          cellTemplate: 'instanceLinkTemplate',\r\n          renderAsync: true\r\n        });\r\n      }\r\n      if (this.showRowNum) {\r\n        columns.unshift({\r\n          caption: '行号',\r\n          fixed: true,\r\n          width: 48,\r\n          alignment: 'center',\r\n          cellTemplate: 'rowIndexTemplate',\r\n          renderAsync: true\r\n        });\r\n      }\r\n      this.columns = columns;\r\n      if (this.onlyFrontEnd && this.filter) {\r\n        if (Array.isArray(this.filter)) {\r\n          this.dxDataGrid.instance.filter(this.filter);\r\n        } else {\r\n          this.dxDataGrid.instance.filter(JSON.parse(this.filter));\r\n        }\r\n      }\r\n    });\r\n    if (this.onlyFrontEnd) {\r\n      if (this.dataSource && !Array.isArray(this.dataSource)) {\r\n        notifyError('因onlyFrontEnd参数为true，需要明确指定dataSource参数为数组');\r\n      }\r\n    } else {\r\n      this.dataSource = this.factory.makeDataGridDataSource(this.tenant, this.className, this.view, this.filter, this.keyExpr, this.dataGridName);\r\n    }\r\n  }\r\n\r\n  getSelectedRowKeys() {\r\n    return this.dxDataGrid.instance.getSelectedRowKeys();\r\n  }\r\n\r\n  getSelectedRowsData() {\r\n    return this.dxDataGrid.instance.getSelectedRowsData();\r\n  }\r\n\r\n  getUserFilter() {\r\n    return this.factory.getFilter();\r\n  }\r\n\r\n  getUserSort() {\r\n    return this.factory.getSort();\r\n  }\r\n\r\n  refresh(callback?: any) {\r\n    this.dxDataGrid.instance.clearSelection();\r\n    this.dxDataGrid.instance.refresh().then(() => {\r\n      if (callback) {\r\n        callback();\r\n      }\r\n    });\r\n  }\r\n\r\n  onDxDataGridEditorPreparing($event: any) {\r\n    if ($event.parentType === 'filterRow' && $event.editorName === 'dxTextBox') {\r\n      $event.editorOptions.valueChangeEvent = 'blur';\r\n      $event.editorOptions.onEnterKey = (e: any) => {\r\n        e.component.blur();\r\n      };\r\n      $event.editorOptions.onPaste = (e: any) => {\r\n        const inputElement = e.element.querySelector('input');\r\n        setTimeout(() => {\r\n          inputElement.value = inputElement.value?.trim();\r\n        });\r\n      };\r\n    }\r\n    this.onEditorPreparing.emit($event);\r\n  }\r\n}\r\n","<dx-data-grid [showBorders]=\"true\"\r\n              [showRowLines]=\"true\"\r\n              [showColumnLines]=\"true\"\r\n              [hoverStateEnabled]=\"true\"\r\n              [rowAlternationEnabled]=\"true\"\r\n              [columnAutoWidth]=\"true\"\r\n              [allowColumnResizing]=\"true\"\r\n              columnResizingMode=\"widget\"\r\n              dateSerializationFormat=\"yyyy/MM/dd HH:mm:ss\"\r\n              [syncLookupFilterValues]=\"false\"\r\n              [dataSource]=\"dataSource\"\r\n              [columns]=\"columns\"\r\n              [height]=\"height\"\r\n              [keyExpr]=\"keyExpr\"\r\n              [selectedRowKeys]=\"selectedRowKeys\"\r\n              (selectedRowKeysChange)=\"selectedRowKeysChange.emit($event)\"\r\n              (onCellPrepared)=\"onCellPrepared.emit($event)\"\r\n              (onContentReady)=\"onContentReady.emit($event)\"\r\n              (onEditorPreparing)=\"onDxDataGridEditorPreparing($event)\"\r\n              (onRowClick)=\"onRowClick.emit($event)\"\r\n              (onRowDblClick)=\"onRowDblClick.emit($event)\"\r\n              (onSelectionChanged)=\"onSelectionChanged.emit($event)\">\r\n  <dxo-sorting [mode]=\"onlyFrontEnd ? 'none' : 'multiple'\"></dxo-sorting>\r\n  <dxo-selection [mode]=\"selectionMode\" selectAllMode=\"page\" showCheckBoxesMode=\"always\"></dxo-selection>\r\n  <dxo-header-filter [visible]=\"!onlyFrontEnd\">\r\n    <dxo-search [enabled]=\"true\"></dxo-search>\r\n    <dxo-texts [ok]=\"'确定'\"></dxo-texts>\r\n  </dxo-header-filter>\r\n  <dxo-filter-row [visible]=\"!onlyFrontEnd\"></dxo-filter-row>\r\n  <dxo-remote-operations [filtering]=\"!onlyFrontEnd\"\r\n                         [sorting]=\"!onlyFrontEnd\"\r\n                         [paging]=\"!onlyFrontEnd\">\r\n  </dxo-remote-operations>\r\n  <dxo-paging [enabled]=\"!disablePage\" [pageSize]=\"pageSize\"></dxo-paging>\r\n  <dxo-pager [visible]=\"!disablePage\"\r\n             displayMode=\"compact\"\r\n             [showInfo]=\"true\"\r\n             infoText=\"第{0}页，共{1}页（共{2}项）\"\r\n             [showPageSizeSelector]=\"true\"\r\n             [allowedPageSizes]=\"allowedPageSizes\"\r\n  ></dxo-pager>\r\n  <dxo-scrolling showScrollbar=\"always\"></dxo-scrolling>\r\n  <div *dxTemplate=\"let cellInfo of 'rowIndexTemplate'\">\r\n    {{ cellInfo.rowIndex + 1 }}\r\n  </div>\r\n  <div *dxTemplate=\"let cellInfo of 'instanceLinkTemplate'\">\r\n    <rs-instance-link-template [tenant]=\"tenant\"\r\n                               [className]=\"className\"\r\n                               [oid]=\"cellInfo.data.oid\"\r\n                               [instanceLinkType]=\"instanceLinkType\"\r\n                               [drawerViewContainerRef]=\"drawerInstanceLinkViewContainerRef\"\r\n                               [drawerSize]=\"drawerInstanceLinkSize\"\r\n                               [drawerShowHeader]=\"drawerInstanceLinkShowHeader\"\r\n                               [drawerFormTemplate]=\"drawerInstanceLinkFormTemplate\">\r\n    </rs-instance-link-template>\r\n  </div>\r\n  <div *dxTemplate=\"let cellInfo of 'cellComponentTemplate'\">\r\n    <rs-cell-component-template [tenant]=\"tenant\" [className]=\"className\"\r\n                                [cellInfo]=\"cellInfo\"></rs-cell-component-template>\r\n  </div>\r\n  <div *dxTemplate=\"let cellInfo of 'rowButtonsTemplate'\">\r\n    <ng-container [ngTemplateOutlet]=\"rowButtonsTemplate.templateRef\"\r\n                  [ngTemplateOutletContext]=\"{$implicit: cellInfo, cellTemplateLoaded$: service.cellTemplateLoaded$}\"></ng-container>\r\n  </div>\r\n  <div *dxTemplate=\"let cellInfo of 'customTemplate'\">\r\n    <ng-container [ngTemplateOutlet]=\"customTemplate.templateRef\"\r\n                  [ngTemplateOutletContext]=\"{$implicit: cellInfo, cellTemplateLoaded$: service.cellTemplateLoaded$}\"></ng-container>\r\n  </div>\r\n</dx-data-grid>\r\n"]}
|
|
212
|
+
//# 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, EventEmitter, Input, Output, ViewChild, ViewContainerRef} from '@angular/core';\r\nimport {DxDataGridComponent} from \"devextreme-angular\";\r\nimport {DataGridService} from \"./data-grid.service\";\r\nimport {RowButtonsTemplateDirective} from \"./row-buttons-template.directive\";\r\nimport {DataGridFactory} from \"./data-grid.factory\";\r\nimport {debounceTime} from \"rxjs\";\r\nimport {notifyError} from \"../util/utils\";\r\nimport {CustomTemplateDirective} from \"./custom-template.directive\";\r\n\r\n@Component({\r\n  selector: 'rs-data-grid',\r\n  templateUrl: './data-grid.component.html',\r\n  styleUrls: ['./data-grid.component.scss'],\r\n  providers: [DataGridService, DataGridFactory]\r\n})\r\nexport class DataGridComponent {\r\n  @Input()\r\n  tenant?: any = 'T';\r\n  @Input()\r\n  className!: any;\r\n  @Input()\r\n  view?: any;\r\n  @Input()\r\n  filter?: Array<any> | string;\r\n  @Input()\r\n  customColumnFn?: (columns: any[]) => void;\r\n  @Input()\r\n  keyExpr: string = ''; // 用于实例属性选择器，加载组件值时以选中字段为主键获取选中行数据\r\n  @Input()\r\n  dataGridName?: string; // 用于在获取数据时同时获取台账配置的行内按钮\r\n  @Input()\r\n  height: any;\r\n  @Input()\r\n  onlyFrontEnd: boolean = false; // 仅前端，需指定dataSource，不自动获取表格数据\r\n  @Input()\r\n  pageSize: number = 20;\r\n  @Input()\r\n  allowedPageSizes: any[] = [10, 20, 30, 40, 50, 100, 'all'];\r\n  @Input()\r\n  disablePage: boolean = false;\r\n  @Input()\r\n  dataSource: any = {};\r\n  @Input()\r\n  selectionMode: 'none' | 'multiple' | 'single' = 'none';\r\n  @Input()\r\n  selectedRowKeys: any[] = [];\r\n  @Output()\r\n  selectedRowKeysChange = new EventEmitter<any[]>();\r\n  @Input()\r\n  showRowNum: boolean = true;\r\n  @Input()\r\n  instanceLinkType: 'tab' | 'drawer' | 'none' = 'tab';\r\n  @Input()\r\n  drawerInstanceLinkViewContainerRef: any = this.viewContainerRef;\r\n  @Input()\r\n  drawerInstanceLinkSize: 'default' | 'large' | string = 'default';\r\n  @Input()\r\n  drawerInstanceLinkShowHeader: boolean = false;\r\n  @Input()\r\n  drawerInstanceLinkFormTemplate: any;\r\n  @Output()\r\n  onCellPrepared = new EventEmitter<any>();\r\n  @Output()\r\n  onContentReady = new EventEmitter<any>();\r\n  @Output()\r\n  onEditorPreparing = new EventEmitter<any>();\r\n  @Output()\r\n  onRowClick = new EventEmitter<any>();\r\n  @Output()\r\n  onRowDblClick = new EventEmitter<any>();\r\n  @Output()\r\n  onSelectionChanged = new EventEmitter<any>();\r\n  @ViewChild(DxDataGridComponent, {static: true})\r\n  private dxDataGrid!: DxDataGridComponent;\r\n  @ContentChild(RowButtonsTemplateDirective)\r\n  protected rowButtonsTemplate!: RowButtonsTemplateDirective;\r\n  @ContentChild(CustomTemplateDirective)\r\n  protected customTemplate!: CustomTemplateDirective;\r\n  protected columns: any[] = [];\r\n\r\n  constructor(protected service: DataGridService, private factory: DataGridFactory, private viewContainerRef: ViewContainerRef) {\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    if (this.pageSize && !this.allowedPageSizes.includes(this.pageSize)) {\r\n      this.pageSize = 20;\r\n    }\r\n    this.reload();\r\n    this.service.cellTemplateLoaded$.pipe(debounceTime(100)).subscribe(() => {\r\n      (<any>this.dxDataGrid.instance).resize();\r\n    });\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.service.cellTemplateLoaded$.unsubscribe();\r\n  }\r\n\r\n  reload() {\r\n    this.dxDataGrid.instance.beginUpdate();\r\n    this.columns.length = 0;\r\n    this.factory.makeDataGridColumns(this.tenant, this.className, this.view, this.dxDataGrid).subscribe(columns => {\r\n      if (this.customColumnFn) {\r\n        this.customColumnFn(columns);\r\n      }\r\n      if (this.instanceLinkType === 'tab' || this.instanceLinkType === 'drawer') {\r\n        columns.unshift({\r\n          caption: '详情',\r\n          fixed: true,\r\n          width: 48,\r\n          alignment: 'center',\r\n          cellTemplate: 'instanceLinkTemplate',\r\n          renderAsync: true\r\n        });\r\n      }\r\n      if (this.showRowNum) {\r\n        columns.unshift({\r\n          caption: '行号',\r\n          fixed: true,\r\n          width: 48,\r\n          alignment: 'center',\r\n          cellTemplate: 'rowIndexTemplate',\r\n          renderAsync: true\r\n        });\r\n      }\r\n      this.columns = columns;\r\n      if (this.onlyFrontEnd && this.filter) {\r\n        if (Array.isArray(this.filter)) {\r\n          this.dxDataGrid.instance.filter(this.filter);\r\n        } else {\r\n          this.dxDataGrid.instance.filter(JSON.parse(this.filter));\r\n        }\r\n      }\r\n    });\r\n    if (this.onlyFrontEnd) {\r\n      if (this.dataSource && !Array.isArray(this.dataSource)) {\r\n        notifyError('因onlyFrontEnd参数为true，需要明确指定dataSource参数为数组');\r\n      }\r\n    } else {\r\n      this.dataSource = this.factory.makeDataGridDataSource(this.tenant, this.className, this.view, this.filter, this.keyExpr, this.dataGridName);\r\n    }\r\n    this.dxDataGrid.instance.endUpdate();\r\n  }\r\n\r\n  getSelectedRowKeys() {\r\n    return this.dxDataGrid.instance.getSelectedRowKeys();\r\n  }\r\n\r\n  getSelectedRowsData() {\r\n    return this.dxDataGrid.instance.getSelectedRowsData();\r\n  }\r\n\r\n  getUserFilter() {\r\n    return this.factory.getFilter();\r\n  }\r\n\r\n  getUserSort() {\r\n    return this.factory.getSort();\r\n  }\r\n\r\n  refresh(callback?: any) {\r\n    this.dxDataGrid.instance.clearSelection();\r\n    this.dxDataGrid.instance.refresh().then(() => {\r\n      if (callback) {\r\n        callback();\r\n      }\r\n    });\r\n  }\r\n\r\n  onDxDataGridEditorPreparing($event: any) {\r\n    if ($event.parentType === 'filterRow' && $event.editorName === 'dxTextBox') {\r\n      $event.editorOptions.valueChangeEvent = 'blur';\r\n      $event.editorOptions.onEnterKey = (e: any) => {\r\n        e.component.blur();\r\n      };\r\n      $event.editorOptions.onPaste = (e: any) => {\r\n        const inputElement = e.element.querySelector('input');\r\n        setTimeout(() => {\r\n          inputElement.value = inputElement.value?.trim();\r\n        });\r\n      };\r\n    }\r\n    this.onEditorPreparing.emit($event);\r\n  }\r\n}\r\n","<dx-data-grid [showBorders]=\"true\"\r\n              [showRowLines]=\"true\"\r\n              [showColumnLines]=\"true\"\r\n              [hoverStateEnabled]=\"true\"\r\n              [rowAlternationEnabled]=\"true\"\r\n              [columnAutoWidth]=\"true\"\r\n              [allowColumnResizing]=\"true\"\r\n              columnResizingMode=\"widget\"\r\n              dateSerializationFormat=\"yyyy/MM/dd HH:mm:ss\"\r\n              [syncLookupFilterValues]=\"false\"\r\n              [dataSource]=\"dataSource\"\r\n              [columns]=\"columns\"\r\n              [height]=\"height\"\r\n              [keyExpr]=\"keyExpr\"\r\n              [selectedRowKeys]=\"selectedRowKeys\"\r\n              (selectedRowKeysChange)=\"selectedRowKeysChange.emit($event)\"\r\n              (onCellPrepared)=\"onCellPrepared.emit($event)\"\r\n              (onContentReady)=\"onContentReady.emit($event)\"\r\n              (onEditorPreparing)=\"onDxDataGridEditorPreparing($event)\"\r\n              (onRowClick)=\"onRowClick.emit($event)\"\r\n              (onRowDblClick)=\"onRowDblClick.emit($event)\"\r\n              (onSelectionChanged)=\"onSelectionChanged.emit($event)\">\r\n  <dxo-sorting [mode]=\"onlyFrontEnd ? 'none' : 'multiple'\"></dxo-sorting>\r\n  <dxo-selection [mode]=\"selectionMode\" selectAllMode=\"page\" showCheckBoxesMode=\"always\"></dxo-selection>\r\n  <dxo-header-filter [visible]=\"!onlyFrontEnd\">\r\n    <dxo-search [enabled]=\"true\"></dxo-search>\r\n    <dxo-texts [ok]=\"'确定'\"></dxo-texts>\r\n  </dxo-header-filter>\r\n  <dxo-filter-row [visible]=\"!onlyFrontEnd\"></dxo-filter-row>\r\n  <dxo-remote-operations [filtering]=\"!onlyFrontEnd\"\r\n                         [sorting]=\"!onlyFrontEnd\"\r\n                         [paging]=\"!onlyFrontEnd\">\r\n  </dxo-remote-operations>\r\n  <dxo-paging [enabled]=\"!disablePage\" [pageSize]=\"pageSize\"></dxo-paging>\r\n  <dxo-pager [visible]=\"!disablePage\"\r\n             displayMode=\"compact\"\r\n             [showInfo]=\"true\"\r\n             infoText=\"第{0}页，共{1}页（共{2}项）\"\r\n             [showPageSizeSelector]=\"true\"\r\n             [allowedPageSizes]=\"allowedPageSizes\"\r\n  ></dxo-pager>\r\n  <dxo-scrolling showScrollbar=\"always\"></dxo-scrolling>\r\n  <div *dxTemplate=\"let cellInfo of 'rowIndexTemplate'\">\r\n    {{ cellInfo.rowIndex + 1 }}\r\n  </div>\r\n  <div *dxTemplate=\"let cellInfo of 'instanceLinkTemplate'\">\r\n    <rs-instance-link-template [tenant]=\"tenant\"\r\n                               [className]=\"className\"\r\n                               [oid]=\"cellInfo.data.oid\"\r\n                               [instanceLinkType]=\"instanceLinkType\"\r\n                               [drawerViewContainerRef]=\"drawerInstanceLinkViewContainerRef\"\r\n                               [drawerSize]=\"drawerInstanceLinkSize\"\r\n                               [drawerShowHeader]=\"drawerInstanceLinkShowHeader\"\r\n                               [drawerFormTemplate]=\"drawerInstanceLinkFormTemplate\">\r\n    </rs-instance-link-template>\r\n  </div>\r\n  <div *dxTemplate=\"let cellInfo of 'cellComponentTemplate'\">\r\n    <rs-cell-component-template [tenant]=\"tenant\" [className]=\"className\"\r\n                                [cellInfo]=\"cellInfo\"></rs-cell-component-template>\r\n  </div>\r\n  <div *dxTemplate=\"let cellInfo of 'rowButtonsTemplate'\">\r\n    <ng-container [ngTemplateOutlet]=\"rowButtonsTemplate.templateRef\"\r\n                  [ngTemplateOutletContext]=\"{$implicit: cellInfo, cellTemplateLoaded$: service.cellTemplateLoaded$}\"></ng-container>\r\n  </div>\r\n  <div *dxTemplate=\"let cellInfo of 'customTemplate'\">\r\n    <ng-container [ngTemplateOutlet]=\"customTemplate.templateRef\"\r\n                  [ngTemplateOutletContext]=\"{$implicit: cellInfo, cellTemplateLoaded$: service.cellTemplateLoaded$}\"></ng-container>\r\n  </div>\r\n</dx-data-grid>\r\n"]}
|
package/fesm2015/ngx-rs-ant.mjs
CHANGED
|
@@ -3045,7 +3045,7 @@ class DataGridComponent {
|
|
|
3045
3045
|
this.onSelectionChanged = new EventEmitter();
|
|
3046
3046
|
this.columns = [];
|
|
3047
3047
|
}
|
|
3048
|
-
|
|
3048
|
+
ngAfterViewInit() {
|
|
3049
3049
|
if (this.pageSize && !this.allowedPageSizes.includes(this.pageSize)) {
|
|
3050
3050
|
this.pageSize = 20;
|
|
3051
3051
|
}
|
|
@@ -3058,6 +3058,7 @@ class DataGridComponent {
|
|
|
3058
3058
|
this.service.cellTemplateLoaded$.unsubscribe();
|
|
3059
3059
|
}
|
|
3060
3060
|
reload() {
|
|
3061
|
+
this.dxDataGrid.instance.beginUpdate();
|
|
3061
3062
|
this.columns.length = 0;
|
|
3062
3063
|
this.factory.makeDataGridColumns(this.tenant, this.className, this.view, this.dxDataGrid).subscribe(columns => {
|
|
3063
3064
|
if (this.customColumnFn) {
|
|
@@ -3101,6 +3102,7 @@ class DataGridComponent {
|
|
|
3101
3102
|
else {
|
|
3102
3103
|
this.dataSource = this.factory.makeDataGridDataSource(this.tenant, this.className, this.view, this.filter, this.keyExpr, this.dataGridName);
|
|
3103
3104
|
}
|
|
3105
|
+
this.dxDataGrid.instance.endUpdate();
|
|
3104
3106
|
}
|
|
3105
3107
|
getSelectedRowKeys() {
|
|
3106
3108
|
return this.dxDataGrid.instance.getSelectedRowKeys();
|