@ecodev/natural 61.0.0 → 61.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (138) hide show
  1. package/esm2022/lib/classes/abstract-detail.mjs +36 -33
  2. package/esm2022/lib/classes/abstract-editable-list.mjs +8 -6
  3. package/esm2022/lib/classes/abstract-list.mjs +74 -55
  4. package/esm2022/lib/classes/abstract-navigable-list.mjs +9 -9
  5. package/esm2022/lib/classes/cumulative-changes.mjs +3 -5
  6. package/esm2022/lib/classes/data-source.mjs +3 -2
  7. package/esm2022/lib/classes/query-variable-manager.mjs +3 -3
  8. package/esm2022/lib/directives/http-prefix.directive.mjs +4 -6
  9. package/esm2022/lib/modules/alert/alert.service.mjs +9 -11
  10. package/esm2022/lib/modules/alert/confirm.component.mjs +6 -11
  11. package/esm2022/lib/modules/avatar/component/avatar.component.mjs +25 -23
  12. package/esm2022/lib/modules/avatar/service/avatar.service.mjs +22 -24
  13. package/esm2022/lib/modules/avatar/sources/source.mjs +2 -1
  14. package/esm2022/lib/modules/columns-picker/columns-picker.component.mjs +26 -28
  15. package/esm2022/lib/modules/columns-picker/public-api.mjs +1 -1
  16. package/esm2022/lib/modules/common/directives/background-density.directive.mjs +6 -8
  17. package/esm2022/lib/modules/common/directives/linkable-tab.directive.mjs +18 -19
  18. package/esm2022/lib/modules/common/directives/src-density.directive.mjs +6 -8
  19. package/esm2022/lib/modules/common/pipes/capitalize.pipe.mjs +3 -3
  20. package/esm2022/lib/modules/common/pipes/ellipsis.pipe.mjs +3 -3
  21. package/esm2022/lib/modules/common/pipes/enum.pipe.mjs +7 -9
  22. package/esm2022/lib/modules/common/pipes/time-ago.pipe.mjs +4 -3
  23. package/esm2022/lib/modules/common/public-api.mjs +2 -2
  24. package/esm2022/lib/modules/common/services/memory-storage.mjs +4 -6
  25. package/esm2022/lib/modules/common/services/seo.service.mjs +18 -26
  26. package/esm2022/lib/modules/detail-header/detail-header.component.mjs +38 -33
  27. package/esm2022/lib/modules/dialog-trigger/dialog-trigger.component.mjs +13 -11
  28. package/esm2022/lib/modules/dropdown-components/abstract-association-select-component.directive.mjs +13 -12
  29. package/esm2022/lib/modules/dropdown-components/public-api.mjs +3 -3
  30. package/esm2022/lib/modules/dropdown-components/type-boolean/type-boolean.component.mjs +10 -13
  31. package/esm2022/lib/modules/dropdown-components/type-date/type-date.component.mjs +29 -33
  32. package/esm2022/lib/modules/dropdown-components/type-date-range/type-date-range.component.mjs +27 -32
  33. package/esm2022/lib/modules/dropdown-components/type-hierarchic-selector/type-hierarchic-selector.component.mjs +3 -3
  34. package/esm2022/lib/modules/dropdown-components/type-natural-select/type-natural-select.component.mjs +3 -3
  35. package/esm2022/lib/modules/dropdown-components/type-number/type-number.component.mjs +29 -30
  36. package/esm2022/lib/modules/dropdown-components/type-options/type-options.component.mjs +17 -15
  37. package/esm2022/lib/modules/dropdown-components/type-select/type-select.component.mjs +25 -25
  38. package/esm2022/lib/modules/dropdown-components/type-text/type-text.component.mjs +15 -17
  39. package/esm2022/lib/modules/file/abstract-file.mjs +51 -47
  40. package/esm2022/lib/modules/file/component/file.component.mjs +51 -41
  41. package/esm2022/lib/modules/file/file-drop.directive.mjs +10 -13
  42. package/esm2022/lib/modules/file/file-select.directive.mjs +9 -12
  43. package/esm2022/lib/modules/file/file.service.mjs +15 -20
  44. package/esm2022/lib/modules/file/public-api.mjs +1 -1
  45. package/esm2022/lib/modules/fixed-button/fixed-button.component.mjs +7 -8
  46. package/esm2022/lib/modules/fixed-button-detail/fixed-button-detail.component.mjs +15 -12
  47. package/esm2022/lib/modules/hierarchic-selector/classes/flat-node.mjs +8 -2
  48. package/esm2022/lib/modules/hierarchic-selector/classes/model-node.mjs +4 -2
  49. package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.mjs +71 -55
  50. package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.service.mjs +18 -20
  51. package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.component.mjs +17 -11
  52. package/esm2022/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.service.mjs +7 -9
  53. package/esm2022/lib/modules/icon/icon.directive.mjs +15 -23
  54. package/esm2022/lib/modules/logger/error-handler.mjs +11 -25
  55. package/esm2022/lib/modules/logger/public-api.mjs +2 -2
  56. package/esm2022/lib/modules/matomo/matomo.service.mjs +15 -22
  57. package/esm2022/lib/modules/panels/abstract-panel.mjs +23 -19
  58. package/esm2022/lib/modules/panels/panels.component.mjs +10 -9
  59. package/esm2022/lib/modules/panels/panels.service.mjs +56 -52
  60. package/esm2022/lib/modules/relations/relations.component.mjs +74 -45
  61. package/esm2022/lib/modules/search/dropdown-container/dropdown-container.component.mjs +21 -22
  62. package/esm2022/lib/modules/search/dropdown-container/dropdown-ref.mjs +4 -2
  63. package/esm2022/lib/modules/search/dropdown-container/dropdown.service.mjs +8 -11
  64. package/esm2022/lib/modules/search/facet-selector/facet-selector.component.mjs +13 -18
  65. package/esm2022/lib/modules/search/group/group.component.mjs +12 -11
  66. package/esm2022/lib/modules/search/input/input.component.mjs +86 -73
  67. package/esm2022/lib/modules/search/public-api.mjs +1 -1
  68. package/esm2022/lib/modules/search/search/search.component.mjs +37 -40
  69. package/esm2022/lib/modules/select/abstract-select.component.mjs +66 -39
  70. package/esm2022/lib/modules/select/select/select.component.mjs +51 -48
  71. package/esm2022/lib/modules/select/select-enum/select-enum.component.mjs +32 -22
  72. package/esm2022/lib/modules/select/select-hierarchic/select-hierarchic.component.mjs +39 -34
  73. package/esm2022/lib/modules/sidenav/sidenav/sidenav.component.mjs +3 -3
  74. package/esm2022/lib/modules/sidenav/sidenav-container/sidenav-container.component.mjs +34 -29
  75. package/esm2022/lib/modules/sidenav/sidenav-content/sidenav-content.component.mjs +3 -3
  76. package/esm2022/lib/modules/sidenav/sidenav-stack.service.mjs +13 -15
  77. package/esm2022/lib/modules/sidenav/sidenav.service.mjs +47 -54
  78. package/esm2022/lib/modules/stamp/stamp.component.mjs +4 -3
  79. package/esm2022/lib/modules/table-button/table-button.component.mjs +16 -13
  80. package/esm2022/lib/services/abstract-model.service.mjs +17 -7
  81. package/esm2022/lib/services/debounce.service.mjs +7 -9
  82. package/esm2022/lib/services/enum.service.mjs +7 -10
  83. package/esm2022/lib/services/link-mutation.service.mjs +11 -10
  84. package/esm2022/lib/services/persistence.service.mjs +9 -21
  85. package/esm2022/lib/services/swiss-parsing-date-adapter.service.mjs +3 -3
  86. package/esm2022/public-api.mjs +2 -2
  87. package/fesm2022/ecodev-natural.mjs +1357 -1270
  88. package/fesm2022/ecodev-natural.mjs.map +1 -1
  89. package/lib/modules/alert/alert.service.d.ts +1 -3
  90. package/lib/modules/alert/confirm.component.d.ts +1 -2
  91. package/lib/modules/avatar/component/avatar.component.d.ts +0 -2
  92. package/lib/modules/columns-picker/columns-picker.component.d.ts +1 -3
  93. package/lib/modules/columns-picker/public-api.d.ts +1 -1
  94. package/lib/modules/common/directives/background-density.directive.d.ts +0 -2
  95. package/lib/modules/common/directives/linkable-tab.directive.d.ts +2 -4
  96. package/lib/modules/common/directives/src-density.directive.d.ts +0 -2
  97. package/lib/modules/common/pipes/enum.pipe.d.ts +0 -2
  98. package/lib/modules/common/public-api.d.ts +2 -1
  99. package/lib/modules/common/services/seo.service.d.ts +2 -3
  100. package/lib/modules/dialog-trigger/dialog-trigger.component.d.ts +3 -3
  101. package/lib/modules/dropdown-components/public-api.d.ts +9 -9
  102. package/lib/modules/dropdown-components/type-boolean/type-boolean.component.d.ts +1 -3
  103. package/lib/modules/dropdown-components/type-date/type-date.component.d.ts +1 -3
  104. package/lib/modules/dropdown-components/type-date-range/type-date-range.component.d.ts +2 -3
  105. package/lib/modules/dropdown-components/type-number/type-number.component.d.ts +1 -2
  106. package/lib/modules/dropdown-components/type-options/type-options.component.d.ts +3 -3
  107. package/lib/modules/dropdown-components/type-select/type-select.component.d.ts +1 -2
  108. package/lib/modules/dropdown-components/type-text/type-text.component.d.ts +1 -2
  109. package/lib/modules/file/component/file.component.d.ts +0 -3
  110. package/lib/modules/file/file.service.d.ts +0 -1
  111. package/lib/modules/file/public-api.d.ts +1 -1
  112. package/lib/modules/fixed-button-detail/fixed-button-detail.component.d.ts +1 -2
  113. package/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.d.ts +2 -3
  114. package/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.service.d.ts +0 -2
  115. package/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.component.d.ts +1 -2
  116. package/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.service.d.ts +1 -2
  117. package/lib/modules/icon/icon.directive.d.ts +3 -5
  118. package/lib/modules/logger/error-handler.d.ts +3 -4
  119. package/lib/modules/logger/public-api.d.ts +2 -1
  120. package/lib/modules/matomo/matomo.service.d.ts +2 -5
  121. package/lib/modules/panels/panels.component.d.ts +1 -3
  122. package/lib/modules/panels/panels.service.d.ts +2 -6
  123. package/lib/modules/relations/relations.component.d.ts +3 -5
  124. package/lib/modules/search/dropdown-container/dropdown-container.component.d.ts +3 -4
  125. package/lib/modules/search/dropdown-container/dropdown.service.d.ts +1 -3
  126. package/lib/modules/search/facet-selector/facet-selector.component.d.ts +1 -2
  127. package/lib/modules/search/input/input.component.d.ts +1 -3
  128. package/lib/modules/search/public-api.d.ts +5 -5
  129. package/lib/modules/search/search/search.component.d.ts +0 -2
  130. package/lib/modules/select/select-enum/select-enum.component.d.ts +4 -4
  131. package/lib/modules/select/select-hierarchic/select-hierarchic.component.d.ts +4 -4
  132. package/lib/modules/sidenav/sidenav-container/sidenav-container.component.d.ts +0 -1
  133. package/lib/modules/sidenav/sidenav.service.d.ts +2 -7
  134. package/lib/services/enum.service.d.ts +0 -2
  135. package/lib/services/link-mutation.service.d.ts +0 -2
  136. package/lib/services/persistence.service.d.ts +2 -4
  137. package/package.json +1 -1
  138. package/public-api.d.ts +3 -2
@@ -1,6 +1,8 @@
1
- import { Component, EventEmitter, HostBinding, Inject, Input, Output, } from '@angular/core';
1
+ import { Component, EventEmitter, HostBinding, Input, Output, inject, } from '@angular/core';
2
2
  import { of, Subject, tap } from 'rxjs';
3
+ import { NaturalFileService } from '../file.service';
3
4
  import { CommonModule, DOCUMENT } from '@angular/common';
5
+ import { NaturalAlertService } from '../../alert/alert.service';
4
6
  import { NaturalCapitalizePipe } from '../../common/pipes/capitalize.pipe';
5
7
  import { NaturalIconDirective } from '../../icon/icon.directive';
6
8
  import { MatIconModule } from '@angular/material/icon';
@@ -8,41 +10,52 @@ import { MatRippleModule } from '@angular/material/core';
8
10
  import { NaturalFileDropDirective } from '../file-drop.directive';
9
11
  import { NaturalBackgroundDensityDirective } from '../../common/directives/background-density.directive';
10
12
  import * as i0 from "@angular/core";
11
- import * as i1 from "../file.service";
12
- import * as i2 from "../../alert/alert.service";
13
- import * as i3 from "@angular/material/core";
14
- import * as i4 from "@angular/common";
15
- import * as i5 from "@angular/material/icon";
13
+ import * as i1 from "@angular/material/core";
14
+ import * as i2 from "@angular/common";
15
+ import * as i3 from "@angular/material/icon";
16
16
  // @dynamic
