@lowcodeunit/applications-flow-common 1.34.59-krakyn-app → 1.34.60-social-ui-bug-fixes
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 -5
- package/esm2020/lib/applications-flow.module.mjs +26 -42
- package/esm2020/lib/controls/devops-source-control-form/devops-source-control-form.component.mjs +3 -3
- package/esm2020/lib/dialogs/build-pipeline-dialog/build-pipeline-dialog.component.mjs +8 -15
- package/esm2020/lib/dialogs/custom-domain-dialog/custom-domain-dialog.component.mjs +3 -3
- package/esm2020/lib/dialogs/source-control-dialog/source-control-dialog.component.mjs +8 -15
- package/esm2020/lib/elements/feed-card-sm/feed-card-sm.component.mjs +2 -2
- package/esm2020/lib/elements/flow-tool/flow-tool.component.mjs +75 -0
- package/esm2020/lib/elements/gh-control/gh-control.component.mjs +107 -0
- package/esm2020/lib/elements/main-feed-card/main-feed-card.component.mjs +5 -6
- package/esm2020/lib/elements/projects/controls/git-auth/git-auth.component.mjs +2 -3
- package/esm2020/lib/elements/projects/controls/project-items/project-items.component.mjs +4 -2
- package/esm2020/lib/elements/projects/controls/tabs/devops/devops.component.mjs +4 -6
- package/esm2020/lib/elements/projects/controls/tabs/dfs-modifiers/dfs-modifiers.component.mjs +6 -4
- 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 +1 -3
- package/esm2020/lib/services/applications-flow.service.mjs +25 -15
- package/esm2020/lib/services/eac.service.mjs +15 -78
- package/esm2020/lib/services/project.service.mjs +69 -36
- package/esm2020/lib/state/applications-flow.state.mjs +1 -1
- package/fesm2015/lowcodeunit-applications-flow-common.mjs +2084 -2728
- package/fesm2015/lowcodeunit-applications-flow-common.mjs.map +1 -1
- package/fesm2020/lowcodeunit-applications-flow-common.mjs +2046 -2669
- package/fesm2020/lowcodeunit-applications-flow-common.mjs.map +1 -1
- package/lcu.api.d.ts +3 -4
- package/lib/applications-flow.module.d.ts +18 -21
- package/lib/dialogs/build-pipeline-dialog/build-pipeline-dialog.component.d.ts +0 -2
- package/lib/dialogs/source-control-dialog/source-control-dialog.component.d.ts +0 -2
- package/lib/elements/flow-tool/flow-tool.component.d.ts +28 -0
- package/lib/elements/{feed-header/feed-header.component.d.ts → gh-control/gh-control.component.d.ts} +7 -9
- package/lib/elements/main-feed-card/main-feed-card.component.d.ts +1 -1
- package/lib/models/user-feed.model.d.ts +0 -17
- package/lib/services/applications-flow.service.d.ts +5 -4
- package/lib/services/eac.service.d.ts +8 -12
- package/lib/services/project.service.d.ts +7 -5
- package/lib/state/applications-flow.state.d.ts +1 -2
- package/package.json +1 -1
- package/esm2020/lib/controls/dfs-modifiers-form/dfs-modifiers-form.component.mjs +0 -275
- package/esm2020/lib/dialogs/dfs-modifiers-dialog/dfs-modifiers-dialog.component.mjs +0 -109
- package/esm2020/lib/dialogs/feed-header-dialog/feed-header-dialog.component.mjs +0 -280
- package/esm2020/lib/elements/feed-header/feed-header.component.mjs +0 -131
- package/lib/controls/dfs-modifiers-form/dfs-modifiers-form.component.d.ts +0 -62
- package/lib/dialogs/dfs-modifiers-dialog/dfs-modifiers-dialog.component.d.ts +0 -41
- package/lib/dialogs/feed-header-dialog/feed-header-dialog.component.d.ts +0 -71
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import { EaCNapkinIDEFlowImporter } from '@semanticjs/napkin-ide';
|
|
3
|
+
// import '@semanticjs/krakyn';
|
|
4
|
+
import { ConstantUtils, DragDropUtils, DragItemsTemplates, VariablesUtils } from '@semanticjs/krakyn';
|
|
5
|
+
import { ApplicationsFlowState } from '../../state/applications-flow.state';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "../../services/applications-flow.service";
|
|
8
|
+
import * as i2 from "../../services/project.service";
|
|
9
|
+
export class FlowToolComponent {
|
|
10
|
+
constructor(injector, appsFlowSvc, projectService) {
|
|
11
|
+
// super(injector);
|
|
12
|
+
this.injector = injector;
|
|
13
|
+
this.appsFlowSvc = appsFlowSvc;
|
|
14
|
+
this.projectService = projectService;
|
|
15
|
+
console.log('CONSTRUCTOR');
|
|
16
|
+
this.State = new ApplicationsFlowState();
|
|
17
|
+
// VariablesUtils.DataFlowModuleData =
|
|
18
|
+
// [
|
|
19
|
+
// ConstantUtils.NAPKIN_IDE_MODULE_DATA,
|
|
20
|
+
// ConstantUtils.HOME_MODULE_DATA
|
|
21
|
+
// ];
|
|
22
|
+
this.Title = 'The Krakyn Tool';
|
|
23
|
+
this.SideMenuItems = DragItemsTemplates.FLOW_DRAG_ITEMS(DragDropUtils.Drag);
|
|
24
|
+
this.TabMenuItems = [
|
|
25
|
+
{ Label: 'External Data Test', Target: 'ExternalData', Class: 'selected' },
|
|
26
|
+
{ Label: 'Original Data', Target: 'OriginalData', Class: '' }
|
|
27
|
+
// { Label: 'Home', Target: 'Home' }
|
|
28
|
+
];
|
|
29
|
+
// this.Data = VariablesUtils.DataFlowModuleData[0];
|
|
30
|
+
// console.log('Krakyn Tool Test Data: ', this.Data.Data);
|
|
31
|
+
}
|
|
32
|
+
// Lifecycle hooks
|
|
33
|
+
ngOnInit() {
|
|
34
|
+
this.handleStateChange()
|
|
35
|
+
.then((eac) => { });
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Import tool data
|
|
39
|
+
*/
|
|
40
|
+
importData() {
|
|
41
|
+
const eaCNapkinIDEFlowImporter = new EaCNapkinIDEFlowImporter();
|
|
42
|
+
this.Title = 'Imported data for Krakyn';
|
|
43
|
+
const externalData = {
|
|
44
|
+
Module: 'ExternalData',
|
|
45
|
+
Data: eaCNapkinIDEFlowImporter.Import(this.State.EaC)
|
|
46
|
+
};
|
|
47
|
+
const dataIndex = 0;
|
|
48
|
+
VariablesUtils.DataFlowModuleData = [
|
|
49
|
+
ConstantUtils.MapData('ExternalData', externalData.Data),
|
|
50
|
+
ConstantUtils.MapData('OriginalData', ConstantUtils.ORIGINAL_TEST_DATA)
|
|
51
|
+
];
|
|
52
|
+
VariablesUtils.ActiveModule = VariablesUtils.DataFlowModuleData[dataIndex].Module;
|
|
53
|
+
this.KrakynData = VariablesUtils.DataFlowModuleData[dataIndex];
|
|
54
|
+
console.log('KRAKYN - DATA SET!!!!!!!', this.KrakynData);
|
|
55
|
+
}
|
|
56
|
+
async handleStateChange() {
|
|
57
|
+
console.log('HANDLE STATE CHANGE');
|
|
58
|
+
this.State.Loading = true;
|
|
59
|
+
await this.projectService.HasValidConnection(this.State);
|
|
60
|
+
await this.projectService.EnsureUserEnterprise(this.State);
|
|
61
|
+
await this.projectService.ListEnterprises(this.State);
|
|
62
|
+
if (this.State.Enterprises?.length > 0) {
|
|
63
|
+
this.State.Loading = false;
|
|
64
|
+
this.importData();
|
|
65
|
+
await this.projectService.GetActiveEnterprise(this.State);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
FlowToolComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: FlowToolComponent, deps: [{ token: i0.Injector }, { token: i1.ApplicationsFlowService }, { token: i2.ProjectService }], target: i0.ɵɵFactoryTarget.Component });
|
|
70
|
+
FlowToolComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: FlowToolComponent, selector: "lcu-flow-tool", ngImport: i0, template: "<krakyn-flow-tool\n [HeaderTitle] = 'Title'\n [FlowData] = 'KrakynData'\n [SideMenuItems] = 'SideMenuItems'\n [TabMenuItems] = 'TabMenuItems'>\n</krakyn-flow-tool>", styles: [""] });
|
|
71
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: FlowToolComponent, decorators: [{
|
|
72
|
+
type: Component,
|
|
73
|
+
args: [{ selector: 'lcu-flow-tool', template: "<krakyn-flow-tool\n [HeaderTitle] = 'Title'\n [FlowData] = 'KrakynData'\n [SideMenuItems] = 'SideMenuItems'\n [TabMenuItems] = 'TabMenuItems'>\n</krakyn-flow-tool>", styles: [""] }]
|
|
74
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i1.ApplicationsFlowService }, { type: i2.ProjectService }]; } });
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"flow-tool.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/elements/flow-tool/flow-tool.component.ts","../../../../../../projects/common/src/lib/elements/flow-tool/flow-tool.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAoB,MAAM,eAAe,CAAC;AAC5D,OAAO,EAAE,wBAAwB,EAAE,MAAM,wBAAwB,CAAC;AAClE,+BAA+B;AAC/B,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,kBAAkB,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACtG,OAAO,EAAE,qBAAqB,EAAE,MAAM,qCAAqC,CAAC;;;;AAU5E,MAAM,OAAO,iBAAiB;IAW5B,YACY,QAAkB,EAClB,WAAoC,EACpC,cAA8B;QAGxC,mBAAmB;QALT,aAAQ,GAAR,QAAQ,CAAU;QAClB,gBAAW,GAAX,WAAW,CAAyB;QACpC,mBAAc,GAAd,cAAc,CAAgB;QAKxC,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;QAE3B,IAAI,CAAC,KAAK,GAAG,IAAI,qBAAqB,EAAE,CAAC;QAEzC,sCAAsC;QACtC,IAAI;QACJ,0CAA0C;QAC1C,mCAAmC;QACnC,KAAK;QAEL,IAAI,CAAC,KAAK,GAAG,iBAAiB,CAAC;QAE/B,IAAI,CAAC,aAAa,GAAG,kBAAkB,CAAC,eAAe,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QAE5E,IAAI,CAAC,YAAY,GAAG;YAClB,EAAE,KAAK,EAAE,oBAAoB,EAAE,MAAM,EAAE,cAAc,EAAE,KAAK,EAAE,UAAU,EAAE;YAC1E,EAAE,KAAK,EAAE,eAAe,EAAE,MAAM,EAAE,cAAc,EAAE,KAAK,EAAE,EAAE,EAAE;YAC/D,sCAAsC;SACrC,CAAC;QAEF,oDAAoD;QACpD,0DAA0D;IAC3D,CAAC;IAED,kBAAkB;IACZ,QAAQ;QAEb,IAAI,CAAC,iBAAiB,EAAE;aACvB,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,GAAE,CAAC,CAAC,CAAC;IACrB,CAAC;IAED;;OAEG;IACO,UAAU;QAElB,MAAM,wBAAwB,GAA6B,IAAI,wBAAwB,EAAE,CAAC;QAE1F,IAAI,CAAC,KAAK,GAAG,0BAA0B,CAAC;QAExC,MAAM,YAAY,GAAkC;YAClD,MAAM,EAAE,cAAc;YACtB,IAAI,EAAE,wBAAwB,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC;SACtD,CAAC;QAEF,MAAM,SAAS,GAAW,CAAC,CAAC;QAE5B,cAAc,CAAC,kBAAkB,GAAG;YAClC,aAAa,CAAC,OAAO,CAAC,cAAc,EAAE,YAAY,CAAC,IAAI,CAAC;YACxD,aAAa,CAAC,OAAO,CAAC,cAAc,EAAE,aAAa,CAAC,kBAAkB,CAAC;SACxE,CAAC;QAEF,cAAc,CAAC,YAAY,GAAG,cAAc,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC;QAElF,IAAI,CAAC,UAAU,GAAG,cAAc,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;QAE/D,OAAO,CAAC,GAAG,CAAC,0BAA0B,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IAE3D,CAAC;IAES,KAAK,CAAC,iBAAiB;QAE/B,OAAO,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;QAEnC,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC;QAE1B,MAAM,IAAI,CAAC,cAAc,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAEzD,MAAM,IAAI,CAAC,cAAc,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAE3D,MAAM,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAEtD,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,MAAM,GAAG,CAAC,EAAE;YAEtC,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,KAAK,CAAC;YAE3B,IAAI,CAAC,UAAU,EAAE,CAAC;YAElB,MAAM,IAAI,CAAC,cAAc,CAAC,mBAAmB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAE3D;IACH,CAAC;;8GApGU,iBAAiB;kGAAjB,iBAAiB,qDCd9B,iLAKmB;2FDSN,iBAAiB;kBAP7B,SAAS;+BACE,eAAe","sourcesContent":["import { Component, Injector, OnInit } from '@angular/core';\nimport { EaCNapkinIDEFlowImporter } from '@semanticjs/napkin-ide';\n// import '@semanticjs/krakyn';\nimport { ConstantUtils, DragDropUtils, DragItemsTemplates, VariablesUtils } from '@semanticjs/krakyn';\nimport { ApplicationsFlowState } from '../../state/applications-flow.state';\nimport { ApplicationsFlowService } from '../../services/applications-flow.service';\nimport { ProjectService } from '../../services/project.service';\n@Component({\n  selector: 'lcu-flow-tool',\n  templateUrl: './flow-tool.component.html',\n  styleUrls: ['./flow-tool.component.scss']\n})\n\n\nexport class FlowToolComponent implements OnInit  {\n\n  public State: ApplicationsFlowState;\n\n\n  // Array<{Module: string, Data: Array<any>}>\n  public KrakynData: any;\n  public SideMenuItems: any;\n  public Title: string;\n  public TabMenuItems: Array<{Label: string, Target: string, Class?: string}>;\n\n  constructor(\n    protected injector: Injector,\n    protected appsFlowSvc: ApplicationsFlowService,\n    protected projectService: ProjectService\n  ) {\n\n    // super(injector);\n\n    console.log('CONSTRUCTOR');\n\n    this.State = new ApplicationsFlowState();\n\n    // VariablesUtils.DataFlowModuleData =\n    // [\n    //   ConstantUtils.NAPKIN_IDE_MODULE_DATA,\n    //   ConstantUtils.HOME_MODULE_DATA\n    // ];\n\n    this.Title = 'The Krakyn Tool';\n\n    this.SideMenuItems = DragItemsTemplates.FLOW_DRAG_ITEMS(DragDropUtils.Drag);\n\n    this.TabMenuItems = [\n      { Label: 'External Data Test', Target: 'ExternalData', Class: 'selected' },\n      { Label: 'Original Data', Target: 'OriginalData', Class: '' }\n    //   { Label: 'Home', Target: 'Home' }\n    ];\n\n    // this.Data = VariablesUtils.DataFlowModuleData[0];\n    // console.log('Krakyn Tool Test Data: ', this.Data.Data);\n   }\n\n   // Lifecycle hooks\n  public ngOnInit(): void {\n\n    this.handleStateChange()\n    .then((eac) => {});\n  }\n\n  /**\n   * Import tool data\n   */\n  protected importData(): void {\n\n    const eaCNapkinIDEFlowImporter: EaCNapkinIDEFlowImporter = new EaCNapkinIDEFlowImporter();\n\n    this.Title = 'Imported data for Krakyn';\n\n    const externalData: { Module: string, Data: any } = {\n      Module: 'ExternalData',\n      Data: eaCNapkinIDEFlowImporter.Import(this.State.EaC)\n    };\n\n    const dataIndex: number = 0;\n\n    VariablesUtils.DataFlowModuleData = [\n      ConstantUtils.MapData('ExternalData', externalData.Data),\n      ConstantUtils.MapData('OriginalData', ConstantUtils.ORIGINAL_TEST_DATA)\n    ];\n\n    VariablesUtils.ActiveModule = VariablesUtils.DataFlowModuleData[dataIndex].Module;\n\n    this.KrakynData = VariablesUtils.DataFlowModuleData[dataIndex];\n\n    console.log('KRAKYN - DATA SET!!!!!!!', this.KrakynData);\n\n  }\n\n  protected async handleStateChange(): Promise<void> {\n\n    console.log('HANDLE STATE CHANGE');\n\n    this.State.Loading = true;\n\n    await this.projectService.HasValidConnection(this.State);\n\n    await this.projectService.EnsureUserEnterprise(this.State);\n\n    await this.projectService.ListEnterprises(this.State);\n\n    if (this.State.Enterprises?.length > 0) {\n\n      this.State.Loading = false;\n\n      this.importData();\n\n      await this.projectService.GetActiveEnterprise(this.State);\n\n    }\n  }\n}\n","<krakyn-flow-tool\n    [HeaderTitle] = 'Title'\n    [FlowData] = 'KrakynData'\n    [SideMenuItems] = 'SideMenuItems'\n    [TabMenuItems] = 'TabMenuItems'>\n</krakyn-flow-tool>"]}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import { NewApplicationDialogComponent } from '../../dialogs/new-application-dialog/new-application-dialog.component';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../../services/eac.service";
|
|
5
|
+
import * as i2 from "@angular/material/dialog";
|
|
6
|
+
import * as i3 from "@angular/material/card";
|
|
7
|
+
import * as i4 from "@angular/material/icon";
|
|
8
|
+
import * as i5 from "@angular/material/form-field";
|
|
9
|
+
import * as i6 from "@angular/material/button";
|
|
10
|
+
import * as i7 from "@angular/material/menu";
|
|
11
|
+
import * as i8 from "skeleton-elements/angular";
|
|
12
|
+
import * as i9 from "@angular/common";
|
|
13
|
+
import * as i10 from "@angular/flex-layout/flex";
|
|
14
|
+
import * as i11 from "@angular/material/input";
|
|
15
|
+
import * as i12 from "@angular/forms";
|
|
16
|
+
export class GhControlComponent {
|
|
17
|
+
constructor(eacSvc, dialog) {
|
|
18
|
+
this.eacSvc = eacSvc;
|
|
19
|
+
this.dialog = dialog;
|
|
20
|
+
this.InputLabel = "Create Pull Request";
|
|
21
|
+
this.SkeletonEffect = "wave";
|
|
22
|
+
this.selectedBtn = "pr-btn";
|
|
23
|
+
}
|
|
24
|
+
get ActiveEnvironmentLookup() {
|
|
25
|
+
// TODO: Eventually support multiple environments
|
|
26
|
+
const envLookups = Object.keys(this.State?.EaC?.Environments || {});
|
|
27
|
+
return envLookups[0];
|
|
28
|
+
}
|
|
29
|
+
get State() {
|
|
30
|
+
return this.eacSvc.State;
|
|
31
|
+
}
|
|
32
|
+
ngOnInit() {
|
|
33
|
+
}
|
|
34
|
+
ngAfterViewInit() {
|
|
35
|
+
this.addSelectBtn();
|
|
36
|
+
}
|
|
37
|
+
CreateFeatureBranch() {
|
|
38
|
+
this.removeSelectedBtn();
|
|
39
|
+
this.InputLabel = "Create Feature Branch";
|
|
40
|
+
this.selectedBtn = "fb-btn";
|
|
41
|
+
this.addSelectBtn();
|
|
42
|
+
console.log("create feature branch selected");
|
|
43
|
+
}
|
|
44
|
+
OpenIssue() {
|
|
45
|
+
this.removeSelectedBtn();
|
|
46
|
+
this.InputLabel = "Open Issue";
|
|
47
|
+
this.selectedBtn = "oi-btn";
|
|
48
|
+
this.addSelectBtn();
|
|
49
|
+
console.log("open issue selected");
|
|
50
|
+
}
|
|
51
|
+
CreatePullRequest() {
|
|
52
|
+
this.removeSelectedBtn();
|
|
53
|
+
this.InputLabel = "Create Pull Request";
|
|
54
|
+
this.selectedBtn = "pr-btn";
|
|
55
|
+
this.addSelectBtn();
|
|
56
|
+
console.log("create pull request selected");
|
|
57
|
+
}
|
|
58
|
+
CreateNewApp() {
|
|
59
|
+
const dialogRef = this.dialog.open(NewApplicationDialogComponent, {
|
|
60
|
+
width: '600px',
|
|
61
|
+
data: {
|
|
62
|
+
environmentLookup: this.ActiveEnvironmentLookup,
|
|
63
|
+
},
|
|
64
|
+
});
|
|
65
|
+
dialogRef.afterClosed().subscribe((result) => {
|
|
66
|
+
// console.log('The dialog was closed');
|
|
67
|
+
// console.log("result:", result)
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
RouteToPath(path) {
|
|
71
|
+
window.location.href = path;
|
|
72
|
+
}
|
|
73
|
+
Submit() {
|
|
74
|
+
console.log("submitting: ", this.value);
|
|
75
|
+
switch (this.selectedBtn) {
|
|
76
|
+
case "pr-btn":
|
|
77
|
+
//Pull request
|
|
78
|
+
console.log("creating pull request: ", this.value);
|
|
79
|
+
break;
|
|
80
|
+
case "oi-btn":
|
|
81
|
+
//Open Issue
|
|
82
|
+
console.log("Open issue: ", this.value);
|
|
83
|
+
break;
|
|
84
|
+
case "fb-btn":
|
|
85
|
+
//Feature Branch
|
|
86
|
+
console.log("creating feature branch: ", this.value);
|
|
87
|
+
break;
|
|
88
|
+
default:
|
|
89
|
+
console.log("hmm");
|
|
90
|
+
break;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
//HELPERS
|
|
94
|
+
addSelectBtn() {
|
|
95
|
+
// (<HTMLElement>document.getElementById(this.selectedBtn)).classList.add('selected');
|
|
96
|
+
}
|
|
97
|
+
removeSelectedBtn() {
|
|
98
|
+
// (<HTMLElement>document.getElementById(this.selectedBtn)).classList.remove('selected');
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
GhControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: GhControlComponent, deps: [{ token: i1.EaCService }, { token: i2.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
|
|
102
|
+
GhControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: GhControlComponent, selector: "lcu-gh-control", ngImport: i0, template: "<mat-card class=\"social-card\" *ngIf=\"false\">\n <ng-container *ngIf=\"!State?.Loading\">\n <div class=\"gh-card-container\" fxLayout=\"row\" fxLayoutAlign=\"center center\">\n <mat-icon fxFlex=\"15%\" class=\"gh-icon\">error_outline</mat-icon>\n <div fxFlex=\"70%\" class=\"gh-card-main-content\">\n <mat-form-field appearance=\"fill\" class=\"gh-input\">\n <mat-label>{{ InputLabel }}</mat-label>\n <input matInput type=\"text\" [(ngModel)]=\"value\" />\n <!-- <button *ngIf=\"value\" matSuffix mat-icon-button aria-label=\"Clear\" (click)=\"value=''\">\n <mat-icon>close</mat-icon>\n </button> -->\n </mat-form-field>\n </div>\n\n <button\n fxFlex=\"15%\"\n mat-button\n (click)=\"Submit()\"\n id=\"submit-btn\"\n color=\"primary\"\n >\n Submit\n </button>\n </div>\n\n <mat-card-actions fxLayout=\"row\" fxLayoutAlign=\"space-around center\">\n <button mat-button (click)=\"CreatePullRequest()\" id=\"pr-btn\">\n Pull Request\n </button>\n <button mat-button (click)=\"OpenIssue()\" id=\"oi-btn\">Open Issue</button>\n <button mat-button (click)=\"CreateFeatureBranch()\" id=\"fb-btn\">\n Feature Branch\n </button>\n <button mat-icon-button [matMenuTriggerFor]=\"menu\" aria-label=\"menu\">\n <mat-icon>more_horiz</mat-icon>\n </button>\n <mat-menu #menu=\"matMenu\">\n <button class=\"gh-menu-action\" mat-menu-item (click)=\"CreateNewApp()\">\n Create New App\n </button>\n\n <button\n class=\"gh-menu-action\"\n mat-menu-item\n (click)=\"RouteToPath('/dashboard/create-project')\"\n >\n Create Project\n </button>\n </mat-menu>\n </mat-card-actions>\n </ng-container>\n\n <!-- SKELETON -->\n <ng-container *ngIf=\"State?.Loading\">\n <div id=\"gh-card-skeleton\" fxLayout=\"row\" fxLayoutAlign=\"center center\">\n <skeleton-avatar\n class=\"gh-icon\"\n [showIcon]=\"false\"\n [effect]=\"SkeletonEffect\"\n ></skeleton-avatar>\n\n <div fxFlex=\"70%\" class=\"gh-card-main-content\">\n <skeleton-block\n height=\"60px\"\n [effect]=\"SkeletonEffect\"\n ></skeleton-block>\n </div>\n\n <div\n skeleton-text\n fxFlex=\"15%\"\n [effect]=\"SkeletonEffect\"\n style=\"margin: 0px 10px\"\n >\n Submit\n </div>\n </div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"space-around center\">\n <div skeleton-text [effect]=\"SkeletonEffect\">Pull Request</div>\n <div skeleton-text [effect]=\"SkeletonEffect\">Open Issue</div>\n <div skeleton-text [effect]=\"SkeletonEffect\">Feature Branch</div>\n <div skeleton-text [effect]=\"SkeletonEffect\">\n <mat-icon>more_horiz</mat-icon>\n </div>\n </div>\n </ng-container>\n</mat-card>\n", styles: [":host ::ng-deep .social-card{margin:20px;padding:15px 5px}:host ::ng-deep mat-card-actions{margin-bottom:-1px!important;margin-left:0!important;margin-right:-.5px!important}:host ::ng-deep .main-slot-container{padding:10px}:host ::ng-deep .slot-header{align-items:center}:host ::ng-deep .slot-content{width:100%}:host ::ng-deep .slot-name{font-size:13px;font-weight:600}:host ::ng-deep .slot-description{font-size:12px;margin-right:10px}:host ::ng-deep .slot-action-anchor{font-size:10px;text-decoration:none;color:#000}:host ::ng-deep .action-icon{height:25px;width:25px;font-size:25px;cursor:pointer}.gh-icon{width:60px;height:60px;font-size:60px;text-align:center}.gh-input{width:90%}.selected{border:1px solid green}.gh-input ::ng-deep .mat-form-field-flex{border:1px solid;border-radius:30px!important}.gh-input ::ng-deep .mat-form-field-wrapper{padding-bottom:0!important}.gh-input ::ng-deep .mat-form-field-underline{display:none}\n"], components: [{ type: i3.MatCard, selector: "mat-card", exportAs: ["matCard"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i5.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i6.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: i7.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i7.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { type: i8.SkeletonAvatarComponent, selector: "skeleton-avatar", inputs: ["size", "color", "showIcon", "iconColor", "borderRadius", "effect"] }, { type: i8.SkeletonBlockComponent, selector: "skeleton-block", inputs: ["width", "height", "effect", "borderRadius"] }], directives: [{ type: i9.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i10.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: i10.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: i10.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"] }, { type: i5.MatLabel, selector: "mat-label" }, { type: i11.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: i12.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: i12.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i12.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i3.MatCardActions, selector: "mat-card-actions", inputs: ["align"], exportAs: ["matCardActions"] }, { type: i7.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { type: i8.SkeletonTextDirective, selector: "[skeleton-text]", inputs: ["effect"] }] });
|
|
103
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: GhControlComponent, decorators: [{
|
|
104
|
+
type: Component,
|
|
105
|
+
args: [{ selector: 'lcu-gh-control', template: "<mat-card class=\"social-card\" *ngIf=\"false\">\n <ng-container *ngIf=\"!State?.Loading\">\n <div class=\"gh-card-container\" fxLayout=\"row\" fxLayoutAlign=\"center center\">\n <mat-icon fxFlex=\"15%\" class=\"gh-icon\">error_outline</mat-icon>\n <div fxFlex=\"70%\" class=\"gh-card-main-content\">\n <mat-form-field appearance=\"fill\" class=\"gh-input\">\n <mat-label>{{ InputLabel }}</mat-label>\n <input matInput type=\"text\" [(ngModel)]=\"value\" />\n <!-- <button *ngIf=\"value\" matSuffix mat-icon-button aria-label=\"Clear\" (click)=\"value=''\">\n <mat-icon>close</mat-icon>\n </button> -->\n </mat-form-field>\n </div>\n\n <button\n fxFlex=\"15%\"\n mat-button\n (click)=\"Submit()\"\n id=\"submit-btn\"\n color=\"primary\"\n >\n Submit\n </button>\n </div>\n\n <mat-card-actions fxLayout=\"row\" fxLayoutAlign=\"space-around center\">\n <button mat-button (click)=\"CreatePullRequest()\" id=\"pr-btn\">\n Pull Request\n </button>\n <button mat-button (click)=\"OpenIssue()\" id=\"oi-btn\">Open Issue</button>\n <button mat-button (click)=\"CreateFeatureBranch()\" id=\"fb-btn\">\n Feature Branch\n </button>\n <button mat-icon-button [matMenuTriggerFor]=\"menu\" aria-label=\"menu\">\n <mat-icon>more_horiz</mat-icon>\n </button>\n <mat-menu #menu=\"matMenu\">\n <button class=\"gh-menu-action\" mat-menu-item (click)=\"CreateNewApp()\">\n Create New App\n </button>\n\n <button\n class=\"gh-menu-action\"\n mat-menu-item\n (click)=\"RouteToPath('/dashboard/create-project')\"\n >\n Create Project\n </button>\n </mat-menu>\n </mat-card-actions>\n </ng-container>\n\n <!-- SKELETON -->\n <ng-container *ngIf=\"State?.Loading\">\n <div id=\"gh-card-skeleton\" fxLayout=\"row\" fxLayoutAlign=\"center center\">\n <skeleton-avatar\n class=\"gh-icon\"\n [showIcon]=\"false\"\n [effect]=\"SkeletonEffect\"\n ></skeleton-avatar>\n\n <div fxFlex=\"70%\" class=\"gh-card-main-content\">\n <skeleton-block\n height=\"60px\"\n [effect]=\"SkeletonEffect\"\n ></skeleton-block>\n </div>\n\n <div\n skeleton-text\n fxFlex=\"15%\"\n [effect]=\"SkeletonEffect\"\n style=\"margin: 0px 10px\"\n >\n Submit\n </div>\n </div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"space-around center\">\n <div skeleton-text [effect]=\"SkeletonEffect\">Pull Request</div>\n <div skeleton-text [effect]=\"SkeletonEffect\">Open Issue</div>\n <div skeleton-text [effect]=\"SkeletonEffect\">Feature Branch</div>\n <div skeleton-text [effect]=\"SkeletonEffect\">\n <mat-icon>more_horiz</mat-icon>\n </div>\n </div>\n </ng-container>\n</mat-card>\n", styles: [":host ::ng-deep .social-card{margin:20px;padding:15px 5px}:host ::ng-deep mat-card-actions{margin-bottom:-1px!important;margin-left:0!important;margin-right:-.5px!important}:host ::ng-deep .main-slot-container{padding:10px}:host ::ng-deep .slot-header{align-items:center}:host ::ng-deep .slot-content{width:100%}:host ::ng-deep .slot-name{font-size:13px;font-weight:600}:host ::ng-deep .slot-description{font-size:12px;margin-right:10px}:host ::ng-deep .slot-action-anchor{font-size:10px;text-decoration:none;color:#000}:host ::ng-deep .action-icon{height:25px;width:25px;font-size:25px;cursor:pointer}.gh-icon{width:60px;height:60px;font-size:60px;text-align:center}.gh-input{width:90%}.selected{border:1px solid green}.gh-input ::ng-deep .mat-form-field-flex{border:1px solid;border-radius:30px!important}.gh-input ::ng-deep .mat-form-field-wrapper{padding-bottom:0!important}.gh-input ::ng-deep .mat-form-field-underline{display:none}\n"] }]
|
|
106
|
+
}], ctorParameters: function () { return [{ type: i1.EaCService }, { type: i2.MatDialog }]; } });
|
|
107
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gh-control.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/elements/gh-control/gh-control.component.ts","../../../../../../projects/common/src/lib/elements/gh-control/gh-control.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport { NewApplicationDialogComponent } from '../../dialogs/new-application-dialog/new-application-dialog.component';\nimport { EaCService } from '../../services/eac.service';\nimport { ApplicationsFlowState } from '../../state/applications-flow.state';\n\n@Component({\n  selector: 'lcu-gh-control',\n  templateUrl: './gh-control.component.html',\n  styleUrls: ['./gh-control.component.scss']\n})\nexport class GhControlComponent implements OnInit {\n\n  public get ActiveEnvironmentLookup(): string {\n    //  TODO:  Eventually support multiple environments\n    const envLookups = Object.keys(this.State?.EaC?.Environments || {});\n\n    return envLookups[0];\n  }\n\n  public get State(): ApplicationsFlowState{\n    return this.eacSvc.State;\n  }\n\n  public InputLabel: string;\n\n  public SkeletonEffect: string;\n\n  protected selectedBtn: string;\n\n  public value: string;\n\n  constructor( \n      protected eacSvc: EaCService,\n      protected dialog: MatDialog) { \n\n    this.InputLabel = \"Create Pull Request\";\n    this.SkeletonEffect = \"wave\";\n    this.selectedBtn = \"pr-btn\";\n\n  }\n\n  public ngOnInit(): void {\n    \n  }\n\n  public ngAfterViewInit(){\n    this.addSelectBtn();\n  }\n\n  public CreateFeatureBranch(){\n    this.removeSelectedBtn();\n    this.InputLabel = \"Create Feature Branch\";\n    this.selectedBtn = \"fb-btn\";\n    this.addSelectBtn();\n    console.log(\"create feature branch selected\");\n\n  }\n\n  public OpenIssue(){\n    this.removeSelectedBtn();\n    this.InputLabel = \"Open Issue\";\n    this.selectedBtn = \"oi-btn\";\n    this.addSelectBtn();\n    console.log(\"open issue selected\");\n\n  }\n\n  public CreatePullRequest(){\n    this.removeSelectedBtn();\n    this.InputLabel = \"Create Pull Request\";\n    this.selectedBtn = \"pr-btn\";\n    this.addSelectBtn();\n    console.log(\"create pull request selected\");\n\n  }\n\n  public CreateNewApp(){\n    const dialogRef = this.dialog.open(NewApplicationDialogComponent, {\n      width: '600px',\n      data: {\n        environmentLookup: this.ActiveEnvironmentLookup,\n      },\n    });\n\n    dialogRef.afterClosed().subscribe((result) => {\n      // console.log('The dialog was closed');\n      // console.log(\"result:\", result)\n    });\n  }\n\n  public RouteToPath(path: string): void {\n    window.location.href = path;\n  }\n\n\n  public Submit(){\n    console.log(\"submitting: \", this.value);\n    switch (this.selectedBtn){\n      case \"pr-btn\":\n        //Pull request\n        console.log(\"creating pull request: \", this.value);\n        break;\n      case \"oi-btn\":\n        //Open Issue\n        console.log(\"Open issue: \", this.value);\n        break;\n      case \"fb-btn\":\n        //Feature Branch\n        console.log(\"creating feature branch: \", this.value);\n        break;\n      default:\n        console.log(\"hmm\")\n\n        break;\n    }\n  }\n\n  //HELPERS\n\n  protected addSelectBtn(){    \n    // (<HTMLElement>document.getElementById(this.selectedBtn)).classList.add('selected');\n  }\n\n  protected removeSelectedBtn(){\n    // (<HTMLElement>document.getElementById(this.selectedBtn)).classList.remove('selected');\n  }\n\n}\n","<mat-card class=\"social-card\" *ngIf=\"false\">\n  <ng-container *ngIf=\"!State?.Loading\">\n    <div class=\"gh-card-container\" fxLayout=\"row\" fxLayoutAlign=\"center center\">\n      <mat-icon fxFlex=\"15%\" class=\"gh-icon\">error_outline</mat-icon>\n      <div fxFlex=\"70%\" class=\"gh-card-main-content\">\n        <mat-form-field appearance=\"fill\" class=\"gh-input\">\n          <mat-label>{{ InputLabel }}</mat-label>\n          <input matInput type=\"text\" [(ngModel)]=\"value\" />\n          <!-- <button *ngIf=\"value\" matSuffix mat-icon-button aria-label=\"Clear\" (click)=\"value=''\">\n                    <mat-icon>close</mat-icon>\n                    </button> -->\n        </mat-form-field>\n      </div>\n\n      <button\n        fxFlex=\"15%\"\n        mat-button\n        (click)=\"Submit()\"\n        id=\"submit-btn\"\n        color=\"primary\"\n      >\n        Submit\n      </button>\n    </div>\n\n    <mat-card-actions fxLayout=\"row\" fxLayoutAlign=\"space-around center\">\n      <button mat-button (click)=\"CreatePullRequest()\" id=\"pr-btn\">\n        Pull Request\n      </button>\n      <button mat-button (click)=\"OpenIssue()\" id=\"oi-btn\">Open Issue</button>\n      <button mat-button (click)=\"CreateFeatureBranch()\" id=\"fb-btn\">\n        Feature Branch\n      </button>\n      <button mat-icon-button [matMenuTriggerFor]=\"menu\" aria-label=\"menu\">\n        <mat-icon>more_horiz</mat-icon>\n      </button>\n      <mat-menu #menu=\"matMenu\">\n        <button class=\"gh-menu-action\" mat-menu-item (click)=\"CreateNewApp()\">\n          Create New App\n        </button>\n\n        <button\n          class=\"gh-menu-action\"\n          mat-menu-item\n          (click)=\"RouteToPath('/dashboard/create-project')\"\n        >\n          Create Project\n        </button>\n      </mat-menu>\n    </mat-card-actions>\n  </ng-container>\n\n  <!-- SKELETON -->\n  <ng-container *ngIf=\"State?.Loading\">\n    <div id=\"gh-card-skeleton\" fxLayout=\"row\" fxLayoutAlign=\"center center\">\n      <skeleton-avatar\n        class=\"gh-icon\"\n        [showIcon]=\"false\"\n        [effect]=\"SkeletonEffect\"\n      ></skeleton-avatar>\n\n      <div fxFlex=\"70%\" class=\"gh-card-main-content\">\n        <skeleton-block\n          height=\"60px\"\n          [effect]=\"SkeletonEffect\"\n        ></skeleton-block>\n      </div>\n\n      <div\n        skeleton-text\n        fxFlex=\"15%\"\n        [effect]=\"SkeletonEffect\"\n        style=\"margin: 0px 10px\"\n      >\n        Submit\n      </div>\n    </div>\n\n    <div fxLayout=\"row\" fxLayoutAlign=\"space-around center\">\n      <div skeleton-text [effect]=\"SkeletonEffect\">Pull Request</div>\n      <div skeleton-text [effect]=\"SkeletonEffect\">Open Issue</div>\n      <div skeleton-text [effect]=\"SkeletonEffect\">Feature Branch</div>\n      <div skeleton-text [effect]=\"SkeletonEffect\">\n        <mat-icon>more_horiz</mat-icon>\n      </div>\n    </div>\n  </ng-container>\n</mat-card>\n"]}
|