nuxeo-development-framework 4.1.2 → 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 (27) hide show
  1. package/bundles/nuxeo-development-framework.umd.js +1213 -1049
  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/copy/copy.component.js +65 -36
  7. package/esm2015/lib/components/file-manger/components/create-directory/create-directory.component.js +39 -13
  8. package/esm2015/lib/components/file-manger/components/folder-modal/folder-modal.component.js +45 -43
  9. package/esm2015/lib/components/file-manger/components/move/move.component.js +60 -31
  10. package/esm2015/lib/components/file-manger/components/scan-modal/scan-modal.component.js +99 -66
  11. package/esm2015/lib/components/permissions/add-permissions-dialog/add-permissions-dialog.component.js +107 -90
  12. package/esm2015/lib/components/permissions/permissions.module.js +23 -7
  13. package/esm2015/lib/shared/components/nuxeo-dialog/nuxeo.dialog.js +21 -21
  14. package/fesm2015/nuxeo-development-framework.js +619 -463
  15. package/fesm2015/nuxeo-development-framework.js.map +1 -1
  16. package/lib/components/dynamic-form/components/department-form/department-form.component.d.ts +4 -4
  17. package/lib/components/dynamic-form/dynamic-form.module.d.ts +2 -1
  18. package/lib/components/file-manger/components/add-to-collection/add-to-collection.component.d.ts +11 -5
  19. package/lib/components/file-manger/components/copy/copy.component.d.ts +11 -4
  20. package/lib/components/file-manger/components/create-directory/create-directory.component.d.ts +9 -4
  21. package/lib/components/file-manger/components/folder-modal/folder-modal.component.d.ts +9 -11
  22. package/lib/components/file-manger/components/move/move.component.d.ts +11 -4
  23. package/lib/components/file-manger/components/scan-modal/scan-modal.component.d.ts +9 -8
  24. package/lib/components/permissions/add-permissions-dialog/add-permissions-dialog.component.d.ts +8 -6
  25. package/lib/components/permissions/permissions.module.d.ts +2 -1
  26. package/lib/shared/components/nuxeo-dialog/nuxeo.dialog.d.ts +5 -5
  27. package/package.json +1 -1
@@ -1,36 +1,56 @@
1
1
  import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
2
2
  import { DxFormComponent } from 'devextreme-angular';
3
+ import { NdfNuxeoDialog } from '../../../../shared/components/nuxeo-dialog/nuxeo.dialog';
4
+ import { BaseComponent } from '../../../../shared/components/base/base.component';
3
5
  import * as i0 from "@angular/core";
4
6
  import * as i1 from "../../../../shared-services/file-manager.service";
5
7
  import * as i2 from "../../../custom-toastr/services/custom-toastr.service";
6
- import * as i3 from "devextreme-angular";
7
- import * as i4 from "devextreme-angular/ui/nested";
8
- import * as i5 from "devextreme-angular/core";
8
+ import * as i3 from "../../../../shared/components/nuxeo-dialog/services/nuxeo-dialog.service";
9
+ import * as i4 from "devextreme-angular";
10
+ import * as i5 from "devextreme-angular/ui/nested";
9
11
  import * as i6 from "@angular/forms";