17
17
  export class NaturalFileComponent {
18
- constructor(naturalFileService, alertService, document) {
19
- this.naturalFileService = naturalFileService;
20
- this.alertService = alertService;
21
- this.document = document;
22
- this.height = 250;
23
- this.action = null;
24
- this.backgroundSize = 'contain';
25
- /**
26
- * Comma-separated list of unique file type specifiers. Like the native element,
27
- * it can be a mix of mime-type and file extensions.
28
- *
29
- * See https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/file#accept
30
- */
31
- this.accept = 'image/bmp,image/gif,image/jpeg,image/pjpeg,image/png,image/svg+xml,image/svg,image/webp';
32
- this.model = null;
33
- /**
34
- * If provided, its value will get updated when the model changes.
35
- * But its value is never read, so if you want to set a value use `[model]` instead.
36
- */
37
- this.formCtrl = null;
38
- /**
39
- * This **must not** be used to mutate the server, because it is very likely it will never be called if the
40
- * human navigates away from the page before the upload is finished. Instead, you should use `[uploader]`.
41
- */
42
- this.modelChange = new EventEmitter();
43
- this.imagePreview = '';
44
- this.filePreview = null;
45
- }
18
+ naturalFileService = inject(NaturalFileService);
19
+ alertService = inject(NaturalAlertService);
20
+ document = inject(DOCUMENT);
21
+ height = 250;
22
+ action = null;
23
+ backgroundSize = 'contain';
24
+ /**
25
+ * Comma-separated list of unique file type specifiers. Like the native element,
26
+ * it can be a mix of mime-type and file extensions.
27
+ *
28
+ * See https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/file#accept
29
+ */
30
+ accept = 'image/bmp,image/gif,image/jpeg,image/pjpeg,image/png,image/svg+xml,image/svg,image/webp';
31
+ /**
32
+ * If given, it will be called when a new file is selected. The callback should typically upload the file
33
+ * to the server and link the newly uploaded file to the existing related object.
34
+ *
35
+ * The callback **must** be able to run even if the calling component has been destroyed. That means in most
36
+ * cases you **must** `bind()` the callback explicitly, like so:
37
+ *
38
+ * ```html
39
+ * <natural-file [uploader]="myCallback.bind(this)" />
40
+ * ```
41
+ *
42
+ * Also, you probably **should** set a `[formCtrl]` so that the form is updated automatically, instead of doing
43
+ * it manually within the callback.
44
+ */
45
+ uploader;
46
+ model = null;
47
+ /**
48
+ * If provided, its value will get updated when the model changes.
49
+ * But its value is never read, so if you want to set a value use `[model]` instead.
50
+ */
51
+ formCtrl = null;
52
+ /**
53
+ * This **must not** be used to mutate the server, because it is very likely it will never be called if the
54
+ * human navigates away from the page before the upload is finished. Instead, you should use `[uploader]`.
55
+ */
56
+ modelChange = new EventEmitter();
57
+ imagePreview = '';
58
+ filePreview = null;
46
59
  ngOnChanges(changes) {
47
60
  if (changes.model && changes.model.previousValue !== changes.model.currentValue) {
48
61
  this.updateImage();
@@ -123,8 +136,8 @@ export class NaturalFileComponent {
123
136
  reader.readAsBinaryString(file);
124
137
  return subject.asObservable();
125
138
  }
126
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileComponent, deps: [{ token: i1.NaturalFileService }, { token: i2.NaturalAlertService }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Component }); }
127
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: NaturalFileComponent, isStandalone: true, selector: "natural-file", inputs: { height: "height", action: "action", backgroundSize: "backgroundSize", accept: "accept", uploader: "uploader", model: "model", formCtrl: "formCtrl" }, outputs: { modelChange: "modelChange" }, host: { properties: { "style.height.px": "this.height" } }, usesOnChanges: true, ngImport: i0, template: "<a\n (fileChange)=\"upload($event)\"\n naturalFileDrop\n [selectable]=\"true\"\n [accept]=\"accept\"\n [attr.href]=\"getDownloadLink()\"\n [class.has-action]=\"!!action\"\n [class.suggest-upload]=\"!model && action === 'upload'\"\n [fileSelectionDisabled]=\"action !== 'upload'\"\n [matRippleDisabled]=\"!action\"\n [naturalBackgroundDensity]=\"imagePreview\"\n [style.backgroundSize]=\"backgroundSize\"\n matRipple\n target=\"_blank\"\n>\n @if (filePreview) {\n <div class=\"file-preview\">\n <mat-icon [size]=\"height * 0.33\" naturalIcon=\"attachment\" />\n {{ filePreview | uppercase }}\n </div>\n }\n\n <div class=\"action-overlay\">\n @if (action === 'upload') {\n <mat-icon [size]=\"height * 0.66\" naturalIcon=\"cloud_upload\" />\n }\n @if (action === 'download') {\n <mat-icon [size]=\"height * 0.66\" naturalIcon=\"get_app\" />\n }\n {{ action | capitalize }}\n </div>\n</a>\n", styles: [":host{display:flex;position:relative;flex-direction:row;overflow:hidden}:host>a{position:relative;flex:1;background-position:center;background-repeat:no-repeat}:host>a.has-action{cursor:pointer}:host>a.has-action.suggest-upload .action-overlay{opacity:.66}:host>a.has-action:hover .action-overlay,:host>a.has-action.natural-file-over .action-overlay{opacity:1}:host .action-overlay,:host .file-preview{display:flex;position:absolute;inset:0;flex-direction:column;justify-content:center;align-items:center;font-size:36px;line-height:1.3em;text-align:center}:host .action-overlay{opacity:0}:host .action-overlay>div{display:flex;position:absolute;inset:0;justify-content:center;align-items:center;opacity:0}\n"], dependencies: [{ kind: "directive", type: NaturalFileDropDirective, selector: ":not([naturalFileSelect])[naturalFileDrop]", outputs: ["fileOver"] }, { kind: "ngmodule", type: MatRippleModule }, { kind: "directive", type: i3.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i4.UpperCasePipe, name: "uppercase" }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: NaturalIconDirective, selector: "mat-icon[naturalIcon]", inputs: ["naturalIcon", "size"] }, { kind: "pipe", type: NaturalCapitalizePipe, name: "capitalize" }, { kind: "directive", type: NaturalBackgroundDensityDirective, selector: "[naturalBackgroundDensity]", inputs: ["naturalBackgroundDensity"] }] }); }
139
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
140
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: NaturalFileComponent, isStandalone: true, selector: "natural-file", inputs: { height: "height", action: "action", backgroundSize: "backgroundSize", accept: "accept", uploader: "uploader", model: "model", formCtrl: "formCtrl" }, outputs: { modelChange: "modelChange" }, host: { properties: { "style.height.px": "this.height" } }, usesOnChanges: true, ngImport: i0, template: "<a\n (fileChange)=\"upload($event)\"\n naturalFileDrop\n [selectable]=\"true\"\n [accept]=\"accept\"\n [attr.href]=\"getDownloadLink()\"\n [class.has-action]=\"!!action\"\n [class.suggest-upload]=\"!model && action === 'upload'\"\n [fileSelectionDisabled]=\"action !== 'upload'\"\n [matRippleDisabled]=\"!action\"\n [naturalBackgroundDensity]=\"imagePreview\"\n [style.backgroundSize]=\"backgroundSize\"\n matRipple\n target=\"_blank\"\n>\n @if (filePreview) {\n <div class=\"file-preview\">\n <mat-icon [size]=\"height * 0.33\" naturalIcon=\"attachment\" />\n {{ filePreview | uppercase }}\n </div>\n }\n\n <div class=\"action-overlay\">\n @if (action === 'upload') {\n <mat-icon [size]=\"height * 0.66\" naturalIcon=\"cloud_upload\" />\n }\n @if (action === 'download') {\n <mat-icon [size]=\"height * 0.66\" naturalIcon=\"get_app\" />\n }\n {{ action | capitalize }}\n </div>\n</a>\n", styles: [":host{display:flex;position:relative;flex-direction:row;overflow:hidden}:host>a{position:relative;flex:1;background-position:center;background-repeat:no-repeat}:host>a.has-action{cursor:pointer}:host>a.has-action.suggest-upload .action-overlay{opacity:.66}:host>a.has-action:hover .action-overlay,:host>a.has-action.natural-file-over .action-overlay{opacity:1}:host .action-overlay,:host .file-preview{display:flex;position:absolute;inset:0;flex-direction:column;justify-content:center;align-items:center;font-size:36px;line-height:1.3em;text-align:center}:host .action-overlay{opacity:0}:host .action-overlay>div{display:flex;position:absolute;inset:0;justify-content:center;align-items:center;opacity:0}\n"], dependencies: [{ kind: "directive", type: NaturalFileDropDirective, selector: ":not([naturalFileSelect])[naturalFileDrop]", outputs: ["fileOver"] }, { kind: "ngmodule", type: MatRippleModule }, { kind: "directive", type: i1.MatRipple, selector: "[mat-ripple], [matRipple]", inputs: ["matRippleColor", "matRippleUnbounded", "matRippleCentered", "matRippleRadius", "matRippleAnimation", "matRippleDisabled", "matRippleTrigger"], exportAs: ["matRipple"] }, { kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: i2.UpperCasePipe, name: "uppercase" }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: NaturalIconDirective, selector: "mat-icon[naturalIcon]", inputs: ["naturalIcon", "size"] }, { kind: "pipe", type: NaturalCapitalizePipe, name: "capitalize" }, { kind: "directive", type: NaturalBackgroundDensityDirective, selector: "[naturalBackgroundDensity]", inputs: ["naturalBackgroundDensity"] }] });
128
141
  }
129
142
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileComponent, decorators: [{
130
143
  type: Component,
@@ -137,10 +150,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImpor
137
150
  NaturalCapitalizePipe,
138
151
  NaturalBackgroundDensityDirective,
139
152
  ], template: "<a\n (fileChange)=\"upload($event)\"\n naturalFileDrop\n [selectable]=\"true\"\n [accept]=\"accept\"\n [attr.href]=\"getDownloadLink()\"\n [class.has-action]=\"!!action\"\n [class.suggest-upload]=\"!model && action === 'upload'\"\n [fileSelectionDisabled]=\"action !== 'upload'\"\n [matRippleDisabled]=\"!action\"\n [naturalBackgroundDensity]=\"imagePreview\"\n [style.backgroundSize]=\"backgroundSize\"\n matRipple\n target=\"_blank\"\n>\n @if (filePreview) {\n <div class=\"file-preview\">\n <mat-icon [size]=\"height * 0.33\" naturalIcon=\"attachment\" />\n {{ filePreview | uppercase }}\n </div>\n }\n\n <div class=\"action-overlay\">\n @if (action === 'upload') {\n <mat-icon [size]=\"height * 0.66\" naturalIcon=\"cloud_upload\" />\n }\n @if (action === 'download') {\n <mat-icon [size]=\"height * 0.66\" naturalIcon=\"get_app\" />\n }\n {{ action | capitalize }}\n </div>\n</a>\n", styles: [":host{display:flex;position:relative;flex-direction:row;overflow:hidden}:host>a{position:relative;flex:1;background-position:center;background-repeat:no-repeat}:host>a.has-action{cursor:pointer}:host>a.has-action.suggest-upload .action-overlay{opacity:.66}:host>a.has-action:hover .action-overlay,:host>a.has-action.natural-file-over .action-overlay{opacity:1}:host .action-overlay,:host .file-preview{display:flex;position:absolute;inset:0;flex-direction:column;justify-content:center;align-items:center;font-size:36px;line-height:1.3em;text-align:center}:host .action-overlay{opacity:0}:host .action-overlay>div{display:flex;position:absolute;inset:0;justify-content:center;align-items:center;opacity:0}\n"] }]
140
- }], ctorParameters: () => [{ type: i1.NaturalFileService }, { type: i2.NaturalAlertService }, { type: Document, decorators: [{
141
- type: Inject,
142
- args: [DOCUMENT]
143
- }] }], propDecorators: { height: [{
153
+ }], propDecorators: { height: [{
144
154
  type: HostBinding,
145
155
  args: ['style.height.px']
146
156
  }, {
@@ -160,4 +170,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImpor
160
170
  }], modelChange: [{
161
171
  type: Output
162
172
  }] } });
