@odx/angular 6.4.0 → 6.6.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 +16 -0
- package/components/calendar/lib/calendar.config.d.ts +1 -1
- package/components/card/lib/card.component.d.ts +11 -4
- package/components/card/lib/card.config.d.ts +43 -0
- package/components/card/lib/card.module.d.ts +6 -10
- package/components/card/lib/components/card-image/card-image.component.d.ts +26 -0
- package/components/card/lib/components/index.d.ts +1 -0
- package/components/card/lib/directives/card-content.directive.d.ts +1 -1
- package/components/card/lib/directives/index.d.ts +0 -1
- package/components/card/lib/models/card-variant.d.ts +1 -0
- package/components/header/lib/header.component.d.ts +1 -1
- package/components/search-bar/README.md +3 -0
- package/components/search-bar/index.d.ts +3 -0
- package/components/search-bar/lib/search-bar-control.directive.d.ts +8 -0
- package/components/search-bar/lib/search-bar.component.d.ts +8 -0
- package/components/search-bar/lib/search-bar.module.d.ts +9 -0
- package/esm2022/components/calendar/lib/calendar.config.mjs +2 -2
- package/esm2022/components/card/lib/card.component.mjs +13 -8
- package/esm2022/components/card/lib/card.config.mjs +24 -0
- package/esm2022/components/card/lib/card.module.mjs +7 -38
- package/esm2022/components/card/lib/components/card-image/card-image.component.mjs +56 -0
- package/esm2022/components/card/lib/components/index.mjs +2 -1
- package/esm2022/components/card/lib/directives/card-content.directive.mjs +3 -3
- package/esm2022/components/card/lib/directives/index.mjs +1 -2
- package/esm2022/components/card/lib/models/card-variant.mjs +2 -1
- package/esm2022/components/header/lib/header.component.mjs +3 -3
- package/esm2022/components/search-bar/index.mjs +4 -0
- package/esm2022/components/search-bar/lib/search-bar-control.directive.mjs +21 -0
- package/esm2022/components/search-bar/lib/search-bar.component.mjs +17 -0
- package/esm2022/components/search-bar/lib/search-bar.module.mjs +19 -0
- package/esm2022/components/search-bar/odx-angular-components-search-bar.mjs +5 -0
- package/fesm2022/odx-angular-components-calendar.mjs +1 -1
- package/fesm2022/odx-angular-components-calendar.mjs.map +1 -1
- package/fesm2022/odx-angular-components-card.mjs +99 -68
- package/fesm2022/odx-angular-components-card.mjs.map +1 -1
- package/fesm2022/odx-angular-components-header.mjs +2 -2
- package/fesm2022/odx-angular-components-header.mjs.map +1 -1
- package/fesm2022/odx-angular-components-search-bar.mjs +58 -0
- package/fesm2022/odx-angular-components-search-bar.mjs.map +1 -0
- package/package.json +7 -1
- package/components/card/lib/directives/card-title.directive.d.ts +0 -8
- package/esm2022/components/card/lib/directives/card-title.directive.mjs +0 -20
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,21 @@
|
|
|
1
1
|
# @odx/angular
|
|
2
2
|
|
|
3
|
+
## 6.6.0
|
|
4
|
+
|
|
5
|
+
### Minor Changes
|
|
6
|
+
|
|
7
|
+
- 61c967c: new search bar component
|
|
8
|
+
|
|
9
|
+
## 6.5.0
|
|
10
|
+
|
|
11
|
+
### Minor Changes
|
|
12
|
+
|
|
13
|
+
- bb425b3: New image-card variant for card component
|
|
14
|
+
|
|
15
|
+
### Patch Changes
|
|
16
|
+
|
|
17
|
+
- d9b77c1: new options in storybook for rail navigation
|
|
18
|
+
|
|
3
19
|
## 6.4.0
|
|
4
20
|
|
|
5
21
|
### Minor Changes
|
|
@@ -57,7 +57,7 @@ export interface CalendarConfig {
|
|
|
57
57
|
* providers: [provideCalendarConfig({ selectionMode: CalendarSelectionMode.DateRange, locale: new BehaviorSubject<Locale>(deDE)})]
|
|
58
58
|
* })
|
|
59
59
|
* export class MyDateRangepickerComponent {}
|
|
60
|
-
*
|
|
60
|
+
* ```
|
|
61
61
|
*
|
|
62
62
|
* @example
|
|
63
63
|
* ```ts
|
|
@@ -14,18 +14,25 @@ import * as i1 from "@odx/angular/cdk/a11y";
|
|
|
14
14
|
export declare class CardComponent {
|
|
15
15
|
private readonly interactiveDirective;
|
|
16
16
|
private readonly takeUntilDestroyed;
|
|
17
|
+
private readonly config;
|
|
18
|
+
protected cardVariant: {
|
|
19
|
+
readonly DEFAULT: "default";
|
|
20
|
+
readonly LAUNCH_TILE: "launch-tile";
|
|
21
|
+
readonly LAUNCH_TILE_CENTERED: "launch-tile-centered";
|
|
22
|
+
readonly IMAGE_CARD: "image-card";
|
|
23
|
+
};
|
|
17
24
|
protected readonly menu?: MenuComponent;
|
|
18
25
|
protected readonly buttons?: ActionGroupComponent;
|
|
19
26
|
protected readonly menuHost?: MenuDirective;
|
|
20
27
|
protected readonly footer?: ElementRef<HTMLElement>;
|
|
21
|
-
|
|
28
|
+
element: ElementRef<HTMLElement>;
|
|
22
29
|
/**
|
|
23
30
|
* The variant of the card.
|
|
24
31
|
*
|
|
25
32
|
* @type {CardVariant}
|
|
26
33
|
* @default CardVariant.DEFAULT
|
|
27
34
|
*/
|
|
28
|
-
variant
|
|
35
|
+
variant: CardVariant;
|
|
29
36
|
/**
|
|
30
37
|
* Menu icon name.
|
|
31
38
|
*
|
|
@@ -39,9 +46,9 @@ export declare class CardComponent {
|
|
|
39
46
|
* @emits {Event}
|
|
40
47
|
*/
|
|
41
48
|
interact: EventEmitter<Event>;
|
|
49
|
+
get launchTile(): boolean;
|
|
42
50
|
constructor();
|
|
43
|
-
protected get launchTile(): boolean;
|
|
44
51
|
private stopEvents;
|
|
45
52
|
static ɵfac: i0.ɵɵFactoryDeclaration<CardComponent, never>;
|
|
46
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<CardComponent, "odx-card", never, { "variant": { "alias": "variant"; "required": false; }; "menuIcon": { "alias": "menuIcon"; "required": false; }; }, { "interact": "interact"; }, ["menu", "buttons", "footer"], ["odx-
|
|
53
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CardComponent, "odx-card", never, { "variant": { "alias": "variant"; "required": false; }; "menuIcon": { "alias": "menuIcon"; "required": false; }; }, { "interact": "interact"; }, ["menu", "buttons", "footer"], ["odx-card-image", "[odxCardContent], odx-card-content", "odx-avatar", "odx-launch-card-subtitle", "odx-card-footer", "odx-menu", "*", "odx-action-group"], true, [{ directive: typeof i1.InteractiveDirective; inputs: {}; outputs: {}; }]>;
|
|
47
54
|
}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { CardVariant } from './models';
|
|
2
|
+
export interface CardConfig {
|
|
3
|
+
variant?: CardVariant;
|
|
4
|
+
maxImageHeight?: string;
|
|
5
|
+
imageRatio?: string;
|
|
6
|
+
}
|
|
7
|
+
/**
|
|
8
|
+
* Tools for customizing configuration for the card component
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* ```ts
|
|
12
|
+
* @Component({
|
|
13
|
+
* ...
|
|
14
|
+
* providers: [provideCardConfig({imageRatio: '5/3', maxImageHeight: '200px'})]
|
|
15
|
+
* })
|
|
16
|
+
* export class MyCardComponent {}
|
|
17
|
+
* ```
|
|
18
|
+
* @example
|
|
19
|
+
* ```ts
|
|
20
|
+
* constructor(@Inject(CardConfig) private readonly cardConfig: CardConfig) {}
|
|
21
|
+
* ```
|
|
22
|
+
*/
|
|
23
|
+
export declare const CardConfig: import("@angular/core").InjectionToken<Partial<{
|
|
24
|
+
variant: CardVariant;
|
|
25
|
+
maxImageHeight: string;
|
|
26
|
+
imageRatio: string;
|
|
27
|
+
}>>, CardDefaultConfig: {
|
|
28
|
+
variant: CardVariant;
|
|
29
|
+
maxImageHeight: string;
|
|
30
|
+
imageRatio: string;
|
|
31
|
+
}, injectCardConfig: () => {
|
|
32
|
+
variant: CardVariant;
|
|
33
|
+
maxImageHeight: string;
|
|
34
|
+
imageRatio: string;
|
|
35
|
+
}, provideCardConfig: <D extends import("@odx/angular/utils").ConfigDependencies<unknown> = import("@odx/angular/utils").ConfigDependencies<Partial<{
|
|
36
|
+
variant: CardVariant;
|
|
37
|
+
maxImageHeight: string;
|
|
38
|
+
imageRatio: string;
|
|
39
|
+
}>>>(config: import("@odx/angular/utils").ConfigProvider<Partial<{
|
|
40
|
+
variant: CardVariant;
|
|
41
|
+
maxImageHeight: string;
|
|
42
|
+
imageRatio: string;
|
|
43
|
+
}>, D>) => import("@angular/core").FactoryProvider | import("@angular/core").ValueProvider;
|
|
@@ -1,16 +1,12 @@
|
|
|
1
1
|
import * as i0 from "@angular/core";
|
|
2
2
|
import * as i1 from "./card.component";
|
|
3
|
-
import * as i2 from "./
|
|
4
|
-
import * as i3 from "./
|
|
5
|
-
import * as i4 from "./components/card-
|
|
6
|
-
import * as i5 from "./
|
|
7
|
-
import * as i6 from "@odx/angular
|
|
8
|
-
import * as i7 from "@odx/angular/components/button";
|
|
9
|
-
import * as i8 from "@odx/angular/components/icon";
|
|
10
|
-
import * as i9 from "@odx/angular";
|
|
11
|
-
import * as i10 from "@odx/angular/components/menu";
|
|
3
|
+
import * as i2 from "./components/card-footer/card-footer.component";
|
|
4
|
+
import * as i3 from "./components/card-image/card-image.component";
|
|
5
|
+
import * as i4 from "./components/launch-card-subtitle/launch-card-subtitle.component";
|
|
6
|
+
import * as i5 from "./directives/card-content.directive";
|
|
7
|
+
import * as i6 from "@odx/angular";
|
|
12
8
|
export declare class CardModule {
|
|
13
9
|
static ɵfac: i0.ɵɵFactoryDeclaration<CardModule, never>;
|
|
14
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<CardModule, never, [typeof i1.CardComponent, typeof i2.
|
|
10
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<CardModule, never, [typeof i1.CardComponent, typeof i2.CardFooterComponent, typeof i3.CardImageComponent, typeof i4.LaunchCardSubtitleComponent, typeof i5.CardContentDirective], [typeof i6.CoreModule, typeof i1.CardComponent, typeof i2.CardFooterComponent, typeof i3.CardImageComponent, typeof i4.LaunchCardSubtitleComponent, typeof i5.CardContentDirective]>;
|
|
15
11
|
static ɵinj: i0.ɵɵInjectorDeclaration<CardModule>;
|
|
16
12
|
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
/**
|
|
3
|
+
* Represents a card image component.
|
|
4
|
+
*/
|
|
5
|
+
export declare class CardImageComponent {
|
|
6
|
+
private readonly config;
|
|
7
|
+
readonly element: import("@angular/core").ElementRef<HTMLElement>;
|
|
8
|
+
/**
|
|
9
|
+
* The ratio of the card image.
|
|
10
|
+
*
|
|
11
|
+
* @type {string}
|
|
12
|
+
* @default 'auto'
|
|
13
|
+
*/
|
|
14
|
+
imageRatio: string;
|
|
15
|
+
/**
|
|
16
|
+
* The maximum height of the card image.
|
|
17
|
+
*
|
|
18
|
+
* @type {string}
|
|
19
|
+
* @default 'auto'
|
|
20
|
+
*/
|
|
21
|
+
maxImageHeight: string;
|
|
22
|
+
protected get getMaxImageHeight(): string;
|
|
23
|
+
protected get getImageAspectRatio(): string;
|
|
24
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<CardImageComponent, never>;
|
|
25
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CardImageComponent, "odx-card-image", never, { "imageRatio": { "alias": "imageRatio"; "required": false; }; "maxImageHeight": { "alias": "maxImageHeight"; "required": false; }; }, {}, never, ["odx-chip", "img"], true, never>;
|
|
26
|
+
}
|
|
@@ -4,5 +4,5 @@ import * as i0 from "@angular/core";
|
|
|
4
4
|
*/
|
|
5
5
|
export declare class CardContentDirective {
|
|
6
6
|
static ɵfac: i0.ɵɵFactoryDeclaration<CardContentDirective, never>;
|
|
7
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<CardContentDirective, "[odxCardContent]", never, {}, {}, never, never, true, never>;
|
|
7
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<CardContentDirective, "[odxCardContent], odx-card-content", never, {}, {}, never, never, true, never>;
|
|
8
8
|
}
|
|
@@ -5,5 +5,5 @@ import * as i0 from "@angular/core";
|
|
|
5
5
|
export declare class HeaderComponent {
|
|
6
6
|
readonly element: import("@angular/core").ElementRef<HTMLElement>;
|
|
7
7
|
static ɵfac: i0.ɵɵFactoryDeclaration<HeaderComponent, never>;
|
|
8
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<HeaderComponent, "odx-header", never, {}, {}, never, ["button[odxMainMenuButton]", "odx-header-title", "*", "odx-action-group, odx-auth", "[odxHeaderAvatar]"], true, never>;
|
|
8
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<HeaderComponent, "odx-header", never, {}, {}, never, ["button[odxMainMenuButton]", "odx-header-title", "*", "odx-search-bar", "odx-action-group, odx-auth", "[odxHeaderAvatar]"], true, never>;
|
|
9
9
|
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
/**
|
|
3
|
+
* Directive for search bar component input.
|
|
4
|
+
*/
|
|
5
|
+
export declare class SearchBarControlDirective {
|
|
6
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<SearchBarControlDirective, never>;
|
|
7
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<SearchBarControlDirective, "input[odxSearchBarControl]", never, {}, {}, never, never, true, never>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
/**
|
|
3
|
+
* Component for displaying the search input.
|
|
4
|
+
*/
|
|
5
|
+
export declare class SearchBarComponent {
|
|
6
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<SearchBarComponent, never>;
|
|
7
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<SearchBarComponent, "odx-search-bar", never, {}, {}, never, ["input[odxSearchBarControl]"], true, never>;
|
|
8
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
import * as i1 from "./search-bar-control.directive";
|
|
3
|
+
import * as i2 from "./search-bar.component";
|
|
4
|
+
import * as i3 from "@odx/angular";
|
|
5
|
+
export declare class SearchBarModule {
|
|
6
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<SearchBarModule, never>;
|
|
7
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<SearchBarModule, never, [typeof i1.SearchBarControlDirective, typeof i2.SearchBarComponent], [typeof i3.CoreModule, typeof i1.SearchBarControlDirective, typeof i2.SearchBarComponent]>;
|
|
8
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<SearchBarModule>;
|
|
9
|
+
}
|
|
@@ -10,7 +10,7 @@ import { CalendarSelectionMode } from './models/selection-mode';
|
|
|
10
10
|
* providers: [provideCalendarConfig({ selectionMode: CalendarSelectionMode.DateRange, locale: new BehaviorSubject<Locale>(deDE)})]
|
|
11
11
|
* })
|
|
12
12
|
* export class MyDateRangepickerComponent {}
|
|
13
|
-
*
|
|
13
|
+
* ```
|
|
14
14
|
*
|
|
15
15
|
* @example
|
|
16
16
|
* ```ts
|
|
@@ -28,4 +28,4 @@ export const { CalendarConfig, CalendarDefaultConfig, injectCalendarConfig, prov
|
|
|
28
28
|
padding: 100,
|
|
29
29
|
},
|
|
30
30
|
});
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIuY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL2NvbXBvbmVudHMvY2FsZW5kYXIvc3JjL2xpYi9jYWxlbmRhci5jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDeEQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUErQ2hFOzs7Ozs7Ozs7Ozs7Ozs7O0dBZ0JHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sRUFBRSxjQUFjLEVBQUUscUJBQXFCLEVBQUUsb0JBQW9CLEVBQUUscUJBQXFCLEVBQUUsR0FBRyxrQkFBa0IsQ0FDdEgsVUFBVSxFQUNWLGtDQUFrQyxFQUNsQztJQUNFLG1CQUFtQixFQUFFLElBQUk7SUFDekIsYUFBYSxFQUFFLHFCQUFxQixDQUFDLElBQUk7SUFDekMsUUFBUSxFQUFFO1FBQ1IsV0FBVyxFQUFFLENBQUM7S0FDZjtJQUNELFNBQVMsRUFBRTtRQUNULFdBQVcsRUFBRSxDQUFDO1FBQ2QsT0FBTyxFQUFFLEdBQUc7S0FDYjtDQUNGLENBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNyZWF0ZUNvbmZpZ1Rva2VucyB9IGZyb20gJ0BvZHgvYW5ndWxhci91dGlscyc7XG5pbXBvcnQgeyBDYWxlbmRhclNlbGVjdGlvbk1vZGUgfSBmcm9tICcuL21vZGVscy9zZWxlY3Rpb24tbW9kZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2FsZW5kYXJDb25maWcge1xuICAvKipcbiAgICogRGlzcGxheXMgdGhlIGFkamFjZW50IGRheXMgaW4gbW9udGggY2FsZW5kYXIgdmlldy5cbiAgICpcbiAgICogQGRlZmF1bHQgdHJ1ZVxuICAgKi9cbiAgZGlzcGxheUFkamFjZW50RGF5czogYm9vbGVhbjtcbiAgLyoqXG4gICAqIFN3aXRjaGVzIGJldHdlZW4gc2luZ2xlIHNlbGVjdGlvbiBhbmQgYSBkYXRlcmFuZ2Ugc2VsZWN0aW9uLlxuICAgKlxuICAgKiBAZGVmYXVsdCBDYWxlbmRhclNlbGVjdGlvbk1vZGUuRGF0ZVxuICAgKi9cbiAgc2VsZWN0aW9uTW9kZTogQ2FsZW5kYXJTZWxlY3Rpb25Nb2RlO1xuXG4gIC8qKlxuICAgKiBDb25maWd1cmF0aW9uIGZvciB0aGUgeWVhciB2aWV3LlxuICAgKlxuICAgKiBAdHlwZWRlZiB7T2JqZWN0fSBZZWFyVmlld0NvbmZpZ1xuICAgKiBAcHJvcGVydHkge251bWJlcn0gaXRlbXNQZXJSb3cgLSBOdW1iZXIgb2YgaXRlbXMgdG8gZGlzcGxheSBwZXIgcm93IGluIHRoZSB5ZWFyIHZpZXcuXG4gICAqIEBkZWZhdWx0IDNcbiAgICovXG4gIC8qKlxuICAgKiBDb25maWd1cmF0aW9uIG9wdGlvbnMgZm9yIHRoZSBjYWxlbmRhcidzIHllYXIgdmlldy5cbiAgICpcbiAgICogQHR5cGUge1llYXJWaWV3Q29uZmlnfVxuICAgKi9cbiAgeWVhclZpZXc6IHsgaXRlbXNQZXJSb3c6IG51bWJlciB9O1xuICAvKipcbiAgICogQ29uZmlndXJhdGlvbiBmb3IgdGhlIHllYXJzIHZpZXcuXG4gICAqXG4gICAqIEB0eXBlZGVmIHtPYmplY3R9IFllYXJzVmlld0NvbmZpZ1xuICAgKiBAcHJvcGVydHkge251bWJlcn0gaXRlbXNQZXJSb3cgLSBOdW1iZXIgb2YgaXRlbXMgdG8gZGlzcGxheSBwZXIgcm93IGluIHRoZSB5ZWFycyB2aWV3LlxuICAgKiBAcHJvcGVydHkge251bWJlcn0gW3BhZGRpbmc9MTAwXSAtIFRoZSBudW1iZXIgb2YgeWVhciBpdGVtcyBiZWZvcmUgYW5kIGFmdGVyIHRoZSBjdXJyZW50IHllYXJcbiAgICogQGRlZmF1bHRcbiAgICogICBpdGVtc1BlclJvdzogMyxcbiAgICogICBwYWRkaW5nOiAxMDBcbiAgICovXG4gIC8qKlxuICAgKiBDb25maWd1cmF0aW9uIG9wdGlvbnMgZm9yIHRoZSBjYWxlbmRhcidzIHllYXJzIHZpZXcuXG4gICAqXG4gICAqIEB0eXBlIHtZZWFyc1ZpZXdDb25maWd9XG4gICAqL1xuICB5ZWFyc1ZpZXc6IHsgaXRlbXNQZXJSb3c6IG51bWJlcjsgcGFkZGluZzogbnVtYmVyIH07XG59XG5cbi8qKlxuICogVG9vbHMgZm9yIGN1c3RvbWl6aW5nIGNvbmZpZ3VyYXRpb24gZm9yIHRoZSBjYWxlbmRhciBjb21wb25lbnRcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHNcbiAqIEBDb21wb25lbnQoe1xuICogIC4uLlxuICogIHByb3ZpZGVyczogW3Byb3ZpZGVDYWxlbmRhckNvbmZpZyh7IHNlbGVjdGlvbk1vZGU6IENhbGVuZGFyU2VsZWN0aW9uTW9kZS5EYXRlUmFuZ2UsIGxvY2FsZTogbmV3IEJlaGF2aW9yU3ViamVjdDxMb2NhbGU+
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIuY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL2NvbXBvbmVudHMvY2FsZW5kYXIvc3JjL2xpYi9jYWxlbmRhci5jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDeEQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUErQ2hFOzs7Ozs7Ozs7Ozs7Ozs7O0dBZ0JHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sRUFBRSxjQUFjLEVBQUUscUJBQXFCLEVBQUUsb0JBQW9CLEVBQUUscUJBQXFCLEVBQUUsR0FBRyxrQkFBa0IsQ0FDdEgsVUFBVSxFQUNWLGtDQUFrQyxFQUNsQztJQUNFLG1CQUFtQixFQUFFLElBQUk7SUFDekIsYUFBYSxFQUFFLHFCQUFxQixDQUFDLElBQUk7SUFDekMsUUFBUSxFQUFFO1FBQ1IsV0FBVyxFQUFFLENBQUM7S0FDZjtJQUNELFNBQVMsRUFBRTtRQUNULFdBQVcsRUFBRSxDQUFDO1FBQ2QsT0FBTyxFQUFFLEdBQUc7S0FDYjtDQUNGLENBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNyZWF0ZUNvbmZpZ1Rva2VucyB9IGZyb20gJ0BvZHgvYW5ndWxhci91dGlscyc7XG5pbXBvcnQgeyBDYWxlbmRhclNlbGVjdGlvbk1vZGUgfSBmcm9tICcuL21vZGVscy9zZWxlY3Rpb24tbW9kZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2FsZW5kYXJDb25maWcge1xuICAvKipcbiAgICogRGlzcGxheXMgdGhlIGFkamFjZW50IGRheXMgaW4gbW9udGggY2FsZW5kYXIgdmlldy5cbiAgICpcbiAgICogQGRlZmF1bHQgdHJ1ZVxuICAgKi9cbiAgZGlzcGxheUFkamFjZW50RGF5czogYm9vbGVhbjtcbiAgLyoqXG4gICAqIFN3aXRjaGVzIGJldHdlZW4gc2luZ2xlIHNlbGVjdGlvbiBhbmQgYSBkYXRlcmFuZ2Ugc2VsZWN0aW9uLlxuICAgKlxuICAgKiBAZGVmYXVsdCBDYWxlbmRhclNlbGVjdGlvbk1vZGUuRGF0ZVxuICAgKi9cbiAgc2VsZWN0aW9uTW9kZTogQ2FsZW5kYXJTZWxlY3Rpb25Nb2RlO1xuXG4gIC8qKlxuICAgKiBDb25maWd1cmF0aW9uIGZvciB0aGUgeWVhciB2aWV3LlxuICAgKlxuICAgKiBAdHlwZWRlZiB7T2JqZWN0fSBZZWFyVmlld0NvbmZpZ1xuICAgKiBAcHJvcGVydHkge251bWJlcn0gaXRlbXNQZXJSb3cgLSBOdW1iZXIgb2YgaXRlbXMgdG8gZGlzcGxheSBwZXIgcm93IGluIHRoZSB5ZWFyIHZpZXcuXG4gICAqIEBkZWZhdWx0IDNcbiAgICovXG4gIC8qKlxuICAgKiBDb25maWd1cmF0aW9uIG9wdGlvbnMgZm9yIHRoZSBjYWxlbmRhcidzIHllYXIgdmlldy5cbiAgICpcbiAgICogQHR5cGUge1llYXJWaWV3Q29uZmlnfVxuICAgKi9cbiAgeWVhclZpZXc6IHsgaXRlbXNQZXJSb3c6IG51bWJlciB9O1xuICAvKipcbiAgICogQ29uZmlndXJhdGlvbiBmb3IgdGhlIHllYXJzIHZpZXcuXG4gICAqXG4gICAqIEB0eXBlZGVmIHtPYmplY3R9IFllYXJzVmlld0NvbmZpZ1xuICAgKiBAcHJvcGVydHkge251bWJlcn0gaXRlbXNQZXJSb3cgLSBOdW1iZXIgb2YgaXRlbXMgdG8gZGlzcGxheSBwZXIgcm93IGluIHRoZSB5ZWFycyB2aWV3LlxuICAgKiBAcHJvcGVydHkge251bWJlcn0gW3BhZGRpbmc9MTAwXSAtIFRoZSBudW1iZXIgb2YgeWVhciBpdGVtcyBiZWZvcmUgYW5kIGFmdGVyIHRoZSBjdXJyZW50IHllYXJcbiAgICogQGRlZmF1bHRcbiAgICogICBpdGVtc1BlclJvdzogMyxcbiAgICogICBwYWRkaW5nOiAxMDBcbiAgICovXG4gIC8qKlxuICAgKiBDb25maWd1cmF0aW9uIG9wdGlvbnMgZm9yIHRoZSBjYWxlbmRhcidzIHllYXJzIHZpZXcuXG4gICAqXG4gICAqIEB0eXBlIHtZZWFyc1ZpZXdDb25maWd9XG4gICAqL1xuICB5ZWFyc1ZpZXc6IHsgaXRlbXNQZXJSb3c6IG51bWJlcjsgcGFkZGluZzogbnVtYmVyIH07XG59XG5cbi8qKlxuICogVG9vbHMgZm9yIGN1c3RvbWl6aW5nIGNvbmZpZ3VyYXRpb24gZm9yIHRoZSBjYWxlbmRhciBjb21wb25lbnRcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHNcbiAqIEBDb21wb25lbnQoe1xuICogIC4uLlxuICogIHByb3ZpZGVyczogW3Byb3ZpZGVDYWxlbmRhckNvbmZpZyh7IHNlbGVjdGlvbk1vZGU6IENhbGVuZGFyU2VsZWN0aW9uTW9kZS5EYXRlUmFuZ2UsIGxvY2FsZTogbmV3IEJlaGF2aW9yU3ViamVjdDxMb2NhbGU+KGRlREUpfSldXG4gKiB9KVxuICogZXhwb3J0IGNsYXNzIE15RGF0ZVJhbmdlcGlja2VyQ29tcG9uZW50IHt9XG4gKiBgYGBcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgdHNcbiAqIGNvbnN0cnVjdG9yKEBJbmplY3QoQ2FsZW5kYXJDb25maWcpIHByaXZhdGUgcmVhZG9ubHkgY2FsZW5kYXJDb25maWc6IENhbGVuZGFyQ29uZmlnKSB7fVxuICogYGBgXG4gKi9cbmV4cG9ydCBjb25zdCB7IENhbGVuZGFyQ29uZmlnLCBDYWxlbmRhckRlZmF1bHRDb25maWcsIGluamVjdENhbGVuZGFyQ29uZmlnLCBwcm92aWRlQ2FsZW5kYXJDb25maWcgfSA9IGNyZWF0ZUNvbmZpZ1Rva2VucyhcbiAgJ0NhbGVuZGFyJyxcbiAgJ0BvZHgvYW5ndWxhci9jb21wb25lbnRzL2NhbGVuZGFyJyxcbiAge1xuICAgIGRpc3BsYXlBZGphY2VudERheXM6IHRydWUsXG4gICAgc2VsZWN0aW9uTW9kZTogQ2FsZW5kYXJTZWxlY3Rpb25Nb2RlLkRhdGUsXG4gICAgeWVhclZpZXc6IHtcbiAgICAgIGl0ZW1zUGVyUm93OiAzLFxuICAgIH0sXG4gICAgeWVhcnNWaWV3OiB7XG4gICAgICBpdGVtc1BlclJvdzogMyxcbiAgICAgIHBhZGRpbmc6IDEwMCxcbiAgICB9LFxuICB9LFxuKTtcbiJdfQ==
|
|
@@ -3,10 +3,12 @@ import { ChangeDetectionStrategy, Component, ContentChild, ElementRef, EventEmit
|
|
|
3
3
|
import { A11yModule, InteractiveDirective } from '@odx/angular/cdk/a11y';
|
|
4
4
|
import { ActionGroupComponent } from '@odx/angular/components/action-group';
|
|
5
5
|
import { ButtonComponent } from '@odx/angular/components/button';
|
|
6
|
+
import { ChipListRowComponent } from '@odx/angular/components/chip';
|
|
6
7
|
import { IconComponent } from '@odx/angular/components/icon';
|
|
7
8
|
import { MenuComponent, MenuDirective, MenuModule } from '@odx/angular/components/menu';
|
|
8
9
|
import { CSSComponent, CSSModifier } from '@odx/angular/internal';
|
|
9
10
|
import { containsElement, injectElement, untilDestroyed } from '@odx/angular/utils';
|
|
11
|
+
import { injectCardConfig } from './card.config';
|
|
10
12
|
import { CardFooterComponent } from './components';
|
|
11
13
|
import { CardVariant } from './models';
|
|
12
14
|
import * as i0 from "@angular/core";
|
|
@@ -21,9 +23,14 @@ import * as i3 from "@odx/angular/components/menu";
|
|
|
21
23
|
* @see {InteractiveDirective}
|
|
22
24
|
*/
|
|
23
25
|
export let CardComponent = class CardComponent {
|
|
26
|
+
get launchTile() {
|
|
27
|
+
return this.variant === CardVariant.LAUNCH_TILE || this.variant === CardVariant.LAUNCH_TILE_CENTERED;
|
|
28
|
+
}
|
|
24
29
|
constructor() {
|
|
25
30
|
this.interactiveDirective = inject(InteractiveDirective, { host: true });
|
|
26
31
|
this.takeUntilDestroyed = untilDestroyed();
|
|
32
|
+
this.config = injectCardConfig();
|
|
33
|
+
this.cardVariant = CardVariant;
|
|
27
34
|
this.element = injectElement();
|
|
28
35
|
/**
|
|
29
36
|
* The variant of the card.
|
|
@@ -31,7 +38,7 @@ export let CardComponent = class CardComponent {
|
|
|
31
38
|
* @type {CardVariant}
|
|
32
39
|
* @default CardVariant.DEFAULT
|
|
33
40
|
*/
|
|
34
|
-
this.variant = CardVariant.DEFAULT;
|
|
41
|
+
this.variant = this.config.variant ?? CardVariant.DEFAULT;
|
|
35
42
|
/**
|
|
36
43
|
* Menu icon name.
|
|
37
44
|
*
|
|
@@ -49,19 +56,17 @@ export let CardComponent = class CardComponent {
|
|
|
49
56
|
this.stopEvents(event);
|
|
50
57
|
});
|
|
51
58
|
}
|
|
52
|
-
get launchTile() {
|
|
53
|
-
return this.variant !== CardVariant.DEFAULT;
|
|
54
|
-
}
|
|
55
59
|
stopEvents(event) {
|
|
56
60
|
const target = event.target;
|
|
57
61
|
const isFooterEvent = containsElement(this.footer?.nativeElement, target, false);
|
|
58
62
|
const isMenuEvent = containsElement(this.menuHost?.element.nativeElement, target);
|
|
59
|
-
|
|
63
|
+
const isHeaderButtonEvent = containsElement(this.buttons?.element.nativeElement, target);
|
|
64
|
+
if (!isFooterEvent && !isMenuEvent && !this.menuHost?.isOpen() && !isHeaderButtonEvent) {
|
|
60
65
|
this.interact.emit(event);
|
|
61
66
|
}
|
|
62
67
|
}
|
|
63
68
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
64
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CardComponent, isStandalone: true, selector: "odx-card", inputs: { variant: "variant", menuIcon: "menuIcon" }, outputs: { interact: "interact" }, queries: [{ propertyName: "menu", first: true, predicate: MenuComponent, descendants: true }, { propertyName: "buttons", first: true, predicate: ActionGroupComponent, descendants: true }, { propertyName: "footer", first: true, predicate: CardFooterComponent, descendants: true, read: ElementRef }], viewQueries: [{ propertyName: "menuHost", first: true, predicate: MenuDirective, descendants: true }], hostDirectives: [{ directive: i1.InteractiveDirective }], ngImport: i0, template: "<div class=\"odx-card__container\"
|
|
69
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CardComponent, isStandalone: true, selector: "odx-card", inputs: { variant: "variant", menuIcon: "menuIcon" }, outputs: { interact: "interact" }, queries: [{ propertyName: "menu", first: true, predicate: MenuComponent, descendants: true }, { propertyName: "buttons", first: true, predicate: ActionGroupComponent, descendants: true }, { propertyName: "footer", first: true, predicate: CardFooterComponent, descendants: true, read: ElementRef }], viewQueries: [{ propertyName: "menuHost", first: true, predicate: MenuDirective, descendants: true }], hostDirectives: [{ directive: i1.InteractiveDirective }], ngImport: i0, template: "<div class=\"odx-card__container\" *ngIf=\"!launchTile; else launchTileTmp\">\n <ng-content select=\"odx-card-image\"></ng-content>\n <div class=\"odx-card__title odx-title-5\">\n <ng-container *ngTemplateOutlet=\"title\"></ng-container>\n </div>\n <ng-content select=\"[odxCardContent], odx-card-content\"></ng-content>\n</div>\n\n<ng-template #launchTileTmp>\n <div class=\"odx-card__container\">\n <ng-content select=\"odx-avatar\"></ng-content>\n <div class=\"odx-card__content\">\n <div class=\"odx-card__title\">\n <ng-container *ngTemplateOutlet=\"title\"></ng-container>\n </div>\n <ng-content select=\"odx-launch-card-subtitle\"></ng-content>\n </div>\n </div>\n</ng-template>\n\n<ng-content select=\"odx-card-footer\"></ng-content>\n\n<odx-action-group *ngIf=\"menu; else buttonGroup\" class=\"odx-card__menu\">\n <button odxButton [odxMenu]=\"menuTpl\" odxMenuPosition=\"bottom-end\">\n <odx-icon [name]=\"menuIcon\" iconSet=\"core\"></odx-icon>\n </button>\n\n <ng-template #menuTpl>\n <ng-content select=\"odx-menu\"></ng-content>\n </ng-template>\n</odx-action-group>\n\n<ng-template #title>\n <ng-content></ng-content>\n</ng-template>\n\n<ng-template #buttonGroup>\n <ng-container *ngIf=\"buttons\">\n <ng-content select=\"odx-action-group\"></ng-content>\n </ng-container>\n</ng-template>\n", dependencies: [{ kind: "ngmodule", type: A11yModule }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { 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"] }, { kind: "ngmodule", type: MenuModule }, { kind: "directive", type: i3.MenuDirective, selector: "[odxMenu]", inputs: ["odxMenu", "odxMenuPosition"], exportAs: ["odxMenu"] }, { kind: "component", type: ActionGroupComponent, selector: "odx-action-group", inputs: ["reverse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
65
70
|
};
|
|
66
71
|
__decorate([
|
|
67
72
|
CSSModifier(),
|
|
@@ -73,7 +78,7 @@ CardComponent = __decorate([
|
|
|
73
78
|
], CardComponent);
|
|
74
79
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CardComponent, decorators: [{
|
|
75
80
|
type: Component,
|
|
76
|
-
args: [{ selector: 'odx-card', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, imports: [A11yModule, ButtonComponent, IconComponent, MenuModule, ActionGroupComponent], hostDirectives: [InteractiveDirective], template: "<div class=\"odx-card__container\"
|
|
81
|
+
args: [{ selector: 'odx-card', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, imports: [A11yModule, ButtonComponent, IconComponent, MenuModule, ActionGroupComponent, ChipListRowComponent], hostDirectives: [InteractiveDirective], template: "<div class=\"odx-card__container\" *ngIf=\"!launchTile; else launchTileTmp\">\n <ng-content select=\"odx-card-image\"></ng-content>\n <div class=\"odx-card__title odx-title-5\">\n <ng-container *ngTemplateOutlet=\"title\"></ng-container>\n </div>\n <ng-content select=\"[odxCardContent], odx-card-content\"></ng-content>\n</div>\n\n<ng-template #launchTileTmp>\n <div class=\"odx-card__container\">\n <ng-content select=\"odx-avatar\"></ng-content>\n <div class=\"odx-card__content\">\n <div class=\"odx-card__title\">\n <ng-container *ngTemplateOutlet=\"title\"></ng-container>\n </div>\n <ng-content select=\"odx-launch-card-subtitle\"></ng-content>\n </div>\n </div>\n</ng-template>\n\n<ng-content select=\"odx-card-footer\"></ng-content>\n\n<odx-action-group *ngIf=\"menu; else buttonGroup\" class=\"odx-card__menu\">\n <button odxButton [odxMenu]=\"menuTpl\" odxMenuPosition=\"bottom-end\">\n <odx-icon [name]=\"menuIcon\" iconSet=\"core\"></odx-icon>\n </button>\n\n <ng-template #menuTpl>\n <ng-content select=\"odx-menu\"></ng-content>\n </ng-template>\n</odx-action-group>\n\n<ng-template #title>\n <ng-content></ng-content>\n</ng-template>\n\n<ng-template #buttonGroup>\n <ng-container *ngIf=\"buttons\">\n <ng-content select=\"odx-action-group\"></ng-content>\n </ng-container>\n</ng-template>\n" }]
|
|
77
82
|
}], ctorParameters: function () { return []; }, propDecorators: { menu: [{
|
|
78
83
|
type: ContentChild,
|
|
79
84
|
args: [MenuComponent]
|
|
@@ -93,4 +98,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
93
98
|
}], interact: [{
|
|
94
99
|
type: Output
|
|
95
100
|
}] } });
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FyZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY29tcG9uZW50cy9jYXJkL3NyYy9saWIvY2FyZC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY29tcG9uZW50cy9jYXJkL3NyYy9saWIvY2FyZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsVUFBVSxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDaEssT0FBTyxFQUFFLFVBQVUsRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3pFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQzVFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNqRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDN0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxhQUFhLEVBQUUsVUFBVSxFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDeEYsT0FBTyxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZUFBZSxFQUFFLGFBQWEsRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNwRixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDbkQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLFVBQVUsQ0FBQzs7Ozs7QUFFdkM7Ozs7OztHQU1HO0FBV0ksV0FBTSxhQUFhLEdBQW5CLE1BQU0sYUFBYTtJQTZDeEI7UUE1Q2lCLHlCQUFvQixHQUFHLE1BQU0sQ0FBQyxvQkFBb0IsRUFBRSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBQ3BFLHVCQUFrQixHQUFHLGNBQWMsRUFBRSxDQUFDO1FBY3ZDLFlBQU8sR0FBRyxhQUFhLEVBQUUsQ0FBQztRQUUxQzs7Ozs7V0FLRztRQUdJLFlBQU8sR0FBaUIsV0FBVyxDQUFDLE9BQU8sQ0FBQztRQUVuRDs7Ozs7V0FLRztRQUVJLGFBQVEsR0FBRyxNQUFNLENBQUM7UUFFekI7Ozs7V0FJRztRQUVJLGFBQVEsR0FBRyxJQUFJLFlBQVksRUFBUyxDQUFDO1FBRzFDLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7WUFDckYsSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN6QixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxJQUFjLFVBQVU7UUFDdEIsT0FBTyxJQUFJLENBQUMsT0FBTyxLQUFLLFdBQVcsQ0FBQyxPQUFPLENBQUM7SUFDOUMsQ0FBQztJQUVPLFVBQVUsQ0FBQyxLQUFZO1FBQzdCLE1BQU0sTUFBTSxHQUFHLEtBQUssQ0FBQyxNQUF3QixDQUFDO1FBQzlDLE1BQU0sYUFBYSxHQUFHLGVBQWUsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLGFBQWEsRUFBRSxNQUFNLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDakYsTUFBTSxXQUFXLEdBQUcsZUFBZSxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsT0FBTyxDQUFDLGFBQWEsRUFBRSxNQUFNLENBQUMsQ0FBQztRQUNsRixJQUFJLENBQUMsYUFBYSxJQUFJLENBQUMsV0FBVyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxNQUFNLEVBQUUsRUFBRTtZQUM5RCxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztTQUMzQjtJQUNILENBQUM7K0dBOURVLGFBQWE7bUdBQWIsYUFBYSwrTEFJVixhQUFhLDBFQUdiLG9CQUFvQix5RUFNcEIsbUJBQW1CLDJCQUFVLFVBQVUsdUVBSDFDLGFBQWEsMEdDdEMxQixtdENBd0NBLDJDRGZZLFVBQVUsMFNBQUUsZUFBZSx5R0FBRSxhQUFhLGlIQUFFLFVBQVUsb0tBQUUsb0JBQW9COztBQTZCL0U7SUFGTixXQUFXLEVBQUU7OzhDQUVxQztBQTFCeEMsYUFBYTtJQVZ6QixZQUFZLENBQUMsTUFBTSxDQUFDOztHQVVSLGFBQWEsQ0ErRHpCOzRGQS9EWSxhQUFhO2tCQVR6QixTQUFTOytCQUNFLFVBQVUsY0FFUixJQUFJLG1CQUNDLHVCQUF1QixDQUFDLE1BQU0saUJBQ2hDLGlCQUFpQixDQUFDLElBQUksV0FDNUIsQ0FBQyxVQUFVLEVBQUUsZUFBZSxFQUFFLGFBQWEsRUFBRSxVQUFVLEVBQUUsb0JBQW9CLENBQUMsa0JBQ3ZFLENBQUMsb0JBQW9CLENBQUM7MEVBT25CLElBQUk7c0JBRHRCLFlBQVk7dUJBQUMsYUFBYTtnQkFJUixPQUFPO3NCQUR6QixZQUFZO3VCQUFDLG9CQUFvQjtnQkFJZixRQUFRO3NCQUQxQixTQUFTO3VCQUFDLGFBQWE7Z0JBSUwsTUFBTTtzQkFEeEIsWUFBWTt1QkFBQyxtQkFBbUIsRUFBRSxFQUFFLElBQUksRUFBRSxVQUFVLEVBQUU7Z0JBYWhELE9BQU87c0JBRGIsS0FBSztnQkFVQyxRQUFRO3NCQURkLEtBQUs7Z0JBU0MsUUFBUTtzQkFEZCxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgQ29udGVudENoaWxkLCBFbGVtZW50UmVmLCBFdmVudEVtaXR0ZXIsIGluamVjdCwgSW5wdXQsIE91dHB1dCwgVmlld0NoaWxkLCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQTExeU1vZHVsZSwgSW50ZXJhY3RpdmVEaXJlY3RpdmUgfSBmcm9tICdAb2R4L2FuZ3VsYXIvY2RrL2ExMXknO1xuaW1wb3J0IHsgQWN0aW9uR3JvdXBDb21wb25lbnQgfSBmcm9tICdAb2R4L2FuZ3VsYXIvY29tcG9uZW50cy9hY3Rpb24tZ3JvdXAnO1xuaW1wb3J0IHsgQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnQG9keC9hbmd1bGFyL2NvbXBvbmVudHMvYnV0dG9uJztcbmltcG9ydCB7IEljb25Db21wb25lbnQgfSBmcm9tICdAb2R4L2FuZ3VsYXIvY29tcG9uZW50cy9pY29uJztcbmltcG9ydCB7IE1lbnVDb21wb25lbnQsIE1lbnVEaXJlY3RpdmUsIE1lbnVNb2R1bGUgfSBmcm9tICdAb2R4L2FuZ3VsYXIvY29tcG9uZW50cy9tZW51JztcbmltcG9ydCB7IENTU0NvbXBvbmVudCwgQ1NTTW9kaWZpZXIgfSBmcm9tICdAb2R4L2FuZ3VsYXIvaW50ZXJuYWwnO1xuaW1wb3J0IHsgY29udGFpbnNFbGVtZW50LCBpbmplY3RFbGVtZW50LCB1bnRpbERlc3Ryb3llZCB9IGZyb20gJ0BvZHgvYW5ndWxhci91dGlscyc7XG5pbXBvcnQgeyBDYXJkRm9vdGVyQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzJztcbmltcG9ydCB7IENhcmRWYXJpYW50IH0gZnJvbSAnLi9tb2RlbHMnO1xuXG4vKipcbiAqIFJlcHJlc2VudHMgYSBjYXJkIGNvbXBvbmVudC5cbiAqIEl0IGNhbiBjb250YWluIGEgaGVhZGVyLCBib2R5LCBhbmQgZm9vdGVyLiBUaGUgY2FyZCBjb21wb25lbnQgY2FuIGFsc28gaGF2ZSBhIG1lbnUgYW5kIGFjdGlvbiBidXR0b25zLlxuICogSGFzIGhvc3QgZGlyZWN0aXZlIGZvciBpbnRlcmFjdGl2aXR5LlxuICpcbiAqIEBzZWUge0ludGVyYWN0aXZlRGlyZWN0aXZlfVxuICovXG5AQ1NTQ29tcG9uZW50KCdjYXJkJylcbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ29keC1jYXJkJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2NhcmQuY29tcG9uZW50Lmh0bWwnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgaW1wb3J0czogW0ExMXlNb2R1bGUsIEJ1dHRvbkNvbXBvbmVudCwgSWNvbkNvbXBvbmVudCwgTWVudU1vZHVsZSwgQWN0aW9uR3JvdXBDb21wb25lbnRdLFxuICBob3N0RGlyZWN0aXZlczogW0ludGVyYWN0aXZlRGlyZWN0aXZlXSxcbn0pXG5leHBvcnQgY2xhc3MgQ2FyZENvbXBvbmVudCB7XG4gIHByaXZhdGUgcmVhZG9ubHkgaW50ZXJhY3RpdmVEaXJlY3RpdmUgPSBpbmplY3QoSW50ZXJhY3RpdmVEaXJlY3RpdmUsIHsgaG9zdDogdHJ1ZSB9KTtcbiAgcHJpdmF0ZSByZWFkb25seSB0YWtlVW50aWxEZXN0cm95ZWQgPSB1bnRpbERlc3Ryb3llZCgpO1xuXG4gIEBDb250ZW50Q2hpbGQoTWVudUNvbXBvbmVudClcbiAgcHJvdGVjdGVkIHJlYWRvbmx5IG1lbnU/OiBNZW51Q29tcG9uZW50O1xuXG4gIEBDb250ZW50Q2hpbGQoQWN0aW9uR3JvdXBDb21wb25lbnQpXG4gIHByb3RlY3RlZCByZWFkb25seSBidXR0b25zPzogQWN0aW9uR3JvdXBDb21wb25lbnQ7XG5cbiAgQFZpZXdDaGlsZChNZW51RGlyZWN0aXZlKVxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgbWVudUhvc3Q/OiBNZW51RGlyZWN0aXZlO1xuXG4gIEBDb250ZW50Q2hpbGQoQ2FyZEZvb3RlckNvbXBvbmVudCwgeyByZWFkOiBFbGVtZW50UmVmIH0pXG4gIHByb3RlY3RlZCByZWFkb25seSBmb290ZXI/OiBFbGVtZW50UmVmPEhUTUxFbGVtZW50PjtcblxuICBwdWJsaWMgcmVhZG9ubHkgZWxlbWVudCA9IGluamVjdEVsZW1lbnQoKTtcblxuICAvKipcbiAgICogVGhlIHZhcmlhbnQgb2YgdGhlIGNhcmQuXG4gICAqXG4gICAqIEB0eXBlIHtDYXJkVmFyaWFudH1cbiAgICogQGRlZmF1bHQgQ2FyZFZhcmlhbnQuREVGQVVMVFxuICAgKi9cbiAgQENTU01vZGlmaWVyKClcbiAgQElucHV0KClcbiAgcHVibGljIHZhcmlhbnQ/OiBDYXJkVmFyaWFudCA9IENhcmRWYXJpYW50LkRFRkFVTFQ7XG5cbiAgLyoqXG4gICAqIE1lbnUgaWNvbiBuYW1lLlxuICAgKlxuICAgKiBAdHlwZSB7c3RyaW5nfVxuICAgKiBAZGVmYXVsdCAnbW9yZSdcbiAgICovXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBtZW51SWNvbiA9ICdtb3JlJztcblxuICAvKipcbiAgICogSW50ZXJhY3Rpdml0eSBldmVudCBlbWl0dGVyLlxuICAgKlxuICAgKiBAZW1pdHMge0V2ZW50fVxuICAgKi9cbiAgQE91dHB1dCgpXG4gIHB1YmxpYyBpbnRlcmFjdCA9IG5ldyBFdmVudEVtaXR0ZXI8RXZlbnQ+KCk7XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5pbnRlcmFjdGl2ZURpcmVjdGl2ZS5pbnRlcmFjdC5waXBlKHRoaXMudGFrZVVudGlsRGVzdHJveWVkKCkpLnN1YnNjcmliZSgoZXZlbnQpID0+IHtcbiAgICAgIHRoaXMuc3RvcEV2ZW50cyhldmVudCk7XG4gICAgfSk7XG4gIH1cblxuICBwcm90ZWN0ZWQgZ2V0IGxhdW5jaFRpbGUoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMudmFyaWFudCAhPT0gQ2FyZFZhcmlhbnQuREVGQVVMVDtcbiAgfVxuXG4gIHByaXZhdGUgc3RvcEV2ZW50cyhldmVudDogRXZlbnQpOiB2b2lkIHtcbiAgICBjb25zdCB0YXJnZXQgPSBldmVudC50YXJnZXQgYXMgRWxlbWVudCB8IG51bGw7XG4gICAgY29uc3QgaXNGb290ZXJFdmVudCA9IGNvbnRhaW5zRWxlbWVudCh0aGlzLmZvb3Rlcj8ubmF0aXZlRWxlbWVudCwgdGFyZ2V0LCBmYWxzZSk7XG4gICAgY29uc3QgaXNNZW51RXZlbnQgPSBjb250YWluc0VsZW1lbnQodGhpcy5tZW51SG9zdD8uZWxlbWVudC5uYXRpdmVFbGVtZW50LCB0YXJnZXQpO1xuICAgIGlmICghaXNGb290ZXJFdmVudCAmJiAhaXNNZW51RXZlbnQgJiYgIXRoaXMubWVudUhvc3Q/LmlzT3BlbigpKSB7XG4gICAgICB0aGlzLmludGVyYWN0LmVtaXQoZXZlbnQpO1xuICAgIH1cbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cIm9keC1jYXJkX19jb250YWluZXJcIj5cbiAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImxhdW5jaFRpbGU7IGVsc2UgY2FyZFwiPlxuICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIm9keC1hdmF0YXJcIj48L25nLWNvbnRlbnQ+XG4gICAgPGRpdiBjbGFzcz1cIm9keC1jYXJkX19jb250ZW50XCI+XG4gICAgICA8ZGl2IGNsYXNzPVwib2R4LWNhcmRfX3RpdGxlXCI+XG4gICAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJ0aXRsZVwiPjwvbmctY29udGFpbmVyPlxuICAgICAgPC9kaXY+XG4gICAgICA8bmctY29udGVudCBzZWxlY3Q9XCJvZHgtbGF1bmNoLWNhcmQtc3VidGl0bGVcIj48L25nLWNvbnRlbnQ+XG4gICAgPC9kaXY+XG4gIDwvbmctY29udGFpbmVyPlxuXG4gIDxuZy10ZW1wbGF0ZSAjY2FyZD5cbiAgICA8ZGl2IGNsYXNzPVwib2R4LWNhcmRfX3RpdGxlXCI+XG4gICAgICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwidGl0bGVcIj48L25nLWNvbnRhaW5lcj5cbiAgICA8L2Rpdj5cbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJbb2R4Q2FyZENvbnRlbnRdXCI+PC9uZy1jb250ZW50PlxuICA8L25nLXRlbXBsYXRlPlxuPC9kaXY+XG5cbjxuZy1jb250ZW50IHNlbGVjdD1cIm9keC1jYXJkLWZvb3RlclwiPjwvbmctY29udGVudD5cblxuPG9keC1hY3Rpb24tZ3JvdXAgKm5nSWY9XCJtZW51OyBlbHNlIGJ1dHRvbkdyb3VwXCI+XG4gIDxidXR0b24gb2R4QnV0dG9uIFtvZHhNZW51XT1cIm1lbnVUcGxcIiBvZHhNZW51UG9zaXRpb249XCJib3R0b20tZW5kXCI+XG4gICAgPG9keC1pY29uIFtuYW1lXT1cIm1lbnVJY29uXCIgaWNvblNldD1cImNvcmVcIj48L29keC1pY29uPlxuICA8L2J1dHRvbj5cblxuICA8bmctdGVtcGxhdGUgI21lbnVUcGw+XG4gICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwib2R4LW1lbnVcIj48L25nLWNvbnRlbnQ+XG4gIDwvbmctdGVtcGxhdGU+XG48L29keC1hY3Rpb24tZ3JvdXA+XG5cbjxuZy10ZW1wbGF0ZSAjdGl0bGU+XG4gIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbjwvbmctdGVtcGxhdGU+XG5cbjxuZy10ZW1wbGF0ZSAjYnV0dG9uR3JvdXA+XG4gIDxuZy1jb250YWluZXIgKm5nSWY9XCJidXR0b25zXCI+XG4gICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwib2R4LWFjdGlvbi1ncm91cFwiPjwvbmctY29udGVudD5cbiAgPC9uZy1jb250YWluZXI+XG48L25nLXRlbXBsYXRlPlxuIl19
|
|
101
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FyZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY29tcG9uZW50cy9jYXJkL3NyYy9saWIvY2FyZC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY29tcG9uZW50cy9jYXJkL3NyYy9saWIvY2FyZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsVUFBVSxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDaEssT0FBTyxFQUFFLFVBQVUsRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3pFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBQzVFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNqRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNwRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDN0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxhQUFhLEVBQUUsVUFBVSxFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDeEYsT0FBTyxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsZUFBZSxFQUFFLGFBQWEsRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNwRixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ25ELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxVQUFVLENBQUM7Ozs7O0FBRXZDOzs7Ozs7R0FNRztBQVdJLFdBQU0sYUFBYSxHQUFuQixNQUFNLGFBQWE7SUFnRHhCLElBQVcsVUFBVTtRQUNuQixPQUFPLElBQUksQ0FBQyxPQUFPLEtBQUssV0FBVyxDQUFDLFdBQVcsSUFBSSxJQUFJLENBQUMsT0FBTyxLQUFLLFdBQVcsQ0FBQyxvQkFBb0IsQ0FBQztJQUN2RyxDQUFDO0lBRUQ7UUFuRGlCLHlCQUFvQixHQUFHLE1BQU0sQ0FBQyxvQkFBb0IsRUFBRSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1FBQ3BFLHVCQUFrQixHQUFHLGNBQWMsRUFBRSxDQUFDO1FBQ3RDLFdBQU0sR0FBRyxnQkFBZ0IsRUFBRSxDQUFDO1FBRW5DLGdCQUFXLEdBQUcsV0FBVyxDQUFDO1FBYzdCLFlBQU8sR0FBRyxhQUFhLEVBQUUsQ0FBQztRQUNqQzs7Ozs7V0FLRztRQUlJLFlBQU8sR0FBZ0IsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLElBQUksV0FBVyxDQUFDLE9BQU8sQ0FBQztRQUV6RTs7Ozs7V0FLRztRQUVJLGFBQVEsR0FBRyxNQUFNLENBQUM7UUFFekI7Ozs7V0FJRztRQUVJLGFBQVEsR0FBRyxJQUFJLFlBQVksRUFBUyxDQUFDO1FBTzFDLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7WUFDckYsSUFBSSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN6QixDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFTyxVQUFVLENBQUMsS0FBWTtRQUM3QixNQUFNLE1BQU0sR0FBRyxLQUFLLENBQUMsTUFBd0IsQ0FBQztRQUM5QyxNQUFNLGFBQWEsR0FBRyxlQUFlLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxhQUFhLEVBQUUsTUFBTSxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ2pGLE1BQU0sV0FBVyxHQUFHLGVBQWUsQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLE9BQU8sQ0FBQyxhQUFhLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFDbEYsTUFBTSxtQkFBbUIsR0FBRyxlQUFlLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRSxPQUFPLENBQUMsYUFBYSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBRXpGLElBQUksQ0FBQyxhQUFhLElBQUksQ0FBQyxXQUFXLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLE1BQU0sRUFBRSxJQUFJLENBQUMsbUJBQW1CLEVBQUU7WUFDdEYsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDM0I7SUFDSCxDQUFDOytHQW5FVSxhQUFhO21HQUFiLGFBQWEsK0xBT1YsYUFBYSwwRUFHYixvQkFBb0IseUVBTXBCLG1CQUFtQiwyQkFBVSxVQUFVLHVFQUgxQyxhQUFhLDBHQzNDMUIsbzFDQXlDQSwyQ0RkWSxVQUFVLDBTQUFFLGVBQWUseUdBQUUsYUFBYSxpSEFBRSxVQUFVLG9LQUFFLG9CQUFvQjs7QUFnQy9FO0lBRk4sV0FBVyxFQUFFOzs4Q0FFMkQ7QUE3QjlELGFBQWE7SUFWekIsWUFBWSxDQUFDLE1BQU0sQ0FBQzs7R0FVUixhQUFhLENBb0V6Qjs0RkFwRVksYUFBYTtrQkFUekIsU0FBUzsrQkFDRSxVQUFVLGNBRVIsSUFBSSxtQkFDQyx1QkFBdUIsQ0FBQyxNQUFNLGlCQUNoQyxpQkFBaUIsQ0FBQyxJQUFJLFdBQzVCLENBQUMsVUFBVSxFQUFFLGVBQWUsRUFBRSxhQUFhLEVBQUUsVUFBVSxFQUFFLG9CQUFvQixFQUFFLG9CQUFvQixDQUFDLGtCQUM3RixDQUFDLG9CQUFvQixDQUFDOzBFQVVuQixJQUFJO3NCQUR0QixZQUFZO3VCQUFDLGFBQWE7Z0JBSVIsT0FBTztzQkFEekIsWUFBWTt1QkFBQyxvQkFBb0I7Z0JBSWYsUUFBUTtzQkFEMUIsU0FBUzt1QkFBQyxhQUFhO2dCQUlMLE1BQU07c0JBRHhCLFlBQVk7dUJBQUMsbUJBQW1CLEVBQUUsRUFBRSxJQUFJLEVBQUUsVUFBVSxFQUFFO2dCQWFoRCxPQUFPO3NCQURiLEtBQUs7Z0JBVUMsUUFBUTtzQkFEZCxLQUFLO2dCQVNDLFFBQVE7c0JBRGQsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIENvbnRlbnRDaGlsZCwgRWxlbWVudFJlZiwgRXZlbnRFbWl0dGVyLCBpbmplY3QsIElucHV0LCBPdXRwdXQsIFZpZXdDaGlsZCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEExMXlNb2R1bGUsIEludGVyYWN0aXZlRGlyZWN0aXZlIH0gZnJvbSAnQG9keC9hbmd1bGFyL2Nkay9hMTF5JztcbmltcG9ydCB7IEFjdGlvbkdyb3VwQ29tcG9uZW50IH0gZnJvbSAnQG9keC9hbmd1bGFyL2NvbXBvbmVudHMvYWN0aW9uLWdyb3VwJztcbmltcG9ydCB7IEJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJ0BvZHgvYW5ndWxhci9jb21wb25lbnRzL2J1dHRvbic7XG5pbXBvcnQgeyBDaGlwTGlzdFJvd0NvbXBvbmVudCB9IGZyb20gJ0BvZHgvYW5ndWxhci9jb21wb25lbnRzL2NoaXAnO1xuaW1wb3J0IHsgSWNvbkNvbXBvbmVudCB9IGZyb20gJ0BvZHgvYW5ndWxhci9jb21wb25lbnRzL2ljb24nO1xuaW1wb3J0IHsgTWVudUNvbXBvbmVudCwgTWVudURpcmVjdGl2ZSwgTWVudU1vZHVsZSB9IGZyb20gJ0BvZHgvYW5ndWxhci9jb21wb25lbnRzL21lbnUnO1xuaW1wb3J0IHsgQ1NTQ29tcG9uZW50LCBDU1NNb2RpZmllciB9IGZyb20gJ0BvZHgvYW5ndWxhci9pbnRlcm5hbCc7XG5pbXBvcnQgeyBjb250YWluc0VsZW1lbnQsIGluamVjdEVsZW1lbnQsIHVudGlsRGVzdHJveWVkIH0gZnJvbSAnQG9keC9hbmd1bGFyL3V0aWxzJztcbmltcG9ydCB7IGluamVjdENhcmRDb25maWcgfSBmcm9tICcuL2NhcmQuY29uZmlnJztcbmltcG9ydCB7IENhcmRGb290ZXJDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMnO1xuaW1wb3J0IHsgQ2FyZFZhcmlhbnQgfSBmcm9tICcuL21vZGVscyc7XG5cbi8qKlxuICogUmVwcmVzZW50cyBhIGNhcmQgY29tcG9uZW50LlxuICogSXQgY2FuIGNvbnRhaW4gYSBoZWFkZXIsIGJvZHksIGFuZCBmb290ZXIuIFRoZSBjYXJkIGNvbXBvbmVudCBjYW4gYWxzbyBoYXZlIGEgbWVudSBhbmQgYWN0aW9uIGJ1dHRvbnMuXG4gKiBIYXMgaG9zdCBkaXJlY3RpdmUgZm9yIGludGVyYWN0aXZpdHkuXG4gKlxuICogQHNlZSB7SW50ZXJhY3RpdmVEaXJlY3RpdmV9XG4gKi9cbkBDU1NDb21wb25lbnQoJ2NhcmQnKVxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnb2R4LWNhcmQnLFxuICB0ZW1wbGF0ZVVybDogJy4vY2FyZC5jb21wb25lbnQuaHRtbCcsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBpbXBvcnRzOiBbQTExeU1vZHVsZSwgQnV0dG9uQ29tcG9uZW50LCBJY29uQ29tcG9uZW50LCBNZW51TW9kdWxlLCBBY3Rpb25Hcm91cENvbXBvbmVudCwgQ2hpcExpc3RSb3dDb21wb25lbnRdLFxuICBob3N0RGlyZWN0aXZlczogW0ludGVyYWN0aXZlRGlyZWN0aXZlXSxcbn0pXG5leHBvcnQgY2xhc3MgQ2FyZENvbXBvbmVudCB7XG4gIHByaXZhdGUgcmVhZG9ubHkgaW50ZXJhY3RpdmVEaXJlY3RpdmUgPSBpbmplY3QoSW50ZXJhY3RpdmVEaXJlY3RpdmUsIHsgaG9zdDogdHJ1ZSB9KTtcbiAgcHJpdmF0ZSByZWFkb25seSB0YWtlVW50aWxEZXN0cm95ZWQgPSB1bnRpbERlc3Ryb3llZCgpO1xuICBwcml2YXRlIHJlYWRvbmx5IGNvbmZpZyA9IGluamVjdENhcmRDb25maWcoKTtcblxuICBwcm90ZWN0ZWQgY2FyZFZhcmlhbnQgPSBDYXJkVmFyaWFudDtcblxuICBAQ29udGVudENoaWxkKE1lbnVDb21wb25lbnQpXG4gIHByb3RlY3RlZCByZWFkb25seSBtZW51PzogTWVudUNvbXBvbmVudDtcblxuICBAQ29udGVudENoaWxkKEFjdGlvbkdyb3VwQ29tcG9uZW50KVxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgYnV0dG9ucz86IEFjdGlvbkdyb3VwQ29tcG9uZW50O1xuXG4gIEBWaWV3Q2hpbGQoTWVudURpcmVjdGl2ZSlcbiAgcHJvdGVjdGVkIHJlYWRvbmx5IG1lbnVIb3N0PzogTWVudURpcmVjdGl2ZTtcblxuICBAQ29udGVudENoaWxkKENhcmRGb290ZXJDb21wb25lbnQsIHsgcmVhZDogRWxlbWVudFJlZiB9KVxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgZm9vdGVyPzogRWxlbWVudFJlZjxIVE1MRWxlbWVudD47XG5cbiAgcHVibGljIGVsZW1lbnQgPSBpbmplY3RFbGVtZW50KCk7XG4gIC8qKlxuICAgKiBUaGUgdmFyaWFudCBvZiB0aGUgY2FyZC5cbiAgICpcbiAgICogQHR5cGUge0NhcmRWYXJpYW50fVxuICAgKiBAZGVmYXVsdCBDYXJkVmFyaWFudC5ERUZBVUxUXG4gICAqL1xuXG4gIEBDU1NNb2RpZmllcigpXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyB2YXJpYW50OiBDYXJkVmFyaWFudCA9IHRoaXMuY29uZmlnLnZhcmlhbnQgPz8gQ2FyZFZhcmlhbnQuREVGQVVMVDtcblxuICAvKipcbiAgICogTWVudSBpY29uIG5hbWUuXG4gICAqXG4gICAqIEB0eXBlIHtzdHJpbmd9XG4gICAqIEBkZWZhdWx0ICdtb3JlJ1xuICAgKi9cbiAgQElucHV0KClcbiAgcHVibGljIG1lbnVJY29uID0gJ21vcmUnO1xuXG4gIC8qKlxuICAgKiBJbnRlcmFjdGl2aXR5IGV2ZW50IGVtaXR0ZXIuXG4gICAqXG4gICAqIEBlbWl0cyB7RXZlbnR9XG4gICAqL1xuICBAT3V0cHV0KClcbiAgcHVibGljIGludGVyYWN0ID0gbmV3IEV2ZW50RW1pdHRlcjxFdmVudD4oKTtcblxuICBwdWJsaWMgZ2V0IGxhdW5jaFRpbGUoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMudmFyaWFudCA9PT0gQ2FyZFZhcmlhbnQuTEFVTkNIX1RJTEUgfHwgdGhpcy52YXJpYW50ID09PSBDYXJkVmFyaWFudC5MQVVOQ0hfVElMRV9DRU5URVJFRDtcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHRoaXMuaW50ZXJhY3RpdmVEaXJlY3RpdmUuaW50ZXJhY3QucGlwZSh0aGlzLnRha2VVbnRpbERlc3Ryb3llZCgpKS5zdWJzY3JpYmUoKGV2ZW50KSA9PiB7XG4gICAgICB0aGlzLnN0b3BFdmVudHMoZXZlbnQpO1xuICAgIH0pO1xuICB9XG5cbiAgcHJpdmF0ZSBzdG9wRXZlbnRzKGV2ZW50OiBFdmVudCk6IHZvaWQge1xuICAgIGNvbnN0IHRhcmdldCA9IGV2ZW50LnRhcmdldCBhcyBFbGVtZW50IHwgbnVsbDtcbiAgICBjb25zdCBpc0Zvb3RlckV2ZW50ID0gY29udGFpbnNFbGVtZW50KHRoaXMuZm9vdGVyPy5uYXRpdmVFbGVtZW50LCB0YXJnZXQsIGZhbHNlKTtcbiAgICBjb25zdCBpc01lbnVFdmVudCA9IGNvbnRhaW5zRWxlbWVudCh0aGlzLm1lbnVIb3N0Py5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQsIHRhcmdldCk7XG4gICAgY29uc3QgaXNIZWFkZXJCdXR0b25FdmVudCA9IGNvbnRhaW5zRWxlbWVudCh0aGlzLmJ1dHRvbnM/LmVsZW1lbnQubmF0aXZlRWxlbWVudCwgdGFyZ2V0KTtcblxuICAgIGlmICghaXNGb290ZXJFdmVudCAmJiAhaXNNZW51RXZlbnQgJiYgIXRoaXMubWVudUhvc3Q/LmlzT3BlbigpICYmICFpc0hlYWRlckJ1dHRvbkV2ZW50KSB7XG4gICAgICB0aGlzLmludGVyYWN0LmVtaXQoZXZlbnQpO1xuICAgIH1cbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cIm9keC1jYXJkX19jb250YWluZXJcIiAqbmdJZj1cIiFsYXVuY2hUaWxlOyBlbHNlIGxhdW5jaFRpbGVUbXBcIj5cbiAgPG5nLWNvbnRlbnQgc2VsZWN0PVwib2R4LWNhcmQtaW1hZ2VcIj48L25nLWNvbnRlbnQ+XG4gIDxkaXYgY2xhc3M9XCJvZHgtY2FyZF9fdGl0bGUgb2R4LXRpdGxlLTVcIj5cbiAgICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwidGl0bGVcIj48L25nLWNvbnRhaW5lcj5cbiAgPC9kaXY+XG4gIDxuZy1jb250ZW50IHNlbGVjdD1cIltvZHhDYXJkQ29udGVudF0sIG9keC1jYXJkLWNvbnRlbnRcIj48L25nLWNvbnRlbnQ+XG48L2Rpdj5cblxuPG5nLXRlbXBsYXRlICNsYXVuY2hUaWxlVG1wPlxuICA8ZGl2IGNsYXNzPVwib2R4LWNhcmRfX2NvbnRhaW5lclwiPlxuICAgIDxuZy1jb250ZW50IHNlbGVjdD1cIm9keC1hdmF0YXJcIj48L25nLWNvbnRlbnQ+XG4gICAgPGRpdiBjbGFzcz1cIm9keC1jYXJkX19jb250ZW50XCI+XG4gICAgICA8ZGl2IGNsYXNzPVwib2R4LWNhcmRfX3RpdGxlXCI+XG4gICAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJ0aXRsZVwiPjwvbmctY29udGFpbmVyPlxuICAgICAgPC9kaXY+XG4gICAgICA8bmctY29udGVudCBzZWxlY3Q9XCJvZHgtbGF1bmNoLWNhcmQtc3VidGl0bGVcIj48L25nLWNvbnRlbnQ+XG4gICAgPC9kaXY+XG4gIDwvZGl2PlxuPC9uZy10ZW1wbGF0ZT5cblxuPG5nLWNvbnRlbnQgc2VsZWN0PVwib2R4LWNhcmQtZm9vdGVyXCI+PC9uZy1jb250ZW50PlxuXG48b2R4LWFjdGlvbi1ncm91cCAqbmdJZj1cIm1lbnU7IGVsc2UgYnV0dG9uR3JvdXBcIiBjbGFzcz1cIm9keC1jYXJkX19tZW51XCI+XG4gIDxidXR0b24gb2R4QnV0dG9uIFtvZHhNZW51XT1cIm1lbnVUcGxcIiBvZHhNZW51UG9zaXRpb249XCJib3R0b20tZW5kXCI+XG4gICAgPG9keC1pY29uIFtuYW1lXT1cIm1lbnVJY29uXCIgaWNvblNldD1cImNvcmVcIj48L29keC1pY29uPlxuICA8L2J1dHRvbj5cblxuICA8bmctdGVtcGxhdGUgI21lbnVUcGw+XG4gICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwib2R4LW1lbnVcIj48L25nLWNvbnRlbnQ+XG4gIDwvbmctdGVtcGxhdGU+XG48L29keC1hY3Rpb24tZ3JvdXA+XG5cbjxuZy10ZW1wbGF0ZSAjdGl0bGU+XG4gIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbjwvbmctdGVtcGxhdGU+XG5cbjxuZy10ZW1wbGF0ZSAjYnV0dG9uR3JvdXA+XG4gIDxuZy1jb250YWluZXIgKm5nSWY9XCJidXR0b25zXCI+XG4gICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwib2R4LWFjdGlvbi1ncm91cFwiPjwvbmctY29udGVudD5cbiAgPC9uZy1jb250YWluZXI+XG48L25nLXRlbXBsYXRlPlxuIl19
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { createConfigTokens } from '@odx/angular/utils';
|
|
2
|
+
import { CardVariant } from './models';
|
|
3
|
+
/**
|
|
4
|
+
* Tools for customizing configuration for the card component
|
|
5
|
+
*
|
|
6
|
+
* @example
|
|
7
|
+
* ```ts
|
|
8
|
+
* @Component({
|
|
9
|
+
* ...
|
|
10
|
+
* providers: [provideCardConfig({imageRatio: '5/3', maxImageHeight: '200px'})]
|
|
11
|
+
* })
|
|
12
|
+
* export class MyCardComponent {}
|
|
13
|
+
* ```
|
|
14
|
+
* @example
|
|
15
|
+
* ```ts
|
|
16
|
+
* constructor(@Inject(CardConfig) private readonly cardConfig: CardConfig) {}
|
|
17
|
+
* ```
|
|
18
|
+
*/
|
|
19
|
+
export const { CardConfig, CardDefaultConfig, injectCardConfig, provideCardConfig } = createConfigTokens('Card', '@odx/angular/components/card', {
|
|
20
|
+
variant: CardVariant.DEFAULT,
|
|
21
|
+
maxImageHeight: 'auto',
|
|
22
|
+
imageRatio: 'auto',
|
|
23
|
+
});
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FyZC5jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY29tcG9uZW50cy9jYXJkL3NyYy9saWIvY2FyZC5jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDeEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQVF2Qzs7Ozs7Ozs7Ozs7Ozs7O0dBZUc7QUFDSCxNQUFNLENBQUMsTUFBTSxFQUFFLFVBQVUsRUFBRSxpQkFBaUIsRUFBRSxnQkFBZ0IsRUFBRSxpQkFBaUIsRUFBRSxHQUFHLGtCQUFrQixDQUFDLE1BQU0sRUFBRSw4QkFBOEIsRUFBRTtJQUMvSSxPQUFPLEVBQUUsV0FBVyxDQUFDLE9BQXNCO0lBQzNDLGNBQWMsRUFBRSxNQUFNO0lBQ3RCLFVBQVUsRUFBRSxNQUFNO0NBQ25CLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNyZWF0ZUNvbmZpZ1Rva2VucyB9IGZyb20gJ0BvZHgvYW5ndWxhci91dGlscyc7XG5pbXBvcnQgeyBDYXJkVmFyaWFudCB9IGZyb20gJy4vbW9kZWxzJztcblxuZXhwb3J0IGludGVyZmFjZSBDYXJkQ29uZmlnIHtcbiAgdmFyaWFudD86IENhcmRWYXJpYW50O1xuICBtYXhJbWFnZUhlaWdodD86IHN0cmluZztcbiAgaW1hZ2VSYXRpbz86IHN0cmluZztcbn1cblxuLyoqXG4gKiBUb29scyBmb3IgY3VzdG9taXppbmcgY29uZmlndXJhdGlvbiBmb3IgdGhlIGNhcmQgY29tcG9uZW50XG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYHRzXG4gKiBAQ29tcG9uZW50KHtcbiAqICAuLi5cbiAqICBwcm92aWRlcnM6IFtwcm92aWRlQ2FyZENvbmZpZyh7aW1hZ2VSYXRpbzogJzUvMycsIG1heEltYWdlSGVpZ2h0OiAnMjAwcHgnfSldXG4gKiB9KVxuICogZXhwb3J0IGNsYXNzIE15Q2FyZENvbXBvbmVudCB7fVxuICogYGBgXG4gKiBAZXhhbXBsZVxuICogYGBgdHNcbiAqICBjb25zdHJ1Y3RvcihASW5qZWN0KENhcmRDb25maWcpIHByaXZhdGUgcmVhZG9ubHkgY2FyZENvbmZpZzogQ2FyZENvbmZpZykge31cbiAqIGBgYFxuICovXG5leHBvcnQgY29uc3QgeyBDYXJkQ29uZmlnLCBDYXJkRGVmYXVsdENvbmZpZywgaW5qZWN0Q2FyZENvbmZpZywgcHJvdmlkZUNhcmRDb25maWcgfSA9IGNyZWF0ZUNvbmZpZ1Rva2VucygnQ2FyZCcsICdAb2R4L2FuZ3VsYXIvY29tcG9uZW50cy9jYXJkJywge1xuICB2YXJpYW50OiBDYXJkVmFyaWFudC5ERUZBVUxUIGFzIENhcmRWYXJpYW50LFxuICBtYXhJbWFnZUhlaWdodDogJ2F1dG8nLFxuICBpbWFnZVJhdGlvOiAnYXV0bycsXG59KTtcbiJdfQ==
|
|
@@ -1,51 +1,20 @@
|
|
|
1
1
|
import { NgModule } from '@angular/core';
|
|
2
2
|
import { CoreModule } from '@odx/angular';
|
|
3
|
-
import { AvatarComponent } from '@odx/angular/components/avatar';
|
|
4
|
-
import { ButtonComponent } from '@odx/angular/components/button';
|
|
5
|
-
import { IconComponent } from '@odx/angular/components/icon';
|
|
6
|
-
import { MenuModule } from '@odx/angular/components/menu';
|
|
7
3
|
import { CardComponent } from './card.component';
|
|
8
|
-
import { CardFooterComponent, LaunchCardSubtitleComponent } from './components';
|
|
9
|
-
import { CardContentDirective } from './directives
|
|
10
|
-
import { CardTitleDirective } from './directives/card-title.directive';
|
|
4
|
+
import { CardFooterComponent, CardImageComponent, LaunchCardSubtitleComponent } from './components';
|
|
5
|
+
import { CardContentDirective } from './directives';
|
|
11
6
|
import * as i0 from "@angular/core";
|
|
12
|
-
const modules = [
|
|
13
|
-
CardComponent,
|
|
14
|
-
CardTitleDirective,
|
|
15
|
-
CardContentDirective,
|
|
16
|
-
CardFooterComponent,
|
|
17
|
-
LaunchCardSubtitleComponent,
|
|
18
|
-
AvatarComponent,
|
|
19
|
-
ButtonComponent,
|
|
20
|
-
IconComponent,
|
|
21
|
-
];
|
|
7
|
+
const modules = [CardComponent, CardFooterComponent, CardImageComponent, LaunchCardSubtitleComponent, CardContentDirective];
|
|
22
8
|
export class CardModule {
|
|
23
9
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CardModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
24
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: CardModule, imports: [CardComponent,
|
|
25
|
-
|
|
26
|
-
CardContentDirective,
|
|
27
|
-
CardFooterComponent,
|
|
28
|
-
LaunchCardSubtitleComponent,
|
|
29
|
-
AvatarComponent,
|
|
30
|
-
ButtonComponent,
|
|
31
|
-
IconComponent], exports: [CoreModule, MenuModule, CardComponent,
|
|
32
|
-
CardTitleDirective,
|
|
33
|
-
CardContentDirective,
|
|
34
|
-
CardFooterComponent,
|
|
35
|
-
LaunchCardSubtitleComponent,
|
|
36
|
-
AvatarComponent,
|
|
37
|
-
ButtonComponent,
|
|
38
|
-
IconComponent] }); }
|
|
39
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CardModule, imports: [CardComponent,
|
|
40
|
-
AvatarComponent,
|
|
41
|
-
ButtonComponent,
|
|
42
|
-
IconComponent, CoreModule, MenuModule] }); }
|
|
10
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: CardModule, imports: [CardComponent, CardFooterComponent, CardImageComponent, LaunchCardSubtitleComponent, CardContentDirective], exports: [CoreModule, CardComponent, CardFooterComponent, CardImageComponent, LaunchCardSubtitleComponent, CardContentDirective] }); }
|
|
11
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CardModule, imports: [CardComponent, CardImageComponent, CoreModule] }); }
|
|
43
12
|
}
|
|
44
13
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CardModule, decorators: [{
|
|
45
14
|
type: NgModule,
|
|
46
15
|
args: [{
|
|
47
16
|
imports: [modules],
|
|
48
|
-
exports: [CoreModule,
|
|
17
|
+
exports: [CoreModule, ...modules],
|
|
49
18
|
}]
|
|
50
19
|
}] });
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FyZC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY29tcG9uZW50cy9jYXJkL3NyYy9saWIvY2FyZC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQzFDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNqRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsa0JBQWtCLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxjQUFjLENBQUM7QUFDcEcsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sY0FBYyxDQUFDOztBQUVwRCxNQUFNLE9BQU8sR0FBRyxDQUFDLGFBQWEsRUFBRSxtQkFBbUIsRUFBRSxrQkFBa0IsRUFBRSwyQkFBMkIsRUFBRSxvQkFBb0IsQ0FBQyxDQUFDO0FBTTVILE1BQU0sT0FBTyxVQUFVOytHQUFWLFVBQVU7Z0hBQVYsVUFBVSxZQU5OLGFBQWEsRUFBRSxtQkFBbUIsRUFBRSxrQkFBa0IsRUFBRSwyQkFBMkIsRUFBRSxvQkFBb0IsYUFJOUcsVUFBVSxFQUpMLGFBQWEsRUFBRSxtQkFBbUIsRUFBRSxrQkFBa0IsRUFBRSwyQkFBMkIsRUFBRSxvQkFBb0I7Z0hBTTdHLFVBQVUsWUFOTixhQUFhLEVBQXVCLGtCQUFrQixFQUkzRCxVQUFVOzs0RkFFVCxVQUFVO2tCQUp0QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLE9BQU8sQ0FBQztvQkFDbEIsT0FBTyxFQUFFLENBQUMsVUFBVSxFQUFFLEdBQUcsT0FBTyxDQUFDO2lCQUNsQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb3JlTW9kdWxlIH0gZnJvbSAnQG9keC9hbmd1bGFyJztcbmltcG9ydCB7IENhcmRDb21wb25lbnQgfSBmcm9tICcuL2NhcmQuY29tcG9uZW50JztcbmltcG9ydCB7IENhcmRGb290ZXJDb21wb25lbnQsIENhcmRJbWFnZUNvbXBvbmVudCwgTGF1bmNoQ2FyZFN1YnRpdGxlQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzJztcbmltcG9ydCB7IENhcmRDb250ZW50RGlyZWN0aXZlIH0gZnJvbSAnLi9kaXJlY3RpdmVzJztcblxuY29uc3QgbW9kdWxlcyA9IFtDYXJkQ29tcG9uZW50LCBDYXJkRm9vdGVyQ29tcG9uZW50LCBDYXJkSW1hZ2VDb21wb25lbnQsIExhdW5jaENhcmRTdWJ0aXRsZUNvbXBvbmVudCwgQ2FyZENvbnRlbnREaXJlY3RpdmVdO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbbW9kdWxlc10sXG4gIGV4cG9ydHM6IFtDb3JlTW9kdWxlLCAuLi5tb2R1bGVzXSxcbn0pXG5leHBvcnQgY2xhc3MgQ2FyZE1vZHVsZSB7fVxuIl19
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { Component, HostBinding, Input } from '@angular/core';
|
|
3
|
+
import { ChipListRowComponent } from '@odx/angular/components/chip';
|
|
4
|
+
import { CSSComponent } from '@odx/angular/internal';
|
|
5
|
+
import { injectElement } from '@odx/angular/utils';
|
|
6
|
+
import { injectCardConfig } from '../../card.config';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
/**
|
|
9
|
+
* Represents a card image component.
|
|
10
|
+
*/
|
|
11
|
+
export let CardImageComponent = class CardImageComponent {
|
|
12
|
+
constructor() {
|
|
13
|
+
this.config = injectCardConfig();
|
|
14
|
+
this.element = injectElement();
|
|
15
|
+
/**
|
|
16
|
+
* The ratio of the card image.
|
|
17
|
+
*
|
|
18
|
+
* @type {string}
|
|
19
|
+
* @default 'auto'
|
|
20
|
+
*/
|
|
21
|
+
this.imageRatio = this.config.imageRatio ?? 'auto';
|
|
22
|
+
/**
|
|
23
|
+
* The maximum height of the card image.
|
|
24
|
+
*
|
|
25
|
+
* @type {string}
|
|
26
|
+
* @default 'auto'
|
|
27
|
+
*/
|
|
28
|
+
this.maxImageHeight = this.config.maxImageHeight ?? 'auto';
|
|
29
|
+
}
|
|
30
|
+
get getMaxImageHeight() {
|
|
31
|
+
return this.maxImageHeight ?? this.config.maxImageHeight ?? 'auto';
|
|
32
|
+
}
|
|
33
|
+
get getImageAspectRatio() {
|
|
34
|
+
return this.imageRatio ?? this.config.imageRatio ?? 'auto';
|
|
35
|
+
}
|
|
36
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CardImageComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
37
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CardImageComponent, isStandalone: true, selector: "odx-card-image", inputs: { imageRatio: "imageRatio", maxImageHeight: "maxImageHeight" }, host: { properties: { "style.--odx-card-image-max-height": "this.getMaxImageHeight", "style.--odx-card-image-aspect-ratio": "this.getImageAspectRatio" } }, ngImport: i0, template: "<odx-chip-list-row>\n <ng-content ngProjectAs=\"odx-chip\" select=\"odx-chip\"></ng-content>\n</odx-chip-list-row>\n\n<figure class=\"odx-card-image__img\">\n <ng-content select=\"img\"></ng-content>\n</figure>\n", dependencies: [{ kind: "component", type: ChipListRowComponent, selector: "odx-chip-list-row" }] }); }
|
|
38
|
+
};
|
|
39
|
+
CardImageComponent = __decorate([
|
|
40
|
+
CSSComponent('card-image')
|
|
41
|
+
], CardImageComponent);
|
|
42
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CardImageComponent, decorators: [{
|
|
43
|
+
type: Component,
|
|
44
|
+
args: [{ selector: 'odx-card-image', standalone: true, imports: [ChipListRowComponent], template: "<odx-chip-list-row>\n <ng-content ngProjectAs=\"odx-chip\" select=\"odx-chip\"></ng-content>\n</odx-chip-list-row>\n\n<figure class=\"odx-card-image__img\">\n <ng-content select=\"img\"></ng-content>\n</figure>\n" }]
|
|
45
|
+
}], propDecorators: { imageRatio: [{
|
|
46
|
+
type: Input
|
|
47
|
+
}], maxImageHeight: [{
|
|
48
|
+
type: Input
|
|
49
|
+
}], getMaxImageHeight: [{
|
|
50
|
+
type: HostBinding,
|
|
51
|
+
args: [`style.--odx-card-image-max-height`]
|
|
52
|
+
}], getImageAspectRatio: [{
|
|
53
|
+
type: HostBinding,
|
|
54
|
+
args: [`style.--odx-card-image-aspect-ratio`]
|
|
55
|
+
}] } });
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FyZC1pbWFnZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY29tcG9uZW50cy9jYXJkL3NyYy9saWIvY29tcG9uZW50cy9jYXJkLWltYWdlL2NhcmQtaW1hZ2UuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL2NvbXBvbmVudHMvY2FyZC9zcmMvbGliL2NvbXBvbmVudHMvY2FyZC1pbWFnZS9jYXJkLWltYWdlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDOUQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDcEUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3JELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNuRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQzs7QUFFckQ7O0dBRUc7QUFRSSxXQUFNLGtCQUFrQixHQUF4QixNQUFNLGtCQUFrQjtJQUF4QjtRQUNZLFdBQU0sR0FBRyxnQkFBZ0IsRUFBRSxDQUFDO1FBQzdCLFlBQU8sR0FBRyxhQUFhLEVBQUUsQ0FBQztRQUUxQzs7Ozs7V0FLRztRQUVJLGVBQVUsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsSUFBSSxNQUFNLENBQUM7UUFFckQ7Ozs7O1dBS0c7UUFFSSxtQkFBYyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsY0FBYyxJQUFJLE1BQU0sQ0FBQztLQVc5RDtJQVRDLElBQ2MsaUJBQWlCO1FBQzdCLE9BQU8sSUFBSSxDQUFDLGNBQWMsSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLGNBQWMsSUFBSSxNQUFNLENBQUM7SUFDckUsQ0FBQztJQUVELElBQ2MsbUJBQW1CO1FBQy9CLE9BQU8sSUFBSSxDQUFDLFVBQVUsSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsSUFBSSxNQUFNLENBQUM7SUFDN0QsQ0FBQzsrR0E5QlUsa0JBQWtCO21HQUFsQixrQkFBa0IsOFNDaEIvQix3TkFPQSw0Q0RPWSxvQkFBb0I7O0FBRW5CLGtCQUFrQjtJQVA5QixZQUFZLENBQUMsWUFBWSxDQUFDO0dBT2Qsa0JBQWtCLENBK0I5Qjs0RkEvQlksa0JBQWtCO2tCQU45QixTQUFTOytCQUNFLGdCQUFnQixjQUVkLElBQUksV0FDUCxDQUFDLG9CQUFvQixDQUFDOzhCQWF4QixVQUFVO3NCQURoQixLQUFLO2dCQVVDLGNBQWM7c0JBRHBCLEtBQUs7Z0JBSVEsaUJBQWlCO3NCQUQ5QixXQUFXO3VCQUFDLG1DQUFtQztnQkFNbEMsbUJBQW1CO3NCQURoQyxXQUFXO3VCQUFDLHFDQUFxQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDaGlwTGlzdFJvd0NvbXBvbmVudCB9IGZyb20gJ0BvZHgvYW5ndWxhci9jb21wb25lbnRzL2NoaXAnO1xuaW1wb3J0IHsgQ1NTQ29tcG9uZW50IH0gZnJvbSAnQG9keC9hbmd1bGFyL2ludGVybmFsJztcbmltcG9ydCB7IGluamVjdEVsZW1lbnQgfSBmcm9tICdAb2R4L2FuZ3VsYXIvdXRpbHMnO1xuaW1wb3J0IHsgaW5qZWN0Q2FyZENvbmZpZyB9IGZyb20gJy4uLy4uL2NhcmQuY29uZmlnJztcblxuLyoqXG4gKiBSZXByZXNlbnRzIGEgY2FyZCBpbWFnZSBjb21wb25lbnQuXG4gKi9cbkBDU1NDb21wb25lbnQoJ2NhcmQtaW1hZ2UnKVxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnb2R4LWNhcmQtaW1hZ2UnLFxuICB0ZW1wbGF0ZVVybDogJy4vY2FyZC1pbWFnZS5jb21wb25lbnQuaHRtbCcsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDaGlwTGlzdFJvd0NvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIENhcmRJbWFnZUNvbXBvbmVudCB7XG4gIHByaXZhdGUgcmVhZG9ubHkgY29uZmlnID0gaW5qZWN0Q2FyZENvbmZpZygpO1xuICBwdWJsaWMgcmVhZG9ubHkgZWxlbWVudCA9IGluamVjdEVsZW1lbnQoKTtcblxuICAvKipcbiAgICogVGhlIHJhdGlvIG9mIHRoZSBjYXJkIGltYWdlLlxuICAgKlxuICAgKiBAdHlwZSB7c3RyaW5nfVxuICAgKiBAZGVmYXVsdCAnYXV0bydcbiAgICovXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBpbWFnZVJhdGlvID0gdGhpcy5jb25maWcuaW1hZ2VSYXRpbyA/PyAnYXV0byc7XG5cbiAgLyoqXG4gICAqIFRoZSBtYXhpbXVtIGhlaWdodCBvZiB0aGUgY2FyZCBpbWFnZS5cbiAgICpcbiAgICogQHR5cGUge3N0cmluZ31cbiAgICogQGRlZmF1bHQgJ2F1dG8nXG4gICAqL1xuICBASW5wdXQoKVxuICBwdWJsaWMgbWF4SW1hZ2VIZWlnaHQgPSB0aGlzLmNvbmZpZy5tYXhJbWFnZUhlaWdodCA/PyAnYXV0byc7XG5cbiAgQEhvc3RCaW5kaW5nKGBzdHlsZS4tLW9keC1jYXJkLWltYWdlLW1heC1oZWlnaHRgKVxuICBwcm90ZWN0ZWQgZ2V0IGdldE1heEltYWdlSGVpZ2h0KCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMubWF4SW1hZ2VIZWlnaHQgPz8gdGhpcy5jb25maWcubWF4SW1hZ2VIZWlnaHQgPz8gJ2F1dG8nO1xuICB9XG5cbiAgQEhvc3RCaW5kaW5nKGBzdHlsZS4tLW9keC1jYXJkLWltYWdlLWFzcGVjdC1yYXRpb2ApXG4gIHByb3RlY3RlZCBnZXQgZ2V0SW1hZ2VBc3BlY3RSYXRpbygpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLmltYWdlUmF0aW8gPz8gdGhpcy5jb25maWcuaW1hZ2VSYXRpbyA/PyAnYXV0byc7XG4gIH1cbn1cbiIsIjxvZHgtY2hpcC1saXN0LXJvdz5cbiAgPG5nLWNvbnRlbnQgbmdQcm9qZWN0QXM9XCJvZHgtY2hpcFwiIHNlbGVjdD1cIm9keC1jaGlwXCI+PC9uZy1jb250ZW50PlxuPC9vZHgtY2hpcC1saXN0LXJvdz5cblxuPGZpZ3VyZSBjbGFzcz1cIm9keC1jYXJkLWltYWdlX19pbWdcIj5cbiAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiaW1nXCI+PC9uZy1jb250ZW50PlxuPC9maWd1cmU+XG4iXX0=
|
|
@@ -1,3 +1,4 @@
|
|
|
1
1
|
export * from './card-footer/card-footer.component';
|
|
2
|
+
export * from './card-image/card-image.component';
|
|
2
3
|
export * from './launch-card-subtitle/launch-card-subtitle.component';
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvY29tcG9uZW50cy9jYXJkL3NyYy9saWIvY29tcG9uZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsbUNBQW1DLENBQUM7QUFDbEQsY0FBYyx1REFBdUQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY2FyZC1mb290ZXIvY2FyZC1mb290ZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY2FyZC1pbWFnZS9jYXJkLWltYWdlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xhdW5jaC1jYXJkLXN1YnRpdGxlL2xhdW5jaC1jYXJkLXN1YnRpdGxlLmNvbXBvbmVudCc7XG4iXX0=
|
|
@@ -5,16 +5,16 @@ import * as i0 from "@angular/core";
|
|
|
5
5
|
*/
|
|
6
6
|
export class CardContentDirective {
|
|
7
7
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CardContentDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
8
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: CardContentDirective, isStandalone: true, selector: "[odxCardContent]", host: { properties: { "class.odx-card__content": "true" } }, ngImport: i0 }); }
|
|
8
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: CardContentDirective, isStandalone: true, selector: "[odxCardContent], odx-card-content", host: { properties: { "class.odx-card__content": "true" } }, ngImport: i0 }); }
|
|
9
9
|
}
|
|
10
10
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CardContentDirective, decorators: [{
|
|
11
11
|
type: Directive,
|
|
12
12
|
args: [{
|
|
13
|
-
selector: '[odxCardContent]',
|
|
13
|
+
selector: '[odxCardContent], odx-card-content',
|
|
14
14
|
standalone: true,
|
|
15
15
|
host: {
|
|
16
16
|
'[class.odx-card__content]': 'true',
|
|
17
17
|
},
|
|
18
18
|
}]
|
|
19
19
|
}] });
|
|
20
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FyZC1jb250ZW50LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9jb21wb25lbnRzL2NhcmQvc3JjL2xpYi9kaXJlY3RpdmVzL2NhcmQtY29udGVudC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFMUM7O0dBRUc7QUFRSCxNQUFNLE9BQU8sb0JBQW9COytHQUFwQixvQkFBb0I7bUdBQXBCLG9CQUFvQjs7NEZBQXBCLG9CQUFvQjtrQkFQaEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsb0NBQW9DO29CQUM5QyxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsSUFBSSxFQUFFO3dCQUNKLDJCQUEyQixFQUFFLE1BQU07cUJBQ3BDO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogRGlyZWN0aXZlIGZvciBkaXNwbGF5aW5nIHRoZSBjb250ZW50IG9mIGEgY2FyZC5cbiAqL1xuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW29keENhcmRDb250ZW50XSwgb2R4LWNhcmQtY29udGVudCcsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGhvc3Q6IHtcbiAgICAnW2NsYXNzLm9keC1jYXJkX19jb250ZW50XSc6ICd0cnVlJyxcbiAgfSxcbn0pXG5leHBvcnQgY2xhc3MgQ2FyZENvbnRlbnREaXJlY3RpdmUge31cbiJdfQ==
|