@c8y/ngx-components 1018.0.147 → 1018.0.151
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/core/common/date.pipe.d.ts +2 -2
- package/core/common/stringify-object.pipe.d.ts +2 -1
- package/ecosystem/application-properties/update-application-modal/update-application-modal.component.d.ts +0 -2
- package/ecosystem/packages/deploy-application/deploy-application.component.d.ts +7 -6
- package/ecosystem/shared/ecosystem.constants.d.ts +3 -1
- package/ecosystem/shared/ecosystem.model.d.ts +3 -1
- package/ecosystem/shared/ecosystem.service.d.ts +11 -5
- package/esm2020/core/common/date.pipe.mjs +12 -7
- package/esm2020/core/common/stringify-object.pipe.mjs +11 -8
- package/esm2020/ecosystem/application-properties/application-properties.component.mjs +6 -4
- package/esm2020/ecosystem/application-properties/update-application-modal/update-application-modal.component.mjs +11 -22
- package/esm2020/ecosystem/applications/install-from-package/install-from-package.component.mjs +2 -2
- package/esm2020/ecosystem/packages/deploy-application/deploy-application.component.mjs +28 -85
- package/esm2020/ecosystem/shared/ecosystem.constants.mjs +5 -3
- package/esm2020/ecosystem/shared/ecosystem.model.mjs +3 -1
- package/esm2020/ecosystem/shared/ecosystem.service.mjs +121 -24
- package/fesm2015/c8y-ngx-components-ecosystem-shared.mjs +139 -27
- package/fesm2015/c8y-ngx-components-ecosystem-shared.mjs.map +1 -1
- package/fesm2015/c8y-ngx-components-ecosystem.mjs +110 -179
- package/fesm2015/c8y-ngx-components-ecosystem.mjs.map +1 -1
- package/fesm2015/c8y-ngx-components.mjs +20 -13
- package/fesm2015/c8y-ngx-components.mjs.map +1 -1
- package/fesm2020/c8y-ngx-components-ecosystem-shared.mjs +126 -25
- package/fesm2020/c8y-ngx-components-ecosystem-shared.mjs.map +1 -1
- package/fesm2020/c8y-ngx-components-ecosystem.mjs +110 -176
- package/fesm2020/c8y-ngx-components-ecosystem.mjs.map +1 -1
- package/fesm2020/c8y-ngx-components.mjs +20 -13
- package/fesm2020/c8y-ngx-components.mjs.map +1 -1
- package/locales/locales.pot +15 -3
- package/package.json +1 -1
|
@@ -35,39 +35,28 @@ export class UpdateApplicationModalComponent {
|
|
|
35
35
|
async updateApplication() {
|
|
36
36
|
try {
|
|
37
37
|
const binaryMoId = this.sourcePackage.activeVersionId;
|
|
38
|
-
await this.
|
|
38
|
+
await this.inventoryService.detail(binaryMoId); // only trying if we can access it
|
|
39
|
+
await this.ecosystemService.uploadBinaryFromOtherPackage(this.sourcePackage, this.application, this.sourcePackage.activeVersionId);
|
|
39
40
|
}
|
|
40
41
|
catch (e) {
|
|
41
42
|
if (e.res?.status === 404) {
|
|
42
|
-
|
|
43
|
+
try {
|
|
44
|
+
this.updateFailure = !(await this.ecosystemService.fallbackToClone(this.application, this.sourcePackage));
|
|
45
|
+
}
|
|
46
|
+
catch (ex) {
|
|
47
|
+
this.updateFailure = true;
|
|
48
|
+
this.ecosystemService.alertError(e);
|
|
49
|
+
}
|
|
43
50
|
}
|
|
44
51
|
else {
|
|
45
52
|
this.updateFailure = true;
|
|
46
|
-
this.
|
|
53
|
+
this.ecosystemService.alertError(e);
|
|
47
54
|
}
|
|
48
55
|
}
|
|
49
56
|
finally {
|
|
50
57
|
this.isUpdateOngoing = false;
|
|
51
58
|
}
|
|
52
59
|
}
|
|
53
|
-
async uploadNewBinary(binaryMoId) {
|
|
54
|
-
const { data: binaryMo } = await this.inventoryService.detail(binaryMoId);
|
|
55
|
-
const binary = await this.inventoryService.binary.download(binaryMo.id);
|
|
56
|
-
const blob = await binary.blob();
|
|
57
|
-
const file = new File([blob], binaryMo.name);
|
|
58
|
-
const app = await this.ecosystemService.uploadArchiveToApp(file, this.application, false);
|
|
59
|
-
await this.ecosystemService.updateAppManifest(app, this.sourcePackage);
|
|
60
|
-
}
|
|
61
|
-
async fallBackToCloneUpdate() {
|
|
62
|
-
try {
|
|
63
|
-
const { data: clonedApp } = await this.applicationService.clone(this.sourcePackage);
|
|
64
|
-
await this.uploadNewBinary(clonedApp.activeVersionId);
|
|
65
|
-
await this.ecosystemService.deleteApp(clonedApp, true);
|
|
66
|
-
}
|
|
67
|
-
catch (e) {
|
|
68
|
-
this.alertService.addServerFailure(e);
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
60
|
}
|
|
72
61
|
UpdateApplicationModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: UpdateApplicationModalComponent, deps: [{ token: i1.InventoryService }, { token: i2.EcosystemService }, { token: i1.ApplicationService }, { token: i3.AlertService }], target: i0.ɵɵFactoryTarget.Component });
|
|
73
62
|
UpdateApplicationModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.6", type: UpdateApplicationModalComponent, selector: "c8y-update-application-modal", viewQueries: [{ propertyName: "modal", first: true, predicate: ["modal"], descendants: true }], ngImport: i0, template: "<c8y-modal\n [title]=\"'Update application' | translate\"\n [headerClasses]=\"'dialog-header'\"\n [customFooter]=\"true\"\n #modal\n>\n <ng-container c8y-modal-title>\n <span class=\"dlt-c8y-icon-installing-updates\"></span>\n </ng-container>\n\n <c8y-progress-bar\n *ngIf=\"isUpdateOngoing\"\n [message]=\"'Updating\u2026' | translate\"\n class=\"text-center d-block p-t-56 p-b-56 m-t-4 m-b-4\"\n style=\"min-height: 180px\"\n ></c8y-progress-bar>\n\n <c8y-operation-result\n *ngIf=\"!isUpdateOngoing && !updateFailure\"\n text=\"{{ 'Update completed' | translate }}\"\n [size]=\"120\"\n [vertical]=\"true\"\n type=\"success\"\n ></c8y-operation-result>\n <c8y-operation-result\n *ngIf=\"!isUpdateOngoing && updateFailure\"\n text=\"{{ 'Failed to update application.' | translate }}\"\n [size]=\"120\"\n [vertical]=\"true\"\n type=\"error\"\n ></c8y-operation-result>\n <div class=\"modal-footer\">\n <button\n title=\"{{ 'Close' | translate }}\"\n [disabled]=\"isUpdateOngoing\"\n class=\"btn btn-default\"\n (click)=\"done()\"\n >\n {{ 'Close' | translate }}\n </button>\n </div>\n</c8y-modal>\n", dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.ProgressBarComponent, selector: "c8y-progress-bar", inputs: ["message", "progress"] }, { kind: "component", type: i3.OperationResultComponent, selector: "c8y-operation-result", inputs: ["text", "vertical", "size", "type"] }, { kind: "component", type: i3.ModalComponent, selector: "c8y-modal", inputs: ["disabled", "close", "dismiss", "title", "body", "customFooter", "headerClasses", "labels"], outputs: ["onDismiss", "onClose"] }, { kind: "pipe", type: i3.C8yTranslatePipe, name: "translate" }] });
|
|
@@ -78,4 +67,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImpor
|
|
|
78
67
|
type: ViewChild,
|
|
79
68
|
args: ['modal', { static: false }]
|
|
80
69
|
}] } });
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBkYXRlLWFwcGxpY2F0aW9uLW1vZGFsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2Vjb3N5c3RlbS9hcHBsaWNhdGlvbi1wcm9wZXJ0aWVzL3VwZGF0ZS1hcHBsaWNhdGlvbi1tb2RhbC91cGRhdGUtYXBwbGljYXRpb24tbW9kYWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vZWNvc3lzdGVtL2FwcGxpY2F0aW9uLXByb3BlcnRpZXMvdXBkYXRlLWFwcGxpY2F0aW9uLW1vZGFsL3VwZGF0ZS1hcHBsaWNhdGlvbi1tb2RhbC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM3RCxPQUFPLEVBQUUsa0JBQWtCLEVBQWdCLGdCQUFnQixFQUFFLE1BQU0sYUFBYSxDQUFDO0FBQ2pGLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNuRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQzs7Ozs7O0FBTXhFLE1BQU0sT0FBTywrQkFBK0I7SUFjMUMsWUFDVSxnQkFBa0MsRUFDbEMsZ0JBQWtDLEVBQ2xDLGtCQUFzQyxFQUN0QyxZQUEwQjtRQUgxQixxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO1FBQ2xDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7UUFDbEMsdUJBQWtCLEdBQWxCLGtCQUFrQixDQUFvQjtRQUN0QyxpQkFBWSxHQUFaLFlBQVksQ0FBYztRQWhCcEMsb0JBQWUsR0FBRyxJQUFJLENBQUM7UUFDdkIsa0JBQWEsR0FBRyxLQUFLLENBQUM7UUFHdEIsV0FBTSxHQUFrQixJQUFJLE9BQU8sQ0FBQyxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsRUFBRTtZQUN0RCxJQUFJLENBQUMsUUFBUSxHQUFHLE9BQU8sQ0FBQztZQUN4QixJQUFJLENBQUMsT0FBTyxHQUFHLE1BQU0sQ0FBQztRQUN4QixDQUFDLENBQUMsQ0FBQztJQVVBLENBQUM7SUFFSixRQUFRO1FBQ04sSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUVELElBQUk7UUFDRixJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRTtZQUN2QixJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDaEIsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUN0QixPQUFPO1NBQ1I7UUFDRCxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDZixJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ3hCLENBQUM7SUFFRCxLQUFLLENBQUMsaUJBQWlCO1FBQ3JCLElBQUk7WUFDRixNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLGVBQWUsQ0FBQztZQUN0RCxNQUFNLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxrQ0FBa0M7WUFDbEYsTUFBTSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsNEJBQTRCLENBQ3RELElBQUksQ0FBQyxhQUFhLEVBQ2xCLElBQUksQ0FBQyxXQUFXLEVBQ2hCLElBQUksQ0FBQyxhQUFhLENBQUMsZUFBZSxDQUNuQyxDQUFDO1NBQ0g7UUFBQyxPQUFPLENBQUMsRUFBRTtZQUNWLElBQUksQ0FBQyxDQUFDLEdBQUcsRUFBRSxNQUFNLEtBQUssR0FBRyxFQUFFO2dCQUN6QixJQUFJO29CQUNGLElBQUksQ0FBQyxhQUFhLEdBQUcsQ0FBQyxDQUFDLE1BQU0sSUFBSSxDQUFDLGdCQUFnQixDQUFDLGVBQWUsQ0FDaEUsSUFBSSxDQUFDLFdBQVcsRUFDaEIsSUFBSSxDQUFDLGFBQWEsQ0FDbkIsQ0FBQyxDQUFDO2lCQUNKO2dCQUFDLE9BQU8sRUFBRSxFQUFFO29CQUNYLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDO29CQUMxQixJQUFJLENBQUMsZ0JBQWdCLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDO2lCQUNyQzthQUNGO2lCQUFNO2dCQUNMLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDO2dCQUMxQixJQUFJLENBQUMsZ0JBQWdCLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDO2FBQ3JDO1NBQ0Y7Z0JBQVM7WUFDUixJQUFJLENBQUMsZUFBZSxHQUFHLEtBQUssQ0FBQztTQUM5QjtJQUNILENBQUM7OzRIQTlEVSwrQkFBK0I7Z0hBQS9CLCtCQUErQixvS0NUNUMseXFDQTBDQTsyRkRqQ2EsK0JBQStCO2tCQUozQyxTQUFTOytCQUNFLDhCQUE4QjtrTUFJTyxLQUFLO3NCQUFuRCxTQUFTO3VCQUFDLE9BQU8sRUFBRSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBcHBsaWNhdGlvblNlcnZpY2UsIElBcHBsaWNhdGlvbiwgSW52ZW50b3J5U2VydmljZSB9IGZyb20gJ0BjOHkvY2xpZW50JztcbmltcG9ydCB7IEFsZXJ0U2VydmljZSB9IGZyb20gJ0BjOHkvbmd4LWNvbXBvbmVudHMnO1xuaW1wb3J0IHsgRWNvc3lzdGVtU2VydmljZSB9IGZyb20gJ0BjOHkvbmd4LWNvbXBvbmVudHMvZWNvc3lzdGVtL3NoYXJlZCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2M4eS11cGRhdGUtYXBwbGljYXRpb24tbW9kYWwnLFxuICB0ZW1wbGF0ZVVybDogJy4vdXBkYXRlLWFwcGxpY2F0aW9uLW1vZGFsLmNvbXBvbmVudC5odG1sJ1xufSlcbmV4cG9ydCBjbGFzcyBVcGRhdGVBcHBsaWNhdGlvbk1vZGFsQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQFZpZXdDaGlsZCgnbW9kYWwnLCB7IHN0YXRpYzogZmFsc2UgfSkgcHJpdmF0ZSBtb2RhbDtcbiAgaXNVcGRhdGVPbmdvaW5nID0gdHJ1ZTtcbiAgdXBkYXRlRmFpbHVyZSA9IGZhbHNlO1xuICBzb3VyY2VQYWNrYWdlOiBJQXBwbGljYXRpb247XG4gIGFwcGxpY2F0aW9uOiBJQXBwbGljYXRpb247XG4gIHJlc3VsdDogUHJvbWlzZTx2b2lkPiA9IG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICB0aGlzLl9yZXNvbHZlID0gcmVzb2x2ZTtcbiAgICB0aGlzLl9yZWplY3QgPSByZWplY3Q7XG4gIH0pO1xuXG4gIHByaXZhdGUgX3Jlc29sdmU6ICh2YWx1ZTogdm9pZCB8IFByb21pc2VMaWtlPHZvaWQ+KSA9PiB2b2lkO1xuICBwcml2YXRlIF9yZWplY3Q6ICh2YWx1ZTogdm9pZCB8IFByb21pc2VMaWtlPHZvaWQ+KSA9PiB2b2lkO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgaW52ZW50b3J5U2VydmljZTogSW52ZW50b3J5U2VydmljZSxcbiAgICBwcml2YXRlIGVjb3N5c3RlbVNlcnZpY2U6IEVjb3N5c3RlbVNlcnZpY2UsXG4gICAgcHJpdmF0ZSBhcHBsaWNhdGlvblNlcnZpY2U6IEFwcGxpY2F0aW9uU2VydmljZSxcbiAgICBwcml2YXRlIGFsZXJ0U2VydmljZTogQWxlcnRTZXJ2aWNlXG4gICkge31cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLnVwZGF0ZUFwcGxpY2F0aW9uKCk7XG4gIH1cblxuICBkb25lKCkge1xuICAgIGlmICghdGhpcy51cGRhdGVGYWlsdXJlKSB7XG4gICAgICB0aGlzLl9yZXNvbHZlKCk7XG4gICAgICB0aGlzLm1vZGFsLl9kaXNtaXNzKCk7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIHRoaXMuX3JlamVjdCgpO1xuICAgIHRoaXMubW9kYWwuX2Rpc21pc3MoKTtcbiAgfVxuXG4gIGFzeW5jIHVwZGF0ZUFwcGxpY2F0aW9uKCkge1xuICAgIHRyeSB7XG4gICAgICBjb25zdCBiaW5hcnlNb0lkID0gdGhpcy5zb3VyY2VQYWNrYWdlLmFjdGl2ZVZlcnNpb25JZDtcbiAgICAgIGF3YWl0IHRoaXMuaW52ZW50b3J5U2VydmljZS5kZXRhaWwoYmluYXJ5TW9JZCk7IC8vIG9ubHkgdHJ5aW5nIGlmIHdlIGNhbiBhY2Nlc3MgaXRcbiAgICAgIGF3YWl0IHRoaXMuZWNvc3lzdGVtU2VydmljZS51cGxvYWRCaW5hcnlGcm9tT3RoZXJQYWNrYWdlKFxuICAgICAgICB0aGlzLnNvdXJjZVBhY2thZ2UsXG4gICAgICAgIHRoaXMuYXBwbGljYXRpb24sXG4gICAgICAgIHRoaXMuc291cmNlUGFja2FnZS5hY3RpdmVWZXJzaW9uSWRcbiAgICAgICk7XG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgaWYgKGUucmVzPy5zdGF0dXMgPT09IDQwNCkge1xuICAgICAgICB0cnkge1xuICAgICAgICAgIHRoaXMudXBkYXRlRmFpbHVyZSA9ICEoYXdhaXQgdGhpcy5lY29zeXN0ZW1TZXJ2aWNlLmZhbGxiYWNrVG9DbG9uZShcbiAgICAgICAgICAgIHRoaXMuYXBwbGljYXRpb24sXG4gICAgICAgICAgICB0aGlzLnNvdXJjZVBhY2thZ2VcbiAgICAgICAgICApKTtcbiAgICAgICAgfSBjYXRjaCAoZXgpIHtcbiAgICAgICAgICB0aGlzLnVwZGF0ZUZhaWx1cmUgPSB0cnVlO1xuICAgICAgICAgIHRoaXMuZWNvc3lzdGVtU2VydmljZS5hbGVydEVycm9yKGUpO1xuICAgICAgICB9XG4gICAgICB9IGVsc2Uge1xuICAgICAgICB0aGlzLnVwZGF0ZUZhaWx1cmUgPSB0cnVlO1xuICAgICAgICB0aGlzLmVjb3N5c3RlbVNlcnZpY2UuYWxlcnRFcnJvcihlKTtcbiAgICAgIH1cbiAgICB9IGZpbmFsbHkge1xuICAgICAgdGhpcy5pc1VwZGF0ZU9uZ29pbmcgPSBmYWxzZTtcbiAgICB9XG4gIH1cbn1cbiIsIjxjOHktbW9kYWxcbiAgW3RpdGxlXT1cIidVcGRhdGUgYXBwbGljYXRpb24nIHwgdHJhbnNsYXRlXCJcbiAgW2hlYWRlckNsYXNzZXNdPVwiJ2RpYWxvZy1oZWFkZXInXCJcbiAgW2N1c3RvbUZvb3Rlcl09XCJ0cnVlXCJcbiAgI21vZGFsXG4+XG4gIDxuZy1jb250YWluZXIgYzh5LW1vZGFsLXRpdGxlPlxuICAgIDxzcGFuIGNsYXNzPVwiZGx0LWM4eS1pY29uLWluc3RhbGxpbmctdXBkYXRlc1wiPjwvc3Bhbj5cbiAgPC9uZy1jb250YWluZXI+XG5cbiAgPGM4eS1wcm9ncmVzcy1iYXJcbiAgICAqbmdJZj1cImlzVXBkYXRlT25nb2luZ1wiXG4gICAgW21lc3NhZ2VdPVwiJ1VwZGF0aW5n4oCmJyB8IHRyYW5zbGF0ZVwiXG4gICAgY2xhc3M9XCJ0ZXh0LWNlbnRlciBkLWJsb2NrIHAtdC01NiBwLWItNTYgbS10LTQgbS1iLTRcIlxuICAgIHN0eWxlPVwibWluLWhlaWdodDogMTgwcHhcIlxuICA+PC9jOHktcHJvZ3Jlc3MtYmFyPlxuXG4gIDxjOHktb3BlcmF0aW9uLXJlc3VsdFxuICAgICpuZ0lmPVwiIWlzVXBkYXRlT25nb2luZyAmJiAhdXBkYXRlRmFpbHVyZVwiXG4gICAgdGV4dD1cInt7ICdVcGRhdGUgY29tcGxldGVkJyB8IHRyYW5zbGF0ZSB9fVwiXG4gICAgW3NpemVdPVwiMTIwXCJcbiAgICBbdmVydGljYWxdPVwidHJ1ZVwiXG4gICAgdHlwZT1cInN1Y2Nlc3NcIlxuICA+PC9jOHktb3BlcmF0aW9uLXJlc3VsdD5cbiAgPGM4eS1vcGVyYXRpb24tcmVzdWx0XG4gICAgKm5nSWY9XCIhaXNVcGRhdGVPbmdvaW5nICYmIHVwZGF0ZUZhaWx1cmVcIlxuICAgIHRleHQ9XCJ7eyAnRmFpbGVkIHRvIHVwZGF0ZSBhcHBsaWNhdGlvbi4nIHwgdHJhbnNsYXRlIH19XCJcbiAgICBbc2l6ZV09XCIxMjBcIlxuICAgIFt2ZXJ0aWNhbF09XCJ0cnVlXCJcbiAgICB0eXBlPVwiZXJyb3JcIlxuICA+PC9jOHktb3BlcmF0aW9uLXJlc3VsdD5cbiAgPGRpdiBjbGFzcz1cIm1vZGFsLWZvb3RlclwiPlxuICAgIDxidXR0b25cbiAgICAgIHRpdGxlPVwie3sgJ0Nsb3NlJyB8IHRyYW5zbGF0ZSB9fVwiXG4gICAgICBbZGlzYWJsZWRdPVwiaXNVcGRhdGVPbmdvaW5nXCJcbiAgICAgIGNsYXNzPVwiYnRuIGJ0bi1kZWZhdWx0XCJcbiAgICAgIChjbGljayk9XCJkb25lKClcIlxuICAgID5cbiAgICAgIHt7ICdDbG9zZScgfCB0cmFuc2xhdGUgfX1cbiAgICA8L2J1dHRvbj5cbiAgPC9kaXY+XG48L2M4eS1tb2RhbD5cbiJdfQ==
|
package/esm2020/ecosystem/applications/install-from-package/install-from-package.component.mjs
CHANGED
|
@@ -128,7 +128,7 @@ export class InstallFromPackageComponent {
|
|
|
128
128
|
this.canDeploy = true;
|
|
129
129
|
}
|
|
130
130
|
async selectPackage(selectedPackage) {
|
|
131
|
-
const apps =
|
|
131
|
+
const apps = await this.ecosystemService.getHostedAndPackageApplications();
|
|
132
132
|
this.newAppConfig = this.ecosystemService.getUniqueAppConfig(selectedPackage, apps);
|
|
133
133
|
this.selectedPackage = selectedPackage;
|
|
134
134
|
this.loadSelectedPackageVersions();
|
|
@@ -184,4 +184,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImpor
|
|
|
184
184
|
type: ViewChild,
|
|
185
185
|
args: [ApplicationPropertiesFormComponent]
|
|
186
186
|
}] } });
|
|
187
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"install-from-package.component.js","sourceRoot":"","sources":["../../../../../ecosystem/applications/install-from-package/install-from-package.component.ts","../../../../../ecosystem/applications/install-from-package/install-from-package.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild } from '@angular/core';\nimport {\n  ApplicationService,\n  IApplication,\n  IApplicationVersion,\n  InventoryService,\n  IResultList\n} from '@c8y/client';\nimport { PluginsService, WizardComponent } from '@c8y/ngx-components';\nimport { BehaviorSubject, combineLatest, from, Observable, of } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { EcosystemService } from '@c8y/ngx-components/ecosystem/shared';\nimport { ApplicationPropertiesFormComponent } from '@c8y/ngx-components/ecosystem/shared';\n\n@Component({\n  selector: 'c8y-install-from-package',\n  templateUrl: './install-from-package.component.html'\n})\nexport class InstallFromPackageComponent implements OnInit {\n  newAppConfig: IApplication;\n  selectedPackage: IApplication;\n  packages: IApplication[];\n  inProgress: boolean;\n  deployedWithSuccess = false;\n  isDeployed = false;\n\n  model = {\n    selected: undefined,\n    binary: {\n      id: undefined\n    }\n  };\n  canDeploy = false;\n  onInput: BehaviorSubject<string> = new BehaviorSubject<string>('');\n  versions$: Observable<IResultList<IApplicationVersion>>;\n  @ViewChild(ApplicationPropertiesFormComponent)\n  applicationPropertiesForm: ApplicationPropertiesFormComponent;\n\n  constructor(\n    private ecosystemService: EcosystemService,\n    private applicationService: ApplicationService,\n    private wizardComponent: WizardComponent,\n    private pluginsService: PluginsService,\n    private inventoryService: InventoryService\n  ) {}\n\n  async ngOnInit() {\n    this.loadPackages();\n  }\n\n  back() {\n    this.wizardComponent.reset();\n  }\n\n  clean() {\n    this.selectedPackage = undefined;\n    this.versions$ = undefined;\n    this.model = {\n      selected: undefined,\n      binary: {\n        id: undefined\n      }\n    };\n  }\n\n  cancel() {\n    this.wizardComponent.close();\n  }\n\n  async deployApp() {\n    this.inProgress = true;\n    const formGroupValue = this.applicationPropertiesForm.formGroup.getRawValue();\n\n    // Create new app config\n    const config = await this.ecosystemService.createConfig(this.selectedPackage, formGroupValue);\n    config.version = this.model.selected.version;\n    config.isSetup = true;\n    if (!config.manifest) {\n      config.manifest = {};\n    }\n    config.manifest.isPackage = false;\n    config.manifest.source = this.selectedPackage.id;\n    config.manifest.package = 'blueprint';\n    config.resourcesUrl = '/';\n\n    // Create new app\n    const newApp = (await this.applicationService.create(config)).data;\n    // Binary\n    try {\n      // Get binary details\n      const { data: binaryDetails } = await this.inventoryService.detail(\n        this.model.selected.binaryId\n      );\n\n      // Get binary from specific package version\n      const binary = await this.ecosystemService.getBinary(this.selectedPackage, {\n        id: this.model.selected.binaryId\n      });\n      // Create zip\n      const fileBinary = new Blob([binary], { type: binaryDetails.contentType });\n      const file = new File([fileBinary], binaryDetails.name, {\n        type: binaryDetails.contentType\n      });\n\n      // Upload binary to new app\n      await this.ecosystemService.uploadArchiveToApp(file, newApp);\n      // Update manifest\n      await this.ecosystemService.updateAppManifest(newApp, this.selectedPackage);\n\n      this.deployedWithSuccess = true;\n    } catch (error) {\n      if (error?.res?.status === 404) {\n        await this.applicationService.delete(newApp.id);\n        await this.fallbackToCloneLatest(config);\n      }\n    } finally {\n      this.markAsDeployed();\n    }\n  }\n\n  async fallbackToCloneLatest(config) {\n    let clonedPkg;\n    try {\n      clonedPkg = (await this.applicationService.clone(this.selectedPackage)).data;\n\n      // clean out all falsely cloned applicationVersions, we don't need them\n      for (const appVersion of clonedPkg.applicationVersions as IApplicationVersion[]) {\n        if (appVersion.tags.includes('latest')) {\n          await this.ecosystemService.setPackageVersionTag(clonedPkg, appVersion.version, []);\n        }\n        await this.ecosystemService.deletePackageVersion(clonedPkg, {\n          version: appVersion.version\n        });\n      }\n      delete config.type;\n      config.isPackage = false;\n      const { data: newApp } = await this.ecosystemService.updateApp(\n        {\n          id: clonedPkg.id,\n          activeVersionId: clonedPkg.activeVersionId,\n          ...config\n        },\n        false\n      );\n      await this.ecosystemService.updateAppManifest(newApp, this.selectedPackage);\n      this.deployedWithSuccess = true;\n    } catch (error) {\n      await this.ecosystemService.deleteApp(clonedPkg.id, true);\n    }\n    this.markAsDeployed();\n  }\n\n  onAppVersionSelect(appVersion: IApplicationVersion) {\n    Object.assign(this.model, {\n      selected: appVersion\n    });\n    this.canDeploy = true;\n  }\n\n  async selectPackage(selectedPackage: IApplication) {\n    const apps = (await this.ecosystemService.getApplications()).data;\n    this.newAppConfig = this.ecosystemService.getUniqueAppConfig(selectedPackage, apps);\n    this.selectedPackage = selectedPackage;\n\n    this.loadSelectedPackageVersions();\n  }\n\n  private loadSelectedPackageVersions() {\n    this.versions$ = combineLatest([\n      this.getAppVersions(this.selectPackage),\n      this.onInput.asObservable()\n    ]).pipe(\n      map(([resultList, filterStr]) => {\n        this.canDeploy = false;\n        const versionsFilteredByStr = this.filterAppVersions(resultList.data, filterStr);\n        const sortedAppVersions = this.pluginsService.sortVersions(\n          {\n            list: versionsFilteredByStr,\n            path: ['version']\n          },\n          'desc'\n        );\n\n        this.setInitialValueForInput(sortedAppVersions);\n        return { data: sortedAppVersions, res: resultList.res };\n      })\n    );\n  }\n\n  private getAppVersions(mo: IApplication) {\n    const versions = mo?.applicationVersions;\n    return versions && versions.length > 0\n      ? of({ data: versions, res: undefined })\n      : from(this.applicationService.listVersions(this.selectedPackage.id));\n  }\n\n  private setInitialValueForInput(versions: IApplicationVersion[]) {\n    if (!this.model.selected && versions.length > 0) {\n      const latest = versions.find(v => v.tags.includes('latest'));\n      this.model.selected = latest || versions[0];\n      this.canDeploy = true;\n    }\n  }\n\n  private filterAppVersions(\n    appVersions: IApplicationVersion[],\n    filterStr: string\n  ): IApplicationVersion[] {\n    return filterStr === ''\n      ? appVersions\n      : appVersions.filter(appVersion => appVersion.version.includes(filterStr));\n  }\n\n  private markAsDeployed() {\n    this.isDeployed = true;\n    this.inProgress = false;\n  }\n\n  private async loadPackages(): Promise<void> {\n    const applications = await this.ecosystemService.getPackageApplications();\n    this.packages = applications.filter(app => this.ecosystemService.isPackageBlueprint(app));\n  }\n}\n","<c8y-wizard-header>\n  <i [c8yIcon]=\"'big-parcel'\"></i>\n  <h4 id=\"modal-title\" translate>Install from extension package</h4>\n</c8y-wizard-header>\n<c8y-wizard-body>\n  <ng-container *ngIf=\"!selectedPackage\">\n    <div class=\"modal-inner-scroll\" id=\"modal-body\">\n      <p class=\"p-16 text-medium text-center separator-bottom sticky-top bg-level-0\">\n        {{ 'Select from available extension packages' | translate }}\n      </p>\n\n      <c8y-ui-empty-state\n        *ngIf=\"!packages?.length\"\n        [icon]=\"'big-parcel'\"\n        [title]=\"'No extension packages to display.' | translate\"\n        [horizontal]=\"true\"\n      ></c8y-ui-empty-state>\n\n      <div *ngIf=\"packages?.length\" class=\"c8y-wizard-list-nav\" style=\"min-height: 257px\">\n        <button\n          class=\"list-group-item text-truncate\"\n          *ngFor=\"let package of packages\"\n          (click)=\"selectPackage(package)\"\n          title=\"{{ package.name }}\"\n          type=\"button\"\n        >\n          <i c8yIcon=\"big-parcel\" class=\"list-group-icon\"></i>\n          <span [innerText]=\"package.name\"></span>\n        </button>\n      </div>\n    </div>\n  </ng-container>\n  <ng-container *ngIf=\"!isDeployed && selectedPackage\">\n    <p class=\"p-16 text-center text-medium separator-bottom sticky-top bg-level-0\">\n      {{ 'Provide application details' | translate }}\n    </p>\n    <div class=\"d-flex d-col a-i-center j-c-center\" style=\"min-height: 257px\">\n      <c8y-application-properties-form\n        *ngIf=\"!inProgress\"\n        [application]=\"newAppConfig\"\n        class=\"d-block fit-w\"\n      ></c8y-application-properties-form>\n\n      <ng-container *ngIf=\"!inProgress\">\n        <div [ngStyle]=\"{ padding: '0 16px' }\" class=\"d-block fit-w bg-gray-white\">\n          <label for=\"packageVersion\" translate>Use extension package version</label>\n          <c8y-form-group>\n            <c8y-typeahead\n              [(ngModel)]=\"model.selected\"\n              name=\"packageVersion\"\n              (onSearch)=\"onInput.next($event)\"\n              placeholder=\"{{ 'Select or enter' | translate }}\"\n              [displayProperty]=\"'version'\"\n              [required]=\"true\"\n              [hideNew]=\"true\"\n              [container]=\"'body'\"\n            >\n              <c8y-li\n                *c8yFor=\"let version of versions$; loadMore: 'auto'; notFound: notFoundTemplate\"\n                (click)=\"onAppVersionSelect(version)\"\n                class=\"p-l-8 p-r-8 c8y-list__item--link\"\n                [active]=\"model.selected === version\"\n              >\n                <c8y-li-icon icon=\"big-parcel\"></c8y-li-icon>\n                <span\n                  [ngStyle]=\"{\n                    display: 'flex',\n                    'flex-direction': 'row',\n                    'align-content': 'center',\n                    'justify-content': 'space-between',\n                    'align-items': 'center'\n                  }\"\n                >\n                  <c8y-highlight\n                    [text]=\"version.version || '--'\"\n                    [pattern]=\"onInput | async\"\n                  ></c8y-highlight>\n\n                  <span>\n                    <span *ngFor=\"let tag of version.tags\" class=\"label label-info m-l-4\">\n                      {{ tag }}\n                    </span>\n                  </span>\n                </span>\n              </c8y-li>\n              <ng-template #notFoundTemplate>\n                <c8y-li\n                  class=\"bg-gray-lighter p-8\"\n                  *ngIf=\"(onInput | async)?.length > 0 && (versions$ | async)?.data?.length === 0\"\n                >\n                  <span translate>No match found.</span>\n                </c8y-li>\n              </ng-template>\n            </c8y-typeahead>\n          </c8y-form-group>\n        </div>\n      </ng-container>\n\n      <c8y-progress-bar\n        [message]=\"'Installing…' | translate\"\n        class=\"text-center d-block\"\n        *ngIf=\"inProgress\"\n      ></c8y-progress-bar>\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"isDeployed\">\n    <div\n      *ngIf=\"deployedWithSuccess; else failedDeploy\"\n      class=\"d-flex a-i-center j-c-center\"\n      style=\"min-height: 257px\"\n    >\n      <c8y-operation-result\n        text=\"{{ 'Application created' | translate }}\"\n        [size]=\"84\"\n        [vertical]=\"true\"\n        type=\"success\"\n        class=\"lead\"\n      ></c8y-operation-result>\n    </div>\n    <ng-template #failedDeploy>\n      <div class=\"d-flex a-i-center j-c-center\" style=\"min-height: 257px\">\n        <c8y-operation-result\n          text=\"{{ 'Application creation failed' | translate }}\"\n          [size]=\"84\"\n          [vertical]=\"true\"\n          type=\"error\"\n          class=\"lead\"\n        ></c8y-operation-result>\n      </div>\n    </ng-template>\n  </ng-container>\n</c8y-wizard-body>\n\n<c8y-wizard-footer>\n  <button\n    *ngIf=\"!isDeployed\"\n    (click)=\"selectedPackage ? clean() : back()\"\n    class=\"btn btn-default\"\n    title=\"{{ 'Back' | translate }}\"\n    [disabled]=\"inProgress\"\n    type=\"button\"\n  >\n    {{ 'Back' | translate }}\n  </button>\n  <button\n    title=\"{{ isDeployed && deployedWithSuccess ? ('Close' | translate) : ('Cancel' | translate) }}\"\n    class=\"btn btn-default\"\n    type=\"button\"\n    (click)=\"cancel()\"\n  >\n    {{ isDeployed && deployedWithSuccess ? ('Close' | translate) : ('Cancel' | translate) }}\n  </button>\n\n  <button\n    title=\"{{ 'Install' | translate }}\"\n    class=\"btn btn-primary\"\n    type=\"button\"\n    (click)=\"deployApp()\"\n    [disabled]=\"inProgress || !packages?.length\"\n    *ngIf=\"!isDeployed\"\n  >\n    {{ 'Install' | translate }}\n  </button>\n</c8y-wizard-footer>\n"]}
|
|
187
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"install-from-package.component.js","sourceRoot":"","sources":["../../../../../ecosystem/applications/install-from-package/install-from-package.component.ts","../../../../../ecosystem/applications/install-from-package/install-from-package.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild } from '@angular/core';\nimport {\n  ApplicationService,\n  IApplication,\n  IApplicationVersion,\n  InventoryService,\n  IResultList\n} from '@c8y/client';\nimport { PluginsService, WizardComponent } from '@c8y/ngx-components';\nimport { BehaviorSubject, combineLatest, from, Observable, of } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { EcosystemService } from '@c8y/ngx-components/ecosystem/shared';\nimport { ApplicationPropertiesFormComponent } from '@c8y/ngx-components/ecosystem/shared';\n\n@Component({\n  selector: 'c8y-install-from-package',\n  templateUrl: './install-from-package.component.html'\n})\nexport class InstallFromPackageComponent implements OnInit {\n  newAppConfig: IApplication;\n  selectedPackage: IApplication;\n  packages: IApplication[];\n  inProgress: boolean;\n  deployedWithSuccess = false;\n  isDeployed = false;\n\n  model = {\n    selected: undefined,\n    binary: {\n      id: undefined\n    }\n  };\n  canDeploy = false;\n  onInput: BehaviorSubject<string> = new BehaviorSubject<string>('');\n  versions$: Observable<IResultList<IApplicationVersion>>;\n  @ViewChild(ApplicationPropertiesFormComponent)\n  applicationPropertiesForm: ApplicationPropertiesFormComponent;\n\n  constructor(\n    private ecosystemService: EcosystemService,\n    private applicationService: ApplicationService,\n    private wizardComponent: WizardComponent,\n    private pluginsService: PluginsService,\n    private inventoryService: InventoryService\n  ) {}\n\n  async ngOnInit() {\n    this.loadPackages();\n  }\n\n  back() {\n    this.wizardComponent.reset();\n  }\n\n  clean() {\n    this.selectedPackage = undefined;\n    this.versions$ = undefined;\n    this.model = {\n      selected: undefined,\n      binary: {\n        id: undefined\n      }\n    };\n  }\n\n  cancel() {\n    this.wizardComponent.close();\n  }\n\n  async deployApp() {\n    this.inProgress = true;\n    const formGroupValue = this.applicationPropertiesForm.formGroup.getRawValue();\n\n    // Create new app config\n    const config = await this.ecosystemService.createConfig(this.selectedPackage, formGroupValue);\n    config.version = this.model.selected.version;\n    config.isSetup = true;\n    if (!config.manifest) {\n      config.manifest = {};\n    }\n    config.manifest.isPackage = false;\n    config.manifest.source = this.selectedPackage.id;\n    config.manifest.package = 'blueprint';\n    config.resourcesUrl = '/';\n\n    // Create new app\n    const newApp = (await this.applicationService.create(config)).data;\n    // Binary\n    try {\n      // Get binary details\n      const { data: binaryDetails } = await this.inventoryService.detail(\n        this.model.selected.binaryId\n      );\n\n      // Get binary from specific package version\n      const binary = await this.ecosystemService.getBinary(this.selectedPackage, {\n        id: this.model.selected.binaryId\n      });\n      // Create zip\n      const fileBinary = new Blob([binary], { type: binaryDetails.contentType });\n      const file = new File([fileBinary], binaryDetails.name, {\n        type: binaryDetails.contentType\n      });\n\n      // Upload binary to new app\n      await this.ecosystemService.uploadArchiveToApp(file, newApp);\n      // Update manifest\n      await this.ecosystemService.updateAppManifest(newApp, this.selectedPackage);\n\n      this.deployedWithSuccess = true;\n    } catch (error) {\n      if (error?.res?.status === 404) {\n        await this.applicationService.delete(newApp.id);\n        await this.fallbackToCloneLatest(config);\n      }\n    } finally {\n      this.markAsDeployed();\n    }\n  }\n\n  async fallbackToCloneLatest(config) {\n    let clonedPkg;\n    try {\n      clonedPkg = (await this.applicationService.clone(this.selectedPackage)).data;\n\n      // clean out all falsely cloned applicationVersions, we don't need them\n      for (const appVersion of clonedPkg.applicationVersions as IApplicationVersion[]) {\n        if (appVersion.tags.includes('latest')) {\n          await this.ecosystemService.setPackageVersionTag(clonedPkg, appVersion.version, []);\n        }\n        await this.ecosystemService.deletePackageVersion(clonedPkg, {\n          version: appVersion.version\n        });\n      }\n      delete config.type;\n      config.isPackage = false;\n      const { data: newApp } = await this.ecosystemService.updateApp(\n        {\n          id: clonedPkg.id,\n          activeVersionId: clonedPkg.activeVersionId,\n          ...config\n        },\n        false\n      );\n      await this.ecosystemService.updateAppManifest(newApp, this.selectedPackage);\n      this.deployedWithSuccess = true;\n    } catch (error) {\n      await this.ecosystemService.deleteApp(clonedPkg.id, true);\n    }\n    this.markAsDeployed();\n  }\n\n  onAppVersionSelect(appVersion: IApplicationVersion) {\n    Object.assign(this.model, {\n      selected: appVersion\n    });\n    this.canDeploy = true;\n  }\n\n  async selectPackage(selectedPackage: IApplication) {\n    const apps = await this.ecosystemService.getHostedAndPackageApplications();\n    this.newAppConfig = this.ecosystemService.getUniqueAppConfig(selectedPackage, apps);\n    this.selectedPackage = selectedPackage;\n\n    this.loadSelectedPackageVersions();\n  }\n\n  private loadSelectedPackageVersions() {\n    this.versions$ = combineLatest([\n      this.getAppVersions(this.selectPackage),\n      this.onInput.asObservable()\n    ]).pipe(\n      map(([resultList, filterStr]) => {\n        this.canDeploy = false;\n        const versionsFilteredByStr = this.filterAppVersions(resultList.data, filterStr);\n        const sortedAppVersions = this.pluginsService.sortVersions(\n          {\n            list: versionsFilteredByStr,\n            path: ['version']\n          },\n          'desc'\n        );\n\n        this.setInitialValueForInput(sortedAppVersions);\n        return { data: sortedAppVersions, res: resultList.res };\n      })\n    );\n  }\n\n  private getAppVersions(mo: IApplication) {\n    const versions = mo?.applicationVersions;\n    return versions && versions.length > 0\n      ? of({ data: versions, res: undefined })\n      : from(this.applicationService.listVersions(this.selectedPackage.id));\n  }\n\n  private setInitialValueForInput(versions: IApplicationVersion[]) {\n    if (!this.model.selected && versions.length > 0) {\n      const latest = versions.find(v => v.tags.includes('latest'));\n      this.model.selected = latest || versions[0];\n      this.canDeploy = true;\n    }\n  }\n\n  private filterAppVersions(\n    appVersions: IApplicationVersion[],\n    filterStr: string\n  ): IApplicationVersion[] {\n    return filterStr === ''\n      ? appVersions\n      : appVersions.filter(appVersion => appVersion.version.includes(filterStr));\n  }\n\n  private markAsDeployed() {\n    this.isDeployed = true;\n    this.inProgress = false;\n  }\n\n  private async loadPackages(): Promise<void> {\n    const applications = await this.ecosystemService.getPackageApplications();\n    this.packages = applications.filter(app => this.ecosystemService.isPackageBlueprint(app));\n  }\n}\n","<c8y-wizard-header>\n  <i [c8yIcon]=\"'big-parcel'\"></i>\n  <h4 id=\"modal-title\" translate>Install from extension package</h4>\n</c8y-wizard-header>\n<c8y-wizard-body>\n  <ng-container *ngIf=\"!selectedPackage\">\n    <div class=\"modal-inner-scroll\" id=\"modal-body\">\n      <p class=\"p-16 text-medium text-center separator-bottom sticky-top bg-level-0\">\n        {{ 'Select from available extension packages' | translate }}\n      </p>\n\n      <c8y-ui-empty-state\n        *ngIf=\"!packages?.length\"\n        [icon]=\"'big-parcel'\"\n        [title]=\"'No extension packages to display.' | translate\"\n        [horizontal]=\"true\"\n      ></c8y-ui-empty-state>\n\n      <div *ngIf=\"packages?.length\" class=\"c8y-wizard-list-nav\" style=\"min-height: 257px\">\n        <button\n          class=\"list-group-item text-truncate\"\n          *ngFor=\"let package of packages\"\n          (click)=\"selectPackage(package)\"\n          title=\"{{ package.name }}\"\n          type=\"button\"\n        >\n          <i c8yIcon=\"big-parcel\" class=\"list-group-icon\"></i>\n          <span [innerText]=\"package.name\"></span>\n        </button>\n      </div>\n    </div>\n  </ng-container>\n  <ng-container *ngIf=\"!isDeployed && selectedPackage\">\n    <p class=\"p-16 text-center text-medium separator-bottom sticky-top bg-level-0\">\n      {{ 'Provide application details' | translate }}\n    </p>\n    <div class=\"d-flex d-col a-i-center j-c-center\" style=\"min-height: 257px\">\n      <c8y-application-properties-form\n        *ngIf=\"!inProgress\"\n        [application]=\"newAppConfig\"\n        class=\"d-block fit-w\"\n      ></c8y-application-properties-form>\n\n      <ng-container *ngIf=\"!inProgress\">\n        <div [ngStyle]=\"{ padding: '0 16px' }\" class=\"d-block fit-w bg-gray-white\">\n          <label for=\"packageVersion\" translate>Use extension package version</label>\n          <c8y-form-group>\n            <c8y-typeahead\n              [(ngModel)]=\"model.selected\"\n              name=\"packageVersion\"\n              (onSearch)=\"onInput.next($event)\"\n              placeholder=\"{{ 'Select or enter' | translate }}\"\n              [displayProperty]=\"'version'\"\n              [required]=\"true\"\n              [hideNew]=\"true\"\n              [container]=\"'body'\"\n            >\n              <c8y-li\n                *c8yFor=\"let version of versions$; loadMore: 'auto'; notFound: notFoundTemplate\"\n                (click)=\"onAppVersionSelect(version)\"\n                class=\"p-l-8 p-r-8 c8y-list__item--link\"\n                [active]=\"model.selected === version\"\n              >\n                <c8y-li-icon icon=\"big-parcel\"></c8y-li-icon>\n                <span\n                  [ngStyle]=\"{\n                    display: 'flex',\n                    'flex-direction': 'row',\n                    'align-content': 'center',\n                    'justify-content': 'space-between',\n                    'align-items': 'center'\n                  }\"\n                >\n                  <c8y-highlight\n                    [text]=\"version.version || '--'\"\n                    [pattern]=\"onInput | async\"\n                  ></c8y-highlight>\n\n                  <span>\n                    <span *ngFor=\"let tag of version.tags\" class=\"label label-info m-l-4\">\n                      {{ tag }}\n                    </span>\n                  </span>\n                </span>\n              </c8y-li>\n              <ng-template #notFoundTemplate>\n                <c8y-li\n                  class=\"bg-gray-lighter p-8\"\n                  *ngIf=\"(onInput | async)?.length > 0 && (versions$ | async)?.data?.length === 0\"\n                >\n                  <span translate>No match found.</span>\n                </c8y-li>\n              </ng-template>\n            </c8y-typeahead>\n          </c8y-form-group>\n        </div>\n      </ng-container>\n\n      <c8y-progress-bar\n        [message]=\"'Installing…' | translate\"\n        class=\"text-center d-block\"\n        *ngIf=\"inProgress\"\n      ></c8y-progress-bar>\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"isDeployed\">\n    <div\n      *ngIf=\"deployedWithSuccess; else failedDeploy\"\n      class=\"d-flex a-i-center j-c-center\"\n      style=\"min-height: 257px\"\n    >\n      <c8y-operation-result\n        text=\"{{ 'Application created' | translate }}\"\n        [size]=\"84\"\n        [vertical]=\"true\"\n        type=\"success\"\n        class=\"lead\"\n      ></c8y-operation-result>\n    </div>\n    <ng-template #failedDeploy>\n      <div class=\"d-flex a-i-center j-c-center\" style=\"min-height: 257px\">\n        <c8y-operation-result\n          text=\"{{ 'Application creation failed' | translate }}\"\n          [size]=\"84\"\n          [vertical]=\"true\"\n          type=\"error\"\n          class=\"lead\"\n        ></c8y-operation-result>\n      </div>\n    </ng-template>\n  </ng-container>\n</c8y-wizard-body>\n\n<c8y-wizard-footer>\n  <button\n    *ngIf=\"!isDeployed\"\n    (click)=\"selectedPackage ? clean() : back()\"\n    class=\"btn btn-default\"\n    title=\"{{ 'Back' | translate }}\"\n    [disabled]=\"inProgress\"\n    type=\"button\"\n  >\n    {{ 'Back' | translate }}\n  </button>\n  <button\n    title=\"{{ isDeployed && deployedWithSuccess ? ('Close' | translate) : ('Cancel' | translate) }}\"\n    class=\"btn btn-default\"\n    type=\"button\"\n    (click)=\"cancel()\"\n  >\n    {{ isDeployed && deployedWithSuccess ? ('Close' | translate) : ('Cancel' | translate) }}\n  </button>\n\n  <button\n    title=\"{{ 'Install' | translate }}\"\n    class=\"btn btn-primary\"\n    type=\"button\"\n    (click)=\"deployApp()\"\n    [disabled]=\"inProgress || !packages?.length\"\n    *ngIf=\"!isDeployed\"\n  >\n    {{ 'Install' | translate }}\n  </button>\n</c8y-wizard-footer>\n"]}
|
|
@@ -1,24 +1,23 @@
|
|
|
1
1
|
import { Component, ViewChild } from '@angular/core';
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
2
|
+
import { Router } from '@angular/router';
|
|
3
|
+
import { GainsightService, PluginsService, ViewContext, WizardComponent, gettext } from '@c8y/ngx-components';
|
|
4
4
|
import { ApplicationPropertiesFormComponent, EcosystemService, PRODUCT_EXPERIENCE } from '@c8y/ngx-components/ecosystem/shared';
|
|
5
5
|
import { TranslateService } from '@ngx-translate/core';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
import * as i1 from "@c8y/ngx-components/ecosystem/shared";
|
|
8
|
-
import * as i2 from "@c8y/
|
|
9
|
-
import * as i3 from "@
|
|
10
|
-
import * as i4 from "@
|
|
8
|
+
import * as i2 from "@c8y/ngx-components";
|
|
9
|
+
import * as i3 from "@ngx-translate/core";
|
|
10
|
+
import * as i4 from "@angular/router";
|
|
11
11
|
import * as i5 from "@angular/common";
|
|
12
12
|
import * as i6 from "@angular/forms";
|
|
13
13
|
export class DeployApplicationComponent {
|
|
14
|
-
constructor(ecosystemService,
|
|
14
|
+
constructor(ecosystemService, wizardComponent, translate, pluginService, gainsightService, router) {
|
|
15
15
|
this.ecosystemService = ecosystemService;
|
|
16
|
-
this.applicationService = applicationService;
|
|
17
16
|
this.wizardComponent = wizardComponent;
|
|
18
17
|
this.translate = translate;
|
|
19
|
-
this.inventoryService = inventoryService;
|
|
20
18
|
this.pluginService = pluginService;
|
|
21
19
|
this.gainsightService = gainsightService;
|
|
20
|
+
this.router = router;
|
|
22
21
|
this.CURRENT_LOCATION = location.href;
|
|
23
22
|
this.inProgress = true;
|
|
24
23
|
this.isDeployed = false;
|
|
@@ -37,7 +36,7 @@ export class DeployApplicationComponent {
|
|
|
37
36
|
this.package = this.wizardComponent.package;
|
|
38
37
|
}
|
|
39
38
|
async ngOnInit() {
|
|
40
|
-
const apps =
|
|
39
|
+
const apps = await this.ecosystemService.getHostedAndPackageApplications();
|
|
41
40
|
this.newAppConfig = this.ecosystemService.getUniqueAppConfig(this.package, apps);
|
|
42
41
|
this.headerText = this.getHeaderText();
|
|
43
42
|
this.inProgress = false;
|
|
@@ -45,11 +44,12 @@ export class DeployApplicationComponent {
|
|
|
45
44
|
async deployApp() {
|
|
46
45
|
this.inProgress = true;
|
|
47
46
|
const formGroupValue = this.applicationPropertiesForm.formGroup.getRawValue();
|
|
48
|
-
|
|
47
|
+
this.package.manifest.version = this.model.selected.version;
|
|
48
|
+
const { contextPath, license, name, manifest } = this.package;
|
|
49
49
|
const type = this.pluginService.getPackageType(this.package);
|
|
50
50
|
const licensedApp = {
|
|
51
51
|
contextPath,
|
|
52
|
-
license,
|
|
52
|
+
license: license || manifest.license,
|
|
53
53
|
name,
|
|
54
54
|
type,
|
|
55
55
|
version: this.model.selected.version
|
|
@@ -59,38 +59,9 @@ export class DeployApplicationComponent {
|
|
|
59
59
|
this.cancel();
|
|
60
60
|
return;
|
|
61
61
|
}
|
|
62
|
-
// Create new app config
|
|
63
|
-
const config = await this.ecosystemService.createConfig(this.package, formGroupValue);
|
|
64
|
-
config.version = this.model.selected.version;
|
|
65
|
-
config.isSetup = true;
|
|
66
|
-
if (!config.manifest) {
|
|
67
|
-
config.manifest = {};
|
|
68
|
-
}
|
|
69
|
-
config.manifest.isPackage = false;
|
|
70
|
-
config.manifest.source = this.package.id;
|
|
71
|
-
config.manifest.package = 'blueprint';
|
|
72
|
-
config.resourcesUrl = '/';
|
|
73
|
-
// Create new app
|
|
74
|
-
const newApp = (await this.applicationService.create(config)).data;
|
|
75
|
-
// Binary
|
|
76
62
|
try {
|
|
77
|
-
|
|
78
|
-
const { data: binaryDetails } = await this.inventoryService.detail(this.model.selected.binaryId);
|
|
79
|
-
// Get binary from specific package version
|
|
80
|
-
const binary = await this.ecosystemService.getBinary(this.package, {
|
|
81
|
-
id: this.model.selected.binaryId
|
|
82
|
-
});
|
|
83
|
-
// Create zip
|
|
84
|
-
const fileBinary = new Blob([binary], { type: binaryDetails.contentType });
|
|
85
|
-
const file = new File([fileBinary], binaryDetails.name, {
|
|
86
|
-
type: binaryDetails.contentType
|
|
87
|
-
});
|
|
88
|
-
// Upload binary to new app
|
|
89
|
-
await this.ecosystemService.uploadArchiveToApp(file, newApp);
|
|
90
|
-
// Update manifest
|
|
91
|
-
await this.ecosystemService.updateAppManifest(newApp, this.package);
|
|
63
|
+
this.deployedApp = await this.ecosystemService.deployApp(this.package, formGroupValue, this.model);
|
|
92
64
|
this.deployedWithSuccess = true;
|
|
93
|
-
this.applicationHref = this.applicationService.getHref(newApp);
|
|
94
65
|
this.gainsightService.triggerEvent(PRODUCT_EXPERIENCE.APPLICATIONS.EVENTS.DEPLOY_APPLICATION, {
|
|
95
66
|
component: PRODUCT_EXPERIENCE.APPLICATIONS.COMPONENTS.DEPLOY_APPLICATION,
|
|
96
67
|
action: PRODUCT_EXPERIENCE.APPLICATIONS.ACTIONS.DEPLOY_APPLICATION,
|
|
@@ -99,50 +70,18 @@ export class DeployApplicationComponent {
|
|
|
99
70
|
});
|
|
100
71
|
}
|
|
101
72
|
catch (error) {
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
url: this.CURRENT_LOCATION
|
|
110
|
-
});
|
|
111
|
-
}
|
|
73
|
+
this.ecosystemService.alertError(error);
|
|
74
|
+
this.gainsightService.triggerEvent(PRODUCT_EXPERIENCE.APPLICATIONS.EVENTS.DEPLOY_APPLICATION, {
|
|
75
|
+
component: PRODUCT_EXPERIENCE.APPLICATIONS.COMPONENTS.DEPLOY_APPLICATION,
|
|
76
|
+
action: PRODUCT_EXPERIENCE.APPLICATIONS.ACTIONS.DEPLOY_APPLICATION,
|
|
77
|
+
result: PRODUCT_EXPERIENCE.APPLICATIONS.RESULTS.SERVER_FAILURE,
|
|
78
|
+
url: this.CURRENT_LOCATION
|
|
79
|
+
});
|
|
112
80
|
}
|
|
113
81
|
finally {
|
|
114
82
|
this.markAsDeployed();
|
|
115
83
|
}
|
|
116
84
|
}
|
|
117
|
-
async fallbackToCloneLatest(config) {
|
|
118
|
-
let clonedPkg;
|
|
119
|
-
try {
|
|
120
|
-
clonedPkg = (await this.applicationService.clone(this.package)).data;
|
|
121
|
-
// clean out all falsely cloned applicationVersions, we don't need them
|
|
122
|
-
for (const appVersion of clonedPkg.applicationVersions) {
|
|
123
|
-
if (appVersion.tags.includes('latest')) {
|
|
124
|
-
await this.ecosystemService.setPackageVersionTag(clonedPkg, appVersion.version, []);
|
|
125
|
-
}
|
|
126
|
-
await this.ecosystemService.deletePackageVersion(clonedPkg, {
|
|
127
|
-
version: appVersion.version
|
|
128
|
-
});
|
|
129
|
-
}
|
|
130
|
-
delete config.type;
|
|
131
|
-
config.isPackage = false;
|
|
132
|
-
const { data: newApp } = await this.ecosystemService.updateApp({
|
|
133
|
-
id: clonedPkg.id,
|
|
134
|
-
activeVersionId: clonedPkg.activeVersionId,
|
|
135
|
-
...config
|
|
136
|
-
}, false);
|
|
137
|
-
await this.ecosystemService.updateAppManifest(newApp, this.package);
|
|
138
|
-
this.deployedWithSuccess = true;
|
|
139
|
-
this.applicationHref = this.applicationService.getHref(newApp);
|
|
140
|
-
}
|
|
141
|
-
catch (error) {
|
|
142
|
-
await this.ecosystemService.deleteApp(clonedPkg.id, true);
|
|
143
|
-
}
|
|
144
|
-
this.markAsDeployed();
|
|
145
|
-
}
|
|
146
85
|
cancel() {
|
|
147
86
|
this.wizardComponent.close();
|
|
148
87
|
}
|
|
@@ -152,6 +91,10 @@ export class DeployApplicationComponent {
|
|
|
152
91
|
});
|
|
153
92
|
this.canDeploy = true;
|
|
154
93
|
}
|
|
94
|
+
open() {
|
|
95
|
+
this.router.navigateByUrl(ViewContext.Application.replace(':id', `${this.deployedApp.id}`));
|
|
96
|
+
this.cancel();
|
|
97
|
+
}
|
|
155
98
|
markAsDeployed() {
|
|
156
99
|
this.isDeployed = true;
|
|
157
100
|
this.inProgress = false;
|
|
@@ -162,13 +105,13 @@ export class DeployApplicationComponent {
|
|
|
162
105
|
});
|
|
163
106
|
}
|
|
164
107
|
}
|
|
165
|
-
DeployApplicationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DeployApplicationComponent, deps: [{ token: i1.EcosystemService }, { token: i2.
|
|
166
|
-
DeployApplicationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.6", type: DeployApplicationComponent, selector: "c8y-deploy-application", viewQueries: [{ propertyName: "applicationPropertiesForm", first: true, predicate: ApplicationPropertiesFormComponent, descendants: true }], ngImport: i0, template: "<c8y-wizard-header>\n <div class=\"modal-header dialog-header\">\n <i c8yIcon=\"output\"></i>\n <h4 id=\"modal-title\">{{ 'Deploy application' | translate }}</h4>\n </div>\n</c8y-wizard-header>\n\n<c8y-wizard-body id=\"modal-body\">\n <ng-container *ngIf=\"!isDeployed\">\n <div class=\"fadeIn animated d-flex a-i-center j-c-center d-col\" style=\"min-height: 309px\">\n <p\n class=\"bg-level-0 fit-w p-16 text-center text-medium sticky-top bg-level-0 separator-bottom\"\n *ngIf=\"!inProgress\"\n >\n {{ headerText | translate }}\n </p>\n <c8y-application-properties-form\n *ngIf=\"!inProgress\"\n [application]=\"newAppConfig\"\n class=\"d-block fit-w bg-level-1\"\n ></c8y-application-properties-form>\n\n <ng-container *ngIf=\"!inProgress\">\n <div [ngStyle]=\"{ padding: '0 16px' }\" class=\"d-block fit-w bg-gray-white\">\n <c8y-package-version-select\n [ngModel]=\"model.selected\"\n (ngModelChange)=\"onAppVersionSelect($event)\"\n [packageId]=\"package?.id\"\n [label]=\"'Use extension package version' | translate\"\n ></c8y-package-version-select>\n </div>\n </ng-container>\n\n <c8y-progress-bar\n *ngIf=\"inProgress\"\n [message]=\"'Deploying\u2026' | translate\"\n class=\"text-center\"\n ></c8y-progress-bar>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"isDeployed\">\n <div\n *ngIf=\"deployedWithSuccess; else failedDeploy\"\n class=\"modal-body fadeIn animated\"\n style=\"min-height: 309px\"\n >\n <div class=\"d-flex a-i-center j-c-center d-col\">\n <c8y-operation-result\n type=\"success\"\n [size]=\"84\"\n [vertical]=\"true\"\n [text]=\"successMessageTemplate | translate: { packageName: package.name }\"\n class=\"lead d-block m-b-16\"\n ></c8y-operation-result>\n </div>\n </div>\n <ng-template #failedDeploy>\n <div class=\"modal-body fadeIn animated text-center\" style=\"min-height: 257px\">\n <c8y-operation-result\n type=\"error\"\n [size]=\"84\"\n [vertical]=\"true\"\n text=\"{{ 'Application creation failed' | translate }}\"\n class=\"lead\"\n ></c8y-operation-result>\n </div>\n </ng-template>\n </ng-container>\n</c8y-wizard-body>\n\n<c8y-wizard-footer>\n <button\n (click)=\"cancel()\"\n type=\"button\"\n class=\"btn btn-default\"\n title=\"{{ (isDeployed && deployedWithSuccess ? doneLabel : cancelLabel) | translate }}\"\n >\n {{ (isDeployed && deployedWithSuccess ? doneLabel : cancelLabel) | translate }}\n </button>\n\n <button\n (click)=\"deployApp()\"\n *ngIf=\"!isDeployed\"\n [disabled]=\"inProgress || !canDeploy\"\n [ngClass]=\"{ 'btn-pending': inProgress }\"\n class=\"btn btn-primary\"\n type=\"button\"\n title=\"{{ 'Deploy' | translate }}\"\n >\n {{ 'Deploy' | translate }}\n </button>\n\n <
|
|
108
|
+
DeployApplicationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DeployApplicationComponent, deps: [{ token: i1.EcosystemService }, { token: i2.WizardComponent }, { token: i3.TranslateService }, { token: i2.PluginsService }, { token: i2.GainsightService }, { token: i4.Router }], target: i0.ɵɵFactoryTarget.Component });
|
|
109
|
+
DeployApplicationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.6", type: DeployApplicationComponent, selector: "c8y-deploy-application", viewQueries: [{ propertyName: "applicationPropertiesForm", first: true, predicate: ApplicationPropertiesFormComponent, descendants: true }], ngImport: i0, template: "<c8y-wizard-header>\n <div class=\"modal-header dialog-header\">\n <i c8yIcon=\"output\"></i>\n <h4 id=\"modal-title\">{{ 'Deploy application' | translate }}</h4>\n </div>\n</c8y-wizard-header>\n\n<c8y-wizard-body id=\"modal-body\">\n <ng-container *ngIf=\"!isDeployed\">\n <div class=\"fadeIn animated d-flex a-i-center j-c-center d-col\" style=\"min-height: 309px\">\n <p\n class=\"bg-level-0 fit-w p-16 text-center text-medium sticky-top bg-level-0 separator-bottom\"\n *ngIf=\"!inProgress\"\n >\n {{ headerText | translate }}\n </p>\n <c8y-application-properties-form\n *ngIf=\"!inProgress\"\n [application]=\"newAppConfig\"\n class=\"d-block fit-w bg-level-1\"\n ></c8y-application-properties-form>\n\n <ng-container *ngIf=\"!inProgress\">\n <div [ngStyle]=\"{ padding: '0 16px' }\" class=\"d-block fit-w bg-gray-white\">\n <c8y-package-version-select\n [ngModel]=\"model.selected\"\n (ngModelChange)=\"onAppVersionSelect($event)\"\n [packageId]=\"package?.id\"\n [label]=\"'Use extension package version' | translate\"\n ></c8y-package-version-select>\n </div>\n </ng-container>\n\n <c8y-progress-bar\n *ngIf=\"inProgress\"\n [message]=\"'Deploying\u2026' | translate\"\n class=\"text-center\"\n ></c8y-progress-bar>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"isDeployed\">\n <div\n *ngIf=\"deployedWithSuccess; else failedDeploy\"\n class=\"modal-body fadeIn animated\"\n style=\"min-height: 309px\"\n >\n <div class=\"d-flex a-i-center j-c-center d-col\">\n <c8y-operation-result\n type=\"success\"\n [size]=\"84\"\n [vertical]=\"true\"\n [text]=\"successMessageTemplate | translate: { packageName: package.name }\"\n class=\"lead d-block m-b-16\"\n ></c8y-operation-result>\n </div>\n </div>\n <ng-template #failedDeploy>\n <div class=\"modal-body fadeIn animated text-center\" style=\"min-height: 257px\">\n <c8y-operation-result\n type=\"error\"\n [size]=\"84\"\n [vertical]=\"true\"\n text=\"{{ 'Application creation failed' | translate }}\"\n class=\"lead\"\n ></c8y-operation-result>\n </div>\n </ng-template>\n </ng-container>\n</c8y-wizard-body>\n\n<c8y-wizard-footer>\n <button\n (click)=\"cancel()\"\n type=\"button\"\n class=\"btn btn-default\"\n title=\"{{ (isDeployed && deployedWithSuccess ? doneLabel : cancelLabel) | translate }}\"\n >\n {{ (isDeployed && deployedWithSuccess ? doneLabel : cancelLabel) | translate }}\n </button>\n\n <button\n (click)=\"deployApp()\"\n *ngIf=\"!isDeployed\"\n [disabled]=\"inProgress || !canDeploy\"\n [ngClass]=\"{ 'btn-pending': inProgress }\"\n class=\"btn btn-primary\"\n type=\"button\"\n title=\"{{ 'Deploy' | translate }}\"\n >\n {{ 'Deploy' | translate }}\n </button>\n\n <button\n (click)=\"open()\"\n type=\"button\"\n class=\"btn btn-primary\"\n *ngIf=\"isDeployed && deployedWithSuccess\"\n title=\"{{ 'Open the application details' | translate }}\"\n translate\n >\n Open\n </button>\n</c8y-wizard-footer>\n", dependencies: [{ kind: "directive", type: i2.IconDirective, selector: "[c8yIcon]", inputs: ["c8yIcon"] }, { kind: "directive", type: i2.C8yTranslateDirective, selector: "[translate],[ngx-translate]" }, { kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.ProgressBarComponent, selector: "c8y-progress-bar", inputs: ["message", "progress"] }, { kind: "component", type: i2.OperationResultComponent, selector: "c8y-operation-result", inputs: ["text", "vertical", "size", "type"] }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i2.WizardHeaderComponent, selector: "c8y-wizard-header" }, { kind: "component", type: i2.WizardBodyComponent, selector: "c8y-wizard-body" }, { kind: "component", type: i2.WizardFooterComponent, selector: "c8y-wizard-footer" }, { kind: "component", type: i1.ApplicationPropertiesFormComponent, selector: "c8y-application-properties-form", inputs: ["application", "disabled"] }, { kind: "component", type: i1.PackageVersionSelectComponent, selector: "c8y-package-version-select", inputs: ["label", "packageContextPath", "packageId"] }, { kind: "pipe", type: i2.C8yTranslatePipe, name: "translate" }] });
|
|
167
110
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.6", ngImport: i0, type: DeployApplicationComponent, decorators: [{
|
|
168
111
|
type: Component,
|
|
169
|
-
args: [{ selector: 'c8y-deploy-application', template: "<c8y-wizard-header>\n <div class=\"modal-header dialog-header\">\n <i c8yIcon=\"output\"></i>\n <h4 id=\"modal-title\">{{ 'Deploy application' | translate }}</h4>\n </div>\n</c8y-wizard-header>\n\n<c8y-wizard-body id=\"modal-body\">\n <ng-container *ngIf=\"!isDeployed\">\n <div class=\"fadeIn animated d-flex a-i-center j-c-center d-col\" style=\"min-height: 309px\">\n <p\n class=\"bg-level-0 fit-w p-16 text-center text-medium sticky-top bg-level-0 separator-bottom\"\n *ngIf=\"!inProgress\"\n >\n {{ headerText | translate }}\n </p>\n <c8y-application-properties-form\n *ngIf=\"!inProgress\"\n [application]=\"newAppConfig\"\n class=\"d-block fit-w bg-level-1\"\n ></c8y-application-properties-form>\n\n <ng-container *ngIf=\"!inProgress\">\n <div [ngStyle]=\"{ padding: '0 16px' }\" class=\"d-block fit-w bg-gray-white\">\n <c8y-package-version-select\n [ngModel]=\"model.selected\"\n (ngModelChange)=\"onAppVersionSelect($event)\"\n [packageId]=\"package?.id\"\n [label]=\"'Use extension package version' | translate\"\n ></c8y-package-version-select>\n </div>\n </ng-container>\n\n <c8y-progress-bar\n *ngIf=\"inProgress\"\n [message]=\"'Deploying\u2026' | translate\"\n class=\"text-center\"\n ></c8y-progress-bar>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"isDeployed\">\n <div\n *ngIf=\"deployedWithSuccess; else failedDeploy\"\n class=\"modal-body fadeIn animated\"\n style=\"min-height: 309px\"\n >\n <div class=\"d-flex a-i-center j-c-center d-col\">\n <c8y-operation-result\n type=\"success\"\n [size]=\"84\"\n [vertical]=\"true\"\n [text]=\"successMessageTemplate | translate: { packageName: package.name }\"\n class=\"lead d-block m-b-16\"\n ></c8y-operation-result>\n </div>\n </div>\n <ng-template #failedDeploy>\n <div class=\"modal-body fadeIn animated text-center\" style=\"min-height: 257px\">\n <c8y-operation-result\n type=\"error\"\n [size]=\"84\"\n [vertical]=\"true\"\n text=\"{{ 'Application creation failed' | translate }}\"\n class=\"lead\"\n ></c8y-operation-result>\n </div>\n </ng-template>\n </ng-container>\n</c8y-wizard-body>\n\n<c8y-wizard-footer>\n <button\n (click)=\"cancel()\"\n type=\"button\"\n class=\"btn btn-default\"\n title=\"{{ (isDeployed && deployedWithSuccess ? doneLabel : cancelLabel) | translate }}\"\n >\n {{ (isDeployed && deployedWithSuccess ? doneLabel : cancelLabel) | translate }}\n </button>\n\n <button\n (click)=\"deployApp()\"\n *ngIf=\"!isDeployed\"\n [disabled]=\"inProgress || !canDeploy\"\n [ngClass]=\"{ 'btn-pending': inProgress }\"\n class=\"btn btn-primary\"\n type=\"button\"\n title=\"{{ 'Deploy' | translate }}\"\n >\n {{ 'Deploy' | translate }}\n </button>\n\n <
|
|
170
|
-
}], ctorParameters: function () { return [{ type: i1.EcosystemService }, { type: i2.
|
|
112
|
+
args: [{ selector: 'c8y-deploy-application', template: "<c8y-wizard-header>\n <div class=\"modal-header dialog-header\">\n <i c8yIcon=\"output\"></i>\n <h4 id=\"modal-title\">{{ 'Deploy application' | translate }}</h4>\n </div>\n</c8y-wizard-header>\n\n<c8y-wizard-body id=\"modal-body\">\n <ng-container *ngIf=\"!isDeployed\">\n <div class=\"fadeIn animated d-flex a-i-center j-c-center d-col\" style=\"min-height: 309px\">\n <p\n class=\"bg-level-0 fit-w p-16 text-center text-medium sticky-top bg-level-0 separator-bottom\"\n *ngIf=\"!inProgress\"\n >\n {{ headerText | translate }}\n </p>\n <c8y-application-properties-form\n *ngIf=\"!inProgress\"\n [application]=\"newAppConfig\"\n class=\"d-block fit-w bg-level-1\"\n ></c8y-application-properties-form>\n\n <ng-container *ngIf=\"!inProgress\">\n <div [ngStyle]=\"{ padding: '0 16px' }\" class=\"d-block fit-w bg-gray-white\">\n <c8y-package-version-select\n [ngModel]=\"model.selected\"\n (ngModelChange)=\"onAppVersionSelect($event)\"\n [packageId]=\"package?.id\"\n [label]=\"'Use extension package version' | translate\"\n ></c8y-package-version-select>\n </div>\n </ng-container>\n\n <c8y-progress-bar\n *ngIf=\"inProgress\"\n [message]=\"'Deploying\u2026' | translate\"\n class=\"text-center\"\n ></c8y-progress-bar>\n </div>\n </ng-container>\n\n <ng-container *ngIf=\"isDeployed\">\n <div\n *ngIf=\"deployedWithSuccess; else failedDeploy\"\n class=\"modal-body fadeIn animated\"\n style=\"min-height: 309px\"\n >\n <div class=\"d-flex a-i-center j-c-center d-col\">\n <c8y-operation-result\n type=\"success\"\n [size]=\"84\"\n [vertical]=\"true\"\n [text]=\"successMessageTemplate | translate: { packageName: package.name }\"\n class=\"lead d-block m-b-16\"\n ></c8y-operation-result>\n </div>\n </div>\n <ng-template #failedDeploy>\n <div class=\"modal-body fadeIn animated text-center\" style=\"min-height: 257px\">\n <c8y-operation-result\n type=\"error\"\n [size]=\"84\"\n [vertical]=\"true\"\n text=\"{{ 'Application creation failed' | translate }}\"\n class=\"lead\"\n ></c8y-operation-result>\n </div>\n </ng-template>\n </ng-container>\n</c8y-wizard-body>\n\n<c8y-wizard-footer>\n <button\n (click)=\"cancel()\"\n type=\"button\"\n class=\"btn btn-default\"\n title=\"{{ (isDeployed && deployedWithSuccess ? doneLabel : cancelLabel) | translate }}\"\n >\n {{ (isDeployed && deployedWithSuccess ? doneLabel : cancelLabel) | translate }}\n </button>\n\n <button\n (click)=\"deployApp()\"\n *ngIf=\"!isDeployed\"\n [disabled]=\"inProgress || !canDeploy\"\n [ngClass]=\"{ 'btn-pending': inProgress }\"\n class=\"btn btn-primary\"\n type=\"button\"\n title=\"{{ 'Deploy' | translate }}\"\n >\n {{ 'Deploy' | translate }}\n </button>\n\n <button\n (click)=\"open()\"\n type=\"button\"\n class=\"btn btn-primary\"\n *ngIf=\"isDeployed && deployedWithSuccess\"\n title=\"{{ 'Open the application details' | translate }}\"\n translate\n >\n Open\n </button>\n</c8y-wizard-footer>\n" }]
|
|
113
|
+
}], ctorParameters: function () { return [{ type: i1.EcosystemService }, { type: i2.WizardComponent }, { type: i3.TranslateService }, { type: i2.PluginsService }, { type: i2.GainsightService }, { type: i4.Router }]; }, propDecorators: { applicationPropertiesForm: [{
|
|
171
114
|
type: ViewChild,
|
|
172
115
|
args: [ApplicationPropertiesFormComponent]
|
|
173
116
|
}] } });
|
|
174
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"deploy-application.component.js","sourceRoot":"","sources":["../../../../../ecosystem/packages/deploy-application/deploy-application.component.ts","../../../../../ecosystem/packages/deploy-application/deploy-application.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild } from '@angular/core';\nimport {\n  ApplicationService,\n  IApplication,\n  IApplicationVersion,\n  InventoryService\n} from '@c8y/client';\nimport { gettext, PluginsService, WizardComponent, GainsightService } from '@c8y/ngx-components';\nimport {\n  ApplicationPropertiesFormComponent,\n  EcosystemService,\n  LicensedApplicationPlugin,\n  PRODUCT_EXPERIENCE\n} from '@c8y/ngx-components/ecosystem/shared';\nimport { TranslateService } from '@ngx-translate/core';\n\n@Component({\n  selector: 'c8y-deploy-application',\n  templateUrl: './deploy-application.component.html'\n})\nexport class DeployApplicationComponent implements OnInit {\n  CURRENT_LOCATION = location.href;\n\n  inProgress = true;\n  package: IApplication;\n  isDeployed = false;\n  deployedWithSuccess = false;\n  newAppConfig: IApplication;\n  applicationHref: string;\n\n  model = {\n    selected: undefined,\n    binary: {\n      id: undefined\n    }\n  };\n  canDeploy = false;\n\n  @ViewChild(ApplicationPropertiesFormComponent)\n  applicationPropertiesForm: ApplicationPropertiesFormComponent;\n\n  readonly descriptionTemplate: string = gettext(\n    'Deploy application using \"{{ packageName }}\" package'\n  );\n  readonly successMessageTemplate = gettext('Application \"{{ packageName }}\" created');\n  readonly doneLabel = gettext('Done');\n  readonly cancelLabel = gettext('Cancel');\n  headerText: string;\n\n  constructor(\n    private ecosystemService: EcosystemService,\n    private applicationService: ApplicationService,\n    private wizardComponent: WizardComponent,\n    private translate: TranslateService,\n    private inventoryService: InventoryService,\n    private pluginService: PluginsService,\n    private gainsightService: GainsightService\n  ) {\n    this.package = (this.wizardComponent as any).package;\n  }\n\n  async ngOnInit() {\n    const apps = (await this.ecosystemService.getApplications()).data;\n    this.newAppConfig = this.ecosystemService.getUniqueAppConfig(this.package, apps);\n    this.headerText = this.getHeaderText();\n    this.inProgress = false;\n  }\n\n  async deployApp() {\n    this.inProgress = true;\n    const formGroupValue = this.applicationPropertiesForm.formGroup.getRawValue();\n\n    const { contextPath, license, name } = this.package;\n    const type = this.pluginService.getPackageType(this.package);\n    const licensedApp: LicensedApplicationPlugin = {\n      contextPath,\n      license,\n      name,\n      type,\n      version: this.model.selected.version\n    };\n    const licensesVerifiedByUser = await this.ecosystemService.verifyLicenses([licensedApp]);\n    if (!licensesVerifiedByUser) {\n      this.cancel();\n      return;\n    }\n\n    // Create new app config\n    const config = await this.ecosystemService.createConfig(this.package, formGroupValue);\n    config.version = this.model.selected.version;\n    config.isSetup = true;\n    if (!config.manifest) {\n      config.manifest = {};\n    }\n    config.manifest.isPackage = false;\n    config.manifest.source = this.package.id;\n    config.manifest.package = 'blueprint';\n    config.resourcesUrl = '/';\n\n    // Create new app\n    const newApp = (await this.applicationService.create(config)).data;\n    // Binary\n    try {\n      // Get binary details\n      const { data: binaryDetails } = await this.inventoryService.detail(\n        this.model.selected.binaryId\n      );\n\n      // Get binary from specific package version\n      const binary = await this.ecosystemService.getBinary(this.package, {\n        id: this.model.selected.binaryId\n      });\n      // Create zip\n      const fileBinary = new Blob([binary], { type: binaryDetails.contentType });\n      const file = new File([fileBinary], binaryDetails.name, {\n        type: binaryDetails.contentType\n      });\n\n      // Upload binary to new app\n      await this.ecosystemService.uploadArchiveToApp(file, newApp);\n      // Update manifest\n      await this.ecosystemService.updateAppManifest(newApp, this.package);\n\n      this.deployedWithSuccess = true;\n      this.applicationHref = this.applicationService.getHref(newApp);\n      this.gainsightService.triggerEvent(\n        PRODUCT_EXPERIENCE.APPLICATIONS.EVENTS.DEPLOY_APPLICATION,\n        {\n          component: PRODUCT_EXPERIENCE.APPLICATIONS.COMPONENTS.DEPLOY_APPLICATION,\n          action: PRODUCT_EXPERIENCE.APPLICATIONS.ACTIONS.DEPLOY_APPLICATION,\n          result: PRODUCT_EXPERIENCE.APPLICATIONS.RESULTS.DEPLOYED,\n          url: this.CURRENT_LOCATION\n        }\n      );\n    } catch (error) {\n      if (error?.res?.status === 404) {\n        await this.applicationService.delete(newApp.id);\n        await this.fallbackToCloneLatest(config);\n        this.gainsightService.triggerEvent(\n          PRODUCT_EXPERIENCE.APPLICATIONS.EVENTS.DEPLOY_APPLICATION,\n          {\n            component: PRODUCT_EXPERIENCE.APPLICATIONS.COMPONENTS.DEPLOY_APPLICATION,\n            action: PRODUCT_EXPERIENCE.APPLICATIONS.ACTIONS.DEPLOY_APPLICATION,\n            result: PRODUCT_EXPERIENCE.APPLICATIONS.RESULTS.SERVER_FAILURE,\n            url: this.CURRENT_LOCATION\n          }\n        );\n      }\n    } finally {\n      this.markAsDeployed();\n    }\n  }\n\n  async fallbackToCloneLatest(config) {\n    let clonedPkg;\n    try {\n      clonedPkg = (await this.applicationService.clone(this.package)).data;\n\n      // clean out all falsely cloned applicationVersions, we don't need them\n      for (const appVersion of clonedPkg.applicationVersions as IApplicationVersion[]) {\n        if (appVersion.tags.includes('latest')) {\n          await this.ecosystemService.setPackageVersionTag(clonedPkg, appVersion.version, []);\n        }\n        await this.ecosystemService.deletePackageVersion(clonedPkg, {\n          version: appVersion.version\n        });\n      }\n      delete config.type;\n      config.isPackage = false;\n      const { data: newApp } = await this.ecosystemService.updateApp(\n        {\n          id: clonedPkg.id,\n          activeVersionId: clonedPkg.activeVersionId,\n          ...config\n        },\n        false\n      );\n      await this.ecosystemService.updateAppManifest(newApp, this.package);\n      this.deployedWithSuccess = true;\n      this.applicationHref = this.applicationService.getHref(newApp);\n    } catch (error) {\n      await this.ecosystemService.deleteApp(clonedPkg.id, true);\n    }\n    this.markAsDeployed();\n  }\n\n  cancel() {\n    this.wizardComponent.close();\n  }\n\n  onAppVersionSelect(appVersion: IApplicationVersion) {\n    Object.assign(this.model, {\n      selected: appVersion\n    });\n    this.canDeploy = true;\n  }\n\n  private markAsDeployed() {\n    this.isDeployed = true;\n    this.inProgress = false;\n  }\n\n  private getHeaderText() {\n    return this.translate.instant(this.descriptionTemplate, {\n      packageName: this.package.name\n    });\n  }\n}\n","<c8y-wizard-header>\n  <div class=\"modal-header dialog-header\">\n    <i c8yIcon=\"output\"></i>\n    <h4 id=\"modal-title\">{{ 'Deploy application' | translate }}</h4>\n  </div>\n</c8y-wizard-header>\n\n<c8y-wizard-body id=\"modal-body\">\n  <ng-container *ngIf=\"!isDeployed\">\n    <div class=\"fadeIn animated d-flex a-i-center j-c-center d-col\" style=\"min-height: 309px\">\n      <p\n        class=\"bg-level-0 fit-w p-16 text-center text-medium sticky-top bg-level-0 separator-bottom\"\n        *ngIf=\"!inProgress\"\n      >\n        {{ headerText | translate }}\n      </p>\n      <c8y-application-properties-form\n        *ngIf=\"!inProgress\"\n        [application]=\"newAppConfig\"\n        class=\"d-block fit-w bg-level-1\"\n      ></c8y-application-properties-form>\n\n      <ng-container *ngIf=\"!inProgress\">\n        <div [ngStyle]=\"{ padding: '0 16px' }\" class=\"d-block fit-w bg-gray-white\">\n          <c8y-package-version-select\n            [ngModel]=\"model.selected\"\n            (ngModelChange)=\"onAppVersionSelect($event)\"\n            [packageId]=\"package?.id\"\n            [label]=\"'Use extension package version' | translate\"\n          ></c8y-package-version-select>\n        </div>\n      </ng-container>\n\n      <c8y-progress-bar\n        *ngIf=\"inProgress\"\n        [message]=\"'Deploying…' | translate\"\n        class=\"text-center\"\n      ></c8y-progress-bar>\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"isDeployed\">\n    <div\n      *ngIf=\"deployedWithSuccess; else failedDeploy\"\n      class=\"modal-body fadeIn animated\"\n      style=\"min-height: 309px\"\n    >\n      <div class=\"d-flex a-i-center j-c-center d-col\">\n        <c8y-operation-result\n          type=\"success\"\n          [size]=\"84\"\n          [vertical]=\"true\"\n          [text]=\"successMessageTemplate | translate: { packageName: package.name }\"\n          class=\"lead d-block m-b-16\"\n        ></c8y-operation-result>\n      </div>\n    </div>\n    <ng-template #failedDeploy>\n      <div class=\"modal-body fadeIn animated text-center\" style=\"min-height: 257px\">\n        <c8y-operation-result\n          type=\"error\"\n          [size]=\"84\"\n          [vertical]=\"true\"\n          text=\"{{ 'Application creation failed' | translate }}\"\n          class=\"lead\"\n        ></c8y-operation-result>\n      </div>\n    </ng-template>\n  </ng-container>\n</c8y-wizard-body>\n\n<c8y-wizard-footer>\n  <button\n    (click)=\"cancel()\"\n    type=\"button\"\n    class=\"btn btn-default\"\n    title=\"{{ (isDeployed && deployedWithSuccess ? doneLabel : cancelLabel) | translate }}\"\n  >\n    {{ (isDeployed && deployedWithSuccess ? doneLabel : cancelLabel) | translate }}\n  </button>\n\n  <button\n    (click)=\"deployApp()\"\n    *ngIf=\"!isDeployed\"\n    [disabled]=\"inProgress || !canDeploy\"\n    [ngClass]=\"{ 'btn-pending': inProgress }\"\n    class=\"btn btn-primary\"\n    type=\"button\"\n    title=\"{{ 'Deploy' | translate }}\"\n  >\n    {{ 'Deploy' | translate }}\n  </button>\n\n  <a\n    *ngIf=\"isDeployed && applicationHref\"\n    [href]=\"applicationHref\"\n    target=\"_blank\"\n    rel=\"noopener noreferrer\"\n    class=\"btn btn-primary\"\n    title=\"{{ 'Open' | translate }}\"\n  >\n    <i c8yIcon=\"external-link\" class=\"m-r-4\"></i>\n    {{ 'Open' | translate }}\n  </a>\n</c8y-wizard-footer>\n"]}
|
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"deploy-application.component.js","sourceRoot":"","sources":["../../../../../ecosystem/packages/deploy-application/deploy-application.component.ts","../../../../../ecosystem/packages/deploy-application/deploy-application.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { IApplication, IApplicationVersion } from '@c8y/client';\nimport {\n  GainsightService,\n  PluginsService,\n  ViewContext,\n  WizardComponent,\n  gettext\n} from '@c8y/ngx-components';\nimport {\n  ApplicationPropertiesFormComponent,\n  EcosystemService,\n  LicensedApplicationPlugin,\n  PRODUCT_EXPERIENCE\n} from '@c8y/ngx-components/ecosystem/shared';\nimport { TranslateService } from '@ngx-translate/core';\n\n@Component({\n  selector: 'c8y-deploy-application',\n  templateUrl: './deploy-application.component.html'\n})\nexport class DeployApplicationComponent implements OnInit {\n  CURRENT_LOCATION = location.href;\n\n  inProgress = true;\n  package: IApplication;\n  isDeployed = false;\n  deployedWithSuccess = false;\n  newAppConfig: IApplication;\n  deployedApp: IApplication;\n  applicationHref: string;\n\n  model = {\n    selected: undefined,\n    binary: {\n      id: undefined\n    }\n  };\n  canDeploy = false;\n\n  @ViewChild(ApplicationPropertiesFormComponent)\n  applicationPropertiesForm: ApplicationPropertiesFormComponent;\n\n  readonly descriptionTemplate: string = gettext(\n    'Deploy application using \"{{ packageName }}\" package'\n  );\n  readonly successMessageTemplate = gettext('Application \"{{ packageName }}\" created');\n  readonly doneLabel = gettext('Done');\n  readonly cancelLabel = gettext('Cancel');\n  headerText: string;\n\n  constructor(\n    private ecosystemService: EcosystemService,\n    private wizardComponent: WizardComponent,\n    private translate: TranslateService,\n    private pluginService: PluginsService,\n    private gainsightService: GainsightService,\n    private router: Router\n  ) {\n    this.package = (this.wizardComponent as any).package;\n  }\n\n  async ngOnInit() {\n    const apps = await this.ecosystemService.getHostedAndPackageApplications();\n    this.newAppConfig = this.ecosystemService.getUniqueAppConfig(this.package, apps);\n    this.headerText = this.getHeaderText();\n    this.inProgress = false;\n  }\n\n  async deployApp() {\n    this.inProgress = true;\n    const formGroupValue = this.applicationPropertiesForm.formGroup.getRawValue();\n    this.package.manifest.version = this.model.selected.version;\n\n    const { contextPath, license, name, manifest } = this.package;\n    const type = this.pluginService.getPackageType(this.package);\n    const licensedApp: LicensedApplicationPlugin = {\n      contextPath,\n      license: license || manifest.license,\n      name,\n      type,\n      version: this.model.selected.version\n    };\n\n    const licensesVerifiedByUser = await this.ecosystemService.verifyLicenses([licensedApp]);\n    if (!licensesVerifiedByUser) {\n      this.cancel();\n      return;\n    }\n\n    try {\n      this.deployedApp = await this.ecosystemService.deployApp(\n        this.package,\n        formGroupValue,\n        this.model\n      );\n      this.deployedWithSuccess = true;\n      this.gainsightService.triggerEvent(\n        PRODUCT_EXPERIENCE.APPLICATIONS.EVENTS.DEPLOY_APPLICATION,\n        {\n          component: PRODUCT_EXPERIENCE.APPLICATIONS.COMPONENTS.DEPLOY_APPLICATION,\n          action: PRODUCT_EXPERIENCE.APPLICATIONS.ACTIONS.DEPLOY_APPLICATION,\n          result: PRODUCT_EXPERIENCE.APPLICATIONS.RESULTS.DEPLOYED,\n          url: this.CURRENT_LOCATION\n        }\n      );\n    } catch (error) {\n      this.ecosystemService.alertError(error);\n      this.gainsightService.triggerEvent(\n        PRODUCT_EXPERIENCE.APPLICATIONS.EVENTS.DEPLOY_APPLICATION,\n        {\n          component: PRODUCT_EXPERIENCE.APPLICATIONS.COMPONENTS.DEPLOY_APPLICATION,\n          action: PRODUCT_EXPERIENCE.APPLICATIONS.ACTIONS.DEPLOY_APPLICATION,\n          result: PRODUCT_EXPERIENCE.APPLICATIONS.RESULTS.SERVER_FAILURE,\n          url: this.CURRENT_LOCATION\n        }\n      );\n    } finally {\n      this.markAsDeployed();\n    }\n  }\n\n  cancel() {\n    this.wizardComponent.close();\n  }\n\n  onAppVersionSelect(appVersion: IApplicationVersion) {\n    Object.assign(this.model, {\n      selected: appVersion\n    });\n    this.canDeploy = true;\n  }\n\n  open() {\n    this.router.navigateByUrl(ViewContext.Application.replace(':id', `${this.deployedApp.id}`));\n    this.cancel();\n  }\n\n  private markAsDeployed() {\n    this.isDeployed = true;\n    this.inProgress = false;\n  }\n\n  private getHeaderText() {\n    return this.translate.instant(this.descriptionTemplate, {\n      packageName: this.package.name\n    });\n  }\n}\n","<c8y-wizard-header>\n  <div class=\"modal-header dialog-header\">\n    <i c8yIcon=\"output\"></i>\n    <h4 id=\"modal-title\">{{ 'Deploy application' | translate }}</h4>\n  </div>\n</c8y-wizard-header>\n\n<c8y-wizard-body id=\"modal-body\">\n  <ng-container *ngIf=\"!isDeployed\">\n    <div class=\"fadeIn animated d-flex a-i-center j-c-center d-col\" style=\"min-height: 309px\">\n      <p\n        class=\"bg-level-0 fit-w p-16 text-center text-medium sticky-top bg-level-0 separator-bottom\"\n        *ngIf=\"!inProgress\"\n      >\n        {{ headerText | translate }}\n      </p>\n      <c8y-application-properties-form\n        *ngIf=\"!inProgress\"\n        [application]=\"newAppConfig\"\n        class=\"d-block fit-w bg-level-1\"\n      ></c8y-application-properties-form>\n\n      <ng-container *ngIf=\"!inProgress\">\n        <div [ngStyle]=\"{ padding: '0 16px' }\" class=\"d-block fit-w bg-gray-white\">\n          <c8y-package-version-select\n            [ngModel]=\"model.selected\"\n            (ngModelChange)=\"onAppVersionSelect($event)\"\n            [packageId]=\"package?.id\"\n            [label]=\"'Use extension package version' | translate\"\n          ></c8y-package-version-select>\n        </div>\n      </ng-container>\n\n      <c8y-progress-bar\n        *ngIf=\"inProgress\"\n        [message]=\"'Deploying…' | translate\"\n        class=\"text-center\"\n      ></c8y-progress-bar>\n    </div>\n  </ng-container>\n\n  <ng-container *ngIf=\"isDeployed\">\n    <div\n      *ngIf=\"deployedWithSuccess; else failedDeploy\"\n      class=\"modal-body fadeIn animated\"\n      style=\"min-height: 309px\"\n    >\n      <div class=\"d-flex a-i-center j-c-center d-col\">\n        <c8y-operation-result\n          type=\"success\"\n          [size]=\"84\"\n          [vertical]=\"true\"\n          [text]=\"successMessageTemplate | translate: { packageName: package.name }\"\n          class=\"lead d-block m-b-16\"\n        ></c8y-operation-result>\n      </div>\n    </div>\n    <ng-template #failedDeploy>\n      <div class=\"modal-body fadeIn animated text-center\" style=\"min-height: 257px\">\n        <c8y-operation-result\n          type=\"error\"\n          [size]=\"84\"\n          [vertical]=\"true\"\n          text=\"{{ 'Application creation failed' | translate }}\"\n          class=\"lead\"\n        ></c8y-operation-result>\n      </div>\n    </ng-template>\n  </ng-container>\n</c8y-wizard-body>\n\n<c8y-wizard-footer>\n  <button\n    (click)=\"cancel()\"\n    type=\"button\"\n    class=\"btn btn-default\"\n    title=\"{{ (isDeployed && deployedWithSuccess ? doneLabel : cancelLabel) | translate }}\"\n  >\n    {{ (isDeployed && deployedWithSuccess ? doneLabel : cancelLabel) | translate }}\n  </button>\n\n  <button\n    (click)=\"deployApp()\"\n    *ngIf=\"!isDeployed\"\n    [disabled]=\"inProgress || !canDeploy\"\n    [ngClass]=\"{ 'btn-pending': inProgress }\"\n    class=\"btn btn-primary\"\n    type=\"button\"\n    title=\"{{ 'Deploy' | translate }}\"\n  >\n    {{ 'Deploy' | translate }}\n  </button>\n\n  <button\n    (click)=\"open()\"\n    type=\"button\"\n    class=\"btn btn-primary\"\n    *ngIf=\"isDeployed && deployedWithSuccess\"\n    title=\"{{ 'Open the application details' | translate }}\"\n    translate\n  >\n    Open\n  </button>\n</c8y-wizard-footer>\n"]}
|