163
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/file/component/file.component.ts","../../../../../../../projects/natural/src/lib/modules/file/component/file.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    EventEmitter,\n    HostBinding,\n    Inject,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChanges,\n} from '@angular/core';\nimport {AbstractControl} from '@angular/forms';\nimport {Observable, of, Subject, tap} from 'rxjs';\nimport {NaturalFileService} from '../file.service';\nimport {CommonModule, DOCUMENT} from '@angular/common';\nimport {FileModel} from '../types';\nimport {NaturalAlertService} from '../../alert/alert.service';\nimport {NaturalCapitalizePipe} from '../../common/pipes/capitalize.pipe';\nimport {NaturalIconDirective} from '../../icon/icon.directive';\nimport {MatIconModule} from '@angular/material/icon';\nimport {MatRippleModule} from '@angular/material/core';\nimport {NaturalFileDropDirective} from '../file-drop.directive';\nimport {NaturalBackgroundDensityDirective} from '../../common/directives/background-density.directive';\n\n// @dynamic\n@Component({\n    selector: 'natural-file',\n    templateUrl: './file.component.html',\n    styleUrl: './file.component.scss',\n    standalone: true,\n    imports: [\n        NaturalFileDropDirective,\n        MatRippleModule,\n        CommonModule,\n        MatIconModule,\n        NaturalIconDirective,\n        NaturalCapitalizePipe,\n        NaturalBackgroundDensityDirective,\n    ],\n})\nexport class NaturalFileComponent implements OnInit, OnChanges {\n    @HostBinding('style.height.px') @Input() public height = 250;\n\n    @Input() public action: 'upload' | 'download' | null = null;\n\n    @Input() public backgroundSize = 'contain';\n\n    /**\n     * Comma-separated list of unique file type specifiers. Like the native element,\n     * it can be a mix of mime-type and file extensions.\n     *\n     * See https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/file#accept\n     */\n    @Input() public accept = 'image/bmp,image/gif,image/jpeg,image/pjpeg,image/png,image/svg+xml,image/svg,image/webp';\n\n    /**\n     * If given, it will be called when a new file is selected. The callback should typically upload the file\n     * to the server and link the newly uploaded file to the existing related object.\n     *\n     * The callback **must** be able to run even if the calling component has been destroyed. That means in most\n     * cases you **must** `bind()` the callback explicitly, like so:\n     *\n     * ```html\n     * <natural-file [uploader]=\"myCallback.bind(this)\" />\n     * ```\n     *\n     * Also, you probably **should** set a `[formCtrl]` so that the form is updated automatically, instead of doing\n     * it manually within the callback.\n     */\n    @Input() public uploader?: (file: File) => Observable<FileModel>;\n\n    @Input() public model: FileModel | null = null;\n\n    /**\n     * If provided, its value will get updated when the model changes.\n     * But its value is never read, so if you want to set a value use `[model]` instead.\n     */\n    @Input() public formCtrl: AbstractControl | null | undefined = null;\n\n    /**\n     * This **must not** be used to mutate the server, because it is very likely it will never be called if the\n     * human navigates away from the page before the upload is finished. Instead, you should use `[uploader]`.\n     */\n    @Output() public readonly modelChange = new EventEmitter<FileModel>();\n\n    public imagePreview = '';\n    public filePreview: string | null = null;\n\n    public constructor(\n        private readonly naturalFileService: NaturalFileService,\n        private readonly alertService: NaturalAlertService,\n        @Inject(DOCUMENT) private readonly document: Document,\n    ) {}\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (changes.model && changes.model.previousValue !== changes.model.currentValue) {\n            this.updateImage();\n        }\n    }\n\n    public ngOnInit(): void {\n        this.updateImage();\n    }\n\n    public upload(file: File): void {\n        this.model = {file: file};\n        this.updateImage();\n\n        if (this.formCtrl) {\n            this.formCtrl.setValue(this.model);\n        }\n\n        const observable =\n            this.uploader?.(file).pipe(tap(() => this.alertService.info($localize`Mis à jour`))) ?? of(this.model);\n\n        observable.subscribe(result => {\n            this.model = result;\n            if (this.formCtrl) {\n                this.formCtrl.setValue(this.model);\n            }\n\n            this.modelChange.emit(this.model);\n        });\n    }\n\n    public getDownloadLink(): null | string {\n        if (this.action !== 'download') {\n            return null;\n        }\n\n        return this.naturalFileService.getDownloadLink(this.model);\n    }\n\n    private updateImage(): void {\n        this.imagePreview = '';\n        this.filePreview = null;\n        if (!this.model) {\n            return;\n        }\n\n        if (this.model.file?.type.includes('image/')) {\n            // Model from upload (before saving)\n            this.getBase64(this.model.file).subscribe(result => {\n                if (this.model?.file?.type) {\n                    const content = 'url(data:' + this.model?.file?.type + ';base64,' + result + ')';\n                    this.imagePreview = content;\n                }\n            });\n        } else if (this.model.file) {\n            this.filePreview = this.model.file.type.split('/')[1];\n        } else if (this.model.__typename === 'Image' && this.model.id) {\n            // Model image with id, use specific API to render image by size\n            const window = this.document.defaultView;\n            if (!window) {\n                throw new Error('Could not show image preview because `window` is undefined');\n            }\n\n            const loc = window.location;\n            const height = this.height ? '/' + this.height : '';\n\n            // create image url without port to stay compatible with dev mode\n            const image = loc.protocol + '//' + loc.hostname + '/api/image/' + this.model.id + height;\n            this.imagePreview = image;\n        } else if (this.model?.mime && ['File', 'AccountingDocument'].includes(this.model.__typename || '')) {\n            this.filePreview = this.model.mime.split('/')[1];\n        } else if (this.model.src) {\n            // external url\n            this.imagePreview = this.model.src;\n        }\n    }\n\n    private getBase64(file: File | null): Observable<string> {\n        if (!file) {\n            return of('');\n        }\n\n        const subject = new Subject<string>();\n\n        const reader = new FileReader();\n        reader.addEventListener('load', (ev: any) => {\n            subject.next(btoa(ev.target.result));\n            subject.complete();\n        });\n        reader.readAsBinaryString(file);\n\n        return subject.asObservable();\n    }\n}\n","<a\n    (fileChange)=\"upload($event)\"\n    naturalFileDrop\n    [selectable]=\"true\"\n    [accept]=\"accept\"\n    [attr.href]=\"getDownloadLink()\"\n    [class.has-action]=\"!!action\"\n    [class.suggest-upload]=\"!model && action === 'upload'\"\n    [fileSelectionDisabled]=\"action !== 'upload'\"\n    [matRippleDisabled]=\"!action\"\n    [naturalBackgroundDensity]=\"imagePreview\"\n    [style.backgroundSize]=\"backgroundSize\"\n    matRipple\n    target=\"_blank\"\n>\n    @if (filePreview) {\n        <div class=\"file-preview\">\n            <mat-icon [size]=\"height * 0.33\" naturalIcon=\"attachment\" />\n            {{ filePreview | uppercase }}\n        </div>\n    }\n\n    <div class=\"action-overlay\">\n        @if (action === 'upload') {\n            <mat-icon [size]=\"height * 0.66\" naturalIcon=\"cloud_upload\" />\n        }\n        @if (action === 'download') {\n            <mat-icon [size]=\"height * 0.66\" naturalIcon=\"get_app\" />\n        }\n        {{ action | capitalize }}\n    </div>\n</a>\n"]}
173
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file.component.js","sourceRoot":"","sources":["../../../../../../../projects/natural/src/lib/modules/file/component/file.component.ts","../../../../../../../projects/natural/src/lib/modules/file/component/file.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    EventEmitter,\n    HostBinding,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChanges,\n    inject,\n} from '@angular/core';\nimport {AbstractControl} from '@angular/forms';\nimport {Observable, of, Subject, tap} from 'rxjs';\nimport {NaturalFileService} from '../file.service';\nimport {CommonModule, DOCUMENT} from '@angular/common';\nimport {FileModel} from '../types';\nimport {NaturalAlertService} from '../../alert/alert.service';\nimport {NaturalCapitalizePipe} from '../../common/pipes/capitalize.pipe';\nimport {NaturalIconDirective} from '../../icon/icon.directive';\nimport {MatIconModule} from '@angular/material/icon';\nimport {MatRippleModule} from '@angular/material/core';\nimport {NaturalFileDropDirective} from '../file-drop.directive';\nimport {NaturalBackgroundDensityDirective} from '../../common/directives/background-density.directive';\n\n// @dynamic\n@Component({\n    selector: 'natural-file',\n    templateUrl: './file.component.html',\n    styleUrl: './file.component.scss',\n    standalone: true,\n    imports: [\n        NaturalFileDropDirective,\n        MatRippleModule,\n        CommonModule,\n        MatIconModule,\n        NaturalIconDirective,\n        NaturalCapitalizePipe,\n        NaturalBackgroundDensityDirective,\n    ],\n})\nexport class NaturalFileComponent implements OnInit, OnChanges {\n    private readonly naturalFileService = inject(NaturalFileService);\n    private readonly alertService = inject(NaturalAlertService);\n    private readonly document = inject<Document>(DOCUMENT);\n\n    @HostBinding('style.height.px') @Input() public height = 250;\n\n    @Input() public action: 'upload' | 'download' | null = null;\n\n    @Input() public backgroundSize = 'contain';\n\n    /**\n     * Comma-separated list of unique file type specifiers. Like the native element,\n     * it can be a mix of mime-type and file extensions.\n     *\n     * See https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/file#accept\n     */\n    @Input() public accept = 'image/bmp,image/gif,image/jpeg,image/pjpeg,image/png,image/svg+xml,image/svg,image/webp';\n\n    /**\n     * If given, it will be called when a new file is selected. The callback should typically upload the file\n     * to the server and link the newly uploaded file to the existing related object.\n     *\n     * The callback **must** be able to run even if the calling component has been destroyed. That means in most\n     * cases you **must** `bind()` the callback explicitly, like so:\n     *\n     * ```html\n     * <natural-file [uploader]=\"myCallback.bind(this)\" />\n     * ```\n     *\n     * Also, you probably **should** set a `[formCtrl]` so that the form is updated automatically, instead of doing\n     * it manually within the callback.\n     */\n    @Input() public uploader?: (file: File) => Observable<FileModel>;\n\n    @Input() public model: FileModel | null = null;\n\n    /**\n     * If provided, its value will get updated when the model changes.\n     * But its value is never read, so if you want to set a value use `[model]` instead.\n     */\n    @Input() public formCtrl: AbstractControl | null | undefined = null;\n\n    /**\n     * This **must not** be used to mutate the server, because it is very likely it will never be called if the\n     * human navigates away from the page before the upload is finished. Instead, you should use `[uploader]`.\n     */\n    @Output() public readonly modelChange = new EventEmitter<FileModel>();\n\n    public imagePreview = '';\n    public filePreview: string | null = null;\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (changes.model && changes.model.previousValue !== changes.model.currentValue) {\n            this.updateImage();\n        }\n    }\n\n    public ngOnInit(): void {\n        this.updateImage();\n    }\n\n    public upload(file: File): void {\n        this.model = {file: file};\n        this.updateImage();\n\n        if (this.formCtrl) {\n            this.formCtrl.setValue(this.model);\n        }\n\n        const observable =\n            this.uploader?.(file).pipe(tap(() => this.alertService.info($localize`Mis à jour`))) ?? of(this.model);\n\n        observable.subscribe(result => {\n            this.model = result;\n            if (this.formCtrl) {\n                this.formCtrl.setValue(this.model);\n            }\n\n            this.modelChange.emit(this.model);\n        });\n    }\n\n    public getDownloadLink(): null | string {\n        if (this.action !== 'download') {\n            return null;\n        }\n\n        return this.naturalFileService.getDownloadLink(this.model);\n    }\n\n    private updateImage(): void {\n        this.imagePreview = '';\n        this.filePreview = null;\n        if (!this.model) {\n            return;\n        }\n\n        if (this.model.file?.type.includes('image/')) {\n            // Model from upload (before saving)\n            this.getBase64(this.model.file).subscribe(result => {\n                if (this.model?.file?.type) {\n                    const content = 'url(data:' + this.model?.file?.type + ';base64,' + result + ')';\n                    this.imagePreview = content;\n                }\n            });\n        } else if (this.model.file) {\n            this.filePreview = this.model.file.type.split('/')[1];\n        } else if (this.model.__typename === 'Image' && this.model.id) {\n            // Model image with id, use specific API to render image by size\n            const window = this.document.defaultView;\n            if (!window) {\n                throw new Error('Could not show image preview because `window` is undefined');\n            }\n\n            const loc = window.location;\n            const height = this.height ? '/' + this.height : '';\n\n            // create image url without port to stay compatible with dev mode\n            const image = loc.protocol + '//' + loc.hostname + '/api/image/' + this.model.id + height;\n            this.imagePreview = image;\n        } else if (this.model?.mime && ['File', 'AccountingDocument'].includes(this.model.__typename || '')) {\n            this.filePreview = this.model.mime.split('/')[1];\n        } else if (this.model.src) {\n            // external url\n            this.imagePreview = this.model.src;\n        }\n    }\n\n    private getBase64(file: File | null): Observable<string> {\n        if (!file) {\n            return of('');\n        }\n\n        const subject = new Subject<string>();\n\n        const reader = new FileReader();\n        reader.addEventListener('load', (ev: any) => {\n            subject.next(btoa(ev.target.result));\n            subject.complete();\n        });\n        reader.readAsBinaryString(file);\n\n        return subject.asObservable();\n    }\n}\n","<a\n    (fileChange)=\"upload($event)\"\n    naturalFileDrop\n    [selectable]=\"true\"\n    [accept]=\"accept\"\n    [attr.href]=\"getDownloadLink()\"\n    [class.has-action]=\"!!action\"\n    [class.suggest-upload]=\"!model && action === 'upload'\"\n    [fileSelectionDisabled]=\"action !== 'upload'\"\n    [matRippleDisabled]=\"!action\"\n    [naturalBackgroundDensity]=\"imagePreview\"\n    [style.backgroundSize]=\"backgroundSize\"\n    matRipple\n    target=\"_blank\"\n>\n    @if (filePreview) {\n        <div class=\"file-preview\">\n            <mat-icon [size]=\"height * 0.33\" naturalIcon=\"attachment\" />\n            {{ filePreview | uppercase }}\n        </div>\n    }\n\n    <div class=\"action-overlay\">\n        @if (action === 'upload') {\n            <mat-icon [size]=\"height * 0.66\" naturalIcon=\"cloud_upload\" />\n        }\n        @if (action === 'download') {\n            <mat-icon [size]=\"height * 0.66\" naturalIcon=\"get_app\" />\n        }\n        {{ action | capitalize }}\n    </div>\n</a>\n"]}
@@ -19,16 +19,13 @@ import * as i0 from "@angular/core";
19
19
  * ```
20
20
  */
21
21
  export class NaturalFileDropDirective extends NaturalAbstractFile {
22
- constructor() {
23
- super(...arguments);
24
- this.destroyRef = inject(DestroyRef);
25
- this.fileOverClass = false;
26
- /**
27
- * Emits whenever files are being dragged over
28
- */
29
- this.fileOver = new EventEmitter();
30
- this.rawFileOver = new Subject();
31
- }
22
+ destroyRef = inject(DestroyRef);
23
+ fileOverClass = false;
24
+ /**
25
+ * Emits whenever files are being dragged over
26
+ */
27
+ fileOver = new EventEmitter();
28
+ rawFileOver = new Subject();
32
29
  ngOnInit() {
33
30
  super.ngOnInit();
34
31
  // Automatically change the class, but not too often to avoid visual
@@ -87,8 +84,8 @@ export class NaturalFileDropDirective extends NaturalAbstractFile {
87
84
  this.filesChange.observed ||
88
85
  (this.broadcast && this.naturalFileService.filesChanged.observed));
89
86
  }
90
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileDropDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
91
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.3", type: NaturalFileDropDirective, isStandalone: true, selector: ":not([naturalFileSelect])[naturalFileDrop]", outputs: { fileOver: "fileOver" }, host: { listeners: { "drop": "onDrop($event)", "dragover": "onDragOver($event)", "dragleave": "onDragLeave($event)" }, properties: { "class.natural-file-over": "this.fileOverClass" } }, usesInheritance: true, ngImport: i0 }); }
87
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileDropDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
88
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.3", type: NaturalFileDropDirective, isStandalone: true, selector: ":not([naturalFileSelect])[naturalFileDrop]", outputs: { fileOver: "fileOver" }, host: { listeners: { "drop": "onDrop($event)", "dragover": "onDragOver($event)", "dragleave": "onDragLeave($event)" }, properties: { "class.natural-file-over": "this.fileOverClass" } }, usesInheritance: true, ngImport: i0 });
92
89
  }
93
90
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileDropDirective, decorators: [{
94
91
  type: Directive,
@@ -111,4 +108,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImpor
111
108
  type: HostListener,
112
109
  args: ['dragleave', ['$event']]
113
110
  }] } });
114
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-drop.directive.js","sourceRoot":"","sources":["../../../../../../projects/natural/src/lib/modules/file/file-drop.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {DestroyRef, Directive, EventEmitter, HostBinding, HostListener, inject, OnInit, Output} from '@angular/core';\nimport {NaturalAbstractFile} from './abstract-file';\nimport {eventToFiles, stopEvent} from './utils';\nimport {asyncScheduler, Subject} from 'rxjs';\nimport {throttleTime} from 'rxjs/operators';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\n\n/**\n * This directive has all options to select files, and adds support for drag'n'drop.\n *\n * It will add the CSS class `natural-file-over` on the component when a file is\n * dragged over. It is up to the component to have some specific styling by using\n * this class.\n *\n * In most cases you probably also want click-to-select, so you should use:\n *\n * ```html\n * <div naturalFileDrop [selectable]=\"true\"></div>\n * ```\n */\n@Directive({\n    selector: ':not([naturalFileSelect])[naturalFileDrop]',\n    standalone: true,\n})\nexport class NaturalFileDropDirective extends NaturalAbstractFile implements OnInit {\n    private readonly destroyRef = inject(DestroyRef);\n    @HostBinding('class.natural-file-over') public fileOverClass = false;\n\n    /**\n     * Emits whenever files are being dragged over\n     */\n    @Output() public readonly fileOver = new EventEmitter<boolean>();\n\n    private readonly rawFileOver = new Subject<boolean>();\n\n    public override ngOnInit(): void {\n        super.ngOnInit();\n\n        // Automatically change the class, but not too often to avoid visual\n        // flickering in Chrome when hovering across child HTML element of our host.\n        // It's not absolutely perfect and if dragging slowly and precisely we can\n        // still see flicker, but it should be better for most normal usages.\n        this.rawFileOver\n            .pipe(\n                takeUntilDestroyed(this.destroyRef),\n                throttleTime(200, asyncScheduler, {\n                    leading: true,\n                    trailing: true,\n                }),\n            )\n            .subscribe(fileOver => {\n                this.fileOver.emit(fileOver);\n                this.fileOverClass = fileOver;\n            });\n    }\n\n    @HostListener('drop', ['$event'])\n    public onDrop(event: DragEvent): void {\n        if (this.fileSelectionDisabled) {\n            return;\n        }\n\n        this.closeDrags();\n\n        const files = eventToFiles(event);\n        if (!files.length) {\n            return;\n        }\n\n        stopEvent(event);\n        this.handleFiles(files);\n    }\n\n    @HostListener('dragover', ['$event'])\n    public onDragOver(event: DragEvent): void {\n        if (!this.hasObservers()) {\n            return;\n        }\n\n        if (this.fileSelectionDisabled) {\n            return;\n        }\n\n        stopEvent(event);\n\n        // Change cursor\n        const transfer = event.dataTransfer;\n        if (transfer) {\n            transfer.dropEffect = 'copy';\n        }\n\n        this.rawFileOver.next(true);\n    }\n\n    private closeDrags(): void {\n        this.rawFileOver.next(false);\n    }\n\n    @HostListener('dragleave', ['$event'])\n    public onDragLeave(event: DragEvent): void {\n        if (this.fileSelectionDisabled) {\n            return;\n        }\n\n        stopEvent(event);\n        this.closeDrags();\n    }\n\n    private hasObservers(): boolean {\n        return (\n            this.fileChange.observed ||\n            this.filesChange.observed ||\n            (this.broadcast && this.naturalFileService.filesChanged.observed)\n        );\n    }\n}\n"]}
111
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-drop.directive.js","sourceRoot":"","sources":["../../../../../../projects/natural/src/lib/modules/file/file-drop.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {DestroyRef, Directive, EventEmitter, HostBinding, HostListener, inject, OnInit, Output} from '@angular/core';\nimport {NaturalAbstractFile} from './abstract-file';\nimport {eventToFiles, stopEvent} from './utils';\nimport {asyncScheduler, Subject} from 'rxjs';\nimport {throttleTime} from 'rxjs/operators';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\n\n/**\n * This directive has all options to select files, and adds support for drag'n'drop.\n *\n * It will add the CSS class `natural-file-over` on the component when a file is\n * dragged over. It is up to the component to have some specific styling by using\n * this class.\n *\n * In most cases you probably also want click-to-select, so you should use:\n *\n * ```html\n * <div naturalFileDrop [selectable]=\"true\"></div>\n * ```\n */\n@Directive({\n    selector: ':not([naturalFileSelect])[naturalFileDrop]',\n    standalone: true,\n})\nexport class NaturalFileDropDirective extends NaturalAbstractFile implements OnInit {\n    private readonly destroyRef = inject(DestroyRef);\n    @HostBinding('class.natural-file-over') public fileOverClass = false;\n\n    /**\n     * Emits whenever files are being dragged over\n     */\n    @Output() public readonly fileOver = new EventEmitter<boolean>();\n\n    private readonly rawFileOver = new Subject<boolean>();\n\n    public override ngOnInit(): void {\n        super.ngOnInit();\n\n        // Automatically change the class, but not too often to avoid visual\n        // flickering in Chrome when hovering across child HTML element of our host.\n        // It's not absolutely perfect and if dragging slowly and precisely we can\n        // still see flicker, but it should be better for most normal usages.\n        this.rawFileOver\n            .pipe(\n                takeUntilDestroyed(this.destroyRef),\n                throttleTime(200, asyncScheduler, {\n                    leading: true,\n                    trailing: true,\n                }),\n            )\n            .subscribe(fileOver => {\n                this.fileOver.emit(fileOver);\n                this.fileOverClass = fileOver;\n            });\n    }\n\n    @HostListener('drop', ['$event'])\n    public onDrop(event: DragEvent): void {\n        if (this.fileSelectionDisabled) {\n            return;\n        }\n\n        this.closeDrags();\n\n        const files = eventToFiles(event);\n        if (!files.length) {\n            return;\n        }\n\n        stopEvent(event);\n        this.handleFiles(files);\n    }\n\n    @HostListener('dragover', ['$event'])\n    public onDragOver(event: DragEvent): void {\n        if (!this.hasObservers()) {\n            return;\n        }\n\n        if (this.fileSelectionDisabled) {\n            return;\n        }\n\n        stopEvent(event);\n\n        // Change cursor\n        const transfer = event.dataTransfer;\n        if (transfer) {\n            transfer.dropEffect = 'copy';\n        }\n\n        this.rawFileOver.next(true);\n    }\n\n    private closeDrags(): void {\n        this.rawFileOver.next(false);\n    }\n\n    @HostListener('dragleave', ['$event'])\n    public onDragLeave(event: DragEvent): void {\n        if (this.fileSelectionDisabled) {\n            return;\n        }\n\n        stopEvent(event);\n        this.closeDrags();\n    }\n\n    private hasObservers(): boolean {\n        return (\n            this.fileChange.observed ||\n            this.filesChange.observed ||\n            (this.broadcast && this.naturalFileService.filesChanged.observed)\n        );\n    }\n}\n"]}
@@ -5,17 +5,14 @@ import * as i0 from "@angular/core";
5
5
  * This directive has all options to select files, except drag'n'drop.
6
6
  */
7
7
  export class NaturalFileSelectDirective extends NaturalAbstractFile {
8
- constructor() {
9
- super(...arguments);
10
- /**
11
- * Whether the user can click on the element to select something
12
- *
13
- * Override parent to enable it by default
14
- */
15
- this.selectable = true;
16
- }
17
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileSelectDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
18
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.3", type: NaturalFileSelectDirective, isStandalone: true, selector: ":not([naturalFileDrop])[naturalFileSelect]", inputs: { selectable: "selectable" }, usesInheritance: true, ngImport: i0 }); }
8
+ /**
9
+ * Whether the user can click on the element to select something
10
+ *
11
+ * Override parent to enable it by default
12
+ */
13
+ selectable = true;
14
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileSelectDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive });
15
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.3", type: NaturalFileSelectDirective, isStandalone: true, selector: ":not([naturalFileDrop])[naturalFileSelect]", inputs: { selectable: "selectable" }, usesInheritance: true, ngImport: i0 });
19
16
  }
