desy-angular 5.0.0 → 5.1.2

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.
Files changed (49) hide show
  1. package/bundles/desy-angular.umd.js +1454 -344
  2. package/bundles/desy-angular.umd.js.map +1 -1
  3. package/bundles/desy-angular.umd.min.js +2 -2
  4. package/bundles/desy-angular.umd.min.js.map +1 -1
  5. package/desy-angular.d.ts +29 -24
  6. package/desy-angular.metadata.json +1 -1
  7. package/esm2015/desy-angular.js +30 -25
  8. package/esm2015/lib/desy-buttons/components/dropdown/dropdown.component.js +70 -70
  9. package/esm2015/lib/desy-buttons/components/listbox/listbox-label/listbox-label.component.js +6 -15
  10. package/esm2015/lib/desy-buttons/components/listbox/listbox.component.js +67 -55
  11. package/esm2015/lib/desy-buttons/components/toggle/toggle-off-state/toggle-off-state.component.js +15 -0
  12. package/esm2015/lib/desy-buttons/components/toggle/toggle-on-state/toggle-on-state.component.js +15 -0
  13. package/esm2015/lib/desy-buttons/components/toggle/toggle.component.js +41 -0
  14. package/esm2015/lib/desy-buttons/desy-buttons.module.js +12 -3
  15. package/esm2015/lib/desy-forms/components/tree/interfaces/itree-item.js +3 -0
  16. package/esm2015/lib/desy-forms/components/tree/interfaces/quit-tree-item-focus-options.js +2 -0
  17. package/esm2015/lib/desy-forms/components/tree/tree-checkbox/tree-checkbox.component.js +151 -0
  18. package/esm2015/lib/desy-forms/components/tree/tree-item/tree-item.component.js +370 -0
  19. package/esm2015/lib/desy-forms/components/tree/tree-items-generator/tree-items-generator.component.js +25 -0
  20. package/esm2015/lib/desy-forms/components/tree/tree-sub/tree-sub.component.js +14 -0
  21. package/esm2015/lib/desy-forms/components/tree/tree.component.js +396 -0
  22. package/esm2015/lib/desy-forms/desy-forms.module.js +15 -1
  23. package/esm2015/lib/desy-nav/components/header/header-dropdown/header-dropdown.component.js +8 -3
  24. package/esm2015/lib/desy-nav/components/header/header-offcanvas/header-offcanvas.component.js +7 -4
  25. package/esm2015/lib/desy-nav/components/header/header-subnav/header-subnav.component.js +2 -2
  26. package/esm2015/lib/desy-nav/components/menu-vertical/menu-vertical.component.js +3 -3
  27. package/esm2015/lib/desy-nav/components/menubar/menubar.component.js +1 -1
  28. package/esm2015/lib/desy-nav/components/nav/nav.component.js +38 -2
  29. package/esm2015/lib/desy-pagination/components/pagination/pagination.component.js +2 -2
  30. package/esm2015/public-api.js +5 -1
  31. package/fesm2015/desy-angular.js +1361 -309
  32. package/fesm2015/desy-angular.js.map +1 -1
  33. package/lib/desy-buttons/components/dropdown/dropdown.component.d.ts +4 -7
  34. package/lib/desy-buttons/components/listbox/listbox-label/listbox-label.component.d.ts +2 -6
  35. package/lib/desy-buttons/components/listbox/listbox.component.d.ts +1 -2
  36. package/lib/desy-buttons/components/toggle/toggle-off-state/toggle-off-state.component.d.ts +5 -0
  37. package/lib/desy-buttons/components/toggle/toggle-on-state/toggle-on-state.component.d.ts +5 -0
  38. package/lib/desy-buttons/components/toggle/toggle.component.d.ts +15 -0
  39. package/lib/desy-forms/components/tree/interfaces/itree-item.d.ts +5 -0
  40. package/lib/desy-forms/components/tree/interfaces/quit-tree-item-focus-options.d.ts +5 -0
  41. package/lib/desy-forms/components/tree/tree-checkbox/tree-checkbox.component.d.ts +43 -0
  42. package/lib/desy-forms/components/tree/tree-item/tree-item.component.d.ts +87 -0
  43. package/lib/desy-forms/components/tree/tree-items-generator/tree-items-generator.component.d.ts +10 -0
  44. package/lib/desy-forms/components/tree/tree-sub/tree-sub.component.d.ts +6 -0
  45. package/lib/desy-forms/components/tree/tree.component.d.ts +107 -0
  46. package/lib/desy-nav/components/header/header-dropdown/header-dropdown.component.d.ts +2 -0
  47. package/lib/desy-nav/components/nav/nav.component.d.ts +4 -0
  48. package/package.json +2 -2
  49. package/public-api.d.ts +4 -0
