@lowcodeunit/applications-flow-common 1.34.6-integration → 1.34.9-lets-get-social-ish
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/esm2020/lcu.api.mjs +4 -3
- package/esm2020/lib/applications-flow.module.mjs +28 -11
- package/esm2020/lib/controls/devops-source-control-form/devops-source-control-form.component.mjs +3 -3
- package/esm2020/lib/controls/dfs-modifiers-form/dfs-modifiers-form.component.mjs +187 -0
- package/esm2020/lib/dialogs/custom-domain-dialog/custom-domain-dialog.component.mjs +3 -3
- package/esm2020/lib/dialogs/dfs-modifiers-dialog/dfs-modifiers-dialog.component.mjs +71 -0
- package/esm2020/lib/dialogs/feed-header-dialog/feed-header-dialog.component.mjs +287 -0
- package/esm2020/lib/elements/feed-card-sm/feed-card-sm.component.mjs +2 -2
- package/esm2020/lib/elements/feed-header/feed-header.component.mjs +131 -0
- package/esm2020/lib/elements/main-feed-card/main-feed-card.component.mjs +2 -2
- package/esm2020/lib/elements/projects/controls/git-auth/git-auth.component.mjs +3 -2
- package/esm2020/lib/elements/projects/controls/tabs/dfs-modifiers/dfs-modifiers.component.mjs +1 -1
- package/esm2020/lib/elements/projects/controls/tabs/domains/domains.component.mjs +2 -2
- package/esm2020/lib/elements/skeleton-feed-card/skeleton-feed-card.component.mjs +2 -2
- package/esm2020/lib/models/user-feed.model.mjs +3 -1
- package/esm2020/lib/services/applications-flow.service.mjs +6 -1
- package/esm2020/lib/services/eac.service.mjs +4 -1
- package/esm2020/lib/services/project.service.mjs +27 -3
- package/esm2020/lib/state/applications-flow.state.mjs +1 -1
- package/fesm2015/lowcodeunit-applications-flow-common.mjs +2258 -1654
- package/fesm2015/lowcodeunit-applications-flow-common.mjs.map +1 -1
- package/fesm2020/lowcodeunit-applications-flow-common.mjs +2367 -1792
- package/fesm2020/lowcodeunit-applications-flow-common.mjs.map +1 -1
- package/lcu.api.d.ts +3 -2
- package/lib/applications-flow.module.d.ts +39 -35
- package/lib/controls/dfs-modifiers-form/dfs-modifiers-form.component.d.ts +51 -0
- package/lib/dialogs/dfs-modifiers-dialog/dfs-modifiers-dialog.component.d.ts +29 -0
- package/lib/dialogs/feed-header-dialog/feed-header-dialog.component.d.ts +71 -0
- package/lib/elements/{gh-control/gh-control.component.d.ts → feed-header/feed-header.component.d.ts} +9 -7
- package/lib/models/user-feed.model.d.ts +17 -0
- package/lib/services/applications-flow.service.d.ts +2 -0
- package/lib/services/eac.service.d.ts +2 -1
- package/lib/services/project.service.d.ts +4 -3
- package/lib/state/applications-flow.state.d.ts +2 -1
- package/package.json +1 -1
- package/esm2020/lib/elements/gh-control/gh-control.component.mjs +0 -107
|
@@ -24,12 +24,12 @@ export class CustomDomainDialogComponent {
|
|
|
24
24
|
}
|
|
25
25
|
}
|
|
26
26
|
CustomDomainDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CustomDomainDialogComponent, deps: [{ token: i1.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
|
|
27
|
-
CustomDomainDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: CustomDomainDialogComponent, selector: "lcu-custom-domain-dialog", ngImport: i0, template: "<div class=\"dialog-header\" fxLayoutAlign=\"end center\">\n <button mat-icon-button (click)=\"CloseDialog()\">\n <mat-icon>cancel</mat-icon>\n </button>\n</div>\n\n<lcu-domains\n[data]=\"DomainData\"\n>\n\n</lcu-domains>\n", styles: [""], components: [{ type: i2.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i4.DomainsComponent, selector: "lcu-domains", inputs: ["data"] }], directives: [{ type: i5.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }] });
|
|
27
|
+
CustomDomainDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: CustomDomainDialogComponent, selector: "lcu-custom-domain-dialog", ngImport: i0, template: "<!-- <div class=\"dialog-header\" fxLayoutAlign=\"end center\">\n <button mat-icon-button (click)=\"CloseDialog()\">\n <mat-icon>cancel</mat-icon>\n </button>\n</div> -->\n\n\n\n\n<!-- NEW BELOW -->\n<div class=\"dialog-header\" fxLayoutAlign=\"space-between center\">\n <h2 mat-dialog-title>Custom Domain</h2>\n\n <button mat-icon-button (click)=\"CloseDialog()\">\n <mat-icon>cancel</mat-icon>\n </button>\n</div>\n\n<mat-dialog-content>\n\n\n\n <lcu-domains\n [data]=\"DomainData\"\n >\n \n </lcu-domains>\n\n <!-- <mat-error *ngIf=\"ErrorMessage\" fxLayoutAlign=\"center center\" >\n {{ ErrorMessage }}\n </mat-error> -->\n\n</mat-dialog-content>\n\n\n<!-- <mat-dialog-actions \n class=\"actions-container\" \n div fxLayout=\"row\" \n fxLayoutAlign=\"end center\"\n>\n <button \n class=\"action-button\"\n mat-raised-button\n fxFlex=\"25%\"\n (click)=\"CloseDialog()\">\n Cancel\n\n </button>\n\n\n\n <button \n *ngIf=\"!State?.Loading\"\n mat-raised-button \n type=\"submit\" \n fxFlex=\"25%\" \n color=\"primary\" \n (click)=\"SaveCustomDomain()\"\n [disabled]=\"!BuildPipelineFormGroup?.valid || !BuildPipelineFormGroup?.dirty\">\n Save\n </button>\n\n</mat-dialog-actions> -->\n", styles: [""], components: [{ type: i2.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i4.DomainsComponent, selector: "lcu-domains", inputs: ["data"] }], directives: [{ type: i5.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }] });
|
|
28
28
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CustomDomainDialogComponent, decorators: [{
|
|
29
29
|
type: Component,
|
|
30
|
-
args: [{ selector: 'lcu-custom-domain-dialog', template: "<div class=\"dialog-header\" fxLayoutAlign=\"end center\">\n <button mat-icon-button (click)=\"CloseDialog()\">\n <mat-icon>cancel</mat-icon>\n </button>\n</div>\n\n<lcu-domains\n[data]=\"DomainData\"\n>\n\n</lcu-domains>\n", styles: [""] }]
|
|
30
|
+
args: [{ selector: 'lcu-custom-domain-dialog', template: "<!-- <div class=\"dialog-header\" fxLayoutAlign=\"end center\">\n <button mat-icon-button (click)=\"CloseDialog()\">\n <mat-icon>cancel</mat-icon>\n </button>\n</div> -->\n\n\n\n\n<!-- NEW BELOW -->\n<div class=\"dialog-header\" fxLayoutAlign=\"space-between center\">\n <h2 mat-dialog-title>Custom Domain</h2>\n\n <button mat-icon-button (click)=\"CloseDialog()\">\n <mat-icon>cancel</mat-icon>\n </button>\n</div>\n\n<mat-dialog-content>\n\n\n\n <lcu-domains\n [data]=\"DomainData\"\n >\n \n </lcu-domains>\n\n <!-- <mat-error *ngIf=\"ErrorMessage\" fxLayoutAlign=\"center center\" >\n {{ ErrorMessage }}\n </mat-error> -->\n\n</mat-dialog-content>\n\n\n<!-- <mat-dialog-actions \n class=\"actions-container\" \n div fxLayout=\"row\" \n fxLayoutAlign=\"end center\"\n>\n <button \n class=\"action-button\"\n mat-raised-button\n fxFlex=\"25%\"\n (click)=\"CloseDialog()\">\n Cancel\n\n </button>\n\n\n\n <button \n *ngIf=\"!State?.Loading\"\n mat-raised-button \n type=\"submit\" \n fxFlex=\"25%\" \n color=\"primary\" \n (click)=\"SaveCustomDomain()\"\n [disabled]=\"!BuildPipelineFormGroup?.valid || !BuildPipelineFormGroup?.dirty\">\n Save\n </button>\n\n</mat-dialog-actions> -->\n", styles: [""] }]
|
|
31
31
|
}], ctorParameters: function () { return [{ type: i1.MatDialogRef }, { type: undefined, decorators: [{
|
|
32
32
|
type: Inject,
|
|
33
33
|
args: [MAT_DIALOG_DATA]
|
|
34
34
|
}] }]; } });
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLWRvbWFpbi1kaWFsb2cuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tbW9uL3NyYy9saWIvZGlhbG9ncy9jdXN0b20tZG9tYWluLWRpYWxvZy9jdXN0b20tZG9tYWluLWRpYWxvZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21tb24vc3JjL2xpYi9kaWFsb2dzL2N1c3RvbS1kb21haW4tZGlhbG9nL2N1c3RvbS1kb21haW4tZGlhbG9nLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQzFELE9BQU8sRUFBZ0IsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7Ozs7Ozs7QUFnQnpFLE1BQU0sT0FBTywyQkFBMkI7SUFJdEMsWUFBbUIsU0FBb0QsRUFDckMsSUFBa0I7UUFEakMsY0FBUyxHQUFULFNBQVMsQ0FBMkM7UUFDckMsU0FBSSxHQUFKLElBQUksQ0FBYztRQUVoRCxJQUFJLENBQUMsVUFBVSxHQUFHO1lBQ2hCLEtBQUssRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUs7WUFDdEIsV0FBVyxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVztZQUNsQyxPQUFPLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPO1lBQzFCLGFBQWEsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWE7U0FDdkMsQ0FBQTtJQUVGLENBQUM7SUFFRyxRQUFRO0lBQ2YsQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUN6QixDQUFDOzt3SEFyQlUsMkJBQTJCLDhDQUs1QixlQUFlOzRHQUxkLDJCQUEyQixnRUNqQnhDLHk2Q0ErREE7MkZEOUNhLDJCQUEyQjtrQkFOdkMsU0FBUzsrQkFDRSwwQkFBMEI7OzBCQVVqQyxNQUFNOzJCQUFDLGVBQWUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEluamVjdCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNYXREaWFsb2dSZWYsIE1BVF9ESUFMT0dfREFUQSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XG5pbXBvcnQgeyBFYUNIb3N0LCBFYUNQcm9qZWN0QXNDb2RlIH0gZnJvbSAnQHNlbWFudGljanMvY29tbW9uJztcblxuZXhwb3J0IGludGVyZmFjZSBDRERpYWxvZ0RhdGEge1xuICAgIGhvc3RzOiB7IFtsb29rdXA6IHN0cmluZ106IEVhQ0hvc3QgfTtcbiAgICBwcmltYXJ5SG9zdDogc3RyaW5nO1xuICAgIHByb2plY3Q6IEVhQ1Byb2plY3RBc0NvZGU7XG4gICAgcHJvamVjdExvb2t1cDogc3RyaW5nO1xufVxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdsY3UtY3VzdG9tLWRvbWFpbi1kaWFsb2cnLFxuICB0ZW1wbGF0ZVVybDogJy4vY3VzdG9tLWRvbWFpbi1kaWFsb2cuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jdXN0b20tZG9tYWluLWRpYWxvZy5jb21wb25lbnQuc2NzcyddXG59KVxuXG5leHBvcnQgY2xhc3MgQ3VzdG9tRG9tYWluRGlhbG9nQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICBwdWJsaWMgRG9tYWluRGF0YToge307XG5cbiAgY29uc3RydWN0b3IocHVibGljIGRpYWxvZ1JlZjogTWF0RGlhbG9nUmVmPEN1c3RvbURvbWFpbkRpYWxvZ0NvbXBvbmVudD4sXG4gICAgQEluamVjdChNQVRfRElBTE9HX0RBVEEpIHB1YmxpYyBkYXRhOiBDRERpYWxvZ0RhdGEpIHtcblxuICAgICAgdGhpcy5Eb21haW5EYXRhID0ge1xuICAgICAgICBIb3N0czogdGhpcy5kYXRhLmhvc3RzLFxuICAgICAgICBQcmltYXJ5SG9zdDogdGhpcy5kYXRhLnByaW1hcnlIb3N0LFxuICAgICAgICBQcm9qZWN0OiB0aGlzLmRhdGEucHJvamVjdCxcbiAgICAgICAgUHJvamVjdExvb2t1cDogdGhpcy5kYXRhLnByb2plY3RMb29rdXBcbiAgICAgIH1cbiAgICAgIFxuICAgICB9XG5cbiAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xuICB9XG5cbiAgcHVibGljIENsb3NlRGlhbG9nKCl7XG4gICAgdGhpcy5kaWFsb2dSZWYuY2xvc2UoKTtcbiAgfVxuXG59XG4iLCI8IS0tIDxkaXYgY2xhc3M9XCJkaWFsb2ctaGVhZGVyXCIgZnhMYXlvdXRBbGlnbj1cImVuZCBjZW50ZXJcIj5cbiAgICA8YnV0dG9uIG1hdC1pY29uLWJ1dHRvbiAoY2xpY2spPVwiQ2xvc2VEaWFsb2coKVwiPlxuICAgICAgICAgICAgPG1hdC1pY29uPmNhbmNlbDwvbWF0LWljb24+XG4gICAgPC9idXR0b24+XG48L2Rpdj4gLS0+XG5cblxuXG5cbjwhLS0gTkVXIEJFTE9XIC0tPlxuPGRpdiBjbGFzcz1cImRpYWxvZy1oZWFkZXJcIiBmeExheW91dEFsaWduPVwic3BhY2UtYmV0d2VlbiBjZW50ZXJcIj5cbiAgICA8aDIgbWF0LWRpYWxvZy10aXRsZT5DdXN0b20gRG9tYWluPC9oMj5cblxuICAgIDxidXR0b24gbWF0LWljb24tYnV0dG9uIChjbGljayk9XCJDbG9zZURpYWxvZygpXCI+XG4gICAgICAgICAgICA8bWF0LWljb24+Y2FuY2VsPC9tYXQtaWNvbj5cbiAgICA8L2J1dHRvbj5cbjwvZGl2PlxuXG48bWF0LWRpYWxvZy1jb250ZW50PlxuXG5cblxuICAgIDxsY3UtZG9tYWluc1xuICAgIFtkYXRhXT1cIkRvbWFpbkRhdGFcIlxuICAgID5cbiAgICBcbiAgICA8L2xjdS1kb21haW5zPlxuXG4gICAgPCEtLSA8bWF0LWVycm9yICpuZ0lmPVwiRXJyb3JNZXNzYWdlXCIgZnhMYXlvdXRBbGlnbj1cImNlbnRlciBjZW50ZXJcIiA+XG4gICAgICAgIHt7IEVycm9yTWVzc2FnZSB9fVxuICAgIDwvbWF0LWVycm9yPiAtLT5cblxuPC9tYXQtZGlhbG9nLWNvbnRlbnQ+XG5cblxuPCEtLSA8bWF0LWRpYWxvZy1hY3Rpb25zIFxuICAgICAgICBjbGFzcz1cImFjdGlvbnMtY29udGFpbmVyXCIgXG4gICAgICAgIGRpdiBmeExheW91dD1cInJvd1wiIFxuICAgICAgICBmeExheW91dEFsaWduPVwiZW5kIGNlbnRlclwiXG4+XG4gICAgICAgIDxidXR0b24gXG4gICAgICAgICAgICAgICAgY2xhc3M9XCJhY3Rpb24tYnV0dG9uXCJcbiAgICAgICAgICAgICAgICBtYXQtcmFpc2VkLWJ1dHRvblxuICAgICAgICAgICAgICAgIGZ4RmxleD1cIjI1JVwiXG4gICAgICAgICAgICAgICAgKGNsaWNrKT1cIkNsb3NlRGlhbG9nKClcIj5cbiAgICAgICAgICAgICAgICBDYW5jZWxcblxuICAgICAgICA8L2J1dHRvbj5cblxuXG5cbiAgICAgICAgPGJ1dHRvbiBcbiAgICAgICAgICAqbmdJZj1cIiFTdGF0ZT8uTG9hZGluZ1wiXG4gICAgICAgICAgbWF0LXJhaXNlZC1idXR0b24gXG4gICAgICAgICAgdHlwZT1cInN1Ym1pdFwiIFxuICAgICAgICAgIGZ4RmxleD1cIjI1JVwiIFxuICAgICAgICAgIGNvbG9yPVwicHJpbWFyeVwiIFxuICAgICAgICAgIChjbGljayk9XCJTYXZlQ3VzdG9tRG9tYWluKClcIlxuICAgICAgICAgIFtkaXNhYmxlZF09XCIhQnVpbGRQaXBlbGluZUZvcm1Hcm91cD8udmFsaWQgfHwgIUJ1aWxkUGlwZWxpbmVGb3JtR3JvdXA/LmRpcnR5XCI+XG4gICAgICAgICAgU2F2ZVxuICAgICAgICA8L2J1dHRvbj5cblxuPC9tYXQtZGlhbG9nLWFjdGlvbnM+IC0tPlxuIl19
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { Component, Inject, ViewChild } from '@angular/core';
|
|
2
|
+
import { MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
3
|
+
import { DFSModifiersFormComponent } from '../../controls/dfs-modifiers-form/dfs-modifiers-form.component';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../../services/eac.service";
|
|
6
|
+
import * as i2 from "@angular/material/dialog";
|
|
7
|
+
import * as i3 from "@angular/material/snack-bar";
|
|
8
|
+
import * as i4 from "@angular/material/button";
|
|
9
|
+
import * as i5 from "@angular/material/icon";
|
|
10
|
+
import * as i6 from "../../controls/dfs-modifiers-form/dfs-modifiers-form.component";
|
|
11
|
+
import * as i7 from "@angular/flex-layout/flex";
|
|
12
|
+
export class DFSModifiersDialogComponent {
|
|
13
|
+
constructor(eacSvc, dialogRef, data, snackBar) {
|
|
14
|
+
this.eacSvc = eacSvc;
|
|
15
|
+
this.dialogRef = dialogRef;
|
|
16
|
+
this.data = data;
|
|
17
|
+
this.snackBar = snackBar;
|
|
18
|
+
}
|
|
19
|
+
// public get Application(): EaCApplicationAsCode {
|
|
20
|
+
// return this.State?.EaC?.Applications[this.data.applicationLookup] || {};
|
|
21
|
+
// }
|
|
22
|
+
// public get Environment(): EaCEnvironmentAsCode {
|
|
23
|
+
// return this.State?.EaC?.Environments[this.data.environmentLookup];
|
|
24
|
+
// }
|
|
25
|
+
// public get SourceControls(): { [lookup: string]: EaCSourceControl } {
|
|
26
|
+
// return this.Environment?.Sources || {};
|
|
27
|
+
// }
|
|
28
|
+
// public get SourceControlLookups(): Array<string> {
|
|
29
|
+
// return Object.keys(this.Environment?.Sources || {});
|
|
30
|
+
// }
|
|
31
|
+
get State() {
|
|
32
|
+
return this.eacSvc.State;
|
|
33
|
+
}
|
|
34
|
+
get DFSModifersFormGroup() {
|
|
35
|
+
return this.DFSModifersFormControls?.ModifierFormGroup;
|
|
36
|
+
}
|
|
37
|
+
ngOnInit() {
|
|
38
|
+
console.log("MDF lookup at dialog: ", this.data.modifierLookup);
|
|
39
|
+
}
|
|
40
|
+
CloseDialog() {
|
|
41
|
+
this.dialogRef.close();
|
|
42
|
+
}
|
|
43
|
+
HandleSaveFormEvent(event) {
|
|
44
|
+
console.log("event: ", event);
|
|
45
|
+
if (event.Code === 0) {
|
|
46
|
+
this.snackBar.open("DFS Modifier Saved Successfully", "Dismiss", {
|
|
47
|
+
duration: 5000
|
|
48
|
+
});
|
|
49
|
+
this.CloseDialog();
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
this.ErrorMessage = event.Message;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
SaveDFSModifier() {
|
|
56
|
+
this.DFSModifersFormControls.SaveModifier();
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
DFSModifiersDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: DFSModifiersDialogComponent, deps: [{ token: i1.EaCService }, { token: i2.MatDialogRef }, { token: MAT_DIALOG_DATA }, { token: i3.MatSnackBar }], target: i0.ɵɵFactoryTarget.Component });
|
|
60
|
+
DFSModifiersDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: DFSModifiersDialogComponent, selector: "lcu-dfs-modifiers-dialog", viewQueries: [{ propertyName: "DFSModifersFormControls", first: true, predicate: DFSModifiersFormComponent, descendants: true }], ngImport: i0, template: "<div class=\"dialog-header\" fxLayoutAlign=\"space-between center\">\n <h2 mat-dialog-title>DFS Modifiers</h2>\n\n <button mat-icon-button (click)=\"CloseDialog()\">\n <mat-icon>cancel</mat-icon>\n </button>\n</div>\n\n<mat-dialog-content>\n\n\n <lcu-dfs-modifiers-form\n [editing-modifier-lookup]=\"data.modifierLookup\"\n >\n\n </lcu-dfs-modifiers-form>\n\n<!-- <mat-error *ngIf=\"ErrorMessage\" fxLayoutAlign=\"center center\" >\n {{ ErrorMessage }}\n</mat-error> -->\n\n</mat-dialog-content>\n\n<mat-dialog-actions \n class=\"actions-container\" \n div fxLayout=\"row\" \n fxLayoutAlign=\"end center\"\n>\n <button \n class=\"action-button\"\n mat-raised-button\n fxFlex=\"25%\"\n (click)=\"CloseDialog()\">\n Cancel\n\n </button>\n\n\n <!-- *ngIf=\"!State?.Loading\" -->\n <button \n \n mat-raised-button \n type=\"submit\" \n fxFlex=\"25%\" \n color=\"primary\" \n (click)=\"SaveDFSModifier()\"\n [disabled]=\"!DFSModifersFormGroup?.valid || !DFSModifersFormGroup?.dirty\"\n >\n <!-- <mat-icon>save</mat-icon> -->\n Save\n </button>\n\n</mat-dialog-actions>\n\n\n", styles: [""], components: [{ type: i4.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i6.DFSModifiersFormComponent, selector: "lcu-dfs-modifiers-form", inputs: ["data", "editing-modifier-lookup"] }], directives: [{ type: i7.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { type: i2.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i2.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i2.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }, { type: i7.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { type: i7.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }] });
|
|
61
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: DFSModifiersDialogComponent, decorators: [{
|
|
62
|
+
type: Component,
|
|
63
|
+
args: [{ selector: 'lcu-dfs-modifiers-dialog', template: "<div class=\"dialog-header\" fxLayoutAlign=\"space-between center\">\n <h2 mat-dialog-title>DFS Modifiers</h2>\n\n <button mat-icon-button (click)=\"CloseDialog()\">\n <mat-icon>cancel</mat-icon>\n </button>\n</div>\n\n<mat-dialog-content>\n\n\n <lcu-dfs-modifiers-form\n [editing-modifier-lookup]=\"data.modifierLookup\"\n >\n\n </lcu-dfs-modifiers-form>\n\n<!-- <mat-error *ngIf=\"ErrorMessage\" fxLayoutAlign=\"center center\" >\n {{ ErrorMessage }}\n</mat-error> -->\n\n</mat-dialog-content>\n\n<mat-dialog-actions \n class=\"actions-container\" \n div fxLayout=\"row\" \n fxLayoutAlign=\"end center\"\n>\n <button \n class=\"action-button\"\n mat-raised-button\n fxFlex=\"25%\"\n (click)=\"CloseDialog()\">\n Cancel\n\n </button>\n\n\n <!-- *ngIf=\"!State?.Loading\" -->\n <button \n \n mat-raised-button \n type=\"submit\" \n fxFlex=\"25%\" \n color=\"primary\" \n (click)=\"SaveDFSModifier()\"\n [disabled]=\"!DFSModifersFormGroup?.valid || !DFSModifersFormGroup?.dirty\"\n >\n <!-- <mat-icon>save</mat-icon> -->\n Save\n </button>\n\n</mat-dialog-actions>\n\n\n", styles: [""] }]
|
|
64
|
+
}], ctorParameters: function () { return [{ type: i1.EaCService }, { type: i2.MatDialogRef }, { type: undefined, decorators: [{
|
|
65
|
+
type: Inject,
|
|
66
|
+
args: [MAT_DIALOG_DATA]
|
|
67
|
+
}] }, { type: i3.MatSnackBar }]; }, propDecorators: { DFSModifersFormControls: [{
|
|
68
|
+
type: ViewChild,
|
|
69
|
+
args: [DFSModifiersFormComponent]
|
|
70
|
+
}] } });
|
|
71
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGZzLW1vZGlmaWVycy1kaWFsb2cuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tbW9uL3NyYy9saWIvZGlhbG9ncy9kZnMtbW9kaWZpZXJzLWRpYWxvZy9kZnMtbW9kaWZpZXJzLWRpYWxvZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21tb24vc3JjL2xpYi9kaWFsb2dzL2Rmcy1tb2RpZmllcnMtZGlhbG9nL2Rmcy1tb2RpZmllcnMtZGlhbG9nLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFVLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVyRSxPQUFPLEVBQWdCLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBR3pFLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGdFQUFnRSxDQUFDOzs7Ozs7Ozs7QUFlM0csTUFBTSxPQUFPLDJCQUEyQjtJQStCdEMsWUFBc0IsTUFBa0IsRUFDL0IsU0FBb0QsRUFDM0IsSUFBNEIsRUFDbEQsUUFBcUI7UUFIWCxXQUFNLEdBQU4sTUFBTSxDQUFZO1FBQy9CLGNBQVMsR0FBVCxTQUFTLENBQTJDO1FBQzNCLFNBQUksR0FBSixJQUFJLENBQXdCO1FBQ2xELGFBQVEsR0FBUixRQUFRLENBQWE7SUFFOUIsQ0FBQztJQS9CSixtREFBbUQ7SUFDbkQsNkVBQTZFO0lBQzdFLElBQUk7SUFFSixtREFBbUQ7SUFDbkQsdUVBQXVFO0lBQ3ZFLElBQUk7SUFFSix3RUFBd0U7SUFDeEUsNENBQTRDO0lBQzVDLElBQUk7SUFFSixxREFBcUQ7SUFDckQseURBQXlEO0lBQ3pELElBQUk7SUFFSixJQUFXLEtBQUs7UUFDZCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDO0lBQzNCLENBQUM7SUFFRCxJQUFXLG9CQUFvQjtRQUM3QixPQUFPLElBQUksQ0FBQyx1QkFBdUIsRUFBRSxpQkFBaUIsQ0FBQztJQUN6RCxDQUFDO0lBV00sUUFBUTtRQUNiLE9BQU8sQ0FBQyxHQUFHLENBQUMsd0JBQXdCLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQTtJQUNqRSxDQUFDO0lBRU0sV0FBVztRQUNoQixJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ3pCLENBQUM7SUFFTSxtQkFBbUIsQ0FBQyxLQUFhO1FBQ3RDLE9BQU8sQ0FBQyxHQUFHLENBQUMsU0FBUyxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQzlCLElBQUksS0FBSyxDQUFDLElBQUksS0FBSyxDQUFDLEVBQUM7WUFDbkIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsaUNBQWlDLEVBQUUsU0FBUyxFQUFDO2dCQUM5RCxRQUFRLEVBQUUsSUFBSTthQUNmLENBQUMsQ0FBQztZQUNILElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztTQUNwQjthQUNHO1lBQ0YsSUFBSSxDQUFDLFlBQVksR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDO1NBQ25DO0lBQ0gsQ0FBQztJQUVNLGVBQWU7UUFDcEIsSUFBSSxDQUFDLHVCQUF1QixDQUFDLFlBQVksRUFBRSxDQUFDO0lBRTlDLENBQUM7O3dIQTlEVSwyQkFBMkIsd0VBaUM1QixlQUFlOzRHQWpDZCwyQkFBMkIseUhBRTNCLHlCQUF5QixnREN0QnRDLCt6Q0F1REE7MkZEbkNhLDJCQUEyQjtrQkFOdkMsU0FBUzsrQkFDRSwwQkFBMEI7OzBCQXNDakMsTUFBTTsyQkFBQyxlQUFlO3NFQTlCbEIsdUJBQXVCO3NCQUQ3QixTQUFTO3VCQUFDLHlCQUF5QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5qZWN0LCBPbkluaXQsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgTWF0RGlhbG9nUmVmLCBNQVRfRElBTE9HX0RBVEEgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuaW1wb3J0IHsgTWF0U25hY2tCYXIgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9zbmFjay1iYXInO1xuaW1wb3J0IHsgU3RhdHVzIH0gZnJvbSAnQGxjdS9jb21tb24nO1xuaW1wb3J0IHsgREZTTW9kaWZpZXJzRm9ybUNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2NvbnRyb2xzL2Rmcy1tb2RpZmllcnMtZm9ybS9kZnMtbW9kaWZpZXJzLWZvcm0uY29tcG9uZW50JztcbmltcG9ydCB7IEVhQ1NlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9lYWMuc2VydmljZSc7XG5pbXBvcnQgeyBBcHBsaWNhdGlvbnNGbG93U3RhdGUgfSBmcm9tICcuLi8uLi9zdGF0ZS9hcHBsaWNhdGlvbnMtZmxvdy5zdGF0ZSc7XG5cblxuZXhwb3J0IGludGVyZmFjZSBERlNNb2RpZmllcnNEaWFsb2dEYXRhIHtcbiAgbW9kaWZpZXJMb29rdXA6IHN0cmluZztcbn1cblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbGN1LWRmcy1tb2RpZmllcnMtZGlhbG9nJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2Rmcy1tb2RpZmllcnMtZGlhbG9nLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZGZzLW1vZGlmaWVycy1kaWFsb2cuY29tcG9uZW50LnNjc3MnXVxufSlcblxuZXhwb3J0IGNsYXNzIERGU01vZGlmaWVyc0RpYWxvZ0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgQFZpZXdDaGlsZChERlNNb2RpZmllcnNGb3JtQ29tcG9uZW50KVxuICBwdWJsaWMgREZTTW9kaWZlcnNGb3JtQ29udHJvbHM6IERGU01vZGlmaWVyc0Zvcm1Db21wb25lbnQ7XG5cbiAgLy8gcHVibGljIGdldCBBcHBsaWNhdGlvbigpOiBFYUNBcHBsaWNhdGlvbkFzQ29kZSB7XG4gIC8vICAgcmV0dXJuIHRoaXMuU3RhdGU/LkVhQz8uQXBwbGljYXRpb25zW3RoaXMuZGF0YS5hcHBsaWNhdGlvbkxvb2t1cF0gfHwge307XG4gIC8vIH1cblxuICAvLyBwdWJsaWMgZ2V0IEVudmlyb25tZW50KCk6IEVhQ0Vudmlyb25tZW50QXNDb2RlIHtcbiAgLy8gICByZXR1cm4gdGhpcy5TdGF0ZT8uRWFDPy5FbnZpcm9ubWVudHNbdGhpcy5kYXRhLmVudmlyb25tZW50TG9va3VwXTtcbiAgLy8gfVxuXG4gIC8vIHB1YmxpYyBnZXQgU291cmNlQ29udHJvbHMoKTogeyBbbG9va3VwOiBzdHJpbmddOiBFYUNTb3VyY2VDb250cm9sIH0ge1xuICAvLyAgIHJldHVybiB0aGlzLkVudmlyb25tZW50Py5Tb3VyY2VzIHx8IHt9O1xuICAvLyB9XG5cbiAgLy8gcHVibGljIGdldCBTb3VyY2VDb250cm9sTG9va3VwcygpOiBBcnJheTxzdHJpbmc+IHtcbiAgLy8gICByZXR1cm4gT2JqZWN0LmtleXModGhpcy5FbnZpcm9ubWVudD8uU291cmNlcyB8fCB7fSk7XG4gIC8vIH1cblxuICBwdWJsaWMgZ2V0IFN0YXRlKCk6IEFwcGxpY2F0aW9uc0Zsb3dTdGF0ZSB7XG4gICAgcmV0dXJuIHRoaXMuZWFjU3ZjLlN0YXRlO1xuICB9XG5cbiAgcHVibGljIGdldCBERlNNb2RpZmVyc0Zvcm1Hcm91cCgpOiBGb3JtR3JvdXB7XG4gICAgcmV0dXJuIHRoaXMuREZTTW9kaWZlcnNGb3JtQ29udHJvbHM/Lk1vZGlmaWVyRm9ybUdyb3VwO1xuICB9XG5cbiAgcHVibGljIEVycm9yTWVzc2FnZTogc3RyaW5nO1xuXG4gIGNvbnN0cnVjdG9yKHByb3RlY3RlZCBlYWNTdmM6IEVhQ1NlcnZpY2UsIFxuICAgIHB1YmxpYyBkaWFsb2dSZWY6IE1hdERpYWxvZ1JlZjxERlNNb2RpZmllcnNEaWFsb2dDb21wb25lbnQ+LFxuICAgIEBJbmplY3QoTUFUX0RJQUxPR19EQVRBKSBwdWJsaWMgZGF0YTogREZTTW9kaWZpZXJzRGlhbG9nRGF0YSxcbiAgICBwcm90ZWN0ZWQgc25hY2tCYXI6IE1hdFNuYWNrQmFyKSB7XG4gICAgIFxuICAgICB9XG5cbiAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGNvbnNvbGUubG9nKFwiTURGIGxvb2t1cCBhdCBkaWFsb2c6IFwiLCB0aGlzLmRhdGEubW9kaWZpZXJMb29rdXApXG4gIH1cblxuICBwdWJsaWMgQ2xvc2VEaWFsb2coKXtcbiAgICB0aGlzLmRpYWxvZ1JlZi5jbG9zZSgpO1xuICB9XG5cbiAgcHVibGljIEhhbmRsZVNhdmVGb3JtRXZlbnQoZXZlbnQ6IFN0YXR1cyl7XG4gICAgY29uc29sZS5sb2coXCJldmVudDogXCIsIGV2ZW50KTtcbiAgICBpZiAoZXZlbnQuQ29kZSA9PT0gMCl7XG4gICAgICB0aGlzLnNuYWNrQmFyLm9wZW4oXCJERlMgTW9kaWZpZXIgU2F2ZWQgU3VjY2Vzc2Z1bGx5XCIsIFwiRGlzbWlzc1wiLHtcbiAgICAgICAgZHVyYXRpb246IDUwMDBcbiAgICAgIH0pO1xuICAgICAgdGhpcy5DbG9zZURpYWxvZygpO1xuICAgIH1cbiAgICBlbHNle1xuICAgICAgdGhpcy5FcnJvck1lc3NhZ2UgPSBldmVudC5NZXNzYWdlO1xuICAgIH1cbiAgfVxuXG4gIHB1YmxpYyBTYXZlREZTTW9kaWZpZXIoKXtcbiAgICB0aGlzLkRGU01vZGlmZXJzRm9ybUNvbnRyb2xzLlNhdmVNb2RpZmllcigpO1xuXG4gIH1cblxuXG4gIFxuXG59XG4iLCI8ZGl2IGNsYXNzPVwiZGlhbG9nLWhlYWRlclwiIGZ4TGF5b3V0QWxpZ249XCJzcGFjZS1iZXR3ZWVuIGNlbnRlclwiPlxuICAgIDxoMiBtYXQtZGlhbG9nLXRpdGxlPkRGUyBNb2RpZmllcnM8L2gyPlxuXG4gICAgPGJ1dHRvbiBtYXQtaWNvbi1idXR0b24gKGNsaWNrKT1cIkNsb3NlRGlhbG9nKClcIj5cbiAgICAgICAgICAgIDxtYXQtaWNvbj5jYW5jZWw8L21hdC1pY29uPlxuICAgIDwvYnV0dG9uPlxuPC9kaXY+XG5cbjxtYXQtZGlhbG9nLWNvbnRlbnQ+XG5cblxuICAgICAgICA8bGN1LWRmcy1tb2RpZmllcnMtZm9ybVxuICAgICAgICBbZWRpdGluZy1tb2RpZmllci1sb29rdXBdPVwiZGF0YS5tb2RpZmllckxvb2t1cFwiXG4gICAgICAgID5cblxuICAgICAgICA8L2xjdS1kZnMtbW9kaWZpZXJzLWZvcm0+XG5cbjwhLS0gPG1hdC1lcnJvciAqbmdJZj1cIkVycm9yTWVzc2FnZVwiIGZ4TGF5b3V0QWxpZ249XCJjZW50ZXIgY2VudGVyXCIgPlxuICAgIHt7IEVycm9yTWVzc2FnZSB9fVxuPC9tYXQtZXJyb3I+IC0tPlxuXG48L21hdC1kaWFsb2ctY29udGVudD5cblxuPG1hdC1kaWFsb2ctYWN0aW9ucyBcbiAgICAgICAgY2xhc3M9XCJhY3Rpb25zLWNvbnRhaW5lclwiIFxuICAgICAgICBkaXYgZnhMYXlvdXQ9XCJyb3dcIiBcbiAgICAgICAgZnhMYXlvdXRBbGlnbj1cImVuZCBjZW50ZXJcIlxuPlxuICAgICAgICA8YnV0dG9uIFxuICAgICAgICAgICAgICAgIGNsYXNzPVwiYWN0aW9uLWJ1dHRvblwiXG4gICAgICAgICAgICAgICAgbWF0LXJhaXNlZC1idXR0b25cbiAgICAgICAgICAgICAgICBmeEZsZXg9XCIyNSVcIlxuICAgICAgICAgICAgICAgIChjbGljayk9XCJDbG9zZURpYWxvZygpXCI+XG4gICAgICAgICAgICAgICAgQ2FuY2VsXG5cbiAgICAgICAgPC9idXR0b24+XG5cblxuICAgICAgICA8IS0tICpuZ0lmPVwiIVN0YXRlPy5Mb2FkaW5nXCIgLS0+XG4gICAgICAgIDxidXR0b24gXG4gICAgICAgICAgXG4gICAgICAgICAgbWF0LXJhaXNlZC1idXR0b24gXG4gICAgICAgICAgdHlwZT1cInN1Ym1pdFwiIFxuICAgICAgICAgIGZ4RmxleD1cIjI1JVwiIFxuICAgICAgICAgIGNvbG9yPVwicHJpbWFyeVwiIFxuICAgICAgICAgIChjbGljayk9XCJTYXZlREZTTW9kaWZpZXIoKVwiXG4gICAgICAgICAgW2Rpc2FibGVkXT1cIiFERlNNb2RpZmVyc0Zvcm1Hcm91cD8udmFsaWQgfHwgIURGU01vZGlmZXJzRm9ybUdyb3VwPy5kaXJ0eVwiXG4gICAgICAgICAgPlxuICAgICAgICAgIDwhLS0gPG1hdC1pY29uPnNhdmU8L21hdC1pY29uPiAtLT5cbiAgICAgICAgICBTYXZlXG4gICAgICAgIDwvYnV0dG9uPlxuXG48L21hdC1kaWFsb2ctYWN0aW9ucz5cblxuXG4iXX0=
|
|
@@ -0,0 +1,287 @@
|
|
|
1
|
+
import { Component, Inject } from '@angular/core';
|
|
2
|
+
import { Validators } from '@angular/forms';
|
|
3
|
+
import { MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../../services/applications-flow.service";
|
|
6
|
+
import * as i2 from "../../services/eac.service";
|
|
7
|
+
import * as i3 from "@angular/forms";
|
|
8
|
+
import * as i4 from "@angular/material/dialog";
|
|
9
|
+
import * as i5 from "@angular/material/button";
|
|
10
|
+
import * as i6 from "@angular/material/icon";
|
|
11
|
+
import * as i7 from "@angular/material/form-field";
|
|
12
|
+
import * as i8 from "@angular/material/select";
|
|
13
|
+
import * as i9 from "@angular/material/core";
|
|
14
|
+
import * as i10 from "@kolkov/angular-editor";
|
|
15
|
+
import * as i11 from "@angular/flex-layout/flex";
|
|
16
|
+
import * as i12 from "@angular/common";
|
|
17
|
+
import * as i13 from "@angular/material/input";
|
|
18
|
+
export class FeedHeaderDialogComponent {
|
|
19
|
+
constructor(appsFlowSvc, eacSvc, formBldr, dialogRef, data) {
|
|
20
|
+
this.appsFlowSvc = appsFlowSvc;
|
|
21
|
+
this.eacSvc = eacSvc;
|
|
22
|
+
this.formBldr = formBldr;
|
|
23
|
+
this.dialogRef = dialogRef;
|
|
24
|
+
this.data = data;
|
|
25
|
+
this.EditorConfig = {
|
|
26
|
+
editable: true,
|
|
27
|
+
spellcheck: true,
|
|
28
|
+
height: '250px',
|
|
29
|
+
minHeight: '0',
|
|
30
|
+
maxHeight: 'auto',
|
|
31
|
+
width: 'auto',
|
|
32
|
+
minWidth: '0',
|
|
33
|
+
translate: 'yes',
|
|
34
|
+
enableToolbar: true,
|
|
35
|
+
showToolbar: true,
|
|
36
|
+
placeholder: 'Enter text here...',
|
|
37
|
+
defaultParagraphSeparator: '',
|
|
38
|
+
defaultFontName: '',
|
|
39
|
+
defaultFontSize: '',
|
|
40
|
+
fonts: [
|
|
41
|
+
{ class: 'arial', name: 'Arial' },
|
|
42
|
+
{ class: 'times-new-roman', name: 'Times New Roman' },
|
|
43
|
+
{ class: 'calibri', name: 'Calibri' },
|
|
44
|
+
{ class: 'comic-sans-ms', name: 'Comic Sans MS' }
|
|
45
|
+
],
|
|
46
|
+
customClasses: [
|
|
47
|
+
{
|
|
48
|
+
name: 'quote',
|
|
49
|
+
class: 'quote',
|
|
50
|
+
},
|
|
51
|
+
{
|
|
52
|
+
name: 'redText',
|
|
53
|
+
class: 'redText'
|
|
54
|
+
},
|
|
55
|
+
{
|
|
56
|
+
name: 'titleText',
|
|
57
|
+
class: 'titleText',
|
|
58
|
+
tag: 'h1',
|
|
59
|
+
},
|
|
60
|
+
],
|
|
61
|
+
sanitize: true,
|
|
62
|
+
toolbarPosition: 'top',
|
|
63
|
+
toolbarHiddenButtons: [
|
|
64
|
+
['subscript', 'superscript'],
|
|
65
|
+
['fontSize']
|
|
66
|
+
]
|
|
67
|
+
};
|
|
68
|
+
this.SlicesCount = 5;
|
|
69
|
+
this.Slices = {
|
|
70
|
+
Sources: this.SlicesCount,
|
|
71
|
+
};
|
|
72
|
+
if (this.SourceControlLookups.length === 1) {
|
|
73
|
+
this.SourceControl = this.Environment?.Sources[this.SourceControlLookups[0]];
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
get ActionIconControl() {
|
|
77
|
+
return this.FeedHeaderFormGroup?.controls.actionIcon;
|
|
78
|
+
}
|
|
79
|
+
get ActionLinkControl() {
|
|
80
|
+
return this.FeedHeaderFormGroup?.controls.actionLink;
|
|
81
|
+
}
|
|
82
|
+
get ActionTextControl() {
|
|
83
|
+
return this.FeedHeaderFormGroup?.controls.actionText;
|
|
84
|
+
}
|
|
85
|
+
get EditorControl() {
|
|
86
|
+
return this.FeedHeaderFormGroup?.controls.editor;
|
|
87
|
+
}
|
|
88
|
+
get Environment() {
|
|
89
|
+
return this.State?.EaC?.Environments[this.State?.EaC?.Enterprise?.PrimaryEnvironment];
|
|
90
|
+
}
|
|
91
|
+
get TargetBranchFormControl() {
|
|
92
|
+
return this.FeedHeaderFormGroup.controls.targetBranch;
|
|
93
|
+
}
|
|
94
|
+
get OrganizationFormControl() {
|
|
95
|
+
return this.FeedHeaderFormGroup.controls.organization;
|
|
96
|
+
}
|
|
97
|
+
get SourceBranchFormControl() {
|
|
98
|
+
return this.FeedHeaderFormGroup.controls.sourceBranch;
|
|
99
|
+
}
|
|
100
|
+
get RepositoryFormControl() {
|
|
101
|
+
return this.FeedHeaderFormGroup.controls.repository;
|
|
102
|
+
}
|
|
103
|
+
get SourceControlFormControl() {
|
|
104
|
+
return this.FeedHeaderFormGroup.controls.sourceControl;
|
|
105
|
+
}
|
|
106
|
+
get SourceControlLookups() {
|
|
107
|
+
return this.State.FeedSourceControlLookups
|
|
108
|
+
? this.State.FeedSourceControlLookups
|
|
109
|
+
: Object.keys(this.SourceControls || {});
|
|
110
|
+
}
|
|
111
|
+
get SourceControls() {
|
|
112
|
+
return this.Environment?.Sources || {};
|
|
113
|
+
}
|
|
114
|
+
get SubtitleFormControl() {
|
|
115
|
+
return this.FeedHeaderFormGroup.controls.subtitle;
|
|
116
|
+
}
|
|
117
|
+
get State() {
|
|
118
|
+
return this.eacSvc.State;
|
|
119
|
+
}
|
|
120
|
+
get TitleFormControl() {
|
|
121
|
+
return this.FeedHeaderFormGroup?.controls.title;
|
|
122
|
+
}
|
|
123
|
+
ngOnInit() {
|
|
124
|
+
this.setupFeedHeaderForm();
|
|
125
|
+
}
|
|
126
|
+
CloseDialog() {
|
|
127
|
+
this.dialogRef.close();
|
|
128
|
+
}
|
|
129
|
+
HandleAction() {
|
|
130
|
+
if (this.ActionLinkControl.value.startsWith('http')) {
|
|
131
|
+
window.open(this.ActionLinkControl.value, '_blank');
|
|
132
|
+
}
|
|
133
|
+
else {
|
|
134
|
+
window.location.href = this.ActionLinkControl.value;
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
PullRequestSourceControlChanged(event) {
|
|
138
|
+
this.SourceControl = this.SourceControls[this.SourceControlFormControl.value];
|
|
139
|
+
this.listBranches();
|
|
140
|
+
}
|
|
141
|
+
FeatureBranchSourceControlChanged(event) {
|
|
142
|
+
this.SourceControl = this.SourceControls[this.SourceControlFormControl.value];
|
|
143
|
+
this.listOrganizations();
|
|
144
|
+
}
|
|
145
|
+
IssueSourceControlChanged(event) {
|
|
146
|
+
this.SourceControl = this.SourceControls[this.SourceControlFormControl.value];
|
|
147
|
+
}
|
|
148
|
+
Submit() {
|
|
149
|
+
let returnObject = {
|
|
150
|
+
ActionIcon: this.ActionIconControl ? this.ActionIconControl.value : null,
|
|
151
|
+
ActionLink: this.ActionLinkControl ? this.ActionLinkControl.value : null,
|
|
152
|
+
ActionText: this.ActionTextControl ? this.ActionTextControl.value : null,
|
|
153
|
+
Avatar: null,
|
|
154
|
+
Content: this.EditorControl ? this.EditorControl.value : null,
|
|
155
|
+
ExpiresAt: null,
|
|
156
|
+
Organization: this.OrganizationFormControl ? this.OrganizationFormControl.value : null,
|
|
157
|
+
Repositroy: this.RepositoryFormControl ? this.RepositoryFormControl.value : null,
|
|
158
|
+
SourceBranch: this.SourceBranchFormControl ? this.SourceBranchFormControl.value : null,
|
|
159
|
+
SourceControlLookup: this.SourceControlFormControl ? this.SourceBranchFormControl.value : null,
|
|
160
|
+
Subtitle: this.SubtitleFormControl ? this.SubtitleFormControl.value : null,
|
|
161
|
+
TargetBranch: this.TargetBranchFormControl ? this.TargetBranchFormControl.value : null,
|
|
162
|
+
Type: this.data.type,
|
|
163
|
+
Title: this.TitleFormControl ? this.TitleFormControl.value : null,
|
|
164
|
+
};
|
|
165
|
+
console.log("Control: ", returnObject);
|
|
166
|
+
let status = this.eacSvc.SubmitFeedEntry(returnObject);
|
|
167
|
+
console.log("feed entry status: ", status);
|
|
168
|
+
// console.log("Editor: ", this.EditorControl.value )
|
|
169
|
+
}
|
|
170
|
+
OrganizationChanged(event) {
|
|
171
|
+
this.RepositoryFormControl.reset();
|
|
172
|
+
this.listRepositories();
|
|
173
|
+
}
|
|
174
|
+
RepositoryChanged(event) {
|
|
175
|
+
this.listBranches();
|
|
176
|
+
}
|
|
177
|
+
//HELPERS
|
|
178
|
+
listBranches() {
|
|
179
|
+
// this.Loading = true;
|
|
180
|
+
this.appsFlowSvc
|
|
181
|
+
.ListBranches(this.SourceControl?.Organization, this.SourceControl?.Repository)
|
|
182
|
+
.subscribe((response) => {
|
|
183
|
+
this.BranchOptions = response.Model;
|
|
184
|
+
// this.Loading = false;
|
|
185
|
+
// if (this.EditingSourceControl?.Branches?.length > 0) {
|
|
186
|
+
// this.SelectedBranches = this.EditingSourceControl.Branches;
|
|
187
|
+
// } else if (this.BranchOptions?.length === 1) {
|
|
188
|
+
// this.BranchesFormControl.setValue(this.BranchOptions[0].Name);
|
|
189
|
+
// this.SelectedBranches = [this.BranchOptions[0].Name];
|
|
190
|
+
// }
|
|
191
|
+
});
|
|
192
|
+
}
|
|
193
|
+
listOrganizations() {
|
|
194
|
+
// this.Loading = true;
|
|
195
|
+
this.appsFlowSvc
|
|
196
|
+
.ListOrganizations()
|
|
197
|
+
.subscribe((response) => {
|
|
198
|
+
this.OrganizationOptions = response.Model;
|
|
199
|
+
console.log("Organization Options: ", this.OrganizationOptions);
|
|
200
|
+
// this.Loading = false;
|
|
201
|
+
if (this.SourceControl?.Organization) {
|
|
202
|
+
setTimeout(() => {
|
|
203
|
+
this.OrganizationFormControl.setValue(this.SourceControl.Organization);
|
|
204
|
+
this.listRepositories(this.SourceControl?.Repository);
|
|
205
|
+
}, 0);
|
|
206
|
+
}
|
|
207
|
+
});
|
|
208
|
+
}
|
|
209
|
+
listRepositories(activeRepo = null) {
|
|
210
|
+
// this.Loading = true;
|
|
211
|
+
this.appsFlowSvc
|
|
212
|
+
.ListRepositories(this.OrganizationFormControl.value)
|
|
213
|
+
.subscribe((response) => {
|
|
214
|
+
this.RepositoryOptions = response.Model;
|
|
215
|
+
// this.Loading = false;
|
|
216
|
+
if (activeRepo) {
|
|
217
|
+
setTimeout(() => {
|
|
218
|
+
this.RepositoryFormControl.setValue(activeRepo);
|
|
219
|
+
this.listBranches();
|
|
220
|
+
}, 0);
|
|
221
|
+
}
|
|
222
|
+
});
|
|
223
|
+
}
|
|
224
|
+
setupFeedHeaderForm() {
|
|
225
|
+
this.FeedHeaderFormGroup = this.formBldr.group({});
|
|
226
|
+
switch (this.data.type) {
|
|
227
|
+
case "Announcement":
|
|
228
|
+
this.setupAnnouncementForm();
|
|
229
|
+
break;
|
|
230
|
+
case "PullRequest":
|
|
231
|
+
this.setupPRForm();
|
|
232
|
+
break;
|
|
233
|
+
case "OpenIssue":
|
|
234
|
+
this.setupIssueForm();
|
|
235
|
+
break;
|
|
236
|
+
case "CreateBranch":
|
|
237
|
+
this.setupFeatureBranchForm();
|
|
238
|
+
break;
|
|
239
|
+
default:
|
|
240
|
+
//
|
|
241
|
+
break;
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
setupAnnouncementForm() {
|
|
245
|
+
this.setupBasicForm();
|
|
246
|
+
this.FeedHeaderFormGroup.addControl('subtitle', this.formBldr.control(''));
|
|
247
|
+
this.FeedHeaderFormGroup.addControl('actionText', this.formBldr.control(''));
|
|
248
|
+
this.FeedHeaderFormGroup.addControl('actionLink', this.formBldr.control(''));
|
|
249
|
+
this.FeedHeaderFormGroup.addControl('actionIcon', this.formBldr.control(''));
|
|
250
|
+
}
|
|
251
|
+
setupPRForm() {
|
|
252
|
+
this.listBranches();
|
|
253
|
+
this.setupIssueForm();
|
|
254
|
+
this.setupBranchesForm();
|
|
255
|
+
}
|
|
256
|
+
setupBasicForm() {
|
|
257
|
+
this.FeedHeaderFormGroup.addControl('title', this.formBldr.control('', [Validators.required]));
|
|
258
|
+
this.FeedHeaderFormGroup.addControl('editor', this.formBldr.control(''));
|
|
259
|
+
}
|
|
260
|
+
setupIssueForm() {
|
|
261
|
+
this.setupBasicForm();
|
|
262
|
+
this.setupSourceControlForm();
|
|
263
|
+
}
|
|
264
|
+
setupFeatureBranchForm() {
|
|
265
|
+
this.setupSourceControlForm();
|
|
266
|
+
this.FeedHeaderFormGroup.addControl('organization', this.formBldr.control(''));
|
|
267
|
+
this.FeedHeaderFormGroup.addControl('repository', this.formBldr.control(''));
|
|
268
|
+
this.setupBranchesForm();
|
|
269
|
+
}
|
|
270
|
+
setupSourceControlForm() {
|
|
271
|
+
this.FeedHeaderFormGroup.addControl('sourceControl', this.formBldr.control(''));
|
|
272
|
+
}
|
|
273
|
+
setupBranchesForm() {
|
|
274
|
+
this.FeedHeaderFormGroup.addControl('targetBranch', this.formBldr.control(''));
|
|
275
|
+
this.FeedHeaderFormGroup.addControl('sourceBranch', this.formBldr.control(''));
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
FeedHeaderDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: FeedHeaderDialogComponent, deps: [{ token: i1.ApplicationsFlowService }, { token: i2.EaCService }, { token: i3.FormBuilder }, { token: i4.MatDialogRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
|
|
279
|
+
FeedHeaderDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: FeedHeaderDialogComponent, selector: "lcu-feed-header-dialog", ngImport: i0, template: "<div class=\"dialog-header\" fxLayoutAlign=\"space-between center\">\n <h2 mat-dialog-title>{{data.dialogTitle}}</h2>\n <button mat-icon-button (click)=\"CloseDialog()\">\n <mat-icon>cancel</mat-icon>\n </button>\n</div>\n\n<mat-dialog-content>\n <form [formGroup]=\"FeedHeaderFormGroup\" >\n\n <!-- ISSUE FORM -->\n <ng-container *ngIf=\"data.type === 'OpenIssue' \">\n\n <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n <mat-form-field appearance=\"fill\">\n <mat-label>Source Control</mat-label>\n <mat-select \n formControlName=\"sourceControl\"\n (selectionChange)=\"IssueSourceControlChanged($event)\"\n\n >\n <ng-container *ngFor=\"let scLookup of SourceControlLookups | slice: 0:Slices.Sources\">\n <mat-option *ngIf=\"SourceControls[scLookup]; let sc\" [value]=\"scLookup\">\n {{sc.Name}}\n </mat-option>\n </ng-container>\n </mat-select>\n </mat-form-field>\n </div>\n\n <mat-form-field class=\"mat-full-width\">\n <input\n matInput\n placeholder=\"Title\"\n formControlName=\"title\"\n required\n />\n </mat-form-field>\n\n\n <angular-editor \n id=\"issue-editor\"\n formControlName=\"editor\" \n [config]=\"EditorConfig\"\n ></angular-editor>\n </ng-container>\n\n <!-- ANNOUNCEMENT FORM -->\n\n <ng-container *ngIf=\"data.type === 'Announcement' \">\n <mat-form-field class=\"mat-full-width\">\n <input\n matInput\n placeholder=\"Title\"\n formControlName=\"title\"\n required\n />\n </mat-form-field>\n\n <mat-form-field class=\"mat-full-width\">\n <input\n matInput\n placeholder=\"Subtitle\"\n formControlName=\"subtitle\"\n />\n </mat-form-field>\n\n <angular-editor \n id=\"announcement-editor\"\n formControlName=\"editor\" \n [config]=\"EditorConfig\"\n ></angular-editor>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"space-between center\">\n\n <mat-form-field class=\"mat-full-width\">\n <input\n matInput\n placeholder=\"Action Text\"\n formControlName=\"actionText\"\n />\n </mat-form-field>\n\n <mat-form-field class=\"mat-full-width\">\n <input\n matInput\n placeholder=\"Action Link\"\n formControlName=\"actionLink\"\n />\n </mat-form-field>\n\n <mat-form-field class=\"mat-full-width\">\n <input\n matInput\n placeholder=\"Action Icon\"\n formControlName=\"actionIcon\"\n />\n </mat-form-field>\n\n </div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n <button \n *ngIf=\"ActionTextControl?.value || ActionIconControl?.value\"\n mat-button color=\"primary\" \n (click)=\"HandleAction(ActionLinkControl?.value)\"\n >\n <mat-icon *ngIf=\"ActionIconControl?.value\">{{ ActionIconControl?.value }}</mat-icon>\n \n {{ ActionTextControl?.value }}\n </button>\n\n <button \n *ngIf=\"!ActionTextControl?.value && !ActionIconControl?.value\"\n mat-button color=\"primary\" \n >\n <mat-icon>cruelty_free</mat-icon>\n \n Example Button\n </button>\n </div>\n\n </ng-container>\n\n <!-- PR FORM -->\n\n <ng-container *ngIf=\"data.type === 'PullRequest' \">\n\n <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n <mat-form-field appearance=\"fill\">\n <mat-label>Source Control</mat-label>\n <mat-select \n formControlName=\"sourceControl\"\n (selectionChange)=\"PullRequestSourceControlChanged($event)\"\n >\n <ng-container *ngFor=\"let scLookup of SourceControlLookups | slice: 0:Slices.Sources\">\n <mat-option *ngIf=\"SourceControls[scLookup]; let sc\" [value]=\"scLookup\">\n {{sc.Name}}\n </mat-option>\n </ng-container>\n </mat-select>\n </mat-form-field>\n </div>\n\n\n <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n <mat-form-field appearance=\"fill\">\n <mat-label>Base</mat-label>\n <mat-select formControlName=\"targetBranch\" required\n >\n <mat-option *ngFor=\"let branchOpt of BranchOptions\" [value]=\"branchOpt.Name\">\n {{branchOpt.Name}}\n </mat-option>\n </mat-select>\n </mat-form-field>\n \n <mat-icon>arrow_back</mat-icon>\n\n <mat-form-field appearance=\"fill\">\n <mat-label>Compare</mat-label>\n <mat-select formControlName=\"sourceBranch\" required\n >\n <mat-option *ngFor=\"let branchOpt of BranchOptions\" [value]=\"branchOpt.Name\">\n {{branchOpt.Name}}\n </mat-option>\n </mat-select>\n </mat-form-field>\n </div>\n\n <mat-form-field class=\"mat-full-width\">\n <input\n matInput\n placeholder=\"Title\"\n formControlName=\"title\"\n required\n />\n </mat-form-field>\n\n\n <angular-editor \n id=\"pr-editor\"\n formControlName=\"editor\" \n [config]=\"EditorConfig\"\n ></angular-editor>\n\n </ng-container>\n\n <!-- Feature Branch form -->\n\n <ng-container *ngIf=\"data.type === 'CreateBranch' \">\n\n <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n <mat-form-field >\n <mat-label>Source Control</mat-label>\n <mat-select \n formControlName=\"sourceControl\"\n (selectionChange)=\"FeatureBranchSourceControlChanged($event)\"\n >\n <ng-container *ngFor=\"let scLookup of SourceControlLookups | slice: 0:Slices.Sources\">\n <mat-option *ngIf=\"SourceControls[scLookup]; let sc\" [value]=\"scLookup\">\n {{sc.Name}}\n </mat-option>\n </ng-container>\n </mat-select>\n </mat-form-field>\n </div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"space-around center\">\n\n <mat-form-field *ngIf=\"OrganizationOptions?.length > 0\">\n\n <mat-select \n formControlName=\"organization\" \n placeholder=\"Organization\"\n (selectionChange)=\"OrganizationChanged($event)\" \n required\n >\n <ng-container *ngFor=\"let orgOpt of OrganizationOptions\">\n <mat-option [value]=\"orgOpt.Name\">\n {{ orgOpt.Name }}\n </mat-option>\n </ng-container>\n </mat-select>\n\n\n\n </mat-form-field>\n\n <mat-form-field *ngIf=\"RepositoryOptions?.length > 0\">\n\n <mat-select formControlName=\"repository\" \n placeholder=\"Repository\" \n (selectionChange)=\"RepositoryChanged($event)\" \n required\n >\n <ng-container *ngFor=\"let repoOpt of RepositoryOptions\">\n <mat-option [value]=\"repoOpt.Name\">\n {{ repoOpt.Name }}\n </mat-option>\n </ng-container>\n </mat-select> \n </mat-form-field>\n\n </div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"space-around center\" *ngIf=\"BranchOptions?.length > 0\">\n\n <mat-form-field >\n <mat-label>Base Branch</mat-label>\n <mat-select formControlName=\"sourceBranch\" required\n >\n <mat-option *ngFor=\"let branchOpt of BranchOptions\" [value]=\"branchOpt.Name\">\n {{branchOpt.Name}}\n </mat-option>\n </mat-select>\n </mat-form-field>\n\n <mat-form-field >\n <input\n matInput\n placeholder=\"Create New Branch\"\n formControlName=\"targetBranch\"\n required\n />\n </mat-form-field>\n </div>\n\n </ng-container>\n\n\n\n\n\n </form>\n \n \n\n <!-- <mat-error *ngIf=\"ErrorMessage\" fxLayoutAlign=\"center center\" >\n {{ ErrorMessage }}\n </mat-error> -->\n</mat-dialog-content>\n\n<mat-dialog-actions\n class=\"actions-container\" \n div fxLayout=\"row\" \n fxLayoutAlign=\"end center\"\n>\n\n <button \n class=\"action-button\"\n mat-raised-button\n fxFlex=\"25%\"\n (click)=\"CloseDialog()\"\n >\n Cancel\n </button>\n\n <!-- -->\n <button \n mat-raised-button \n color=\"primary\"\n fxFlex=\"25%\"\n class=\"submit\" \n (click)=\"Submit()\"\n [disabled]=\"\n !FeedHeaderFormGroup?.valid \n\"\n \n >\n Submit\n </button>\n</mat-dialog-actions>\n\n\n", styles: [""], components: [{ type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i7.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i8.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { type: i9.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { type: i10.AngularEditorComponent, selector: "angular-editor", inputs: ["id", "config", "placeholder", "tabIndex"], outputs: ["html", "viewMode", "blur", "focus"] }], directives: [{ type: i11.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { type: i4.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i4.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i12.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i11.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { type: i7.MatLabel, selector: "mat-label" }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i12.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i13.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i3.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i4.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }, { type: i11.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }], pipes: { "slice": i12.SlicePipe } });
|
|
280
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: FeedHeaderDialogComponent, decorators: [{
|
|
281
|
+
type: Component,
|
|
282
|
+
args: [{ selector: 'lcu-feed-header-dialog', template: "<div class=\"dialog-header\" fxLayoutAlign=\"space-between center\">\n <h2 mat-dialog-title>{{data.dialogTitle}}</h2>\n <button mat-icon-button (click)=\"CloseDialog()\">\n <mat-icon>cancel</mat-icon>\n </button>\n</div>\n\n<mat-dialog-content>\n <form [formGroup]=\"FeedHeaderFormGroup\" >\n\n <!-- ISSUE FORM -->\n <ng-container *ngIf=\"data.type === 'OpenIssue' \">\n\n <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n <mat-form-field appearance=\"fill\">\n <mat-label>Source Control</mat-label>\n <mat-select \n formControlName=\"sourceControl\"\n (selectionChange)=\"IssueSourceControlChanged($event)\"\n\n >\n <ng-container *ngFor=\"let scLookup of SourceControlLookups | slice: 0:Slices.Sources\">\n <mat-option *ngIf=\"SourceControls[scLookup]; let sc\" [value]=\"scLookup\">\n {{sc.Name}}\n </mat-option>\n </ng-container>\n </mat-select>\n </mat-form-field>\n </div>\n\n <mat-form-field class=\"mat-full-width\">\n <input\n matInput\n placeholder=\"Title\"\n formControlName=\"title\"\n required\n />\n </mat-form-field>\n\n\n <angular-editor \n id=\"issue-editor\"\n formControlName=\"editor\" \n [config]=\"EditorConfig\"\n ></angular-editor>\n </ng-container>\n\n <!-- ANNOUNCEMENT FORM -->\n\n <ng-container *ngIf=\"data.type === 'Announcement' \">\n <mat-form-field class=\"mat-full-width\">\n <input\n matInput\n placeholder=\"Title\"\n formControlName=\"title\"\n required\n />\n </mat-form-field>\n\n <mat-form-field class=\"mat-full-width\">\n <input\n matInput\n placeholder=\"Subtitle\"\n formControlName=\"subtitle\"\n />\n </mat-form-field>\n\n <angular-editor \n id=\"announcement-editor\"\n formControlName=\"editor\" \n [config]=\"EditorConfig\"\n ></angular-editor>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"space-between center\">\n\n <mat-form-field class=\"mat-full-width\">\n <input\n matInput\n placeholder=\"Action Text\"\n formControlName=\"actionText\"\n />\n </mat-form-field>\n\n <mat-form-field class=\"mat-full-width\">\n <input\n matInput\n placeholder=\"Action Link\"\n formControlName=\"actionLink\"\n />\n </mat-form-field>\n\n <mat-form-field class=\"mat-full-width\">\n <input\n matInput\n placeholder=\"Action Icon\"\n formControlName=\"actionIcon\"\n />\n </mat-form-field>\n\n </div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n <button \n *ngIf=\"ActionTextControl?.value || ActionIconControl?.value\"\n mat-button color=\"primary\" \n (click)=\"HandleAction(ActionLinkControl?.value)\"\n >\n <mat-icon *ngIf=\"ActionIconControl?.value\">{{ ActionIconControl?.value }}</mat-icon>\n \n {{ ActionTextControl?.value }}\n </button>\n\n <button \n *ngIf=\"!ActionTextControl?.value && !ActionIconControl?.value\"\n mat-button color=\"primary\" \n >\n <mat-icon>cruelty_free</mat-icon>\n \n Example Button\n </button>\n </div>\n\n </ng-container>\n\n <!-- PR FORM -->\n\n <ng-container *ngIf=\"data.type === 'PullRequest' \">\n\n <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n <mat-form-field appearance=\"fill\">\n <mat-label>Source Control</mat-label>\n <mat-select \n formControlName=\"sourceControl\"\n (selectionChange)=\"PullRequestSourceControlChanged($event)\"\n >\n <ng-container *ngFor=\"let scLookup of SourceControlLookups | slice: 0:Slices.Sources\">\n <mat-option *ngIf=\"SourceControls[scLookup]; let sc\" [value]=\"scLookup\">\n {{sc.Name}}\n </mat-option>\n </ng-container>\n </mat-select>\n </mat-form-field>\n </div>\n\n\n <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n <mat-form-field appearance=\"fill\">\n <mat-label>Base</mat-label>\n <mat-select formControlName=\"targetBranch\" required\n >\n <mat-option *ngFor=\"let branchOpt of BranchOptions\" [value]=\"branchOpt.Name\">\n {{branchOpt.Name}}\n </mat-option>\n </mat-select>\n </mat-form-field>\n \n <mat-icon>arrow_back</mat-icon>\n\n <mat-form-field appearance=\"fill\">\n <mat-label>Compare</mat-label>\n <mat-select formControlName=\"sourceBranch\" required\n >\n <mat-option *ngFor=\"let branchOpt of BranchOptions\" [value]=\"branchOpt.Name\">\n {{branchOpt.Name}}\n </mat-option>\n </mat-select>\n </mat-form-field>\n </div>\n\n <mat-form-field class=\"mat-full-width\">\n <input\n matInput\n placeholder=\"Title\"\n formControlName=\"title\"\n required\n />\n </mat-form-field>\n\n\n <angular-editor \n id=\"pr-editor\"\n formControlName=\"editor\" \n [config]=\"EditorConfig\"\n ></angular-editor>\n\n </ng-container>\n\n <!-- Feature Branch form -->\n\n <ng-container *ngIf=\"data.type === 'CreateBranch' \">\n\n <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n <mat-form-field >\n <mat-label>Source Control</mat-label>\n <mat-select \n formControlName=\"sourceControl\"\n (selectionChange)=\"FeatureBranchSourceControlChanged($event)\"\n >\n <ng-container *ngFor=\"let scLookup of SourceControlLookups | slice: 0:Slices.Sources\">\n <mat-option *ngIf=\"SourceControls[scLookup]; let sc\" [value]=\"scLookup\">\n {{sc.Name}}\n </mat-option>\n </ng-container>\n </mat-select>\n </mat-form-field>\n </div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"space-around center\">\n\n <mat-form-field *ngIf=\"OrganizationOptions?.length > 0\">\n\n <mat-select \n formControlName=\"organization\" \n placeholder=\"Organization\"\n (selectionChange)=\"OrganizationChanged($event)\" \n required\n >\n <ng-container *ngFor=\"let orgOpt of OrganizationOptions\">\n <mat-option [value]=\"orgOpt.Name\">\n {{ orgOpt.Name }}\n </mat-option>\n </ng-container>\n </mat-select>\n\n\n\n </mat-form-field>\n\n <mat-form-field *ngIf=\"RepositoryOptions?.length > 0\">\n\n <mat-select formControlName=\"repository\" \n placeholder=\"Repository\" \n (selectionChange)=\"RepositoryChanged($event)\" \n required\n >\n <ng-container *ngFor=\"let repoOpt of RepositoryOptions\">\n <mat-option [value]=\"repoOpt.Name\">\n {{ repoOpt.Name }}\n </mat-option>\n </ng-container>\n </mat-select> \n </mat-form-field>\n\n </div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"space-around center\" *ngIf=\"BranchOptions?.length > 0\">\n\n <mat-form-field >\n <mat-label>Base Branch</mat-label>\n <mat-select formControlName=\"sourceBranch\" required\n >\n <mat-option *ngFor=\"let branchOpt of BranchOptions\" [value]=\"branchOpt.Name\">\n {{branchOpt.Name}}\n </mat-option>\n </mat-select>\n </mat-form-field>\n\n <mat-form-field >\n <input\n matInput\n placeholder=\"Create New Branch\"\n formControlName=\"targetBranch\"\n required\n />\n </mat-form-field>\n </div>\n\n </ng-container>\n\n\n\n\n\n </form>\n \n \n\n <!-- <mat-error *ngIf=\"ErrorMessage\" fxLayoutAlign=\"center center\" >\n {{ ErrorMessage }}\n </mat-error> -->\n</mat-dialog-content>\n\n<mat-dialog-actions\n class=\"actions-container\" \n div fxLayout=\"row\" \n fxLayoutAlign=\"end center\"\n>\n\n <button \n class=\"action-button\"\n mat-raised-button\n fxFlex=\"25%\"\n (click)=\"CloseDialog()\"\n >\n Cancel\n </button>\n\n <!-- -->\n <button \n mat-raised-button \n color=\"primary\"\n fxFlex=\"25%\"\n class=\"submit\" \n (click)=\"Submit()\"\n [disabled]=\"\n !FeedHeaderFormGroup?.valid \n\"\n \n >\n Submit\n </button>\n</mat-dialog-actions>\n\n\n", styles: [""] }]
|
|
283
|
+
}], ctorParameters: function () { return [{ type: i1.ApplicationsFlowService }, { type: i2.EaCService }, { type: i3.FormBuilder }, { type: i4.MatDialogRef }, { type: undefined, decorators: [{
|
|
284
|
+
type: Inject,
|
|
285
|
+
args: [MAT_DIALOG_DATA]
|
|
286
|
+
}] }]; } });
|
|
287
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"feed-header-dialog.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/dialogs/feed-header-dialog/feed-header-dialog.component.ts","../../../../../../projects/common/src/lib/dialogs/feed-header-dialog/feed-header-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, OnInit } from '@angular/core';\nimport { AbstractControl, FormBuilder, FormGroup, Validators } from '@angular/forms';\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\nimport { MatSelectChange } from '@angular/material/select';\nimport { AngularEditorConfig } from '@kolkov/angular-editor';\nimport { BaseModeledResponse } from '@lcu/common';\nimport { EaCEnvironmentAsCode, EaCSourceControl } from '@semanticjs/common';\nimport { FeedEntry, FeedItemAction } from '../../models/user-feed.model';\nimport { ApplicationsFlowService } from '../../services/applications-flow.service';\nimport { EaCService } from '../../services/eac.service';\nimport { ApplicationsFlowState, GitHubBranch, GitHubOrganization, GitHubRepository } from '../../state/applications-flow.state';\n\nexport interface FeedHeaderDialogData {\n  // action: FeedItemAction,\n  dialogTitle: string,\n  type: string,\n}\n\n@Component({\n  selector: 'lcu-feed-header-dialog',\n  templateUrl: './feed-header-dialog.component.html',\n  styleUrls: ['./feed-header-dialog.component.scss']\n})\n\nexport class FeedHeaderDialogComponent implements OnInit {\n\n  public get ActionIconControl(): AbstractControl {\n    return this.FeedHeaderFormGroup?.controls.actionIcon;\n  }\n\n  public get ActionLinkControl(): AbstractControl {\n    return this.FeedHeaderFormGroup?.controls.actionLink;\n  }\n\n  public get ActionTextControl(): AbstractControl {\n    return this.FeedHeaderFormGroup?.controls.actionText;\n  }\n\n  public get EditorControl(): AbstractControl {\n    return this.FeedHeaderFormGroup?.controls.editor;\n  }\n\n  public get Environment(): EaCEnvironmentAsCode {\n    return this.State?.EaC?.Environments[\n      this.State?.EaC?.Enterprise?.PrimaryEnvironment\n    ];\n  }\n\n  public get TargetBranchFormControl(): AbstractControl {\n    return this.FeedHeaderFormGroup.controls.targetBranch;\n  }\n\n  public get OrganizationFormControl(): AbstractControl {\n    return this.FeedHeaderFormGroup.controls.organization;\n  }\n\n  public get SourceBranchFormControl(): AbstractControl {\n    return this.FeedHeaderFormGroup.controls.sourceBranch;\n  }\n\n  public get RepositoryFormControl(): AbstractControl {\n    return this.FeedHeaderFormGroup.controls.repository;\n  }\n\n\n  public get SourceControlFormControl(): AbstractControl {\n    return this.FeedHeaderFormGroup.controls.sourceControl;\n  }\n\n  public get SourceControlLookups(): Array<string> {\n    return this.State.FeedSourceControlLookups \n      ? this.State.FeedSourceControlLookups \n      : Object.keys(this.SourceControls || {});\n  }\n\n  public get SourceControls(): { [lookup: string]: EaCSourceControl } {\n    return this.Environment?.Sources || {};\n  }\n\n  public get SubtitleFormControl(): AbstractControl {\n    return this.FeedHeaderFormGroup.controls.subtitle;\n  }\n\n  public get State(): ApplicationsFlowState{\n    return this.eacSvc.State;\n  }\n\n  public get TitleFormControl(): AbstractControl {\n    return this.FeedHeaderFormGroup?.controls.title;\n  }\n\n  public BranchOptions: GitHubBranch[];\n\n  public EditorConfig: AngularEditorConfig;\n\n  public FeedHeaderFormGroup: FormGroup;\n\n  public OrganizationOptions: GitHubOrganization[];\n\n  public RepositoryOptions: GitHubRepository[];\n\n  public SourceControl: EaCSourceControl;\n\n  public Slices: { [key: string]: number };\n\n  public SlicesCount: number;\n\n\n\n\n  constructor(protected appsFlowSvc: ApplicationsFlowService,\n    protected eacSvc: EaCService,\n    protected formBldr: FormBuilder,\n    public dialogRef: MatDialogRef<FeedHeaderDialogComponent>,\n    @Inject(MAT_DIALOG_DATA) public data: FeedHeaderDialogData,) {\n      \n    this.EditorConfig = {\n      editable: true,\n      spellcheck: true,\n      height: '250px',\n      minHeight: '0',\n      maxHeight: 'auto',\n      width: 'auto',\n      minWidth: '0',\n      translate: 'yes',\n      enableToolbar: true,\n      showToolbar: true,\n      placeholder: 'Enter text here...',\n      defaultParagraphSeparator: '',\n      defaultFontName: '',\n      defaultFontSize: '',\n      fonts: [\n        {class: 'arial', name: 'Arial'},\n        {class: 'times-new-roman', name: 'Times New Roman'},\n        {class: 'calibri', name: 'Calibri'},\n        {class: 'comic-sans-ms', name: 'Comic Sans MS'}\n      ],\n      customClasses: [\n      {\n        name: 'quote',\n        class: 'quote',\n      },\n      {\n        name: 'redText',\n        class: 'redText'\n      },\n      {\n        name: 'titleText',\n        class: 'titleText',\n        tag: 'h1',\n      },\n      ],\n      sanitize: true,\n      toolbarPosition: 'top',\n      toolbarHiddenButtons: [\n        ['subscript', 'superscript'],\n        ['fontSize']\n      ]\n    };\n\n    this.SlicesCount = 5;\n\n    this.Slices = {\n      Sources: this.SlicesCount,\n    };\n\n    if(this.SourceControlLookups.length === 1){\n      this.SourceControl = this.Environment?.Sources[this.SourceControlLookups[0]];\n    }\n   }\n\n  public ngOnInit(): void {\n    this.setupFeedHeaderForm();\n  }\n\n  public CloseDialog(){\n    this.dialogRef.close();\n  }\n\n  public HandleAction(){\n    if (this.ActionLinkControl.value.startsWith('http')) {\n      window.open(this.ActionLinkControl.value, '_blank');\n    } else {\n      window.location.href = this.ActionLinkControl.value;\n    }\n  }\n\n  public PullRequestSourceControlChanged(event: MatSelectChange){\n    this.SourceControl = this.SourceControls[this.SourceControlFormControl.value];\n    this.listBranches();\n\n  }\n\n  public FeatureBranchSourceControlChanged(event: MatSelectChange){\n    this.SourceControl = this.SourceControls[this.SourceControlFormControl.value];\n    this.listOrganizations();\n\n  }\n\n  public IssueSourceControlChanged(event: MatSelectChange){\n    this.SourceControl = this.SourceControls[this.SourceControlFormControl.value];\n\n  }\n\n  public Submit(){\n    let returnObject: FeedEntry = {\n      ActionIcon: this.ActionIconControl ? this.ActionIconControl.value : null,\n      ActionLink: this.ActionLinkControl ? this.ActionLinkControl.value : null,\n      ActionText: this.ActionTextControl ? this.ActionTextControl.value : null,\n      Avatar: null,\n      Content: this.EditorControl ? this.EditorControl.value : null,\n      ExpiresAt: null,\n      Organization: this.OrganizationFormControl ? this.OrganizationFormControl.value : null,\n      Repositroy: this.RepositoryFormControl ? this.RepositoryFormControl.value : null,\n      SourceBranch: this.SourceBranchFormControl ? this.SourceBranchFormControl.value : null,\n      SourceControlLookup: this.SourceControlFormControl ? this.SourceBranchFormControl.value : null,\n      Subtitle: this.SubtitleFormControl ? this.SubtitleFormControl.value : null,\n      TargetBranch: this.TargetBranchFormControl ? this.TargetBranchFormControl.value: null,\n      Type: this.data.type,\n      Title: this.TitleFormControl ? this.TitleFormControl.value : null,\n\n    }\n    console.log(\"Control: \", returnObject );\n\n    let status = this.eacSvc.SubmitFeedEntry(returnObject);\n    console.log(\"feed entry status: \", status);\n\n    // console.log(\"Editor: \", this.EditorControl.value )\n  }\n\n  public OrganizationChanged(event: MatSelectChange): void {\n\n    this.RepositoryFormControl.reset();\n\n\n    this.listRepositories();\n  }\n\n  public RepositoryChanged(event: MatSelectChange){\n    this.listBranches();\n  }\n\n  //HELPERS\n\n  protected listBranches(): void {\n    // this.Loading = true;\n\n      this.appsFlowSvc\n        .ListBranches(\n          this.SourceControl?.Organization,\n          this.SourceControl?.Repository\n        )\n        .subscribe((response: BaseModeledResponse<GitHubBranch[]>) => {\n          this.BranchOptions = response.Model;\n\n          // this.Loading = false;\n\n          // if (this.EditingSourceControl?.Branches?.length > 0) {\n          //   this.SelectedBranches = this.EditingSourceControl.Branches;\n          // } else if (this.BranchOptions?.length === 1) {\n          //   this.BranchesFormControl.setValue(this.BranchOptions[0].Name);\n\n          //   this.SelectedBranches = [this.BranchOptions[0].Name];\n          // }\n\n        });\n    \n  }\n\n  protected listOrganizations(): void {\n    // this.Loading = true;\n\n    this.appsFlowSvc\n      .ListOrganizations()\n      .subscribe((response: BaseModeledResponse<GitHubOrganization[]>) => {\n        this.OrganizationOptions = response.Model;\n        console.log(\"Organization Options: \", this.OrganizationOptions);\n\n        // this.Loading = false;\n\n        if (this.SourceControl?.Organization) {\n          setTimeout(() => {\n            this.OrganizationFormControl.setValue(\n              this.SourceControl.Organization\n            );\n\n            this.listRepositories(this.SourceControl?.Repository);\n          }, 0);\n        }\n      });\n  }\n\n  protected listRepositories(activeRepo: string = null): void {\n    // this.Loading = true;\n\n    this.appsFlowSvc\n      .ListRepositories(this.OrganizationFormControl.value)\n      .subscribe((response: BaseModeledResponse<GitHubRepository[]>) => {\n        this.RepositoryOptions = response.Model;\n\n        // this.Loading = false;\n\n        if (activeRepo) {\n          setTimeout(() => {\n            this.RepositoryFormControl.setValue(activeRepo);\n\n            this.listBranches();\n\n          }, 0);\n        } \n      });\n  }\n\n  \n\n  protected setupFeedHeaderForm(){\n    this.FeedHeaderFormGroup = this.formBldr.group({});\n\n    switch ( this.data.type ) {\n      case \"Announcement\":\n        this.setupAnnouncementForm();\n          break;\n      case \"PullRequest\":\n        this.setupPRForm();\n          break;\n      case \"OpenIssue\":\n        this.setupIssueForm();\n          break;\n      case \"CreateBranch\":\n        this.setupFeatureBranchForm();\n          break;\n      default: \n          // \n          break;\n   }\n\n  }\n\n  protected setupAnnouncementForm(){\n    this.setupBasicForm();\n\n    this.FeedHeaderFormGroup.addControl(\n      'subtitle',\n      this.formBldr.control(\n        ''\n      )\n    );\n\n    this.FeedHeaderFormGroup.addControl(\n      'actionText',\n      this.formBldr.control(\n        ''\n      )\n    );\n\n    this.FeedHeaderFormGroup.addControl(\n      'actionLink',\n      this.formBldr.control(\n        ''\n      )\n    );\n    this.FeedHeaderFormGroup.addControl(\n      'actionIcon',\n      this.formBldr.control(\n        ''\n      )\n    );\n\n\n  }\n\n  protected setupPRForm(){\n    this.listBranches();\n    this.setupIssueForm();\n    this.setupBranchesForm();\n\n\n  }\n\nprotected setupBasicForm(){\n  this.FeedHeaderFormGroup.addControl(\n    'title',\n    this.formBldr.control(\n      '',[Validators.required]\n    )\n  );\n\n  this.FeedHeaderFormGroup.addControl(\n    'editor',\n    this.formBldr.control(\n      ''\n    )\n  );\n}\n\n\n  protected setupIssueForm(){\n    this.setupBasicForm();\n    \n    this.setupSourceControlForm();\n\n  }\n\n  protected setupFeatureBranchForm(){\n\n    this.setupSourceControlForm();\n\n    this.FeedHeaderFormGroup.addControl(\n      'organization',\n      this.formBldr.control(\n        ''\n      )\n    );\n\n    this.FeedHeaderFormGroup.addControl(\n      'repository',\n      this.formBldr.control(\n        ''\n      )\n    );\n\n    this.setupBranchesForm();\n\n  }\n\n  protected setupSourceControlForm(){\n    this.FeedHeaderFormGroup.addControl(\n      'sourceControl',\n      this.formBldr.control(\n        ''\n      )\n    );\n  }\n\n  protected setupBranchesForm(){\n    this.FeedHeaderFormGroup.addControl(\n      'targetBranch',\n      this.formBldr.control(\n        ''\n      )\n    );\n\n    this.FeedHeaderFormGroup.addControl(\n      'sourceBranch',\n      this.formBldr.control(\n        ''\n      )\n    );\n  }\n\n}\n","<div class=\"dialog-header\" fxLayoutAlign=\"space-between center\">\n    <h2 mat-dialog-title>{{data.dialogTitle}}</h2>\n    <button mat-icon-button (click)=\"CloseDialog()\">\n            <mat-icon>cancel</mat-icon>\n    </button>\n</div>\n\n<mat-dialog-content>\n    <form [formGroup]=\"FeedHeaderFormGroup\" >\n\n        <!-- ISSUE FORM -->\n        <ng-container *ngIf=\"data.type === 'OpenIssue' \">\n\n            <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n                <mat-form-field appearance=\"fill\">\n                    <mat-label>Source Control</mat-label>\n                    <mat-select \n                        formControlName=\"sourceControl\"\n                        (selectionChange)=\"IssueSourceControlChanged($event)\"\n\n                    >\n                    <ng-container *ngFor=\"let scLookup of SourceControlLookups | slice: 0:Slices.Sources\">\n                    <mat-option *ngIf=\"SourceControls[scLookup]; let sc\" [value]=\"scLookup\">\n                        {{sc.Name}}\n                    </mat-option>\n                    </ng-container>\n                    </mat-select>\n                </mat-form-field>\n            </div>\n\n            <mat-form-field class=\"mat-full-width\">\n                <input\n                matInput\n                placeholder=\"Title\"\n                formControlName=\"title\"\n                required\n                />\n            </mat-form-field>\n\n\n            <angular-editor \n                id=\"issue-editor\"\n                formControlName=\"editor\" \n                [config]=\"EditorConfig\"\n            ></angular-editor>\n        </ng-container>\n\n        <!-- ANNOUNCEMENT FORM -->\n\n        <ng-container *ngIf=\"data.type === 'Announcement' \">\n            <mat-form-field class=\"mat-full-width\">\n                <input\n                matInput\n                placeholder=\"Title\"\n                formControlName=\"title\"\n                required\n                />\n            </mat-form-field>\n\n            <mat-form-field class=\"mat-full-width\">\n                <input\n                matInput\n                placeholder=\"Subtitle\"\n                formControlName=\"subtitle\"\n                />\n            </mat-form-field>\n\n            <angular-editor \n                id=\"announcement-editor\"\n                formControlName=\"editor\" \n                [config]=\"EditorConfig\"\n            ></angular-editor>\n\n            <div fxLayout=\"row\" fxLayoutAlign=\"space-between center\">\n\n                <mat-form-field class=\"mat-full-width\">\n                    <input\n                    matInput\n                    placeholder=\"Action Text\"\n                    formControlName=\"actionText\"\n                    />\n                </mat-form-field>\n\n                <mat-form-field class=\"mat-full-width\">\n                    <input\n                    matInput\n                    placeholder=\"Action Link\"\n                    formControlName=\"actionLink\"\n                    />\n                </mat-form-field>\n\n                <mat-form-field class=\"mat-full-width\">\n                    <input\n                    matInput\n                    placeholder=\"Action Icon\"\n                    formControlName=\"actionIcon\"\n                    />\n                </mat-form-field>\n\n            </div>\n\n            <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n                <button \n                *ngIf=\"ActionTextControl?.value || ActionIconControl?.value\"\n                    mat-button color=\"primary\" \n                    (click)=\"HandleAction(ActionLinkControl?.value)\"\n                >\n                    <mat-icon *ngIf=\"ActionIconControl?.value\">{{ ActionIconControl?.value }}</mat-icon>\n            \n                    {{ ActionTextControl?.value }}\n                  </button>\n\n                  <button \n                    *ngIf=\"!ActionTextControl?.value && !ActionIconControl?.value\"\n                    mat-button color=\"primary\" \n                >\n                    <mat-icon>cruelty_free</mat-icon>\n            \n                    Example Button\n                  </button>\n            </div>\n\n        </ng-container>\n\n        <!-- PR FORM -->\n\n        <ng-container *ngIf=\"data.type === 'PullRequest' \">\n\n            <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n                <mat-form-field appearance=\"fill\">\n                    <mat-label>Source Control</mat-label>\n                    <mat-select \n                        formControlName=\"sourceControl\"\n                        (selectionChange)=\"PullRequestSourceControlChanged($event)\"\n                    >\n                    <ng-container *ngFor=\"let scLookup of SourceControlLookups | slice: 0:Slices.Sources\">\n                    <mat-option *ngIf=\"SourceControls[scLookup]; let sc\" [value]=\"scLookup\">\n                        {{sc.Name}}\n                    </mat-option>\n                    </ng-container>\n                    </mat-select>\n                </mat-form-field>\n            </div>\n\n\n            <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n            <mat-form-field appearance=\"fill\">\n                <mat-label>Base</mat-label>\n                <mat-select formControlName=\"targetBranch\" required\n                >\n                  <mat-option *ngFor=\"let branchOpt of BranchOptions\" [value]=\"branchOpt.Name\">\n                    {{branchOpt.Name}}\n                  </mat-option>\n                </mat-select>\n            </mat-form-field>\n              \n              <mat-icon>arrow_back</mat-icon>\n\n              <mat-form-field appearance=\"fill\">\n                <mat-label>Compare</mat-label>\n                <mat-select formControlName=\"sourceBranch\" required\n                >\n                  <mat-option *ngFor=\"let branchOpt of BranchOptions\" [value]=\"branchOpt.Name\">\n                    {{branchOpt.Name}}\n                  </mat-option>\n                </mat-select>\n              </mat-form-field>\n            </div>\n\n            <mat-form-field class=\"mat-full-width\">\n                <input\n                matInput\n                placeholder=\"Title\"\n                formControlName=\"title\"\n                required\n                />\n            </mat-form-field>\n\n\n            <angular-editor \n                id=\"pr-editor\"\n                formControlName=\"editor\" \n                [config]=\"EditorConfig\"\n            ></angular-editor>\n\n        </ng-container>\n\n        <!-- Feature Branch form -->\n\n        <ng-container *ngIf=\"data.type === 'CreateBranch' \">\n\n            <div fxLayout=\"row\" fxLayoutAlign=\"center center\">\n\n                <mat-form-field >\n                    <mat-label>Source Control</mat-label>\n                    <mat-select \n                        formControlName=\"sourceControl\"\n                        (selectionChange)=\"FeatureBranchSourceControlChanged($event)\"\n                    >\n                    <ng-container *ngFor=\"let scLookup of SourceControlLookups | slice: 0:Slices.Sources\">\n                    <mat-option *ngIf=\"SourceControls[scLookup]; let sc\" [value]=\"scLookup\">\n                        {{sc.Name}}\n                    </mat-option>\n                    </ng-container>\n                    </mat-select>\n                </mat-form-field>\n            </div>\n\n            <div fxLayout=\"row\" fxLayoutAlign=\"space-around center\">\n\n            <mat-form-field *ngIf=\"OrganizationOptions?.length > 0\">\n\n            <mat-select \n              formControlName=\"organization\" \n              placeholder=\"Organization\"\n              (selectionChange)=\"OrganizationChanged($event)\" \n              required\n            >\n              <ng-container *ngFor=\"let orgOpt of OrganizationOptions\">\n                <mat-option [value]=\"orgOpt.Name\">\n                  {{ orgOpt.Name }}\n                </mat-option>\n              </ng-container>\n            </mat-select>\n\n\n\n          </mat-form-field>\n\n          <mat-form-field *ngIf=\"RepositoryOptions?.length > 0\">\n\n            <mat-select formControlName=\"repository\" \n                        placeholder=\"Repository\"  \n                        (selectionChange)=\"RepositoryChanged($event)\" \n                        required\n            >\n              <ng-container *ngFor=\"let repoOpt of RepositoryOptions\">\n                <mat-option [value]=\"repoOpt.Name\">\n                  {{ repoOpt.Name }}\n                </mat-option>\n              </ng-container>\n            </mat-select>  \n          </mat-form-field>\n\n        </div>\n\n          <div fxLayout=\"row\" fxLayoutAlign=\"space-around center\" *ngIf=\"BranchOptions?.length > 0\">\n\n            <mat-form-field >\n                <mat-label>Base Branch</mat-label>\n                <mat-select formControlName=\"sourceBranch\" required\n                >\n                <mat-option *ngFor=\"let branchOpt of BranchOptions\" [value]=\"branchOpt.Name\">\n                    {{branchOpt.Name}}\n                </mat-option>\n                </mat-select>\n            </mat-form-field>\n\n            <mat-form-field >\n                <input\n                matInput\n                placeholder=\"Create New Branch\"\n                formControlName=\"targetBranch\"\n                required\n                />\n            </mat-form-field>\n        </div>\n\n        </ng-container>\n\n\n\n\n\n    </form>\n    \n    \n\n    <!-- <mat-error *ngIf=\"ErrorMessage\" fxLayoutAlign=\"center center\" >\n        {{ ErrorMessage }}\n    </mat-error> -->\n</mat-dialog-content>\n\n<mat-dialog-actions\n    class=\"actions-container\" \n    div fxLayout=\"row\" \n    fxLayoutAlign=\"end center\"\n>\n\n    <button \n        class=\"action-button\"\n        mat-raised-button\n        fxFlex=\"25%\"\n        (click)=\"CloseDialog()\"\n    >\n        Cancel\n    </button>\n\n    <!--  -->\n    <button \n        mat-raised-button \n        color=\"primary\"\n        fxFlex=\"25%\"\n        class=\"submit\" \n        (click)=\"Submit()\"\n        [disabled]=\"\n    !FeedHeaderFormGroup?.valid \n\"\n        \n    >\n        Submit\n    </button>\n</mat-dialog-actions>\n\n\n"]}
|