20
17
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileSelectDirective, decorators: [{
21
18
  type: Directive,
@@ -26,4 +23,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImpor
26
23
  }], propDecorators: { selectable: [{
27
24
  type: Input
28
25
  }] } });
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1zZWxlY3QuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvZmlsZS9maWxlLXNlbGVjdC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxLQUFLLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDL0MsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0saUJBQWlCLENBQUM7O0FBRXBEOztHQUVHO0FBS0gsTUFBTSxPQUFPLDBCQUEyQixTQUFRLG1CQUFtQjtJQUpuRTs7UUFLSTs7OztXQUlHO1FBQ3NCLGVBQVUsR0FBRyxJQUFJLENBQUM7S0FDOUM7OEdBUFksMEJBQTBCO2tHQUExQiwwQkFBMEI7OzJGQUExQiwwQkFBMEI7a0JBSnRDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLDRDQUE0QztvQkFDdEQsVUFBVSxFQUFFLElBQUk7aUJBQ25COzhCQU80QixVQUFVO3NCQUFsQyxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaXJlY3RpdmUsIElucHV0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7TmF0dXJhbEFic3RyYWN0RmlsZX0gZnJvbSAnLi9hYnN0cmFjdC1maWxlJztcblxuLyoqXG4gKiBUaGlzIGRpcmVjdGl2ZSBoYXMgYWxsIG9wdGlvbnMgdG8gc2VsZWN0IGZpbGVzLCBleGNlcHQgZHJhZyduJ2Ryb3AuXG4gKi9cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnOm5vdChbbmF0dXJhbEZpbGVEcm9wXSlbbmF0dXJhbEZpbGVTZWxlY3RdJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBOYXR1cmFsRmlsZVNlbGVjdERpcmVjdGl2ZSBleHRlbmRzIE5hdHVyYWxBYnN0cmFjdEZpbGUge1xuICAgIC8qKlxuICAgICAqIFdoZXRoZXIgdGhlIHVzZXIgY2FuIGNsaWNrIG9uIHRoZSBlbGVtZW50IHRvIHNlbGVjdCBzb21ldGhpbmdcbiAgICAgKlxuICAgICAqIE92ZXJyaWRlIHBhcmVudCB0byBlbmFibGUgaXQgYnkgZGVmYXVsdFxuICAgICAqL1xuICAgIEBJbnB1dCgpIHB1YmxpYyBvdmVycmlkZSBzZWxlY3RhYmxlID0gdHJ1ZTtcbn1cbiJdfQ==
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1zZWxlY3QuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvZmlsZS9maWxlLXNlbGVjdC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxLQUFLLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDL0MsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0saUJBQWlCLENBQUM7O0FBRXBEOztHQUVHO0FBS0gsTUFBTSxPQUFPLDBCQUEyQixTQUFRLG1CQUFtQjtJQUMvRDs7OztPQUlHO0lBQ3NCLFVBQVUsR0FBRyxJQUFJLENBQUM7dUdBTmxDLDBCQUEwQjsyRkFBMUIsMEJBQTBCOzsyRkFBMUIsMEJBQTBCO2tCQUp0QyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSw0Q0FBNEM7b0JBQ3RELFVBQVUsRUFBRSxJQUFJO2lCQUNuQjs4QkFPNEIsVUFBVTtzQkFBbEMsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RGlyZWN0aXZlLCBJbnB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge05hdHVyYWxBYnN0cmFjdEZpbGV9IGZyb20gJy4vYWJzdHJhY3QtZmlsZSc7XG5cbi8qKlxuICogVGhpcyBkaXJlY3RpdmUgaGFzIGFsbCBvcHRpb25zIHRvIHNlbGVjdCBmaWxlcywgZXhjZXB0IGRyYWcnbidkcm9wLlxuICovXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJzpub3QoW25hdHVyYWxGaWxlRHJvcF0pW25hdHVyYWxGaWxlU2VsZWN0XScsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgTmF0dXJhbEZpbGVTZWxlY3REaXJlY3RpdmUgZXh0ZW5kcyBOYXR1cmFsQWJzdHJhY3RGaWxlIHtcbiAgICAvKipcbiAgICAgKiBXaGV0aGVyIHRoZSB1c2VyIGNhbiBjbGljayBvbiB0aGUgZWxlbWVudCB0byBzZWxlY3Qgc29tZXRoaW5nXG4gICAgICpcbiAgICAgKiBPdmVycmlkZSBwYXJlbnQgdG8gZW5hYmxlIGl0IGJ5IGRlZmF1bHRcbiAgICAgKi9cbiAgICBASW5wdXQoKSBwdWJsaWMgb3ZlcnJpZGUgc2VsZWN0YWJsZSA9IHRydWU7XG59XG4iXX0=
@@ -1,21 +1,19 @@
1
- import { Inject, Injectable } from '@angular/core';
1
+ import { Injectable, inject } from '@angular/core';
2
2
  import { Subject } from 'rxjs';
