ngx-tethys 13.2.0-next.4 → 13.2.0

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.
Files changed (60) hide show
  1. package/CHANGELOG.md +35 -0
  2. package/arrow-switcher/arrow-switcher.component.d.ts +4 -1
  3. package/arrow-switcher/module.d.ts +3 -1
  4. package/calendar/calendar-cells.d.ts +6 -12
  5. package/calendar/calendar-header.component.d.ts +18 -0
  6. package/calendar/calendar.component.d.ts +34 -7
  7. package/calendar/examples/{basic/basic.component.scss → custom-cell/custom-cell.component.scss} +0 -0
  8. package/calendar/module.d.ts +1 -1
  9. package/esm2020/arrow-switcher/arrow-switcher.component.mjs +14 -5
  10. package/esm2020/arrow-switcher/module.mjs +6 -4
  11. package/esm2020/calendar/calendar-cells.mjs +7 -34
  12. package/esm2020/calendar/calendar-header.component.mjs +16 -4
  13. package/esm2020/calendar/calendar.component.mjs +18 -23
  14. package/esm2020/calendar/module.mjs +6 -34
  15. package/esm2020/layout/header.component.mjs +14 -3
  16. package/esm2020/nav/nav.component.mjs +1 -1
  17. package/esm2020/shared/option/group/option-group.component.mjs +3 -3
  18. package/esm2020/tabs/tab.component.mjs +4 -2
  19. package/esm2020/tabs/tabs.component.mjs +16 -4
  20. package/esm2020/version.mjs +2 -2
  21. package/fesm2015/ngx-tethys-arrow-switcher.mjs +18 -7
  22. package/fesm2015/ngx-tethys-arrow-switcher.mjs.map +1 -1
  23. package/fesm2015/ngx-tethys-calendar.mjs +43 -91
  24. package/fesm2015/ngx-tethys-calendar.mjs.map +1 -1
  25. package/fesm2015/ngx-tethys-layout.mjs +13 -2
  26. package/fesm2015/ngx-tethys-layout.mjs.map +1 -1
  27. package/fesm2015/ngx-tethys-nav.mjs.map +1 -1
  28. package/fesm2015/ngx-tethys-shared.mjs +2 -2
  29. package/fesm2015/ngx-tethys-shared.mjs.map +1 -1
  30. package/fesm2015/ngx-tethys-tabs.mjs +18 -4
  31. package/fesm2015/ngx-tethys-tabs.mjs.map +1 -1
  32. package/fesm2015/ngx-tethys.mjs +1 -1
  33. package/fesm2015/ngx-tethys.mjs.map +1 -1
  34. package/fesm2020/ngx-tethys-arrow-switcher.mjs +18 -7
  35. package/fesm2020/ngx-tethys-arrow-switcher.mjs.map +1 -1
  36. package/fesm2020/ngx-tethys-calendar.mjs +43 -91
  37. package/fesm2020/ngx-tethys-calendar.mjs.map +1 -1
  38. package/fesm2020/ngx-tethys-layout.mjs +13 -2
  39. package/fesm2020/ngx-tethys-layout.mjs.map +1 -1
  40. package/fesm2020/ngx-tethys-nav.mjs.map +1 -1
  41. package/fesm2020/ngx-tethys-shared.mjs +2 -2
  42. package/fesm2020/ngx-tethys-shared.mjs.map +1 -1
  43. package/fesm2020/ngx-tethys-tabs.mjs +18 -4
  44. package/fesm2020/ngx-tethys-tabs.mjs.map +1 -1
  45. package/fesm2020/ngx-tethys.mjs +1 -1
  46. package/fesm2020/ngx-tethys.mjs.map +1 -1
  47. package/layout/header.component.d.ts +5 -1
  48. package/layout/styles/layout.scss +7 -0
  49. package/nav/examples/lite/lite.component.scss +4 -0
  50. package/nav/nav.component.d.ts +1 -0
  51. package/nav/styles/mixin.scss +33 -0
  52. package/nav/styles/nav.scss +19 -40
  53. package/package.json +1 -1
  54. package/schematics/version.d.ts +1 -1
  55. package/schematics/version.js +1 -1
  56. package/shared/option/styles/select-dropdown.scss +1 -2
  57. package/styles/variables.scss +1 -0
  58. package/tabs/styles/tabs.scss +11 -0
  59. package/tabs/tab.component.d.ts +9 -1
  60. package/tabs/tabs.component.d.ts +7 -1
package/CHANGELOG.md CHANGED
@@ -2,6 +2,41 @@
2
2
 
3
3
  All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
4
4
 
5
+ # [13.2.0](https://github.com/atinc/ngx-tethys/compare/13.2.0-next.6...13.2.0) (2022-08-11)
6
+
7
+
8
+ ### Features
9
+
10
+ * **layout:** add thyShadow for thy-header #INFR-4049 ([#2071](https://github.com/atinc/ngx-tethys/issues/2071)) ([d662cf5](https://github.com/atinc/ngx-tethys/commit/d662cf57860de2a312dac0a66d065ec2aded1e79)), closes [#INFR-4049](https://github.com/atinc/ngx-tethys/issues/INFR-4049)
11
+
12
+
13
+
14
+ # [13.2.0-next.6](https://github.com/atinc/ngx-tethys/compare/13.2.0-next.5...13.2.0-next.6) (2022-08-11)
15
+
16
+
17
+ ### Features
18
+
19
+ * **arrow-switcher:** add lite theme for arrow switcher zd/#INFR-4138 ([#2067](https://github.com/atinc/ngx-tethys/issues/2067)) ([01cc602](https://github.com/atinc/ngx-tethys/commit/01cc602398b7c60714e94c2ca07786426a48c1c1)), closes [zd/#INFR-4138](https://github.com/atinc/ngx-tethys/issues/INFR-4138)
20
+ * **nav:** add lite mode for nav and tabs #INFR-4149 ([#2068](https://github.com/atinc/ngx-tethys/issues/2068)) ([4774de3](https://github.com/atinc/ngx-tethys/commit/4774de3e39061e145df9d22a58cccd9e538804f7)), closes [#INFR-4149](https://github.com/atinc/ngx-tethys/issues/INFR-4149)
21
+
22
+
23
+
24
+ # [13.2.0-next.5](https://github.com/atinc/ngx-tethys/compare/13.2.0-next.4...13.2.0-next.5) (2022-08-09)
25
+
26
+
27
+ ### Bug Fixes
28
+
29
+ * **nav:** remove transform: translateY(1px); from thy-nav-item for secondary type #INFR-4132 ([#2065](https://github.com/atinc/ngx-tethys/issues/2065)) ([ce805a6](https://github.com/atinc/ngx-tethys/commit/ce805a63059fe146a83e044d0a74638188a4820b)), closes [#INFR-4132](https://github.com/atinc/ngx-tethys/issues/INFR-4132)
30
+ * **shared:** fix option-group group-name style error #INFR-3841 ([beeed04](https://github.com/atinc/ngx-tethys/commit/beeed048eb07739bc4953f95514c24e0c1239233)), closes [#INFR-3841](https://github.com/atinc/ngx-tethys/issues/INFR-3841)
31
+
32
+
33
+ ### Features
34
+
35
+ * **tabs:** tabs support disable tab #INFR-4104 ([#2059](https://github.com/atinc/ngx-tethys/issues/2059)) ([b7433f3](https://github.com/atinc/ngx-tethys/commit/b7433f358ce348756078f1c08f1d418e3fd54877)), closes [#INFR-4104](https://github.com/atinc/ngx-tethys/issues/INFR-4104)
36
+ * **tabs:** tabs support set thyPosition #INFR-4026 ([#2058](https://github.com/atinc/ngx-tethys/issues/2058)) ([e4eb60d](https://github.com/atinc/ngx-tethys/commit/e4eb60d97a5f569c8a589dfe889df214c39388c1)), closes [#INFR-4026](https://github.com/atinc/ngx-tethys/issues/INFR-4026)
37
+
38
+
39
+
5
40
  # [13.2.0-next.4](https://github.com/atinc/ngx-tethys/compare/13.2.0-next.3...13.2.0-next.4) (2022-08-05)
6
41
 
7
42
 
@@ -1,6 +1,7 @@
1
1
  import { EventEmitter, OnInit, ChangeDetectorRef } from '@angular/core';
2
2
  import { ControlValueAccessor } from '@angular/forms';
3
3
  import * as i0 from "@angular/core";
