@ecodev/natural 50.4.1 → 52.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/classes/abstract-controller.mjs +30 -0
- package/esm2022/lib/classes/abstract-detail.mjs +166 -0
- package/{esm2020 → esm2022}/lib/classes/abstract-editable-list.mjs +4 -4
- package/esm2022/lib/classes/abstract-list.mjs +434 -0
- package/esm2022/lib/classes/abstract-navigable-list.mjs +131 -0
- package/{esm2020 → esm2022}/lib/directives/http-prefix.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/alert/alert.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modules/alert/alert.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/alert/confirm.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/avatar/avatar.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modules/avatar/component/avatar.component.mjs +6 -6
- package/{esm2020 → esm2022}/lib/modules/avatar/service/avatar.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/columns-picker/columns-picker.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/columns-picker/columns-picker.module.mjs +19 -19
- package/{esm2020 → esm2022}/lib/modules/common/common-module.mjs +19 -19
- package/{esm2020 → esm2022}/lib/modules/common/directives/linkable-tab.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/common/directives/src-density.directive.mjs +6 -5
- package/{esm2020 → esm2022}/lib/modules/common/pipes/capitalize.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/common/pipes/ellipsis.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/common/pipes/enum.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/common/pipes/swiss-date.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/common/pipes/time-ago.pipe.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/common/services/memory-storage.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/common/services/seo.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/detail-header/detail-header.component.mjs +6 -5
- package/{esm2020 → esm2022}/lib/modules/detail-header/detail-header.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modules/dialog-trigger/dialog-trigger.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/dialog-trigger/dialog-trigger.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modules/dropdown-components/abstract-association-select-component.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/dropdown-components/natural-dropdown-components.module.mjs +39 -39
- package/esm2022/lib/modules/dropdown-components/type-date/type-date.component.mjs +164 -0
- package/{esm2020 → esm2022}/lib/modules/dropdown-components/type-date-range/type-date-range.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/dropdown-components/type-hierarchic-selector/type-hierarchic-selector.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/dropdown-components/type-natural-select/type-natural-select.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/dropdown-components/type-number/type-number.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/dropdown-components/type-select/type-select.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/dropdown-components/type-text/type-text.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/file/abstract-file.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/file/component/file.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/file/file-drop.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/file/file-select.directive.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/file/file.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modules/file/file.service.mjs +4 -4
- package/esm2022/lib/modules/fixed-button/fixed-button.component.mjs +29 -0
- package/{esm2020 → esm2022}/lib/modules/fixed-button/fixed-button.module.mjs +5 -5
- package/esm2022/lib/modules/fixed-button-detail/fixed-button-detail.component.mjs +53 -0
- package/{esm2020 → esm2022}/lib/modules/fixed-button-detail/fixed-button-detail.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.mjs +6 -5
- package/{esm2020 → esm2022}/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/hierarchic-selector/hierarchic-selector-dialog/hierarchic-selector-dialog.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/hierarchic-selector/hierarchic-selector.module.mjs +33 -33
- package/{esm2020 → esm2022}/lib/modules/icon/icon.directive.mjs +6 -5
- package/{esm2020 → esm2022}/lib/modules/icon/icon.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modules/logger/error-handler.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/logger/error.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modules/matomo/matomo-module.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modules/matomo/matomo.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/panels/abstract-panel.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/panels/panels.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/panels/panels.module.mjs +5 -5
- package/esm2022/lib/modules/panels/panels.service.mjs +328 -0
- package/esm2022/lib/modules/panels/panels.urlmatcher.mjs +75 -0
- package/esm2022/lib/modules/panels/types.mjs +3 -0
- package/esm2022/lib/modules/relations/relations.component.mjs +211 -0
- package/{esm2020 → esm2022}/lib/modules/relations/relations.module.mjs +25 -25
- package/{esm2020 → esm2022}/lib/modules/search/dropdown-container/dropdown-container.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/search/dropdown-container/dropdown.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/search/facet-selector/facet-selector.component.mjs +4 -4
- package/esm2022/lib/modules/search/group/group.component.mjs +53 -0
- package/{esm2020 → esm2022}/lib/modules/search/input/input.component.mjs +6 -5
- package/{esm2020 → esm2022}/lib/modules/search/search/search.component.mjs +4 -4
- package/esm2022/lib/modules/search/search.module.mjs +90 -0
- package/{esm2020 → esm2022}/lib/modules/select/abstract-select.component.mjs +4 -4
- package/esm2022/lib/modules/select/select/select.component.mjs +279 -0
- package/esm2022/lib/modules/select/select-enum/select-enum.component.mjs +47 -0
- package/{esm2020 → esm2022}/lib/modules/select/select-hierarchic/select-hierarchic.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/select/select.module.mjs +29 -29
- package/{esm2020 → esm2022}/lib/modules/sidenav/sidenav/sidenav.component.mjs +4 -4
- package/esm2022/lib/modules/sidenav/sidenav-container/sidenav-container.component.mjs +87 -0
- package/{esm2020 → esm2022}/lib/modules/sidenav/sidenav-content/sidenav-content.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/sidenav/sidenav-stack.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/sidenav/sidenav.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modules/sidenav/sidenav.service.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modules/stamp/stamp-module.module.mjs +5 -5
- package/esm2022/lib/modules/stamp/stamp.component.mjs +23 -0
- package/{esm2020 → esm2022}/lib/modules/table-button/table-button.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/table-button/table-button.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/services/debounce.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/services/enum.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/services/link-mutation.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/services/persistence.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/services/swiss-parsing-date-adapter.service.mjs +4 -4
- package/{fesm2020 → fesm2022}/ecodev-natural.mjs +555 -537
- package/fesm2022/ecodev-natural.mjs.map +1 -0
- package/lib/classes/abstract-controller.d.ts +12 -6
- package/lib/classes/abstract-detail.d.ts +5 -6
- package/lib/classes/abstract-list.d.ts +7 -8
- package/lib/classes/abstract-navigable-list.d.ts +3 -3
- package/lib/directives/http-prefix.directive.d.ts +1 -1
- package/lib/modules/avatar/component/avatar.component.d.ts +1 -1
- package/lib/modules/columns-picker/columns-picker.component.d.ts +1 -1
- package/lib/modules/common/directives/linkable-tab.directive.d.ts +1 -1
- package/lib/modules/common/directives/src-density.directive.d.ts +1 -1
- package/lib/modules/detail-header/detail-header.component.d.ts +1 -1
- package/lib/modules/dropdown-components/type-date/type-date.component.d.ts +1 -2
- package/lib/modules/file/abstract-file.d.ts +1 -1
- package/lib/modules/file/component/file.component.d.ts +1 -1
- package/lib/modules/file/file-select.directive.d.ts +1 -1
- package/lib/modules/fixed-button/fixed-button.component.d.ts +1 -1
- package/lib/modules/fixed-button-detail/fixed-button-detail.component.d.ts +2 -3
- package/lib/modules/hierarchic-selector/hierarchic-selector/hierarchic-selector.component.d.ts +1 -1
- package/lib/modules/icon/icon.directive.d.ts +1 -1
- package/lib/modules/panels/panels.service.d.ts +1 -1
- package/lib/modules/panels/types.d.ts +10 -12
- package/lib/modules/relations/relations.component.d.ts +1 -1
- package/lib/modules/search/group/group.component.d.ts +1 -1
- package/lib/modules/search/input/input.component.d.ts +1 -1
- package/lib/modules/search/search/search.component.d.ts +1 -1
- package/lib/modules/select/abstract-select.component.d.ts +1 -1
- package/lib/modules/select/select/select.component.d.ts +1 -1
- package/lib/modules/select/select-enum/select-enum.component.d.ts +1 -1
- package/lib/modules/select/select-hierarchic/select-hierarchic.component.d.ts +1 -1
- package/lib/modules/sidenav/sidenav-container/sidenav-container.component.d.ts +1 -1
- package/lib/modules/sidenav/sidenav.service.d.ts +1 -1
- package/lib/modules/stamp/stamp.component.d.ts +1 -1
- package/lib/modules/table-button/table-button.component.d.ts +1 -1
- package/package.json +17 -25
- package/esm2020/lib/classes/abstract-controller.mjs +0 -30
- package/esm2020/lib/classes/abstract-detail.mjs +0 -158
- package/esm2020/lib/classes/abstract-list.mjs +0 -435
- package/esm2020/lib/classes/abstract-navigable-list.mjs +0 -131
- package/esm2020/lib/modules/dropdown-components/type-date/type-date.component.mjs +0 -166
- package/esm2020/lib/modules/fixed-button/fixed-button.component.mjs +0 -28
- package/esm2020/lib/modules/fixed-button-detail/fixed-button-detail.component.mjs +0 -53
- package/esm2020/lib/modules/panels/panels.service.mjs +0 -325
- package/esm2020/lib/modules/panels/panels.urlmatcher.mjs +0 -81
- package/esm2020/lib/modules/panels/types.mjs +0 -3
- package/esm2020/lib/modules/relations/relations.component.mjs +0 -210
- package/esm2020/lib/modules/search/group/group.component.mjs +0 -51
- package/esm2020/lib/modules/search/search.module.mjs +0 -90
- package/esm2020/lib/modules/select/select/select.component.mjs +0 -278
- package/esm2020/lib/modules/select/select-enum/select-enum.component.mjs +0 -46
- package/esm2020/lib/modules/sidenav/sidenav-container/sidenav-container.component.mjs +0 -86
- package/esm2020/lib/modules/stamp/stamp.component.mjs +0 -22
- package/fesm2015/ecodev-natural.mjs +0 -11532
- package/fesm2015/ecodev-natural.mjs.map +0 -1
- package/fesm2020/ecodev-natural.mjs.map +0 -1
- /package/{esm2020 → esm2022}/ecodev-natural.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/classes/apollo-utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/classes/data-source.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/classes/query-variable-manager-utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/classes/query-variable-manager.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/classes/rxjs.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/classes/tld.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/classes/utility.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/classes/validators.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/alert/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/avatar/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/avatar/service/md5.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/avatar/sources/gravatar.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/avatar/sources/image.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/avatar/sources/initials.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/avatar/sources/source.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/columns-picker/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/columns-picker/types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/common/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/detail-header/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/dialog-trigger/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/dropdown-components/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/dropdown-components/types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/dropdown-components/utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/file/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/file/types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/file/utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/fixed-button/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/fixed-button-detail/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/hierarchic-selector/classes/flat-node.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/hierarchic-selector/classes/hierarchic-configuration.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/hierarchic-selector/classes/hierarchic-filters-configuration.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/hierarchic-selector/classes/model-node.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/hierarchic-selector/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/icon/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/logger/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/matomo/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/panels/fallback-if-no-opened-panels.urlmatcher.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/panels/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/relations/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/search/classes/graphql-doctrine.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/search/classes/graphql-doctrine.types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/search/classes/transformers.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/search/classes/url.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/search/classes/utils.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/search/dropdown-container/dropdown-container-animations.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/search/dropdown-container/dropdown-ref.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/search/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/search/types/dropdown-component.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/search/types/facet.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/search/types/values.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/select/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/sidenav/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/stamp/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/table-button/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/services/abstract-model.service.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/types/types.mjs +0 -0
- /package/{esm2020 → esm2022}/public-api.mjs +0 -0
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { Directive } from '@angular/core';
|
|
2
|
+
import { Subject } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class NaturalAbstractController {
|
|
5
|
+
constructor() {
|
|
6
|
+
/**
|
|
7
|
+
* Usage:
|
|
8
|
+
*
|
|
9
|
+
* ```ts
|
|
10
|
+
* import { takeUntil } from 'rxjs/operators';
|
|
11
|
+
* .pipe(takeUntil(this.ngUnsubscribe)) // as first pipe on observables that should be destroyed on component destroy
|
|
12
|
+
* ```
|
|
13
|
+
*
|
|
14
|
+
* @deprecated Instead of this, you should create the observable in the constructor or field initializers and use
|
|
15
|
+
* Angular native `.pipe(takeUntilDestroyed())`. And most likely subscribe at a later point. We keep this method until
|
|
16
|
+
* all existing usages (typically in `ngOnInit()`) are migrated away.
|
|
17
|
+
*/
|
|
18
|
+
this.ngUnsubscribe = new Subject();
|
|
19
|
+
}
|
|
20
|
+
ngOnDestroy() {
|
|
21
|
+
this.ngUnsubscribe.next(); // unsubscribe everybody
|
|
22
|
+
this.ngUnsubscribe.complete(); // complete the stream, because we will never emit again
|
|
23
|
+
}
|
|
24
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: NaturalAbstractController, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
25
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.2", type: NaturalAbstractController, ngImport: i0 }); }
|
|
26
|
+
}
|
|
27
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: NaturalAbstractController, decorators: [{
|
|
28
|
+
type: Directive
|
|
29
|
+
}] });
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzdHJhY3QtY29udHJvbGxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25hdHVyYWwvc3JjL2xpYi9jbGFzc2VzL2Fic3RyYWN0LWNvbnRyb2xsZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBWSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBQUMsT0FBTyxFQUFDLE1BQU0sTUFBTSxDQUFDOztBQUc3QixNQUFNLE9BQU8seUJBQXlCO0lBRHRDO1FBRUk7Ozs7Ozs7Ozs7O1dBV0c7UUFDZ0Isa0JBQWEsR0FBRyxJQUFJLE9BQU8sRUFBUSxDQUFDO0tBTTFEO0lBSlUsV0FBVztRQUNkLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyx3QkFBd0I7UUFDbkQsSUFBSSxDQUFDLGFBQWEsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDLHdEQUF3RDtJQUMzRixDQUFDOzhHQWxCUSx5QkFBeUI7a0dBQXpCLHlCQUF5Qjs7MkZBQXpCLHlCQUF5QjtrQkFEckMsU0FBUyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RGlyZWN0aXZlLCBPbkRlc3Ryb3l9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtTdWJqZWN0fSBmcm9tICdyeGpzJztcblxuQERpcmVjdGl2ZSgpXG5leHBvcnQgY2xhc3MgTmF0dXJhbEFic3RyYWN0Q29udHJvbGxlciBpbXBsZW1lbnRzIE9uRGVzdHJveSB7XG4gICAgLyoqXG4gICAgICogVXNhZ2U6XG4gICAgICpcbiAgICAgKiBgYGB0c1xuICAgICAqIGltcG9ydCB7IHRha2VVbnRpbCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcbiAgICAgKiAucGlwZSh0YWtlVW50aWwodGhpcy5uZ1Vuc3Vic2NyaWJlKSkgLy8gYXMgZmlyc3QgcGlwZSBvbiBvYnNlcnZhYmxlcyB0aGF0IHNob3VsZCBiZSBkZXN0cm95ZWQgb24gY29tcG9uZW50IGRlc3Ryb3lcbiAgICAgKiBgYGBcbiAgICAgKlxuICAgICAqIEBkZXByZWNhdGVkIEluc3RlYWQgb2YgdGhpcywgeW91IHNob3VsZCBjcmVhdGUgdGhlIG9ic2VydmFibGUgaW4gdGhlIGNvbnN0cnVjdG9yIG9yIGZpZWxkIGluaXRpYWxpemVycyBhbmQgdXNlXG4gICAgICogQW5ndWxhciBuYXRpdmUgYC5waXBlKHRha2VVbnRpbERlc3Ryb3llZCgpKWAuIEFuZCBtb3N0IGxpa2VseSBzdWJzY3JpYmUgYXQgYSBsYXRlciBwb2ludC4gV2Uga2VlcCB0aGlzIG1ldGhvZCB1bnRpbFxuICAgICAqIGFsbCBleGlzdGluZyB1c2FnZXMgKHR5cGljYWxseSBpbiBgbmdPbkluaXQoKWApIGFyZSBtaWdyYXRlZCBhd2F5LlxuICAgICAqL1xuICAgIHByb3RlY3RlZCByZWFkb25seSBuZ1Vuc3Vic2NyaWJlID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcblxuICAgIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5uZ1Vuc3Vic2NyaWJlLm5leHQoKTsgLy8gdW5zdWJzY3JpYmUgZXZlcnlib2R5XG4gICAgICAgIHRoaXMubmdVbnN1YnNjcmliZS5jb21wbGV0ZSgpOyAvLyBjb21wbGV0ZSB0aGUgc3RyZWFtLCBiZWNhdXNlIHdlIHdpbGwgbmV2ZXIgZW1pdCBhZ2FpblxuICAgIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
import { Directive, inject } from '@angular/core';
|
|
2
|
+
import { UntypedFormGroup } from '@angular/forms';
|
|
3
|
+
import { ActivatedRoute, Router } from '@angular/router';
|
|
4
|
+
import { kebabCase, merge, mergeWith, omit } from 'lodash-es';
|
|
5
|
+
import { NaturalAlertService } from '../modules/alert/alert.service';
|
|
6
|
+
import { NaturalAbstractPanel } from '../modules/panels/abstract-panel';
|
|
7
|
+
import { finalize } from 'rxjs/operators';
|
|
8
|
+
import { ifValid, validateAllFormControls } from './validators';
|
|
9
|
+
import { mergeOverrideArray } from './utility';
|
|
10
|
+
import { EMPTY, endWith, last, switchMap } from 'rxjs';
|
|
11
|
+
import * as i0 from "@angular/core";
|
|
12
|
+
// @dynamic
|
|
13
|
+
export class NaturalAbstractDetail extends NaturalAbstractPanel {
|
|
14
|
+
constructor(key, service) {
|
|
15
|
+
super();
|
|
16
|
+
this.key = key;
|
|
17
|
+
this.service = service;
|
|
18
|
+
/**
|
|
19
|
+
* Empty placeholder for data retrieved by the server
|
|
20
|
+
*/
|
|
21
|
+
this.data = {
|
|
22
|
+
model: {},
|
|
23
|
+
};
|
|
24
|
+
/**
|
|
25
|
+
* Form that manages the data from the controller
|
|
26
|
+
*/
|
|
27
|
+
this.form = new UntypedFormGroup({});
|
|
28
|
+
/**
|
|
29
|
+
* Show / hides the bottom fab button (mostly to hide it when we are on other tabs where semantic of button can conflict with ...
|
|
30
|
+
* semantic of data on other tab, like relations that list other objects)
|
|
31
|
+
*/
|
|
32
|
+
this.showFabButton = true;
|
|
33
|
+
/**
|
|
34
|
+
* Injected service
|
|
35
|
+
*/
|
|
36
|
+
this.alertService = inject(NaturalAlertService);
|
|
37
|
+
/**
|
|
38
|
+
* Injected service
|
|
39
|
+
*/
|
|
40
|
+
this.router = inject(Router);
|
|
41
|
+
/**
|
|
42
|
+
* Injected service
|
|
43
|
+
*/
|
|
44
|
+
this.route = inject(ActivatedRoute);
|
|
45
|
+
}
|
|
46
|
+
ngOnInit() {
|
|
47
|
+
if (!this.isPanel) {
|
|
48
|
+
this.route.data.subscribe(data => {
|
|
49
|
+
this.data = merge({ model: this.service.getConsolidatedForClient() }, data[this.key]);
|
|
50
|
+
this.data = merge(this.data, omit(data, [this.key]));
|
|
51
|
+
this.initForm();
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
else {
|
|
55
|
+
this.initForm();
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
changeTab(index) {
|
|
59
|
+
this.showFabButton = index === 0;
|
|
60
|
+
}
|
|
61
|
+
update(now = false) {
|
|
62
|
+
if (!this.data.model.id) {
|
|
63
|
+
return;
|
|
64
|
+
}
|
|
65
|
+
validateAllFormControls(this.form);
|
|
66
|
+
ifValid(this.form).subscribe(() => {
|
|
67
|
+
this.formToData();
|
|
68
|
+
const postUpdate = (model) => {
|
|
69
|
+
this.alertService.info($localize `Mis à jour`);
|
|
70
|
+
this.form.patchValue(model);
|
|
71
|
+
this.postUpdate(model);
|
|
72
|
+
};
|
|
73
|
+
if (now) {
|
|
74
|
+
this.service.updateNow(this.data.model).subscribe(postUpdate);
|
|
75
|
+
}
|
|
76
|
+
else {
|
|
77
|
+
this.service.update(this.data.model).subscribe(postUpdate);
|
|
78
|
+
}
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
create(redirect = true) {
|
|
82
|
+
validateAllFormControls(this.form);
|
|
83
|
+
if (!this.form.valid) {
|
|
84
|
+
return;
|
|
85
|
+
}
|
|
86
|
+
this.formToData();
|
|
87
|
+
this.form.disable();
|
|
88
|
+
this.service
|
|
89
|
+
.create(this.data.model)
|
|
90
|
+
.pipe(switchMap(model => {
|
|
91
|
+
this.alertService.info($localize `Créé`);
|
|
92
|
+
this.form.patchValue(model);
|
|
93
|
+
return this.postCreate(model).pipe(endWith(model), last());
|
|
94
|
+
}), switchMap(model => {
|
|
95
|
+
if (redirect) {
|
|
96
|
+
if (this.isPanel) {
|
|
97
|
+
const oldUrl = this.router.url;
|
|
98
|
+
const nextUrl = this.panelData?.config.params.nextRoute;
|
|
99
|
+
const newUrl = oldUrl.replace('/new', '/' + model.id) + (nextUrl ? '/' + nextUrl : '');
|
|
100
|
+
return this.router.navigateByUrl(newUrl); // replace /new by /123
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
return this.router.navigate(['..', model.id], { relativeTo: this.route });
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
return EMPTY;
|
|
107
|
+
}), finalize(() => this.form.enable()))
|
|
108
|
+
.subscribe();
|
|
109
|
+
}
|
|
110
|
+
delete(redirectionRoute) {
|
|
111
|
+
this.form.disable();
|
|
112
|
+
this.alertService
|
|
113
|
+
.confirm($localize `Suppression`, $localize `Voulez-vous supprimer définitivement cet élément ?`, $localize `Supprimer définitivement`)
|
|
114
|
+
.pipe(switchMap(confirmed => {
|
|
115
|
+
if (!confirmed) {
|
|
116
|
+
return EMPTY;
|
|
117
|
+
}
|
|
118
|
+
this.preDelete(this.data.model);
|
|
119
|
+
return this.service.delete([this.data.model]).pipe(switchMap(() => {
|
|
120
|
+
this.alertService.info($localize `Supprimé`);
|
|
121
|
+
if (this.isPanel) {
|
|
122
|
+
this.panelService?.goToPenultimatePanel();
|
|
123
|
+
return EMPTY;
|
|
124
|
+
}
|
|
125
|
+
else {
|
|
126
|
+
const defaultRoute = ['../../' + kebabCase(this.key)];
|
|
127
|
+
return this.router.navigate(redirectionRoute ? redirectionRoute : defaultRoute, {
|
|
128
|
+
relativeTo: this.route,
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
}));
|
|
132
|
+
}), finalize(() => this.form.enable()))
|
|
133
|
+
.subscribe();
|
|
134
|
+
}
|
|
135
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
136
|
+
postUpdate(model) {
|
|
137
|
+
// noop
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Returns an observable that will be subscribed to immediately and the
|
|
141
|
+
* redirect navigation will only happen after the observable completes.
|
|
142
|
+
*/
|
|
143
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
144
|
+
postCreate(model) {
|
|
145
|
+
return EMPTY;
|
|
146
|
+
}
|
|
147
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
148
|
+
preDelete(model) {
|
|
149
|
+
// noop
|
|
150
|
+
}
|
|
151
|
+
initForm() {
|
|
152
|
+
this.form = this.service.getFormGroup(this.data.model);
|
|
153
|
+
}
|
|
154
|
+
/**
|
|
155
|
+
* Merge values of form into `this.data.model`.
|
|
156
|
+
*/
|
|
157
|
+
formToData() {
|
|
158
|
+
mergeWith(this.data.model, this.form.value, mergeOverrideArray);
|
|
159
|
+
}
|
|
160
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: NaturalAbstractDetail, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive }); }
|
|
161
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.2", type: NaturalAbstractDetail, usesInheritance: true, ngImport: i0 }); }
|
|
162
|
+
}
|
|
163
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: NaturalAbstractDetail, decorators: [{
|
|
164
|
+
type: Directive
|
|
165
|
+
}], ctorParameters: function () { return [{ type: undefined }, { type: undefined }]; } });
|
|
166
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-detail.js","sourceRoot":"","sources":["../../../../../projects/natural/src/lib/classes/abstract-detail.ts"],"names":[],"mappings":"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","sourcesContent":["import {Directive, inject, OnInit} from '@angular/core';\nimport {UntypedFormGroup} from '@angular/forms';\nimport {ActivatedRoute, Router} from '@angular/router';\nimport {kebabCase, merge, mergeWith, omit} from 'lodash-es';\nimport {NaturalAlertService} from '../modules/alert/alert.service';\nimport {NaturalAbstractPanel} from '../modules/panels/abstract-panel';\nimport {NaturalAbstractModelService} from '../services/abstract-model.service';\nimport {ExtractTcreate, ExtractTone, ExtractTupdate, Literal} from '../types/types';\nimport {finalize} from 'rxjs/operators';\nimport {ifValid, validateAllFormControls} from './validators';\nimport {mergeOverrideArray} from './utility';\nimport {PaginatedData} from './data-source';\nimport {QueryVariables} from './query-variable-manager';\nimport {EMPTY, endWith, last, Observable, switchMap} from 'rxjs';\n\n// @dynamic\n@Directive()\nexport class NaturalAbstractDetail<\n        TService extends NaturalAbstractModelService<\n            unknown,\n            any,\n            PaginatedData<Literal>,\n            QueryVariables,\n            any,\n            any,\n            any,\n            any,\n            unknown,\n            any\n        >,\n    >\n    extends NaturalAbstractPanel\n    implements OnInit\n{\n    /**\n     * Empty placeholder for data retrieved by the server\n     */\n    public override data: any = {\n        model: {},\n    };\n\n    /**\n     * Form that manages the data from the controller\n     */\n    public form: UntypedFormGroup = new UntypedFormGroup({});\n\n    /**\n     * Show / hides the bottom fab button (mostly to hide it when we are on other tabs where semantic of button can conflict with ...\n     * semantic of data on other tab, like relations that list other objects)\n     */\n    public showFabButton = true;\n\n    /**\n     * Injected service\n     */\n    protected readonly alertService = inject(NaturalAlertService);\n\n    /**\n     * Injected service\n     */\n    protected readonly router = inject(Router);\n\n    /**\n     * Injected service\n     */\n    protected readonly route = inject(ActivatedRoute);\n\n    public constructor(protected readonly key: string, public readonly service: TService) {\n        super();\n    }\n\n    public ngOnInit(): void {\n        if (!this.isPanel) {\n            this.route.data.subscribe(data => {\n                this.data = merge({model: this.service.getConsolidatedForClient()}, data[this.key]);\n                this.data = merge(this.data, omit(data, [this.key]));\n                this.initForm();\n            });\n        } else {\n            this.initForm();\n        }\n    }\n\n    public changeTab(index: number): void {\n        this.showFabButton = index === 0;\n    }\n\n    public update(now = false): void {\n        if (!this.data.model.id) {\n            return;\n        }\n\n        validateAllFormControls(this.form);\n\n        ifValid(this.form).subscribe(() => {\n            this.formToData();\n            const postUpdate = (model: ExtractTupdate<TService>): void => {\n                this.alertService.info($localize`Mis à jour`);\n                this.form.patchValue(model);\n                this.postUpdate(model);\n            };\n\n            if (now) {\n                this.service.updateNow(this.data.model).subscribe(postUpdate);\n            } else {\n                this.service.update(this.data.model).subscribe(postUpdate);\n            }\n        });\n    }\n\n    public create(redirect = true): void {\n        validateAllFormControls(this.form);\n\n        if (!this.form.valid) {\n            return;\n        }\n\n        this.formToData();\n        this.form.disable();\n\n        this.service\n            .create(this.data.model)\n            .pipe(\n                switchMap(model => {\n                    this.alertService.info($localize`Créé`);\n                    this.form.patchValue(model);\n\n                    return this.postCreate(model).pipe(endWith(model), last());\n                }),\n                switchMap(model => {\n                    if (redirect) {\n                        if (this.isPanel) {\n                            const oldUrl = this.router.url;\n                            const nextUrl = this.panelData?.config.params.nextRoute;\n                            const newUrl = oldUrl.replace('/new', '/' + model.id) + (nextUrl ? '/' + nextUrl : '');\n                            return this.router.navigateByUrl(newUrl); // replace /new by /123\n                        } else {\n                            return this.router.navigate(['..', model.id], {relativeTo: this.route});\n                        }\n                    }\n\n                    return EMPTY;\n                }),\n                finalize(() => this.form.enable()),\n            )\n            .subscribe();\n    }\n\n    public delete(redirectionRoute?: unknown[]): void {\n        this.form.disable();\n        this.alertService\n            .confirm(\n                $localize`Suppression`,\n                $localize`Voulez-vous supprimer définitivement cet élément ?`,\n                $localize`Supprimer définitivement`,\n            )\n            .pipe(\n                switchMap(confirmed => {\n                    if (!confirmed) {\n                        return EMPTY;\n                    }\n\n                    this.preDelete(this.data.model);\n\n                    return this.service.delete([this.data.model]).pipe(\n                        switchMap(() => {\n                            this.alertService.info($localize`Supprimé`);\n\n                            if (this.isPanel) {\n                                this.panelService?.goToPenultimatePanel();\n\n                                return EMPTY;\n                            } else {\n                                const defaultRoute = ['../../' + kebabCase(this.key)];\n                                return this.router.navigate(redirectionRoute ? redirectionRoute : defaultRoute, {\n                                    relativeTo: this.route,\n                                });\n                            }\n                        }),\n                    );\n                }),\n                finalize(() => this.form.enable()),\n            )\n            .subscribe();\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    protected postUpdate(model: ExtractTupdate<TService>): void {\n        // noop\n    }\n\n    /**\n     * Returns an observable that will be subscribed to immediately and the\n     * redirect navigation will only happen after the observable completes.\n     */\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    protected postCreate(model: ExtractTcreate<TService>): Observable<unknown> {\n        return EMPTY;\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    protected preDelete(model: ExtractTone<TService>): void {\n        // noop\n    }\n\n    protected initForm(): void {\n        this.form = this.service.getFormGroup(this.data.model);\n    }\n\n    /**\n     * Merge values of form into `this.data.model`.\n     */\n    protected formToData(): void {\n        mergeWith(this.data.model, this.form.value, mergeOverrideArray);\n    }\n}\n"]}
|
|
@@ -89,10 +89,10 @@ export class NaturalAbstractEditableList extends NaturalAbstractController {
|
|
|
89
89
|
validateForm() {
|
|
90
90
|
validateAllFormControls(this.form);
|
|
91
91
|
}
|
|
92
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: NaturalAbstractEditableList, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive }); }
|
|
93
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.2", type: NaturalAbstractEditableList, usesInheritance: true, ngImport: i0 }); }
|
|
92
94
|
}
|
|
93
|
-
|
|
94
|
-
NaturalAbstractEditableList.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.2", type: NaturalAbstractEditableList, usesInheritance: true, ngImport: i0 });
|
|
95
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.2", ngImport: i0, type: NaturalAbstractEditableList, decorators: [{
|
|
95
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.2", ngImport: i0, type: NaturalAbstractEditableList, decorators: [{
|
|
96
96
|
type: Directive
|
|
97
97
|
}], ctorParameters: function () { return [{ type: undefined }]; } });
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-editable-list.js","sourceRoot":"","sources":["../../../../../projects/natural/src/lib/classes/abstract-editable-list.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,gBAAgB,EAAE,gBAAgB,EAAC,MAAM,gBAAgB,CAAC;AACnF,OAAO,EAAC,kBAAkB,EAAC,MAAM,yBAAyB,CAAC;AAC3D,OAAO,EAAC,KAAK,EAAC,MAAM,WAAW,CAAC;AAEhC,OAAO,EAAC,yBAAyB,EAAC,MAAM,uBAAuB,CAAC;AAChE,OAAO,EAAC,4BAA4B,EAAiB,MAAM,0BAA0B,CAAC;AAEtF,OAAO,EAAC,uBAAuB,EAAC,MAAM,cAAc,CAAC;AACrD,OAAO,EAAC,SAAS,EAAC,MAAM,eAAe,CAAC;;AAGxC;;;;;;;;;;;;;;;;;;;GAmBG;AAEH,MAAM,OAAO,2BAgBX,SAAQ,yBAAyB;IAM/B,YAAsC,OAAiB;QACnD,KAAK,EAAE,CAAC;QAD0B,YAAO,GAAP,OAAO,CAAU;QAJvC,cAAS,GAAG,IAAI,gBAAgB,CAAC,EAAE,CAAC,CAAC;QACrC,qBAAgB,GAAG,IAAI,4BAA4B,EAAyB,CAAC;QAC7E,eAAU,GAAG,IAAI,kBAAkB,EAAmB,CAAC;QAKnE,8GAA8G;QAC9G,IAAI,CAAC,IAAI,GAAG,IAAI,gBAAgB,CAAC,EAAC,IAAI,EAAE,IAAI,CAAC,SAAS,EAAC,CAAC,CAAC;QACzD,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;QAC/C,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,YAAY,EAAE,EAAC,UAAU,EAAE,EAAC,QAAQ,EAAE,GAAG,EAAE,SAAS,EAAE,CAAC,EAAC,EAA0B,CAAC,CAAC;IAClH,CAAC;IAED;;OAEG;IACI,QAAQ,CAAC,KAAmB;QAC/B,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC,aAAa;QACrC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IAED;;;OAGG;IACI,QAAQ,CAAC,KAAmB;QAC/B,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACjB,MAAM,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,wBAAwB,EAAE,EAAE,IAAI,CAAC,CAAC;YAC3E,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;YAC/D,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;IACnD,CAAC;IAEM,QAAQ,CAAC,KAAa;QACzB,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAC/B,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;IACnD,CAAC;IAED;;OAEG;IACI,QAAQ;QACX,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAO,CAAC,CAAC,CAAC;IAC7B,CAAC;IAED;;;;;;;;;;OAUG;IACI,QAAQ;QACX,OAAO,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,CAAC;IACxC,CAAC;IAED;;;;OAIG;IACI,YAAY;QACf,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACvC,CAAC;8GAvFQ,2BAA2B;kGAA3B,2BAA2B;;2FAA3B,2BAA2B;kBADvC,SAAS","sourcesContent":["import {AbstractControl, UntypedFormArray, UntypedFormGroup} from '@angular/forms';\nimport {MatTableDataSource} from '@angular/material/table';\nimport {merge} from 'lodash-es';\nimport {NaturalAbstractModelService} from '../services/abstract-model.service';\nimport {NaturalAbstractController} from './abstract-controller';\nimport {NaturalQueryVariablesManager, QueryVariables} from './query-variable-manager';\nimport {ExtractTallOne, ExtractVall, Literal} from '../types/types';\nimport {validateAllFormControls} from './validators';\nimport {Directive} from '@angular/core';\nimport {PaginatedData} from './data-source';\n\n/**\n * This class helps managing non-paginated rows of items that can be edited in-place, typically in a <mat-table>.\n * But it does **not** mutate anything to persist the edits on the server. It is up to the consuming component to implement\n * custom mutation mechanism.\n *\n * To access data of this component from a parent component, use:\n *\n * ```\n * @ViewChildren(ComponentType) cmp: ComponentType;\n * this.cmp.getItems();\n * ```\n *\n * To add empty line, call:\n *\n * ```\n * this.cmp.addEmpty();\n * ```\n *\n * @dynamic\n */\n@Directive()\nexport class NaturalAbstractEditableList<\n    TService extends NaturalAbstractModelService<\n        any,\n        any,\n        PaginatedData<Literal>,\n        QueryVariables,\n        any,\n        any,\n        any,\n        any,\n        any,\n        any\n    >,\n    // The Literal here is a bit too loose. Ideally we would like to express\n    // \"it must be a union and one of the type in the union must be ExtractTallOne<TService>\"\n    T extends Literal = ExtractTallOne<TService>,\n> extends NaturalAbstractController {\n    public readonly form: UntypedFormGroup;\n    public readonly formArray = new UntypedFormArray([]);\n    public readonly variablesManager = new NaturalQueryVariablesManager<ExtractVall<TService>>();\n    public readonly dataSource = new MatTableDataSource<AbstractControl>();\n\n    public constructor(protected readonly service: TService) {\n        super();\n\n        // Create a form group with a line attributes that contain an array of formGroups (one by line = one by model)\n        this.form = new UntypedFormGroup({rows: this.formArray});\n        this.dataSource.data = this.formArray.controls;\n        this.variablesManager.set('pagination', {pagination: {pageSize: 999, pageIndex: 0}} as ExtractVall<TService>);\n    }\n\n    /**\n     * Set the list of items (overwriting what may have existed)\n     */\n    public setItems(items: readonly T[]): void {\n        this.formArray.clear(); // reset list\n        this.addItems(items);\n    }\n\n    /**\n     * Add given items to the list\n     * Reproduces the model data loading the same way as it would be on a detail page (via AbstractDetail controller) but without resolving\n     */\n    public addItems(items: readonly T[]): void {\n        items.forEach(item => {\n            const completedItem = merge(this.service.getConsolidatedForClient(), item);\n            const lineFormGroup = this.service.getFormGroup(completedItem);\n            this.formArray.push(lineFormGroup);\n        });\n\n        this.dataSource.data = this.formArray.controls;\n    }\n\n    public removeAt(index: number): void {\n        this.formArray.removeAt(index);\n        this.dataSource.data = this.formArray.controls;\n    }\n\n    /**\n     * Add empty item at the end of the list\n     */\n    public addEmpty(): void {\n        this.addItems([{} as T]);\n    }\n\n    /**\n     * Return a list of models without any treatment.\n     *\n     * To mutate models, it would be required to map them using :\n     *  - AbstractModelService.getInput()\n     *  - AbstractModelService.getPartialVariablesForCreation()\n     *  - AbstractModelService.getPartialVariablesForUpdate()\n     *  - some other required treatment.\n     *\n     * TODO return type is incorrect and should be closer to `Partial<T>[]` or an even looser type, because we don't really know what fields exists in the form. When we fix this, we should also remove type coercing in unit tests.\n     */\n    public getItems(): T[] {\n        return this.formArray.getRawValue();\n    }\n\n    /**\n     * Force the form validation.\n     *\n     * The valid state can then be read via `this.form.valid`\n     */\n    public validateForm(): void {\n        validateAllFormControls(this.form);\n    }\n}\n"]}
|