3
3
  import { DOCUMENT } from '@angular/common';
4
4
  import * as i0 from "@angular/core";
5
5
  // @dynamic
6
6
  export class NaturalFileService {
7
- constructor(document) {
8
- this.document = document;
9
- /**
10
- * Allow to subscribe to selected files in the entire application. So a
11
- * child component is able to receive a file that was dropped on a parent
12
- * component.
13
- *
14
- * Typically useful to drop a file on the entire screen, instead of a precise
15
- * component.
16
- */
17
- this.filesChanged = new Subject();
18
- }
7
+ document = inject(DOCUMENT);
8
+ /**
9
+ * Allow to subscribe to selected files in the entire application. So a
10
+ * child component is able to receive a file that was dropped on a parent
11
+ * component.
12
+ *
13
+ * Typically useful to drop a file on the entire screen, instead of a precise
14
+ * component.
15
+ */
16
+ filesChanged = new Subject();
19
17
  getDownloadLink(model) {
20
18
  const window = this.document.defaultView;
21
19
  if (!window) {
@@ -33,16 +31,13 @@ export class NaturalFileService {
33
31
  }
34
32
  return null;
35
33
  }
36
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileService, deps: [{ token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
37
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileService, providedIn: 'root' }); }
34
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
35
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileService, providedIn: 'root' });
38
36
  }
39
37
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFileService, decorators: [{
40
38
  type: Injectable,
41
39
  args: [{
42
40
  providedIn: 'root',
43
41
  }]
44
- }], ctorParameters: () => [{ type: Document, decorators: [{
45
- type: Inject,
46
- args: [DOCUMENT]
47
- }] }] });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvZmlsZS9maWxlLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLE1BQU0sRUFBRSxVQUFVLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFDLE9BQU8sRUFBQyxNQUFNLE1BQU0sQ0FBQztBQUc3QixPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0saUJBQWlCLENBQUM7O0FBRXpDLFdBQVc7QUFJWCxNQUFNLE9BQU8sa0JBQWtCO0lBVzNCLFlBQXNELFFBQWtCO1FBQWxCLGFBQVEsR0FBUixRQUFRLENBQVU7UUFWeEU7Ozs7Ozs7V0FPRztRQUNhLGlCQUFZLEdBQUcsSUFBSSxPQUFPLEVBQWlCLENBQUM7SUFFZSxDQUFDO0lBRXJFLGVBQWUsQ0FBQyxLQUF1QjtRQUMxQyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQztRQUN6QyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDVixNQUFNLElBQUksS0FBSyxDQUFDLDBEQUEwRCxDQUFDLENBQUM7UUFDaEYsQ0FBQztRQUVELE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsUUFBUSxHQUFHLElBQUksR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQztRQUU1RSxJQUFJLEtBQUssRUFBRSxVQUFVLEtBQUssTUFBTSxFQUFFLENBQUM7WUFDL0IsT0FBTyxRQUFRLEdBQUcsWUFBWSxHQUFHLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDOUMsQ0FBQzthQUFNLElBQUksS0FBSyxFQUFFLFVBQVUsS0FBSyxvQkFBb0IsRUFBRSxDQUFDO1lBQ3BELE9BQU8sUUFBUSxHQUFHLDJCQUEyQixHQUFHLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDN0QsQ0FBQzthQUFNLElBQUksS0FBSyxFQUFFLFVBQVUsS0FBSyxPQUFPLEVBQUUsQ0FBQztZQUN2QyxPQUFPLFFBQVEsR0FBRyxhQUFhLEdBQUcsS0FBSyxDQUFDLEVBQUUsQ0FBQztRQUMvQyxDQUFDO1FBRUQsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQzs4R0E5QlEsa0JBQWtCLGtCQVdBLFFBQVE7a0hBWDFCLGtCQUFrQixjQUZmLE1BQU07OzJGQUVULGtCQUFrQjtrQkFIOUIsVUFBVTttQkFBQztvQkFDUixVQUFVLEVBQUUsTUFBTTtpQkFDckI7OzBCQVl1QixNQUFNOzJCQUFDLFFBQVEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdCwgSW5qZWN0YWJsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1N1YmplY3R9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtGaWxlU2VsZWN0aW9ufSBmcm9tICcuL2Fic3RyYWN0LWZpbGUnO1xuaW1wb3J0IHtGaWxlTW9kZWx9IGZyb20gJy4vdHlwZXMnO1xuaW1wb3J0IHtET0NVTUVOVH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuLy8gQGR5bmFtaWNcbkBJbmplY3RhYmxlKHtcbiAgICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIE5hdHVyYWxGaWxlU2VydmljZSB7XG4gICAgLyoqXG4gICAgICogQWxsb3cgdG8gc3Vic2NyaWJlIHRvIHNlbGVjdGVkIGZpbGVzIGluIHRoZSBlbnRpcmUgYXBwbGljYXRpb24uIFNvIGFcbiAgICAgKiBjaGlsZCBjb21wb25lbnQgaXMgYWJsZSB0byByZWNlaXZlIGEgZmlsZSB0aGF0IHdhcyBkcm9wcGVkIG9uIGEgcGFyZW50XG4gICAgICogY29tcG9uZW50LlxuICAgICAqXG4gICAgICogVHlwaWNhbGx5IHVzZWZ1bCB0byBkcm9wIGEgZmlsZSBvbiB0aGUgZW50aXJlIHNjcmVlbiwgaW5zdGVhZCBvZiBhIHByZWNpc2VcbiAgICAgKiBjb21wb25lbnQuXG4gICAgICovXG4gICAgcHVibGljIHJlYWRvbmx5IGZpbGVzQ2hhbmdlZCA9IG5ldyBTdWJqZWN0PEZpbGVTZWxlY3Rpb24+KCk7XG5cbiAgICBwdWJsaWMgY29uc3RydWN0b3IoQEluamVjdChET0NVTUVOVCkgcHJpdmF0ZSByZWFkb25seSBkb2N1bWVudDogRG9jdW1lbnQpIHt9XG5cbiAgICBwdWJsaWMgZ2V0RG93bmxvYWRMaW5rKG1vZGVsOiBGaWxlTW9kZWwgfCBudWxsKTogbnVsbCB8IHN0cmluZyB7XG4gICAgICAgIGNvbnN0IHdpbmRvdyA9IHRoaXMuZG9jdW1lbnQuZGVmYXVsdFZpZXc7XG4gICAgICAgIGlmICghd2luZG93KSB7XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ0Nhbm5vdCBidWlsZCBkb3dubG9hZCBsaW5rIGJlY2F1c2UgYHdpbmRvd2AgaXMgdW5kZWZpbmVkJyk7XG4gICAgICAgIH1cblxuICAgICAgICBjb25zdCBob3N0bmFtZSA9IHdpbmRvdy5sb2NhdGlvbi5wcm90b2NvbCArICcvLycgKyB3aW5kb3cubG9jYXRpb24uaG9zdG5hbWU7XG5cbiAgICAgICAgaWYgKG1vZGVsPy5fX3R5cGVuYW1lID09PSAnRmlsZScpIHtcbiAgICAgICAgICAgIHJldHVybiBob3N0bmFtZSArICcvYXBpL2ZpbGUvJyArIG1vZGVsLmlkO1xuICAgICAgICB9IGVsc2UgaWYgKG1vZGVsPy5fX3R5cGVuYW1lID09PSAnQWNjb3VudGluZ0RvY3VtZW50Jykge1xuICAgICAgICAgICAgcmV0dXJuIGhvc3RuYW1lICsgJy9hcGkvYWNjb3VudGluZy1kb2N1bWVudC8nICsgbW9kZWwuaWQ7XG4gICAgICAgIH0gZWxzZSBpZiAobW9kZWw/Ll9fdHlwZW5hbWUgPT09ICdJbWFnZScpIHtcbiAgICAgICAgICAgIHJldHVybiBob3N0bmFtZSArICcvYXBpL2ltYWdlLycgKyBtb2RlbC5pZDtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBudWxsO1xuICAgIH1cbn1cbiJdfQ==
42
+ }] });
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvZmlsZS9maWxlLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFVBQVUsRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFDLE9BQU8sRUFBQyxNQUFNLE1BQU0sQ0FBQztBQUc3QixPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0saUJBQWlCLENBQUM7O0FBRXpDLFdBQVc7QUFJWCxNQUFNLE9BQU8sa0JBQWtCO0lBQ1YsUUFBUSxHQUFHLE1BQU0sQ0FBVyxRQUFRLENBQUMsQ0FBQztJQUV2RDs7Ozs7OztPQU9HO0lBQ2EsWUFBWSxHQUFHLElBQUksT0FBTyxFQUFpQixDQUFDO0lBRXJELGVBQWUsQ0FBQyxLQUF1QjtRQUMxQyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQztRQUN6QyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDVixNQUFNLElBQUksS0FBSyxDQUFDLDBEQUEwRCxDQUFDLENBQUM7UUFDaEYsQ0FBQztRQUVELE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsUUFBUSxHQUFHLElBQUksR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQztRQUU1RSxJQUFJLEtBQUssRUFBRSxVQUFVLEtBQUssTUFBTSxFQUFFLENBQUM7WUFDL0IsT0FBTyxRQUFRLEdBQUcsWUFBWSxHQUFHLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDOUMsQ0FBQzthQUFNLElBQUksS0FBSyxFQUFFLFVBQVUsS0FBSyxvQkFBb0IsRUFBRSxDQUFDO1lBQ3BELE9BQU8sUUFBUSxHQUFHLDJCQUEyQixHQUFHLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDN0QsQ0FBQzthQUFNLElBQUksS0FBSyxFQUFFLFVBQVUsS0FBSyxPQUFPLEVBQUUsQ0FBQztZQUN2QyxPQUFPLFFBQVEsR0FBRyxhQUFhLEdBQUcsS0FBSyxDQUFDLEVBQUUsQ0FBQztRQUMvQyxDQUFDO1FBRUQsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQzt1R0E5QlEsa0JBQWtCOzJHQUFsQixrQkFBa0IsY0FGZixNQUFNOzsyRkFFVCxrQkFBa0I7a0JBSDlCLFVBQVU7bUJBQUM7b0JBQ1IsVUFBVSxFQUFFLE1BQU07aUJBQ3JCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtJbmplY3RhYmxlLCBpbmplY3R9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtTdWJqZWN0fSBmcm9tICdyeGpzJztcbmltcG9ydCB7RmlsZVNlbGVjdGlvbn0gZnJvbSAnLi9hYnN0cmFjdC1maWxlJztcbmltcG9ydCB7RmlsZU1vZGVsfSBmcm9tICcuL3R5cGVzJztcbmltcG9ydCB7RE9DVU1FTlR9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbi8vIEBkeW5hbWljXG5ASW5qZWN0YWJsZSh7XG4gICAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBOYXR1cmFsRmlsZVNlcnZpY2Uge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgZG9jdW1lbnQgPSBpbmplY3Q8RG9jdW1lbnQ+KERPQ1VNRU5UKTtcblxuICAgIC8qKlxuICAgICAqIEFsbG93IHRvIHN1YnNjcmliZSB0byBzZWxlY3RlZCBmaWxlcyBpbiB0aGUgZW50aXJlIGFwcGxpY2F0aW9uLiBTbyBhXG4gICAgICogY2hpbGQgY29tcG9uZW50IGlzIGFibGUgdG8gcmVjZWl2ZSBhIGZpbGUgdGhhdCB3YXMgZHJvcHBlZCBvbiBhIHBhcmVudFxuICAgICAqIGNvbXBvbmVudC5cbiAgICAgKlxuICAgICAqIFR5cGljYWxseSB1c2VmdWwgdG8gZHJvcCBhIGZpbGUgb24gdGhlIGVudGlyZSBzY3JlZW4sIGluc3RlYWQgb2YgYSBwcmVjaXNlXG4gICAgICogY29tcG9uZW50LlxuICAgICAqL1xuICAgIHB1YmxpYyByZWFkb25seSBmaWxlc0NoYW5nZWQgPSBuZXcgU3ViamVjdDxGaWxlU2VsZWN0aW9uPigpO1xuXG4gICAgcHVibGljIGdldERvd25sb2FkTGluayhtb2RlbDogRmlsZU1vZGVsIHwgbnVsbCk6IG51bGwgfCBzdHJpbmcge1xuICAgICAgICBjb25zdCB3aW5kb3cgPSB0aGlzLmRvY3VtZW50LmRlZmF1bHRWaWV3O1xuICAgICAgICBpZiAoIXdpbmRvdykge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdDYW5ub3QgYnVpbGQgZG93bmxvYWQgbGluayBiZWNhdXNlIGB3aW5kb3dgIGlzIHVuZGVmaW5lZCcpO1xuICAgICAgICB9XG5cbiAgICAgICAgY29uc3QgaG9zdG5hbWUgPSB3aW5kb3cubG9jYXRpb24ucHJvdG9jb2wgKyAnLy8nICsgd2luZG93LmxvY2F0aW9uLmhvc3RuYW1lO1xuXG4gICAgICAgIGlmIChtb2RlbD8uX190eXBlbmFtZSA9PT0gJ0ZpbGUnKSB7XG4gICAgICAgICAgICByZXR1cm4gaG9zdG5hbWUgKyAnL2FwaS9maWxlLycgKyBtb2RlbC5pZDtcbiAgICAgICAgfSBlbHNlIGlmIChtb2RlbD8uX190eXBlbmFtZSA9PT0gJ0FjY291bnRpbmdEb2N1bWVudCcpIHtcbiAgICAgICAgICAgIHJldHVybiBob3N0bmFtZSArICcvYXBpL2FjY291bnRpbmctZG9jdW1lbnQvJyArIG1vZGVsLmlkO1xuICAgICAgICB9IGVsc2UgaWYgKG1vZGVsPy5fX3R5cGVuYW1lID09PSAnSW1hZ2UnKSB7XG4gICAgICAgICAgICByZXR1cm4gaG9zdG5hbWUgKyAnL2FwaS9pbWFnZS8nICsgbW9kZWwuaWQ7XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG59XG4iXX0=
@@ -6,4 +6,4 @@ export * from './file-select.directive';
6
6
  export * from './file.service';