4
+ export declare type ThyArrowSwitcherTheme = 'default' | 'lite';
4
5
  export interface ThyArrowSwitcherEvent {
5
6
  index: number;
6
7
  event: Event;
@@ -10,8 +11,10 @@ export declare class ThyArrowSwitcherComponent implements OnInit, ControlValueAc
10
11
  _isArrowSwitcher: boolean;
11
12
  _isSmallSize: boolean;
12
13
  total: number;
14
+ theme: ThyArrowSwitcherTheme;
13
15
  thyPrevious: EventEmitter<ThyArrowSwitcherEvent>;
14
16
  thyNext: EventEmitter<ThyArrowSwitcherEvent>;
17
+ set thyTheme(value: ThyArrowSwitcherTheme);
15
18
  set thyTotal(value: number);
16
19
  set thySize(size: string);
17
20
  index: number;
@@ -30,5 +33,5 @@ export declare class ThyArrowSwitcherComponent implements OnInit, ControlValueAc
30
33
  onPreviousClick(event: Event): void;
31
34
  onNextClick(event: Event): void;
32
35
  static ɵfac: i0.ɵɵFactoryDeclaration<ThyArrowSwitcherComponent, never>;
33
- static ɵcmp: i0.ɵɵComponentDeclaration<ThyArrowSwitcherComponent, "thy-arrow-switcher", never, { "thyTotal": "thyTotal"; "thySize": "thySize"; }, { "thyPrevious": "thyPrevious"; "thyNext": "thyNext"; }, never, never>;
36
+ static ɵcmp: i0.ɵɵComponentDeclaration<ThyArrowSwitcherComponent, "thy-arrow-switcher", never, { "thyTheme": "thyTheme"; "thyTotal": "thyTotal"; "thySize": "thySize"; }, { "thyPrevious": "thyPrevious"; "thyNext": "thyNext"; }, never, never>;
34
37
  }
@@ -2,8 +2,10 @@ import * as i0 from "@angular/core";
2
2
  import * as i1 from "./arrow-switcher.component";
3
3
  import * as i2 from "@angular/common";
4
4
  import * as i3 from "ngx-tethys/button";
5
+ import * as i4 from "ngx-tethys/icon";
6
+ import * as i5 from "ngx-tethys/action";
5
7
  export declare class ThyArrowSwitcherModule {
6
8
  static ɵfac: i0.ɵɵFactoryDeclaration<ThyArrowSwitcherModule, never>;
7
- static ɵmod: i0.ɵɵNgModuleDeclaration<ThyArrowSwitcherModule, [typeof i1.ThyArrowSwitcherComponent], [typeof i2.CommonModule, typeof i3.ThyButtonModule], [typeof i1.ThyArrowSwitcherComponent]>;
9
+ static ɵmod: i0.ɵɵNgModuleDeclaration<ThyArrowSwitcherModule, [typeof i1.ThyArrowSwitcherComponent], [typeof i2.CommonModule, typeof i3.ThyButtonModule, typeof i4.ThyIconModule, typeof i5.ThyActionModule], [typeof i1.ThyArrowSwitcherComponent]>;
8
10
  static ɵinj: i0.ɵɵInjectorDeclaration<ThyArrowSwitcherModule>;
9
11
  }
@@ -1,20 +1,14 @@
1
1
  import * as i0 from "@angular/core";
2
+ /**
3
+ * 自定义日期单元格,模版内容会被追加到单元格,可通过 *thyDateCell 传入模板
4
+ */
2
5
  export declare class ThyDateCellDirective {
3
6
  static ɵfac: i0.ɵɵFactoryDeclaration<ThyDateCellDirective, never>;
4
7
  static ɵdir: i0.ɵɵDirectiveDeclaration<ThyDateCellDirective, "[thyDateCell]", ["thyDateCell"], {}, {}, never>;
5
8
  }
