@alauda/ui 6.4.8-beta.13 → 6.4.8-beta.15
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.
|
@@ -40,27 +40,45 @@ export class TableScrollableDirective extends CdkScrollable {
|
|
|
40
40
|
super(el, scrollDispatcher, ngZone, dir);
|
|
41
41
|
this.el = el;
|
|
42
42
|
this.table = table;
|
|
43
|
-
this.
|
|
43
|
+
this._scrollable = true;
|
|
44
|
+
this.scrollable$$ = new BehaviorSubject(this._scrollable);
|
|
44
45
|
this.destroy$$ = new Subject();
|
|
45
46
|
this.SCROLL_BEFORE_END_CLASS = true;
|
|
46
47
|
this.SHADOW_CLASS = true;
|
|
47
48
|
}
|
|
48
|
-
set
|
|
49
|
-
this.
|
|
49
|
+
set scrollable(scrollable) {
|
|
50
|
+
this._scrollable = coerceAttrBoolean(scrollable);
|
|
51
|
+
this.scrollable$$.next(this._scrollable);
|
|
52
|
+
}
|
|
53
|
+
get scrollable() {
|
|
54
|
+
return this._scrollable;
|
|
50
55
|
}
|
|
51
56
|
get containerEl() {
|
|
52
57
|
return this.el.nativeElement;
|
|
53
58
|
}
|
|
59
|
+
ngOnInit() {
|
|
60
|
+
if (this.scrollable) {
|
|
61
|
+
this.scrollDispatcher.register(this);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
54
64
|
ngAfterViewInit() {
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
65
|
+
this.viewMutation();
|
|
66
|
+
}
|
|
67
|
+
ngOnDestroy() {
|
|
68
|
+
super.ngOnDestroy();
|
|
69
|
+
this.destroy$$.next();
|
|
70
|
+
this.destroy$$.complete();
|
|
58
71
|
}
|
|
59
72
|
viewMutation() {
|
|
60
|
-
this.
|
|
61
|
-
.pipe(switchMap(
|
|
62
|
-
|
|
63
|
-
|
|
73
|
+
this.scrollable$$
|
|
74
|
+
.pipe(switchMap(scrollable => {
|
|
75
|
+
if (scrollable) {
|
|
76
|
+
this.scrollDispatcher.register(this);
|
|
77
|
+
return merge(observeResizeOn(this.containerEl), fromEvent(this.containerEl, 'scroll')).pipe(startWith(null));
|
|
78
|
+
}
|
|
79
|
+
this.scrollDispatcher.deregister(this);
|
|
80
|
+
return NEVER;
|
|
81
|
+
}))
|
|
64
82
|
.pipe(takeUntil(this.destroy$$))
|
|
65
83
|
.subscribe(() => {
|
|
66
84
|
this.mutateVerticalScroll();
|
|
@@ -86,14 +104,9 @@ export class TableScrollableDirective extends CdkScrollable {
|
|
|
86
104
|
placeClassList(classList, condition, className) {
|
|
87
105
|
classList[condition ? 'add' : 'remove'](className);
|
|
88
106
|
}
|
|
89
|
-
ngOnDestroy() {
|
|
90
|
-
super.ngOnDestroy();
|
|
91
|
-
this.destroy$$.next();
|
|
92
|
-
this.destroy$$.complete();
|
|
93
|
-
}
|
|
94
107
|
}
|
|
95
108
|
TableScrollableDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: TableScrollableDirective, deps: [{ token: i0.ElementRef }, { token: i1.ScrollDispatcher }, { token: i0.NgZone }, { token: i2.TableComponent, host: true }, { token: i3.Directionality, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
|
|
96
|
-
TableScrollableDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.8", type: TableScrollableDirective, selector: "[auiTableScrollable]", inputs: {
|
|
109
|
+
TableScrollableDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.8", type: TableScrollableDirective, selector: "[auiTableScrollable]", inputs: { scrollable: ["auiTableScrollable", "scrollable"] }, host: { properties: { "class.aui-table__scroll-shadow--before-end": "this.SCROLL_BEFORE_END_CLASS", "class.aui-table__scroll-shadow": "this.SHADOW_CLASS" } }, providers: [
|
|
97
110
|
{ provide: CdkScrollable, useExisting: TableScrollableDirective },
|
|
98
111
|
], usesInheritance: true, ngImport: i0 });
|
|
99
112
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: TableScrollableDirective, decorators: [{
|
|
@@ -108,8 +121,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
108
121
|
type: Host
|
|
109
122
|
}] }, { type: i3.Directionality, decorators: [{
|
|
110
123
|
type: Optional
|
|
111
|
-
}] }]; }, propDecorators: {
|
|
112
|
-
type: Input
|
|
124
|
+
}] }]; }, propDecorators: { scrollable: [{
|
|
125
|
+
type: Input,
|
|
126
|
+
args: ['auiTableScrollable']
|
|
113
127
|
}], SCROLL_BEFORE_END_CLASS: [{
|
|
114
128
|
type: HostBinding,
|
|
115
129
|
args: [`class.${SCROLL_BEFORE_END_CLASS}`]
|
|
@@ -117,4 +131,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
117
131
|
type: HostBinding,
|
|
118
132
|
args: [`class.${SHADOW_CLASS}`]
|
|
119
133
|
}] } });
|
|
120
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-scroll.directive.js","sourceRoot":"","sources":["../../../src/table/table-scroll.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directionality } from '@angular/cdk/bidi';\nimport { CdkScrollable, ScrollDispatcher } from '@angular/cdk/scrolling';\nimport {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  Host,\n  HostBinding,\n  Input,\n  NgZone,\n  OnDestroy,\n  Optional,\n} from '@angular/core';\nimport {\n  Subject,\n  fromEvent,\n  merge,\n  startWith,\n  takeUntil,\n  switchMap,\n  NEVER,\n  BehaviorSubject,\n} from 'rxjs';\n\nimport { coerceAttrBoolean, observeResizeOn } from '../utils';\n\nimport { TableComponent } from './table.component';\n\nconst CLASS_PREFIX = 'aui-table';\nconst SHADOW_CLASS = `${CLASS_PREFIX}__scroll-shadow`;\nconst HAS_SCROLL_CLASS = `${SHADOW_CLASS}--has-scroll`;\nconst SCROLLING_CLASS = `${SHADOW_CLASS}--scrolling`;\nconst SCROLL_BEFORE_END_CLASS = `${SHADOW_CLASS}--before-end`;\n\nconst HAS_TABLE_TOP_SHADOW = 'hasTableTopShadow';\nconst HAS_TABLE_BOTTOM_SHADOW = 'hasTableBottomShadow';\nconst HAS_TABLE_VERTICAL_SCROLL = 'hasTableVerticalScroll';\n\n@Directive({\n  selector: '[auiTableScrollWrapper]',\n  host: {\n    class: 'aui-table__scroll-wrapper',\n  },\n})\nexport class TableScrollWrapperDirective {\n  @HostBinding('style.max-height')\n  @Input()\n  auiTableScrollWrapper = '100%';\n}\n\n@Directive({\n  selector: '[auiTableScrollable]',\n  providers: [\n    { provide: CdkScrollable, useExisting: TableScrollableDirective },\n  ],\n})\nexport class TableScrollableDirective\n  extends CdkScrollable\n  implements AfterViewInit, OnDestroy\n{\n  scrollShadow$$ = new BehaviorSubject<boolean>(true);\n\n  destroy$$ = new Subject<void>();\n\n  @Input()\n  set auiTableScrollable(scrollShadow: boolean | '') {\n    this.scrollShadow$$.next(coerceAttrBoolean(scrollShadow));\n  }\n\n  constructor(\n    private readonly el: ElementRef<HTMLElement>,\n    scrollDispatcher: ScrollDispatcher,\n    ngZone: NgZone,\n    @Host() private readonly table: TableComponent<unknown>,\n    @Optional() dir?: Directionality,\n  ) {\n    super(el, scrollDispatcher, ngZone, dir);\n  }\n\n  @HostBinding(`class.${SCROLL_BEFORE_END_CLASS}`)\n  SCROLL_BEFORE_END_CLASS = true;\n\n  @HostBinding(`class.${SHADOW_CLASS}`)\n  SHADOW_CLASS = true;\n\n  get containerEl() {\n    return this.el.nativeElement;\n  }\n\n  ngAfterViewInit() {\n    requestAnimationFrame(() => {\n      this.viewMutation();\n    });\n  }\n\n  viewMutation() {\n    this.scrollShadow$$\n      .pipe(\n        switchMap(scrollShadow =>\n          scrollShadow\n            ? merge(\n                observeResizeOn(this.containerEl),\n                fromEvent(this.containerEl, 'scroll'),\n              ).pipe(startWith(null))\n            : NEVER,\n        ),\n      )\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(() => {\n        this.mutateVerticalScroll();\n        this.mutateHorizontalScroll();\n      });\n  }\n\n  mutateVerticalScroll() {\n    const scrollDis =\n      this.containerEl.scrollHeight - this.containerEl.offsetHeight;\n\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollDis > 0,\n      HAS_TABLE_VERTICAL_SCROLL,\n    );\n\n    const scrollTop = this.containerEl.scrollTop;\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollTop > 0,\n      HAS_TABLE_TOP_SHADOW,\n    );\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollTop < scrollDis,\n      HAS_TABLE_BOTTOM_SHADOW,\n    );\n\n    // 兼容屏幕缩放是 sticky多列的样式问题\n    this.table.updateStickyColumnStyles();\n  }\n\n  mutateHorizontalScroll() {\n    const scrollDis =\n      this.containerEl.scrollWidth - this.containerEl.offsetWidth;\n\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollDis > 0,\n      HAS_SCROLL_CLASS,\n    );\n\n    const scrollLeft = this.containerEl.scrollLeft;\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollLeft > 0,\n      SCROLLING_CLASS,\n    );\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollLeft < scrollDis,\n      SCROLL_BEFORE_END_CLASS,\n    );\n  }\n\n  placeClassList(\n    classList: DOMTokenList,\n    condition: boolean,\n    className: string,\n  ) {\n    classList[condition ? 'add' : 'remove'](className);\n  }\n\n  override ngOnDestroy() {\n    super.ngOnDestroy();\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n}\n"]}
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-scroll.directive.js","sourceRoot":"","sources":["../../../src/table/table-scroll.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directionality } from '@angular/cdk/bidi';\nimport { CdkScrollable, ScrollDispatcher } from '@angular/cdk/scrolling';\nimport {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  Host,\n  HostBinding,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Optional,\n} from '@angular/core';\nimport {\n  Subject,\n  fromEvent,\n  merge,\n  startWith,\n  takeUntil,\n  switchMap,\n  NEVER,\n  BehaviorSubject,\n} from 'rxjs';\n\nimport { coerceAttrBoolean, observeResizeOn } from '../utils';\n\nimport { TableComponent } from './table.component';\n\nconst CLASS_PREFIX = 'aui-table';\nconst SHADOW_CLASS = `${CLASS_PREFIX}__scroll-shadow`;\nconst HAS_SCROLL_CLASS = `${SHADOW_CLASS}--has-scroll`;\nconst SCROLLING_CLASS = `${SHADOW_CLASS}--scrolling`;\nconst SCROLL_BEFORE_END_CLASS = `${SHADOW_CLASS}--before-end`;\n\nconst HAS_TABLE_TOP_SHADOW = 'hasTableTopShadow';\nconst HAS_TABLE_BOTTOM_SHADOW = 'hasTableBottomShadow';\nconst HAS_TABLE_VERTICAL_SCROLL = 'hasTableVerticalScroll';\n\n@Directive({\n  selector: '[auiTableScrollWrapper]',\n  host: {\n    class: 'aui-table__scroll-wrapper',\n  },\n})\nexport class TableScrollWrapperDirective {\n  @HostBinding('style.max-height')\n  @Input()\n  auiTableScrollWrapper = '100%';\n}\n\n@Directive({\n  selector: '[auiTableScrollable]',\n  providers: [\n    { provide: CdkScrollable, useExisting: TableScrollableDirective },\n  ],\n})\nexport class TableScrollableDirective\n  extends CdkScrollable\n  implements AfterViewInit, OnInit, OnDestroy\n{\n  @Input('auiTableScrollable')\n  set scrollable(scrollable: boolean | '') {\n    this._scrollable = coerceAttrBoolean(scrollable);\n    this.scrollable$$.next(this._scrollable);\n  }\n\n  get scrollable() {\n    return this._scrollable;\n  }\n\n  private _scrollable = true;\n\n  scrollable$$ = new BehaviorSubject<boolean>(this._scrollable);\n  destroy$$ = new Subject<void>();\n\n  constructor(\n    private readonly el: ElementRef<HTMLElement>,\n    scrollDispatcher: ScrollDispatcher,\n    ngZone: NgZone,\n    @Host() private readonly table: TableComponent<unknown>,\n    @Optional() dir?: Directionality,\n  ) {\n    super(el, scrollDispatcher, ngZone, dir);\n  }\n\n  @HostBinding(`class.${SCROLL_BEFORE_END_CLASS}`)\n  SCROLL_BEFORE_END_CLASS = true;\n\n  @HostBinding(`class.${SHADOW_CLASS}`)\n  SHADOW_CLASS = true;\n\n  get containerEl() {\n    return this.el.nativeElement;\n  }\n\n  override ngOnInit() {\n    if (this.scrollable) {\n      this.scrollDispatcher.register(this);\n    }\n  }\n\n  ngAfterViewInit() {\n    this.viewMutation();\n  }\n\n  override ngOnDestroy() {\n    super.ngOnDestroy();\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n\n  viewMutation() {\n    this.scrollable$$\n      .pipe(\n        switchMap(scrollable => {\n          if (scrollable) {\n            this.scrollDispatcher.register(this);\n            return merge(\n              observeResizeOn(this.containerEl),\n              fromEvent(this.containerEl, 'scroll'),\n            ).pipe(startWith(null));\n          }\n\n          this.scrollDispatcher.deregister(this);\n          return NEVER;\n        }),\n      )\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(() => {\n        this.mutateVerticalScroll();\n        this.mutateHorizontalScroll();\n      });\n  }\n\n  mutateVerticalScroll() {\n    const scrollDis =\n      this.containerEl.scrollHeight - this.containerEl.offsetHeight;\n\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollDis > 0,\n      HAS_TABLE_VERTICAL_SCROLL,\n    );\n\n    const scrollTop = this.containerEl.scrollTop;\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollTop > 0,\n      HAS_TABLE_TOP_SHADOW,\n    );\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollTop < scrollDis,\n      HAS_TABLE_BOTTOM_SHADOW,\n    );\n\n    // 兼容屏幕缩放是 sticky多列的样式问题\n    this.table.updateStickyColumnStyles();\n  }\n\n  mutateHorizontalScroll() {\n    const scrollDis =\n      this.containerEl.scrollWidth - this.containerEl.offsetWidth;\n\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollDis > 0,\n      HAS_SCROLL_CLASS,\n    );\n\n    const scrollLeft = this.containerEl.scrollLeft;\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollLeft > 0,\n      SCROLLING_CLASS,\n    );\n    this.placeClassList(\n      this.containerEl.classList,\n      scrollLeft < scrollDis,\n      SCROLL_BEFORE_END_CLASS,\n    );\n  }\n\n  placeClassList(\n    classList: DOMTokenList,\n    condition: boolean,\n    className: string,\n  ) {\n    classList[condition ? 'add' : 'remove'](className);\n  }\n}\n"]}
|
package/fesm2015/alauda-ui.mjs
CHANGED
|
@@ -9150,27 +9150,45 @@ class TableScrollableDirective extends CdkScrollable$1 {
|
|
|
9150
9150
|
super(el, scrollDispatcher, ngZone, dir);
|
|
9151
9151
|
this.el = el;
|
|
9152
9152
|
this.table = table;
|
|
9153
|
-
this.
|
|
9153
|
+
this._scrollable = true;
|
|
9154
|
+
this.scrollable$$ = new BehaviorSubject(this._scrollable);
|
|
9154
9155
|
this.destroy$$ = new Subject();
|
|
9155
9156
|
this.SCROLL_BEFORE_END_CLASS = true;
|
|
9156
9157
|
this.SHADOW_CLASS = true;
|
|
9157
9158
|
}
|
|
9158
|
-
set
|
|
9159
|
-
this.
|
|
9159
|
+
set scrollable(scrollable) {
|
|
9160
|
+
this._scrollable = coerceAttrBoolean(scrollable);
|
|
9161
|
+
this.scrollable$$.next(this._scrollable);
|
|
9162
|
+
}
|
|
9163
|
+
get scrollable() {
|
|
9164
|
+
return this._scrollable;
|
|
9160
9165
|
}
|
|
9161
9166
|
get containerEl() {
|
|
9162
9167
|
return this.el.nativeElement;
|
|
9163
9168
|
}
|
|
9169
|
+
ngOnInit() {
|
|
9170
|
+
if (this.scrollable) {
|
|
9171
|
+
this.scrollDispatcher.register(this);
|
|
9172
|
+
}
|
|
9173
|
+
}
|
|
9164
9174
|
ngAfterViewInit() {
|
|
9165
|
-
|
|
9166
|
-
|
|
9167
|
-
|
|
9175
|
+
this.viewMutation();
|
|
9176
|
+
}
|
|
9177
|
+
ngOnDestroy() {
|
|
9178
|
+
super.ngOnDestroy();
|
|
9179
|
+
this.destroy$$.next();
|
|
9180
|
+
this.destroy$$.complete();
|
|
9168
9181
|
}
|
|
9169
9182
|
viewMutation() {
|
|
9170
|
-
this.
|
|
9171
|
-
.pipe(switchMap(
|
|
9172
|
-
|
|
9173
|
-
|
|
9183
|
+
this.scrollable$$
|
|
9184
|
+
.pipe(switchMap(scrollable => {
|
|
9185
|
+
if (scrollable) {
|
|
9186
|
+
this.scrollDispatcher.register(this);
|
|
9187
|
+
return merge(observeResizeOn(this.containerEl), fromEvent(this.containerEl, 'scroll')).pipe(startWith(null));
|
|
9188
|
+
}
|
|
9189
|
+
this.scrollDispatcher.deregister(this);
|
|
9190
|
+
return NEVER;
|
|
9191
|
+
}))
|
|
9174
9192
|
.pipe(takeUntil(this.destroy$$))
|
|
9175
9193
|
.subscribe(() => {
|
|
9176
9194
|
this.mutateVerticalScroll();
|
|
@@ -9196,14 +9214,9 @@ class TableScrollableDirective extends CdkScrollable$1 {
|
|
|
9196
9214
|
placeClassList(classList, condition, className) {
|
|
9197
9215
|
classList[condition ? 'add' : 'remove'](className);
|
|
9198
9216
|
}
|
|
9199
|
-
ngOnDestroy() {
|
|
9200
|
-
super.ngOnDestroy();
|
|
9201
|
-
this.destroy$$.next();
|
|
9202
|
-
this.destroy$$.complete();
|
|
9203
|
-
}
|
|
9204
9217
|
}
|
|
9205
9218
|
TableScrollableDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: TableScrollableDirective, deps: [{ token: i0.ElementRef }, { token: i1$1.ScrollDispatcher }, { token: i0.NgZone }, { token: TableComponent, host: true }, { token: i2$3.Directionality, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
|
|
9206
|
-
TableScrollableDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.8", type: TableScrollableDirective, selector: "[auiTableScrollable]", inputs: {
|
|
9219
|
+
TableScrollableDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.8", type: TableScrollableDirective, selector: "[auiTableScrollable]", inputs: { scrollable: ["auiTableScrollable", "scrollable"] }, host: { properties: { "class.aui-table__scroll-shadow--before-end": "this.SCROLL_BEFORE_END_CLASS", "class.aui-table__scroll-shadow": "this.SHADOW_CLASS" } }, providers: [
|
|
9207
9220
|
{ provide: CdkScrollable$1, useExisting: TableScrollableDirective },
|
|
9208
9221
|
], usesInheritance: true, ngImport: i0 });
|
|
9209
9222
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: TableScrollableDirective, decorators: [{
|
|
@@ -9220,8 +9233,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
9220
9233
|
}] }, { type: i2$3.Directionality, decorators: [{
|
|
9221
9234
|
type: Optional
|
|
9222
9235
|
}] }];
|
|
9223
|
-
}, propDecorators: {
|
|
9224
|
-
type: Input
|
|
9236
|
+
}, propDecorators: { scrollable: [{
|
|
9237
|
+
type: Input,
|
|
9238
|
+
args: ['auiTableScrollable']
|
|
9225
9239
|
}], SCROLL_BEFORE_END_CLASS: [{
|
|
9226
9240
|
type: HostBinding,
|
|
9227
9241
|
args: [`class.${SCROLL_BEFORE_END_CLASS}`]
|