@ecodev/natural 47.3.1 → 48.0.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.
Files changed (105) hide show
  1. package/esm2020/lib/classes/abstract-editable-list.mjs +2 -2
  2. package/esm2020/lib/classes/abstract-list.mjs +1 -1
  3. package/esm2020/lib/modules/alert/alert.module.mjs +4 -4
  4. package/esm2020/lib/modules/alert/alert.service.mjs +5 -5
  5. package/esm2020/lib/modules/alert/confirm.component.mjs +6 -6
  6. package/esm2020/lib/modules/columns-picker/columns-picker.component.mjs +9 -8
  7. package/esm2020/lib/modules/columns-picker/columns-picker.module.mjs +11 -7
  8. package/esm2020/lib/modules/common/common-module.mjs +4 -4
  9. package/esm2020/lib/modules/common/directives/linkable-tab.directive.mjs +5 -5
  10. package/esm2020/lib/modules/detail-header/detail-header.component.mjs +6 -5
  11. package/esm2020/lib/modules/detail-header/detail-header.module.mjs +6 -5
  12. package/esm2020/lib/modules/dialog-trigger/dialog-trigger.component.mjs +4 -4
  13. package/esm2020/lib/modules/dialog-trigger/dialog-trigger.module.mjs +2 -2
  14. package/esm2020/lib/modules/dropdown-components/natural-dropdown-components.module.mjs +7 -7
  15. package/esm2020/lib/modules/dropdown-components/type-date/type-date.component.mjs +7 -8
  16. package/esm2020/lib/modules/dropdown-components/type-date-range/type-date-range.component.mjs +5 -5
  17. package/esm2020/lib/modules/dropdown-components/type-hierarchic-selector/type-hierarchic-selector.component.mjs +4 -4
  18. package/esm2020/lib/modules/dropdown-components/type-natural-select/type-natural-select.component.mjs +4 -4
  19. package/esm2020/lib/modules/dropdown-components/type-number/type-number.component.mjs +5 -5
  20. package/esm2020/lib/modules/dropdown-components/type-select/type-select.component.mjs +7 -7
  21. package/esm2020/lib/modules/dropdown-components/type-text/type-text.component.mjs +3 -3
  22. package/esm2020/lib/modules/file/component/file.component.mjs +7 -6
  23. package/esm2020/lib/modules/file/file.module.mjs +5 -4
  24. package/esm2020/lib/modules/file/utils.mjs +16 -5
  25. package/esm2020/lib/modules/fixed-button/fixed-button.component.mjs +6 -5
  26. package/esm2020/lib/modules/fixed-button/fixed-button.module.mjs +6 -5
  27. package/esm2020/lib/modules/fixed-button-detail/fixed-button-detail.component.mjs +2 -2
  28. package/esm2020/lib/modules/fixed-button-detail/fixed-button-detail.module.mjs +2 -2
  29. package/esm2020/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.mjs +10 -9
  30. package/esm2020/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.component.mjs +8 -8
  31. package/esm2020/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.service.mjs +4 -4
  32. package/esm2020/lib/modules/hierarchic-selector/hierarchic-selector.module.mjs +8 -8
  33. package/esm2020/lib/modules/icon/icon.directive.mjs +100 -0
  34. package/esm2020/lib/modules/icon/icon.module.mjs +6 -6
  35. package/esm2020/lib/modules/icon/public-api.mjs +2 -2
  36. package/esm2020/lib/modules/panels/panels.module.mjs +2 -2
  37. package/esm2020/lib/modules/panels/panels.service.mjs +4 -4
  38. package/esm2020/lib/modules/relations/relations.component.mjs +10 -9
  39. package/esm2020/lib/modules/relations/relations.module.mjs +13 -9
  40. package/esm2020/lib/modules/search/classes/graphql-doctrine.mjs +1 -1
  41. package/esm2020/lib/modules/search/classes/graphql-doctrine.types.mjs +1 -1
  42. package/esm2020/lib/modules/search/dropdown-container/dropdown-container.component.mjs +3 -3
  43. package/esm2020/lib/modules/search/facet-selector/facet-selector.component.mjs +4 -5
  44. package/esm2020/lib/modules/search/input/input.component.mjs +8 -7
  45. package/esm2020/lib/modules/search/search/search.component.mjs +7 -6
  46. package/esm2020/lib/modules/search/search.module.mjs +12 -8
  47. package/esm2020/lib/modules/search/types/facet.mjs +1 -1
  48. package/esm2020/lib/modules/select/abstract-select.component.mjs +2 -5
  49. package/esm2020/lib/modules/select/select/select.component.mjs +13 -17
  50. package/esm2020/lib/modules/select/select-enum/select-enum.component.mjs +4 -4
  51. package/esm2020/lib/modules/select/select-hierarchic/select-hierarchic.component.mjs +9 -11
  52. package/esm2020/lib/modules/select/select.module.mjs +14 -10
  53. package/esm2020/lib/modules/sidenav/sidenav.module.mjs +2 -2
  54. package/esm2020/lib/modules/stamp/stamp.component.mjs +3 -3
  55. package/esm2020/lib/modules/table-button/table-button.component.mjs +6 -5
  56. package/esm2020/lib/modules/table-button/table-button.module.mjs +6 -5
  57. package/fesm2015/ecodev-natural.mjs +320 -305
  58. package/fesm2015/ecodev-natural.mjs.map +1 -1
  59. package/fesm2020/ecodev-natural.mjs +322 -305
  60. package/fesm2020/ecodev-natural.mjs.map +1 -1
  61. package/lib/classes/abstract-editable-list.d.ts +2 -2
  62. package/lib/classes/abstract-list.d.ts +1 -1
  63. package/lib/modules/alert/alert.module.d.ts +4 -4
  64. package/lib/modules/alert/alert.service.d.ts +2 -2
  65. package/lib/modules/columns-picker/columns-picker.module.d.ts +6 -5
  66. package/lib/modules/common/common-module.d.ts +4 -4
  67. package/lib/modules/common/directives/linkable-tab.directive.d.ts +2 -2
  68. package/lib/modules/detail-header/detail-header.module.d.ts +3 -2
  69. package/lib/modules/dialog-trigger/dialog-trigger.component.d.ts +1 -1
  70. package/lib/modules/dialog-trigger/dialog-trigger.module.d.ts +2 -2
  71. package/lib/modules/dropdown-components/natural-dropdown-components.module.d.ts +7 -7
  72. package/lib/modules/dropdown-components/type-select/type-select.component.d.ts +1 -1
  73. package/lib/modules/file/file.module.d.ts +2 -1
  74. package/lib/modules/fixed-button/fixed-button.module.d.ts +4 -3
  75. package/lib/modules/fixed-button-detail/fixed-button-detail.module.d.ts +2 -2
  76. package/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.component.d.ts +1 -1
  77. package/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.service.d.ts +1 -1
  78. package/lib/modules/hierarchic-selector/hierarchic-selector.module.d.ts +8 -8
  79. package/lib/modules/icon/icon.directive.d.ts +43 -0
  80. package/lib/modules/icon/icon.module.d.ts +3 -3
  81. package/lib/modules/icon/public-api.d.ts +1 -1
  82. package/lib/modules/panels/panels.module.d.ts +2 -2
  83. package/lib/modules/panels/panels.service.d.ts +1 -1
  84. package/lib/modules/relations/relations.component.d.ts +1 -1
  85. package/lib/modules/relations/relations.module.d.ts +8 -7
  86. package/lib/modules/search/classes/graphql-doctrine.types.d.ts +23 -23
  87. package/lib/modules/search/search.module.d.ts +6 -5
  88. package/lib/modules/search/types/facet.d.ts +3 -3
  89. package/lib/modules/select/abstract-select.component.d.ts +1 -3
  90. package/lib/modules/select/select/select.component.d.ts +1 -6
  91. package/lib/modules/select/select-hierarchic/select-hierarchic.component.d.ts +0 -3
  92. package/lib/modules/select/select.module.d.ts +9 -8
  93. package/lib/modules/sidenav/sidenav.module.d.ts +2 -2
  94. package/lib/modules/table-button/table-button.module.d.ts +3 -2
  95. package/package.json +1 -1
  96. package/src/lib/_natural.theme.scss +34 -2
  97. package/src/lib/modules/alert/_alert.theme.scss +1 -1
  98. package/src/lib/modules/panels/_panels.external.scss +2 -3
  99. package/src/lib/modules/search/input/_input.theme.scss +2 -2
  100. package/src/lib/styles/_table.scss +4 -4
  101. package/theming/_natural.theme.scss +1 -1
  102. package/esm2020/lib/modules/icon/icon.component.mjs +0 -95
  103. package/lib/modules/icon/icon.component.d.ts +0 -41
  104. package/src/lib/modules/icon/_icon.theme.scss +0 -34
  105. package/src/lib/modules/table-button/_table-button.theme.scss +0 -22
@@ -6,19 +6,20 @@ import { FileComponent } from './component/file.component';
6
6
  import { NaturalIconModule } from '../icon/icon.module';
7
7
  import { MatRippleModule } from '@angular/material/core';
8
8
  import { NaturalCommonModule } from '../common/common-module';
9
+ import { MatIconModule } from '@angular/material/icon';
9
10
  import * as i0 from "@angular/core";
10
11
  const declarations = [NaturalFileDropDirective, NaturalFileSelectDirective, FileComponent];
11
12
  export class NaturalFileModule {
12
13
  }
13
14
  NaturalFileModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: NaturalFileModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
14
- NaturalFileModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.2", ngImport: i0, type: NaturalFileModule, declarations: [NaturalFileDropDirective, NaturalFileSelectDirective, FileComponent], imports: [CommonModule, NaturalIconModule, MatRippleModule, NaturalCommonModule], exports: [NaturalFileDropDirective, NaturalFileSelectDirective, FileComponent] });
15
- NaturalFileModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: NaturalFileModule, imports: [CommonModule, NaturalIconModule, MatRippleModule, NaturalCommonModule] });
15
+ NaturalFileModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.2", ngImport: i0, type: NaturalFileModule, declarations: [NaturalFileDropDirective, NaturalFileSelectDirective, FileComponent], imports: [CommonModule, NaturalIconModule, MatRippleModule, NaturalCommonModule, MatIconModule], exports: [NaturalFileDropDirective, NaturalFileSelectDirective, FileComponent] });
16
+ NaturalFileModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: NaturalFileModule, imports: [CommonModule, NaturalIconModule, MatRippleModule, NaturalCommonModule, MatIconModule] });
16
17
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: NaturalFileModule, decorators: [{
17
18
  type: NgModule,
18
19
  args: [{
19
- imports: [CommonModule, NaturalIconModule, MatRippleModule, NaturalCommonModule],
20
+ imports: [CommonModule, NaturalIconModule, MatRippleModule, NaturalCommonModule, MatIconModule],
20
21
  declarations: declarations,
21
22
  exports: declarations,
22
23
  }]
23
24
  }] });
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uYXR1cmFsL3NyYy9saWIvbW9kdWxlcy9maWxlL2ZpbGUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRXZDLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLHVCQUF1QixDQUFDO0FBQy9ELE9BQU8sRUFBQywwQkFBMEIsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ25FLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUN6RCxPQUFPLEVBQUMsaUJBQWlCLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUN0RCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0seUJBQXlCLENBQUM7O0FBRTVELE1BQU0sWUFBWSxHQUFHLENBQUMsd0JBQXdCLEVBQUUsMEJBQTBCLEVBQUUsYUFBYSxDQUFDLENBQUM7QUFPM0YsTUFBTSxPQUFPLGlCQUFpQjs7OEdBQWpCLGlCQUFpQjsrR0FBakIsaUJBQWlCLGlCQVBSLHdCQUF3QixFQUFFLDBCQUEwQixFQUFFLGFBQWEsYUFHM0UsWUFBWSxFQUFFLGlCQUFpQixFQUFFLGVBQWUsRUFBRSxtQkFBbUIsYUFIN0Qsd0JBQXdCLEVBQUUsMEJBQTBCLEVBQUUsYUFBYTsrR0FPNUUsaUJBQWlCLFlBSmhCLFlBQVksRUFBRSxpQkFBaUIsRUFBRSxlQUFlLEVBQUUsbUJBQW1COzJGQUl0RSxpQkFBaUI7a0JBTDdCLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLGlCQUFpQixFQUFFLGVBQWUsRUFBRSxtQkFBbUIsQ0FBQztvQkFDaEYsWUFBWSxFQUFFLFlBQVk7b0JBQzFCLE9BQU8sRUFBRSxZQUFZO2lCQUN4QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7TmF0dXJhbEZpbGVEcm9wRGlyZWN0aXZlfSBmcm9tICcuL2ZpbGUtZHJvcC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtOYXR1cmFsRmlsZVNlbGVjdERpcmVjdGl2ZX0gZnJvbSAnLi9maWxlLXNlbGVjdC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtGaWxlQ29tcG9uZW50fSBmcm9tICcuL2NvbXBvbmVudC9maWxlLmNvbXBvbmVudCc7XG5pbXBvcnQge05hdHVyYWxJY29uTW9kdWxlfSBmcm9tICcuLi9pY29uL2ljb24ubW9kdWxlJztcbmltcG9ydCB7TWF0UmlwcGxlTW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jb3JlJztcbmltcG9ydCB7TmF0dXJhbENvbW1vbk1vZHVsZX0gZnJvbSAnLi4vY29tbW9uL2NvbW1vbi1tb2R1bGUnO1xuXG5jb25zdCBkZWNsYXJhdGlvbnMgPSBbTmF0dXJhbEZpbGVEcm9wRGlyZWN0aXZlLCBOYXR1cmFsRmlsZVNlbGVjdERpcmVjdGl2ZSwgRmlsZUNvbXBvbmVudF07XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgTmF0dXJhbEljb25Nb2R1bGUsIE1hdFJpcHBsZU1vZHVsZSwgTmF0dXJhbENvbW1vbk1vZHVsZV0sXG4gICAgZGVjbGFyYXRpb25zOiBkZWNsYXJhdGlvbnMsXG4gICAgZXhwb3J0czogZGVjbGFyYXRpb25zLFxufSlcbmV4cG9ydCBjbGFzcyBOYXR1cmFsRmlsZU1vZHVsZSB7fVxuIl19
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uYXR1cmFsL3NyYy9saWIvbW9kdWxlcy9maWxlL2ZpbGUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRXZDLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLHVCQUF1QixDQUFDO0FBQy9ELE9BQU8sRUFBQywwQkFBMEIsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ25FLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUN6RCxPQUFPLEVBQUMsaUJBQWlCLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUN0RCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDNUQsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHdCQUF3QixDQUFDOztBQUVyRCxNQUFNLFlBQVksR0FBRyxDQUFDLHdCQUF3QixFQUFFLDBCQUEwQixFQUFFLGFBQWEsQ0FBQyxDQUFDO0FBTzNGLE1BQU0sT0FBTyxpQkFBaUI7OzhHQUFqQixpQkFBaUI7K0dBQWpCLGlCQUFpQixpQkFQUix3QkFBd0IsRUFBRSwwQkFBMEIsRUFBRSxhQUFhLGFBRzNFLFlBQVksRUFBRSxpQkFBaUIsRUFBRSxlQUFlLEVBQUUsbUJBQW1CLEVBQUUsYUFBYSxhQUg1RSx3QkFBd0IsRUFBRSwwQkFBMEIsRUFBRSxhQUFhOytHQU81RSxpQkFBaUIsWUFKaEIsWUFBWSxFQUFFLGlCQUFpQixFQUFFLGVBQWUsRUFBRSxtQkFBbUIsRUFBRSxhQUFhOzJGQUlyRixpQkFBaUI7a0JBTDdCLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLGlCQUFpQixFQUFFLGVBQWUsRUFBRSxtQkFBbUIsRUFBRSxhQUFhLENBQUM7b0JBQy9GLFlBQVksRUFBRSxZQUFZO29CQUMxQixPQUFPLEVBQUUsWUFBWTtpQkFDeEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQge05hdHVyYWxGaWxlRHJvcERpcmVjdGl2ZX0gZnJvbSAnLi9maWxlLWRyb3AuZGlyZWN0aXZlJztcbmltcG9ydCB7TmF0dXJhbEZpbGVTZWxlY3REaXJlY3RpdmV9IGZyb20gJy4vZmlsZS1zZWxlY3QuZGlyZWN0aXZlJztcbmltcG9ydCB7RmlsZUNvbXBvbmVudH0gZnJvbSAnLi9jb21wb25lbnQvZmlsZS5jb21wb25lbnQnO1xuaW1wb3J0IHtOYXR1cmFsSWNvbk1vZHVsZX0gZnJvbSAnLi4vaWNvbi9pY29uLm1vZHVsZSc7XG5pbXBvcnQge01hdFJpcHBsZU1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XG5pbXBvcnQge05hdHVyYWxDb21tb25Nb2R1bGV9IGZyb20gJy4uL2NvbW1vbi9jb21tb24tbW9kdWxlJztcbmltcG9ydCB7TWF0SWNvbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5cbmNvbnN0IGRlY2xhcmF0aW9ucyA9IFtOYXR1cmFsRmlsZURyb3BEaXJlY3RpdmUsIE5hdHVyYWxGaWxlU2VsZWN0RGlyZWN0aXZlLCBGaWxlQ29tcG9uZW50XTtcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBOYXR1cmFsSWNvbk1vZHVsZSwgTWF0UmlwcGxlTW9kdWxlLCBOYXR1cmFsQ29tbW9uTW9kdWxlLCBNYXRJY29uTW9kdWxlXSxcbiAgICBkZWNsYXJhdGlvbnM6IGRlY2xhcmF0aW9ucyxcbiAgICBleHBvcnRzOiBkZWNsYXJhdGlvbnMsXG59KVxuZXhwb3J0IGNsYXNzIE5hdHVyYWxGaWxlTW9kdWxlIHt9XG4iXX0=
@@ -70,16 +70,27 @@ function createFileInput(document) {
70
70
  return fileElem;
71
71
  }