6
- export declare class ThyMonthCellDirective {
7
- static ɵfac: i0.ɵɵFactoryDeclaration<ThyMonthCellDirective, never>;
8
- static ɵdir: i0.ɵɵDirectiveDeclaration<ThyMonthCellDirective, "[thyMonthCell]", ["thyMonthCell"], {}, {}, never>;
9
- }
10
- export declare class ThyDateFullCellDirective {
11
- static ɵfac: i0.ɵɵFactoryDeclaration<ThyDateFullCellDirective, never>;
12
- static ɵdir: i0.ɵɵDirectiveDeclaration<ThyDateFullCellDirective, "[thyDateFullCell]", ["thyDateFullCell"], {}, {}, never>;
13
- }
14
- export declare class ThyMonthFullCellDirective {
15
- static ɵfac: i0.ɵɵFactoryDeclaration<ThyMonthFullCellDirective, never>;
16
- static ɵdir: i0.ɵɵDirectiveDeclaration<ThyMonthFullCellDirective, "[thyMonthFullCell]", ["thyMonthFullCell"], {}, {}, never>;
17
- }
9
+ /**
10
+ * 自定义右上角操作项,可通过 *thyCalendarHeaderOperation传入模板
11
+ */
18
12
  export declare class ThyCalendarHeaderOperationDirective {
19
13
  static ɵfac: i0.ɵɵFactoryDeclaration<ThyCalendarHeaderOperationDirective, never>;
20
14
  static ɵdir: i0.ɵɵDirectiveDeclaration<ThyCalendarHeaderOperationDirective, "[thyCalendarHeaderOperation]", ["thyCalendarHeaderOperation"], {}, {}, never>;
@@ -2,13 +2,31 @@ import { DateRangeItemInfo } from 'ngx-tethys/date-range';
2
2
  import { FunctionProp, TinyDate } from 'ngx-tethys/util';
3
3
  import { ChangeDetectorRef, EventEmitter, OnInit, TemplateRef } from '@angular/core';
4
4
  import * as i0 from "@angular/core";
5
+ /**
6
+ * 日历头部操作栏组件
7
+ */
5
8
  export declare class ThyCalendarHeaderComponent implements OnInit {
6
9
  private cdr;
7
10
  className: boolean;
11
+ /**
12
+ * 当前选中日期
13
+ */
8
14
  set currentDate(value: TinyDate);
15
+ /**
16
+ * 自定义渲染右侧操作项
17
+ */
9
18
  operationRender: FunctionProp<TemplateRef<any>>;
19
+ /**
20
+ * 日期选择范围(年)发生变化的回调
21
+ */
10
22
  readonly yearChange: EventEmitter<number>;
23
+ /**
24
+ * 日期选择范围(月)发生变化的回调
25
+ */
11
26
  readonly monthChange: EventEmitter<number>;
27
+ /**
28
+ * 日期选择范围(日期)发生变化的回调
29
+ */
12
30
  readonly dateRangeChange: EventEmitter<DateRangeItemInfo>;
13
31
  dateRanges: DateRangeItemInfo[];
14
32
  date: DateRangeItemInfo;
@@ -6,28 +6,55 @@ export declare type CalendarMode = 'month' | 'year';
6
6
  declare type CalendarDateTemplate = TemplateRef<{
7
7
  $implicit: Date;
8
8
  }>;
9
+ /**
10
+ * Calendar 组件
11
+ */
9
12
  export declare class ThyCalendarComponent implements OnInit, OnChanges {
10
13
  private cdr;
11
14
  className: boolean;
12
15
  className1: boolean;
16
+ /**
17
+ * 展示模式,默认为'month','month' | 'year'
18
+ */
13
19
  thyMode: CalendarMode;
20
+ /**
21
+ * (可双向绑定)展示日期,默认为当前日期
22
+ */
14
23
  thyValue?: Date;
24
+ /**
25
+ * 不可选择的日期
26
+ */
15
27
  thyDisabledDate?: (date: Date) => boolean;
16
- thyModeChange: EventEmitter<CalendarMode>;
17
- thyPanelChange: EventEmitter<{
18
- date: Date;
19
- mode: CalendarMode;
20
- }>;
28
+ /**
29
+ * 日期选择变化的回调
30
+ */
21
31
  thySelectChange: EventEmitter<Date>;
32
+ /**
33
+ * 日期选择变化的回调
34
+ */
22
35
  thyValueChange: EventEmitter<Date>;
36
+ /**
37
+ * 日期选择范围变化的回调
38
+ */
23
39
  thyDateRangeChange: EventEmitter<DateRangeItemInfo>;
40
+ /**
41
+ * (可作为内容)自定义渲染日期单元格,模版内容会被追加到单元格
42
+ */
24
43
  thyDateCell?: CalendarDateTemplate;
44
+ /**
45
+ * 追加到单元格的自定义模板
46
+ */
25
47
  thyDateCellChild?: CalendarDateTemplate;
26
48
  get dateCell(): CalendarDateTemplate;
49
+ /**
50
+ * (可作为内容)自定义渲染右上角操作项
51
+ */
27
52
  thyCalendarHeaderOperation?: CalendarDateTemplate;
53
+ /**
54
+ * 右上角操作项的自定义模板
55
+ */
28
56
  thyCalendarHeaderOperationChild?: CalendarDateTemplate;
29
57
  get headerOperation(): CalendarDateTemplate;
30
- thyFullscreen: boolean;
31
58
  currentDate: TinyDate;
32
59
  prefixCls: string;
33
60
  private onChangeFn;
@@ -44,6 +71,6 @@ export declare class ThyCalendarComponent implements OnInit, OnChanges {
44
71
  private updateDate;
45
72
  ngOnChanges(changes: SimpleChanges): void;
46
73
  static ɵfac: i0.ɵɵFactoryDeclaration<ThyCalendarComponent, never>;
47
- static ɵcmp: i0.ɵɵComponentDeclaration<ThyCalendarComponent, "thy-calendar", never, { "thyMode": "thyMode"; "thyValue": "thyValue"; "thyDisabledDate": "thyDisabledDate"; "thyDateCell": "thyDateCell"; "thyCalendarHeaderOperation": "thyCalendarHeaderOperation"; "thyFullscreen": "thyFullscreen"; }, { "thyModeChange": "thyModeChange"; "thyPanelChange": "thyPanelChange"; "thySelectChange": "thySelectChange"; "thyValueChange": "thyValueChange"; "thyDateRangeChange": "thyDateRangeChange"; }, ["thyDateCellChild", "thyCalendarHeaderOperationChild"], never>;
74
+ static ɵcmp: i0.ɵɵComponentDeclaration<ThyCalendarComponent, "thy-calendar", never, { "thyMode": "thyMode"; "thyValue": "thyValue"; "thyDisabledDate": "thyDisabledDate"; "thyDateCell": "thyDateCell"; "thyCalendarHeaderOperation": "thyCalendarHeaderOperation"; }, { "thySelectChange": "thySelectChange"; "thyValueChange": "thyValueChange"; "thyDateRangeChange": "thyDateRangeChange"; }, ["thyDateCellChild", "thyCalendarHeaderOperationChild"], never>;
48
75
  }
49
76
  export {};
@@ -13,6 +13,6 @@ import * as i11 from "ngx-tethys/button";
13
13
  import * as i12 from "ngx-tethys/date-range";
14
14
  export declare class ThyCalendarModule {
15
15
  static ɵfac: i0.ɵɵFactoryDeclaration<ThyCalendarModule, never>;
16
- static ɵmod: i0.ɵɵNgModuleDeclaration<ThyCalendarModule, [typeof i1.ThyCalendarHeaderComponent, typeof i2.ThyCalendarComponent, typeof i3.ThyDateCellDirective, typeof i3.ThyDateFullCellDirective, typeof i3.ThyMonthCellDirective, typeof i3.ThyMonthFullCellDirective, typeof i3.ThyCalendarHeaderOperationDirective], [typeof i4.CommonModule, typeof i5.FormsModule, typeof i6.ThySharedModule, typeof i7.ThyIconModule, typeof i8.LibPackerModule, typeof i9.ThySelectModule, typeof i10.ThyRadioModule, typeof i11.ThyButtonModule, typeof i12.ThyDateRangeModule], [typeof i1.ThyCalendarHeaderComponent, typeof i2.ThyCalendarComponent, typeof i3.ThyDateCellDirective, typeof i3.ThyDateFullCellDirective, typeof i3.ThyMonthCellDirective, typeof i3.ThyMonthFullCellDirective, typeof i3.ThyCalendarHeaderOperationDirective]>;
16
+ static ɵmod: i0.ɵɵNgModuleDeclaration<ThyCalendarModule, [typeof i1.ThyCalendarHeaderComponent, typeof i2.ThyCalendarComponent, typeof i3.ThyDateCellDirective, typeof i3.ThyCalendarHeaderOperationDirective], [typeof i4.CommonModule, typeof i5.FormsModule, typeof i6.ThySharedModule, typeof i7.ThyIconModule, typeof i8.LibPackerModule, typeof i9.ThySelectModule, typeof i10.ThyRadioModule, typeof i11.ThyButtonModule, typeof i12.ThyDateRangeModule], [typeof i1.ThyCalendarHeaderComponent, typeof i2.ThyCalendarComponent, typeof i3.ThyDateCellDirective, typeof i3.ThyCalendarHeaderOperationDirective]>;
17
17
  static ɵinj: i0.ɵɵInjectorDeclaration<ThyCalendarModule>;
18
18
  }
@@ -1,12 +1,16 @@
1
1
  import { Component, HostBinding, Input, Output, EventEmitter, ChangeDetectionStrategy, ChangeDetectorRef, forwardRef } from '@angular/core';
2
2
  import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
3
  import * as i0 from "@angular/core";
4
- import * as i1 from "ngx-tethys/button";
4
+ import * as i1 from "ngx-tethys/action";
5
+ import * as i2 from "ngx-tethys/icon";
6
+ import * as i3 from "ngx-tethys/button";
7
+ import * as i4 from "@angular/common";
5
8
  export class ThyArrowSwitcherComponent {
6
9
  constructor(cd) {
7
10
  this.cd = cd;
8
11
  this._isArrowSwitcher = true;
9
12
  this._isSmallSize = false;
13
+ this.theme = 'default';
10
14
  this.thyPrevious = new EventEmitter();
11
15
  this.thyNext = new EventEmitter();
12
16
  this.index = 0;
@@ -14,6 +18,9 @@ export class ThyArrowSwitcherComponent {
14
18
  this.previousDisabled = false;
15
19
  this.nextDisabled = false;
16
20
  }
21
+ set thyTheme(value) {
22
+ this.theme = value;
23
+ }
17
24
  set thyTotal(value) {
18
25
  if (value) {
19
26
  this.total = value;
@@ -60,13 +67,13 @@ export class ThyArrowSwitcherComponent {
60
67
  }
61
68
  }
62
69
  ThyArrowSwitcherComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyArrowSwitcherComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
63
- ThyArrowSwitcherComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.6", type: ThyArrowSwitcherComponent, selector: "thy-arrow-switcher", inputs: { thyTotal: "thyTotal", thySize: "thySize" }, outputs: { thyPrevious: "thyPrevious", thyNext: "thyNext" }, host: { properties: { "class.thy-arrow-switcher": "this._isArrowSwitcher", "class.thy-arrow-switcher-small": "this._isSmallSize" } }, providers: [
70
+ ThyArrowSwitcherComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.6", type: ThyArrowSwitcherComponent, selector: "thy-arrow-switcher", inputs: { thyTheme: "thyTheme", thyTotal: "thyTotal", thySize: "thySize" }, outputs: { thyPrevious: "thyPrevious", thyNext: "thyNext" }, host: { properties: { "class.thy-arrow-switcher": "this._isArrowSwitcher", "class.thy-arrow-switcher-small": "this._isSmallSize" } }, providers: [
64
71
  {
65
72
  provide: NG_VALUE_ACCESSOR,
66
73
  useExisting: forwardRef(() => ThyArrowSwitcherComponent),
67
74
  multi: true
68
75
  }
69
- ], ngImport: i0, template: "<div class=\"switcher-wrapper\">\n <button thyButtonIcon=\"angle-left\" [disabled]=\"previousDisabled\" (click)=\"onPreviousClick($event)\"></button>\n <span>{{ index + 1 }} / {{ total }}</span>\n <button thyButtonIcon=\"angle-right\" [disabled]=\"nextDisabled\" (click)=\"onNextClick($event)\"></button>\n</div>\n", components: [{ type: i1.ThyButtonIconComponent, selector: "thy-button-icon,[thy-button-icon],[thyButtonIcon]", inputs: ["thySize", "thyIcon", "thyButtonIcon", "thyShape", "thyLight", "thyActive", "thyTheme", "thyColor"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
76
+ ], ngImport: i0, template: "<div class=\"switcher-wrapper\" *ngIf=\"theme === 'lite'; else default\">\n <a thyAction href=\"javascript:;\" [thyDisabled]=\"previousDisabled\" class=\"mr-2\" (click)=\"onPreviousClick($event)\"\n ><thy-icon thyIconName=\"angle-up\"></thy-icon\n ></a>\n <a thyAction href=\"javascript:;\" [thyDisabled]=\"nextDisabled\" (click)=\"onNextClick($event)\"\n ><thy-icon thyIconName=\"angle-down\"></thy-icon\n ></a>\n</div>\n\n<ng-template #default>\n <div class=\"switcher-wrapper\">\n <button thyButtonIcon=\"angle-left\" [disabled]=\"previousDisabled\" (click)=\"onPreviousClick($event)\"></button>\n <span>{{ index + 1 }} / {{ total }}</span>\n <button thyButtonIcon=\"angle-right\" [disabled]=\"nextDisabled\" (click)=\"onNextClick($event)\"></button>\n </div>\n</ng-template>\n", components: [{ type: i1.ThyActionComponent, selector: "thy-action, [thyAction]", inputs: ["thyType", "thyIcon", "thyActionIcon", "thyActive", "thyActionActive", "thyTheme", "thyHoverIcon", "thyDisabled"] }, { type: i2.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { type: i3.ThyButtonIconComponent, selector: "thy-button-icon,[thy-button-icon],[thyButtonIcon]", inputs: ["thySize", "thyIcon", "thyButtonIcon", "thyShape", "thyLight", "thyActive", "thyTheme", "thyColor"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
70
77
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyArrowSwitcherComponent, decorators: [{
71
78
  type: Component,
72
79
  args: [{ selector: 'thy-arrow-switcher', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
@@ -75,7 +82,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImpor
75
82
  useExisting: forwardRef(() => ThyArrowSwitcherComponent),
76
83
  multi: true
77
84
  }
78
- ], template: "<div class=\"switcher-wrapper\">\n <button thyButtonIcon=\"angle-left\" [disabled]=\"previousDisabled\" (click)=\"onPreviousClick($event)\"></button>\n <span>{{ index + 1 }} / {{ total }}</span>\n <button thyButtonIcon=\"angle-right\" [disabled]=\"nextDisabled\" (click)=\"onNextClick($event)\"></button>\n</div>\n" }]
85
+ ], template: "<div class=\"switcher-wrapper\" *ngIf=\"theme === 'lite'; else default\">\n <a thyAction href=\"javascript:;\" [thyDisabled]=\"previousDisabled\" class=\"mr-2\" (click)=\"onPreviousClick($event)\"\n ><thy-icon thyIconName=\"angle-up\"></thy-icon\n ></a>\n <a thyAction href=\"javascript:;\" [thyDisabled]=\"nextDisabled\" (click)=\"onNextClick($event)\"\n ><thy-icon thyIconName=\"angle-down\"></thy-icon\n ></a>\n</div>\n\n<ng-template #default>\n <div class=\"switcher-wrapper\">\n <button thyButtonIcon=\"angle-left\" [disabled]=\"previousDisabled\" (click)=\"onPreviousClick($event)\"></button>\n <span>{{ index + 1 }} / {{ total }}</span>\n <button thyButtonIcon=\"angle-right\" [disabled]=\"nextDisabled\" (click)=\"onNextClick($event)\"></button>\n </div>\n</ng-template>\n" }]
79
86
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { _isArrowSwitcher: [{
80
87
  type: HostBinding,
81
88
  args: ['class.thy-arrow-switcher']
@@ -86,9 +93,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImpor
86
93
  type: Output
87
94
  }], thyNext: [{
88
95
  type: Output
96
+ }], thyTheme: [{
97
+ type: Input
89
98
  }], thyTotal: [{
90
99
  type: Input
91
100
  }], thySize: [{
92
101
  type: Input
93
102
  }] } });
94
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJyb3ctc3dpdGNoZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2Fycm93LXN3aXRjaGVyL2Fycm93LXN3aXRjaGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uL3NyYy9hcnJvdy1zd2l0Y2hlci9hcnJvdy1zd2l0Y2hlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsU0FBUyxFQUNULFdBQVcsRUFDWCxLQUFLLEVBQ0wsTUFBTSxFQUNOLFlBQVksRUFDWix1QkFBdUIsRUFFdkIsaUJBQWlCLEVBQ2pCLFVBQVUsRUFDYixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQXdCLGlCQUFpQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7OztBQW1CekUsTUFBTSxPQUFPLHlCQUF5QjtJQXNDbEMsWUFBb0IsRUFBcUI7UUFBckIsT0FBRSxHQUFGLEVBQUUsQ0FBbUI7UUFyQ0EscUJBQWdCLEdBQUcsSUFBSSxDQUFDO1FBRWxCLGlCQUFZLEdBQUcsS0FBSyxDQUFDO1FBSTFELGdCQUFXLEdBQUcsSUFBSSxZQUFZLEVBQXlCLENBQUM7UUFFeEQsWUFBTyxHQUFHLElBQUksWUFBWSxFQUF5QixDQUFDO1FBaUI5RCxVQUFLLEdBQUcsQ0FBQyxDQUFDO1FBRVYsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUVqQixxQkFBZ0IsR0FBRyxLQUFLLENBQUM7UUFFekIsaUJBQVksR0FBRyxLQUFLLENBQUM7SUFNdUIsQ0FBQztJQTNCN0MsSUFDSSxRQUFRLENBQUMsS0FBYTtRQUN0QixJQUFJLEtBQUssRUFBRTtZQUNQLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1lBQ25CLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztTQUN0QjtJQUNMLENBQUM7SUFFRCxJQUNJLE9BQU8sQ0FBQyxJQUFZO1FBQ3BCLElBQUksSUFBSSxLQUFLLElBQUksRUFBRTtZQUNmLElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFDO1NBQzVCO0lBQ0wsQ0FBQztJQWdCRCxRQUFRLEtBQUksQ0FBQztJQUViLFVBQVUsQ0FBQyxLQUFhO1FBQ3BCLElBQUksS0FBSyxJQUFJLENBQUMsRUFBRTtZQUNaLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1lBQ25CLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztTQUN0QjtRQUNELElBQUksQ0FBQyxFQUFFLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVELGdCQUFnQixDQUFDLEVBQWM7UUFDM0IsSUFBSSxDQUFDLGFBQWEsR0FBRyxFQUFFLENBQUM7SUFDNUIsQ0FBQztJQUVELGlCQUFpQixDQUFDLEVBQWM7UUFDNUIsSUFBSSxDQUFDLGNBQWMsR0FBRyxFQUFFLENBQUM7SUFDN0IsQ0FBQztJQUVELGdCQUFnQixDQUFDLFNBQWtCO1FBQy9CLElBQUksQ0FBQyxRQUFRLEdBQUcsU0FBUyxDQUFDO0lBQzlCLENBQUM7SUFFRCxXQUFXO1FBQ1AsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksQ0FBQyxLQUFLLElBQUksQ0FBQyxJQUFJLElBQUksQ0FBQyxRQUFRLENBQUM7UUFDekQsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsS0FBSyxJQUFJLElBQUksQ0FBQyxLQUFLLEdBQUcsQ0FBQyxJQUFJLElBQUksQ0FBQyxRQUFRLENBQUM7SUFDdEUsQ0FBQztJQUVELGVBQWUsQ0FBQyxLQUFZO1FBQ3hCLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNiLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQy9CLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUNuQixJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxFQUFFLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDeEQsQ0FBQztJQUVELFdBQVcsQ0FBQyxLQUFZO1FBQ3BCLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNiLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQy9CLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUNuQixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDcEQsQ0FBQzs7c0hBL0VRLHlCQUF5QjswR0FBekIseUJBQXlCLHNTQVJ2QjtRQUNQO1lBQ0ksT0FBTyxFQUFFLGlCQUFpQjtZQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLHlCQUF5QixDQUFDO1lBQ3hELEtBQUssRUFBRSxJQUFJO1NBQ2Q7S0FDSiwwQkM1QkwsK1RBS0E7MkZEeUJhLHlCQUF5QjtrQkFackMsU0FBUzsrQkFDSSxvQkFBb0IsbUJBRWIsdUJBQXVCLENBQUMsTUFBTSxhQUNwQzt3QkFDUDs0QkFDSSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSwwQkFBMEIsQ0FBQzs0QkFDeEQsS0FBSyxFQUFFLElBQUk7eUJBQ2Q7cUJBQ0o7d0dBR3dDLGdCQUFnQjtzQkFBeEQsV0FBVzt1QkFBQywwQkFBMEI7Z0JBRVEsWUFBWTtzQkFBMUQsV0FBVzt1QkFBQyxnQ0FBZ0M7Z0JBSW5DLFdBQVc7c0JBQXBCLE1BQU07Z0JBRUcsT0FBTztzQkFBaEIsTUFBTTtnQkFHSCxRQUFRO3NCQURYLEtBQUs7Z0JBU0YsT0FBTztzQkFEVixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgICBDb21wb25lbnQsXG4gICAgSG9zdEJpbmRpbmcsXG4gICAgSW5wdXQsXG4gICAgT3V0cHV0LFxuICAgIEV2ZW50RW1pdHRlcixcbiAgICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgICBPbkluaXQsXG4gICAgQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gICAgZm9yd2FyZFJlZlxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuZXhwb3J0IGludGVyZmFjZSBUaHlBcnJvd1N3aXRjaGVyRXZlbnQge1xuICAgIGluZGV4OiBudW1iZXI7XG4gICAgZXZlbnQ6IEV2ZW50O1xufVxuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3RoeS1hcnJvdy1zd2l0Y2hlcicsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2Fycm93LXN3aXRjaGVyLmNvbXBvbmVudC5odG1sJyxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgICAgICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBUaHlBcnJvd1N3aXRjaGVyQ29tcG9uZW50KSxcbiAgICAgICAgICAgIG11bHRpOiB0cnVlXG4gICAgICAgIH1cbiAgICBdXG59KVxuZXhwb3J0IGNsYXNzIFRoeUFycm93U3dpdGNoZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIENvbnRyb2xWYWx1ZUFjY2Vzc29yIHtcbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzLnRoeS1hcnJvdy1zd2l0Y2hlcicpIF9pc0Fycm93U3dpdGNoZXIgPSB0cnVlO1xuXG4gICAgQEhvc3RCaW5kaW5nKCdjbGFzcy50aHktYXJyb3ctc3dpdGNoZXItc21hbGwnKSBfaXNTbWFsbFNpemUgPSBmYWxzZTtcblxuICAgIHRvdGFsOiBudW1iZXI7XG5cbiAgICBAT3V0cHV0KCkgdGh5UHJldmlvdXMgPSBuZXcgRXZlbnRFbWl0dGVyPFRoeUFycm93U3dpdGNoZXJFdmVudD4oKTtcblxuICAgIEBPdXRwdXQoKSB0aHlOZXh0ID0gbmV3IEV2ZW50RW1pdHRlcjxUaHlBcnJvd1N3aXRjaGVyRXZlbnQ+KCk7XG5cbiAgICBASW5wdXQoKVxuICAgIHNldCB0aHlUb3RhbCh2YWx1ZTogbnVtYmVyKSB7XG4gICAgICAgIGlmICh2YWx1ZSkge1xuICAgICAgICAgICAgdGhpcy50b3RhbCA9IHZhbHVlO1xuICAgICAgICAgICAgdGhpcy5nZXREaXNhYmxlZCgpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgQElucHV0KClcbiAgICBzZXQgdGh5U2l6ZShzaXplOiBzdHJpbmcpIHtcbiAgICAgICAgaWYgKHNpemUgPT09ICdzbScpIHtcbiAgICAgICAgICAgIHRoaXMuX2lzU21hbGxTaXplID0gdHJ1ZTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIGluZGV4ID0gMDtcblxuICAgIGRpc2FibGVkID0gZmFsc2U7XG5cbiAgICBwcmV2aW91c0Rpc2FibGVkID0gZmFsc2U7XG5cbiAgICBuZXh0RGlzYWJsZWQgPSBmYWxzZTtcblxuICAgIHByaXZhdGUgb25Nb2RlbENoYW5nZTogKHZhbHVlOiBudW1iZXIpID0+IHZvaWQ7XG5cbiAgICBwcml2YXRlIG9uTW9kZWxUb3VjaGVkOiAoKSA9PiB2b2lkO1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBjZDogQ2hhbmdlRGV0ZWN0b3JSZWYpIHt9XG5cbiAgICBuZ09uSW5pdCgpIHt9XG5cbiAgICB3cml0ZVZhbHVlKHZhbHVlOiBudW1iZXIpOiB2b2lkIHtcbiAgICAgICAgaWYgKHZhbHVlID49IDApIHtcbiAgICAgICAgICAgIHRoaXMuaW5kZXggPSB2YWx1ZTtcbiAgICAgICAgICAgIHRoaXMuZ2V0RGlzYWJsZWQoKTtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLmNkLm1hcmtGb3JDaGVjaygpO1xuICAgIH1cblxuICAgIHJlZ2lzdGVyT25DaGFuZ2UoZm46ICgpID0+IHZvaWQpIHtcbiAgICAgICAgdGhpcy5vbk1vZGVsQ2hhbmdlID0gZm47XG4gICAgfVxuXG4gICAgcmVnaXN0ZXJPblRvdWNoZWQoZm46ICgpID0+IHZvaWQpIHtcbiAgICAgICAgdGhpcy5vbk1vZGVsVG91Y2hlZCA9IGZuO1xuICAgIH1cblxuICAgIHNldERpc2FibGVkU3RhdGUoaXNEaXNhYmxlOiBib29sZWFuKSB7XG4gICAgICAgIHRoaXMuZGlzYWJsZWQgPSBpc0Rpc2FibGU7XG4gICAgfVxuXG4gICAgZ2V0RGlzYWJsZWQoKSB7XG4gICAgICAgIHRoaXMucHJldmlvdXNEaXNhYmxlZCA9IHRoaXMuaW5kZXggPD0gMCB8fCB0aGlzLmRpc2FibGVkO1xuICAgICAgICB0aGlzLm5leHREaXNhYmxlZCA9IHRoaXMuaW5kZXggPj0gdGhpcy50b3RhbCAtIDEgfHwgdGhpcy5kaXNhYmxlZDtcbiAgICB9XG5cbiAgICBvblByZXZpb3VzQ2xpY2soZXZlbnQ6IEV2ZW50KSB7XG4gICAgICAgIHRoaXMuaW5kZXgtLTtcbiAgICAgICAgdGhpcy5vbk1vZGVsQ2hhbmdlKHRoaXMuaW5kZXgpO1xuICAgICAgICB0aGlzLmdldERpc2FibGVkKCk7XG4gICAgICAgIHRoaXMudGh5UHJldmlvdXMuZW1pdCh7IGluZGV4OiB0aGlzLmluZGV4LCBldmVudCB9KTtcbiAgICB9XG5cbiAgICBvbk5leHRDbGljayhldmVudDogRXZlbnQpIHtcbiAgICAgICAgdGhpcy5pbmRleCsrO1xuICAgICAgICB0aGlzLm9uTW9kZWxDaGFuZ2UodGhpcy5pbmRleCk7XG4gICAgICAgIHRoaXMuZ2V0RGlzYWJsZWQoKTtcbiAgICAgICAgdGhpcy50aHlOZXh0LmVtaXQoeyBpbmRleDogdGhpcy5pbmRleCwgZXZlbnQgfSk7XG4gICAgfVxufVxuIiwiPGRpdiBjbGFzcz1cInN3aXRjaGVyLXdyYXBwZXJcIj5cbiAgPGJ1dHRvbiB0aHlCdXR0b25JY29uPVwiYW5nbGUtbGVmdFwiIFtkaXNhYmxlZF09XCJwcmV2aW91c0Rpc2FibGVkXCIgKGNsaWNrKT1cIm9uUHJldmlvdXNDbGljaygkZXZlbnQpXCI+PC9idXR0b24+XG4gIDxzcGFuPnt7IGluZGV4ICsgMSB9fSAvIHt7IHRvdGFsIH19PC9zcGFuPlxuICA8YnV0dG9uIHRoeUJ1dHRvbkljb249XCJhbmdsZS1yaWdodFwiIFtkaXNhYmxlZF09XCJuZXh0RGlzYWJsZWRcIiAoY2xpY2spPVwib25OZXh0Q2xpY2soJGV2ZW50KVwiPjwvYnV0dG9uPlxuPC9kaXY+XG4iXX0=
103
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"arrow-switcher.component.js","sourceRoot":"","sources":["../../../../src/arrow-switcher/arrow-switcher.component.ts","../../../../src/arrow-switcher/arrow-switcher.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    HostBinding,\n    Input,\n    Output,\n    EventEmitter,\n    ChangeDetectionStrategy,\n    OnInit,\n    ChangeDetectorRef,\n    forwardRef\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nexport type ThyArrowSwitcherTheme = 'default' | 'lite';\nexport interface ThyArrowSwitcherEvent {\n    index: number;\n    event: Event;\n}\n\n@Component({\n    selector: 'thy-arrow-switcher',\n    templateUrl: './arrow-switcher.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => ThyArrowSwitcherComponent),\n            multi: true\n        }\n    ]\n})\nexport class ThyArrowSwitcherComponent implements OnInit, ControlValueAccessor {\n    @HostBinding('class.thy-arrow-switcher') _isArrowSwitcher = true;\n\n    @HostBinding('class.thy-arrow-switcher-small') _isSmallSize = false;\n\n    total: number;\n\n    theme: ThyArrowSwitcherTheme = 'default';\n\n    @Output() thyPrevious = new EventEmitter<ThyArrowSwitcherEvent>();\n\n    @Output() thyNext = new EventEmitter<ThyArrowSwitcherEvent>();\n\n    @Input() set thyTheme(value: ThyArrowSwitcherTheme) {\n        this.theme = value;\n    }\n\n    @Input()\n    set thyTotal(value: number) {\n        if (value) {\n            this.total = value;\n            this.getDisabled();\n        }\n    }\n\n    @Input()\n    set thySize(size: string) {\n        if (size === 'sm') {\n            this._isSmallSize = true;\n        }\n    }\n\n    index = 0;\n\n    disabled = false;\n\n    previousDisabled = false;\n\n    nextDisabled = false;\n\n    private onModelChange: (value: number) => void;\n\n    private onModelTouched: () => void;\n\n    constructor(private cd: ChangeDetectorRef) {}\n\n    ngOnInit() {}\n\n    writeValue(value: number): void {\n        if (value >= 0) {\n            this.index = value;\n            this.getDisabled();\n        }\n        this.cd.markForCheck();\n    }\n\n    registerOnChange(fn: () => void) {\n        this.onModelChange = fn;\n    }\n\n    registerOnTouched(fn: () => void) {\n        this.onModelTouched = fn;\n    }\n\n    setDisabledState(isDisable: boolean) {\n        this.disabled = isDisable;\n    }\n\n    getDisabled() {\n        this.previousDisabled = this.index <= 0 || this.disabled;\n        this.nextDisabled = this.index >= this.total - 1 || this.disabled;\n    }\n\n    onPreviousClick(event: Event) {\n        this.index--;\n        this.onModelChange(this.index);\n        this.getDisabled();\n        this.thyPrevious.emit({ index: this.index, event });\n    }\n\n    onNextClick(event: Event) {\n        this.index++;\n        this.onModelChange(this.index);\n        this.getDisabled();\n        this.thyNext.emit({ index: this.index, event });\n    }\n}\n","<div class=\"switcher-wrapper\" *ngIf=\"theme === 'lite'; else default\">\n  <a thyAction href=\"javascript:;\" [thyDisabled]=\"previousDisabled\" class=\"mr-2\" (click)=\"onPreviousClick($event)\"\n    ><thy-icon thyIconName=\"angle-up\"></thy-icon\n  ></a>\n  <a thyAction href=\"javascript:;\" [thyDisabled]=\"nextDisabled\" (click)=\"onNextClick($event)\"\n    ><thy-icon thyIconName=\"angle-down\"></thy-icon\n  ></a>\n</div>\n\n<ng-template #default>\n  <div class=\"switcher-wrapper\">\n    <button thyButtonIcon=\"angle-left\" [disabled]=\"previousDisabled\" (click)=\"onPreviousClick($event)\"></button>\n    <span>{{ index + 1 }} / {{ total }}</span>\n    <button thyButtonIcon=\"angle-right\" [disabled]=\"nextDisabled\" (click)=\"onNextClick($event)\"></button>\n  </div>\n</ng-template>\n"]}
@@ -2,18 +2,20 @@ import { NgModule } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
3
  import { ThyButtonModule } from 'ngx-tethys/button';
4
4
  import { ThyArrowSwitcherComponent } from './arrow-switcher.component';
5
+ import { ThyIconModule } from 'ngx-tethys/icon';
6
+ import { ThyActionModule } from 'ngx-tethys/action';
5
7
  import * as i0 from "@angular/core";
6
8
  export class ThyArrowSwitcherModule {
7
9
  }
8
10
  ThyArrowSwitcherModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyArrowSwitcherModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
9
- ThyArrowSwitcherModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyArrowSwitcherModule, declarations: [ThyArrowSwitcherComponent], imports: [CommonModule, ThyButtonModule], exports: [ThyArrowSwitcherComponent] });
10
- ThyArrowSwitcherModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyArrowSwitcherModule, imports: [[CommonModule, ThyButtonModule]] });
11
+ ThyArrowSwitcherModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyArrowSwitcherModule, declarations: [ThyArrowSwitcherComponent], imports: [CommonModule, ThyButtonModule, ThyIconModule, ThyActionModule], exports: [ThyArrowSwitcherComponent] });
12
+ ThyArrowSwitcherModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyArrowSwitcherModule, imports: [[CommonModule, ThyButtonModule, ThyIconModule, ThyActionModule]] });
11
13
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyArrowSwitcherModule, decorators: [{
12
14
  type: NgModule,
13
15
  args: [{
14
16
  declarations: [ThyArrowSwitcherComponent],
15
- imports: [CommonModule, ThyButtonModule],
17
+ imports: [CommonModule, ThyButtonModule, ThyIconModule, ThyActionModule],
16
18
  exports: [ThyArrowSwitcherComponent]
17
19
  }]
18
20
  }] });
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2Fycm93LXN3aXRjaGVyL21vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDcEQsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sNEJBQTRCLENBQUM7O0FBT3ZFLE1BQU0sT0FBTyxzQkFBc0I7O21IQUF0QixzQkFBc0I7b0hBQXRCLHNCQUFzQixpQkFKaEIseUJBQXlCLGFBQzlCLFlBQVksRUFBRSxlQUFlLGFBQzdCLHlCQUF5QjtvSEFFMUIsc0JBQXNCLFlBSHRCLENBQUMsWUFBWSxFQUFFLGVBQWUsQ0FBQzsyRkFHL0Isc0JBQXNCO2tCQUxsQyxRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRSxDQUFDLHlCQUF5QixDQUFDO29CQUN6QyxPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsZUFBZSxDQUFDO29CQUN4QyxPQUFPLEVBQUUsQ0FBQyx5QkFBeUIsQ0FBQztpQkFDdkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IFRoeUJ1dHRvbk1vZHVsZSB9IGZyb20gJ25neC10ZXRoeXMvYnV0dG9uJztcbmltcG9ydCB7IFRoeUFycm93U3dpdGNoZXJDb21wb25lbnQgfSBmcm9tICcuL2Fycm93LXN3aXRjaGVyLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbVGh5QXJyb3dTd2l0Y2hlckNvbXBvbmVudF0sXG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgVGh5QnV0dG9uTW9kdWxlXSxcbiAgICBleHBvcnRzOiBbVGh5QXJyb3dTd2l0Y2hlckNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgVGh5QXJyb3dTd2l0Y2hlck1vZHVsZSB7fVxuIl19
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2Fycm93LXN3aXRjaGVyL21vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDcEQsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDdkUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ2hELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQzs7QUFPcEQsTUFBTSxPQUFPLHNCQUFzQjs7bUhBQXRCLHNCQUFzQjtvSEFBdEIsc0JBQXNCLGlCQUpoQix5QkFBeUIsYUFDOUIsWUFBWSxFQUFFLGVBQWUsRUFBRSxhQUFhLEVBQUUsZUFBZSxhQUM3RCx5QkFBeUI7b0hBRTFCLHNCQUFzQixZQUh0QixDQUFDLFlBQVksRUFBRSxlQUFlLEVBQUUsYUFBYSxFQUFFLGVBQWUsQ0FBQzsyRkFHL0Qsc0JBQXNCO2tCQUxsQyxRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRSxDQUFDLHlCQUF5QixDQUFDO29CQUN6QyxPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsZUFBZSxFQUFFLGFBQWEsRUFBRSxlQUFlLENBQUM7b0JBQ3hFLE9BQU8sRUFBRSxDQUFDLHlCQUF5QixDQUFDO2lCQUN2QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgVGh5QnV0dG9uTW9kdWxlIH0gZnJvbSAnbmd4LXRldGh5cy9idXR0b24nO1xuaW1wb3J0IHsgVGh5QXJyb3dTd2l0Y2hlckNvbXBvbmVudCB9IGZyb20gJy4vYXJyb3ctc3dpdGNoZXIuY29tcG9uZW50JztcbmltcG9ydCB7IFRoeUljb25Nb2R1bGUgfSBmcm9tICduZ3gtdGV0aHlzL2ljb24nO1xuaW1wb3J0IHsgVGh5QWN0aW9uTW9kdWxlIH0gZnJvbSAnbmd4LXRldGh5cy9hY3Rpb24nO1xuXG5ATmdNb2R1bGUoe1xuICAgIGRlY2xhcmF0aW9uczogW1RoeUFycm93U3dpdGNoZXJDb21wb25lbnRdLFxuICAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIFRoeUJ1dHRvbk1vZHVsZSwgVGh5SWNvbk1vZHVsZSwgVGh5QWN0aW9uTW9kdWxlXSxcbiAgICBleHBvcnRzOiBbVGh5QXJyb3dTd2l0Y2hlckNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgVGh5QXJyb3dTd2l0Y2hlck1vZHVsZSB7fVxuIl19
@@ -1,5 +1,8 @@
1
1
  import { Directive } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
