@alauda/ui 7.3.3-beta.24 → 7.3.3-beta.26

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@alauda/ui",
3
- "version": "7.3.3-beta.24",
3
+ "version": "7.3.3-beta.26",
4
4
  "description": "Angular UI components by Alauda Frontend Team.",
5
5
  "repository": "git+https://github.com/alauda/alauda-ui.git",
6
6
  "author": "Alauda Frontend",
package/table/index.d.ts CHANGED
@@ -3,7 +3,7 @@ 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 { TableColResizableDirective } from './table-col-resizable.directive';
6
+ export * from './table-column-resizable.directive';
7
7
  export * from './table-column-def.directive';
8
8
  export * from './table-header-cell.directive';
9
9
  export * from './table-header-cell-def.directive';
@@ -1,7 +1,6 @@
1
1
  import { AfterViewInit } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
- export declare const resizableBem: import("../utils").Bem;
4
- export declare class TableColResizableDirective implements AfterViewInit {
3
+ export declare class TableColumnResizableDirective implements AfterViewInit {
5
4
  minWidth: string;
6
5
  maxWidth: string;
7
6
  private readonly renderer2;
@@ -10,9 +9,9 @@ export declare class TableColResizableDirective implements AfterViewInit {
10
9
  private readonly tableScrollWrapperDirective;
11
10
  private readonly selfElement;
12
11
  private readonly containerElement;
13
- private readonly destroy$$;
14
- private styleEl;
12
+ private styleElement;
15
13
  private hostAttr;
14
+ private resizeSubscription;
16
15
  ngAfterViewInit(): void;
17
16
  ngOnDestroy(): void;
18
17
  private bindResizable;
@@ -22,6 +21,6 @@ export declare class TableColResizableDirective implements AfterViewInit {
22
21
  private getColumnWidth;
23
22
  private getColumnOffset;
24
23
  private renderWidthStyles;
25
- static ɵfac: i0.ɵɵFactoryDeclaration<TableColResizableDirective, never>;
26
- static ɵdir: i0.ɵɵDirectiveDeclaration<TableColResizableDirective, "[auiTableColumnResizable]", never, { "minWidth": { "alias": "minWidth"; "required": false; }; "maxWidth": { "alias": "maxWidth"; "required": false; }; }, {}, never, never, true, never>;
24
+ static ɵfac: i0.ɵɵFactoryDeclaration<TableColumnResizableDirective, never>;
25
+ static ɵdir: i0.ɵɵDirectiveDeclaration<TableColumnResizableDirective, "[auiTableColumnResizable]", never, { "minWidth": { "alias": "minWidth"; "required": false; }; "maxWidth": { "alias": "maxWidth"; "required": false; }; }, {}, never, never, true, never>;
27
26
  }
@@ -1,127 +0,0 @@
1
- import { Directive, ElementRef, inject, Input, Renderer2, } from '@angular/core';
2
- import { first, fromEvent, map, startWith, Subject, switchMap, takeUntil, } from 'rxjs';
3
- import { buildBem } from '../utils';
4
- import { tableBem, TableColumnDefDirective, TableComponent, TableScrollWrapperDirective, } from './index';
5
- import * as i0 from "@angular/core";
6
- let tableColResizableUid = 0;
7
- export const resizableBem = buildBem('aui-table-column-resizable');
8
- export class TableColResizableDirective {
9
- minWidth = '60px';
10
- maxWidth = '100%';
11
- renderer2 = inject(Renderer2);
12
- tableColumnDefDirective = inject(TableColumnDefDirective);
13
- tableComponent = inject(TableComponent);
14
- tableScrollWrapperDirective = inject(TableScrollWrapperDirective, {
15
- optional: true,
16
- });
17
- selfElement = inject(ElementRef).nativeElement;
18
- containerElement = (this.tableScrollWrapperDirective || this.tableComponent).elementRef.nativeElement;
19
- destroy$$ = new Subject();
20
- styleEl;
21
- hostAttr;
22
- ngAfterViewInit() {
23
- const resizeHandle = this.createResizeHandle();
24
- this.bindResizable(resizeHandle);
25
- }
26
- ngOnDestroy() {
27
- this.destroy$$.next();
28
- this.destroy$$.complete();
29
- }
30
- bindResizable(resizeHandle) {
31
- fromEvent(resizeHandle, 'mousedown')
32
- .pipe(switchMap(mouseDownEvent => {
33
- this.renderer2.setStyle(resizeHandle, 'visibility', 'hidden');
34
- const initialMouseX = mouseDownEvent.clientX;
35
- const columnWidth = this.getColumnWidth();
36
- const columnOffset = this.getColumnOffset();
37
- const resizeMarkLine = this.createResizeMarkLine(columnWidth + columnOffset);
38
- const resizeOverlay = this.createResizeOverlay();
39
- return fromEvent(document, 'mousemove').pipe(map(mouseMoveEvent => () => resizeMarkLine.updateOffset(mouseMoveEvent.clientX - initialMouseX)), switchMap(renderMarkLine => fromEvent(document, 'mouseup').pipe(first(), map(mouseUpEvent => () => {
40
- this.renderer2.removeStyle(resizeHandle, 'visibility');
41
- resizeMarkLine.destroy();
42
- resizeOverlay.destroy();
43
- this.renderWidthStyles(columnWidth + mouseUpEvent.clientX - initialMouseX);
44
- }), startWith(renderMarkLine))));
45
- }), takeUntil(this.destroy$$))
46
- .subscribe(exec => {
47
- exec();
48
- });
49
- }
50
- createResizeHandle() {
51
- const resizeHandle = this.renderer2.createElement('div');
52
- this.renderer2.addClass(resizeHandle, resizableBem.element('handle'));
53
- this.renderer2.appendChild(this.selfElement, resizeHandle);
54
- return resizeHandle;
55
- }
56
- createResizeMarkLine(initialOffset) {
57
- const markLine = this.renderer2.createElement('div');
58
- this.renderer2.addClass(markLine, resizableBem.element('mark-line'));
59
- this.renderer2.setStyle(markLine, 'left', initialOffset + 'px');
60
- this.renderer2.appendChild(this.containerElement, markLine);
61
- return {
62
- element: markLine,
63
- updateOffset: (offset) => {
64
- this.renderer2.setStyle(markLine, 'left', initialOffset + offset + 'px');
65
- },
66
- destroy: () => {
67
- this.renderer2.removeChild(this.containerElement, markLine);
68
- },
69
- };
70
- }
71
- createResizeOverlay() {
72
- const resizeOverlay = this.renderer2.createElement('div');
73
- this.renderer2.addClass(resizeOverlay, resizableBem.element('overlay'));
74
- this.renderer2.appendChild(this.containerElement, resizeOverlay);
75
- return {
76
- element: resizeOverlay,
77
- destroy: () => {
78
- this.renderer2.removeChild(this.containerElement, resizeOverlay);
79
- },
80
- };
81
- }
82
- getColumnWidth() {
83
- return this.selfElement.clientWidth;
84
- }
85
- getColumnOffset() {
86
- return (this.selfElement.getBoundingClientRect().left -
87
- this.containerElement.getBoundingClientRect().left);
88
- }
89
- renderWidthStyles(width) {
90
- const className = tableBem.element(`column-${this.tableColumnDefDirective.cssClassFriendlyName}`);
91
- if (!this.hostAttr) {
92
- this.hostAttr = `table-resizable-${tableColResizableUid++}`;
93
- this.containerElement.setAttribute(this.hostAttr, '');
94
- }
95
- const styleString = `
96
- [${this.hostAttr}] .${className} {
97
- flex: none !important;
98
- width: ${width}px !important;
99
- min-width: ${width}px !important;
100
- max-width: ${width}px !important;
101
- }
102
- `;
103
- if (this.styleEl) {
104
- this.styleEl.innerHTML = styleString;
105
- }
106
- else {
107
- this.styleEl = this.renderer2.createElement('style');
108
- this.styleEl.innerHTML = styleString;
109
- this.renderer2.appendChild(this.containerElement, this.styleEl);
110
- }
111
- this.tableComponent.updateStickyColumnStyles();
112
- }
113
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: TableColResizableDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
114
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.3", type: TableColResizableDirective, isStandalone: true, selector: "[auiTableColumnResizable]", inputs: { minWidth: "minWidth", maxWidth: "maxWidth" }, ngImport: i0 });
115
- }
116
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.3", ngImport: i0, type: TableColResizableDirective, decorators: [{
117
- type: Directive,
118
- args: [{
119
- selector: '[auiTableColumnResizable]',
120
- standalone: true,
121
- }]
122
- }], propDecorators: { minWidth: [{
123
- type: Input
124
- }], maxWidth: [{
125
- type: Input
126
- }] } });
127
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-col-resizable.directive.js","sourceRoot":"","sources":["../../../src/table/table-col-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  first,\n  fromEvent,\n  map,\n  startWith,\n  Subject,\n  switchMap,\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;\nexport const resizableBem = buildBem('aui-table-column-resizable');\n\n@Directive({\n  selector: '[auiTableColumnResizable]',\n  standalone: true,\n})\nexport class TableColResizableDirective 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 barWidth = 2;\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        // map(event => {\n        //   event.preventDefault();\n        //   event.stopPropagation();\n\n        //   const initialWidth = this.selfElement.clientWidth;\n\n        //   // 避免两条线不对齐\n        //   this.renderer2.setStyle(resizeHandle, 'visibility', 'hidden');\n\n        //   return {\n        //     markLine: this.createResizeMarkLine(),\n        //     resizeOverlay: this.createResizeOverlay(),\n        //     initialWidth,\n        //     initialMouseX: event.clientX,\n        //   };\n        // }),\n        switchMap(mouseDownEvent => {\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          return fromEvent<MouseEvent>(document, 'mousemove').pipe(\n            map(\n              mouseMoveEvent => () =>\n                resizeMarkLine.updateOffset(\n                  mouseMoveEvent.clientX - initialMouseX,\n                ),\n            ),\n            switchMap(renderMarkLine =>\n              fromEvent<MouseEvent>(document, 'mouseup').pipe(\n                first(),\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                startWith(renderMarkLine),\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    // fromEvent<MouseEvent>(resizeHandle, 'click')\n    //   .pipe(takeUntil(this.destroy$$))\n    //   .subscribe(event => event.stopPropagation());\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"]}