72
72
  export function isDirectory(file) {
73
- return file
74
- .slice(0, 1)
75
- .text()
76
- .then(text => {
73
+ return blobText(file.slice(0, 1)).then(text => {
77
74
  // Firefox will return empty string for a folder, so we must check that special case.
78
75
  // That means that any empty file will incorrectly be interpreted as a folder on all
79
76
  // browsers, but that's tolerable because there is no real use-case to upload an empty file.
80
77
  return text !== '';
81
78
  }, () => false);
82
79
  }
80
+ /**
81
+ * This is a ponyfill for `Blob.text()`, because Safari 13 and 14 do not support it, https://caniuse.com/?search=blob.text,
82
+ * and we try our best not to break iPhone users too much.
83
+ */
84
+ function blobText(blob) {
85
+ return new Promise((resolve, reject) => {
86
+ const reader = new FileReader();
87
+ reader.onload = () => {
88
+ resolve(reader.result);
89
+ };
90
+ reader.onerror = reject;
91
+ reader.readAsText(blob);
92
+ });
93
+ }
83
94
  export function stopEvent(event) {
84
95
  event.preventDefault();
85
96
  event.stopPropagation();
@@ -115,4 +126,4 @@ export function eventToFiles(event) {
115
126
  }
116
127
  return [];
117
128
  }
118
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../../projects/natural/src/lib/modules/file/utils.ts"],"names":[],"mappings":"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","sourcesContent":["export function acceptType(accept: string, type: string, filename: string): boolean {\n    if (!accept.trim()) {\n        return true;\n    }\n\n    type = type.toLowerCase();\n    filename = filename.toLowerCase();\n\n    return accept.split(',').some(mimeOrExtension => {\n        mimeOrExtension = mimeOrExtension.trim().toLowerCase();\n        if (mimeOrExtension.startsWith('.')) {\n            return filename.endsWith(mimeOrExtension);\n        } else {\n            // Transform `*` into `.*`\n            const pattern = mimeOrExtension.replace(/\\*/g, '.*');\n\n            return type.match(pattern);\n        }\n    });\n}\n\nexport function isFileInput(elm: HTMLElement): elm is HTMLInputElement {\n    const type = elm.getAttribute('type');\n\n    return elm.tagName.toLowerCase() === 'input' && !!type && type.toLowerCase() === 'file';\n}\n\nlet initialTouchStartY = 0;\nlet initialTouchStartX = 0;\n\nexport function detectSwipe(event: Event | TouchEvent): boolean {\n    const touches = 'changedTouches' in event ? event.changedTouches : null;\n    if (!touches) {\n        return false;\n    }\n\n    if (event.type === 'touchstart') {\n        initialTouchStartX = touches[0].clientX;\n        initialTouchStartY = touches[0].clientY;\n\n        return true; // don't block event default\n    } else {\n        // prevent scroll from triggering event\n        if (event.type === 'touchend') {\n            const currentX = touches[0].clientX;\n            const currentY = touches[0].clientY;\n            if (Math.abs(currentX - initialTouchStartX) > 20 || Math.abs(currentY - initialTouchStartY) > 20) {\n                event.stopPropagation();\n                if (event.cancelable) {\n                    event.preventDefault();\n                }\n\n                return false;\n            }\n        }\n\n        return true;\n    }\n}\n\nexport function createInvisibleFileInputWrap(document: Document): HTMLLabelElement {\n    const fileElem = createFileInput(document);\n    const label = document.createElement('label');\n    label.innerHTML = 'upload';\n    label.style.visibility = 'hidden';\n    label.style.position = 'absolute';\n    label.style.overflow = 'hidden';\n    label.style.width = '0px';\n    label.style.height = '0px';\n    label.style.border = 'none';\n    label.style.margin = '0px';\n    label.style.padding = '0px';\n    label.setAttribute('tabindex', '-1');\n\n    label.appendChild(fileElem);\n\n    return label;\n}\n\nfunction createFileInput(document: Document): HTMLInputElement {\n    const fileElem = document.createElement('input');\n    fileElem.type = 'file';\n\n    return fileElem;\n}\n\nexport function isDirectory(file: File): Promise<boolean> {\n    return file\n        .slice(0, 1)\n        .text()\n        .then(\n            text => {\n                // Firefox will return empty string for a folder, so we must check that special case.\n                // That means that any empty file will incorrectly be interpreted as a folder on all\n                // browsers, but that's tolerable because there is no real use-case to upload an empty file.\n                return text !== '';\n            },\n            () => false,\n        );\n}\n\nexport function stopEvent(event: Event): void {\n    event.preventDefault();\n    event.stopPropagation();\n}\n\nexport function fileListToArray(fileList: FileList): File[] {\n    const result: File[] = [];\n    for (let i = 0; i < fileList.length; i++) {\n        const file = fileList.item(i);\n        if (file) {\n            result.push(file);\n        }\n    }\n\n    return result;\n}\n\nfunction dataTransferItemListToArray(items: DataTransferItemList): File[] {\n    const result: File[] = [];\n\n    // eslint-disable-next-line @typescript-eslint/prefer-for-of\n    for (let i = 0; i < items.length; i++) {\n        const file = items[i].getAsFile();\n        if (file) {\n            result.push(file);\n        }\n    }\n\n    return result;\n}\n\nexport function eventToFiles(event: Event | DragEvent): File[] {\n    const transfer = 'dataTransfer' in event ? event.dataTransfer : null;\n    if (transfer?.files?.length) {\n        return fileListToArray(transfer.files);\n    }\n\n    if (transfer) {\n        return dataTransferItemListToArray(transfer.items);\n    }\n\n    return [];\n}\n"]}
129
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../../projects/natural/src/lib/modules/file/utils.ts"],"names":[],"mappings":"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","sourcesContent":["export function acceptType(accept: string, type: string, filename: string): boolean {\n    if (!accept.trim()) {\n        return true;\n    }\n\n    type = type.toLowerCase();\n    filename = filename.toLowerCase();\n\n    return accept.split(',').some(mimeOrExtension => {\n        mimeOrExtension = mimeOrExtension.trim().toLowerCase();\n        if (mimeOrExtension.startsWith('.')) {\n            return filename.endsWith(mimeOrExtension);\n        } else {\n            // Transform `*` into `.*`\n            const pattern = mimeOrExtension.replace(/\\*/g, '.*');\n\n            return type.match(pattern);\n        }\n    });\n}\n\nexport function isFileInput(elm: HTMLElement): elm is HTMLInputElement {\n    const type = elm.getAttribute('type');\n\n    return elm.tagName.toLowerCase() === 'input' && !!type && type.toLowerCase() === 'file';\n}\n\nlet initialTouchStartY = 0;\nlet initialTouchStartX = 0;\n\nexport function detectSwipe(event: Event | TouchEvent): boolean {\n    const touches = 'changedTouches' in event ? event.changedTouches : null;\n    if (!touches) {\n        return false;\n    }\n\n    if (event.type === 'touchstart') {\n        initialTouchStartX = touches[0].clientX;\n        initialTouchStartY = touches[0].clientY;\n\n        return true; // don't block event default\n    } else {\n        // prevent scroll from triggering event\n        if (event.type === 'touchend') {\n            const currentX = touches[0].clientX;\n            const currentY = touches[0].clientY;\n            if (Math.abs(currentX - initialTouchStartX) > 20 || Math.abs(currentY - initialTouchStartY) > 20) {\n                event.stopPropagation();\n                if (event.cancelable) {\n                    event.preventDefault();\n                }\n\n                return false;\n            }\n        }\n\n        return true;\n    }\n}\n\nexport function createInvisibleFileInputWrap(document: Document): HTMLLabelElement {\n    const fileElem = createFileInput(document);\n    const label = document.createElement('label');\n    label.innerHTML = 'upload';\n    label.style.visibility = 'hidden';\n    label.style.position = 'absolute';\n    label.style.overflow = 'hidden';\n    label.style.width = '0px';\n    label.style.height = '0px';\n    label.style.border = 'none';\n    label.style.margin = '0px';\n    label.style.padding = '0px';\n    label.setAttribute('tabindex', '-1');\n\n    label.appendChild(fileElem);\n\n    return label;\n}\n\nfunction createFileInput(document: Document): HTMLInputElement {\n    const fileElem = document.createElement('input');\n    fileElem.type = 'file';\n\n    return fileElem;\n}\n\nexport function isDirectory(file: File): Promise<boolean> {\n    return blobText(file.slice(0, 1)).then(\n        text => {\n            // Firefox will return empty string for a folder, so we must check that special case.\n            // That means that any empty file will incorrectly be interpreted as a folder on all\n            // browsers, but that's tolerable because there is no real use-case to upload an empty file.\n            return text !== '';\n        },\n        () => false,\n    );\n}\n\n/**\n * This is a ponyfill for `Blob.text()`, because Safari 13 and 14 do not support it, https://caniuse.com/?search=blob.text,\n * and we try our best not to break iPhone users too much.\n */\nfunction blobText(blob: Blob): Promise<string> {\n    return new Promise((resolve, reject) => {\n        const reader = new FileReader();\n        reader.onload = () => {\n            resolve(reader.result as string);\n        };\n        reader.onerror = reject;\n        reader.readAsText(blob);\n    });\n}\n\nexport function stopEvent(event: Event): void {\n    event.preventDefault();\n    event.stopPropagation();\n}\n\nexport function fileListToArray(fileList: FileList): File[] {\n    const result: File[] = [];\n    for (let i = 0; i < fileList.length; i++) {\n        const file = fileList.item(i);\n        if (file) {\n            result.push(file);\n        }\n    }\n\n    return result;\n}\n\nfunction dataTransferItemListToArray(items: DataTransferItemList): File[] {\n    const result: File[] = [];\n\n    // eslint-disable-next-line @typescript-eslint/prefer-for-of\n    for (let i = 0; i < items.length; i++) {\n        const file = items[i].getAsFile();\n        if (file) {\n            result.push(file);\n        }\n    }\n\n    return result;\n}\n\nexport function eventToFiles(event: Event | DragEvent): File[] {\n    const transfer = 'dataTransfer' in event ? event.dataTransfer : null;\n    if (transfer?.files?.length) {\n        return fileListToArray(transfer.files);\n    }\n\n    if (transfer) {\n        return dataTransferItemListToArray(transfer.items);\n    }\n\n    return [];\n}\n"]}
@@ -1,8 +1,9 @@
1
1
  import { Component, Input } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  import * as i1 from "@angular/router";
4
- import * as i2 from "@angular/material/legacy-button";
5
- import * as i3 from "../icon/icon.component";
4
+ import * as i2 from "@angular/material/button";
5
+ import * as i3 from "@angular/material/icon";
6
+ import * as i4 from "../icon/icon.directive";
6
7
  export class NaturalFixedButtonComponent {
7
8
  constructor() {
8
9
  this.link = [];
@@ -11,10 +12,10 @@ export class NaturalFixedButtonComponent {
11
12
  }
12
13
  }
13
14
  NaturalFixedButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: NaturalFixedButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
14
- NaturalFixedButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.2", type: NaturalFixedButtonComponent, selector: "natural-fixed-button", inputs: { icon: "icon", link: "link", color: "color", disabled: "disabled" }, ngImport: i0, template: "<button\n [color]=\"color\"\n [disabled]=\"disabled\"\n [routerLink]=\"link\"\n class=\"floating-button bottom-right\"\n mat-fab\n mat-raised-button\n>\n <natural-icon [name]=\"icon\"></natural-icon>\n</button>\n", styles: [":host{position:fixed!important;z-index:999;bottom:32px;right:32px}\n"], dependencies: [{ kind: "directive", type: i1.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i2.MatLegacyButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i3.NaturalIconComponent, selector: "natural-icon", inputs: ["label", "labelColor", "labelPosition", "name", "size"] }] });
15
+ NaturalFixedButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.2", type: NaturalFixedButtonComponent, selector: "natural-fixed-button", inputs: { icon: "icon", link: "link", color: "color", disabled: "disabled" }, ngImport: i0, template: "<button [color]=\"color\" [disabled]=\"disabled\" [routerLink]=\"link\" mat-fab>\n <mat-icon [naturalIcon]=\"icon\"></mat-icon>\n</button>\n", styles: [":host{position:fixed!important;z-index:999;bottom:32px;right:32px}\n"], dependencies: [{ kind: "directive", type: i1.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "component", type: i2.MatFabButton, selector: "button[mat-fab]", inputs: ["disabled", "disableRipple", "color", "tabIndex", "extended"], exportAs: ["matButton"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i4.NaturalIconDirective, selector: "mat-icon[naturalIcon]", inputs: ["naturalIcon", "size"] }] });
15
16
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: NaturalFixedButtonComponent, decorators: [{
16
17
  type: Component,
17
- args: [{ selector: 'natural-fixed-button', template: "<button\n [color]=\"color\"\n [disabled]=\"disabled\"\n [routerLink]=\"link\"\n class=\"floating-button bottom-right\"\n mat-fab\n mat-raised-button\n>\n <natural-icon [name]=\"icon\"></natural-icon>\n</button>\n", styles: [":host{position:fixed!important;z-index:999;bottom:32px;right:32px}\n"] }]
18
+ args: [{ selector: 'natural-fixed-button', template: "<button [color]=\"color\" [disabled]=\"disabled\" [routerLink]=\"link\" mat-fab>\n <mat-icon [naturalIcon]=\"icon\"></mat-icon>\n</button>\n", styles: [":host{position:fixed!important;z-index:999;bottom:32px;right:32px}\n"] }]
18
19
  }], propDecorators: { icon: [{
19
20
  type: Input
20
21
  }], link: [{
@@ -24,4 +25,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.2", ngImpor
24
25
  }], disabled: [{
25
26
  type: Input
26
27
  }] } });
27
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZml4ZWQtYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL2ZpeGVkLWJ1dHRvbi9maXhlZC1idXR0b24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvZml4ZWQtYnV0dG9uL2ZpeGVkLWJ1dHRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLEtBQUssRUFBQyxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFTL0MsTUFBTSxPQUFPLDJCQUEyQjtJQUx4QztRQU9vQixTQUFJLEdBQTZCLEVBQUUsQ0FBQztRQUNwQyxVQUFLLEdBQWlCLFFBQVEsQ0FBQztRQUMvQixhQUFRLEdBQUcsS0FBSyxDQUFDO0tBQ3BDOzt3SEFMWSwyQkFBMkI7NEdBQTNCLDJCQUEyQiwwSUNUeEMsMk9BVUE7MkZERGEsMkJBQTJCO2tCQUx2QyxTQUFTOytCQUNJLHNCQUFzQjs4QkFLaEIsSUFBSTtzQkFBbkIsS0FBSztnQkFDVSxJQUFJO3NCQUFuQixLQUFLO2dCQUNVLEtBQUs7c0JBQXBCLEtBQUs7Z0JBQ1UsUUFBUTtzQkFBdkIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBJbnB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1RoZW1lUGFsZXR0ZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XG5pbXBvcnQge1JvdXRlckxpbmt9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnbmF0dXJhbC1maXhlZC1idXR0b24nLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9maXhlZC1idXR0b24uY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2ZpeGVkLWJ1dHRvbi5jb21wb25lbnQuc2NzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBOYXR1cmFsRml4ZWRCdXR0b25Db21wb25lbnQge1xuICAgIEBJbnB1dCgpIHB1YmxpYyBpY29uITogc3RyaW5nO1xuICAgIEBJbnB1dCgpIHB1YmxpYyBsaW5rOiBSb3V0ZXJMaW5rWydyb3V0ZXJMaW5rJ10gPSBbXTtcbiAgICBASW5wdXQoKSBwdWJsaWMgY29sb3I6IFRoZW1lUGFsZXR0ZSA9ICdhY2NlbnQnO1xuICAgIEBJbnB1dCgpIHB1YmxpYyBkaXNhYmxlZCA9IGZhbHNlO1xufVxuIiwiPGJ1dHRvblxuICAgIFtjb2xvcl09XCJjb2xvclwiXG4gICAgW2Rpc2FibGVkXT1cImRpc2FibGVkXCJcbiAgICBbcm91dGVyTGlua109XCJsaW5rXCJcbiAgICBjbGFzcz1cImZsb2F0aW5nLWJ1dHRvbiBib3R0b20tcmlnaHRcIlxuICAgIG1hdC1mYWJcbiAgICBtYXQtcmFpc2VkLWJ1dHRvblxuPlxuICAgIDxuYXR1cmFsLWljb24gW25hbWVdPVwiaWNvblwiPjwvbmF0dXJhbC1pY29uPlxuPC9idXR0b24+XG4iXX0=
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZml4ZWQtYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL2ZpeGVkLWJ1dHRvbi9maXhlZC1idXR0b24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvZml4ZWQtYnV0dG9uL2ZpeGVkLWJ1dHRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLEtBQUssRUFBQyxNQUFNLGVBQWUsQ0FBQzs7Ozs7O0FBUy9DLE1BQU0sT0FBTywyQkFBMkI7SUFMeEM7UUFPb0IsU0FBSSxHQUE2QixFQUFFLENBQUM7UUFDcEMsVUFBSyxHQUFpQixRQUFRLENBQUM7UUFDL0IsYUFBUSxHQUFHLEtBQUssQ0FBQztLQUNwQzs7d0hBTFksMkJBQTJCOzRHQUEzQiwyQkFBMkIsMElDVHhDLGlKQUdBOzJGRE1hLDJCQUEyQjtrQkFMdkMsU0FBUzsrQkFDSSxzQkFBc0I7OEJBS2hCLElBQUk7c0JBQW5CLEtBQUs7Z0JBQ1UsSUFBSTtzQkFBbkIsS0FBSztnQkFDVSxLQUFLO3NCQUFwQixLQUFLO2dCQUNVLFFBQVE7c0JBQXZCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgSW5wdXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtUaGVtZVBhbGV0dGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xuaW1wb3J0IHtSb3V0ZXJMaW5rfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ25hdHVyYWwtZml4ZWQtYnV0dG9uJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZml4ZWQtYnV0dG9uLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9maXhlZC1idXR0b24uY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgTmF0dXJhbEZpeGVkQnV0dG9uQ29tcG9uZW50IHtcbiAgICBASW5wdXQoKSBwdWJsaWMgaWNvbiE6IHN0cmluZztcbiAgICBASW5wdXQoKSBwdWJsaWMgbGluazogUm91dGVyTGlua1sncm91dGVyTGluayddID0gW107XG4gICAgQElucHV0KCkgcHVibGljIGNvbG9yOiBUaGVtZVBhbGV0dGUgPSAnYWNjZW50JztcbiAgICBASW5wdXQoKSBwdWJsaWMgZGlzYWJsZWQgPSBmYWxzZTtcbn1cbiIsIjxidXR0b24gW2NvbG9yXT1cImNvbG9yXCIgW2Rpc2FibGVkXT1cImRpc2FibGVkXCIgW3JvdXRlckxpbmtdPVwibGlua1wiIG1hdC1mYWI+XG4gICAgPG1hdC1pY29uIFtuYXR1cmFsSWNvbl09XCJpY29uXCI+PC9tYXQtaWNvbj5cbjwvYnV0dG9uPlxuIl19
@@ -1,21 +1,22 @@
1
1
  import { CommonModule } from '@angular/common';
2
2
  import { NgModule } from '@angular/core';
3
- import { MatLegacyButtonModule as MatButtonModule } from '@angular/material/legacy-button';
3
+ import { MatButtonModule } from '@angular/material/button';
4
4
  import { RouterModule } from '@angular/router';
5
5
  import { NaturalIconModule } from '../icon/icon.module';
6
6
  import { NaturalFixedButtonComponent } from './fixed-button.component';
7
+ import { MatIconModule } from '@angular/material/icon';
7
8
  import * as i0 from "@angular/core";
8
9
  export class NaturalFixedButtonModule {
9
10
  }
10
11
  NaturalFixedButtonModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: NaturalFixedButtonModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
11
- NaturalFixedButtonModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.2", ngImport: i0, type: NaturalFixedButtonModule, declarations: [NaturalFixedButtonComponent], imports: [CommonModule, RouterModule, MatButtonModule, NaturalIconModule], exports: [NaturalFixedButtonComponent] });
12
- NaturalFixedButtonModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: NaturalFixedButtonModule, imports: [CommonModule, RouterModule, MatButtonModule, NaturalIconModule] });
12
+ NaturalFixedButtonModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.2", ngImport: i0, type: NaturalFixedButtonModule, declarations: [NaturalFixedButtonComponent], imports: [CommonModule, RouterModule, MatButtonModule, MatIconModule, NaturalIconModule], exports: [NaturalFixedButtonComponent] });
13
+ NaturalFixedButtonModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: NaturalFixedButtonModule, imports: [CommonModule, RouterModule, MatButtonModule, MatIconModule, NaturalIconModule] });
13
14
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: NaturalFixedButtonModule, decorators: [{
14
15
  type: NgModule,
15
16
  args: [{
16
17
  declarations: [NaturalFixedButtonComponent],
17
- imports: [CommonModule, RouterModule, MatButtonModule, NaturalIconModule],
18
+ imports: [CommonModule, RouterModule, MatButtonModule, MatIconModule, NaturalIconModule],
18
19
  exports: [NaturalFixedButtonComponent],
19
20
  }]
20
21
  }] });
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZml4ZWQtYnV0dG9uLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL2ZpeGVkLWJ1dHRvbi9maXhlZC1idXR0b24ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxxQkFBcUIsSUFBSSxlQUFlLEVBQUMsTUFBTSxpQ0FBaUMsQ0FBQztBQUN6RixPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFDdEQsT0FBTyxFQUFDLDJCQUEyQixFQUFDLE1BQU0sMEJBQTBCLENBQUM7O0FBT3JFLE1BQU0sT0FBTyx3QkFBd0I7O3FIQUF4Qix3QkFBd0I7c0hBQXhCLHdCQUF3QixpQkFKbEIsMkJBQTJCLGFBQ2hDLFlBQVksRUFBRSxZQUFZLEVBQUUsZUFBZSxFQUFFLGlCQUFpQixhQUM5RCwyQkFBMkI7c0hBRTVCLHdCQUF3QixZQUh2QixZQUFZLEVBQUUsWUFBWSxFQUFFLGVBQWUsRUFBRSxpQkFBaUI7MkZBRy9ELHdCQUF3QjtrQkFMcEMsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsQ0FBQywyQkFBMkIsQ0FBQztvQkFDM0MsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFlBQVksRUFBRSxlQUFlLEVBQUUsaUJBQWlCLENBQUM7b0JBQ3pFLE9BQU8sRUFBRSxDQUFDLDJCQUEyQixDQUFDO2lCQUN6QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge01hdExlZ2FjeUJ1dHRvbk1vZHVsZSBhcyBNYXRCdXR0b25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2xlZ2FjeS1idXR0b24nO1xuaW1wb3J0IHtSb3V0ZXJNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQge05hdHVyYWxJY29uTW9kdWxlfSBmcm9tICcuLi9pY29uL2ljb24ubW9kdWxlJztcbmltcG9ydCB7TmF0dXJhbEZpeGVkQnV0dG9uQ29tcG9uZW50fSBmcm9tICcuL2ZpeGVkLWJ1dHRvbi5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICAgIGRlY2xhcmF0aW9uczogW05hdHVyYWxGaXhlZEJ1dHRvbkNvbXBvbmVudF0sXG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgUm91dGVyTW9kdWxlLCBNYXRCdXR0b25Nb2R1bGUsIE5hdHVyYWxJY29uTW9kdWxlXSxcbiAgICBleHBvcnRzOiBbTmF0dXJhbEZpeGVkQnV0dG9uQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgTmF0dXJhbEZpeGVkQnV0dG9uTW9kdWxlIHt9XG4iXX0=
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZml4ZWQtYnV0dG9uLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL2ZpeGVkLWJ1dHRvbi9maXhlZC1idXR0b24ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUN6RCxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFDdEQsT0FBTyxFQUFDLDJCQUEyQixFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDckUsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHdCQUF3QixDQUFDOztBQU9yRCxNQUFNLE9BQU8sd0JBQXdCOztxSEFBeEIsd0JBQXdCO3NIQUF4Qix3QkFBd0IsaUJBSmxCLDJCQUEyQixhQUNoQyxZQUFZLEVBQUUsWUFBWSxFQUFFLGVBQWUsRUFBRSxhQUFhLEVBQUUsaUJBQWlCLGFBQzdFLDJCQUEyQjtzSEFFNUIsd0JBQXdCLFlBSHZCLFlBQVksRUFBRSxZQUFZLEVBQUUsZUFBZSxFQUFFLGFBQWEsRUFBRSxpQkFBaUI7MkZBRzlFLHdCQUF3QjtrQkFMcEMsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsQ0FBQywyQkFBMkIsQ0FBQztvQkFDM0MsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFlBQVksRUFBRSxlQUFlLEVBQUUsYUFBYSxFQUFFLGlCQUFpQixDQUFDO29CQUN4RixPQUFPLEVBQUUsQ0FBQywyQkFBMkIsQ0FBQztpQkFDekMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtNYXRCdXR0b25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQge1JvdXRlck1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7TmF0dXJhbEljb25Nb2R1bGV9IGZyb20gJy4uL2ljb24vaWNvbi5tb2R1bGUnO1xuaW1wb3J0IHtOYXR1cmFsRml4ZWRCdXR0b25Db21wb25lbnR9IGZyb20gJy4vZml4ZWQtYnV0dG9uLmNvbXBvbmVudCc7XG5pbXBvcnQge01hdEljb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xuXG5ATmdNb2R1bGUoe1xuICAgIGRlY2xhcmF0aW9uczogW05hdHVyYWxGaXhlZEJ1dHRvbkNvbXBvbmVudF0sXG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgUm91dGVyTW9kdWxlLCBNYXRCdXR0b25Nb2R1bGUsIE1hdEljb25Nb2R1bGUsIE5hdHVyYWxJY29uTW9kdWxlXSxcbiAgICBleHBvcnRzOiBbTmF0dXJhbEZpeGVkQnV0dG9uQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgTmF0dXJhbEZpeGVkQnV0dG9uTW9kdWxlIHt9XG4iXX0=
@@ -5,7 +5,7 @@ import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/router";
6
6
  import * as i2 from "@angular/common";
