@daffodil/design 0.75.0 → 0.76.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/article/src/article-theme.scss +18 -8
- package/breadcrumb/README.md +52 -0
- package/breadcrumb/breadcrumb/breadcrumb.component.d.ts +7 -0
- package/breadcrumb/breadcrumb-item/breadcrumb-item.directive.d.ts +9 -0
- package/breadcrumb/breadcrumb.d.ts +3 -0
- package/breadcrumb/breadcrumb.module.d.ts +9 -0
- package/breadcrumb/examples/basic-breadcrumb/basic-breadcrumb.component.d.ts +5 -0
- package/breadcrumb/examples/index.d.ts +1 -0
- package/breadcrumb/examples/public_api.d.ts +2 -0
- package/breadcrumb/index.d.ts +1 -0
- package/breadcrumb/public_api.d.ts +4 -0
- package/breadcrumb/src/breadcrumb-theme.scss +13 -0
- package/core/article-encapsulated/article-encapsulated.directive.d.ts +17 -5
- package/core/colorable/colorable.directive.d.ts +29 -2
- package/core/compactable/compactable.directive.d.ts +31 -2
- package/core/manage-container-layout/manage-container-layout.directive.d.ts +38 -1
- package/core/sizable/sizable.directive.d.ts +46 -3
- package/core/skeletonable/skeletonable.directive.d.ts +36 -3
- package/core/statusable/statusable.directive.d.ts +33 -6
- package/core/text-alignable/text-alignable.directive.d.ts +35 -4
- package/esm2022/article/article/article.component.mjs +2 -2
- package/esm2022/breadcrumb/breadcrumb/breadcrumb.component.mjs +25 -0
- package/esm2022/breadcrumb/breadcrumb-item/breadcrumb-item.directive.mjs +33 -0
- package/esm2022/breadcrumb/breadcrumb.mjs +7 -0
- package/esm2022/breadcrumb/breadcrumb.module.mjs +26 -0
- package/esm2022/breadcrumb/daffodil-design-breadcrumb.mjs +5 -0
- package/esm2022/breadcrumb/examples/basic-breadcrumb/basic-breadcrumb.component.mjs +15 -0
- package/esm2022/breadcrumb/examples/daffodil-design-breadcrumb-examples.mjs +5 -0
- package/esm2022/breadcrumb/examples/index.mjs +2 -0
- package/esm2022/breadcrumb/examples/public_api.mjs +5 -0
- package/esm2022/breadcrumb/index.mjs +2 -0
- package/esm2022/breadcrumb/public_api.mjs +5 -0
- package/esm2022/core/article-encapsulated/article-encapsulated.directive.mjs +18 -6
- package/esm2022/core/colorable/colorable.directive.mjs +30 -3
- package/esm2022/core/compactable/compactable.directive.mjs +32 -3
- package/esm2022/core/manage-container-layout/manage-container-layout.directive.mjs +39 -2
- package/esm2022/core/sizable/sizable.directive.mjs +47 -4
- package/esm2022/core/skeletonable/skeletonable.directive.mjs +37 -4
- package/esm2022/core/statusable/statusable.directive.mjs +34 -7
- package/esm2022/core/text-alignable/text-alignable.directive.mjs +36 -5
- package/esm2022/modal/examples/basic-modal/basic-modal.component.mjs +2 -2
- package/esm2022/modal/modal/modal-config.mjs +1 -1
- package/esm2022/modal/service/modal.service.mjs +4 -1
- package/esm2022/sidebar/helper/is-docked-mode.mjs +9 -0
- package/esm2022/sidebar/helper/is-floating-mode.mjs +9 -0
- package/esm2022/sidebar/public_api.mjs +5 -1
- package/esm2022/sidebar/service/registration.type.mjs +2 -0
- package/esm2022/sidebar/service/sidebar.service.mjs +36 -0
- package/esm2022/sidebar/sidebar-viewport/sidebar-viewport.component.mjs +3 -3
- package/esm2022/tree/tree/tree.component.mjs +2 -2
- package/esm2022/tree/tree-item/tree-item.directive.mjs +3 -3
- package/fesm2022/daffodil-design-article.mjs +2 -2
- package/fesm2022/daffodil-design-article.mjs.map +1 -1
- package/fesm2022/daffodil-design-breadcrumb-examples.mjs +26 -0
- package/fesm2022/daffodil-design-breadcrumb-examples.mjs.map +1 -0
- package/fesm2022/daffodil-design-breadcrumb.mjs +90 -0
- package/fesm2022/daffodil-design-breadcrumb.mjs.map +1 -0
- package/fesm2022/daffodil-design-modal-examples.mjs +1 -1
- package/fesm2022/daffodil-design-modal-examples.mjs.map +1 -1
- package/fesm2022/daffodil-design-modal.mjs +3 -0
- package/fesm2022/daffodil-design-modal.mjs.map +1 -1
- package/fesm2022/daffodil-design-sidebar.mjs +57 -5
- package/fesm2022/daffodil-design-sidebar.mjs.map +1 -1
- package/fesm2022/daffodil-design-tree.mjs +4 -4
- package/fesm2022/daffodil-design-tree.mjs.map +1 -1
- package/fesm2022/daffodil-design.mjs +265 -26
- package/fesm2022/daffodil-design.mjs.map +1 -1
- package/modal/README.md +14 -1
- package/modal/modal/modal-config.d.ts +2 -0
- package/package.json +1 -1
- package/scss/theme.scss +2 -0
- package/scss/theming/_theme-css-variables.scss +1 -1
- package/sidebar/helper/is-docked-mode.d.ts +5 -0
- package/sidebar/helper/is-floating-mode.d.ts +5 -0
- package/sidebar/public_api.d.ts +4 -0
- package/sidebar/service/registration.type.d.ts +11 -0
- package/sidebar/service/sidebar.service.d.ts +25 -0
@@ -2,23 +2,50 @@ import { Directive, HostBinding, Input, } from '@angular/core';
|
|
2
2
|
import { DaffStatusEnum, } from './statusable';
|
3
3
|
import * as i0 from "@angular/core";
|
4
4
|
/**
|
5
|
-
*
|
5
|
+
* `DaffStatusableDirective` allows a component to conditionally apply status-specific
|
6
6
|
* styles by setting CSS classes based on the specified status. This directive is useful
|
7
|
-
* for indicating different statuses such as
|
7
|
+
* for indicating different statuses such as warning, danger, or success states.
|
8
8
|
*
|
9
|
-
* ##
|
9
|
+
* ## Usage
|
10
|
+
*
|
11
|
+
* ### Implementing it as an attribute directive
|
10
12
|
*
|
11
13
|
* ```html
|
12
14
|
* <div daffStatusable [status]="componentStatus">Status content</div>
|
13
15
|
* ```
|
14
16
|
*
|
17
|
+
* ### Implementing it as an Angular host directive
|
18
|
+
*
|
19
|
+
* ```ts
|
20
|
+
* @Component({
|
21
|
+
* standalone: true,
|
22
|
+
* selector: 'custom-component',
|
23
|
+
* template: 'custom-component.html',
|
24
|
+
* hostDirectives: [
|
25
|
+
* {
|
26
|
+
* directive: DaffStatusableDirective,
|
27
|
+
* inputs: ['status'],
|
28
|
+
* },
|
29
|
+
* ],
|
30
|
+
* })
|
31
|
+
* export class CustomComponent { }
|
32
|
+
*
|
33
|
+
* ```scss
|
34
|
+
* .custom-component {
|
35
|
+
*
|
36
|
+
* &.daff-danger {
|
37
|
+
* background: daff-color($red, 10);
|
38
|
+
* color: daff-color($red, 90);
|
39
|
+
* }
|
40
|
+
* }
|
41
|
+
* ```
|
15
42
|
* ## Styles
|
16
43
|
*
|
17
44
|
* The directive applies the following CSS classes based on the status:
|
18
45
|
*
|
19
|
-
* - `daff-warn`: Applied when the status is `
|
20
|
-
* - `daff-danger`: Applied when the status is `
|
21
|
-
* - `daff-success`: Applied when the status is `
|
46
|
+
* - `daff-warn`: Applied when the status is `warn`.
|
47
|
+
* - `daff-danger`: Applied when the status is `danger`.
|
48
|
+
* - `daff-success`: Applied when the status is `success`.
|
22
49
|
*/
|
23
50
|
export class DaffStatusableDirective {
|
24
51
|
/**
|
@@ -47,4 +74,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImpo
|
|
47
74
|
}], status: [{
|
48
75
|
type: Input
|
49
76
|
}] } });
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
77
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RhdHVzYWJsZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2Rlc2lnbi9zcmMvY29yZS9zdGF0dXNhYmxlL3N0YXR1c2FibGUuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxTQUFTLEVBQ1QsV0FBVyxFQUNYLEtBQUssR0FDTixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBRUwsY0FBYyxHQUVmLE1BQU0sY0FBYyxDQUFDOztBQUV0Qjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBNkNHO0FBS0gsTUFBTSxPQUFPLHVCQUF1QjtJQUVsQzs7O09BR0c7SUFDSCxJQUEwQixLQUFLO1FBQzdCLE9BQU87WUFDTCxXQUFXLEVBQUUsSUFBSSxDQUFDLE1BQU0sS0FBSyxjQUFjLENBQUMsSUFBSTtZQUNoRCxhQUFhLEVBQUUsSUFBSSxDQUFDLE1BQU0sS0FBSyxjQUFjLENBQUMsTUFBTTtZQUNwRCxjQUFjLEVBQUUsSUFBSSxDQUFDLE1BQU0sS0FBSyxjQUFjLENBQUMsT0FBTztTQUN2RCxDQUFDO0lBQ0osQ0FBQztrSUFaVSx1QkFBdUI7c0hBQXZCLHVCQUF1Qjs7NEZBQXZCLHVCQUF1QjtrQkFKbkMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsa0JBQWtCO29CQUM1QixVQUFVLEVBQUUsSUFBSTtpQkFDakI7OEJBTzJCLEtBQUs7c0JBQTlCLFdBQVc7dUJBQUMsT0FBTztnQkFXWCxNQUFNO3NCQUFkLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBEaXJlY3RpdmUsXG4gIEhvc3RCaW5kaW5nLFxuICBJbnB1dCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7XG4gIERhZmZTdGF0dXMsXG4gIERhZmZTdGF0dXNFbnVtLFxuICBEYWZmU3RhdHVzYWJsZSxcbn0gZnJvbSAnLi9zdGF0dXNhYmxlJztcblxuLyoqXG4gKiBgRGFmZlN0YXR1c2FibGVEaXJlY3RpdmVgIGFsbG93cyBhIGNvbXBvbmVudCB0byBjb25kaXRpb25hbGx5IGFwcGx5IHN0YXR1cy1zcGVjaWZpY1xuICogc3R5bGVzIGJ5IHNldHRpbmcgQ1NTIGNsYXNzZXMgYmFzZWQgb24gdGhlIHNwZWNpZmllZCBzdGF0dXMuIFRoaXMgZGlyZWN0aXZlIGlzIHVzZWZ1bFxuICogZm9yIGluZGljYXRpbmcgZGlmZmVyZW50IHN0YXR1c2VzIHN1Y2ggYXMgd2FybmluZywgZGFuZ2VyLCBvciBzdWNjZXNzIHN0YXRlcy5cbiAqXG4gKiAjIyBVc2FnZVxuICpcbiAqICMjIyBJbXBsZW1lbnRpbmcgaXQgYXMgYW4gYXR0cmlidXRlIGRpcmVjdGl2ZVxuICpcbiAqIGBgYGh0bWxcbiAqIDxkaXYgZGFmZlN0YXR1c2FibGUgW3N0YXR1c109XCJjb21wb25lbnRTdGF0dXNcIj5TdGF0dXMgY29udGVudDwvZGl2PlxuICogYGBgXG4gKlxuICogIyMjIEltcGxlbWVudGluZyBpdCBhcyBhbiBBbmd1bGFyIGhvc3QgZGlyZWN0aXZlXG4gKlxuICogYGBgdHNcbiAqIEBDb21wb25lbnQoe1xuICogIHN0YW5kYWxvbmU6IHRydWUsXG4gKiAgc2VsZWN0b3I6ICdjdXN0b20tY29tcG9uZW50JyxcbiAqICB0ZW1wbGF0ZTogJ2N1c3RvbS1jb21wb25lbnQuaHRtbCcsXG4gKiAgaG9zdERpcmVjdGl2ZXM6IFtcbiAqICAgIHtcbiAqICAgICAgZGlyZWN0aXZlOiBEYWZmU3RhdHVzYWJsZURpcmVjdGl2ZSxcbiAqICAgICAgaW5wdXRzOiBbJ3N0YXR1cyddLFxuICogICAgfSxcbiAqICBdLFxuICogfSlcbiAqIGV4cG9ydCBjbGFzcyBDdXN0b21Db21wb25lbnQgeyB9XG4gKlxuICogYGBgc2Nzc1xuICogLmN1c3RvbS1jb21wb25lbnQge1xuICpcbiAqICAmLmRhZmYtZGFuZ2VyIHtcbiAqICAgIGJhY2tncm91bmQ6IGRhZmYtY29sb3IoJHJlZCwgMTApO1xuICogICAgY29sb3I6IGRhZmYtY29sb3IoJHJlZCwgOTApO1xuICogIH1cbiAqIH1cbiAqIGBgYFxuICogIyMgU3R5bGVzXG4gKlxuICogVGhlIGRpcmVjdGl2ZSBhcHBsaWVzIHRoZSBmb2xsb3dpbmcgQ1NTIGNsYXNzZXMgYmFzZWQgb24gdGhlIHN0YXR1czpcbiAqXG4gKiAtIGBkYWZmLXdhcm5gOiBBcHBsaWVkIHdoZW4gdGhlIHN0YXR1cyBpcyBgd2FybmAuXG4gKiAtIGBkYWZmLWRhbmdlcmA6IEFwcGxpZWQgd2hlbiB0aGUgc3RhdHVzIGlzIGBkYW5nZXJgLlxuICogLSBgZGFmZi1zdWNjZXNzYDogQXBwbGllZCB3aGVuIHRoZSBzdGF0dXMgaXMgYHN1Y2Nlc3NgLlxuICovXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbZGFmZlN0YXR1c2FibGVdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgRGFmZlN0YXR1c2FibGVEaXJlY3RpdmUgaW1wbGVtZW50cyBEYWZmU3RhdHVzYWJsZSB7XG5cbiAgLyoqXG4gICAqIER5bmFtaWNhbGx5IHNldHMgdGhlIENTUyBjbGFzc2VzIGJhc2VkIG9uIHRoZSBzdGF0dXMuXG4gICAqIEBkb2NzLXByaXZhdGVcbiAgICovXG4gIEBIb3N0QmluZGluZygnY2xhc3MnKSBnZXQgY2xhc3MoKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgICdkYWZmLXdhcm4nOiB0aGlzLnN0YXR1cyA9PT0gRGFmZlN0YXR1c0VudW0uV2FybixcbiAgICAgICdkYWZmLWRhbmdlcic6IHRoaXMuc3RhdHVzID09PSBEYWZmU3RhdHVzRW51bS5EYW5nZXIsXG4gICAgICAnZGFmZi1zdWNjZXNzJzogdGhpcy5zdGF0dXMgPT09IERhZmZTdGF0dXNFbnVtLlN1Y2Nlc3MsXG4gICAgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBTZXRzIHRoZSBzdGF0dXMgb24gYSBjb21wb25lbnQuXG4gICAqL1xuICBASW5wdXQoKSBzdGF0dXM6IERhZmZTdGF0dXM7XG59XG5cbiJdfQ==
|
@@ -2,21 +2,52 @@ import { Directive, HostBinding, Input, } from '@angular/core';
|
|
2
2
|
import { DaffTextAlignmentEnum, } from './text-alignable';
|
3
3
|
import * as i0 from "@angular/core";
|
4
4
|
/**
|
5
|
-
*
|
6
|
-
*
|
5
|
+
* `DaffTextAlignableDirective` allows for dynamic text alignment of a component by
|
6
|
+
* setting CSS classes based on the specified text alignment. This directive is
|
7
7
|
* useful when text alignment needs to be managed dynamically in an Angular component.
|
8
8
|
*
|
9
|
-
* ##
|
9
|
+
* ## Usage
|
10
|
+
*
|
11
|
+
* ### Implementing it as an attribute directive
|
10
12
|
*
|
11
13
|
* ```html
|
12
14
|
* <div daffTextAlignable textAlignment="center">Aligned text</div>
|
15
|
+
*
|
16
|
+
* In this example, the `daff-center` class is added to the `div` element, allowing
|
17
|
+
* you to style the `div` as you wish using the class.
|
18
|
+
*
|
19
|
+
* ```
|
20
|
+
*
|
21
|
+
* ### Implementing it as an Angular host directive
|
22
|
+
*
|
23
|
+
* ```ts
|
24
|
+
* @Component({
|
25
|
+
* standalone: true,
|
26
|
+
* selector: 'custom-component',
|
27
|
+
* template: 'custom-component.html',
|
28
|
+
* hostDirectives: [
|
29
|
+
* {
|
30
|
+
* directive: DaffTextAlignableDirective,
|
31
|
+
* inputs: ['textAlignment'],
|
32
|
+
* },
|
33
|
+
* ],
|
34
|
+
* })
|
35
|
+
* export class CustomComponent { }
|
36
|
+
* ```
|
37
|
+
*
|
38
|
+
* ```scss
|
39
|
+
* .custom-component {
|
40
|
+
* &.daff-left {
|
41
|
+
* text-align: left;
|
42
|
+
* }
|
43
|
+
* }
|
13
44
|
* ```
|
14
45
|
*
|
15
46
|
* ## Why not just use CSS?
|
16
47
|
*
|
17
48
|
* While the native CSS `text-align` property can be used for static text alignment,
|
18
49
|
* the `DaffTextAlignableDirective` provides a structured and consistent way to handle
|
19
|
-
* dynamic text alignment within Angular components in more complex use-cases
|
50
|
+
* dynamic text alignment within Angular components in more complex use-cases where the
|
20
51
|
* application of `text-align:center` would cause unexpected side effects.
|
21
52
|
*/
|
22
53
|
export class DaffTextAlignableDirective {
|
@@ -50,4 +81,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImpo
|
|
50
81
|
}], textAlignment: [{
|
51
82
|
type: Input
|
52
83
|
}] } });
|
53
|
-
//# sourceMappingURL=data:application/json;base64,
|
84
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC1hbGlnbmFibGUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9kZXNpZ24vc3JjL2NvcmUvdGV4dC1hbGlnbmFibGUvdGV4dC1hbGlnbmFibGUuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxTQUFTLEVBQ1QsV0FBVyxFQUNYLEtBQUssR0FHTixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBR0wscUJBQXFCLEdBQ3RCLE1BQU0sa0JBQWtCLENBQUM7O0FBRTFCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FnREc7QUFLSCxNQUFNLE9BQU8sMEJBQTBCO0lBRXJDOztPQUVHO0lBQ0gsSUFBMEIsS0FBSztRQUM3QixPQUFPO1lBQ0wsV0FBVyxFQUFFLElBQUksQ0FBQyxhQUFhLEtBQUsscUJBQXFCLENBQUMsSUFBSTtZQUM5RCxhQUFhLEVBQUUsSUFBSSxDQUFDLGFBQWEsS0FBSyxxQkFBcUIsQ0FBQyxNQUFNO1lBQ2xFLFlBQVksRUFBRSxJQUFJLENBQUMsYUFBYSxLQUFLLHFCQUFxQixDQUFDLEtBQUs7U0FDakUsQ0FBQztJQUNKLENBQUM7SUFZRCxXQUFXLENBQUMsT0FBc0I7UUFDaEMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLEVBQUUsWUFBWSxFQUFFO1lBQ3hDLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDO1NBQzVDO0lBQ0gsQ0FBQztrSUEzQlUsMEJBQTBCO3NIQUExQiwwQkFBMEI7OzRGQUExQiwwQkFBMEI7a0JBSnRDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHFCQUFxQjtvQkFDL0IsVUFBVSxFQUFFLElBQUk7aUJBQ2pCOzhCQU0yQixLQUFLO3NCQUE5QixXQUFXO3VCQUFDLE9BQU87Z0JBV1gsYUFBYTtzQkFBckIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIERpcmVjdGl2ZSxcbiAgSG9zdEJpbmRpbmcsXG4gIElucHV0LFxuICBPbkNoYW5nZXMsXG4gIFNpbXBsZUNoYW5nZXMsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQge1xuICBEYWZmVGV4dEFsaWduYWJsZSxcbiAgRGFmZlRleHRBbGlnbm1lbnQsXG4gIERhZmZUZXh0QWxpZ25tZW50RW51bSxcbn0gZnJvbSAnLi90ZXh0LWFsaWduYWJsZSc7XG5cbi8qKlxuICogYERhZmZUZXh0QWxpZ25hYmxlRGlyZWN0aXZlYCBhbGxvd3MgZm9yIGR5bmFtaWMgdGV4dCBhbGlnbm1lbnQgb2YgYSBjb21wb25lbnQgYnlcbiAqIHNldHRpbmcgQ1NTIGNsYXNzZXMgYmFzZWQgb24gdGhlIHNwZWNpZmllZCB0ZXh0IGFsaWdubWVudC4gVGhpcyBkaXJlY3RpdmUgaXNcbiAqIHVzZWZ1bCB3aGVuIHRleHQgYWxpZ25tZW50IG5lZWRzIHRvIGJlIG1hbmFnZWQgZHluYW1pY2FsbHkgaW4gYW4gQW5ndWxhciBjb21wb25lbnQuXG4gKlxuICogIyMgVXNhZ2VcbiAqXG4gKiAjIyMgSW1wbGVtZW50aW5nIGl0IGFzIGFuIGF0dHJpYnV0ZSBkaXJlY3RpdmVcbiAqXG4gKiBgYGBodG1sXG4gKiA8ZGl2IGRhZmZUZXh0QWxpZ25hYmxlIHRleHRBbGlnbm1lbnQ9XCJjZW50ZXJcIj5BbGlnbmVkIHRleHQ8L2Rpdj5cbiAqXG4gKiBJbiB0aGlzIGV4YW1wbGUsIHRoZSBgZGFmZi1jZW50ZXJgIGNsYXNzIGlzIGFkZGVkIHRvIHRoZSBgZGl2YCBlbGVtZW50LCBhbGxvd2luZ1xuICogeW91IHRvIHN0eWxlIHRoZSBgZGl2YCBhcyB5b3Ugd2lzaCB1c2luZyB0aGUgY2xhc3MuXG4gKlxuICogYGBgXG4gKlxuICogIyMjIEltcGxlbWVudGluZyBpdCBhcyBhbiBBbmd1bGFyIGhvc3QgZGlyZWN0aXZlXG4gKlxuICogYGBgdHNcbiAqIEBDb21wb25lbnQoe1xuICogIHN0YW5kYWxvbmU6IHRydWUsXG4gKiAgc2VsZWN0b3I6ICdjdXN0b20tY29tcG9uZW50JyxcbiAqICB0ZW1wbGF0ZTogJ2N1c3RvbS1jb21wb25lbnQuaHRtbCcsXG4gKiAgaG9zdERpcmVjdGl2ZXM6IFtcbiAqICAgIHtcbiAqICAgICAgZGlyZWN0aXZlOiBEYWZmVGV4dEFsaWduYWJsZURpcmVjdGl2ZSxcbiAqICAgICAgaW5wdXRzOiBbJ3RleHRBbGlnbm1lbnQnXSxcbiAqICAgIH0sXG4gKiAgXSxcbiAqIH0pXG4gKiBleHBvcnQgY2xhc3MgQ3VzdG9tQ29tcG9uZW50IHsgfVxuICogYGBgXG4gKlxuICogYGBgc2Nzc1xuICogLmN1c3RvbS1jb21wb25lbnQge1xuICogICYuZGFmZi1sZWZ0IHtcbiAqICAgIHRleHQtYWxpZ246IGxlZnQ7XG4gKiAgfVxuICogfVxuICogYGBgXG4gKlxuICogIyMgV2h5IG5vdCBqdXN0IHVzZSBDU1M/XG4gKlxuICogV2hpbGUgdGhlIG5hdGl2ZSBDU1MgYHRleHQtYWxpZ25gIHByb3BlcnR5IGNhbiBiZSB1c2VkIGZvciBzdGF0aWMgdGV4dCBhbGlnbm1lbnQsXG4gKiB0aGUgYERhZmZUZXh0QWxpZ25hYmxlRGlyZWN0aXZlYCBwcm92aWRlcyBhIHN0cnVjdHVyZWQgYW5kIGNvbnNpc3RlbnQgd2F5IHRvIGhhbmRsZVxuICogZHluYW1pYyB0ZXh0IGFsaWdubWVudCB3aXRoaW4gQW5ndWxhciBjb21wb25lbnRzIGluIG1vcmUgY29tcGxleCB1c2UtY2FzZXMgd2hlcmUgdGhlXG4gKiBhcHBsaWNhdGlvbiBvZiBgdGV4dC1hbGlnbjpjZW50ZXJgIHdvdWxkIGNhdXNlIHVuZXhwZWN0ZWQgc2lkZSBlZmZlY3RzLlxuICovXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbZGFmZlRleHRBbGlnbmFibGVdJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgRGFmZlRleHRBbGlnbmFibGVEaXJlY3RpdmUgaW1wbGVtZW50cyBEYWZmVGV4dEFsaWduYWJsZSwgT25DaGFuZ2VzIHtcblxuICAvKipcbiAgICogQGRvY3MtcHJpdmF0ZVxuICAgKi9cbiAgQEhvc3RCaW5kaW5nKCdjbGFzcycpIGdldCBjbGFzcygpIHtcbiAgICByZXR1cm4ge1xuICAgICAgJ2RhZmYtbGVmdCc6IHRoaXMudGV4dEFsaWdubWVudCA9PT0gRGFmZlRleHRBbGlnbm1lbnRFbnVtLkxlZnQsXG4gICAgICAnZGFmZi1jZW50ZXInOiB0aGlzLnRleHRBbGlnbm1lbnQgPT09IERhZmZUZXh0QWxpZ25tZW50RW51bS5DZW50ZXIsXG4gICAgICAnZGFmZi1yaWdodCc6IHRoaXMudGV4dEFsaWdubWVudCA9PT0gRGFmZlRleHRBbGlnbm1lbnRFbnVtLlJpZ2h0LFxuICAgIH07XG4gIH1cblxuICAvKipcbiAgICogVGhlIHRleHQtYWxpZ25tZW50IG9mIGEgY29tcG9uZW50LlxuICAgKi9cbiAgQElucHV0KCkgdGV4dEFsaWdubWVudDogRGFmZlRleHRBbGlnbm1lbnQ7XG5cbiAgLyoqXG4gICAqIFNldHMgYSBkZWZhdWx0IHRleHRBbGlnbm1lbnQuXG4gICAqL1xuICBwdWJsaWMgZGVmYXVsdEFsaWdubWVudDogRGFmZlRleHRBbGlnbm1lbnQ7XG5cbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcykge1xuICAgIGlmICghY2hhbmdlcy50ZXh0QWxpZ25tZW50Py5jdXJyZW50VmFsdWUpIHtcbiAgICAgIHRoaXMudGV4dEFsaWdubWVudCA9IHRoaXMuZGVmYXVsdEFsaWdubWVudDtcbiAgICB9XG4gIH1cbn1cblxuIl19
|
@@ -10,7 +10,7 @@ export class BasicModalComponent {
|
|
10
10
|
this.modalService = modalService;
|
11
11
|
}
|
12
12
|
showModal() {
|
13
|
-
this.modal = this.modalService.open(BasicModalContentComponent);
|
13
|
+
this.modal = this.modalService.open(BasicModalContentComponent, { ariaLabelledBy: 'Modal Title' });
|
14
14
|
}
|
15
15
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: BasicModalComponent, deps: [{ token: i1.DaffModalService }], target: i0.ɵɵFactoryTarget.Component }); }
|
16
16
|
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.10", type: BasicModalComponent, isStandalone: true, selector: "basic-modal", ngImport: i0, template: "<button daff-button (click)=\"showModal()\">Open Modal</button>\n", dependencies: [{ kind: "ngmodule", type: DaffButtonModule }, { kind: "component", type: i2.DaffButtonComponent, selector: "button[daff-button],button[daff-stroked-button],button[daff-raised-button],button[daff-flat-button],button[daff-icon-button],button[daff-underline-button],a[daff-button],a[daff-stroked-button],a[daff-raised-button],a[daff-flat-button],a[daff-icon-button],a[daff-underline-button]", inputs: ["loading", "tabindex", "disabled"] }, { kind: "ngmodule", type: DaffModalModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
@@ -19,4 +19,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImpo
|
|
19
19
|
type: Component,
|
20
20
|
args: [{ selector: 'basic-modal', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [DaffButtonModule, DaffModalModule], template: "<button daff-button (click)=\"showModal()\">Open Modal</button>\n" }]
|
21
21
|
}], ctorParameters: () => [{ type: i1.DaffModalService }] });
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzaWMtbW9kYWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9kZXNpZ24vbW9kYWwvZXhhbXBsZXMvc3JjL2Jhc2ljLW1vZGFsL2Jhc2ljLW1vZGFsLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvZGVzaWduL21vZGFsL2V4YW1wbGVzL3NyYy9iYXNpYy1tb2RhbC9iYXNpYy1tb2RhbC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsR0FDVixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUMzRCxPQUFPLEVBRUwsZUFBZSxFQUNmLGdCQUFnQixHQUNqQixNQUFNLHdCQUF3QixDQUFDO0FBRWhDLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLDJCQUEyQixDQUFDOzs7O0FBVXZFLE1BQU0sT0FBTyxtQkFBbUI7SUFHOUIsWUFBb0IsWUFBOEI7UUFBOUIsaUJBQVksR0FBWixZQUFZLENBQWtCO0lBQUcsQ0FBQztJQUV0RCxTQUFTO1FBQ1AsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FDakMsMEJBQTBCLEVBQzFCLEVBQUUsY0FBYyxFQUFFLGFBQWEsRUFBRSxDQUNsQyxDQUFDO0lBQ0osQ0FBQztrSUFWVSxtQkFBbUI7c0hBQW5CLG1CQUFtQix1RUN0QmhDLG1FQUNBLDJDRG1CWSxnQkFBZ0IscWFBQUUsZUFBZTs7NEZBRWhDLG1CQUFtQjtrQkFSL0IsU0FBUzsrQkFFRSxhQUFhLG1CQUVOLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsSUFBSSxXQUNQLENBQUMsZ0JBQWdCLEVBQUUsZUFBZSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IERhZmZCdXR0b25Nb2R1bGUgfSBmcm9tICdAZGFmZm9kaWwvZGVzaWduL2J1dHRvbic7XG5pbXBvcnQge1xuICBEYWZmTW9kYWxDb21wb25lbnQsXG4gIERhZmZNb2RhbE1vZHVsZSxcbiAgRGFmZk1vZGFsU2VydmljZSxcbn0gZnJvbSAnQGRhZmZvZGlsL2Rlc2lnbi9tb2RhbCc7XG5cbmltcG9ydCB7IEJhc2ljTW9kYWxDb250ZW50Q29tcG9uZW50IH0gZnJvbSAnLi9tb2RhbC1jb250ZW50LmNvbXBvbmVudCc7XG5cbkBDb21wb25lbnQoe1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQGFuZ3VsYXItZXNsaW50L2NvbXBvbmVudC1zZWxlY3RvclxuICBzZWxlY3RvcjogJ2Jhc2ljLW1vZGFsJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2Jhc2ljLW1vZGFsLmNvbXBvbmVudC5odG1sJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtEYWZmQnV0dG9uTW9kdWxlLCBEYWZmTW9kYWxNb2R1bGVdLFxufSlcbmV4cG9ydCBjbGFzcyBCYXNpY01vZGFsQ29tcG9uZW50IHtcbiAgbW9kYWw6IERhZmZNb2RhbENvbXBvbmVudDtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIG1vZGFsU2VydmljZTogRGFmZk1vZGFsU2VydmljZSkge31cblxuICBzaG93TW9kYWwoKSB7XG4gICAgdGhpcy5tb2RhbCA9IHRoaXMubW9kYWxTZXJ2aWNlLm9wZW4oXG4gICAgICBCYXNpY01vZGFsQ29udGVudENvbXBvbmVudCxcbiAgICAgIHsgYXJpYUxhYmVsbGVkQnk6ICdNb2RhbCBUaXRsZScgfSxcbiAgICApO1xuICB9XG59XG4iLCI8YnV0dG9uIGRhZmYtYnV0dG9uIChjbGljayk9XCJzaG93TW9kYWwoKVwiPk9wZW4gTW9kYWw8L2J1dHRvbj5cbiJdfQ==
|
@@ -1,2 +1,2 @@
|
|
1
1
|
export {};
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9kZXNpZ24vbW9kYWwvc3JjL21vZGFsL21vZGFsLWNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBEYWZmTW9kYWxDb25maWd1cmF0aW9uIHtcbiAgLyoqXG4gICAqIEEgaG9vayBmb3Igd2hhdCB0byBkbyB3aGVuIHRoZSBiYWNrZHJvcCBiZWhpbmQgYVxuICAgKiBEYWZmTW9kYWxDb21wb25lbnQgaXMgaW50ZXJhY3RlZCB3aXRoLlxuICAgKi9cbiAgb25CYWNrZHJvcENsaWNrZWQ/
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwtY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9kZXNpZ24vbW9kYWwvc3JjL21vZGFsL21vZGFsLWNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBEYWZmTW9kYWxDb25maWd1cmF0aW9uIHtcbiAgLyoqXG4gICAqIEEgaG9vayBmb3Igd2hhdCB0byBkbyB3aGVuIHRoZSBiYWNrZHJvcCBiZWhpbmQgYVxuICAgKiBEYWZmTW9kYWxDb21wb25lbnQgaXMgaW50ZXJhY3RlZCB3aXRoLlxuICAgKi9cbiAgb25CYWNrZHJvcENsaWNrZWQ/OiAoKSA9PiB2b2lkO1xuXG4gIC8qKiBTZXRzIHRoZSBgYXJpYS1sYWJlbGxlZGJ5YCBwcm9wZXJ0eSBvbiB0aGUgbW9kYWwgKi9cbiAgYXJpYUxhYmVsbGVkQnk/OiBzdHJpbmc7XG59XG4iXX0=
|
@@ -42,6 +42,9 @@ export class DaffModalService {
|
|
42
42
|
const _ref = this._createOverlayRef();
|
43
43
|
const _modal = this._attachModal(_ref);
|
44
44
|
const _attachedModal = this._attachModalContent(component, _modal);
|
45
|
+
if (configuration?.ariaLabelledBy) {
|
46
|
+
_modal.instance.ariaLabelledBy = configuration.ariaLabelledBy;
|
47
|
+
}
|
45
48
|
const modal = {
|
46
49
|
modal: _modal,
|
47
50
|
overlay: _ref,
|
@@ -66,4 +69,4 @@ export class DaffModalService {
|
|
66
69
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: DaffModalService, decorators: [{
|
67
70
|
type: Injectable
|
68
71
|
}], ctorParameters: () => [{ type: i1.Overlay }] });
|
69
|
-
//# sourceMappingURL=data:application/json;base64,
|
72
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9kYWwuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvZGVzaWduL21vZGFsL3NyYy9zZXJ2aWNlL21vZGFsLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUVMLE9BQU8sRUFDUCxzQkFBc0IsR0FDdkIsTUFBTSxzQkFBc0IsQ0FBQztBQUM5QixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDdEQsT0FBTyxFQUNMLFVBQVUsRUFHVixRQUFRLEdBQ1QsTUFBTSxlQUFlLENBQUM7QUFJdkIsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7OztBQUc5RCxNQUFNLE9BQU8sZ0JBQWdCO0lBRzNCLFlBQW9CLE9BQWdCO1FBQWhCLFlBQU8sR0FBUCxPQUFPLENBQVM7UUFGNUIsWUFBTyxHQUF1QyxJQUFJLEdBQUcsRUFBRSxDQUFDO1FBSXhELHlCQUFvQixHQUEyQixFQUFFLENBQUM7SUFGbkIsQ0FBQztJQUloQyxZQUFZLENBQ25CLFVBQXNCO1FBRXRCLE1BQU0sS0FBSyxHQUFHLFVBQVUsQ0FBQyxNQUFNLENBQzVCLElBQUksZUFBZSxDQUNqQixrQkFBa0IsRUFDbEIsU0FBUyxFQUNULFFBQVEsQ0FBQyxNQUFNLENBQUMsRUFBRSxTQUFTLEVBQUUsQ0FBQztvQkFDNUIsT0FBTyxFQUFFLGdCQUFnQjtvQkFDekIsUUFBUSxFQUFFLElBQUk7aUJBQ2YsQ0FBQyxFQUFDLENBQUMsQ0FDTCxDQUNGLENBQUM7UUFDSCxLQUFLLENBQUMsUUFBUSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUM7UUFDM0IsT0FBTyxLQUFLLENBQUM7SUFDZCxDQUFDO0lBRU8sbUJBQW1CLENBQzFCLFNBQW9CLEVBQ3BCLEtBQXVDO1FBRXZDLEtBQUssQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLElBQUksZUFBZSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUM7SUFDOUQsQ0FBQztJQUVPLGlCQUFpQjtRQUN4QixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDO1lBQ3pCLFdBQVcsRUFBRSxJQUFJO1lBQ2pCLGdCQUFnQixFQUFFLElBQUksc0JBQXNCLEVBQUU7aUJBQzNDLGtCQUFrQixFQUFFO2lCQUNuQixnQkFBZ0IsRUFBRTtZQUN0QixjQUFjLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLEVBQUU7U0FDdEQsQ0FBQyxDQUFDO0lBQ0osQ0FBQztJQUVPLFlBQVksQ0FBQyxLQUFnQjtRQUNuQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsRUFBRTtZQUMzQyxNQUFNLElBQUksS0FBSyxDQUNkLHlEQUF5RCxDQUMxRCxDQUFDO1NBQ0Y7UUFFRixJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRTFDLEtBQUssQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUVELElBQUksQ0FDSCxTQUFvQixFQUNwQixhQUErQztRQUUvQyxNQUFNLE1BQU0sR0FBRyxFQUFFLEdBQUcsSUFBSSxDQUFDLG9CQUFvQixFQUFFLEdBQUcsYUFBYSxFQUFFLENBQUM7UUFDbEUsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUM7UUFDdEMsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN2QyxNQUFNLGNBQWMsR0FBRyxJQUFJLENBQUMsbUJBQW1CLENBQUMsU0FBUyxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBRWxFLElBQUcsYUFBYSxFQUFFLGNBQWMsRUFBRTtZQUNoQyxNQUFNLENBQUMsUUFBUSxDQUFDLGNBQWMsR0FBRyxhQUFhLENBQUMsY0FBYyxDQUFDO1NBQy9EO1FBRUYsTUFBTSxLQUFLLEdBQWM7WUFDdkIsS0FBSyxFQUFFLE1BQU07WUFDYixPQUFPLEVBQUUsSUFBSTtTQUNkLENBQUM7UUFFRixJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUU5QyxJQUFJO2FBQ0QsYUFBYSxFQUFFO2FBQ2YsU0FBUyxDQUFDLEdBQUcsRUFBRSxDQUNkLE1BQU0sQ0FBQyxpQkFBaUI7WUFDdEIsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxpQkFBaUIsRUFBRTtZQUM1QixDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUNyQyxDQUFDO1FBQ0osT0FBTyxLQUFLLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQztJQUM3QixDQUFDO0lBRUQsS0FBSyxDQUFDLFNBQTZCO1FBQ2xDLFNBQVMsQ0FBQyxJQUFJLEdBQUcsS0FBSyxDQUFDO1FBQ3RCLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBRTNDLEtBQUssQ0FBQyxPQUFPLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDL0IsU0FBUyxDQUFDLHdCQUF3QixDQUFDLFNBQVMsQ0FDMUMsQ0FBQyxDQUFpQixFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLEtBQUssQ0FBQyxDQUNoRCxDQUFDO0lBQ0gsQ0FBQztrSUEzRlUsZ0JBQWdCO3NJQUFoQixnQkFBZ0I7OzRGQUFoQixnQkFBZ0I7a0JBRDVCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBbmltYXRpb25FdmVudCB9IGZyb20gJ0Bhbmd1bGFyL2FuaW1hdGlvbnMnO1xuaW1wb3J0IHtcbiAgT3ZlcmxheVJlZixcbiAgT3ZlcmxheSxcbiAgR2xvYmFsUG9zaXRpb25TdHJhdGVneSxcbn0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuaW1wb3J0IHsgQ29tcG9uZW50UG9ydGFsIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3BvcnRhbCc7XG5pbXBvcnQge1xuICBJbmplY3RhYmxlLFxuICBUeXBlLFxuICBDb21wb25lbnRSZWYsXG4gIEluamVjdG9yLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRGFmZk1vZGFsIH0gZnJvbSAnLi4vbW9kYWwvbW9kYWwnO1xuaW1wb3J0IHsgRGFmZk1vZGFsQ29uZmlndXJhdGlvbiB9IGZyb20gJy4uL21vZGFsL21vZGFsLWNvbmZpZyc7XG5pbXBvcnQgeyBEYWZmTW9kYWxDb21wb25lbnQgfSBmcm9tICcuLi9tb2RhbC9tb2RhbC5jb21wb25lbnQnO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgRGFmZk1vZGFsU2VydmljZSB7XG4gIHByaXZhdGUgX21vZGFsczogTWFwPERhZmZNb2RhbENvbXBvbmVudCwgRGFmZk1vZGFsPiA9IG5ldyBNYXAoKTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIG92ZXJsYXk6IE92ZXJsYXkpIHt9XG5cbiAgcHJpdmF0ZSBkZWZhdWx0Q29uZmlndXJhdGlvbjogRGFmZk1vZGFsQ29uZmlndXJhdGlvbiA9IHt9O1xuXG4gIHByaXZhdGUgX2F0dGFjaE1vZGFsKFxuXHQgIG92ZXJsYXlSZWY6IE92ZXJsYXlSZWYsXG4gICk6IENvbXBvbmVudFJlZjxEYWZmTW9kYWxDb21wb25lbnQ+IHtcblx0ICBjb25zdCBtb2RhbCA9IG92ZXJsYXlSZWYuYXR0YWNoKFxuICAgICAgbmV3IENvbXBvbmVudFBvcnRhbChcbiAgICAgICAgRGFmZk1vZGFsQ29tcG9uZW50LFxuICAgICAgICB1bmRlZmluZWQsXG4gICAgICAgIEluamVjdG9yLmNyZWF0ZSh7IHByb3ZpZGVyczogW3tcbiAgICAgICAgICBwcm92aWRlOiBEYWZmTW9kYWxTZXJ2aWNlLFxuICAgICAgICAgIHVzZVZhbHVlOiB0aGlzLFxuICAgICAgICB9XX0pLFxuICAgICAgKSxcbiAgICApO1xuXHQgIG1vZGFsLmluc3RhbmNlLm9wZW4gPSB0cnVlO1xuXHQgIHJldHVybiBtb2RhbDtcbiAgfVxuXG4gIHByaXZhdGUgX2F0dGFjaE1vZGFsQ29udGVudChcblx0ICBjb21wb25lbnQ6IFR5cGU8YW55Pixcblx0ICBtb2RhbDogQ29tcG9uZW50UmVmPERhZmZNb2RhbENvbXBvbmVudD4sXG4gICk6IHZvaWQge1xuXHQgIG1vZGFsLmluc3RhbmNlLmF0dGFjaENvbnRlbnQobmV3IENvbXBvbmVudFBvcnRhbChjb21wb25lbnQpKTtcbiAgfVxuXG4gIHByaXZhdGUgX2NyZWF0ZU92ZXJsYXlSZWYoKTogT3ZlcmxheVJlZiB7XG5cdCAgcmV0dXJuIHRoaXMub3ZlcmxheS5jcmVhdGUoe1xuXHQgICAgaGFzQmFja2Ryb3A6IHRydWUsXG5cdCAgICBwb3NpdGlvblN0cmF0ZWd5OiBuZXcgR2xvYmFsUG9zaXRpb25TdHJhdGVneSgpXG5cdCAgICAgIC5jZW50ZXJIb3Jpem9udGFsbHkoKVxuICAgICAgICAuY2VudGVyVmVydGljYWxseSgpLFxuXHQgICAgc2Nyb2xsU3RyYXRlZ3k6IHRoaXMub3ZlcmxheS5zY3JvbGxTdHJhdGVnaWVzLmJsb2NrKCksXG5cdCAgfSk7XG4gIH1cblxuICBwcml2YXRlIF9yZW1vdmVNb2RhbChtb2RhbDogRGFmZk1vZGFsKSB7XG4gICAgaWYgKCF0aGlzLl9tb2RhbHMuaGFzKG1vZGFsLm1vZGFsLmluc3RhbmNlKSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKFxuXHQgICAgICAnVGhlIE1vZGFsIHRoYXQgeW91IGFyZSB0cnlpbmcgdG8gcmVtb3ZlIGRvZXMgbm90IGV4aXN0LicsXG5cdCAgICApO1xuICAgIH1cblxuXHQgIHRoaXMuX21vZGFscy5kZWxldGUobW9kYWwubW9kYWwuaW5zdGFuY2UpO1xuXG5cdCAgbW9kYWwub3ZlcmxheS5kaXNwb3NlKCk7XG4gIH1cblxuICBvcGVuKFxuXHQgIGNvbXBvbmVudDogVHlwZTxhbnk+LFxuXHQgIGNvbmZpZ3VyYXRpb24/OiBQYXJ0aWFsPERhZmZNb2RhbENvbmZpZ3VyYXRpb24+LFxuICApOiBEYWZmTW9kYWxDb21wb25lbnQge1xuXHQgIGNvbnN0IGNvbmZpZyA9IHsgLi4udGhpcy5kZWZhdWx0Q29uZmlndXJhdGlvbiwgLi4uY29uZmlndXJhdGlvbiB9O1xuXHQgIGNvbnN0IF9yZWYgPSB0aGlzLl9jcmVhdGVPdmVybGF5UmVmKCk7XG5cdCAgY29uc3QgX21vZGFsID0gdGhpcy5fYXR0YWNoTW9kYWwoX3JlZik7XG5cdCAgY29uc3QgX2F0dGFjaGVkTW9kYWwgPSB0aGlzLl9hdHRhY2hNb2RhbENvbnRlbnQoY29tcG9uZW50LCBfbW9kYWwpO1xuXG4gICAgaWYoY29uZmlndXJhdGlvbj8uYXJpYUxhYmVsbGVkQnkpIHtcbiAgICAgIF9tb2RhbC5pbnN0YW5jZS5hcmlhTGFiZWxsZWRCeSA9IGNvbmZpZ3VyYXRpb24uYXJpYUxhYmVsbGVkQnk7XG4gICAgfVxuXG5cdCAgY29uc3QgbW9kYWw6IERhZmZNb2RhbCA9IHtcblx0ICAgIG1vZGFsOiBfbW9kYWwsXG5cdCAgICBvdmVybGF5OiBfcmVmLFxuXHQgIH07XG5cblx0ICB0aGlzLl9tb2RhbHMuc2V0KG1vZGFsLm1vZGFsLmluc3RhbmNlLCBtb2RhbCk7XG5cblx0ICBfcmVmXG5cdCAgICAuYmFja2Ryb3BDbGljaygpXG5cdCAgICAuc3Vic2NyaWJlKCgpID0+XG5cdCAgICAgIGNvbmZpZy5vbkJhY2tkcm9wQ2xpY2tlZFxuXHQgICAgICAgID8gY29uZmlnLm9uQmFja2Ryb3BDbGlja2VkKClcblx0ICAgICAgICA6IHRoaXMuY2xvc2UobW9kYWwubW9kYWwuaW5zdGFuY2UpLFxuXHQgICAgKTtcblx0ICByZXR1cm4gbW9kYWwubW9kYWwuaW5zdGFuY2U7XG4gIH1cblxuICBjbG9zZShjb21wb25lbnQ6IERhZmZNb2RhbENvbXBvbmVudCk6IHZvaWQge1xuXHQgIGNvbXBvbmVudC5vcGVuID0gZmFsc2U7XG4gICAgY29uc3QgbW9kYWwgPSB0aGlzLl9tb2RhbHMuZ2V0KGNvbXBvbmVudCk7XG5cblx0ICBtb2RhbC5vdmVybGF5LmRldGFjaEJhY2tkcm9wKCk7XG5cdCAgY29tcG9uZW50LmNsb3NlZEFuaW1hdGlvbkNvbXBsZXRlZC5zdWJzY3JpYmUoXG5cdCAgICAoZTogQW5pbWF0aW9uRXZlbnQpID0+IHRoaXMuX3JlbW92ZU1vZGFsKG1vZGFsKSxcblx0ICApO1xuICB9XG59XG4iXX0=
|
@@ -0,0 +1,9 @@
|
|
1
|
+
const DOCKED_MODES = [
|
2
|
+
"side" /* DaffSidebarModeEnum.Side */,
|
3
|
+
"side-fixed" /* DaffSidebarModeEnum.SideFixed */,
|
4
|
+
];
|
5
|
+
/**
|
6
|
+
* Returns whether the passed mode is a docked mode, i.e. side or side-fixed.
|
7
|
+
*/
|
8
|
+
export const daffSidebarIsDockedMode = (mode) => DOCKED_MODES.includes(mode);
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXMtZG9ja2VkLW1vZGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2Rlc2lnbi9zaWRlYmFyL3NyYy9oZWxwZXIvaXMtZG9ja2VkLW1vZGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxZQUFZLEdBQUc7OztDQUdwQixDQUFDO0FBRUY7O0dBRUc7QUFDSCxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBRyxDQUFDLElBQXlCLEVBQVcsRUFBRSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEYWZmU2lkZWJhck1vZGVFbnVtIH0gZnJvbSAnLi9zaWRlYmFyLW1vZGUnO1xuXG5jb25zdCBET0NLRURfTU9ERVMgPSBbXG4gIERhZmZTaWRlYmFyTW9kZUVudW0uU2lkZSxcbiAgRGFmZlNpZGViYXJNb2RlRW51bS5TaWRlRml4ZWQsXG5dO1xuXG4vKipcbiAqIFJldHVybnMgd2hldGhlciB0aGUgcGFzc2VkIG1vZGUgaXMgYSBkb2NrZWQgbW9kZSwgaS5lLiBzaWRlIG9yIHNpZGUtZml4ZWQuXG4gKi9cbmV4cG9ydCBjb25zdCBkYWZmU2lkZWJhcklzRG9ja2VkTW9kZSA9IChtb2RlOiBEYWZmU2lkZWJhck1vZGVFbnVtKTogYm9vbGVhbiA9PiBET0NLRURfTU9ERVMuaW5jbHVkZXMobW9kZSk7XG4iXX0=
|
@@ -0,0 +1,9 @@
|
|
1
|
+
const FLOATING_MODES = [
|
2
|
+
"under" /* DaffSidebarModeEnum.Under */,
|
3
|
+
"over" /* DaffSidebarModeEnum.Over */,
|
4
|
+
];
|
5
|
+
/**
|
6
|
+
* Returns whether the passed mode is a floating mode, i.e. under or over.
|
7
|
+
*/
|
8
|
+
export const daffSidebarIsFloatingMode = (mode) => FLOATING_MODES.includes(mode);
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXMtZmxvYXRpbmctbW9kZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvZGVzaWduL3NpZGViYXIvc3JjL2hlbHBlci9pcy1mbG9hdGluZy1tb2RlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sY0FBYyxHQUFHOzs7Q0FHdEIsQ0FBQztBQUVGOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0seUJBQXlCLEdBQUcsQ0FBQyxJQUF5QixFQUFXLEVBQUUsQ0FBQyxjQUFjLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGFmZlNpZGViYXJNb2RlRW51bSB9IGZyb20gJy4vc2lkZWJhci1tb2RlJztcblxuY29uc3QgRkxPQVRJTkdfTU9ERVMgPSBbXG4gIERhZmZTaWRlYmFyTW9kZUVudW0uVW5kZXIsXG4gIERhZmZTaWRlYmFyTW9kZUVudW0uT3Zlcixcbl07XG5cbi8qKlxuICogUmV0dXJucyB3aGV0aGVyIHRoZSBwYXNzZWQgbW9kZSBpcyBhIGZsb2F0aW5nIG1vZGUsIGkuZS4gdW5kZXIgb3Igb3Zlci5cbiAqL1xuZXhwb3J0IGNvbnN0IGRhZmZTaWRlYmFySXNGbG9hdGluZ01vZGUgPSAobW9kZTogRGFmZlNpZGViYXJNb2RlRW51bSk6IGJvb2xlYW4gPT4gRkxPQVRJTkdfTU9ERVMuaW5jbHVkZXMobW9kZSk7XG4iXX0=
|
@@ -1,4 +1,6 @@
|
|
1
1
|
export { DaffSidebarModule } from './sidebar.module';
|
2
|
+
export * from './service/registration.type';
|
3
|
+
export * from './service/sidebar.service';
|
2
4
|
export * from './sidebar-viewport/sidebar-viewport.component';
|
3
5
|
export * from './sidebar/sidebar.component';
|
4
6
|
export * from './sidebar-header/sidebar-header.component';
|
@@ -6,4 +8,6 @@ export * from './sidebar-footer/sidebar-footer.component';
|
|
6
8
|
export * from './sidebar-header/sidebar-header-title/sidebar-header-title.directive';
|
7
9
|
export * from './sidebar-header/sidebar-header-action/sidebar-header-action.directive';
|
8
10
|
export * from './sidebar-viewport-backdrop/sidebar-viewport-backdrop.component';
|
9
|
-
|
11
|
+
export * from './helper/is-docked-mode';
|
12
|
+
export * from './helper/is-floating-mode';
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYnMvZGVzaWduL3NpZGViYXIvc3JjL3B1YmxpY19hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDckQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyxzRUFBc0UsQ0FBQztBQUNyRixjQUFjLHdFQUF3RSxDQUFDO0FBQ3ZGLGNBQWMsaUVBQWlFLENBQUM7QUFTaEYsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgRGFmZlNpZGViYXJNb2R1bGUgfSBmcm9tICcuL3NpZGViYXIubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vc2VydmljZS9yZWdpc3RyYXRpb24udHlwZSc7XG5leHBvcnQgKiBmcm9tICcuL3NlcnZpY2Uvc2lkZWJhci5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vc2lkZWJhci12aWV3cG9ydC9zaWRlYmFyLXZpZXdwb3J0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3NpZGViYXIvc2lkZWJhci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9zaWRlYmFyLWhlYWRlci9zaWRlYmFyLWhlYWRlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9zaWRlYmFyLWZvb3Rlci9zaWRlYmFyLWZvb3Rlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9zaWRlYmFyLWhlYWRlci9zaWRlYmFyLWhlYWRlci10aXRsZS9zaWRlYmFyLWhlYWRlci10aXRsZS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9zaWRlYmFyLWhlYWRlci9zaWRlYmFyLWhlYWRlci1hY3Rpb24vc2lkZWJhci1oZWFkZXItYWN0aW9uLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3NpZGViYXItdmlld3BvcnQtYmFja2Ryb3Avc2lkZWJhci12aWV3cG9ydC1iYWNrZHJvcC5jb21wb25lbnQnO1xuZXhwb3J0IHtcbiAgRGFmZlNpZGViYXJNb2RlLFxuICBEYWZmU2lkZWJhck1vZGVFbnVtLFxufSBmcm9tICcuL2hlbHBlci9zaWRlYmFyLW1vZGUnO1xuZXhwb3J0IHtcbiAgRGFmZlNpZGViYXJTaWRlLFxuICBEYWZmU2lkZWJhclNpZGVFbnVtLFxufSBmcm9tICcuL2hlbHBlci9zaWRlYmFyLXNpZGUnO1xuZXhwb3J0ICogZnJvbSAnLi9oZWxwZXIvaXMtZG9ja2VkLW1vZGUnO1xuZXhwb3J0ICogZnJvbSAnLi9oZWxwZXIvaXMtZmxvYXRpbmctbW9kZSc7XG4iXX0=
|
@@ -0,0 +1,2 @@
|
|
1
|
+
export {};
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVnaXN0cmF0aW9uLnR5cGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2Rlc2lnbi9zaWRlYmFyL3NyYy9zZXJ2aWNlL3JlZ2lzdHJhdGlvbi50eXBlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUeXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogUmVwcmVzZW50cyBhIHJlZ2lzdHJhdGlvbiBvZiBhIHNpZGViYXIuXG4gKiBBIGNvbGxlY3Rpb24gb2Ygc2lkZWJhciBjb21wb25lbnRzIGlzIGFzc29jaWF0ZWQgd2l0aCBhbiBJRCB3aGljaCBjYW4gYmUgcGFzc2VkIHRvIHtAbGluayBEYWZmU2lkZWJhclNlcnZpY2Ujb3Blbn0uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRGFmZlNpZGViYXJSZWdpc3RyYXRpb24ge1xuICBpZDogc3RyaW5nO1xuICBoZWFkZXI/OiBUeXBlPHVua25vd24+O1xuICBib2R5PzogVHlwZTx1bmtub3duPjtcbiAgZm9vdGVyPzogVHlwZTx1bmtub3duPjtcbn1cbiJdfQ==
|
@@ -0,0 +1,36 @@
|
|
1
|
+
import { signal, } from '@angular/core';
|
2
|
+
import { BehaviorSubject, } from 'rxjs';
|
3
|
+
/**
|
4
|
+
* A service that stores the open state and ID of the currently opened sidebar.
|
5
|
+
*
|
6
|
+
* A default sidebar ID can be passed to the constructor that will be the initial value of `$id`.
|
7
|
+
*/
|
8
|
+
export class DaffSidebarService {
|
9
|
+
get isOpen() {
|
10
|
+
return this._open.asReadonly();
|
11
|
+
}
|
12
|
+
constructor(defaultId = null) {
|
13
|
+
this._open = signal(false);
|
14
|
+
this._id$ = new BehaviorSubject(defaultId);
|
15
|
+
this.id$ = this._id$.asObservable();
|
16
|
+
}
|
17
|
+
/**
|
18
|
+
* Opens the specified sidebar.
|
19
|
+
*
|
20
|
+
* @param id The optional sidebar ID. If omitted the most recently passed opened sidebar ID will persist (or the default if none was passed).
|
21
|
+
*/
|
22
|
+
open(id) {
|
23
|
+
if (id) {
|
24
|
+
this._id$.next(id);
|
25
|
+
}
|
26
|
+
this._open.set(true);
|
27
|
+
}
|
28
|
+
;
|
29
|
+
/**
|
30
|
+
* Closes the sidebar. Does not clear the ID.
|
31
|
+
*/
|
32
|
+
close() {
|
33
|
+
this._open.set(false);
|
34
|
+
}
|
35
|
+
}
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lkZWJhci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9kZXNpZ24vc2lkZWJhci9zcmMvc2VydmljZS9zaWRlYmFyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLE1BQU0sR0FDUCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQ0wsZUFBZSxHQUVoQixNQUFNLE1BQU0sQ0FBQztBQUlkOzs7O0dBSUc7QUFDSCxNQUFNLE9BQWdCLGtCQUFrQjtJQU10QyxJQUFJLE1BQU07UUFDUixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsVUFBVSxFQUFFLENBQUM7SUFDakMsQ0FBQztJQUVELFlBQ0UsWUFBMkMsSUFBSTtRQVR2QyxVQUFLLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBVzlCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxlQUFlLENBQWdDLFNBQVMsQ0FBQyxDQUFDO1FBRTFFLElBQUksQ0FBQyxHQUFHLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUN0QyxDQUFDO0lBRUQ7Ozs7T0FJRztJQUNILElBQUksQ0FBQyxFQUFrQztRQUNyQyxJQUFJLEVBQUUsRUFBRTtZQUNOLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1NBQ3BCO1FBQ0QsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDdkIsQ0FBQztJQUFBLENBQUM7SUFFRjs7T0FFRztJQUNILEtBQUs7UUFDSCxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN4QixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBTaWduYWwsXG4gIHNpZ25hbCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1xuICBCZWhhdmlvclN1YmplY3QsXG4gIE9ic2VydmFibGUsXG59IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBEYWZmU2lkZWJhclJlZ2lzdHJhdGlvbiB9IGZyb20gJy4vcmVnaXN0cmF0aW9uLnR5cGUnO1xuXG4vKipcbiAqIEEgc2VydmljZSB0aGF0IHN0b3JlcyB0aGUgb3BlbiBzdGF0ZSBhbmQgSUQgb2YgdGhlIGN1cnJlbnRseSBvcGVuZWQgc2lkZWJhci5cbiAqXG4gKiBBIGRlZmF1bHQgc2lkZWJhciBJRCBjYW4gYmUgcGFzc2VkIHRvIHRoZSBjb25zdHJ1Y3RvciB0aGF0IHdpbGwgYmUgdGhlIGluaXRpYWwgdmFsdWUgb2YgYCRpZGAuXG4gKi9cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBEYWZmU2lkZWJhclNlcnZpY2Uge1xuICBwcm90ZWN0ZWQgX2lkJDogQmVoYXZpb3JTdWJqZWN0PERhZmZTaWRlYmFyUmVnaXN0cmF0aW9uWydpZCddPjtcbiAgcHJvdGVjdGVkIF9vcGVuID0gc2lnbmFsKGZhbHNlKTtcblxuICByZWFkb25seSBpZCQ6IE9ic2VydmFibGU8RGFmZlNpZGViYXJSZWdpc3RyYXRpb25bJ2lkJ10+O1xuXG4gIGdldCBpc09wZW4oKTogU2lnbmFsPGJvb2xlYW4+IHtcbiAgICByZXR1cm4gdGhpcy5fb3Blbi5hc1JlYWRvbmx5KCk7XG4gIH1cblxuICBjb25zdHJ1Y3RvcihcbiAgICBkZWZhdWx0SWQ6IERhZmZTaWRlYmFyUmVnaXN0cmF0aW9uWydpZCddID0gbnVsbCxcbiAgKSB7XG4gICAgdGhpcy5faWQkID0gbmV3IEJlaGF2aW9yU3ViamVjdDxEYWZmU2lkZWJhclJlZ2lzdHJhdGlvblsnaWQnXT4oZGVmYXVsdElkKTtcblxuICAgIHRoaXMuaWQkID0gdGhpcy5faWQkLmFzT2JzZXJ2YWJsZSgpO1xuICB9XG5cbiAgLyoqXG4gICAqIE9wZW5zIHRoZSBzcGVjaWZpZWQgc2lkZWJhci5cbiAgICpcbiAgICogQHBhcmFtIGlkIFRoZSBvcHRpb25hbCBzaWRlYmFyIElELiBJZiBvbWl0dGVkIHRoZSBtb3N0IHJlY2VudGx5IHBhc3NlZCBvcGVuZWQgc2lkZWJhciBJRCB3aWxsIHBlcnNpc3QgKG9yIHRoZSBkZWZhdWx0IGlmIG5vbmUgd2FzIHBhc3NlZCkuXG4gICAqL1xuICBvcGVuKGlkPzogRGFmZlNpZGViYXJSZWdpc3RyYXRpb25bJ2lkJ10pIHtcbiAgICBpZiAoaWQpIHtcbiAgICAgIHRoaXMuX2lkJC5uZXh0KGlkKTtcbiAgICB9XG4gICAgdGhpcy5fb3Blbi5zZXQodHJ1ZSk7XG4gIH07XG5cbiAgLyoqXG4gICAqIENsb3NlcyB0aGUgc2lkZWJhci4gRG9lcyBub3QgY2xlYXIgdGhlIElELlxuICAgKi9cbiAgY2xvc2UoKSB7XG4gICAgdGhpcy5fb3Blbi5zZXQoZmFsc2UpO1xuICB9XG59XG4iXX0=
|
@@ -171,7 +171,7 @@ export class DaffSidebarViewportComponent {
|
|
171
171
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: DaffSidebarViewportComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: DAFF_SIDEBAR_SCROLL_TOKEN, skipSelf: true }, { token: DaffSidebarViewportComponent, optional: true, skipSelf: true }, { token: DAFF_SIDEBAR_SCROLL_TOKEN }], target: i0.ɵɵFactoryTarget.Component }); }
|
172
172
|
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.10", type: DaffSidebarViewportComponent, selector: "daff-sidebar-viewport", inputs: { navPlacement: "navPlacement" }, outputs: { backdropClicked: "backdropClicked" }, host: { properties: { "class.daff-sidebar-viewport": "this.hostClass", "class": "this.classes" } }, providers: [
|
173
173
|
{ provide: DAFF_SIDEBAR_SCROLL_TOKEN, useFactory: daffSidebarViewportScrollFactory },
|
174
|
-
], queries: [{ propertyName: "sidebars", predicate: DaffSidebarComponent }], ngImport: i0, template: "<ng-content select=\"daff-sidebar:not([side=right])\"></ng-content>\n\n<daff-sidebar-viewport-backdrop\n [@transformContent]=\"_animationState\"\n [interactable]=\"_backdropInteractable\"\n (backdropClicked)=\"_backdropClicked()\">\n</daff-sidebar-viewport-backdrop>\n\n<div class=\"daff-sidebar-viewport__nav\"\n [@transformContent]=\"_animationState\"\n [style.padding-left.px]=\"_navPadLeft\"\n [style.padding-right.px]=\"_navPadRight\">\n <ng-content select=\"[daff-sidebar-viewport-nav]\"></ng-content>\n</div>\n\n<div class=\"daff-sidebar-viewport__content\"\n [@transformContent]=\"_animationState\"\n (@transformContent.start)=\"onContentAnimationStart($event)\"\n (@transformContent.done)=\"onContentAnimationDone($event)\">\n <div class=\"daff-sidebar-viewport__inner\"\n [style.padding-left.px]=\"_contentPadLeft\"\n [style.padding-right.px]=\"_contentPadRight\">\n <ng-content></ng-content>\n </div>\n</div>\n\n<ng-content select=\"daff-sidebar[side=right]\"></ng-content>\n", styles: [":host{display:flex;min-height:100dvh;position:relative;width:100%;z-index:1}.daff-sidebar-viewport__content{flex:0 1 auto;width:100%;z-index:3;height:100%}.daff-sidebar-viewport__nav{position:fixed;top:0;width:100%;z-index:4}.daff-sidebar-viewport__nav:empty{display:none}.daff-sidebar-viewport__nav:not(:empty)+.daff-sidebar-viewport__content{margin-top:var(--daff-sidebar-side-fixed-top-shift)}:host-context(daff-sidebar-viewport daff-sidebar-viewport){transform:translate(0);min-height:auto}:host-context(daff-sidebar-viewport daff-sidebar-viewport) .daff-sidebar-viewport__inner{padding-left:0!important;padding-right:0!important}\n"], dependencies: [{ kind: "component", type: i1.DaffSidebarViewportBackdropComponent, selector: "daff-sidebar-viewport-backdrop", inputs: ["transparent", "interactable", "fullscreen"], outputs: ["backdropClicked"] }], animations: [
|
174
|
+
], queries: [{ propertyName: "sidebars", predicate: DaffSidebarComponent }], ngImport: i0, template: "<ng-content select=\"daff-sidebar:not([side=right])\"></ng-content>\n\n<daff-sidebar-viewport-backdrop\n [@transformContent]=\"_animationState\"\n [interactable]=\"_backdropInteractable\"\n (backdropClicked)=\"_backdropClicked()\">\n</daff-sidebar-viewport-backdrop>\n\n<div class=\"daff-sidebar-viewport__nav\"\n [@transformContent]=\"_animationState\"\n [style.padding-left.px]=\"_navPadLeft\"\n [style.padding-right.px]=\"_navPadRight\">\n <ng-content select=\"[daff-sidebar-viewport-nav]\"></ng-content>\n</div>\n\n<div class=\"daff-sidebar-viewport__content\"\n [@transformContent]=\"_animationState\"\n (@transformContent.start)=\"onContentAnimationStart($event)\"\n (@transformContent.done)=\"onContentAnimationDone($event)\">\n <div class=\"daff-sidebar-viewport__inner\"\n [style.padding-left.px]=\"_contentPadLeft\"\n [style.padding-right.px]=\"_contentPadRight\">\n <ng-content></ng-content>\n </div>\n</div>\n\n<ng-content select=\"daff-sidebar[side=right]\"></ng-content>\n", styles: [":host{display:flex;min-height:100dvh;position:relative;width:100%;z-index:1}.daff-sidebar-viewport__content{flex:0 1 auto;width:100%;z-index:3;min-height:100%}.daff-sidebar-viewport__nav{position:fixed;top:0;width:100%;z-index:4}.daff-sidebar-viewport__nav:empty{display:none}.daff-sidebar-viewport__nav:not(:empty)+.daff-sidebar-viewport__content{margin-top:var(--daff-sidebar-side-fixed-top-shift)}:host-context(daff-sidebar-viewport daff-sidebar-viewport){transform:translate(0);min-height:auto}:host-context(daff-sidebar-viewport daff-sidebar-viewport) .daff-sidebar-viewport__inner{padding-left:0!important;padding-right:0!important}\n"], dependencies: [{ kind: "component", type: i1.DaffSidebarViewportBackdropComponent, selector: "daff-sidebar-viewport-backdrop", inputs: ["transparent", "interactable", "fullscreen"], outputs: ["backdropClicked"] }], animations: [
|
175
175
|
daffSidebarAnimations.transformContent,
|
176
176
|
], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
177
177
|
}
|
@@ -181,7 +181,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImpo
|
|
181
181
|
daffSidebarAnimations.transformContent,
|
182
182
|
], providers: [
|
183
183
|
{ provide: DAFF_SIDEBAR_SCROLL_TOKEN, useFactory: daffSidebarViewportScrollFactory },
|
184
|
-
], template: "<ng-content select=\"daff-sidebar:not([side=right])\"></ng-content>\n\n<daff-sidebar-viewport-backdrop\n [@transformContent]=\"_animationState\"\n [interactable]=\"_backdropInteractable\"\n (backdropClicked)=\"_backdropClicked()\">\n</daff-sidebar-viewport-backdrop>\n\n<div class=\"daff-sidebar-viewport__nav\"\n [@transformContent]=\"_animationState\"\n [style.padding-left.px]=\"_navPadLeft\"\n [style.padding-right.px]=\"_navPadRight\">\n <ng-content select=\"[daff-sidebar-viewport-nav]\"></ng-content>\n</div>\n\n<div class=\"daff-sidebar-viewport__content\"\n [@transformContent]=\"_animationState\"\n (@transformContent.start)=\"onContentAnimationStart($event)\"\n (@transformContent.done)=\"onContentAnimationDone($event)\">\n <div class=\"daff-sidebar-viewport__inner\"\n [style.padding-left.px]=\"_contentPadLeft\"\n [style.padding-right.px]=\"_contentPadRight\">\n <ng-content></ng-content>\n </div>\n</div>\n\n<ng-content select=\"daff-sidebar[side=right]\"></ng-content>\n", styles: [":host{display:flex;min-height:100dvh;position:relative;width:100%;z-index:1}.daff-sidebar-viewport__content{flex:0 1 auto;width:100%;z-index:3;height:100%}.daff-sidebar-viewport__nav{position:fixed;top:0;width:100%;z-index:4}.daff-sidebar-viewport__nav:empty{display:none}.daff-sidebar-viewport__nav:not(:empty)+.daff-sidebar-viewport__content{margin-top:var(--daff-sidebar-side-fixed-top-shift)}:host-context(daff-sidebar-viewport daff-sidebar-viewport){transform:translate(0);min-height:auto}:host-context(daff-sidebar-viewport daff-sidebar-viewport) .daff-sidebar-viewport__inner{padding-left:0!important;padding-right:0!important}\n"] }]
|
184
|
+
], template: "<ng-content select=\"daff-sidebar:not([side=right])\"></ng-content>\n\n<daff-sidebar-viewport-backdrop\n [@transformContent]=\"_animationState\"\n [interactable]=\"_backdropInteractable\"\n (backdropClicked)=\"_backdropClicked()\">\n</daff-sidebar-viewport-backdrop>\n\n<div class=\"daff-sidebar-viewport__nav\"\n [@transformContent]=\"_animationState\"\n [style.padding-left.px]=\"_navPadLeft\"\n [style.padding-right.px]=\"_navPadRight\">\n <ng-content select=\"[daff-sidebar-viewport-nav]\"></ng-content>\n</div>\n\n<div class=\"daff-sidebar-viewport__content\"\n [@transformContent]=\"_animationState\"\n (@transformContent.start)=\"onContentAnimationStart($event)\"\n (@transformContent.done)=\"onContentAnimationDone($event)\">\n <div class=\"daff-sidebar-viewport__inner\"\n [style.padding-left.px]=\"_contentPadLeft\"\n [style.padding-right.px]=\"_contentPadRight\">\n <ng-content></ng-content>\n </div>\n</div>\n\n<ng-content select=\"daff-sidebar[side=right]\"></ng-content>\n", styles: [":host{display:flex;min-height:100dvh;position:relative;width:100%;z-index:1}.daff-sidebar-viewport__content{flex:0 1 auto;width:100%;z-index:3;min-height:100%}.daff-sidebar-viewport__nav{position:fixed;top:0;width:100%;z-index:4}.daff-sidebar-viewport__nav:empty{display:none}.daff-sidebar-viewport__nav:not(:empty)+.daff-sidebar-viewport__content{margin-top:var(--daff-sidebar-side-fixed-top-shift)}:host-context(daff-sidebar-viewport daff-sidebar-viewport){transform:translate(0);min-height:auto}:host-context(daff-sidebar-viewport daff-sidebar-viewport) .daff-sidebar-viewport__inner{padding-left:0!important;padding-right:0!important}\n"] }]
|
185
185
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: undefined, decorators: [{
|
186
186
|
type: Inject,
|
187
187
|
args: [DAFF_SIDEBAR_SCROLL_TOKEN]
|
@@ -211,4 +211,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImpo
|
|
211
211
|
}], backdropClicked: [{
|
212
212
|
type: Output
|
213
213
|
}] } });
|
214
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidebar-viewport.component.js","sourceRoot":"","sources":["../../../../../libs/design/sidebar/src/sidebar-viewport/sidebar-viewport.component.ts","../../../../../libs/design/sidebar/src/sidebar-viewport/sidebar-viewport.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AnimationEvent } from '@angular/animations';\nimport {\n  Component,\n  Output,\n  EventEmitter,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  ContentChildren,\n  QueryList,\n  AfterContentChecked,\n  ElementRef,\n  Input,\n  HostBinding,\n  Inject,\n  SkipSelf,\n  Optional,\n  OnDestroy,\n} from '@angular/core';\n\nimport { hasParentViewport } from './helper/has-parent-viewport';\nimport {\n  DaffNavPlacement,\n  DaffNavPlacementEnum,\n} from './nav-placement';\nimport {\n  DAFF_SIDEBAR_SCROLL_TOKEN,\n  DaffSidebarScroll,\n  daffSidebarViewportScrollFactory,\n} from './scroll-token/scroll.token';\nimport { sidebarViewportBackdropInteractable } from './utils/backdrop-interactable';\nimport { sidebarViewportContentPadding } from './utils/content-pad';\nimport {\n  isViewportContentShifted,\n  sidebarViewportContentShift,\n} from './utils/content-shift';\nimport {\n  DaffSidebarAnimationStates,\n  daffSidebarAnimations,\n} from '../animation/sidebar-animation';\nimport {\n  DaffSidebarViewportAnimationStateWithParams,\n  getSidebarViewportAnimationState,\n} from '../animation/sidebar-viewport-animation-state';\nimport { DaffSidebarMode } from '../helper/sidebar-mode';\nimport { DaffSidebarComponent } from '../sidebar/sidebar.component';\n\n/**\n * The DaffSidebarViewport is the \"holder\" of sidebars throughout an entire application.\n * It's generally only used once, like\n *\n * ```html\n * <daff-sidebar-viewport>\n *    <daff-sidebar></daff-sidebar>\n *    <p>Some Content</p>\n * </daff-sidebar-viewport>\n * ```\n *\n * Importantly, its possible for there to be multiple sidebars of many modes\n * at the same time. @see {@link DaffSidebarMode }\n *\n * Since this is a functional component, it's possible to have multiple \"open\" sidebars\n * at the same time. As a result, this component attempts to gracefully handle these situations.\n * However, importantly, there can only be one sidebar of each mode, on each side, at any given time.\n * If this is violated, this component will throw an exception.\n */\n@Component({\n  selector: 'daff-sidebar-viewport',\n  templateUrl: './sidebar-viewport.component.html',\n  styleUrls: ['./sidebar-viewport.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  animations: [\n    daffSidebarAnimations.transformContent,\n  ],\n  providers: [\n    { provide: DAFF_SIDEBAR_SCROLL_TOKEN, useFactory: daffSidebarViewportScrollFactory },\n  ],\n})\nexport class DaffSidebarViewportComponent implements AfterContentChecked, OnDestroy {\n  @HostBinding('class.daff-sidebar-viewport') hostClass = true;\n\n  @HostBinding('class') get classes() {\n    return {\n      'daff-sidebar-viewport': true,\n      [this.navPlacement]: true,\n    };\n  };\n\n  get isNavOnSide() {\n    return this.navPlacement === DaffNavPlacementEnum.BESIDE;\n  }\n\n  onContentAnimationStart(e: AnimationEvent) {\n    if(e.toState === 'open') {\n      this._elementRef.nativeElement.style.overflow = 'hidden';\n    }\n  }\n\n  onContentAnimationDone(e: AnimationEvent) {\n    if(e.toState === 'closed') {\n      this._elementRef.nativeElement.style.overflow = null;\n    }\n  }\n\n  /**\n   * The placement of the nav in relation to the sidebar. The default is set to `top`.\n   * Note that this is really only available when there is a `side-fixed` sidebar.\n   */\n  @Input() navPlacement: DaffNavPlacement = DaffNavPlacementEnum.ABOVE;\n\n  constructor(\n    private cdRef: ChangeDetectorRef,\n    private _elementRef: ElementRef<HTMLElement>,\n    @Inject(DAFF_SIDEBAR_SCROLL_TOKEN) @SkipSelf() private bodyScroll: DaffSidebarScroll,\n    @Inject(DaffSidebarViewportComponent) @SkipSelf() @Optional() private parentViewport,\n    @Inject(DAFF_SIDEBAR_SCROLL_TOKEN) private scroll: DaffSidebarScroll,\n  ) { }\n\n  /**\n   * The list of sidebars in the viewport.\n   *\n   * @docs-private\n   */\n  @ContentChildren(DaffSidebarComponent, { descendants: false }) private sidebars: QueryList<DaffSidebarComponent>;\n\n  /**\n   * The number of pixels that the main content of the page should be shifted to\n   * right when there are child sidebars.\n   */\n  private _shift = '0px';\n\n  /**\n   * The left padding on the content when left side-fixed sidebars are open.\n   */\n  public _contentPadLeft = 0;\n\n  /**\n   * The left padding on the nav when left side-fixed sidebars are open.\n   */\n  public _navPadLeft = 0;\n\n  /**\n   * The right padding on the content when right side-fixed sidebars are open.\n   */\n  public _contentPadRight = 0;\n\n  /**\n   * The right padding on the content when right side-fixed sidebars are open.\n   */\n  public _navPadRight = 0;\n\n  /**\n   * Whether or not the backdrop is interactable\n   */\n  _backdropInteractable = false;\n\n  /**\n   * The animation state\n   */\n  _animationState: DaffSidebarViewportAnimationStateWithParams = { value: DaffSidebarAnimationStates.CLOSED, params: { shift: '0px' }};\n\n  /**\n   * Event fired when the backdrop is clicked. This is often used to close the sidebar.\n   */\n  @Output() backdropClicked: EventEmitter<void> = new EventEmitter<void>();\n\n  ngAfterContentChecked() {\n    const nextShift = sidebarViewportContentShift(this.sidebars) + 'px';\n    if (this._shift !== nextShift) {\n      this._shift = nextShift;\n\n      this.updateAnimationState();\n      this.cdRef.markForCheck();\n    }\n\n    const nextBackdropInteractable = sidebarViewportBackdropInteractable(this.sidebars);\n    if (this._backdropInteractable !== nextBackdropInteractable) {\n      this._backdropInteractable = nextBackdropInteractable;\n      this.updateAnimationState();\n      this.cdRef.markForCheck();\n      if(nextBackdropInteractable) {\n        if(!this.parentViewport && !hasParentViewport(this._elementRef.nativeElement)) {\n          this.bodyScroll.disable();\n        } else {\n          this.scroll.disable();\n        }\n      } else { //if we are hiding the sidebars\n        if(!this.parentViewport && !hasParentViewport(this._elementRef.nativeElement)) {\n          this.bodyScroll.enable();\n        } else {\n          this.scroll.enable();\n        }\n      }\n    };\n\n    const nextLeftPadding = sidebarViewportContentPadding(this.sidebars, 'left');\n    if(this._contentPadLeft !== nextLeftPadding) {\n      this._contentPadLeft = nextLeftPadding;\n      this._navPadLeft = this.isNavOnSide ? this._contentPadLeft : null;\n      this.updateAnimationState();\n      this.cdRef.markForCheck();\n    }\n\n    const nextRightPadding = sidebarViewportContentPadding(this.sidebars, 'right');\n    if(this._contentPadRight !== nextRightPadding) {\n      this._contentPadRight = nextRightPadding;\n      this._navPadRight = this.isNavOnSide ? this._contentPadRight : null;\n      this.updateAnimationState();\n      this.cdRef.markForCheck();\n    }\n  }\n\n  ngOnDestroy() {\n    if(!this.parentViewport && !hasParentViewport(this._elementRef.nativeElement)) {\n      this.bodyScroll.enable();\n    } else {\n      this.scroll.enable();\n    }\n  }\n\n  /**\n   * @docs-private\n   *\n   * Updates the animation state of the viewport depending upon the state\n   * of all sidebars within the viewport.\n   */\n  private updateAnimationState() {\n    this._animationState = {\n      value: getSidebarViewportAnimationState(\n        this.sidebars.reduce((acc: boolean, sidebar) => acc || isViewportContentShifted(sidebar.mode, sidebar.open), false),\n      ),\n      params: { shift: this._shift },\n    };\n  }\n\n  /**\n   * @docs-private\n   * The called when the backdrop of the viewport is clicked upon.\n   */\n  _backdropClicked(): void {\n    this.backdropClicked.emit();\n  }\n}\n","<ng-content select=\"daff-sidebar:not([side=right])\"></ng-content>\n\n<daff-sidebar-viewport-backdrop\n  [@transformContent]=\"_animationState\"\n  [interactable]=\"_backdropInteractable\"\n  (backdropClicked)=\"_backdropClicked()\">\n</daff-sidebar-viewport-backdrop>\n\n<div class=\"daff-sidebar-viewport__nav\"\n  [@transformContent]=\"_animationState\"\n  [style.padding-left.px]=\"_navPadLeft\"\n  [style.padding-right.px]=\"_navPadRight\">\n    <ng-content select=\"[daff-sidebar-viewport-nav]\"></ng-content>\n</div>\n\n<div class=\"daff-sidebar-viewport__content\"\n  [@transformContent]=\"_animationState\"\n  (@transformContent.start)=\"onContentAnimationStart($event)\"\n  (@transformContent.done)=\"onContentAnimationDone($event)\">\n  <div class=\"daff-sidebar-viewport__inner\"\n    [style.padding-left.px]=\"_contentPadLeft\"\n    [style.padding-right.px]=\"_contentPadRight\">\n      <ng-content></ng-content>\n  </div>\n</div>\n\n<ng-content select=\"daff-sidebar[side=right]\"></ng-content>\n"]}
|
214
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sidebar-viewport.component.js","sourceRoot":"","sources":["../../../../../libs/design/sidebar/src/sidebar-viewport/sidebar-viewport.component.ts","../../../../../libs/design/sidebar/src/sidebar-viewport/sidebar-viewport.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AnimationEvent } from '@angular/animations';\nimport {\n  Component,\n  Output,\n  EventEmitter,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  ContentChildren,\n  QueryList,\n  AfterContentChecked,\n  ElementRef,\n  Input,\n  HostBinding,\n  Inject,\n  SkipSelf,\n  Optional,\n  OnDestroy,\n} from '@angular/core';\n\nimport { hasParentViewport } from './helper/has-parent-viewport';\nimport {\n  DaffNavPlacement,\n  DaffNavPlacementEnum,\n} from './nav-placement';\nimport {\n  DAFF_SIDEBAR_SCROLL_TOKEN,\n  DaffSidebarScroll,\n  daffSidebarViewportScrollFactory,\n} from './scroll-token/scroll.token';\nimport { sidebarViewportBackdropInteractable } from './utils/backdrop-interactable';\nimport { sidebarViewportContentPadding } from './utils/content-pad';\nimport {\n  isViewportContentShifted,\n  sidebarViewportContentShift,\n} from './utils/content-shift';\nimport {\n  DaffSidebarAnimationStates,\n  daffSidebarAnimations,\n} from '../animation/sidebar-animation';\nimport {\n  DaffSidebarViewportAnimationStateWithParams,\n  getSidebarViewportAnimationState,\n} from '../animation/sidebar-viewport-animation-state';\nimport { DaffSidebarMode } from '../helper/sidebar-mode';\nimport { DaffSidebarComponent } from '../sidebar/sidebar.component';\n\n/**\n * The DaffSidebarViewport is the \"holder\" of sidebars throughout an entire application.\n * It's generally only used once, like\n *\n * ```html\n * <daff-sidebar-viewport>\n *    <daff-sidebar></daff-sidebar>\n *    <p>Some Content</p>\n * </daff-sidebar-viewport>\n * ```\n *\n * Importantly, its possible for there to be multiple sidebars of many modes\n * at the same time. @see {@link DaffSidebarMode }\n *\n * Since this is a functional component, it's possible to have multiple \"open\" sidebars\n * at the same time. As a result, this component attempts to gracefully handle these situations.\n * However, importantly, there can only be one sidebar of each mode, on each side, at any given time.\n * If this is violated, this component will throw an exception.\n */\n@Component({\n  selector: 'daff-sidebar-viewport',\n  templateUrl: './sidebar-viewport.component.html',\n  styleUrls: ['./sidebar-viewport.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  animations: [\n    daffSidebarAnimations.transformContent,\n  ],\n  providers: [\n    { provide: DAFF_SIDEBAR_SCROLL_TOKEN, useFactory: daffSidebarViewportScrollFactory },\n  ],\n})\nexport class DaffSidebarViewportComponent implements AfterContentChecked, OnDestroy {\n  @HostBinding('class.daff-sidebar-viewport') hostClass = true;\n\n  @HostBinding('class') get classes() {\n    return {\n      'daff-sidebar-viewport': true,\n      [this.navPlacement]: true,\n    };\n  };\n\n  get isNavOnSide() {\n    return this.navPlacement === DaffNavPlacementEnum.BESIDE;\n  }\n\n  onContentAnimationStart(e: AnimationEvent) {\n    if(e.toState === 'open') {\n      this._elementRef.nativeElement.style.overflow = 'hidden';\n    }\n  }\n\n  onContentAnimationDone(e: AnimationEvent) {\n    if(e.toState === 'closed') {\n      this._elementRef.nativeElement.style.overflow = null;\n    }\n  }\n\n  /**\n   * The placement of the nav in relation to the sidebar. The default is set to `top`.\n   * Note that this is really only available when there is a `side-fixed` sidebar.\n   */\n  @Input() navPlacement: DaffNavPlacement = DaffNavPlacementEnum.ABOVE;\n\n  constructor(\n    private cdRef: ChangeDetectorRef,\n    private _elementRef: ElementRef<HTMLElement>,\n    @Inject(DAFF_SIDEBAR_SCROLL_TOKEN) @SkipSelf() private bodyScroll: DaffSidebarScroll,\n    @Inject(DaffSidebarViewportComponent) @SkipSelf() @Optional() private parentViewport,\n    @Inject(DAFF_SIDEBAR_SCROLL_TOKEN) private scroll: DaffSidebarScroll,\n  ) { }\n\n  /**\n   * The list of sidebars in the viewport.\n   *\n   * @docs-private\n   */\n  @ContentChildren(DaffSidebarComponent, { descendants: false }) private sidebars: QueryList<DaffSidebarComponent>;\n\n  /**\n   * The number of pixels that the main content of the page should be shifted to\n   * right when there are child sidebars.\n   */\n  private _shift = '0px';\n\n  /**\n   * The left padding on the content when left side-fixed sidebars are open.\n   */\n  public _contentPadLeft = 0;\n\n  /**\n   * The left padding on the nav when left side-fixed sidebars are open.\n   */\n  public _navPadLeft = 0;\n\n  /**\n   * The right padding on the content when right side-fixed sidebars are open.\n   */\n  public _contentPadRight = 0;\n\n  /**\n   * The right padding on the content when right side-fixed sidebars are open.\n   */\n  public _navPadRight = 0;\n\n  /**\n   * Whether or not the backdrop is interactable\n   */\n  _backdropInteractable = false;\n\n  /**\n   * The animation state\n   */\n  _animationState: DaffSidebarViewportAnimationStateWithParams = { value: DaffSidebarAnimationStates.CLOSED, params: { shift: '0px' }};\n\n  /**\n   * Event fired when the backdrop is clicked. This is often used to close the sidebar.\n   */\n  @Output() backdropClicked: EventEmitter<void> = new EventEmitter<void>();\n\n  ngAfterContentChecked() {\n    const nextShift = sidebarViewportContentShift(this.sidebars) + 'px';\n    if (this._shift !== nextShift) {\n      this._shift = nextShift;\n\n      this.updateAnimationState();\n      this.cdRef.markForCheck();\n    }\n\n    const nextBackdropInteractable = sidebarViewportBackdropInteractable(this.sidebars);\n    if (this._backdropInteractable !== nextBackdropInteractable) {\n      this._backdropInteractable = nextBackdropInteractable;\n      this.updateAnimationState();\n      this.cdRef.markForCheck();\n      if(nextBackdropInteractable) {\n        if(!this.parentViewport && !hasParentViewport(this._elementRef.nativeElement)) {\n          this.bodyScroll.disable();\n        } else {\n          this.scroll.disable();\n        }\n      } else { //if we are hiding the sidebars\n        if(!this.parentViewport && !hasParentViewport(this._elementRef.nativeElement)) {\n          this.bodyScroll.enable();\n        } else {\n          this.scroll.enable();\n        }\n      }\n    };\n\n    const nextLeftPadding = sidebarViewportContentPadding(this.sidebars, 'left');\n    if(this._contentPadLeft !== nextLeftPadding) {\n      this._contentPadLeft = nextLeftPadding;\n      this._navPadLeft = this.isNavOnSide ? this._contentPadLeft : null;\n      this.updateAnimationState();\n      this.cdRef.markForCheck();\n    }\n\n    const nextRightPadding = sidebarViewportContentPadding(this.sidebars, 'right');\n    if(this._contentPadRight !== nextRightPadding) {\n      this._contentPadRight = nextRightPadding;\n      this._navPadRight = this.isNavOnSide ? this._contentPadRight : null;\n      this.updateAnimationState();\n      this.cdRef.markForCheck();\n    }\n  }\n\n  ngOnDestroy() {\n    if(!this.parentViewport && !hasParentViewport(this._elementRef.nativeElement)) {\n      this.bodyScroll.enable();\n    } else {\n      this.scroll.enable();\n    }\n  }\n\n  /**\n   * @docs-private\n   *\n   * Updates the animation state of the viewport depending upon the state\n   * of all sidebars within the viewport.\n   */\n  private updateAnimationState() {\n    this._animationState = {\n      value: getSidebarViewportAnimationState(\n        this.sidebars.reduce((acc: boolean, sidebar) => acc || isViewportContentShifted(sidebar.mode, sidebar.open), false),\n      ),\n      params: { shift: this._shift },\n    };\n  }\n\n  /**\n   * @docs-private\n   * The called when the backdrop of the viewport is clicked upon.\n   */\n  _backdropClicked(): void {\n    this.backdropClicked.emit();\n  }\n}\n","<ng-content select=\"daff-sidebar:not([side=right])\"></ng-content>\n\n<daff-sidebar-viewport-backdrop\n  [@transformContent]=\"_animationState\"\n  [interactable]=\"_backdropInteractable\"\n  (backdropClicked)=\"_backdropClicked()\">\n</daff-sidebar-viewport-backdrop>\n\n<div class=\"daff-sidebar-viewport__nav\"\n  [@transformContent]=\"_animationState\"\n  [style.padding-left.px]=\"_navPadLeft\"\n  [style.padding-right.px]=\"_navPadRight\">\n    <ng-content select=\"[daff-sidebar-viewport-nav]\"></ng-content>\n</div>\n\n<div class=\"daff-sidebar-viewport__content\"\n  [@transformContent]=\"_animationState\"\n  (@transformContent.start)=\"onContentAnimationStart($event)\"\n  (@transformContent.done)=\"onContentAnimationDone($event)\">\n  <div class=\"daff-sidebar-viewport__inner\"\n    [style.padding-left.px]=\"_contentPadLeft\"\n    [style.padding-right.px]=\"_contentPadRight\">\n      <ng-content></ng-content>\n  </div>\n</div>\n\n<ng-content select=\"daff-sidebar[side=right]\"></ng-content>\n"]}
|
@@ -77,7 +77,7 @@ export class DaffTreeComponent {
|
|
77
77
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: DaffTreeComponent, deps: [{ token: i1.DaffTreeNotifierService }], target: i0.ɵɵFactoryTarget.Component }); }
|
78
78
|
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.10", type: DaffTreeComponent, selector: "ul[daff-tree]", inputs: { renderMode: "renderMode", tree: "tree" }, host: { properties: { "class.daff-tree": "this.class" } }, providers: [
|
79
79
|
DaffTreeNotifierService,
|
80
|
-
], queries: [{ propertyName: "withChildrenTemplate", first: true, predicate: ["daffTreeItemWithChildrenTpl"], descendants: true, static: true }, { propertyName: "treeItemTemplate", first: true, predicate: ["daffTreeItemTpl"], descendants: true, static: true }], usesOnChanges: true, hostDirectives: [{ directive: i2.DaffArticleEncapsulatedDirective }], ngImport: i0, template: "<ng-container *ngFor=\"let node of flatTree; trackBy: trackByTreeElement\">\n\t<ng-container>\n\t\t<li [attr.aria-level]=\"node.level\" [class.hidden]=\"!node.visible\">\n\t\t\t<ng-container\n\t\t\t\t*ngTemplateOutlet=\"node.hasChildren ? withChildrenTemplate : treeItemTemplate; context: { $implicit: node }\">\n\t\t\t</ng-container>\n\t\t</li>\n\t</ng-container>\n</ng-container>", styles: [".daff-tree{margin:0;padding:0;list-style:none;--tree-padding:
|
80
|
+
], queries: [{ propertyName: "withChildrenTemplate", first: true, predicate: ["daffTreeItemWithChildrenTpl"], descendants: true, static: true }, { propertyName: "treeItemTemplate", first: true, predicate: ["daffTreeItemTpl"], descendants: true, static: true }], usesOnChanges: true, hostDirectives: [{ directive: i2.DaffArticleEncapsulatedDirective }], ngImport: i0, template: "<ng-container *ngFor=\"let node of flatTree; trackBy: trackByTreeElement\">\n\t<ng-container>\n\t\t<li [attr.aria-level]=\"node.level\" [class.hidden]=\"!node.visible\">\n\t\t\t<ng-container\n\t\t\t\t*ngTemplateOutlet=\"node.hasChildren ? withChildrenTemplate : treeItemTemplate; context: { $implicit: node }\">\n\t\t\t</ng-container>\n\t\t</li>\n\t</ng-container>\n</ng-container>", styles: [".daff-tree{margin:0;padding:0;list-style:none;--tree-padding: 1rem}.daff-tree li.hidden{display:none}.daff-tree-item{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block;position:relative;background:none;border:0;padding:.5rem 1rem .5rem 0;line-height:1.5rem;font-weight:400;text-align:left;text-decoration:none;width:100%;padding-left:calc(var(--tree-padding) * (var(--depth)))}.daff-tree-item:before{content:\"\";position:absolute;top:0;bottom:0;left:0;width:.25rem}.daff-tree-item:focus,.daff-tree-item:focus-visible{z-index:1}.daff-tree-item.selected{font-weight:600}.daff-tree-item.parent{position:relative;padding-right:2.5rem}.daff-tree-item.parent:after{content:\"\";position:absolute;top:48%;right:1rem;display:inline-block;border-right:2px solid currentColor;border-bottom:2px solid currentColor;width:.5rem;height:.5rem;transform:translateY(-50%) rotate(45deg);transition:transform .15s}.daff-tree-item.parent.open:after{top:56%;transform:translateY(-50%) rotate(225deg)}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
81
81
|
}
|
82
82
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: DaffTreeComponent, decorators: [{
|
83
83
|
type: Component,
|
@@ -85,7 +85,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImpo
|
|
85
85
|
DaffTreeNotifierService,
|
86
86
|
], hostDirectives: [{
|
87
87
|
directive: DaffArticleEncapsulatedDirective,
|
88
|
-
}], template: "<ng-container *ngFor=\"let node of flatTree; trackBy: trackByTreeElement\">\n\t<ng-container>\n\t\t<li [attr.aria-level]=\"node.level\" [class.hidden]=\"!node.visible\">\n\t\t\t<ng-container\n\t\t\t\t*ngTemplateOutlet=\"node.hasChildren ? withChildrenTemplate : treeItemTemplate; context: { $implicit: node }\">\n\t\t\t</ng-container>\n\t\t</li>\n\t</ng-container>\n</ng-container>", styles: [".daff-tree{margin:0;padding:0;list-style:none;--tree-padding:
|
88
|
+
}], template: "<ng-container *ngFor=\"let node of flatTree; trackBy: trackByTreeElement\">\n\t<ng-container>\n\t\t<li [attr.aria-level]=\"node.level\" [class.hidden]=\"!node.visible\">\n\t\t\t<ng-container\n\t\t\t\t*ngTemplateOutlet=\"node.hasChildren ? withChildrenTemplate : treeItemTemplate; context: { $implicit: node }\">\n\t\t\t</ng-container>\n\t\t</li>\n\t</ng-container>\n</ng-container>", styles: [".daff-tree{margin:0;padding:0;list-style:none;--tree-padding: 1rem}.daff-tree li.hidden{display:none}.daff-tree-item{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:block;position:relative;background:none;border:0;padding:.5rem 1rem .5rem 0;line-height:1.5rem;font-weight:400;text-align:left;text-decoration:none;width:100%;padding-left:calc(var(--tree-padding) * (var(--depth)))}.daff-tree-item:before{content:\"\";position:absolute;top:0;bottom:0;left:0;width:.25rem}.daff-tree-item:focus,.daff-tree-item:focus-visible{z-index:1}.daff-tree-item.selected{font-weight:600}.daff-tree-item.parent{position:relative;padding-right:2.5rem}.daff-tree-item.parent:after{content:\"\";position:absolute;top:48%;right:1rem;display:inline-block;border-right:2px solid currentColor;border-bottom:2px solid currentColor;width:.5rem;height:.5rem;transform:translateY(-50%) rotate(45deg);transition:transform .15s}.daff-tree-item.parent.open:after{top:56%;transform:translateY(-50%) rotate(225deg)}\n"] }]
|
89
89
|
}], ctorParameters: () => [{ type: i1.DaffTreeNotifierService }], propDecorators: { class: [{
|
90
90
|
type: HostBinding,
|
91
91
|
args: ['class.daff-tree']
|
@@ -111,7 +111,7 @@ export class DaffTreeItemDirective {
|
|
111
111
|
}
|
112
112
|
}
|
113
113
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: DaffTreeItemDirective, deps: [{ token: DOCUMENT }, { token: i1.DaffTreeNotifierService }], target: i0.ɵɵFactoryTarget.Directive }); }
|
114
|
-
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.10", type: DaffTreeItemDirective, selector: "[daffTreeItem]", inputs: { node: "node", selected: "selected" }, host: { listeners: { "keydown.escape": "onEscape()", "click": "onClick()" }, properties: { "class.daff-tree-item": "this.class", "class.
|
114
|
+
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.10", type: DaffTreeItemDirective, selector: "[daffTreeItem]", inputs: { node: "node", selected: "selected" }, host: { listeners: { "keydown.escape": "onEscape()", "click": "onClick()" }, properties: { "class.daff-tree-item": "this.class", "class.parent": "this.classParent", "attr.id": "this.id", "attr.aria-expanded": "this.ariaExpanded", "style.--depth": "this.depth", "class.selected": "this.selectedClass", "class.open": "this.openClass" } }, ngImport: i0 }); }
|
115
115
|
}
|
116
116
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImport: i0, type: DaffTreeItemDirective, decorators: [{
|
117
117
|
type: Directive,
|
@@ -126,7 +126,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImpo
|
|
126
126
|
args: ['class.daff-tree-item']
|
127
127
|
}], classParent: [{
|
128
128
|
type: HostBinding,
|
129
|
-
args: ['class.
|
129
|
+
args: ['class.parent']
|
130
130
|
}], id: [{
|
131
131
|
type: HostBinding,
|
132
132
|
args: ['attr.id']
|
@@ -153,4 +153,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImpo
|
|
153
153
|
type: HostListener,
|
154
154
|
args: ['click']
|
155
155
|
}] } });
|
156
|
-
//# sourceMappingURL=data:application/json;base64,
|
156
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-item.directive.js","sourceRoot":"","sources":["../../../../../libs/design/tree/src/tree-item/tree-item.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport {\n  Directive,\n  HostBinding,\n  HostListener,\n  Inject,\n  Input,\n} from '@angular/core';\n\nimport { DaffTreeNotifierService } from '../tree/tree-notifier.service';\nimport { DaffTreeFlatNode } from '../utils/flatten-tree';\n\n/**\n * The `DaffTreeItemDirective` allows you to demarcate the elements which are\n * tree-children that interact with the parent tree.\n *\n * They can be used like:\n *\n * ```html\n * <ul daff-tree [tree]=\"tree\">\n *   <ng-template #daffTreeItemWithChildrenTpl let-node>\n *       <button daffTreeItem [node]=\"node\">{{ node.title }} </button>\n *   </ng-template>\n *\n *   <ng-template #daffTreeItemTpl let-node>\n *       <a daffTreeItem [node]=\"node\" [routerLink]=\"node.url\">{{ node.title }}</a>\n *   </ng-template>\n * </ul>\n * ```\n *\n * where `tree` is a {@link DaffTreeData} and `daff-tree` is a {@link DaffTreeComponent}.\n *\n */\n@Directive({\n  selector: '[daffTreeItem]',\n})\nexport class DaffTreeItemDirective {\n\n  /**\n   * The css class of the daff-tree.\n   *\n   * @docs-private\n   */\n  @HostBinding('class.daff-tree-item') class = true;\n\n  /**\n   * The css class of a DaffTreeItemDirective that has children.\n   *\n   * @docs-private\n   */\n  @HostBinding('class.parent') classParent = false;\n\n  /**\n   * The html `id` of the tree item. This is derived from the {@link DaffTreeData}.\n   *\n   * @docs-private\n   */\n  @HostBinding('attr.id') id;\n\n  /**\n   * Accessibility property, notifying users about whether\n   * or not the tree item is open.\n   *\n   * @docs-private\n   */\n  @HostBinding('attr.aria-expanded') ariaExpanded: string;\n\n  /**\n   * A css variable indicating the depth of the tree.\n   * You can use this to style your templates if you want to\n   * use different designs at different depths.\n   */\n  @HostBinding('style.--depth') depth: number;\n\n  /**\n   * The CSS class indicating whether or not the tree is `selected`.\n   */\n  @HostBinding('class.selected') get selectedClass() {\n    return this.selected;\n  };\n\n  /**\n   * The CSS class indicating whether or not the tree is `open`.\n   */\n  @HostBinding('class.open') openClass = false;\n\n  /**\n   * The {@link DaffTreeFlatNode} associated with this specific tree item.\n   *\n   * @docs-private\n   */\n  private _node: DaffTreeFlatNode;\n\n  /**\n   * The {@link DaffTreeFlatNode} associated with this specific tree item.\n   */\n  @Input()\n  get node() {\n    return this._node;\n  };\n  set node(val: DaffTreeFlatNode) {\n    this._node = val;\n    this.id = 'tree-' + this._node.id;\n    this.depth = this._node.level;\n    this.classParent = this._node.hasChildren;\n    this.openClass = this._node._treeRef.open;\n\n    if(this._node.hasChildren) {\n      this.ariaExpanded = this._node._treeRef.open ? 'true' : 'false';\n    }\n  }\n\n  /**\n   * Whether or not the tree item is the currently active item.\n   * Note that there is no requirement there there only be one active item at a time.\n   */\n  @Input() selected = false;\n\n  constructor(\n    @Inject(DOCUMENT) private document: any,\n    private treeNotifier: DaffTreeNotifierService,\n  ) {}\n\n  /**\n   * @docs-private\n   */\n  @HostListener('keydown.escape')\n  onEscape() {\n    this.toggleParent(this.node);\n  }\n\n  /**\n   * @docs-private\n   */\n  @HostListener('click')\n  onClick() {\n    if(this.node.hasChildren) {\n      this.toggleTree(this.node);\n    }\n    this.treeNotifier.notify();\n  }\n\n  /**\n   * Toggle the open state of the tree's parent.\n   */\n  toggleParent(node: DaffTreeFlatNode) {\n    if(node._treeRef?.parent.parent === undefined) {\n      return;\n    }\n    node._treeRef.parent.open = !node._treeRef.parent.open;\n    (<Document>this.document).getElementById('tree-' + node._treeRef.parent.id).focus();\n  }\n\n  /**\n   * Toggle the open state of this specific subtree tree.\n   */\n  toggleTree(node: DaffTreeFlatNode) {\n    if(node._treeRef.open === false) {\n      node._treeRef.open = true;\n    } else {\n      node._treeRef.open = false;\n    }\n  }\n}\n"]}
|