@@ -1,6 +1,6 @@
1
- import { EventEmitter, TemplateRef, OnChanges, SimpleChanges, ElementRef, OnInit } from '@angular/core';
1
+ import { EventEmitter, TemplateRef, ElementRef, OnInit } from '@angular/core';
2
2
  import { AccessibilityAndContentRequiredComponent } from '../../../shared/components';
3
- export declare class DropdownComponent extends AccessibilityAndContentRequiredComponent implements OnChanges, OnInit {
3
+ export declare class DropdownComponent extends AccessibilityAndContentRequiredComponent implements OnInit {
4
4
  static readonly KEY_CODE_ESC = "Escape";
5
5
  dropdownContent: ElementRef;
6
6
  id: string;
@@ -11,14 +11,11 @@ export declare class DropdownComponent extends AccessibilityAndContentRequiredCo
11
11
  classes: string;
12
12
  caller: TemplateRef<any>;
13
13
  clickEvent: EventEmitter<any>;
14
- show: boolean;
14
+ isOpen: boolean;
15
15
  clickOutsideEnabled: boolean;
16
16
  tippyProperties: any;
17
17
  ngOnInit(): any;
18
- ngOnChanges(changes: SimpleChanges): void;
19
18
  onClick(event: any): void;
20
- toggleDropdown(): void;
21
- closeDropdown(): void;
19
+ setOpen(isOpen: boolean): void;
22
20
  isDisabled(): boolean;
23
- onKeyDown(event: KeyboardEvent): void;
24
21
  }
@@ -1,8 +1,4 @@
1
- import { OnInit, TemplateRef } from '@angular/core';
2
- export declare class ListboxLabelComponent implements OnInit {
1
+ import { ContentBaseComponent } from '../../../../shared/components';
2
+ export declare class ListboxLabelComponent extends ContentBaseComponent {
3
3
  classes: string;
4
- content: TemplateRef<any>;
5
- private isInit;
6
- ngOnInit(): void;
7
- getContent(): TemplateRef<any>;
8
4
  }
@@ -27,7 +27,7 @@ export declare class ListboxComponent extends AccessibilityAndTextOrHtmlRequired
27
27
  activeItemChange: EventEmitter<any>;
28
28
  tippyProperties: any;
29
29
  currentFocusIndex: number;
30
- buttonContent: string;
30
+ buttonContentHtml: string;
31
31
  isListVisible: boolean;
32
32
  lastActiveItems: {
33
33
  item: ListboxItemData;
@@ -50,5 +50,4 @@ export declare class ListboxComponent extends AccessibilityAndTextOrHtmlRequired
50
50
  getItemId(item: ListboxItemData, index: number): string;
51
51
  hasLabel(): boolean;
52
52
  getLabelContent(label: ListboxLabelData): string;
53
- isButtonContentHtml(): boolean;
54
53
  }
@@ -0,0 +1,5 @@
1
+ import { AccessibilityComponent } from '../../../../shared/components';
2
+ export declare class ToggleOffStateComponent extends AccessibilityComponent {
3
+ content: any;
4
+ classes: string;
5
+ }
@@ -0,0 +1,5 @@
1
+ import { AccessibilityComponent } from '../../../../shared/components';
2
+ export declare class ToggleOnStateComponent extends AccessibilityComponent {
3
+ content: any;
4
+ classes: string;
5
+ }
@@ -0,0 +1,15 @@
1
+ import { EventEmitter } from '@angular/core';
2
+ import { AccessibilityComponent } from '../../../shared/components';
3
+ import { ToggleOffStateComponent } from './toggle-off-state/toggle-off-state.component';
4
+ import { ToggleOnStateComponent } from './toggle-on-state/toggle-on-state.component';
5
+ export declare class ToggleComponent extends AccessibilityComponent {
6
+ id: string;
7
+ isSwitch: boolean;
8
+ pressed: boolean;
9
+ classes: string;
10
+ clickEvent: EventEmitter<any>;
11
+ pressedChange: EventEmitter<any>;
12
+ contentTemplateOnState: ToggleOnStateComponent;
13
+ contentTemplateOffState: ToggleOffStateComponent;
14
+ onClick(event: any): void;
15
+ }
@@ -0,0 +1,5 @@
1
+ export declare class ITreeItem {
2
+ id: string;
3
+ subLevel: number;
4
+ defaultId: string;
5
+ }
@@ -0,0 +1,5 @@
1
+ import { TreeItemComponent } from "../tree-item/tree-item.component";
2
+ export interface QuitTreeItemFocusOptions {
3
+ nextElement?: 'first' | 'last' | 'previous' | 'next' | 'firstChild' | 'parent';
4
+ currentItem?: TreeItemComponent;
5
+ }
@@ -0,0 +1,43 @@
1
+ import { ChangeDetectorRef, ElementRef, EventEmitter, OnInit } from '@angular/core';
2
+ import { LabelComponent } from "../../label/label.component";
3
+ import { HintComponent } from "../../hint/hint.component";
4
+ import { AccessibilityComponent } from "../../../../shared/components";
5
+ export declare class TreeCheckboxComponent extends AccessibilityComponent implements OnInit {
6
+ private changeDetector;
7
+ inputElement: ElementRef;
8
+ contentWrapper: ElementRef;
9
+ id: string;
10
+ name: string;
11
+ type: 'radio' | 'checkbox' | null | undefined;
12
+ classes: string;
13
+ value: any;
14
+ checked: boolean;
15
+ checkedChange: EventEmitter<any>;
16
+ isIndeterminate: boolean;
17
+ indeterminateChecked: boolean;
18
+ indeterminateCheckedChange: EventEmitter<any>;
19
+ disabled: boolean;
20
+ hasDividers: boolean;
21
+ describedBy: string;
22
+ hasError: boolean;
23
+ labelComponent: LabelComponent;
24
+ hintComponent: HintComponent;
25
+ itemDescribedBy: string;
26
+ private _lastIndeterminate;
27
+ private _hasInit;
28
+ constructor(changeDetector: ChangeDetectorRef);
29
+ ngOnInit(): void;
30
+ detectChanges(): void;
31
+ hasChanged(): void;
32
+ onIdChange(): void;
33
+ setIndeterminateStatus(): void;
34
+ setIndeterminateChecked(indeterminateChecked: boolean): void;
35
+ focus(): void;
36
+ matchesText(value: string): boolean;
37
+ preventDefault(event: KeyboardEvent): void;
38
+ getHintId(): string;
39
+ overrideLabelParams(): void;
40
+ overrideHintParams(): void;
41
+ getItemDescribedBy(): string;
42
+ onDescribedByChange(): void;
43
+ }
@@ -0,0 +1,87 @@
1
+ import { ChangeDetectorRef, ElementRef, EventEmitter, OnChanges, SimpleChanges } from '@angular/core';
2
+ import { TreeSubComponent } from "../tree-sub/tree-sub.component";
3
+ import { ITreeItem } from "../interfaces/itree-item";
4
+ import { HintComponent } from "../../hint/hint.component";
5
+ import { LabelComponent } from "../../label/label.component";
6
+ import { QuitTreeItemFocusOptions } from "../interfaces/quit-tree-item-focus-options";
7
+ import { TreeCheckboxComponent } from "../tree-checkbox/tree-checkbox.component";
8
+ import { AccessibilityComponent } from "../../../../shared/components";
9
+ export declare class TreeItemComponent extends AccessibilityComponent implements OnChanges, ITreeItem {
10
+ private changeDetector;
11
+ private element;
12
+ private static _treeItemKeySuffix;
13
+ hiddenWrapper: ElementRef;
14
+ id: string;
15
+ name: string;
16
+ value: string;
17
+ classes: string;
18
+ active: boolean;
19
+ disabled: boolean;
20
+ title: string;
21
+ hasDividers: boolean;
22
+ isIndeterminate: boolean;
23
+ checked: boolean;
24
+ checkedChange: EventEmitter<any>;
25
+ checkedChangeForTree: EventEmitter<any>;
26
+ expanded: boolean;
27
+ expandedChange: EventEmitter<any>;
28
+ indeterminateChecked: boolean;
29
+ indeterminateCheckedChange: EventEmitter<any>;
30
+ sub: TreeSubComponent;
31
+ hint: HintComponent;
32
+ label: LabelComponent;
33
+ checkbox: TreeCheckboxComponent;
34
+ readonly treeItemKey: string;
35
+ type: 'radio' | 'checkbox' | null | undefined;
36
+ subLevel: number;
37
+ parentName: string;
38
+ defaultId: any;
39
+ inheritedExpandedFirstLevel: boolean;
40
+ inheritedDecoupleChildFromParent: boolean;
41
+ inheritedDescribedBy: string;
42
+ inheritedHasError: boolean;
43
+ allParentsExpanded: boolean;
44
+ inheritedMatchesSearch: boolean;
45
+ orderInTree: number;
46
+ quitFocus: EventEmitter<QuitTreeItemFocusOptions>;
47
+ isFocus: boolean;
48
+ isHover: boolean;
49
+ private _matchesValidText;
50
+ constructor(changeDetector: ChangeDetectorRef, element: ElementRef);
51
+ ngOnChanges(changes: SimpleChanges): void;
52
+ focus(): void;
53
+ setCheckedAutomaticallyDependingOnChildren(): void;
54
+ refreshAllParentsExpandedRecursive(value: any): void;
55
+ detectChanges(): void;
56
+ expandSub(value: boolean): void;
57
+ handleCheckboxChange(checked: boolean): void;
58
+ handleIndeterminateCheckedChange(indeterminate: boolean): void;
59
+ handleItemFocus(value: any, condition?: boolean): void;
60
+ handleItemHover(value: any, condition?: boolean): void;
61
+ handleArrowUp(event: KeyboardEvent, condition?: boolean): void;
62
+ handleHome(event: KeyboardEvent, condition?: boolean): void;
63
+ handleEnd(event: KeyboardEvent, condition?: boolean): void;
64
+ handleArrowDown(event: KeyboardEvent, condition?: boolean): void;
65
+ handleArrowRight(event: KeyboardEvent, condition?: boolean): void;
66
+ handleArrowLeft(event: KeyboardEvent, condition?: boolean): void;
67
+ setChecked(checked: boolean, ignoreInTree: boolean, emitEvent?: boolean): void;
68
+ setIndeterminateChecked(indeterminate: boolean): void;
69
+ setSubLevel(subLevel: number): void;
70
+ setOrderRecursively(order: number): number;
71
+ setDefaultId(defaultId: string): void;
72
+ setDefaultIdRecursive(): void;
73
+ getId(): string;
74
+ isHidden(): boolean;
75
+ areAllChildrenHidden(): boolean;
76
+ areAllChildrenChecked(): boolean;
77
+ hasChildrenCheckedOrIndeterminate(): boolean;
78
+ matchesText(value: string): boolean;
79
+ getKey(): string;
80
+ getParentKey(): string;
81
+ isActive(): boolean;
82
+ /**
83
+ * Genera una clave única para el componente
84
+ * @private
85
+ */
86
+ private static generateStaticItemKey;
87
+ }
@@ -0,0 +1,10 @@
1
+ import { OnInit, TemplateRef, ViewContainerRef } from '@angular/core';
2
+ import { TreeItemComponent } from "../tree-item/tree-item.component";
3
+ export declare class TreeItemsGeneratorComponent implements OnInit {
4
+ private viewContainerRef;
5
+ content: TemplateRef<any>;
6
+ items: any[];
7
+ itemTemplate: TemplateRef<TreeItemComponent>;
8
+ constructor(viewContainerRef: ViewContainerRef);
9
+ ngOnInit(): void;
10
+ }
@@ -0,0 +1,6 @@
1
+ import { ITreeItem } from "../interfaces/itree-item";
2
+ import { ContentBaseComponent } from "../../../../shared/components";
3
+ export declare class TreeSubComponent extends ContentBaseComponent {
4
+ classes: string;
5
+ itemList: ITreeItem[];
6
+ }
@@ -0,0 +1,107 @@
1
+ import { ChangeDetectorRef, EventEmitter, OnChanges, OnDestroy, QueryList, SimpleChanges, TemplateRef } from '@angular/core';
2
+ import { TreeItemComponent } from "./tree-item/tree-item.component";
3
+ import { FormFieldComponent } from "../form-field/form-field.component";
4
+ import { FieldsetComponent } from "../fieldset/fieldset.component";
5
+ import { QuitTreeItemFocusOptions } from "./interfaces/quit-tree-item-focus-options";
6
+ import { SearchBarComponent } from "../search-bar/search-bar.component";
7
+ export declare class TreeComponent extends FormFieldComponent<any[]> implements OnChanges, OnDestroy {
8
+ private changeDetector;
9
+ idPrefix: string;
10
+ classes: string;
11
+ formGroupClasses: string;
12
+ name: string;
13
+ type: 'radio' | 'checkbox' | null | undefined;
14
+ describedBy: string;
15
+ expandedFirstLevel: boolean;
16
+ decoupleChildFromParent: boolean;
17
+ disableDefaultSearch: boolean;
18
+ searchMatchValues: string[];
19
+ searchMatchValuesChange: EventEmitter<string[]>;
20
+ allItems: QueryList<TreeItemComponent>;
21
+ fieldsetComponent: FieldsetComponent;
22
+ searchBarComponent: SearchBarComponent;
23
+ innerHtml: TemplateRef<any>;
24
+ private rootItems;
25
+ private _itemListSubscription;
26
+ private _allItemListSubscription;
27
+ private _itemListCheckedSubscriptions;
28
+ private _itemListQuitFocusSubscriptions;
29
+ private _alreadyConfiguringItems;
30
+ constructor(changeDetector: ChangeDetectorRef);
31
+ ngOnDestroy(): void;
32
+ ngOnChanges(changes: SimpleChanges): void;
33
+ /**
34
+ * Actualiza el valor del componente al checkquearse un ítem
35
+ * @param originItem ítem modificado
36
+ */
37
+ updateValueFromItems(originItem?: TreeItemComponent): void;
38
+ /**
39
+ * Gestiona cuando el foco abandona un ítem desde un evento de teclado controlado
40
+ * @param options
41
+ */
42
+ handleItemQuitFocus(options: QuitTreeItemFocusOptions): void;
43
+ /**
44
+ * Realiza la búsqueda interna de los items en el componente
45
+ * @param value texto de búsqueda
46
+ */
47
+ onSearch(value: string): void;
48
+ /**
49
+ * Configura los items del árbol
50
+ */
51
+ configureAllItems(): void;
52
+ /**
53
+ * Modifica los items visibles según el filtro de búsqueda
54
+ */
55
+ onSearchMatchValuesChange(): void;
56
+ getIdPrefix(): string;
57
+ getDescribedBy(): string;
58
+ /**
59
+ * Devuelve el valor de describedBy que se transmitirá a los items
60
+ */
61
+ getDescribedByForItems(): string;
62
+ hasFieldsetComponent(): boolean;
63
+ /**
64
+ * Overrides super.getHintId();
65
+ */
66
+ getHintId(): string;
67
+ /**
68
+ * Overrides super.getHintId();
69
+ */
70
+ getErrorId(): string;
71
+ overrideFieldsetParams(fieldset: FieldsetComponent): void;
72
+ overrideSearchBarParams(searchbar: SearchBarComponent): void;
73
+ /**
74
+ * Se llama desde FormField
75
+ */
76
+ overrideHintParams(hint: any): void;
77
+ /**
78
+ * Se llama desde FormField
79
+ */
80
+ overrideErrorMessageParams(errorMessage: any): void;
81
+ /**
82
+ * Se llama desde FormField
83
+ */
84
+ onDeleteErrorMessage(errorMessage: any): void;
85
+ /**
86
+ * Configura la estructura del árbol
87
+ * @private
88
+ */
89
+ private buildTree;
90
+ /**
91
+ * Si tiene un mensaje de error, se indica a los items
92
+ * @param hasError
93
+ * @private
94
+ */
95
+ private setErrorInItems;
96
+ /**
97
+ * Limpia un listado de subscripciones
98
+ * @param subscriptionList
99
+ * @private
100
+ */
101
+ private clearSubscriptions;
102
+ /**
103
+ * Devuelve los items del árbol ordenados
104
+ * @private
105
+ */
106
+ private getAllItemsInOrder;
107
+ }
@@ -1,11 +1,13 @@
1
1
  import { NavComponent } from '../../nav/nav.component';
2
2
  import { AccessibilityComponent } from "../../../../shared/components";
3
+ import { ContentComponent } from "../../../../desy-commons/components/content/content.component";
3
4
  export declare class HeaderDropdownComponent extends AccessibilityComponent {
4
5
  hiddenText: string;
5
6
  classesContainer: string;
6
7
  classesTooltip: string;
7
8
  classes: string;
8
9
  nav: NavComponent;
10
+ contentComponent: ContentComponent;
9
11
  overrideNavParams(nav: NavComponent): void;
10
12
  handleEmptyContent(element: string): void;
11
13
  }
@@ -15,4 +15,8 @@ export declare class NavComponent extends AccessibilityComponent implements OnCh
15
15
  handleContentEmpty(position: number): void;
16
16
  getItemId(item: NavItemData, index: number): string;
17
17
  getIdPrefix(): string;
18
+ movePrevious(event: KeyboardEvent, currentIndex: number): void;
19
+ moveNext(event: KeyboardEvent, currentIndex: number): void;
20
+ simulateClick(event: KeyboardEvent, item: NavItemData, index: number): void;
21
+ private isFocusableItem;
18
22
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "desy-angular",
3
- "version": "5.0.0",
3
+ "version": "5.1.2",
4
4
  "description": "Desy Angular contains the code you need to start building your Angular app for Gobierno de Aragón.",
5
5
  "engines": {
6
6
  "node": "^12.18.0"
@@ -31,7 +31,7 @@
31
31
  "@angular/platform-browser": "^11.0.0",
32
32
  "@angular/platform-browser-dynamic": "^11.0.0",
33
33
  "@angular/router": "^11.0.0",
34
- "desy-html": "^5.0.0"
34
+ "desy-html": "^5.2.2"
35
35
  },
36
36
  "dependencies": {
37
37
  "ngx-tippy-wrapper": "2.1.0",
package/public-api.d.ts CHANGED
@@ -27,6 +27,7 @@ export * from './lib/desy-forms/components/radios/radios.component';
27
27
  export * from './lib/desy-forms/components/checkboxes/checkboxes.component';
28
28
  export * from './lib/desy-forms/components/date-input/date-input.component';
29
29
  export * from './lib/desy-forms/components/search-bar/search-bar.component';
30
+ export * from './lib/desy-forms/components/tree/tree.component';
30
31
  export * from './lib/desy-forms/directives/condition.directive';
31
32
  export * from './lib/desy-forms/interfaces/legend-data';
32
33
  export * from './lib/desy-forms/interfaces/error-message-data';
@@ -46,6 +47,9 @@ export * from './lib/desy-forms/components/input-group/input-group-select/input-
46
47
  export * from './lib/desy-forms/components/radios/radio-item/radio-item.component';
47
48
  export * from './lib/desy-forms/components/select/option/option.component';
48
49
  export * from './lib/desy-forms/components/select/option-group/option-group.component';
50
+ export * from './lib/desy-forms/components/tree/tree-sub/tree-sub.component';
51
+ export * from './lib/desy-forms/components/tree/tree-item/tree-item.component';
52
+ export * from './lib/desy-forms/components/tree/tree-items-generator/tree-items-generator.component';
49
53
  export * from './lib/desy-modals/components/modal/modal.component';
50
54
  export * from './lib/desy-modals/components/dialog/dialog.component';
51
55
  export * from './lib/desy-modals/interfaces/modal-icon-data';