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.
@@ -34,9 +34,8 @@ export class ModalComponent {
34
34
  }
35
35
  show() {
36
36
  // 若存在多层模态框,仅保留最上层遮罩颜色,下层遮罩设置为透明
37
- const parentElement = this.elementRef.nativeElement.parentElement;
38
37
  const nodeName = this.elementRef.nativeElement.nodeName;
39
- const modals = parentElement.querySelectorAll(nodeName);
38
+ const modals = this._parentViewContainerRef.element.nativeElement.querySelectorAll(nodeName);
40
39
  for (let i = 0; i < modals.length; i++) {
41
40
  if (i === modals.length - 1) {
42
41
  modals[i].querySelector('.modal-backdrop').style.backgroundColor = 'rgba(37, 43, 58, 0.05)';
@@ -51,9 +50,8 @@ export class ModalComponent {
51
50
  }
52
51
  ngOnDestroy() {
53
52
  // 若存在多层模态框,下一层遮罩设置为不透明
54
- const parentElement = this.elementRef.nativeElement.parentElement;
55
53
  const nodeName = this.elementRef.nativeElement.nodeName;
56
- const nextModal = parentElement.querySelector(nodeName + ':nth-last-child(2)');
54
+ const nextModal = this._parentViewContainerRef.element.nativeElement.querySelector(nodeName + ':nth-last-child(2)');
57
55
  if (nextModal) {
58
56
  nextModal.querySelector('.modal-backdrop').style.backgroundColor = 'rgba(37, 43, 58, 0.05)';
59
57
  }
@@ -157,4 +155,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
157
155
  type: HostListener,
158
156
  args: ['window:resize', ['$event']]
159
157
  }] } });
