@semantic-components/ui 0.0.1 → 0.0.10

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 (48) hide show
  1. package/README.md +6 -0
  2. package/components/date-picker/date-picker.component.d.ts +30 -2
  3. package/components/date-picker/index.d.ts +1 -0
  4. package/components/date-picker/inline-date-picker.component.d.ts +23 -0
  5. package/components/date-picker/month-days.component.d.ts +11 -0
  6. package/components/date-picker/month-year-header.component.d.ts +7 -0
  7. package/components/date-picker/week-days-names.component.d.ts +11 -0
  8. package/components/dropdown/dropdown-divider.component.d.ts +5 -0
  9. package/components/dropdown/dropdown-item.component.d.ts +6 -0
  10. package/components/dropdown/dropdown.component.d.ts +5 -0
  11. package/components/dropdown/index.d.ts +3 -0
  12. package/components/editor/editor.component.d.ts +1 -1
  13. package/components/nav/index.d.ts +3 -0
  14. package/components/nav/nav-item-dropdown.component.d.ts +5 -0
  15. package/components/nav/nav-item.component.d.ts +5 -0
  16. package/components/nav/nav.component.d.ts +5 -0
  17. package/components/select/index.d.ts +2 -0
  18. package/components/select/select-option.component.d.ts +7 -0
  19. package/components/select/select.component.d.ts +55 -0
  20. package/components/tooltip/tooltip.component.d.ts +1 -1
  21. package/esm2022/components/date-picker/date-picker.component.mjs +181 -8
  22. package/esm2022/components/date-picker/index.mjs +2 -1
  23. package/esm2022/components/date-picker/inline-date-picker.component.mjs +185 -0
  24. package/esm2022/components/date-picker/month-days.component.mjs +69 -0
  25. package/esm2022/components/date-picker/month-year-header.component.mjs +124 -0
  26. package/esm2022/components/date-picker/week-days-names.component.mjs +37 -0
  27. package/esm2022/components/dropdown/dropdown-divider.component.mjs +16 -0
  28. package/esm2022/components/dropdown/dropdown-item.component.mjs +33 -0
  29. package/esm2022/components/dropdown/dropdown.component.mjs +85 -0
  30. package/esm2022/components/dropdown/index.mjs +4 -0
  31. package/esm2022/components/editor/editor.component.mjs +4 -4
  32. package/esm2022/components/nav/index.mjs +4 -0
  33. package/esm2022/components/nav/nav-item-dropdown.component.mjs +148 -0
  34. package/esm2022/components/nav/nav-item.component.mjs +16 -0
  35. package/esm2022/components/nav/nav.component.mjs +16 -0
  36. package/esm2022/components/select/index.mjs +3 -0
  37. package/esm2022/components/select/select-option.component.mjs +28 -0
  38. package/esm2022/components/select/select.component.mjs +252 -0
  39. package/esm2022/components/tooltip/tooltip.component.mjs +4 -4
  40. package/esm2022/index.mjs +4 -2
  41. package/fesm2022/semantic-components-ui.mjs +1132 -559
  42. package/fesm2022/semantic-components-ui.mjs.map +1 -1
  43. package/index.d.ts +3 -1
  44. package/package.json +7 -3
  45. package/components/navbar/index.d.ts +0 -1
  46. package/components/navbar/navbar.component.d.ts +0 -5
  47. package/esm2022/components/navbar/index.mjs +0 -2
  48. package/esm2022/components/navbar/navbar.component.mjs +0 -566
