@alauda/ui 7.3.3-beta.25 → 7.3.3-beta.27

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,13 +1,13 @@
1
1
  import { Directive, ElementRef, inject, Input, Renderer2, } from '@angular/core';
2
- import { fromEvent, map, merge, Subject, switchMap, take, takeUntil, } from 'rxjs';
2
+ import { fromEvent, map, merge, switchMap, take, takeUntil, } from 'rxjs';
3
3
  import { buildBem } from '../utils';
4
4
  import { tableBem, TableColumnDefDirective, TableComponent, TableScrollWrapperDirective, } from './index';
5
5
  import * as i0 from "@angular/core";
6
- let tableColResizableUid = 0;
6
+ let tableColumnResizableID = 0;
7
7
  const resizableBem = buildBem('aui-table-column-resizable');
8
8
  export class TableColumnResizableDirective {
9
- minWidth = '60px';
10
- maxWidth = '100%';
9
+ minWidth = '40px';
10
+ maxWidth = '80%';
11
11
  renderer2 = inject(Renderer2);
12
12
  tableColumnDefDirective = inject(TableColumnDefDirective);
13
13
  tableComponent = inject(TableComponent);
@@ -16,16 +16,16 @@ export class TableColumnResizableDirective {
16
16
  });
17
17
  selfElement = inject(ElementRef).nativeElement;
18
18
  containerElement = (this.tableScrollWrapperDirective || this.tableComponent).elementRef.nativeElement;
19
- destroy$$ = new Subject();
20
- styleEl;
19
+ styleElement;
21
20
  hostAttr;
21
+ resizeSubscription;
22
22
  ngAfterViewInit() {
23
23
  const resizeHandle = this.createResizeHandle();
24
24
  this.bindResizable(resizeHandle);
25
25
  }
26
26
  ngOnDestroy() {
27
- this.destroy$$.next();
28
- this.destroy$$.complete();
27
+ this.resizeSubscription?.unsubscribe();
28
+ this.styleElement?.remove();
29
29
  }
30
30
  bindResizable(resizeHandle) {
31
31
  fromEvent(resizeHandle, 'mousedown')
@@ -33,6 +33,7 @@ export class TableColumnResizableDirective {
33
33
  mouseDownEvent.preventDefault();
34
34
  mouseDownEvent.stopPropagation();
35
35
  this.renderer2.setStyle(resizeHandle, 'visibility', 'hidden');
36
+ const resizeRange = this.getResizeRange();
36
37
  const initialMouseX = mouseDownEvent.clientX;
37
38
  const columnWidth = this.getColumnWidth();
38
39
  const columnOffset = this.getColumnOffset();
@@ -44,9 +45,9 @@ export class TableColumnResizableDirective {
44
45
  this.renderer2.removeStyle(resizeHandle, 'visibility');
45
46
  resizeMarkLine.destroy();
46
47
  resizeOverlay.destroy();
47
- this.renderWidthStyles(columnWidth + mouseUpEvent.clientX - initialMouseX);
48
+ this.renderWidthStyles(this.getWidthInRange(resizeRange, columnWidth + mouseUpEvent.clientX - initialMouseX));
48
49
  })));
49
- }), takeUntil(this.destroy$$))
50
+ }))
50
51
  .subscribe(exec => {
51
52
  exec();
52
53
  });
@@ -90,10 +91,29 @@ export class TableColumnResizableDirective {
90
91
  return (this.selfElement.getBoundingClientRect().left -
91
92
  this.containerElement.getBoundingClientRect().left);
92
93
  }