160
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../projects/ngx-rs-ant/src/modal/modal.component.ts","../../../../projects/ngx-rs-ant/src/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  HostListener,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  TemplateRef,\r\n  ViewChild\r\n} from '@angular/core';\r\n\r\n@Component({\r\n  selector: 'rs-modal',\r\n  templateUrl: './modal.component.html',\r\n  styleUrls: ['./modal.component.scss']\r\n})\r\nexport class ModalComponent implements OnInit, OnDestroy {\r\n  @Input() title!: string;\r\n  @Input() size: 'default' | 'large' | 'full' = 'default';\r\n  _width: number = 480;\r\n  @ViewChild('modal', {static: true}) modalElementRef!: ElementRef;\r\n  moveHandleEl!: HTMLElement;\r\n  movable: boolean = false;\r\n  topStart = 0;\r\n  leftStart = 0;\r\n  @Input()\r\n  contentTemplate!: TemplateRef<any>;\r\n  @Input()\r\n  contentTemplateContext: any;\r\n  @Input()\r\n  footerTemplate?: TemplateRef<any>;\r\n  @Input()\r\n  footerTemplateContext: any;\r\n\r\n  constructor(private elementRef: ElementRef, private changeDetectorRef: ChangeDetectorRef) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.size === 'full') {\r\n      this.modalElementRef.nativeElement.style.top = '0px';\r\n      this.modalElementRef.nativeElement.style.right = '0px';\r\n      this.modalElementRef.nativeElement.style.bottom = '0px';\r\n      this.modalElementRef.nativeElement.style.left = '0px';\r\n      this.modalElementRef.nativeElement.style.margin = '2px';\r\n      this.modalElementRef.nativeElement.style.boxShadow = 'none';\r\n    } else {\r\n      if (this.size === 'large') {\r\n        this._width = 960;\r\n      }\r\n      this.modalElementRef.nativeElement.style.width = this._width + 'px';\r\n      this.modalElementRef.nativeElement.style.top = '24px';\r\n      this.modalElementRef.nativeElement.style.left =\r\n        (this.elementRef.nativeElement.parentElement.offsetWidth - this.modalElementRef.nativeElement.offsetWidth) / 2 + 'px';\r\n      this.moveHandleEl = this.elementRef.nativeElement.querySelector('.modal-header');\r\n      this.moveHandleEl.style.cursor = 'move';\r\n    }\r\n  }\r\n\r\n  show() {\r\n    // 若存在多层模态框，仅保留最上层遮罩颜色，下层遮罩设置为透明\r\n    const parentElement = this.elementRef.nativeElement.parentElement;\r\n    const nodeName = this.elementRef.nativeElement.nodeName;\r\n    const modals = parentElement.querySelectorAll(nodeName);\r\n    for (let i = 0; i < modals.length; i++) {\r\n      if (i === modals.length - 1) {\r\n        modals[i].querySelector('.modal-backdrop').style.backgroundColor = 'rgba(37, 43, 58, 0.05)';\r\n      } else {\r\n        modals[i].querySelector('.modal-backdrop').style.backgroundColor = 'rgba(37, 43, 58, 0)';\r\n      }\r\n    }\r\n  }\r\n\r\n  hide() {\r\n    // 在service中重写\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    // 若存在多层模态框，下一层遮罩设置为不透明\r\n    const parentElement = this.elementRef.nativeElement.parentElement;\r\n    const nodeName = this.elementRef.nativeElement.nodeName;\r\n    const nextModal = parentElement.querySelector(nodeName + ':nth-last-child(2)');\r\n    if (nextModal) {\r\n      nextModal.querySelector('.modal-backdrop').style.backgroundColor = 'rgba(37, 43, 58, 0.05)';\r\n    }\r\n  }\r\n\r\n  resolveModalBackdropPosition() {\r\n    return {\r\n      \"width\": this.elementRef.nativeElement.parentElement.offsetWidth + 'px',\r\n      \"height\": this.elementRef.nativeElement.parentElement.offsetHeight + 'px',\r\n      \"top\": this.elementRef.nativeElement.parentElement.offsetTop + 'px',\r\n      \"left\": this.elementRef.nativeElement.parentElement.offsetLeft + 'px',\r\n    };\r\n  }\r\n\r\n  resolveModalPosition() {\r\n    if (this.modalElementRef.nativeElement.offsetHeight >= this.elementRef.nativeElement.parentElement.offsetHeight - 48) {\r\n      this.modalElementRef.nativeElement.style.height = this.elementRef.nativeElement.parentElement.offsetHeight - 48 + 'px';\r\n    } else {\r\n      this.modalElementRef.nativeElement.style.height = 'auto';\r\n    }\r\n    return {};\r\n  }\r\n\r\n  onMousedown($event: MouseEvent) {\r\n    if ($event.button === 2 || !this.checkHandleTarget($event.target, this.moveHandleEl)) {\r\n      return;\r\n    }\r\n    this.movable = true;\r\n    this.topStart = $event.clientY - this.modalElementRef.nativeElement.style.top.replace('px', '');\r\n    this.leftStart = $event.clientX - this.modalElementRef.nativeElement.style.left.replace('px', '');\r\n  }\r\n\r\n  private checkHandleTarget(target: any, element: any): boolean {\r\n    if (!element) {\r\n      return false;\r\n    }\r\n    if (target === element) {\r\n      return true;\r\n    }\r\n    for (let child in element.children) {\r\n      if (Object.prototype.hasOwnProperty.call(element.children, child)) {\r\n        if (this.checkHandleTarget(target, element.children[child])) {\r\n          return true;\r\n        }\r\n      }\r\n    }\r\n    return false;\r\n  }\r\n\r\n  @HostListener('document:mouseup', ['$event'])\r\n  onMouseup() {\r\n    this.movable = false;\r\n  }\r\n\r\n  @HostListener('document:mousemove', ['$event'])\r\n  onMousemove($event: MouseEvent) {\r\n    if (!this.movable) {\r\n      return;\r\n    }\r\n    $event.stopPropagation();\r\n    $event.preventDefault();\r\n    const element = this.modalElementRef.nativeElement;\r\n    let currentTop = $event.clientY - this.topStart;\r\n    let currentLeft = $event.clientX - this.leftStart;\r\n    currentTop = currentTop < 0 ? 0 : currentTop;\r\n    const maxTop = element.parentElement.offsetHeight - element.offsetHeight;\r\n    currentTop = currentTop > maxTop ? maxTop : currentTop;\r\n    currentLeft = currentLeft < 0 ? 0 : currentLeft;\r\n    const maxLeft = element.parentElement.offsetWidth - element.offsetWidth;\r\n    currentLeft = currentLeft > maxLeft ? maxLeft : currentLeft;\r\n    element.style.top = currentTop + 'px';\r\n    element.style.left = currentLeft + 'px';\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize() {\r\n    this.modalElementRef.nativeElement.style.top = '24px';\r\n    this.modalElementRef.nativeElement.style.left =\r\n      (this.elementRef.nativeElement.parentElement.offsetWidth - this.modalElementRef.nativeElement.offsetWidth) / 2 + 'px';\r\n    this.changeDetectorRef.detectChanges();\r\n  }\r\n}\r\n","<div class=\"modal-backdrop\" [ngStyle]=\"resolveModalBackdropPosition()\">\r\n  <div #modal class=\"modal\" [ngStyle]=\"resolveModalPosition()\">\r\n    <div class=\"modal-header\" (mousedown)=\"onMousedown($event)\">\r\n      <div class=\"modal-title\">{{title}}</div>\r\n      <i class=\"icon-close\" (click)=\"hide()\"></i>\r\n    </div>\r\n    <div class=\"modal-content\">\r\n      <ng-template [ngTemplateOutlet]=\"contentTemplate\"\r\n                   [ngTemplateOutletContext]=\"{$implicit: contentTemplateContext}\"></ng-template>\r\n    </div>\r\n    <div *ngIf=\"footerTemplate\" class=\"modal-footer\">\r\n      <ng-template [ngTemplateOutlet]=\"footerTemplate\"\r\n                   [ngTemplateOutletContext]=\"{$implicit: footerTemplateContext}\"></ng-template>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
158
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../projects/ngx-rs-ant/src/modal/modal.component.ts","../../../../projects/ngx-rs-ant/src/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  HostListener,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  TemplateRef,\r\n  ViewChild\r\n} from '@angular/core';\r\n\r\n@Component({\r\n  selector: 'rs-modal',\r\n  templateUrl: './modal.component.html',\r\n  styleUrls: ['./modal.component.scss']\r\n})\r\nexport class ModalComponent implements OnInit, OnDestroy {\r\n  @Input() title!: string;\r\n  @Input() size: 'default' | 'large' | 'full' = 'default';\r\n  _width: number = 480;\r\n  @ViewChild('modal', {static: true}) modalElementRef!: ElementRef;\r\n  moveHandleEl!: HTMLElement;\r\n  movable: boolean = false;\r\n  topStart = 0;\r\n  leftStart = 0;\r\n  @Input()\r\n  contentTemplate!: TemplateRef<any>;\r\n  @Input()\r\n  contentTemplateContext: any;\r\n  @Input()\r\n  footerTemplate?: TemplateRef<any>;\r\n  @Input()\r\n  footerTemplateContext: any;\r\n  _parentViewContainerRef: any;\r\n\r\n  constructor(private elementRef: ElementRef, private changeDetectorRef: ChangeDetectorRef) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.size === 'full') {\r\n      this.modalElementRef.nativeElement.style.top = '0px';\r\n      this.modalElementRef.nativeElement.style.right = '0px';\r\n      this.modalElementRef.nativeElement.style.bottom = '0px';\r\n      this.modalElementRef.nativeElement.style.left = '0px';\r\n      this.modalElementRef.nativeElement.style.margin = '2px';\r\n      this.modalElementRef.nativeElement.style.boxShadow = 'none';\r\n    } else {\r\n      if (this.size === 'large') {\r\n        this._width = 960;\r\n      }\r\n      this.modalElementRef.nativeElement.style.width = this._width + 'px';\r\n      this.modalElementRef.nativeElement.style.top = '24px';\r\n      this.modalElementRef.nativeElement.style.left =\r\n        (this.elementRef.nativeElement.parentElement.offsetWidth - this.modalElementRef.nativeElement.offsetWidth) / 2 + 'px';\r\n      this.moveHandleEl = this.elementRef.nativeElement.querySelector('.modal-header');\r\n      this.moveHandleEl.style.cursor = 'move';\r\n    }\r\n  }\r\n\r\n  show() {\r\n    // 若存在多层模态框，仅保留最上层遮罩颜色，下层遮罩设置为透明\r\n    const nodeName = this.elementRef.nativeElement.nodeName;\r\n    const modals = this._parentViewContainerRef.element.nativeElement.querySelectorAll(nodeName);\r\n    for (let i = 0; i < modals.length; i++) {\r\n      if (i === modals.length - 1) {\r\n        modals[i].querySelector('.modal-backdrop').style.backgroundColor = 'rgba(37, 43, 58, 0.05)';\r\n      } else {\r\n        modals[i].querySelector('.modal-backdrop').style.backgroundColor = 'rgba(37, 43, 58, 0)';\r\n      }\r\n    }\r\n  }\r\n\r\n  hide() {\r\n    // 在service中重写\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    // 若存在多层模态框，下一层遮罩设置为不透明\r\n    const nodeName = this.elementRef.nativeElement.nodeName;\r\n    const nextModal = this._parentViewContainerRef.element.nativeElement.querySelector(nodeName + ':nth-last-child(2)');\r\n    if (nextModal) {\r\n      nextModal.querySelector('.modal-backdrop').style.backgroundColor = 'rgba(37, 43, 58, 0.05)';\r\n    }\r\n  }\r\n\r\n  resolveModalBackdropPosition() {\r\n    return {\r\n      \"width\": this.elementRef.nativeElement.parentElement.offsetWidth + 'px',\r\n      \"height\": this.elementRef.nativeElement.parentElement.offsetHeight + 'px',\r\n      \"top\": this.elementRef.nativeElement.parentElement.offsetTop + 'px',\r\n      \"left\": this.elementRef.nativeElement.parentElement.offsetLeft + 'px',\r\n    };\r\n  }\r\n\r\n  resolveModalPosition() {\r\n    if (this.modalElementRef.nativeElement.offsetHeight >= this.elementRef.nativeElement.parentElement.offsetHeight - 48) {\r\n      this.modalElementRef.nativeElement.style.height = this.elementRef.nativeElement.parentElement.offsetHeight - 48 + 'px';\r\n    } else {\r\n      this.modalElementRef.nativeElement.style.height = 'auto';\r\n    }\r\n    return {};\r\n  }\r\n\r\n  onMousedown($event: MouseEvent) {\r\n    if ($event.button === 2 || !this.checkHandleTarget($event.target, this.moveHandleEl)) {\r\n      return;\r\n    }\r\n    this.movable = true;\r\n    this.topStart = $event.clientY - this.modalElementRef.nativeElement.style.top.replace('px', '');\r\n    this.leftStart = $event.clientX - this.modalElementRef.nativeElement.style.left.replace('px', '');\r\n  }\r\n\r\n  private checkHandleTarget(target: any, element: any): boolean {\r\n    if (!element) {\r\n      return false;\r\n    }\r\n    if (target === element) {\r\n      return true;\r\n    }\r\n    for (let child in element.children) {\r\n      if (Object.prototype.hasOwnProperty.call(element.children, child)) {\r\n        if (this.checkHandleTarget(target, element.children[child])) {\r\n          return true;\r\n        }\r\n      }\r\n    }\r\n    return false;\r\n  }\r\n\r\n  @HostListener('document:mouseup', ['$event'])\r\n  onMouseup() {\r\n    this.movable = false;\r\n  }\r\n\r\n  @HostListener('document:mousemove', ['$event'])\r\n  onMousemove($event: MouseEvent) {\r\n    if (!this.movable) {\r\n      return;\r\n    }\r\n    $event.stopPropagation();\r\n    $event.preventDefault();\r\n    const element = this.modalElementRef.nativeElement;\r\n    let currentTop = $event.clientY - this.topStart;\r\n    let currentLeft = $event.clientX - this.leftStart;\r\n    currentTop = currentTop < 0 ? 0 : currentTop;\r\n    const maxTop = element.parentElement.offsetHeight - element.offsetHeight;\r\n    currentTop = currentTop > maxTop ? maxTop : currentTop;\r\n    currentLeft = currentLeft < 0 ? 0 : currentLeft;\r\n    const maxLeft = element.parentElement.offsetWidth - element.offsetWidth;\r\n    currentLeft = currentLeft > maxLeft ? maxLeft : currentLeft;\r\n    element.style.top = currentTop + 'px';\r\n    element.style.left = currentLeft + 'px';\r\n  }\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  onWindowResize() {\r\n    this.modalElementRef.nativeElement.style.top = '24px';\r\n    this.modalElementRef.nativeElement.style.left =\r\n      (this.elementRef.nativeElement.parentElement.offsetWidth - this.modalElementRef.nativeElement.offsetWidth) / 2 + 'px';\r\n    this.changeDetectorRef.detectChanges();\r\n  }\r\n}\r\n","<div class=\"modal-backdrop\" [ngStyle]=\"resolveModalBackdropPosition()\">\r\n  <div #modal class=\"modal\" [ngStyle]=\"resolveModalPosition()\">\r\n    <div class=\"modal-header\" (mousedown)=\"onMousedown($event)\">\r\n      <div class=\"modal-title\">{{title}}</div>\r\n      <i class=\"icon-close\" (click)=\"hide()\"></i>\r\n    </div>\r\n    <div class=\"modal-content\">\r\n      <ng-template [ngTemplateOutlet]=\"contentTemplate\"\r\n                   [ngTemplateOutletContext]=\"{$implicit: contentTemplateContext}\"></ng-template>\r\n    </div>\r\n    <div *ngIf=\"footerTemplate\" class=\"modal-footer\">\r\n      <ng-template [ngTemplateOutlet]=\"footerTemplate\"\r\n                   [ngTemplateOutletContext]=\"{$implicit: footerTemplateContext}\"></ng-template>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
@@ -11,6 +11,7 @@ export class ModalService {
11
11
  };
12
12
  modalRef.instance.title = title;
13
13
  modalRef.instance.size = size;
14
+ modalRef.instance._parentViewContainerRef = viewContainerRef;
14
15
  modalRef.instance.contentTemplate = contentTemplate;
15
16
  modalRef.instance.contentTemplateContext = contentTemplateContext;
16
17
  modalRef.instance.footerTemplate = footerTemplate;
@@ -27,4 +28,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
27
28
  providedIn: 'root'
28
29
  }]