7
7
  export * from './component/file.component';
8
8
  export * from './types';
9
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL2ZpbGUvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLGdCQUFnQixDQUFDO0FBRS9CLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIG5hdHVyYWxcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2ZpbGUtZHJvcC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9maWxlLXNlbGVjdC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9maWxlLnNlcnZpY2UnO1xuZXhwb3J0IHtJbnZhbGlkRmlsZSwgRmlsZVNlbGVjdGlvbn0gZnJvbSAnLi9hYnN0cmFjdC1maWxlJztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50L2ZpbGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vdHlwZXMnO1xuIl19
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL2ZpbGUvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLGdCQUFnQixDQUFDO0FBRS9CLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIG5hdHVyYWxcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2ZpbGUtZHJvcC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9maWxlLXNlbGVjdC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9maWxlLnNlcnZpY2UnO1xuZXhwb3J0IHR5cGUge0ludmFsaWRGaWxlLCBGaWxlU2VsZWN0aW9ufSBmcm9tICcuL2Fic3RyYWN0LWZpbGUnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnQvZmlsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcyc7XG4iXX0=
@@ -7,13 +7,12 @@ import * as i0 from "@angular/core";
7
7
  import * as i1 from "@angular/material/button";
8
8
  import * as i2 from "@angular/material/icon";
9
9
  export class NaturalFixedButtonComponent {
10
- constructor() {
11
- this.link = [];
12
- this.color = 'accent';
13
- this.disabled = false;
14
- }
15
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFixedButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
16
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.3", type: NaturalFixedButtonComponent, isStandalone: true, 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\" />\n</button>\n", styles: [":host{position:fixed!important;right:32px;bottom:32px;z-index:999}\n"], dependencies: [{ kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i1.MatFabButton, selector: "button[mat-fab]", inputs: ["extended"], exportAs: ["matButton"] }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: NaturalIconDirective, selector: "mat-icon[naturalIcon]", inputs: ["naturalIcon", "size"] }] }); }
10
+ icon;
11
+ link = [];
12
+ color = 'accent';
13
+ disabled = false;
14
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFixedButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
15
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.3", type: NaturalFixedButtonComponent, isStandalone: true, 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\" />\n</button>\n", styles: [":host{position:fixed!important;right:32px;bottom:32px;z-index:999}\n"], dependencies: [{ kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i1.MatFabButton, selector: "button[mat-fab]", inputs: ["extended"], exportAs: ["matButton"] }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: NaturalIconDirective, selector: "mat-icon[naturalIcon]", inputs: ["naturalIcon", "size"] }] });
17
16
  }
18
17
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFixedButtonComponent, decorators: [{
19
18
  type: Component,
@@ -28,4 +27,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImpor
28
27
  }], disabled: [{
29
28
  type: Input
30
29
  }] } });
31
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZml4ZWQtYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL2ZpeGVkLWJ1dHRvbi9maXhlZC1idXR0b24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvZml4ZWQtYnV0dG9uL2ZpeGVkLWJ1dHRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLEtBQUssRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUUvQyxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDM0MsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDNUQsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ3JELE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQzs7OztBQVN6RCxNQUFNLE9BQU8sMkJBQTJCO0lBUHhDO1FBU29CLFNBQUksR0FBNkIsRUFBRSxDQUFDO1FBQ3BDLFVBQUssR0FBaUIsUUFBUSxDQUFDO1FBQy9CLGFBQVEsR0FBRyxLQUFLLENBQUM7S0FDcEM7OEdBTFksMkJBQTJCO2tHQUEzQiwyQkFBMkIsOEpDZHhDLHdJQUdBLDZIRFNjLGVBQWUseUpBQUUsVUFBVSxtT0FBRSxhQUFhLG9MQUFFLG9CQUFvQjs7MkZBRWpFLDJCQUEyQjtrQkFQdkMsU0FBUzsrQkFDSSxzQkFBc0IsY0FHcEIsSUFBSSxXQUNQLENBQUMsZUFBZSxFQUFFLFVBQVUsRUFBRSxhQUFhLEVBQUUsb0JBQW9CLENBQUM7OEJBRzNDLElBQUk7c0JBQW5DLEtBQUs7dUJBQUMsRUFBQyxRQUFRLEVBQUUsSUFBSSxFQUFDO2dCQUNQLElBQUk7c0JBQW5CLEtBQUs7Z0JBQ1UsS0FBSztzQkFBcEIsS0FBSztnQkFDVSxRQUFRO3NCQUF2QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIElucHV0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7VGhlbWVQYWxldHRlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9jb3JlJztcbmltcG9ydCB7Um91dGVyTGlua30gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7TmF0dXJhbEljb25EaXJlY3RpdmV9IGZyb20gJy4uL2ljb24vaWNvbi5kaXJlY3RpdmUnO1xuaW1wb3J0IHtNYXRJY29uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcbmltcG9ydCB7TWF0QnV0dG9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ25hdHVyYWwtZml4ZWQtYnV0dG9uJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZml4ZWQtYnV0dG9uLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybDogJy4vZml4ZWQtYnV0dG9uLmNvbXBvbmVudC5zY3NzJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtNYXRCdXR0b25Nb2R1bGUsIFJvdXRlckxpbmssIE1hdEljb25Nb2R1bGUsIE5hdHVyYWxJY29uRGlyZWN0aXZlXSxcbn0pXG5leHBvcnQgY2xhc3MgTmF0dXJhbEZpeGVkQnV0dG9uQ29tcG9uZW50IHtcbiAgICBASW5wdXQoe3JlcXVpcmVkOiB0cnVlfSkgcHVibGljIGljb24hOiBzdHJpbmc7XG4gICAgQElucHV0KCkgcHVibGljIGxpbms6IFJvdXRlckxpbmtbJ3JvdXRlckxpbmsnXSA9IFtdO1xuICAgIEBJbnB1dCgpIHB1YmxpYyBjb2xvcjogVGhlbWVQYWxldHRlID0gJ2FjY2VudCc7XG4gICAgQElucHV0KCkgcHVibGljIGRpc2FibGVkID0gZmFsc2U7XG59XG4iLCI8YnV0dG9uIFtjb2xvcl09XCJjb2xvclwiIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiIFtyb3V0ZXJMaW5rXT1cImxpbmtcIiBtYXQtZmFiPlxuICAgIDxtYXQtaWNvbiBbbmF0dXJhbEljb25dPVwiaWNvblwiIC8+XG48L2J1dHRvbj5cbiJdfQ==
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZml4ZWQtYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9tb2R1bGVzL2ZpeGVkLWJ1dHRvbi9maXhlZC1idXR0b24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvZml4ZWQtYnV0dG9uL2ZpeGVkLWJ1dHRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLEtBQUssRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUUvQyxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDM0MsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDNUQsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBQ3JELE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQzs7OztBQVN6RCxNQUFNLE9BQU8sMkJBQTJCO0lBQ0osSUFBSSxDQUFVO0lBQzlCLElBQUksR0FBNkIsRUFBRSxDQUFDO0lBQ3BDLEtBQUssR0FBaUIsUUFBUSxDQUFDO0lBQy9CLFFBQVEsR0FBRyxLQUFLLENBQUM7dUdBSnhCLDJCQUEyQjsyRkFBM0IsMkJBQTJCLDhKQ2R4Qyx3SUFHQSw2SERTYyxlQUFlLHlKQUFFLFVBQVUsbU9BQUUsYUFBYSxvTEFBRSxvQkFBb0I7OzJGQUVqRSwyQkFBMkI7a0JBUHZDLFNBQVM7K0JBQ0ksc0JBQXNCLGNBR3BCLElBQUksV0FDUCxDQUFDLGVBQWUsRUFBRSxVQUFVLEVBQUUsYUFBYSxFQUFFLG9CQUFvQixDQUFDOzhCQUczQyxJQUFJO3NCQUFuQyxLQUFLO3VCQUFDLEVBQUMsUUFBUSxFQUFFLElBQUksRUFBQztnQkFDUCxJQUFJO3NCQUFuQixLQUFLO2dCQUNVLEtBQUs7c0JBQXBCLEtBQUs7Z0JBQ1UsUUFBUTtzQkFBdkIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBJbnB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1RoZW1lUGFsZXR0ZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY29yZSc7XG5pbXBvcnQge1JvdXRlckxpbmt9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQge05hdHVyYWxJY29uRGlyZWN0aXZlfSBmcm9tICcuLi9pY29uL2ljb24uZGlyZWN0aXZlJztcbmltcG9ydCB7TWF0SWNvbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5pbXBvcnQge01hdEJ1dHRvbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICduYXR1cmFsLWZpeGVkLWJ1dHRvbicsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2ZpeGVkLWJ1dHRvbi5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmw6ICcuL2ZpeGVkLWJ1dHRvbi5jb21wb25lbnQuc2NzcycsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbTWF0QnV0dG9uTW9kdWxlLCBSb3V0ZXJMaW5rLCBNYXRJY29uTW9kdWxlLCBOYXR1cmFsSWNvbkRpcmVjdGl2ZV0sXG59KVxuZXhwb3J0IGNsYXNzIE5hdHVyYWxGaXhlZEJ1dHRvbkNvbXBvbmVudCB7XG4gICAgQElucHV0KHtyZXF1aXJlZDogdHJ1ZX0pIHB1YmxpYyBpY29uITogc3RyaW5nO1xuICAgIEBJbnB1dCgpIHB1YmxpYyBsaW5rOiBSb3V0ZXJMaW5rWydyb3V0ZXJMaW5rJ10gPSBbXTtcbiAgICBASW5wdXQoKSBwdWJsaWMgY29sb3I6IFRoZW1lUGFsZXR0ZSA9ICdhY2NlbnQnO1xuICAgIEBJbnB1dCgpIHB1YmxpYyBkaXNhYmxlZCA9IGZhbHNlO1xufVxuIiwiPGJ1dHRvbiBbY29sb3JdPVwiY29sb3JcIiBbZGlzYWJsZWRdPVwiZGlzYWJsZWRcIiBbcm91dGVyTGlua109XCJsaW5rXCIgbWF0LWZhYj5cbiAgICA8bWF0LWljb24gW25hdHVyYWxJY29uXT1cImljb25cIiAvPlxuPC9idXR0b24+XG4iXX0=
@@ -1,11 +1,13 @@
1
- import { Component, EventEmitter, Input, Output } from '@angular/core';
1
+ import { Component, EventEmitter, Input, Output, inject } from '@angular/core';
2
+ import { ActivatedRoute } from '@angular/router';
2
3
  import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
3
4
  import { MatTooltipModule } from '@angular/material/tooltip';
4
5
  import { NaturalFixedButtonComponent } from '../fixed-button/fixed-button.component';
5
6
  import * as i0 from "@angular/core";
6
- import * as i1 from "@angular/router";
7
- import * as i2 from "@angular/material/tooltip";
7
+ import * as i1 from "@angular/material/tooltip";
8
8
  export class NaturalFixedButtonDetailComponent {
9
+ canChange = true;
10
+ isCreation = false;
9
11
  get model() {
10
12
  return this._model;
11
13
  }
@@ -16,11 +18,12 @@ export class NaturalFixedButtonDetailComponent {
16
18
  this.canChange = false;
17
19
  }
18
20
  }