94
+ getWidthInRange([minWidth, maxWidth], width) {
95
+ return Math.min(Math.max(width, minWidth), maxWidth);
96
+ }
97
+ getResizeRange() {
98
+ const minWidth = this.getActualWidth(this.minWidth);
99
+ const maxWidth = this.getActualWidth(this.maxWidth);
100
+ return [minWidth, maxWidth];
101
+ }
102
+ getActualWidth(width) {
103
+ if (typeof width === 'number') {
104
+ return width;
105
+ }
106
+ else if (width.endsWith('px')) {
107
+ return parseInt(width.slice(0, -2));
108
+ }
109
+ else if (width.endsWith('%')) {
110
+ return ((this.containerElement.clientWidth * parseInt(width.slice(0, -1))) / 100);
111
+ }
112
+ }
93
113
  renderWidthStyles(width) {
94
114
  const className = tableBem.element(`column-${this.tableColumnDefDirective.cssClassFriendlyName}`);
95
115
  if (!this.hostAttr) {
96
- this.hostAttr = `table-resizable-${tableColResizableUid++}`;
116
+ this.hostAttr = `table-resizable-${tableColumnResizableID++}`;
97
117
  this.containerElement.setAttribute(this.hostAttr, '');
98
118
  }
99
119
  const styleString = `
@@ -104,13 +124,13 @@ export class TableColumnResizableDirective {
104
124
  max-width: ${width}px !important;
105
125
  }
106
126
  `;
107
- if (this.styleEl) {
108
- this.styleEl.innerHTML = styleString;
127
+ if (this.styleElement) {
128
+ this.styleElement.innerHTML = styleString;
109
129
  }
110
130
  else {
111
- this.styleEl = this.renderer2.createElement('style');
112
- this.styleEl.innerHTML = styleString;
113
- this.renderer2.appendChild(this.containerElement, this.styleEl);
131
+ this.styleElement = this.renderer2.createElement('style');
132
+ this.styleElement.innerHTML = styleString;
133
+ this.renderer2.appendChild(document.querySelector('head'), this.styleElement);
114
134
  }
115
135
  this.tableComponent.updateStickyColumnStyles();
116
136
  }
@@ -128,4 +148,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
128
148
  }], maxWidth: [{
129
149
  type: Input
130
150
  }] } });