29
30
  }], ctorParameters: function () { return []; } });
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1ycy1hbnQvc3JjL21vZGFsL21vZGFsLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFVBQVUsRUFBZ0MsTUFBTSxlQUFlLENBQUM7QUFDeEUsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLG1CQUFtQixDQUFDOztBQUtqRCxNQUFNLE9BQU8sWUFBWTtJQUN2QjtJQUNBLENBQUM7SUFFRCxJQUFJLENBQUMsZ0JBQWtDLEVBQ2xDLEtBQWEsRUFBRSxPQUFxQyxTQUFTLEVBQzdELGVBQWlDLEVBQ2pDLHNCQUEyQixFQUMzQixjQUFpQyxFQUNqQyxxQkFBMkI7UUFDOUIsTUFBTSxRQUFRLEdBQUcsZ0JBQWdCLENBQUMsZUFBZSxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBQ2xFLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxHQUFHLEdBQUcsRUFBRTtZQUM1QixRQUFRLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQzlCLENBQUMsQ0FBQTtRQUNELFFBQVEsQ0FBQyxRQUFRLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUNoQyxRQUFRLENBQUMsUUFBUSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7UUFDOUIsUUFBUSxDQUFDLFFBQVEsQ0FBQyxlQUFlLEdBQUcsZUFBZSxDQUFDO1FBQ3BELFFBQVEsQ0FBQyxRQUFRLENBQUMsc0JBQXNCLEdBQUcsc0JBQXNCLENBQUM7UUFDbEUsUUFBUSxDQUFDLFFBQVEsQ0FBQyxjQUFjLEdBQUcsY0FBYyxDQUFDO1FBQ2xELFFBQVEsQ0FBQyxRQUFRLENBQUMscUJBQXFCLEdBQUcscUJBQXFCLENBQUM7UUFDaEUsUUFBUSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUN6QixPQUFPLFFBQVEsQ0FBQyxRQUFRLENBQUM7SUFDM0IsQ0FBQzs7eUdBdEJVLFlBQVk7NkdBQVosWUFBWSxjQUZYLE1BQU07MkZBRVAsWUFBWTtrQkFIeEIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdGFibGUsIFRlbXBsYXRlUmVmLCBWaWV3Q29udGFpbmVyUmVmfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7TW9kYWxDb21wb25lbnR9IGZyb20gJy4vbW9kYWwuY29tcG9uZW50JztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgTW9kYWxTZXJ2aWNlIHtcbiAgY29uc3RydWN0b3IoKSB7XG4gIH1cblxuICBvcGVuKHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWYsXG4gICAgICAgdGl0bGU6IHN0cmluZywgc2l6ZTogJ2RlZmF1bHQnIHwgJ2xhcmdlJyB8ICdmdWxsJyA9ICdkZWZhdWx0JyxcbiAgICAgICBjb250ZW50VGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT4sXG4gICAgICAgY29udGVudFRlbXBsYXRlQ29udGV4dDogYW55LFxuICAgICAgIGZvb3RlclRlbXBsYXRlPzogVGVtcGxhdGVSZWY8YW55PixcbiAgICAgICBmb290ZXJUZW1wbGF0ZUNvbnRleHQ/OiBhbnkpIHtcbiAgICBjb25zdCBtb2RhbFJlZiA9IHZpZXdDb250YWluZXJSZWYuY3JlYXRlQ29tcG9uZW50KE1vZGFsQ29tcG9uZW50KTtcbiAgICBtb2RhbFJlZi5pbnN0YW5jZS5oaWRlID0gKCkgPT4ge1xuICAgICAgbW9kYWxSZWYuaG9zdFZpZXcuZGVzdHJveSgpO1xuICAgIH1cbiAgICBtb2RhbFJlZi5pbnN0YW5jZS50aXRsZSA9IHRpdGxlO1xuICAgIG1vZGFsUmVmLmluc3RhbmNlLnNpemUgPSBzaXplO1xuICAgIG1vZGFsUmVmLmluc3RhbmNlLmNvbnRlbnRUZW1wbGF0ZSA9IGNvbnRlbnRUZW1wbGF0ZTtcbiAgICBtb2RhbFJlZi5pbnN0YW5jZS5jb250ZW50VGVtcGxhdGVDb250ZXh0ID0gY29udGVudFRlbXBsYXRlQ29udGV4dDtcbiAgICBtb2RhbFJlZi5pbnN0YW5jZS5mb290ZXJUZW1wbGF0ZSA9IGZvb3RlclRlbXBsYXRlO1xuICAgIG1vZGFsUmVmLmluc3RhbmNlLmZvb3RlclRlbXBsYXRlQ29udGV4dCA9IGZvb3RlclRlbXBsYXRlQ29udGV4dDtcbiAgICBtb2RhbFJlZi5pbnN0YW5jZS5zaG93KCk7XG4gICAgcmV0dXJuIG1vZGFsUmVmLmluc3RhbmNlO1xuICB9XG59XG4iXX0=
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1ycy1hbnQvc3JjL21vZGFsL21vZGFsLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFVBQVUsRUFBZ0MsTUFBTSxlQUFlLENBQUM7QUFDeEUsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLG1CQUFtQixDQUFDOztBQUtqRCxNQUFNLE9BQU8sWUFBWTtJQUN2QjtJQUNBLENBQUM7SUFFRCxJQUFJLENBQUMsZ0JBQWtDLEVBQ2xDLEtBQWEsRUFBRSxPQUFxQyxTQUFTLEVBQzdELGVBQWlDLEVBQ2pDLHNCQUEyQixFQUMzQixjQUFpQyxFQUNqQyxxQkFBMkI7UUFDOUIsTUFBTSxRQUFRLEdBQUcsZ0JBQWdCLENBQUMsZUFBZSxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBQ2xFLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxHQUFHLEdBQUcsRUFBRTtZQUM1QixRQUFRLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQzlCLENBQUMsQ0FBQTtRQUNELFFBQVEsQ0FBQyxRQUFRLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUNoQyxRQUFRLENBQUMsUUFBUSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7UUFDOUIsUUFBUSxDQUFDLFFBQVEsQ0FBQyx1QkFBdUIsR0FBRyxnQkFBZ0IsQ0FBQztRQUM3RCxRQUFRLENBQUMsUUFBUSxDQUFDLGVBQWUsR0FBRyxlQUFlLENBQUM7UUFDcEQsUUFBUSxDQUFDLFFBQVEsQ0FBQyxzQkFBc0IsR0FBRyxzQkFBc0IsQ0FBQztRQUNsRSxRQUFRLENBQUMsUUFBUSxDQUFDLGNBQWMsR0FBRyxjQUFjLENBQUM7UUFDbEQsUUFBUSxDQUFDLFFBQVEsQ0FBQyxxQkFBcUIsR0FBRyxxQkFBcUIsQ0FBQztRQUNoRSxRQUFRLENBQUMsUUFBUSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3pCLE9BQU8sUUFBUSxDQUFDLFFBQVEsQ0FBQztJQUMzQixDQUFDOzt5R0F2QlUsWUFBWTs2R0FBWixZQUFZLGNBRlgsTUFBTTsyRkFFUCxZQUFZO2tCQUh4QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0YWJsZSwgVGVtcGxhdGVSZWYsIFZpZXdDb250YWluZXJSZWZ9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtNb2RhbENvbXBvbmVudH0gZnJvbSAnLi9tb2RhbC5jb21wb25lbnQnO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBNb2RhbFNlcnZpY2Uge1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgfVxuXG4gIG9wZW4odmlld0NvbnRhaW5lclJlZjogVmlld0NvbnRhaW5lclJlZixcbiAgICAgICB0aXRsZTogc3RyaW5nLCBzaXplOiAnZGVmYXVsdCcgfCAnbGFyZ2UnIHwgJ2Z1bGwnID0gJ2RlZmF1bHQnLFxuICAgICAgIGNvbnRlbnRUZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55PixcbiAgICAgICBjb250ZW50VGVtcGxhdGVDb250ZXh0OiBhbnksXG4gICAgICAgZm9vdGVyVGVtcGxhdGU/OiBUZW1wbGF0ZVJlZjxhbnk+LFxuICAgICAgIGZvb3RlclRlbXBsYXRlQ29udGV4dD86IGFueSkge1xuICAgIGNvbnN0IG1vZGFsUmVmID0gdmlld0NvbnRhaW5lclJlZi5jcmVhdGVDb21wb25lbnQoTW9kYWxDb21wb25lbnQpO1xuICAgIG1vZGFsUmVmLmluc3RhbmNlLmhpZGUgPSAoKSA9PiB7XG4gICAgICBtb2RhbFJlZi5ob3N0Vmlldy5kZXN0cm95KCk7XG4gICAgfVxuICAgIG1vZGFsUmVmLmluc3RhbmNlLnRpdGxlID0gdGl0bGU7XG4gICAgbW9kYWxSZWYuaW5zdGFuY2Uuc2l6ZSA9IHNpemU7XG4gICAgbW9kYWxSZWYuaW5zdGFuY2UuX3BhcmVudFZpZXdDb250YWluZXJSZWYgPSB2aWV3Q29udGFpbmVyUmVmO1xuICAgIG1vZGFsUmVmLmluc3RhbmNlLmNvbnRlbnRUZW1wbGF0ZSA9IGNvbnRlbnRUZW1wbGF0ZTtcbiAgICBtb2RhbFJlZi5pbnN0YW5jZS5jb250ZW50VGVtcGxhdGVDb250ZXh0ID0gY29udGVudFRlbXBsYXRlQ29udGV4dDtcbiAgICBtb2RhbFJlZi5pbnN0YW5jZS5mb290ZXJUZW1wbGF0ZSA9IGZvb3RlclRlbXBsYXRlO1xuICAgIG1vZGFsUmVmLmluc3RhbmNlLmZvb3RlclRlbXBsYXRlQ29udGV4dCA9IGZvb3RlclRlbXBsYXRlQ29udGV4dDtcbiAgICBtb2RhbFJlZi5pbnN0YW5jZS5zaG93KCk7XG4gICAgcmV0dXJuIG1vZGFsUmVmLmluc3RhbmNlO1xuICB9XG59XG4iXX0=
@@ -1,8 +1,8 @@
1
1
  import * as i0 from '@angular/core';