+ /**
4
+ * 自定义日期单元格,模版内容会被追加到单元格,可通过 *thyDateCell 传入模板
5
+ */
3
6
  export class ThyDateCellDirective {
4
7
  }
5
8
  ThyDateCellDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyDateCellDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
@@ -11,39 +14,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImpor
11
14
  exportAs: 'thyDateCell'
12
15
  }]
13
16
  }] });
14
- export class ThyMonthCellDirective {
15
- }
16
- ThyMonthCellDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyMonthCellDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
17
- ThyMonthCellDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.6", type: ThyMonthCellDirective, selector: "[thyMonthCell]", exportAs: ["thyMonthCell"], ngImport: i0 });
18
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyMonthCellDirective, decorators: [{
19
- type: Directive,
20
- args: [{
21
- selector: '[thyMonthCell]',
22
- exportAs: 'thyMonthCell'
23
- }]
24
- }] });
25
- export class ThyDateFullCellDirective {
26
- }
27
- ThyDateFullCellDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyDateFullCellDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
28
- ThyDateFullCellDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.6", type: ThyDateFullCellDirective, selector: "[thyDateFullCell]", exportAs: ["thyDateFullCell"], ngImport: i0 });
29
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyDateFullCellDirective, decorators: [{
30
- type: Directive,
31
- args: [{
32
- selector: '[thyDateFullCell]',
33
- exportAs: 'thyDateFullCell'
34
- }]
35
- }] });
36
- export class ThyMonthFullCellDirective {
37
- }
38
- ThyMonthFullCellDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyMonthFullCellDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
39
- ThyMonthFullCellDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.6", type: ThyMonthFullCellDirective, selector: "[thyMonthFullCell]", exportAs: ["thyMonthFullCell"], ngImport: i0 });
40
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyMonthFullCellDirective, decorators: [{
41
- type: Directive,
42
- args: [{
43
- selector: '[thyMonthFullCell]',
44
- exportAs: 'thyMonthFullCell'
45
- }]
46
- }] });
17
+ /**
18
+ * 自定义右上角操作项,可通过 *thyCalendarHeaderOperation传入模板
19
+ */
47
20
  export class ThyCalendarHeaderOperationDirective {
48
21
  }
