@ng-nest/ui 15.0.12 → 15.0.14
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/anchor/anchor-inner.component.d.ts +6 -0
- package/anchor/anchor.component.d.ts +5 -2
- package/anchor/anchor.module.d.ts +5 -4
- package/anchor/anchor.property.d.ts +13 -0
- package/anchor/public-api.d.ts +1 -0
- package/core/config/config.d.ts +2 -0
- package/core/functions/date.d.ts +3 -0
- package/core/functions/parent-path.d.ts +1 -0
- package/core/functions/public-api.d.ts +1 -0
- package/date-picker/date-picker-portal.component.d.ts +7 -2
- package/date-picker/date-picker.property.d.ts +87 -6
- package/date-picker/date-range-portal.component.d.ts +6 -2
- package/date-picker/picker-date.component.d.ts +6 -0
- package/date-picker/picker-month.component.d.ts +1 -0
- package/date-picker/picker-year.component.d.ts +1 -0
- package/esm2020/anchor/anchor-inner.component.mjs +17 -0
- package/esm2020/anchor/anchor.component.mjs +25 -11
- package/esm2020/anchor/anchor.module.mjs +6 -5
- package/esm2020/anchor/anchor.property.mjs +18 -1
- package/esm2020/anchor/public-api.mjs +2 -1
- package/esm2020/core/config/config.mjs +1 -1
- package/esm2020/core/functions/date.mjs +73 -1
- package/esm2020/core/functions/parent-path.mjs +10 -0
- package/esm2020/core/functions/public-api.mjs +2 -1
- package/esm2020/date-picker/date-picker-portal.component.mjs +34 -6
- package/esm2020/date-picker/date-picker.component.mjs +14 -4
- package/esm2020/date-picker/date-picker.property.mjs +20 -6
- package/esm2020/date-picker/date-range-portal.component.mjs +33 -18
- package/esm2020/date-picker/date-range.component.mjs +24 -7
- package/esm2020/date-picker/picker-date.component.mjs +54 -6
- package/esm2020/date-picker/picker-month.component.mjs +13 -4
- package/esm2020/date-picker/picker-year.component.mjs +15 -4
- package/esm2020/i18n/i18n.property.mjs +1 -1
- package/esm2020/i18n/languages/en_GB.mjs +6 -2
- package/esm2020/i18n/languages/en_US.mjs +6 -2
- package/esm2020/i18n/languages/zh_CN.mjs +6 -2
- package/esm2020/i18n/languages/zh_TW.mjs +6 -2
- package/esm2020/list/list-option.component.mjs +2 -2
- package/esm2020/list/list.component.mjs +2 -2
- package/esm2020/slider/slider.component.mjs +3 -3
- package/esm2020/slider/slider.property.mjs +8 -2
- package/esm2020/table/table-body.component.mjs +6 -6
- package/esm2020/table/table.component.mjs +4 -3
- package/esm2020/table/table.property.mjs +9 -2
- package/esm2020/time-picker/time-picker-frame.component.mjs +48 -14
- package/esm2020/time-picker/time-picker-portal.component.mjs +3 -3
- package/esm2020/time-picker/time-picker.component.mjs +2 -1
- package/esm2020/time-picker/time-picker.property.mjs +4 -2
- package/esm2020/transfer/transfer.component.mjs +2 -2
- package/esm2020/tree/tree-node.component.mjs +98 -15
- package/esm2020/tree/tree.component.mjs +126 -29
- package/esm2020/tree/tree.module.mjs +31 -4
- package/esm2020/tree/tree.property.mjs +37 -3
- package/esm2020/tree/tree.service.mjs +77 -0
- package/esm2020/tree-file/tree-file.component.mjs +14 -3
- package/fesm2015/ng-nest-ui-anchor.mjs +60 -15
- package/fesm2015/ng-nest-ui-anchor.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-core.mjs +83 -1
- package/fesm2015/ng-nest-ui-core.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-date-picker.mjs +193 -42
- package/fesm2015/ng-nest-ui-date-picker.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-i18n.mjs +20 -4
- package/fesm2015/ng-nest-ui-i18n.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-list.mjs +4 -4
- package/fesm2015/ng-nest-ui-list.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-slider.mjs +9 -3
- package/fesm2015/ng-nest-ui-slider.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-table.mjs +16 -8
- package/fesm2015/ng-nest-ui-table.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-time-picker.mjs +53 -16
- package/fesm2015/ng-nest-ui-time-picker.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-transfer.mjs +1 -1
- package/fesm2015/ng-nest-ui-transfer.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-tree-file.mjs +13 -2
- package/fesm2015/ng-nest-ui-tree-file.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-tree.mjs +359 -45
- package/fesm2015/ng-nest-ui-tree.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-anchor.mjs +60 -15
- package/fesm2020/ng-nest-ui-anchor.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-core.mjs +83 -1
- package/fesm2020/ng-nest-ui-core.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-date-picker.mjs +193 -42
- package/fesm2020/ng-nest-ui-date-picker.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-i18n.mjs +20 -4
- package/fesm2020/ng-nest-ui-i18n.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-list.mjs +4 -4
- package/fesm2020/ng-nest-ui-list.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-slider.mjs +9 -3
- package/fesm2020/ng-nest-ui-slider.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-table.mjs +16 -8
- package/fesm2020/ng-nest-ui-table.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-time-picker.mjs +53 -16
- package/fesm2020/ng-nest-ui-time-picker.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-transfer.mjs +1 -1
- package/fesm2020/ng-nest-ui-transfer.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-tree-file.mjs +13 -2
- package/fesm2020/ng-nest-ui-tree-file.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-tree.mjs +356 -45
- package/fesm2020/ng-nest-ui-tree.mjs.map +1 -1
- package/i18n/i18n.property.d.ts +3 -0
- package/i18n/languages/en_GB.d.ts +4 -0
- package/i18n/languages/en_US.d.ts +4 -0
- package/i18n/languages/zh_CN.d.ts +4 -0
- package/i18n/languages/zh_TW.d.ts +4 -0
- package/package.json +1 -1
- package/slider/slider.property.d.ts +6 -1
- package/table/table.component.d.ts +1 -1
- package/table/table.property.d.ts +25 -4
- package/time-picker/time-picker-frame.component.d.ts +6 -2
- package/time-picker/time-picker-portal.component.d.ts +2 -1
- package/time-picker/time-picker.property.d.ts +32 -1
- package/transfer/transfer.component.d.ts +2 -4
- package/tree/tree-node.component.d.ts +35 -4
- package/tree/tree.component.d.ts +24 -3
- package/tree/tree.module.d.ts +8 -7
- package/tree/tree.property.d.ts +63 -1
- package/tree/tree.service.d.ts +10 -0
- package/tree-file/tree-file.component.d.ts +1 -0
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { XAnchorInnerProperty } from './anchor.property';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class XAnchorInnerComponent extends XAnchorInnerProperty {
|
|
4
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<XAnchorInnerComponent, never>;
|
|
5
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<XAnchorInnerComponent, "x-anchor-inner", never, {}, {}, never, ["*"], false, never>;
|
|
6
|
+
}
|
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
import { OnInit, Renderer2, ElementRef, ChangeDetectorRef, AfterViewInit, OnDestroy } from '@angular/core';
|
|
1
|
+
import { OnInit, Renderer2, ElementRef, ChangeDetectorRef, AfterViewInit, OnDestroy, AfterContentChecked } from '@angular/core';
|
|
2
2
|
import { XAnchorProperty } from './anchor.property';
|
|
3
3
|
import { XConfigService } from '@ng-nest/ui/core';
|
|
4
4
|
import { XSliderNode } from '@ng-nest/ui/slider';
|
|
5
|
+
import { Subject } from 'rxjs';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
|
-
export declare class XAnchorComponent extends XAnchorProperty implements OnInit, AfterViewInit, OnDestroy {
|
|
7
|
+
export declare class XAnchorComponent extends XAnchorProperty implements OnInit, AfterViewInit, OnDestroy, AfterContentChecked {
|
|
7
8
|
renderer: Renderer2;
|
|
8
9
|
elementRef: ElementRef<HTMLElement>;
|
|
9
10
|
cdr: ChangeDetectorRef;
|
|
@@ -15,10 +16,12 @@ export declare class XAnchorComponent extends XAnchorProperty implements OnInit,
|
|
|
15
16
|
activatedIndex: number;
|
|
16
17
|
sliderHeight?: number;
|
|
17
18
|
document: Document;
|
|
19
|
+
contentChange: Subject<unknown>;
|
|
18
20
|
private _scrolling;
|
|
19
21
|
private _fontSize;
|
|
20
22
|
private _unSubject;
|
|
21
23
|
constructor(renderer: Renderer2, elementRef: ElementRef<HTMLElement>, cdr: ChangeDetectorRef, doc: any, configService: XConfigService);
|
|
24
|
+
ngAfterContentChecked(): void;
|
|
22
25
|
ngOnInit(): void;
|
|
23
26
|
ngAfterViewInit(): void;
|
|
24
27
|
ngOnDestroy(): void;
|
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
import * as i0 from "@angular/core";
|
|
2
2
|
import * as i1 from "./anchor.component";
|
|
3
3
|
import * as i2 from "./anchor.property";
|
|
4
|
-
import * as i3 from "
|
|
5
|
-
import * as i4 from "@
|
|
6
|
-
import * as i5 from "@ng-nest/ui/
|
|
4
|
+
import * as i3 from "./anchor-inner.component";
|
|
5
|
+
import * as i4 from "@angular/common";
|
|
6
|
+
import * as i5 from "@ng-nest/ui/affix";
|
|
7
|
+
import * as i6 from "@ng-nest/ui/slider";
|
|
7
8
|
export declare class XAnchorModule {
|
|
8
9
|
static ɵfac: i0.ɵɵFactoryDeclaration<XAnchorModule, never>;
|
|
9
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<XAnchorModule, [typeof i1.XAnchorComponent, typeof i2.XAnchorProperty], [typeof
|
|
10
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<XAnchorModule, [typeof i1.XAnchorComponent, typeof i2.XAnchorProperty, typeof i3.XAnchorInnerComponent, typeof i2.XAnchorInnerProperty], [typeof i4.CommonModule, typeof i5.XAffixModule, typeof i6.XSliderModule], [typeof i1.XAnchorComponent, typeof i3.XAnchorInnerComponent]>;
|
|
10
11
|
static ɵinj: i0.ɵɵInjectorDeclaration<XAnchorModule>;
|
|
11
12
|
}
|
|
@@ -33,6 +33,19 @@ export declare class XAnchorProperty extends XProperty {
|
|
|
33
33
|
static ɵfac: i0.ɵɵFactoryDeclaration<XAnchorProperty, never>;
|
|
34
34
|
static ɵcmp: i0.ɵɵComponentDeclaration<XAnchorProperty, "ng-component", never, { "scroll": "scroll"; "affixTop": "affixTop"; "layout": "layout"; "justify": "justify"; }, {}, never, never, false, never>;
|
|
35
35
|
}
|
|
36
|
+
/**
|
|
37
|
+
* Anchor inner
|
|
38
|
+
* @selector x-anchor-inner
|
|
39
|
+
* @decorator component
|
|
40
|
+
*/
|
|
41
|
+
export declare const XAnchorInnerPrefix = "x-anchor-inner";
|
|
42
|
+
/**
|
|
43
|
+
* Anchor inner Property
|
|
44
|
+
*/
|
|
45
|
+
export declare class XAnchorInnerProperty {
|
|
46
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<XAnchorInnerProperty, never>;
|
|
47
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<XAnchorInnerProperty, "ng-component", never, {}, {}, never, never, false, never>;
|
|
48
|
+
}
|
|
36
49
|
/**
|
|
37
50
|
* Anchor Node
|
|
38
51
|
*/
|
package/anchor/public-api.d.ts
CHANGED
package/core/config/config.d.ts
CHANGED
|
@@ -425,6 +425,7 @@ export interface XSliderConfig {
|
|
|
425
425
|
animated?: XBoolean;
|
|
426
426
|
size?: XSize;
|
|
427
427
|
showExpand?: XBoolean;
|
|
428
|
+
autoShowArrow?: XBoolean;
|
|
428
429
|
}
|
|
429
430
|
export interface XSliderSelectConfig {
|
|
430
431
|
}
|
|
@@ -501,6 +502,7 @@ export interface XTreeConfig {
|
|
|
501
502
|
nodeAlignItems?: XAlign;
|
|
502
503
|
virtualScroll?: boolean;
|
|
503
504
|
onlyLeaf?: boolean;
|
|
505
|
+
showLine?: boolean;
|
|
504
506
|
}
|
|
505
507
|
export interface XTextareaConfig {
|
|
506
508
|
clearable?: XBoolean;
|
package/core/functions/date.d.ts
CHANGED
|
@@ -7,3 +7,6 @@ export declare function XAddHours(date: XDate, amount: number): Date;
|
|
|
7
7
|
export declare function XAddDays(date: XDate, amount: number): Date;
|
|
8
8
|
export declare function XAddMonths(date: XDate, amount: number): Date;
|
|
9
9
|
export declare function XAddYears(date: XDate, amount: number): Date;
|
|
10
|
+
export declare function XDateWeek(date: XDate): number | undefined;
|
|
11
|
+
export declare function XDateWeekYear(date: XDate): number | undefined;
|
|
12
|
+
export declare function XDateYearWeek(date: XDate): string | undefined;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function XParentPath(ele: HTMLElement): string[];
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import { ChangeDetectorRef, OnInit, OnDestroy, AfterViewInit } from '@angular/core';
|
|
2
|
-
import { XDatePickerPreset, XDatePickerType } from './date-picker.property';
|
|
2
|
+
import { XDatePickerDisabledDate, XDatePickerDisabledTime, XDatePickerPreset, XDatePickerType } from './date-picker.property';
|
|
3
3
|
import { XPositionTopBottom, XTemplate } from '@ng-nest/ui/core';
|
|
4
4
|
import { Subject } from 'rxjs';
|
|
5
5
|
import { DatePipe, LowerCasePipe } from '@angular/common';
|
|
6
6
|
import { XI18nService, XI18nDatePicker } from '@ng-nest/ui/i18n';
|
|
7
7
|
import { XInputComponent } from '@ng-nest/ui/input';
|
|
8
|
+
import { XTimePickerFrameComponent } from '@ng-nest/ui/time-picker';
|
|
8
9
|
import * as i0 from "@angular/core";
|
|
9
10
|
export declare class XDatePickerPortalComponent implements OnInit, OnDestroy, AfterViewInit {
|
|
10
11
|
datePipe: DatePipe;
|
|
@@ -16,6 +17,7 @@ export declare class XDatePickerPortalComponent implements OnInit, OnDestroy, Af
|
|
|
16
17
|
toState: any;
|
|
17
18
|
}): void;
|
|
18
19
|
start(): void;
|
|
20
|
+
timePickerFrame?: XTimePickerFrameComponent;
|
|
19
21
|
type: XDatePickerType;
|
|
20
22
|
display: Date;
|
|
21
23
|
model: Date;
|
|
@@ -27,13 +29,16 @@ export declare class XDatePickerPortalComponent implements OnInit, OnDestroy, Af
|
|
|
27
29
|
destroyPortal: Function;
|
|
28
30
|
nodeEmit: (date: Date, sure?: boolean) => void;
|
|
29
31
|
locale: XI18nDatePicker;
|
|
30
|
-
time: number;
|
|
32
|
+
time: number | null;
|
|
31
33
|
preset: XDatePickerPreset[];
|
|
32
34
|
extraFooter?: XTemplate;
|
|
33
35
|
inputCom: XInputComponent;
|
|
36
|
+
disabledDate: XDatePickerDisabledDate;
|
|
37
|
+
disabledTime: XDatePickerDisabledTime;
|
|
34
38
|
private _type;
|
|
35
39
|
private _unSubject;
|
|
36
40
|
get isDatePicker(): boolean;
|
|
41
|
+
get sureDisabled(): boolean;
|
|
37
42
|
constructor(datePipe: DatePipe, lowerCasePipe: LowerCasePipe, cdr: ChangeDetectorRef, i18n: XI18nService);
|
|
38
43
|
ngOnInit(): void;
|
|
39
44
|
ngAfterViewInit(): void;
|
|
@@ -52,13 +52,23 @@ export declare class XDatePickerProperty extends XControlValueAccessor<any> impl
|
|
|
52
52
|
* @en_US Footer
|
|
53
53
|
*/
|
|
54
54
|
extraFooter?: XTemplate;
|
|
55
|
+
/**
|
|
56
|
+
* @zh_CN 禁用的日期
|
|
57
|
+
* @en_US Disabled date
|
|
58
|
+
*/
|
|
59
|
+
disabledDate?: XDatePickerDisabledDate;
|
|
60
|
+
/**
|
|
61
|
+
* @zh_CN 禁用的时间
|
|
62
|
+
* @en_US Disabled time
|
|
63
|
+
*/
|
|
64
|
+
disabledTime?: XDatePickerDisabledTime;
|
|
55
65
|
/**
|
|
56
66
|
* @zh_CN 节点点击的事件
|
|
57
67
|
* @en_US Node click event
|
|
58
68
|
*/
|
|
59
69
|
nodeEmit: EventEmitter<number>;
|
|
60
70
|
static ɵfac: i0.ɵɵFactoryDeclaration<XDatePickerProperty, never>;
|
|
61
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<XDatePickerProperty, "ng-component", never, { "type": "type"; "format": "format"; "clearable": "clearable"; "placement": "placement"; "size": "size"; "bordered": "bordered"; "preset": "preset"; "extraFooter": "extraFooter"; }, { "nodeEmit": "nodeEmit"; }, never, never, false, never>;
|
|
71
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<XDatePickerProperty, "ng-component", never, { "type": "type"; "format": "format"; "clearable": "clearable"; "placement": "placement"; "size": "size"; "bordered": "bordered"; "preset": "preset"; "extraFooter": "extraFooter"; "disabledDate": "disabledDate"; "disabledTime": "disabledTime"; }, { "nodeEmit": "nodeEmit"; }, never, never, false, never>;
|
|
62
72
|
}
|
|
63
73
|
/**
|
|
64
74
|
* DatePicker Option
|
|
@@ -166,13 +176,23 @@ export declare class XDateRangeProperty extends XControlValueAccessor<any> imple
|
|
|
166
176
|
* @en_US Footer
|
|
167
177
|
*/
|
|
168
178
|
extraFooter?: XTemplate;
|
|
179
|
+
/**
|
|
180
|
+
* @zh_CN 禁用的日期
|
|
181
|
+
* @en_US Disabled date
|
|
182
|
+
*/
|
|
183
|
+
disabledDate?: XDatePickerDisabledDate;
|
|
184
|
+
/**
|
|
185
|
+
* @zh_CN 禁用的时间
|
|
186
|
+
* @en_US Disabled time
|
|
187
|
+
*/
|
|
188
|
+
disabledTime?: XDatePickerDisabledTime;
|
|
169
189
|
/**
|
|
170
190
|
* @zh_CN 节点点击的事件
|
|
171
191
|
* @en_US Node click event
|
|
172
192
|
*/
|
|
173
193
|
nodeEmit: EventEmitter<number[]>;
|
|
174
194
|
static ɵfac: i0.ɵɵFactoryDeclaration<XDateRangeProperty, never>;
|
|
175
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<XDateRangeProperty, "ng-component", never, { "type": "type"; "format": "format"; "clearable": "clearable"; "placement": "placement"; "size": "size"; "bordered": "bordered"; "preset": "preset"; "placeholder": "placeholder"; "extraFooter": "extraFooter"; }, { "nodeEmit": "nodeEmit"; }, never, never, false, never>;
|
|
195
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<XDateRangeProperty, "ng-component", never, { "type": "type"; "format": "format"; "clearable": "clearable"; "placement": "placement"; "size": "size"; "bordered": "bordered"; "preset": "preset"; "placeholder": "placeholder"; "extraFooter": "extraFooter"; "disabledDate": "disabledDate"; "disabledTime": "disabledTime"; }, { "nodeEmit": "nodeEmit"; }, never, never, false, never>;
|
|
176
196
|
}
|
|
177
197
|
/**
|
|
178
198
|
* DateRange Option
|
|
@@ -190,6 +210,37 @@ export interface XDateRangeOption extends XFormOption {
|
|
|
190
210
|
*/
|
|
191
211
|
placeholder?: string[];
|
|
192
212
|
}
|
|
213
|
+
/**
|
|
214
|
+
* @zh_CN 禁用日期的自定义类型
|
|
215
|
+
* @en_US 禁用日期的自定义类型
|
|
216
|
+
*/
|
|
217
|
+
export declare type XDatePickerDisabledDate = (current: Date) => boolean;
|
|
218
|
+
/**
|
|
219
|
+
* @zh_CN 禁用时间的自定义类型
|
|
220
|
+
* @en_US 禁用时间的自定义类型
|
|
221
|
+
*/
|
|
222
|
+
export declare type XDatePickerDisabledTime = (type?: XDatePickerRangType) => XDatePickerDisabledTimeFn;
|
|
223
|
+
/**
|
|
224
|
+
* @zh_CN 禁用时间的自定义函数
|
|
225
|
+
* @en_US 禁用时间的自定义函数
|
|
226
|
+
*/
|
|
227
|
+
export declare type XDatePickerDisabledTimeFn = {
|
|
228
|
+
/**
|
|
229
|
+
* @zh_CN 禁用小时的自定义函数
|
|
230
|
+
* @en_US 禁用小时的自定义函数
|
|
231
|
+
*/
|
|
232
|
+
disabledHours?: () => number[];
|
|
233
|
+
/**
|
|
234
|
+
* @zh_CN 禁用分钟的自定义函数
|
|
235
|
+
* @en_US 禁用分钟的自定义函数
|
|
236
|
+
*/
|
|
237
|
+
disabledMinutes?: () => number[];
|
|
238
|
+
/**
|
|
239
|
+
* @zh_CN 禁用秒的自定义函数
|
|
240
|
+
* @en_US 禁用秒的自定义函数
|
|
241
|
+
*/
|
|
242
|
+
disabledSeconds?: () => number[];
|
|
243
|
+
};
|
|
193
244
|
/**
|
|
194
245
|
* @zh_CN 快捷选择按钮
|
|
195
246
|
* @en_US Quick selection button
|
|
@@ -216,7 +267,7 @@ export interface XDateRangePreset extends XIdentityProperty {
|
|
|
216
267
|
* @zh_CN 日期选择类型
|
|
217
268
|
* @en_US Date selection type
|
|
218
269
|
*/
|
|
219
|
-
export declare type XDatePickerType = 'date' | 'month' | 'year' | 'date-time' | 'date-hour' | 'date-minute';
|
|
270
|
+
export declare type XDatePickerType = 'date' | 'week' | 'month' | 'year' | 'date-time' | 'date-hour' | 'date-minute';
|
|
220
271
|
/**
|
|
221
272
|
* @zh_CN 日期数据类型
|
|
222
273
|
* @en_US Date data type
|
|
@@ -309,6 +360,11 @@ export declare class XPickerDateProperty extends XProperty {
|
|
|
309
360
|
* @en_US The current choice is the start / end date
|
|
310
361
|
*/
|
|
311
362
|
rangeType: XDatePickerRangType;
|
|
363
|
+
/**
|
|
364
|
+
* @zh_CN 禁用的日期
|
|
365
|
+
* @en_US Disabled date
|
|
366
|
+
*/
|
|
367
|
+
disabledDate?: XDatePickerDisabledDate;
|
|
312
368
|
/**
|
|
313
369
|
* @zh_CN 选择类型
|
|
314
370
|
* @en_US Select type
|
|
@@ -355,7 +411,7 @@ export declare class XPickerDateProperty extends XProperty {
|
|
|
355
411
|
*/
|
|
356
412
|
rangeDateClick: EventEmitter<XDateCell>;
|
|
357
413
|
static ɵfac: i0.ɵɵFactoryDeclaration<XPickerDateProperty, never>;
|
|
358
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<XPickerDateProperty, "ng-component", never, { "type": "type"; "display": "display"; "model": "model"; "dateTemp": "dateTemp"; "showHeader": "showHeader"; "rangePicker": "rangePicker"; "lastYearBtn": "lastYearBtn"; "lastMonthBtn": "lastMonthBtn"; "nextYearBtn": "nextYearBtn"; "nextMonthBtn": "nextMonthBtn"; "rangeHover": "rangeHover"; "rangeValue": "rangeValue"; "rangeType": "rangeType"; }, { "typeChange": "typeChange"; "modelChange": "modelChange"; "rangeChange": "rangeChange"; "yearChange": "yearChange"; "monthChange": "monthChange"; "displayChange": "displayChange"; "rangeTdMouseenter": "rangeTdMouseenter"; "rangeTdMouseleave": "rangeTdMouseleave"; "rangeDateClick": "rangeDateClick"; }, never, never, false, never>;
|
|
414
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<XPickerDateProperty, "ng-component", never, { "type": "type"; "display": "display"; "model": "model"; "dateTemp": "dateTemp"; "showHeader": "showHeader"; "rangePicker": "rangePicker"; "lastYearBtn": "lastYearBtn"; "lastMonthBtn": "lastMonthBtn"; "nextYearBtn": "nextYearBtn"; "nextMonthBtn": "nextMonthBtn"; "rangeHover": "rangeHover"; "rangeValue": "rangeValue"; "rangeType": "rangeType"; "disabledDate": "disabledDate"; }, { "typeChange": "typeChange"; "modelChange": "modelChange"; "rangeChange": "rangeChange"; "yearChange": "yearChange"; "monthChange": "monthChange"; "displayChange": "displayChange"; "rangeTdMouseenter": "rangeTdMouseenter"; "rangeTdMouseleave": "rangeTdMouseleave"; "rangeDateClick": "rangeDateClick"; }, never, never, false, never>;
|
|
359
415
|
}
|
|
360
416
|
/**
|
|
361
417
|
* @zh_CN 单个日期数据对象
|
|
@@ -467,6 +523,21 @@ export interface XDateCell {
|
|
|
467
523
|
* @en_US Current selected date
|
|
468
524
|
*/
|
|
469
525
|
isActive?: boolean;
|
|
526
|
+
/**
|
|
527
|
+
* @zh_CN 禁用日期
|
|
528
|
+
* @en_US Disabled date
|
|
529
|
+
*/
|
|
530
|
+
isDisabled?: boolean;
|
|
531
|
+
/**
|
|
532
|
+
* @zh_CN 类型
|
|
533
|
+
* @en_US Type
|
|
534
|
+
*/
|
|
535
|
+
type?: XDatePickerType;
|
|
536
|
+
/**
|
|
537
|
+
* @zh_CN 第几周
|
|
538
|
+
* @en_US Week
|
|
539
|
+
*/
|
|
540
|
+
week?: number;
|
|
470
541
|
}
|
|
471
542
|
/**
|
|
472
543
|
* @zh_CN 当前选择的是开始/结束日期
|
|
@@ -533,6 +604,11 @@ export declare class XPickerMonthProperty extends XProperty {
|
|
|
533
604
|
* @en_US The current choice is the start / end date
|
|
534
605
|
*/
|
|
535
606
|
rangeType: XDatePickerRangType;
|
|
607
|
+
/**
|
|
608
|
+
* @zh_CN 禁用的日期
|
|
609
|
+
* @en_US Disabled date
|
|
610
|
+
*/
|
|
611
|
+
disabledDate?: XDatePickerDisabledDate;
|
|
536
612
|
/**
|
|
537
613
|
* @zh_CN 选中的事件
|
|
538
614
|
* @en_US Selected event
|
|
@@ -579,7 +655,7 @@ export declare class XPickerMonthProperty extends XProperty {
|
|
|
579
655
|
*/
|
|
580
656
|
rangeDateClick: EventEmitter<XDateCell>;
|
|
581
657
|
static ɵfac: i0.ɵɵFactoryDeclaration<XPickerMonthProperty, never>;
|
|
582
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<XPickerMonthProperty, "ng-component", never, { "type": "type"; "display": "display"; "model": "model"; "monthTemp": "monthTemp"; "showHeader": "showHeader"; "rangePicker": "rangePicker"; "lastYearBtn": "lastYearBtn"; "nextYearBtn": "nextYearBtn"; "rangeValue": "rangeValue"; "rangeType": "rangeType"; }, { "modelChange": "modelChange"; "typeChange": "typeChange"; "rangeChange": "rangeChange"; "yearChange": "yearChange"; "monthChange": "monthChange"; "displayChange": "displayChange"; "rangeTdMouseenter": "rangeTdMouseenter"; "rangeTdMouseleave": "rangeTdMouseleave"; "rangeDateClick": "rangeDateClick"; }, never, never, false, never>;
|
|
658
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<XPickerMonthProperty, "ng-component", never, { "type": "type"; "display": "display"; "model": "model"; "monthTemp": "monthTemp"; "showHeader": "showHeader"; "rangePicker": "rangePicker"; "lastYearBtn": "lastYearBtn"; "nextYearBtn": "nextYearBtn"; "rangeValue": "rangeValue"; "rangeType": "rangeType"; "disabledDate": "disabledDate"; }, { "modelChange": "modelChange"; "typeChange": "typeChange"; "rangeChange": "rangeChange"; "yearChange": "yearChange"; "monthChange": "monthChange"; "displayChange": "displayChange"; "rangeTdMouseenter": "rangeTdMouseenter"; "rangeTdMouseleave": "rangeTdMouseleave"; "rangeDateClick": "rangeDateClick"; }, never, never, false, never>;
|
|
583
659
|
}
|
|
584
660
|
/**
|
|
585
661
|
* PickerYear
|
|
@@ -641,6 +717,11 @@ export declare class XPickerYearProperty extends XProperty {
|
|
|
641
717
|
* @en_US The current choice is the start / end date
|
|
642
718
|
*/
|
|
643
719
|
rangeType: XDatePickerRangType;
|
|
720
|
+
/**
|
|
721
|
+
* @zh_CN 禁用的日期
|
|
722
|
+
* @en_US Disabled date
|
|
723
|
+
*/
|
|
724
|
+
disabledDate?: XDatePickerDisabledDate;
|
|
644
725
|
/**
|
|
645
726
|
* @zh_CN 选中的事件
|
|
646
727
|
* @en_US Selected event
|
|
@@ -692,5 +773,5 @@ export declare class XPickerYearProperty extends XProperty {
|
|
|
692
773
|
*/
|
|
693
774
|
rangeDateClick: EventEmitter<XDateCell>;
|
|
694
775
|
static ɵfac: i0.ɵɵFactoryDeclaration<XPickerYearProperty, never>;
|
|
695
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<XPickerYearProperty, "ng-component", never, { "type": "type"; "display": "display"; "model": "model"; "yearTemp": "yearTemp"; "showHeader": "showHeader"; "rangePicker": "rangePicker"; "lastYearBtn": "lastYearBtn"; "nextYearBtn": "nextYearBtn"; "rangeValue": "rangeValue"; "rangeType": "rangeType"; }, { "modelChange": "modelChange"; "typeChange": "typeChange"; "startChange": "startChange"; "rangeChange": "rangeChange"; "yearChange": "yearChange"; "monthChange": "monthChange"; "displayChange": "displayChange"; "rangeTdMouseenter": "rangeTdMouseenter"; "rangeTdMouseleave": "rangeTdMouseleave"; "rangeDateClick": "rangeDateClick"; }, never, never, false, never>;
|
|
776
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<XPickerYearProperty, "ng-component", never, { "type": "type"; "display": "display"; "model": "model"; "yearTemp": "yearTemp"; "showHeader": "showHeader"; "rangePicker": "rangePicker"; "lastYearBtn": "lastYearBtn"; "nextYearBtn": "nextYearBtn"; "rangeValue": "rangeValue"; "rangeType": "rangeType"; "disabledDate": "disabledDate"; }, { "modelChange": "modelChange"; "typeChange": "typeChange"; "startChange": "startChange"; "rangeChange": "rangeChange"; "yearChange": "yearChange"; "monthChange": "monthChange"; "displayChange": "displayChange"; "rangeTdMouseenter": "rangeTdMouseenter"; "rangeTdMouseleave": "rangeTdMouseleave"; "rangeDateClick": "rangeDateClick"; }, never, never, false, never>;
|
|
696
777
|
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ChangeDetectorRef, OnInit, OnDestroy, AfterViewInit } from '@angular/core';
|
|
2
|
-
import { XDatePickerType, XDateCell, XDateRangePreset } from './date-picker.property';
|
|
2
|
+
import { XDatePickerType, XDateCell, XDateRangePreset, XDatePickerDisabledDate, XDatePickerDisabledTime } from './date-picker.property';
|
|
3
3
|
import { XPositionTopBottom, XTemplate } from '@ng-nest/ui/core';
|
|
4
4
|
import { Subject } from 'rxjs';
|
|
5
5
|
import { DatePipe, LowerCasePipe } from '@angular/common';
|
|
@@ -7,6 +7,7 @@ import { XI18nService, XI18nDatePicker } from '@ng-nest/ui/i18n';
|
|
|
7
7
|
import { XPickerMonthComponent } from './picker-month.component';
|
|
8
8
|
import { XPickerYearComponent } from './picker-year.component';
|
|
9
9
|
import { XPickerDateComponent } from './picker-date.component';
|
|
10
|
+
import { XTimePickerFrameComponent } from '@ng-nest/ui/time-picker';
|
|
10
11
|
import * as i0 from "@angular/core";
|
|
11
12
|
export declare class XDateRangePortalComponent implements OnInit, OnDestroy, AfterViewInit {
|
|
12
13
|
datePipe: DatePipe;
|
|
@@ -20,6 +21,7 @@ export declare class XDateRangePortalComponent implements OnInit, OnDestroy, Aft
|
|
|
20
21
|
start(): void;
|
|
21
22
|
startPicker: XPickerDateComponent | XPickerMonthComponent | XPickerYearComponent;
|
|
22
23
|
endPicker: XPickerDateComponent | XPickerMonthComponent | XPickerYearComponent;
|
|
24
|
+
timePickerFrame?: XTimePickerFrameComponent;
|
|
23
25
|
type: XDatePickerType;
|
|
24
26
|
display: Date;
|
|
25
27
|
model: Date;
|
|
@@ -36,6 +38,8 @@ export declare class XDateRangePortalComponent implements OnInit, OnDestroy, Aft
|
|
|
36
38
|
animating: Function;
|
|
37
39
|
closePortal: Function;
|
|
38
40
|
destroyPortal: Function;
|
|
41
|
+
disabledDate: XDatePickerDisabledDate;
|
|
42
|
+
disabledTime: XDatePickerDisabledTime;
|
|
39
43
|
nodeEmit: (date: Date[], close?: boolean) => void;
|
|
40
44
|
startNodeEmit: (date: Date | null, close?: boolean, isDatePicker?: boolean) => void;
|
|
41
45
|
endNodeEmit: (date: Date | null, close?: boolean, isDatePicker?: boolean) => void;
|
|
@@ -48,8 +52,8 @@ export declare class XDateRangePortalComponent implements OnInit, OnDestroy, Aft
|
|
|
48
52
|
preset: XDateRangePreset[];
|
|
49
53
|
extraFooter?: XTemplate;
|
|
50
54
|
private _unSubject;
|
|
51
|
-
get timeSureDisabled(): boolean;
|
|
52
55
|
get isDatePicker(): boolean;
|
|
56
|
+
get sureDisabled(): boolean;
|
|
53
57
|
constructor(datePipe: DatePipe, lowerCasePipe: LowerCasePipe, cdr: ChangeDetectorRef, i18n: XI18nService);
|
|
54
58
|
ngOnInit(): void;
|
|
55
59
|
ngAfterViewInit(): void;
|
|
@@ -20,14 +20,20 @@ export declare class XPickerDateComponent extends XPickerDateProperty implements
|
|
|
20
20
|
private _unSubject;
|
|
21
21
|
get rangeStart(): number | "" | null;
|
|
22
22
|
get rangeEnd(): number | "" | null;
|
|
23
|
+
isWeekRange(): import("@ng-nest/ui/core").XBoolean | undefined;
|
|
24
|
+
isDisabled(date: Date): boolean;
|
|
23
25
|
constructor(renderer: Renderer2, datePipe: DatePipe, lowerCasePipe: LowerCasePipe, cdr: ChangeDetectorRef, configService: XConfigService, i18n: XI18nService);
|
|
24
26
|
ngOnInit(): void;
|
|
25
27
|
ngOnChanges(simples: SimpleChanges): void;
|
|
26
28
|
ngOnDestroy(): void;
|
|
27
29
|
init(): void;
|
|
30
|
+
isWeekActive(week: XDateCell[]): boolean;
|
|
31
|
+
isStartWeek(week: XDateCell[]): boolean | undefined;
|
|
32
|
+
isEndWeek(week: XDateCell[]): boolean | undefined;
|
|
28
33
|
isStartDate(date: Date): boolean | undefined;
|
|
29
34
|
isEndDate(date: Date): boolean | undefined;
|
|
30
35
|
setDatesState(cell: XDateCell): void;
|
|
36
|
+
setTitles(): void;
|
|
31
37
|
onTdMouseenter(cell: XDateCell, isEmit?: boolean): void;
|
|
32
38
|
onTdMouseleave(cell: XDateCell, isEmit?: boolean): void;
|
|
33
39
|
clearState(...cells: XDateCell[]): void;
|
|
@@ -18,6 +18,7 @@ export declare class XPickerMonthComponent extends XPickerMonthProperty implemen
|
|
|
18
18
|
private _unSubject;
|
|
19
19
|
get rangeStart(): number | "" | null;
|
|
20
20
|
get rangeEnd(): number | "" | null;
|
|
21
|
+
isDisabled(date: Date): boolean;
|
|
21
22
|
constructor(renderer: Renderer2, datePipe: DatePipe, lowerCasePipe: LowerCasePipe, cdr: ChangeDetectorRef, configService: XConfigService, i18n: XI18nService);
|
|
22
23
|
ngOnInit(): void;
|
|
23
24
|
ngOnChanges(simples: SimpleChanges): void;
|
|
@@ -15,6 +15,7 @@ export declare class XPickerYearComponent extends XPickerYearProperty implements
|
|
|
15
15
|
end: number;
|
|
16
16
|
get rangeStart(): number | "" | null;
|
|
17
17
|
get rangeEnd(): number | "" | null;
|
|
18
|
+
isDisabled(date: Date): boolean;
|
|
18
19
|
constructor(renderer: Renderer2, cdr: ChangeDetectorRef, datePipe: DatePipe, configService: XConfigService);
|
|
19
20
|
ngOnChanges(simples: SimpleChanges): void;
|
|
20
21
|
init(): void;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import { XAnchorInnerPrefix, XAnchorInnerProperty } from './anchor.property';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class XAnchorInnerComponent extends XAnchorInnerProperty {
|
|
5
|
+
}
|
|
6
|
+
/** @nocollapse */ XAnchorInnerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XAnchorInnerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
7
|
+
/** @nocollapse */ XAnchorInnerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XAnchorInnerComponent, selector: "x-anchor-inner", usesInheritance: true, ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
8
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XAnchorInnerComponent, decorators: [{
|
|
9
|
+
type: Component,
|
|
10
|
+
args: [{
|
|
11
|
+
selector: `${XAnchorInnerPrefix}`,
|
|
12
|
+
template: '<ng-content></ng-content>',
|
|
13
|
+
encapsulation: ViewEncapsulation.None,
|
|
14
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
15
|
+
}]
|
|
16
|
+
}] });
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5jaG9yLWlubmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYi9uZy1uZXN0L3VpL2FuY2hvci9hbmNob3ItaW5uZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdEYsT0FBTyxFQUFFLGtCQUFrQixFQUFFLG9CQUFvQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7O0FBUTdFLE1BQU0sT0FBTyxxQkFBc0IsU0FBUSxvQkFBb0I7O3FJQUFsRCxxQkFBcUI7eUhBQXJCLHFCQUFxQiw2RUFKdEIsMkJBQTJCOzJGQUkxQixxQkFBcUI7a0JBTmpDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLEdBQUcsa0JBQWtCLEVBQUU7b0JBQ2pDLFFBQVEsRUFBRSwyQkFBMkI7b0JBQ3JDLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO29CQUNyQyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBYQW5jaG9ySW5uZXJQcmVmaXgsIFhBbmNob3JJbm5lclByb3BlcnR5IH0gZnJvbSAnLi9hbmNob3IucHJvcGVydHknO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IGAke1hBbmNob3JJbm5lclByZWZpeH1gLFxyXG4gIHRlbXBsYXRlOiAnPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PicsXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgWEFuY2hvcklubmVyQ29tcG9uZW50IGV4dGVuZHMgWEFuY2hvcklubmVyUHJvcGVydHkge31cclxuIl19
|
|
@@ -3,7 +3,7 @@ import { XAnchorPrefix, XAnchorProperty } from './anchor.property';
|
|
|
3
3
|
import { computedStyle, XIsEmpty, reqAnimFrame, XIsNumber, XIsUndefined } from '@ng-nest/ui/core';
|
|
4
4
|
import { DOCUMENT } from '@angular/common';
|
|
5
5
|
import { fromEvent, Subject } from 'rxjs';
|
|
6
|
-
import { throttleTime, takeUntil } from 'rxjs/operators';
|
|
6
|
+
import { throttleTime, takeUntil, distinctUntilChanged } from 'rxjs/operators';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
import * as i1 from "@ng-nest/ui/core";
|
|
9
9
|
import * as i2 from "@angular/common";
|
|
@@ -18,11 +18,15 @@ export class XAnchorComponent extends XAnchorProperty {
|
|
|
18
18
|
this.configService = configService;
|
|
19
19
|
this.sliderData = [];
|
|
20
20
|
this.activatedIndex = 0;
|
|
21
|
+
this.contentChange = new Subject();
|
|
21
22
|
this._scrolling = false;
|
|
22
23
|
this._unSubject = new Subject();
|
|
23
24
|
this.document = doc;
|
|
24
25
|
this._fontSize = parseFloat(computedStyle(this.document.documentElement, 'font-size'));
|
|
25
26
|
}
|
|
27
|
+
ngAfterContentChecked() {
|
|
28
|
+
this.contentChange.next(this.elementRef.nativeElement.innerHTML);
|
|
29
|
+
}
|
|
26
30
|
ngOnInit() {
|
|
27
31
|
this.setClassMap();
|
|
28
32
|
this.setSliderData();
|
|
@@ -30,6 +34,11 @@ export class XAnchorComponent extends XAnchorProperty {
|
|
|
30
34
|
}
|
|
31
35
|
ngAfterViewInit() {
|
|
32
36
|
this.setScroll();
|
|
37
|
+
this.contentChange.pipe(distinctUntilChanged(), takeUntil(this._unSubject)).subscribe(() => {
|
|
38
|
+
this.setSliderData();
|
|
39
|
+
this.setHeight();
|
|
40
|
+
this.cdr.detectChanges();
|
|
41
|
+
});
|
|
33
42
|
}
|
|
34
43
|
ngOnDestroy() {
|
|
35
44
|
this._unSubject.next();
|
|
@@ -74,7 +83,7 @@ export class XAnchorComponent extends XAnchorProperty {
|
|
|
74
83
|
this.cdr.detectChanges();
|
|
75
84
|
}
|
|
76
85
|
setSliderData() {
|
|
77
|
-
this.hElements = this.content.nativeElement.querySelectorAll(':scope> h1,:scope> h2,:scope> h3,:scope> h4,:scope> h5');
|
|
86
|
+
this.hElements = this.content.nativeElement.querySelectorAll(':scope> h1,:scope> h2,:scope> h3,:scope> h4,:scope> h5,:scope> x-anchor-inner> h1,:scope> x-anchor-inner>h2,:scope> x-anchor-inner>h3,:scope> x-anchor-inner>h4,:scope> x-anchor-inner>h5');
|
|
78
87
|
if (this.hElements.length > 0) {
|
|
79
88
|
let list = [];
|
|
80
89
|
this.hElements.forEach((x, i) => {
|
|
@@ -101,12 +110,17 @@ export class XAnchorComponent extends XAnchorProperty {
|
|
|
101
110
|
}
|
|
102
111
|
setHeight() {
|
|
103
112
|
if (this.scroll) {
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
113
|
+
if (XIsEmpty(this.sliderData)) {
|
|
114
|
+
this.sliderHeight = 0;
|
|
115
|
+
}
|
|
116
|
+
else {
|
|
117
|
+
let height = this.scroll.offsetHeight;
|
|
118
|
+
let top = parseFloat(computedStyle(this.scroll, 'padding-top'));
|
|
119
|
+
let borderTop = parseFloat(computedStyle(this.scroll, 'border-top'));
|
|
120
|
+
let bottom = parseFloat(computedStyle(this.scroll, 'padding-bottom'));
|
|
121
|
+
let borderBottom = parseFloat(computedStyle(this.scroll, 'border-bottom'));
|
|
122
|
+
this.sliderHeight = height - top - bottom - borderTop - borderBottom - this.getTop();
|
|
123
|
+
}
|
|
110
124
|
}
|
|
111
125
|
}
|
|
112
126
|
getTop() {
|
|
@@ -136,10 +150,10 @@ export class XAnchorComponent extends XAnchorProperty {
|
|
|
136
150
|
}
|
|
137
151
|
}
|
|
138
152
|
/** @nocollapse */ XAnchorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XAnchorComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: DOCUMENT }, { token: i1.XConfigService }], target: i0.ɵɵFactoryTarget.Component });
|
|
139
|
-
/** @nocollapse */ XAnchorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XAnchorComponent, selector: "x-anchor", viewQueries: [{ propertyName: "anchor", first: true, predicate: ["anchor"], descendants: true, static: true }, { propertyName: "content", first: true, predicate: ["content"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div #anchor class=\"x-anchor\" [ngClass]=\"classMap\">\r\n <div #content class=\"x-anchor-content\">\r\n <ng-content></ng-content>\r\n </div>\r\n <x-affix class=\"x-anchor-affix\" [top]=\"affixTop\">\r\n <div class=\"x-anchor-slider\" [style.height.px]=\"sliderHeight\">\r\n <x-slider\r\n [data]=\"sliderData\"\r\n layout=\"column\"\r\n [activatedIndex]=\"activatedIndex\"\r\n [nodeJustify]=\"justify\"\r\n [nodeTpl]=\"sliderNodeTpl\"\r\n [showAnchor]=\"true\"\r\n (indexChange)=\"activatedChange($event)\"\r\n ></x-slider>\r\n </div>\r\n </x-affix>\r\n</div>\r\n\r\n<ng-template #sliderNodeTpl let-node=\"$node\">\r\n <span [style.padding-left.rem]=\"node.left - 1\">{{ node.label }}</span>\r\n</ng-template>\r\n", styles: [".x-anchor{margin:0;padding:0;display:flex}.x-anchor-content{flex:1}.x-anchor-affix{display:block}.x-anchor-slider{float:left
|
|
153
|
+
/** @nocollapse */ XAnchorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XAnchorComponent, selector: "x-anchor", viewQueries: [{ propertyName: "anchor", first: true, predicate: ["anchor"], descendants: true, static: true }, { propertyName: "content", first: true, predicate: ["content"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div #anchor class=\"x-anchor\" [ngClass]=\"classMap\">\r\n <div #content class=\"x-anchor-content\">\r\n <ng-content></ng-content>\r\n </div>\r\n <x-affix class=\"x-anchor-affix\" [top]=\"affixTop\">\r\n <div class=\"x-anchor-slider\" [style.height.px]=\"sliderHeight\">\r\n <x-slider\r\n [data]=\"sliderData\"\r\n layout=\"column\"\r\n [activatedIndex]=\"activatedIndex\"\r\n [nodeJustify]=\"justify\"\r\n [nodeTpl]=\"sliderNodeTpl\"\r\n [showAnchor]=\"true\"\r\n (indexChange)=\"activatedChange($event)\"\r\n ></x-slider>\r\n </div>\r\n </x-affix>\r\n</div>\r\n\r\n<ng-template #sliderNodeTpl let-node=\"$node\">\r\n <span [style.padding-left.rem]=\"node.left - 1\">{{ node.label }}</span>\r\n</ng-template>\r\n", styles: [".x-anchor{margin:0;padding:0;display:flex}.x-anchor-content{flex:1}.x-anchor-affix{display:block}.x-anchor-slider{float:left}.x-anchor-slider:hover{overflow-y:auto}.x-anchor-slider .x-slider{overflow:hidden}.x-anchor-right{flex-direction:row}.x-anchor-right .x-anchor-slider .x-slider-column>.x-slider-scroll{overflow-y:auto}.x-anchor-right .x-anchor-slider .x-slider-column>.x-slider-scroll>ul>li{border-left:.125rem solid var(--x-border)}.x-anchor-right .x-anchor-slider .x-slider-column>.x-slider-scroll>ul>li.x-slider-highlight{border:none;border-top-left-radius:0;border-bottom-left-radius:0;z-index:2;border-left:.125rem solid var(--x-primary)}.x-anchor-left{flex-direction:row-reverse}.x-anchor-left .x-anchor-slider .x-slider-column>.x-slider-scroll{overflow-y:auto}.x-anchor-left .x-anchor-slider .x-slider-column>.x-slider-scroll>ul>li{border-right:.125rem solid var(--x-border)}.x-anchor-left .x-anchor-slider .x-slider-column>.x-slider-scroll>ul>li.x-slider-highlight{border:none;border-top-right-radius:0;border-bottom-right-radius:0;z-index:2;border-right:.125rem solid var(--x-primary)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i3.XAffixComponent, selector: "x-affix" }, { kind: "component", type: i4.XSliderComponent, selector: "x-slider" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
140
154
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XAnchorComponent, decorators: [{
|
|
141
155
|
type: Component,
|
|
142
|
-
args: [{ selector: `${XAnchorPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #anchor class=\"x-anchor\" [ngClass]=\"classMap\">\r\n <div #content class=\"x-anchor-content\">\r\n <ng-content></ng-content>\r\n </div>\r\n <x-affix class=\"x-anchor-affix\" [top]=\"affixTop\">\r\n <div class=\"x-anchor-slider\" [style.height.px]=\"sliderHeight\">\r\n <x-slider\r\n [data]=\"sliderData\"\r\n layout=\"column\"\r\n [activatedIndex]=\"activatedIndex\"\r\n [nodeJustify]=\"justify\"\r\n [nodeTpl]=\"sliderNodeTpl\"\r\n [showAnchor]=\"true\"\r\n (indexChange)=\"activatedChange($event)\"\r\n ></x-slider>\r\n </div>\r\n </x-affix>\r\n</div>\r\n\r\n<ng-template #sliderNodeTpl let-node=\"$node\">\r\n <span [style.padding-left.rem]=\"node.left - 1\">{{ node.label }}</span>\r\n</ng-template>\r\n", styles: [".x-anchor{margin:0;padding:0;display:flex}.x-anchor-content{flex:1}.x-anchor-affix{display:block}.x-anchor-slider{float:left
|
|
156
|
+
args: [{ selector: `${XAnchorPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #anchor class=\"x-anchor\" [ngClass]=\"classMap\">\r\n <div #content class=\"x-anchor-content\">\r\n <ng-content></ng-content>\r\n </div>\r\n <x-affix class=\"x-anchor-affix\" [top]=\"affixTop\">\r\n <div class=\"x-anchor-slider\" [style.height.px]=\"sliderHeight\">\r\n <x-slider\r\n [data]=\"sliderData\"\r\n layout=\"column\"\r\n [activatedIndex]=\"activatedIndex\"\r\n [nodeJustify]=\"justify\"\r\n [nodeTpl]=\"sliderNodeTpl\"\r\n [showAnchor]=\"true\"\r\n (indexChange)=\"activatedChange($event)\"\r\n ></x-slider>\r\n </div>\r\n </x-affix>\r\n</div>\r\n\r\n<ng-template #sliderNodeTpl let-node=\"$node\">\r\n <span [style.padding-left.rem]=\"node.left - 1\">{{ node.label }}</span>\r\n</ng-template>\r\n", styles: [".x-anchor{margin:0;padding:0;display:flex}.x-anchor-content{flex:1}.x-anchor-affix{display:block}.x-anchor-slider{float:left}.x-anchor-slider:hover{overflow-y:auto}.x-anchor-slider .x-slider{overflow:hidden}.x-anchor-right{flex-direction:row}.x-anchor-right .x-anchor-slider .x-slider-column>.x-slider-scroll{overflow-y:auto}.x-anchor-right .x-anchor-slider .x-slider-column>.x-slider-scroll>ul>li{border-left:.125rem solid var(--x-border)}.x-anchor-right .x-anchor-slider .x-slider-column>.x-slider-scroll>ul>li.x-slider-highlight{border:none;border-top-left-radius:0;border-bottom-left-radius:0;z-index:2;border-left:.125rem solid var(--x-primary)}.x-anchor-left{flex-direction:row-reverse}.x-anchor-left .x-anchor-slider .x-slider-column>.x-slider-scroll{overflow-y:auto}.x-anchor-left .x-anchor-slider .x-slider-column>.x-slider-scroll>ul>li{border-right:.125rem solid var(--x-border)}.x-anchor-left .x-anchor-slider .x-slider-column>.x-slider-scroll>ul>li.x-slider-highlight{border:none;border-top-right-radius:0;border-bottom-right-radius:0;z-index:2;border-right:.125rem solid var(--x-primary)}\n"] }]
|
|
143
157
|
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
|
|
144
158
|
type: Inject,
|
|
145
159
|
args: [DOCUMENT]
|
|
@@ -150,4 +164,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImpor
|
|
|
150
164
|
type: ViewChild,
|
|
151
165
|
args: ['content', { static: true }]
|
|
152
166
|
}] } });
|
|
153
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anchor.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/anchor/anchor.component.ts","../../../../../lib/ng-nest/ui/anchor/anchor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  Renderer2,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  ChangeDetectionStrategy,\r\n  ViewChild,\r\n  AfterViewInit,\r\n  Inject,\r\n  OnDestroy\r\n} from '@angular/core';\r\nimport { XAnchorPrefix, XAnchorNode, XAnchorProperty } from './anchor.property';\r\nimport { computedStyle, XIsEmpty, reqAnimFrame, XIsNumber, XIsUndefined, XConfigService } from '@ng-nest/ui/core';\r\nimport { XSliderNode } from '@ng-nest/ui/slider';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { fromEvent, Subject } from 'rxjs';\r\nimport { throttleTime, takeUntil } from 'rxjs/operators';\r\n\r\n@Component({\r\n  selector: `${XAnchorPrefix}`,\r\n  templateUrl: './anchor.component.html',\r\n  styleUrls: ['./anchor.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class XAnchorComponent extends XAnchorProperty implements OnInit, AfterViewInit, OnDestroy {\r\n  @ViewChild('anchor', { static: true }) anchor!: ElementRef<HTMLElement>;\r\n  @ViewChild('content', { static: true }) content!: ElementRef<HTMLElement>;\r\n  hElements!: NodeListOf<HTMLElement>;\r\n  sliderData: XSliderNode[] = [];\r\n  activatedIndex: number = 0;\r\n  sliderHeight?: number;\r\n  document: Document;\r\n  private _scrolling = false;\r\n  private _fontSize: number;\r\n  private _unSubject = new Subject<void>();\r\n\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef<HTMLElement>,\r\n    public cdr: ChangeDetectorRef,\r\n    @Inject(DOCUMENT) doc: any,\r\n    public configService: XConfigService\r\n  ) {\r\n    super();\r\n    this.document = doc;\r\n    this._fontSize = parseFloat(computedStyle(this.document.documentElement, 'font-size'));\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setClassMap();\r\n    this.setSliderData();\r\n    this.setHeight();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.setScroll();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n  }\r\n\r\n  activatedChange(index: number) {\r\n    if (XIsEmpty(this.hElements) || XIsUndefined(this.scroll)) return;\r\n\r\n    this._scrolling = true;\r\n    const hElement = this.hElements[index];\r\n    let scrollTop = hElement.offsetTop - this.anchor.nativeElement.offsetTop - parseFloat(computedStyle(hElement, 'margin-top'));\r\n    let maxScrollTop = this.scroll.scrollHeight - this.scroll.clientHeight;\r\n    if (scrollTop > maxScrollTop) scrollTop = maxScrollTop;\r\n    this.scrollTo(this.scroll, parseInt(`${scrollTop}`), 150);\r\n  }\r\n\r\n  private setClassMap() {\r\n    this.classMap[`${XAnchorPrefix}-${this.layout}`] = !XIsEmpty(this.layout);\r\n  }\r\n\r\n  private setScroll() {\r\n    fromEvent(this.scroll ? this.scroll : window, 'scroll')\r\n      .pipe(throttleTime(10), takeUntil(this._unSubject))\r\n      .subscribe(() => {\r\n        if (this._scrolling) return;\r\n        this.setActivatedByScroll();\r\n      });\r\n    if (!this.scroll) {\r\n      this.scroll = this.document.documentElement;\r\n    }\r\n  }\r\n\r\n  private setActivatedByScroll() {\r\n    let now = 0;\r\n    this.hElements.forEach((h, index) => {\r\n      let distance = this.scroll.scrollTop + this.anchor.nativeElement.offsetTop;\r\n      if (distance >= h.offsetTop) {\r\n        now = index;\r\n        return;\r\n      }\r\n    });\r\n    this.activatedIndex = now;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  private setSliderData() {\r\n    this.hElements = this.content.nativeElement.querySelectorAll(':scope> h1,:scope> h2,:scope> h3,:scope> h4,:scope> h5');\r\n    if (this.hElements.length > 0) {\r\n      let list: XAnchorNode[] = [];\r\n      this.hElements.forEach((x: HTMLElement, i: number) => {\r\n        const link = `x-anchor-${i}`;\r\n        const left = this.setLeft(x);\r\n        this.renderer.setAttribute(x, 'id', link);\r\n        list = [\r\n          ...list,\r\n          {\r\n            id: i,\r\n            label: x.innerText,\r\n            left: left,\r\n            link: link\r\n          }\r\n        ];\r\n      });\r\n      this.sliderData = list;\r\n    }\r\n  }\r\n\r\n  private setLeft(element: HTMLElement): number {\r\n    const eles = ['H1', 'H2', 'H3', 'H4', 'H5'];\r\n    const index = eles.indexOf(element.tagName);\r\n    return index + 1;\r\n  }\r\n\r\n  private setHeight() {\r\n    if (this.scroll) {\r\n      let height = this.scroll.offsetHeight;\r\n      let top = parseFloat(computedStyle(this.scroll, 'padding-top'));\r\n      let borderTop = parseFloat(computedStyle(this.scroll, 'border-top'));\r\n      let bottom = parseFloat(computedStyle(this.scroll, 'padding-bottom'));\r\n      let borderBottom = parseFloat(computedStyle(this.scroll, 'border-bottom'));\r\n      this.sliderHeight = height - top - bottom - borderTop - borderBottom - this.getTop();\r\n    }\r\n  }\r\n\r\n  private getTop() {\r\n    if (this.affixTop === '0') return 0;\r\n    if (XIsNumber(this.affixTop)) return Number(this.affixTop);\r\n    else if (this.affixTop.indexOf('rem') !== -1) return Number(this.affixTop.replace(/rem/g, '')) * this._fontSize;\r\n    else if (this.affixTop.indexOf('px') !== -1) return Number(this.affixTop.replace(/px/g, ''));\r\n    return 0;\r\n  }\r\n\r\n  private scrollTo(element: HTMLElement, to: number, duration: number) {\r\n    const difference = to - element.scrollTop;\r\n    const perTick = (difference / duration) * 10;\r\n    reqAnimFrame(() => {\r\n      element.scrollTop = element.scrollTop + perTick;\r\n      if (element.scrollTop === to || duration <= 0) {\r\n        setTimeout(() => (this._scrolling = false), 20);\r\n        return;\r\n      } else {\r\n        this.scrollTo(element, to, duration - 10);\r\n      }\r\n    });\r\n  }\r\n}\r\n","<div #anchor class=\"x-anchor\" [ngClass]=\"classMap\">\r\n  <div #content class=\"x-anchor-content\">\r\n    <ng-content></ng-content>\r\n  </div>\r\n  <x-affix class=\"x-anchor-affix\" [top]=\"affixTop\">\r\n    <div class=\"x-anchor-slider\" [style.height.px]=\"sliderHeight\">\r\n      <x-slider\r\n        [data]=\"sliderData\"\r\n        layout=\"column\"\r\n        [activatedIndex]=\"activatedIndex\"\r\n        [nodeJustify]=\"justify\"\r\n        [nodeTpl]=\"sliderNodeTpl\"\r\n        [showAnchor]=\"true\"\r\n        (indexChange)=\"activatedChange($event)\"\r\n      ></x-slider>\r\n    </div>\r\n  </x-affix>\r\n</div>\r\n\r\n<ng-template #sliderNodeTpl let-node=\"$node\">\r\n  <span [style.padding-left.rem]=\"node.left - 1\">{{ node.label }}</span>\r\n</ng-template>\r\n"]}
|
|
167
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anchor.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/anchor/anchor.component.ts","../../../../../lib/ng-nest/ui/anchor/anchor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  Renderer2,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  ChangeDetectionStrategy,\r\n  ViewChild,\r\n  AfterViewInit,\r\n  Inject,\r\n  OnDestroy,\r\n  AfterContentChecked\r\n} from '@angular/core';\r\nimport { XAnchorPrefix, XAnchorNode, XAnchorProperty } from './anchor.property';\r\nimport { computedStyle, XIsEmpty, reqAnimFrame, XIsNumber, XIsUndefined, XConfigService } from '@ng-nest/ui/core';\r\nimport { XSliderNode } from '@ng-nest/ui/slider';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { fromEvent, Subject } from 'rxjs';\r\nimport { throttleTime, takeUntil, distinctUntilChanged } from 'rxjs/operators';\r\n\r\n@Component({\r\n  selector: `${XAnchorPrefix}`,\r\n  templateUrl: './anchor.component.html',\r\n  styleUrls: ['./anchor.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class XAnchorComponent extends XAnchorProperty implements OnInit, AfterViewInit, OnDestroy, AfterContentChecked {\r\n  @ViewChild('anchor', { static: true }) anchor!: ElementRef<HTMLElement>;\r\n  @ViewChild('content', { static: true }) content!: ElementRef<HTMLElement>;\r\n  hElements!: NodeListOf<HTMLElement>;\r\n  sliderData: XSliderNode[] = [];\r\n  activatedIndex: number = 0;\r\n  sliderHeight?: number;\r\n  document: Document;\r\n  contentChange = new Subject();\r\n  private _scrolling = false;\r\n  private _fontSize: number;\r\n  private _unSubject = new Subject<void>();\r\n\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef<HTMLElement>,\r\n    public cdr: ChangeDetectorRef,\r\n    @Inject(DOCUMENT) doc: any,\r\n    public configService: XConfigService\r\n  ) {\r\n    super();\r\n    this.document = doc;\r\n    this._fontSize = parseFloat(computedStyle(this.document.documentElement, 'font-size'));\r\n  }\r\n  ngAfterContentChecked(): void {\r\n    this.contentChange.next(this.elementRef.nativeElement.innerHTML);\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setClassMap();\r\n    this.setSliderData();\r\n    this.setHeight();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.setScroll();\r\n    this.contentChange.pipe(distinctUntilChanged(), takeUntil(this._unSubject)).subscribe(() => {\r\n      this.setSliderData();\r\n      this.setHeight();\r\n      this.cdr.detectChanges();\r\n    });\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n  }\r\n\r\n  activatedChange(index: number) {\r\n    if (XIsEmpty(this.hElements) || XIsUndefined(this.scroll)) return;\r\n\r\n    this._scrolling = true;\r\n    const hElement = this.hElements[index];\r\n    let scrollTop = hElement.offsetTop - this.anchor.nativeElement.offsetTop - parseFloat(computedStyle(hElement, 'margin-top'));\r\n    let maxScrollTop = this.scroll.scrollHeight - this.scroll.clientHeight;\r\n    if (scrollTop > maxScrollTop) scrollTop = maxScrollTop;\r\n    this.scrollTo(this.scroll, parseInt(`${scrollTop}`), 150);\r\n  }\r\n\r\n  private setClassMap() {\r\n    this.classMap[`${XAnchorPrefix}-${this.layout}`] = !XIsEmpty(this.layout);\r\n  }\r\n\r\n  private setScroll() {\r\n    fromEvent(this.scroll ? this.scroll : window, 'scroll')\r\n      .pipe(throttleTime(10), takeUntil(this._unSubject))\r\n      .subscribe(() => {\r\n        if (this._scrolling) return;\r\n        this.setActivatedByScroll();\r\n      });\r\n    if (!this.scroll) {\r\n      this.scroll = this.document.documentElement;\r\n    }\r\n  }\r\n\r\n  private setActivatedByScroll() {\r\n    let now = 0;\r\n    this.hElements.forEach((h, index) => {\r\n      let distance = this.scroll.scrollTop + this.anchor.nativeElement.offsetTop;\r\n      if (distance >= h.offsetTop) {\r\n        now = index;\r\n        return;\r\n      }\r\n    });\r\n    this.activatedIndex = now;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  private setSliderData() {\r\n    this.hElements = this.content.nativeElement.querySelectorAll(\r\n      ':scope> h1,:scope> h2,:scope> h3,:scope> h4,:scope> h5,:scope> x-anchor-inner> h1,:scope> x-anchor-inner>h2,:scope> x-anchor-inner>h3,:scope> x-anchor-inner>h4,:scope> x-anchor-inner>h5'\r\n    );\r\n    if (this.hElements.length > 0) {\r\n      let list: XAnchorNode[] = [];\r\n      this.hElements.forEach((x: HTMLElement, i: number) => {\r\n        const link = `x-anchor-${i}`;\r\n        const left = this.setLeft(x);\r\n        this.renderer.setAttribute(x, 'id', link);\r\n        list = [\r\n          ...list,\r\n          {\r\n            id: i,\r\n            label: x.innerText,\r\n            left: left,\r\n            link: link\r\n          }\r\n        ];\r\n      });\r\n      this.sliderData = list;\r\n    }\r\n  }\r\n\r\n  private setLeft(element: HTMLElement): number {\r\n    const eles = ['H1', 'H2', 'H3', 'H4', 'H5'];\r\n    const index = eles.indexOf(element.tagName);\r\n    return index + 1;\r\n  }\r\n\r\n  private setHeight() {\r\n    if (this.scroll) {\r\n      if (XIsEmpty(this.sliderData)) {\r\n        this.sliderHeight = 0;\r\n      } else {\r\n        let height = this.scroll.offsetHeight;\r\n        let top = parseFloat(computedStyle(this.scroll, 'padding-top'));\r\n        let borderTop = parseFloat(computedStyle(this.scroll, 'border-top'));\r\n        let bottom = parseFloat(computedStyle(this.scroll, 'padding-bottom'));\r\n        let borderBottom = parseFloat(computedStyle(this.scroll, 'border-bottom'));\r\n        this.sliderHeight = height - top - bottom - borderTop - borderBottom - this.getTop();\r\n      }\r\n    }\r\n  }\r\n\r\n  private getTop() {\r\n    if (this.affixTop === '0') return 0;\r\n    if (XIsNumber(this.affixTop)) return Number(this.affixTop);\r\n    else if (this.affixTop.indexOf('rem') !== -1) return Number(this.affixTop.replace(/rem/g, '')) * this._fontSize;\r\n    else if (this.affixTop.indexOf('px') !== -1) return Number(this.affixTop.replace(/px/g, ''));\r\n    return 0;\r\n  }\r\n\r\n  private scrollTo(element: HTMLElement, to: number, duration: number) {\r\n    const difference = to - element.scrollTop;\r\n    const perTick = (difference / duration) * 10;\r\n    reqAnimFrame(() => {\r\n      element.scrollTop = element.scrollTop + perTick;\r\n      if (element.scrollTop === to || duration <= 0) {\r\n        setTimeout(() => (this._scrolling = false), 20);\r\n        return;\r\n      } else {\r\n        this.scrollTo(element, to, duration - 10);\r\n      }\r\n    });\r\n  }\r\n}\r\n","<div #anchor class=\"x-anchor\" [ngClass]=\"classMap\">\r\n  <div #content class=\"x-anchor-content\">\r\n    <ng-content></ng-content>\r\n  </div>\r\n  <x-affix class=\"x-anchor-affix\" [top]=\"affixTop\">\r\n    <div class=\"x-anchor-slider\" [style.height.px]=\"sliderHeight\">\r\n      <x-slider\r\n        [data]=\"sliderData\"\r\n        layout=\"column\"\r\n        [activatedIndex]=\"activatedIndex\"\r\n        [nodeJustify]=\"justify\"\r\n        [nodeTpl]=\"sliderNodeTpl\"\r\n        [showAnchor]=\"true\"\r\n        (indexChange)=\"activatedChange($event)\"\r\n      ></x-slider>\r\n    </div>\r\n  </x-affix>\r\n</div>\r\n\r\n<ng-template #sliderNodeTpl let-node=\"$node\">\r\n  <span [style.padding-left.rem]=\"node.left - 1\">{{ node.label }}</span>\r\n</ng-template>\r\n"]}
|