2
- import { Component, Input, HostBinding, EventEmitter, Output, HostListener, ViewContainerRef, ViewChild, Directive, ViewChildren, NgModule, Injectable, ContentChild } from '@angular/core';
2
+ import { Component, Input, HostBinding, EventEmitter, Output, HostListener, ViewContainerRef, ViewChild, Directive, ViewChildren, NgModule, Injectable, LOCALE_ID, Inject, ContentChild } from '@angular/core';
3
3
  import { PluginFactory } from 'coast-plugin-register';
4
4
  import * as i1 from '@angular/common';
5
- import { CommonModule } from '@angular/common';
5
+ import { CommonModule, formatDate } from '@angular/common';
6
6
  import * as i2 from 'ng-devui/dragdrop';
7
7
  import { Subject, map, lastValueFrom } from 'rxjs';
8
8
  import * as i2$1 from 'ng-devui/input-number';
@@ -15,6 +15,7 @@ import { DxDataGridComponent, DxDataGridModule } from 'devextreme-angular';
15
15
  import * as i1$1 from '@angular/common/http';
16
16
  import * as i4 from 'devextreme-angular/ui/nested';
17
17
  import * as i5$1 from 'devextreme-angular/core';
18
+ import * as i6 from 'ng-devui/popover';
18
19
  import * as i2$2 from 'ng-devui/button';