7
7
  import * as i3 from "../fixed-button/fixed-button.component";
8
- import * as i4 from "@angular/material/legacy-tooltip";
8
+ import * as i4 from "@angular/material/tooltip";
9
9
  export class NaturalFixedButtonDetailComponent extends NaturalAbstractController {
10
10
  get model() {
11
11
  return this._model;
@@ -37,7 +37,7 @@ export class NaturalFixedButtonDetailComponent extends NaturalAbstractController
37
37
  }
38
38
  }
39
39
  NaturalFixedButtonDetailComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: NaturalFixedButtonDetailComponent, deps: [{ token: i1.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Component });
40
- NaturalFixedButtonDetailComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.2", type: NaturalFixedButtonDetailComponent, selector: "natural-fixed-button-detail", inputs: { model: "model", form: "form" }, outputs: { create: "create", delete: "delete" }, usesInheritance: true, ngImport: i0, template: "<natural-fixed-button\n (click)=\"clickCreate()\"\n *ngIf=\"isCreation\"\n [disabled]=\"form.disabled\"\n [color]=\"form.valid ? 'accent' : 'warn'\"\n class=\"detail-speed-dial\"\n icon=\"save\"\n></natural-fixed-button>\n\n<natural-fixed-button\n (click)=\"clickDelete()\"\n *ngIf=\"!isCreation && (!model.permissions || model.permissions.delete)\"\n [disabled]=\"form.disabled\"\n class=\"detail-speed-dial\"\n color=\"warn\"\n icon=\"delete_forever\"\n i18n-matTooltip\n matTooltip=\"Supprimer d\u00E9finitivement\"\n matTooltipPosition=\"left\"\n></natural-fixed-button>\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.NaturalFixedButtonComponent, selector: "natural-fixed-button", inputs: ["icon", "link", "color", "disabled"] }, { kind: "directive", type: i4.MatLegacyTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] });
40
+ NaturalFixedButtonDetailComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.2", type: NaturalFixedButtonDetailComponent, selector: "natural-fixed-button-detail", inputs: { model: "model", form: "form" }, outputs: { create: "create", delete: "delete" }, usesInheritance: true, ngImport: i0, template: "<natural-fixed-button\n (click)=\"clickCreate()\"\n *ngIf=\"isCreation\"\n [disabled]=\"form.disabled\"\n [color]=\"form.valid ? 'accent' : 'warn'\"\n class=\"detail-speed-dial\"\n icon=\"save\"\n></natural-fixed-button>\n\n<natural-fixed-button\n (click)=\"clickDelete()\"\n *ngIf=\"!isCreation && (!model.permissions || model.permissions.delete)\"\n [disabled]=\"form.disabled\"\n class=\"detail-speed-dial\"\n color=\"warn\"\n icon=\"delete_forever\"\n i18n-matTooltip\n matTooltip=\"Supprimer d\u00E9finitivement\"\n matTooltipPosition=\"left\"\n></natural-fixed-button>\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.NaturalFixedButtonComponent, selector: "natural-fixed-button", inputs: ["icon", "link", "color", "disabled"] }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] });
41
41
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: NaturalFixedButtonDetailComponent, decorators: [{
42
42
  type: Component,
43
43
  args: [{ selector: 'natural-fixed-button-detail', template: "<natural-fixed-button\n (click)=\"clickCreate()\"\n *ngIf=\"isCreation\"\n [disabled]=\"form.disabled\"\n [color]=\"form.valid ? 'accent' : 'warn'\"\n class=\"detail-speed-dial\"\n icon=\"save\"\n></natural-fixed-button>\n\n<natural-fixed-button\n (click)=\"clickDelete()\"\n *ngIf=\"!isCreation && (!model.permissions || model.permissions.delete)\"\n [disabled]=\"form.disabled\"\n class=\"detail-speed-dial\"\n color=\"warn\"\n icon=\"delete_forever\"\n i18n-matTooltip\n matTooltip=\"Supprimer d\u00E9finitivement\"\n matTooltipPosition=\"left\"\n></natural-fixed-button>\n" }]
@@ -2,7 +2,7 @@ import { CommonModule } from '@angular/common';
2
2
  import { NgModule } from '@angular/core';
3
3
  import { NaturalFixedButtonModule } from '../fixed-button/fixed-button.module';
4
4
  import { NaturalFixedButtonDetailComponent } from './fixed-button-detail.component';
5
- import { MatLegacyTooltipModule as MatTooltipModule } from '@angular/material/legacy-tooltip';
5
+ import { MatTooltipModule } from '@angular/material/tooltip';
6
6
  import * as i0 from "@angular/core";
7
7
  export class NaturalFixedButtonDetailModule {
8
8
  }
@@ -17,4 +17,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.2", ngImpor
17
17
  exports: [NaturalFixedButtonDetailComponent],
18
18
  }]
