nuxeo-development-framework 4.1.1 → 4.1.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/nuxeo-development-framework.umd.js +1521 -1053
- package/bundles/nuxeo-development-framework.umd.js.map +1 -1
- package/esm2015/lib/components/diagrams/components/circle-node/circle-node.component.js +6 -7
- package/esm2015/lib/components/diagrams/components/connection-label.component.js +92 -0
- package/esm2015/lib/components/diagrams/components/content-node/content-node.component.js +7 -8
- package/esm2015/lib/components/diagrams/components/custom-connection.component.js +68 -32
- package/esm2015/lib/components/diagrams/components/custom-socket.component.js +22 -19
- package/esm2015/lib/components/diagrams/components/gateway-node/gateway-node.component.js +18 -0
- package/esm2015/lib/components/diagrams/components/gateway-ports.component.js +118 -0
- package/esm2015/lib/components/diagrams/components/index.js +5 -1
- package/esm2015/lib/components/diagrams/components/node-inputs.component.js +34 -35
- package/esm2015/lib/components/diagrams/components/node-outputs.component.js +30 -31
- package/esm2015/lib/components/diagrams/components/node-ports.component.js +98 -0
- package/esm2015/lib/components/diagrams/components/remove-button.component.js +46 -43
- package/esm2015/lib/components/diagrams/components/template-node/template-node.component.js +6 -7
- package/esm2015/lib/components/diagrams/constants/node-type.js +2 -1
- package/esm2015/lib/components/diagrams/constants/sizes.js +2 -1
- package/esm2015/lib/components/diagrams/constants/status.js +4 -1
- package/esm2015/lib/components/diagrams/diagrams.module.js +14 -6
- package/esm2015/lib/components/diagrams/directive/diagram.directive.js +9 -6
- package/esm2015/lib/components/diagrams/editor/customize.js +16 -12
- package/esm2015/lib/components/diagrams/editor/editor.js +21 -19
- package/esm2015/lib/components/diagrams/editor/overrides/connection-path.transformers.js +32 -7
- package/esm2015/lib/components/diagrams/editor/path-plugin.js +10 -9
- package/esm2015/lib/components/diagrams/models/base-node.model.js +3 -2
- package/esm2015/lib/components/diagrams/models/connection.model.js +11 -4
- package/esm2015/lib/components/diagrams/models/gate-way.model.js +11 -0
- package/esm2015/lib/components/diagrams/models/index.js +2 -1
- package/esm2015/lib/components/diagrams/models/ports.model.js +14 -0
- package/esm2015/lib/components/diagrams/models/socket.model.js +5 -4
- package/esm2015/lib/components/diagrams/services/diagram.service.js +77 -29
- package/esm2015/lib/components/diagrams/services/workflow.service.js +14 -19
- package/esm2015/lib/components/diagrams/types/common.type.js +1 -1
- package/esm2015/lib/components/diagrams/types/connection-config.type.js +2 -0
- package/esm2015/lib/components/diagrams/types/connection-label.type.js +2 -0
- package/esm2015/lib/components/diagrams/types/diagram-config.type.js +1 -1
- package/esm2015/lib/components/diagrams/types/diagram-editor.type.js +1 -1
- package/esm2015/lib/components/diagrams/types/index.js +6 -2
- package/esm2015/lib/components/diagrams/types/node-definition.js +1 -1
- package/esm2015/lib/components/diagrams/types/path.type.js +1 -1
- package/esm2015/lib/components/diagrams/types/ports-config.type.js +2 -0
- package/esm2015/lib/components/diagrams/types/socket.type.js +2 -0
- package/esm2015/lib/components/diagrams/utilities/common.js +35 -0
- package/esm2015/lib/components/diagrams/utilities/index.js +3 -1
- package/esm2015/lib/components/diagrams/utilities/random.js +11 -0
- package/esm2015/lib/components/diagrams/utilities/remove.util.js +2 -2
- package/esm2015/lib/components/file-manger/components/copy/copy.component.js +65 -36
- package/esm2015/lib/components/file-manger/components/create-directory/create-directory.component.js +39 -13
- package/esm2015/lib/components/file-manger/components/folder-modal/folder-modal.component.js +45 -43
- package/esm2015/lib/components/file-manger/components/move/move.component.js +60 -31
- package/fesm2015/nuxeo-development-framework.js +1269 -675
- package/fesm2015/nuxeo-development-framework.js.map +1 -1
- package/lib/components/diagrams/components/base-node.component.d.ts +1 -0
- package/lib/components/diagrams/components/connection-label.component.d.ts +19 -0
- package/lib/components/diagrams/components/custom-connection.component.d.ts +5 -0
- package/lib/components/diagrams/components/gateway-node/gateway-node.component.d.ts +6 -0
- package/lib/components/diagrams/components/gateway-ports.component.d.ts +12 -0
- package/lib/components/diagrams/components/index.d.ts +4 -0
- package/lib/components/diagrams/components/node-ports.component.d.ts +13 -0
- package/lib/components/diagrams/constants/node-type.d.ts +1 -0
- package/lib/components/diagrams/constants/sizes.d.ts +1 -0
- package/lib/components/diagrams/constants/status.d.ts +3 -0
- package/lib/components/diagrams/diagrams.module.d.ts +12 -8
- package/lib/components/diagrams/editor/overrides/connection-path.transformers.d.ts +2 -7
- package/lib/components/diagrams/models/base-node.model.d.ts +3 -2
- package/lib/components/diagrams/models/connection.model.d.ts +9 -1
- package/lib/components/diagrams/models/gate-way.model.d.ts +8 -0
- package/lib/components/diagrams/models/index.d.ts +1 -0
- package/lib/components/diagrams/models/ports.model.d.ts +11 -0
- package/lib/components/diagrams/models/socket.model.d.ts +3 -1
- package/lib/components/diagrams/services/diagram.service.d.ts +20 -9
- package/lib/components/diagrams/services/workflow.service.d.ts +0 -1
- package/lib/components/diagrams/types/common.type.d.ts +5 -0
- package/lib/components/diagrams/types/connection-config.type.d.ts +11 -0
- package/lib/components/diagrams/types/connection-label.type.d.ts +4 -0
- package/lib/components/diagrams/types/diagram-config.type.d.ts +6 -0
- package/lib/components/diagrams/types/diagram-editor.type.d.ts +3 -2
- package/lib/components/diagrams/types/index.d.ts +5 -1
- package/lib/components/diagrams/types/node-definition.d.ts +1 -0
- package/lib/components/diagrams/types/path.type.d.ts +1 -0
- package/lib/components/diagrams/types/ports-config.type.d.ts +11 -0
- package/lib/components/diagrams/types/socket.type.d.ts +5 -0
- package/lib/components/diagrams/utilities/common.d.ts +19 -0
- package/lib/components/diagrams/utilities/index.d.ts +2 -0
- package/lib/components/diagrams/utilities/random.d.ts +1 -0
- package/lib/components/diagrams/utilities/remove.util.d.ts +1 -1
- package/lib/components/file-manger/components/copy/copy.component.d.ts +11 -4
- package/lib/components/file-manger/components/create-directory/create-directory.component.d.ts +9 -4
- package/lib/components/file-manger/components/folder-modal/folder-modal.component.d.ts +9 -11
- package/lib/components/file-manger/components/move/move.component.d.ts +11 -4
- package/package.json +1 -1
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
export class DiagramUtils {
|
|
2
|
+
static createInputId(id, type = 'primary') {
|
|
3
|
+
return `${id}-${type}-input`;
|
|
4
|
+
}
|
|
5
|
+
static createOutputId(id, type = 'primary') {
|
|
6
|
+
return `${id}-${type}-output`;
|
|
7
|
+
}
|
|
8
|
+
static createInputClass(type = 'primary') {
|
|
9
|
+
return `input-${type}-port`;
|
|
10
|
+
}
|
|
11
|
+
static createOutputClass(type = 'primary') {
|
|
12
|
+
return `output-${type}-port`;
|
|
13
|
+
}
|
|
14
|
+
static createOutputsConfig(id, types) {
|
|
15
|
+
return types.map((type) => {
|
|
16
|
+
return {
|
|
17
|
+
id: DiagramUtils.createOutputId(id, type),
|
|
18
|
+
config: {
|
|
19
|
+
styleClass: DiagramUtils.createOutputClass(type)
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
static createInputsConfig(id, types) {
|
|
25
|
+
return types.map((type) => {
|
|
26
|
+
return {
|
|
27
|
+
id: DiagramUtils.createInputId(id, type),
|
|
28
|
+
config: {
|
|
29
|
+
styleClass: DiagramUtils.createInputClass(type)
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9kaWFncmFtcy91dGlsaXRpZXMvY29tbW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sT0FBTyxZQUFZO0lBRXhCLE1BQU0sQ0FBQyxhQUFhLENBQUMsRUFBVSxFQUFFLE9BQWlCLFNBQVM7UUFDMUQsT0FBTyxHQUFHLEVBQUUsSUFBSSxJQUFJLFFBQVEsQ0FBQztJQUM5QixDQUFDO0lBRUQsTUFBTSxDQUFDLGNBQWMsQ0FBQyxFQUFVLEVBQUUsT0FBaUIsU0FBUztRQUMzRCxPQUFPLEdBQUcsRUFBRSxJQUFJLElBQUksU0FBUyxDQUFDO0lBQy9CLENBQUM7SUFFRCxNQUFNLENBQUMsZ0JBQWdCLENBQUMsT0FBaUIsU0FBUztRQUNqRCxPQUFPLFNBQVMsSUFBSSxPQUFPLENBQUM7SUFDN0IsQ0FBQztJQUVELE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxPQUFpQixTQUFTO1FBQ2xELE9BQU8sVUFBVSxJQUFJLE9BQU8sQ0FBQztJQUM5QixDQUFDO0lBRUQsTUFBTSxDQUFDLG1CQUFtQixDQUFDLEVBQVUsRUFBRSxLQUFpQjtRQUN2RCxPQUFPLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRTtZQUN6QixPQUFPO2dCQUNOLEVBQUUsRUFBRSxZQUFZLENBQUMsY0FBYyxDQUFDLEVBQUUsRUFBRSxJQUFJLENBQUM7Z0JBQ3pDLE1BQU0sRUFBRTtvQkFDUCxVQUFVLEVBQUUsWUFBWSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQztpQkFDaEQ7YUFDRCxDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7SUFDSixDQUFDO0lBRUQsTUFBTSxDQUFDLGtCQUFrQixDQUFDLEVBQVUsRUFBRSxLQUFpQjtRQUN0RCxPQUFPLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRTtZQUN6QixPQUFPO2dCQUNOLEVBQUUsRUFBRSxZQUFZLENBQUMsYUFBYSxDQUFDLEVBQUUsRUFBRSxJQUFJLENBQUM7Z0JBQ3hDLE1BQU0sRUFBRTtvQkFDUCxVQUFVLEVBQUUsWUFBWSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQztpQkFDL0M7YUFDRCxDQUFDO1FBQ0gsQ0FBQyxDQUFDLENBQUM7SUFDSixDQUFDO0NBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQb3J0VHlwZSB9IGZyb20gJy4uL3R5cGVzJztcclxuXHJcbmV4cG9ydCBjbGFzcyBEaWFncmFtVXRpbHMge1xyXG5cclxuXHRzdGF0aWMgY3JlYXRlSW5wdXRJZChpZDogc3RyaW5nLCB0eXBlOiBQb3J0VHlwZSA9ICdwcmltYXJ5Jykge1xyXG5cdFx0cmV0dXJuIGAke2lkfS0ke3R5cGV9LWlucHV0YDtcclxuXHR9XHJcblxyXG5cdHN0YXRpYyBjcmVhdGVPdXRwdXRJZChpZDogc3RyaW5nLCB0eXBlOiBQb3J0VHlwZSA9ICdwcmltYXJ5Jykge1xyXG5cdFx0cmV0dXJuIGAke2lkfS0ke3R5cGV9LW91dHB1dGA7XHJcblx0fVxyXG5cclxuXHRzdGF0aWMgY3JlYXRlSW5wdXRDbGFzcyh0eXBlOiBQb3J0VHlwZSA9ICdwcmltYXJ5Jykge1xyXG5cdFx0cmV0dXJuIGBpbnB1dC0ke3R5cGV9LXBvcnRgO1xyXG5cdH1cclxuXHJcblx0c3RhdGljIGNyZWF0ZU91dHB1dENsYXNzKHR5cGU6IFBvcnRUeXBlID0gJ3ByaW1hcnknKSB7XHJcblx0XHRyZXR1cm4gYG91dHB1dC0ke3R5cGV9LXBvcnRgO1xyXG5cdH1cclxuXHJcblx0c3RhdGljIGNyZWF0ZU91dHB1dHNDb25maWcoaWQ6IHN0cmluZywgdHlwZXM6IFBvcnRUeXBlW10pIHtcclxuXHRcdHJldHVybiB0eXBlcy5tYXAoKHR5cGUpID0+IHtcclxuXHRcdFx0cmV0dXJuIHtcclxuXHRcdFx0XHRpZDogRGlhZ3JhbVV0aWxzLmNyZWF0ZU91dHB1dElkKGlkLCB0eXBlKSxcclxuXHRcdFx0XHRjb25maWc6IHtcclxuXHRcdFx0XHRcdHN0eWxlQ2xhc3M6IERpYWdyYW1VdGlscy5jcmVhdGVPdXRwdXRDbGFzcyh0eXBlKVxyXG5cdFx0XHRcdH1cclxuXHRcdFx0fTtcclxuXHRcdH0pO1xyXG5cdH1cclxuXHJcblx0c3RhdGljIGNyZWF0ZUlucHV0c0NvbmZpZyhpZDogc3RyaW5nLCB0eXBlczogUG9ydFR5cGVbXSkge1xyXG5cdFx0cmV0dXJuIHR5cGVzLm1hcCgodHlwZSkgPT4ge1xyXG5cdFx0XHRyZXR1cm4ge1xyXG5cdFx0XHRcdGlkOiBEaWFncmFtVXRpbHMuY3JlYXRlSW5wdXRJZChpZCwgdHlwZSksXHJcblx0XHRcdFx0Y29uZmlnOiB7XHJcblx0XHRcdFx0XHRzdHlsZUNsYXNzOiBEaWFncmFtVXRpbHMuY3JlYXRlSW5wdXRDbGFzcyh0eXBlKVxyXG5cdFx0XHRcdH1cclxuXHRcdFx0fTtcclxuXHRcdH0pO1xyXG5cdH1cclxufVxyXG4iXX0=
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
export * from './common';
|
|
2
|
+
export * from './random';
|
|
1
3
|
export * from './remove.util';
|
|
2
4
|
export * from './serialize';
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9udXhlby1kZXZlbG9wbWVudC1mcmFtZXdvcmsvc3JjL2xpYi9jb21wb25lbnRzL2RpYWdyYW1zL3V0aWxpdGllcy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGFBQWEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29tbW9uJztcclxuZXhwb3J0ICogZnJvbSAnLi9yYW5kb20nO1xyXG5leHBvcnQgKiBmcm9tICcuL3JlbW92ZS51dGlsJztcclxuZXhwb3J0ICogZnJvbSAnLi9zZXJpYWxpemUnO1xyXG4iXX0=
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export function getRandomNumber(x, y, step = 1, min = 0, max = 1000) {
|
|
2
|
+
// Create a deterministic seed based on x and y
|
|
3
|
+
const seed = Math.abs(x * 31 + y * 17) % 100000;
|
|
4
|
+
// Generate a pseudo-random number based on the seed
|
|
5
|
+
const seededRandom = ((seed * 9301 + 49297) % 233280) / 233280;
|
|
6
|
+
// Calculate range
|
|
7
|
+
const range = Math.floor((max - min) / step) + 1;
|
|
8
|
+
// Return the adjusted number
|
|
9
|
+
return min + Math.floor(seededRandom * range) * step;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFuZG9tLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnV4ZW8tZGV2ZWxvcG1lbnQtZnJhbWV3b3JrL3NyYy9saWIvY29tcG9uZW50cy9kaWFncmFtcy91dGlsaXRpZXMvcmFuZG9tLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sVUFBVSxlQUFlLENBQzlCLENBQVMsRUFDVCxDQUFTLEVBQ1QsSUFBSSxHQUFHLENBQUMsRUFDUixHQUFHLEdBQUcsQ0FBQyxFQUNQLEdBQUcsR0FBRyxJQUFJO0lBRVYsK0NBQStDO0lBQy9DLE1BQU0sSUFBSSxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFHLEVBQUUsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLEdBQUcsTUFBTSxDQUFDO0lBRWhELG9EQUFvRDtJQUNwRCxNQUFNLFlBQVksR0FBRyxDQUFDLENBQUMsSUFBSSxHQUFHLElBQUksR0FBRyxLQUFLLENBQUMsR0FBRyxNQUFNLENBQUMsR0FBRyxNQUFNLENBQUM7SUFFL0Qsa0JBQWtCO0lBQ2xCLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRWpELDZCQUE2QjtJQUM3QixPQUFPLEdBQUcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFlBQVksR0FBRyxLQUFLLENBQUMsR0FBRyxJQUFJLENBQUM7QUFDdEQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBmdW5jdGlvbiBnZXRSYW5kb21OdW1iZXIoXHJcblx0eDogbnVtYmVyLFxyXG5cdHk6IG51bWJlcixcclxuXHRzdGVwID0gMSxcclxuXHRtaW4gPSAwLFxyXG5cdG1heCA9IDEwMDBcclxuKSB7XHJcblx0Ly8gQ3JlYXRlIGEgZGV0ZXJtaW5pc3RpYyBzZWVkIGJhc2VkIG9uIHggYW5kIHlcclxuXHRjb25zdCBzZWVkID0gTWF0aC5hYnMoeCAqIDMxICsgeSAqIDE3KSAlIDEwMDAwMDtcclxuXHJcblx0Ly8gR2VuZXJhdGUgYSBwc2V1ZG8tcmFuZG9tIG51bWJlciBiYXNlZCBvbiB0aGUgc2VlZFxyXG5cdGNvbnN0IHNlZWRlZFJhbmRvbSA9ICgoc2VlZCAqIDkzMDEgKyA0OTI5NykgJSAyMzMyODApIC8gMjMzMjgwO1xyXG5cclxuXHQvLyBDYWxjdWxhdGUgcmFuZ2VcclxuXHRjb25zdCByYW5nZSA9IE1hdGguZmxvb3IoKG1heCAtIG1pbikgLyBzdGVwKSArIDE7XHJcblxyXG5cdC8vIFJldHVybiB0aGUgYWRqdXN0ZWQgbnVtYmVyXHJcblx0cmV0dXJuIG1pbiArIE1hdGguZmxvb3Ioc2VlZGVkUmFuZG9tICogcmFuZ2UpICogc3RlcDtcclxufVxyXG4iXX0=
|
|
@@ -89,7 +89,7 @@ const _updateConnections = (outputs, inputs, editor) => __awaiter(void 0, void 0
|
|
|
89
89
|
if (!sourceNode || !targetNode) {
|
|
90
90
|
return;
|
|
91
91
|
}
|
|
92
|
-
const connection = new Connection(sourceNode,
|
|
92
|
+
const connection = new Connection(sourceNode, targetNode);
|
|
93
93
|
yield editor.addConnection(connection);
|
|
94
94
|
});
|
|
95
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"remove.util.js","sourceRoot":"","sources":["../../../../../../../projects/nuxeo-development-framework/src/lib/components/diagrams/utilities/remove.util.ts"],"names":[],"mappings":"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","sourcesContent":["import { NodeEditor } from 'rete';\r\nimport { NODE_TYPE } from '../constants';\r\nimport { BaseNodeClass, Connection } from '../models';\r\nimport { Schemes } from '../types';\r\n\r\n/**\r\n *\r\n * @param node\r\n * @returns\r\n */\r\nexport const removeNode = async (\r\n  data: { nodeId: string },\r\n  editor: NodeEditor<Schemes>\r\n) => {\r\n  if (!data || !editor) {\r\n    console.log('Node not found.');\r\n    return;\r\n  }\r\n  const nodes = editor.getNodes();\r\n  const node = editor.getNode(data.nodeId);\r\n\r\n  if (!node) {\r\n    console.log('Node not found.');\r\n    return;\r\n  }\r\n\r\n  if (node.type === NODE_TYPE.start && nodes.length > 1) {\r\n    return;\r\n  }\r\n\r\n  const nodeConfig = node.config;\r\n\r\n  return nodeConfig?.isLinked\r\n    ? await removeNodeAndReplaceConnections(node, editor)\r\n    : await removeNodeAndConnections(node, editor);\r\n};\r\n\r\n/**\r\n *\r\n * @param node\r\n * @param editor\r\n */\r\nexport const removeNodeAndConnections = async (\r\n  node: BaseNodeClass,\r\n  editor: NodeEditor<Schemes>\r\n) => {\r\n  removeConnections(node, editor);\r\n  await editor.removeNode(node.id);\r\n};\r\n\r\n/**\r\n *\r\n * @param node\r\n * @param editor\r\n */\r\nconst removeNodeAndReplaceConnections = async (\r\n  node: BaseNodeClass,\r\n  editor: NodeEditor<Schemes>\r\n) => {\r\n  const outputs = getConnections(\r\n    editor,\r\n    (connection) => connection.source == node.id\r\n  );\r\n  const inputs = getConnections(\r\n    editor,\r\n    (connection) => connection.target == node.id\r\n  );\r\n\r\n  if (!!inputs.length && !!outputs.length) {\r\n    await _updateConnections(outputs, inputs, editor);\r\n  } else {\r\n    removeConnections(node, editor);\r\n  }\r\n\r\n  await editor.removeNode(node.id);\r\n};\r\n/**\r\n *\r\n * @param node\r\n * @param editor\r\n */\r\nexport const removeConnections = (\r\n  node: BaseNodeClass,\r\n  editor: NodeEditor<Schemes>\r\n) => {\r\n  const connections = getConnections(\r\n    editor,\r\n    (connection) =>\r\n      connection.source === node.id || connection.target === node.id\r\n  );\r\n\r\n  if (connections.length) {\r\n    connections.forEach((connection) => {\r\n      editor.removeConnection(connection.id);\r\n    });\r\n  }\r\n};\r\n/**\r\n *\r\n * @param editor\r\n * @param predicate\r\n * @returns\r\n */\r\nexport const getConnections = (\r\n  editor: NodeEditor<Schemes>,\r\n  predicate: (connection: Connection) => boolean\r\n) => {\r\n  return editor.getConnections().filter(predicate);\r\n};\r\n/**\r\n *\r\n * @param outputs\r\n * @param inputs\r\n * @param editor\r\n */\r\nconst _updateConnections = async (\r\n  outputs: Connection[],\r\n  inputs: Connection[],\r\n  editor: NodeEditor<Schemes>\r\n) => {\r\n  const source = inputs[0].source;\r\n  const target = outputs[0].target;\r\n\r\n  const sourceNode = editor.getNode(source) as BaseNodeClass;\r\n  const targetNode = editor.getNode(target) as BaseNodeClass;\r\n\r\n  [...outputs, ...inputs].forEach(async (connection) => {\r\n    await editor.removeConnection(connection.id);\r\n  });\r\n\r\n  if (!sourceNode || !targetNode) {\r\n    return;\r\n  }\r\n  const connection = new Connection(\r\n    sourceNode,\r\n    targetNode,\r\n  );\r\n\r\n  await editor.addConnection(connection);\r\n};\r\n"]}
|
|
@@ -1,17 +1,21 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
2
|
import { DxFormComponent } from 'devextreme-angular';
|
|
3
3
|
import { of } from 'rxjs';
|
|
4
|
+
import { NdfNuxeoDialog } from '../../../../shared/components/nuxeo-dialog/nuxeo.dialog';
|
|
5
|
+
import { tap } from 'rxjs/operators';
|
|
6
|
+
import { BaseComponent } from '../../../../shared/components/base/base.component';
|
|
4
7
|
import * as i0 from "@angular/core";
|
|
5
8
|
import * as i1 from "../../../../shared-services/file-manager.service";
|
|
6
9
|
import * as i2 from "../../../custom-toastr/services/custom-toastr.service";
|
|
7
|
-
import * as i3 from "
|
|
8
|
-
import * as i4 from "devextreme-angular
|
|
9
|
-
import * as i5 from "
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
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 "@ngx-translate/core";
|
|
13
|
+
export class CopyComponent extends BaseComponent {
|
|
14
|
+
constructor(fileManagerService, customToastrService, nuxeoDialogService, injector) {
|
|
15
|
+
super(injector);
|
|
13
16
|
this.fileManagerService = fileManagerService;
|
|
14
17
|
this.customToastrService = customToastrService;
|
|
18
|
+
this.nuxeoDialogService = nuxeoDialogService;
|
|
15
19
|
this.visibleChange = new EventEmitter();
|
|
16
20
|
this.getSelectedFolder = new EventEmitter();
|
|
17
21
|
this.rtlEnabled = false;
|
|
@@ -22,7 +26,7 @@ export class CopyComponent {
|
|
|
22
26
|
let myparent = parent ? parent.key : this.rootFolder;
|
|
23
27
|
let myobs;
|
|
24
28
|
if (myparent === this.pageConfigurations.rootName) {
|
|
25
|
-
// when it is root of file list then used passed root entries and for root of
|
|
29
|
+
// when it is root of file list then used passed root entries and for root of
|
|
26
30
|
// my files or any other folder use getting childs for that folder with its id
|
|
27
31
|
myobs = this.fileManagerService.parseNodeChildren(of(this.rootEntries), this.pageConfigurations, parent);
|
|
28
32
|
}
|
|
@@ -40,18 +44,61 @@ export class CopyComponent {
|
|
|
40
44
|
// )
|
|
41
45
|
// return this.fileManagerService.parseNodeChildren(obs, parent);
|
|
42
46
|
};
|
|
47
|
+
this.copy = (answer) => {
|
|
48
|
+
var _a, _b;
|
|
49
|
+
if (this.currentItem.canCopyToDestination) {
|
|
50
|
+
if (((_b = (_a = this.directory) === null || _a === void 0 ? void 0 : _a.dataItem) === null || _b === void 0 ? void 0 : _b.id) !== this.currentItem.id &&
|
|
51
|
+
!this.currentItem.entity.path.includes(this.selectedItem.name)) {
|
|
52
|
+
// this.currentPath = '';
|
|
53
|
+
return this.fileManagerService
|
|
54
|
+
.copyTo(this.currentItem, this.selectedItems)
|
|
55
|
+
.pipe(tap((res) => {
|
|
56
|
+
this.visible = answer;
|
|
57
|
+
this.getSelectedFolder.next(this.currentItem.id);
|
|
58
|
+
this.customToastrService.show('success', 'TOASTER.SUCCESS', 'TOASTER.DOCUMENT_COPIED');
|
|
59
|
+
}, (err) => {
|
|
60
|
+
this.visible = true;
|
|
61
|
+
this.customToastrService.show('error', 'TOASTER.ERROR', 'TOASTER.DOCUMENT_COPIED_ERROR');
|
|
62
|
+
}));
|
|
63
|
+
}
|
|
64
|
+
else
|
|
65
|
+
this.customToastrService.show('error', 'TOASTER.ERROR', 'TOASTER.FAILED_TO_COPY');
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
this.customToastrService.show('error', 'TOASTER.ERROR', 'TOASTER.NO_PERMISSION');
|
|
69
|
+
}
|
|
70
|
+
return of(null);
|
|
71
|
+
};
|
|
43
72
|
}
|
|
44
73
|
set visible(value) {
|
|
45
74
|
if (this._visible === value) {
|
|
46
75
|
return;
|
|
47
76
|
}
|
|
77
|
+
if (value) {
|
|
78
|
+
this.openDialog();
|
|
79
|
+
}
|
|
48
80
|
this._visible = value;
|
|
49
81
|
this.visibleChange.emit(this._visible);
|
|
50
82
|
}
|
|
51
83
|
get visible() {
|
|
52
84
|
return this._visible;
|
|
53
85
|
}
|
|
54
|
-
ngOnInit() {
|
|
86
|
+
ngOnInit() { }
|
|
87
|
+
openDialog() {
|
|
88
|
+
const options = {
|
|
89
|
+
component: NdfNuxeoDialog,
|
|
90
|
+
config: {
|
|
91
|
+
title: this.translateService.instant('FILE_MANAGER.COPY_OR_MOVE'),
|
|
92
|
+
contentTemplate: this.contentTemplate,
|
|
93
|
+
actionsTemplate: this.actionsTemplate
|
|
94
|
+
}
|
|
95
|
+
};
|
|
96
|
+
this.nuxeoDialogService
|
|
97
|
+
.open(options)
|
|
98
|
+
.afterClosed()
|
|
99
|
+
.subscribe((res) => {
|
|
100
|
+
this.cancel();
|
|
101
|
+
});
|
|
55
102
|
}
|
|
56
103
|
cancel() {
|
|
57
104
|
this.visible = false;
|
|
@@ -60,33 +107,9 @@ export class CopyComponent {
|
|
|
60
107
|
this.disable = false;
|
|
61
108
|
this.currentItem = e.itemData;
|
|
62
109
|
}
|
|
63
|
-
copy(answer) {
|
|
64
|
-
var _a, _b;
|
|
65
|
-
if (this.currentItem.canCopyToDestination) {
|
|
66
|
-
if (((_b = (_a = this.directory) === null || _a === void 0 ? void 0 : _a.dataItem) === null || _b === void 0 ? void 0 : _b.id) !== this.currentItem.id &&
|
|
67
|
-
!this.currentItem.entity.path.includes(this.selectedItem.name)) {
|
|
68
|
-
// this.currentPath = '';
|
|
69
|
-
this.fileManagerService
|
|
70
|
-
.copyTo(this.currentItem, this.selectedItems)
|
|
71
|
-
.subscribe((res) => {
|
|
72
|
-
this.visible = answer;
|
|
73
|
-
this.getSelectedFolder.next(this.currentItem.id);
|
|
74
|
-
this.customToastrService.show('success', 'TOASTER.SUCCESS', 'TOASTER.DOCUMENT_COPIED');
|
|
75
|
-
}, (err) => {
|
|
76
|
-
this.visible = true;
|
|
77
|
-
this.customToastrService.show('error', 'TOASTER.ERROR', 'TOASTER.DOCUMENT_COPIED_ERROR');
|
|
78
|
-
});
|
|
79
|
-
}
|
|
80
|
-
else
|
|
81
|
-
this.customToastrService.show('error', 'TOASTER.ERROR', 'TOASTER.FAILED_TO_COPY');
|
|
82
|
-
}
|
|
83
|
-
else {
|
|
84
|
-
this.customToastrService.show('error', 'TOASTER.ERROR', 'TOASTER.NO_PERMISSION');
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
110
|
}
|
|
88
|
-
CopyComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: CopyComponent, deps: [{ token: i1.FileManagerService }, { token: i2.CustomToastrService }], target: i0.ɵɵFactoryTarget.Component });
|
|
89
|
-
CopyComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: CopyComponent, selector: "app-copy", inputs: { visible: "visible", rtlEnabled: "rtlEnabled", selectedItem: "selectedItem", rootFolder: "rootFolder", rootEntries: "rootEntries", selectedItems: "selectedItems", directory: "directory", pageConfigurations: "pageConfigurations" }, outputs: { visibleChange: "visibleChange", getSelectedFolder: "getSelectedFolder" }, viewQueries: [{ propertyName: "form", first: true, predicate: DxFormComponent, descendants: true }
|
|
111
|
+
CopyComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: CopyComponent, deps: [{ token: i1.FileManagerService }, { token: i2.CustomToastrService }, { token: i3.NuxeoDialogService }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
|
|
112
|
+
CopyComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: CopyComponent, selector: "app-copy", inputs: { visible: "visible", rtlEnabled: "rtlEnabled", selectedItem: "selectedItem", rootFolder: "rootFolder", rootEntries: "rootEntries", selectedItems: "selectedItems", directory: "directory", pageConfigurations: "pageConfigurations" }, outputs: { visibleChange: "visibleChange", getSelectedFolder: "getSelectedFolder" }, 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: "<ng-template #contentTemplate>\r\n\t<div class=\"p-4\">\r\n\t\t<dx-scroll-view width=\"100%\" height=\"100%\">\r\n\t\t\t<div class=\"form\">\r\n\t\t\t\t<dx-tree-view\r\n\t\t\t\t\t[rtlEnabled]=\"rtlEnabled\"\r\n\t\t\t\t\tid=\"treeList\"\r\n\t\t\t\t\t[rootValue]=\"rootFolder\"\r\n\t\t\t\t\tkeyExpr=\"id\"\r\n\t\t\t\t\tdisplayExpr=\"name\"\r\n\t\t\t\t\thasItemsExpr=\"isExpanded\"\r\n\t\t\t\t\tdataStructure=\"plain\"\r\n\t\t\t\t\t[createChildren]=\"createTreeNodeChildren\"\r\n\t\t\t\t\t[width]=\"465\"\r\n\t\t\t\t\t(onItemClick)=\"selectItem($event)\"\r\n\t\t\t\t>\r\n\t\t\t\t</dx-tree-view>\r\n\t\t\t</div>\r\n\t\t</dx-scroll-view>\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\t[disabled]=\"disable\"\r\n\t\tclass=\"submission-button px-5\"\r\n\t\t(click)=\"dialog.executeAction(copy, [false])\"\r\n\t>\r\n\t\t{{ 'BUTTONS.COPY' | translate }}\r\n\t</button>\r\n</ng-template>\r\n", styles: [""], components: [{ type: i4.DxScrollViewComponent, selector: "dx-scroll-view", inputs: ["bounceEnabled", "direction", "disabled", "elementAttr", "height", "pulledDownText", "pullingDownText", "reachBottomText", "refreshingText", "rtlEnabled", "scrollByContent", "scrollByThumb", "showScrollbar", "useNative", "width"], outputs: ["onDisposing", "onInitialized", "onOptionChanged", "onPullDown", "onReachBottom", "onScroll", "onUpdated", "bounceEnabledChange", "directionChange", "disabledChange", "elementAttrChange", "heightChange", "pulledDownTextChange", "pullingDownTextChange", "reachBottomTextChange", "refreshingTextChange", "rtlEnabledChange", "scrollByContentChange", "scrollByThumbChange", "showScrollbarChange", "useNativeChange", "widthChange"] }, { type: i4.DxTreeViewComponent, selector: "dx-tree-view", inputs: ["accessKey", "activeStateEnabled", "animationEnabled", "collapseIcon", "createChildren", "dataSource", "dataStructure", "disabled", "disabledExpr", "displayExpr", "elementAttr", "expandAllEnabled", "expandedExpr", "expandEvent", "expandIcon", "expandNodesRecursive", "focusStateEnabled", "hasItemsExpr", "height", "hint", "hoverStateEnabled", "itemHoldTimeout", "items", "itemsExpr", "itemTemplate", "keyExpr", "noDataText", "parentIdExpr", "rootValue", "rtlEnabled", "scrollDirection", "searchEditorOptions", "searchEnabled", "searchExpr", "searchMode", "searchTimeout", "searchValue", "selectAllText", "selectByClick", "selectedExpr", "selectionMode", "selectNodesRecursive", "showCheckBoxesMode", "tabIndex", "useNativeScrolling", "virtualModeEnabled", "visible", "width"], outputs: ["onContentReady", "onDisposing", "onInitialized", "onItemClick", "onItemCollapsed", "onItemContextMenu", "onItemExpanded", "onItemHold", "onItemRendered", "onItemSelectionChanged", "onOptionChanged", "onSelectAllValueChanged", "onSelectionChanged", "accessKeyChange", "activeStateEnabledChange", "animationEnabledChange", "collapseIconChange", "createChildrenChange", "dataSourceChange", "dataStructureChange", "disabledChange", "disabledExprChange", "displayExprChange", "elementAttrChange", "expandAllEnabledChange", "expandedExprChange", "expandEventChange", "expandIconChange", "expandNodesRecursiveChange", "focusStateEnabledChange", "hasItemsExprChange", "heightChange", "hintChange", "hoverStateEnabledChange", "itemHoldTimeoutChange", "itemsChange", "itemsExprChange", "itemTemplateChange", "keyExprChange", "noDataTextChange", "parentIdExprChange", "rootValueChange", "rtlEnabledChange", "scrollDirectionChange", "searchEditorOptionsChange", "searchEnabledChange", "searchExprChange", "searchModeChange", "searchTimeoutChange", "searchValueChange", "selectAllTextChange", "selectByClickChange", "selectedExprChange", "selectionModeChange", "selectNodesRecursiveChange", "showCheckBoxesModeChange", "tabIndexChange", "useNativeScrollingChange", "virtualModeEnabledChange", "visibleChange", "widthChange"] }], pipes: { "translate": i5.TranslatePipe } });
|
|
90
113
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: CopyComponent, decorators: [{
|
|
91
114
|
type: Component,
|
|
92
115
|
args: [{
|
|
@@ -94,9 +117,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
94
117
|
templateUrl: './copy.component.html',
|
|
95
118
|
styleUrls: ['./copy.component.scss']
|
|
96
119
|
}]
|
|
97
|
-
}], ctorParameters: function () { return [{ type: i1.FileManagerService }, { type: i2.CustomToastrService }]; }, propDecorators: { form: [{
|
|
120
|
+
}], ctorParameters: function () { return [{ type: i1.FileManagerService }, { type: i2.CustomToastrService }, { type: i3.NuxeoDialogService }, { type: i0.Injector }]; }, propDecorators: { form: [{
|
|
98
121
|
type: ViewChild,
|
|
99
122
|
args: [DxFormComponent, { static: false }]
|
|
123
|
+
}], contentTemplate: [{
|
|
124
|
+
type: ViewChild,
|
|
125
|
+
args: ['contentTemplate']
|
|
126
|
+
}], actionsTemplate: [{
|
|
127
|
+
type: ViewChild,
|
|
128
|
+
args: ['actionsTemplate']
|
|
100
129
|
}], visible: [{
|
|
101
130
|
type: Input
|
|
102
131
|
}], visibleChange: [{
|
|
@@ -118,4 +147,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
118
147
|
}], pageConfigurations: [{
|
|
119
148
|
type: Input
|
|
120
149
|
}] } });
|
|
121
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"copy.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/file-manger/components/copy/copy.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/file-manger/components/copy/copy.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { DxFormComponent } from 'devextreme-angular';\r\nimport { of } from 'rxjs';\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-copy',\r\n  templateUrl: './copy.component.html',\r\n  styleUrls: ['./copy.component.scss']\r\n})\r\nexport class CopyComponent 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  getSelectedFolder = new EventEmitter<any>();\r\n  @Input()\r\n  rtlEnabled = false;\r\n  @Input()\r\n  selectedItem: any;\r\n  @Input()\r\n  rootFolder: any;\r\n  @Input()\r\n  rootEntries: any;\r\n  @Input()\r\n  selectedItems: any;\r\n  @Input()\r\n  directory: any;\r\n  @Input() pageConfigurations;\r\n  formData: any = {};\r\n  disable = true;\r\n  _visible = false;\r\n  currentItem;\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\r\n  cancel() {\r\n    this.visible = false;\r\n  }\r\n  selectItem(e) {\r\n    this.disable = false;\r\n    this.currentItem = e.itemData;\r\n  }\r\n\r\n  createTreeNodeChildren = (parent) => {\r\n    let myparent = parent ? parent.key : this.rootFolder;\r\n    let myobs;\r\n    if (myparent === this.pageConfigurations.rootName) {\r\n      // when it is root of file list then used passed root entries and for root of \r\n      // my files or any other folder use getting childs for that folder with its id\r\n      myobs = this.fileManagerService.parseNodeChildren(of(this.rootEntries), this.pageConfigurations , parent);\r\n\r\n    } else {\r\n      myobs = this.fileManagerService.createTreeNodeChildren(myparent)\r\n    }\r\n    return myobs;\r\n    // console.log(parent);\r\n    // let obs = (\r\n    //   parent\r\n    //     ? this.fileManagerService.getTreeNodeChildren(parent)\r\n    //     : of(\r\n    //       this.rootEntries\r\n    //     )\r\n    // )\r\n    // return this.fileManagerService.parseNodeChildren(obs, parent);\r\n  }\r\n\r\n  copy(answer) {\r\n    if (this.currentItem.canCopyToDestination) {\r\n      if (\r\n        this.directory?.dataItem?.id !== this.currentItem.id &&\r\n        !this.currentItem.entity.path.includes(this.selectedItem.name)\r\n      ) {\r\n        // this.currentPath = '';\r\n        this.fileManagerService\r\n          .copyTo(this.currentItem, this.selectedItems)\r\n          .subscribe(\r\n            (res) => {\r\n              this.visible = answer;\r\n              this.getSelectedFolder.next(this.currentItem.id);\r\n              this.customToastrService.show(\r\n                'success',\r\n                'TOASTER.SUCCESS',\r\n                'TOASTER.DOCUMENT_COPIED'\r\n              );\r\n            },\r\n            (err) => {\r\n              this.visible = true;\r\n              this.customToastrService.show(\r\n                'error',\r\n                'TOASTER.ERROR',\r\n                'TOASTER.DOCUMENT_COPIED_ERROR'\r\n              );\r\n            }\r\n          );\r\n      } else\r\n        this.customToastrService.show(\r\n          'error',\r\n          'TOASTER.ERROR',\r\n          'TOASTER.FAILED_TO_COPY'\r\n        );\r\n    } else {\r\n      this.customToastrService.show(\r\n        'error',\r\n        'TOASTER.ERROR',\r\n        'TOASTER.NO_PERMISSION'\r\n      );\r\n    }\r\n  }\r\n}\r\n","<dx-popup class=\"popUpParent\" [rtlEnabled]=\"rtlEnabled\" id=\"photo-popup\" [width]=\"500\" [height]=\"500\"\r\n    title=\"{{ 'FILE_MANAGER.COPY_OR_MOVE' | translate }}\" [(visible)]=\"visible\" [showTitle]=\"true\"\r\n    [closeOnOutsideClick]=\"true\">\r\n    <div class=\"p-4\" *dxTemplate=\"let data of 'content'\">\r\n        <dx-scroll-view width=\"100%\" height=\"100%\">\r\n            <div class=\"form\">\r\n                <dx-tree-view [rtlEnabled]=\"rtlEnabled\" id=\"treeList\" [rootValue]=\"rootFolder\" keyExpr=\"id\"\r\n                    displayExpr=\"name\" hasItemsExpr=\"isExpanded\" dataStructure=\"plain\"\r\n                    [createChildren]=\"createTreeNodeChildren\" [width]=\"465\" (onItemClick)=\"selectItem($event)\">\r\n                </dx-tree-view>\r\n            </div>\r\n        </dx-scroll-view>\r\n    </div>\r\n    <dxi-toolbar-item toolbar=\"bottom\" [disabled]=\"disable\">\r\n        <button class=\"submission-button px-5\" (click)=\"copy(false)\">\r\n            {{ \"BUTTONS.COPY\" | translate }}\r\n        </button>\r\n    </dxi-toolbar-item>\r\n    <dxi-toolbar-item toolbar=\"bottom\">\r\n        <button class=\"cancelation-button px-5\" (click)=\"cancel()\">\r\n            {{ \"BUTTONS.CANCEL\" | translate }}\r\n        </button>\r\n    </dxi-toolbar-item>\r\n</dx-popup>"]}
|
|
150
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"copy.component.js","sourceRoot":"","sources":["../../../../../../../../projects/nuxeo-development-framework/src/lib/components/file-manger/components/copy/copy.component.ts","../../../../../../../../projects/nuxeo-development-framework/src/lib/components/file-manger/components/copy/copy.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 { DxFormComponent } from 'devextreme-angular';\r\nimport { of } from 'rxjs';\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 { NuxeoDialogService } from '../../../../shared/components/nuxeo-dialog/services/nuxeo-dialog.service';\r\nimport { DialogActionType } from '../../../../shared/components/nuxeo-dialog/models/dialog-option.model';\r\nimport { tap } from 'rxjs/operators';\r\nimport { BaseComponent } from '../../../../shared/components/base/base.component';\r\n@Component({\r\n\tselector: 'app-copy',\r\n\ttemplateUrl: './copy.component.html',\r\n\tstyleUrls: ['./copy.component.scss']\r\n})\r\nexport class CopyComponent 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\tgetSelectedFolder = new EventEmitter<any>();\r\n\t@Input()\r\n\trtlEnabled = false;\r\n\t@Input()\r\n\tselectedItem: any;\r\n\t@Input()\r\n\trootFolder: any;\r\n\t@Input()\r\n\trootEntries: any;\r\n\t@Input()\r\n\tselectedItems: any;\r\n\t@Input()\r\n\tdirectory: any;\r\n\t@Input() pageConfigurations;\r\n\tformData: any = {};\r\n\tdisable = true;\r\n\t_visible = false;\r\n\tcurrentItem;\r\n\tconstructor(\r\n\t\tprivate fileManagerService: FileManagerService,\r\n\t\tprotected 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('FILE_MANAGER.COPY_OR_MOVE'),\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.cancel();\r\n\t\t\t});\r\n\t}\r\n\r\n\tcancel() {\r\n\t\tthis.visible = false;\r\n\t}\r\n\tselectItem(e) {\r\n\t\tthis.disable = false;\r\n\t\tthis.currentItem = e.itemData;\r\n\t}\r\n\r\n\tcreateTreeNodeChildren = (parent) => {\r\n\t\tlet myparent = parent ? parent.key : this.rootFolder;\r\n\t\tlet myobs;\r\n\t\tif (myparent === this.pageConfigurations.rootName) {\r\n\t\t\t// when it is root of file list then used passed root entries and for root of\r\n\t\t\t// my files or any other folder use getting childs for that folder with its id\r\n\t\t\tmyobs = this.fileManagerService.parseNodeChildren(\r\n\t\t\t\tof(this.rootEntries),\r\n\t\t\t\tthis.pageConfigurations,\r\n\t\t\t\tparent\r\n\t\t\t);\r\n\t\t} else {\r\n\t\t\tmyobs = this.fileManagerService.createTreeNodeChildren(myparent);\r\n\t\t}\r\n\t\treturn myobs;\r\n\t\t// console.log(parent);\r\n\t\t// let obs = (\r\n\t\t//   parent\r\n\t\t//     ? this.fileManagerService.getTreeNodeChildren(parent)\r\n\t\t//     : of(\r\n\t\t//       this.rootEntries\r\n\t\t//     )\r\n\t\t// )\r\n\t\t// return this.fileManagerService.parseNodeChildren(obs, parent);\r\n\t};\r\n\r\n\tcopy: DialogActionType = (answer) => {\r\n\t\tif (this.currentItem.canCopyToDestination) {\r\n\t\t\tif (\r\n\t\t\t\tthis.directory?.dataItem?.id !== this.currentItem.id &&\r\n\t\t\t\t!this.currentItem.entity.path.includes(this.selectedItem.name)\r\n\t\t\t) {\r\n\t\t\t\t// this.currentPath = '';\r\n\t\t\t\treturn this.fileManagerService\r\n\t\t\t\t\t.copyTo(this.currentItem, this.selectedItems)\r\n\t\t\t\t\t.pipe(\r\n\t\t\t\t\t\ttap(\r\n\t\t\t\t\t\t\t(res) => {\r\n\t\t\t\t\t\t\t\tthis.visible = answer;\r\n\t\t\t\t\t\t\t\tthis.getSelectedFolder.next(this.currentItem.id);\r\n\t\t\t\t\t\t\t\tthis.customToastrService.show(\r\n\t\t\t\t\t\t\t\t\t'success',\r\n\t\t\t\t\t\t\t\t\t'TOASTER.SUCCESS',\r\n\t\t\t\t\t\t\t\t\t'TOASTER.DOCUMENT_COPIED'\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\t(err) => {\r\n\t\t\t\t\t\t\t\tthis.visible = true;\r\n\t\t\t\t\t\t\t\tthis.customToastrService.show(\r\n\t\t\t\t\t\t\t\t\t'error',\r\n\t\t\t\t\t\t\t\t\t'TOASTER.ERROR',\r\n\t\t\t\t\t\t\t\t\t'TOASTER.DOCUMENT_COPIED_ERROR'\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)\r\n\t\t\t\t\t);\r\n\t\t\t} else\r\n\t\t\t\tthis.customToastrService.show(\r\n\t\t\t\t\t'error',\r\n\t\t\t\t\t'TOASTER.ERROR',\r\n\t\t\t\t\t'TOASTER.FAILED_TO_COPY'\r\n\t\t\t\t);\r\n\t\t} else {\r\n\t\t\tthis.customToastrService.show(\r\n\t\t\t\t'error',\r\n\t\t\t\t'TOASTER.ERROR',\r\n\t\t\t\t'TOASTER.NO_PERMISSION'\r\n\t\t\t);\r\n\t\t}\r\n\t\treturn of(null);\r\n\t};\r\n}\r\n","<ng-template #contentTemplate>\r\n\t<div class=\"p-4\">\r\n\t\t<dx-scroll-view width=\"100%\" height=\"100%\">\r\n\t\t\t<div class=\"form\">\r\n\t\t\t\t<dx-tree-view\r\n\t\t\t\t\t[rtlEnabled]=\"rtlEnabled\"\r\n\t\t\t\t\tid=\"treeList\"\r\n\t\t\t\t\t[rootValue]=\"rootFolder\"\r\n\t\t\t\t\tkeyExpr=\"id\"\r\n\t\t\t\t\tdisplayExpr=\"name\"\r\n\t\t\t\t\thasItemsExpr=\"isExpanded\"\r\n\t\t\t\t\tdataStructure=\"plain\"\r\n\t\t\t\t\t[createChildren]=\"createTreeNodeChildren\"\r\n\t\t\t\t\t[width]=\"465\"\r\n\t\t\t\t\t(onItemClick)=\"selectItem($event)\"\r\n\t\t\t\t>\r\n\t\t\t\t</dx-tree-view>\r\n\t\t\t</div>\r\n\t\t</dx-scroll-view>\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\t[disabled]=\"disable\"\r\n\t\tclass=\"submission-button px-5\"\r\n\t\t(click)=\"dialog.executeAction(copy, [false])\"\r\n\t>\r\n\t\t{{ 'BUTTONS.COPY' | translate }}\r\n\t</button>\r\n</ng-template>\r\n"]}
|
package/esm2015/lib/components/file-manger/components/create-directory/create-directory.component.js
CHANGED
|
@@ -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 "
|
|
7
|
-
import * as i4 from "devextreme-angular
|
|
8
|
-
import * as i5 from "devextreme-angular/
|
|
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 "@
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
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>
|
|
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"]}
|