49
22
  ThyCalendarHeaderOperationDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.6", ngImport: i0, type: ThyCalendarHeaderOperationDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
@@ -55,4 +28,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImpor
55
28
  exportAs: 'thyCalendarHeaderOperation'
56
29
  }]
57
30
  }] });
58
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItY2VsbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY2FsZW5kYXIvY2FsZW5kYXItY2VsbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFNMUMsTUFBTSxPQUFPLG9CQUFvQjs7aUhBQXBCLG9CQUFvQjtxR0FBcEIsb0JBQW9COzJGQUFwQixvQkFBb0I7a0JBSmhDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLGVBQWU7b0JBQ3pCLFFBQVEsRUFBRSxhQUFhO2lCQUMxQjs7QUFPRCxNQUFNLE9BQU8scUJBQXFCOztrSEFBckIscUJBQXFCO3NHQUFyQixxQkFBcUI7MkZBQXJCLHFCQUFxQjtrQkFKakMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsZ0JBQWdCO29CQUMxQixRQUFRLEVBQUUsY0FBYztpQkFDM0I7O0FBT0QsTUFBTSxPQUFPLHdCQUF3Qjs7cUhBQXhCLHdCQUF3Qjt5R0FBeEIsd0JBQXdCOzJGQUF4Qix3QkFBd0I7a0JBSnBDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLG1CQUFtQjtvQkFDN0IsUUFBUSxFQUFFLGlCQUFpQjtpQkFDOUI7O0FBT0QsTUFBTSxPQUFPLHlCQUF5Qjs7c0hBQXpCLHlCQUF5QjswR0FBekIseUJBQXlCOzJGQUF6Qix5QkFBeUI7a0JBSnJDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLG9CQUFvQjtvQkFDOUIsUUFBUSxFQUFFLGtCQUFrQjtpQkFDL0I7O0FBT0QsTUFBTSxPQUFPLG1DQUFtQzs7Z0lBQW5DLG1DQUFtQztvSEFBbkMsbUNBQW1DOzJGQUFuQyxtQ0FBbUM7a0JBSi9DLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLDhCQUE4QjtvQkFDeEMsUUFBUSxFQUFFLDRCQUE0QjtpQkFDekMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbdGh5RGF0ZUNlbGxdJyxcbiAgICBleHBvcnRBczogJ3RoeURhdGVDZWxsJ1xufSlcbmV4cG9ydCBjbGFzcyBUaHlEYXRlQ2VsbERpcmVjdGl2ZSB7fVxuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1t0aHlNb250aENlbGxdJyxcbiAgICBleHBvcnRBczogJ3RoeU1vbnRoQ2VsbCdcbn0pXG5leHBvcnQgY2xhc3MgVGh5TW9udGhDZWxsRGlyZWN0aXZlIHt9XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW3RoeURhdGVGdWxsQ2VsbF0nLFxuICAgIGV4cG9ydEFzOiAndGh5RGF0ZUZ1bGxDZWxsJ1xufSlcbmV4cG9ydCBjbGFzcyBUaHlEYXRlRnVsbENlbGxEaXJlY3RpdmUge31cblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbdGh5TW9udGhGdWxsQ2VsbF0nLFxuICAgIGV4cG9ydEFzOiAndGh5TW9udGhGdWxsQ2VsbCdcbn0pXG5leHBvcnQgY2xhc3MgVGh5TW9udGhGdWxsQ2VsbERpcmVjdGl2ZSB7fVxuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1t0aHlDYWxlbmRhckhlYWRlck9wZXJhdGlvbl0nLFxuICAgIGV4cG9ydEFzOiAndGh5Q2FsZW5kYXJIZWFkZXJPcGVyYXRpb24nXG59KVxuZXhwb3J0IGNsYXNzIFRoeUNhbGVuZGFySGVhZGVyT3BlcmF0aW9uRGlyZWN0aXZlIHt9XG4iXX0=
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItY2VsbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY2FsZW5kYXIvY2FsZW5kYXItY2VsbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFMUM7O0dBRUc7QUFLSCxNQUFNLE9BQU8sb0JBQW9COztpSEFBcEIsb0JBQW9CO3FHQUFwQixvQkFBb0I7MkZBQXBCLG9CQUFvQjtrQkFKaEMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsZUFBZTtvQkFDekIsUUFBUSxFQUFFLGFBQWE7aUJBQzFCOztBQUdEOztHQUVHO0FBS0gsTUFBTSxPQUFPLG1DQUFtQzs7Z0lBQW5DLG1DQUFtQztvSEFBbkMsbUNBQW1DOzJGQUFuQyxtQ0FBbUM7a0JBSi9DLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLDhCQUE4QjtvQkFDeEMsUUFBUSxFQUFFLDRCQUE0QjtpQkFDekMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyoqXG4gKiDoh6rlrprkuYnml6XmnJ/ljZXlhYPmoLzvvIzmqKHniYjlhoXlrrnkvJrooqvov73liqDliLDljZXlhYPmoLzvvIzlj6/pgJrov4cgKnRoeURhdGVDZWxsIOS8oOWFpeaooeadv1xuICovXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1t0aHlEYXRlQ2VsbF0nLFxuICAgIGV4cG9ydEFzOiAndGh5RGF0ZUNlbGwnXG59KVxuZXhwb3J0IGNsYXNzIFRoeURhdGVDZWxsRGlyZWN0aXZlIHt9XG5cbi8qKlxuICog6Ieq5a6a5LmJ5Y+z5LiK6KeS5pON5L2c6aG577yM5Y+v6YCa6L+HICp0aHlDYWxlbmRhckhlYWRlck9wZXJhdGlvbuS8oOWFpeaooeadv1xuICovXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1t0aHlDYWxlbmRhckhlYWRlck9wZXJhdGlvbl0nLFxuICAgIGV4cG9ydEFzOiAndGh5Q2FsZW5kYXJIZWFkZXJPcGVyYXRpb24nXG59KVxuZXhwb3J0IGNsYXNzIFRoeUNhbGVuZGFySGVhZGVyT3BlcmF0aW9uRGlyZWN0aXZlIHt9XG4iXX0=
@@ -6,13 +6,24 @@ import * as i1 from "ngx-tethys/date-range";
6
6
  import * as i2 from "ngx-tethys/button";
