nuxeo-development-framework 4.1.3 → 4.1.4

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 (19) hide show
  1. package/bundles/nuxeo-development-framework.umd.js +510 -433
  2. package/bundles/nuxeo-development-framework.umd.js.map +1 -1
  3. package/esm2015/lib/components/dynamic-form/components/department-form/department-form.component.js +28 -29
  4. package/esm2015/lib/components/dynamic-form/dynamic-form.module.js +13 -10
  5. package/esm2015/lib/components/file-manger/components/add-to-collection/add-to-collection.component.js +58 -42
  6. package/esm2015/lib/components/file-manger/components/scan-modal/scan-modal.component.js +99 -66
  7. package/esm2015/lib/components/permissions/add-permissions-dialog/add-permissions-dialog.component.js +107 -90
  8. package/esm2015/lib/components/permissions/permissions.module.js +23 -7
  9. package/esm2015/lib/shared/components/nuxeo-dialog/nuxeo.dialog.js +21 -21
  10. package/fesm2015/nuxeo-development-framework.js +334 -259
  11. package/fesm2015/nuxeo-development-framework.js.map +1 -1
  12. package/lib/components/dynamic-form/components/department-form/department-form.component.d.ts +4 -4
  13. package/lib/components/dynamic-form/dynamic-form.module.d.ts +2 -1
  14. package/lib/components/file-manger/components/add-to-collection/add-to-collection.component.d.ts +11 -5
  15. package/lib/components/file-manger/components/scan-modal/scan-modal.component.d.ts +9 -8
  16. package/lib/components/permissions/add-permissions-dialog/add-permissions-dialog.component.d.ts +8 -6
  17. package/lib/components/permissions/permissions.module.d.ts +2 -1
  18. package/lib/shared/components/nuxeo-dialog/nuxeo.dialog.d.ts +5 -5
  19. package/package.json +1 -1
@@ -1,41 +1,77 @@
1
- import { __awaiter } from "tslib";
2
1
  import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
3
2
  import { DxFormComponent } from 'devextreme-angular';
4
3
  import { concat, of, Subject } from 'rxjs';
5
4
  import { debounceTime, distinctUntilChanged, switchMap, catchError, tap } from 'rxjs/operators';
5
+ import { NdfNuxeoDialog } from '../../../../shared/components/nuxeo-dialog/nuxeo.dialog';
6
+ import { BaseComponent } from '../../../../shared/components/base/base.component';
6
7
  import * as i0 from "@angular/core";
7
8
  import * as i1 from "../../../../shared-services/file-manager.service";
8
9
  import * as i2 from "../../../custom-toastr/services/custom-toastr.service";
9
- import * as i3 from "devextreme-angular";
10
- import * as i4 from "devextreme-angular/ui/nested";
11
- import * as i5 from "@ng-select/ng-select";
12
- import * as i6 from "devextreme-angular/core";
10
+ import * as i3 from "../../../../shared/components/nuxeo-dialog/services/nuxeo-dialog.service";
11
+ import * as i4 from "devextreme-angular";
12
+ import * as i5 from "devextreme-angular/ui/nested";
13
+ import * as i6 from "@ng-select/ng-select";
13
14
  import * as i7 from "@angular/forms";
14
15
  import * as i8 from "@angular/common";
15
16
  import * as i9 from "@ngx-translate/core";
