@odx/angular 10.0.1 → 10.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +24 -0
- package/cdk/option-control/lib/option-control.d.ts +1 -1
- package/components/chip/lib/components/chip/chip.component.d.ts +1 -1
- package/components/icon/lib/helpers/unpack-icon-identifier.d.ts +15 -1
- package/components/icon/lib/icon.component.d.ts +4 -3
- package/components/icon/lib/icon.config.d.ts +3 -2
- package/components/icon/lib/models/icon-set.d.ts +7 -0
- package/components/icon/lib/models/index.d.ts +1 -0
- package/components/list/lib/components/expandable-list-item/expandable-list-item.component.d.ts +3 -1
- package/components/timepicker/lib/components/timepicker-option.component.d.ts +4 -0
- package/components/wizard/lib/wizard.component.d.ts +20 -0
- package/esm2022/cdk/option-control/lib/option-control.mjs +6 -11
- package/esm2022/components/autocomplete/lib/autocomplete.component.mjs +1 -1
- package/esm2022/components/autocomplete/lib/components/option/autocomplete-option.component.mjs +6 -2
- package/esm2022/components/chip/lib/components/chip/chip.component.mjs +4 -5
- package/esm2022/components/icon/lib/helpers/unpack-icon-identifier.mjs +20 -3
- package/esm2022/components/icon/lib/icon.component.mjs +6 -5
- package/esm2022/components/icon/lib/icon.config.mjs +3 -2
- package/esm2022/components/icon/lib/models/icon-set.mjs +7 -0
- package/esm2022/components/icon/lib/models/index.mjs +2 -1
- package/esm2022/components/list/lib/components/expandable-list-item/expandable-list-item.component.mjs +15 -7
- package/esm2022/components/loading-spinner/lib/loading-spinner.directive.mjs +2 -2
- package/esm2022/components/select/lib/components/select-option/select-option.component.mjs +6 -2
- package/esm2022/components/timepicker/lib/components/timepicker-option.component.mjs +7 -1
- package/esm2022/components/timepicker/lib/timepicker.component.mjs +3 -3
- package/esm2022/components/wizard/lib/wizard.component.mjs +33 -1
- package/fesm2022/odx-angular-cdk-option-control.mjs +5 -10
- package/fesm2022/odx-angular-cdk-option-control.mjs.map +1 -1
- package/fesm2022/odx-angular-components-autocomplete.mjs +4 -1
- package/fesm2022/odx-angular-components-autocomplete.mjs.map +1 -1
- package/fesm2022/odx-angular-components-chip.mjs +2 -3
- package/fesm2022/odx-angular-components-chip.mjs.map +1 -1
- package/fesm2022/odx-angular-components-icon.mjs +39 -15
- package/fesm2022/odx-angular-components-icon.mjs.map +1 -1
- package/fesm2022/odx-angular-components-list.mjs +13 -5
- package/fesm2022/odx-angular-components-list.mjs.map +1 -1
- package/fesm2022/odx-angular-components-loading-spinner.mjs +1 -1
- package/fesm2022/odx-angular-components-loading-spinner.mjs.map +1 -1
- package/fesm2022/odx-angular-components-select.mjs +5 -2
- package/fesm2022/odx-angular-components-select.mjs.map +1 -1
- package/fesm2022/odx-angular-components-timepicker.mjs +8 -2
- package/fesm2022/odx-angular-components-timepicker.mjs.map +1 -1
- package/fesm2022/odx-angular-components-wizard.mjs +32 -0
- package/fesm2022/odx-angular-components-wizard.mjs.map +1 -1
- package/package.json +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,29 @@
|
|
|
1
1
|
# @odx/angular
|
|
2
2
|
|
|
3
|
+
## 10.2.0
|
|
4
|
+
|
|
5
|
+
### Minor Changes
|
|
6
|
+
|
|
7
|
+
- c6c4202: Maintenance minor updates for angular and dev packages
|
|
8
|
+
|
|
9
|
+
### Patch Changes
|
|
10
|
+
|
|
11
|
+
- 9c57826: Fixed. Initial min-height for host spinner element was wrong
|
|
12
|
+
- 936522c: Type for icon set name
|
|
13
|
+
- 7321a90: Fixed "expression changed after it has been checked" error in select and autocomplete components
|
|
14
|
+
- 6012d89: Updated dropdown options in timepicker component
|
|
15
|
+
|
|
16
|
+
## 10.1.0
|
|
17
|
+
|
|
18
|
+
### Minor Changes
|
|
19
|
+
|
|
20
|
+
- cae7f1c: Add "interactive" boolean attribute to expandable list item to change the expanded state control behavior
|
|
21
|
+
- 7f25fe3: Exposing programmable API for wizard component
|
|
22
|
+
|
|
23
|
+
### Patch Changes
|
|
24
|
+
|
|
25
|
+
- 6411da5: New slot for Icon Prefix in Chip Component
|
|
26
|
+
|
|
3
27
|
## 10.0.1
|
|
4
28
|
|
|
5
29
|
### Patch Changes
|
|
@@ -37,6 +37,6 @@ export declare class ChipComponent {
|
|
|
37
37
|
protected onClick(): void;
|
|
38
38
|
protected get buttonVariant(): ButtonVariant | null;
|
|
39
39
|
static ɵfac: i0.ɵɵFactoryDeclaration<ChipComponent, never>;
|
|
40
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<ChipComponent, "odx-chip", never, { "removable": { "alias": "removable"; "required": false; }; "size": { "alias": "size"; "required": false; }; "variant": { "alias": "variant"; "required": false; }; }, { "remove": "remove"; }, never, ["*"], true, never>;
|
|
40
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<ChipComponent, "odx-chip", never, { "removable": { "alias": "removable"; "required": false; }; "size": { "alias": "size"; "required": false; }; "variant": { "alias": "variant"; "required": false; }; }, { "remove": "remove"; }, never, ["odx-icon", "*"], true, never>;
|
|
41
41
|
static ngAcceptInputType_removable: unknown;
|
|
42
42
|
}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { IconSet } from '../models';
|
|
1
2
|
/**
|
|
2
3
|
* Unpacks a combined icon identifier string into separate icon set and icon name components.
|
|
3
4
|
* The identifier is expected to follow the format "iconSet::iconName". If the "iconName" part is
|
|
@@ -12,4 +13,17 @@
|
|
|
12
13
|
* unpackIconIdentifier("menu") // returns ['core', 'menu']
|
|
13
14
|
* ```
|
|
14
15
|
*/
|
|
15
|
-
export declare function unpackIconIdentifier(value: string): [iconSet:
|
|
16
|
+
export declare function unpackIconIdentifier(value: string): [iconSet: IconSet, iconName: string];
|
|
17
|
+
/**
|
|
18
|
+
* Determines if a given string is a valid icon set.
|
|
19
|
+
*
|
|
20
|
+
* @param {string} value The value to check if it is a valid icon set.
|
|
21
|
+
* @returns {boolean} Whether the value is a valid icon set.
|
|
22
|
+
*
|
|
23
|
+
* @example
|
|
24
|
+
* ```ts
|
|
25
|
+
* isIconSet('core') // returns true
|
|
26
|
+
* isIconSet('custom') // returns false
|
|
27
|
+
* ```
|
|
28
|
+
*/
|
|
29
|
+
export declare function isIconSet(value: string): value is IconSet;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { IconSize } from './models';
|
|
1
|
+
import { IconSet, IconSize } from './models';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
/**
|
|
4
4
|
* Represents an icon component that can dynamically display various icons based on input properties. This component
|
|
@@ -33,9 +33,9 @@ export declare class IconComponent {
|
|
|
33
33
|
/**
|
|
34
34
|
* Specifies the icon set that the icon belongs to. The default set can be injected from the icon configuration.
|
|
35
35
|
*
|
|
36
|
-
* @type {
|
|
36
|
+
* @type {IconSet | null}
|
|
37
37
|
*/
|
|
38
|
-
iconSet:
|
|
38
|
+
iconSet: IconSet | null;
|
|
39
39
|
/**
|
|
40
40
|
* Allows for setting both the icon set and icon name via a single identifier, typically formatted as 'set::name'.
|
|
41
41
|
* Unpacking this identifier sets both `name` and `iconSet` properties.
|
|
@@ -46,4 +46,5 @@ export declare class IconComponent {
|
|
|
46
46
|
static ɵfac: i0.ɵɵFactoryDeclaration<IconComponent, never>;
|
|
47
47
|
static ɵcmp: i0.ɵɵComponentDeclaration<IconComponent, "odx-icon", never, { "inline": { "alias": "inline"; "required": false; }; "size": { "alias": "size"; "required": false; }; "name": { "alias": "name"; "required": false; }; "iconSet": { "alias": "iconSet"; "required": false; }; "identifier": { "alias": "identifier"; "required": false; }; }, {}, never, never, true, never>;
|
|
48
48
|
static ngAcceptInputType_inline: unknown;
|
|
49
|
+
static ngAcceptInputType_iconSet: string;
|
|
49
50
|
}
|
|
@@ -1,12 +1,13 @@
|
|
|
1
|
+
import { IconSet } from './models';
|
|
1
2
|
/**
|
|
2
3
|
* Represents the configuration options for icons in the application, specifying defaults
|
|
3
4
|
* and configurations for the icon components used across the system.
|
|
4
5
|
*
|
|
5
6
|
* @typedef {Object} IconConfig
|
|
6
|
-
* @property {
|
|
7
|
+
* @property {IconSet} defaultIconSet - The default set of icons to use if no specific set is provided.
|
|
7
8
|
*/
|
|
8
9
|
export interface IconConfig {
|
|
9
|
-
defaultIconSet:
|
|
10
|
+
defaultIconSet: IconSet;
|
|
10
11
|
}
|
|
11
12
|
/**
|
|
12
13
|
* Utility functions generated to handle the injection and provision of the `IconConfig`.
|
package/components/list/lib/components/expandable-list-item/expandable-list-item.component.d.ts
CHANGED
|
@@ -11,6 +11,8 @@ import * as i1 from "@odx/angular/cdk/expandable";
|
|
|
11
11
|
export declare class ExpandableListItemComponent {
|
|
12
12
|
protected readonly expandableItem: ExpandableItemDirective;
|
|
13
13
|
readonly element: import("@angular/core").ElementRef<HTMLElement>;
|
|
14
|
+
interactive: boolean;
|
|
14
15
|
static ɵfac: i0.ɵɵFactoryDeclaration<ExpandableListItemComponent, never>;
|
|
15
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<ExpandableListItemComponent, "odx-expandable-list-item", never, {}, {}, never, ["odx-list-item, [odxListItem]", "odx-list"], true, [{ directive: typeof i1.ExpandableItemDirective; inputs: { "expanded": "expanded"; "id": "id"; }; outputs: {}; }]>;
|
|
16
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<ExpandableListItemComponent, "odx-expandable-list-item", never, { "interactive": { "alias": "interactive"; "required": false; }; }, {}, never, ["odx-list-item, [odxListItem]", "odx-list"], true, [{ directive: typeof i1.ExpandableItemDirective; inputs: { "expanded": "expanded"; "id": "id"; }; outputs: {}; }]>;
|
|
17
|
+
static ngAcceptInputType_interactive: unknown;
|
|
16
18
|
}
|
|
@@ -30,6 +30,10 @@ export declare class TimepickerOptionComponent extends OptionControl<string> imp
|
|
|
30
30
|
selected: EventEmitter<TimepickerOptionComponent>;
|
|
31
31
|
constructor();
|
|
32
32
|
ngOnInit(): void;
|
|
33
|
+
/**
|
|
34
|
+
* Sets the active styles for the option, indicating that it is currently
|
|
35
|
+
*/
|
|
36
|
+
setActiveStyles(): void;
|
|
33
37
|
protected selectOption(): void;
|
|
34
38
|
static ɵfac: i0.ɵɵFactoryDeclaration<TimepickerOptionComponent, never>;
|
|
35
39
|
static ɵcmp: i0.ɵɵComponentDeclaration<TimepickerOptionComponent, "odx-timepicker-option", never, {}, { "selected": "selected"; }, never, ["*"], true, [{ directive: typeof i1.WithDisabledState; inputs: {}; outputs: {}; }]>;
|
|
@@ -48,6 +48,26 @@ export declare class WizardComponent implements AfterViewInit {
|
|
|
48
48
|
* Sets the active step to the specified index.
|
|
49
49
|
*/
|
|
50
50
|
setActiveStepValid(): void;
|
|
51
|
+
/**
|
|
52
|
+
* Sets the validity of a step at the specified index.
|
|
53
|
+
*
|
|
54
|
+
* @param {number} stepIndex - Index of the step to set validity.
|
|
55
|
+
* @param {boolean} valid - Whether the step should be valid or not.
|
|
56
|
+
*/
|
|
57
|
+
setStepValid(stepIndex: number, valid: boolean): void;
|
|
58
|
+
/**
|
|
59
|
+
* Returns whether the step at the specified index is valid.
|
|
60
|
+
*
|
|
61
|
+
* @param {number} stepIndex - Index of the step to check validity.
|
|
62
|
+
* @returns {boolean} - Whether the step is valid or not.
|
|
63
|
+
*/
|
|
64
|
+
isStepValid(stepIndex: number): boolean;
|
|
65
|
+
/**
|
|
66
|
+
* Returns whether the current active step is valid.
|
|
67
|
+
*
|
|
68
|
+
* @returns {boolean} - Whether the current step is valid or not.
|
|
69
|
+
*/
|
|
70
|
+
isCurrentStepValid(): boolean;
|
|
51
71
|
private calculateVisibleStepsSegments;
|
|
52
72
|
private getStyleFromCSS;
|
|
53
73
|
private setActiveStep;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ChangeDetectorRef, Directive, HostListener, inject, Input } from '@angular/core';
|
|
2
|
-
import { injectElement, untilDestroyed } from '@odx/angular/utils';
|
|
2
|
+
import { deferFn, injectElement, untilDestroyed } from '@odx/angular/utils';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
/**
|
|
5
5
|
* `OptionControl` is an abstract directive that serves as a base class for implementing selectable options in a dropdown
|
|
@@ -43,21 +43,16 @@ export class OptionControl {
|
|
|
43
43
|
this.value = null;
|
|
44
44
|
this.element = injectElement();
|
|
45
45
|
}
|
|
46
|
-
/**
|
|
47
|
-
* Sets the active styles for the option control.
|
|
48
|
-
*
|
|
49
|
-
* @returns {void}
|
|
50
|
-
*/
|
|
51
|
-
setActiveStyles() {
|
|
52
|
-
this.isActive = true;
|
|
53
|
-
}
|
|
54
46
|
/**
|
|
55
47
|
* Sets the inactive styles for the option control.
|
|
56
48
|
*
|
|
57
49
|
* @returns {void}
|
|
58
50
|
*/
|
|
59
51
|
setInactiveStyles() {
|
|
60
|
-
|
|
52
|
+
deferFn(() => {
|
|
53
|
+
this.isActive = false;
|
|
54
|
+
this.cdr.markForCheck();
|
|
55
|
+
});
|
|
61
56
|
}
|
|
62
57
|
/**
|
|
63
58
|
* Retrieves the label of the option control.
|
|
@@ -93,4 +88,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
93
88
|
type: HostListener,
|
|
94
89
|
args: ['click', ['$event']]
|
|
95
90
|
}] } });
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9uLWNvbnRyb2wuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY2RrL29wdGlvbi1jb250cm9sL3NyYy9saWIvb3B0aW9uLWNvbnRyb2wudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLGlCQUFpQixFQUFFLFNBQVMsRUFBYyxZQUFZLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN0RyxPQUFPLEVBQUUsT0FBTyxFQUFFLGFBQWEsRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQzs7QUFFNUU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0E0Qkc7QUFXSCxNQUFNLE9BQWdCLGFBQWE7SUFWbkM7UUFXcUIsdUJBQWtCLEdBQUcsY0FBYyxFQUFFLENBQUM7UUFDdEMsUUFBRyxHQUFHLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO1FBRXpDLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFFM0I7Ozs7V0FJRztRQUVJLFVBQUssR0FBYSxJQUFJLENBQUM7UUFFZCxZQUFPLEdBQTRCLGFBQWEsRUFBRSxDQUFDO0tBdUNwRTtJQTlCQzs7OztPQUlHO0lBQ0ksaUJBQWlCO1FBQ3RCLE9BQU8sQ0FBQyxHQUFHLEVBQUU7WUFDWCxJQUFJLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQztZQUN0QixJQUFJLENBQUMsR0FBRyxDQUFDLFlBQVksRUFBRSxDQUFDO1FBQzFCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVEOzs7O09BSUc7SUFDSSxRQUFRO1FBQ2IsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxXQUFXLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxDQUFDO0lBQzlELENBQUM7SUFLUyxNQUFNLENBQUMsS0FBWTtRQUMzQixLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDeEIsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBRXZCLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUN0QixDQUFDOytHQXBEbUIsYUFBYTttR0FBYixhQUFhOzs0RkFBYixhQUFhO2tCQVZsQyxTQUFTO21CQUFDO29CQUNULFVBQVUsRUFBRSxJQUFJO29CQUNoQixJQUFJLEVBQUU7d0JBQ0osSUFBSSxFQUFFLFFBQVE7d0JBQ2Qsb0JBQW9CLEVBQUUsTUFBTTt3QkFDNUIsbUJBQW1CLEVBQUUsVUFBVTt3QkFDL0Isc0JBQXNCLEVBQUUsWUFBWTt3QkFDcEMscUJBQXFCLEVBQUUsWUFBWTtxQkFDcEM7aUJBQ0Y7OEJBYVEsS0FBSztzQkFEWCxLQUFLO2dCQW9DSSxNQUFNO3NCQURmLFlBQVk7dUJBQUMsT0FBTyxFQUFFLENBQUMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSGlnaGxpZ2h0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9hMTF5JztcbmltcG9ydCB7IENoYW5nZURldGVjdG9yUmVmLCBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIEhvc3RMaXN0ZW5lciwgaW5qZWN0LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgZGVmZXJGbiwgaW5qZWN0RWxlbWVudCwgdW50aWxEZXN0cm95ZWQgfSBmcm9tICdAb2R4L2FuZ3VsYXIvdXRpbHMnO1xuXG4vKipcbiAqIGBPcHRpb25Db250cm9sYCBpcyBhbiBhYnN0cmFjdCBkaXJlY3RpdmUgdGhhdCBzZXJ2ZXMgYXMgYSBiYXNlIGNsYXNzIGZvciBpbXBsZW1lbnRpbmcgc2VsZWN0YWJsZSBvcHRpb25zIGluIGEgZHJvcGRvd25cbiAqIGxpc3Qgb3IgYSBzaW1pbGFyIGNvbXBvbmVudC4gSXQgaW50ZWdyYXRlcyB3aXRoIENESydzIGBIaWdobGlnaHRhYmxlYCBpbnRlcmZhY2UgdG8gcHJvdmlkZSBrZXlib2FyZCBuYXZpZ2F0aW9uIHN1cHBvcnQuXG4gKlxuICogQHBhcmFtIHtUfSAtIFRoZSB0eXBlIG9mIHRoZSB2YWx1ZS5cbiAqXG4gKiBUaGlzIGJhc2UgY2xhc3MgaGFuZGxlcyB0aGUgdmlzdWFsIGZlZWRiYWNrIGZvciBhY3RpdmUgYW5kIHNlbGVjdGVkIHN0YXRlcyBhbmQgcHJvdmlkZXMgYSBzdHJ1Y3R1cmUgZm9yIGRlZmluaW5nXG4gKiBob3cgYW4gb3B0aW9uIGlzIHNlbGVjdGVkLlxuICpcbiAqIEV4dGVuZCBgT3B0aW9uQ29udHJvbGAgdG8gY3JlYXRlIGEgY29uY3JldGUgb3B0aW9uIGNvbXBvbmVudDpcbiAqIEBleGFtcGxlXG4gKiBgYGB0c1xuICogQENvbXBvbmVudCh7XG4gKiAgIHNlbGVjdG9yOiAnbXktb3B0aW9uJyxcbiAqICAgdGVtcGxhdGVVcmw6ICcuL215LW9wdGlvbi5jb21wb25lbnQuaHRtbCcsXG4gKiAgIHByb3ZpZGVyczogW3sgcHJvdmlkZTogT3B0aW9uQ29udHJvbCwgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gTXlPcHRpb25Db21wb25lbnQpIH1dLFxuICogfSlcbiAqIGNsYXNzIE15T3B0aW9uQ29tcG9uZW50IGV4dGVuZHMgT3B0aW9uQ29udHJvbDxNeURhdGFUeXBlPiB7XG4gKiAgIEBJbnB1dCgpIG92ZXJyaWRlIHZhbHVlOiBNeURhdGFUeXBlIHwgbnVsbCA9IG51bGw7XG4gKlxuICogICBwcm90ZWN0ZWQgb3ZlcnJpZGUgc2VsZWN0T3B0aW9uKCk6IHZvaWQge1xuICogICAgIC8vIEN1c3RvbSBsb2dpYyBmb3Igd2hlbiB0aGlzIG9wdGlvbiBpcyBzZWxlY3RlZFxuICogICB9XG4gKiB9XG4gKiBgYGBcbiAqXG4gKiBJbXBsZW1lbnQgYHNlbGVjdE9wdGlvbmAgaW4gc3ViY2xhc3NlcyB0byBkZWZpbmUgd2hhdCBoYXBwZW5zIHdoZW4gYW4gb3B0aW9uIGlzIHNlbGVjdGVkLCBzdWNoIGFzIHVwZGF0aW5nIGEgbW9kZWxcbiAqIG9yIGNsb3NpbmcgYSBkcm9wZG93bi5cbiAqL1xuQERpcmVjdGl2ZSh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGhvc3Q6IHtcbiAgICByb2xlOiAnb3B0aW9uJyxcbiAgICAnW2NsYXNzLm9keC1vcHRpb25dJzogJ3RydWUnLFxuICAgICdbY2xhc3MuaXMtYWN0aXZlXSc6ICdpc0FjdGl2ZScsXG4gICAgJ1thdHRyLmFyaWEtc2VsZWN0ZWRdJzogJ2lzU2VsZWN0ZWQnLFxuICAgICdbY2xhc3MuaXMtc2VsZWN0ZWRdJzogJ2lzU2VsZWN0ZWQnLFxuICB9LFxufSlcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBPcHRpb25Db250cm9sPFQ+IGltcGxlbWVudHMgSGlnaGxpZ2h0YWJsZSB7XG4gIHByb3RlY3RlZCByZWFkb25seSB0YWtlVW50aWxEZXN0cm95ZWQgPSB1bnRpbERlc3Ryb3llZCgpO1xuICBwcm90ZWN0ZWQgcmVhZG9ubHkgY2RyID0gaW5qZWN0KENoYW5nZURldGVjdG9yUmVmKTtcblxuICBwcm90ZWN0ZWQgaXNBY3RpdmUgPSBmYWxzZTtcblxuICAvKipcbiAgICogUmVwcmVzZW50cyB0aGUgdmFsdWUgb2YgdGhlIG9wdGlvbiBjb250cm9sLlxuICAgKlxuICAgKiBAdHlwZSB7VH0gLSBUaGUgdHlwZSBvZiB0aGUgdmFsdWUuXG4gICAqL1xuICBASW5wdXQoKVxuICBwdWJsaWMgdmFsdWU6IFQgfCBudWxsID0gbnVsbDtcblxuICBwdWJsaWMgcmVhZG9ubHkgZWxlbWVudDogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4gPSBpbmplY3RFbGVtZW50KCk7XG5cbiAgLyoqXG4gICAqIFNldHMgdGhlIGFjdGl2ZSBzdHlsZXMgZm9yIHRoZSBvcHRpb24gY29udHJvbC5cbiAgICpcbiAgICogQHJldHVybnMge3ZvaWR9XG4gICAqL1xuICBwdWJsaWMgYWJzdHJhY3Qgc2V0QWN0aXZlU3R5bGVzKCk6IHZvaWQ7XG5cbiAgLyoqXG4gICAqIFNldHMgdGhlIGluYWN0aXZlIHN0eWxlcyBmb3IgdGhlIG9wdGlvbiBjb250cm9sLlxuICAgKlxuICAgKiBAcmV0dXJucyB7dm9pZH1cbiAgICovXG4gIHB1YmxpYyBzZXRJbmFjdGl2ZVN0eWxlcygpOiB2b2lkIHtcbiAgICBkZWZlckZuKCgpID0+IHtcbiAgICAgIHRoaXMuaXNBY3RpdmUgPSBmYWxzZTtcbiAgICAgIHRoaXMuY2RyLm1hcmtGb3JDaGVjaygpO1xuICAgIH0pO1xuICB9XG5cbiAgLyoqXG4gICAqIFJldHJpZXZlcyB0aGUgbGFiZWwgb2YgdGhlIG9wdGlvbiBjb250cm9sLlxuICAgKlxuICAgKiBAcmV0dXJucyB7c3RyaW5nfSAtIFRoZSBsYWJlbCBvZiB0aGUgb3B0aW9uIGNvbnRyb2wuXG4gICAqL1xuICBwdWJsaWMgZ2V0TGFiZWwoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQudGV4dENvbnRlbnQ/LnRyaW0oKSA/PyAnJztcbiAgfVxuXG4gIHByb3RlY3RlZCBhYnN0cmFjdCBzZWxlY3RPcHRpb24oKTogdm9pZDtcblxuICBASG9zdExpc3RlbmVyKCdjbGljaycsIFsnJGV2ZW50J10pXG4gIHByb3RlY3RlZCBzZWxlY3QoZXZlbnQ6IEV2ZW50KTogdm9pZCB7XG4gICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcblxuICAgIHRoaXMuc2VsZWN0T3B0aW9uKCk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -180,4 +180,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
180
180
|
type: HostListener,
|
|
181
181
|
args: ['keydown', ['$event']]
|
|
182
182
|
}] } });
|
|
183
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/components/autocomplete/src/lib/autocomplete.component.ts","../../../../../../../libs/angular/components/autocomplete/src/lib/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  ContentChildren,\n  forwardRef,\n  HostListener,\n  inject,\n  QueryList,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ClickOutsideDirective } from '@odx/angular';\nimport { AutocompleteControl, ODX_SEARCH_FILTER_HOST } from '@odx/angular/cdk/autocomplete-control';\nimport { DropdownDirective } from '@odx/angular/components/dropdown';\nimport { LoadingSpinnerModule } from '@odx/angular/components/loading-spinner';\nimport { CSSComponent } from '@odx/angular/internal';\nimport { deferFn } from '@odx/angular/utils';\nimport { filter, tap } from 'rxjs';\nimport { AUTOCOMPLETE_CONTROL } from './autocomplete.tokens';\nimport { AutocompleteOptionComponent } from './components';\nimport { AutocompleteInputControlDirective } from './directives';\n\n/**\n * Represents an autocomplete component that provides user interface for a dropdown list to select from as users type.\n * It extends `AutocompleteControl`, integrating custom logic for handling keyboard and mouse events,\n * managing the dropdown state, and updating the associated search field.\n *\n * @see {AutocompleteControl}\n *\n * @template T - The type of the value handled by the autocomplete.\n */\n@CSSComponent('autocomplete')\n@Component({\n  standalone: true,\n  selector: 'odx-autocomplete',\n  imports: [DropdownDirective, AutocompleteOptionComponent, LoadingSpinnerModule],\n  templateUrl: './autocomplete.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: AUTOCOMPLETE_CONTROL,\n      useExisting: forwardRef(() => AutocompleteComponent),\n    },\n    {\n      provide: ODX_SEARCH_FILTER_HOST,\n      useExisting: AUTOCOMPLETE_CONTROL,\n    },\n  ],\n  hostDirectives: [ClickOutsideDirective],\n})\nexport class AutocompleteComponent<T = unknown> extends AutocompleteControl<T | null> implements AfterViewInit {\n  private readonly defaultActiveOptionIndex = 0;\n  private patchValueFlag = false;\n  protected readonly clickOutsideDirective = inject(ClickOutsideDirective, { host: true });\n\n  /**\n   * The list of autocomplete options.\n   *\n   * @type {QueryList<AutocompleteOptionComponent<T>> | undefined}\n   */\n  @ContentChildren(AutocompleteOptionComponent, { descendants: true, emitDistinctChangesOnly: true })\n  public options?: QueryList<AutocompleteOptionComponent<T>>;\n\n  /**\n   * The search field input control.\n   *\n   * @type {AutocompleteInputControlDirective | undefined}\n   */\n  @ContentChild(AutocompleteInputControlDirective)\n  public searchField?: AutocompleteInputControlDirective;\n\n  public override ngAfterViewInit(): void {\n    if (!this.options) return;\n    if (this.value) this.updateSearchField(this.value);\n\n    this.initKeyManager(this.options);\n    this.handleQueryListOption(this.options);\n    this.handleSearchFieldChanges();\n    this.handleClickOutside();\n  }\n\n  /**\n   * Selects an option, updates the value, updates the search field display,\n   * emits the selected value, and closes the dropdown.\n   *\n   * @param {AutocompleteOptionComponent<T> | null} option - The option component to select. If the option is undefined or its value is undefined,\n   * no action is taken.\n   */\n  public selectOption(option?: AutocompleteOptionComponent<T> | null): void {\n    if (!option?.value) return;\n\n    this.updateValue(option.value);\n    this.updateSearchField(option.value);\n\n    this.optionSelected.emit(option.value);\n\n    this.closeDropdown();\n  }\n\n  /**\n   * Resets the search field to its initial state and updates the value of the autocomplete\n   * to an empty string or initial value.\n   */\n  public resetSearchField(): void {\n    this.updateValue('' as T);\n    this.searchField?.reset();\n  }\n\n  protected handleQueryListOption(options: QueryList<AutocompleteOptionComponent<T>>): void {\n    options.changes\n      .pipe(\n        tap(() => deferFn(() => this.updateDropdownState())),\n        filter(() => this.isOpen),\n        this.takeUntilDestroyed(),\n      )\n      .subscribe(() => {\n        deferFn(() => this.activateSelectedOption());\n      });\n  }\n\n  protected handleSearchFieldChanges(): void {\n    this.searchField?.valueChange$.pipe(this.takeUntilDestroyed()).subscribe(() => this.triggerControllerChange());\n  }\n\n  protected handleClickOutside(): void {\n    this.clickOutsideDirective.odxClickOutside.pipe(this.takeUntilDestroyed()).subscribe(() => this.clickOutside());\n  }\n\n  protected clickOutside(): void {\n    this.closeDropdown();\n    this.blurSelectSearchField();\n  }\n\n  protected updateDropdownState(): void {\n    if (this.patchValueFlag) {\n      this.patchValueFlag = false;\n      return;\n    }\n\n    if (this.isOpen && !this.hasOptions) {\n      this.closeDropdown();\n    } else if (!this.isOpen && this.hasOptions) {\n      this.openDropdown();\n    }\n  }\n\n  @HostListener('click')\n  protected handleClickEvent() {\n    if (this.isLoading && this.isOpen) {\n      this.closeDropdown();\n      this.blurSelectSearchField();\n      return;\n    }\n\n    if (this.isReadonly || this.isDisabled) return;\n\n    if (!this.isOpen && this.hasOptions) {\n      this.openDropdown();\n    }\n  }\n\n  @HostListener('keydown', ['$event'])\n  protected handleKeyboardEvent(event: KeyboardEvent) {\n    if (this.isReadonly || this.isDisabled) return;\n\n    if (this.isOpen && this.hasOptions) {\n      if (event.key === 'Enter' || event.key === 'Tab') {\n        event.preventDefault();\n        event.stopImmediatePropagation();\n        this.selectOption(this.keyManager?.activeItem as AutocompleteOptionComponent<T> | undefined);\n        return;\n      }\n    }\n\n    if (event.key === 'Enter') {\n      this.optionSelected.emit((this.value ?? '') as T);\n      return;\n    }\n\n    if (!this.isOpen && event.key === 'Tab') {\n      return;\n    }\n\n    if (!this.isOpen && this.hasOptions) {\n      this.openDropdown();\n      return;\n    }\n\n    this.keyManager?.onKeydown(event);\n  }\n\n  protected activateSelectedOption(): void {\n    this.keyManager?.setActiveItem(this.defaultActiveOptionIndex);\n  }\n\n  private updateSearchField(value: T): void {\n    if (!this.searchField) return;\n    this.patchValueFlag = true;\n    this.searchField.nativeElementValue = this.stringify?.(value) ?? (value as string);\n  }\n\n  private blurSelectSearchField(): void {\n    this.searchField?.blur();\n  }\n}\n","<div\n  aria-haspopup=\"listbox\"\n  class=\"odx-autocomplete__trigger\"\n  [odxDropdown]=\"dropdownContent\"\n  [odxDropdownDisabled]=\"isDisabled || isReadonly\"\n  [odxDropdownOptions]=\"{ matchReferenceWidth: true, offset: 4, outerPadding: 10, position: 'bottom-start' }\"\n  [odxDropdownReferenceElement]=\"dropdownReferenceElement\"\n  [odxDropdownShowLoader]=\"isLoading\"\n  [odxDropdownOpenTrigger]=\"[]\"\n  [odxDropdownClickOutsideActive]=\"false\"\n  (odxDropdownBeforeOpen)=\"onDropdownOpen()\"\n  (odxDropdownAfterOpen)=\"onDropdownOpened()\"\n  (odxDropdownBeforeClose)=\"onDropdownClose()\"\n  (odxDropdownAfterClose)=\"onDropdownClosed()\"\n>\n  <ng-content select=\"input[odxAutocompleteControl]\"></ng-content>\n</div>\n<ng-template #dropdownContent>\n  <div class=\"odx-dropdown__option-list\" role=\"listbox\">\n    <ng-template [ngIf]=\"hasOptions\">\n      <ng-content></ng-content>\n    </ng-template>\n  </div>\n</ng-template>\n"]}
|
|
183
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/components/autocomplete/src/lib/autocomplete.component.ts","../../../../../../../libs/angular/components/autocomplete/src/lib/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  ContentChildren,\n  forwardRef,\n  HostListener,\n  inject,\n  QueryList,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ClickOutsideDirective } from '@odx/angular';\nimport { AutocompleteControl, ODX_SEARCH_FILTER_HOST } from '@odx/angular/cdk/autocomplete-control';\nimport { DropdownDirective } from '@odx/angular/components/dropdown';\nimport { LoadingSpinnerModule } from '@odx/angular/components/loading-spinner';\nimport { CSSComponent } from '@odx/angular/internal';\nimport { deferFn } from '@odx/angular/utils';\nimport { filter, tap } from 'rxjs';\nimport { AUTOCOMPLETE_CONTROL } from './autocomplete.tokens';\nimport { AutocompleteOptionComponent } from './components';\nimport { AutocompleteInputControlDirective } from './directives';\n\n/**\n * Represents an autocomplete component that provides user interface for a dropdown list to select from as users type.\n * It extends `AutocompleteControl`, integrating custom logic for handling keyboard and mouse events,\n * managing the dropdown state, and updating the associated search field.\n *\n * @see {AutocompleteControl}\n *\n * @template T - The type of the value handled by the autocomplete.\n */\n@CSSComponent('autocomplete')\n@Component({\n  standalone: true,\n  selector: 'odx-autocomplete',\n  imports: [DropdownDirective, AutocompleteOptionComponent, LoadingSpinnerModule],\n  templateUrl: './autocomplete.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: AUTOCOMPLETE_CONTROL,\n      useExisting: forwardRef(() => AutocompleteComponent),\n    },\n    {\n      provide: ODX_SEARCH_FILTER_HOST,\n      useExisting: AUTOCOMPLETE_CONTROL,\n    },\n  ],\n  hostDirectives: [ClickOutsideDirective],\n})\nexport class AutocompleteComponent<T = unknown> extends AutocompleteControl<T | null> implements AfterViewInit {\n  private readonly defaultActiveOptionIndex = 0;\n  private patchValueFlag = false;\n  protected readonly clickOutsideDirective = inject(ClickOutsideDirective, { host: true });\n\n  /**\n   * The list of autocomplete options.\n   *\n   * @type {QueryList<AutocompleteOptionComponent<T>> | undefined}\n   */\n  @ContentChildren(AutocompleteOptionComponent, { descendants: true, emitDistinctChangesOnly: true })\n  public options?: QueryList<AutocompleteOptionComponent<T>>;\n\n  /**\n   * The search field input control.\n   *\n   * @type {AutocompleteInputControlDirective | undefined}\n   */\n  @ContentChild(AutocompleteInputControlDirective)\n  public searchField?: AutocompleteInputControlDirective;\n\n  public override ngAfterViewInit(): void {\n    if (!this.options) return;\n    if (this.value) this.updateSearchField(this.value);\n    this.initKeyManager(this.options);\n    this.handleQueryListOption(this.options);\n    this.handleSearchFieldChanges();\n    this.handleClickOutside();\n  }\n\n  /**\n   * Selects an option, updates the value, updates the search field display,\n   * emits the selected value, and closes the dropdown.\n   *\n   * @param {AutocompleteOptionComponent<T> | null} option - The option component to select. If the option is undefined or its value is undefined,\n   * no action is taken.\n   */\n  public selectOption(option?: AutocompleteOptionComponent<T> | null): void {\n    if (!option?.value) return;\n\n    this.updateValue(option.value);\n    this.updateSearchField(option.value);\n\n    this.optionSelected.emit(option.value);\n\n    this.closeDropdown();\n  }\n\n  /**\n   * Resets the search field to its initial state and updates the value of the autocomplete\n   * to an empty string or initial value.\n   */\n  public resetSearchField(): void {\n    this.updateValue('' as T);\n    this.searchField?.reset();\n  }\n\n  protected handleQueryListOption(options: QueryList<AutocompleteOptionComponent<T>>): void {\n    options.changes\n      .pipe(\n        tap(() => deferFn(() => this.updateDropdownState())),\n        filter(() => this.isOpen),\n        this.takeUntilDestroyed(),\n      )\n      .subscribe(() => {\n        deferFn(() => this.activateSelectedOption());\n      });\n  }\n\n  protected handleSearchFieldChanges(): void {\n    this.searchField?.valueChange$.pipe(this.takeUntilDestroyed()).subscribe(() => this.triggerControllerChange());\n  }\n\n  protected handleClickOutside(): void {\n    this.clickOutsideDirective.odxClickOutside.pipe(this.takeUntilDestroyed()).subscribe(() => this.clickOutside());\n  }\n\n  protected clickOutside(): void {\n    this.closeDropdown();\n    this.blurSelectSearchField();\n  }\n\n  protected updateDropdownState(): void {\n    if (this.patchValueFlag) {\n      this.patchValueFlag = false;\n      return;\n    }\n\n    if (this.isOpen && !this.hasOptions) {\n      this.closeDropdown();\n    } else if (!this.isOpen && this.hasOptions) {\n      this.openDropdown();\n    }\n  }\n\n  @HostListener('click')\n  protected handleClickEvent() {\n    if (this.isLoading && this.isOpen) {\n      this.closeDropdown();\n      this.blurSelectSearchField();\n      return;\n    }\n\n    if (this.isReadonly || this.isDisabled) return;\n\n    if (!this.isOpen && this.hasOptions) {\n      this.openDropdown();\n    }\n  }\n\n  @HostListener('keydown', ['$event'])\n  protected handleKeyboardEvent(event: KeyboardEvent) {\n    if (this.isReadonly || this.isDisabled) return;\n\n    if (this.isOpen && this.hasOptions) {\n      if (event.key === 'Enter' || event.key === 'Tab') {\n        event.preventDefault();\n        event.stopImmediatePropagation();\n        this.selectOption(this.keyManager?.activeItem as AutocompleteOptionComponent<T> | undefined);\n        return;\n      }\n    }\n\n    if (event.key === 'Enter') {\n      this.optionSelected.emit((this.value ?? '') as T);\n      return;\n    }\n\n    if (!this.isOpen && event.key === 'Tab') {\n      return;\n    }\n\n    if (!this.isOpen && this.hasOptions) {\n      this.openDropdown();\n      return;\n    }\n\n    this.keyManager?.onKeydown(event);\n  }\n\n  protected activateSelectedOption(): void {\n    this.keyManager?.setActiveItem(this.defaultActiveOptionIndex);\n  }\n\n  private updateSearchField(value: T): void {\n    if (!this.searchField) return;\n    this.patchValueFlag = true;\n    this.searchField.nativeElementValue = this.stringify?.(value) ?? (value as string);\n  }\n\n  private blurSelectSearchField(): void {\n    this.searchField?.blur();\n  }\n}\n","<div\n  aria-haspopup=\"listbox\"\n  class=\"odx-autocomplete__trigger\"\n  [odxDropdown]=\"dropdownContent\"\n  [odxDropdownDisabled]=\"isDisabled || isReadonly\"\n  [odxDropdownOptions]=\"{ matchReferenceWidth: true, offset: 4, outerPadding: 10, position: 'bottom-start' }\"\n  [odxDropdownReferenceElement]=\"dropdownReferenceElement\"\n  [odxDropdownShowLoader]=\"isLoading\"\n  [odxDropdownOpenTrigger]=\"[]\"\n  [odxDropdownClickOutsideActive]=\"false\"\n  (odxDropdownBeforeOpen)=\"onDropdownOpen()\"\n  (odxDropdownAfterOpen)=\"onDropdownOpened()\"\n  (odxDropdownBeforeClose)=\"onDropdownClose()\"\n  (odxDropdownAfterClose)=\"onDropdownClosed()\"\n>\n  <ng-content select=\"input[odxAutocompleteControl]\"></ng-content>\n</div>\n<ng-template #dropdownContent>\n  <div class=\"odx-dropdown__option-list\" role=\"listbox\">\n    <ng-template [ngIf]=\"hasOptions\">\n      <ng-content></ng-content>\n    </ng-template>\n  </div>\n</ng-template>\n"]}
|
package/esm2022/components/autocomplete/lib/components/option/autocomplete-option.component.mjs
CHANGED
|
@@ -3,6 +3,7 @@ import { ChangeDetectionStrategy, Component, inject, ViewEncapsulation } from '@
|
|
|
3
3
|
import { CoreModule } from '@odx/angular';
|
|
4
4
|
import { OptionControl } from '@odx/angular/cdk/option-control';
|
|
5
5
|
import { CSSComponent } from '@odx/angular/internal';
|
|
6
|
+
import { deferFn } from '@odx/angular/utils';
|
|
6
7
|
import { AUTOCOMPLETE_CONTROL } from '../../autocomplete.tokens';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
9
|
/**
|
|
@@ -19,7 +20,10 @@ let AutocompleteOptionComponent = class AutocompleteOptionComponent extends Opti
|
|
|
19
20
|
* Sets the active styles for the option component.
|
|
20
21
|
*/
|
|
21
22
|
setActiveStyles() {
|
|
22
|
-
|
|
23
|
+
deferFn(() => {
|
|
24
|
+
this.isActive = true;
|
|
25
|
+
this.cdr.markForCheck();
|
|
26
|
+
});
|
|
23
27
|
if (this.autocompleteControl.isOpen) {
|
|
24
28
|
this.autocompleteControl.scrollOptionIntoView(this);
|
|
25
29
|
}
|
|
@@ -38,4 +42,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
38
42
|
type: Component,
|
|
39
43
|
args: [{ standalone: true, selector: 'odx-autocomplete-option', imports: [CoreModule], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-content></ng-content>\n" }]
|
|
40
44
|
}] });
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b2NvbXBsZXRlLW9wdGlvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY29tcG9uZW50cy9hdXRvY29tcGxldGUvc3JjL2xpYi9jb21wb25lbnRzL29wdGlvbi9hdXRvY29tcGxldGUtb3B0aW9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9jb21wb25lbnRzL2F1dG9jb21wbGV0ZS9zcmMvbGliL2NvbXBvbmVudHMvb3B0aW9uL2F1dG9jb21wbGV0ZS1vcHRpb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzlGLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDMUMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ2hFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNyRCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDN0MsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7O0FBRWpFOzs7O0dBSUc7QUFVSSxJQUFNLDJCQUEyQixHQUFqQyxNQUFNLDJCQUErQixTQUFRLGFBQWdCO0lBQTdEOztRQUNjLHdCQUFtQixHQUFHLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO0tBbUJ2RTtJQWpCQzs7T0FFRztJQUNJLGVBQWU7UUFDcEIsT0FBTyxDQUFDLEdBQUcsRUFBRTtZQUNYLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxHQUFHLENBQUMsWUFBWSxFQUFFLENBQUM7UUFDMUIsQ0FBQyxDQUFDLENBQUM7UUFFSCxJQUFJLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNwQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsb0JBQW9CLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDdEQsQ0FBQztJQUNILENBQUM7SUFFUyxZQUFZO1FBQ3BCLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDOUMsQ0FBQzsrR0FuQlUsMkJBQTJCO21HQUEzQiwyQkFBMkIsMEdDckJ4Qyw2QkFDQSwyQ0RlWSxVQUFVOztBQUtULDJCQUEyQjtJQVR2QyxZQUFZLENBQUMscUJBQXFCLENBQUM7R0FTdkIsMkJBQTJCLENBb0J2Qzs7NEZBcEJZLDJCQUEyQjtrQkFSdkMsU0FBUztpQ0FDSSxJQUFJLFlBQ04seUJBQXlCLFdBQzFCLENBQUMsVUFBVSxDQUFDLGlCQUVOLGlCQUFpQixDQUFDLElBQUksbUJBQ3BCLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBpbmplY3QsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb3JlTW9kdWxlIH0gZnJvbSAnQG9keC9hbmd1bGFyJztcbmltcG9ydCB7IE9wdGlvbkNvbnRyb2wgfSBmcm9tICdAb2R4L2FuZ3VsYXIvY2RrL29wdGlvbi1jb250cm9sJztcbmltcG9ydCB7IENTU0NvbXBvbmVudCB9IGZyb20gJ0BvZHgvYW5ndWxhci9pbnRlcm5hbCc7XG5pbXBvcnQgeyBkZWZlckZuIH0gZnJvbSAnQG9keC9hbmd1bGFyL3V0aWxzJztcbmltcG9ydCB7IEFVVE9DT01QTEVURV9DT05UUk9MIH0gZnJvbSAnLi4vLi4vYXV0b2NvbXBsZXRlLnRva2Vucyc7XG5cbi8qKlxuICogUmVwcmVzZW50cyBhbiBvcHRpb24gY29tcG9uZW50IGZvciB0aGUgYXV0b2NvbXBsZXRlIGNvbnRyb2wuXG4gKlxuICogQHRlbXBsYXRlIFQgLSBUaGUgdHlwZSBvZiB0aGUgb3B0aW9uIHZhbHVlLlxuICovXG5AQ1NTQ29tcG9uZW50KCdhdXRvY29tcGxldGUtb3B0aW9uJylcbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBzZWxlY3RvcjogJ29keC1hdXRvY29tcGxldGUtb3B0aW9uJyxcbiAgaW1wb3J0czogW0NvcmVNb2R1bGVdLFxuICB0ZW1wbGF0ZVVybDogJy4vYXV0b2NvbXBsZXRlLW9wdGlvbi5jb21wb25lbnQuaHRtbCcsXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBBdXRvY29tcGxldGVPcHRpb25Db21wb25lbnQ8VD4gZXh0ZW5kcyBPcHRpb25Db250cm9sPFQ+IHtcbiAgcHJvdGVjdGVkIHJlYWRvbmx5IGF1dG9jb21wbGV0ZUNvbnRyb2wgPSBpbmplY3QoQVVUT0NPTVBMRVRFX0NPTlRST0wpO1xuXG4gIC8qKlxuICAgKiBTZXRzIHRoZSBhY3RpdmUgc3R5bGVzIGZvciB0aGUgb3B0aW9uIGNvbXBvbmVudC5cbiAgICovXG4gIHB1YmxpYyBzZXRBY3RpdmVTdHlsZXMoKTogdm9pZCB7XG4gICAgZGVmZXJGbigoKSA9PiB7XG4gICAgICB0aGlzLmlzQWN0aXZlID0gdHJ1ZTtcbiAgICAgIHRoaXMuY2RyLm1hcmtGb3JDaGVjaygpO1xuICAgIH0pO1xuXG4gICAgaWYgKHRoaXMuYXV0b2NvbXBsZXRlQ29udHJvbC5pc09wZW4pIHtcbiAgICAgIHRoaXMuYXV0b2NvbXBsZXRlQ29udHJvbC5zY3JvbGxPcHRpb25JbnRvVmlldyh0aGlzKTtcbiAgICB9XG4gIH1cblxuICBwcm90ZWN0ZWQgc2VsZWN0T3B0aW9uKCk6IHZvaWQge1xuICAgIHRoaXMuYXV0b2NvbXBsZXRlQ29udHJvbC5zZWxlY3RPcHRpb24odGhpcyk7XG4gIH1cbn1cbiIsIjxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiJdfQ==
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { __decorate, __metadata } from "tslib";
|
|
2
|
-
import {
|
|
2
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation, booleanAttribute } from '@angular/core';
|
|
3
3
|
import { CoreModule } from '@odx/angular';
|
|
4
4
|
import { ButtonComponent } from '@odx/angular/components/button';
|
|
5
5
|
import { IconComponent } from '@odx/angular/components/icon';
|
|
@@ -7,7 +7,6 @@ import { CSSComponent, CSSModifier } from '@odx/angular/internal';
|
|
|
7
7
|
import { injectElement } from '@odx/angular/utils';
|
|
8
8
|
import { ChipSize, ChipVariant } from '../../models';
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
|
-
import * as i1 from "@angular/common";
|
|
11
10
|
/**
|
|
12
11
|
* Represents a chip component.
|
|
13
12
|
*/
|
|
@@ -49,7 +48,7 @@ let ChipComponent = class ChipComponent {
|
|
|
49
48
|
return this.variant === ChipVariant.WARNING ? null : this.variant;
|
|
50
49
|
}
|
|
51
50
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ChipComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
52
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
51
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: ChipComponent, isStandalone: true, selector: "odx-chip", inputs: { removable: ["removable", "removable", booleanAttribute], size: "size", variant: "variant" }, outputs: { remove: "remove" }, ngImport: i0, template: "<ng-content select=\"odx-icon\"></ng-content>\n<div class=\"odx-chip__content\">\n <ng-content></ng-content>\n</div>\n@if (removable) {\n <button odxButton class=\"odx-chip__action\" [size]=\"size\" [variant]=\"buttonVariant\" type=\"button\" (click)=\"onClick()\">\n <odx-icon [size]=\"size\" name=\"close\" iconSet=\"core\"></odx-icon>\n </button>\n}\n", dependencies: [{ kind: "ngmodule", type: CoreModule }, { kind: "component", type: ButtonComponent, selector: "button[odxButton], a[odxButton]", inputs: ["variant", "size"] }, { kind: "component", type: IconComponent, selector: "odx-icon", inputs: ["inline", "size", "name", "iconSet", "identifier"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
53
52
|
};
|
|
54
53
|
__decorate([
|
|
55
54
|
CSSModifier(),
|
|
@@ -65,7 +64,7 @@ ChipComponent = __decorate([
|
|
|
65
64
|
export { ChipComponent };
|
|
66
65
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ChipComponent, decorators: [{
|
|
67
66
|
type: Component,
|
|
68
|
-
args: [{ selector: 'odx-chip', imports: [CoreModule, ButtonComponent, IconComponent], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, template: "<div class=\"odx-chip__content\">\n <ng-content></ng-content>\n</div>\n<button odxButton class=\"odx-chip__action\" [size]=\"size\" [variant]=\"buttonVariant\" type=\"button\" (click)=\"onClick()\"
|
|
67
|
+
args: [{ selector: 'odx-chip', imports: [CoreModule, ButtonComponent, IconComponent], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, template: "<ng-content select=\"odx-icon\"></ng-content>\n<div class=\"odx-chip__content\">\n <ng-content></ng-content>\n</div>\n@if (removable) {\n <button odxButton class=\"odx-chip__action\" [size]=\"size\" [variant]=\"buttonVariant\" type=\"button\" (click)=\"onClick()\">\n <odx-icon [size]=\"size\" name=\"close\" iconSet=\"core\"></odx-icon>\n </button>\n}\n" }]
|
|
69
68
|
}], propDecorators: { removable: [{
|
|
70
69
|
type: Input,
|
|
71
70
|
args: [{ transform: booleanAttribute }]
|
|
@@ -76,4 +75,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
76
75
|
}], remove: [{
|
|
77
76
|
type: Output
|
|
78
77
|
}] } });
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY29tcG9uZW50cy9jaGlwL3NyYy9saWIvY29tcG9uZW50cy9jaGlwL2NoaXAuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL2NvbXBvbmVudHMvY2hpcC9zcmMvbGliL2NvbXBvbmVudHMvY2hpcC9jaGlwLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLGlCQUFpQixFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3JJLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDMUMsT0FBTyxFQUFFLGVBQWUsRUFBaUIsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNoRixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDN0QsT0FBTyxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDbkQsT0FBTyxFQUFFLFFBQVEsRUFBRSxXQUFXLEVBQUUsTUFBTSxjQUFjLENBQUM7O0FBRXJEOztHQUVHO0FBVUksSUFBTSxhQUFhLEdBQW5CLE1BQU0sYUFBYTtJQUFuQjtRQUNXLFlBQU8sR0FBRyxhQUFhLEVBQUUsQ0FBQztRQUUxQzs7Ozs7V0FLRztRQUVJLGNBQVMsR0FBRyxLQUFLLENBQUM7UUFFekI7Ozs7O1dBS0c7UUFHSSxTQUFJLEdBQWEsUUFBUSxDQUFDLEtBQUssQ0FBQztRQUV2Qzs7Ozs7V0FLRztRQUdJLFlBQU8sR0FBZ0IsV0FBVyxDQUFDLFNBQVMsQ0FBQztRQUVwRDs7OztXQUlHO1FBRUksV0FBTSxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7S0FTMUM7SUFQVyxPQUFPO1FBQ2YsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUNyQixDQUFDO0lBRUQsSUFBYyxhQUFhO1FBQ3pCLE9BQU8sSUFBSSxDQUFDLE9BQU8sS0FBSyxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDcEUsQ0FBQzsrR0E5Q1UsYUFBYTttR0FBYixhQUFhLDRGQVNKLGdCQUFnQiw4RkM3QnRDLDBXQVNBLDJDRE1ZLFVBQVUsK0JBQUUsZUFBZSx5R0FBRSxhQUFhOztBQXlCN0M7SUFGTixXQUFXLEVBQUU7OzJDQUV5QjtBQVVoQztJQUZOLFdBQVcsRUFBRTs7OENBRXNDO0FBOUJ6QyxhQUFhO0lBVHpCLFlBQVksQ0FBQyxNQUFNLENBQUM7R0FTUixhQUFhLENBK0N6Qjs7NEZBL0NZLGFBQWE7a0JBUnpCLFNBQVM7K0JBQ0UsVUFBVSxXQUVYLENBQUMsVUFBVSxFQUFFLGVBQWUsRUFBRSxhQUFhLENBQUMsaUJBQ3RDLGlCQUFpQixDQUFDLElBQUksbUJBQ3BCLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsSUFBSTs4QkFZVCxTQUFTO3NCQURmLEtBQUs7dUJBQUMsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUU7Z0JBVy9CLElBQUk7c0JBRFYsS0FBSztnQkFXQyxPQUFPO3NCQURiLEtBQUs7Z0JBU0MsTUFBTTtzQkFEWixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0LCBWaWV3RW5jYXBzdWxhdGlvbiwgYm9vbGVhbkF0dHJpYnV0ZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29yZU1vZHVsZSB9IGZyb20gJ0BvZHgvYW5ndWxhcic7XG5pbXBvcnQgeyBCdXR0b25Db21wb25lbnQsIEJ1dHRvblZhcmlhbnQgfSBmcm9tICdAb2R4L2FuZ3VsYXIvY29tcG9uZW50cy9idXR0b24nO1xuaW1wb3J0IHsgSWNvbkNvbXBvbmVudCB9IGZyb20gJ0BvZHgvYW5ndWxhci9jb21wb25lbnRzL2ljb24nO1xuaW1wb3J0IHsgQ1NTQ29tcG9uZW50LCBDU1NNb2RpZmllciB9IGZyb20gJ0BvZHgvYW5ndWxhci9pbnRlcm5hbCc7XG5pbXBvcnQgeyBpbmplY3RFbGVtZW50IH0gZnJvbSAnQG9keC9hbmd1bGFyL3V0aWxzJztcbmltcG9ydCB7IENoaXBTaXplLCBDaGlwVmFyaWFudCB9IGZyb20gJy4uLy4uL21vZGVscyc7XG5cbi8qKlxuICogUmVwcmVzZW50cyBhIGNoaXAgY29tcG9uZW50LlxuICovXG5AQ1NTQ29tcG9uZW50KCdjaGlwJylcbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ29keC1jaGlwJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2NoaXAuY29tcG9uZW50Lmh0bWwnLFxuICBpbXBvcnRzOiBbQ29yZU1vZHVsZSwgQnV0dG9uQ29tcG9uZW50LCBJY29uQ29tcG9uZW50XSxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIENoaXBDb21wb25lbnQge1xuICBwdWJsaWMgcmVhZG9ubHkgZWxlbWVudCA9IGluamVjdEVsZW1lbnQoKTtcblxuICAvKipcbiAgICogSW5kaWNhdGVzIHdoZXRoZXIgdGhlIGNoaXAgaXMgcmVtb3ZhYmxlLlxuICAgKlxuICAgKiBAdHlwZSB7Ym9vbGVhbn1cbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIEBJbnB1dCh7IHRyYW5zZm9ybTogYm9vbGVhbkF0dHJpYnV0ZSB9KVxuICBwdWJsaWMgcmVtb3ZhYmxlID0gZmFsc2U7XG5cbiAgLyoqXG4gICAqIFRoZSBzaXplIG9mIHRoZSBjaGlwLlxuICAgKlxuICAgKiBAdHlwZSB7Q2hpcFNpemV9XG4gICAqIEBkZWZhdWx0IENoaXBTaXplLlNNQUxMXG4gICAqL1xuICBAQ1NTTW9kaWZpZXIoKVxuICBASW5wdXQoKVxuICBwdWJsaWMgc2l6ZTogQ2hpcFNpemUgPSBDaGlwU2l6ZS5TTUFMTDtcblxuICAvKipcbiAgICogVGhlIHZhcmlhbnQgb2YgdGhlIGNoaXAuXG4gICAqXG4gICAqIEB0eXBlIHtDaGlwVmFyaWFudH1cbiAgICogQGRlZmF1bHQgQ2hpcFZhcmlhbnQuU0VDT05EQVJZXG4gICAqL1xuICBAQ1NTTW9kaWZpZXIoKVxuICBASW5wdXQoKVxuICBwdWJsaWMgdmFyaWFudDogQ2hpcFZhcmlhbnQgPSBDaGlwVmFyaWFudC5TRUNPTkRBUlk7XG5cbiAgLyoqXG4gICAqIEV2ZW50IGVtaXR0ZXIgdGhhdCBlbWl0cyB3aGVuIHRoZSBjaGlwIGlzIHJlbW92ZWQuXG4gICAqXG4gICAqIEBlbWl0cyB7dm9pZH1cbiAgICovXG4gIEBPdXRwdXQoKVxuICBwdWJsaWMgcmVtb3ZlID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gIHByb3RlY3RlZCBvbkNsaWNrKCk6IHZvaWQge1xuICAgIHRoaXMucmVtb3ZlLmVtaXQoKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBnZXQgYnV0dG9uVmFyaWFudCgpOiBCdXR0b25WYXJpYW50IHwgbnVsbCB7XG4gICAgcmV0dXJuIHRoaXMudmFyaWFudCA9PT0gQ2hpcFZhcmlhbnQuV0FSTklORyA/IG51bGwgOiB0aGlzLnZhcmlhbnQ7XG4gIH1cbn1cbiIsIjxuZy1jb250ZW50IHNlbGVjdD1cIm9keC1pY29uXCI+PC9uZy1jb250ZW50PlxuPGRpdiBjbGFzcz1cIm9keC1jaGlwX19jb250ZW50XCI+XG4gIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbjwvZGl2PlxuQGlmIChyZW1vdmFibGUpIHtcbiAgPGJ1dHRvbiBvZHhCdXR0b24gY2xhc3M9XCJvZHgtY2hpcF9fYWN0aW9uXCIgW3NpemVdPVwic2l6ZVwiIFt2YXJpYW50XT1cImJ1dHRvblZhcmlhbnRcIiB0eXBlPVwiYnV0dG9uXCIgKGNsaWNrKT1cIm9uQ2xpY2soKVwiPlxuICAgIDxvZHgtaWNvbiBbc2l6ZV09XCJzaXplXCIgbmFtZT1cImNsb3NlXCIgaWNvblNldD1cImNvcmVcIj48L29keC1pY29uPlxuICA8L2J1dHRvbj5cbn1cbiJdfQ==
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { IconSet } from '../models';
|
|
1
2
|
/**
|
|
2
3
|
* Unpacks a combined icon identifier string into separate icon set and icon name components.
|
|
3
4
|
* The identifier is expected to follow the format "iconSet::iconName". If the "iconName" part is
|
|
@@ -15,7 +16,23 @@
|
|
|
15
16
|
export function unpackIconIdentifier(value) {
|
|
16
17
|
const [iconSet, iconName] = value.split('::');
|
|
17
18
|
if (!iconName)
|
|
18
|
-
return [
|
|
19
|
-
|
|
19
|
+
return [IconSet.CORE, iconSet];
|
|
20
|
+
const set = isIconSet(iconSet) ? iconSet : IconSet.CORE;
|
|
21
|
+
return [set, iconName];
|
|
20
22
|
}
|
|
21
|
-
|
|
23
|
+
/**
|
|
24
|
+
* Determines if a given string is a valid icon set.
|
|
25
|
+
*
|
|
26
|
+
* @param {string} value The value to check if it is a valid icon set.
|
|
27
|
+
* @returns {boolean} Whether the value is a valid icon set.
|
|
28
|
+
*
|
|
29
|
+
* @example
|
|
30
|
+
* ```ts
|
|
31
|
+
* isIconSet('core') // returns true
|
|
32
|
+
* isIconSet('custom') // returns false
|
|
33
|
+
* ```
|
|
34
|
+
*/
|
|
35
|
+
export function isIconSet(value) {
|
|
36
|
+
return Object.values(IconSet).includes(value);
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5wYWNrLWljb24taWRlbnRpZmllci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9jb21wb25lbnRzL2ljb24vc3JjL2xpYi9oZWxwZXJzL3VucGFjay1pY29uLWlkZW50aWZpZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUVwQzs7Ozs7Ozs7Ozs7OztHQWFHO0FBQ0gsTUFBTSxVQUFVLG9CQUFvQixDQUFDLEtBQWE7SUFDaEQsTUFBTSxDQUFDLE9BQU8sRUFBRSxRQUFRLENBQUMsR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzlDLElBQUksQ0FBQyxRQUFRO1FBQUUsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDOUMsTUFBTSxHQUFHLEdBQVksU0FBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7SUFDakUsT0FBTyxDQUFDLEdBQUcsRUFBRSxRQUFRLENBQUMsQ0FBQztBQUN6QixDQUFDO0FBRUQ7Ozs7Ozs7Ozs7O0dBV0c7QUFDSCxNQUFNLFVBQVUsU0FBUyxDQUFDLEtBQWE7SUFDckMsT0FBTyxNQUFNLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDLFFBQVEsQ0FBQyxLQUFnQixDQUFDLENBQUM7QUFDM0QsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEljb25TZXQgfSBmcm9tICcuLi9tb2RlbHMnO1xuXG4vKipcbiAqIFVucGFja3MgYSBjb21iaW5lZCBpY29uIGlkZW50aWZpZXIgc3RyaW5nIGludG8gc2VwYXJhdGUgaWNvbiBzZXQgYW5kIGljb24gbmFtZSBjb21wb25lbnRzLlxuICogVGhlIGlkZW50aWZpZXIgaXMgZXhwZWN0ZWQgdG8gZm9sbG93IHRoZSBmb3JtYXQgXCJpY29uU2V0OjppY29uTmFtZVwiLiBJZiB0aGUgXCJpY29uTmFtZVwiIHBhcnQgaXNcbiAqIG1pc3NpbmcsIHRoZSBmdW5jdGlvbiBhc3N1bWVzIHRoZSBpY29uIGJlbG9uZ3MgdG8gdGhlICdjb3JlJyBzZXQuXG4gKlxuICogQHBhcmFtIHtzdHJpbmd9IHZhbHVlIFRoZSBjb21iaW5lZCBpZGVudGlmaWVyIHN0cmluZyBpbiB0aGUgZm9ybWF0IFwiaWNvblNldDo6aWNvbk5hbWVcIi5cbiAqIEByZXR1cm5zIHtbaWNvblNldDogc3RyaW5nLCBpY29uTmFtZTogc3RyaW5nXX0gQSB0dXBsZSBjb250YWluaW5nIHRoZSBpY29uIHNldCBhbmQgaWNvbiBuYW1lIGFzIHR3byBzZXBhcmF0ZSBzdHJpbmdzLiBEZWZhdWx0cyB0byAnY29yZSdcbiAqICAgICAgICAgIGlmIHRoZSBpY29uTmFtZSBpcyBvbWl0dGVkIGluIHRoZSBpbnB1dC5cbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHNcbiAqIHVucGFja0ljb25JZGVudGlmaWVyKFwibWVudVwiKSAgICAgICAvLyByZXR1cm5zIFsnY29yZScsICdtZW51J11cbiAqIGBgYFxuICovXG5leHBvcnQgZnVuY3Rpb24gdW5wYWNrSWNvbklkZW50aWZpZXIodmFsdWU6IHN0cmluZyk6IFtpY29uU2V0OiBJY29uU2V0LCBpY29uTmFtZTogc3RyaW5nXSB7XG4gIGNvbnN0IFtpY29uU2V0LCBpY29uTmFtZV0gPSB2YWx1ZS5zcGxpdCgnOjonKTtcbiAgaWYgKCFpY29uTmFtZSkgcmV0dXJuIFtJY29uU2V0LkNPUkUsIGljb25TZXRdO1xuICBjb25zdCBzZXQ6IEljb25TZXQgPSBpc0ljb25TZXQoaWNvblNldCkgPyBpY29uU2V0IDogSWNvblNldC5DT1JFO1xuICByZXR1cm4gW3NldCwgaWNvbk5hbWVdO1xufVxuXG4vKipcbiAqIERldGVybWluZXMgaWYgYSBnaXZlbiBzdHJpbmcgaXMgYSB2YWxpZCBpY29uIHNldC5cbiAqXG4gKiBAcGFyYW0ge3N0cmluZ30gdmFsdWUgVGhlIHZhbHVlIHRvIGNoZWNrIGlmIGl0IGlzIGEgdmFsaWQgaWNvbiBzZXQuXG4gKiBAcmV0dXJucyB7Ym9vbGVhbn0gV2hldGhlciB0aGUgdmFsdWUgaXMgYSB2YWxpZCBpY29uIHNldC5cbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHNcbiAqIGlzSWNvblNldCgnY29yZScpICAgICAgIC8vIHJldHVybnMgdHJ1ZVxuICogaXNJY29uU2V0KCdjdXN0b20nKSAgICAgLy8gcmV0dXJucyBmYWxzZVxuICogYGBgXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpc0ljb25TZXQodmFsdWU6IHN0cmluZyk6IHZhbHVlIGlzIEljb25TZXQge1xuICByZXR1cm4gT2JqZWN0LnZhbHVlcyhJY29uU2V0KS5pbmNsdWRlcyh2YWx1ZSBhcyBJY29uU2V0KTtcbn1cbiJdfQ==
|
|
@@ -2,7 +2,7 @@ import { __decorate, __metadata } from "tslib";
|
|
|
2
2
|
import { booleanAttribute, ChangeDetectionStrategy, Component, Input, ViewEncapsulation } from '@angular/core';
|
|
3
3
|
import { CSSComponent, CSSModifier } from '@odx/angular/internal';
|
|
4
4
|
import { injectElement } from '@odx/angular/utils';
|
|
5
|
-
import { unpackIconIdentifier } from './helpers';
|
|
5
|
+
import { isIconSet, unpackIconIdentifier } from './helpers';
|
|
6
6
|
import { injectIconConfig } from './icon.config';
|
|
7
7
|
import { IconSize } from './models';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
@@ -40,7 +40,7 @@ let IconComponent = class IconComponent {
|
|
|
40
40
|
/**
|
|
41
41
|
* Specifies the icon set that the icon belongs to. The default set can be injected from the icon configuration.
|
|
42
42
|
*
|
|
43
|
-
* @type {
|
|
43
|
+
* @type {IconSet | null}
|
|
44
44
|
*/
|
|
45
45
|
this.iconSet = injectIconConfig().defaultIconSet;
|
|
46
46
|
}
|
|
@@ -56,7 +56,7 @@ let IconComponent = class IconComponent {
|
|
|
56
56
|
this.iconSet = iconSet;
|
|
57
57
|
}
|
|
58
58
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: IconComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
59
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.3.12", type: IconComponent, isStandalone: true, selector: "odx-icon", inputs: { inline: ["inline", "inline", booleanAttribute], size: "size", name: "name", iconSet: "iconSet", identifier: "identifier" }, host: { attributes: { "translate": "no" }, properties: { "class.notranslate": "true", "attr.data-icon-name": "name", "attr.data-icon-set": "iconSet" } }, ngImport: i0, template: '<span></span>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
59
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "17.3.12", type: IconComponent, isStandalone: true, selector: "odx-icon", inputs: { inline: ["inline", "inline", booleanAttribute], size: "size", name: "name", iconSet: ["iconSet", "iconSet", (value) => (isIconSet(value) ? value : null)], identifier: "identifier" }, host: { attributes: { "translate": "no" }, properties: { "class.notranslate": "true", "attr.data-icon-name": "name", "attr.data-icon-set": "iconSet" } }, ngImport: i0, template: '<span></span>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
60
60
|
};
|
|
61
61
|
__decorate([
|
|
62
62
|
CSSModifier(),
|
|
@@ -93,8 +93,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
93
93
|
}], name: [{
|
|
94
94
|
type: Input
|
|
95
95
|
}], iconSet: [{
|
|
96
|
-
type: Input
|
|
96
|
+
type: Input,
|
|
97
|
+
args: [{ transform: (value) => (isIconSet(value) ? value : null) }]
|
|
97
98
|
}], identifier: [{
|
|
98
99
|
type: Input
|
|
99
100
|
}] } });
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY29tcG9uZW50cy9pY29uL3NyYy9saWIvaWNvbi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9HLE9BQU8sRUFBRSxZQUFZLEVBQUUsV0FBVyxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxTQUFTLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDNUQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBVyxRQUFRLEVBQUUsTUFBTSxVQUFVLENBQUM7O0FBRTdDOzs7Ozs7R0FNRztBQWVJLElBQU0sYUFBYSxHQUFuQixNQUFNLGFBQWE7SUFBbkI7UUFDVyxZQUFPLEdBQUcsYUFBYSxFQUFFLENBQUM7UUFFMUM7Ozs7O1dBS0c7UUFHSSxXQUFNLEdBQUcsS0FBSyxDQUFDO1FBRXRCOzs7OztXQUtHO1FBR0ksU0FBSSxHQUFhLFFBQVEsQ0FBQyxNQUFNLENBQUM7UUFFeEM7Ozs7O1dBS0c7UUFFSSxTQUFJLEdBQWtCLElBQUksQ0FBQztRQUVsQzs7OztXQUlHO1FBRUksWUFBTyxHQUFtQixnQkFBZ0IsRUFBRSxDQUFDLGNBQWMsQ0FBQztLQWNwRTtJQVpDOzs7OztPQUtHO0lBQ0gsSUFDVyxVQUFVLENBQUMsS0FBZ0M7UUFDcEQsTUFBTSxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsR0FBRyxLQUFLLENBQUMsQ0FBQyxDQUFDLG9CQUFvQixDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztRQUMzRSxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztRQUNqQixJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztJQUN6QixDQUFDOytHQW5EVSxhQUFhO21HQUFiLGFBQWEsbUZBVUosZ0JBQWdCLCtEQTJCaEIsQ0FBQyxLQUFhLEVBQUUsRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxpTkFoRDlELGVBQWU7O0FBc0JsQjtJQUZOLFdBQVcsRUFBRTs7NkNBRVE7QUFVZjtJQUZOLFdBQVcsRUFBRTs7MkNBRTBCO0FBckI3QixhQUFhO0lBZHpCLFlBQVksQ0FBQyxNQUFNLENBQUM7R0FjUixhQUFhLENBb0R6Qjs7NEZBcERZLGFBQWE7a0JBYnpCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLFVBQVU7b0JBQ3BCLFFBQVEsRUFBRSxlQUFlO29CQUN6QixhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTtvQkFDckMsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07b0JBQy9DLFVBQVUsRUFBRSxJQUFJO29CQUNoQixJQUFJLEVBQUU7d0JBQ0oscUJBQXFCLEVBQUUsTUFBTTt3QkFDN0IsdUJBQXVCLEVBQUUsTUFBTTt3QkFDL0Isc0JBQXNCLEVBQUUsU0FBUzt3QkFDakMsU0FBUyxFQUFFLElBQUk7cUJBQ2hCO2lCQUNGOzhCQVlRLE1BQU07c0JBRFosS0FBSzt1QkFBQyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRTtnQkFXL0IsSUFBSTtzQkFEVixLQUFLO2dCQVVDLElBQUk7c0JBRFYsS0FBSztnQkFTQyxPQUFPO3NCQURiLEtBQUs7dUJBQUMsRUFBRSxTQUFTLEVBQUUsQ0FBQyxLQUFhLEVBQUUsRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxFQUFFO2dCQVUvRCxVQUFVO3NCQURwQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYm9vbGVhbkF0dHJpYnV0ZSwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDU1NDb21wb25lbnQsIENTU01vZGlmaWVyIH0gZnJvbSAnQG9keC9hbmd1bGFyL2ludGVybmFsJztcbmltcG9ydCB7IGluamVjdEVsZW1lbnQgfSBmcm9tICdAb2R4L2FuZ3VsYXIvdXRpbHMnO1xuaW1wb3J0IHsgaXNJY29uU2V0LCB1bnBhY2tJY29uSWRlbnRpZmllciB9IGZyb20gJy4vaGVscGVycyc7XG5pbXBvcnQgeyBpbmplY3RJY29uQ29uZmlnIH0gZnJvbSAnLi9pY29uLmNvbmZpZyc7XG5pbXBvcnQgeyBJY29uU2V0LCBJY29uU2l6ZSB9IGZyb20gJy4vbW9kZWxzJztcblxuLyoqXG4gKiBSZXByZXNlbnRzIGFuIGljb24gY29tcG9uZW50IHRoYXQgY2FuIGR5bmFtaWNhbGx5IGRpc3BsYXkgdmFyaW91cyBpY29ucyBiYXNlZCBvbiBpbnB1dCBwcm9wZXJ0aWVzLiBUaGlzIGNvbXBvbmVudFxuICogbGV2ZXJhZ2VzIENTUyBmb3Igc3R5bGluZyBhbmQgaXMgZGVzaWduZWQgdG8gYmUgZWFzaWx5IGVtYmVkZGVkIHdpdGhpbiBvdGhlciBjb21wb25lbnRzIGFuZCB2aWV3cy5cbiAqXG4gKiBJdCBhbGxvd3MgZm9yIHNwZWNpZnlpbmcgaWNvbiBzZXRzIGFuZCBpbmRpdmlkdWFsIGljb24gbmFtZXMsIHN1cHBvcnRpbmcgZmxleGlibGUgdXNhZ2UgYWNyb3NzIGRpZmZlcmVudCBjb250ZXh0c1xuICogYW5kIHRoZW1lcy4gVGhlIGNvbXBvbmVudCBpcyBhbHNvIG9wdGltaXplZCBmb3IgcGVyZm9ybWFuY2Ugd2l0aCBBbmd1bGFyJ3MgT25QdXNoIGNoYW5nZSBkZXRlY3Rpb24gc3RyYXRlZ3kuXG4gKi9cbkBDU1NDb21wb25lbnQoJ2ljb24nKVxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnb2R4LWljb24nLFxuICB0ZW1wbGF0ZTogJzxzcGFuPjwvc3Bhbj4nLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaG9zdDoge1xuICAgICdbY2xhc3Mubm90cmFuc2xhdGVdJzogJ3RydWUnLFxuICAgICdbYXR0ci5kYXRhLWljb24tbmFtZV0nOiAnbmFtZScsXG4gICAgJ1thdHRyLmRhdGEtaWNvbi1zZXRdJzogJ2ljb25TZXQnLFxuICAgIHRyYW5zbGF0ZTogJ25vJyxcbiAgfSxcbn0pXG5leHBvcnQgY2xhc3MgSWNvbkNvbXBvbmVudCB7XG4gIHB1YmxpYyByZWFkb25seSBlbGVtZW50ID0gaW5qZWN0RWxlbWVudCgpO1xuXG4gIC8qKlxuICAgKiBEZXRlcm1pbmVzIHdoZXRoZXIgdGhlIGljb24gc2hvdWxkIGJlIGRpc3BsYXllZCBpbmxpbmUgd2l0aCB0ZXh0IG9yIG90aGVyIGVsZW1lbnRzLlxuICAgKlxuICAgKiBAdHlwZSB7Ym9vbGVhbn1cbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIEBDU1NNb2RpZmllcigpXG4gIEBJbnB1dCh7IHRyYW5zZm9ybTogYm9vbGVhbkF0dHJpYnV0ZSB9KVxuICBwdWJsaWMgaW5saW5lID0gZmFsc2U7XG5cbiAgLyoqXG4gICAqIFNwZWNpZmllcyB0aGUgc2l6ZSBvZiB0aGUgaWNvbiwgd2hpY2ggY2FuIGJlIGFkanVzdGVkIHVzaW5nIHByZWRlZmluZWQgc2l6ZXMgZnJvbSB0aGUgSWNvblNpemUgZW51bS5cbiAgICpcbiAgICogQHR5cGUge0ljb25TaXplfVxuICAgKiBAZGVmYXVsdCBJY29uU2l6ZS5NRURJVU1cbiAgICovXG4gIEBDU1NNb2RpZmllcigpXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBzaXplOiBJY29uU2l6ZSA9IEljb25TaXplLk1FRElVTTtcblxuICAvKipcbiAgICogVGhlIG5hbWUgb2YgdGhlIGljb24gdG8gYmUgZGlzcGxheWVkLCB3aGljaCBjb3JyZXNwb25kcyB0byBzcGVjaWZpYyBpY29ucyB3aXRoaW4gYSBnaXZlbiBpY29uIHNldC5cbiAgICpcbiAgICogQHR5cGUge3N0cmluZyB8IG51bGx9XG4gICAqIEBkZWZhdWx0IG51bGxcbiAgICovXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBuYW1lOiBzdHJpbmcgfCBudWxsID0gbnVsbDtcblxuICAvKipcbiAgICogU3BlY2lmaWVzIHRoZSBpY29uIHNldCB0aGF0IHRoZSBpY29uIGJlbG9uZ3MgdG8uIFRoZSBkZWZhdWx0IHNldCBjYW4gYmUgaW5qZWN0ZWQgZnJvbSB0aGUgaWNvbiBjb25maWd1cmF0aW9uLlxuICAgKlxuICAgKiBAdHlwZSB7SWNvblNldCB8IG51bGx9XG4gICAqL1xuICBASW5wdXQoeyB0cmFuc2Zvcm06ICh2YWx1ZTogc3RyaW5nKSA9PiAoaXNJY29uU2V0KHZhbHVlKSA/IHZhbHVlIDogbnVsbCkgfSlcbiAgcHVibGljIGljb25TZXQ6IEljb25TZXQgfCBudWxsID0gaW5qZWN0SWNvbkNvbmZpZygpLmRlZmF1bHRJY29uU2V0O1xuXG4gIC8qKlxuICAgKiBBbGxvd3MgZm9yIHNldHRpbmcgYm90aCB0aGUgaWNvbiBzZXQgYW5kIGljb24gbmFtZSB2aWEgYSBzaW5nbGUgaWRlbnRpZmllciwgdHlwaWNhbGx5IGZvcm1hdHRlZCBhcyAnc2V0OjpuYW1lJy5cbiAgICogVW5wYWNraW5nIHRoaXMgaWRlbnRpZmllciBzZXRzIGJvdGggYG5hbWVgIGFuZCBgaWNvblNldGAgcHJvcGVydGllcy5cbiAgICpcbiAgICogQHBhcmFtIHtzdHJpbmcgfCBudWxsIHwgdW5kZWZpbmVkfSB2YWx1ZSAtIFRoZSBpZGVudGlmaWVyIHRvIHVucGFjay5cbiAgICovXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBzZXQgaWRlbnRpZmllcih2YWx1ZTogc3RyaW5nIHwgbnVsbCB8IHVuZGVmaW5lZCkge1xuICAgIGNvbnN0IFtpY29uU2V0LCBuYW1lXSA9IHZhbHVlID8gdW5wYWNrSWNvbklkZW50aWZpZXIodmFsdWUpIDogW251bGwsIG51bGxdO1xuICAgIHRoaXMubmFtZSA9IG5hbWU7XG4gICAgdGhpcy5pY29uU2V0ID0gaWNvblNldDtcbiAgfVxufVxuIl19
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { createConfigTokens } from '@odx/angular/utils';
|
|
2
|
+
import { IconSet } from './models';
|
|
2
3
|
/**
|
|
3
4
|
* Utility functions generated to handle the injection and provision of the `IconConfig`.
|
|
4
5
|
* These include tokens and functions for accessing and providing icon configurations.
|
|
@@ -19,6 +20,6 @@ import { createConfigTokens } from '@odx/angular/utils';
|
|
|
19
20
|
* ```
|
|
20
21
|
*/
|
|
21
22
|
export const { IconConfig, IconDefaultConfig, injectIconConfig, provideIconConfig } = createConfigTokens('Icon', '@odx/angular/components/icon', {
|
|
22
|
-
defaultIconSet:
|
|
23
|
+
defaultIconSet: IconSet.CORE,
|
|
23
24
|
});
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY29tcG9uZW50cy9pY29uL3NyYy9saWIvaWNvbi5jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDeEQsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLFVBQVUsQ0FBQztBQWFuQzs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBa0JHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sRUFBRSxVQUFVLEVBQUUsaUJBQWlCLEVBQUUsZ0JBQWdCLEVBQUUsaUJBQWlCLEVBQUUsR0FBRyxrQkFBa0IsQ0FBQyxNQUFNLEVBQUUsOEJBQThCLEVBQUU7SUFDL0ksY0FBYyxFQUFFLE9BQU8sQ0FBQyxJQUFJO0NBQ2YsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3JlYXRlQ29uZmlnVG9rZW5zIH0gZnJvbSAnQG9keC9hbmd1bGFyL3V0aWxzJztcbmltcG9ydCB7IEljb25TZXQgfSBmcm9tICcuL21vZGVscyc7XG5cbi8qKlxuICogUmVwcmVzZW50cyB0aGUgY29uZmlndXJhdGlvbiBvcHRpb25zIGZvciBpY29ucyBpbiB0aGUgYXBwbGljYXRpb24sIHNwZWNpZnlpbmcgZGVmYXVsdHNcbiAqIGFuZCBjb25maWd1cmF0aW9ucyBmb3IgdGhlIGljb24gY29tcG9uZW50cyB1c2VkIGFjcm9zcyB0aGUgc3lzdGVtLlxuICpcbiAqIEB0eXBlZGVmIHtPYmplY3R9IEljb25Db25maWdcbiAqIEBwcm9wZXJ0eSB7SWNvblNldH0gZGVmYXVsdEljb25TZXQgLSBUaGUgZGVmYXVsdCBzZXQgb2YgaWNvbnMgdG8gdXNlIGlmIG5vIHNwZWNpZmljIHNldCBpcyBwcm92aWRlZC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJY29uQ29uZmlnIHtcbiAgZGVmYXVsdEljb25TZXQ6IEljb25TZXQ7XG59XG5cbi8qKlxuICogVXRpbGl0eSBmdW5jdGlvbnMgZ2VuZXJhdGVkIHRvIGhhbmRsZSB0aGUgaW5qZWN0aW9uIGFuZCBwcm92aXNpb24gb2YgdGhlIGBJY29uQ29uZmlnYC5cbiAqIFRoZXNlIGluY2x1ZGUgdG9rZW5zIGFuZCBmdW5jdGlvbnMgZm9yIGFjY2Vzc2luZyBhbmQgcHJvdmlkaW5nIGljb24gY29uZmlndXJhdGlvbnMuXG4gKlxuICogLSBgSWNvbkNvbmZpZ2A6IEEgdHlwZSByZXByZXNlbnRpbmcgdGhlIHNoYXBlIG9mIHRoZSBpY29uIGNvbmZpZ3VyYXRpb24gb2JqZWN0LlxuICogLSBgSWNvbkRlZmF1bHRDb25maWdgOiBUaGUgZGVmYXVsdCBjb25maWd1cmF0aW9uIHdoaWNoIHNldHMgJ2NvcmUnIGFzIHRoZSBkZWZhdWx0IGljb24gc2V0LlxuICogLSBgaW5qZWN0SWNvbkNvbmZpZ2A6IEEgZnVuY3Rpb24gdG8gaW5qZWN0IHRoZSBpY29uIGNvbmZpZ3VyYXRpb24sIHVzYWJsZSBpbiBBbmd1bGFyIGNvbXBvbmVudHMgb3Igc2VydmljZXMuXG4gKiAtIGBwcm92aWRlSWNvbkNvbmZpZ2A6IEEgZnVuY3Rpb24gdG8gcHJvdmlkZSB0aGUgaWNvbiBjb25maWd1cmF0aW9uLCB0eXBpY2FsbHkgdXNlZCBpbiBBbmd1bGFyIG1vZHVsZSBwcm92aWRlcnMuXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHRzXG4gKiAvLyBUbyBpbmplY3QgaWNvbiBjb25maWd1cmF0aW9uIGluIGEgY29tcG9uZW50IG9yIHNlcnZpY2VcbiAqIGNvbnN0IGNvbmZpZyA9IGluamVjdEljb25Db25maWcoKTtcbiAqIGNvbnNvbGUubG9nKGNvbmZpZy5kZWZhdWx0SWNvblNldCk7IC8vIE91dHB1dHM6ICdjb3JlJ1xuICpcbiAqIC8vIFRvIHByb3ZpZGUgaWNvbiBjb25maWd1cmF0aW9uIGluIGEgbW9kdWxlXG4gKiBwcm92aWRlSWNvbkNvbmZpZyh7IGRlZmF1bHRJY29uU2V0OiAnY3VzdG9tJyB9KTtcbiAqIGBgYFxuICovXG5leHBvcnQgY29uc3QgeyBJY29uQ29uZmlnLCBJY29uRGVmYXVsdENvbmZpZywgaW5qZWN0SWNvbkNvbmZpZywgcHJvdmlkZUljb25Db25maWcgfSA9IGNyZWF0ZUNvbmZpZ1Rva2VucygnSWNvbicsICdAb2R4L2FuZ3VsYXIvY29tcG9uZW50cy9pY29uJywge1xuICBkZWZhdWx0SWNvblNldDogSWNvblNldC5DT1JFLFxufSBhcyBJY29uQ29uZmlnKTtcbiJdfQ==
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export const IconSet = {
|
|
2
|
+
CORE: 'core',
|
|
3
|
+
MEDICAL: 'medical',
|
|
4
|
+
SAFETY: 'safety',
|
|
5
|
+
UIB_LEGACY: 'uib-legacy',
|
|
6
|
+
};
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi1zZXQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY29tcG9uZW50cy9pY29uL3NyYy9saWIvbW9kZWxzL2ljb24tc2V0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRztJQUNyQixJQUFJLEVBQUUsTUFBTTtJQUNaLE9BQU8sRUFBRSxTQUFTO0lBQ2xCLE1BQU0sRUFBRSxRQUFRO0lBQ2hCLFVBQVUsRUFBRSxZQUFZO0NBQ2hCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBJY29uU2V0ID0gKHR5cGVvZiBJY29uU2V0KVtrZXlvZiB0eXBlb2YgSWNvblNldF07XG5cbmV4cG9ydCBjb25zdCBJY29uU2V0ID0ge1xuICBDT1JFOiAnY29yZScsXG4gIE1FRElDQUw6ICdtZWRpY2FsJyxcbiAgU0FGRVRZOiAnc2FmZXR5JyxcbiAgVUlCX0xFR0FDWTogJ3VpYi1sZWdhY3knLFxufSBhcyBjb25zdDtcbiJdfQ==
|
|
@@ -1,2 +1,3 @@
|
|
|
1
|
+
export * from './icon-set';
|
|
1
2
|
export * from './icon-size';
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY29tcG9uZW50cy9pY29uL3NyYy9saWIvbW9kZWxzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9pY29uLXNldCc7XG5leHBvcnQgKiBmcm9tICcuL2ljb24tc2l6ZSc7XG4iXX0=
|