19
19
  }] });
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZml4ZWQtYnV0dG9uLWRldGFpbC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uYXR1cmFsL3NyYy9saWIvbW9kdWxlcy9maXhlZC1idXR0b24tZGV0YWlsL2ZpeGVkLWJ1dHRvbi1kZXRhaWwubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQzdFLE9BQU8sRUFBQyxpQ0FBaUMsRUFBQyxNQUFNLGlDQUFpQyxDQUFDO0FBQ2xGLE9BQU8sRUFBQyxzQkFBc0IsSUFBSSxnQkFBZ0IsRUFBQyxNQUFNLGtDQUFrQyxDQUFDOztBQU81RixNQUFNLE9BQU8sOEJBQThCOzsySEFBOUIsOEJBQThCOzRIQUE5Qiw4QkFBOEIsaUJBSnhCLGlDQUFpQyxhQUN0QyxZQUFZLEVBQUUsd0JBQXdCLEVBQUUsZ0JBQWdCLGFBQ3hELGlDQUFpQzs0SEFFbEMsOEJBQThCLFlBSDdCLFlBQVksRUFBRSx3QkFBd0IsRUFBRSxnQkFBZ0I7MkZBR3pELDhCQUE4QjtrQkFMMUMsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsQ0FBQyxpQ0FBaUMsQ0FBQztvQkFDakQsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLHdCQUF3QixFQUFFLGdCQUFnQixDQUFDO29CQUNuRSxPQUFPLEVBQUUsQ0FBQyxpQ0FBaUMsQ0FBQztpQkFDL0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtOYXR1cmFsRml4ZWRCdXR0b25Nb2R1bGV9IGZyb20gJy4uL2ZpeGVkLWJ1dHRvbi9maXhlZC1idXR0b24ubW9kdWxlJztcbmltcG9ydCB7TmF0dXJhbEZpeGVkQnV0dG9uRGV0YWlsQ29tcG9uZW50fSBmcm9tICcuL2ZpeGVkLWJ1dHRvbi1kZXRhaWwuY29tcG9uZW50JztcbmltcG9ydCB7TWF0TGVnYWN5VG9vbHRpcE1vZHVsZSBhcyBNYXRUb29sdGlwTW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9sZWdhY3ktdG9vbHRpcCc7XG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbTmF0dXJhbEZpeGVkQnV0dG9uRGV0YWlsQ29tcG9uZW50XSxcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBOYXR1cmFsRml4ZWRCdXR0b25Nb2R1bGUsIE1hdFRvb2x0aXBNb2R1bGVdLFxuICAgIGV4cG9ydHM6IFtOYXR1cmFsRml4ZWRCdXR0b25EZXRhaWxDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBOYXR1cmFsRml4ZWRCdXR0b25EZXRhaWxNb2R1bGUge31cbiJdfQ==
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZml4ZWQtYnV0dG9uLWRldGFpbC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uYXR1cmFsL3NyYy9saWIvbW9kdWxlcy9maXhlZC1idXR0b24tZGV0YWlsL2ZpeGVkLWJ1dHRvbi1kZXRhaWwubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBQzdFLE9BQU8sRUFBQyxpQ0FBaUMsRUFBQyxNQUFNLGlDQUFpQyxDQUFDO0FBQ2xGLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLDJCQUEyQixDQUFDOztBQU8zRCxNQUFNLE9BQU8sOEJBQThCOzsySEFBOUIsOEJBQThCOzRIQUE5Qiw4QkFBOEIsaUJBSnhCLGlDQUFpQyxhQUN0QyxZQUFZLEVBQUUsd0JBQXdCLEVBQUUsZ0JBQWdCLGFBQ3hELGlDQUFpQzs0SEFFbEMsOEJBQThCLFlBSDdCLFlBQVksRUFBRSx3QkFBd0IsRUFBRSxnQkFBZ0I7MkZBR3pELDhCQUE4QjtrQkFMMUMsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsQ0FBQyxpQ0FBaUMsQ0FBQztvQkFDakQsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLHdCQUF3QixFQUFFLGdCQUFnQixDQUFDO29CQUNuRSxPQUFPLEVBQUUsQ0FBQyxpQ0FBaUMsQ0FBQztpQkFDL0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtOYXR1cmFsRml4ZWRCdXR0b25Nb2R1bGV9IGZyb20gJy4uL2ZpeGVkLWJ1dHRvbi9maXhlZC1idXR0b24ubW9kdWxlJztcbmltcG9ydCB7TmF0dXJhbEZpeGVkQnV0dG9uRGV0YWlsQ29tcG9uZW50fSBmcm9tICcuL2ZpeGVkLWJ1dHRvbi1kZXRhaWwuY29tcG9uZW50JztcbmltcG9ydCB7TWF0VG9vbHRpcE1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvdG9vbHRpcCc7XG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbTmF0dXJhbEZpeGVkQnV0dG9uRGV0YWlsQ29tcG9uZW50XSxcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBOYXR1cmFsRml4ZWRCdXR0b25Nb2R1bGUsIE1hdFRvb2x0aXBNb2R1bGVdLFxuICAgIGV4cG9ydHM6IFtOYXR1cmFsRml4ZWRCdXR0b25EZXRhaWxDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBOYXR1cmFsRml4ZWRCdXR0b25EZXRhaWxNb2R1bGUge31cbiJdfQ==
@@ -11,13 +11,14 @@ import { replaceObjectKeepingReference } from '../../../classes/utility';
11
11
  import * as i0 from "@angular/core";
12
12
  import * as i1 from "./hierarchic-selector.service";
13
13
  import * as i2 from "@angular/common";
14
- import * as i3 from "@angular/material/legacy-checkbox";
15
- import * as i4 from "@angular/material/legacy-button";
14
+ import * as i3 from "@angular/material/checkbox";
15
+ import * as i4 from "@angular/material/button";
16
16
  import * as i5 from "@angular/material/tree";
17
- import * as i6 from "@angular/material/legacy-progress-spinner";
18
- import * as i7 from "../../icon/icon.component";
19
- import * as i8 from "@angular/material/legacy-chips";
20
- import * as i9 from "../../search/search/search.component";
17
+ import * as i6 from "@angular/material/icon";
18
+ import * as i7 from "@angular/material/progress-spinner";
19
+ import * as i8 from "../../icon/icon.directive";
20
+ import * as i9 from "@angular/material/chips";
21
+ import * as i10 from "../../search/search/search.component";
21
22
  export class NaturalHierarchicSelectorComponent extends NaturalAbstractController {
22
23
  constructor(hierarchicSelectorService) {
23
24
  super();
@@ -336,10 +337,10 @@ export class NaturalHierarchicSelectorComponent extends NaturalAbstractControlle
336
337
  }
337
338
  }
338
339
  NaturalHierarchicSelectorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: NaturalHierarchicSelectorComponent, deps: [{ token: i1.NaturalHierarchicSelectorService }], target: i0.ɵɵFactoryTarget.Component });