7
7
  import * as i3 from "@angular/forms";
8
8
  import * as i4 from "@angular/common";
9
+ /**
10
+ * 日历头部操作栏组件
11
+ */
9
12
  export class ThyCalendarHeaderComponent {
10
13
  constructor(cdr) {
11
14
  this.cdr = cdr;
12
15
  this.className = true;
13
- // @Output() readonly modeChange: EventEmitter<'month' | 'year'> = new EventEmitter();
16
+ /**
17
+ * 日期选择范围(年)发生变化的回调
18
+ */
14
19
  this.yearChange = new EventEmitter();
20
+ /**
21
+ * 日期选择范围(月)发生变化的回调
22
+ */
15
23
  this.monthChange = new EventEmitter();
24
+ /**
25
+ * 日期选择范围(日期)发生变化的回调
26
+ */
16
27
  this.dateRangeChange = new EventEmitter();
17
28
  this.dateRanges = [
18
29
  {
@@ -27,8 +38,9 @@ export class ThyCalendarHeaderComponent {
27
38
  }
28
39
  ];
29
40
  }
30
- // @Input() mode: 'month' | 'year' = 'month';
31
- // @Input() fullscreen = true;
41
+ /**
42
+ * 当前选中日期
43
+ */
32
44
  set currentDate(value) {
33
45
  this.setDate(value);
34
46
  }
@@ -94,4 +106,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImpor
94
106
  }], dateRangeChange: [{
95
107
  type: Output
96
108
  }] } });
