@tedi-design-system/angular 6.2.0-rc.2 → 6.2.0-rc.20
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 +26 -1
- package/community/components/cards/accordion/accordion/accordion.component.d.ts +3 -0
- package/community/components/cards/accordion/accordion/accordion.component.d.ts.map +1 -1
- package/community/components/cards/accordion/accordion-item/accordion-item.component.d.ts +2 -2
- package/community/components/cards/accordion/accordion-item/accordion-item.component.d.ts.map +1 -1
- package/community/components/cards/accordion/accordion-item-header/accordion-item-header.component.d.ts +1 -1
- package/community/components/cards/accordion/accordion-item-header/accordion-item-header.component.d.ts.map +1 -1
- package/community/components/form/file-dropzone/file.service.d.ts.map +1 -1
- package/community/components/form/input/input.component.d.ts +3 -0
- package/community/components/form/input/input.component.d.ts.map +1 -1
- package/community/components/tags/status-badge/status-badge.component.d.ts +3 -0
- package/community/components/tags/status-badge/status-badge.component.d.ts.map +1 -1
- package/fesm2022/tedi-design-system-angular-community.mjs +27 -20
- package/fesm2022/tedi-design-system-angular-community.mjs.map +1 -1
- package/fesm2022/tedi-design-system-angular-tedi.mjs +618 -62
- package/fesm2022/tedi-design-system-angular-tedi.mjs.map +1 -1
- package/index.css +1 -1
- package/package.json +10 -10
- package/tedi/components/cards/accordion/accordion/accordion.component.d.ts +14 -0
- package/tedi/components/cards/accordion/accordion/accordion.component.d.ts.map +1 -0
- package/tedi/components/cards/accordion/accordion-item/accordion-item.component.d.ts +90 -0
- package/tedi/components/cards/accordion/accordion-item/accordion-item.component.d.ts.map +1 -0
- package/tedi/components/cards/accordion/index.d.ts +3 -0
- package/tedi/components/cards/accordion/index.d.ts.map +1 -0
- package/tedi/components/cards/index.d.ts +2 -0
- package/tedi/components/cards/index.d.ts.map +1 -0
- package/tedi/components/content/carousel/carousel-content/carousel-content.component.d.ts +22 -1
- package/tedi/components/content/carousel/carousel-content/carousel-content.component.d.ts.map +1 -1
- package/tedi/components/form/date-picker/date-picker.component.d.ts +12 -3
- package/tedi/components/form/date-picker/date-picker.component.d.ts.map +1 -1
- package/tedi/components/form/form-field/form-field-control.d.ts +31 -0
- package/tedi/components/form/form-field/form-field-control.d.ts.map +1 -0
- package/tedi/components/form/form-field/form-field.component.d.ts +57 -0
- package/tedi/components/form/form-field/form-field.component.d.ts.map +1 -0
- package/tedi/components/form/index.d.ts +2 -0
- package/tedi/components/form/index.d.ts.map +1 -1
- package/tedi/components/form/text-field/text-field.component.d.ts +38 -0
- package/tedi/components/form/text-field/text-field.component.d.ts.map +1 -0
- package/tedi/components/index.d.ts +1 -0
- package/tedi/components/index.d.ts.map +1 -1
- package/tedi/components/loader/spinner/spinner.component.d.ts +3 -0
- package/tedi/components/loader/spinner/spinner.component.d.ts.map +1 -1
- package/tedi/components/overlay/popover/popover.component.d.ts +12 -1
- package/tedi/components/overlay/popover/popover.component.d.ts.map +1 -1
- package/tedi/components/overlay/tooltip/tooltip-trigger/tooltip-trigger.component.d.ts +3 -0
- package/tedi/components/overlay/tooltip/tooltip-trigger/tooltip-trigger.component.d.ts.map +1 -1
- package/tedi/components/tags/index.d.ts +1 -0
- package/tedi/components/tags/index.d.ts.map +1 -1
- package/tedi/components/tags/status-badge/status-badge.component.d.ts +55 -0
- package/tedi/components/tags/status-badge/status-badge.component.d.ts.map +1 -0
- package/tedi/providers/tedi.provider.d.ts.map +1 -1
- package/tedi/services/theme/theme.service.d.ts +3 -3
- package/tedi/services/theme/theme.service.d.ts.map +1 -1
- package/tedi/tokens/theme.token.d.ts +1 -2
- package/tedi/tokens/theme.token.d.ts.map +1 -1
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tedi-design-system/angular",
|
|
3
|
-
"version": "6.2.0-rc.
|
|
3
|
+
"version": "6.2.0-rc.20",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"main": "community.mjs",
|
|
6
6
|
"module": "fesm2022/tedi-design-system-angular.mjs",
|
|
@@ -25,16 +25,16 @@
|
|
|
25
25
|
}
|
|
26
26
|
},
|
|
27
27
|
"peerDependencies": {
|
|
28
|
-
"@angular/animations": "^19.0.0 || ^20.0.0",
|
|
29
|
-
"@angular/cdk": "^19.0.0 || ^20.0.0",
|
|
30
|
-
"@angular/common": "^19.0.0 || ^20.0.0",
|
|
31
|
-
"@angular/core": "^19.0.0 || ^20.0.0",
|
|
32
|
-
"@angular/forms": "^19.0.0 || ^20.0.0",
|
|
33
|
-
"@angular/platform-browser": "^19.0.0 || ^20.0.0",
|
|
34
|
-
"ngx-float-ui": "^19.0.1 || ^20.0.0"
|
|
28
|
+
"@angular/animations": "^19.0.0 || ^20.0.0 || ^21.0.0",
|
|
29
|
+
"@angular/cdk": "^19.0.0 || ^20.0.0 || ^21.0.0",
|
|
30
|
+
"@angular/common": "^19.0.0 || ^20.0.0 || ^21.0.0",
|
|
31
|
+
"@angular/core": "^19.0.0 || ^20.0.0 || ^21.0.0",
|
|
32
|
+
"@angular/forms": "^19.0.0 || ^20.0.0 || ^21.0.0",
|
|
33
|
+
"@angular/platform-browser": "^19.0.0 || ^20.0.0 || ^21.0.0",
|
|
34
|
+
"ngx-float-ui": "^19.0.1 || ^20.0.0 || ^21.0.0"
|
|
35
35
|
},
|
|
36
36
|
"dependencies": {
|
|
37
|
-
"@tedi-design-system/core": "^3.0
|
|
37
|
+
"@tedi-design-system/core": "^3.3.0",
|
|
38
38
|
"tslib": "^2.3.0"
|
|
39
39
|
},
|
|
40
40
|
"commitlint": {
|
|
@@ -69,7 +69,7 @@
|
|
|
69
69
|
},
|
|
70
70
|
"repository": {
|
|
71
71
|
"type": "git",
|
|
72
|
-
"url": "https://github.com/TEDI-Design-System/angular.git"
|
|
72
|
+
"url": "git+https://github.com/TEDI-Design-System/angular.git"
|
|
73
73
|
},
|
|
74
74
|
"typings": "index.d.ts",
|
|
75
75
|
"sideEffects": false
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { AccordionItemComponent } from "../accordion-item/accordion-item.component";
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class AccordionComponent {
|
|
4
|
+
/**
|
|
5
|
+
* Whether the accordion allows multiple items to be expanded at the same time.
|
|
6
|
+
* If false, opening one item will collapse the others automatically.
|
|
7
|
+
*/
|
|
8
|
+
allowMultiple: import("@angular/core").InputSignal<boolean>;
|
|
9
|
+
items: import("@angular/core").Signal<readonly AccordionItemComponent[]>;
|
|
10
|
+
onItemToggled(activeItem: AccordionItemComponent): void;
|
|
11
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<AccordionComponent, never>;
|
|
12
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<AccordionComponent, "tedi-accordion", never, { "allowMultiple": { "alias": "allowMultiple"; "required": false; "isSignal": true; }; }, {}, ["items"], ["*"], true, never>;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=accordion.component.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"accordion.component.d.ts","sourceRoot":"","sources":["../../../../../../tedi/components/cards/accordion/accordion/accordion.component.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,sBAAsB,EAAE,MAAM,4CAA4C,CAAC;;AAEpF,qBAQa,kBAAkB;IAC7B;;;OAGG;IACH,aAAa,+CAAgB;IAE7B,KAAK,oEAA2C;IAEhD,aAAa,CAAC,UAAU,EAAE,sBAAsB;yCATrC,kBAAkB;2CAAlB,kBAAkB;CAoB9B"}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { OnInit } from "@angular/core";
|
|
2
|
+
import { _IdGenerator } from "@angular/cdk/a11y";
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export declare class AccordionItemComponent implements OnInit {
|
|
5
|
+
readonly idGenerator: _IdGenerator;
|
|
6
|
+
readonly bodyId: string;
|
|
7
|
+
readonly headerId: string;
|
|
8
|
+
/**
|
|
9
|
+
* If false, disables header toggling and enables using interactive elements in the accordion header.
|
|
10
|
+
*/
|
|
11
|
+
headerClickable: import("@angular/core").InputSignal<boolean>;
|
|
12
|
+
/** The title of the accordion item. */
|
|
13
|
+
title: import("@angular/core").InputSignal<string>;
|
|
14
|
+
/**
|
|
15
|
+
* Sets how the accordion title stretches horizontally.
|
|
16
|
+
* `hug` - container sizes to its content.
|
|
17
|
+
* `fill` - container expands to available space, moving any trailing elements to the end.
|
|
18
|
+
*/
|
|
19
|
+
titleLayout: import("@angular/core").InputSignal<"fill" | "hug">;
|
|
20
|
+
/**
|
|
21
|
+
* Whether the title is rendered as separate text in the accordion header.
|
|
22
|
+
* If false and `showExpandLabel` is true, the title is used as the expand button label.
|
|
23
|
+
*/
|
|
24
|
+
showSeparateTitle: import("@angular/core").InputSignal<boolean>;
|
|
25
|
+
/** Label shown when accordion is collapsed */
|
|
26
|
+
openLabel: import("@angular/core").InputSignal<string>;
|
|
27
|
+
/** Label shown when accordion is expanded */
|
|
28
|
+
closeLabel: import("@angular/core").InputSignal<string>;
|
|
29
|
+
/**
|
|
30
|
+
* Controls whether the expand/collapse label is shown.
|
|
31
|
+
*/
|
|
32
|
+
showExpandLabel: import("@angular/core").InputSignal<boolean>;
|
|
33
|
+
/**
|
|
34
|
+
* Controls whether the default expand/collapse action is shown.
|
|
35
|
+
*/
|
|
36
|
+
showDefaultExpandAction: import("@angular/core").InputSignal<boolean>;
|
|
37
|
+
/**
|
|
38
|
+
* Position of the expand action relative to the header content.
|
|
39
|
+
*/
|
|
40
|
+
expandActionPosition: import("@angular/core").InputSignal<"end" | "start">;
|
|
41
|
+
/**
|
|
42
|
+
* Whether the accordion item is expanded initially.
|
|
43
|
+
* Does not control the expanded state after initialization.
|
|
44
|
+
*/
|
|
45
|
+
defaultExpanded: import("@angular/core").InputSignal<boolean>;
|
|
46
|
+
/** Optional description text shown in the header */
|
|
47
|
+
description: import("@angular/core").InputSignal<string | undefined>;
|
|
48
|
+
/**
|
|
49
|
+
* Position of the description relative to the title.
|
|
50
|
+
*/
|
|
51
|
+
descriptionPosition: import("@angular/core").InputSignal<"end" | "start" | "both">;
|
|
52
|
+
/**
|
|
53
|
+
* Enables the icon-card layout variant.
|
|
54
|
+
*/
|
|
55
|
+
showIconCard: import("@angular/core").InputSignal<boolean>;
|
|
56
|
+
/**
|
|
57
|
+
* Marks the accordion item as selected.
|
|
58
|
+
*/
|
|
59
|
+
selected: import("@angular/core").InputSignal<boolean>;
|
|
60
|
+
/**
|
|
61
|
+
* Custom CSS classes for the accordion header.
|
|
62
|
+
*/
|
|
63
|
+
headerClass: import("@angular/core").InputSignal<string | null>;
|
|
64
|
+
/**
|
|
65
|
+
* Custom CSS classes for the accordion body.
|
|
66
|
+
*/
|
|
67
|
+
bodyClass: import("@angular/core").InputSignal<string | null>;
|
|
68
|
+
expanded: import("@angular/core").ModelSignal<boolean>;
|
|
69
|
+
private readonly accordion;
|
|
70
|
+
ngOnInit(): void;
|
|
71
|
+
toggle(): void;
|
|
72
|
+
setExpanded(value: boolean): void;
|
|
73
|
+
expandLabel: import("@angular/core").Signal<string>;
|
|
74
|
+
showStartExpandAction: import("@angular/core").Signal<boolean>;
|
|
75
|
+
showEndExpandAction: import("@angular/core").Signal<boolean>;
|
|
76
|
+
readonly headerClasses: import("@angular/core").Signal<{
|
|
77
|
+
"tedi-accordion__header--hoverable": boolean;
|
|
78
|
+
"tedi-accordion__header--expanded": boolean;
|
|
79
|
+
"tedi-accordion__header--with-icon-card": boolean;
|
|
80
|
+
"tedi-accordion__header": boolean;
|
|
81
|
+
}>;
|
|
82
|
+
readonly bodyClasses: import("@angular/core").Signal<{
|
|
83
|
+
"tedi-accordion__body--with-icon-card": boolean;
|
|
84
|
+
"tedi-accordion__body": boolean;
|
|
85
|
+
}>;
|
|
86
|
+
hideTitleFromSR: import("@angular/core").Signal<boolean>;
|
|
87
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<AccordionItemComponent, never>;
|
|
88
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<AccordionItemComponent, "tedi-accordion-item", never, { "headerClickable": { "alias": "headerClickable"; "required": false; "isSignal": true; }; "title": { "alias": "title"; "required": false; "isSignal": true; }; "titleLayout": { "alias": "titleLayout"; "required": false; "isSignal": true; }; "showSeparateTitle": { "alias": "showSeparateTitle"; "required": false; "isSignal": true; }; "openLabel": { "alias": "openLabel"; "required": false; "isSignal": true; }; "closeLabel": { "alias": "closeLabel"; "required": false; "isSignal": true; }; "showExpandLabel": { "alias": "showExpandLabel"; "required": false; "isSignal": true; }; "showDefaultExpandAction": { "alias": "showDefaultExpandAction"; "required": false; "isSignal": true; }; "expandActionPosition": { "alias": "expandActionPosition"; "required": false; "isSignal": true; }; "defaultExpanded": { "alias": "defaultExpanded"; "required": false; "isSignal": true; }; "description": { "alias": "description"; "required": false; "isSignal": true; }; "descriptionPosition": { "alias": "descriptionPosition"; "required": false; "isSignal": true; }; "showIconCard": { "alias": "showIconCard"; "required": false; "isSignal": true; }; "selected": { "alias": "selected"; "required": false; "isSignal": true; }; "headerClass": { "alias": "headerClass"; "required": false; "isSignal": true; }; "bodyClass": { "alias": "bodyClass"; "required": false; "isSignal": true; }; "expanded": { "alias": "expanded"; "required": false; "isSignal": true; }; }, { "expanded": "expandedChange"; }, never, ["[tedi-accordion-icon-card]", "*", "[tedi-accordion-start-action]", "[tedi-accordion-start-before-title]", "[tedi-accordion-start-description]", "[tedi-accordion-start-after-title]", "[tedi-accordion-end-description]", "[tedi-accordion-end-action]"], true, never>;
|
|
89
|
+
}
|
|
90
|
+
//# sourceMappingURL=accordion-item.component.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"accordion-item.component.d.ts","sourceRoot":"","sources":["../../../../../../tedi/components/cards/accordion/accordion-item/accordion-item.component.ts"],"names":[],"mappings":"AACA,OAAO,EAKL,MAAM,EAIP,MAAM,eAAe,CAAC;AAOvB,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;;AAEjD,qBAgBa,sBAAuB,YAAW,MAAM;IACnD,QAAQ,CAAC,WAAW,eAAwB;IAC5C,QAAQ,CAAC,MAAM,SAAiD;IAChE,QAAQ,CAAC,QAAQ,SAAmD;IACpE;;OAEG;IACH,eAAe,+CAAe;IAC9B,uCAAuC;IACvC,KAAK,8CAAa;IAClB;;;;OAIG;IACH,WAAW,sDAAgC;IAC3C;;;OAGG;IACH,iBAAiB,+CAAe;IAChC,8CAA8C;IAC9C,SAAS,8CAAyB;IAClC,6CAA6C;IAC7C,UAAU,8CAA0B;IACpC;;OAEG;IACH,eAAe,+CAAe;IAC9B;;OAEG;IACH,uBAAuB,+CAAe;IACtC;;OAEG;IACH,oBAAoB,uDAAiC;IACrD;;;OAGG;IACH,eAAe,+CAAgB;IAC/B,oDAAoD;IACpD,WAAW,0DAAwC;IACnD;;OAEG;IACH,mBAAmB,gEAA4C;IAC/D;;OAEG;IACH,YAAY,+CAAgB;IAC5B;;OAEG;IACH,QAAQ,+CAAgB;IACxB;;OAEG;IACH,WAAW,qDAA8B;IACzC;;OAEG;IACH,SAAS,qDAA8B;IAEvC,QAAQ,+CAAgB;IAExB,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAkD;IAE5E,QAAQ;IAIR,MAAM;IAKN,WAAW,CAAC,KAAK,EAAE,OAAO;IAI1B,WAAW,yCAET;IAEF,qBAAqB,0CAGnB;IAEF,mBAAmB,0CAGjB;IAEF,QAAQ,CAAC,aAAa;;;;;OAUnB;IAEH,QAAQ,CAAC,WAAW;;;OAOjB;IAEH,eAAe,0CAEZ;yCAvHQ,sBAAsB;2CAAtB,sBAAsB;CAwHlC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../tedi/components/cards/accordion/index.ts"],"names":[],"mappings":"AAAA,cAAc,iCAAiC,CAAC;AAChD,cAAc,2CAA2C,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../tedi/components/cards/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC"}
|
|
@@ -15,7 +15,9 @@ export declare class CarouselContentComponent implements AfterViewInit, OnDestro
|
|
|
15
15
|
readonly translationService: TediTranslationService;
|
|
16
16
|
private readonly breakpointService;
|
|
17
17
|
private readonly host;
|
|
18
|
+
private readonly liveAnnouncer;
|
|
18
19
|
readonly track: import("@angular/core").Signal<ElementRef<HTMLDivElement>>;
|
|
20
|
+
readonly slideElements: import("@angular/core").Signal<readonly ElementRef<HTMLDivElement>[]>;
|
|
19
21
|
readonly slides: import("@angular/core").Signal<readonly CarouselSlideDirective[]>;
|
|
20
22
|
readonly trackIndex: import("@angular/core").WritableSignal<number>;
|
|
21
23
|
readonly animate: import("@angular/core").WritableSignal<boolean>;
|
|
@@ -26,6 +28,11 @@ export declare class CarouselContentComponent implements AfterViewInit, OnDestro
|
|
|
26
28
|
readonly buffer: import("@angular/core").Signal<number>;
|
|
27
29
|
readonly slideIndex: import("@angular/core").Signal<number>;
|
|
28
30
|
readonly renderedActiveIndex: import("@angular/core").Signal<number>;
|
|
31
|
+
/**
|
|
32
|
+
* Checks if a slide at the given rendered index is currently visible in the viewport.
|
|
33
|
+
* Used to determine which slides should be accessible to screen readers.
|
|
34
|
+
*/
|
|
35
|
+
isSlideVisible(renderedIndex: number): boolean;
|
|
29
36
|
readonly renderedIndices: import("@angular/core").Signal<number[]>;
|
|
30
37
|
readonly slideFlex: import("@angular/core").Signal<string>;
|
|
31
38
|
readonly classes: import("@angular/core").Signal<string>;
|
|
@@ -36,11 +43,13 @@ export declare class CarouselContentComponent implements AfterViewInit, OnDestro
|
|
|
36
43
|
}>;
|
|
37
44
|
locked: boolean;
|
|
38
45
|
dragging: boolean;
|
|
46
|
+
private pendingFocus;
|
|
39
47
|
private startX;
|
|
40
48
|
private startIndex;
|
|
41
49
|
private ro?;
|
|
42
50
|
private wheelTimeout?;
|
|
43
51
|
private scrollDelta;
|
|
52
|
+
onScroll(): void;
|
|
44
53
|
onWheel(event: WheelEvent): void;
|
|
45
54
|
onKeyDown(event: KeyboardEvent): void;
|
|
46
55
|
onPointerDown(ev: PointerEvent): void;
|
|
@@ -50,9 +59,21 @@ export declare class CarouselContentComponent implements AfterViewInit, OnDestro
|
|
|
50
59
|
ngOnDestroy(): void;
|
|
51
60
|
next(): void;
|
|
52
61
|
prev(): void;
|
|
53
|
-
goToIndex(index: number
|
|
62
|
+
goToIndex(index: number, options?: {
|
|
63
|
+
focusSlide?: boolean;
|
|
64
|
+
}): void;
|
|
65
|
+
/**
|
|
66
|
+
* Focuses the currently active slide for screen reader users.
|
|
67
|
+
* Uses preventScroll to avoid breaking carousel layout.
|
|
68
|
+
*/
|
|
69
|
+
focusActiveSlide(): void;
|
|
54
70
|
onTransitionEnd(e: TransitionEvent): void;
|
|
55
71
|
lockNavigation(): void;
|
|
72
|
+
/**
|
|
73
|
+
* Announces the current slide position to screen readers via LiveAnnouncer.
|
|
74
|
+
* Called after navigation to inform users of the slide change.
|
|
75
|
+
*/
|
|
76
|
+
announceSlideChange(): void;
|
|
56
77
|
static ɵfac: i0.ɵɵFactoryDeclaration<CarouselContentComponent, never>;
|
|
57
78
|
static ɵcmp: i0.ɵɵComponentDeclaration<CarouselContentComponent, "tedi-carousel-content", never, { "slidesPerView": { "alias": "slidesPerView"; "required": false; "isSignal": true; }; "gap": { "alias": "gap"; "required": false; "isSignal": true; }; "fade": { "alias": "fade"; "required": false; "isSignal": true; }; "transitionMs": { "alias": "transitionMs"; "required": false; "isSignal": true; }; }, {}, ["slides"], never, true, never>;
|
|
58
79
|
}
|
package/tedi/components/content/carousel/carousel-content/carousel-content.component.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"carousel-content.component.d.ts","sourceRoot":"","sources":["../../../../../../tedi/components/content/carousel/carousel-content/carousel-content.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,UAAU,
|
|
1
|
+
{"version":3,"file":"carousel-content.component.d.ts","sourceRoot":"","sources":["../../../../../../tedi/components/content/carousel/carousel-content/carousel-content.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,UAAU,EAOV,aAAa,EACb,SAAS,EAIV,MAAM,eAAe,CAAC;AAGvB,OAAO,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;AACrE,OAAO,EAEL,eAAe,EAEhB,MAAM,oDAAoD,CAAC;AAC5D,OAAO,EAAE,sBAAsB,EAAE,MAAM,sBAAsB,CAAC;;AAE9D,qBAiBa,wBAAyB,YAAW,aAAa,EAAE,SAAS;IACvE,4EAA4E;IAC5E,QAAQ,CAAC,aAAa,qIAGpB;IAEF,+BAA+B;IAC/B,QAAQ,CAAC,GAAG,qIAGV;IAEF,uFAAuF;IACvF,QAAQ,CAAC,IAAI,+CAAgB;IAE7B,gCAAgC;IAChC,QAAQ,CAAC,YAAY,8CAAc;IAEnC,QAAQ,CAAC,kBAAkB,yBAAkC;IAC7D,OAAO,CAAC,QAAQ,CAAC,iBAAiB,CAA6B;IAC/D,OAAO,CAAC,QAAQ,CAAC,IAAI,CAA+C;IACpE,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAyB;IAEvD,QAAQ,CAAC,KAAK,6DAA2D;IACzE,QAAQ,CAAC,aAAa,wEAAqD;IAC3E,QAAQ,CAAC,MAAM,oEAA2C;IAE1D,QAAQ,CAAC,UAAU,iDAAa;IAChC,QAAQ,CAAC,OAAO,kDAAiB;IACjC,QAAQ,CAAC,aAAa,iDAAa;IACnC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAa;IAExC,QAAQ,CAAC,oBAAoB,yCA6B1B;IAEH,QAAQ,CAAC,UAAU,yCA0BhB;IAEH,QAAQ,CAAC,MAAM,yCAAwC;IAEvD,QAAQ,CAAC,UAAU,yCAShB;IAGH,QAAQ,CAAC,mBAAmB,yCAEzB;IAEH;;;OAGG;IACH,cAAc,CAAC,aAAa,EAAE,MAAM,GAAG,OAAO;IAM9C,QAAQ,CAAC,eAAe,2CAcrB;IAEH,QAAQ,CAAC,SAAS,yCAIf;IAEH,QAAQ,CAAC,OAAO,yCAUb;IAEH,QAAQ,CAAC,UAAU;;;;OA0BhB;IAEH,MAAM,UAAS;IACf,QAAQ,UAAS;IACjB,OAAO,CAAC,YAAY,CAAS;IAC7B,OAAO,CAAC,MAAM,CAAK;IACnB,OAAO,CAAC,UAAU,CAAK;IACvB,OAAO,CAAC,EAAE,CAAC,CAAiB;IAC5B,OAAO,CAAC,YAAY,CAAC,CAAgC;IACrD,OAAO,CAAC,WAAW,CAAK;IAGxB,QAAQ;IAOR,OAAO,CAAC,KAAK,EAAE,UAAU;IAsEzB,SAAS,CAAC,KAAK,EAAE,aAAa;IA+B9B,aAAa,CAAC,EAAE,EAAE,YAAY;IAc9B,aAAa,CAAC,EAAE,EAAE,YAAY;IA6B9B,WAAW;IAUX,eAAe,IAAI,IAAI;IAWvB,WAAW,IAAI,IAAI;IAInB,IAAI,IAAI,IAAI;IAWZ,IAAI,IAAI,IAAI;IAWZ,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE;QAAE,UAAU,CAAC,EAAE,OAAO,CAAA;KAAE;IAqB3D;;;OAGG;IACH,gBAAgB,IAAI,IAAI;IAUxB,eAAe,CAAC,CAAC,EAAE,eAAe;IAkBlC,cAAc;IAKd;;;OAGG;IACH,mBAAmB,IAAI,IAAI;yCApchB,wBAAwB;2CAAxB,wBAAwB;CAidpC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { OnInit, ElementRef } from "@angular/core";
|
|
2
|
-
import {
|
|
2
|
+
import { ControlValueAccessor } from "@angular/forms";
|
|
3
3
|
import { PopoverComponent } from "../../overlay/popover/popover.component";
|
|
4
4
|
import { DatePickerCalendarGridComponent } from "./date-picker-calendar-grid/date-picker-calendar-grid.component";
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
@@ -20,9 +20,13 @@ export type DatePickerMatcher = Date | Date[] | {
|
|
|
20
20
|
from: Date;
|
|
21
21
|
to?: Date;
|
|
22
22
|
} | ((date: Date) => boolean);
|
|
23
|
-
export declare class DatePickerComponent implements OnInit {
|
|
23
|
+
export declare class DatePickerComponent implements OnInit, ControlValueAccessor {
|
|
24
24
|
readonly today: Date;
|
|
25
25
|
readonly uniqueId: string;
|
|
26
|
+
private formDisabled;
|
|
27
|
+
private onChange;
|
|
28
|
+
private onTouched;
|
|
29
|
+
private emitIfChanged;
|
|
26
30
|
/** Selected date */
|
|
27
31
|
readonly selected: import("@angular/core").ModelSignal<Date | null>;
|
|
28
32
|
/** Currently shown month */
|
|
@@ -49,6 +53,8 @@ export declare class DatePickerComponent implements OnInit {
|
|
|
49
53
|
readonly inputSize: import("@angular/core").InputSignal<DatePickerInputSize>;
|
|
50
54
|
/** Is input disabled? */
|
|
51
55
|
readonly inputDisabled: import("@angular/core").InputSignal<boolean>;
|
|
56
|
+
/** Internal computed for combined disabled state (inputDisabled + formDisabled from reactive forms) */
|
|
57
|
+
readonly fieldDisabled: import("@angular/core").Signal<boolean>;
|
|
52
58
|
/** Is manual typing into input allowed? */
|
|
53
59
|
readonly allowManualInput: import("@angular/core").InputSignal<boolean>;
|
|
54
60
|
/** Should show week numbers before calendar grid? */
|
|
@@ -78,9 +84,12 @@ export declare class DatePickerComponent implements OnInit {
|
|
|
78
84
|
readonly inputElement: import("@angular/core").Signal<ElementRef<HTMLInputElement>>;
|
|
79
85
|
readonly calendarGrid: import("@angular/core").Signal<DatePickerCalendarGridComponent | undefined>;
|
|
80
86
|
readonly popover: import("@angular/core").Signal<PopoverComponent>;
|
|
81
|
-
readonly translationService: TediTranslationService;
|
|
82
87
|
constructor();
|
|
83
88
|
ngOnInit(): void;
|
|
89
|
+
writeValue(value: Date | null): void;
|
|
90
|
+
registerOnChange(fn: (value: Date | null) => void): void;
|
|
91
|
+
registerOnTouched(fn: () => void): void;
|
|
92
|
+
setDisabledState(disabled: boolean): void;
|
|
84
93
|
getTabIndex(date: Date): number;
|
|
85
94
|
prevMonth(): void;
|
|
86
95
|
nextMonth(): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"date-picker.component.d.ts","sourceRoot":"","sources":["../../../../../tedi/components/form/date-picker/date-picker.component.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"date-picker.component.d.ts","sourceRoot":"","sources":["../../../../../tedi/components/form/date-picker/date-picker.component.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { InjectionToken, Signal } from "@angular/core";
|
|
2
|
+
/**
|
|
3
|
+
* Interface implemented by controls that can be used inside `tedi-form-field`.
|
|
4
|
+
* Allows the form field container to interact with the underlying control.
|
|
5
|
+
*/
|
|
6
|
+
export interface FormFieldControl<T = unknown> {
|
|
7
|
+
/**
|
|
8
|
+
* Current value of the control.
|
|
9
|
+
*/
|
|
10
|
+
value: Signal<T>;
|
|
11
|
+
/**
|
|
12
|
+
* Whether the control is disabled.
|
|
13
|
+
*/
|
|
14
|
+
disabled: Signal<boolean>;
|
|
15
|
+
/**
|
|
16
|
+
* Whether the control is currently in an invalid state.
|
|
17
|
+
* Usually derived from Angular form validation state.
|
|
18
|
+
*/
|
|
19
|
+
invalid: Signal<boolean>;
|
|
20
|
+
/**
|
|
21
|
+
* Optional method used by the form field clear button.
|
|
22
|
+
* If implemented, the form field can trigger clearing the value.
|
|
23
|
+
*/
|
|
24
|
+
clearField?(): void;
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Injection token used by `tedi-form-field` to obtain
|
|
28
|
+
* the associated control instance.
|
|
29
|
+
*/
|
|
30
|
+
export declare const TEDI_FORM_FIELD_CONTROL: InjectionToken<FormFieldControl<unknown>>;
|
|
31
|
+
//# sourceMappingURL=form-field-control.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"form-field-control.d.ts","sourceRoot":"","sources":["../../../../../tedi/components/form/form-field/form-field-control.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvD;;;GAGG;AACH,MAAM,WAAW,gBAAgB,CAAC,CAAC,GAAG,OAAO;IAC3C;;OAEG;IACH,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;IACjB;;OAEG;IACH,QAAQ,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC;IAC1B;;;OAGG;IACH,OAAO,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC;IAEzB;;;OAGG;IACH,UAAU,CAAC,IAAI,IAAI,CAAC;CACrB;AAED;;;GAGG;AACH,eAAO,MAAM,uBAAuB,2CAEnC,CAAC"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { FormFieldControl } from "./form-field-control";
|
|
2
|
+
import { IconColor, IconSize, IconType, IconVariant } from "../../../components/base/icon/icon.component";
|
|
3
|
+
import { FeedbackTextComponent } from "../feedback-text/feedback-text.component";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export type InputSize = "small" | "large" | "default";
|
|
6
|
+
export type InputState = "valid" | "error" | "default";
|
|
7
|
+
type ValidationState = "invalid" | "valid" | "neutral";
|
|
8
|
+
export interface FormFieldIcon {
|
|
9
|
+
name: string;
|
|
10
|
+
size?: IconSize;
|
|
11
|
+
color?: IconColor;
|
|
12
|
+
type?: IconType;
|
|
13
|
+
variant?: IconVariant;
|
|
14
|
+
}
|
|
15
|
+
export declare class FormFieldComponent {
|
|
16
|
+
/**
|
|
17
|
+
* The size of the form field.
|
|
18
|
+
* @default "default"
|
|
19
|
+
*/
|
|
20
|
+
size: import("@angular/core").InputSignal<InputSize>;
|
|
21
|
+
/**
|
|
22
|
+
* Icon name or configuration object.
|
|
23
|
+
*/
|
|
24
|
+
icon: import("@angular/core").InputSignal<string | FormFieldIcon | undefined>;
|
|
25
|
+
/**
|
|
26
|
+
* Whether the form field includes a clear button.
|
|
27
|
+
* @default false
|
|
28
|
+
*/
|
|
29
|
+
clearable: import("@angular/core").InputSignal<boolean>;
|
|
30
|
+
/**
|
|
31
|
+
* Custom CSS classes for the input.
|
|
32
|
+
*/
|
|
33
|
+
inputClass: import("@angular/core").InputSignal<string | null>;
|
|
34
|
+
control?: FormFieldControl;
|
|
35
|
+
feedback?: FeedbackTextComponent;
|
|
36
|
+
readonly resolvedIcon: import("@angular/core").Signal<FormFieldIcon | undefined>;
|
|
37
|
+
readonly validationState: import("@angular/core").Signal<ValidationState>;
|
|
38
|
+
showClearButton: import("@angular/core").Signal<boolean>;
|
|
39
|
+
readonly isDisabled: import("@angular/core").Signal<boolean>;
|
|
40
|
+
readonly hostClasses: import("@angular/core").Signal<{
|
|
41
|
+
"tedi-form-field": boolean;
|
|
42
|
+
"tedi-form-field--valid": boolean;
|
|
43
|
+
"tedi-form-field--invalid": boolean;
|
|
44
|
+
"tedi-form-field--disabled": boolean | undefined;
|
|
45
|
+
"tedi-form-field--small": boolean;
|
|
46
|
+
"tedi-form-field--large": boolean;
|
|
47
|
+
"tedi-form-field--with-icon": boolean;
|
|
48
|
+
}>;
|
|
49
|
+
readonly inputClasses: import("@angular/core").Signal<{
|
|
50
|
+
"tedi-form-field__input": boolean;
|
|
51
|
+
}>;
|
|
52
|
+
clear(): void;
|
|
53
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<FormFieldComponent, never>;
|
|
54
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<FormFieldComponent, "tedi-form-field", never, { "size": { "alias": "size"; "required": false; "isSignal": true; }; "icon": { "alias": "icon"; "required": false; "isSignal": true; }; "clearable": { "alias": "clearable"; "required": false; "isSignal": true; }; "inputClass": { "alias": "inputClass"; "required": false; "isSignal": true; }; }, {}, ["control", "feedback"], ["label[tedi-label]", "input[tedi-text-field]", "tedi-feedback-text"], true, never>;
|
|
55
|
+
}
|
|
56
|
+
export {};
|
|
57
|
+
//# sourceMappingURL=form-field.component.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"form-field.component.d.ts","sourceRoot":"","sources":["../../../../../tedi/components/form/form-field/form-field.component.ts"],"names":[],"mappings":"AASA,OAAO,EACL,gBAAgB,EAEjB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EACL,SAAS,EAET,QAAQ,EACR,QAAQ,EACR,WAAW,EACZ,MAAM,8CAA8C,CAAC;AAItD,OAAO,EAAE,qBAAqB,EAAE,MAAM,0CAA0C,CAAC;;AAEjF,MAAM,MAAM,SAAS,GAAG,OAAO,GAAG,OAAO,GAAG,SAAS,CAAC;AACtD,MAAM,MAAM,UAAU,GAAG,OAAO,GAAG,OAAO,GAAG,SAAS,CAAC;AACvD,KAAK,eAAe,GAAG,SAAS,GAAG,OAAO,GAAG,SAAS,CAAC;AAEvD,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,QAAQ,CAAC;IAChB,KAAK,CAAC,EAAE,SAAS,CAAC;IAClB,IAAI,CAAC,EAAE,QAAQ,CAAC;IAChB,OAAO,CAAC,EAAE,WAAW,CAAC;CACvB;AAED,qBAkBa,kBAAkB;IAC7B;;;OAGG;IACH,IAAI,iDAA+B;IACnC;;OAEG;IACH,IAAI,0EAA+C;IACnD;;;OAGG;IACH,SAAS,+CAAyB;IAClC;;OAEG;IACH,UAAU,qDAA8B;IAGxC,OAAO,CAAC,EAAE,gBAAgB,CAAC;IAG3B,QAAQ,CAAC,EAAE,qBAAqB,CAAC;IAEjC,QAAQ,CAAC,YAAY,4DAKlB;IAEH,QAAQ,CAAC,eAAe,kDAQrB;IAEH,eAAe,0CAGZ;IAEH,QAAQ,CAAC,UAAU,0CAAqD;IAExE,QAAQ,CAAC,WAAW;;;;;;;;OAUjB;IAEH,QAAQ,CAAC,YAAY;;OAOlB;IAEH,KAAK;yCAvEM,kBAAkB;2CAAlB,kBAAkB;CA0E9B"}
|
|
@@ -4,4 +4,6 @@ export * from "./feedback-text/feedback-text.component";
|
|
|
4
4
|
export * from "./label/label.component";
|
|
5
5
|
export * from "./number-field/number-field.component";
|
|
6
6
|
export * from "./toggle/toggle.component";
|
|
7
|
+
export * from "./form-field/form-field.component";
|
|
8
|
+
export * from "./text-field/text-field.component";
|
|
7
9
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../tedi/components/form/index.ts"],"names":[],"mappings":"AAAA,cAAc,+BAA+B,CAAC;AAC9C,cAAc,qCAAqC,CAAC;AACpD,cAAc,yCAAyC,CAAC;AACxD,cAAc,yBAAyB,CAAC;AACxC,cAAc,uCAAuC,CAAC;AACtD,cAAc,2BAA2B,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../tedi/components/form/index.ts"],"names":[],"mappings":"AAAA,cAAc,+BAA+B,CAAC;AAC9C,cAAc,qCAAqC,CAAC;AACpD,cAAc,yCAAyC,CAAC;AACxD,cAAc,yBAAyB,CAAC;AACxC,cAAc,uCAAuC,CAAC;AACtD,cAAc,2BAA2B,CAAC;AAC1C,cAAc,mCAAmC,CAAC;AAClD,cAAc,mCAAmC,CAAC"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { ElementRef } from "@angular/core";
|
|
2
|
+
import { ControlValueAccessor, NgControl } from "@angular/forms";
|
|
3
|
+
import { FormFieldControl } from "../form-field/form-field-control";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export declare class TextFieldComponent implements ControlValueAccessor, FormFieldControl {
|
|
6
|
+
private el;
|
|
7
|
+
private ngControl;
|
|
8
|
+
/**
|
|
9
|
+
* Value of the input field. Supports two-way binding, use with form controls.
|
|
10
|
+
*/
|
|
11
|
+
value: import("@angular/core").ModelSignal<string>;
|
|
12
|
+
/**
|
|
13
|
+
* Whether to hide arrows for number inputs.
|
|
14
|
+
* @default true
|
|
15
|
+
*/
|
|
16
|
+
arrowsHidden: import("@angular/core").InputSignal<boolean>;
|
|
17
|
+
/**
|
|
18
|
+
* Callback triggered when the clear button is clicked.
|
|
19
|
+
*/
|
|
20
|
+
readonly clear: import("@angular/core").OutputEmitterRef<void>;
|
|
21
|
+
constructor(el: ElementRef<HTMLInputElement>, ngControl: NgControl | null);
|
|
22
|
+
readonly disabled: import("@angular/core").Signal<boolean>;
|
|
23
|
+
readonly invalid: import("@angular/core").Signal<boolean>;
|
|
24
|
+
private formDisabled;
|
|
25
|
+
private onChange;
|
|
26
|
+
private onTouched;
|
|
27
|
+
private setValue;
|
|
28
|
+
writeValue(value: string | null): void;
|
|
29
|
+
registerOnChange(fn: (value: string) => void): void;
|
|
30
|
+
registerOnTouched(fn: () => void): void;
|
|
31
|
+
setDisabledState(isDisabled: boolean): void;
|
|
32
|
+
handleInputChange(event: Event): void;
|
|
33
|
+
handleBlur(): void;
|
|
34
|
+
clearField(): void;
|
|
35
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TextFieldComponent, [null, { optional: true; self: true; }]>;
|
|
36
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TextFieldComponent, "input[tedi-text-field]", never, { "value": { "alias": "value"; "required": false; "isSignal": true; }; "arrowsHidden": { "alias": "arrowsHidden"; "required": false; "isSignal": true; }; }, { "value": "valueChange"; "clear": "clear"; }, never, never, true, never>;
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=text-field.component.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"text-field.component.d.ts","sourceRoot":"","sources":["../../../../../tedi/components/form/text-field/text-field.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAUL,UAAU,EAGX,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,oBAAoB,EAEpB,SAAS,EACV,MAAM,gBAAgB,CAAC;AACxB,OAAO,EACL,gBAAgB,EAEjB,MAAM,kCAAkC,CAAC;;AAE1C,qBA0Ba,kBACX,YAAW,oBAAoB,EAAE,gBAAgB;IAiB/C,OAAO,CAAC,EAAE;IACU,OAAO,CAAC,SAAS;IAhBvC;;OAEG;IACH,KAAK,8CAAqB;IAC1B;;;OAGG;IACH,YAAY,+CAAwB;IACpC;;OAEG;IACH,QAAQ,CAAC,KAAK,iDAAkB;gBAGtB,EAAE,EAAE,UAAU,CAAC,gBAAgB,CAAC,EACZ,SAAS,EAAE,SAAS,GAAG,IAAI;IAOzD,QAAQ,CAAC,QAAQ,0CAEf;IACF,QAAQ,CAAC,OAAO,0CAGb;IAEH,OAAO,CAAC,YAAY,CAAiB;IACrC,OAAO,CAAC,QAAQ,CAAqC;IACrD,OAAO,CAAC,SAAS,CAAwB;IAEzC,OAAO,CAAC,QAAQ;IAKhB,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,GAAG,IAAI;IAItC,gBAAgB,CAAC,EAAE,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,GAAG,IAAI;IAInD,iBAAiB,CAAC,EAAE,EAAE,MAAM,IAAI,GAAG,IAAI;IAIvC,gBAAgB,CAAC,UAAU,EAAE,OAAO,GAAG,IAAI;IAK3C,iBAAiB,CAAC,KAAK,EAAE,KAAK;IAQ9B,UAAU;IAIV,UAAU;yCAxEC,kBAAkB;2CAAlB,kBAAkB;CAgF9B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../tedi/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAC;AACvB,cAAc,WAAW,CAAC;AAC1B,cAAc,WAAW,CAAC;AAC1B,cAAc,QAAQ,CAAC;AACvB,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC;AACzB,cAAc,cAAc,CAAC;AAC7B,cAAc,WAAW,CAAC;AAC1B,cAAc,iBAAiB,CAAC;AAChC,cAAc,QAAQ,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../tedi/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAC;AACvB,cAAc,WAAW,CAAC;AAC1B,cAAc,WAAW,CAAC;AAC1B,cAAc,QAAQ,CAAC;AACvB,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC;AACzB,cAAc,cAAc,CAAC;AAC7B,cAAc,WAAW,CAAC;AAC1B,cAAc,iBAAiB,CAAC;AAChC,cAAc,QAAQ,CAAC;AACvB,cAAc,SAAS,CAAC"}
|
|
@@ -17,6 +17,9 @@ export declare class SpinnerComponent {
|
|
|
17
17
|
* Provides a text label for screen readers to announce the spinner's purpose or status.
|
|
18
18
|
*/
|
|
19
19
|
label: import("@angular/core").InputSignal<string | undefined>;
|
|
20
|
+
private readonly sizeConfig;
|
|
21
|
+
strokeWidth: import("@angular/core").Signal<number>;
|
|
22
|
+
r: import("@angular/core").Signal<number>;
|
|
20
23
|
classes: import("@angular/core").Signal<string>;
|
|
21
24
|
static ɵfac: i0.ɵɵFactoryDeclaration<SpinnerComponent, never>;
|
|
22
25
|
static ɵcmp: i0.ɵɵComponentDeclaration<SpinnerComponent, "tedi-spinner", never, { "size": { "alias": "size"; "required": false; "isSignal": true; }; "color": { "alias": "color"; "required": false; "isSignal": true; }; "label": { "alias": "label"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"spinner.component.d.ts","sourceRoot":"","sources":["../../../../../tedi/components/loader/spinner/spinner.component.ts"],"names":[],"mappings":";AAQA,MAAM,MAAM,WAAW,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AACvC,MAAM,MAAM,YAAY,GAAG,SAAS,GAAG,WAAW,CAAC;AAEnD,qBAea,gBAAgB;IAC3B;;;OAGG;IACH,IAAI,mDAA0B;IAC9B;;;;OAIG;IACH,KAAK,oDAAkC;IACvC;;OAEG;IACH,KAAK,0DAAmB;IAExB,OAAO,yCAQJ;
|
|
1
|
+
{"version":3,"file":"spinner.component.d.ts","sourceRoot":"","sources":["../../../../../tedi/components/loader/spinner/spinner.component.ts"],"names":[],"mappings":";AAQA,MAAM,MAAM,WAAW,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;AACvC,MAAM,MAAM,YAAY,GAAG,SAAS,GAAG,WAAW,CAAC;AAEnD,qBAea,gBAAgB;IAC3B;;;OAGG;IACH,IAAI,mDAA0B;IAC9B;;;;OAIG;IACH,KAAK,oDAAkC;IACvC;;OAEG;IACH,KAAK,0DAAmB;IAExB,OAAO,CAAC,QAAQ,CAAC,UAAU,CAIzB;IAEF,WAAW,yCAA4D;IACvE,CAAC,yCAAkD;IAEnD,OAAO,yCAQJ;yCAlCQ,gBAAgB;2CAAhB,gBAAgB;CAmC5B"}
|
|
@@ -9,6 +9,11 @@ export declare class PopoverComponent implements AfterContentChecked {
|
|
|
9
9
|
* @default top
|
|
10
10
|
*/
|
|
11
11
|
position: import("@angular/core").InputSignal<"left" | "right" | "top" | "bottom" | "auto" | "auto-start" | "auto-end" | "top-start" | "bottom-start" | "left-start" | "right-start" | "top-end" | "bottom-end" | "left-end" | "right-end">;
|
|
12
|
+
/**
|
|
13
|
+
* Should position flip to opposite direction when overflowing screen?
|
|
14
|
+
* @default false
|
|
15
|
+
*/
|
|
16
|
+
preventOverflow: import("@angular/core").InputSignal<boolean>;
|
|
12
17
|
/**
|
|
13
18
|
* Is dismissible by clicking outside of content?
|
|
14
19
|
* @default true
|
|
@@ -33,6 +38,12 @@ export declare class PopoverComponent implements AfterContentChecked {
|
|
|
33
38
|
* @default false
|
|
34
39
|
*/
|
|
35
40
|
lockScroll: import("@angular/core").InputSignal<boolean>;
|
|
41
|
+
/**
|
|
42
|
+
* Append floating element to given selector.
|
|
43
|
+
* Use 'body' to append at the end of DOM or empty string to append next to trigger element.
|
|
44
|
+
* @default "body"
|
|
45
|
+
*/
|
|
46
|
+
readonly appendTo: import("@angular/core").InputSignal<string>;
|
|
36
47
|
/** Delay time (in ms) for closing popover when not hovering trigger or content.
|
|
37
48
|
* @default 100
|
|
38
49
|
*/
|
|
@@ -64,6 +75,6 @@ export declare class PopoverComponent implements AfterContentChecked {
|
|
|
64
75
|
private focusElementBeforeTrigger;
|
|
65
76
|
private handleClosePopoverEvent;
|
|
66
77
|
static ɵfac: i0.ɵɵFactoryDeclaration<PopoverComponent, never>;
|
|
67
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<PopoverComponent, "tedi-popover", never, { "position": { "alias": "position"; "required": false; "isSignal": true; }; "dismissible": { "alias": "dismissible"; "required": false; "isSignal": true; }; "hideOnScroll": { "alias": "hideOnScroll"; "required": false; "isSignal": true; }; "withBorder": { "alias": "withBorder"; "required": false; "isSignal": true; }; "withArrow": { "alias": "withArrow"; "required": false; "isSignal": true; }; "lockScroll": { "alias": "lockScroll"; "required": false; "isSignal": true; }; "timeoutDelay": { "alias": "timeoutDelay"; "required": false; "isSignal": true; }; }, {}, ["popoverTrigger", "popoverContent"], ["[tedi-popover-trigger]", "tedi-popover-content"], true, never>;
|
|
78
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<PopoverComponent, "tedi-popover", never, { "position": { "alias": "position"; "required": false; "isSignal": true; }; "preventOverflow": { "alias": "preventOverflow"; "required": false; "isSignal": true; }; "dismissible": { "alias": "dismissible"; "required": false; "isSignal": true; }; "hideOnScroll": { "alias": "hideOnScroll"; "required": false; "isSignal": true; }; "withBorder": { "alias": "withBorder"; "required": false; "isSignal": true; }; "withArrow": { "alias": "withArrow"; "required": false; "isSignal": true; }; "lockScroll": { "alias": "lockScroll"; "required": false; "isSignal": true; }; "appendTo": { "alias": "appendTo"; "required": false; "isSignal": true; }; "timeoutDelay": { "alias": "timeoutDelay"; "required": false; "isSignal": true; }; }, {}, ["popoverTrigger", "popoverContent"], ["[tedi-popover-trigger]", "tedi-popover-content"], true, never>;
|
|
68
79
|
}
|
|
69
80
|
//# sourceMappingURL=popover.component.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"popover.component.d.ts","sourceRoot":"","sources":["../../../../../tedi/components/overlay/popover/popover.component.ts"],"names":[],"mappings":"AACA,OAAO,EAWL,mBAAmB,EACpB,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,0BAA0B,EAE1B,oBAAoB,EACrB,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,uBAAuB,EAAE,MAAM,6CAA6C,CAAC;;AAItF,MAAM,MAAM,eAAe,GAAG,GAAG,oBAAoB,EAAE,CAAC;AAExD,qBASa,gBAAiB,YAAW,mBAAmB;IAC1D;;;OAGG;IACH,QAAQ,oOAAiC;IACzC;;;OAGG;IACH,WAAW,+CAAe;IAC1B;;;OAGG;IACH,YAAY,+CAAgB;IAC5B;;;OAGG;IACH,UAAU,+CAAgB;IAC1B;;OAEG;IACH,SAAS,+CAAe;IACxB;;;OAGG;IACH,UAAU,+CAAgB;IAC1B;;OAEG;IACH,QAAQ,CAAC,YAAY,8CAAc;IAEnC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAoB;IAC7C,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAqB;IAE9C,QAAQ,CAAC,gBAAgB,6DAAkD;IAC3E,QAAQ,CAAC,cAAc,0DAAkD;IACzE,OAAO,CAAC,QAAQ,CAAC,cAAc,CAE7B;IAEF,QAAQ,CAAC,WAAW,iDAAc;IAClC,QAAQ,CAAC,gBAAgB,kDAAiB;IAE1C,WAAW,CAAC,EAAE,UAAU,CAAC,OAAO,UAAU,CAAC,CAAC;IAC5C,OAAO,CAAC,eAAe,CAAC,CAAa;IACrC,OAAO,CAAC,cAAc,CAAC,CAAa;IACpC,OAAO,CAAC,eAAe,CAAC,CAAa;IACrC,OAAO,CAAC,iBAAiB,CAAC,CAAa;IAEvC,qBAAqB;IAiBrB,WAAW;IA8BX,WAAW,CAAC,YAAY,CAAC,EAAE,OAAO;IAiBlC,aAAa;IAQb,QAAQ,CAAC,qBAAqB,yCAY3B;IAEH,OAAO,CAAC,uBAAuB;IAqC/B,OAAO,CAAC,yBAAyB;IAOjC,OAAO,CAAC,mBAAmB;IAe3B,OAAO,CAAC,qBAAqB;IAO7B,OAAO,CAAC,qBAAqB;IAgB7B,OAAO,CAAC,uBAAuB;IAY/B,OAAO,CAAC,wBAAwB;IAahC,OAAO,CAAC,yBAAyB;IAajC,OAAO,CAAC,uBAAuB;
|
|
1
|
+
{"version":3,"file":"popover.component.d.ts","sourceRoot":"","sources":["../../../../../tedi/components/overlay/popover/popover.component.ts"],"names":[],"mappings":"AACA,OAAO,EAWL,mBAAmB,EACpB,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,0BAA0B,EAE1B,oBAAoB,EACrB,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,uBAAuB,EAAE,MAAM,6CAA6C,CAAC;;AAItF,MAAM,MAAM,eAAe,GAAG,GAAG,oBAAoB,EAAE,CAAC;AAExD,qBASa,gBAAiB,YAAW,mBAAmB;IAC1D;;;OAGG;IACH,QAAQ,oOAAiC;IACzC;;;OAGG;IACH,eAAe,+CAAgB;IAC/B;;;OAGG;IACH,WAAW,+CAAe;IAC1B;;;OAGG;IACH,YAAY,+CAAgB;IAC5B;;;OAGG;IACH,UAAU,+CAAgB;IAC1B;;OAEG;IACH,SAAS,+CAAe;IACxB;;;OAGG;IACH,UAAU,+CAAgB;IAC1B;;;;OAIG;IACH,QAAQ,CAAC,QAAQ,8CAAiB;IAClC;;OAEG;IACH,QAAQ,CAAC,YAAY,8CAAc;IAEnC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAoB;IAC7C,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAqB;IAE9C,QAAQ,CAAC,gBAAgB,6DAAkD;IAC3E,QAAQ,CAAC,cAAc,0DAAkD;IACzE,OAAO,CAAC,QAAQ,CAAC,cAAc,CAE7B;IAEF,QAAQ,CAAC,WAAW,iDAAc;IAClC,QAAQ,CAAC,gBAAgB,kDAAiB;IAE1C,WAAW,CAAC,EAAE,UAAU,CAAC,OAAO,UAAU,CAAC,CAAC;IAC5C,OAAO,CAAC,eAAe,CAAC,CAAa;IACrC,OAAO,CAAC,cAAc,CAAC,CAAa;IACpC,OAAO,CAAC,eAAe,CAAC,CAAa;IACrC,OAAO,CAAC,iBAAiB,CAAC,CAAa;IAEvC,qBAAqB;IAiBrB,WAAW;IA8BX,WAAW,CAAC,YAAY,CAAC,EAAE,OAAO;IAiBlC,aAAa;IAQb,QAAQ,CAAC,qBAAqB,yCAY3B;IAEH,OAAO,CAAC,uBAAuB;IAqC/B,OAAO,CAAC,yBAAyB;IAOjC,OAAO,CAAC,mBAAmB;IAe3B,OAAO,CAAC,qBAAqB;IAO7B,OAAO,CAAC,qBAAqB;IAgB7B,OAAO,CAAC,uBAAuB;IAY/B,OAAO,CAAC,wBAAwB;IAahC,OAAO,CAAC,yBAAyB;IAajC,OAAO,CAAC,uBAAuB;yCA9QpB,gBAAgB;2CAAhB,gBAAgB;CA0R5B"}
|
|
@@ -6,7 +6,10 @@ export declare class TooltipTriggerComponent implements AfterContentChecked {
|
|
|
6
6
|
private renderer;
|
|
7
7
|
readonly tooltip: TooltipComponent;
|
|
8
8
|
private interactiveElement;
|
|
9
|
+
private isTouch;
|
|
9
10
|
constructor();
|
|
11
|
+
onTouchStart(): void;
|
|
12
|
+
onTouchEnd(): void;
|
|
10
13
|
onClick(): void;
|
|
11
14
|
onMouseEnter(): void;
|
|
12
15
|
onMouseLeave(): void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tooltip-trigger.component.d.ts","sourceRoot":"","sources":["../../../../../../tedi/components/overlay/tooltip/tooltip-trigger/tooltip-trigger.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,mBAAmB,EAInB,UAAU,EAMX,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;;AAExD,qBAQa,uBAAwB,YAAW,mBAAmB;IACjE,QAAQ,CAAC,IAAI,0BAA+C;IAC5D,OAAO,CAAC,QAAQ,CAAqB;IACrC,QAAQ,CAAC,OAAO,mBAA4B;IAC5C,OAAO,CAAC,kBAAkB,CAAoC;;
|
|
1
|
+
{"version":3,"file":"tooltip-trigger.component.d.ts","sourceRoot":"","sources":["../../../../../../tedi/components/overlay/tooltip/tooltip-trigger/tooltip-trigger.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,mBAAmB,EAInB,UAAU,EAMX,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;;AAExD,qBAQa,uBAAwB,YAAW,mBAAmB;IACjE,QAAQ,CAAC,IAAI,0BAA+C;IAC5D,OAAO,CAAC,QAAQ,CAAqB;IACrC,QAAQ,CAAC,OAAO,mBAA4B;IAC5C,OAAO,CAAC,kBAAkB,CAAoC;IAE9D,OAAO,CAAC,OAAO,CAAS;;IAYxB,YAAY;IAKZ,UAAU;IAMV,OAAO;IAYP,YAAY;IAYZ,YAAY;IAgBZ,SAAS;IAYT,UAAU;IAaV,QAAQ;IAIR,qBAAqB,IAAI,IAAI;yCAlGlB,uBAAuB;2CAAvB,uBAAuB;CAgInC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../tedi/components/tags/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../tedi/components/tags/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAC;AACpC,cAAc,uCAAuC,CAAC"}
|