19
- constructor(route) {
20
- this.canChange = true;
21
- this.isCreation = false;
22
- this.create = new EventEmitter();
23
- this.delete = new EventEmitter();
21
+ _model;
22
+ form;
23
+ create = new EventEmitter();
24
+ delete = new EventEmitter();
25
+ constructor() {
26
+ const route = inject(ActivatedRoute);
24
27
  route.params.pipe(takeUntilDestroyed()).subscribe(() => (this.canChange = true));
25
28
  }
26
29
  clickCreate() {
@@ -33,13 +36,13 @@ export class NaturalFixedButtonDetailComponent {
33
36
  this.delete.emit();
34
37
  }
35
38
  }
36
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFixedButtonDetailComponent, deps: [{ token: i1.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Component }); }
37
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: NaturalFixedButtonDetailComponent, isStandalone: true, selector: "natural-fixed-button-detail", inputs: { model: "model", form: "form" }, outputs: { create: "create", delete: "delete" }, ngImport: i0, template: "@if (isCreation) {\n <natural-fixed-button\n (click)=\"clickCreate()\"\n [disabled]=\"form.disabled\"\n [color]=\"form.valid ? 'accent' : 'warn'\"\n class=\"detail-speed-dial\"\n icon=\"save\"\n />\n}\n\n@if (!isCreation && (!model.permissions || model.permissions.delete)) {\n <natural-fixed-button\n (click)=\"clickDelete()\"\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 />\n}\n", styles: [""], dependencies: [{ kind: "component", type: NaturalFixedButtonComponent, selector: "natural-fixed-button", inputs: ["icon", "link", "color", "disabled"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i2.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }] }); }
39
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFixedButtonDetailComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
40
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.3", type: NaturalFixedButtonDetailComponent, isStandalone: true, selector: "natural-fixed-button-detail", inputs: { model: "model", form: "form" }, outputs: { create: "create", delete: "delete" }, ngImport: i0, template: "@if (isCreation) {\n <natural-fixed-button\n (click)=\"clickCreate()\"\n [disabled]=\"form.disabled\"\n [color]=\"form.valid ? 'accent' : 'warn'\"\n class=\"detail-speed-dial\"\n icon=\"save\"\n />\n}\n\n@if (!isCreation && (!model.permissions || model.permissions.delete)) {\n <natural-fixed-button\n (click)=\"clickDelete()\"\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 />\n}\n", styles: [""], dependencies: [{ kind: "component", type: NaturalFixedButtonComponent, selector: "natural-fixed-button", inputs: ["icon", "link", "color", "disabled"] }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i1.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }] });
38
41
  }
39
42
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImport: i0, type: NaturalFixedButtonDetailComponent, decorators: [{
40
43
  type: Component,
41
44
  args: [{ selector: 'natural-fixed-button-detail', standalone: true, imports: [NaturalFixedButtonComponent, MatTooltipModule], template: "@if (isCreation) {\n <natural-fixed-button\n (click)=\"clickCreate()\"\n [disabled]=\"form.disabled\"\n [color]=\"form.valid ? 'accent' : 'warn'\"\n class=\"detail-speed-dial\"\n icon=\"save\"\n />\n}\n\n@if (!isCreation && (!model.permissions || model.permissions.delete)) {\n <natural-fixed-button\n (click)=\"clickDelete()\"\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 />\n}\n" }]
42
- }], ctorParameters: () => [{ type: i1.ActivatedRoute }], propDecorators: { model: [{
45
+ }], ctorParameters: () => [], propDecorators: { model: [{
43
46
  type: Input,
44
47
  args: [{ required: true }]
45
48
  }], form: [{
@@ -50,4 +53,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.3", ngImpor
50
53
  }], delete: [{
51
54
  type: Output
52
55
  }] } });
