@alauda/ui 7.3.3-beta.31 → 7.3.3-beta.33
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.
- package/esm2022/table/index.mjs +3 -3
- package/esm2022/table/table-column-resizable.directive.mjs +20 -30
- package/esm2022/utils/index.mjs +2 -1
- package/esm2022/utils/styles-render.mjs +45 -0
- package/fesm2022/alauda-ui.mjs +62 -28
- package/fesm2022/alauda-ui.mjs.map +1 -1
- package/package.json +1 -1
- package/table/index.d.ts +2 -2
- package/table/table-column-resizable.directive.d.ts +5 -4
- package/utils/index.d.ts +1 -0
- package/utils/styles-render.d.ts +18 -0
package/esm2022/table/index.mjs
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
export
|
|
1
|
+
export { TableComponent } from './table.component';
|
|
2
2
|
export * from './table.module';
|
|
3
3
|
export * from './table-cell.component';
|
|
4
4
|
export * from './table-cell.directive';
|
|
5
5
|
export * from './table-cell-def.directive';
|
|
6
|
-
export * from './table-column-resizable.directive';
|
|
7
6
|
export * from './table-column-def.directive';
|
|
7
|
+
export * from './table-column-resizable.directive';
|
|
8
8
|
export * from './table-header-cell.directive';
|
|
9
9
|
export * from './table-header-cell-def.directive';
|
|
10
10
|
export * from './table-header-row.component';
|
|
@@ -13,4 +13,4 @@ export * from './table-placeholder.directive';
|
|
|
13
13
|
export * from './table-row.component';
|
|
14
14
|
export * from './table-row-def.directive';
|
|
15
15
|
export * from './table-scroll.directive';
|
|
16
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdGFibGUvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ25ELGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYywwQkFBMEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IFRhYmxlQ29tcG9uZW50IH0gZnJvbSAnLi90YWJsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi90YWJsZS5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi90YWJsZS1jZWxsLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3RhYmxlLWNlbGwuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vdGFibGUtY2VsbC1kZWYuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vdGFibGUtY29sdW1uLWRlZi5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi90YWJsZS1jb2x1bW4tcmVzaXphYmxlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3RhYmxlLWhlYWRlci1jZWxsLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3RhYmxlLWhlYWRlci1jZWxsLWRlZi5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi90YWJsZS1oZWFkZXItcm93LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3RhYmxlLWhlYWRlci1yb3ctZGVmLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3RhYmxlLXBsYWNlaG9sZGVyLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3RhYmxlLXJvdy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi90YWJsZS1yb3ctZGVmLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3RhYmxlLXNjcm9sbC5kaXJlY3RpdmUnO1xuIl19
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { Directive, ElementRef, inject, Input, Renderer2, } from '@angular/core';
|
|
2
2
|
import { fromEvent, map, merge, switchMap, take, takeUntil, } from 'rxjs';
|
|
3
|
-
import { buildBem } from '../utils';
|
|
4
|
-
import {
|
|
3
|
+
import { buildBem, getCompatibleStylesRenderer } from '../utils';
|
|
4
|
+
import { TableColumnDefDirective } from './table-column-def.directive';
|
|
5
|
+
import { tableBem, TableComponent } from './table.component';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
let tableColumnResizableID = 0;
|
|
7
8
|
const resizableBem = buildBem('aui-table-column-resizable');
|
|
@@ -14,22 +15,23 @@ export class TableColumnResizableDirective {
|
|
|
14
15
|
tableComponent = inject(TableComponent);
|
|
15
16
|
columnElement = inject(ElementRef).nativeElement;
|
|
16
17
|
containerElement = this.tableComponent.elementRef.nativeElement;
|
|
17
|
-
|
|
18
|
-
|
|
18
|
+
hostAttr = `table-column-resizable-${tableColumnResizableID++}`;
|
|
19
|
+
stylesRenderer = getCompatibleStylesRenderer();
|
|
19
20
|
resizeSubscription;
|
|
21
|
+
ngOnInit() {
|
|
22
|
+
this.containerElement.setAttribute(this.hostAttr, '');
|
|
23
|
+
}
|
|
20
24
|
ngAfterViewInit() {
|
|
21
25
|
const resizeHandle = this.createResizeHandle();
|
|
22
26
|
this.bindResizable(resizeHandle);
|
|
23
27
|
}
|
|
24
28
|
ngOnDestroy() {
|
|
25
29
|
this.resizeSubscription?.unsubscribe();
|
|
26
|
-
this.
|
|
27
|
-
|
|
28
|
-
this.containerElement.removeAttribute(this.hostAttr);
|
|
29
|
-
}
|
|
30
|
+
this.containerElement.removeAttribute(this.hostAttr);
|
|
31
|
+
this.stylesRenderer.cleanup();
|
|
30
32
|
}
|
|
31
33
|
bindResizable(resizeHandle) {
|
|
32
|
-
fromEvent(resizeHandle, 'mousedown')
|
|
34
|
+
this.resizeSubscription = fromEvent(resizeHandle, 'mousedown')
|
|
33
35
|
.pipe(switchMap(mouseDownEvent => {
|
|
34
36
|
mouseDownEvent.preventDefault();
|
|
35
37
|
mouseDownEvent.stopPropagation();
|
|
@@ -108,38 +110,26 @@ export class TableColumnResizableDirective {
|
|
|
108
110
|
if (typeof width === 'number') {
|
|
109
111
|
return width;
|
|
110
112
|
}
|
|
111
|
-
|
|
112
|
-
return parseInt(width.slice(0, -2));
|
|
113
|
-
}
|
|
114
|
-
else if (width.endsWith('%')) {
|
|
113
|
+
if (width.endsWith('%')) {
|
|
115
114
|
return ((this.containerElement.clientWidth * parseInt(width.slice(0, -1))) / 100);
|
|
116
115
|
}
|
|
116
|
+
if (width.endsWith('px')) {
|
|
117
|
+
return parseInt(width.slice(0, -2));
|
|
118
|
+
}
|
|
119
|
+
return parseInt(width);
|
|
117
120
|
}
|
|
118
121
|
isStickyLeftBorderColumn() {
|
|
119
122
|
return this.columnElement.classList.contains('aui-table-sticky-border-elem-left');
|
|
120
123
|
}
|
|
121
124
|
renderWidthStyles(width) {
|
|
122
125
|
const className = tableBem.element(`column-${this.tableColumnDefDirective.cssClassFriendlyName}`);
|
|
123
|
-
|
|
124
|
-
this.hostAttr = `table-resizable-${tableColumnResizableID++}`;
|
|
125
|
-
this.containerElement.setAttribute(this.hostAttr, '');
|
|
126
|
-
}
|
|
127
|
-
const styleString = `
|
|
128
|
-
[${this.hostAttr}] .${className} {
|
|
126
|
+
const styleString = `[${this.hostAttr}] .${className} {
|
|
129
127
|
flex: none !important;
|
|
130
128
|
width: ${width}px !important;
|
|
131
129
|
min-width: ${width}px !important;
|
|
132
130
|
max-width: ${width}px !important;
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
if (this.styleElement) {
|
|
136
|
-
this.styleElement.innerHTML = styleString;
|
|
137
|
-
}
|
|
138
|
-
else {
|
|
139
|
-
this.styleElement = this.renderer2.createElement('style');
|
|
140
|
-
this.styleElement.innerHTML = styleString;
|
|
141
|
-
this.renderer2.appendChild(document.querySelector('head'), this.styleElement);
|
|
142
|
-
}
|
|
131
|
+
}`;
|
|
132
|
+
this.stylesRenderer.render(styleString);
|
|
143
133
|
this.tableComponent.updateStickyColumnStyles();
|
|
144
134
|
}
|
|
145
135
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: TableColumnResizableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
@@ -156,4 +146,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
156
146
|
}], maxWidth: [{
|
|
157
147
|
type: Input
|
|
158
148
|
}] } });
|
|
159
|
-
//# 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 { tableBem, TableColumnDefDirective, TableComponent } from './index';\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 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\n  private readonly columnElement: HTMLElement =\n    inject(ElementRef).nativeElement;\n  private readonly containerElement: HTMLElement =\n    this.tableComponent.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    if (this.hostAttr) {\n      this.containerElement.removeAttribute(this.hostAttr);\n    }\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            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    } 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 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    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"]}
|
|
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"]}
|
package/esm2022/utils/index.mjs
CHANGED
|
@@ -5,5 +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
9
|
export * from './watch-content-exist';
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdXRpbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxTQUFTLENBQUM7QUFDeEIsY0FBYyxPQUFPLENBQUM7QUFDdEIsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxNQUFNLENBQUM7QUFDckIsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsdUJBQXVCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2FzeW5jJztcbmV4cG9ydCAqIGZyb20gJy4vYmVtJztcbmV4cG9ydCAqIGZyb20gJy4vY29lcmNpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9mbic7XG5leHBvcnQgKiBmcm9tICcuL29ic2VydmUtZG9tJztcbmV4cG9ydCAqIGZyb20gJy4vb3BlcmF0b3JzJztcbmV4cG9ydCAqIGZyb20gJy4vc2Nyb2xsLWludG8tdmlldyc7XG5leHBvcnQgKiBmcm9tICcuL3N0eWxlcy1yZW5kZXInO1xuZXhwb3J0ICogZnJvbSAnLi93YXRjaC1jb250ZW50LWV4aXN0JztcbiJdfQ==
|
|
@@ -0,0 +1,45 @@
|
|
|
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
|
+
if (this.styleElement) {
|
|
18
|
+
this.styleElement.remove();
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
export class CSSStyleSheetRenderer {
|
|
23
|
+
options;
|
|
24
|
+
styleSheet;
|
|
25
|
+
constructor(options) {
|
|
26
|
+
this.options = options;
|
|
27
|
+
}
|
|
28
|
+
render(styles) {
|
|
29
|
+
if (!this.styleSheet) {
|
|
30
|
+
this.styleSheet = new CSSStyleSheet(this.options);
|
|
31
|
+
document.adoptedStyleSheets = [
|
|
32
|
+
...document.adoptedStyleSheets,
|
|
33
|
+
this.styleSheet,
|
|
34
|
+
];
|
|
35
|
+
}
|
|
36
|
+
this.styleSheet.replaceSync(styles);
|
|
37
|
+
}
|
|
38
|
+
cleanup() {
|
|
39
|
+
if (this.styleSheet) {
|
|
40
|
+
const i = document.adoptedStyleSheets.indexOf(this.styleSheet);
|
|
41
|
+
document.adoptedStyleSheets.splice(i, 1);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3R5bGVzLXJlbmRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91dGlscy9zdHlsZXMtcmVuZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sVUFBVSwyQkFBMkI7SUFDekMsSUFBSSxlQUFlLElBQUksSUFBSSxJQUFJLG9CQUFvQixJQUFJLFFBQVEsRUFBRTtRQUMvRCxPQUFPLElBQUkscUJBQXFCLEVBQUUsQ0FBQztLQUNwQztJQUNELE9BQU8sSUFBSSxjQUFjLEVBQUUsQ0FBQztBQUM5QixDQUFDO0FBRUQsTUFBTSxPQUFPLGNBQWM7SUFDakIsWUFBWSxDQUFtQjtJQUV2QyxNQUFNLENBQUMsTUFBYztRQUNuQixJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRTtZQUN0QixJQUFJLENBQUMsWUFBWSxHQUFHLFFBQVEsQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDcEQsUUFBUSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO1NBQ3pDO1FBQ0QsSUFBSSxDQUFDLFlBQVksQ0FBQyxTQUFTLEdBQUcsTUFBTSxDQUFDO0lBQ3ZDLENBQUM7SUFFRCxPQUFPO1FBQ0wsSUFBSSxJQUFJLENBQUMsWUFBWSxFQUFFO1lBQ3JCLElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxFQUFFLENBQUM7U0FDNUI7SUFDSCxDQUFDO0NBQ0Y7QUFFRCxNQUFNLE9BQU8scUJBQXFCO0lBR0g7SUFGckIsVUFBVSxDQUFnQjtJQUVsQyxZQUE2QixPQUEyQjtRQUEzQixZQUFPLEdBQVAsT0FBTyxDQUFvQjtJQUFHLENBQUM7SUFFNUQsTUFBTSxDQUFDLE1BQWM7UUFDbkIsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUU7WUFDcEIsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLGFBQWEsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDbEQsUUFBUSxDQUFDLGtCQUFrQixHQUFHO2dCQUM1QixHQUFHLFFBQVEsQ0FBQyxrQkFBa0I7Z0JBQzlCLElBQUksQ0FBQyxVQUFVO2FBQ2hCLENBQUM7U0FDSDtRQUNELElBQUksQ0FBQyxVQUFVLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFRCxPQUFPO1FBQ0wsSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFO1lBQ25CLE1BQU0sQ0FBQyxHQUFHLFFBQVEsQ0FBQyxrQkFBa0IsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBQy9ELFFBQVEsQ0FBQyxrQkFBa0IsQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1NBQzFDO0lBQ0gsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGZ1bmN0aW9uIGdldENvbXBhdGlibGVTdHlsZXNSZW5kZXJlcigpIHtcbiAgaWYgKCdDU1NTdHlsZVNoZWV0JyBpbiBzZWxmICYmICdhZG9wdGVkU3R5bGVTaGVldHMnIGluIGRvY3VtZW50KSB7XG4gICAgcmV0dXJuIG5ldyBDU1NTdHlsZVNoZWV0UmVuZGVyZXIoKTtcbiAgfVxuICByZXR1cm4gbmV3IFN0eWxlc1JlbmRlcmVyKCk7XG59XG5cbmV4cG9ydCBjbGFzcyBTdHlsZXNSZW5kZXJlciBpbXBsZW1lbnRzIFJlbmRlcmVyIHtcbiAgcHJpdmF0ZSBzdHlsZUVsZW1lbnQ6IEhUTUxTdHlsZUVsZW1lbnQ7XG5cbiAgcmVuZGVyKHN0eWxlczogc3RyaW5nKTogdm9pZCB7XG4gICAgaWYgKCF0aGlzLnN0eWxlRWxlbWVudCkge1xuICAgICAgdGhpcy5zdHlsZUVsZW1lbnQgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KCdzdHlsZScpO1xuICAgICAgZG9jdW1lbnQuaGVhZC5hcHBlbmQodGhpcy5zdHlsZUVsZW1lbnQpO1xuICAgIH1cbiAgICB0aGlzLnN0eWxlRWxlbWVudC5pbm5lckhUTUwgPSBzdHlsZXM7XG4gIH1cblxuICBjbGVhbnVwKCk6IHZvaWQge1xuICAgIGlmICh0aGlzLnN0eWxlRWxlbWVudCkge1xuICAgICAgdGhpcy5zdHlsZUVsZW1lbnQucmVtb3ZlKCk7XG4gICAgfVxuICB9XG59XG5cbmV4cG9ydCBjbGFzcyBDU1NTdHlsZVNoZWV0UmVuZGVyZXIgaW1wbGVtZW50cyBSZW5kZXJlciB7XG4gIHByaXZhdGUgc3R5bGVTaGVldDogQ1NTU3R5bGVTaGVldDtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IG9wdGlvbnM/OiBDU1NTdHlsZVNoZWV0SW5pdCkge31cblxuICByZW5kZXIoc3R5bGVzOiBzdHJpbmcpOiB2b2lkIHtcbiAgICBpZiAoIXRoaXMuc3R5bGVTaGVldCkge1xuICAgICAgdGhpcy5zdHlsZVNoZWV0ID0gbmV3IENTU1N0eWxlU2hlZXQodGhpcy5vcHRpb25zKTtcbiAgICAgIGRvY3VtZW50LmFkb3B0ZWRTdHlsZVNoZWV0cyA9IFtcbiAgICAgICAgLi4uZG9jdW1lbnQuYWRvcHRlZFN0eWxlU2hlZXRzLFxuICAgICAgICB0aGlzLnN0eWxlU2hlZXQsXG4gICAgICBdO1xuICAgIH1cbiAgICB0aGlzLnN0eWxlU2hlZXQucmVwbGFjZVN5bmMoc3R5bGVzKTtcbiAgfVxuXG4gIGNsZWFudXAoKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuc3R5bGVTaGVldCkge1xuICAgICAgY29uc3QgaSA9IGRvY3VtZW50LmFkb3B0ZWRTdHlsZVNoZWV0cy5pbmRleE9mKHRoaXMuc3R5bGVTaGVldCk7XG4gICAgICBkb2N1bWVudC5hZG9wdGVkU3R5bGVTaGVldHMuc3BsaWNlKGksIDEpO1xuICAgIH1cbiAgfVxufVxuXG5pbnRlcmZhY2UgUmVuZGVyZXIge1xuICByZW5kZXIoc3R5bGVzOiBzdHJpbmcpOiB2b2lkO1xuICBjbGVhbnVwKCk6IHZvaWQ7XG59XG4iXX0=
|
package/fesm2022/alauda-ui.mjs
CHANGED
|
@@ -316,6 +316,51 @@ function scrollIntoView(container, selected) {
|
|
|
316
316
|
}
|
|
317
317
|
}
|
|
318
318
|
|
|
319
|
+
function getCompatibleStylesRenderer() {
|
|
320
|
+
if ('CSSStyleSheet' in self && 'adoptedStyleSheets' in document) {
|
|
321
|
+
return new CSSStyleSheetRenderer();
|
|
322
|
+
}
|
|
323
|
+
return new StylesRenderer();
|
|
324
|
+
}
|
|
325
|
+
class StylesRenderer {
|
|
326
|
+
styleElement;
|
|
327
|
+
render(styles) {
|
|
328
|
+
if (!this.styleElement) {
|
|
329
|
+
this.styleElement = document.createElement('style');
|
|
330
|
+
document.head.append(this.styleElement);
|
|
331
|
+
}
|
|
332
|
+
this.styleElement.innerHTML = styles;
|
|
333
|
+
}
|
|
334
|
+
cleanup() {
|
|
335
|
+
if (this.styleElement) {
|
|
336
|
+
this.styleElement.remove();
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
class CSSStyleSheetRenderer {
|
|
341
|
+
options;
|
|
342
|
+
styleSheet;
|
|
343
|
+
constructor(options) {
|
|
344
|
+
this.options = options;
|
|
345
|
+
}
|
|
346
|
+
render(styles) {
|
|
347
|
+
if (!this.styleSheet) {
|
|
348
|
+
this.styleSheet = new CSSStyleSheet(this.options);
|
|
349
|
+
document.adoptedStyleSheets = [
|
|
350
|
+
...document.adoptedStyleSheets,
|
|
351
|
+
this.styleSheet,
|
|
352
|
+
];
|
|
353
|
+
}
|
|
354
|
+
this.styleSheet.replaceSync(styles);
|
|
355
|
+
}
|
|
356
|
+
cleanup() {
|
|
357
|
+
if (this.styleSheet) {
|
|
358
|
+
const i = document.adoptedStyleSheets.indexOf(this.styleSheet);
|
|
359
|
+
document.adoptedStyleSheets.splice(i, 1);
|
|
360
|
+
}
|
|
361
|
+
}
|
|
362
|
+
}
|
|
363
|
+
|
|
319
364
|
function watchContentExist(queryList) {
|
|
320
365
|
return queryList.changes.pipe(startWith(queryList), map((list) => !!list.length), publishRef());
|
|
321
366
|
}
|
|
@@ -10248,22 +10293,23 @@ class TableColumnResizableDirective {
|
|
|
10248
10293
|
tableComponent = inject(TableComponent);
|
|
10249
10294
|
columnElement = inject(ElementRef).nativeElement;
|
|
10250
10295
|
containerElement = this.tableComponent.elementRef.nativeElement;
|
|
10251
|
-
|
|
10252
|
-
|
|
10296
|
+
hostAttr = `table-column-resizable-${tableColumnResizableID++}`;
|
|
10297
|
+
stylesRenderer = getCompatibleStylesRenderer();
|
|
10253
10298
|
resizeSubscription;
|
|
10299
|
+
ngOnInit() {
|
|
10300
|
+
this.containerElement.setAttribute(this.hostAttr, '');
|
|
10301
|
+
}
|
|
10254
10302
|
ngAfterViewInit() {
|
|
10255
10303
|
const resizeHandle = this.createResizeHandle();
|
|
10256
10304
|
this.bindResizable(resizeHandle);
|
|
10257
10305
|
}
|
|
10258
10306
|
ngOnDestroy() {
|
|
10259
10307
|
this.resizeSubscription?.unsubscribe();
|
|
10260
|
-
this.
|
|
10261
|
-
|
|
10262
|
-
this.containerElement.removeAttribute(this.hostAttr);
|
|
10263
|
-
}
|
|
10308
|
+
this.containerElement.removeAttribute(this.hostAttr);
|
|
10309
|
+
this.stylesRenderer.cleanup();
|
|
10264
10310
|
}
|
|
10265
10311
|
bindResizable(resizeHandle) {
|
|
10266
|
-
fromEvent(resizeHandle, 'mousedown')
|
|
10312
|
+
this.resizeSubscription = fromEvent(resizeHandle, 'mousedown')
|
|
10267
10313
|
.pipe(switchMap(mouseDownEvent => {
|
|
10268
10314
|
mouseDownEvent.preventDefault();
|
|
10269
10315
|
mouseDownEvent.stopPropagation();
|
|
@@ -10342,38 +10388,26 @@ class TableColumnResizableDirective {
|
|
|
10342
10388
|
if (typeof width === 'number') {
|
|
10343
10389
|
return width;
|
|
10344
10390
|
}
|
|
10345
|
-
|
|
10346
|
-
return parseInt(width.slice(0, -2));
|
|
10347
|
-
}
|
|
10348
|
-
else if (width.endsWith('%')) {
|
|
10391
|
+
if (width.endsWith('%')) {
|
|
10349
10392
|
return ((this.containerElement.clientWidth * parseInt(width.slice(0, -1))) / 100);
|
|
10350
10393
|
}
|
|
10394
|
+
if (width.endsWith('px')) {
|
|
10395
|
+
return parseInt(width.slice(0, -2));
|
|
10396
|
+
}
|
|
10397
|
+
return parseInt(width);
|
|
10351
10398
|
}
|
|
10352
10399
|
isStickyLeftBorderColumn() {
|
|
10353
10400
|
return this.columnElement.classList.contains('aui-table-sticky-border-elem-left');
|
|
10354
10401
|
}
|
|
10355
10402
|
renderWidthStyles(width) {
|
|
10356
10403
|
const className = tableBem.element(`column-${this.tableColumnDefDirective.cssClassFriendlyName}`);
|
|
10357
|
-
|
|
10358
|
-
this.hostAttr = `table-resizable-${tableColumnResizableID++}`;
|
|
10359
|
-
this.containerElement.setAttribute(this.hostAttr, '');
|
|
10360
|
-
}
|
|
10361
|
-
const styleString = `
|
|
10362
|
-
[${this.hostAttr}] .${className} {
|
|
10404
|
+
const styleString = `[${this.hostAttr}] .${className} {
|
|
10363
10405
|
flex: none !important;
|
|
10364
10406
|
width: ${width}px !important;
|
|
10365
10407
|
min-width: ${width}px !important;
|
|
10366
10408
|
max-width: ${width}px !important;
|
|
10367
|
-
}
|
|
10368
|
-
|
|
10369
|
-
if (this.styleElement) {
|
|
10370
|
-
this.styleElement.innerHTML = styleString;
|
|
10371
|
-
}
|
|
10372
|
-
else {
|
|
10373
|
-
this.styleElement = this.renderer2.createElement('style');
|
|
10374
|
-
this.styleElement.innerHTML = styleString;
|
|
10375
|
-
this.renderer2.appendChild(document.querySelector('head'), this.styleElement);
|
|
10376
|
-
}
|
|
10409
|
+
}`;
|
|
10410
|
+
this.stylesRenderer.render(styleString);
|
|
10377
10411
|
this.tableComponent.updateStickyColumnStyles();
|
|
10378
10412
|
}
|
|
10379
10413
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: TableColumnResizableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
@@ -12623,5 +12657,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImpor
|
|
|
12623
12657
|
}]
|
|
12624
12658
|
}] });
|
|
12625
12659
|
|
|
12626
|
-
export { ACCORDION_MODULE, ANCHOR_MODULE, AUTOCOMPLETE_MODULE, AccordionComponent, AccordionItemComponent, AccordionItemContentDirective, AccordionItemHeaderDirective, AccordionModule, AnchorComponent, AnchorDirective, AnchorDirectiveChild, AnchorLabelDirective, AnchorModule, AnchorTreeComponent, AuiSelectValidators, AutoCompleteDirective, AutocompleteComponent, AutocompleteModule, AutocompletePlaceholderComponent, AutosizeDirective, BREADCRUMB_MODULE, BackTopComponent, BackTopModule, BaseDialogConfig, BaseTooltip, Bem, BreadcrumbComponent, BreadcrumbItemComponent, BreadcrumbModule, ButtonComponent, ButtonGroupComponent, ButtonModule, ButtonType, CARD_MODULE, CHECKBOX_MODULE, CONTROL_ITEM_HEIGHT, CalendarFooterComponent, CalendarHeaderComponent, CardComponent, CardFooterDirective, CardHeaderDirective, CardModule, CheckTagComponent, CheckboxComponent, CheckboxGroupComponent, CheckboxModule, ColorPickerComponent, ColorPickerModule, CommonFormControl, ComponentSize, ConfirmDialogConfig, ConfirmType, CssVarPipe, CustomAutoCompleteDirective, DATE, DATE_NAV_RANGES, DATE_TYPES, DAY, DAY_PANEL_COLUMN_COUNT, DAY_PANEL_ROW_COUNT, DIALOG_DATA, DISPLAY_DELAY, DateNavRange, DatePickerComponent, DatePickerModule, DatePickerPanelComponent, DatePickerTriggerComponent, DatePickerType, DateRangePickerPanelComponent, DialogCloseDirective, DialogComponent, DialogConfig, DialogContentComponent, DialogFooterComponent, DialogHeaderComponent, DialogModule, DialogRef, DialogService, DialogSize, DrawerComponent, DrawerContentDirective, DrawerFooterDirective, DrawerHeaderDirective, DrawerModule, DrawerRef, DrawerService, DrawerSize, DropdownActiveDirective, DropdownButtonComponent, DropdownDirective, DropdownModule, FORM_MODULE, FixedSizeTableVirtualScrollDirective, FixedSizeTableVirtualScrollStrategy, FixedSizeVirtualScrollDirective, FormDirective, FormItemAddonDirective, FormItemComponent, FormItemControlDirective, FormItemErrorDirective, FormItemHintDirective, FormItemLabelDirective, FormItemWidth, FormModule, HIDDEN_DELAY, HOUR, HOUR_ITEMS, I18NInterfaceToken, I18nModule, I18nPipe, I18nService, INLINE_ALERT_MODULE, INPUT_ERROR_KEY, INPUT_GROUP_MODULE, IconComponent, IconModule, IconRegisterService, IncludesDirective, InlineAlertComponent, InlineAlertModule, InlineAlertTitleDirective, InlineAlertType, InputAddonAfterDirective, InputAddonBeforeDirective, InputComponent, InputGroupComponent, InputModule, InputPrefixDirective, InputSuffixDirective, LabelPosition, MESSAGE_CONFIG, MESSAGE_DEFAULT_CONFIG, MINUTE, MINUTE_ITEMS, MONTH, MONTH_PANEL_COLUMN_COUNT, MONTH_PANEL_ROW_COUNT, MenuComponent, MenuGroupComponent, MenuGroupTitleDirective, MenuItemComponent, MenuItemType, MessageConfig, MessageModule, MessageService, MessageType, MultiSelectComponent, NOTIFICATION_CONFIG, NOTIFICATION_DEFAULT_CONFIG, NUMBER_INPUT_MODULE, NotificationComponent, NotificationModule, NotificationService, NumberInputComponent, OptionComponent, OptionContentDirective, OptionGroupComponent, OptionGroupTitleDirective, OptionPlaceholderComponent, PaginatorComponent, PaginatorIntl, PaginatorModule, PickerPanelComponent, RadioButtonComponent, RadioComponent, RadioGroupComponent, RadioModule, RadioSize, RangePickerComponent, RgbColorPipe, RgbaColorPipe, SECOND, SECOND_ITEMS, SELECT_MODULE, SORT_MODULE, ScrollingModule, SearchComponent, SectionComponent, SectionTitleDirective, SelectAllStatus, SelectComponent, SelectModule, Side, SortDirective, SortHeaderComponent, SortModule, StatusBarComponent, StatusBarModule, StatusBarSize, StatusType, StepState, StepsComponent, StepsModule, SubmenuComponent, SuggestionComponent, SuggestionGroupComponent, SuggestionGroupTitleDirective, SwitchComponent, SwitchModule, TABLE_MODULE, TABLE_OF_CONTENTS_MODULE, TABS_MODULE, TabBodyComponent, TabBodyPortalDirective, TabChangeEvent, TabComponent, TabContentDirective, TabContextService, TabGroupComponent, TabHeaderActiveIndicatorComponent, TabHeaderAddonDirective, TabHeaderComponent, TabLabelDirective, TabLabelWrapperDirective, TabSize, TabTitleDirective, TabType, TableCellDefDirective, TableCellDirective, TableColumnDefDirective, TableColumnResizableDirective, TableComponent, TableExpandButtonCellComponent, TableExpandPanelCellComponent, TableHeaderCellDefDirective, TableHeaderCellDirective, TableHeaderRowComponent, TableHeaderRowDefDirective, TableModule, TableOfContentsModule, TablePlaceholderDefDirective, TablePlaceholderOutletDirective, TableRowComponent, TableRowDefDirective, TableScrollWrapperDirective, TableScrollableDirective, TabsModule, TagComponent, TagModule, TagType, TagsInputComponent, ThemeModule, ThemePickerPipe, ThemeService, TimePickerComponent, TimePickerControlType, TimePickerModule, TimePickerPanelComponent, TocContainerDirective, TocContentDirective, TocLinkDirective, TooltipActiveDirective, TooltipComponent, TooltipCopyDirective, TooltipCopyIntl, TooltipDirective, TooltipModule, TooltipTrigger, TooltipType, TreeNodeComponent, TreeNodePlaceholderComponent, TreeSelectComponent, TreeSelectModule, VirtualForOfDirective, VirtualScrollViewportComponent, YEAR, YEAR_PANEL_COLUMN_COUNT, YEAR_PANEL_ROW_COUNT, _tableVirtualScrollDirectiveStrategyFactory, buildBem, coerceAttrBoolean, coerceString, cssVar, en, getAnchorTreeItems, getElementOffset, getSortDuplicateSortableIdError, getSortHeaderMissingIdError, getSortHeaderNotContainedWithinSortError, getSortInvalidDirectionError, handlePixel, isNumberValue, isString, isTemplateRef, isTimePickerModel, last, observeMutationOn, observeResizeOn, publishRef, rgbColor, rgbaColor, scrollIntoView, sleep,
|
|
12660
|
+
export { ACCORDION_MODULE, ANCHOR_MODULE, AUTOCOMPLETE_MODULE, AccordionComponent, AccordionItemComponent, AccordionItemContentDirective, AccordionItemHeaderDirective, AccordionModule, AnchorComponent, AnchorDirective, AnchorDirectiveChild, AnchorLabelDirective, AnchorModule, AnchorTreeComponent, AuiSelectValidators, AutoCompleteDirective, AutocompleteComponent, AutocompleteModule, AutocompletePlaceholderComponent, AutosizeDirective, BREADCRUMB_MODULE, BackTopComponent, BackTopModule, BaseDialogConfig, BaseTooltip, Bem, BreadcrumbComponent, BreadcrumbItemComponent, BreadcrumbModule, ButtonComponent, ButtonGroupComponent, ButtonModule, ButtonType, CARD_MODULE, CHECKBOX_MODULE, CONTROL_ITEM_HEIGHT, CSSStyleSheetRenderer, CalendarFooterComponent, CalendarHeaderComponent, CardComponent, CardFooterDirective, CardHeaderDirective, CardModule, CheckTagComponent, CheckboxComponent, CheckboxGroupComponent, CheckboxModule, ColorPickerComponent, ColorPickerModule, CommonFormControl, ComponentSize, ConfirmDialogConfig, ConfirmType, CssVarPipe, CustomAutoCompleteDirective, DATE, DATE_NAV_RANGES, DATE_TYPES, DAY, DAY_PANEL_COLUMN_COUNT, DAY_PANEL_ROW_COUNT, DIALOG_DATA, DISPLAY_DELAY, DateNavRange, DatePickerComponent, DatePickerModule, DatePickerPanelComponent, DatePickerTriggerComponent, DatePickerType, DateRangePickerPanelComponent, DialogCloseDirective, DialogComponent, DialogConfig, DialogContentComponent, DialogFooterComponent, DialogHeaderComponent, DialogModule, DialogRef, DialogService, DialogSize, DrawerComponent, DrawerContentDirective, DrawerFooterDirective, DrawerHeaderDirective, DrawerModule, DrawerRef, DrawerService, DrawerSize, DropdownActiveDirective, DropdownButtonComponent, DropdownDirective, DropdownModule, FORM_MODULE, FixedSizeTableVirtualScrollDirective, FixedSizeTableVirtualScrollStrategy, FixedSizeVirtualScrollDirective, FormDirective, FormItemAddonDirective, FormItemComponent, FormItemControlDirective, FormItemErrorDirective, FormItemHintDirective, FormItemLabelDirective, FormItemWidth, FormModule, HIDDEN_DELAY, HOUR, HOUR_ITEMS, I18NInterfaceToken, I18nModule, I18nPipe, I18nService, INLINE_ALERT_MODULE, INPUT_ERROR_KEY, INPUT_GROUP_MODULE, IconComponent, IconModule, IconRegisterService, IncludesDirective, InlineAlertComponent, InlineAlertModule, InlineAlertTitleDirective, InlineAlertType, InputAddonAfterDirective, InputAddonBeforeDirective, InputComponent, InputGroupComponent, InputModule, InputPrefixDirective, InputSuffixDirective, LabelPosition, MESSAGE_CONFIG, MESSAGE_DEFAULT_CONFIG, MINUTE, MINUTE_ITEMS, MONTH, MONTH_PANEL_COLUMN_COUNT, MONTH_PANEL_ROW_COUNT, MenuComponent, MenuGroupComponent, MenuGroupTitleDirective, MenuItemComponent, MenuItemType, MessageConfig, MessageModule, MessageService, MessageType, MultiSelectComponent, NOTIFICATION_CONFIG, NOTIFICATION_DEFAULT_CONFIG, NUMBER_INPUT_MODULE, NotificationComponent, NotificationModule, NotificationService, NumberInputComponent, OptionComponent, OptionContentDirective, OptionGroupComponent, OptionGroupTitleDirective, OptionPlaceholderComponent, PaginatorComponent, PaginatorIntl, PaginatorModule, PickerPanelComponent, RadioButtonComponent, RadioComponent, RadioGroupComponent, RadioModule, RadioSize, RangePickerComponent, RgbColorPipe, RgbaColorPipe, SECOND, SECOND_ITEMS, SELECT_MODULE, SORT_MODULE, ScrollingModule, SearchComponent, SectionComponent, SectionTitleDirective, SelectAllStatus, SelectComponent, SelectModule, Side, SortDirective, SortHeaderComponent, SortModule, StatusBarComponent, StatusBarModule, StatusBarSize, StatusType, StepState, StepsComponent, StepsModule, StylesRenderer, SubmenuComponent, SuggestionComponent, SuggestionGroupComponent, SuggestionGroupTitleDirective, SwitchComponent, SwitchModule, TABLE_MODULE, TABLE_OF_CONTENTS_MODULE, TABS_MODULE, TabBodyComponent, TabBodyPortalDirective, TabChangeEvent, TabComponent, TabContentDirective, TabContextService, TabGroupComponent, TabHeaderActiveIndicatorComponent, TabHeaderAddonDirective, TabHeaderComponent, TabLabelDirective, TabLabelWrapperDirective, TabSize, TabTitleDirective, TabType, TableCellDefDirective, TableCellDirective, TableColumnDefDirective, TableColumnResizableDirective, TableComponent, TableExpandButtonCellComponent, TableExpandPanelCellComponent, TableHeaderCellDefDirective, TableHeaderCellDirective, TableHeaderRowComponent, TableHeaderRowDefDirective, TableModule, TableOfContentsModule, TablePlaceholderDefDirective, TablePlaceholderOutletDirective, TableRowComponent, TableRowDefDirective, TableScrollWrapperDirective, TableScrollableDirective, TabsModule, TagComponent, TagModule, TagType, TagsInputComponent, ThemeModule, ThemePickerPipe, ThemeService, TimePickerComponent, TimePickerControlType, TimePickerModule, TimePickerPanelComponent, TocContainerDirective, TocContentDirective, TocLinkDirective, TooltipActiveDirective, TooltipComponent, TooltipCopyDirective, TooltipCopyIntl, TooltipDirective, TooltipModule, TooltipTrigger, TooltipType, TreeNodeComponent, TreeNodePlaceholderComponent, TreeSelectComponent, TreeSelectModule, VirtualForOfDirective, VirtualScrollViewportComponent, YEAR, YEAR_PANEL_COLUMN_COUNT, YEAR_PANEL_ROW_COUNT, _tableVirtualScrollDirectiveStrategyFactory, buildBem, coerceAttrBoolean, coerceString, cssVar, en, getAnchorTreeItems, getCompatibleStylesRenderer, getElementOffset, getSortDuplicateSortableIdError, getSortHeaderMissingIdError, getSortHeaderNotContainedWithinSortError, getSortInvalidDirectionError, handlePixel, isNumberValue, isString, isTemplateRef, isTimePickerModel, last, observeMutationOn, observeResizeOn, publishRef, rgbColor, rgbaColor, scrollIntoView, sleep, watchContentExist, zh };
|
|
12627
12661
|
//# sourceMappingURL=alauda-ui.mjs.map
|