16
- export class AddToCollectionComponent {
17
- constructor(fileManagerService, customToastrService) {
17
+ export class AddToCollectionComponent extends BaseComponent {
18
+ constructor(fileManagerService, customToastrService, nuxeoDialogService, injector) {
19
+ super(injector);
18
20
  this.fileManagerService = fileManagerService;
19
21
  this.customToastrService = customToastrService;
22
+ this.nuxeoDialogService = nuxeoDialogService;
20
23
  this.visibleChange = new EventEmitter();
21
24
  this.rtlEnabled = false;
22
- this.loading = false;
23
25
  this.isSelected = true;
24
26
  this.tagsInput$ = new Subject();
25
27
  this.tagsLoading = false;
26
28
  this._visible = false;
29
+ this.onFormCollectionSubmit = (e) => {
30
+ e.preventDefault();
31
+ this.loading = true;
32
+ return this.fileManagerService
33
+ .addToCollection(this.selectedItems, this.collectionid)
34
+ .pipe(tap((res) => {
35
+ this.loading = false;
36
+ this.form.instance.resetValues();
37
+ this.selectedTags = null;
38
+ this.visible = false;
39
+ this.customToastrService.show('success', 'TOASTER.SUCCESS', 'TOASTER.DOCUMENT_ADDED_TO_COLLECTION');
40
+ }, (err) => {
41
+ this.loading = false;
42
+ this.customToastrService.show('error', 'TOASTER.ERROR', 'TOASTER.DOCUMENT_ADDED_TO_COLLECTION_ERROR');
43
+ }));
44
+ };
27
45
  }
28
46
  set visible(value) {
29
47
  if (this._visible === value) {
30
48
  return;
31
49
  }
50
+ if (value) {
51
+ this.openDialog();
52
+ }
32
53
  this._visible = value;
33
54
  this.visibleChange.emit(this._visible);
34
55
  }
35
56
  get visible() {
36
57
  return this._visible;
37
58
  }
38
- ngOnInit() {
59
+ ngOnInit() { }
60
+ openDialog() {
61
+ const options = {
62
+ component: NdfNuxeoDialog,
63
+ config: {
64
+ title: this.translateService.instant('FILE_MANAGER.ADD_TO_COLLECTION'),
65
+ contentTemplate: this.contentTemplate,
66
+ actionsTemplate: this.actionsTemplate
67
+ }
68
+ };
69
+ this.nuxeoDialogService
70
+ .open(options)
71
+ .afterClosed()
72
+ .subscribe((res) => {
73
+ this.visible = false;
74
+ });
39
75
  }
40
76
  emitSelection(event) {
41
77
  if (this.isSelected) {
@@ -53,7 +89,7 @@ export class AddToCollectionComponent {
53
89
  this.isSelected = false;
54
90
  let mycategories = [];
55
91
  this.items$ = concat(this.fileManagerService.getCollectionFromPP(searchterm).pipe(switchMap((res) => {
56
- res.entries.map(entry => {
92
+ res.entries.map((entry) => {
57
93
  mycategories.push({
58
94
  displayLabel: entry.title,
59
95
  id: entry.uid,
@@ -64,15 +100,12 @@ export class AddToCollectionComponent {
64
100
  return of(mycategories);
65
101
  })), // default items
66
102
  this.tagsInput$.pipe(debounceTime(200), distinctUntilChanged(), tap(() => (this.tagsLoading = true)), switchMap((searchterm) => {
67
- // if (searchterm && searchterm.length) {
68
- return this.fileManagerService
69
- .getCollectionFromPP(searchterm)
70
- .pipe(catchError(() => of([])), // empty list on error
103
+ return this.fileManagerService.getCollectionFromPP(searchterm).pipe(catchError(() => of([])), // empty list on error
71
104
  switchMap((searchCat) => {
72
105
  let myInerCateg = [];
73
106
  this.tagsLoading = false;
74
107
  this.isSelected = true;
75
- searchCat.entries.map(entry => {
108
+ searchCat.entries.map((entry) => {
76
109
  myInerCateg.push({
77
110
  displayLabel: entry.title,
78
111
  id: entry.uid,
@@ -82,34 +115,11 @@ export class AddToCollectionComponent {
82
115
  });
83
116
  return of(myInerCateg);
84
117
  }));
85
- // } else {
86
- // this.tagsLoading = false;
87
- // this.isSelected = true;
88
- // return of();
89
- // }
90
118
  })));
91
119
  }
92
- onFormCollectionSubmit(e) {
93
- return __awaiter(this, void 0, void 0, function* () {
94
- e.preventDefault();
95
- this.loading = true;
96
- this.fileManagerService
97
- .addToCollection(this.selectedItems, this.collectionid)
98
- .subscribe((res) => {
99
- this.loading = false;
100
- this.form.instance.resetValues();
101
- this.selectedTags = null;
102
- this.visible = false;
103
- this.customToastrService.show('success', 'TOASTER.SUCCESS', 'TOASTER.DOCUMENT_ADDED_TO_COLLECTION');
104
- }, (err) => {
105
- this.loading = false;
106
- this.customToastrService.show('error', 'TOASTER.ERROR', 'TOASTER.DOCUMENT_ADDED_TO_COLLECTION_ERROR');
107
- });
108
- });
109
- }
110
120
  }
111
- AddToCollectionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: AddToCollectionComponent, deps: [{ token: i1.FileManagerService }, { token: i2.CustomToastrService }], target: i0.ɵɵFactoryTarget.Component });
112
- AddToCollectionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: AddToCollectionComponent, selector: "app-add-to-collection", inputs: { visible: "visible", rtlEnabled: "rtlEnabled", selectedItems: "selectedItems" }, outputs: { visibleChange: "visibleChange" }, viewQueries: [{ propertyName: "form", first: true, predicate: DxFormComponent, descendants: true }], ngImport: i0, template: "<dx-popup class=\"popUpParent\" [rtlEnabled]=\"rtlEnabled\" id=\"photo-popup\" [width]=\"500\" [height]=\"200\"\r\n (onShown)=\"loadItems()\" closeOnOutsideClick=\"true\" title=\"{{ 'FILE_MANAGER.ADD_TO_COLLECTION' | translate }}\"\r\n [(visible)]=\"visible\">\r\n <div *dxTemplate=\"let data of 'content'\">\r\n <form (submit)=\"onFormCollectionSubmit($event)\">\r\n <dx-form class=\"collection-form-wrapper\" #createForm [formData]=\"formData\" [disabled]=\"loading\">\r\n <dxi-item editorType=\"dxTextBox\">\r\n <ng-select [items]=\"items$ | async\" bindLabel=\"displayLabel\" [addTag]=\"true\"\r\n addTagText=\"Add collection\" [multiple]=\"false\" [hideSelected]=\"true\" [minTermLength]=\"0\"\r\n [loading]=\"tagsLoading\" typeToSearchText=\"search\" [typeahead]=\"tagsInput$\"\r\n [(ngModel)]=\"selectedTags\" required placeholder=\"{{\r\n 'VOCABULARY.SELECT_ITEM' | translate\r\n }}\" name=\"selectedItem\" (change)=\"emitSelection($event)\">\r\n </ng-select>\r\n </dxi-item>\r\n <dxi-item itemType=\"button\">\r\n <dxo-button-options width=\"30%\" type=\"danger\" [useSubmitBehavior]=\"true\"\r\n [template]=\"'addToCollectionTemplate'\">\r\n </dxo-button-options>\r\n </dxi-item>\r\n <ng-container *dxTemplate=\"let item of 'addToCollectionTemplate'\">\r\n <span class=\"dx-button-text\">\r\n <ng-container *ngIf=\"loading; else notLoading\">\r\n <dx-load-indicator width=\"24px\" height=\"24px\" [visible]=\"true\"></dx-load-indicator>\r\n </ng-container>\r\n <ng-template #notLoading>{{\r\n \"FILE_MANAGER.ADD\" | translate\r\n }}</ng-template>\r\n </span>\r\n </ng-container>\r\n </dx-form>\r\n </form>\r\n </div>\r\n</dx-popup>", styles: [""], components: [{ type: i3.DxPopupComponent, selector: "dx-popup", inputs: ["accessKey", "animation", "closeOnOutsideClick", "container", "contentTemplate", "copyRootClassesToWrapper", "deferRendering", "disabled", "dragAndResizeArea", "dragEnabled", "dragOutsideBoundary", "elementAttr", "enableBodyScroll", "focusStateEnabled", "fullScreen", "height", "hideOnOutsideClick", "hideOnParentScroll", "hint", "hoverStateEnabled", "maxHeight", "maxWidth", "minHeight", "minWidth", "position", "resizeEnabled", "restorePosition", "rtlEnabled", "shading", "shadingColor", "showCloseButton", "showTitle", "tabIndex", "title", "titleTemplate", "toolbarItems", "visible", "width", "wrapperAttr"], outputs: ["onContentReady", "onDisposing", "onHidden", "onHiding", "onInitialized", "onOptionChanged", "onResize", "onResizeEnd", "onResizeStart", "onShowing", "onShown", "onTitleRendered", "accessKeyChange", "animationChange", "closeOnOutsideClickChange", "containerChange", "contentTemplateChange", "copyRootClassesToWrapperChange", "deferRenderingChange", "disabledChange", "dragAndResizeAreaChange", "dragEnabledChange", "dragOutsideBoundaryChange", "elementAttrChange", "enableBodyScrollChange", "focusStateEnabledChange", "fullScreenChange", "heightChange", "hideOnOutsideClickChange", "hideOnParentScrollChange", "hintChange", "hoverStateEnabledChange", "maxHeightChange", "maxWidthChange", "minHeightChange", "minWidthChange", "positionChange", "resizeEnabledChange", "restorePositionChange", "rtlEnabledChange", "shadingChange", "shadingColorChange", "showCloseButtonChange", "showTitleChange", "tabIndexChange", "titleChange", "titleTemplateChange", "toolbarItemsChange", "visibleChange", "widthChange", "wrapperAttrChange"] }, { type: i3.DxFormComponent, selector: "dx-form", inputs: ["accessKey", "activeStateEnabled", "alignItemLabels", "alignItemLabelsInAllGroups", "colCount", "colCountByScreen", "customizeItem", "disabled", "elementAttr", "focusStateEnabled", "formData", "height", "hint", "hoverStateEnabled", "items", "labelLocation", "labelMode", "minColWidth", "optionalMark", "readOnly", "requiredMark", "requiredMessage", "rtlEnabled", "screenByWidth", "scrollingEnabled", "showColonAfterLabel", "showOptionalMark", "showRequiredMark", "showValidationSummary", "tabIndex", "validationGroup", "visible", "width"], outputs: ["onContentReady", "onDisposing", "onEditorEnterKey", "onFieldDataChanged", "onInitialized", "onOptionChanged", "accessKeyChange", "activeStateEnabledChange", "alignItemLabelsChange", "alignItemLabelsInAllGroupsChange", "colCountChange", "colCountByScreenChange", "customizeItemChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "formDataChange", "heightChange", "hintChange", "hoverStateEnabledChange", "itemsChange", "labelLocationChange", "labelModeChange", "minColWidthChange", "optionalMarkChange", "readOnlyChange", "requiredMarkChange", "requiredMessageChange", "rtlEnabledChange", "screenByWidthChange", "scrollingEnabledChange", "showColonAfterLabelChange", "showOptionalMarkChange", "showRequiredMarkChange", "showValidationSummaryChange", "tabIndexChange", "validationGroupChange", "visibleChange", "widthChange"] }, { type: i4.DxiItemComponent, selector: "dxi-item", inputs: ["disabled", "html", "icon", "template", "text", "title", "titleTemplate", "visible", "onClick", "stylingMode", "type", "baseSize", "box", "ratio", "shrink", "elementAttr", "hint", "beginGroup", "closeMenuOnClick", "items", "selectable", "selected", "colSpan", "cssClass", "dataField", "editorOptions", "editorType", "helpText", "isRequired", "itemType", "label", "name", "validationRules", "visibleIndex", "alignItemLabels", "caption", "colCount", "colCountByScreen", "tabPanelOptions", "tabs", "badge", "tabTemplate", "buttonOptions", "horizontalAlignment", "verticalAlignment", "locateInMenu", "location", "menuItemTemplate", "options", "showText", "widget", "height", "width", "imageAlt", "imageSrc", "acceptedValues", "formatName", "formatValues", "key", "showChevron", "linkAttr", "url", "heightRatio", "widthRatio", "expanded", "hasItems", "id", "parentId"] }, { type: i5.NgSelectComponent, selector: "ng-select", inputs: ["markFirst", "dropdownPosition", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "bufferAmount", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "bindLabel", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "virtualScroll", "openOnEnter", "appendTo", "bindValue", "appearance", "maxSelectedItems", "groupBy", "groupValue", "tabIndex", "typeahead"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { type: i4.DxoButtonOptionsComponent, selector: "dxo-button-options", inputs: ["accessKey", "activeStateEnabled", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "icon", "onClick", "onContentReady", "onDisposing", "onInitialized", "onOptionChanged", "rtlEnabled", "stylingMode", "tabIndex", "template", "text", "type", "useSubmitBehavior", "validationGroup", "visible", "width"] }], directives: [{ type: i6.DxTemplateDirective, selector: "[dxTemplate]", inputs: ["dxTemplateOf"] }, { type: i7.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i7.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i7.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i7.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i9.TranslatePipe, "async": i8.AsyncPipe } });
121
+ AddToCollectionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: AddToCollectionComponent, deps: [{ token: i1.FileManagerService }, { token: i2.CustomToastrService }, { token: i3.NuxeoDialogService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
122
+ AddToCollectionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: AddToCollectionComponent, selector: "app-add-to-collection", inputs: { visible: "visible", rtlEnabled: "rtlEnabled", selectedItems: "selectedItems" }, outputs: { visibleChange: "visibleChange" }, viewQueries: [{ propertyName: "form", first: true, predicate: DxFormComponent, descendants: true }, { propertyName: "contentTemplate", first: true, predicate: ["contentTemplate"], descendants: true }, { propertyName: "actionsTemplate", first: true, predicate: ["actionsTemplate"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<!-- <dx-popup class=\"popUpParent\" [rtlEnabled]=\"rtlEnabled\" id=\"photo-popup\" [width]=\"500\" [height]=\"200\"\r\n (onShown)=\"loadItems()\" closeOnOutsideClick=\"true\" title=\"{{ '' | translate }}\"\r\n [(visible)]=\"visible\">\r\n\r\n</dx-popup>\r\n\r\n\r\n -->\r\n<ng-template #contentTemplate>\r\n\t<form>\r\n\t\t<dx-form\r\n\t\t\tclass=\"collection-form-wrapper\"\r\n\t\t\t#createForm\r\n\t\t\t[formData]=\"formData\"\r\n\t\t\t[disabled]=\"loading\"\r\n\t\t>\r\n\t\t\t<dxi-item editorType=\"dxTextBox\">\r\n\t\t\t\t<ng-select\r\n\t\t\t\t\t[items]=\"items$ | async\"\r\n\t\t\t\t\tbindLabel=\"displayLabel\"\r\n\t\t\t\t\t[addTag]=\"true\"\r\n\t\t\t\t\taddTagText=\"Add collection\"\r\n\t\t\t\t\t[multiple]=\"false\"\r\n\t\t\t\t\t[hideSelected]=\"true\"\r\n\t\t\t\t\t[minTermLength]=\"0\"\r\n\t\t\t\t\t[loading]=\"tagsLoading\"\r\n\t\t\t\t\ttypeToSearchText=\"search\"\r\n\t\t\t\t\t[typeahead]=\"tagsInput$\"\r\n\t\t\t\t\t[(ngModel)]=\"selectedTags\"\r\n\t\t\t\t\trequired\r\n\t\t\t\t\tplaceholder=\"{{ 'VOCABULARY.SELECT_ITEM' | translate }}\"\r\n\t\t\t\t\tname=\"selectedItem\"\r\n\t\t\t\t\t(change)=\"emitSelection($event)\"\r\n\t\t\t\t>\r\n\t\t\t\t</ng-select>\r\n\t\t\t</dxi-item>\r\n\t\t</dx-form>\r\n\t</form>\r\n</ng-template>\r\n\r\n<ng-template #actionsTemplate let-dialog=\"dialog\">\r\n\t<button\r\n\t\tclass=\"submission-button px-5\"\r\n\t\t(click)=\"dialog.executeAction(onFormCollectionSubmit, [$event])\"\r\n\t>\r\n\t\t{{ 'FILE_MANAGER.ADD' | translate }}\r\n\t</button>\r\n</ng-template>\r\n", styles: [""], components: [{ type: i4.DxFormComponent, selector: "dx-form", inputs: ["accessKey", "activeStateEnabled", "alignItemLabels", "alignItemLabelsInAllGroups", "colCount", "colCountByScreen", "customizeItem", "disabled", "elementAttr", "focusStateEnabled", "formData", "height", "hint", "hoverStateEnabled", "items", "labelLocation", "labelMode", "minColWidth", "optionalMark", "readOnly", "requiredMark", "requiredMessage", "rtlEnabled", "screenByWidth", "scrollingEnabled", "showColonAfterLabel", "showOptionalMark", "showRequiredMark", "showValidationSummary", "tabIndex", "validationGroup", "visible", "width"], outputs: ["onContentReady", "onDisposing", "onEditorEnterKey", "onFieldDataChanged", "onInitialized", "onOptionChanged", "accessKeyChange", "activeStateEnabledChange", "alignItemLabelsChange", "alignItemLabelsInAllGroupsChange", "colCountChange", "colCountByScreenChange", "customizeItemChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "formDataChange", "heightChange", "hintChange", "hoverStateEnabledChange", "itemsChange", "labelLocationChange", "labelModeChange", "minColWidthChange", "optionalMarkChange", "readOnlyChange", "requiredMarkChange", "requiredMessageChange", "rtlEnabledChange", "screenByWidthChange", "scrollingEnabledChange", "showColonAfterLabelChange", "showOptionalMarkChange", "showRequiredMarkChange", "showValidationSummaryChange", "tabIndexChange", "validationGroupChange", "visibleChange", "widthChange"] }, { type: i5.DxiItemComponent, selector: "dxi-item", inputs: ["disabled", "html", "icon", "template", "text", "title", "titleTemplate", "visible", "onClick", "stylingMode", "type", "baseSize", "box", "ratio", "shrink", "elementAttr", "hint", "beginGroup", "closeMenuOnClick", "items", "selectable", "selected", "colSpan", "cssClass", "dataField", "editorOptions", "editorType", "helpText", "isRequired", "itemType", "label", "name", "validationRules", "visibleIndex", "alignItemLabels", "caption", "colCount", "colCountByScreen", "tabPanelOptions", "tabs", "badge", "tabTemplate", "buttonOptions", "horizontalAlignment", "verticalAlignment", "locateInMenu", "location", "menuItemTemplate", "options", "showText", "widget", "height", "width", "imageAlt", "imageSrc", "acceptedValues", "formatName", "formatValues", "key", "showChevron", "linkAttr", "url", "heightRatio", "widthRatio", "expanded", "hasItems", "id", "parentId"] }, { type: i6.NgSelectComponent, selector: "ng-select", inputs: ["markFirst", "dropdownPosition", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "bufferAmount", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "bindLabel", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "virtualScroll", "openOnEnter", "appendTo", "bindValue", "appearance", "maxSelectedItems", "groupBy", "groupValue", "tabIndex", "typeahead"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }], directives: [{ type: i7.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i7.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i7.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i7.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], pipes: { "async": i8.AsyncPipe, "translate": i9.TranslatePipe } });
113
123
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: AddToCollectionComponent, decorators: [{
114
124
  type: Component,
115
125
  args: [{
@@ -117,9 +127,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
117
127
  templateUrl: './add-to-collection.component.html',
118
128
  styleUrls: ['./add-to-collection.component.scss']
119
129
  }]
120
- }], ctorParameters: function () { return [{ type: i1.FileManagerService }, { type: i2.CustomToastrService }]; }, propDecorators: { form: [{
130
+ }], ctorParameters: function () { return [{ type: i1.FileManagerService }, { type: i2.CustomToastrService }, { type: i3.NuxeoDialogService }, { type: i0.Injector }]; }, propDecorators: { form: [{
121
131
  type: ViewChild,
122
132
  args: [DxFormComponent, { static: false }]
133
+ }], contentTemplate: [{
134
+ type: ViewChild,
135
+ args: ['contentTemplate']
136
+ }], actionsTemplate: [{
137
+ type: ViewChild,
138
+ args: ['actionsTemplate']
123
139
  }], visible: [{
124
140
  type: Input
125
141
  }], visibleChange: [{
@@ -129,4 +145,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
129
145
  }], selectedItems: [{
130
146
  type: Input
131
147
  }] } });
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-to-collection.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/file-manger/components/add-to-collection/add-to-collection.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/file-manger/components/add-to-collection/add-to-collection.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, ViewChild } from '@angular/core';\r\nimport { DxFormComponent } from 'devextreme-angular';\r\nimport { concat, Observable, of, Subject } from 'rxjs';\r\nimport { debounceTime, distinctUntilChanged, switchMap, catchError, tap, map } from 'rxjs/operators';\r\nimport { CustomToastrService } from '../../../custom-toastr/services/custom-toastr.service';\r\nimport { FileManagerService } from '../../../../shared-services/file-manager.service';\r\n\r\n@Component({\r\n  selector: 'app-add-to-collection',\r\n  templateUrl: './add-to-collection.component.html',\r\n  styleUrls: ['./add-to-collection.component.scss']\r\n})\r\nexport class AddToCollectionComponent implements OnInit {\r\n  @ViewChild(DxFormComponent, { static: false }) form: DxFormComponent;\r\n  @Input()\r\n  set visible(value: any) {\r\n    if (this._visible === value) {\r\n      return;\r\n    }\r\n    this._visible = value;\r\n    this.visibleChange.emit(this._visible);\r\n  }\r\n  get visible() {\r\n    return this._visible;\r\n  }\r\n  @Output()\r\n  visibleChange = new EventEmitter<any>();\r\n  @Input()\r\n  rtlEnabled = false;\r\n  @Input()\r\n  selectedItems: any;\r\n\r\n  loading = false;\r\n  isSelected: boolean = true;\r\n  collectionid: any;\r\n  selectedTags: any;\r\n  items$: Observable<any[]>;\r\n  tagsInput$ = new Subject<string>();\r\n  tagsLoading = false;\r\n  _visible = false;\r\n  constructor(\r\n    private fileManagerService: FileManagerService,\r\n    protected customToastrService: CustomToastrService\r\n\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n  }\r\n\r\n  emitSelection(event) {\r\n    if (this.isSelected) {\r\n      this.fileManagerService\r\n        .createNewCollection(event.displayLabel)\r\n        .subscribe((res) => {\r\n          this.collectionid = res.uid;\r\n        });\r\n    } else this.collectionid = event.id;\r\n  }\r\n\r\n  loadItems() {\r\n    let searchterm = '';\r\n    this.isSelected = false;\r\n    let mycategories = [];\r\n    this.items$ = concat(\r\n      this.fileManagerService.getCollectionFromPP(searchterm).pipe(switchMap((res:any)=> {\r\n        res.entries.map(entry => {\r\n                mycategories.push({\r\n                    displayLabel : entry.title,\r\n                    id : entry.uid,\r\n                    path: entry.path,\r\n                    icon :entry.properties['common:icon']\r\n                })\r\n        })\r\n        return of(mycategories);\r\n    })) , // default items\r\n      this.tagsInput$.pipe(\r\n        debounceTime(200),\r\n        distinctUntilChanged(),\r\n        tap(() => (this.tagsLoading = true)),\r\n        switchMap((searchterm) => {\r\n          // if (searchterm && searchterm.length) {\r\n            return this.fileManagerService\r\n              .getCollectionFromPP(searchterm)\r\n              .pipe(\r\n                catchError(() => of([])), // empty list on error\r\n                switchMap((searchCat) => {\r\n                  let myInerCateg = [];\r\n                  this.tagsLoading = false;\r\n                  this.isSelected = true;\r\n                  searchCat.entries.map(entry => {\r\n                    myInerCateg.push({\r\n                        displayLabel : entry.title,\r\n                        id : entry.uid,\r\n                        path: entry.path,\r\n                        icon :entry.properties['common:icon']\r\n                    })\r\n                })\r\n                return of(myInerCateg);\r\n                })\r\n              );\r\n          // } else {\r\n          //   this.tagsLoading = false;\r\n          //   this.isSelected = true;\r\n          //   return of();\r\n          // }\r\n        })\r\n      )\r\n    );\r\n  }\r\n\r\n  async onFormCollectionSubmit(e) {\r\n    e.preventDefault();\r\n    this.loading = true;\r\n    this.fileManagerService\r\n      .addToCollection(this.selectedItems, this.collectionid)\r\n      .subscribe(\r\n        (res) => {\r\n          this.loading = false;\r\n          this.form.instance.resetValues();\r\n          this.selectedTags = null;\r\n          this.visible = false;\r\n          this.customToastrService.show(\r\n            'success',\r\n            'TOASTER.SUCCESS',\r\n            'TOASTER.DOCUMENT_ADDED_TO_COLLECTION'\r\n          );\r\n        },\r\n        (err) => {\r\n          this.loading = false;\r\n          this.customToastrService.show(\r\n            'error',\r\n            'TOASTER.ERROR',\r\n            'TOASTER.DOCUMENT_ADDED_TO_COLLECTION_ERROR'\r\n          );\r\n        }\r\n      );\r\n  }\r\n\r\n}\r\n","<dx-popup class=\"popUpParent\" [rtlEnabled]=\"rtlEnabled\" id=\"photo-popup\" [width]=\"500\" [height]=\"200\"\r\n    (onShown)=\"loadItems()\" closeOnOutsideClick=\"true\" title=\"{{ 'FILE_MANAGER.ADD_TO_COLLECTION' | translate }}\"\r\n    [(visible)]=\"visible\">\r\n    <div *dxTemplate=\"let data of 'content'\">\r\n        <form (submit)=\"onFormCollectionSubmit($event)\">\r\n            <dx-form class=\"collection-form-wrapper\" #createForm [formData]=\"formData\" [disabled]=\"loading\">\r\n                <dxi-item editorType=\"dxTextBox\">\r\n                    <ng-select [items]=\"items$ | async\" bindLabel=\"displayLabel\" [addTag]=\"true\"\r\n                        addTagText=\"Add collection\" [multiple]=\"false\" [hideSelected]=\"true\" [minTermLength]=\"0\"\r\n                        [loading]=\"tagsLoading\" typeToSearchText=\"search\" [typeahead]=\"tagsInput$\"\r\n                        [(ngModel)]=\"selectedTags\" required placeholder=\"{{\r\n                        'VOCABULARY.SELECT_ITEM' | translate\r\n                    }}\" name=\"selectedItem\" (change)=\"emitSelection($event)\">\r\n                    </ng-select>\r\n                </dxi-item>\r\n                <dxi-item itemType=\"button\">\r\n                    <dxo-button-options width=\"30%\" type=\"danger\" [useSubmitBehavior]=\"true\"\r\n                        [template]=\"'addToCollectionTemplate'\">\r\n                    </dxo-button-options>\r\n                </dxi-item>\r\n                <ng-container *dxTemplate=\"let item of 'addToCollectionTemplate'\">\r\n                    <span class=\"dx-button-text\">\r\n                        <ng-container *ngIf=\"loading; else notLoading\">\r\n                            <dx-load-indicator width=\"24px\" height=\"24px\" [visible]=\"true\"></dx-load-indicator>\r\n                        </ng-container>\r\n                        <ng-template #notLoading>{{\r\n                            \"FILE_MANAGER.ADD\" | translate\r\n                            }}</ng-template>\r\n                    </span>\r\n                </ng-container>\r\n            </dx-form>\r\n        </form>\r\n    </div>\r\n</dx-popup>"]}
148
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-to-collection.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/file-manger/components/add-to-collection/add-to-collection.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/file-manger/components/add-to-collection/add-to-collection.component.html"],"names":[],"mappings":"AAAA,OAAO,EACN,SAAS,EACT,YAAY,EAEZ,KAAK,EAGL,MAAM,EAGN,SAAS,EACT,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAE,MAAM,EAAc,EAAE,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACvD,OAAO,EACN,YAAY,EACZ,oBAAoB,EACpB,SAAS,EACT,UAAU,EACV,GAAG,EAEH,MAAM,gBAAgB,CAAC;AAIxB,OAAO,EAAE,cAAc,EAAE,MAAM,yDAAyD,CAAC;AACzF,OAAO,EAAE,aAAa,EAAE,MAAM,mDAAmD,CAAC;;;;;;;;;;;AASlF,MAAM,OAAO,wBAAyB,SAAQ,aAAa;IAgC1D,YACS,kBAAsC,EACpC,mBAAwC,EAC3C,kBAAsC,EAE7C,QAAkB;QAElB,KAAK,CAAC,QAAQ,CAAC,CAAC;QANR,uBAAkB,GAAlB,kBAAkB,CAAoB;QACpC,wBAAmB,GAAnB,mBAAmB,CAAqB;QAC3C,uBAAkB,GAAlB,kBAAkB,CAAoB;QAhB9C,kBAAa,GAAG,IAAI,YAAY,EAAO,CAAC;QAExC,eAAU,GAAG,KAAK,CAAC;QAInB,eAAU,GAAY,IAAI,CAAC;QAI3B,eAAU,GAAG,IAAI,OAAO,EAAU,CAAC;QACnC,gBAAW,GAAG,KAAK,CAAC;QACpB,aAAQ,GAAG,KAAK,CAAC;QAqFjB,2BAAsB,GAAqB,CAAC,CAAC,EAAE,EAAE;YAChD,CAAC,CAAC,cAAc,EAAE,CAAC;YACnB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,OAAO,IAAI,CAAC,kBAAkB;iBAC5B,eAAe,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,YAAY,CAAC;iBACtD,IAAI,CACJ,GAAG,CACF,CAAC,GAAG,EAAE,EAAE;gBACP,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;gBACrB,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;gBACjC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;gBACzB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;gBACrB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAC5B,SAAS,EACT,iBAAiB,EACjB,sCAAsC,CACtC,CAAC;YACH,CAAC,EACD,CAAC,GAAG,EAAE,EAAE;gBACP,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;gBACrB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAC5B,OAAO,EACP,eAAe,EACf,4CAA4C,CAC5C,CAAC;YACH,CAAC,CACD,CACD,CAAC;QACJ,CAAC,CAAC;IAxGF,CAAC;IApCD,IACI,OAAO,CAAC,KAAU;QACrB,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK,EAAE;YAC5B,OAAO;SACP;QACD,IAAI,KAAK,EAAE;YACV,IAAI,CAAC,UAAU,EAAE,CAAC;SAClB;QACD,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACxC,CAAC;IACD,IAAI,OAAO;QACV,OAAO,IAAI,CAAC,QAAQ,CAAC;IACtB,CAAC;IAyBD,QAAQ,KAAU,CAAC;IAEnB,UAAU;QACT,MAAM,OAAO,GAAkB;YAC9B,SAAS,EAAE,cAAc;YACzB,MAAM,EAAE;gBACP,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,gCAAgC,CAAC;gBACtE,eAAe,EAAE,IAAI,CAAC,eAAe;gBACrC,eAAe,EAAE,IAAI,CAAC,eAAe;aACrC;SACD,CAAC;QACF,IAAI,CAAC,kBAAkB;aACrB,IAAI,CAAC,OAAO,CAAC;aACb,WAAW,EAAE;aACb,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;YAClB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACtB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,aAAa,CAAC,KAAK;QAClB,IAAI,IAAI,CAAC,UAAU,EAAE;YACpB,IAAI,CAAC,kBAAkB;iBACrB,mBAAmB,CAAC,KAAK,CAAC,YAAY,CAAC;iBACvC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;gBAClB,IAAI,CAAC,YAAY,GAAG,GAAG,CAAC,GAAG,CAAC;YAC7B,CAAC,CAAC,CAAC;SACJ;;YAAM,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,EAAE,CAAC;IACrC,CAAC;IAED,SAAS;QACR,IAAI,UAAU,GAAG,EAAE,CAAC;QACpB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,YAAY,GAAG,EAAE,CAAC;QACtB,IAAI,CAAC,MAAM,GAAG,MAAM,CACnB,IAAI,CAAC,kBAAkB,CAAC,mBAAmB,CAAC,UAAU,CAAC,CAAC,IAAI,CAC3D,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;YACtB,GAAG,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;gBACzB,YAAY,CAAC,IAAI,CAAC;oBACjB,YAAY,EAAE,KAAK,CAAC,KAAK;oBACzB,EAAE,EAAE,KAAK,CAAC,GAAG;oBACb,IAAI,EAAE,KAAK,CAAC,IAAI;oBAChB,IAAI,EAAE,KAAK,CAAC,UAAU,CAAC,aAAa,CAAC;iBACrC,CAAC,CAAC;YACJ,CAAC,CAAC,CAAC;YACH,OAAO,EAAE,CAAC,YAAY,CAAC,CAAC;QACzB,CAAC,CAAC,CACF,EAAE,gBAAgB;QACnB,IAAI,CAAC,UAAU,CAAC,IAAI,CACnB,YAAY,CAAC,GAAG,CAAC,EACjB,oBAAoB,EAAE,EACtB,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC,EACpC,SAAS,CAAC,CAAC,UAAU,EAAE,EAAE;YACxB,OAAO,IAAI,CAAC,kBAAkB,CAAC,mBAAmB,CAAC,UAAU,CAAC,CAAC,IAAI,CAClE,UAAU,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,sBAAsB;YAChD,SAAS,CAAC,CAAC,SAAS,EAAE,EAAE;gBACvB,IAAI,WAAW,GAAG,EAAE,CAAC;gBACrB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;gBACzB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;gBACvB,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;oBAC/B,WAAW,CAAC,IAAI,CAAC;wBAChB,YAAY,EAAE,KAAK,CAAC,KAAK;wBACzB,EAAE,EAAE,KAAK,CAAC,GAAG;wBACb,IAAI,EAAE,KAAK,CAAC,IAAI;wBAChB,IAAI,EAAE,KAAK,CAAC,UAAU,CAAC,aAAa,CAAC;qBACrC,CAAC,CAAC;gBACJ,CAAC,CAAC,CAAC;gBACH,OAAO,EAAE,CAAC,WAAW,CAAC,CAAC;YACxB,CAAC,CAAC,CACF,CAAC;QACH,CAAC,CAAC,CACF,CACD,CAAC;IACH,CAAC;;sHAlHW,wBAAwB;0GAAxB,wBAAwB,0OACzB,eAAe,iRCpC3B,s/CAgDA;4FDba,wBAAwB;kBALpC,SAAS;mBAAC;oBACV,QAAQ,EAAE,uBAAuB;oBACjC,WAAW,EAAE,oCAAoC;oBACjD,SAAS,EAAE,CAAC,oCAAoC,CAAC;iBACjD;mMAE+C,IAAI;sBAAlD,SAAS;uBAAC,eAAe,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBACf,eAAe;sBAA5C,SAAS;uBAAC,iBAAiB;gBACE,eAAe;sBAA5C,SAAS;uBAAC,iBAAiB;gBAExB,OAAO;sBADV,KAAK;gBAeN,aAAa;sBADZ,MAAM;gBAGP,UAAU;sBADT,KAAK;gBAGN,aAAa;sBADZ,KAAK","sourcesContent":["import {\r\n\tComponent,\r\n\tEventEmitter,\r\n\tInjector,\r\n\tInput,\r\n\tOnChanges,\r\n\tOnInit,\r\n\tOutput,\r\n\tSimpleChanges,\r\n\tTemplateRef,\r\n\tViewChild\r\n} from '@angular/core';\r\nimport { DxFormComponent } from 'devextreme-angular';\r\nimport { concat, Observable, of, Subject } from 'rxjs';\r\nimport {\r\n\tdebounceTime,\r\n\tdistinctUntilChanged,\r\n\tswitchMap,\r\n\tcatchError,\r\n\ttap,\r\n\tmap\r\n} from 'rxjs/operators';\r\nimport { CustomToastrService } from '../../../custom-toastr/services/custom-toastr.service';\r\nimport { FileManagerService } from '../../../../shared-services/file-manager.service';\r\nimport { DialogOptions } from '../../../../shared/components/nuxeo-dialog/models/dialog-option.model';\r\nimport { NdfNuxeoDialog } from '../../../../shared/components/nuxeo-dialog/nuxeo.dialog';\r\nimport { BaseComponent } from '../../../../shared/components/base/base.component';\r\nimport { NuxeoDialogService } from '../../../../shared/components/nuxeo-dialog/services/nuxeo-dialog.service';\r\nimport { DialogActionType } from '../../../../shared/components/nuxeo-dialog/models/dialog-option.model';\r\n\r\n@Component({\r\n\tselector: 'app-add-to-collection',\r\n\ttemplateUrl: './add-to-collection.component.html',\r\n\tstyleUrls: ['./add-to-collection.component.scss']\r\n})\r\nexport class AddToCollectionComponent extends BaseComponent implements OnInit {\r\n\t@ViewChild(DxFormComponent, { static: false }) form: DxFormComponent;\r\n\t@ViewChild('contentTemplate') contentTemplate!: TemplateRef<any>;\r\n\t@ViewChild('actionsTemplate') actionsTemplate!: TemplateRef<any>;\r\n\t@Input()\r\n\tset visible(value: any) {\r\n\t\tif (this._visible === value) {\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tif (value) {\r\n\t\t\tthis.openDialog();\r\n\t\t}\r\n\t\tthis._visible = value;\r\n\t\tthis.visibleChange.emit(this._visible);\r\n\t}\r\n\tget visible() {\r\n\t\treturn this._visible;\r\n\t}\r\n\t@Output()\r\n\tvisibleChange = new EventEmitter<any>();\r\n\t@Input()\r\n\trtlEnabled = false;\r\n\t@Input()\r\n\tselectedItems: any;\r\n\r\n\tisSelected: boolean = true;\r\n\tcollectionid: any;\r\n\tselectedTags: any;\r\n\titems$: Observable<any[]>;\r\n\ttagsInput$ = new Subject<string>();\r\n\ttagsLoading = false;\r\n\t_visible = false;\r\n\tconstructor(\r\n\t\tprivate fileManagerService: FileManagerService,\r\n\t\tprotected customToastrService: CustomToastrService,\r\n\t\tpublic nuxeoDialogService: NuxeoDialogService,\r\n\r\n\t\tinjector: Injector\r\n\t) {\r\n\t\tsuper(injector);\r\n\t}\r\n\r\n\tngOnInit(): void {}\r\n\r\n\topenDialog(): void {\r\n\t\tconst options: DialogOptions = {\r\n\t\t\tcomponent: NdfNuxeoDialog,\r\n\t\t\tconfig: {\r\n\t\t\t\ttitle: this.translateService.instant('FILE_MANAGER.ADD_TO_COLLECTION'),\r\n\t\t\t\tcontentTemplate: this.contentTemplate,\r\n\t\t\t\tactionsTemplate: this.actionsTemplate\r\n\t\t\t}\r\n\t\t};\r\n\t\tthis.nuxeoDialogService\r\n\t\t\t.open(options)\r\n\t\t\t.afterClosed()\r\n\t\t\t.subscribe((res) => {\r\n\t\t\t\tthis.visible = false;\r\n\t\t\t});\r\n\t}\r\n\r\n\temitSelection(event) {\r\n\t\tif (this.isSelected) {\r\n\t\t\tthis.fileManagerService\r\n\t\t\t\t.createNewCollection(event.displayLabel)\r\n\t\t\t\t.subscribe((res) => {\r\n\t\t\t\t\tthis.collectionid = res.uid;\r\n\t\t\t\t});\r\n\t\t} else this.collectionid = event.id;\r\n\t}\r\n\r\n\tloadItems() {\r\n\t\tlet searchterm = '';\r\n\t\tthis.isSelected = false;\r\n\t\tlet mycategories = [];\r\n\t\tthis.items$ = concat(\r\n\t\t\tthis.fileManagerService.getCollectionFromPP(searchterm).pipe(\r\n\t\t\t\tswitchMap((res: any) => {\r\n\t\t\t\t\tres.entries.map((entry) => {\r\n\t\t\t\t\t\tmycategories.push({\r\n\t\t\t\t\t\t\tdisplayLabel: entry.title,\r\n\t\t\t\t\t\t\tid: entry.uid,\r\n\t\t\t\t\t\t\tpath: entry.path,\r\n\t\t\t\t\t\t\ticon: entry.properties['common:icon']\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t});\r\n\t\t\t\t\treturn of(mycategories);\r\n\t\t\t\t})\r\n\t\t\t), // default items\r\n\t\t\tthis.tagsInput$.pipe(\r\n\t\t\t\tdebounceTime(200),\r\n\t\t\t\tdistinctUntilChanged(),\r\n\t\t\t\ttap(() => (this.tagsLoading = true)),\r\n\t\t\t\tswitchMap((searchterm) => {\r\n\t\t\t\t\treturn this.fileManagerService.getCollectionFromPP(searchterm).pipe(\r\n\t\t\t\t\t\tcatchError(() => of([])), // empty list on error\r\n\t\t\t\t\t\tswitchMap((searchCat) => {\r\n\t\t\t\t\t\t\tlet myInerCateg = [];\r\n\t\t\t\t\t\t\tthis.tagsLoading = false;\r\n\t\t\t\t\t\t\tthis.isSelected = true;\r\n\t\t\t\t\t\t\tsearchCat.entries.map((entry) => {\r\n\t\t\t\t\t\t\t\tmyInerCateg.push({\r\n\t\t\t\t\t\t\t\t\tdisplayLabel: entry.title,\r\n\t\t\t\t\t\t\t\t\tid: entry.uid,\r\n\t\t\t\t\t\t\t\t\tpath: entry.path,\r\n\t\t\t\t\t\t\t\t\ticon: entry.properties['common:icon']\r\n\t\t\t\t\t\t\t\t});\r\n\t\t\t\t\t\t\t});\r\n\t\t\t\t\t\t\treturn of(myInerCateg);\r\n\t\t\t\t\t\t})\r\n\t\t\t\t\t);\r\n\t\t\t\t})\r\n\t\t\t)\r\n\t\t);\r\n\t}\r\n\r\n\tonFormCollectionSubmit: DialogActionType = (e) => {\r\n\t\te.preventDefault();\r\n\t\tthis.loading = true;\r\n\t\treturn this.fileManagerService\r\n\t\t\t.addToCollection(this.selectedItems, this.collectionid)\r\n\t\t\t.pipe(\r\n\t\t\t\ttap(\r\n\t\t\t\t\t(res) => {\r\n\t\t\t\t\t\tthis.loading = false;\r\n\t\t\t\t\t\tthis.form.instance.resetValues();\r\n\t\t\t\t\t\tthis.selectedTags = null;\r\n\t\t\t\t\t\tthis.visible = false;\r\n\t\t\t\t\t\tthis.customToastrService.show(\r\n\t\t\t\t\t\t\t'success',\r\n\t\t\t\t\t\t\t'TOASTER.SUCCESS',\r\n\t\t\t\t\t\t\t'TOASTER.DOCUMENT_ADDED_TO_COLLECTION'\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t},\r\n\t\t\t\t\t(err) => {\r\n\t\t\t\t\t\tthis.loading = false;\r\n\t\t\t\t\t\tthis.customToastrService.show(\r\n\t\t\t\t\t\t\t'error',\r\n\t\t\t\t\t\t\t'TOASTER.ERROR',\r\n\t\t\t\t\t\t\t'TOASTER.DOCUMENT_ADDED_TO_COLLECTION_ERROR'\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t}\r\n\t\t\t\t)\r\n\t\t\t);\r\n\t};\r\n}\r\n","<!-- <dx-popup class=\"popUpParent\" [rtlEnabled]=\"rtlEnabled\" id=\"photo-popup\" [width]=\"500\" [height]=\"200\"\r\n    (onShown)=\"loadItems()\" closeOnOutsideClick=\"true\" title=\"{{ '' | translate }}\"\r\n    [(visible)]=\"visible\">\r\n\r\n</dx-popup>\r\n\r\n\r\n -->\r\n<ng-template #contentTemplate>\r\n\t<form>\r\n\t\t<dx-form\r\n\t\t\tclass=\"collection-form-wrapper\"\r\n\t\t\t#createForm\r\n\t\t\t[formData]=\"formData\"\r\n\t\t\t[disabled]=\"loading\"\r\n\t\t>\r\n\t\t\t<dxi-item editorType=\"dxTextBox\">\r\n\t\t\t\t<ng-select\r\n\t\t\t\t\t[items]=\"items$ | async\"\r\n\t\t\t\t\tbindLabel=\"displayLabel\"\r\n\t\t\t\t\t[addTag]=\"true\"\r\n\t\t\t\t\taddTagText=\"Add collection\"\r\n\t\t\t\t\t[multiple]=\"false\"\r\n\t\t\t\t\t[hideSelected]=\"true\"\r\n\t\t\t\t\t[minTermLength]=\"0\"\r\n\t\t\t\t\t[loading]=\"tagsLoading\"\r\n\t\t\t\t\ttypeToSearchText=\"search\"\r\n\t\t\t\t\t[typeahead]=\"tagsInput$\"\r\n\t\t\t\t\t[(ngModel)]=\"selectedTags\"\r\n\t\t\t\t\trequired\r\n\t\t\t\t\tplaceholder=\"{{ 'VOCABULARY.SELECT_ITEM' | translate }}\"\r\n\t\t\t\t\tname=\"selectedItem\"\r\n\t\t\t\t\t(change)=\"emitSelection($event)\"\r\n\t\t\t\t>\r\n\t\t\t\t</ng-select>\r\n\t\t\t</dxi-item>\r\n\t\t</dx-form>\r\n\t</form>\r\n</ng-template>\r\n\r\n<ng-template #actionsTemplate let-dialog=\"dialog\">\r\n\t<button\r\n\t\tclass=\"submission-button px-5\"\r\n\t\t(click)=\"dialog.executeAction(onFormCollectionSubmit, [$event])\"\r\n\t>\r\n\t\t{{ 'FILE_MANAGER.ADD' | translate }}\r\n\t</button>\r\n</ng-template>\r\n"]}