339
- NaturalHierarchicSelectorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.2", type: NaturalHierarchicSelectorComponent, selector: "natural-hierarchic-selector", inputs: { displayWith: "displayWith", config: "config", multiple: "multiple", selected: "selected", allowUnselect: "allowUnselect", filters: "filters", searchFacets: "searchFacets", searchSelections: "searchSelections" }, outputs: { searchSelectionChange: "searchSelectionChange", selectionChange: "selectionChange" }, providers: [NaturalHierarchicSelectorService], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div [style.margin-bottom.px]=\"20\">\n <natural-search\n (selectionChange)=\"search($event)\"\n [facets]=\"searchFacets\"\n [selections]=\"searchSelections\"\n ></natural-search>\n</div>\n\n<div class=\"body\">\n <mat-progress-spinner\n *ngIf=\"loading\"\n [diameter]=\"36\"\n mode=\"indeterminate\"\n style=\"margin: 10px\"\n ></mat-progress-spinner>\n\n <mat-tree [dataSource]=\"dataSource\" [treeControl]=\"treeControl\">\n <mat-tree-node *matTreeNodeDef=\"let node\" [ngClass]=\"{leaf: !node.expandable}\" matTreeNodePadding>\n <button\n (click)=\"loadChildren(node)\"\n *ngIf=\"node.expandable\"\n [attr.aria-label]=\"'toggle ' + node.name\"\n mat-icon-button\n matTreeNodeToggle\n >\n <mat-progress-spinner\n *ngIf=\"node.loading\"\n [diameter]=\"24\"\n [strokeWidth]=\"5\"\n mode=\"indeterminate\"\n style=\"margin: 8px\"\n ></mat-progress-spinner>\n\n <natural-icon\n *ngIf=\"!node.loading\"\n [name]=\"treeControl.isExpanded(node) ? 'expand_more' : 'chevron_right'\"\n >\n </natural-icon>\n </button>\n\n <mat-checkbox\n (change)=\"toggleFlatNode(node)\"\n [checked]=\"flatNodesSelection.isSelected(node)\"\n [disabled]=\"!isNodeTogglable(node)\"\n style=\"margin-right: 10px\"\n >\n <natural-icon\n *ngIf=\"node.node.config.icon\"\n [name]=\"node.node.config.icon\"\n style=\"margin-right: 10px\"\n ></natural-icon>\n <span>{{ node.name }}</span>\n </mat-checkbox>\n </mat-tree-node>\n </mat-tree>\n\n <mat-chip-list aria-orientation=\"vertical\" class=\"mat-chip-list-stacked\">\n <mat-chip\n (removed)=\"unselectModelNode(node)\"\n *ngFor=\"let node of selectedNodes\"\n [removable]=\"true\"\n [selectable]=\"false\"\n >\n <natural-icon *ngIf=\"node.config.icon\" [name]=\"node.config.icon\"></natural-icon>\n <div class=\"mat-body chip-label\">{{ node.model.name || node.model.fullName }}</div>\n <natural-icon matChipRemove name=\"cancel\"></natural-icon>\n </mat-chip>\n </mat-chip-list>\n</div>\n\n<div *ngIf=\"!loading && !dataSource.data.length\" class=\"margin-v\" i18n>Aucun r\u00E9sultat</div>\n", styles: [":host{display:block}:host ul,:host li{-webkit-margin-before:0;-webkit-margin-after:0;list-style-type:none}:host natural-icon{width:18px;height:18px;font-size:18px;margin-right:5px}:host .mat-tree-node.leaf{margin-left:40px}:host .body{display:flex;flex-direction:row;justify-content:space-between}:host .body mat-tree{flex:66}:host .body mat-chip-list{flex:33}:host mat-tree{flex-shrink:0}:host mat-chip-list{margin-left:10px}:host mat-chip{display:flex;flex-direction:row;height:auto!important}:host mat-chip .chip-label{flex:1}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatLegacyCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "component", type: i4.MatLegacyButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i5.MatTreeNodeDef, selector: "[matTreeNodeDef]", inputs: ["matTreeNodeDefWhen", "matTreeNode"] }, { kind: "directive", type: i5.MatTreeNodePadding, selector: "[matTreeNodePadding]", inputs: ["matTreeNodePadding", "matTreeNodePaddingIndent"] }, { kind: "directive", type: i5.MatTreeNodeToggle, selector: "[matTreeNodeToggle]", inputs: ["matTreeNodeToggleRecursive"] }, { kind: "component", type: i5.MatTree, selector: "mat-tree", exportAs: ["matTree"] }, { kind: "directive", type: i5.MatTreeNode, selector: "mat-tree-node", inputs: ["role", "disabled", "tabIndex"], exportAs: ["matTreeNode"] }, { kind: "component", type: i6.MatLegacyProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "diameter", "strokeWidth", "mode", "value"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: i7.NaturalIconComponent, selector: "natural-icon", inputs: ["label", "labelColor", "labelPosition", "name", "size"] }, { kind: "component", type: i8.MatLegacyChipList, selector: "mat-chip-list", inputs: ["role", "aria-describedby", "errorStateMatcher", "multiple", "compareWith", "value", "required", "placeholder", "disabled", "aria-orientation", "selectable", "tabIndex"], outputs: ["change", "valueChange"], exportAs: ["matChipList"] }, { kind: "directive", type: i8.MatLegacyChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disableRipple", "tabIndex", "role", "selected", "value", "selectable", "disabled", "removable"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["matChip"] }, { kind: "directive", type: i8.MatLegacyChipRemove, selector: "[matChipRemove]" }, { kind: "component", type: i9.NaturalSearchComponent, selector: "natural-search", inputs: ["placeholder", "facets", "multipleGroups", "selections"], outputs: ["selectionChange"] }] });
340
+ NaturalHierarchicSelectorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.1.2", type: NaturalHierarchicSelectorComponent, selector: "natural-hierarchic-selector", inputs: { displayWith: "displayWith", config: "config", multiple: "multiple", selected: "selected", allowUnselect: "allowUnselect", filters: "filters", searchFacets: "searchFacets", searchSelections: "searchSelections" }, outputs: { searchSelectionChange: "searchSelectionChange", selectionChange: "selectionChange" }, providers: [NaturalHierarchicSelectorService], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div [style.margin-bottom.px]=\"20\">\n <natural-search\n (selectionChange)=\"search($event)\"\n [facets]=\"searchFacets\"\n [selections]=\"searchSelections\"\n ></natural-search>\n</div>\n\n<div class=\"body\">\n <mat-progress-spinner\n *ngIf=\"loading\"\n [diameter]=\"36\"\n mode=\"indeterminate\"\n style=\"margin: 10px\"\n ></mat-progress-spinner>\n\n <mat-tree [dataSource]=\"dataSource\" [treeControl]=\"treeControl\">\n <mat-tree-node *matTreeNodeDef=\"let node\" [ngClass]=\"{leaf: !node.expandable}\" matTreeNodePadding>\n <button\n (click)=\"loadChildren(node)\"\n *ngIf=\"node.expandable\"\n [attr.aria-label]=\"'toggle ' + node.name\"\n mat-icon-button\n matTreeNodeToggle\n >\n <mat-progress-spinner\n *ngIf=\"node.loading\"\n [diameter]=\"24\"\n [strokeWidth]=\"5\"\n mode=\"indeterminate\"\n ></mat-progress-spinner>\n\n <mat-icon\n *ngIf=\"!node.loading\"\n [naturalIcon]=\"treeControl.isExpanded(node) ? 'expand_more' : 'chevron_right'\"\n ></mat-icon>\n </button>\n\n <mat-checkbox\n (change)=\"toggleFlatNode(node)\"\n [checked]=\"flatNodesSelection.isSelected(node)\"\n [disabled]=\"!isNodeTogglable(node)\"\n style=\"margin-right: 10px\"\n >\n <mat-icon\n *ngIf=\"node.node.config.icon\"\n [naturalIcon]=\"node.node.config.icon\"\n style=\"margin-right: 10px\"\n ></mat-icon>\n <span>{{ node.name }}</span>\n </mat-checkbox>\n </mat-tree-node>\n </mat-tree>\n\n <mat-chip-listbox aria-orientation=\"vertical\" class=\"mat-mdc-chip-set-stacked\">\n <mat-chip-option\n (removed)=\"unselectModelNode(node)\"\n *ngFor=\"let node of selectedNodes\"\n [removable]=\"true\"\n [selectable]=\"false\"\n >\n <mat-icon *ngIf=\"node.config.icon\" [naturalIcon]=\"node.config.icon\"></mat-icon>\n <div class=\"mat-body chip-label\">{{ node.model.name || node.model.fullName }}</div>\n <mat-icon matChipRemove naturalIcon=\"cancel\"></mat-icon>\n </mat-chip-option>\n </mat-chip-listbox>\n</div>\n\n<div *ngIf=\"!loading && !dataSource.data.length\" class=\"margin-v\" i18n>Aucun r\u00E9sultat</div>\n", styles: [":host{display:block}:host ul,:host li{-webkit-margin-before:0;-webkit-margin-after:0;list-style-type:none}:host mat-icon{width:18px;height:18px;font-size:18px}:host .mat-tree-node.leaf{margin-left:48px}:host .body{display:flex;flex-direction:row;justify-content:space-between}:host .body mat-tree{flex:66}:host .body mat-chip-listbox{flex:33}:host mat-tree{flex-shrink:0}:host mat-chip-listbox{margin-left:10px}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "component", type: i4.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i5.MatTreeNodeDef, selector: "[matTreeNodeDef]", inputs: ["matTreeNodeDefWhen", "matTreeNode"] }, { kind: "directive", type: i5.MatTreeNodePadding, selector: "[matTreeNodePadding]", inputs: ["matTreeNodePadding", "matTreeNodePaddingIndent"] }, { kind: "directive", type: i5.MatTreeNodeToggle, selector: "[matTreeNodeToggle]", inputs: ["matTreeNodeToggleRecursive"] }, { kind: "component", type: i5.MatTree, selector: "mat-tree", exportAs: ["matTree"] }, { kind: "directive", type: i5.MatTreeNode, selector: "mat-tree-node", inputs: ["role", "disabled", "tabIndex"], exportAs: ["matTreeNode"] }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i7.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "directive", type: i8.NaturalIconDirective, selector: "mat-icon[naturalIcon]", inputs: ["naturalIcon", "size"] }, { kind: "component", type: i9.MatChipListbox, selector: "mat-chip-listbox", inputs: ["tabIndex", "multiple", "aria-orientation", "selectable", "compareWith", "required", "value"], outputs: ["change"] }, { kind: "component", type: i9.MatChipOption, selector: "mat-basic-chip-option, mat-chip-option", inputs: ["color", "disabled", "disableRipple", "tabIndex", "selectable", "selected"], outputs: ["selectionChange"] }, { kind: "directive", type: i9.MatChipRemove, selector: "[matChipRemove]" }, { kind: "component", type: i10.NaturalSearchComponent, selector: "natural-search", inputs: ["placeholder", "facets", "multipleGroups", "selections"], outputs: ["selectionChange"] }] });
340
341
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: NaturalHierarchicSelectorComponent, decorators: [{
341
342
  type: Component,
342
- args: [{ selector: 'natural-hierarchic-selector', providers: [NaturalHierarchicSelectorService], template: "<div [style.margin-bottom.px]=\"20\">\n <natural-search\n (selectionChange)=\"search($event)\"\n [facets]=\"searchFacets\"\n [selections]=\"searchSelections\"\n ></natural-search>\n</div>\n\n<div class=\"body\">\n <mat-progress-spinner\n *ngIf=\"loading\"\n [diameter]=\"36\"\n mode=\"indeterminate\"\n style=\"margin: 10px\"\n ></mat-progress-spinner>\n\n <mat-tree [dataSource]=\"dataSource\" [treeControl]=\"treeControl\">\n <mat-tree-node *matTreeNodeDef=\"let node\" [ngClass]=\"{leaf: !node.expandable}\" matTreeNodePadding>\n <button\n (click)=\"loadChildren(node)\"\n *ngIf=\"node.expandable\"\n [attr.aria-label]=\"'toggle ' + node.name\"\n mat-icon-button\n matTreeNodeToggle\n >\n <mat-progress-spinner\n *ngIf=\"node.loading\"\n [diameter]=\"24\"\n [strokeWidth]=\"5\"\n mode=\"indeterminate\"\n style=\"margin: 8px\"\n ></mat-progress-spinner>\n\n <natural-icon\n *ngIf=\"!node.loading\"\n [name]=\"treeControl.isExpanded(node) ? 'expand_more' : 'chevron_right'\"\n >\n </natural-icon>\n </button>\n\n <mat-checkbox\n (change)=\"toggleFlatNode(node)\"\n [checked]=\"flatNodesSelection.isSelected(node)\"\n [disabled]=\"!isNodeTogglable(node)\"\n style=\"margin-right: 10px\"\n >\n <natural-icon\n *ngIf=\"node.node.config.icon\"\n [name]=\"node.node.config.icon\"\n style=\"margin-right: 10px\"\n ></natural-icon>\n <span>{{ node.name }}</span>\n </mat-checkbox>\n </mat-tree-node>\n </mat-tree>\n\n <mat-chip-list aria-orientation=\"vertical\" class=\"mat-chip-list-stacked\">\n <mat-chip\n (removed)=\"unselectModelNode(node)\"\n *ngFor=\"let node of selectedNodes\"\n [removable]=\"true\"\n [selectable]=\"false\"\n >\n <natural-icon *ngIf=\"node.config.icon\" [name]=\"node.config.icon\"></natural-icon>\n <div class=\"mat-body chip-label\">{{ node.model.name || node.model.fullName }}</div>\n <natural-icon matChipRemove name=\"cancel\"></natural-icon>\n </mat-chip>\n </mat-chip-list>\n</div>\n\n<div *ngIf=\"!loading && !dataSource.data.length\" class=\"margin-v\" i18n>Aucun r\u00E9sultat</div>\n", styles: [":host{display:block}:host ul,:host li{-webkit-margin-before:0;-webkit-margin-after:0;list-style-type:none}:host natural-icon{width:18px;height:18px;font-size:18px;margin-right:5px}:host .mat-tree-node.leaf{margin-left:40px}:host .body{display:flex;flex-direction:row;justify-content:space-between}:host .body mat-tree{flex:66}:host .body mat-chip-list{flex:33}:host mat-tree{flex-shrink:0}:host mat-chip-list{margin-left:10px}:host mat-chip{display:flex;flex-direction:row;height:auto!important}:host mat-chip .chip-label{flex:1}\n"] }]
343
+ args: [{ selector: 'natural-hierarchic-selector', providers: [NaturalHierarchicSelectorService], template: "<div [style.margin-bottom.px]=\"20\">\n <natural-search\n (selectionChange)=\"search($event)\"\n [facets]=\"searchFacets\"\n [selections]=\"searchSelections\"\n ></natural-search>\n</div>\n\n<div class=\"body\">\n <mat-progress-spinner\n *ngIf=\"loading\"\n [diameter]=\"36\"\n mode=\"indeterminate\"\n style=\"margin: 10px\"\n ></mat-progress-spinner>\n\n <mat-tree [dataSource]=\"dataSource\" [treeControl]=\"treeControl\">\n <mat-tree-node *matTreeNodeDef=\"let node\" [ngClass]=\"{leaf: !node.expandable}\" matTreeNodePadding>\n <button\n (click)=\"loadChildren(node)\"\n *ngIf=\"node.expandable\"\n [attr.aria-label]=\"'toggle ' + node.name\"\n mat-icon-button\n matTreeNodeToggle\n >\n <mat-progress-spinner\n *ngIf=\"node.loading\"\n [diameter]=\"24\"\n [strokeWidth]=\"5\"\n mode=\"indeterminate\"\n ></mat-progress-spinner>\n\n <mat-icon\n *ngIf=\"!node.loading\"\n [naturalIcon]=\"treeControl.isExpanded(node) ? 'expand_more' : 'chevron_right'\"\n ></mat-icon>\n </button>\n\n <mat-checkbox\n (change)=\"toggleFlatNode(node)\"\n [checked]=\"flatNodesSelection.isSelected(node)\"\n [disabled]=\"!isNodeTogglable(node)\"\n style=\"margin-right: 10px\"\n >\n <mat-icon\n *ngIf=\"node.node.config.icon\"\n [naturalIcon]=\"node.node.config.icon\"\n style=\"margin-right: 10px\"\n ></mat-icon>\n <span>{{ node.name }}</span>\n </mat-checkbox>\n </mat-tree-node>\n </mat-tree>\n\n <mat-chip-listbox aria-orientation=\"vertical\" class=\"mat-mdc-chip-set-stacked\">\n <mat-chip-option\n (removed)=\"unselectModelNode(node)\"\n *ngFor=\"let node of selectedNodes\"\n [removable]=\"true\"\n [selectable]=\"false\"\n >\n <mat-icon *ngIf=\"node.config.icon\" [naturalIcon]=\"node.config.icon\"></mat-icon>\n <div class=\"mat-body chip-label\">{{ node.model.name || node.model.fullName }}</div>\n <mat-icon matChipRemove naturalIcon=\"cancel\"></mat-icon>\n </mat-chip-option>\n </mat-chip-listbox>\n</div>\n\n<div *ngIf=\"!loading && !dataSource.data.length\" class=\"margin-v\" i18n>Aucun r\u00E9sultat</div>\n", styles: [":host{display:block}:host ul,:host li{-webkit-margin-before:0;-webkit-margin-after:0;list-style-type:none}:host mat-icon{width:18px;height:18px;font-size:18px}:host .mat-tree-node.leaf{margin-left:48px}:host .body{display:flex;flex-direction:row;justify-content:space-between}:host .body mat-tree{flex:66}:host .body mat-chip-listbox{flex:33}:host mat-tree{flex-shrink:0}:host mat-chip-listbox{margin-left:10px}\n"] }]
343
344
  }], ctorParameters: function () { return [{ type: i1.NaturalHierarchicSelectorService }]; }, propDecorators: { displayWith: [{
344
345
  type: Input
345
346
  }], config: [{
@@ -361,4 +362,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.2", ngImpor
361
362
  }], selectionChange: [{
362
363
  type: Output
363
364
  }] } });