97
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-header.component.js","sourceRoot":"","sources":["../../../../src/calendar/calendar-header.component.ts","../../../../src/calendar/calendar-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { fromUnixTime, getMonth, getYear } from 'date-fns';\nimport { DateRangeItemInfo } from 'ngx-tethys/date-range';\nimport { endOfMonth, FunctionProp, getUnixTime, startOfMonth, TinyDate } from 'ngx-tethys/util';\n\nimport { ChangeDetectorRef, Component, EventEmitter, HostBinding, Input, OnInit, Output, TemplateRef } from '@angular/core';\n\n@Component({\n    selector: 'thy-calendar-header',\n    templateUrl: './calendar-header.component.html'\n})\nexport class ThyCalendarHeaderComponent implements OnInit {\n    @HostBinding('class.thy-calendar-full-header-container') className = true;\n\n    // @Input() mode: 'month' | 'year' = 'month';\n\n    // @Input() fullscreen = true;\n\n    @Input()\n    set currentDate(value: TinyDate) {\n        this.setDate(value);\n    }\n\n    @Input() operationRender: FunctionProp<TemplateRef<any>>;\n\n    // @Output() readonly modeChange: EventEmitter<'month' | 'year'> = new EventEmitter();\n\n    @Output() readonly yearChange: EventEmitter<number> = new EventEmitter();\n\n    @Output() readonly monthChange: EventEmitter<number> = new EventEmitter();\n\n    @Output() readonly dateRangeChange: EventEmitter<DateRangeItemInfo> = new EventEmitter();\n\n    public dateRanges: DateRangeItemInfo[] = [\n        {\n            key: 'month',\n            text: getYear(new Date()) + '年' + (getMonth(new Date()) + 1) + '月',\n            begin: getUnixTime(startOfMonth(new Date())),\n            end: getUnixTime(endOfMonth(new Date())),\n            timestamp: {\n                interval: 1,\n                unit: 'month'\n            }\n        }\n    ];\n\n    public date: DateRangeItemInfo;\n\n    private _currentDate: TinyDate;\n\n    public isCurrent: boolean;\n\n    constructor(private cdr: ChangeDetectorRef) {}\n\n    ngOnInit(): void {}\n\n    onChangeMonth(month: DateRangeItemInfo) {\n        const currentMonth = fromUnixTime(month.begin).getMonth();\n        this.monthChange.emit(currentMonth);\n    }\n\n    onChangeYear(year: DateRangeItemInfo) {\n        const currentYear = fromUnixTime(year.begin).getFullYear();\n        this.yearChange.emit(currentYear);\n    }\n\n    onChangeRange(dateRange: DateRangeItemInfo) {\n        this.isCurrentDate(this._currentDate);\n        this.onChangeYear(dateRange);\n        this.onChangeMonth(dateRange);\n        this.dateRangeChange.emit(dateRange);\n    }\n\n    backToday() {\n        this._currentDate = new TinyDate();\n        this.date = { ...this.dateRanges[0] };\n        this.onChangeRange(this.date);\n        this.cdr.detectChanges();\n    }\n\n    setDate(value: TinyDate) {\n        this.isCurrentDate(value);\n        if (this.isCurrent) {\n            this._currentDate = value;\n            const dateRange = {\n                ...this.dateRanges[0],\n                key: 'exception',\n                text: getYear(this._currentDate.nativeDate) + '年' + (getMonth(this._currentDate.nativeDate) + 1) + '月',\n                begin: getUnixTime(startOfMonth(this._currentDate.nativeDate)),\n                end: getUnixTime(endOfMonth(this._currentDate.nativeDate))\n            };\n            this.date = dateRange;\n        } else {\n            this._currentDate = new TinyDate();\n            this.date = { ...this.dateRanges[0] };\n        }\n    }\n\n    isCurrentDate(currentDate: TinyDate) {\n        this.isCurrent = currentDate.getMonth() !== getMonth(new Date()) || currentDate.getYear() !== getYear(new Date());\n    }\n}\n","<div class=\"thy-calendar-full-header-left\">\n  <thy-date-range\n    class=\"select-date-range\"\n    [ngModel]=\"date\"\n    [thyHiddenMenu]=\"true\"\n    [thyCustomKey]=\"'exception'\"\n    [thyPickerFormat]=\"'yyyy年MM月'\"\n    (ngModelChange)=\"onChangeRange($event)\"\n  ></thy-date-range>\n  <button *ngIf=\"isCurrent\" thyButton=\"outline-default-square\" thySize=\"md\" (click)=\"backToday()\">\n    今天\n  </button>\n</div>\n<div class=\"thy-calendar-full-header-right\">\n  <ng-container *ngTemplateOutlet=\"$any(operationRender); context: { $implicit: operationRender }\">\n    <span>{{ operationRender | json }}</span>\n  </ng-container>\n</div>\n"]}
109
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar-header.component.js","sourceRoot":"","sources":["../../../../src/calendar/calendar-header.component.ts","../../../../src/calendar/calendar-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { fromUnixTime, getMonth, getYear } from 'date-fns';\nimport { DateRangeItemInfo } from 'ngx-tethys/date-range';\nimport { endOfMonth, FunctionProp, getUnixTime, startOfMonth, TinyDate } from 'ngx-tethys/util';\n\nimport { ChangeDetectorRef, Component, EventEmitter, HostBinding, Input, OnInit, Output, TemplateRef } from '@angular/core';\n/**\n * 日历头部操作栏组件\n */\n@Component({\n    selector: 'thy-calendar-header',\n    templateUrl: './calendar-header.component.html'\n})\nexport class ThyCalendarHeaderComponent implements OnInit {\n    @HostBinding('class.thy-calendar-full-header-container') className = true;\n\n    /**\n     * 当前选中日期\n     */\n    @Input()\n    set currentDate(value: TinyDate) {\n        this.setDate(value);\n    }\n\n    /**\n     * \t自定义渲染右侧操作项\n     */\n    @Input() operationRender: FunctionProp<TemplateRef<any>>;\n\n    /**\n     * 日期选择范围（年）发生变化的回调\n     */\n    @Output() readonly yearChange: EventEmitter<number> = new EventEmitter();\n\n    /**\n     * 日期选择范围（月）发生变化的回调\n     */\n    @Output() readonly monthChange: EventEmitter<number> = new EventEmitter();\n\n    /**\n     * 日期选择范围（日期）发生变化的回调\n     */\n    @Output() readonly dateRangeChange: EventEmitter<DateRangeItemInfo> = new EventEmitter();\n\n    public dateRanges: DateRangeItemInfo[] = [\n        {\n            key: 'month',\n            text: getYear(new Date()) + '年' + (getMonth(new Date()) + 1) + '月',\n            begin: getUnixTime(startOfMonth(new Date())),\n            end: getUnixTime(endOfMonth(new Date())),\n            timestamp: {\n                interval: 1,\n                unit: 'month'\n            }\n        }\n    ];\n\n    public date: DateRangeItemInfo;\n\n    private _currentDate: TinyDate;\n\n    public isCurrent: boolean;\n\n    constructor(private cdr: ChangeDetectorRef) {}\n\n    ngOnInit(): void {}\n\n    onChangeMonth(month: DateRangeItemInfo) {\n        const currentMonth = fromUnixTime(month.begin).getMonth();\n        this.monthChange.emit(currentMonth);\n    }\n\n    onChangeYear(year: DateRangeItemInfo) {\n        const currentYear = fromUnixTime(year.begin).getFullYear();\n        this.yearChange.emit(currentYear);\n    }\n\n    onChangeRange(dateRange: DateRangeItemInfo) {\n        this.isCurrentDate(this._currentDate);\n        this.onChangeYear(dateRange);\n        this.onChangeMonth(dateRange);\n        this.dateRangeChange.emit(dateRange);\n    }\n\n    backToday() {\n        this._currentDate = new TinyDate();\n        this.date = { ...this.dateRanges[0] };\n        this.onChangeRange(this.date);\n        this.cdr.detectChanges();\n    }\n\n    setDate(value: TinyDate) {\n        this.isCurrentDate(value);\n        if (this.isCurrent) {\n            this._currentDate = value;\n            const dateRange = {\n                ...this.dateRanges[0],\n                key: 'exception',\n                text: getYear(this._currentDate.nativeDate) + '年' + (getMonth(this._currentDate.nativeDate) + 1) + '月',\n                begin: getUnixTime(startOfMonth(this._currentDate.nativeDate)),\n                end: getUnixTime(endOfMonth(this._currentDate.nativeDate))\n            };\n            this.date = dateRange;\n        } else {\n            this._currentDate = new TinyDate();\n            this.date = { ...this.dateRanges[0] };\n        }\n    }\n\n    isCurrentDate(currentDate: TinyDate) {\n        this.isCurrent = currentDate.getMonth() !== getMonth(new Date()) || currentDate.getYear() !== getYear(new Date());\n    }\n}\n","<div class=\"thy-calendar-full-header-left\">\n  <thy-date-range\n    class=\"select-date-range\"\n    [ngModel]=\"date\"\n    [thyHiddenMenu]=\"true\"\n    [thyCustomKey]=\"'exception'\"\n    [thyPickerFormat]=\"'yyyy年MM月'\"\n    (ngModelChange)=\"onChangeRange($event)\"\n  ></thy-date-range>\n  <button *ngIf=\"isCurrent\" thyButton=\"outline-default-square\" thySize=\"md\" (click)=\"backToday()\">\n    今天\n  </button>\n</div>\n<div class=\"thy-calendar-full-header-right\">\n  <ng-container *ngTemplateOutlet=\"$any(operationRender); context: { $implicit: operationRender }\">\n    <span>{{ operationRender | json }}</span>\n  </ng-container>\n</div>\n"]}