19
20
  import * as i3$1 from 'ng-devui/form';
20
21
  import * as i4$1 from 'ng-devui/text-input';
@@ -264,7 +265,7 @@ class PluginManager {
264
265
  if (this.activeItems.indexOf($event.target) < 0) {
265
266
  return;
266
267
  }
267
- this.activeItem.next({ boxItem, index, style, config: config.config });
268
+ this.activeItem.next({ boxItem, index, style, config: config.config, componentRef });
268
269
  $event.target.classList.add('plugin-active');
269
270
  });
270
271
  activeComponentRef.instance.itemRemove.subscribe(() => {
@@ -299,9 +300,14 @@ class ItemConfigComponent {
299
300
  if (pluginType === 'form') {
300
301
  instance.fieldTree = this.fieldTree;
301
302
  }
302
- instance.configChange.subscribe(() => {
303
- const componentRef = PluginManager.createComponent(item.boxItem, item.index, item.style, item.config);
304
- componentRef.location.nativeElement.click();
303
+ instance.configChange.subscribe((reload) => {
304
+ if (reload) {
305
+ const componentRef = PluginManager.createComponent(item.boxItem, item.index, item.style, item.config);
306
+ componentRef.location.nativeElement.click();
307
+ }
308
+ else {
309
+ Object.assign(item.componentRef.instance, item.config.pluginConfig);
310
+ }
305
311
  });
306
312
  });
307
313
  }
@@ -772,8 +778,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
772
778
  }], ctorParameters: function () { return [{ type: i0.TemplateRef }]; } });