364
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hierarchic-selector.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.ts","../../../../../../../projects/natural/src/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,cAAc,EAAC,MAAM,0BAA0B,CAAC;AACxD,OAAO,EAAC,eAAe,EAAC,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAC,SAAS,EAAE,YAAY,EAAE,KAAK,EAAqB,MAAM,EAAgB,MAAM,eAAe,CAAC;AACvG,OAAO,EAAC,qBAAqB,EAAE,gBAAgB,EAAC,MAAM,wBAAwB,CAAC;AAE/E,OAAO,EAAC,QAAQ,EAAE,SAAS,EAAC,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAC,yBAAyB,EAAC,MAAM,sCAAsC,CAAC;AAG/E,OAAO,EAAC,uBAAuB,EAAC,MAAM,uCAAuC,CAAC;AAG9E,OAAO,EAAC,kBAAkB,EAAC,MAAM,sBAAsB,CAAC;AAIxD,OAAO,EAAC,gCAAgC,EAA0B,MAAM,+BAA+B,CAAC;AACxG,OAAO,EAAC,6BAA6B,EAAC,MAAM,0BAA0B,CAAC;;;;;;;;;;;AAQvE,MAAM,OAAO,kCAAmC,SAAQ,yBAAyB;IA0E7E,YAAoC,yBAA2D;QAC3F,KAAK,EAAE,CAAC;QADwB,8BAAyB,GAAzB,yBAAyB,CAAkC;QA/D/F;;WAEG;QACa,aAAQ,GAAG,KAAK,CAAC;QAEjC;;;WAGG;QACa,aAAQ,GAA4B,EAAE,CAAC;QAEvD;;WAEG;QACa,kBAAa,GAAG,IAAI,CAAC;QAOrC;;WAEG;QACa,iBAAY,GAAwB,EAAE,CAAC;QAEvD;;WAEG;QACa,qBAAgB,GAA4B,EAAE,CAAC;QAE/D;;WAEG;QACuB,0BAAqB,GAAG,IAAI,YAAY,EAA2B,CAAC;QAE9F;;WAEG;QACI,kBAAa,GAA0B,EAAE,CAAC;QAEjD;;;WAGG;QACuB,oBAAe,GAAG,IAAI,YAAY,EAA2B,CAAC;QAWjF,YAAO,GAAG,KAAK,CAAC;QAEvB;;WAEG;QACK,gBAAW,GAAoC,IAAI,GAAG,EAA8B,CAAC;IAI7F,CAAC;IAED;;OAEG;IACI,QAAQ;QACX,+BAA+B;QAC/B,IAAI,CAAC,kBAAkB,GAAG,IAAI,cAAc,CAAM,IAAI,CAAC,QAAQ,CAAC,CAAC;QAEjE,oCAAoC;QACpC,IAAI,CAAC,aAAa,GAAG,IAAI,gBAAgB,CACrC,IAAI,CAAC,WAAW,EAAE,EAClB,IAAI,CAAC,QAAQ,EAAE,EACf,IAAI,CAAC,YAAY,EAAE,EACnB,IAAI,CAAC,WAAW,EAAE,CACrB,CAAC;QACF,IAAI,CAAC,WAAW,GAAG,IAAI,eAAe,CAAqB,IAAI,CAAC,QAAQ,EAAE,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;QAEjG,qHAAqH;QACrH,kIAAkI;QAClI,IAAI,CAAC,UAAU,GAAG,IAAI,qBAAqB,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QAElF,wEAAwE;QACxE,qEAAqE;QACrE,IAAI,CAAC,yBAAyB,CAAC,UAAU;aACpC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;aACnC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC;QAEtD,2GAA2G;QAC3G,IAAI,SAAS,CAAC;QACd,IAAI,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE;YAC3C,SAAS,GAAG,EAAC,MAAM,EAAE,uBAAuB,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,gBAAgB,CAAC,EAAC,CAAC;SAC3F;QACD,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAE1B,kDAAkD;QAClD,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC7C,CAAC;IAED;;OAEG;IACI,WAAW,CAAC,OAAsB;QACrC,IAAI,OAAO,CAAC,QAAQ,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,WAAW,EAAE;YACnD,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SAC5C;QAED,IAAI,OAAO,CAAC,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,WAAW,EAAE;YACjD,IAAI,CAAC,SAAS,EAAE,CAAC;SACpB;IACL,CAAC;IAED;;OAEG;IACI,cAAc,CAAC,QAA4B;QAC9C,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,2CAA2C;YAC3C,IAAI,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE;gBAC9C,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;aACnC;iBAAM;gBACH,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;aACjC;SACJ;aAAM,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YACvB,IAAI,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE;gBAC9C,IAAI,CAAC,sBAAsB,EAAE,CAAC;aACjC;iBAAM;gBACH,2GAA2G;gBAC3G,IAAI,CAAC,oBAAoB,CAAC,QAAQ,CAAC,CAAC;aACvC;SACJ;IACL,CAAC;IAED;;;OAGG;IACI,iBAAiB,CAAC,IAAyB;QAC9C,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QACxC,IAAI,QAAQ,EAAE;YACV,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;SACnC;aAAM;YACH,gGAAgG;YAChG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;YAC3B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SAC5C;IACL,CAAC;IAEM,eAAe,CAAC,QAA4B;QAC/C,IAAI,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;YACpC,OAAO,QAAQ,CAAC,YAAY,CAAC;SAChC;aAAM;YACH,OAAO,QAAQ,CAAC,UAAU,CAAC;SAC9B;IACL,CAAC;IAEO,YAAY,CAAC,MAAsC;QACvD,IAAI,MAAM,CAAC,WAAW,EAAE;YACpB,OAAO,MAAM,CAAC,WAAW,CAAC;SAC7B;QAED,IAAI,IAAI,CAAC,WAAW,EAAE;YAClB,OAAO,IAAI,CAAC,WAAW,CAAC;SAC3B;QAED,OAAO,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;IAC5D,CAAC;IAEM,YAAY,CAAC,QAA4B;QAC5C,IAAI,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE;YACvC,IAAI,CAAC,yBAAyB,CAAC,YAAY,CAAC,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;SACvE;IACL,CAAC;IAED;;OAEG;IACH,sDAAsD;IACtD,mDAAmD;IACnD,EAAE;IACF,kEAAkE;IAClE,gCAAgC;IAChC,yFAAyF;IACzF,EAAE;IACF,gCAAgC;IAChC,8DAA8D;IAC9D,6DAA6D;IAC7D,mCAAmC;IACnC,4DAA4D;IAC5D,oBAAoB;IACpB,kBAAkB;IAClB,YAAY;IACZ,QAAQ;IACR,IAAI;IAEI,WAAW;QACf,OAAO,CAAC,IAAyB,EAAqC,EAAE;YACpE,OAAO,IAAI,CAAC,cAAc,CAAC;QAC/B,CAAC,CAAC;IACN,CAAC;IAED;;OAEG;IACK,WAAW;QACf,OAAO,CAAC,IAAyB,EAAE,KAAa,EAAE,EAAE;YAChD,OAAO,IAAI,CAAC,mBAAmB,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QACjD,CAAC,CAAC;IACN,CAAC;IAED;;OAEG;IACK,QAAQ;QACZ,OAAO,CAAC,IAAwB,EAAE,EAAE;YAChC,OAAO,IAAI,CAAC,KAAK,CAAC;QACtB,CAAC,CAAC;IACN,CAAC;IAED;;OAEG;IACK,YAAY;QAChB,OAAO,CAAC,IAAwB,EAAE,EAAE;YAChC,OAAO,IAAI,CAAC,UAAU,CAAC;QAC3B,CAAC,CAAC;IACN,CAAC;IAEO,mBAAmB,CAAC,IAAyB,EAAE,KAAa;QAChE,4BAA4B;QAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;QACxC,IAAI,QAAQ,EAAE;YACV,OAAO,QAAQ,CAAC;SACnB;QAED,sBAAsB;QACtB,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IAC5C,CAAC;IAEM,MAAM,CAAC,UAAmC;QAC7C,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC5C,IAAI,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE;YAChC,MAAM,SAAS,GAAG,EAAC,MAAM,EAAE,uBAAuB,CAAC,IAAI,CAAC,YAAY,EAAE,UAAU,CAAC,EAAC,CAAC;YACnF,IAAI,CAAC,yBAAyB,CAAC,MAAM,CAAC,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;SAClE;aAAM;YACH,IAAI,CAAC,SAAS,EAAE,CAAC;SACpB;IACL,CAAC;IAEO,SAAS,CAAC,eAAgC;QAC9C,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,WAAW,GAAG,IAAI,GAAG,EAA8B,CAAC;QACzD,IAAI,CAAC,yBAAyB;aACzB,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,EAAE,eAAe,IAAI,IAAI,CAAC;aACxD,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,CAAC,CAAC;aAC5C,SAAS,EAAE,CAAC;IACrB,CAAC;IAED;;OAEG;IACK,oBAAoB,CAAC,QAAiC;QAC1D,+HAA+H;QAC/H,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,yBAAyB,CAAC,sBAAsB,CAAC,QAAQ,CAAC,CAAC;QAErF,IAAI,CAAC,kBAAkB,CAAC,KAAK,EAAE,CAAC;QAChC,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,aAAa,EAAE;YACnC,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;YACxC,IAAI,QAAQ,EAAE;gBACV,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;aAC5C;SACJ;IACL,CAAC;IAED;;OAEG;IACK,gBAAgB,CAAC,QAA4B;QACjD,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QAC3C,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACpC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAC7C,CAAC;IAED;;OAEG;IACK,eAAe,CAAC,IAAyB;QAC7C,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvC,MAAM,cAAc,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC;QAC1F,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC;IACjD,CAAC;IAED;;OAEG;IACK,cAAc,CAAC,QAA4B;QAC/C,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QACzC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACvC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAC7C,CAAC;IAED;;OAEG;IACK,oBAAoB,CAAC,QAA4B;QACrD,IAAI,CAAC,kBAAkB,CAAC,KAAK,EAAE,CAAC;QAChC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QACzC,IAAI,CAAC,aAAa,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACrC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAC7C,CAAC;IAED;;OAEG;IACK,sBAAsB;QAC1B,IAAI,CAAC,kBAAkB,CAAC,KAAK,EAAE,CAAC;QAChC,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;QACxB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAC7C,CAAC;IAED;;OAEG;IACK,eAAe,CAAC,QAA+B;QACnD,MAAM,2BAA2B,GAAG,IAAI,CAAC,yBAAyB,CAAC,oBAAoB,CAAC,QAAQ,CAAC,CAAC;QAClG,6BAA6B,CAAC,IAAI,CAAC,QAAQ,EAAE,2BAA2B,CAAC,CAAC;QAC1E,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC;IAC3D,CAAC;IAEO,cAAc,CAAC,IAAyB;QAC5C,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAEvC,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC;IACzE,CAAC;IAEO,WAAW,CAAC,IAAyB;QACzC,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvC,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC;IAC7C,CAAC;IAEO,cAAc,CAAC,IAAyB,EAAE,KAAa;QAC3D,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvC,MAAM,IAAI,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACxD,MAAM,UAAU,GAAG,KAAK,CAAC;QACzB,MAAM,kBAAkB,GAAG,IAAI,CAAC,MAAM,CAAC,oBAAoB;YACvD,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC;YAC9C,CAAC,CAAC,IAAI,CAAC;QACX,MAAM,YAAY,GAAG,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,eAAe,IAAI,kBAAkB,CAAC;QAEzE,MAAM,QAAQ,GAAG,IAAI,kBAAkB,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE,YAAY,CAAC,CAAC;QAErF,IAAI,CAAC,yBAAyB,CAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QAElE,wEAAwE;QACxE,IAAI,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE;YAC3B,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;gBACrB,QAAQ,CAAC,YAAY,GAAG,KAAK,CAAC;aACjC;YACD,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;SAC5C;QAED,iBAAiB;QACjB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,EAAE,QAAQ,CAAC,CAAC;QAEpC,OAAO,QAAQ,CAAC;IACpB,CAAC;IAED;;;OAGG;IACK,SAAS,CAAC,KAAc;QAC5B,OAAO,KAAK,CAAC,UAAU,GAAG,GAAG,GAAG,KAAK,CAAC,EAAE,CAAC;IAC7C,CAAC;;+HArYQ,kCAAkC;mHAAlC,kCAAkC,qXAFhC,CAAC,gCAAgC,CAAC,sECvBjD,2pFAuEA;2FD9Ca,kCAAkC;kBAN9C,SAAS;+BACI,6BAA6B,aAG5B,CAAC,gCAAgC,CAAC;uHAM7B,WAAW;sBAA1B,KAAK;gBAKU,MAAM;sBAArB,KAAK;gBAKU,QAAQ;sBAAvB,KAAK;gBAMU,QAAQ;sBAAvB,KAAK;gBAKU,aAAa;sBAA5B,KAAK;gBAKU,OAAO;sBAAtB,KAAK;gBAKU,YAAY;sBAA3B,KAAK;gBAKU,gBAAgB;sBAA/B,KAAK;gBAKoB,qBAAqB;sBAA9C,MAAM;gBAWmB,eAAe;sBAAxC,MAAM","sourcesContent":["import {SelectionModel} from '@angular/cdk/collections';\nimport {FlatTreeControl} from '@angular/cdk/tree';\nimport {Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges} from '@angular/core';\nimport {MatTreeFlatDataSource, MatTreeFlattener} from '@angular/material/tree';\nimport {Observable} from 'rxjs';\nimport {finalize, takeUntil} from 'rxjs/operators';\nimport {NaturalAbstractController} from '../../../classes/abstract-controller';\nimport {QueryVariables} from '../../../classes/query-variable-manager';\nimport {Literal} from '../../../types/types';\nimport {toGraphQLDoctrineFilter} from '../../search/classes/graphql-doctrine';\nimport {NaturalSearchFacets} from '../../search/types/facet';\nimport {NaturalSearchSelections} from '../../search/types/values';\nimport {HierarchicFlatNode} from '../classes/flat-node';\nimport {NaturalHierarchicConfiguration} from '../classes/hierarchic-configuration';\nimport {HierarchicFiltersConfiguration} from '../classes/hierarchic-filters-configuration';\nimport {HierarchicModelNode} from '../classes/model-node';\nimport {NaturalHierarchicSelectorService, OrganizedModelSelection} from './hierarchic-selector.service';\nimport {replaceObjectKeepingReference} from '../../../classes/utility';\n\n@Component({\n    selector: 'natural-hierarchic-selector',\n    templateUrl: './hierarchic-selector.component.html',\n    styleUrls: ['./hierarchic-selector.component.scss'],\n    providers: [NaturalHierarchicSelectorService],\n})\nexport class NaturalHierarchicSelectorComponent extends NaturalAbstractController implements OnInit, OnChanges {\n    /**\n     * Function that receives a model and returns a string for display value\n     */\n    @Input() public displayWith?: (item: any) => string;\n\n    /**\n     * Config for items and relations arrangement\n     */\n    @Input() public config!: NaturalHierarchicConfiguration[];\n\n    /**\n     * If multiple or single item selection\n     */\n    @Input() public multiple = false;\n\n    /**\n     * Selected items\n     * Organized by key, containing each an array of selected items of same type\n     */\n    @Input() public selected: OrganizedModelSelection = {};\n\n    /**\n     * Wherever if selectable elements can be unselected\n     */\n    @Input() public allowUnselect = true;\n\n    /**\n     * Filters that apply to each query\n     */\n    @Input() public filters?: HierarchicFiltersConfiguration | null;\n\n    /**\n     * Search facets\n     */\n    @Input() public searchFacets: NaturalSearchFacets = [];\n\n    /**\n     * Selections to apply on natural-search on component initialisation\n     */\n    @Input() public searchSelections: NaturalSearchSelections = [];\n\n    /**\n     * Emits when natural-search selections change\n     */\n    @Output() public readonly searchSelectionChange = new EventEmitter<NaturalSearchSelections>();\n\n    /**\n     * Inner representation of selected @Input() to allow flat listing as mat-chip.\n     */\n    public selectedNodes: HierarchicModelNode[] = [];\n\n    /**\n     * Emits selection change\n     * Returns a Literal where selected models are organized by key\n     */\n    @Output() public readonly selectionChange = new EventEmitter<OrganizedModelSelection>();\n\n    /**\n     * Controller for nodes selection\n     */\n    public flatNodesSelection!: SelectionModel<HierarchicFlatNode>;\n\n    public treeControl!: FlatTreeControl<HierarchicFlatNode>;\n    public treeFlattener!: MatTreeFlattener<HierarchicModelNode, HierarchicFlatNode>;\n    public dataSource!: MatTreeFlatDataSource<HierarchicModelNode, HierarchicFlatNode>;\n\n    public loading = false;\n\n    /**\n     * Cache for transformed nodes\n     */\n    private flatNodeMap: Map<string, HierarchicFlatNode> = new Map<string, HierarchicFlatNode>();\n\n    public constructor(private readonly hierarchicSelectorService: NaturalHierarchicSelectorService) {\n        super();\n    }\n\n    /**\n     * Angular OnInit implementation\n     */\n    public ngOnInit(): void {\n        // Init tree checkbox selectors\n        this.flatNodesSelection = new SelectionModel<any>(this.multiple);\n\n        // Tree controllers and manipulators\n        this.treeFlattener = new MatTreeFlattener(\n            this.transformer(),\n            this.getLevel(),\n            this.isExpandable(),\n            this.getChildren(),\n        );\n        this.treeControl = new FlatTreeControl<HierarchicFlatNode>(this.getLevel(), this.isExpandable());\n\n        // The dataSource contains a nested ModelNodes list. Each ModelNode has a child attribute that returns an observable.\n        // The dataSource contains a flat representation of the nested ModelNodes that is generated by the treeFlattener related functions\n        this.dataSource = new MatTreeFlatDataSource(this.treeControl, this.treeFlattener);\n\n        // Update dataSource when receiving new list -> we assign the whole tree\n        // The treeControl and treeFlattener will generate the displayed tree\n        this.hierarchicSelectorService.dataChange\n            .pipe(takeUntil(this.ngUnsubscribe))\n            .subscribe(data => (this.dataSource.data = data));\n\n        // Prevent empty screen on first load and init NaturalHierarchicSelectorService with inputted configuration\n        let variables;\n        if (this.searchSelections.some(s => s.length)) {\n            variables = {filter: toGraphQLDoctrineFilter(this.searchFacets, this.searchSelections)};\n        }\n        this.loadRoots(variables);\n\n        // OrganizedSelection into list usable by template\n        this.updateInnerSelection(this.selected);\n    }\n\n    /**\n     * Angular OnChange implementation\n     */\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (changes.selected && !changes.selected.firstChange) {\n            this.updateInnerSelection(this.selected);\n        }\n\n        if (changes.filters && !changes.filters.firstChange) {\n            this.loadRoots();\n        }\n    }\n\n    /**\n     * Toggle selection of a FlatNode, considering if multiple selection is activated or not\n     */\n    public toggleFlatNode(flatNode: HierarchicFlatNode): void {\n        if (this.multiple) {\n            // Is multiple allowed, just toggle element\n            if (this.flatNodesSelection.isSelected(flatNode)) {\n                this.unselectFlatNode(flatNode);\n            } else {\n                this.selectFlatNode(flatNode);\n            }\n        } else if (!this.multiple) {\n            if (this.flatNodesSelection.isSelected(flatNode)) {\n                this.unselectSingleFlatNode();\n            } else {\n                // If not multiple, and we want to select an element, unselect everything before to keep a single selection\n                this.selectSingleFlatNode(flatNode);\n            }\n        }\n    }\n\n    /**\n     * When unselecting an element from the mat-chips, it can be deep in the hierarchy, and the tree element may not exist...\n     * ... but we still need to remove the element from the mat-chips list.\n     */\n    public unselectModelNode(node: HierarchicModelNode): void {\n        const flatNode = this.getFlatNode(node);\n        if (flatNode) {\n            this.unselectFlatNode(flatNode);\n        } else {\n            // Remove from chips list only if no flatNode, because unselectFlatNode() already deals with it.\n            this.removeModelNode(node);\n            this.updateSelection(this.selectedNodes);\n        }\n    }\n\n    public isNodeTogglable(flatNode: HierarchicFlatNode): boolean {\n        if (this.isNodeSelected(flatNode.node)) {\n            return flatNode.deselectable;\n        } else {\n            return flatNode.selectable;\n        }\n    }\n\n    private getDisplayFn(config: NaturalHierarchicConfiguration): (item: any) => string {\n        if (config.displayWith) {\n            return config.displayWith;\n        }\n\n        if (this.displayWith) {\n            return this.displayWith;\n        }\n\n        return item => (item ? item.fullName || item.name : '');\n    }\n\n    public loadChildren(flatNode: HierarchicFlatNode): void {\n        if (this.treeControl.isExpanded(flatNode)) {\n            this.hierarchicSelectorService.loadChildren(flatNode, this.filters);\n        }\n    }\n\n    /**\n     * Created to collapse all children when closing a parent, but not sure it's good.\n     */\n    // public loadChildren(flatNode: HierarchicFlatNode) {\n    //     if (this.treeControl.isExpanded(flatNode)) {\n    //\n    //         const cachedFlatNode = this.getFlatNode(flatNode.node);\n    //         if (cachedFlatNode) {\n    //             this.hierarchicSelectorService.loadChildren(cachedFlatNode, this.filters);\n    //\n    //             // Close children\n    //             cachedFlatNode.node.children.forEach(child => {\n    //                 const childNode = this.getFlatNode(child);\n    //                 if (childNode) {\n    //                     this.treeControl.collapse(childNode);\n    //                 }\n    //             });\n    //         }\n    //     }\n    // }\n\n    private getChildren(): (node: HierarchicModelNode) => Observable<HierarchicModelNode[]> {\n        return (node: HierarchicModelNode): Observable<HierarchicModelNode[]> => {\n            return node.childrenChange;\n        };\n    }\n\n    /**\n     * Transforms a HierarchicModelNode into a FlatNode\n     */\n    private transformer(): (node: HierarchicModelNode, level: number) => HierarchicFlatNode {\n        return (node: HierarchicModelNode, level: number) => {\n            return this.getOrCreateFlatNode(node, level);\n        };\n    }\n\n    /**\n     * Return deep of the node in the tree\n     */\n    private getLevel(): (node: HierarchicFlatNode) => number {\n        return (node: HierarchicFlatNode) => {\n            return node.level;\n        };\n    }\n\n    /**\n     * Is always expandable because we load on demand, we don't know if there are children yet\n     */\n    private isExpandable(): (node: HierarchicFlatNode) => boolean {\n        return (node: HierarchicFlatNode) => {\n            return node.expandable;\n        };\n    }\n\n    private getOrCreateFlatNode(node: HierarchicModelNode, level: number): HierarchicFlatNode {\n        // Return FlatNode if exists\n        const flatNode = this.getFlatNode(node);\n        if (flatNode) {\n            return flatNode;\n        }\n\n        // Return new FlatNode\n        return this.createFlatNode(node, level);\n    }\n\n    public search(selections: NaturalSearchSelections): void {\n        this.searchSelectionChange.emit(selections);\n        if (selections.some(s => s.length)) {\n            const variables = {filter: toGraphQLDoctrineFilter(this.searchFacets, selections)};\n            this.hierarchicSelectorService.search(variables, this.filters);\n        } else {\n            this.loadRoots();\n        }\n    }\n\n    private loadRoots(searchVariables?: QueryVariables): void {\n        this.loading = true;\n        this.flatNodeMap = new Map<string, HierarchicFlatNode>();\n        this.hierarchicSelectorService\n            .init(this.config, this.filters, searchVariables || null)\n            .pipe(finalize(() => (this.loading = false)))\n            .subscribe();\n    }\n\n    /**\n     * Sync inner selection (tree and mat-chips) according to selected input attribute\n     */\n    private updateInnerSelection(selected: OrganizedModelSelection): void {\n        // Transform an OrganizedModelSelection into a ModelNode list that is used in the selected zone of the component (see template)\n        this.selectedNodes = this.hierarchicSelectorService.fromOrganizedSelection(selected);\n\n        this.flatNodesSelection.clear();\n        for (const node of this.selectedNodes) {\n            const flatNode = this.getFlatNode(node);\n            if (flatNode) {\n                this.flatNodesSelection.select(flatNode);\n            }\n        }\n    }\n\n    /**\n     * Unselect a node, keeping the rest of the selected untouched\n     */\n    private unselectFlatNode(flatNode: HierarchicFlatNode): void {\n        this.flatNodesSelection.deselect(flatNode);\n        this.removeModelNode(flatNode.node);\n        this.updateSelection(this.selectedNodes);\n    }\n\n    /**\n     * Remove a node from chip lists\n     */\n    private removeModelNode(node: HierarchicModelNode): void {\n        const key = this.getMapKey(node.model);\n        const selectionIndex = this.selectedNodes.findIndex(n => this.getMapKey(n.model) === key);\n        this.selectedNodes.splice(selectionIndex, 1);\n    }\n\n    /**\n     * Select a node, keeping th rest of the selected untouched\n     */\n    private selectFlatNode(flatNode: HierarchicFlatNode): void {\n        this.flatNodesSelection.select(flatNode);\n        this.selectedNodes.push(flatNode.node);\n        this.updateSelection(this.selectedNodes);\n    }\n\n    /**\n     * Clear all selected and select the given node\n     */\n    private selectSingleFlatNode(flatNode: HierarchicFlatNode): void {\n        this.flatNodesSelection.clear();\n        this.flatNodesSelection.select(flatNode);\n        this.selectedNodes = [flatNode.node];\n        this.updateSelection(this.selectedNodes);\n    }\n\n    /**\n     * Clear all selected and select the given node\n     */\n    private unselectSingleFlatNode(): void {\n        this.flatNodesSelection.clear();\n        this.selectedNodes = [];\n        this.updateSelection(this.selectedNodes);\n    }\n\n    /**\n     * Transform the given elements into the organized selection that is emitted to output\n     */\n    private updateSelection(selected: HierarchicModelNode[]): void {\n        const organizedFlatNodesSelection = this.hierarchicSelectorService.toOrganizedSelection(selected);\n        replaceObjectKeepingReference(this.selected, organizedFlatNodesSelection);\n        this.selectionChange.emit(organizedFlatNodesSelection);\n    }\n\n    private isNodeSelected(node: HierarchicModelNode): boolean {\n        const key = this.getMapKey(node.model);\n\n        return this.selectedNodes.some(n => this.getMapKey(n.model) === key);\n    }\n\n    private getFlatNode(node: HierarchicModelNode): HierarchicFlatNode | null {\n        const key = this.getMapKey(node.model);\n        return this.flatNodeMap.get(key) || null;\n    }\n\n    private createFlatNode(node: HierarchicModelNode, level: number): HierarchicFlatNode {\n        const key = this.getMapKey(node.model);\n        const name = this.getDisplayFn(node.config)(node.model);\n        const expandable = false;\n        const isCustomSelectable = node.config.isSelectableCallback\n            ? node.config.isSelectableCallback(node.model)\n            : true;\n        const isSelectable = !!node.config.selectableAtKey && isCustomSelectable;\n\n        const flatNode = new HierarchicFlatNode(node, name, level, expandable, isSelectable);\n\n        this.hierarchicSelectorService.countItems(flatNode, this.filters);\n\n        // Mark node as selected if needed (checks the selected processed input)\n        if (this.isNodeSelected(node)) {\n            if (!this.allowUnselect) {\n                flatNode.deselectable = false;\n            }\n            this.flatNodesSelection.select(flatNode);\n        }\n\n        // Cache FlatNode\n        this.flatNodeMap.set(key, flatNode);\n\n        return flatNode;\n    }\n\n    /**\n     * Returns an identifier key for map cache\n     * As many object types can be used, this function considers typename and ID to return something like document-123\n     */\n    private getMapKey(model: Literal): string {\n        return model.__typename + '-' + model.id;\n    }\n}\n","<div [style.margin-bottom.px]=\"20\">\n    <natural-search\n        (selectionChange)=\"search($event)\"\n        [facets]=\"searchFacets\"\n        [selections]=\"searchSelections\"\n    ></natural-search>\n</div>\n\n<div class=\"body\">\n    <mat-progress-spinner\n        *ngIf=\"loading\"\n        [diameter]=\"36\"\n        mode=\"indeterminate\"\n        style=\"margin: 10px\"\n    ></mat-progress-spinner>\n\n    <mat-tree [dataSource]=\"dataSource\" [treeControl]=\"treeControl\">\n        <mat-tree-node *matTreeNodeDef=\"let node\" [ngClass]=\"{leaf: !node.expandable}\" matTreeNodePadding>\n            <button\n                (click)=\"loadChildren(node)\"\n                *ngIf=\"node.expandable\"\n                [attr.aria-label]=\"'toggle ' + node.name\"\n                mat-icon-button\n                matTreeNodeToggle\n            >\n                <mat-progress-spinner\n                    *ngIf=\"node.loading\"\n                    [diameter]=\"24\"\n                    [strokeWidth]=\"5\"\n                    mode=\"indeterminate\"\n                    style=\"margin: 8px\"\n                ></mat-progress-spinner>\n\n                <natural-icon\n                    *ngIf=\"!node.loading\"\n                    [name]=\"treeControl.isExpanded(node) ? 'expand_more' : 'chevron_right'\"\n                >\n                </natural-icon>\n            </button>\n\n            <mat-checkbox\n                (change)=\"toggleFlatNode(node)\"\n                [checked]=\"flatNodesSelection.isSelected(node)\"\n                [disabled]=\"!isNodeTogglable(node)\"\n                style=\"margin-right: 10px\"\n            >\n                <natural-icon\n                    *ngIf=\"node.node.config.icon\"\n                    [name]=\"node.node.config.icon\"\n                    style=\"margin-right: 10px\"\n                ></natural-icon>\n                <span>{{ node.name }}</span>\n            </mat-checkbox>\n        </mat-tree-node>\n    </mat-tree>\n\n    <mat-chip-list aria-orientation=\"vertical\" class=\"mat-chip-list-stacked\">\n        <mat-chip\n            (removed)=\"unselectModelNode(node)\"\n            *ngFor=\"let node of selectedNodes\"\n            [removable]=\"true\"\n            [selectable]=\"false\"\n        >\n            <natural-icon *ngIf=\"node.config.icon\" [name]=\"node.config.icon\"></natural-icon>\n            <div class=\"mat-body chip-label\">{{ node.model.name || node.model.fullName }}</div>\n            <natural-icon matChipRemove name=\"cancel\"></natural-icon>\n        </mat-chip>\n    </mat-chip-list>\n</div>\n\n<div *ngIf=\"!loading && !dataSource.data.length\" class=\"margin-v\" i18n>Aucun résultat</div>\n"]}
365
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hierarchic-selector.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.ts","../../../../../../../projects/natural/src/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.html"],"names":[],"mappings":"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","sourcesContent":["import {SelectionModel} from '@angular/cdk/collections';\nimport {FlatTreeControl} from '@angular/cdk/tree';\nimport {Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges} from '@angular/core';\nimport {MatTreeFlatDataSource, MatTreeFlattener} from '@angular/material/tree';\nimport {Observable} from 'rxjs';\nimport {finalize, takeUntil} from 'rxjs/operators';\nimport {NaturalAbstractController} from '../../../classes/abstract-controller';\nimport {QueryVariables} from '../../../classes/query-variable-manager';\nimport {Literal} from '../../../types/types';\nimport {toGraphQLDoctrineFilter} from '../../search/classes/graphql-doctrine';\nimport {NaturalSearchFacets} from '../../search/types/facet';\nimport {NaturalSearchSelections} from '../../search/types/values';\nimport {HierarchicFlatNode} from '../classes/flat-node';\nimport {NaturalHierarchicConfiguration} from '../classes/hierarchic-configuration';\nimport {HierarchicFiltersConfiguration} from '../classes/hierarchic-filters-configuration';\nimport {HierarchicModelNode} from '../classes/model-node';\nimport {NaturalHierarchicSelectorService, OrganizedModelSelection} from './hierarchic-selector.service';\nimport {replaceObjectKeepingReference} from '../../../classes/utility';\n\n@Component({\n    selector: 'natural-hierarchic-selector',\n    templateUrl: './hierarchic-selector.component.html',\n    styleUrls: ['./hierarchic-selector.component.scss'],\n    providers: [NaturalHierarchicSelectorService],\n})\nexport class NaturalHierarchicSelectorComponent extends NaturalAbstractController implements OnInit, OnChanges {\n    /**\n     * Function that receives a model and returns a string for display value\n     */\n    @Input() public displayWith?: (item: any) => string;\n\n    /**\n     * Config for items and relations arrangement\n     */\n    @Input() public config!: NaturalHierarchicConfiguration[];\n\n    /**\n     * If multiple or single item selection\n     */\n    @Input() public multiple = false;\n\n    /**\n     * Selected items\n     * Organized by key, containing each an array of selected items of same type\n     */\n    @Input() public selected: OrganizedModelSelection = {};\n\n    /**\n     * Wherever if selectable elements can be unselected\n     */\n    @Input() public allowUnselect = true;\n\n    /**\n     * Filters that apply to each query\n     */\n    @Input() public filters?: HierarchicFiltersConfiguration | null;\n\n    /**\n     * Search facets\n     */\n    @Input() public searchFacets: NaturalSearchFacets = [];\n\n    /**\n     * Selections to apply on natural-search on component initialisation\n     */\n    @Input() public searchSelections: NaturalSearchSelections = [];\n\n    /**\n     * Emits when natural-search selections change\n     */\n    @Output() public readonly searchSelectionChange = new EventEmitter<NaturalSearchSelections>();\n\n    /**\n     * Inner representation of selected @Input() to allow flat listing as mat-chip.\n     */\n    public selectedNodes: HierarchicModelNode[] = [];\n\n    /**\n     * Emits selection change\n     * Returns a Literal where selected models are organized by key\n     */\n    @Output() public readonly selectionChange = new EventEmitter<OrganizedModelSelection>();\n\n    /**\n     * Controller for nodes selection\n     */\n    public flatNodesSelection!: SelectionModel<HierarchicFlatNode>;\n\n    public treeControl!: FlatTreeControl<HierarchicFlatNode>;\n    public treeFlattener!: MatTreeFlattener<HierarchicModelNode, HierarchicFlatNode>;\n    public dataSource!: MatTreeFlatDataSource<HierarchicModelNode, HierarchicFlatNode>;\n\n    public loading = false;\n\n    /**\n     * Cache for transformed nodes\n     */\n    private flatNodeMap: Map<string, HierarchicFlatNode> = new Map<string, HierarchicFlatNode>();\n\n    public constructor(private readonly hierarchicSelectorService: NaturalHierarchicSelectorService) {\n        super();\n    }\n\n    /**\n     * Angular OnInit implementation\n     */\n    public ngOnInit(): void {\n        // Init tree checkbox selectors\n        this.flatNodesSelection = new SelectionModel<any>(this.multiple);\n\n        // Tree controllers and manipulators\n        this.treeFlattener = new MatTreeFlattener(\n            this.transformer(),\n            this.getLevel(),\n            this.isExpandable(),\n            this.getChildren(),\n        );\n        this.treeControl = new FlatTreeControl<HierarchicFlatNode>(this.getLevel(), this.isExpandable());\n\n        // The dataSource contains a nested ModelNodes list. Each ModelNode has a child attribute that returns an observable.\n        // The dataSource contains a flat representation of the nested ModelNodes that is generated by the treeFlattener related functions\n        this.dataSource = new MatTreeFlatDataSource(this.treeControl, this.treeFlattener);\n\n        // Update dataSource when receiving new list -> we assign the whole tree\n        // The treeControl and treeFlattener will generate the displayed tree\n        this.hierarchicSelectorService.dataChange\n            .pipe(takeUntil(this.ngUnsubscribe))\n            .subscribe(data => (this.dataSource.data = data));\n\n        // Prevent empty screen on first load and init NaturalHierarchicSelectorService with inputted configuration\n        let variables;\n        if (this.searchSelections.some(s => s.length)) {\n            variables = {filter: toGraphQLDoctrineFilter(this.searchFacets, this.searchSelections)};\n        }\n        this.loadRoots(variables);\n\n        // OrganizedSelection into list usable by template\n        this.updateInnerSelection(this.selected);\n    }\n\n    /**\n     * Angular OnChange implementation\n     */\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (changes.selected && !changes.selected.firstChange) {\n            this.updateInnerSelection(this.selected);\n        }\n\n        if (changes.filters && !changes.filters.firstChange) {\n            this.loadRoots();\n        }\n    }\n\n    /**\n     * Toggle selection of a FlatNode, considering if multiple selection is activated or not\n     */\n    public toggleFlatNode(flatNode: HierarchicFlatNode): void {\n        if (this.multiple) {\n            // Is multiple allowed, just toggle element\n            if (this.flatNodesSelection.isSelected(flatNode)) {\n                this.unselectFlatNode(flatNode);\n            } else {\n                this.selectFlatNode(flatNode);\n            }\n        } else if (!this.multiple) {\n            if (this.flatNodesSelection.isSelected(flatNode)) {\n                this.unselectSingleFlatNode();\n            } else {\n                // If not multiple, and we want to select an element, unselect everything before to keep a single selection\n                this.selectSingleFlatNode(flatNode);\n            }\n        }\n    }\n\n    /**\n     * When unselecting an element from the mat-chips, it can be deep in the hierarchy, and the tree element may not exist...\n     * ... but we still need to remove the element from the mat-chips list.\n     */\n    public unselectModelNode(node: HierarchicModelNode): void {\n        const flatNode = this.getFlatNode(node);\n        if (flatNode) {\n            this.unselectFlatNode(flatNode);\n        } else {\n            // Remove from chips list only if no flatNode, because unselectFlatNode() already deals with it.\n            this.removeModelNode(node);\n            this.updateSelection(this.selectedNodes);\n        }\n    }\n\n    public isNodeTogglable(flatNode: HierarchicFlatNode): boolean {\n        if (this.isNodeSelected(flatNode.node)) {\n            return flatNode.deselectable;\n        } else {\n            return flatNode.selectable;\n        }\n    }\n\n    private getDisplayFn(config: NaturalHierarchicConfiguration): (item: any) => string {\n        if (config.displayWith) {\n            return config.displayWith;\n        }\n\n        if (this.displayWith) {\n            return this.displayWith;\n        }\n\n        return item => (item ? item.fullName || item.name : '');\n    }\n\n    public loadChildren(flatNode: HierarchicFlatNode): void {\n        if (this.treeControl.isExpanded(flatNode)) {\n            this.hierarchicSelectorService.loadChildren(flatNode, this.filters);\n        }\n    }\n\n    /**\n     * Created to collapse all children when closing a parent, but not sure it's good.\n     */\n    // public loadChildren(flatNode: HierarchicFlatNode) {\n    //     if (this.treeControl.isExpanded(flatNode)) {\n    //\n    //         const cachedFlatNode = this.getFlatNode(flatNode.node);\n    //         if (cachedFlatNode) {\n    //             this.hierarchicSelectorService.loadChildren(cachedFlatNode, this.filters);\n    //\n    //             // Close children\n    //             cachedFlatNode.node.children.forEach(child => {\n    //                 const childNode = this.getFlatNode(child);\n    //                 if (childNode) {\n    //                     this.treeControl.collapse(childNode);\n    //                 }\n    //             });\n    //         }\n    //     }\n    // }\n\n    private getChildren(): (node: HierarchicModelNode) => Observable<HierarchicModelNode[]> {\n        return (node: HierarchicModelNode): Observable<HierarchicModelNode[]> => {\n            return node.childrenChange;\n        };\n    }\n\n    /**\n     * Transforms a HierarchicModelNode into a FlatNode\n     */\n    private transformer(): (node: HierarchicModelNode, level: number) => HierarchicFlatNode {\n        return (node: HierarchicModelNode, level: number) => {\n            return this.getOrCreateFlatNode(node, level);\n        };\n    }\n\n    /**\n     * Return deep of the node in the tree\n     */\n    private getLevel(): (node: HierarchicFlatNode) => number {\n        return (node: HierarchicFlatNode) => {\n            return node.level;\n        };\n    }\n\n    /**\n     * Is always expandable because we load on demand, we don't know if there are children yet\n     */\n    private isExpandable(): (node: HierarchicFlatNode) => boolean {\n        return (node: HierarchicFlatNode) => {\n            return node.expandable;\n        };\n    }\n\n    private getOrCreateFlatNode(node: HierarchicModelNode, level: number): HierarchicFlatNode {\n        // Return FlatNode if exists\n        const flatNode = this.getFlatNode(node);\n        if (flatNode) {\n            return flatNode;\n        }\n\n        // Return new FlatNode\n        return this.createFlatNode(node, level);\n    }\n\n    public search(selections: NaturalSearchSelections): void {\n        this.searchSelectionChange.emit(selections);\n        if (selections.some(s => s.length)) {\n            const variables = {filter: toGraphQLDoctrineFilter(this.searchFacets, selections)};\n            this.hierarchicSelectorService.search(variables, this.filters);\n        } else {\n            this.loadRoots();\n        }\n    }\n\n    private loadRoots(searchVariables?: QueryVariables): void {\n        this.loading = true;\n        this.flatNodeMap = new Map<string, HierarchicFlatNode>();\n        this.hierarchicSelectorService\n            .init(this.config, this.filters, searchVariables || null)\n            .pipe(finalize(() => (this.loading = false)))\n            .subscribe();\n    }\n\n    /**\n     * Sync inner selection (tree and mat-chips) according to selected input attribute\n     */\n    private updateInnerSelection(selected: OrganizedModelSelection): void {\n        // Transform an OrganizedModelSelection into a ModelNode list that is used in the selected zone of the component (see template)\n        this.selectedNodes = this.hierarchicSelectorService.fromOrganizedSelection(selected);\n\n        this.flatNodesSelection.clear();\n        for (const node of this.selectedNodes) {\n            const flatNode = this.getFlatNode(node);\n            if (flatNode) {\n                this.flatNodesSelection.select(flatNode);\n            }\n        }\n    }\n\n    /**\n     * Unselect a node, keeping the rest of the selected untouched\n     */\n    private unselectFlatNode(flatNode: HierarchicFlatNode): void {\n        this.flatNodesSelection.deselect(flatNode);\n        this.removeModelNode(flatNode.node);\n        this.updateSelection(this.selectedNodes);\n    }\n\n    /**\n     * Remove a node from chip lists\n     */\n    private removeModelNode(node: HierarchicModelNode): void {\n        const key = this.getMapKey(node.model);\n        const selectionIndex = this.selectedNodes.findIndex(n => this.getMapKey(n.model) === key);\n        this.selectedNodes.splice(selectionIndex, 1);\n    }\n\n    /**\n     * Select a node, keeping th rest of the selected untouched\n     */\n    private selectFlatNode(flatNode: HierarchicFlatNode): void {\n        this.flatNodesSelection.select(flatNode);\n        this.selectedNodes.push(flatNode.node);\n        this.updateSelection(this.selectedNodes);\n    }\n\n    /**\n     * Clear all selected and select the given node\n     */\n    private selectSingleFlatNode(flatNode: HierarchicFlatNode): void {\n        this.flatNodesSelection.clear();\n        this.flatNodesSelection.select(flatNode);\n        this.selectedNodes = [flatNode.node];\n        this.updateSelection(this.selectedNodes);\n    }\n\n    /**\n     * Clear all selected and select the given node\n     */\n    private unselectSingleFlatNode(): void {\n        this.flatNodesSelection.clear();\n        this.selectedNodes = [];\n        this.updateSelection(this.selectedNodes);\n    }\n\n    /**\n     * Transform the given elements into the organized selection that is emitted to output\n     */\n    private updateSelection(selected: HierarchicModelNode[]): void {\n        const organizedFlatNodesSelection = this.hierarchicSelectorService.toOrganizedSelection(selected);\n        replaceObjectKeepingReference(this.selected, organizedFlatNodesSelection);\n        this.selectionChange.emit(organizedFlatNodesSelection);\n    }\n\n    private isNodeSelected(node: HierarchicModelNode): boolean {\n        const key = this.getMapKey(node.model);\n\n        return this.selectedNodes.some(n => this.getMapKey(n.model) === key);\n    }\n\n    private getFlatNode(node: HierarchicModelNode): HierarchicFlatNode | null {\n        const key = this.getMapKey(node.model);\n        return this.flatNodeMap.get(key) || null;\n    }\n\n    private createFlatNode(node: HierarchicModelNode, level: number): HierarchicFlatNode {\n        const key = this.getMapKey(node.model);\n        const name = this.getDisplayFn(node.config)(node.model);\n        const expandable = false;\n        const isCustomSelectable = node.config.isSelectableCallback\n            ? node.config.isSelectableCallback(node.model)\n            : true;\n        const isSelectable = !!node.config.selectableAtKey && isCustomSelectable;\n\n        const flatNode = new HierarchicFlatNode(node, name, level, expandable, isSelectable);\n\n        this.hierarchicSelectorService.countItems(flatNode, this.filters);\n\n        // Mark node as selected if needed (checks the selected processed input)\n        if (this.isNodeSelected(node)) {\n            if (!this.allowUnselect) {\n                flatNode.deselectable = false;\n            }\n            this.flatNodesSelection.select(flatNode);\n        }\n\n        // Cache FlatNode\n        this.flatNodeMap.set(key, flatNode);\n\n        return flatNode;\n    }\n\n    /**\n     * Returns an identifier key for map cache\n     * As many object types can be used, this function considers typename and ID to return something like document-123\n     */\n    private getMapKey(model: Literal): string {\n        return model.__typename + '-' + model.id;\n    }\n}\n","<div [style.margin-bottom.px]=\"20\">\n    <natural-search\n        (selectionChange)=\"search($event)\"\n        [facets]=\"searchFacets\"\n        [selections]=\"searchSelections\"\n    ></natural-search>\n</div>\n\n<div class=\"body\">\n    <mat-progress-spinner\n        *ngIf=\"loading\"\n        [diameter]=\"36\"\n        mode=\"indeterminate\"\n        style=\"margin: 10px\"\n    ></mat-progress-spinner>\n\n    <mat-tree [dataSource]=\"dataSource\" [treeControl]=\"treeControl\">\n        <mat-tree-node *matTreeNodeDef=\"let node\" [ngClass]=\"{leaf: !node.expandable}\" matTreeNodePadding>\n            <button\n                (click)=\"loadChildren(node)\"\n                *ngIf=\"node.expandable\"\n                [attr.aria-label]=\"'toggle ' + node.name\"\n                mat-icon-button\n                matTreeNodeToggle\n            >\n                <mat-progress-spinner\n                    *ngIf=\"node.loading\"\n                    [diameter]=\"24\"\n                    [strokeWidth]=\"5\"\n                    mode=\"indeterminate\"\n                ></mat-progress-spinner>\n\n                <mat-icon\n                    *ngIf=\"!node.loading\"\n                    [naturalIcon]=\"treeControl.isExpanded(node) ? 'expand_more' : 'chevron_right'\"\n                ></mat-icon>\n            </button>\n\n            <mat-checkbox\n                (change)=\"toggleFlatNode(node)\"\n                [checked]=\"flatNodesSelection.isSelected(node)\"\n                [disabled]=\"!isNodeTogglable(node)\"\n                style=\"margin-right: 10px\"\n            >\n                <mat-icon\n                    *ngIf=\"node.node.config.icon\"\n                    [naturalIcon]=\"node.node.config.icon\"\n                    style=\"margin-right: 10px\"\n                ></mat-icon>\n                <span>{{ node.name }}</span>\n            </mat-checkbox>\n        </mat-tree-node>\n    </mat-tree>\n\n    <mat-chip-listbox aria-orientation=\"vertical\" class=\"mat-mdc-chip-set-stacked\">\n        <mat-chip-option\n            (removed)=\"unselectModelNode(node)\"\n            *ngFor=\"let node of selectedNodes\"\n            [removable]=\"true\"\n            [selectable]=\"false\"\n        >\n            <mat-icon *ngIf=\"node.config.icon\" [naturalIcon]=\"node.config.icon\"></mat-icon>\n            <div class=\"mat-body chip-label\">{{ node.model.name || node.model.fullName }}</div>\n            <mat-icon matChipRemove naturalIcon=\"cancel\"></mat-icon>\n        </mat-chip-option>\n    </mat-chip-listbox>\n</div>\n\n<div *ngIf=\"!loading && !dataSource.data.length\" class=\"margin-v\" i18n>Aucun résultat</div>\n"]}