53
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZml4ZWQtYnV0dG9uLWRldGFpbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uYXR1cmFsL3NyYy9saWIvbW9kdWxlcy9maXhlZC1idXR0b24tZGV0YWlsL2ZpeGVkLWJ1dHRvbi1kZXRhaWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvZml4ZWQtYnV0dG9uLWRldGFpbC9maXhlZC1idXR0b24tZGV0YWlsLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFHckUsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sNEJBQTRCLENBQUM7QUFDOUQsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFDM0QsT0FBTyxFQUFDLDJCQUEyQixFQUFDLE1BQU0sd0NBQXdDLENBQUM7Ozs7QUFnQm5GLE1BQU0sT0FBTyxpQ0FBaUM7SUFJMUMsSUFBVyxLQUFLO1FBQ1osT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDO0lBQ3ZCLENBQUM7SUFFRCxJQUNXLEtBQUssQ0FBQyxLQUFZO1FBQ3pCLElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDO1FBQ3BCLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ2pCLElBQUksQ0FBQyxVQUFVLEdBQUcsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztZQUNsQyxJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQztRQUMzQixDQUFDO0lBQ0wsQ0FBQztJQVNELFlBQW1CLEtBQXFCO1FBdkJoQyxjQUFTLEdBQUcsSUFBSSxDQUFDO1FBQ2xCLGVBQVUsR0FBRyxLQUFLLENBQUM7UUFtQkEsV0FBTSxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7UUFDbEMsV0FBTSxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7UUFHeEQsS0FBSyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUNyRixDQUFDO0lBRU0sV0FBVztRQUNkLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNwQixJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3ZCLENBQUM7SUFDTCxDQUFDO0lBRU0sV0FBVztRQUNkLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNwQixJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3ZCLENBQUM7SUFDTCxDQUFDOzhHQXRDUSxpQ0FBaUM7a0dBQWpDLGlDQUFpQyxrTENyQjlDLGlvQkFzQkEsMERESGMsMkJBQTJCLCtHQUFFLGdCQUFnQjs7MkZBRTlDLGlDQUFpQztrQkFQN0MsU0FBUzsrQkFDSSw2QkFBNkIsY0FHM0IsSUFBSSxXQUNQLENBQUMsMkJBQTJCLEVBQUUsZ0JBQWdCLENBQUM7bUZBVzdDLEtBQUs7c0JBRGYsS0FBSzt1QkFBQyxFQUFDLFFBQVEsRUFBRSxJQUFJLEVBQUM7Z0JBV1MsSUFBSTtzQkFBbkMsS0FBSzt1QkFBQyxFQUFDLFFBQVEsRUFBRSxJQUFJLEVBQUM7Z0JBRUcsTUFBTTtzQkFBL0IsTUFBTTtnQkFDbUIsTUFBTTtzQkFBL0IsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtGb3JtR3JvdXB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7QWN0aXZhdGVkUm91dGV9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQge3Rha2VVbnRpbERlc3Ryb3llZH0gZnJvbSAnQGFuZ3VsYXIvY29yZS9yeGpzLWludGVyb3AnO1xuaW1wb3J0IHtNYXRUb29sdGlwTW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90b29sdGlwJztcbmltcG9ydCB7TmF0dXJhbEZpeGVkQnV0dG9uQ29tcG9uZW50fSBmcm9tICcuLi9maXhlZC1idXR0b24vZml4ZWQtYnV0dG9uLmNvbXBvbmVudCc7XG5cbnR5cGUgTW9kZWwgPSB7XG4gICAgaWQ/OiBzdHJpbmc7XG4gICAgcGVybWlzc2lvbnM/OiB7XG4gICAgICAgIGRlbGV0ZTogYm9vbGVhbjtcbiAgICB9O1xufTtcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICduYXR1cmFsLWZpeGVkLWJ1dHRvbi1kZXRhaWwnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9maXhlZC1idXR0b24tZGV0YWlsLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybDogJy4vZml4ZWQtYnV0dG9uLWRldGFpbC5jb21wb25lbnQuc2NzcycsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbTmF0dXJhbEZpeGVkQnV0dG9uQ29tcG9uZW50LCBNYXRUb29sdGlwTW9kdWxlXSxcbn0pXG5leHBvcnQgY2xhc3MgTmF0dXJhbEZpeGVkQnV0dG9uRGV0YWlsQ29tcG9uZW50IHtcbiAgICBwcml2YXRlIGNhbkNoYW5nZSA9IHRydWU7XG4gICAgcHVibGljIGlzQ3JlYXRpb24gPSBmYWxzZTtcblxuICAgIHB1YmxpYyBnZXQgbW9kZWwoKTogTW9kZWwge1xuICAgICAgICByZXR1cm4gdGhpcy5fbW9kZWw7XG4gICAgfVxuXG4gICAgQElucHV0KHtyZXF1aXJlZDogdHJ1ZX0pXG4gICAgcHVibGljIHNldCBtb2RlbCh2YWx1ZTogTW9kZWwpIHtcbiAgICAgICAgdGhpcy5fbW9kZWwgPSB2YWx1ZTtcbiAgICAgICAgaWYgKHRoaXMuY2FuQ2hhbmdlKSB7XG4gICAgICAgICAgICB0aGlzLmlzQ3JlYXRpb24gPSAhdGhpcy5fbW9kZWwuaWQ7XG4gICAgICAgICAgICB0aGlzLmNhbkNoYW5nZSA9IGZhbHNlO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBfbW9kZWwhOiBNb2RlbDtcblxuICAgIEBJbnB1dCh7cmVxdWlyZWQ6IHRydWV9KSBwdWJsaWMgZm9ybSE6IEZvcm1Hcm91cDtcblxuICAgIEBPdXRwdXQoKSBwdWJsaWMgcmVhZG9ubHkgY3JlYXRlID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuICAgIEBPdXRwdXQoKSBwdWJsaWMgcmVhZG9ubHkgZGVsZXRlID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gICAgcHVibGljIGNvbnN0cnVjdG9yKHJvdXRlOiBBY3RpdmF0ZWRSb3V0ZSkge1xuICAgICAgICByb3V0ZS5wYXJhbXMucGlwZSh0YWtlVW50aWxEZXN0cm95ZWQoKSkuc3Vic2NyaWJlKCgpID0+ICh0aGlzLmNhbkNoYW5nZSA9IHRydWUpKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgY2xpY2tDcmVhdGUoKTogdm9pZCB7XG4gICAgICAgIGlmICh0aGlzLmZvcm0uZW5hYmxlZCkge1xuICAgICAgICAgICAgdGhpcy5jcmVhdGUuZW1pdCgpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHVibGljIGNsaWNrRGVsZXRlKCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5mb3JtLmVuYWJsZWQpIHtcbiAgICAgICAgICAgIHRoaXMuZGVsZXRlLmVtaXQoKTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiIsIkBpZiAoaXNDcmVhdGlvbikge1xuICAgIDxuYXR1cmFsLWZpeGVkLWJ1dHRvblxuICAgICAgICAoY2xpY2spPVwiY2xpY2tDcmVhdGUoKVwiXG4gICAgICAgIFtkaXNhYmxlZF09XCJmb3JtLmRpc2FibGVkXCJcbiAgICAgICAgW2NvbG9yXT1cImZvcm0udmFsaWQgPyAnYWNjZW50JyA6ICd3YXJuJ1wiXG4gICAgICAgIGNsYXNzPVwiZGV0YWlsLXNwZWVkLWRpYWxcIlxuICAgICAgICBpY29uPVwic2F2ZVwiXG4gICAgLz5cbn1cblxuQGlmICghaXNDcmVhdGlvbiAmJiAoIW1vZGVsLnBlcm1pc3Npb25zIHx8IG1vZGVsLnBlcm1pc3Npb25zLmRlbGV0ZSkpIHtcbiAgICA8bmF0dXJhbC1maXhlZC1idXR0b25cbiAgICAgICAgKGNsaWNrKT1cImNsaWNrRGVsZXRlKClcIlxuICAgICAgICBbZGlzYWJsZWRdPVwiZm9ybS5kaXNhYmxlZFwiXG4gICAgICAgIGNsYXNzPVwiZGV0YWlsLXNwZWVkLWRpYWxcIlxuICAgICAgICBjb2xvcj1cIndhcm5cIlxuICAgICAgICBpY29uPVwiZGVsZXRlX2ZvcmV2ZXJcIlxuICAgICAgICBpMThuLW1hdFRvb2x0aXBcbiAgICAgICAgbWF0VG9vbHRpcD1cIlN1cHByaW1lciBkw6lmaW5pdGl2ZW1lbnRcIlxuICAgICAgICBtYXRUb29sdGlwUG9zaXRpb249XCJsZWZ0XCJcbiAgICAvPlxufVxuIl19
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZml4ZWQtYnV0dG9uLWRldGFpbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uYXR1cmFsL3NyYy9saWIvbW9kdWxlcy9maXhlZC1idXR0b24tZGV0YWlsL2ZpeGVkLWJ1dHRvbi1kZXRhaWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvZml4ZWQtYnV0dG9uLWRldGFpbC9maXhlZC1idXR0b24tZGV0YWlsLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRTdFLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUM5RCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQztBQUMzRCxPQUFPLEVBQUMsMkJBQTJCLEVBQUMsTUFBTSx3Q0FBd0MsQ0FBQzs7O0FBZ0JuRixNQUFNLE9BQU8saUNBQWlDO0lBQ2xDLFNBQVMsR0FBRyxJQUFJLENBQUM7SUFDbEIsVUFBVSxHQUFHLEtBQUssQ0FBQztJQUUxQixJQUFXLEtBQUs7UUFDWixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUM7SUFDdkIsQ0FBQztJQUVELElBQ1csS0FBSyxDQUFDLEtBQVk7UUFDekIsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUM7UUFDcEIsSUFBSSxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7WUFDakIsSUFBSSxDQUFDLFVBQVUsR0FBRyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO1lBQ2xDLElBQUksQ0FBQyxTQUFTLEdBQUcsS0FBSyxDQUFDO1FBQzNCLENBQUM7SUFDTCxDQUFDO0lBRU8sTUFBTSxDQUFTO0lBRVMsSUFBSSxDQUFhO0lBRXZCLE1BQU0sR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO0lBQ2xDLE1BQU0sR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO0lBRTVEO1FBQ0ksTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBRXJDLEtBQUssQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLGtCQUFrQixFQUFFLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUM7SUFDckYsQ0FBQztJQUVNLFdBQVc7UUFDZCxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDcEIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUN2QixDQUFDO0lBQ0wsQ0FBQztJQUVNLFdBQVc7UUFDZCxJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDcEIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUN2QixDQUFDO0lBQ0wsQ0FBQzt1R0F4Q1EsaUNBQWlDOzJGQUFqQyxpQ0FBaUMsa0xDckI5Qyxpb0JBc0JBLDBEREhjLDJCQUEyQiwrR0FBRSxnQkFBZ0I7OzJGQUU5QyxpQ0FBaUM7a0JBUDdDLFNBQVM7K0JBQ0ksNkJBQTZCLGNBRzNCLElBQUksV0FDUCxDQUFDLDJCQUEyQixFQUFFLGdCQUFnQixDQUFDO3dEQVc3QyxLQUFLO3NCQURmLEtBQUs7dUJBQUMsRUFBQyxRQUFRLEVBQUUsSUFBSSxFQUFDO2dCQVdTLElBQUk7c0JBQW5DLEtBQUs7dUJBQUMsRUFBQyxRQUFRLEVBQUUsSUFBSSxFQUFDO2dCQUVHLE1BQU07c0JBQS9CLE1BQU07Z0JBQ21CLE1BQU07c0JBQS9CLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT3V0cHV0LCBpbmplY3R9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtGb3JtR3JvdXB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7QWN0aXZhdGVkUm91dGV9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQge3Rha2VVbnRpbERlc3Ryb3llZH0gZnJvbSAnQGFuZ3VsYXIvY29yZS9yeGpzLWludGVyb3AnO1xuaW1wb3J0IHtNYXRUb29sdGlwTW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90b29sdGlwJztcbmltcG9ydCB7TmF0dXJhbEZpeGVkQnV0dG9uQ29tcG9uZW50fSBmcm9tICcuLi9maXhlZC1idXR0b24vZml4ZWQtYnV0dG9uLmNvbXBvbmVudCc7XG5cbnR5cGUgTW9kZWwgPSB7XG4gICAgaWQ/OiBzdHJpbmc7XG4gICAgcGVybWlzc2lvbnM/OiB7XG4gICAgICAgIGRlbGV0ZTogYm9vbGVhbjtcbiAgICB9O1xufTtcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICduYXR1cmFsLWZpeGVkLWJ1dHRvbi1kZXRhaWwnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9maXhlZC1idXR0b24tZGV0YWlsLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybDogJy4vZml4ZWQtYnV0dG9uLWRldGFpbC5jb21wb25lbnQuc2NzcycsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbTmF0dXJhbEZpeGVkQnV0dG9uQ29tcG9uZW50LCBNYXRUb29sdGlwTW9kdWxlXSxcbn0pXG5leHBvcnQgY2xhc3MgTmF0dXJhbEZpeGVkQnV0dG9uRGV0YWlsQ29tcG9uZW50IHtcbiAgICBwcml2YXRlIGNhbkNoYW5nZSA9IHRydWU7XG4gICAgcHVibGljIGlzQ3JlYXRpb24gPSBmYWxzZTtcblxuICAgIHB1YmxpYyBnZXQgbW9kZWwoKTogTW9kZWwge1xuICAgICAgICByZXR1cm4gdGhpcy5fbW9kZWw7XG4gICAgfVxuXG4gICAgQElucHV0KHtyZXF1aXJlZDogdHJ1ZX0pXG4gICAgcHVibGljIHNldCBtb2RlbCh2YWx1ZTogTW9kZWwpIHtcbiAgICAgICAgdGhpcy5fbW9kZWwgPSB2YWx1ZTtcbiAgICAgICAgaWYgKHRoaXMuY2FuQ2hhbmdlKSB7XG4gICAgICAgICAgICB0aGlzLmlzQ3JlYXRpb24gPSAhdGhpcy5fbW9kZWwuaWQ7XG4gICAgICAgICAgICB0aGlzLmNhbkNoYW5nZSA9IGZhbHNlO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBfbW9kZWwhOiBNb2RlbDtcblxuICAgIEBJbnB1dCh7cmVxdWlyZWQ6IHRydWV9KSBwdWJsaWMgZm9ybSE6IEZvcm1Hcm91cDtcblxuICAgIEBPdXRwdXQoKSBwdWJsaWMgcmVhZG9ubHkgY3JlYXRlID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuICAgIEBPdXRwdXQoKSBwdWJsaWMgcmVhZG9ubHkgZGVsZXRlID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gICAgcHVibGljIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBjb25zdCByb3V0ZSA9IGluamVjdChBY3RpdmF0ZWRSb3V0ZSk7XG5cbiAgICAgICAgcm91dGUucGFyYW1zLnBpcGUodGFrZVVudGlsRGVzdHJveWVkKCkpLnN1YnNjcmliZSgoKSA9PiAodGhpcy5jYW5DaGFuZ2UgPSB0cnVlKSk7XG4gICAgfVxuXG4gICAgcHVibGljIGNsaWNrQ3JlYXRlKCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5mb3JtLmVuYWJsZWQpIHtcbiAgICAgICAgICAgIHRoaXMuY3JlYXRlLmVtaXQoKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHB1YmxpYyBjbGlja0RlbGV0ZSgpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuZm9ybS5lbmFibGVkKSB7XG4gICAgICAgICAgICB0aGlzLmRlbGV0ZS5lbWl0KCk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iLCJAaWYgKGlzQ3JlYXRpb24pIHtcbiAgICA8bmF0dXJhbC1maXhlZC1idXR0b25cbiAgICAgICAgKGNsaWNrKT1cImNsaWNrQ3JlYXRlKClcIlxuICAgICAgICBbZGlzYWJsZWRdPVwiZm9ybS5kaXNhYmxlZFwiXG4gICAgICAgIFtjb2xvcl09XCJmb3JtLnZhbGlkID8gJ2FjY2VudCcgOiAnd2FybidcIlxuICAgICAgICBjbGFzcz1cImRldGFpbC1zcGVlZC1kaWFsXCJcbiAgICAgICAgaWNvbj1cInNhdmVcIlxuICAgIC8+XG59XG5cbkBpZiAoIWlzQ3JlYXRpb24gJiYgKCFtb2RlbC5wZXJtaXNzaW9ucyB8fCBtb2RlbC5wZXJtaXNzaW9ucy5kZWxldGUpKSB7XG4gICAgPG5hdHVyYWwtZml4ZWQtYnV0dG9uXG4gICAgICAgIChjbGljayk9XCJjbGlja0RlbGV0ZSgpXCJcbiAgICAgICAgW2Rpc2FibGVkXT1cImZvcm0uZGlzYWJsZWRcIlxuICAgICAgICBjbGFzcz1cImRldGFpbC1zcGVlZC1kaWFsXCJcbiAgICAgICAgY29sb3I9XCJ3YXJuXCJcbiAgICAgICAgaWNvbj1cImRlbGV0ZV9mb3JldmVyXCJcbiAgICAgICAgaTE4bi1tYXRUb29sdGlwXG4gICAgICAgIG1hdFRvb2x0aXA9XCJTdXBwcmltZXIgZMOpZmluaXRpdmVtZW50XCJcbiAgICAgICAgbWF0VG9vbHRpcFBvc2l0aW9uPVwibGVmdFwiXG4gICAgLz5cbn1cbiJdfQ==
@@ -1,4 +1,11 @@
1
1
  export class HierarchicFlatNode {
2
+ node;
3
+ name;
4
+ level;
5
+ expandable;
6
+ selectable;
7
+ deselectable;
8
+ loading = false;
2
9
  constructor(node, name, level = 0, expandable = false, selectable = true, deselectable = true) {
3
10
  this.node = node;
4
11
  this.name = name;
@@ -6,7 +13,6 @@ export class HierarchicFlatNode {
6
13
  this.expandable = expandable;
7
14
  this.selectable = selectable;
8
15
  this.deselectable = deselectable;
9
- this.loading = false;
10
16
  }
11
17
  }
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxhdC1ub2RlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvaGllcmFyY2hpYy1zZWxlY3Rvci9jbGFzc2VzL2ZsYXQtbm9kZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLE9BQU8sa0JBQWtCO0lBRzNCLFlBQ29CLElBQXlCLEVBQ3pCLElBQVksRUFDWixRQUFRLENBQUMsRUFDbEIsYUFBYSxLQUFLLEVBQ1QsYUFBYSxJQUFJLEVBQzFCLGVBQWUsSUFBSTtRQUxWLFNBQUksR0FBSixJQUFJLENBQXFCO1FBQ3pCLFNBQUksR0FBSixJQUFJLENBQVE7UUFDWixVQUFLLEdBQUwsS0FBSyxDQUFJO1FBQ2xCLGVBQVUsR0FBVixVQUFVLENBQVE7UUFDVCxlQUFVLEdBQVYsVUFBVSxDQUFPO1FBQzFCLGlCQUFZLEdBQVosWUFBWSxDQUFPO1FBUnZCLFlBQU8sR0FBRyxLQUFLLENBQUM7SUFTcEIsQ0FBQztDQUNQIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtIaWVyYXJjaGljTW9kZWxOb2RlfSBmcm9tICcuL21vZGVsLW5vZGUnO1xuXG5leHBvcnQgY2xhc3MgSGllcmFyY2hpY0ZsYXROb2RlIHtcbiAgICBwdWJsaWMgbG9hZGluZyA9IGZhbHNlO1xuXG4gICAgcHVibGljIGNvbnN0cnVjdG9yKFxuICAgICAgICBwdWJsaWMgcmVhZG9ubHkgbm9kZTogSGllcmFyY2hpY01vZGVsTm9kZSxcbiAgICAgICAgcHVibGljIHJlYWRvbmx5IG5hbWU6IHN0cmluZyxcbiAgICAgICAgcHVibGljIHJlYWRvbmx5IGxldmVsID0gMCxcbiAgICAgICAgcHVibGljIGV4cGFuZGFibGUgPSBmYWxzZSxcbiAgICAgICAgcHVibGljIHJlYWRvbmx5IHNlbGVjdGFibGUgPSB0cnVlLFxuICAgICAgICBwdWJsaWMgZGVzZWxlY3RhYmxlID0gdHJ1ZSxcbiAgICApIHt9XG59XG4iXX0=
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxhdC1ub2RlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmF0dXJhbC9zcmMvbGliL21vZHVsZXMvaGllcmFyY2hpYy1zZWxlY3Rvci9jbGFzc2VzL2ZsYXQtbm9kZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLE9BQU8sa0JBQWtCO0lBSVA7SUFDQTtJQUNBO0lBQ1Q7SUFDUztJQUNUO0lBUkosT0FBTyxHQUFHLEtBQUssQ0FBQztJQUV2QixZQUNvQixJQUF5QixFQUN6QixJQUFZLEVBQ1osUUFBUSxDQUFDLEVBQ2xCLGFBQWEsS0FBSyxFQUNULGFBQWEsSUFBSSxFQUMxQixlQUFlLElBQUk7UUFMVixTQUFJLEdBQUosSUFBSSxDQUFxQjtRQUN6QixTQUFJLEdBQUosSUFBSSxDQUFRO1FBQ1osVUFBSyxHQUFMLEtBQUssQ0FBSTtRQUNsQixlQUFVLEdBQVYsVUFBVSxDQUFRO1FBQ1QsZUFBVSxHQUFWLFVBQVUsQ0FBTztRQUMxQixpQkFBWSxHQUFaLFlBQVksQ0FBTztJQUMzQixDQUFDO0NBQ1AiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0hpZXJhcmNoaWNNb2RlbE5vZGV9IGZyb20gJy4vbW9kZWwtbm9kZSc7XG5cbmV4cG9ydCBjbGFzcyBIaWVyYXJjaGljRmxhdE5vZGUge1xuICAgIHB1YmxpYyBsb2FkaW5nID0gZmFsc2U7XG5cbiAgICBwdWJsaWMgY29uc3RydWN0b3IoXG4gICAgICAgIHB1YmxpYyByZWFkb25seSBub2RlOiBIaWVyYXJjaGljTW9kZWxOb2RlLFxuICAgICAgICBwdWJsaWMgcmVhZG9ubHkgbmFtZTogc3RyaW5nLFxuICAgICAgICBwdWJsaWMgcmVhZG9ubHkgbGV2ZWwgPSAwLFxuICAgICAgICBwdWJsaWMgZXhwYW5kYWJsZSA9IGZhbHNlLFxuICAgICAgICBwdWJsaWMgcmVhZG9ubHkgc2VsZWN0YWJsZSA9IHRydWUsXG4gICAgICAgIHB1YmxpYyBkZXNlbGVjdGFibGUgPSB0cnVlLFxuICAgICkge31cbn1cbiJdfQ==