ngx-rs-ant 2.2.3 → 2.2.4
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.
|
@@ -50,11 +50,15 @@ export class ModalComponent {
|
|
|
50
50
|
modals[i].querySelector('.modal-backdrop').style.backgroundColor = 'rgba(37, 43, 58, 0)';
|
|
51
51
|
}
|
|
52
52
|
}
|
|
53
|
+
this.elementRef.nativeElement.style.display = 'block';
|
|
53
54
|
}
|
|
54
55
|
hide() {
|
|
55
56
|
// 在service中重写
|
|
56
57
|
this.onHide.emit();
|
|
57
58
|
}
|
|
59
|
+
onlyHide() {
|
|
60
|
+
this.elementRef.nativeElement.style.display = 'none';
|
|
61
|
+
}
|
|
58
62
|
ngOnDestroy() {
|
|
59
63
|
// 若存在多层模态框,下一层遮罩设置为不透明
|
|
60
64
|
const nodeName = this.elementRef.nativeElement.nodeName;
|
|
@@ -149,4 +153,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
149
153
|
type: HostListener,
|
|
150
154
|
args: ['window:resize', ['$event']]
|
|
151
155
|
}] } });
|
|
152
|
-
//# 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  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\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  title!: string;\r\n  size: 'default' | 'large' | 'full' | string = 'default';\r\n  _width: string = '480px';\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  contentTemplate!: TemplateRef<any>;\r\n  contentTemplateContext: any;\r\n  footerTemplate?: TemplateRef<any>;\r\n  footerTemplateContext: any;\r\n  _parentViewContainerRef: any;\r\n  @Output()\r\n  onHide = new EventEmitter();\r\n\r\n  constructor(private elementRef: ElementRef) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.size === 'full') {\r\n      this.modalElementRef.nativeElement.style.top = '1px';\r\n      this.modalElementRef.nativeElement.style.right = '1px';\r\n      this.modalElementRef.nativeElement.style.bottom = '1px';\r\n      this.modalElementRef.nativeElement.style.left = '1px';\r\n      this.modalElementRef.nativeElement.style.margin = '0';\r\n      this.modalElementRef.nativeElement.style.boxShadow = 'none';\r\n    } else {\r\n      if (this.size === 'default') {\r\n        this._width = '480px';\r\n      } else if (this.size === 'large') {\r\n        this._width = '960px';\r\n      } else {\r\n        this._width = this.size;\r\n      }\r\n      this.modalElementRef.nativeElement.style.width = this._width;\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.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    this.onHide.emit();\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.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  resolveModalPosition() {\r\n    if (this.size === 'full') {\r\n      return {};\r\n    }\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 - 1;\r\n    currentTop = currentTop > maxTop ? maxTop : currentTop;\r\n    currentLeft = currentLeft < 0 ? 0 : currentLeft;\r\n    const maxLeft = element.parentElement.offsetWidth - element.offsetWidth - 1;\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    if (this.size === 'full') {\r\n      return;\r\n    }\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  }\r\n}\r\n","<div class=\"modal-backdrop\">\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=\"coast-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"]}
|
|
156
|
+
//# 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  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\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  title!: string;\r\n  size: 'default' | 'large' | 'full' | string = 'default';\r\n  _width: string = '480px';\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  contentTemplate!: TemplateRef<any>;\r\n  contentTemplateContext: any;\r\n  footerTemplate?: TemplateRef<any>;\r\n  footerTemplateContext: any;\r\n  _parentViewContainerRef: any;\r\n  @Output()\r\n  onHide = new EventEmitter();\r\n\r\n  constructor(private elementRef: ElementRef) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.size === 'full') {\r\n      this.modalElementRef.nativeElement.style.top = '1px';\r\n      this.modalElementRef.nativeElement.style.right = '1px';\r\n      this.modalElementRef.nativeElement.style.bottom = '1px';\r\n      this.modalElementRef.nativeElement.style.left = '1px';\r\n      this.modalElementRef.nativeElement.style.margin = '0';\r\n      this.modalElementRef.nativeElement.style.boxShadow = 'none';\r\n    } else {\r\n      if (this.size === 'default') {\r\n        this._width = '480px';\r\n      } else if (this.size === 'large') {\r\n        this._width = '960px';\r\n      } else {\r\n        this._width = this.size;\r\n      }\r\n      this.modalElementRef.nativeElement.style.width = this._width;\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.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    this.elementRef.nativeElement.style.display = 'block';\r\n  }\r\n\r\n  hide() {\r\n    // 在service中重写\r\n    this.onHide.emit();\r\n  }\r\n\r\n  onlyHide() {\r\n    this.elementRef.nativeElement.style.display = 'none';\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.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  resolveModalPosition() {\r\n    if (this.size === 'full') {\r\n      return {};\r\n    }\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 - 1;\r\n    currentTop = currentTop > maxTop ? maxTop : currentTop;\r\n    currentLeft = currentLeft < 0 ? 0 : currentLeft;\r\n    const maxLeft = element.parentElement.offsetWidth - element.offsetWidth - 1;\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    if (this.size === 'full') {\r\n      return;\r\n    }\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  }\r\n}\r\n","<div class=\"modal-backdrop\">\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=\"coast-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"]}
|
package/fesm2015/ngx-rs-ant.mjs
CHANGED
|
@@ -3703,11 +3703,15 @@ class ModalComponent {
|
|
|
3703
3703
|
modals[i].querySelector('.modal-backdrop').style.backgroundColor = 'rgba(37, 43, 58, 0)';
|
|
3704
3704
|
}
|
|
3705
3705
|
}
|
|
3706
|
+
this.elementRef.nativeElement.style.display = 'block';
|
|
3706
3707
|
}
|
|
3707
3708
|
hide() {
|
|
3708
3709
|
// 在service中重写
|
|
3709
3710
|
this.onHide.emit();
|
|
3710
3711
|
}
|
|
3712
|
+
onlyHide() {
|
|
3713
|
+
this.elementRef.nativeElement.style.display = 'none';
|
|
3714
|
+
}
|
|
3711
3715
|
ngOnDestroy() {
|
|
3712
3716
|
// 若存在多层模态框,下一层遮罩设置为不透明
|
|
3713
3717
|
const nodeName = this.elementRef.nativeElement.nodeName;
|