@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.
- package/README.md +6 -0
- package/components/date-picker/date-picker.component.d.ts +30 -2
- package/components/date-picker/index.d.ts +1 -0
- package/components/date-picker/inline-date-picker.component.d.ts +23 -0
- package/components/date-picker/month-days.component.d.ts +11 -0
- package/components/date-picker/month-year-header.component.d.ts +7 -0
- package/components/date-picker/week-days-names.component.d.ts +11 -0
- package/components/dropdown/dropdown-divider.component.d.ts +5 -0
- package/components/dropdown/dropdown-item.component.d.ts +6 -0
- package/components/dropdown/dropdown.component.d.ts +5 -0
- package/components/dropdown/index.d.ts +3 -0
- package/components/editor/editor.component.d.ts +1 -1
- package/components/nav/index.d.ts +3 -0
- package/components/nav/nav-item-dropdown.component.d.ts +5 -0
- package/components/nav/nav-item.component.d.ts +5 -0
- package/components/nav/nav.component.d.ts +5 -0
- package/components/select/index.d.ts +2 -0
- package/components/select/select-option.component.d.ts +7 -0
- package/components/select/select.component.d.ts +55 -0
- package/components/tooltip/tooltip.component.d.ts +1 -1
- package/esm2022/components/date-picker/date-picker.component.mjs +181 -8
- package/esm2022/components/date-picker/index.mjs +2 -1
- package/esm2022/components/date-picker/inline-date-picker.component.mjs +185 -0
- package/esm2022/components/date-picker/month-days.component.mjs +69 -0
- package/esm2022/components/date-picker/month-year-header.component.mjs +124 -0
- package/esm2022/components/date-picker/week-days-names.component.mjs +37 -0
- package/esm2022/components/dropdown/dropdown-divider.component.mjs +16 -0
- package/esm2022/components/dropdown/dropdown-item.component.mjs +33 -0
- package/esm2022/components/dropdown/dropdown.component.mjs +85 -0
- package/esm2022/components/dropdown/index.mjs +4 -0
- package/esm2022/components/editor/editor.component.mjs +4 -4
- package/esm2022/components/nav/index.mjs +4 -0
- package/esm2022/components/nav/nav-item-dropdown.component.mjs +148 -0
- package/esm2022/components/nav/nav-item.component.mjs +16 -0
- package/esm2022/components/nav/nav.component.mjs +16 -0
- package/esm2022/components/select/index.mjs +3 -0
- package/esm2022/components/select/select-option.component.mjs +28 -0
- package/esm2022/components/select/select.component.mjs +252 -0
- package/esm2022/components/tooltip/tooltip.component.mjs +4 -4
- package/esm2022/index.mjs +4 -2
- package/fesm2022/semantic-components-ui.mjs +1132 -559
- package/fesm2022/semantic-components-ui.mjs.map +1 -1
- package/index.d.ts +3 -1
- package/package.json +7 -3
- package/components/navbar/index.d.ts +0 -1
- package/components/navbar/navbar.component.d.ts +0 -5
- package/esm2022/components/navbar/index.mjs +0 -2
- package/esm2022/components/navbar/navbar.component.mjs +0 -566
package/README.md
CHANGED
|
@@ -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, "
|
|
32
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DatePickerComponent, "sc-date-picker", never, {}, { "opened": "opened"; "closed": "closed"; "selected": "selected"; }, never, never, true, never>;
|
|
5
33
|
}
|
|
@@ -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
|
+
}
|
|
@@ -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, "
|
|
4
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<EditorComponent, "sc-editor", never, {}, {}, never, never, true, never>;
|
|
5
5
|
}
|
|
@@ -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,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, "
|
|
4
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TooltipComponent, "sc-tooltip", never, {}, {}, never, never, true, never>;
|
|
5
5
|
}
|
|
@@ -1,16 +1,189 @@
|
|
|
1
|
-
import {
|
|
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
|
-
|
|
6
|
-
|
|
7
|
-
|
|
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: '
|
|
13
|
-
<
|
|
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
|
-
|
|
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
|
-
|
|
2
|
+
export * from './inline-date-picker.component';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpL3NyYy9jb21wb25lbnRzL2RhdGUtcGlja2VyL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyxnQ0FBZ0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZGF0ZS1waWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vaW5saW5lLWRhdGUtcGlja2VyLmNvbXBvbmVudCc7XG4iXX0=
|