@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
package/README.md CHANGED
@@ -5,3 +5,9 @@ This library was generated with [Nx](https://nx.dev).
5
5
  ## Running unit tests
6
6
 
7
7
  Run `nx test ui` to execute the unit tests.
8
+
9
+ ## components
10
+
11
+ ### dropdown
12
+
13
+ https://medium.com/codeshakeio/build-a-dropdown-component-using-angular-cdk-fa45455e6a73
@@ -1,5 +1,33 @@
1
+ import { OnInit, OutputEmitterRef } from '@angular/core';
1
2
  import * as i0 from "@angular/core";
2
- export declare class DatePickerComponent {
3
+ export declare class DatePickerComponent implements OnInit {
4
+ private readonly localeId;
5
+ dateFormatPattern: import("@angular/core").WritableSignal<string>;
6
+ constructor(localeId: string);
7
+ ngOnInit(): void;
8
+ getDateFormatPattern(localeId: string): string;
9
+ private readonly _injector;
10
+ private readonly _dir;
11
+ private readonly _overlay;
12
+ private readonly _isOpen;
13
+ private readonly _input;
14
+ private readonly _overlayOrigin;
15
+ private _overlayRef;
16
+ private _portal;
17
+ /** Emits when the datepicker is opened. */
18
+ readonly opened: OutputEmitterRef<void>;
19
+ /** Emits when the datepicker is closed. */
20
+ readonly closed: OutputEmitterRef<void>;
21
+ /** Emits when the user selects a date. */
22
+ readonly selected: OutputEmitterRef<string>;
23
+ /** Opens the datepicker. */
24
+ open(): void;
25
+ /** Closes the datepicker. */
26
+ close(): void;
27
+ /** Creates an overlay reference for the datepicker panel. */
28
+ private _getOverlayRef;
29
+ /** Selects a specific date value. */
30
+ protected _selectValue(value: string): void;
3
31
  static ɵfac: i0.ɵɵFactoryDeclaration<DatePickerComponent, never>;
4
- static ɵcmp: i0.ɵɵComponentDeclaration<DatePickerComponent, "lib-date-picker", never, {}, {}, never, never, true, never>;
32
+ static ɵcmp: i0.ɵɵComponentDeclaration<DatePickerComponent, "sc-date-picker", never, {}, { "opened": "opened"; "closed": "closed"; "selected": "selected"; }, never, never, true, never>;
5
33
  }
@@ -1 +1,2 @@
1
1
  export * from './date-picker.component';
2
+ export * from './inline-date-picker.component';
@@ -0,0 +1,23 @@
1
+ import { OnInit } from '@angular/core';
2
+ import { WeekDayName } from './week-days-names.component';
3
+ import * as i0 from "@angular/core";
4
+ export declare class InlineDatePickerComponent implements OnInit {
5
+ private readonly localeId;
6
+ year: import("@angular/core").WritableSignal<number>;
7
+ month: import("@angular/core").WritableSignal<number>;
8
+ weekDaysNames: import("@angular/core").WritableSignal<WeekDayName[]>;
9
+ monthYear: import("@angular/core").Signal<string>;
10
+ monthDays: import("@angular/core").Signal<string[]>;
11
+ firstDayMonth: import("@angular/core").Signal<number>;
12
+ selectedDay: import("@angular/core").WritableSignal<string>;
13
+ constructor(localeId: string);
14
+ ngOnInit(): void;
15
+ init(): void;
16
+ setSelectedDay(day: string): void;
17
+ private setLocaleDayNames;
18
+ private getFirstDayOfWeek;
19
+ setMonthYear(n: number): void;
20
+ twoDigits(n: number): string;
21
+ static ɵfac: i0.ɵɵFactoryDeclaration<InlineDatePickerComponent, never>;
22
+ static ɵcmp: i0.ɵɵComponentDeclaration<InlineDatePickerComponent, "sc-inline-date-picker", never, {}, {}, never, never, true, never>;
23
+ }
@@ -0,0 +1,11 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class MonthDaysComponent {
3
+ days: import("@angular/core").InputSignal<string[]>;
4
+ firstDayMonth: import("@angular/core").InputSignal<number>;
5
+ selectedDay: import("@angular/core").InputSignal<string>;
6
+ selectedDayChange: import("@angular/core").OutputEmitterRef<string>;
7
+ isSelected(day: string): boolean;
8
+ setSelectedDay(event: any): void;
9
+ static ɵfac: i0.ɵɵFactoryDeclaration<MonthDaysComponent, never>;
10
+ static ɵcmp: i0.ɵɵComponentDeclaration<MonthDaysComponent, "sc-month-days", never, { "days": { "alias": "days"; "required": true; "isSignal": true; }; "firstDayMonth": { "alias": "firstDayMonth"; "required": true; "isSignal": true; }; "selectedDay": { "alias": "selectedDay"; "required": false; "isSignal": true; }; }, { "selectedDayChange": "selectedDayChange"; }, never, never, true, never>;
11
+ }
@@ -0,0 +1,7 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class MonthYearHeaderComponent {
3
+ monthYear: import("@angular/core").InputSignal<string>;
4
+ monthYearChange: import("@angular/core").OutputEmitterRef<number>;
5
+ static ɵfac: i0.ɵɵFactoryDeclaration<MonthYearHeaderComponent, never>;
6
+ static ɵcmp: i0.ɵɵComponentDeclaration<MonthYearHeaderComponent, "sc-month-year-header", never, { "monthYear": { "alias": "monthYear"; "required": true; "isSignal": true; }; }, { "monthYearChange": "monthYearChange"; }, never, never, true, never>;
7
+ }
@@ -0,0 +1,11 @@
1
+ import * as i0 from "@angular/core";
2
+ export interface WeekDayName {
3
+ narrow: string;
4
+ short: string;
5
+ long: string;
6
+ }
7
+ export declare class WeekDaysNamesComponent {
8
+ weekDaysNames: import("@angular/core").InputSignal<WeekDayName[]>;
9
+ static ɵfac: i0.ɵɵFactoryDeclaration<WeekDaysNamesComponent, never>;
10
+ static ɵcmp: i0.ɵɵComponentDeclaration<WeekDaysNamesComponent, "sc-week-days-names", never, { "weekDaysNames": { "alias": "weekDaysNames"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
11
+ }
@@ -0,0 +1,5 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class DropdownDividerComponent {
3
+ static ɵfac: i0.ɵɵFactoryDeclaration<DropdownDividerComponent, never>;
4
+ static ɵcmp: i0.ɵɵComponentDeclaration<DropdownDividerComponent, "sc-dropdown-divider", never, {}, {}, never, never, true, never>;
5
+ }
@@ -0,0 +1,6 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class DropdownItemComponent {
3
+ text: import("@angular/core").InputSignal<string>;
4
+ static ɵfac: i0.ɵɵFactoryDeclaration<DropdownItemComponent, never>;
5
+ static ɵcmp: i0.ɵɵComponentDeclaration<DropdownItemComponent, "sc-dropdown-item", never, { "text": { "alias": "text"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
6
+ }
@@ -0,0 +1,5 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class DropdownComponent {
3
+ static ɵfac: i0.ɵɵFactoryDeclaration<DropdownComponent, never>;
4
+ static ɵcmp: i0.ɵɵComponentDeclaration<DropdownComponent, "sc-dropdown", never, {}, {}, never, ["dropdown-items"], true, never>;
5
+ }
@@ -0,0 +1,3 @@
1
+ export * from './dropdown.component';
2
+ export * from './dropdown-divider.component';
3
+ export * from './dropdown-item.component';
@@ -1,5 +1,5 @@
1
1
  import * as i0 from "@angular/core";
2
2
  export declare class EditorComponent {
3
3
  static ɵfac: i0.ɵɵFactoryDeclaration<EditorComponent, never>;
4
- static ɵcmp: i0.ɵɵComponentDeclaration<EditorComponent, "lib-editor", never, {}, {}, never, never, true, never>;
4
+ static ɵcmp: i0.ɵɵComponentDeclaration<EditorComponent, "sc-editor", never, {}, {}, never, never, true, never>;
5
5
  }
@@ -0,0 +1,3 @@
1
+ export * from './nav.component';
2
+ export * from './nav-item.component';
3
+ export * from './nav-item-dropdown.component';
@@ -0,0 +1,5 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class NavItemDropdownComponent {
3
+ static ɵfac: i0.ɵɵFactoryDeclaration<NavItemDropdownComponent, never>;
4
+ static ɵcmp: i0.ɵɵComponentDeclaration<NavItemDropdownComponent, "sc-nav-item-dropdown", never, {}, {}, never, never, true, never>;
5
+ }
@@ -0,0 +1,5 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class NavItemComponent {
3
+ static ɵfac: i0.ɵɵFactoryDeclaration<NavItemComponent, never>;
4
+ static ɵcmp: i0.ɵɵComponentDeclaration<NavItemComponent, "sc-nav-item", never, {}, {}, never, never, true, never>;
5
+ }
@@ -0,0 +1,5 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class NavComponent {
3
+ static ɵfac: i0.ɵɵFactoryDeclaration<NavComponent, never>;
4
+ static ɵcmp: i0.ɵɵComponentDeclaration<NavComponent, "sc-nav", never, {}, {}, never, never, true, never>;
5
+ }
@@ -0,0 +1,2 @@
1
+ export * from './select.component';
2
+ export * from './select-option.component';
@@ -0,0 +1,7 @@
1
+ import * as i0 from "@angular/core";
2
+ export declare class SelectOptionComponent {
3
+ value: any;
4
+ disabled: boolean;
5
+ static ɵfac: i0.ɵɵFactoryDeclaration<SelectOptionComponent, never>;
6
+ static ɵcmp: i0.ɵɵComponentDeclaration<SelectOptionComponent, "sc-select-option", never, { "value": { "alias": "value"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; }, {}, never, ["*"], true, never>;
7
+ }
@@ -0,0 +1,55 @@
1
+ import { Overlay } from '@angular/cdk/overlay';
2
+ import { CdkPortal } from '@angular/cdk/portal';
3
+ import { ChangeDetectorRef, ElementRef, EventEmitter, OnInit, QueryList } from '@angular/core';
4
+ import { AbstractControl, ControlValueAccessor, ValidationErrors, Validator } from '@angular/forms';
5
+ import { DomSanitizer, SafeHtml } from '@angular/platform-browser';
6
+ import { SelectOptionComponent } from './select-option.component';
7
+ import * as i0 from "@angular/core";
8
+ export interface CustomSelectEvent {
9
+ source: SelectComponent;
10
+ selected: any;
11
+ }
12
+ export declare class SelectComponent implements OnInit, ControlValueAccessor, Validator {
13
+ private readonly cd;
14
+ private readonly domSanitizer;
15
+ private readonly overlay;
16
+ inputId: string;
17
+ label: string;
18
+ placeholder: string;
19
+ required: boolean;
20
+ disabled: boolean;
21
+ error: boolean;
22
+ multiple: boolean;
23
+ search: boolean;
24
+ ariaLabel: string;
25
+ ariaLabelledby: string;
26
+ readonly change: EventEmitter<CustomSelectEvent>;
27
+ select: ElementRef;
28
+ contentTemplate: CdkPortal;
29
+ options: QueryList<SelectOptionComponent>;
30
+ displayText: SafeHtml;
31
+ displayX: boolean;
32
+ private showing;
33
+ private readonly showPlaceholder;
34
+ private overlayRef;
35
+ constructor(cd: ChangeDetectorRef, domSanitizer: DomSanitizer, overlay: Overlay);
36
+ onChangeFn: any;
37
+ onTouchedFn: any;
38
+ registerOnChange(fn: any): void;
39
+ registerOnTouched(fn: any): void;
40
+ validate(control: AbstractControl): ValidationErrors | null;
41
+ ngOnInit(): void;
42
+ writeValue(obj: any): void;
43
+ onTouched(): void;
44
+ mainSelectClasses(): {
45
+ [key: string]: any;
46
+ };
47
+ onDropMenuIconClick(event: UIEvent): void;
48
+ onKeyDown(event: KeyboardEvent): void;
49
+ showDropdown(): void;
50
+ private hide;
51
+ private syncWidth;
52
+ private getOverlayConfig;
53
+ static ɵfac: i0.ɵɵFactoryDeclaration<SelectComponent, never>;
54
+ static ɵcmp: i0.ɵɵComponentDeclaration<SelectComponent, "sc-select", never, { "inputId": { "alias": "id"; "required": false; }; "label": { "alias": "label"; "required": false; }; "placeholder": { "alias": "placeholder"; "required": false; }; "required": { "alias": "required"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "error": { "alias": "error"; "required": false; }; "multiple": { "alias": "multiple"; "required": false; }; "search": { "alias": "search"; "required": false; }; "ariaLabel": { "alias": "aria-label"; "required": false; }; "ariaLabelledby": { "alias": "aria-labelledby"; "required": false; }; }, { "change": "change"; }, ["options"], ["*"], true, never>;
55
+ }
@@ -1,5 +1,5 @@
1
1
  import * as i0 from "@angular/core";
2
2
  export declare class TooltipComponent {
3
3
  static ɵfac: i0.ɵɵFactoryDeclaration<TooltipComponent, never>;
4
- static ɵcmp: i0.ɵɵComponentDeclaration<TooltipComponent, "lib-tooltip", never, {}, {}, never, never, true, never>;
4
+ static ɵcmp: i0.ɵɵComponentDeclaration<TooltipComponent, "sc-tooltip", never, {}, {}, never, never, true, never>;
5
5
  }
@@ -1,16 +1,189 @@
1
- import { ChangeDetectionStrategy, Component, ViewEncapsulation } from '@angular/core';
1
+ import { Directionality } from '@angular/cdk/bidi';
2
+ import { Overlay } from '@angular/cdk/overlay';
3
+ import { _getEventTarget } from '@angular/cdk/platform';
4
+ import { ComponentPortal } from '@angular/cdk/portal';
2
5
  import { CommonModule } from '@angular/common';
6
+ import { ChangeDetectionStrategy, Component, Inject, Injector, LOCALE_ID, ViewEncapsulation, inject, output, signal, viewChild, } from '@angular/core';
7
+ import { InlineDatePickerComponent } from './inline-date-picker.component';
3
8
  import * as i0 from "@angular/core";
4
9
  export class DatePickerComponent {
5
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: DatePickerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
6
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.11", type: DatePickerComponent, isStandalone: true, selector: "lib-date-picker", ngImport: i0, template: `
7
- <p>date-picker works!</p>
10
+ localeId;
11
+ dateFormatPattern = signal('');
12
+ constructor(localeId) {
13
+ this.localeId = localeId;
14
+ }
15
+ ngOnInit() {
16
+ this.dateFormatPattern.set(this.getDateFormatPattern(this.localeId));
17
+ }
18
+ getDateFormatPattern(localeId) {
19
+ const getPatternForPart = (part) => {
20
+ switch (part.type) {
21
+ case 'day':
22
+ return 'd'.repeat(part.value.length);
23
+ case 'month':
24
+ return 'M'.repeat(part.value.length);
25
+ case 'year':
26
+ return 'y'.repeat(part.value.length);
27
+ case 'literal':
28
+ return part.value;
29
+ default:
30
+ throw new Error('no default');
31
+ }
32
+ };
33
+ return new Intl.DateTimeFormat(localeId)
34
+ .formatToParts(new Date('2022-01-01'))
35
+ .map(getPatternForPart)
36
+ .join('');
37
+ }
38
+ _injector = inject(Injector);
39
+ _dir = inject(Directionality, { optional: true });
40
+ _overlay = inject(Overlay);
41
+ _isOpen = signal(false);
42
+ _input = viewChild('input');
43
+ _overlayOrigin = viewChild('overlayOrigin');
44
+ _overlayRef = null;
45
+ _portal = null;
46
+ /** Emits when the datepicker is opened. */
47
+ opened = output();
48
+ /** Emits when the datepicker is closed. */
49
+ closed = output();
50
+ /** Emits when the user selects a date. */
51
+ selected = output();
52
+ /** Opens the datepicker. */
53
+ open() {
54
+ if (!this._input) {
55
+ return;
56
+ }
57
+ // Focus should already be on the input, but this call is in case the datepicker is opened
58
+ // programmatically. We need to call this even if the datepicker is already open, because
59
+ // the user might be clicking the toggle.
60
+ this._input()?.nativeElement.focus();
61
+ if (this._isOpen()) {
62
+ return;
63
+ }
64
+ this._isOpen.set(true);
65
+ const overlayRef = this._getOverlayRef();
66
+ overlayRef.updateSize({ width: this._overlayOrigin()?.nativeElement.offsetWidth });
67
+ this._portal ??= new ComponentPortal(InlineDatePickerComponent);
68
+ overlayRef.attach(this._portal);
69
+ this.opened.emit();
70
+ }
71
+ /** Closes the datepicker. */
72
+ close() {
73
+ if (this._isOpen()) {
74
+ this._isOpen.set(false);
75
+ this._overlayRef?.detach();
76
+ this.closed.emit();
77
+ }
78
+ }
79
+ /** Creates an overlay reference for the datepicker panel. */
80
+ _getOverlayRef() {
81
+ if (this._overlayRef) {
82
+ return this._overlayRef;
83
+ }
84
+ const _overlayOrigin = this._overlayOrigin();
85
+ if (_overlayOrigin === undefined) {
86
+ throw new Error('_overlayOrigin is undefined');
87
+ }
88
+ const positionStrategy = this._overlay
89
+ .position()
90
+ .flexibleConnectedTo(_overlayOrigin)
91
+ .withFlexibleDimensions(false)
92
+ .withPush(false)
93
+ // .withTransformOriginOn('.mat-datepicker-panel')
94
+ .withPositions([
95
+ {
96
+ originX: 'start',
97
+ originY: 'bottom',
98
+ overlayX: 'start',
99
+ overlayY: 'top',
100
+ },
101
+ {
102
+ originX: 'start',
103
+ originY: 'top',
104
+ overlayX: 'start',
105
+ overlayY: 'bottom',
106
+ //panelClass: 'mat-datepicker-above',
107
+ },
108
+ ]);
109
+ this._overlayRef = this._overlay.create({
110
+ positionStrategy,
111
+ scrollStrategy: this._overlay.scrollStrategies.reposition(),
112
+ direction: this._dir || 'ltr',
113
+ hasBackdrop: false,
114
+ });
115
+ this._overlayRef.keydownEvents().subscribe((event) => {
116
+ console.log(event);
117
+ });
118
+ this._overlayRef.outsidePointerEvents().subscribe((event) => {
119
+ const target = _getEventTarget(event);
120
+ const origin = this._overlayOrigin()?.nativeElement;
121
+ if (target && target !== origin && !origin?.contains(target)) {
122
+ this.close();
123
+ }
124
+ });
125
+ return this._overlayRef;
126
+ }
127
+ /** Selects a specific date value. */
128
+ _selectValue(value) {
129
+ this.close();
130
+ this.selected.emit(value);
131
+ this._input()?.nativeElement.focus();
132
+ }
133
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: DatePickerComponent, deps: [{ token: LOCALE_ID }], target: i0.ɵɵFactoryTarget.Component });
134
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.11", type: DatePickerComponent, isStandalone: true, selector: "sc-date-picker", outputs: { opened: "opened", closed: "closed", selected: "selected" }, viewQueries: [{ propertyName: "_input", first: true, predicate: ["input"], descendants: true, isSignal: true }, { propertyName: "_overlayOrigin", first: true, predicate: ["overlayOrigin"], descendants: true, isSignal: true }], ngImport: i0, template: `
135
+ <div class="relative max-w-sm" #overlayOrigin>
136
+ <button class="absolute inset-y-0 end-0 flex items-center pe-3.5" (click)="open()">
137
+ <svg
138
+ class="size-4 text-gray-500 dark:text-gray-400"
139
+ aria-hidden="true"
140
+ xmlns="http://www.w3.org/2000/svg"
141
+ fill="currentColor"
142
+ viewBox="0 0 20 20"
143
+ >
144
+ <path
145
+ d="M20 4a2 2 0 0 0-2-2h-2V1a1 1 0 0 0-2 0v1h-3V1a1 1 0 0 0-2 0v1H6V1a1 1 0 0 0-2 0v1H2a2 2 0 0 0-2 2v2h20V4ZM0 18a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2V8H0v10Zm5-8h10a1 1 0 0 1 0 2H5a1 1 0 0 1 0-2Z"
146
+ />
147
+ </svg>
148
+ </button>
149
+ <input
150
+ class="block w-full rounded-lg border border-gray-300 bg-gray-50 p-2.5 pe-10 text-sm text-gray-900 focus:border-blue-500 focus:ring-blue-500 dark:border-gray-600 dark:bg-gray-700 dark:text-white dark:placeholder:text-gray-400 dark:focus:border-blue-500 dark:focus:ring-blue-500"
151
+ #input
152
+ type="text"
153
+ placeholder="Select date"
154
+ />
155
+ </div>
156
+ {{ dateFormatPattern() }}
8
157
  `, isInline: true, styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
9
158
  }
10
159
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: DatePickerComponent, decorators: [{
11
160
  type: Component,
12
- args: [{ selector: 'lib-date-picker', standalone: true, imports: [CommonModule], template: `
13
- <p>date-picker works!</p>
161
+ args: [{ selector: 'sc-date-picker', standalone: true, imports: [CommonModule, InlineDatePickerComponent], template: `
162
+ <div class="relative max-w-sm" #overlayOrigin>
163
+ <button class="absolute inset-y-0 end-0 flex items-center pe-3.5" (click)="open()">
164
+ <svg
165
+ class="size-4 text-gray-500 dark:text-gray-400"
166
+ aria-hidden="true"
167
+ xmlns="http://www.w3.org/2000/svg"
168
+ fill="currentColor"
169
+ viewBox="0 0 20 20"
170
+ >
171
+ <path
172
+ d="M20 4a2 2 0 0 0-2-2h-2V1a1 1 0 0 0-2 0v1h-3V1a1 1 0 0 0-2 0v1H6V1a1 1 0 0 0-2 0v1H2a2 2 0 0 0-2 2v2h20V4ZM0 18a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2V8H0v10Zm5-8h10a1 1 0 0 1 0 2H5a1 1 0 0 1 0-2Z"
173
+ />
174
+ </svg>
175
+ </button>
176
+ <input
177
+ class="block w-full rounded-lg border border-gray-300 bg-gray-50 p-2.5 pe-10 text-sm text-gray-900 focus:border-blue-500 focus:ring-blue-500 dark:border-gray-600 dark:bg-gray-700 dark:text-white dark:placeholder:text-gray-400 dark:focus:border-blue-500 dark:focus:ring-blue-500"
178
+ #input
179
+ type="text"
180
+ placeholder="Select date"
181
+ />
182
+ </div>
183
+ {{ dateFormatPattern() }}
14
184
  `, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush }]
15
- }] });
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1waWNrZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS9zcmMvY29tcG9uZW50cy9kYXRlLXBpY2tlci9kYXRlLXBpY2tlci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN0RixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7O0FBYS9DLE1BQU0sT0FBTyxtQkFBbUI7d0dBQW5CLG1CQUFtQjs0RkFBbkIsbUJBQW1CLDJFQVBwQjs7R0FFVCx5RUFIUyxZQUFZOzs0RkFRWCxtQkFBbUI7a0JBWC9CLFNBQVM7K0JBQ0UsaUJBQWlCLGNBQ2YsSUFBSSxXQUNQLENBQUMsWUFBWSxDQUFDLFlBQ2I7O0dBRVQsaUJBRWMsaUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdsaWItZGF0ZS1waWNrZXInLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgdGVtcGxhdGU6IGBcbiAgICA8cD5kYXRlLXBpY2tlciB3b3JrcyE8L3A+XG4gIGAsXG4gIHN0eWxlczogYGAsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBEYXRlUGlja2VyQ29tcG9uZW50IHt9XG4iXX0=
185
+ }], ctorParameters: () => [{ type: undefined, decorators: [{
186
+ type: Inject,
187
+ args: [LOCALE_ID]
188
+ }] }] });
189
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker.component.js","sourceRoot":"","sources":["../../../../../../libs/ui/src/components/date-picker/date-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directionality } from '@angular/cdk/bidi';\nimport { Overlay, OverlayRef } from '@angular/cdk/overlay';\nimport { _getEventTarget } from '@angular/cdk/platform';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Inject,\n  Injector,\n  LOCALE_ID,\n  OnInit,\n  OutputEmitterRef,\n  ViewEncapsulation,\n  inject,\n  output,\n  signal,\n  viewChild,\n} from '@angular/core';\n\nimport { InlineDatePickerComponent } from './inline-date-picker.component';\n\n@Component({\n  selector: 'sc-date-picker',\n  standalone: true,\n  imports: [CommonModule, InlineDatePickerComponent],\n  template: `\n    <div class=\"relative max-w-sm\" #overlayOrigin>\n      <button class=\"absolute inset-y-0 end-0 flex items-center pe-3.5\" (click)=\"open()\">\n        <svg\n          class=\"size-4 text-gray-500 dark:text-gray-400\"\n          aria-hidden=\"true\"\n          xmlns=\"http://www.w3.org/2000/svg\"\n          fill=\"currentColor\"\n          viewBox=\"0 0 20 20\"\n        >\n          <path\n            d=\"M20 4a2 2 0 0 0-2-2h-2V1a1 1 0 0 0-2 0v1h-3V1a1 1 0 0 0-2 0v1H6V1a1 1 0 0 0-2 0v1H2a2 2 0 0 0-2 2v2h20V4ZM0 18a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2V8H0v10Zm5-8h10a1 1 0 0 1 0 2H5a1 1 0 0 1 0-2Z\"\n          />\n        </svg>\n      </button>\n      <input\n        class=\"block w-full rounded-lg border border-gray-300 bg-gray-50 p-2.5 pe-10 text-sm text-gray-900 focus:border-blue-500 focus:ring-blue-500 dark:border-gray-600 dark:bg-gray-700 dark:text-white dark:placeholder:text-gray-400 dark:focus:border-blue-500 dark:focus:ring-blue-500\"\n        #input\n        type=\"text\"\n        placeholder=\"Select date\"\n      />\n    </div>\n    {{ dateFormatPattern() }}\n  `,\n  styles: ``,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DatePickerComponent implements OnInit {\n  dateFormatPattern = signal<string>('');\n\n  constructor(@Inject(LOCALE_ID) private readonly localeId: string) {}\n\n  ngOnInit() {\n    this.dateFormatPattern.set(this.getDateFormatPattern(this.localeId));\n  }\n\n  getDateFormatPattern(localeId: string) {\n    const getPatternForPart = (part: Intl.DateTimeFormatPart) => {\n      switch (part.type) {\n        case 'day':\n          return 'd'.repeat(part.value.length);\n        case 'month':\n          return 'M'.repeat(part.value.length);\n        case 'year':\n          return 'y'.repeat(part.value.length);\n        case 'literal':\n          return part.value;\n        default:\n          throw new Error('no default');\n      }\n    };\n\n    return new Intl.DateTimeFormat(localeId)\n      .formatToParts(new Date('2022-01-01'))\n      .map(getPatternForPart)\n      .join('');\n  }\n\n  private readonly _injector = inject(Injector);\n\n  private readonly _dir = inject(Directionality, { optional: true });\n  private readonly _overlay = inject(Overlay);\n\n  private readonly _isOpen = signal(false);\n  private readonly _input = viewChild<ElementRef<HTMLInputElement>>('input');\n  private readonly _overlayOrigin = viewChild<ElementRef<HTMLDivElement>>('overlayOrigin');\n  private _overlayRef: OverlayRef | null = null;\n  private _portal: ComponentPortal<unknown> | null = null;\n\n  /** Emits when the datepicker is opened. */\n  readonly opened: OutputEmitterRef<void> = output();\n  /** Emits when the datepicker is closed. */\n  readonly closed: OutputEmitterRef<void> = output();\n\n  /** Emits when the user selects a date. */\n  readonly selected: OutputEmitterRef<string> = output();\n\n  /** Opens the datepicker. */\n  open(): void {\n    if (!this._input) {\n      return;\n    }\n\n    // Focus should already be on the input, but this call is in case the datepicker is opened\n    // programmatically. We need to call this even if the datepicker is already open, because\n    // the user might be clicking the toggle.\n    this._input()?.nativeElement.focus();\n\n    if (this._isOpen()) {\n      return;\n    }\n\n    this._isOpen.set(true);\n\n    const overlayRef = this._getOverlayRef();\n\n    overlayRef.updateSize({ width: this._overlayOrigin()?.nativeElement.offsetWidth });\n\n    this._portal ??= new ComponentPortal(InlineDatePickerComponent);\n\n    overlayRef.attach(this._portal);\n\n    this.opened.emit();\n  }\n\n  /** Closes the datepicker. */\n  close(): void {\n    if (this._isOpen()) {\n      this._isOpen.set(false);\n      this._overlayRef?.detach();\n      this.closed.emit();\n    }\n  }\n\n  /** Creates an overlay reference for the datepicker panel. */\n  private _getOverlayRef(): OverlayRef {\n    if (this._overlayRef) {\n      return this._overlayRef;\n    }\n\n    const _overlayOrigin = this._overlayOrigin();\n    if (_overlayOrigin === undefined) {\n      throw new Error('_overlayOrigin is undefined');\n    }\n\n    const positionStrategy = this._overlay\n      .position()\n      .flexibleConnectedTo(_overlayOrigin)\n      .withFlexibleDimensions(false)\n      .withPush(false)\n      // .withTransformOriginOn('.mat-datepicker-panel')\n      .withPositions([\n        {\n          originX: 'start',\n          originY: 'bottom',\n          overlayX: 'start',\n          overlayY: 'top',\n        },\n        {\n          originX: 'start',\n          originY: 'top',\n          overlayX: 'start',\n          overlayY: 'bottom',\n          //panelClass: 'mat-datepicker-above',\n        },\n      ]);\n\n    this._overlayRef = this._overlay.create({\n      positionStrategy,\n      scrollStrategy: this._overlay.scrollStrategies.reposition(),\n      direction: this._dir || 'ltr',\n      hasBackdrop: false,\n    });\n\n    this._overlayRef.keydownEvents().subscribe((event) => {\n      console.log(event);\n    });\n\n    this._overlayRef.outsidePointerEvents().subscribe((event) => {\n      const target = _getEventTarget(event) as HTMLElement;\n      const origin = this._overlayOrigin()?.nativeElement;\n\n      if (target && target !== origin && !origin?.contains(target)) {\n        this.close();\n      }\n    });\n\n    return this._overlayRef;\n  }\n\n  /** Selects a specific date value. */\n  protected _selectValue(value: string) {\n    this.close();\n    this.selected.emit(value);\n    this._input()?.nativeElement.focus();\n  }\n}\n"]}
@@ -1,2 +1,3 @@
1
1
  export * from './date-picker.component';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL3NyYy9jb21wb25lbnRzL2RhdGUtcGlja2VyL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMseUJBQXlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2RhdGUtcGlja2VyLmNvbXBvbmVudCc7XG4iXX0=
2
+ export * from './inline-date-picker.component';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL3NyYy9jb21wb25lbnRzL2RhdGUtcGlja2VyL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxnQ0FBZ0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZGF0ZS1waWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vaW5saW5lLWRhdGUtcGlja2VyLmNvbXBvbmVudCc7XG4iXX0=