@@ -0,0 +1,185 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, Inject, LOCALE_ID, ViewEncapsulation, computed, signal, } from '@angular/core';
3
+ import { MonthDaysComponent } from './month-days.component';
4
+ import { MonthYearHeaderComponent } from './month-year-header.component';
5
+ import { WeekDaysNamesComponent } from './week-days-names.component';
6
+ import * as i0 from "@angular/core";
7
+ export class InlineDatePickerComponent {
8
+ localeId;
9
+ year = signal(0);
10
+ month = signal(0);
11
+ weekDaysNames = signal([]);
12
+ monthYear = computed(() => {
13
+ const options = {
14
+ month: 'long',
15
+ year: 'numeric',
16
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
17
+ };
18
+ const s = new Intl.DateTimeFormat(this.localeId, options).format(new Date(this.year(), this.month(), 1));
19
+ return s;
20
+ });
21
+ monthDays = computed(() => {
22
+ // Month in JavaScript is 0-indexed (January is 0, February is 1, etc),
23
+ // but by using 0 as the day it will give us the last day of the prior
24
+ // month. So passing in 1 as the month number will return the last day
25
+ // of January, not February
26
+ const numOfDays = new Date(this.year(), this.month() + 1, 0).getDate();
27
+ const days = [];
28
+ for (let i = 1; i <= numOfDays; i++) {
29
+ const date = new Date(this.year(), this.month(), i);
30
+ days.push(`${date.getFullYear()}-${this.twoDigits(date.getMonth() + 1)}-${this.twoDigits(date.getDate())}`);
31
+ }
32
+ return days;
33
+ });
34
+ firstDayMonth = computed(() => {
35
+ const date = new Date(this.year(), this.month(), 1);
36
+ const intlLongFormatter = new Intl.DateTimeFormat(this.localeId, { weekday: 'long' });
37
+ const dayName = intlLongFormatter.format(date);
38
+ return this.weekDaysNames()
39
+ .map((e) => e.long)
40
+ .indexOf(dayName);
41
+ });
42
+ selectedDay = signal('');
43
+ constructor(localeId) {
44
+ this.localeId = localeId;
45
+ }
46
+ ngOnInit() {
47
+ this.init();
48
+ this.setLocaleDayNames();
49
+ }
50
+ init() {
51
+ const today = new Date();
52
+ this.year.set(today.getFullYear());
53
+ this.month.set(today.getMonth());
54
+ }
55
+ setSelectedDay(day) {
56
+ this.selectedDay.set(day);
57
+ }
58
+ //https://github.com/angular/angular/issues/57193
59
+ setLocaleDayNames() {
60
+ const weekDaysNames = [];
61
+ const intlNarrowFormatter = new Intl.DateTimeFormat(this.localeId, { weekday: 'narrow' });
62
+ const intlShortFormatter = new Intl.DateTimeFormat(this.localeId, { weekday: 'short' });
63
+ const intlLongFormatter = new Intl.DateTimeFormat(this.localeId, { weekday: 'long' });
64
+ let k = 0;
65
+ const firstDayOfWeek = this.getFirstDayOfWeek();
66
+ if (firstDayOfWeek === 7) {
67
+ // First day of the week is Sunday
68
+ k = 3; // 3th January 2021 is a Sunday
69
+ }
70
+ if (firstDayOfWeek === 1) {
71
+ // First day of the week is Monday
72
+ k = 4; // 4th January 2021 is a Monday
73
+ }
74
+ for (let i = 0; i < 7; i += 1) {
75
+ const date = new Date(Date.UTC(2021, 0, i + k));
76
+ weekDaysNames.push({
77
+ narrow: intlNarrowFormatter.format(date),
78
+ short: intlShortFormatter.format(date),
79
+ long: intlLongFormatter.format(date),
80
+ });
81
+ }
82
+ this.weekDaysNames.set(weekDaysNames);
83
+ }
84
+ getFirstDayOfWeek() {
85
+ const locale = new Intl.Locale(this.localeId);
86
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
87
+ return locale.getWeekInfo().firstDay;
88
+ }
89
+ setMonthYear(n) {
90
+ if (n === 1) {
91
+ if (this.month() < 11) {
92
+ this.month.update((value) => value + 1);
93
+ }
94
+ else {
95
+ this.month.set(0);
96
+ this.year.update((value) => value + 1);
97
+ }
98
+ }
99
+ if (n === -1) {
100
+ if (this.month() > 0) {
101
+ this.month.update((value) => value - 1);
102
+ }
103
+ else {
104
+ this.month.set(11);
105
+ this.year.update((value) => value - 1);
106
+ }
107
+ }
108
+ }
109
+ twoDigits(n) {
110
+ return n.toLocaleString(this.localeId, {
111
+ minimumIntegerDigits: 2,
112
+ useGrouping: false,
113
+ });
114
+ }
115
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: InlineDatePickerComponent, deps: [{ token: LOCALE_ID }], target: i0.ɵɵFactoryTarget.Component });
116
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.11", type: InlineDatePickerComponent, isStandalone: true, selector: "sc-inline-date-picker", ngImport: i0, template: `
117
+ <div class="inline-block rounded-lg bg-white p-4 shadow-lg dark:bg-gray-700">
118
+ <div class="bg-white px-2 py-3 text-center font-semibold dark:bg-gray-700 dark:text-white">
119
+ <sc-month-year-header [monthYear]="monthYear()" (monthYearChange)="setMonthYear($event)" />
120
+ </div>
121
+
122
+ <sc-week-days-names [weekDaysNames]="weekDaysNames()" />
123
+
124
+ <sc-month-days
125
+ [days]="monthDays()"
126
+ [firstDayMonth]="firstDayMonth()"
127
+ [selectedDay]="selectedDay()"
128
+ (selectedDayChange)="setSelectedDay($event)"
129
+ />
130
+
131
+ <div class="mt-2 flex space-x-2 rtl:space-x-reverse">
132
+ <button
133
+ class="bg-primary-700 hover:bg-primary-800 dark:hover:bg-primary-700 focus:ring-primary-300 dark:bg-primary-600 w-1/2 rounded-lg px-5 py-2 text-center text-sm font-medium text-white focus:ring-4"
134
+ type="button"
135
+ >
136
+ Today
137
+ </button>
138
+ <button
139
+ class="focus:ring-primary-300 w-1/2 rounded-lg border border-gray-300 bg-white px-5 py-2 text-center text-sm font-medium text-gray-900 hover:bg-gray-100 focus:ring-4 dark:border-gray-600 dark:bg-gray-700 dark:text-white dark:hover:bg-gray-600"
140
+ type="button"
141
+ >
142
+ Clear
143
+ </button>
144
+ </div>
145
+ </div>
146
+ `, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: WeekDaysNamesComponent, selector: "sc-week-days-names", inputs: ["weekDaysNames"] }, { kind: "component", type: MonthYearHeaderComponent, selector: "sc-month-year-header", inputs: ["monthYear"], outputs: ["monthYearChange"] }, { kind: "component", type: MonthDaysComponent, selector: "sc-month-days", inputs: ["days", "firstDayMonth", "selectedDay"], outputs: ["selectedDayChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
147
+ }
148
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: InlineDatePickerComponent, decorators: [{
149
+ type: Component,
150
+ args: [{ selector: 'sc-inline-date-picker', standalone: true, imports: [CommonModule, WeekDaysNamesComponent, MonthYearHeaderComponent, MonthDaysComponent], template: `
151
+ <div class="inline-block rounded-lg bg-white p-4 shadow-lg dark:bg-gray-700">
152
+ <div class="bg-white px-2 py-3 text-center font-semibold dark:bg-gray-700 dark:text-white">
153
+ <sc-month-year-header [monthYear]="monthYear()" (monthYearChange)="setMonthYear($event)" />
154
+ </div>
155
+
156
+ <sc-week-days-names [weekDaysNames]="weekDaysNames()" />
157
+
158
+ <sc-month-days
159
+ [days]="monthDays()"
160
+ [firstDayMonth]="firstDayMonth()"
161
+ [selectedDay]="selectedDay()"
162
+ (selectedDayChange)="setSelectedDay($event)"
163
+ />
164
+
165
+ <div class="mt-2 flex space-x-2 rtl:space-x-reverse">
166
+ <button
167
+ class="bg-primary-700 hover:bg-primary-800 dark:hover:bg-primary-700 focus:ring-primary-300 dark:bg-primary-600 w-1/2 rounded-lg px-5 py-2 text-center text-sm font-medium text-white focus:ring-4"
168
+ type="button"
169
+ >
170
+ Today
171
+ </button>
172
+ <button
173
+ class="focus:ring-primary-300 w-1/2 rounded-lg border border-gray-300 bg-white px-5 py-2 text-center text-sm font-medium text-gray-900 hover:bg-gray-100 focus:ring-4 dark:border-gray-600 dark:bg-gray-700 dark:text-white dark:hover:bg-gray-600"
174
+ type="button"
175
+ >
176
+ Clear
177
+ </button>
178
+ </div>
179
+ </div>
180
+ `, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush }]
181
+ }], ctorParameters: () => [{ type: undefined, decorators: [{
182
+ type: Inject,
183
+ args: [LOCALE_ID]
184
+ }] }] });
185
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inline-date-picker.component.js","sourceRoot":"","sources":["../../../../../../libs/ui/src/components/date-picker/inline-date-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  Inject,\n  LOCALE_ID,\n  OnInit,\n  ViewEncapsulation,\n  computed,\n  signal,\n} from '@angular/core';\n\nimport { MonthDaysComponent } from './month-days.component';\nimport { MonthYearHeaderComponent } from './month-year-header.component';\nimport { WeekDayName, WeekDaysNamesComponent } from './week-days-names.component';\n\n@Component({\n  selector: 'sc-inline-date-picker',\n  standalone: true,\n  imports: [CommonModule, WeekDaysNamesComponent, MonthYearHeaderComponent, MonthDaysComponent],\n  template: `\n    <div class=\"inline-block rounded-lg bg-white p-4 shadow-lg dark:bg-gray-700\">\n      <div class=\"bg-white px-2 py-3 text-center font-semibold dark:bg-gray-700 dark:text-white\">\n        <sc-month-year-header [monthYear]=\"monthYear()\" (monthYearChange)=\"setMonthYear($event)\" />\n      </div>\n\n      <sc-week-days-names [weekDaysNames]=\"weekDaysNames()\" />\n\n      <sc-month-days\n        [days]=\"monthDays()\"\n        [firstDayMonth]=\"firstDayMonth()\"\n        [selectedDay]=\"selectedDay()\"\n        (selectedDayChange)=\"setSelectedDay($event)\"\n      />\n\n      <div class=\"mt-2 flex space-x-2 rtl:space-x-reverse\">\n        <button\n          class=\"bg-primary-700 hover:bg-primary-800 dark:hover:bg-primary-700 focus:ring-primary-300 dark:bg-primary-600 w-1/2 rounded-lg px-5 py-2 text-center text-sm font-medium text-white focus:ring-4\"\n          type=\"button\"\n        >\n          Today\n        </button>\n        <button\n          class=\"focus:ring-primary-300 w-1/2 rounded-lg border border-gray-300 bg-white px-5 py-2 text-center text-sm font-medium text-gray-900 hover:bg-gray-100 focus:ring-4 dark:border-gray-600 dark:bg-gray-700 dark:text-white dark:hover:bg-gray-600\"\n          type=\"button\"\n        >\n          Clear\n        </button>\n      </div>\n    </div>\n  `,\n  styles: ``,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class InlineDatePickerComponent implements OnInit {\n  year = signal<number>(0);\n  month = signal<number>(0);\n  weekDaysNames = signal<WeekDayName[]>([]);\n\n  monthYear = computed(() => {\n    const options = {\n      month: 'long',\n      year: 'numeric',\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    } as any;\n\n    const s = new Intl.DateTimeFormat(this.localeId, options).format(\n      new Date(this.year(), this.month(), 1),\n    );\n\n    return s;\n  });\n\n  monthDays = computed(() => {\n    // Month in JavaScript is 0-indexed (January is 0, February is 1, etc),\n    // but by using 0 as the day it will give us the last day of the prior\n    // month. So passing in 1 as the month number will return the last day\n    // of January, not February\n    const numOfDays = new Date(this.year(), this.month() + 1, 0).getDate();\n\n    const days = [];\n\n    for (let i = 1; i <= numOfDays; i++) {\n      const date = new Date(this.year(), this.month(), i);\n\n      days.push(\n        `${date.getFullYear()}-${this.twoDigits(date.getMonth() + 1)}-${this.twoDigits(date.getDate())}`,\n      );\n    }\n\n    return days;\n  });\n\n  firstDayMonth = computed(() => {\n    const date = new Date(this.year(), this.month(), 1);\n    const intlLongFormatter = new Intl.DateTimeFormat(this.localeId, { weekday: 'long' });\n\n    const dayName = intlLongFormatter.format(date);\n    return this.weekDaysNames()\n      .map((e) => e.long)\n      .indexOf(dayName);\n  });\n\n  selectedDay = signal<string>('');\n\n  constructor(@Inject(LOCALE_ID) private readonly localeId: string) {}\n\n  ngOnInit() {\n    this.init();\n    this.setLocaleDayNames();\n  }\n\n  init() {\n    const today = new Date();\n    this.year.set(today.getFullYear());\n    this.month.set(today.getMonth());\n  }\n\n  setSelectedDay(day: string) {\n    this.selectedDay.set(day);\n  }\n\n  //https://github.com/angular/angular/issues/57193\n  private setLocaleDayNames() {\n    const weekDaysNames = [];\n    const intlNarrowFormatter = new Intl.DateTimeFormat(this.localeId, { weekday: 'narrow' });\n    const intlShortFormatter = new Intl.DateTimeFormat(this.localeId, { weekday: 'short' });\n    const intlLongFormatter = new Intl.DateTimeFormat(this.localeId, { weekday: 'long' });\n\n    let k = 0;\n    const firstDayOfWeek = this.getFirstDayOfWeek();\n    if (firstDayOfWeek === 7) {\n      // First day of the week is Sunday\n      k = 3; // 3th January 2021 is a Sunday\n    }\n    if (firstDayOfWeek === 1) {\n      // First day of the week is Monday\n      k = 4; // 4th January 2021 is a Monday\n    }\n\n    for (let i = 0; i < 7; i += 1) {\n      const date = new Date(Date.UTC(2021, 0, i + k));\n      weekDaysNames.push({\n        narrow: intlNarrowFormatter.format(date),\n        short: intlShortFormatter.format(date),\n        long: intlLongFormatter.format(date),\n      });\n    }\n\n    this.weekDaysNames.set(weekDaysNames);\n  }\n\n  private getFirstDayOfWeek(): number {\n    const locale = new Intl.Locale(this.localeId);\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    return (locale as any).getWeekInfo().firstDay;\n  }\n\n  setMonthYear(n: number) {\n    if (n === 1) {\n      if (this.month() < 11) {\n        this.month.update((value) => value + 1);\n      } else {\n        this.month.set(0);\n        this.year.update((value) => value + 1);\n      }\n    }\n\n    if (n === -1) {\n      if (this.month() > 0) {\n        this.month.update((value) => value - 1);\n      } else {\n        this.month.set(11);\n        this.year.update((value) => value - 1);\n      }\n    }\n  }\n\n  twoDigits(n: number) {\n    return n.toLocaleString(this.localeId, {\n      minimumIntegerDigits: 2,\n      useGrouping: false,\n    });\n  }\n}\n"]}
@@ -0,0 +1,69 @@
1
+ import { CommonModule, NgClass } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, ViewEncapsulation, input, output, } from '@angular/core';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ export class MonthDaysComponent {
6
+ days = input.required();
7
+ firstDayMonth = input.required();
8
+ selectedDay = input('');
9
+ selectedDayChange = output();
10
+ isSelected(day) {
11
+ return day === this.selectedDay();
12
+ }
13
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
14
+ setSelectedDay(event) {
15
+ const selectedDay = event.target.dataset.scDay;
16
+ this.selectedDayChange.emit(selectedDay);
17
+ }
18
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: MonthDaysComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
19
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.11", type: MonthDaysComponent, isStandalone: true, selector: "sc-month-days", inputs: { days: { classPropertyName: "days", publicName: "days", isSignal: true, isRequired: true, transformFunction: null }, firstDayMonth: { classPropertyName: "firstDayMonth", publicName: "firstDayMonth", isSignal: true, isRequired: true, transformFunction: null }, selectedDay: { classPropertyName: "selectedDay", publicName: "selectedDay", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { selectedDayChange: "selectedDayChange" }, ngImport: i0, template: `
20
+ <div class="grid w-64 grid-cols-7">
21
+ @for (day of days(); track $index; let index = $index) {
22
+ <button
23
+ class="block flex-1 cursor-pointer rounded-lg border-0 text-center text-sm font-semibold leading-9 text-gray-900 hover:bg-gray-100 dark:text-white dark:hover:bg-gray-600"
24
+ [ngClass]="{
25
+ 'col-start-1': index === 0 && firstDayMonth() === 0,
26
+ 'col-start-2': index === 0 && firstDayMonth() === 1,
27
+ 'col-start-3': index === 0 && firstDayMonth() === 2,
28
+ 'col-start-4': index === 0 && firstDayMonth() === 3,
29
+ 'col-start-5': index === 0 && firstDayMonth() === 4,
30
+ 'col-start-6': index === 0 && firstDayMonth() === 5,
31
+ 'col-start-7': index === 0 && firstDayMonth() === 6,
32
+ '!bg-primary-700 dark:!bg-primary-600 !text-white': isSelected(day),
33
+ }"
34
+ [attr.data-sc-day]="day"
35
+ (click)="setSelectedDay($event)"
36
+ >
37
+ {{ day.slice(-2) }}
38
+ </button>
39
+ }
40
+ </div>
41
+ `, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
42
+ }
43
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: MonthDaysComponent, decorators: [{
44
+ type: Component,
45
+ args: [{ selector: 'sc-month-days', standalone: true, imports: [CommonModule, NgClass], template: `
46
+ <div class="grid w-64 grid-cols-7">
47
+ @for (day of days(); track $index; let index = $index) {
48
+ <button
49
+ class="block flex-1 cursor-pointer rounded-lg border-0 text-center text-sm font-semibold leading-9 text-gray-900 hover:bg-gray-100 dark:text-white dark:hover:bg-gray-600"
50
+ [ngClass]="{
51
+ 'col-start-1': index === 0 && firstDayMonth() === 0,
52
+ 'col-start-2': index === 0 && firstDayMonth() === 1,
53
+ 'col-start-3': index === 0 && firstDayMonth() === 2,
54
+ 'col-start-4': index === 0 && firstDayMonth() === 3,
55
+ 'col-start-5': index === 0 && firstDayMonth() === 4,
56
+ 'col-start-6': index === 0 && firstDayMonth() === 5,
57
+ 'col-start-7': index === 0 && firstDayMonth() === 6,
58
+ '!bg-primary-700 dark:!bg-primary-600 !text-white': isSelected(day),
59
+ }"
60
+ [attr.data-sc-day]="day"
61
+ (click)="setSelectedDay($event)"
62
+ >
63
+ {{ day.slice(-2) }}
64
+ </button>
65
+ }
66
+ </div>
67
+ `, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush }]
68
+ }] });
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9udGgtZGF5cy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL3NyYy9jb21wb25lbnRzL2RhdGUtcGlja2VyL21vbnRoLWRheXMuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsT0FBTyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDeEQsT0FBTyxFQUNMLHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsaUJBQWlCLEVBQ2pCLEtBQUssRUFDTCxNQUFNLEdBQ1AsTUFBTSxlQUFlLENBQUM7OztBQWlDdkIsTUFBTSxPQUFPLGtCQUFrQjtJQUM3QixJQUFJLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBWSxDQUFDO0lBQ2xDLGFBQWEsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFVLENBQUM7SUFDekMsV0FBVyxHQUFHLEtBQUssQ0FBUyxFQUFFLENBQUMsQ0FBQztJQUVoQyxpQkFBaUIsR0FBRyxNQUFNLEVBQVUsQ0FBQztJQUVyQyxVQUFVLENBQUMsR0FBVztRQUNwQixPQUFPLEdBQUcsS0FBSyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDcEMsQ0FBQztJQUVELDhEQUE4RDtJQUM5RCxjQUFjLENBQUMsS0FBVTtRQUN2QixNQUFNLFdBQVcsR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUM7UUFDL0MsSUFBSSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUMzQyxDQUFDO3dHQWZVLGtCQUFrQjs0RkFBbEIsa0JBQWtCLHVoQkEzQm5COzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBc0JULHlFQXZCUyxZQUFZOzs0RkE0Qlgsa0JBQWtCO2tCQS9COUIsU0FBUzsrQkFDRSxlQUFlLGNBQ2IsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLE9BQU8sQ0FBQyxZQUN0Qjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXNCVCxpQkFFYyxpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlLCBOZ0NsYXNzIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDb21wb25lbnQsXG4gIFZpZXdFbmNhcHN1bGF0aW9uLFxuICBpbnB1dCxcbiAgb3V0cHV0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnc2MtbW9udGgtZGF5cycsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIE5nQ2xhc3NdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkaXYgY2xhc3M9XCJncmlkIHctNjQgZ3JpZC1jb2xzLTdcIj5cbiAgICAgIEBmb3IgKGRheSBvZiBkYXlzKCk7IHRyYWNrICRpbmRleDsgbGV0IGluZGV4ID0gJGluZGV4KSB7XG4gICAgICAgIDxidXR0b25cbiAgICAgICAgICBjbGFzcz1cImJsb2NrIGZsZXgtMSBjdXJzb3ItcG9pbnRlciByb3VuZGVkLWxnIGJvcmRlci0wIHRleHQtY2VudGVyIHRleHQtc20gZm9udC1zZW1pYm9sZCBsZWFkaW5nLTkgdGV4dC1ncmF5LTkwMCBob3ZlcjpiZy1ncmF5LTEwMCBkYXJrOnRleHQtd2hpdGUgZGFyazpob3ZlcjpiZy1ncmF5LTYwMFwiXG4gICAgICAgICAgW25nQ2xhc3NdPVwie1xuICAgICAgICAgICAgJ2NvbC1zdGFydC0xJzogaW5kZXggPT09IDAgJiYgZmlyc3REYXlNb250aCgpID09PSAwLFxuICAgICAgICAgICAgJ2NvbC1zdGFydC0yJzogaW5kZXggPT09IDAgJiYgZmlyc3REYXlNb250aCgpID09PSAxLFxuICAgICAgICAgICAgJ2NvbC1zdGFydC0zJzogaW5kZXggPT09IDAgJiYgZmlyc3REYXlNb250aCgpID09PSAyLFxuICAgICAgICAgICAgJ2NvbC1zdGFydC00JzogaW5kZXggPT09IDAgJiYgZmlyc3REYXlNb250aCgpID09PSAzLFxuICAgICAgICAgICAgJ2NvbC1zdGFydC01JzogaW5kZXggPT09IDAgJiYgZmlyc3REYXlNb250aCgpID09PSA0LFxuICAgICAgICAgICAgJ2NvbC1zdGFydC02JzogaW5kZXggPT09IDAgJiYgZmlyc3REYXlNb250aCgpID09PSA1LFxuICAgICAgICAgICAgJ2NvbC1zdGFydC03JzogaW5kZXggPT09IDAgJiYgZmlyc3REYXlNb250aCgpID09PSA2LFxuICAgICAgICAgICAgJyFiZy1wcmltYXJ5LTcwMCBkYXJrOiFiZy1wcmltYXJ5LTYwMCAhdGV4dC13aGl0ZSc6IGlzU2VsZWN0ZWQoZGF5KSxcbiAgICAgICAgICB9XCJcbiAgICAgICAgICBbYXR0ci5kYXRhLXNjLWRheV09XCJkYXlcIlxuICAgICAgICAgIChjbGljayk9XCJzZXRTZWxlY3RlZERheSgkZXZlbnQpXCJcbiAgICAgICAgPlxuICAgICAgICAgIHt7IGRheS5zbGljZSgtMikgfX1cbiAgICAgICAgPC9idXR0b24+XG4gICAgICB9XG4gICAgPC9kaXY+XG4gIGAsXG4gIHN0eWxlczogYGAsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBNb250aERheXNDb21wb25lbnQge1xuICBkYXlzID0gaW5wdXQucmVxdWlyZWQ8c3RyaW5nW10+KCk7XG4gIGZpcnN0RGF5TW9udGggPSBpbnB1dC5yZXF1aXJlZDxudW1iZXI+KCk7XG4gIHNlbGVjdGVkRGF5ID0gaW5wdXQ8c3RyaW5nPignJyk7XG5cbiAgc2VsZWN0ZWREYXlDaGFuZ2UgPSBvdXRwdXQ8c3RyaW5nPigpO1xuXG4gIGlzU2VsZWN0ZWQoZGF5OiBzdHJpbmcpIHtcbiAgICByZXR1cm4gZGF5ID09PSB0aGlzLnNlbGVjdGVkRGF5KCk7XG4gIH1cblxuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueVxuICBzZXRTZWxlY3RlZERheShldmVudDogYW55KSB7XG4gICAgY29uc3Qgc2VsZWN0ZWREYXkgPSBldmVudC50YXJnZXQuZGF0YXNldC5zY0RheTtcbiAgICB0aGlzLnNlbGVjdGVkRGF5Q2hhbmdlLmVtaXQoc2VsZWN0ZWREYXkpO1xuICB9XG59XG4iXX0=
@@ -0,0 +1,124 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, ViewEncapsulation, input, output, } from '@angular/core';
3
+ import * as i0 from "@angular/core";
4
+ export class MonthYearHeaderComponent {
5
+ monthYear = input.required();
6
+ monthYearChange = output();
7
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: MonthYearHeaderComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
8
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.11", type: MonthYearHeaderComponent, isStandalone: true, selector: "sc-month-year-header", inputs: { monthYear: { classPropertyName: "monthYear", publicName: "monthYear", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { monthYearChange: "monthYearChange" }, ngImport: i0, template: `
9
+ <div class="mb-2 flex justify-between">
10
+ <button
11
+ class="rounded-lg bg-white p-2.5 text-lg text-gray-500 hover:bg-gray-100 hover:text-gray-900 focus:outline-none focus:ring-2 focus:ring-gray-200 dark:bg-gray-700 dark:text-white dark:hover:bg-gray-600 dark:hover:text-white"
12
+ (click)="monthYearChange.emit(-1)"
13
+ aria-label="Previous month"
14
+ type="button"
15
+ >
16
+ <svg
17
+ class="size-4 text-gray-800 rtl:rotate-180 dark:text-white"
18
+ aria-hidden="true"
19
+ xmlns="http://www.w3.org/2000/svg"
20
+ fill="none"
21
+ viewBox="0 0 14 10"
22
+ >
23
+ <path
24
+ stroke="currentColor"
25
+ stroke-linecap="round"
26
+ stroke-linejoin="round"
27
+ stroke-width="2"
28
+ d="M13 5H1m0 0 4 4M1 5l4-4"
29
+ ></path>
30
+ </svg>
31
+ </button>
32
+
33
+ <button
34
+ class="rounded-lg bg-white px-5 py-2.5 text-sm font-semibold text-gray-900 hover:bg-gray-100 focus:outline-none focus:ring-2 focus:ring-gray-200 dark:bg-gray-700 dark:text-white dark:hover:bg-gray-600"
35
+ type="button"
36
+ >
37
+ {{ monthYear() }}
38
+ </button>
39
+
40
+ <button
41
+ class="rounded-lg bg-white p-2.5 text-lg text-gray-500 hover:bg-gray-100 hover:text-gray-900 focus:outline-none focus:ring-2 focus:ring-gray-200 dark:bg-gray-700 dark:text-white dark:hover:bg-gray-600 dark:hover:text-white"
42
+ (click)="monthYearChange.emit(1)"
43
+ type="button"
44
+ aria-label="Next month"
45
+ >
46
+ <svg
47
+ class="size-4 text-gray-800 rtl:rotate-180 dark:text-white"
48
+ aria-hidden="true"
49
+ xmlns="http://www.w3.org/2000/svg"
50
+ fill="none"
51
+ viewBox="0 0 14 10"
52
+ >
53
+ <path
54
+ stroke="currentColor"
55
+ stroke-linecap="round"
56
+ stroke-linejoin="round"
57
+ stroke-width="2"
58
+ d="M1 5h12m0 0L9 1m4 4L9 9"
59
+ ></path>
60
+ </svg>
61
+ </button>
62
+ </div>
63
+ `, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
64
+ }
65
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: MonthYearHeaderComponent, decorators: [{
66
+ type: Component,
67
+ args: [{ selector: 'sc-month-year-header', standalone: true, imports: [CommonModule], template: `
68
+ <div class="mb-2 flex justify-between">
69
+ <button
70
+ class="rounded-lg bg-white p-2.5 text-lg text-gray-500 hover:bg-gray-100 hover:text-gray-900 focus:outline-none focus:ring-2 focus:ring-gray-200 dark:bg-gray-700 dark:text-white dark:hover:bg-gray-600 dark:hover:text-white"
71
+ (click)="monthYearChange.emit(-1)"
72
+ aria-label="Previous month"
73
+ type="button"
74
+ >
75
+ <svg
76
+ class="size-4 text-gray-800 rtl:rotate-180 dark:text-white"
77
+ aria-hidden="true"
78
+ xmlns="http://www.w3.org/2000/svg"
79
+ fill="none"
80
+ viewBox="0 0 14 10"
81
+ >
82
+ <path
83
+ stroke="currentColor"
84
+ stroke-linecap="round"
85
+ stroke-linejoin="round"
86
+ stroke-width="2"
87
+ d="M13 5H1m0 0 4 4M1 5l4-4"
88
+ ></path>
89
+ </svg>
90
+ </button>
91
+
92
+ <button
93
+ class="rounded-lg bg-white px-5 py-2.5 text-sm font-semibold text-gray-900 hover:bg-gray-100 focus:outline-none focus:ring-2 focus:ring-gray-200 dark:bg-gray-700 dark:text-white dark:hover:bg-gray-600"
94
+ type="button"
95
+ >
96
+ {{ monthYear() }}
97
+ </button>
98
+
99
+ <button
100
+ class="rounded-lg bg-white p-2.5 text-lg text-gray-500 hover:bg-gray-100 hover:text-gray-900 focus:outline-none focus:ring-2 focus:ring-gray-200 dark:bg-gray-700 dark:text-white dark:hover:bg-gray-600 dark:hover:text-white"
101
+ (click)="monthYearChange.emit(1)"
102
+ type="button"
103
+ aria-label="Next month"
104
+ >
105
+ <svg
106
+ class="size-4 text-gray-800 rtl:rotate-180 dark:text-white"
107
+ aria-hidden="true"
108
+ xmlns="http://www.w3.org/2000/svg"
109
+ fill="none"
110
+ viewBox="0 0 14 10"
111
+ >
112
+ <path
113
+ stroke="currentColor"
114
+ stroke-linecap="round"
115
+ stroke-linejoin="round"
116
+ stroke-width="2"
117
+ d="M1 5h12m0 0L9 1m4 4L9 9"
118
+ ></path>
119
+ </svg>
120
+ </button>
121
+ </div>
122
+ `, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush }]
123
+ }] });
124
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9udGgteWVhci1oZWFkZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS9zcmMvY29tcG9uZW50cy9kYXRlLXBpY2tlci9tb250aC15ZWFyLWhlYWRlci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULGlCQUFpQixFQUNqQixLQUFLLEVBQ0wsTUFBTSxHQUNQLE1BQU0sZUFBZSxDQUFDOztBQWtFdkIsTUFBTSxPQUFPLHdCQUF3QjtJQUNuQyxTQUFTLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBVSxDQUFDO0lBRXJDLGVBQWUsR0FBRyxNQUFNLEVBQVUsQ0FBQzt3R0FIeEIsd0JBQXdCOzRGQUF4Qix3QkFBd0IsZ1JBNUR6Qjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXVEVCx5RUF4RFMsWUFBWTs7NEZBNkRYLHdCQUF3QjtrQkFoRXBDLFNBQVM7K0JBQ0Usc0JBQXNCLGNBQ3BCLElBQUksV0FDUCxDQUFDLFlBQVksQ0FBQyxZQUNiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBdURULGlCQUVjLGlCQUFpQixDQUFDLElBQUksbUJBQ3BCLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG4gIGlucHV0LFxuICBvdXRwdXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzYy1tb250aC15ZWFyLWhlYWRlcicsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkaXYgY2xhc3M9XCJtYi0yIGZsZXgganVzdGlmeS1iZXR3ZWVuXCI+XG4gICAgICA8YnV0dG9uXG4gICAgICAgIGNsYXNzPVwicm91bmRlZC1sZyBiZy13aGl0ZSBwLTIuNSB0ZXh0LWxnIHRleHQtZ3JheS01MDAgaG92ZXI6YmctZ3JheS0xMDAgaG92ZXI6dGV4dC1ncmF5LTkwMCBmb2N1czpvdXRsaW5lLW5vbmUgZm9jdXM6cmluZy0yIGZvY3VzOnJpbmctZ3JheS0yMDAgZGFyazpiZy1ncmF5LTcwMCBkYXJrOnRleHQtd2hpdGUgZGFyazpob3ZlcjpiZy1ncmF5LTYwMCBkYXJrOmhvdmVyOnRleHQtd2hpdGVcIlxuICAgICAgICAoY2xpY2spPVwibW9udGhZZWFyQ2hhbmdlLmVtaXQoLTEpXCJcbiAgICAgICAgYXJpYS1sYWJlbD1cIlByZXZpb3VzIG1vbnRoXCJcbiAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICA+XG4gICAgICAgIDxzdmdcbiAgICAgICAgICBjbGFzcz1cInNpemUtNCB0ZXh0LWdyYXktODAwIHJ0bDpyb3RhdGUtMTgwIGRhcms6dGV4dC13aGl0ZVwiXG4gICAgICAgICAgYXJpYS1oaWRkZW49XCJ0cnVlXCJcbiAgICAgICAgICB4bWxucz1cImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnXCJcbiAgICAgICAgICBmaWxsPVwibm9uZVwiXG4gICAgICAgICAgdmlld0JveD1cIjAgMCAxNCAxMFwiXG4gICAgICAgID5cbiAgICAgICAgICA8cGF0aFxuICAgICAgICAgICAgc3Ryb2tlPVwiY3VycmVudENvbG9yXCJcbiAgICAgICAgICAgIHN0cm9rZS1saW5lY2FwPVwicm91bmRcIlxuICAgICAgICAgICAgc3Ryb2tlLWxpbmVqb2luPVwicm91bmRcIlxuICAgICAgICAgICAgc3Ryb2tlLXdpZHRoPVwiMlwiXG4gICAgICAgICAgICBkPVwiTTEzIDVIMW0wIDAgNCA0TTEgNWw0LTRcIlxuICAgICAgICAgID48L3BhdGg+XG4gICAgICAgIDwvc3ZnPlxuICAgICAgPC9idXR0b24+XG5cbiAgICAgIDxidXR0b25cbiAgICAgICAgY2xhc3M9XCJyb3VuZGVkLWxnIGJnLXdoaXRlIHB4LTUgcHktMi41IHRleHQtc20gZm9udC1zZW1pYm9sZCB0ZXh0LWdyYXktOTAwIGhvdmVyOmJnLWdyYXktMTAwIGZvY3VzOm91dGxpbmUtbm9uZSBmb2N1czpyaW5nLTIgZm9jdXM6cmluZy1ncmF5LTIwMCBkYXJrOmJnLWdyYXktNzAwIGRhcms6dGV4dC13aGl0ZSBkYXJrOmhvdmVyOmJnLWdyYXktNjAwXCJcbiAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICA+XG4gICAgICAgIHt7IG1vbnRoWWVhcigpIH19XG4gICAgICA8L2J1dHRvbj5cblxuICAgICAgPGJ1dHRvblxuICAgICAgICBjbGFzcz1cInJvdW5kZWQtbGcgYmctd2hpdGUgcC0yLjUgdGV4dC1sZyB0ZXh0LWdyYXktNTAwIGhvdmVyOmJnLWdyYXktMTAwIGhvdmVyOnRleHQtZ3JheS05MDAgZm9jdXM6b3V0bGluZS1ub25lIGZvY3VzOnJpbmctMiBmb2N1czpyaW5nLWdyYXktMjAwIGRhcms6YmctZ3JheS03MDAgZGFyazp0ZXh0LXdoaXRlIGRhcms6aG92ZXI6YmctZ3JheS02MDAgZGFyazpob3Zlcjp0ZXh0LXdoaXRlXCJcbiAgICAgICAgKGNsaWNrKT1cIm1vbnRoWWVhckNoYW5nZS5lbWl0KDEpXCJcbiAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgIGFyaWEtbGFiZWw9XCJOZXh0IG1vbnRoXCJcbiAgICAgID5cbiAgICAgICAgPHN2Z1xuICAgICAgICAgIGNsYXNzPVwic2l6ZS00IHRleHQtZ3JheS04MDAgcnRsOnJvdGF0ZS0xODAgZGFyazp0ZXh0LXdoaXRlXCJcbiAgICAgICAgICBhcmlhLWhpZGRlbj1cInRydWVcIlxuICAgICAgICAgIHhtbG5zPVwiaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmdcIlxuICAgICAgICAgIGZpbGw9XCJub25lXCJcbiAgICAgICAgICB2aWV3Qm94PVwiMCAwIDE0IDEwXCJcbiAgICAgICAgPlxuICAgICAgICAgIDxwYXRoXG4gICAgICAgICAgICBzdHJva2U9XCJjdXJyZW50Q29sb3JcIlxuICAgICAgICAgICAgc3Ryb2tlLWxpbmVjYXA9XCJyb3VuZFwiXG4gICAgICAgICAgICBzdHJva2UtbGluZWpvaW49XCJyb3VuZFwiXG4gICAgICAgICAgICBzdHJva2Utd2lkdGg9XCIyXCJcbiAgICAgICAgICAgIGQ9XCJNMSA1aDEybTAgMEw5IDFtNCA0TDkgOVwiXG4gICAgICAgICAgPjwvcGF0aD5cbiAgICAgICAgPC9zdmc+XG4gICAgICA8L2J1dHRvbj5cbiAgICA8L2Rpdj5cbiAgYCxcbiAgc3R5bGVzOiBgYCxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIE1vbnRoWWVhckhlYWRlckNvbXBvbmVudCB7XG4gIG1vbnRoWWVhciA9IGlucHV0LnJlcXVpcmVkPHN0cmluZz4oKTtcblxuICBtb250aFllYXJDaGFuZ2UgPSBvdXRwdXQ8bnVtYmVyPigpO1xufVxuIl19
@@ -0,0 +1,37 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, ViewEncapsulation, input } from '@angular/core';
3
+ import * as i0 from "@angular/core";
4
+ export class WeekDaysNamesComponent {
5
+ weekDaysNames = input.required();
6
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: WeekDaysNamesComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
7
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.11", type: WeekDaysNamesComponent, isStandalone: true, selector: "sc-week-days-names", inputs: { weekDaysNames: { classPropertyName: "weekDaysNames", publicName: "weekDaysNames", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: `
8
+ <div class="mb-1 grid grid-cols-7">
9
+ @for (weekDayName of weekDaysNames(); track weekDayName.long) {
10
+ <abbr
11
+ class="h-6 text-center text-sm font-medium leading-6 text-gray-500 dark:text-gray-400"
12
+ [title]="weekDayName.long"
13
+ [attr.aria-label]="weekDayName.long"
14
+ >
15
+ {{ weekDayName.short }}
16
+ </abbr>
17
+ }
18
+ </div>
19
+ `, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
20
+ }
21
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: WeekDaysNamesComponent, decorators: [{
22
+ type: Component,
23
+ args: [{ selector: 'sc-week-days-names', standalone: true, imports: [CommonModule], template: `
24
+ <div class="mb-1 grid grid-cols-7">
25
+ @for (weekDayName of weekDaysNames(); track weekDayName.long) {
26
+ <abbr
27
+ class="h-6 text-center text-sm font-medium leading-6 text-gray-500 dark:text-gray-400"
28
+ [title]="weekDayName.long"
29
+ [attr.aria-label]="weekDayName.long"
30
+ >
31
+ {{ weekDayName.short }}
32
+ </abbr>
33
+ }
34
+ </div>
35
+ `, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush }]
36
+ }] });
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2Vlay1kYXlzLW5hbWVzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWkvc3JjL2NvbXBvbmVudHMvZGF0ZS1waWNrZXIvd2Vlay1kYXlzLW5hbWVzLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxpQkFBaUIsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBNkI3RixNQUFNLE9BQU8sc0JBQXNCO0lBQ2pDLGFBQWEsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFpQixDQUFDO3dHQURyQyxzQkFBc0I7NEZBQXRCLHNCQUFzQix5T0FqQnZCOzs7Ozs7Ozs7Ozs7R0FZVCx5RUFiUyxZQUFZOzs0RkFrQlgsc0JBQXNCO2tCQXJCbEMsU0FBUzsrQkFDRSxvQkFBb0IsY0FDbEIsSUFBSSxXQUNQLENBQUMsWUFBWSxDQUFDLFlBQ2I7Ozs7Ozs7Ozs7OztHQVlULGlCQUVjLGlCQUFpQixDQUFDLElBQUksbUJBQ3BCLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgVmlld0VuY2Fwc3VsYXRpb24sIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgV2Vla0RheU5hbWUge1xuICBuYXJyb3c6IHN0cmluZztcbiAgc2hvcnQ6IHN0cmluZztcbiAgbG9uZzogc3RyaW5nO1xufVxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzYy13ZWVrLWRheXMtbmFtZXMnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgdGVtcGxhdGU6IGBcbiAgICA8ZGl2IGNsYXNzPVwibWItMSBncmlkIGdyaWQtY29scy03XCI+XG4gICAgICBAZm9yICh3ZWVrRGF5TmFtZSBvZiB3ZWVrRGF5c05hbWVzKCk7IHRyYWNrIHdlZWtEYXlOYW1lLmxvbmcpIHtcbiAgICAgICAgPGFiYnJcbiAgICAgICAgICBjbGFzcz1cImgtNiB0ZXh0LWNlbnRlciB0ZXh0LXNtIGZvbnQtbWVkaXVtIGxlYWRpbmctNiB0ZXh0LWdyYXktNTAwIGRhcms6dGV4dC1ncmF5LTQwMFwiXG4gICAgICAgICAgW3RpdGxlXT1cIndlZWtEYXlOYW1lLmxvbmdcIlxuICAgICAgICAgIFthdHRyLmFyaWEtbGFiZWxdPVwid2Vla0RheU5hbWUubG9uZ1wiXG4gICAgICAgID5cbiAgICAgICAgICB7eyB3ZWVrRGF5TmFtZS5zaG9ydCB9fVxuICAgICAgICA8L2FiYnI+XG4gICAgICB9XG4gICAgPC9kaXY+XG4gIGAsXG4gIHN0eWxlczogYGAsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBXZWVrRGF5c05hbWVzQ29tcG9uZW50IHtcbiAgd2Vla0RheXNOYW1lcyA9IGlucHV0LnJlcXVpcmVkPFdlZWtEYXlOYW1lW10+KCk7XG59XG4iXX0=
@@ -0,0 +1,16 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, ViewEncapsulation } from '@angular/core';
3
+ import * as i0 from "@angular/core";
4
+ export class DropdownDividerComponent {
5
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: DropdownDividerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
6
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.11", type: DropdownDividerComponent, isStandalone: true, selector: "sc-dropdown-divider", ngImport: i0, template: `
7
+ <li class="py-2"><hr /></li>
8
+ `, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
9
+ }
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: DropdownDividerComponent, decorators: [{
11
+ type: Component,
12
+ args: [{ selector: 'sc-dropdown-divider', standalone: true, imports: [CommonModule], template: `
13
+ <li class="py-2"><hr /></li>
14
+ `, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush }]
15
+ }] });
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24tZGl2aWRlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL3NyYy9jb21wb25lbnRzL2Ryb3Bkb3duL2Ryb3Bkb3duLWRpdmlkZXIuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDOztBQWF0RixNQUFNLE9BQU8sd0JBQXdCO3dHQUF4Qix3QkFBd0I7NEZBQXhCLHdCQUF3QiwrRUFQekI7O0dBRVQseUVBSFMsWUFBWTs7NEZBUVgsd0JBQXdCO2tCQVhwQyxTQUFTOytCQUNFLHFCQUFxQixjQUNuQixJQUFJLFdBQ1AsQ0FBQyxZQUFZLENBQUMsWUFDYjs7R0FFVCxpQkFFYyxpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NjLWRyb3Bkb3duLWRpdmlkZXInLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgdGVtcGxhdGU6IGBcbiAgICA8bGkgY2xhc3M9XCJweS0yXCI+PGhyIC8+PC9saT5cbiAgYCxcbiAgc3R5bGVzOiBgYCxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIERyb3Bkb3duRGl2aWRlckNvbXBvbmVudCB7fVxuIl19
@@ -0,0 +1,33 @@
1
+ import { CdkMenuItem } from '@angular/cdk/menu';
2
+ import { CommonModule } from '@angular/common';
3
+ import { ChangeDetectionStrategy, Component, ViewEncapsulation, input } from '@angular/core';
4
+ import * as i0 from "@angular/core";
5
+ //TODO try to add CdkMenuItem
6
+ export class DropdownItemComponent {
7
+ text = input.required();
8
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: DropdownItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
9
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.11", type: DropdownItemComponent, isStandalone: true, selector: "sc-dropdown-item", inputs: { text: { classPropertyName: "text", publicName: "text", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: `
10
+ <li>
11
+ <a
12
+ class="block px-4 py-2 hover:bg-gray-100 dark:hover:bg-gray-600 dark:hover:text-white"
13
+ href="javascript:void(0)"
14
+ >
15
+ {{ text() }}
16
+ </a>
17
+ </li>
18
+ `, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
19
+ }
20
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: DropdownItemComponent, decorators: [{
21
+ type: Component,
22
+ args: [{ selector: 'sc-dropdown-item', standalone: true, imports: [CommonModule, CdkMenuItem], template: `
23
+ <li>
24
+ <a
25
+ class="block px-4 py-2 hover:bg-gray-100 dark:hover:bg-gray-600 dark:hover:text-white"
26
+ href="javascript:void(0)"
27
+ >
28
+ {{ text() }}
29
+ </a>
30
+ </li>
31
+ `, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush }]
32
+ }] });
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24taXRlbS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL3NyYy9jb21wb25lbnRzL2Ryb3Bkb3duL2Ryb3Bkb3duLWl0ZW0uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNoRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxpQkFBaUIsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRTdGLDZCQUE2QjtBQW9CN0IsTUFBTSxPQUFPLHFCQUFxQjtJQUNoQyxJQUFJLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBVSxDQUFDO3dHQURyQixxQkFBcUI7NEZBQXJCLHFCQUFxQiw0TUFkdEI7Ozs7Ozs7OztHQVNULHlFQVZTLFlBQVk7OzRGQWVYLHFCQUFxQjtrQkFsQmpDLFNBQVM7K0JBQ0Usa0JBQWtCLGNBQ2hCLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSxXQUFXLENBQUMsWUFDMUI7Ozs7Ozs7OztHQVNULGlCQUVjLGlCQUFpQixDQUFDLElBQUksbUJBQ3BCLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDZGtNZW51SXRlbSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9tZW51JztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBWaWV3RW5jYXBzdWxhdGlvbiwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLy9UT0RPIHRyeSB0byBhZGQgQ2RrTWVudUl0ZW1cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnc2MtZHJvcGRvd24taXRlbScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIENka01lbnVJdGVtXSxcbiAgdGVtcGxhdGU6IGBcbiAgICA8bGk+XG4gICAgICA8YVxuICAgICAgICBjbGFzcz1cImJsb2NrIHB4LTQgcHktMiBob3ZlcjpiZy1ncmF5LTEwMCBkYXJrOmhvdmVyOmJnLWdyYXktNjAwIGRhcms6aG92ZXI6dGV4dC13aGl0ZVwiXG4gICAgICAgIGhyZWY9XCJqYXZhc2NyaXB0OnZvaWQoMClcIlxuICAgICAgPlxuICAgICAgICB7eyB0ZXh0KCkgfX1cbiAgICAgIDwvYT5cbiAgICA8L2xpPlxuICBgLFxuICBzdHlsZXM6IGBgLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgRHJvcGRvd25JdGVtQ29tcG9uZW50IHtcbiAgdGV4dCA9IGlucHV0LnJlcXVpcmVkPHN0cmluZz4oKTtcbn1cbiJdfQ==
@@ -0,0 +1,85 @@
1
+ import { CdkMenu, CdkMenuTrigger } from '@angular/cdk/menu';
2
+ import { CommonModule } from '@angular/common';
3
+ import { ChangeDetectionStrategy, Component, ViewEncapsulation } from '@angular/core';
4
+ import * as i0 from "@angular/core";
5
+ export class DropdownComponent {
6
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: DropdownComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
7
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.11", type: DropdownComponent, isStandalone: true, selector: "sc-dropdown", ngImport: i0, template: `
8
+ <!--ng-content select="dropdown-toggle" /-->
9
+
10
+ <button
11
+ class="inline-flex items-center rounded-lg bg-blue-700 px-5 py-2.5 text-center text-sm font-medium text-white hover:bg-blue-800 focus:outline-none focus:ring-4 focus:ring-blue-300 dark:bg-blue-600 dark:hover:bg-blue-700 dark:focus:ring-blue-800"
12
+ [cdkMenuTriggerFor]="menu"
13
+ type="button"
14
+ >
15
+ Dropdown button
16
+ <svg
17
+ class="ms-3 size-2.5"
18
+ aria-hidden="true"
19
+ xmlns="http://www.w3.org/2000/svg"
20
+ fill="none"
21
+ viewBox="0 0 10 6"
22
+ >
23
+ <path
24
+ stroke="currentColor"
25
+ stroke-linecap="round"
26
+ stroke-linejoin="round"
27
+ stroke-width="2"
28
+ d="m1 1 4 4 4-4"
29
+ />
30
+ </svg>
31
+ </button>
32
+
33
+ <ng-template #menu>
34
+ <div
35
+ class="z-10 w-44 divide-y divide-gray-100 rounded-lg bg-white shadow dark:bg-gray-700"
36
+ cdkMenu
37
+ >
38
+ <ul class="py-2 text-sm text-gray-700 dark:text-gray-200">
39
+ <ng-content select="dropdown-items" />
40
+ </ul>
41
+ </div>
42
+ </ng-template>
43
+ `, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: CdkMenuTrigger, selector: "[cdkMenuTriggerFor]", inputs: ["cdkMenuTriggerFor", "cdkMenuPosition", "cdkMenuTriggerData"], outputs: ["cdkMenuOpened", "cdkMenuClosed"], exportAs: ["cdkMenuTriggerFor"] }, { kind: "directive", type: CdkMenu, selector: "[cdkMenu]", outputs: ["closed"], exportAs: ["cdkMenu"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
44
+ }
45
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: DropdownComponent, decorators: [{
46
+ type: Component,
47
+ args: [{ selector: 'sc-dropdown', standalone: true, imports: [CommonModule, CdkMenuTrigger, CdkMenu], template: `
48
+ <!--ng-content select="dropdown-toggle" /-->
49
+
50
+ <button
51
+ class="inline-flex items-center rounded-lg bg-blue-700 px-5 py-2.5 text-center text-sm font-medium text-white hover:bg-blue-800 focus:outline-none focus:ring-4 focus:ring-blue-300 dark:bg-blue-600 dark:hover:bg-blue-700 dark:focus:ring-blue-800"
52
+ [cdkMenuTriggerFor]="menu"
53
+ type="button"
54
+ >
55
+ Dropdown button
56
+ <svg
57
+ class="ms-3 size-2.5"
58
+ aria-hidden="true"
59
+ xmlns="http://www.w3.org/2000/svg"
60
+ fill="none"
61
+ viewBox="0 0 10 6"
62
+ >
63
+ <path
64
+ stroke="currentColor"
65
+ stroke-linecap="round"
66
+ stroke-linejoin="round"
67
+ stroke-width="2"
68
+ d="m1 1 4 4 4-4"
69
+ />
70
+ </svg>
71
+ </button>
72
+
73
+ <ng-template #menu>
74
+ <div
75
+ class="z-10 w-44 divide-y divide-gray-100 rounded-lg bg-white shadow dark:bg-gray-700"
76
+ cdkMenu
77
+ >
78
+ <ul class="py-2 text-sm text-gray-700 dark:text-gray-200">
79
+ <ng-content select="dropdown-items" />
80
+ </ul>
81
+ </div>
82
+ </ng-template>
83
+ `, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush }]
84
+ }] });
85
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS9zcmMvY29tcG9uZW50cy9kcm9wZG93bi9kcm9wZG93bi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUErQ3RGLE1BQU0sT0FBTyxpQkFBaUI7d0dBQWpCLGlCQUFpQjs0RkFBakIsaUJBQWlCLHVFQXpDbEI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW9DVCx5RUFyQ1MsWUFBWSwrQkFBRSxjQUFjLHNOQUFFLE9BQU87OzRGQTBDcEMsaUJBQWlCO2tCQTdDN0IsU0FBUzsrQkFDRSxhQUFhLGNBQ1gsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLGNBQWMsRUFBRSxPQUFPLENBQUMsWUFDdEM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW9DVCxpQkFFYyxpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2RrTWVudSwgQ2RrTWVudVRyaWdnZXIgfSBmcm9tICdAYW5ndWxhci9jZGsvbWVudSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnc2MtZHJvcGRvd24nLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBDZGtNZW51VHJpZ2dlciwgQ2RrTWVudV0sXG4gIHRlbXBsYXRlOiBgXG4gICAgPCEtLW5nLWNvbnRlbnQgc2VsZWN0PVwiZHJvcGRvd24tdG9nZ2xlXCIgLy0tPlxuXG4gICAgPGJ1dHRvblxuICAgICAgY2xhc3M9XCJpbmxpbmUtZmxleCBpdGVtcy1jZW50ZXIgcm91bmRlZC1sZyBiZy1ibHVlLTcwMCBweC01IHB5LTIuNSB0ZXh0LWNlbnRlciB0ZXh0LXNtIGZvbnQtbWVkaXVtIHRleHQtd2hpdGUgaG92ZXI6YmctYmx1ZS04MDAgZm9jdXM6b3V0bGluZS1ub25lIGZvY3VzOnJpbmctNCBmb2N1czpyaW5nLWJsdWUtMzAwIGRhcms6YmctYmx1ZS02MDAgZGFyazpob3ZlcjpiZy1ibHVlLTcwMCBkYXJrOmZvY3VzOnJpbmctYmx1ZS04MDBcIlxuICAgICAgW2Nka01lbnVUcmlnZ2VyRm9yXT1cIm1lbnVcIlxuICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgPlxuICAgICAgRHJvcGRvd24gYnV0dG9uXG4gICAgICA8c3ZnXG4gICAgICAgIGNsYXNzPVwibXMtMyBzaXplLTIuNVwiXG4gICAgICAgIGFyaWEtaGlkZGVuPVwidHJ1ZVwiXG4gICAgICAgIHhtbG5zPVwiaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmdcIlxuICAgICAgICBmaWxsPVwibm9uZVwiXG4gICAgICAgIHZpZXdCb3g9XCIwIDAgMTAgNlwiXG4gICAgICA+XG4gICAgICAgIDxwYXRoXG4gICAgICAgICAgc3Ryb2tlPVwiY3VycmVudENvbG9yXCJcbiAgICAgICAgICBzdHJva2UtbGluZWNhcD1cInJvdW5kXCJcbiAgICAgICAgICBzdHJva2UtbGluZWpvaW49XCJyb3VuZFwiXG4gICAgICAgICAgc3Ryb2tlLXdpZHRoPVwiMlwiXG4gICAgICAgICAgZD1cIm0xIDEgNCA0IDQtNFwiXG4gICAgICAgIC8+XG4gICAgICA8L3N2Zz5cbiAgICA8L2J1dHRvbj5cblxuICAgIDxuZy10ZW1wbGF0ZSAjbWVudT5cbiAgICAgIDxkaXZcbiAgICAgICAgY2xhc3M9XCJ6LTEwIHctNDQgZGl2aWRlLXkgZGl2aWRlLWdyYXktMTAwIHJvdW5kZWQtbGcgYmctd2hpdGUgc2hhZG93IGRhcms6YmctZ3JheS03MDBcIlxuICAgICAgICBjZGtNZW51XG4gICAgICA+XG4gICAgICAgIDx1bCBjbGFzcz1cInB5LTIgdGV4dC1zbSB0ZXh0LWdyYXktNzAwIGRhcms6dGV4dC1ncmF5LTIwMFwiPlxuICAgICAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cImRyb3Bkb3duLWl0ZW1zXCIgLz5cbiAgICAgICAgPC91bD5cbiAgICAgIDwvZGl2PlxuICAgIDwvbmctdGVtcGxhdGU+XG4gIGAsXG4gIHN0eWxlczogYGAsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBEcm9wZG93bkNvbXBvbmVudCB7fVxuIl19
@@ -0,0 +1,4 @@
1
+ export * from './dropdown.component';
2
+ export * from './dropdown-divider.component';
3
+ export * from './dropdown-item.component';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL3NyYy9jb21wb25lbnRzL2Ryb3Bkb3duL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9kcm9wZG93bi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9kcm9wZG93bi1kaXZpZGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duLWl0ZW0uY29tcG9uZW50JztcbiJdfQ==