10
- import * as i7 from "@angular/common";
11
- import * as i8 from "@ngx-translate/core";
12
- export class CreateDirectoryComponent {
13
- constructor(fileManagerService, customToastrService) {
12
+ import * as i7 from "@ngx-translate/core";
13
+ export class CreateDirectoryComponent extends BaseComponent {
14
+ constructor(fileManagerService, customToastrService, nuxeoDialogService, injector) {
15
+ super(injector);
14
16
  this.fileManagerService = fileManagerService;
15
17
  this.customToastrService = customToastrService;
18
+ this.nuxeoDialogService = nuxeoDialogService;
16
19
  this.visibleChange = new EventEmitter();
17
20
  this.refresh = new EventEmitter();
18
21
  this.rtlEnabled = false;
19
22
  this.formData = {};
20
23
  this._visible = false;
21
- this.loading = false;
22
24
  }
23
25
  set visible(value) {
24
26
  if (this._visible === value) {
25
27
  return;
26
28
  }
29
+ if (value) {
30
+ this.openDialog();
31
+ }
27
32
  this._visible = value;
28
33
  this.visibleChange.emit(this._visible);
29
34
  }
30
35
  get visible() {
31
36
  return this._visible;
32
37
  }
33
- ngOnInit() {
38
+ ngOnInit() { }
39
+ openDialog() {
40
+ const options = {
41
+ component: NdfNuxeoDialog,
42
+ config: {
43
+ title: this.translateService.instant('CREATE.createFolder'),
44
+ contentTemplate: this.contentTemplate,
45
+ actionsTemplate: this.actionsTemplate
46
+ }
47
+ };
48
+ this.nuxeoDialogService
49
+ .open(options)
50
+ .afterClosed()
51
+ .subscribe((res) => {
52
+ this.visible = false;
53
+ });
34
54
  }
35
55
  onSubmit(e) {
36
56
  e.preventDefault();
@@ -65,8 +85,8 @@ export class CreateDirectoryComponent {
65
85
  });
66
86
  }
67
87
  }
68
- CreateDirectoryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: CreateDirectoryComponent, deps: [{ token: i1.FileManagerService }, { token: i2.CustomToastrService }], target: i0.ɵɵFactoryTarget.Component });
69
- CreateDirectoryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: CreateDirectoryComponent, selector: "app-create-directory", inputs: { visible: "visible", rtlEnabled: "rtlEnabled", selectedItem: "selectedItem" }, outputs: { visibleChange: "visibleChange", refresh: "refresh" }, viewQueries: [{ propertyName: "form", first: true, predicate: DxFormComponent, descendants: true }], ngImport: i0, template: "<dx-popup class=\"popUpParent\" [rtlEnabled]=\"rtlEnabled\" [width]=\"500\" [height]=\"230\" [dragEnabled]=\"false\"\r\n[closeOnOutsideClick]=\"true\" [(visible)]=\"visible\"\r\ntitle=\"{{ 'FILE_MANAGER.NEW_DIRECTORY' | translate }}\">\r\n<div *dxTemplate=\"let data of 'content'\">\r\n <form (submit)=\"onSubmit($event)\">\r\n <dx-form class=\"form-wrapper\" #form [formData]=\"formData\" [disabled]=\"loading\">\r\n <dxi-item dataField=\"title\" editorType=\"dxTextBox\">\r\n <dxo-label text=\"{{ 'CREATE.TITLE' | translate }}\"></dxo-label>\r\n <dxi-validation-rule type=\"required\" message=\"Title is required\"></dxi-validation-rule>\r\n </dxi-item>\r\n <dxi-item name=\"description\" editorType=\"dxTextBox\">\r\n <dxo-label text=\"{{ 'CREATE.DESCRIPTION' | translate }}\"></dxo-label>\r\n </dxi-item>\r\n <dxi-item itemType=\"button\">\r\n <dxo-button-options width=\"30%\" type=\"danger\" [useSubmitBehavior]=\"true\"\r\n [template]=\"'createTemplate'\">\r\n </dxo-button-options>\r\n </dxi-item>\r\n <ng-container *dxTemplate=\"let item of 'createTemplate'\">\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.CREATE\" | 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: i4.DxoLabelComponent, selector: "dxo-label", inputs: ["connectorColor", "connectorWidth", "customizeText", "font", "format", "indent", "visible", "horizontalAlignment", "position", "text", "verticalAlignment", "alignment", "customizeHint", "displayMode", "indentFromAxis", "overlappingBehavior", "rotationAngle", "staggeringSpacing", "template", "textOverflow", "wordWrap", "argumentFormat", "backgroundColor", "border", "connector", "displayFormat", "horizontalOffset", "showForZeroValues", "verticalOffset", "hideFirstOrLast", "indentFromTick", "useRangeColors", "location", "showColon", "radialOffset", "topIndent", "shadow", "useNodeColors", "dataField", "enabled"] }, { type: i4.DxiValidationRuleComponent, selector: "dxi-validation-rule", inputs: ["message", "trim", "type", "ignoreEmptyValue", "max", "min", "reevaluate", "validationCallback", "comparisonTarget", "comparisonType", "pattern"] }, { 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: i5.DxTemplateDirective, selector: "[dxTemplate]", inputs: ["dxTemplateOf"] }, { type: i6.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i6.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i6.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i8.TranslatePipe } });
88
+ CreateDirectoryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: CreateDirectoryComponent, deps: [{ token: i1.FileManagerService }, { token: i2.CustomToastrService }, { token: i3.NuxeoDialogService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
89
+ CreateDirectoryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: CreateDirectoryComponent, selector: "app-create-directory", inputs: { visible: "visible", rtlEnabled: "rtlEnabled", selectedItem: "selectedItem" }, outputs: { visibleChange: "visibleChange", refresh: "refresh" }, 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\" [width]=\"500\" [height]=\"230\" [dragEnabled]=\"false\"\r\n[closeOnOutsideClick]=\"true\" [(visible)]=\"visible\"\r\ntitle=\"{{ 'FILE_MANAGER.NEW_DIRECTORY' | translate }}\">\r\n<div *dxTemplate=\"let data of 'content'\">\r\n <form (submit)=\"onSubmit($event)\">\r\n <dx-form class=\"form-wrapper\" #form [formData]=\"formData\" [disabled]=\"loading\">\r\n <dxi-item dataField=\"title\" editorType=\"dxTextBox\">\r\n <dxo-label text=\"{{ 'CREATE.TITLE' | translate }}\"></dxo-label>\r\n <dxi-validation-rule type=\"required\" message=\"Title is required\"></dxi-validation-rule>\r\n </dxi-item>\r\n <dxi-item name=\"description\" editorType=\"dxTextBox\">\r\n <dxo-label text=\"{{ 'CREATE.DESCRIPTION' | translate }}\"></dxo-label>\r\n </dxi-item>\r\n <dxi-item itemType=\"button\">\r\n <dxo-button-options width=\"30%\" type=\"danger\" [useSubmitBehavior]=\"true\"\r\n [template]=\"'createTemplate'\">\r\n </dxo-button-options>\r\n </dxi-item>\r\n <ng-container *dxTemplate=\"let item of 'createTemplate'\">\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.CREATE\" | 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> -->\r\n\r\n<ng-template #contentTemplate>\r\n\t<div>\r\n\t\t<form>\r\n\t\t\t<dx-form\r\n\t\t\t\tclass=\"form-wrapper\"\r\n\t\t\t\t#form\r\n\t\t\t\t[formData]=\"formData\"\r\n\t\t\t\t[disabled]=\"loading\"\r\n\t\t\t>\r\n\t\t\t\t<dxi-item dataField=\"title\" editorType=\"dxTextBox\">\r\n\t\t\t\t\t<dxo-label text=\"{{ 'CREATE.TITLE' | translate }}\"></dxo-label>\r\n\t\t\t\t\t<dxi-validation-rule\r\n\t\t\t\t\t\ttype=\"required\"\r\n\t\t\t\t\t\tmessage=\"Title is required\"\r\n\t\t\t\t\t></dxi-validation-rule>\r\n\t\t\t\t</dxi-item>\r\n\t\t\t\t<dxi-item name=\"description\" editorType=\"dxTextBox\">\r\n\t\t\t\t\t<dxo-label text=\"{{ 'CREATE.DESCRIPTION' | translate }}\"></dxo-label>\r\n\t\t\t\t</dxi-item>\r\n\t\t\t</dx-form>\r\n\t\t</form>\r\n\t</div>\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(onSubmit, [$event])\"\r\n\t>\r\n\t\t{{ 'FILE_MANAGER.CREATE' | 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: i5.DxoLabelComponent, selector: "dxo-label", inputs: ["connectorColor", "connectorWidth", "customizeText", "font", "format", "indent", "visible", "horizontalAlignment", "position", "text", "verticalAlignment", "alignment", "customizeHint", "displayMode", "indentFromAxis", "overlappingBehavior", "rotationAngle", "staggeringSpacing", "template", "textOverflow", "wordWrap", "argumentFormat", "backgroundColor", "border", "connector", "displayFormat", "horizontalOffset", "showForZeroValues", "verticalOffset", "hideFirstOrLast", "indentFromTick", "useRangeColors", "location", "showColon", "radialOffset", "topIndent", "shadow", "useNodeColors", "dataField", "enabled"] }, { type: i5.DxiValidationRuleComponent, selector: "dxi-validation-rule", inputs: ["message", "trim", "type", "ignoreEmptyValue", "max", "min", "reevaluate", "validationCallback", "comparisonTarget", "comparisonType", "pattern"] }], directives: [{ type: i6.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i6.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i6.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }], pipes: { "translate": i7.TranslatePipe } });
70
90
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: CreateDirectoryComponent, decorators: [{
71
91
  type: Component,
72
92
  args: [{
@@ -74,9 +94,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
74
94
  templateUrl: './create-directory.component.html',
75
95
  styleUrls: ['./create-directory.component.scss']
76
96
  }]
77
- }], ctorParameters: function () { return [{ type: i1.FileManagerService }, { type: i2.CustomToastrService }]; }, propDecorators: { form: [{
97
+ }], ctorParameters: function () { return [{ type: i1.FileManagerService }, { type: i2.CustomToastrService }, { type: i3.NuxeoDialogService }, { type: i0.Injector }]; }, propDecorators: { form: [{
78
98
  type: ViewChild,
79
99
  args: [DxFormComponent, { static: false }]
100
+ }], contentTemplate: [{
101
+ type: ViewChild,
102
+ args: ['contentTemplate']
103
+ }], actionsTemplate: [{
104
+ type: ViewChild,
105
+ args: ['actionsTemplate']
80
106
  }], visible: [{
81
107
  type: Input
82
108
  }], visibleChange: [{
@@ -88,4 +114,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
88
114
  }], selectedItem: [{
89
115
  type: Input
90
116
  }] } });
91
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-directory.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/file-manger/components/create-directory/create-directory.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/file-manger/components/create-directory/create-directory.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAE1F,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;;;;;;;;;;AAQrD,MAAM,OAAO,wBAAwB;IAyBnC,YAAoB,kBAAuC,EACjD,mBAAyC;QAD/B,uBAAkB,GAAlB,kBAAkB,CAAqB;QACjD,wBAAmB,GAAnB,mBAAmB,CAAsB;QAZnD,kBAAa,GAAG,IAAI,YAAY,EAAO,CAAC;QAExC,YAAO,GAAG,IAAI,YAAY,EAAO,CAAC;QAElC,eAAU,GAAG,KAAK,CAAC;QAInB,aAAQ,GAAQ,EAAE,CAAC;QACnB,aAAQ,GAAG,KAAK,CAAC;QACjB,YAAO,GAAG,KAAK,CAAC;IAEuC,CAAC;IAxBxD,IACI,OAAO,CAAC,KAAU;QACpB,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK,EAAE;YAC3B,OAAO;SACR;QACD,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACzC,CAAC;IACD,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAgBD,QAAQ;IACR,CAAC;IAED,QAAQ,CAAC,CAAC;QACR,CAAC,CAAC,cAAc,EAAE,CAAC;QACnB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,8CAA8C;QAC9C,WAAW;QACX,uCAAuC;QACvC,4BAA4B;QAC5B,gDAAgD;QAChD,IAAI,CAAC,kBAAkB;aAClB,eAAe,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,YAAY,CAAC;aACjD,SAAS,CACN,CAAC,GAAG,EAAE,EAAE;YACJ,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,6BAA6B;YAC7B,yBAAyB;YACzB,wDAAwD;YACxD,yBAAyB;YACzB,kDAAkD;YAClD,+CAA+C;YAC/C,aAAa;YACb,mCAAmC;YACnC,8BAA8B;YAC9B,IAAI;YACJ,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACxB,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;YACjC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CACzB,SAAS,EACT,iBAAiB,EACjB,0BAA0B,CAC7B,CAAC;QACN,CAAC,EACD,CAAC,GAAG,EAAE,EAAE;YACJ,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CACzB,OAAO,EACP,eAAe,EACf,gCAAgC,CACnC,CAAC;QACN,CAAC,CACJ,CAAC;IACV,CAAC;;sHAzEY,wBAAwB;0GAAxB,wBAAwB,2PACxB,eAAe,gDCX5B,kxDA+BW;4FDrBE,wBAAwB;kBALpC,SAAS;mBAAC;oBACT,QAAQ,EAAE,sBAAsB;oBAChC,WAAW,EAAE,mCAAmC;oBAChD,SAAS,EAAE,CAAC,mCAAmC,CAAC;iBACjD;2IAEgD,IAAI;sBAAlD,SAAS;uBAAC,eAAe,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAEzC,OAAO;sBADV,KAAK;gBAYN,aAAa;sBADZ,MAAM;gBAGP,OAAO;sBADN,MAAM;gBAGP,UAAU;sBADT,KAAK;gBAGN,YAAY;sBADX,KAAK","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { FileManagerService } from '../../../../shared-services/file-manager.service';\r\nimport { DxFormComponent } from 'devextreme-angular';\r\nimport { CustomToastrService } from '../../../custom-toastr/services/custom-toastr.service';\r\n\r\n@Component({\r\n  selector: 'app-create-directory',\r\n  templateUrl: './create-directory.component.html',\r\n  styleUrls: ['./create-directory.component.scss']\r\n})\r\nexport class CreateDirectoryComponent 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  @Output()\r\n  refresh = new EventEmitter<any>();\r\n  @Input()\r\n  rtlEnabled = false;\r\n  @Input()\r\n  selectedItem: any;\r\n\r\n  formData: any = {};\r\n  _visible = false;\r\n  loading = false;\r\n  constructor(private fileManagerService : FileManagerService,\r\n    private customToastrService : CustomToastrService) { }\r\n\r\n  ngOnInit(): void {\r\n  }\r\n\r\n  onSubmit(e) {\r\n    e.preventDefault();\r\n    this.loading = true;\r\n    // let directory = this.getCurrentDirectory();\r\n    // let id =\r\n    //     directory.dataItem === undefined\r\n    //         ? this.mainFolder\r\n    //         : this.getCurrentFolderId(directory);\r\n    this.fileManagerService\r\n        .createDirectory(this.formData, this.selectedItem)\r\n        .subscribe(\r\n            (res) => {\r\n                this.loading = false;\r\n                this.visible = false;\r\n                // if (this.isItemSelected) {\r\n                //     let selectedItem =\r\n                //         this.fileManager.instance.getSelectedItems();\r\n                //     this.currentPath =\r\n                //         this.selectedObject.entity.path.substr(\r\n                //             this.fileManagerObj?.path.length\r\n                //         );\r\n                //     directory = selectedItem[0];\r\n                //     id = this.selectedItem;\r\n                // }\r\n                this.refresh.next(true);\r\n                this.form.instance.resetValues();\r\n                this.customToastrService.show(\r\n                    'success',\r\n                    'TOASTER.SUCCESS',\r\n                    'TOASTER.DOCUMENT_CREATED'\r\n                );\r\n            },\r\n            (err) => {\r\n                this.loading = false;\r\n                this.visible = true;\r\n                this.customToastrService.show(\r\n                    'error',\r\n                    'TOASTER.ERROR',\r\n                    'TOASTER.DOCUMENT_CREATED_ERROR'\r\n                );\r\n            }\r\n        );\r\n}\r\n}\r\n","<dx-popup class=\"popUpParent\" [rtlEnabled]=\"rtlEnabled\" [width]=\"500\" [height]=\"230\" [dragEnabled]=\"false\"\r\n[closeOnOutsideClick]=\"true\" [(visible)]=\"visible\"\r\ntitle=\"{{ 'FILE_MANAGER.NEW_DIRECTORY' | translate }}\">\r\n<div *dxTemplate=\"let data of 'content'\">\r\n    <form (submit)=\"onSubmit($event)\">\r\n        <dx-form class=\"form-wrapper\" #form [formData]=\"formData\" [disabled]=\"loading\">\r\n            <dxi-item dataField=\"title\" editorType=\"dxTextBox\">\r\n                <dxo-label text=\"{{ 'CREATE.TITLE' | translate }}\"></dxo-label>\r\n                <dxi-validation-rule type=\"required\" message=\"Title is required\"></dxi-validation-rule>\r\n            </dxi-item>\r\n            <dxi-item name=\"description\" editorType=\"dxTextBox\">\r\n                <dxo-label text=\"{{ 'CREATE.DESCRIPTION' | translate }}\"></dxo-label>\r\n            </dxi-item>\r\n            <dxi-item itemType=\"button\">\r\n                <dxo-button-options width=\"30%\" type=\"danger\" [useSubmitBehavior]=\"true\"\r\n                    [template]=\"'createTemplate'\">\r\n                </dxo-button-options>\r\n            </dxi-item>\r\n            <ng-container *dxTemplate=\"let item of 'createTemplate'\">\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.CREATE\" | 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>"]}
117
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-directory.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/file-manger/components/create-directory/create-directory.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/file-manger/components/create-directory/create-directory.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n\tComponent,\r\n\tEventEmitter,\r\n\tInjector,\r\n\tInput,\r\n\tOnInit,\r\n\tOutput,\r\n\tTemplateRef,\r\n\tViewChild\r\n} from '@angular/core';\r\nimport { FileManagerService } from '../../../../shared-services/file-manager.service';\r\nimport { DxFormComponent } from 'devextreme-angular';\r\nimport { CustomToastrService } from '../../../custom-toastr/services/custom-toastr.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 { NuxeoDialogService } from '../../../../shared/components/nuxeo-dialog/services/nuxeo-dialog.service';\r\nimport { BaseComponent } from '../../../../shared/components/base/base.component';\r\n\r\n@Component({\r\n\tselector: 'app-create-directory',\r\n\ttemplateUrl: './create-directory.component.html',\r\n\tstyleUrls: ['./create-directory.component.scss']\r\n})\r\nexport class CreateDirectoryComponent 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@Output()\r\n\trefresh = new EventEmitter<any>();\r\n\t@Input()\r\n\trtlEnabled = false;\r\n\t@Input()\r\n\tselectedItem: any;\r\n\r\n\tformData: any = {};\r\n\t_visible = false;\r\n\tconstructor(\r\n\t\tprivate fileManagerService: FileManagerService,\r\n\t\tprivate customToastrService: CustomToastrService,\r\n\t\tpublic nuxeoDialogService: NuxeoDialogService,\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('CREATE.createFolder'),\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\tonSubmit(e) {\r\n\t\te.preventDefault();\r\n\t\tthis.loading = true;\r\n\t\t// let directory = this.getCurrentDirectory();\r\n\t\t// let id =\r\n\t\t//     directory.dataItem === undefined\r\n\t\t//         ? this.mainFolder\r\n\t\t//         : this.getCurrentFolderId(directory);\r\n\t\tthis.fileManagerService\r\n\t\t\t.createDirectory(this.formData, this.selectedItem)\r\n\t\t\t.subscribe(\r\n\t\t\t\t(res) => {\r\n\t\t\t\t\tthis.loading = false;\r\n\t\t\t\t\tthis.visible = false;\r\n\t\t\t\t\t// if (this.isItemSelected) {\r\n\t\t\t\t\t//     let selectedItem =\r\n\t\t\t\t\t//         this.fileManager.instance.getSelectedItems();\r\n\t\t\t\t\t//     this.currentPath =\r\n\t\t\t\t\t//         this.selectedObject.entity.path.substr(\r\n\t\t\t\t\t//             this.fileManagerObj?.path.length\r\n\t\t\t\t\t//         );\r\n\t\t\t\t\t//     directory = selectedItem[0];\r\n\t\t\t\t\t//     id = this.selectedItem;\r\n\t\t\t\t\t// }\r\n\t\t\t\t\tthis.refresh.next(true);\r\n\t\t\t\t\tthis.form.instance.resetValues();\r\n\t\t\t\t\tthis.customToastrService.show(\r\n\t\t\t\t\t\t'success',\r\n\t\t\t\t\t\t'TOASTER.SUCCESS',\r\n\t\t\t\t\t\t'TOASTER.DOCUMENT_CREATED'\r\n\t\t\t\t\t);\r\n\t\t\t\t},\r\n\t\t\t\t(err) => {\r\n\t\t\t\t\tthis.loading = false;\r\n\t\t\t\t\tthis.visible = true;\r\n\t\t\t\t\tthis.customToastrService.show(\r\n\t\t\t\t\t\t'error',\r\n\t\t\t\t\t\t'TOASTER.ERROR',\r\n\t\t\t\t\t\t'TOASTER.DOCUMENT_CREATED_ERROR'\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\" [width]=\"500\" [height]=\"230\" [dragEnabled]=\"false\"\r\n[closeOnOutsideClick]=\"true\" [(visible)]=\"visible\"\r\ntitle=\"{{ 'FILE_MANAGER.NEW_DIRECTORY' | translate }}\">\r\n<div *dxTemplate=\"let data of 'content'\">\r\n    <form (submit)=\"onSubmit($event)\">\r\n        <dx-form class=\"form-wrapper\" #form [formData]=\"formData\" [disabled]=\"loading\">\r\n            <dxi-item dataField=\"title\" editorType=\"dxTextBox\">\r\n                <dxo-label text=\"{{ 'CREATE.TITLE' | translate }}\"></dxo-label>\r\n                <dxi-validation-rule type=\"required\" message=\"Title is required\"></dxi-validation-rule>\r\n            </dxi-item>\r\n            <dxi-item name=\"description\" editorType=\"dxTextBox\">\r\n                <dxo-label text=\"{{ 'CREATE.DESCRIPTION' | translate }}\"></dxo-label>\r\n            </dxi-item>\r\n            <dxi-item itemType=\"button\">\r\n                <dxo-button-options width=\"30%\" type=\"danger\" [useSubmitBehavior]=\"true\"\r\n                    [template]=\"'createTemplate'\">\r\n                </dxo-button-options>\r\n            </dxi-item>\r\n            <ng-container *dxTemplate=\"let item of 'createTemplate'\">\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.CREATE\" | 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> -->\r\n\r\n<ng-template #contentTemplate>\r\n\t<div>\r\n\t\t<form>\r\n\t\t\t<dx-form\r\n\t\t\t\tclass=\"form-wrapper\"\r\n\t\t\t\t#form\r\n\t\t\t\t[formData]=\"formData\"\r\n\t\t\t\t[disabled]=\"loading\"\r\n\t\t\t>\r\n\t\t\t\t<dxi-item dataField=\"title\" editorType=\"dxTextBox\">\r\n\t\t\t\t\t<dxo-label text=\"{{ 'CREATE.TITLE' | translate }}\"></dxo-label>\r\n\t\t\t\t\t<dxi-validation-rule\r\n\t\t\t\t\t\ttype=\"required\"\r\n\t\t\t\t\t\tmessage=\"Title is required\"\r\n\t\t\t\t\t></dxi-validation-rule>\r\n\t\t\t\t</dxi-item>\r\n\t\t\t\t<dxi-item name=\"description\" editorType=\"dxTextBox\">\r\n\t\t\t\t\t<dxo-label text=\"{{ 'CREATE.DESCRIPTION' | translate }}\"></dxo-label>\r\n\t\t\t\t</dxi-item>\r\n\t\t\t</dx-form>\r\n\t\t</form>\r\n\t</div>\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(onSubmit, [$event])\"\r\n\t>\r\n\t\t{{ 'FILE_MANAGER.CREATE' | translate }}\r\n\t</button>\r\n</ng-template>\r\n"]}
@@ -1,28 +1,27 @@
1
1
  import { Component, HostListener, Inject, ViewChild } from '@angular/core';
2
2
  import { MAT_DIALOG_DATA } from '@angular/material/dialog';
3
3
  import { Subject } from 'rxjs';
4
- import { takeUntil } from 'rxjs/operators';
4
+ import { BaseDialogComponent } from '../../../../shared/components/base/base-dialog.component';
5
+ import { tap } from 'rxjs/operators';
5
6
  import * as i0 from "@angular/core";
6
7
  import * as i1 from "@angular/material/dialog";
7
8
  import * as i2 from "../../../../shared-services/file-manager.service";
8
9
  import * as i3 from "../../../../shared-services/dynamic-form.service";
9
- import * as i4 from "../../../../core/services/translation/translation.service";
10
- import * as i5 from "../../../custom-toastr/services/custom-toastr.service";
11
- import * as i6 from "@angular/forms";
12
- import * as i7 from "../../../dynamic-form/components/dynamic-form/dynamic-form.component";
13
- import * as i8 from "@angular/material/progress-spinner";
14
- import * as i9 from "../../../../directive/rtl/set-rtl.directive";
15
- import * as i10 from "@angular/common";
16
- import * as i11 from "@ngx-translate/core";
17
- export class FolderModalComponent {
18
- constructor(data, dialogRef, fileMangerService, dynamicFormService, translationService, tosterService, formBuilder) {
10
+ import * as i4 from "../../../custom-toastr/services/custom-toastr.service";
11
+ import * as i5 from "../../../../shared/components/nuxeo-dialog/nuxeo.dialog";
12
+ import * as i6 from "../../../dynamic-form/components/dynamic-form/dynamic-form.component";
13
+ import * as i7 from "../../../../directive/rtl/set-rtl.directive";
14
+ import * as i8 from "@angular/forms";
15
+ import * as i9 from "@angular/common";
16
+ import * as i10 from "@ngx-translate/core";
17
+ export class FolderModalComponent extends BaseDialogComponent {
18
+ constructor(data, dialogRef, fileMangerService, dynamicFormService, tosterService, injector) {
19
+ super(injector);
19
20
  this.data = data;
20
21
  this.dialogRef = dialogRef;
21
22
  this.fileMangerService = fileMangerService;
22
23
  this.dynamicFormService = dynamicFormService;
23
- this.translationService = translationService;
24
24
  this.tosterService = tosterService;
25
- this.formBuilder = formBuilder;
26
25
  this.temporaryDyanmicData = {};
27
26
  this.showRenderer = false;
28
27
  this.dynamicData = {
@@ -30,31 +29,44 @@ export class FolderModalComponent {
30
29
  };
31
30
  this.staticForm = {
32
31
  title: '',
33
- description: '',
32
+ description: ''
34
33
  // department:''
35
34
  };
36
35
  this.filter = {};
37
36
  this.filter2 = {};
38
37
  this.parentId = '2';
39
- this.isArabic = false;
40
38
  this._unsubscribeAll = new Subject();
41
39
  this.isDmsFolder = false;
42
40
  this.creating = false;
41
+ this.createDocument = () => {
42
+ this.creating = true;
43
+ let params = this.constructPayLoad(this.dynamicData['data'], this.staticForm);
44
+ return this.fileMangerService
45
+ .createFolder(params, this.fileMangerService.selectedFolderId)
46
+ .pipe(tap((res) => {
47
+ //console.log(res);
48
+ this.creating = false;
49
+ this.fileMangerService.onRefreshingFileManger.next();
50
+ this.tosterService.show('success', 'TOASTER.SUCCESS', 'TOASTER.FOLDER_CREATED_SUCCE');
51
+ this.closeDialog();
52
+ }));
53
+ };
43
54
  }
44
55
  KeyUpEvent(event) {
45
- if (this.dynamicData.valid && !this.folderForm.invalid && this.staticForm.title != '..') {
56
+ if (this.dynamicData.valid &&
57
+ !this.folderForm.invalid &&
58
+ this.staticForm.title != '..') {
46
59
  this.createDocument();
47
60
  }
48
61
  }
49
62
  ngOnInit() {
50
- this.translationService.isArabic.pipe(takeUntil(this._unsubscribeAll)).subscribe(res => {
51
- this.isArabic = res;
52
- });
53
63
  this.folderType = this.data.folderType;
54
64
  this.dynamicForm = this.data.dynamicForm;
55
- this.fileMangerService.getFileSchemas(this.folderType.type).subscribe(schemas => {
56
- schemas.map(item => {
57
- if (item.name === "dmsfolder") {
65
+ this.fileMangerService
66
+ .getFileSchemas(this.folderType.type)
67
+ .subscribe((schemas) => {
68
+ schemas.map((item) => {
69
+ if (item.name === 'dmsfolder') {
58
70
  this.isDmsFolder = true;
59
71
  }
60
72
  });
@@ -76,30 +88,20 @@ export class FolderModalComponent {
76
88
  closeDialog() {
77
89
  this.dialogRef.close(false);
78
90
  }
79
- createDocument() {
80
- this.creating = true;
81
- let params = this.constructPayLoad(this.dynamicData['data'], this.staticForm);
82
- this.fileMangerService.createFolder(params, this.fileMangerService.selectedFolderId).subscribe(res => {
83
- //console.log(res);
84
- this.creating = false;
85
- this.fileMangerService.onRefreshingFileManger.next();
86
- this.tosterService.show('success', 'TOASTER.SUCCESS', "TOASTER.FOLDER_CREATED_SUCCE");
87
- this.closeDialog();
88
- });
89
- }
90
91
  constructPayLoad(dynamicValues, staticForm) {
91
92
  // let props = this.constructDynamicFormPayload(dynamicValues);
92
93
  let props = this.dynamicFormService.constructDynamicFormPayload(dynamicValues, this.dynamicForm);
93
94
  let param = {
94
- "document": {
95
- "type": this.folderType.type,
96
- "name": staticForm.title,
97
- "properties": Object.assign(Object.assign({}, props), { "dc:description": staticForm.description, "dc:title": staticForm.title })
95
+ document: {
96
+ type: this.folderType.type,
97
+ name: staticForm.title,
98
+ properties: Object.assign(Object.assign({}, props), { 'dc:description': staticForm.description, 'dc:title': staticForm.title })
98
99
  }
99
100
  };
100
101
  if (this.folderType.documentCode && this.isDmsFolder) {
101
- param["documentTypeCode"] = this.folderType.documentCode;
102
- param['document']['properties']['dmsfolder:documentTypeCode'] = this.folderType.documentCode;
102
+ param['documentTypeCode'] = this.folderType.documentCode;
103
+ param['document']['properties']['dmsfolder:documentTypeCode'] =
104
+ this.folderType.documentCode;
103
105
  }
104
106
  return param;
105
107
  }
@@ -107,8 +109,8 @@ export class FolderModalComponent {
107
109
  //console.log(data);
108
110
  }
109
111
  }
110
- FolderModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FolderModalComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }, { token: i2.FileManagerService }, { token: i3.DynamicFormService }, { token: i4.TranslationService }, { token: i5.CustomToastrService }, { token: i6.FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
111
- FolderModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: FolderModalComponent, selector: "app-folder-modal", host: { listeners: { "document:keyup.enter": "KeyUpEvent($event)" } }, viewQueries: [{ propertyName: "folderForm", first: true, predicate: ["folderForm"], descendants: true }], ngImport: i0, template: "<div class=\"create-folder-modal d-flex justify-center w-full relative h-full\">\r\n <div class=\"folder-wrapper\" SetRtl>\r\n <div class=\"mb-5\">\r\n <div class=\"label-style\">\r\n {{ \"FOLDERS.TYPE\" | translate }}\r\n </div>\r\n <div class=\"text-base text-gray-900\">\r\n {{ isArabic ? folderType.arabicText : folderType.englishText }}\r\n </div>\r\n </div>\r\n <form #folderForm=\"ngForm\">\r\n <div class=\"mb-3\">\r\n <div class=\"label-style\">\r\n {{ \"FOLDERS.TITLE\" | translate }}\r\n </div>\r\n <input\r\n class=\"field-style\"\r\n [ngClass]=\"{ 'border-red-500': staticForm.title === '..' }\"\r\n required\r\n [(ngModel)]=\"staticForm.title\"\r\n id=\"folderTitle\"\r\n name=\"folderTitle\"\r\n />\r\n <div class=\"text-red-500 text-base\" *ngIf=\"staticForm.title === '..'\">\r\n Invalid Folder Title\r\n </div>\r\n </div>\r\n <div class=\"mb-3\">\r\n <div class=\"label-style\">\r\n {{ \"FOLDERS.DESCRIPTION\" | translate }}\r\n </div>\r\n <input\r\n class=\"field-style\"\r\n [(ngModel)]=\"staticForm.description\"\r\n id=\"folderDescription\"\r\n name=\"folderDescription\"\r\n />\r\n </div>\r\n </form>\r\n \r\n <div class=\"dynamic-part -mx-4\" *ngIf=\"dynamicForm && showRenderer\">\r\n <app-dynamic-form\r\n [form]=\"dynamicForm\"\r\n [data]=\"temporaryDyanmicData\"\r\n (change)=\"ondynamicFormChange($event)\"\r\n ></app-dynamic-form>\r\n </div>\r\n </div>\r\n <!-- -->\r\n <!-- actions and buttons -->\r\n <div\r\n class=\"w-full d-flex justify-between absolute bottom-0 actionsBtnWrapper\"\r\n >\r\n <ng-container *ngIf=\"!creating\">\r\n <button\r\n (click)=\"createDocument()\"\r\n [disabled]=\"\r\n !dynamicData.valid || folderForm.invalid || staticForm.title === '..'\r\n \"\r\n [ngClass]=\"{\r\n 'opacity-30 cursor-not-allowed':\r\n !dynamicData.valid ||\r\n folderForm.invalid ||\r\n staticForm.title === '..'\r\n }\"\r\n class=\"submission-button\"\r\n >\r\n {{ \"BUTTONS.CREATE\" | translate }}\r\n </button>\r\n </ng-container>\r\n <span class=\"submission-button\" *ngIf=\"creating\">\r\n <mat-spinner\r\n [value]=\"90\"\r\n [strokeWidth]=\"3\"\r\n overlay=\"true\"\r\n [diameter]=\"25\"\r\n color=\"warn\"\r\n >\r\n </mat-spinner>\r\n </span>\r\n \r\n <button class=\"cancelation-button\" (click)=\"closeDialog()\">\r\n {{ \"BUTTONS.CANCEL\" | translate }}\r\n </button>\r\n </div>\r\n </div>\r\n ", styles: [".folder-wrapper{height:calc(100% - 50px);overflow-y:auto;overflow-x:hidden;padding:0 10px;width:100%}.rtl .actionsBtnWrapper{direction:ltr}.actionsBtnWrapper{direction:rtl}\n"], components: [{ type: i7.DynamicFormComponent, selector: "app-dynamic-form", inputs: ["form", "data", "readOnly"], outputs: ["change"] }, { type: i8.MatSpinner, selector: "mat-spinner", inputs: ["color"] }], directives: [{ type: i9.SetRtlDirective, selector: "[SetRtl]" }, { type: i6.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i6.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i6.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i6.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i10.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i11.TranslatePipe } });
112
+ FolderModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FolderModalComponent, deps: [{ token: MAT_DIALOG_DATA }, { token: i1.MatDialogRef }, { token: i2.FileManagerService }, { token: i3.DynamicFormService }, { token: i4.CustomToastrService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
113
+ FolderModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: FolderModalComponent, selector: "app-folder-modal", host: { listeners: { "document:keyup.enter": "KeyUpEvent($event)" } }, viewQueries: [{ propertyName: "folderForm", first: true, predicate: ["folderForm"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<ndf-nuxeo-dialog dialogTitle=\"{{ 'CREATE.createFolder' | translate }}\">\r\n\t<ng-template #contentTemplate>\r\n\t\t<div\r\n\t\t\tclass=\"create-folder-modal d-flex justify-center w-full relative h-full\"\r\n\t\t>\r\n\t\t\t<div class=\"folder-wrapper\" SetRtl>\r\n\t\t\t\t<div class=\"mb-5\">\r\n\t\t\t\t\t<div class=\"label-style\">\r\n\t\t\t\t\t\t{{ 'FOLDERS.TYPE' | translate }}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t\t<div class=\"text-base text-gray-900\">\r\n\t\t\t\t\t\t{{ isArabic ? folderType.arabicText : folderType.englishText }}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</div>\r\n\t\t\t\t<form #folderForm=\"ngForm\">\r\n\t\t\t\t\t<div class=\"mb-3\">\r\n\t\t\t\t\t\t<div class=\"label-style\">\r\n\t\t\t\t\t\t\t{{ 'FOLDERS.TITLE' | translate }}\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t<input\r\n\t\t\t\t\t\t\tclass=\"field-style\"\r\n\t\t\t\t\t\t\t[ngClass]=\"{ 'border-red-500': staticForm.title === '..' }\"\r\n\t\t\t\t\t\t\trequired\r\n\t\t\t\t\t\t\t[(ngModel)]=\"staticForm.title\"\r\n\t\t\t\t\t\t\tid=\"folderTitle\"\r\n\t\t\t\t\t\t\tname=\"folderTitle\"\r\n\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t<div\r\n\t\t\t\t\t\t\tclass=\"text-red-500 text-base\"\r\n\t\t\t\t\t\t\t*ngIf=\"staticForm.title === '..'\"\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\tInvalid Folder Title\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t\t<div class=\"mb-3\">\r\n\t\t\t\t\t\t<div class=\"label-style\">\r\n\t\t\t\t\t\t\t{{ 'FOLDERS.DESCRIPTION' | translate }}\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t<input\r\n\t\t\t\t\t\t\tclass=\"field-style\"\r\n\t\t\t\t\t\t\t[(ngModel)]=\"staticForm.description\"\r\n\t\t\t\t\t\t\tid=\"folderDescription\"\r\n\t\t\t\t\t\t\tname=\"folderDescription\"\r\n\t\t\t\t\t\t/>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</form>\r\n\r\n\t\t\t\t<div class=\"dynamic-part -mx-4\" *ngIf=\"dynamicForm && showRenderer\">\r\n\t\t\t\t\t<app-dynamic-form\r\n\t\t\t\t\t\t[form]=\"dynamicForm\"\r\n\t\t\t\t\t\t[data]=\"temporaryDyanmicData\"\r\n\t\t\t\t\t\t(change)=\"ondynamicFormChange($event)\"\r\n\t\t\t\t\t></app-dynamic-form>\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t\t<!-- -->\r\n\t\t</div>\r\n\t</ng-template>\r\n\r\n\t<ng-template #actionsTemplate let-dialog=\"dialog\">\r\n\t\t<ng-container *ngIf=\"!creating\">\r\n\t\t\t<button\r\n\t\t\t\tclass=\"submission-button w-44\"\r\n\t\t\t\t(click)=\"dialog.executeAction(createDocument)\"\r\n\t\t\t>\r\n\t\t\t\t{{ 'BUTTONS.CREATE' | translate }}\r\n\t\t\t</button>\r\n\t\t</ng-container>\r\n\t</ng-template>\r\n</ndf-nuxeo-dialog>\r\n", styles: [".folder-wrapper{height:calc(100% - 50px);overflow-y:auto;overflow-x:hidden;padding:0 10px;width:100%}.rtl .actionsBtnWrapper{direction:ltr}.actionsBtnWrapper{direction:rtl}\n"], components: [{ type: i5.NdfNuxeoDialog, selector: "ndf-nuxeo-dialog", inputs: ["dialogTitle", "subTitle", "loaderMode"] }, { type: i6.DynamicFormComponent, selector: "app-dynamic-form", inputs: ["form", "data", "readOnly"], outputs: ["change"] }], directives: [{ type: i7.SetRtlDirective, selector: "[SetRtl]" }, { type: i8.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i8.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i8.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i8.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i9.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i8.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": i10.TranslatePipe } });
112
114
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FolderModalComponent, decorators: [{
113
115
  type: Component,
114
116
  args: [{
@@ -119,11 +121,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
119
121
  }], ctorParameters: function () { return [{ type: undefined, decorators: [{
120
122
  type: Inject,
121
123
  args: [MAT_DIALOG_DATA]
122
- }] }, { type: i1.MatDialogRef }, { type: i2.FileManagerService }, { type: i3.DynamicFormService }, { type: i4.TranslationService }, { type: i5.CustomToastrService }, { type: i6.FormBuilder }]; }, propDecorators: { folderForm: [{
124
+ }] }, { type: i1.MatDialogRef }, { type: i2.FileManagerService }, { type: i3.DynamicFormService }, { type: i4.CustomToastrService }, { type: i0.Injector }]; }, propDecorators: { folderForm: [{
123
125
  type: ViewChild,
124
126
  args: ['folderForm']
125
127
  }], KeyUpEvent: [{
126
128
  type: HostListener,
127
129
  args: ['document:keyup.enter', ['$event']]
128
130
  }] } });
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"folder-modal.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/file-manger/components/folder-modal/folder-modal.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/file-manger/components/folder-modal/folder-modal.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAE,YAAY,EAAE,MAAM,EAAqB,SAAS,EAAE,MAAM,eAAe,CAAC;AAE7G,OAAO,EAAgB,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAGzE,OAAO,EAAE,OAAO,EAAgB,MAAM,MAAM,CAAC;AAC7C,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;;;;;;AAS3C,MAAM,OAAO,oBAAoB;IA8B/B,YAA4C,IAAI,EACxC,SAA8C,EAC9C,iBAAsC,EACtC,kBAAuC,EACvC,kBAAuC,EACvC,aAAmC,EACnC,WAAyB;QANW,SAAI,GAAJ,IAAI,CAAA;QACxC,cAAS,GAAT,SAAS,CAAqC;QAC9C,sBAAiB,GAAjB,iBAAiB,CAAqB;QACtC,uBAAkB,GAAlB,kBAAkB,CAAqB;QACvC,uBAAkB,GAAlB,kBAAkB,CAAqB;QACvC,kBAAa,GAAb,aAAa,CAAsB;QACnC,gBAAW,GAAX,WAAW,CAAc;QAjCjC,yBAAoB,GAAG,EAAE,CAAC;QAC1B,iBAAY,GAAG,KAAK,CAAC;QACrB,gBAAW,GAAG;YACZ,KAAK,EAAG,KAAK;SACd,CAAC;QACF,eAAU,GAAG;YACX,KAAK,EAAG,EAAE;YACV,WAAW,EAAG,EAAE;YAChB,gBAAgB;SACjB,CAAA;QAED,WAAM,GAAC,EAAE,CAAC;QACV,YAAO,GAAC,EAAE,CAAC;QACX,aAAQ,GAAC,GAAG,CAAC;QAGb,aAAQ,GAAG,KAAK,CAAC;QACT,oBAAe,GAAiB,IAAI,OAAO,EAAO,CAAC;QAC3D,gBAAW,GAAG,KAAK,CAAC;QACpB,aAAQ,GAAG,KAAK,CAAC;IAcoB,CAAC;IAXtC,UAAU,CAAC,KAAoB;QAC7B,IAAG,IAAI,CAAC,WAAW,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,IAAI,IAAI,CAAC,UAAU,CAAC,KAAK,IAAI,IAAI,EAAE;YACtF,IAAI,CAAC,cAAc,EAAE,CAAC;SACvB;IACH,CAAC;IASD,QAAQ;QACN,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YACrF,IAAI,CAAC,QAAQ,GAAG,GAAG,CAAC;QACtB,CAAC,CAAC,CAAA;QACF,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC;QACvC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC;QACzC,IAAI,CAAC,iBAAiB,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE;YAC9E,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;gBACjB,IAAG,IAAI,CAAC,IAAI,KAAK,WAAW,EAAC;oBAC3B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;iBACzB;YACH,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;IACH,CAAC;IACF,eAAe;QACb,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;IAC3B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,CAAC;QAC5B,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;IAClC,CAAC;IACD,mBAAmB,CAAC,WAAW;QAC7B,IAAI,WAAW,CAAC,IAAI,EAAE;YACpB,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,CAAA;YAC7B,IAAI,CAAC,WAAW,qBAAQ,WAAW,CAAE,CAAC;SACvC;IACH,CAAC;IACD,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,EAAG,IAAI,CAAC,UAAU,CAAC,CAAC;QAC/E,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,MAAM,EAAG,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE;YACpG,mBAAmB;YACnB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;YACtB,IAAI,CAAC,iBAAiB,CAAC,sBAAsB,CAAC,IAAI,EAAE,CAAC;YACrD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,EAAE,iBAAiB,EAAE,8BAA8B,CAAC,CAAC;YACtF,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,CAAC,CAAC,CAAA;IAEJ,CAAC;IAED,gBAAgB,CAAC,aAAa,EAAG,UAAU;QACvC,+DAA+D;QAC/D,IAAI,KAAK,GAAG,IAAI,CAAC,kBAAkB,CAAC,2BAA2B,CAAC,aAAa,EAAG,IAAI,CAAC,WAAW,CAAC,CAAC;QAClG,IAAI,KAAK,GAAG;YACV,UAAU,EAAE;gBACV,MAAM,EAAE,IAAI,CAAC,UAAU,CAAC,IAAI;gBAC5B,MAAM,EAAE,UAAU,CAAC,KAAK;gBACxB,YAAY,kCACP,KAAK,KACR,gBAAgB,EAAE,UAAU,CAAC,WAAW,EACxC,UAAU,EAAE,UAAU,CAAC,KAAK,GAC7B;aACF;SACF,CAAC;QACF,IAAG,IAAI,CAAC,UAAU,CAAC,YAAY,IAAI,IAAI,CAAC,WAAW,EAAC;YACnD,KAAK,CAAC,kBAAkB,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC;YACzD,KAAK,CAAC,UAAU,CAAC,CAAC,YAAY,CAAC,CAAC,4BAA4B,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC;SAC7F;QACD,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,QAAQ,CAAC,IAAI;QACX,oBAAoB;IACtB,CAAC;;kHA1GU,oBAAoB,kBA8BX,eAAe;sGA9BxB,oBAAoB,yOCfjC,o7FAsFE;4FDvEW,oBAAoB;kBALhC,SAAS;mBAAC;oBACT,QAAQ,EAAE,kBAAkB;oBAC5B,WAAW,EAAE,+BAA+B;oBAC5C,SAAS,EAAE,CAAC,+BAA+B,CAAC;iBAC7C;;0BA+Bc,MAAM;2BAAC,eAAe;sOAPV,UAAU;sBAAlC,SAAS;uBAAC,YAAY;gBAEvB,UAAU;sBADT,YAAY;uBAAC,sBAAsB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { AfterViewInit, Component, HostListener, Inject, OnDestroy, OnInit, ViewChild } from '@angular/core';\r\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\r\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { DynamicFormService } from '../../../../shared-services/dynamic-form.service';\r\nimport { FileManagerService } from '../../../../shared-services/file-manager.service';\r\nimport { Subject, Subscription } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { TranslationService } from '../../../../core/services/translation/translation.service';\r\nimport { CustomToastrService } from '../../../custom-toastr/services/custom-toastr.service';\r\n\r\n@Component({\r\n  selector: 'app-folder-modal',\r\n  templateUrl: './folder-modal.component.html',\r\n  styleUrls: ['./folder-modal.component.scss']\r\n})\r\nexport class FolderModalComponent implements OnInit , AfterViewInit , OnDestroy {\r\n  folderType;\r\n  dynamicForm;\r\n  temporaryDyanmicData = {};\r\n  showRenderer = false;\r\n  dynamicData = {\r\n    valid : false\r\n  };\r\n  staticForm = {\r\n    title : '',\r\n    description : '',\r\n    // department:''\r\n  }\r\n\r\n  filter={};\r\n  filter2={};\r\n  parentId='2';\r\n  childId;\r\n  testingForm : FormGroup;\r\n  isArabic = false;\r\n  private _unsubscribeAll: Subject<any> = new Subject<any>();\r\n  isDmsFolder = false;\r\n  creating = false;\r\n  @ViewChild('folderForm') folderForm: FormGroup;\r\n  @HostListener('document:keyup.enter', ['$event'])\r\n  KeyUpEvent(event: KeyboardEvent) {\r\n    if(this.dynamicData.valid && !this.folderForm.invalid && this.staticForm.title != '..') {\r\n      this.createDocument();\r\n    }\r\n  }\r\n  constructor(@Inject(MAT_DIALOG_DATA) public data , \r\n  private dialogRef : MatDialogRef<FolderModalComponent>,\r\n  private fileMangerService : FileManagerService,\r\n  private dynamicFormService : DynamicFormService,\r\n  private translationService : TranslationService,\r\n  private tosterService : CustomToastrService,\r\n  private formBuilder : FormBuilder) { }\r\n\r\n  ngOnInit(): void {\r\n    this.translationService.isArabic.pipe(takeUntil(this._unsubscribeAll)).subscribe(res => {\r\n      this.isArabic = res;\r\n    })\r\n    this.folderType = this.data.folderType;\r\n    this.dynamicForm = this.data.dynamicForm;\r\n    this.fileMangerService.getFileSchemas(this.folderType.type).subscribe(schemas => {\r\n      schemas.map(item => {\r\n        if(item.name === \"dmsfolder\"){\r\n          this.isDmsFolder = true;\r\n        }\r\n      })\r\n    })\r\n   }\r\n  ngAfterViewInit(){\r\n    this.showRenderer = true;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._unsubscribeAll.next();\r\n    this._unsubscribeAll.complete();\r\n  }\r\n  ondynamicFormChange(dynamicData) {\r\n    if (dynamicData.data) {\r\n      console.log(dynamicData.data)\r\n      this.dynamicData = { ...dynamicData };\r\n    }\r\n  }\r\n  closeDialog() {\r\n    this.dialogRef.close(false);\r\n  }\r\n\r\n  createDocument() {\r\n    this.creating = true;\r\n    let params = this.constructPayLoad(this.dynamicData['data'] , this.staticForm);\r\n    this.fileMangerService.createFolder(params , this.fileMangerService.selectedFolderId).subscribe(res =>{\r\n      //console.log(res);\r\n      this.creating = false;\r\n      this.fileMangerService.onRefreshingFileManger.next();\r\n      this.tosterService.show('success', 'TOASTER.SUCCESS', \"TOASTER.FOLDER_CREATED_SUCCE\");\r\n      this.closeDialog();\r\n    })\r\n\r\n  }\r\n\r\n  constructPayLoad(dynamicValues , staticForm) {\r\n      // let props = this.constructDynamicFormPayload(dynamicValues);\r\n      let props = this.dynamicFormService.constructDynamicFormPayload(dynamicValues , this.dynamicForm);\r\n      let param = {\r\n        \"document\": {\r\n          \"type\": this.folderType.type,\r\n          \"name\": staticForm.title,\r\n          \"properties\": {\r\n            ...props,\r\n            \"dc:description\": staticForm.description,\r\n            \"dc:title\": staticForm.title,\r\n          }\r\n        }\r\n      };\r\n      if(this.folderType.documentCode && this.isDmsFolder){\r\n       param[\"documentTypeCode\"] = this.folderType.documentCode;\r\n       param['document']['properties']['dmsfolder:documentTypeCode'] = this.folderType.documentCode;\r\n      }\r\n      return param;\r\n  }\r\n\r\n  changing(data){\r\n    //console.log(data);\r\n  }\r\n}\r\n\r\n","<div class=\"create-folder-modal d-flex justify-center w-full relative h-full\">\r\n    <div class=\"folder-wrapper\" SetRtl>\r\n      <div class=\"mb-5\">\r\n        <div class=\"label-style\">\r\n          {{ \"FOLDERS.TYPE\" | translate }}\r\n        </div>\r\n        <div class=\"text-base text-gray-900\">\r\n          {{ isArabic ? folderType.arabicText : folderType.englishText }}\r\n        </div>\r\n      </div>\r\n      <form #folderForm=\"ngForm\">\r\n        <div class=\"mb-3\">\r\n          <div class=\"label-style\">\r\n            {{ \"FOLDERS.TITLE\" | translate }}\r\n          </div>\r\n          <input\r\n            class=\"field-style\"\r\n            [ngClass]=\"{ 'border-red-500': staticForm.title === '..' }\"\r\n            required\r\n            [(ngModel)]=\"staticForm.title\"\r\n            id=\"folderTitle\"\r\n            name=\"folderTitle\"\r\n          />\r\n          <div class=\"text-red-500 text-base\" *ngIf=\"staticForm.title === '..'\">\r\n            Invalid Folder Title\r\n          </div>\r\n        </div>\r\n        <div class=\"mb-3\">\r\n          <div class=\"label-style\">\r\n            {{ \"FOLDERS.DESCRIPTION\" | translate }}\r\n          </div>\r\n          <input\r\n            class=\"field-style\"\r\n            [(ngModel)]=\"staticForm.description\"\r\n            id=\"folderDescription\"\r\n            name=\"folderDescription\"\r\n          />\r\n        </div>\r\n      </form>\r\n  \r\n      <div class=\"dynamic-part -mx-4\" *ngIf=\"dynamicForm && showRenderer\">\r\n        <app-dynamic-form\r\n          [form]=\"dynamicForm\"\r\n          [data]=\"temporaryDyanmicData\"\r\n          (change)=\"ondynamicFormChange($event)\"\r\n        ></app-dynamic-form>\r\n      </div>\r\n    </div>\r\n    <!--  -->\r\n    <!-- actions and buttons  -->\r\n    <div\r\n      class=\"w-full d-flex justify-between absolute bottom-0 actionsBtnWrapper\"\r\n    >\r\n      <ng-container *ngIf=\"!creating\">\r\n        <button\r\n          (click)=\"createDocument()\"\r\n          [disabled]=\"\r\n            !dynamicData.valid || folderForm.invalid || staticForm.title === '..'\r\n          \"\r\n          [ngClass]=\"{\r\n            'opacity-30 cursor-not-allowed':\r\n              !dynamicData.valid ||\r\n              folderForm.invalid ||\r\n              staticForm.title === '..'\r\n          }\"\r\n          class=\"submission-button\"\r\n        >\r\n          {{ \"BUTTONS.CREATE\" | translate }}\r\n        </button>\r\n      </ng-container>\r\n      <span class=\"submission-button\" *ngIf=\"creating\">\r\n        <mat-spinner\r\n          [value]=\"90\"\r\n          [strokeWidth]=\"3\"\r\n          overlay=\"true\"\r\n          [diameter]=\"25\"\r\n          color=\"warn\"\r\n        >\r\n        </mat-spinner>\r\n      </span>\r\n  \r\n      <button class=\"cancelation-button\" (click)=\"closeDialog()\">\r\n        {{ \"BUTTONS.CANCEL\" | translate }}\r\n      </button>\r\n    </div>\r\n  </div>\r\n  "]}
131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"folder-modal.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/file-manger/components/folder-modal/folder-modal.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/file-manger/components/folder-modal/folder-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n\tAfterViewInit,\r\n\tComponent,\r\n\tHostListener,\r\n\tInject,\r\n\tInjector,\r\n\tOnDestroy,\r\n\tOnInit,\r\n\tViewChild\r\n} from '@angular/core';\r\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\r\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { DynamicFormService } from '../../../../shared-services/dynamic-form.service';\r\nimport { FileManagerService } from '../../../../shared-services/file-manager.service';\r\nimport { Subject, Subscription } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { TranslationService } from '../../../../core/services/translation/translation.service';\r\nimport { CustomToastrService } from '../../../custom-toastr/services/custom-toastr.service';\r\nimport { BaseDialogComponent } from '../../../../shared/components/base/base-dialog.component';\r\nimport { DialogActionType } from '../../../../shared/components/nuxeo-dialog/models/dialog-option.model';\r\nimport { tap } from 'rxjs/operators';\r\n\r\n@Component({\r\n\tselector: 'app-folder-modal',\r\n\ttemplateUrl: './folder-modal.component.html',\r\n\tstyleUrls: ['./folder-modal.component.scss']\r\n})\r\nexport class FolderModalComponent\r\n\textends BaseDialogComponent<FolderModalComponent, any, any>\r\n\timplements OnInit, AfterViewInit, OnDestroy\r\n{\r\n\tfolderType;\r\n\tdynamicForm;\r\n\ttemporaryDyanmicData = {};\r\n\tshowRenderer = false;\r\n\tdynamicData = {\r\n\t\tvalid: false\r\n\t};\r\n\tstaticForm = {\r\n\t\ttitle: '',\r\n\t\tdescription: ''\r\n\t\t// department:''\r\n\t};\r\n\r\n\tfilter = {};\r\n\tfilter2 = {};\r\n\tparentId = '2';\r\n\tchildId;\r\n\ttestingForm: FormGroup;\r\n\tprivate _unsubscribeAll: Subject<any> = new Subject<any>();\r\n\tisDmsFolder = false;\r\n\tcreating = false;\r\n\t@ViewChild('folderForm') folderForm: FormGroup;\r\n\t@HostListener('document:keyup.enter', ['$event'])\r\n\tKeyUpEvent(event: KeyboardEvent) {\r\n\t\tif (\r\n\t\t\tthis.dynamicData.valid &&\r\n\t\t\t!this.folderForm.invalid &&\r\n\t\t\tthis.staticForm.title != '..'\r\n\t\t) {\r\n\t\t\tthis.createDocument();\r\n\t\t}\r\n\t}\r\n\tconstructor(\r\n\t\t@Inject(MAT_DIALOG_DATA) public data,\r\n\t\tprivate dialogRef: MatDialogRef<FolderModalComponent>,\r\n\t\tprivate fileMangerService: FileManagerService,\r\n\t\tprivate dynamicFormService: DynamicFormService,\r\n\t\tprivate tosterService: CustomToastrService,\r\n\t\tinjector: Injector\r\n\t) {\r\n\t\tsuper(injector);\r\n\t}\r\n\r\n\tngOnInit(): void {\r\n\t\tthis.folderType = this.data.folderType;\r\n\t\tthis.dynamicForm = this.data.dynamicForm;\r\n\t\tthis.fileMangerService\r\n\t\t\t.getFileSchemas(this.folderType.type)\r\n\t\t\t.subscribe((schemas) => {\r\n\t\t\t\tschemas.map((item) => {\r\n\t\t\t\t\tif (item.name === 'dmsfolder') {\r\n\t\t\t\t\t\tthis.isDmsFolder = true;\r\n\t\t\t\t\t}\r\n\t\t\t\t});\r\n\t\t\t});\r\n\t}\r\n\tngAfterViewInit() {\r\n\t\tthis.showRenderer = true;\r\n\t}\r\n\r\n\tngOnDestroy(): void {\r\n\t\tthis._unsubscribeAll.next();\r\n\t\tthis._unsubscribeAll.complete();\r\n\t}\r\n\tondynamicFormChange(dynamicData) {\r\n\t\tif (dynamicData.data) {\r\n\t\t\tconsole.log(dynamicData.data);\r\n\t\t\tthis.dynamicData = { ...dynamicData };\r\n\t\t}\r\n\t}\r\n\tcloseDialog() {\r\n\t\tthis.dialogRef.close(false);\r\n\t}\r\n\r\n\tcreateDocument: DialogActionType = () => {\r\n\t\tthis.creating = true;\r\n\t\tlet params = this.constructPayLoad(\r\n\t\t\tthis.dynamicData['data'],\r\n\t\t\tthis.staticForm\r\n\t\t);\r\n\t\treturn this.fileMangerService\r\n\t\t\t.createFolder(params, this.fileMangerService.selectedFolderId)\r\n\r\n\t\t\t.pipe(\r\n\t\t\t\ttap((res) => {\r\n\t\t\t\t\t//console.log(res);\r\n\t\t\t\t\tthis.creating = false;\r\n\t\t\t\t\tthis.fileMangerService.onRefreshingFileManger.next();\r\n\t\t\t\t\tthis.tosterService.show(\r\n\t\t\t\t\t\t'success',\r\n\t\t\t\t\t\t'TOASTER.SUCCESS',\r\n\t\t\t\t\t\t'TOASTER.FOLDER_CREATED_SUCCE'\r\n\t\t\t\t\t);\r\n\t\t\t\t\tthis.closeDialog();\r\n\t\t\t\t})\r\n\t\t\t);\r\n\t};\r\n\r\n\tconstructPayLoad(dynamicValues, staticForm) {\r\n\t\t// let props = this.constructDynamicFormPayload(dynamicValues);\r\n\t\tlet props = this.dynamicFormService.constructDynamicFormPayload(\r\n\t\t\tdynamicValues,\r\n\t\t\tthis.dynamicForm\r\n\t\t);\r\n\t\tlet param = {\r\n\t\t\tdocument: {\r\n\t\t\t\ttype: this.folderType.type,\r\n\t\t\t\tname: staticForm.title,\r\n\t\t\t\tproperties: {\r\n\t\t\t\t\t...props,\r\n\t\t\t\t\t'dc:description': staticForm.description,\r\n\t\t\t\t\t'dc:title': staticForm.title\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t};\r\n\t\tif (this.folderType.documentCode && this.isDmsFolder) {\r\n\t\t\tparam['documentTypeCode'] = this.folderType.documentCode;\r\n\t\t\tparam['document']['properties']['dmsfolder:documentTypeCode'] =\r\n\t\t\t\tthis.folderType.documentCode;\r\n\t\t}\r\n\t\treturn param;\r\n\t}\r\n\r\n\tchanging(data) {\r\n\t\t//console.log(data);\r\n\t}\r\n}\r\n","<ndf-nuxeo-dialog dialogTitle=\"{{ 'CREATE.createFolder' | translate }}\">\r\n\t<ng-template #contentTemplate>\r\n\t\t<div\r\n\t\t\tclass=\"create-folder-modal d-flex justify-center w-full relative h-full\"\r\n\t\t>\r\n\t\t\t<div class=\"folder-wrapper\" SetRtl>\r\n\t\t\t\t<div class=\"mb-5\">\r\n\t\t\t\t\t<div class=\"label-style\">\r\n\t\t\t\t\t\t{{ 'FOLDERS.TYPE' | translate }}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t\t<div class=\"text-base text-gray-900\">\r\n\t\t\t\t\t\t{{ isArabic ? folderType.arabicText : folderType.englishText }}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</div>\r\n\t\t\t\t<form #folderForm=\"ngForm\">\r\n\t\t\t\t\t<div class=\"mb-3\">\r\n\t\t\t\t\t\t<div class=\"label-style\">\r\n\t\t\t\t\t\t\t{{ 'FOLDERS.TITLE' | translate }}\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t<input\r\n\t\t\t\t\t\t\tclass=\"field-style\"\r\n\t\t\t\t\t\t\t[ngClass]=\"{ 'border-red-500': staticForm.title === '..' }\"\r\n\t\t\t\t\t\t\trequired\r\n\t\t\t\t\t\t\t[(ngModel)]=\"staticForm.title\"\r\n\t\t\t\t\t\t\tid=\"folderTitle\"\r\n\t\t\t\t\t\t\tname=\"folderTitle\"\r\n\t\t\t\t\t\t/>\r\n\t\t\t\t\t\t<div\r\n\t\t\t\t\t\t\tclass=\"text-red-500 text-base\"\r\n\t\t\t\t\t\t\t*ngIf=\"staticForm.title === '..'\"\r\n\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\tInvalid Folder Title\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t\t<div class=\"mb-3\">\r\n\t\t\t\t\t\t<div class=\"label-style\">\r\n\t\t\t\t\t\t\t{{ 'FOLDERS.DESCRIPTION' | translate }}\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t<input\r\n\t\t\t\t\t\t\tclass=\"field-style\"\r\n\t\t\t\t\t\t\t[(ngModel)]=\"staticForm.description\"\r\n\t\t\t\t\t\t\tid=\"folderDescription\"\r\n\t\t\t\t\t\t\tname=\"folderDescription\"\r\n\t\t\t\t\t\t/>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</form>\r\n\r\n\t\t\t\t<div class=\"dynamic-part -mx-4\" *ngIf=\"dynamicForm && showRenderer\">\r\n\t\t\t\t\t<app-dynamic-form\r\n\t\t\t\t\t\t[form]=\"dynamicForm\"\r\n\t\t\t\t\t\t[data]=\"temporaryDyanmicData\"\r\n\t\t\t\t\t\t(change)=\"ondynamicFormChange($event)\"\r\n\t\t\t\t\t></app-dynamic-form>\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t\t<!--  -->\r\n\t\t</div>\r\n\t</ng-template>\r\n\r\n\t<ng-template #actionsTemplate let-dialog=\"dialog\">\r\n\t\t<ng-container *ngIf=\"!creating\">\r\n\t\t\t<button\r\n\t\t\t\tclass=\"submission-button w-44\"\r\n\t\t\t\t(click)=\"dialog.executeAction(createDocument)\"\r\n\t\t\t>\r\n\t\t\t\t{{ 'BUTTONS.CREATE' | translate }}\r\n\t\t\t</button>\r\n\t\t</ng-container>\r\n\t</ng-template>\r\n</ndf-nuxeo-dialog>\r\n"]}