@alauda/ui 7.3.3-beta.34 → 7.3.3-beta.36

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.
@@ -31,6 +31,8 @@ export class TableColumnResizableDirective {
31
31
  this.stylesRenderer.cleanup();
32
32
  }
33
33
  bindResizable(resizeHandle) {
34
+ const mouseUp$ = fromEvent(document, 'mouseup').pipe(take(1));
35
+ const mouseMove$ = fromEvent(document, 'mousemove').pipe(takeUntil(mouseUp$));
34
36
  this.resizeSubscription = fromEvent(resizeHandle, 'mousedown')
35
37
  .pipe(switchMap(mouseDownEvent => {
36
38
  mouseDownEvent.preventDefault();
@@ -42,8 +44,6 @@ export class TableColumnResizableDirective {
42
44
  const columnOffset = this.getColumnOffset();
43
45
  const resizeMarkLine = this.createResizeMarkLine(columnOffset + columnWidth);
44
46
  const resizeOverlay = this.createResizeOverlay();
45
- const mouseUp$ = fromEvent(document, 'mouseup').pipe(take(1));
46
- const mouseMove$ = fromEvent(document, 'mousemove').pipe(takeUntil(mouseUp$));
47
47
  return merge(mouseMove$.pipe(map(mouseMoveEvent => () => resizeMarkLine.updateOffset(columnOffset +
48
48
  this.getWidthInRange(resizeRange, columnWidth + mouseMoveEvent.clientX - initialMouseX)))), mouseUp$.pipe(map(mouseUpEvent => () => {
49
49
  this.renderer2.removeStyle(resizeHandle, 'visibility');
@@ -146,4 +146,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
146
146
  }], maxWidth: [{
147
147
  type: Input
148
148
  }] } });
149
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-column-resizable.directive.js","sourceRoot":"","sources":["../../../src/table/table-column-resizable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n} from '@angular/core';\nimport {\n  fromEvent,\n  map,\n  merge,\n  Subscription,\n  switchMap,\n  take,\n  takeUntil,\n} from 'rxjs';\n\nimport { buildBem, getCompatibleStylesRenderer } from '../utils';\n\nimport { TableColumnDefDirective } from './table-column-def.directive';\nimport { tableBem, TableComponent } from './table.component';\n\nlet tableColumnResizableID = 0;\n\nconst resizableBem = buildBem('aui-table-column-resizable');\nconst markLineWidth = 1;\n\n@Directive({\n  selector: '[auiTableColumnResizable]',\n  standalone: true,\n})\nexport class TableColumnResizableDirective\n  implements OnInit, AfterViewInit, OnDestroy\n{\n  @Input()\n  minWidth = '40px';\n\n  @Input()\n  maxWidth = '80%';\n\n  private readonly renderer2 = inject(Renderer2);\n  private readonly tableColumnDefDirective = inject(TableColumnDefDirective);\n  private readonly tableComponent = inject(TableComponent);\n\n  private readonly columnElement: HTMLElement =\n    inject(ElementRef).nativeElement;\n\n  private readonly containerElement: HTMLElement =\n    this.tableComponent.elementRef.nativeElement;\n\n  private readonly hostAttr = `table-column-resizable-${tableColumnResizableID++}`;\n  private readonly stylesRenderer = getCompatibleStylesRenderer();\n  private resizeSubscription: Subscription;\n\n  ngOnInit() {\n    this.containerElement.setAttribute(this.hostAttr, '');\n  }\n\n  ngAfterViewInit() {\n    const resizeHandle = this.createResizeHandle();\n    this.bindResizable(resizeHandle);\n  }\n\n  ngOnDestroy() {\n    this.resizeSubscription?.unsubscribe();\n    this.containerElement.removeAttribute(this.hostAttr);\n    this.stylesRenderer.cleanup();\n  }\n\n  private bindResizable(resizeHandle: HTMLElement) {\n    this.resizeSubscription = fromEvent<MouseEvent>(resizeHandle, 'mousedown')\n      .pipe(\n        switchMap(mouseDownEvent => {\n          mouseDownEvent.preventDefault();\n          mouseDownEvent.stopPropagation();\n\n          this.renderer2.setStyle(resizeHandle, 'visibility', 'hidden');\n          const resizeRange = this.getResizeRange();\n          const initialMouseX = mouseDownEvent.clientX;\n          const columnWidth = this.getColumnWidth();\n          const columnOffset = this.getColumnOffset();\n          const resizeMarkLine = this.createResizeMarkLine(\n            columnOffset + columnWidth,\n          );\n          const resizeOverlay = this.createResizeOverlay();\n\n          const mouseUp$ = fromEvent<MouseEvent>(document, 'mouseup').pipe(\n            take(1),\n          );\n          const mouseMove$ = fromEvent<MouseEvent>(document, 'mousemove').pipe(\n            takeUntil(mouseUp$),\n          );\n\n          return merge(\n            mouseMove$.pipe(\n              map(\n                mouseMoveEvent => () =>\n                  resizeMarkLine.updateOffset(\n                    columnOffset +\n                      this.getWidthInRange(\n                        resizeRange,\n                        columnWidth + mouseMoveEvent.clientX - initialMouseX,\n                      ),\n                  ),\n              ),\n            ),\n            mouseUp$.pipe(\n              map(mouseUpEvent => () => {\n                this.renderer2.removeStyle(resizeHandle, 'visibility');\n                resizeMarkLine.destroy();\n                resizeOverlay.destroy();\n\n                this.renderWidthStyles(\n                  this.getWidthInRange(\n                    resizeRange,\n                    columnWidth + mouseUpEvent.clientX - initialMouseX,\n                  ),\n                );\n              }),\n            ),\n          );\n        }),\n      )\n      .subscribe(exec => {\n        exec();\n      });\n  }\n\n  private createResizeHandle() {\n    const resizeHandle: HTMLDivElement = this.renderer2.createElement('div');\n    this.renderer2.addClass(resizeHandle, resizableBem.element('handle'));\n    this.renderer2.appendChild(this.columnElement, resizeHandle);\n\n    return resizeHandle;\n  }\n\n  private createResizeMarkLine(initialOffset: number) {\n    const markLine: HTMLElement = this.renderer2.createElement('div');\n    this.renderer2.addClass(markLine, resizableBem.element('mark-line'));\n    this.renderer2.setStyle(\n      markLine,\n      'left',\n      initialOffset - markLineWidth + 'px',\n    );\n    if (this.isStickyLeftBorderColumn()) {\n      this.renderer2.addClass(markLine, 'inStickyBorderElemLeft');\n    }\n    this.renderer2.appendChild(this.containerElement, markLine);\n    return {\n      element: markLine,\n      updateOffset: (offset: number) => {\n        this.renderer2.setStyle(\n          markLine,\n          'left',\n          offset - markLineWidth + 'px',\n        );\n      },\n      destroy: () => {\n        this.renderer2.removeChild(this.containerElement, markLine);\n      },\n    };\n  }\n\n  private createResizeOverlay() {\n    const resizeOverlay = this.renderer2.createElement('div');\n    this.renderer2.addClass(resizeOverlay, resizableBem.element('overlay'));\n    this.renderer2.appendChild(this.containerElement, resizeOverlay);\n    return {\n      element: resizeOverlay,\n      destroy: () => {\n        this.renderer2.removeChild(this.containerElement, resizeOverlay);\n      },\n    };\n  }\n\n  private getColumnWidth() {\n    return this.columnElement.clientWidth;\n  }\n\n  private getColumnOffset() {\n    return (\n      this.columnElement.getBoundingClientRect().left -\n      this.containerElement.getBoundingClientRect().left\n    );\n  }\n\n  private getWidthInRange(\n    [minWidth, maxWidth]: [number, number],\n    width: number,\n  ): number {\n    return Math.min(Math.max(width, minWidth), maxWidth);\n  }\n\n  private getResizeRange(): [number, number] {\n    const minWidth = this.getActualWidth(this.minWidth);\n    const maxWidth = this.getActualWidth(this.maxWidth);\n    return [minWidth, maxWidth];\n  }\n\n  private getActualWidth(width: number | string): number {\n    if (typeof width === 'number') {\n      return width;\n    }\n    if (width.endsWith('%')) {\n      return (\n        (this.containerElement.clientWidth * parseInt(width.slice(0, -1))) / 100\n      );\n    }\n    if (width.endsWith('px')) {\n      return parseInt(width.slice(0, -2));\n    }\n    return parseInt(width);\n  }\n\n  private isStickyLeftBorderColumn() {\n    return this.columnElement.classList.contains(\n      'aui-table-sticky-border-elem-left',\n    );\n  }\n\n  private renderWidthStyles(width: number) {\n    const className = tableBem.element(\n      `column-${this.tableColumnDefDirective.cssClassFriendlyName}`,\n    );\n\n    const styleString = `[${this.hostAttr}] .${className} {\n      flex: none !important;\n      width: ${width}px !important;\n      min-width: ${width}px !important;\n      max-width: ${width}px !important;\n    }`;\n\n    this.stylesRenderer.render(styleString);\n    this.tableComponent.updateStickyColumnStyles();\n  }\n}\n"]}
149
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-column-resizable.directive.js","sourceRoot":"","sources":["../../../src/table/table-column-resizable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n} from '@angular/core';\nimport {\n  fromEvent,\n  map,\n  merge,\n  Subscription,\n  switchMap,\n  take,\n  takeUntil,\n} from 'rxjs';\n\nimport { buildBem, getCompatibleStylesRenderer } from '../utils';\n\nimport { TableColumnDefDirective } from './table-column-def.directive';\nimport { tableBem, TableComponent } from './table.component';\n\nlet tableColumnResizableID = 0;\n\nconst resizableBem = buildBem('aui-table-column-resizable');\nconst markLineWidth = 1;\n\n@Directive({\n  selector: '[auiTableColumnResizable]',\n  standalone: true,\n})\nexport class TableColumnResizableDirective\n  implements OnInit, AfterViewInit, OnDestroy\n{\n  @Input()\n  minWidth = '40px';\n\n  @Input()\n  maxWidth = '80%';\n\n  private readonly renderer2 = inject(Renderer2);\n  private readonly tableColumnDefDirective = inject(TableColumnDefDirective);\n  private readonly tableComponent = inject(TableComponent);\n\n  private readonly columnElement: HTMLElement =\n    inject(ElementRef).nativeElement;\n\n  private readonly containerElement: HTMLElement =\n    this.tableComponent.elementRef.nativeElement;\n\n  private readonly hostAttr = `table-column-resizable-${tableColumnResizableID++}`;\n  private readonly stylesRenderer = getCompatibleStylesRenderer();\n  private resizeSubscription: Subscription;\n\n  ngOnInit() {\n    this.containerElement.setAttribute(this.hostAttr, '');\n  }\n\n  ngAfterViewInit() {\n    const resizeHandle = this.createResizeHandle();\n    this.bindResizable(resizeHandle);\n  }\n\n  ngOnDestroy() {\n    this.resizeSubscription?.unsubscribe();\n    this.containerElement.removeAttribute(this.hostAttr);\n    this.stylesRenderer.cleanup();\n  }\n\n  private bindResizable(resizeHandle: HTMLElement) {\n    const mouseUp$ = fromEvent<MouseEvent>(document, 'mouseup').pipe(take(1));\n\n    const mouseMove$ = fromEvent<MouseEvent>(document, 'mousemove').pipe(\n      takeUntil(mouseUp$),\n    );\n\n    this.resizeSubscription = fromEvent<MouseEvent>(resizeHandle, 'mousedown')\n      .pipe(\n        switchMap(mouseDownEvent => {\n          mouseDownEvent.preventDefault();\n          mouseDownEvent.stopPropagation();\n\n          this.renderer2.setStyle(resizeHandle, 'visibility', 'hidden');\n          const resizeRange = this.getResizeRange();\n          const initialMouseX = mouseDownEvent.clientX;\n          const columnWidth = this.getColumnWidth();\n          const columnOffset = this.getColumnOffset();\n          const resizeMarkLine = this.createResizeMarkLine(\n            columnOffset + columnWidth,\n          );\n          const resizeOverlay = this.createResizeOverlay();\n\n          return merge(\n            mouseMove$.pipe(\n              map(\n                mouseMoveEvent => () =>\n                  resizeMarkLine.updateOffset(\n                    columnOffset +\n                      this.getWidthInRange(\n                        resizeRange,\n                        columnWidth + mouseMoveEvent.clientX - initialMouseX,\n                      ),\n                  ),\n              ),\n            ),\n            mouseUp$.pipe(\n              map(mouseUpEvent => () => {\n                this.renderer2.removeStyle(resizeHandle, 'visibility');\n                resizeMarkLine.destroy();\n                resizeOverlay.destroy();\n\n                this.renderWidthStyles(\n                  this.getWidthInRange(\n                    resizeRange,\n                    columnWidth + mouseUpEvent.clientX - initialMouseX,\n                  ),\n                );\n              }),\n            ),\n          );\n        }),\n      )\n      .subscribe(exec => {\n        exec();\n      });\n  }\n\n  private createResizeHandle() {\n    const resizeHandle: HTMLDivElement = this.renderer2.createElement('div');\n    this.renderer2.addClass(resizeHandle, resizableBem.element('handle'));\n    this.renderer2.appendChild(this.columnElement, resizeHandle);\n\n    return resizeHandle;\n  }\n\n  private createResizeMarkLine(initialOffset: number) {\n    const markLine: HTMLElement = this.renderer2.createElement('div');\n    this.renderer2.addClass(markLine, resizableBem.element('mark-line'));\n    this.renderer2.setStyle(\n      markLine,\n      'left',\n      initialOffset - markLineWidth + 'px',\n    );\n    if (this.isStickyLeftBorderColumn()) {\n      this.renderer2.addClass(markLine, 'inStickyBorderElemLeft');\n    }\n    this.renderer2.appendChild(this.containerElement, markLine);\n    return {\n      element: markLine,\n      updateOffset: (offset: number) => {\n        this.renderer2.setStyle(\n          markLine,\n          'left',\n          offset - markLineWidth + 'px',\n        );\n      },\n      destroy: () => {\n        this.renderer2.removeChild(this.containerElement, markLine);\n      },\n    };\n  }\n\n  private createResizeOverlay() {\n    const resizeOverlay = this.renderer2.createElement('div');\n    this.renderer2.addClass(resizeOverlay, resizableBem.element('overlay'));\n    this.renderer2.appendChild(this.containerElement, resizeOverlay);\n    return {\n      element: resizeOverlay,\n      destroy: () => {\n        this.renderer2.removeChild(this.containerElement, resizeOverlay);\n      },\n    };\n  }\n\n  private getColumnWidth() {\n    return this.columnElement.clientWidth;\n  }\n\n  private getColumnOffset() {\n    return (\n      this.columnElement.getBoundingClientRect().left -\n      this.containerElement.getBoundingClientRect().left\n    );\n  }\n\n  private getWidthInRange(\n    [minWidth, maxWidth]: [number, number],\n    width: number,\n  ): number {\n    return Math.min(Math.max(width, minWidth), maxWidth);\n  }\n\n  private getResizeRange(): [number, number] {\n    const minWidth = this.getActualWidth(this.minWidth);\n    const maxWidth = this.getActualWidth(this.maxWidth);\n    return [minWidth, maxWidth];\n  }\n\n  private getActualWidth(width: number | string): number {\n    if (typeof width === 'number') {\n      return width;\n    }\n    if (width.endsWith('%')) {\n      return (\n        (this.containerElement.clientWidth * parseInt(width.slice(0, -1))) / 100\n      );\n    }\n    if (width.endsWith('px')) {\n      return parseInt(width.slice(0, -2));\n    }\n    return parseInt(width);\n  }\n\n  private isStickyLeftBorderColumn() {\n    return this.columnElement.classList.contains(\n      'aui-table-sticky-border-elem-left',\n    );\n  }\n\n  private renderWidthStyles(width: number) {\n    const className = tableBem.element(\n      `column-${this.tableColumnDefDirective.cssClassFriendlyName}`,\n    );\n\n    const styleString = `[${this.hostAttr}] .${className} {\n      flex: none !important;\n      width: ${width}px !important;\n      min-width: ${width}px !important;\n      max-width: ${width}px !important;\n    }`;\n\n    this.stylesRenderer.render(styleString);\n    this.tableComponent.updateStickyColumnStyles();\n  }\n}\n"]}
@@ -5,6 +5,6 @@ export * from './fn';
5
5
  export * from './observe-dom';
6
6
  export * from './operators';
7
7
  export * from './scroll-into-view';
8
- export * from './styles-render';
8
+ export * from './styles-renderer';
9
9
  export * from './watch-content-exist';
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdXRpbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxPQUFPLENBQUM7QUFDdEIsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxNQUFNLENBQUM7QUFDckIsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsdUJBQXVCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2FzeW5jJztcbmV4cG9ydCAqIGZyb20gJy4vYmVtJztcbmV4cG9ydCAqIGZyb20gJy4vY29lcmNpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9mbic7XG5leHBvcnQgKiBmcm9tICcuL29ic2VydmUtZG9tJztcbmV4cG9ydCAqIGZyb20gJy4vb3BlcmF0b3JzJztcbmV4cG9ydCAqIGZyb20gJy4vc2Nyb2xsLWludG8tdmlldyc7XG5leHBvcnQgKiBmcm9tICcuL3N0eWxlcy1yZW5kZXInO1xuZXhwb3J0ICogZnJvbSAnLi93YXRjaC1jb250ZW50LWV4aXN0JztcbiJdfQ==
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdXRpbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxPQUFPLENBQUM7QUFDdEIsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxNQUFNLENBQUM7QUFDckIsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsdUJBQXVCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2FzeW5jJztcbmV4cG9ydCAqIGZyb20gJy4vYmVtJztcbmV4cG9ydCAqIGZyb20gJy4vY29lcmNpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9mbic7XG5leHBvcnQgKiBmcm9tICcuL29ic2VydmUtZG9tJztcbmV4cG9ydCAqIGZyb20gJy4vb3BlcmF0b3JzJztcbmV4cG9ydCAqIGZyb20gJy4vc2Nyb2xsLWludG8tdmlldyc7XG5leHBvcnQgKiBmcm9tICcuL3N0eWxlcy1yZW5kZXJlcic7XG5leHBvcnQgKiBmcm9tICcuL3dhdGNoLWNvbnRlbnQtZXhpc3QnO1xuIl19
@@ -0,0 +1,43 @@
1
+ export function getCompatibleStylesRenderer() {
2
+ if ('CSSStyleSheet' in self && 'adoptedStyleSheets' in document) {
3
+ return new CSSStyleSheetRenderer();
4
+ }
5
+ return new StylesRenderer();
6
+ }
7
+ export class StylesRenderer {
8
+ styleElement;
9
+ render(styles) {
10
+ if (!this.styleElement) {
11
+ this.styleElement = document.createElement('style');
12
+ document.head.append(this.styleElement);
13
+ }
14
+ this.styleElement.innerHTML = styles;
15
+ }
16
+ cleanup() {
17
+ this.styleElement?.remove();
18
+ }
19
+ }
20
+ export class CSSStyleSheetRenderer {
21
+ options;
22
+ styleSheet;
23
+ constructor(options) {
24
+ this.options = options;
25
+ }
26
+ render(styles) {
27
+ if (!this.styleSheet) {
28
+ this.styleSheet = new CSSStyleSheet(this.options);
29
+ document.adoptedStyleSheets.push(this.styleSheet);
30
+ }
31
+ this.styleSheet.replaceSync(styles);
32
+ }
33
+ cleanup() {
34
+ if (!this.styleSheet) {
35
+ return;
36
+ }
37
+ const i = document.adoptedStyleSheets.indexOf(this.styleSheet);
38
+ if (i >= 0) {
39
+ document.adoptedStyleSheets.splice(i, 1);
40
+ }
41
+ }
42
+ }
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3R5bGVzLXJlbmRlcmVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3V0aWxzL3N0eWxlcy1yZW5kZXJlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLFVBQVUsMkJBQTJCO0lBQ3pDLElBQUksZUFBZSxJQUFJLElBQUksSUFBSSxvQkFBb0IsSUFBSSxRQUFRLEVBQUU7UUFDL0QsT0FBTyxJQUFJLHFCQUFxQixFQUFFLENBQUM7S0FDcEM7SUFDRCxPQUFPLElBQUksY0FBYyxFQUFFLENBQUM7QUFDOUIsQ0FBQztBQUVELE1BQU0sT0FBTyxjQUFjO0lBQ2pCLFlBQVksQ0FBbUI7SUFFdkMsTUFBTSxDQUFDLE1BQWM7UUFDbkIsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDdEIsSUFBSSxDQUFDLFlBQVksR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQ3BELFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztTQUN6QztRQUNELElBQUksQ0FBQyxZQUFZLENBQUMsU0FBUyxHQUFHLE1BQU0sQ0FBQztJQUN2QyxDQUFDO0lBRUQsT0FBTztRQUNMLElBQUksQ0FBQyxZQUFZLEVBQUUsTUFBTSxFQUFFLENBQUM7SUFDOUIsQ0FBQztDQUNGO0FBRUQsTUFBTSxPQUFPLHFCQUFxQjtJQUdIO0lBRnJCLFVBQVUsQ0FBZ0I7SUFFbEMsWUFBNkIsT0FBMkI7UUFBM0IsWUFBTyxHQUFQLE9BQU8sQ0FBb0I7SUFBRyxDQUFDO0lBRTVELE1BQU0sQ0FBQyxNQUFjO1FBQ25CLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFO1lBQ3BCLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxhQUFhLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQ2xELFFBQVEsQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1NBQ25EO1FBQ0QsSUFBSSxDQUFDLFVBQVUsQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDdEMsQ0FBQztJQUVELE9BQU87UUFDTCxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRTtZQUNwQixPQUFPO1NBQ1I7UUFFRCxNQUFNLENBQUMsR0FBRyxRQUFRLENBQUMsa0JBQWtCLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUMvRCxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDVixRQUFRLENBQUMsa0JBQWtCLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztTQUMxQztJQUNILENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBmdW5jdGlvbiBnZXRDb21wYXRpYmxlU3R5bGVzUmVuZGVyZXIoKSB7XG4gIGlmICgnQ1NTU3R5bGVTaGVldCcgaW4gc2VsZiAmJiAnYWRvcHRlZFN0eWxlU2hlZXRzJyBpbiBkb2N1bWVudCkge1xuICAgIHJldHVybiBuZXcgQ1NTU3R5bGVTaGVldFJlbmRlcmVyKCk7XG4gIH1cbiAgcmV0dXJuIG5ldyBTdHlsZXNSZW5kZXJlcigpO1xufVxuXG5leHBvcnQgY2xhc3MgU3R5bGVzUmVuZGVyZXIgaW1wbGVtZW50cyBSZW5kZXJlciB7XG4gIHByaXZhdGUgc3R5bGVFbGVtZW50OiBIVE1MU3R5bGVFbGVtZW50O1xuXG4gIHJlbmRlcihzdHlsZXM6IHN0cmluZyk6IHZvaWQge1xuICAgIGlmICghdGhpcy5zdHlsZUVsZW1lbnQpIHtcbiAgICAgIHRoaXMuc3R5bGVFbGVtZW50ID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnc3R5bGUnKTtcbiAgICAgIGRvY3VtZW50LmhlYWQuYXBwZW5kKHRoaXMuc3R5bGVFbGVtZW50KTtcbiAgICB9XG4gICAgdGhpcy5zdHlsZUVsZW1lbnQuaW5uZXJIVE1MID0gc3R5bGVzO1xuICB9XG5cbiAgY2xlYW51cCgpOiB2b2lkIHtcbiAgICB0aGlzLnN0eWxlRWxlbWVudD8ucmVtb3ZlKCk7XG4gIH1cbn1cblxuZXhwb3J0IGNsYXNzIENTU1N0eWxlU2hlZXRSZW5kZXJlciBpbXBsZW1lbnRzIFJlbmRlcmVyIHtcbiAgcHJpdmF0ZSBzdHlsZVNoZWV0OiBDU1NTdHlsZVNoZWV0O1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgb3B0aW9ucz86IENTU1N0eWxlU2hlZXRJbml0KSB7fVxuXG4gIHJlbmRlcihzdHlsZXM6IHN0cmluZyk6IHZvaWQge1xuICAgIGlmICghdGhpcy5zdHlsZVNoZWV0KSB7XG4gICAgICB0aGlzLnN0eWxlU2hlZXQgPSBuZXcgQ1NTU3R5bGVTaGVldCh0aGlzLm9wdGlvbnMpO1xuICAgICAgZG9jdW1lbnQuYWRvcHRlZFN0eWxlU2hlZXRzLnB1c2godGhpcy5zdHlsZVNoZWV0KTtcbiAgICB9XG4gICAgdGhpcy5zdHlsZVNoZWV0LnJlcGxhY2VTeW5jKHN0eWxlcyk7XG4gIH1cblxuICBjbGVhbnVwKCk6IHZvaWQge1xuICAgIGlmICghdGhpcy5zdHlsZVNoZWV0KSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgY29uc3QgaSA9IGRvY3VtZW50LmFkb3B0ZWRTdHlsZVNoZWV0cy5pbmRleE9mKHRoaXMuc3R5bGVTaGVldCk7XG4gICAgaWYgKGkgPj0gMCkge1xuICAgICAgZG9jdW1lbnQuYWRvcHRlZFN0eWxlU2hlZXRzLnNwbGljZShpLCAxKTtcbiAgICB9XG4gIH1cbn1cblxuaW50ZXJmYWNlIFJlbmRlcmVyIHtcbiAgcmVuZGVyKHN0eWxlczogc3RyaW5nKTogdm9pZDtcbiAgY2xlYW51cCgpOiB2b2lkO1xufVxuIl19
@@ -332,9 +332,7 @@ class StylesRenderer {
332
332
  this.styleElement.innerHTML = styles;
333
333
  }
334
334
  cleanup() {
335
- if (this.styleElement) {
336
- this.styleElement.remove();
337
- }
335
+ this.styleElement?.remove();
338
336
  }
339
337
  }
340
338
  class CSSStyleSheetRenderer {
@@ -346,16 +344,16 @@ class CSSStyleSheetRenderer {
346
344
  render(styles) {
347
345
  if (!this.styleSheet) {
348
346
  this.styleSheet = new CSSStyleSheet(this.options);
349
- document.adoptedStyleSheets = [
350
- ...document.adoptedStyleSheets,
351
- this.styleSheet,
352
- ];
347
+ document.adoptedStyleSheets.push(this.styleSheet);
353
348
  }
354
349
  this.styleSheet.replaceSync(styles);
355
350
  }
356
351
  cleanup() {
357
- if (this.styleSheet) {
358
- const i = document.adoptedStyleSheets.indexOf(this.styleSheet);
352
+ if (!this.styleSheet) {
353
+ return;
354
+ }
355
+ const i = document.adoptedStyleSheets.indexOf(this.styleSheet);
356
+ if (i >= 0) {
359
357
  document.adoptedStyleSheets.splice(i, 1);
360
358
  }
361
359
  }
@@ -9912,6 +9910,8 @@ class TableColumnResizableDirective {
9912
9910
  this.stylesRenderer.cleanup();
9913
9911
  }
9914
9912
  bindResizable(resizeHandle) {
9913
+ const mouseUp$ = fromEvent(document, 'mouseup').pipe(take(1));
9914
+ const mouseMove$ = fromEvent(document, 'mousemove').pipe(takeUntil(mouseUp$));
9915
9915
  this.resizeSubscription = fromEvent(resizeHandle, 'mousedown')
9916
9916
  .pipe(switchMap(mouseDownEvent => {
9917
9917
  mouseDownEvent.preventDefault();
@@ -9923,8 +9923,6 @@ class TableColumnResizableDirective {
9923
9923
  const columnOffset = this.getColumnOffset();
9924
9924
  const resizeMarkLine = this.createResizeMarkLine(columnOffset + columnWidth);
9925
9925
  const resizeOverlay = this.createResizeOverlay();
9926
- const mouseUp$ = fromEvent(document, 'mouseup').pipe(take(1));
9927
- const mouseMove$ = fromEvent(document, 'mousemove').pipe(takeUntil(mouseUp$));
9928
9926
  return merge$1(mouseMove$.pipe(map(mouseMoveEvent => () => resizeMarkLine.updateOffset(columnOffset +
9929
9927
  this.getWidthInRange(resizeRange, columnWidth + mouseMoveEvent.clientX - initialMouseX)))), mouseUp$.pipe(map(mouseUpEvent => () => {
9930
9928
  this.renderer2.removeStyle(resizeHandle, 'visibility');