131
- //# 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  Renderer2,\n} from '@angular/core';\nimport {\n  fromEvent,\n  map,\n  merge,\n  Subject,\n  switchMap,\n  take,\n  takeUntil,\n} from 'rxjs';\n\nimport { buildBem } from '../utils';\n\nimport {\n  tableBem,\n  TableColumnDefDirective,\n  TableComponent,\n  TableScrollWrapperDirective,\n} from './index';\n\nlet tableColResizableUid = 0;\n\nconst resizableBem = buildBem('aui-table-column-resizable');\n\n@Directive({\n  selector: '[auiTableColumnResizable]',\n  standalone: true,\n})\nexport class TableColumnResizableDirective implements AfterViewInit {\n  @Input()\n  minWidth = '60px';\n\n  @Input()\n  maxWidth = '100%';\n\n  private readonly renderer2 = inject(Renderer2);\n  private readonly tableColumnDefDirective = inject(TableColumnDefDirective);\n  private readonly tableComponent = inject(TableComponent);\n  private readonly tableScrollWrapperDirective = inject(\n    TableScrollWrapperDirective,\n    {\n      optional: true,\n    },\n  );\n\n  private readonly selfElement: HTMLElement = inject(ElementRef).nativeElement;\n  private readonly containerElement: HTMLElement = (\n    this.tableScrollWrapperDirective || this.tableComponent\n  ).elementRef.nativeElement;\n\n  private readonly destroy$$ = new Subject<void>();\n\n  private styleEl: HTMLStyleElement;\n  private hostAttr: string;\n\n  ngAfterViewInit() {\n    const resizeHandle = this.createResizeHandle();\n    this.bindResizable(resizeHandle);\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n\n  private bindResizable(resizeHandle: HTMLElement) {\n    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 initialMouseX = mouseDownEvent.clientX;\n          const columnWidth = this.getColumnWidth();\n          const columnOffset = this.getColumnOffset();\n          const resizeMarkLine = this.createResizeMarkLine(\n            columnWidth + columnOffset,\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                    mouseMoveEvent.clientX - initialMouseX,\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                  columnWidth + mouseUpEvent.clientX - initialMouseX,\n                );\n              }),\n            ),\n          );\n        }),\n        takeUntil(this.destroy$$),\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.selfElement, 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(markLine, 'left', initialOffset + 'px');\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          initialOffset + offset + '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.selfElement.clientWidth;\n  }\n\n  private getColumnOffset() {\n    return (\n      this.selfElement.getBoundingClientRect().left -\n      this.containerElement.getBoundingClientRect().left\n    );\n  }\n\n  private renderWidthStyles(width: number) {\n    const className = tableBem.element(\n      `column-${this.tableColumnDefDirective.cssClassFriendlyName}`,\n    );\n    if (!this.hostAttr) {\n      this.hostAttr = `table-resizable-${tableColResizableUid++}`;\n      this.containerElement.setAttribute(this.hostAttr, '');\n    }\n    const styleString = `\n     [${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    if (this.styleEl) {\n      this.styleEl.innerHTML = styleString;\n    } else {\n      this.styleEl = this.renderer2.createElement('style');\n      this.styleEl.innerHTML = styleString;\n      this.renderer2.appendChild(this.containerElement, this.styleEl);\n    }\n\n    this.tableComponent.updateStickyColumnStyles();\n  }\n}\n"]}
151
+ //# 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  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 } from '../utils';\n\nimport {\n  tableBem,\n  TableColumnDefDirective,\n  TableComponent,\n  TableScrollWrapperDirective,\n} from './index';\n\nlet tableColumnResizableID = 0;\n\nconst resizableBem = buildBem('aui-table-column-resizable');\n\n@Directive({\n  selector: '[auiTableColumnResizable]',\n  standalone: true,\n})\nexport class TableColumnResizableDirective implements AfterViewInit {\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  private readonly tableScrollWrapperDirective = inject(\n    TableScrollWrapperDirective,\n    {\n      optional: true,\n    },\n  );\n\n  private readonly selfElement: HTMLElement = inject(ElementRef).nativeElement;\n  private readonly containerElement: HTMLElement = (\n    this.tableScrollWrapperDirective || this.tableComponent\n  ).elementRef.nativeElement;\n\n  private styleElement: HTMLStyleElement;\n  private hostAttr: string;\n  private resizeSubscription: Subscription;\n\n  ngAfterViewInit() {\n    const resizeHandle = this.createResizeHandle();\n    this.bindResizable(resizeHandle);\n  }\n\n  ngOnDestroy() {\n    this.resizeSubscription?.unsubscribe();\n    this.styleElement?.remove();\n  }\n\n  private bindResizable(resizeHandle: HTMLElement) {\n    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            columnWidth + columnOffset,\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                    mouseMoveEvent.clientX - initialMouseX,\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.selfElement, 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(markLine, 'left', initialOffset + 'px');\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          initialOffset + offset + '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.selfElement.clientWidth;\n  }\n\n  private getColumnOffset() {\n    return (\n      this.selfElement.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    } else if (width.endsWith('px')) {\n      return parseInt(width.slice(0, -2));\n    } else if (width.endsWith('%')) {\n      return (\n        (this.containerElement.clientWidth * parseInt(width.slice(0, -1))) / 100\n      );\n    }\n  }\n\n  private renderWidthStyles(width: number) {\n    const className = tableBem.element(\n      `column-${this.tableColumnDefDirective.cssClassFriendlyName}`,\n    );\n    if (!this.hostAttr) {\n      this.hostAttr = `table-resizable-${tableColumnResizableID++}`;\n      this.containerElement.setAttribute(this.hostAttr, '');\n    }\n    const styleString = `\n     [${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    if (this.styleElement) {\n      this.styleElement.innerHTML = styleString;\n    } else {\n      this.styleElement = this.renderer2.createElement('style');\n      this.styleElement.innerHTML = styleString;\n      this.renderer2.appendChild(\n        document.querySelector('head'),\n        this.styleElement,\n      );\n    }\n\n    this.tableComponent.updateStickyColumnStyles();\n  }\n}\n"]}
@@ -10380,11 +10380,11 @@ const TABLE_MODULE = [
10380
10380
  TableScrollWrapperDirective,
10381
10381
  ];
10382
10382
 
10383
- let tableColResizableUid = 0;
10383
+ let tableColumnResizableID = 0;
10384
10384
  const resizableBem = buildBem('aui-table-column-resizable');
10385
10385
  class TableColumnResizableDirective {
10386
- minWidth = '60px';
10387
- maxWidth = '100%';
10386
+ minWidth = '40px';
10387
+ maxWidth = '80%';
10388
10388
  renderer2 = inject(Renderer2);
10389
10389
  tableColumnDefDirective = inject(TableColumnDefDirective);
10390
10390
  tableComponent = inject(TableComponent);
@@ -10393,16 +10393,16 @@ class TableColumnResizableDirective {
10393
10393
  });
10394
10394
  selfElement = inject(ElementRef).nativeElement;
10395
10395
  containerElement = (this.tableScrollWrapperDirective || this.tableComponent).elementRef.nativeElement;
10396
- destroy$$ = new Subject();
10397
- styleEl;
10396
+ styleElement;
10398
10397
  hostAttr;