773
779
 
774
780
  class DataGridComponent {
775
- constructor(service) {
781
+ constructor(service, locale) {
776
782
  this.service = service;
783
+ this.locale = locale;
777
784
  this.enableMasterDetail = false;
778
785
  this.dataSource = {};
779
786
  this.columns = [];
@@ -818,36 +825,100 @@ class DataGridComponent {
818
825
  (_a = this.dxDataGrid.instance) === null || _a === void 0 ? void 0 : _a.state(null);
819
826
  this.service.getMetadataByView(this.tenant, this.className, this.view || '').subscribe((response) => {
820
827
  this.columns = [];
821
- for (let column of response.data.columns) {
822
- if (column.type === 'NORMAL') {
828
+ for (let field of response.data.columns) {
829
+ if (field.type === 'FILE') {
823
830
  this.columns.push({
824
- dataField: column.name,
825
- caption: column.caption,
826
- dataType: this.typeMap[column.dataType].dataType,
831
+ dataField: field.name,
832
+ caption: field.caption,
833
+ dataType: 'string',
827
834
  alignment: 'left',
828
- filterOperations: this.typeMap[column.dataType].filterOperations,
829
- format: this.typeMap[column.dataType].format
835
+ filterOperations: [],
836
+ visible: field.visible
830
837
  });
831
838
  }
832
- else if (column.type === 'FILE') {
833
- this.columns.push({
834
- dataField: column.name,
835
- caption: column.caption,
836
- dataType: 'string',
839
+ else if (field.type === 'NORMAL') {
840
+ const column = {
841
+ dataField: field.name,
842
+ caption: field.caption,
843
+ dataType: this.typeMap[field.dataType].dataType,
837
844
  alignment: 'left',
838
- filterOperations: []
839
- });
845
+ filterOperations: this.typeMap[field.dataType].filterOperations,
846
+ format: this.typeMap[field.dataType].format,
847
+ visible: field.visible
848
+ };
849
+ this.columns.push(column);
850
+ switch (field.dataType) {
851
+ case 'BOOLEAN':
852
+ column.alignment = 'center';
853
+ column.trueText = '是';
854
+ column.falseText = '否';
855
+ break;
856
+ case 'DATE':
857
+ column.calculateFilterExpression = (filterValue, selectedFilterOperation) => {
858
+ if (selectedFilterOperation === 'between' && Array.isArray(filterValue)) {
859
+ return [
860
+ [column.name, '>=', formatDate(filterValue[0], 'yyyy/MM/dd', this.locale, 'GMT+8')],
861
+ 'and',
862
+ [column.name, '<', formatDate(filterValue[1], 'yyyy/MM/dd', this.locale, 'GMT+8')]
863
+ ];
864
+ }
865
+ return [column.name, selectedFilterOperation, formatDate(filterValue, 'yyyy/MM/dd', this.locale, 'GMT+8')];
866
+ };
867
+ break;
868
+ case 'DATETIME':
869
+ case 'DOUBLE':
870
+ case 'INTEGER':
871
+ break;
872
+ case 'STRING':
873
+ switch (field.config.constraint.type) {
874
+ case 'USER':
875
+ column.dataField = '__' + field.name + '\u0001User_displayName';
876
+ column.calculateFilterExpression = (filterValue, selectedFilterOperation) => {
877
+ return [
878
+ [column.name, selectedFilterOperation, filterValue],
879
+ 'or',
880
+ ['__' + field.name + '\u0001User_username', selectedFilterOperation, filterValue]
881
+ ];
882
+ };
883
+ break;
884
+ case 'UNIT':
885
+ column.dataField = '__' + field.name + '\u0001Role_displayName';
886
+ column.calculateFilterExpression = (filterValue, selectedFilterOperation) => {
887
+ return [
888
+ [column.name, selectedFilterOperation, filterValue],
889
+ 'or',
890
+ ['__' + field.name + '\u0001Role_name', selectedFilterOperation, filterValue]
891
+ ];
892
+ };
893
+ break;
894
+ case 'CUSTOM':
895
+ column.lookup = {
896
+ dataSource: '',
897
+ valueExpr: 'store',
898
+ displayExpr: 'display'
899
+ };
900
+ break;
901
+ }
902
+ break;
903
+ case 'TEXT':
904
+ column.cellTemplate = 'textCellTemplate';
905
+ break;
906
+ }
840
907
  }
841
- else if (column.type === 'RELATION') {
908
+ else if (field.type === 'RELATION') {
842
909
  this.columns.push({
843
- dataField: column.name,
844
- caption: column.caption,
910
+ dataField: field.name,
911
+ caption: field.caption,
845
912
  dataType: 'string',
846
913
  alignment: 'left',
847
- filterOperations: ['=']
914
+ filterOperations: ['='],
915
+ visible: field.visible
848
916
  });
849
917
  }
850
918
  }
919
+ if (this.customColumnFn) {
920
+ this.customColumnFn(this.columns);
921
+ }
851
922
  });
852
923
  this.dataSource = new CustomStore({
853
924
  key: 'oid',
@@ -908,12 +979,17 @@ class DataGridComponent {
908
979
  return this.dxDataGrid.instance.getSelectedRowKeys();
909
980
  }
910
981
  }
911
- DataGridComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DataGridComponent, deps: [{ token: DataGridService }], target: i0.ɵɵFactoryTarget.Component });
912
- 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: i1.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$1.DxTemplateDirective, selector: "[dxTemplate]", inputs: ["dxTemplateOf"] }] });
982
+ DataGridComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DataGridComponent, deps: [{ token: DataGridService }, { token: LOCALE_ID }], target: i0.ɵɵFactoryTarget.Component });
983
+ 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: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.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$1.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"] }] });
913
984
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DataGridComponent, decorators: [{
914
985
  type: Component,
915
- 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"] }]
916
- }], ctorParameters: function () { return [{ type: DataGridService }]; }, propDecorators: { tenant: [{
986
+ 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"] }]
987
+ }], ctorParameters: function () {
988
+ return [{ type: DataGridService }, { type: undefined, decorators: [{
989
+ type: Inject,
990
+ args: [LOCALE_ID]
991
+ }] }];
992
+ }, propDecorators: { tenant: [{
917
993
  type: Input
918
994
  }], className: [{
919
995
  type: Input
@@ -923,6 +999,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
923
999
  type: Input
924
1000
  }], enableMasterDetail: [{
925
1001
  type: Input
1002
+ }], customColumnFn: [{
1003
+ type: Input
926
1004
  }], dxDataGrid: [{
927
1005
  type: ViewChild,
928
1006
  args: [DxDataGridComponent, { static: true }]
@@ -936,10 +1014,12 @@ class DataGridModule {
936
1014
  DataGridModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DataGridModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
937
1015
  DataGridModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.7", ngImport: i0, type: DataGridModule, declarations: [DataGridComponent,
938
1016
  MasterDetailTemplateDirective], imports: [CommonModule,
939
- DxDataGridModule], exports: [DataGridComponent,
1017
+ DxDataGridModule,
1018
+ DevUIModule], exports: [DataGridComponent,
940
1019
  MasterDetailTemplateDirective] });
941
1020
  DataGridModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DataGridModule, imports: [CommonModule,
942
- DxDataGridModule] });
1021
+ DxDataGridModule,
1022
+ DevUIModule] });
943
1023
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImport: i0, type: DataGridModule, decorators: [{
944
1024
  type: NgModule,
945
1025
  args: [{
@@ -949,7 +1029,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
949
1029
  ],
950
1030
  imports: [
951
1031
  CommonModule,
952
- DxDataGridModule
1032
+ DxDataGridModule,
1033
+ DevUIModule
953
1034
  ],
954
1035
  exports: [
955
1036
  DataGridComponent,
@@ -1170,9 +1251,8 @@ class ModalComponent {
1170
1251
  }
1171
1252
  show() {
1172
1253
  // 若存在多层模态框,仅保留最上层遮罩颜色,下层遮罩设置为透明
1173
- const parentElement = this.elementRef.nativeElement.parentElement;
1174
1254
  const nodeName = this.elementRef.nativeElement.nodeName;
1175
- const modals = parentElement.querySelectorAll(nodeName);
1255
+ const modals = this._parentViewContainerRef.element.nativeElement.querySelectorAll(nodeName);
1176
1256
  for (let i = 0; i < modals.length; i++) {
1177
1257
  if (i === modals.length - 1) {
1178
1258
  modals[i].querySelector('.modal-backdrop').style.backgroundColor = 'rgba(37, 43, 58, 0.05)';
@@ -1187,9 +1267,8 @@ class ModalComponent {
1187
1267
  }
1188
1268
  ngOnDestroy() {
1189
1269
  // 若存在多层模态框,下一层遮罩设置为不透明
1190
- const parentElement = this.elementRef.nativeElement.parentElement;
1191
1270
  const nodeName = this.elementRef.nativeElement.nodeName;
1192
- const nextModal = parentElement.querySelector(nodeName + ':nth-last-child(2)');
1271
+ const nextModal = this._parentViewContainerRef.element.nativeElement.querySelector(nodeName + ':nth-last-child(2)');
1193
1272
  if (nextModal) {
1194
1273
  nextModal.querySelector('.modal-backdrop').style.backgroundColor = 'rgba(37, 43, 58, 0.05)';
1195
1274
  }
@@ -1324,6 +1403,7 @@ class ModalService {
1324
1403
  };
1325
1404
  modalRef.instance.title = title;
1326
1405
  modalRef.instance.size = size;
1406
+ modalRef.instance._parentViewContainerRef = viewContainerRef;
1327
1407
  modalRef.instance.contentTemplate = contentTemplate;
1328
1408
  modalRef.instance.contentTemplateContext = contentTemplateContext;
1329
1409
  modalRef.instance.footerTemplate = footerTemplate;