10398
+ resizeSubscription;
10399
10399
  ngAfterViewInit() {
10400
10400
  const resizeHandle = this.createResizeHandle();
10401
10401
  this.bindResizable(resizeHandle);
10402
10402
  }
10403
10403
  ngOnDestroy() {
10404
- this.destroy$$.next();
10405
- this.destroy$$.complete();
10404
+ this.resizeSubscription?.unsubscribe();
10405
+ this.styleElement?.remove();
10406
10406
  }
10407
10407
  bindResizable(resizeHandle) {
10408
10408
  fromEvent(resizeHandle, 'mousedown')
@@ -10410,6 +10410,7 @@ class TableColumnResizableDirective {
10410
10410
  mouseDownEvent.preventDefault();
10411
10411
  mouseDownEvent.stopPropagation();
10412
10412
  this.renderer2.setStyle(resizeHandle, 'visibility', 'hidden');
10413
+ const resizeRange = this.getResizeRange();
10413
10414
  const initialMouseX = mouseDownEvent.clientX;
10414
10415
  const columnWidth = this.getColumnWidth();
10415
10416
  const columnOffset = this.getColumnOffset();
@@ -10421,9 +10422,9 @@ class TableColumnResizableDirective {
10421
10422
  this.renderer2.removeStyle(resizeHandle, 'visibility');
10422
10423
  resizeMarkLine.destroy();
10423
10424
  resizeOverlay.destroy();
10424
- this.renderWidthStyles(columnWidth + mouseUpEvent.clientX - initialMouseX);
10425
+ this.renderWidthStyles(this.getWidthInRange(resizeRange, columnWidth + mouseUpEvent.clientX - initialMouseX));
10425
10426
  })));
10426
- }), takeUntil(this.destroy$$))
10427
+ }))
10427
10428
  .subscribe(exec => {
10428
10429
  exec();
10429
10430
  });
@@ -10467,10 +10468,29 @@ class TableColumnResizableDirective {
10467
10468
  return (this.selfElement.getBoundingClientRect().left -
10468
10469
  this.containerElement.getBoundingClientRect().left);
10469
10470
  }
10471
+ getWidthInRange([minWidth, maxWidth], width) {
10472
+ return Math.min(Math.max(width, minWidth), maxWidth);
10473
+ }
10474
+ getResizeRange() {
10475
+ const minWidth = this.getActualWidth(this.minWidth);
10476
+ const maxWidth = this.getActualWidth(this.maxWidth);
10477
+ return [minWidth, maxWidth];
10478
+ }
10479
+ getActualWidth(width) {
10480
+ if (typeof width === 'number') {
10481
+ return width;
10482
+ }
10483
+ else if (width.endsWith('px')) {
10484
+ return parseInt(width.slice(0, -2));
10485
+ }
10486
+ else if (width.endsWith('%')) {
10487
+ return ((this.containerElement.clientWidth * parseInt(width.slice(0, -1))) / 100);
10488
+ }
10489
+ }
10470
10490
  renderWidthStyles(width) {
10471
10491
  const className = tableBem.element(`column-${this.tableColumnDefDirective.cssClassFriendlyName}`);
10472
10492
  if (!this.hostAttr) {
10473
- this.hostAttr = `table-resizable-${tableColResizableUid++}`;
10493
+ this.hostAttr = `table-resizable-${tableColumnResizableID++}`;
10474
10494
  this.containerElement.setAttribute(this.hostAttr, '');
10475
10495
  }
10476
10496
  const styleString = `
@@ -10481,13 +10501,13 @@ class TableColumnResizableDirective {
10481
10501
  max-width: ${width}px !important;
10482
10502
  }
10483
10503
  `;
10484
- if (this.styleEl) {
10485
- this.styleEl.innerHTML = styleString;
10504
+ if (this.styleElement) {
10505
+ this.styleElement.innerHTML = styleString;
10486
10506
  }
10487
10507
  else {
10488
- this.styleEl = this.renderer2.createElement('style');
10489
- this.styleEl.innerHTML = styleString;
10490
- this.renderer2.appendChild(this.containerElement, this.styleEl);
10508
+ this.styleElement = this.renderer2.createElement('style');
10509
+ this.styleElement.innerHTML = styleString;
10510
+ this.renderer2.appendChild(document.querySelector('head'), this.styleElement);
10491
10511
  }
10492
10512
  this.tableComponent.updateStickyColumnStyles();
10493
10513
  }