@lowcodeunit/applications-flow-common 1.33.233-lets-get-social-ish → 1.33.236-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/lib/controls/build-pipeline-form/build-pipeline-form.component.mjs +2 -2
- package/esm2020/lib/dialogs/upgrade-dialog/upgrade-dialog.component.mjs +3 -3
- package/esm2020/lib/elements/project-info-card/project-info-card.component.mjs +3 -3
- package/fesm2015/lowcodeunit-applications-flow-common.mjs +5 -5
- package/fesm2015/lowcodeunit-applications-flow-common.mjs.map +1 -1
- package/fesm2020/lowcodeunit-applications-flow-common.mjs +5 -5
- package/fesm2020/lowcodeunit-applications-flow-common.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -214,7 +214,7 @@ export class BuildPipelineFormComponent {
|
|
|
214
214
|
// console.log("response: ", response);
|
|
215
215
|
this.HostingDetails.Loading = false;
|
|
216
216
|
const hostOption = this.HostingDetails?.HostingOptions?.find((ho) => ho.Path === this.DevOpsAction.Path);
|
|
217
|
-
this.BuildPipeline = hostOption
|
|
217
|
+
this.BuildPipeline = hostOption?.Lookup;
|
|
218
218
|
// console.log("Build Pipeline HERE= ", this.BuildPipeline);
|
|
219
219
|
this.setupControlsForForm();
|
|
220
220
|
}, (err) => {
|
|
@@ -248,4 +248,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
|
|
|
248
248
|
type: Output,
|
|
249
249
|
args: ['response-event']
|
|
250
250
|
}] } });
|
|
251
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"build-pipeline-form.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/controls/build-pipeline-form/build-pipeline-form.component.ts","../../../../../../projects/common/src/lib/controls/build-pipeline-form/build-pipeline-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport {\n  AbstractControl,\n  FormBuilder,\n  FormGroup,\n  Validators,\n} from '@angular/forms';\nimport { BaseModeledResponse, Guid } from '@lcu/common';\nimport {\n  EaCArtifact,\n  EaCDevOpsAction,\n  EaCEnvironmentAsCode,\n  EaCSourceControl,\n} from '@semanticjs/common';\nimport { ApplicationsFlowService } from '../../services/applications-flow.service';\nimport {\n  EaCService,\n  SaveEnvironmentAsCodeEventRequest,\n} from '../../services/eac.service';\nimport {\n  ApplicationsFlowState,\n  ProjectHostingDetails,\n  ProjectHostingOption,\n} from '../../state/applications-flow.state';\n\n@Component({\n  selector: 'lcu-build-pipeline-form',\n  templateUrl: './build-pipeline-form.component.html',\n  styleUrls: ['./build-pipeline-form.component.scss'],\n})\nexport class BuildPipelineFormComponent implements OnInit {\n  //PROPERTIES\n\n  // @Input('build-pipeline')\n  public BuildPipeline: string;\n\n  @Input('devops-action-lookup')\n  public DevOpsActionLookup: string;\n\n  @Input('disabled')\n  public Disabled: boolean;\n\n  @Input('environment')\n  public Environment: EaCEnvironmentAsCode;\n\n  @Input('environment-lookup')\n  public EnvironmentLookup: string;\n\n  @Input('hosting-details')\n  public HostingDetails: ProjectHostingDetails;\n\n  @Output('response-event')\n  public ResponseEvent: EventEmitter<any>;\n\n  public get Artifact(): EaCArtifact {\n    // console.log(\"ARTIFACT: \", this.Environment?.Artifacts[this.ArtifactLookup]);\n    return this.Environment?.Artifacts && this.ArtifactLookup\n      ? this.Environment?.Artifacts[this.ArtifactLookup] || {}\n      : {};\n  }\n\n  public get ArtifactLookup(): string {\n    const artLookup = this.DevOpsAction?.ArtifactLookups\n      ? this.DevOpsAction?.ArtifactLookups[0]\n      : null;\n\n    return artLookup;\n  }\n\n  public get BuildPipelineFormControl(): AbstractControl {\n    return this.BuildPipelineFormGroup?.get('buildPipeline');\n  }\n\n  public get DevOpsAction(): EaCDevOpsAction {\n    return this.Environment.DevOpsActions && this.DevOpsActionLookup\n      ? this.Environment.DevOpsActions[this.DevOpsActionLookup] || {}\n      : {};\n  }\n\n  public get DevOpsActions(): { [lookup: string]: EaCDevOpsAction } {\n    return this.Environment.DevOpsActions || {};\n  }\n\n  public get DevOpsActionNameFormControl(): AbstractControl {\n    return this.BuildPipelineFormGroup.get('devOpsActionName');\n  }\n\n  public get NPMTokenFormControl(): AbstractControl {\n    return this.BuildPipelineFormGroup.get('npmToken');\n  }\n\n  // (ho) => ho.Lookup === this.BuildPipeline\n  public get SelectedHostingOption(): ProjectHostingOption {\n    return this.HostingDetails?.HostingOptions?.find(\n      (ho) => ho.Lookup === this.BuildPipeline\n    );\n  }\n\n  public get SelectedHostingOptionInputControlValues(): {\n    [lookup: string]: any;\n  } {\n    return this.SelectedHostingOption?.Inputs?.reduce((prev, cur) => {\n      const res = {\n        ...prev,\n      };\n\n      res[cur.Lookup] = this.BuildPipelineFormGroup.controls[cur.Lookup].value;\n\n      return res;\n    }, {});\n  }\n\n  public get SourceControlLookups(): Array<string> {\n    return Object.keys(this.SourceControls || {});\n  }\n\n  public get SourceControls(): { [lookup: string]: EaCSourceControl } {\n    return this.Environment.Sources || {};\n  }\n\n  public get State(): ApplicationsFlowState{\n    return this.eacSvc.State;\n  }\n\n  public BuildPipelineFormGroup: FormGroup;\n\n  constructor(\n    protected eacSvc: EaCService,\n    protected formBuilder: FormBuilder,\n    protected appsFlowSvc: ApplicationsFlowService\n  ) {\n    this.HostingDetails = new ProjectHostingDetails();\n    this.ResponseEvent = new EventEmitter;\n  }\n\n  public ngOnInit(): void {\n    // console.log('BuildPipeline = ', this.BuildPipeline)\n\n    // this.BuildPipelineFormGroup = this.formBuilder.group({});\n\n    // if (this.BuildPipelineFormGroup != null) {\n    //   this.BuildPipelineFormGroup.removeControl('hostingDetails');\n    // }\n\n    // this.BuildPipelineFormGroup.addControl(\n    //   'hostingDetails',\n    this.BuildPipelineFormGroup = this.formBuilder.group({\n      buildPipeline: [this.BuildPipeline, [Validators.required]],\n    });\n    // );\n\n    this.loadProjectHostingDetails();\n    // this.setupControlsForForm();\n  }\n\n  //API METHODS\n\n  public BuildPipelineChanged(): void {\n    //for some reason this value is coming back undefined\n    // console.log(\"build pipeline value: \", this.BuildPipelineFormControl?.value)\n    this.BuildPipeline = this.BuildPipelineFormControl?.value;\n\n    this.setupControlsForForm();\n  }\n\n  public SubmitBuildPipeline() {\n    // console.log(\"submitting build pipeline: \", this.BuildPipelineFormGroup.value);\n    this.SaveEnvironment();\n  }\n\n  public SaveEnvironment(): void {\n    const saveEnvReq: SaveEnvironmentAsCodeEventRequest = {\n      Environment: {\n        ...this.Environment,\n        Artifacts: this.Environment.Artifacts || {},\n        DevOpsActions: this.Environment.DevOpsActions || {},\n        Secrets: this.Environment.Secrets || {},\n        Sources: this.Environment.Sources || {},\n      },\n      EnvironmentLookup: this.EnvironmentLookup,\n      EnterpriseDataTokens: {},\n    };\n\n    let artifactLookup: string;\n\n    let artifact: EaCArtifact = {\n      ...this.Artifact,\n      ...this.SelectedHostingOptionInputControlValues,\n    };\n\n    if (!this.ArtifactLookup) {\n      artifactLookup = Guid.CreateRaw();\n\n      artifact = {\n        ...artifact,\n        Type: this.SelectedHostingOption.ArtifactType,\n        Name: this.SelectedHostingOption.Name,\n        NPMRegistry: 'https://registry.npmjs.org/',\n      };\n    } else {\n      artifactLookup = this.ArtifactLookup;\n    }\n\n    saveEnvReq.Environment.Artifacts[artifactLookup] = artifact;\n\n    let devOpsActionLookup: string;\n\n    if (!this.DevOpsActionLookup) {\n      devOpsActionLookup = Guid.CreateRaw();\n\n      const doa: EaCDevOpsAction = {\n        ...this.DevOpsAction,\n        ArtifactLookups: [artifactLookup],\n        Name: this.DevOpsActionNameFormControl.value,\n        Path: this.SelectedHostingOption.Path,\n        Templates: this.SelectedHostingOption.Templates,\n      };\n\n      if (this.NPMTokenFormControl?.value) {\n        const secretLookup = 'npm-access-token';\n\n        doa.SecretLookups = [secretLookup];\n\n        saveEnvReq.Environment.Secrets[secretLookup] = {\n          Name: 'NPM Access Token',\n          DataTokenLookup: secretLookup,\n          KnownAs: 'NPM_TOKEN',\n        };\n\n        saveEnvReq.EnterpriseDataTokens[secretLookup] = {\n          Name: saveEnvReq.Environment.Secrets[secretLookup].Name,\n          Description: saveEnvReq.Environment.Secrets[secretLookup].Name,\n          Value: this.NPMTokenFormControl.value,\n        };\n      }\n\n      saveEnvReq.Environment.DevOpsActions[devOpsActionLookup] = doa;\n    } else {\n      devOpsActionLookup = this.DevOpsActionLookup;\n\n      const doa: EaCDevOpsAction = {\n        ...this.DevOpsAction,\n        Name: this.DevOpsActionNameFormControl.value,\n      };\n\n      saveEnvReq.Environment.DevOpsActions[devOpsActionLookup] = doa;\n    }\n\n    \n    this.eacSvc.SaveEnvironmentAsCode(saveEnvReq).then(res =>{\n      this.ResponseEvent.emit(res);\n    });\n    \n  }\n\n  //  Helpers\n  protected setupControlsForForm(): void {\n    // this.BuildPipeline =\n    //         this.BuildPipeline || this.HostingDetails?.HostingOptions\n    //           ? this.HostingDetails?.HostingOptions[0]?.Lookup\n    //           : '';\n\n    // console.log(\"hosting details: \", this.HostingDetails)\n\n    for (const ctrlName in this.BuildPipelineFormGroup.controls) {\n      //devOpsAction doesn't exist\n      //removes hosting details\n      if (ctrlName !== 'buildPipeline' && ctrlName !== 'devOpsAction') {\n        // console.log(\"removing control: \", ctrlName)\n        this.BuildPipelineFormGroup.removeControl(ctrlName);\n      }\n    }\n\n    this.BuildPipelineFormGroup.addControl(\n      'devOpsActionName',\n      this.formBuilder.control(\n        this.DevOpsAction?.Name || this.SelectedHostingOption?.Name || '',\n        [Validators.required]\n      )\n    );\n\n    // console.log(\"selected hosting options: \", this.SelectedHostingOption.Inputs);\n\n    this.SelectedHostingOption?.Inputs?.forEach((input) => {\n      const validators = input.Required ? [Validators.required] : [];\n\n      this.BuildPipelineFormGroup.addControl(\n        input.Lookup,\n        this.formBuilder.control(\n          this.Artifact[input.Lookup] || input.DefaultValue || '',\n          validators\n        )\n      );\n\n      // if (this.Disabled) {\n      //   this.FormGroup.controls[input.Lookup].disable();\n      // }\n    });\n\n    if (this.BuildPipelineFormControl?.value === 'npm-release') {\n      if (!this.BuildPipelineFormGroup.controls.npmToken) {\n        this.BuildPipelineFormGroup.addControl(\n          'npmToken',\n          this.formBuilder.control(\n            '',\n            this.Disabled ? [] : [Validators.required]\n          )\n        );\n\n        if (this.Disabled) {\n          this.BuildPipelineFormGroup.controls.npmToken.disable();\n        }\n      }\n    } else if (\n      this.BuildPipelineFormControl?.value === 'github-artifacts-release'\n    ) {\n      if (this.BuildPipelineFormGroup.controls.npmToken) {\n        this.BuildPipelineFormGroup.removeControl('npmToken');\n      }\n    }\n  }\n\n  protected loadProjectHostingDetails(): void {\n    this.HostingDetails.Loading = true;\n    this.appsFlowSvc.NewLoadProjectHostingDetails().subscribe(\n      (response: BaseModeledResponse<ProjectHostingDetails>) => {\n        this.HostingDetails = response.Model;\n        // console.log(\"response: \", response);\n        this.HostingDetails.Loading = false;\n\n        const hostOption = this.HostingDetails?.HostingOptions?.find(\n          (ho) => ho.Path === this.DevOpsAction.Path\n        );\n        this.BuildPipeline = hostOption.Lookup;\n\n        // console.log(\"Build Pipeline HERE= \", this.BuildPipeline);\n\n        this.setupControlsForForm();\n      },\n      (err) => {\n        console.log('ERR: ', err);\n        this.HostingDetails.Loading = false;\n      }\n    );\n    console.log('HOSTING DETAILS: ', this.HostingDetails);\n  }\n}\n","<form class=\"form-card\" [formGroup]=\"BuildPipelineFormGroup\" (ngSubmit)=\"SubmitBuildPipeline()\">\n    <mat-card\n      class=\"spread\"  \n    >\n      <mat-card-header>\n        <mat-card-title> Build Pipeline </mat-card-title>\n\n        <mat-hint>\n          Changes made here are reflected for all sources using this\n          DevOpsAction\n        </mat-hint>\n      </mat-card-header>\n\n      <mat-card-content>\n\n\n        <div  *ngIf=\"!HostingDetails?.Loading\">\n          <mat-form-field class=\"mat-full-width\">\n            <mat-select\n              formControlName=\"buildPipeline\"\n              placeholder=\"Build Pipeline\"\n              [disabled]=\"Disabled\"\n              (selectionChange)=\"BuildPipelineChanged()\"\n              required\n            >\n              <ng-container\n                *ngFor=\"let hostOption of HostingDetails?.HostingOptions; let i = index\"\n              >\n                <mat-option [value]=\"hostOption.Lookup\">\n                  {{ hostOption.Name }}\n                </mat-option>\n              </ng-container>\n            </mat-select>\n        \n            <mat-hint>\n              <ng-container *ngFor=\"let hostOption of HostingDetails?.HostingOptions\">\n                <span *ngIf=\"BuildPipeline == hostOption?.Lookup\">\n                  {{ hostOption.Description }}\n                </span>\n              </ng-container>\n            </mat-hint>\n          </mat-form-field>\n        \n          <mat-form-field class=\"mat-full-width\">\n            <input\n              matInput\n              formControlName=\"devOpsActionName\"\n              placeholder=\"Name of DevOps Action\"\n              required=\"true\"\n            />\n          </mat-form-field>\n        \n          <ng-container *ngFor=\"let input of SelectedHostingOption?.Inputs\">\n            <mat-form-field class=\"mat-full-width\">\n              <input\n                matInput\n                [formControlName]=\"input.Lookup\"\n                [placeholder]=\"input.Placeholder\"\n                [required]=\"input.Required\"\n              />\n        \n              <mat-hint>{{ input.Hint }}</mat-hint>\n            </mat-form-field>\n          </ng-container>\n        \n          <div *ngIf=\"BuildPipeline == 'npm-release'\">\n            <mat-form-field class=\"mat-full-width with-hint padding-bottom-4\">\n              <mat-icon matPrefix>security</mat-icon>\n        \n              <input\n                id=\"npm-token\"\n                matInput\n                type=\"text\"\n                formControlName=\"npmToken\"\n                placeholder=\"NPM token\"\n                [required]=\"!Disabled\"\n                style=\"-webkit-text-security: disc;\"\n              />\n              <mat-hint>\n                Securely publish to NPM, provide an NPM Personal Access Token (PAT) with publish access to the organization used for your NPM packages.              \n                Learn how to create and view access tokens \n                <a\n                  href=\"https://docs.npmjs.com/creating-and-viewing-access-tokens\"\n                  target=\"_blank\"\n                >\n                  here.\n                </a>\n              </mat-hint>\n            </mat-form-field>\n          </div>\n        </div>\n        \n        <div *ngIf=\"HostingDetails?.Loading\">\n          <div class=\"spread\">\n            <lcu-loader style=\"margin: auto\" [loading]=\"true\"></lcu-loader>\n        \n            <div class=\"margin-3\">\n              <h4 class=\"mat-title\">Loading hosting details</h4>\n            </div>\n          </div>\n        </div>\n      </mat-card-content>\n      <mat-card-actions fxLayoutAlign=\"center center\">\n\n        <button \n          *ngIf=\"!State?.Loading\"\n          mat-raised-button \n          type=\"submit\" \n          fxFlex=\"100%\" \n          color=\"primary\" \n          [disabled]=\"!BuildPipelineFormGroup.valid || !BuildPipelineFormGroup.dirty\">\n          <mat-icon>save</mat-icon>\n          Save Build Pipeline\n        </button>\n        <lcu-loader [loading]=\"State?.Loading\"></lcu-loader>  \n        \n    </mat-card-actions>\n    </mat-card>\n</form>\n"]}
|
|
251
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"build-pipeline-form.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/controls/build-pipeline-form/build-pipeline-form.component.ts","../../../../../../projects/common/src/lib/controls/build-pipeline-form/build-pipeline-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport {\n  AbstractControl,\n  FormBuilder,\n  FormGroup,\n  Validators,\n} from '@angular/forms';\nimport { BaseModeledResponse, Guid } from '@lcu/common';\nimport {\n  EaCArtifact,\n  EaCDevOpsAction,\n  EaCEnvironmentAsCode,\n  EaCSourceControl,\n} from '@semanticjs/common';\nimport { ApplicationsFlowService } from '../../services/applications-flow.service';\nimport {\n  EaCService,\n  SaveEnvironmentAsCodeEventRequest,\n} from '../../services/eac.service';\nimport {\n  ApplicationsFlowState,\n  ProjectHostingDetails,\n  ProjectHostingOption,\n} from '../../state/applications-flow.state';\n\n@Component({\n  selector: 'lcu-build-pipeline-form',\n  templateUrl: './build-pipeline-form.component.html',\n  styleUrls: ['./build-pipeline-form.component.scss'],\n})\nexport class BuildPipelineFormComponent implements OnInit {\n  //PROPERTIES\n\n  // @Input('build-pipeline')\n  public BuildPipeline: string;\n\n  @Input('devops-action-lookup')\n  public DevOpsActionLookup: string;\n\n  @Input('disabled')\n  public Disabled: boolean;\n\n  @Input('environment')\n  public Environment: EaCEnvironmentAsCode;\n\n  @Input('environment-lookup')\n  public EnvironmentLookup: string;\n\n  @Input('hosting-details')\n  public HostingDetails: ProjectHostingDetails;\n\n  @Output('response-event')\n  public ResponseEvent: EventEmitter<any>;\n\n  public get Artifact(): EaCArtifact {\n    // console.log(\"ARTIFACT: \", this.Environment?.Artifacts[this.ArtifactLookup]);\n    return this.Environment?.Artifacts && this.ArtifactLookup\n      ? this.Environment?.Artifacts[this.ArtifactLookup] || {}\n      : {};\n  }\n\n  public get ArtifactLookup(): string {\n    const artLookup = this.DevOpsAction?.ArtifactLookups\n      ? this.DevOpsAction?.ArtifactLookups[0]\n      : null;\n\n    return artLookup;\n  }\n\n  public get BuildPipelineFormControl(): AbstractControl {\n    return this.BuildPipelineFormGroup?.get('buildPipeline');\n  }\n\n  public get DevOpsAction(): EaCDevOpsAction {\n    return this.Environment.DevOpsActions && this.DevOpsActionLookup\n      ? this.Environment.DevOpsActions[this.DevOpsActionLookup] || {}\n      : {};\n  }\n\n  public get DevOpsActions(): { [lookup: string]: EaCDevOpsAction } {\n    return this.Environment.DevOpsActions || {};\n  }\n\n  public get DevOpsActionNameFormControl(): AbstractControl {\n    return this.BuildPipelineFormGroup.get('devOpsActionName');\n  }\n\n  public get NPMTokenFormControl(): AbstractControl {\n    return this.BuildPipelineFormGroup.get('npmToken');\n  }\n\n  // (ho) => ho.Lookup === this.BuildPipeline\n  public get SelectedHostingOption(): ProjectHostingOption {\n    return this.HostingDetails?.HostingOptions?.find(\n      (ho) => ho.Lookup === this.BuildPipeline\n    );\n  }\n\n  public get SelectedHostingOptionInputControlValues(): {\n    [lookup: string]: any;\n  } {\n    return this.SelectedHostingOption?.Inputs?.reduce((prev, cur) => {\n      const res = {\n        ...prev,\n      };\n\n      res[cur.Lookup] = this.BuildPipelineFormGroup.controls[cur.Lookup].value;\n\n      return res;\n    }, {});\n  }\n\n  public get SourceControlLookups(): Array<string> {\n    return Object.keys(this.SourceControls || {});\n  }\n\n  public get SourceControls(): { [lookup: string]: EaCSourceControl } {\n    return this.Environment.Sources || {};\n  }\n\n  public get State(): ApplicationsFlowState{\n    return this.eacSvc.State;\n  }\n\n  public BuildPipelineFormGroup: FormGroup;\n\n  constructor(\n    protected eacSvc: EaCService,\n    protected formBuilder: FormBuilder,\n    protected appsFlowSvc: ApplicationsFlowService\n  ) {\n    this.HostingDetails = new ProjectHostingDetails();\n    this.ResponseEvent = new EventEmitter;\n  }\n\n  public ngOnInit(): void {\n    // console.log('BuildPipeline = ', this.BuildPipeline)\n\n    // this.BuildPipelineFormGroup = this.formBuilder.group({});\n\n    // if (this.BuildPipelineFormGroup != null) {\n    //   this.BuildPipelineFormGroup.removeControl('hostingDetails');\n    // }\n\n    // this.BuildPipelineFormGroup.addControl(\n    //   'hostingDetails',\n    this.BuildPipelineFormGroup = this.formBuilder.group({\n      buildPipeline: [this.BuildPipeline, [Validators.required]],\n    });\n    // );\n\n    this.loadProjectHostingDetails();\n    // this.setupControlsForForm();\n  }\n\n  //API METHODS\n\n  public BuildPipelineChanged(): void {\n    //for some reason this value is coming back undefined\n    // console.log(\"build pipeline value: \", this.BuildPipelineFormControl?.value)\n    this.BuildPipeline = this.BuildPipelineFormControl?.value;\n\n    this.setupControlsForForm();\n  }\n\n  public SubmitBuildPipeline() {\n    // console.log(\"submitting build pipeline: \", this.BuildPipelineFormGroup.value);\n    this.SaveEnvironment();\n  }\n\n  public SaveEnvironment(): void {\n    const saveEnvReq: SaveEnvironmentAsCodeEventRequest = {\n      Environment: {\n        ...this.Environment,\n        Artifacts: this.Environment.Artifacts || {},\n        DevOpsActions: this.Environment.DevOpsActions || {},\n        Secrets: this.Environment.Secrets || {},\n        Sources: this.Environment.Sources || {},\n      },\n      EnvironmentLookup: this.EnvironmentLookup,\n      EnterpriseDataTokens: {},\n    };\n\n    let artifactLookup: string;\n\n    let artifact: EaCArtifact = {\n      ...this.Artifact,\n      ...this.SelectedHostingOptionInputControlValues,\n    };\n\n    if (!this.ArtifactLookup) {\n      artifactLookup = Guid.CreateRaw();\n\n      artifact = {\n        ...artifact,\n        Type: this.SelectedHostingOption.ArtifactType,\n        Name: this.SelectedHostingOption.Name,\n        NPMRegistry: 'https://registry.npmjs.org/',\n      };\n    } else {\n      artifactLookup = this.ArtifactLookup;\n    }\n\n    saveEnvReq.Environment.Artifacts[artifactLookup] = artifact;\n\n    let devOpsActionLookup: string;\n\n    if (!this.DevOpsActionLookup) {\n      devOpsActionLookup = Guid.CreateRaw();\n\n      const doa: EaCDevOpsAction = {\n        ...this.DevOpsAction,\n        ArtifactLookups: [artifactLookup],\n        Name: this.DevOpsActionNameFormControl.value,\n        Path: this.SelectedHostingOption.Path,\n        Templates: this.SelectedHostingOption.Templates,\n      };\n\n      if (this.NPMTokenFormControl?.value) {\n        const secretLookup = 'npm-access-token';\n\n        doa.SecretLookups = [secretLookup];\n\n        saveEnvReq.Environment.Secrets[secretLookup] = {\n          Name: 'NPM Access Token',\n          DataTokenLookup: secretLookup,\n          KnownAs: 'NPM_TOKEN',\n        };\n\n        saveEnvReq.EnterpriseDataTokens[secretLookup] = {\n          Name: saveEnvReq.Environment.Secrets[secretLookup].Name,\n          Description: saveEnvReq.Environment.Secrets[secretLookup].Name,\n          Value: this.NPMTokenFormControl.value,\n        };\n      }\n\n      saveEnvReq.Environment.DevOpsActions[devOpsActionLookup] = doa;\n    } else {\n      devOpsActionLookup = this.DevOpsActionLookup;\n\n      const doa: EaCDevOpsAction = {\n        ...this.DevOpsAction,\n        Name: this.DevOpsActionNameFormControl.value,\n      };\n\n      saveEnvReq.Environment.DevOpsActions[devOpsActionLookup] = doa;\n    }\n\n    \n    this.eacSvc.SaveEnvironmentAsCode(saveEnvReq).then(res =>{\n      this.ResponseEvent.emit(res);\n    });\n    \n  }\n\n  //  Helpers\n  protected setupControlsForForm(): void {\n    // this.BuildPipeline =\n    //         this.BuildPipeline || this.HostingDetails?.HostingOptions\n    //           ? this.HostingDetails?.HostingOptions[0]?.Lookup\n    //           : '';\n\n    // console.log(\"hosting details: \", this.HostingDetails)\n\n    for (const ctrlName in this.BuildPipelineFormGroup.controls) {\n      //devOpsAction doesn't exist\n      //removes hosting details\n      if (ctrlName !== 'buildPipeline' && ctrlName !== 'devOpsAction') {\n        // console.log(\"removing control: \", ctrlName)\n        this.BuildPipelineFormGroup.removeControl(ctrlName);\n      }\n    }\n\n    this.BuildPipelineFormGroup.addControl(\n      'devOpsActionName',\n      this.formBuilder.control(\n        this.DevOpsAction?.Name || this.SelectedHostingOption?.Name || '',\n        [Validators.required]\n      )\n    );\n\n    // console.log(\"selected hosting options: \", this.SelectedHostingOption.Inputs);\n\n    this.SelectedHostingOption?.Inputs?.forEach((input) => {\n      const validators = input.Required ? [Validators.required] : [];\n\n      this.BuildPipelineFormGroup.addControl(\n        input.Lookup,\n        this.formBuilder.control(\n          this.Artifact[input.Lookup] || input.DefaultValue || '',\n          validators\n        )\n      );\n\n      // if (this.Disabled) {\n      //   this.FormGroup.controls[input.Lookup].disable();\n      // }\n    });\n\n    if (this.BuildPipelineFormControl?.value === 'npm-release') {\n      if (!this.BuildPipelineFormGroup.controls.npmToken) {\n        this.BuildPipelineFormGroup.addControl(\n          'npmToken',\n          this.formBuilder.control(\n            '',\n            this.Disabled ? [] : [Validators.required]\n          )\n        );\n\n        if (this.Disabled) {\n          this.BuildPipelineFormGroup.controls.npmToken.disable();\n        }\n      }\n    } else if (\n      this.BuildPipelineFormControl?.value === 'github-artifacts-release'\n    ) {\n      if (this.BuildPipelineFormGroup.controls.npmToken) {\n        this.BuildPipelineFormGroup.removeControl('npmToken');\n      }\n    }\n  }\n\n  protected loadProjectHostingDetails(): void {\n    this.HostingDetails.Loading = true;\n    this.appsFlowSvc.NewLoadProjectHostingDetails().subscribe(\n      (response: BaseModeledResponse<ProjectHostingDetails>) => {\n        this.HostingDetails = response.Model;\n        // console.log(\"response: \", response);\n        this.HostingDetails.Loading = false;\n\n        const hostOption = this.HostingDetails?.HostingOptions?.find(\n          (ho) => ho.Path === this.DevOpsAction.Path\n        );\n        this.BuildPipeline = hostOption?.Lookup;\n\n        // console.log(\"Build Pipeline HERE= \", this.BuildPipeline);\n\n        this.setupControlsForForm();\n      },\n      (err) => {\n        console.log('ERR: ', err);\n        this.HostingDetails.Loading = false;\n      }\n    );\n    console.log('HOSTING DETAILS: ', this.HostingDetails);\n  }\n}\n","<form class=\"form-card\" [formGroup]=\"BuildPipelineFormGroup\" (ngSubmit)=\"SubmitBuildPipeline()\">\n    <mat-card\n      class=\"spread\"  \n    >\n      <mat-card-header>\n        <mat-card-title> Build Pipeline </mat-card-title>\n\n        <mat-hint>\n          Changes made here are reflected for all sources using this\n          DevOpsAction\n        </mat-hint>\n      </mat-card-header>\n\n      <mat-card-content>\n\n\n        <div  *ngIf=\"!HostingDetails?.Loading\">\n          <mat-form-field class=\"mat-full-width\">\n            <mat-select\n              formControlName=\"buildPipeline\"\n              placeholder=\"Build Pipeline\"\n              [disabled]=\"Disabled\"\n              (selectionChange)=\"BuildPipelineChanged()\"\n              required\n            >\n              <ng-container\n                *ngFor=\"let hostOption of HostingDetails?.HostingOptions; let i = index\"\n              >\n                <mat-option [value]=\"hostOption.Lookup\">\n                  {{ hostOption.Name }}\n                </mat-option>\n              </ng-container>\n            </mat-select>\n        \n            <mat-hint>\n              <ng-container *ngFor=\"let hostOption of HostingDetails?.HostingOptions\">\n                <span *ngIf=\"BuildPipeline == hostOption?.Lookup\">\n                  {{ hostOption.Description }}\n                </span>\n              </ng-container>\n            </mat-hint>\n          </mat-form-field>\n        \n          <mat-form-field class=\"mat-full-width\">\n            <input\n              matInput\n              formControlName=\"devOpsActionName\"\n              placeholder=\"Name of DevOps Action\"\n              required=\"true\"\n            />\n          </mat-form-field>\n        \n          <ng-container *ngFor=\"let input of SelectedHostingOption?.Inputs\">\n            <mat-form-field class=\"mat-full-width\">\n              <input\n                matInput\n                [formControlName]=\"input.Lookup\"\n                [placeholder]=\"input.Placeholder\"\n                [required]=\"input.Required\"\n              />\n        \n              <mat-hint>{{ input.Hint }}</mat-hint>\n            </mat-form-field>\n          </ng-container>\n        \n          <div *ngIf=\"BuildPipeline == 'npm-release'\">\n            <mat-form-field class=\"mat-full-width with-hint padding-bottom-4\">\n              <mat-icon matPrefix>security</mat-icon>\n        \n              <input\n                id=\"npm-token\"\n                matInput\n                type=\"text\"\n                formControlName=\"npmToken\"\n                placeholder=\"NPM token\"\n                [required]=\"!Disabled\"\n                style=\"-webkit-text-security: disc;\"\n              />\n              <mat-hint>\n                Securely publish to NPM, provide an NPM Personal Access Token (PAT) with publish access to the organization used for your NPM packages.              \n                Learn how to create and view access tokens \n                <a\n                  href=\"https://docs.npmjs.com/creating-and-viewing-access-tokens\"\n                  target=\"_blank\"\n                >\n                  here.\n                </a>\n              </mat-hint>\n            </mat-form-field>\n          </div>\n        </div>\n        \n        <div *ngIf=\"HostingDetails?.Loading\">\n          <div class=\"spread\">\n            <lcu-loader style=\"margin: auto\" [loading]=\"true\"></lcu-loader>\n        \n            <div class=\"margin-3\">\n              <h4 class=\"mat-title\">Loading hosting details</h4>\n            </div>\n          </div>\n        </div>\n      </mat-card-content>\n      <mat-card-actions fxLayoutAlign=\"center center\">\n\n        <button \n          *ngIf=\"!State?.Loading\"\n          mat-raised-button \n          type=\"submit\" \n          fxFlex=\"100%\" \n          color=\"primary\" \n          [disabled]=\"!BuildPipelineFormGroup.valid || !BuildPipelineFormGroup.dirty\">\n          <mat-icon>save</mat-icon>\n          Save Build Pipeline\n        </button>\n        <lcu-loader [loading]=\"State?.Loading\"></lcu-loader>  \n        \n    </mat-card-actions>\n    </mat-card>\n</form>\n"]}
|
|
@@ -15,9 +15,9 @@ export class UpgradeDialogComponent {
|
|
|
15
15
|
}
|
|
16
16
|
}
|
|
17
17
|
UpgradeDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: UpgradeDialogComponent, deps: [{ token: i1.MatDialogRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
18
|
-
UpgradeDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: UpgradeDialogComponent, selector: "lcu-upgrade-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<div fxLayout=\"row\" fxLayoutAlign=\"space-around center\"
|
|
18
|
+
UpgradeDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: UpgradeDialogComponent, selector: "lcu-upgrade-dialog", ngImport: i0, template: "<div class=\"dialog-header\" fxLayoutAlign=\"end center\">\n <button mat-icon-button id=\"close-upgrade-button\" (click)=\"CloseDialog()\">\n <mat-icon>cancel</mat-icon>\n </button>\n</div>\n\n<div fxLayout=\"row\" fxLayoutAlign=\"space-around center\" id=\"upgrade-content\">\n \n <div class=\"upgrade-container\" fxLayout=\"column\" fxLayoutAlign=\"center start\">\n <div class=\"x-large\">Wow!</div>\n <div class=\"x-large\">Fathym Premium is Free During Beta!</div>\n <div class=\"large\">Really...no credit card required.</div>\n </div>\n <div class=\"upgrade-container\">\n <img src=\"./assets/images/Happy_Lady.png\" id=\"upgrade-promo-image\" alt=\"Fathym Premium Free During Beta\">\n </div>\n</div>\n", styles: ["::ng-deep .mat-dialog-container{padding:5px!important}#upgrade-content{margin-top:-35px;padding:20px}.upgrade-container{padding:10px}#upgrade-promo-image{border-radius:5px;width:280px}.x-large{font-size:x-large;font-weight:700;margin:5px 0}.large{font-size:large;font-weight:700;margin:5px 0}\n"], 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"] }], directives: [{ type: i4.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.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"] }] });
|
|
19
19
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: UpgradeDialogComponent, decorators: [{
|
|
20
20
|
type: Component,
|
|
21
|
-
args: [{ selector: 'lcu-upgrade-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<div fxLayout=\"row\" fxLayoutAlign=\"space-around center\"
|
|
21
|
+
args: [{ selector: 'lcu-upgrade-dialog', template: "<div class=\"dialog-header\" fxLayoutAlign=\"end center\">\n <button mat-icon-button id=\"close-upgrade-button\" (click)=\"CloseDialog()\">\n <mat-icon>cancel</mat-icon>\n </button>\n</div>\n\n<div fxLayout=\"row\" fxLayoutAlign=\"space-around center\" id=\"upgrade-content\">\n \n <div class=\"upgrade-container\" fxLayout=\"column\" fxLayoutAlign=\"center start\">\n <div class=\"x-large\">Wow!</div>\n <div class=\"x-large\">Fathym Premium is Free During Beta!</div>\n <div class=\"large\">Really...no credit card required.</div>\n </div>\n <div class=\"upgrade-container\">\n <img src=\"./assets/images/Happy_Lady.png\" id=\"upgrade-promo-image\" alt=\"Fathym Premium Free During Beta\">\n </div>\n</div>\n", styles: ["::ng-deep .mat-dialog-container{padding:5px!important}#upgrade-content{margin-top:-35px;padding:20px}.upgrade-container{padding:10px}#upgrade-promo-image{border-radius:5px;width:280px}.x-large{font-size:x-large;font-weight:700;margin:5px 0}.large{font-size:large;font-weight:700;margin:5px 0}\n"] }]
|
|
22
22
|
}], ctorParameters: function () { return [{ type: i1.MatDialogRef }]; } });
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBncmFkZS1kaWFsb2cuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tbW9uL3NyYy9saWIvZGlhbG9ncy91cGdyYWRlLWRpYWxvZy91cGdyYWRlLWRpYWxvZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb21tb24vc3JjL2xpYi9kaWFsb2dzL3VwZ3JhZGUtZGlhbG9nL3VwZ3JhZGUtZGlhbG9nLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7Ozs7OztBQVFsRCxNQUFNLE9BQU8sc0JBQXNCO0lBRWpDLFlBQW1CLFNBQStDO1FBQS9DLGNBQVMsR0FBVCxTQUFTLENBQXNDO0lBQzVELENBQUM7SUFFQSxRQUFRO0lBQ2YsQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUN6QixDQUFDOzttSEFWVSxzQkFBc0I7dUdBQXRCLHNCQUFzQiwwRENSbkMscXdCQWlCQTsyRkRUYSxzQkFBc0I7a0JBTGxDLFNBQVM7K0JBQ0Usb0JBQW9CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hdERpYWxvZ1JlZiB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2xjdS11cGdyYWRlLWRpYWxvZycsXG4gIHRlbXBsYXRlVXJsOiAnLi91cGdyYWRlLWRpYWxvZy5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3VwZ3JhZGUtZGlhbG9nLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgVXBncmFkZURpYWxvZ0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgY29uc3RydWN0b3IocHVibGljIGRpYWxvZ1JlZjogTWF0RGlhbG9nUmVmPFVwZ3JhZGVEaWFsb2dDb21wb25lbnQ+LFxuICAgICkgeyB9XG5cbiAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xuICB9XG5cbiAgcHVibGljIENsb3NlRGlhbG9nKCl7XG4gICAgdGhpcy5kaWFsb2dSZWYuY2xvc2UoKTtcbiAgfVxuXG59XG4iLCI8ZGl2IGNsYXNzPVwiZGlhbG9nLWhlYWRlclwiIGZ4TGF5b3V0QWxpZ249XCJlbmQgY2VudGVyXCI+XG4gICAgPGJ1dHRvbiBtYXQtaWNvbi1idXR0b24gaWQ9XCJjbG9zZS11cGdyYWRlLWJ1dHRvblwiIChjbGljayk9XCJDbG9zZURpYWxvZygpXCI+XG4gICAgICAgICAgICA8bWF0LWljb24+Y2FuY2VsPC9tYXQtaWNvbj5cbiAgICA8L2J1dHRvbj5cbjwvZGl2PlxuXG48ZGl2IGZ4TGF5b3V0PVwicm93XCIgZnhMYXlvdXRBbGlnbj1cInNwYWNlLWFyb3VuZCBjZW50ZXJcIiBpZD1cInVwZ3JhZGUtY29udGVudFwiPlxuICAgIFxuICAgIDxkaXYgY2xhc3M9XCJ1cGdyYWRlLWNvbnRhaW5lclwiIGZ4TGF5b3V0PVwiY29sdW1uXCIgZnhMYXlvdXRBbGlnbj1cImNlbnRlciBzdGFydFwiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwieC1sYXJnZVwiPldvdyE8L2Rpdj5cbiAgICAgICAgPGRpdiBjbGFzcz1cIngtbGFyZ2VcIj5GYXRoeW0gUHJlbWl1bSBpcyBGcmVlIER1cmluZyBCZXRhITwvZGl2PlxuICAgICAgICA8ZGl2IGNsYXNzPVwibGFyZ2VcIj5SZWFsbHkuLi5ubyBjcmVkaXQgY2FyZCByZXF1aXJlZC48L2Rpdj5cbiAgICA8L2Rpdj5cbiAgICA8ZGl2IGNsYXNzPVwidXBncmFkZS1jb250YWluZXJcIj5cbiAgICAgICAgPGltZyBzcmM9XCIuL2Fzc2V0cy9pbWFnZXMvSGFwcHlfTGFkeS5wbmdcIiAgaWQ9XCJ1cGdyYWRlLXByb21vLWltYWdlXCIgYWx0PVwiRmF0aHltIFByZW1pdW0gRnJlZSBEdXJpbmcgQmV0YVwiPlxuICAgIDwvZGl2PlxuPC9kaXY+XG4iXX0=
|
|
@@ -44,10 +44,10 @@ export class ProjectInfoCardComponent {
|
|
|
44
44
|
}
|
|
45
45
|
}
|
|
46
46
|
ProjectInfoCardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: ProjectInfoCardComponent, deps: [{ token: i1.EaCService }, { token: i2.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
|
|
47
|
-
ProjectInfoCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: ProjectInfoCardComponent, selector: "lcu-project-info-card", inputs: { Description: ["description", "Description"], Image: ["image", "Image"], IsEditable: ["is-editable", "IsEditable"], IsShareable: ["is-shareable", "IsShareable"], Name: ["name", "Name"], Subtext: ["subtext", "Subtext"], Version: ["version", "Version"] }, outputs: { LeftClickEvent: "left-click-event", RightClickEvent: "right-click-event" }, ngImport: i0, template: "<mat-card class=\"project-info-card\">\n <!-- SKELETON CONTENT -->\n <ng-container *ngIf=\"State?.Loading\">\n <div class=\"header-img-container\" fxLayout=\"row\">\n <skeleton-avatar\n class=\"round-project-img\"\n [effect]=\"SkeletonEffect\"\n [size]=\"75\"\n ></skeleton-avatar>\n </div>\n\n <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n <mat-card-title\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"project-card-name\"\n >\n Name of card\n </mat-card-title>\n\n <mat-card-subtitle\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"project-card-description\"\n >\n Description Text\n </mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-host\">\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"host-anchor\">\n https://www.fathym.com\n </div>\n </mat-card-subtitle>\n </mat-card-header>\n <mat-card-content class=\"card-content-container\">\n <div\n skeleton-block\n [effect]=\"SkeletonEffect\"\n class=\"stats-container\"\n ></div>\n\n <div\n class=\"promo-container-skeleton\"\n fxLayout=\"column\"\n fxLayoutAlign=\"center center\"\n >\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">\n Access exclusive tools & insights\n </div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"skeleton-item\"\n >emoji_events</mat-icon\n >\n\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">\n Upgrade to premium now\n </div>\n </div>\n </div>\n </mat-card-content>\n <mat-card-actions\n class=\"actions-container-skeleton\"\n fxLayoutAlign=\"center center\"\n >\n <div\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"skeleton-item\"\n action\n mat-button\n >\n <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\"\n >outbox</mat-icon\n >\n Unpack\n </div>\n </mat-card-actions>\n </ng-container>\n <!-- END SKELETON CONTENT -->\n\n <!-- ACTUAL CONTENT -->\n\n <ng-container *ngIf=\"!State?.Loading\">\n <div class=\"header-img-container\" fxLayout=\"row\">\n <div class=\"round-project-img\" fxLayoutAlign=\"center center\">\n <mat-icon *ngIf=\"!Image\" class=\"temp-icon\">flutter_dash</mat-icon>\n <img\n *ngIf=\"Image\"\n [src]=\"Image\"\n [alt]=\"Name\"\n style=\"width: 75px;
|
|
47
|
+
ProjectInfoCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: ProjectInfoCardComponent, selector: "lcu-project-info-card", inputs: { Description: ["description", "Description"], Image: ["image", "Image"], IsEditable: ["is-editable", "IsEditable"], IsShareable: ["is-shareable", "IsShareable"], Name: ["name", "Name"], Subtext: ["subtext", "Subtext"], Version: ["version", "Version"] }, outputs: { LeftClickEvent: "left-click-event", RightClickEvent: "right-click-event" }, ngImport: i0, template: "<mat-card class=\"project-info-card\">\n <!-- SKELETON CONTENT -->\n <ng-container *ngIf=\"State?.Loading\">\n <div class=\"header-img-container\" fxLayout=\"row\">\n <skeleton-avatar\n class=\"round-project-img\"\n [effect]=\"SkeletonEffect\"\n [size]=\"75\"\n ></skeleton-avatar>\n </div>\n\n <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n <mat-card-title\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"project-card-name\"\n >\n Name of card\n </mat-card-title>\n\n <mat-card-subtitle\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"project-card-description\"\n >\n Description Text\n </mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-host\">\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"host-anchor\">\n https://www.fathym.com\n </div>\n </mat-card-subtitle>\n </mat-card-header>\n <mat-card-content class=\"card-content-container\">\n <div\n skeleton-block\n [effect]=\"SkeletonEffect\"\n class=\"stats-container\"\n ></div>\n\n <div\n class=\"promo-container-skeleton\"\n fxLayout=\"column\"\n fxLayoutAlign=\"center center\"\n >\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">\n Access exclusive tools & insights\n </div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"skeleton-item\"\n >emoji_events</mat-icon\n >\n\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">\n Upgrade to premium now\n </div>\n </div>\n </div>\n </mat-card-content>\n <mat-card-actions\n class=\"actions-container-skeleton\"\n fxLayoutAlign=\"center center\"\n >\n <div\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"skeleton-item\"\n action\n mat-button\n >\n <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\"\n >outbox</mat-icon\n >\n Unpack\n </div>\n </mat-card-actions>\n </ng-container>\n <!-- END SKELETON CONTENT -->\n\n <!-- ACTUAL CONTENT -->\n\n <ng-container *ngIf=\"!State?.Loading\">\n <div class=\"header-img-container\" fxLayout=\"row\">\n <div class=\"round-project-img\" fxLayoutAlign=\"center center\">\n <mat-icon *ngIf=\"!Image\" class=\"temp-icon\">flutter_dash</mat-icon>\n <img\n *ngIf=\"Image\"\n [src]=\"Image\"\n [alt]=\"Name\"\n style=\"width: 75px; border-radius: 40px; \"\n />\n </div>\n </div>\n\n <div\n class=\"icon-btn-container\"\n fxLayout=\"row\"\n fxLayoutAlign=\"space-between center\"\n >\n <button\n *ngIf=\"IsEditable\"\n mat-icon-button\n id=\"left-icon\"\n (click)=\"LeftIconClicked()\"\n >\n <mat-icon>edit</mat-icon>\n </button>\n <button\n *ngIf=\"IsShareable\"\n mat-icon-button\n id=\"right-icon\"\n (click)=\"RightIconClicked()\"\n >\n <mat-icon>share</mat-icon>\n </button>\n </div>\n\n <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n <mat-card-title class=\"project-card-name\" *ngIf=\"Name\">\n {{ Name }}\n </mat-card-title>\n\n <mat-card-subtitle class=\"project-card-description\" *ngIf=\"Description\">\n {{ Description }}\n </mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-version\" *ngIf=\"Version\">\n {{ Version }}\n </mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-host\">\n <a\n class=\"host-anchor\"\n *ngIf=\"Subtext\"\n [href]=\"'https://' + Subtext\"\n target=\"_blank\"\n >\n {{ Subtext }}\n </a>\n </mat-card-subtitle>\n </mat-card-header>\n\n <mat-card-content class=\"card-content-container\">\n <div class=\"stats-container\">\n <ng-content select=\"[stats]\"></ng-content>\n </div>\n\n <!-- <div class=\"promo-container\"> -->\n <!-- <ng-content select=\"[promo]\"></ng-content> -->\n <div\n class=\"promo-container\"\n fxLayout=\"column\"\n fxLayoutAlign=\"center center\"\n (click)=\"UpgradeClicked()\"\n >\n <div>Access exclusive tools & insights</div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon class=\"gold-icon\">emoji_events</mat-icon>\n\n <div class=\"upgrade-text\" (click)=\"UpgradeClicked()\">\n Upgrade to premium now\n </div>\n </div>\n </div>\n <!-- </div> -->\n </mat-card-content>\n <mat-card-actions class=\"actions-container\">\n <ng-content select=\"[action]\"></ng-content>\n </mat-card-actions>\n </ng-container>\n</mat-card>\n", styles: [".project-info-card{margin:20px;padding:0}.round-project-img{background-color:#fff;width:75px;height:75px;border-radius:40px;text-align:center;margin-top:20px;border:2px solid white}.temp-icon{height:50px;width:50px;font-size:50px}.icon-btn-container{margin:5px}.project-card-header{text-align:center;margin-top:50px}.host-anchor{text-decoration:none;color:#4a918e}.header-img-container{background-color:#a4bab3;height:60px;border-radius:2px 2px 0 0;margin-top:-.5px!important;margin-right:-.5px;justify-content:center}.project-card-name{font-size:17px;font-weight:600}.card-content-container{margin-bottom:0!important}.stats-container{border-top:1px solid #b9dddd}.promo-container{cursor:pointer}.gold-icon{color:#d4af37}.upgrade-text{font-weight:700;margin-left:10px;cursor:pointer}mat-card-actions{margin-bottom:-1px!important;margin-left:0!important;margin-right:-.5px!important}.promo-container-skeleton{margin:5px}.actions-container{padding:0!important}.actions-container-skeleton{padding:0!important;border-top:1px solid #b9dddd}.info-card-btn{width:100%;border-radius:0 0 2px 2px;border-top:1px solid #b9dddd}.skeleton-item{margin:5px}\n"], components: [{ type: i3.MatCard, selector: "mat-card", exportAs: ["matCard"] }, { type: i4.SkeletonAvatarComponent, selector: "skeleton-avatar", inputs: ["size", "color", "showIcon", "iconColor", "borderRadius", "effect"] }, { type: i3.MatCardHeader, selector: "mat-card-header" }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { 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"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.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: i8.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: i3.MatCardTitle, selector: "mat-card-title, [mat-card-title], [matCardTitle]" }, { type: i4.SkeletonTextDirective, selector: "[skeleton-text]", inputs: ["effect"] }, { type: i3.MatCardSubtitle, selector: "mat-card-subtitle, [mat-card-subtitle], [matCardSubtitle]" }, { type: i3.MatCardContent, selector: "mat-card-content, [mat-card-content], [matCardContent]" }, { type: i3.MatCardActions, selector: "mat-card-actions", inputs: ["align"], exportAs: ["matCardActions"] }] });
|
|
48
48
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: ProjectInfoCardComponent, decorators: [{
|
|
49
49
|
type: Component,
|
|
50
|
-
args: [{ selector: 'lcu-project-info-card', template: "<mat-card class=\"project-info-card\">\n <!-- SKELETON CONTENT -->\n <ng-container *ngIf=\"State?.Loading\">\n <div class=\"header-img-container\" fxLayout=\"row\">\n <skeleton-avatar\n class=\"round-project-img\"\n [effect]=\"SkeletonEffect\"\n [size]=\"75\"\n ></skeleton-avatar>\n </div>\n\n <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n <mat-card-title\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"project-card-name\"\n >\n Name of card\n </mat-card-title>\n\n <mat-card-subtitle\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"project-card-description\"\n >\n Description Text\n </mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-host\">\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"host-anchor\">\n https://www.fathym.com\n </div>\n </mat-card-subtitle>\n </mat-card-header>\n <mat-card-content class=\"card-content-container\">\n <div\n skeleton-block\n [effect]=\"SkeletonEffect\"\n class=\"stats-container\"\n ></div>\n\n <div\n class=\"promo-container-skeleton\"\n fxLayout=\"column\"\n fxLayoutAlign=\"center center\"\n >\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">\n Access exclusive tools & insights\n </div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"skeleton-item\"\n >emoji_events</mat-icon\n >\n\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">\n Upgrade to premium now\n </div>\n </div>\n </div>\n </mat-card-content>\n <mat-card-actions\n class=\"actions-container-skeleton\"\n fxLayoutAlign=\"center center\"\n >\n <div\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"skeleton-item\"\n action\n mat-button\n >\n <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\"\n >outbox</mat-icon\n >\n Unpack\n </div>\n </mat-card-actions>\n </ng-container>\n <!-- END SKELETON CONTENT -->\n\n <!-- ACTUAL CONTENT -->\n\n <ng-container *ngIf=\"!State?.Loading\">\n <div class=\"header-img-container\" fxLayout=\"row\">\n <div class=\"round-project-img\" fxLayoutAlign=\"center center\">\n <mat-icon *ngIf=\"!Image\" class=\"temp-icon\">flutter_dash</mat-icon>\n <img\n *ngIf=\"Image\"\n [src]=\"Image\"\n [alt]=\"Name\"\n style=\"width: 75px;
|
|
50
|
+
args: [{ selector: 'lcu-project-info-card', template: "<mat-card class=\"project-info-card\">\n <!-- SKELETON CONTENT -->\n <ng-container *ngIf=\"State?.Loading\">\n <div class=\"header-img-container\" fxLayout=\"row\">\n <skeleton-avatar\n class=\"round-project-img\"\n [effect]=\"SkeletonEffect\"\n [size]=\"75\"\n ></skeleton-avatar>\n </div>\n\n <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n <mat-card-title\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"project-card-name\"\n >\n Name of card\n </mat-card-title>\n\n <mat-card-subtitle\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"project-card-description\"\n >\n Description Text\n </mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-host\">\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"host-anchor\">\n https://www.fathym.com\n </div>\n </mat-card-subtitle>\n </mat-card-header>\n <mat-card-content class=\"card-content-container\">\n <div\n skeleton-block\n [effect]=\"SkeletonEffect\"\n class=\"stats-container\"\n ></div>\n\n <div\n class=\"promo-container-skeleton\"\n fxLayout=\"column\"\n fxLayoutAlign=\"center center\"\n >\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">\n Access exclusive tools & insights\n </div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"skeleton-item\"\n >emoji_events</mat-icon\n >\n\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">\n Upgrade to premium now\n </div>\n </div>\n </div>\n </mat-card-content>\n <mat-card-actions\n class=\"actions-container-skeleton\"\n fxLayoutAlign=\"center center\"\n >\n <div\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"skeleton-item\"\n action\n mat-button\n >\n <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\"\n >outbox</mat-icon\n >\n Unpack\n </div>\n </mat-card-actions>\n </ng-container>\n <!-- END SKELETON CONTENT -->\n\n <!-- ACTUAL CONTENT -->\n\n <ng-container *ngIf=\"!State?.Loading\">\n <div class=\"header-img-container\" fxLayout=\"row\">\n <div class=\"round-project-img\" fxLayoutAlign=\"center center\">\n <mat-icon *ngIf=\"!Image\" class=\"temp-icon\">flutter_dash</mat-icon>\n <img\n *ngIf=\"Image\"\n [src]=\"Image\"\n [alt]=\"Name\"\n style=\"width: 75px; border-radius: 40px; \"\n />\n </div>\n </div>\n\n <div\n class=\"icon-btn-container\"\n fxLayout=\"row\"\n fxLayoutAlign=\"space-between center\"\n >\n <button\n *ngIf=\"IsEditable\"\n mat-icon-button\n id=\"left-icon\"\n (click)=\"LeftIconClicked()\"\n >\n <mat-icon>edit</mat-icon>\n </button>\n <button\n *ngIf=\"IsShareable\"\n mat-icon-button\n id=\"right-icon\"\n (click)=\"RightIconClicked()\"\n >\n <mat-icon>share</mat-icon>\n </button>\n </div>\n\n <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n <mat-card-title class=\"project-card-name\" *ngIf=\"Name\">\n {{ Name }}\n </mat-card-title>\n\n <mat-card-subtitle class=\"project-card-description\" *ngIf=\"Description\">\n {{ Description }}\n </mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-version\" *ngIf=\"Version\">\n {{ Version }}\n </mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-host\">\n <a\n class=\"host-anchor\"\n *ngIf=\"Subtext\"\n [href]=\"'https://' + Subtext\"\n target=\"_blank\"\n >\n {{ Subtext }}\n </a>\n </mat-card-subtitle>\n </mat-card-header>\n\n <mat-card-content class=\"card-content-container\">\n <div class=\"stats-container\">\n <ng-content select=\"[stats]\"></ng-content>\n </div>\n\n <!-- <div class=\"promo-container\"> -->\n <!-- <ng-content select=\"[promo]\"></ng-content> -->\n <div\n class=\"promo-container\"\n fxLayout=\"column\"\n fxLayoutAlign=\"center center\"\n (click)=\"UpgradeClicked()\"\n >\n <div>Access exclusive tools & insights</div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon class=\"gold-icon\">emoji_events</mat-icon>\n\n <div class=\"upgrade-text\" (click)=\"UpgradeClicked()\">\n Upgrade to premium now\n </div>\n </div>\n </div>\n <!-- </div> -->\n </mat-card-content>\n <mat-card-actions class=\"actions-container\">\n <ng-content select=\"[action]\"></ng-content>\n </mat-card-actions>\n </ng-container>\n</mat-card>\n", styles: [".project-info-card{margin:20px;padding:0}.round-project-img{background-color:#fff;width:75px;height:75px;border-radius:40px;text-align:center;margin-top:20px;border:2px solid white}.temp-icon{height:50px;width:50px;font-size:50px}.icon-btn-container{margin:5px}.project-card-header{text-align:center;margin-top:50px}.host-anchor{text-decoration:none;color:#4a918e}.header-img-container{background-color:#a4bab3;height:60px;border-radius:2px 2px 0 0;margin-top:-.5px!important;margin-right:-.5px;justify-content:center}.project-card-name{font-size:17px;font-weight:600}.card-content-container{margin-bottom:0!important}.stats-container{border-top:1px solid #b9dddd}.promo-container{cursor:pointer}.gold-icon{color:#d4af37}.upgrade-text{font-weight:700;margin-left:10px;cursor:pointer}mat-card-actions{margin-bottom:-1px!important;margin-left:0!important;margin-right:-.5px!important}.promo-container-skeleton{margin:5px}.actions-container{padding:0!important}.actions-container-skeleton{padding:0!important;border-top:1px solid #b9dddd}.info-card-btn{width:100%;border-radius:0 0 2px 2px;border-top:1px solid #b9dddd}.skeleton-item{margin:5px}\n"] }]
|
|
51
51
|
}], ctorParameters: function () { return [{ type: i1.EaCService }, { type: i2.MatDialog }]; }, propDecorators: { Description: [{
|
|
52
52
|
type: Input,
|
|
53
53
|
args: ['description']
|
|
@@ -76,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
|
|
|
76
76
|
type: Output,
|
|
77
77
|
args: ['right-click-event']
|
|
78
78
|
}] } });
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"project-info-card.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/elements/project-info-card/project-info-card.component.ts","../../../../../../projects/common/src/lib/elements/project-info-card/project-info-card.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAE/E,OAAO,EAAE,sBAAsB,EAAE,MAAM,uDAAuD,CAAC;;;;;;;;;;AAS/F,MAAM,OAAO,wBAAwB;IAoCnC,YAAsB,MAAkB,EAAW,MAAiB;QAA9C,WAAM,GAAN,MAAM,CAAY;QAAW,WAAM,GAAN,MAAM,CAAW;QAClE,IAAI,CAAC,cAAc,GAAG,IAAI,YAAY,EAAE,CAAC;QAEzC,IAAI,CAAC,eAAe,GAAG,IAAI,YAAY,EAAE,CAAC;QAE1C,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;IAC9B,CAAC;IAbF,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;IAC3B,CAAC;IAaM,QAAQ;QACb,0CAA0C;QAC1C,mDAAmD;QACnD,iDAAiD;IACnD,CAAC;IAIM,eAAe;QACpB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC/B,CAAC;IAEM,gBAAgB;QACrB,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAA;QAC5B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAChC,CAAC;IAEM,cAAc;QACnB,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,sBAAsB,EAAE;YACzD,KAAK,EAAE,OAAO;YACd,IAAI,EAAE,EACL;SACF,CAAC,CAAC;QAEH,SAAS,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YAC3C,wCAAwC;YACxC,iCAAiC;QACnC,CAAC,CAAC,CAAC;IAEL,CAAC;;qHAzEU,wBAAwB;yGAAxB,wBAAwB,2ZCXrC,qlKAiLA;2FDtKa,wBAAwB;kBALpC,SAAS;+BACE,uBAAuB;yHAO1B,WAAW;sBADjB,KAAK;uBAAC,aAAa;gBAIb,KAAK;sBADX,KAAK;uBAAC,OAAO;gBAIP,UAAU;sBADhB,KAAK;uBAAC,aAAa;gBAIb,WAAW;sBADjB,KAAK;uBAAC,cAAc;gBAId,IAAI;sBADV,KAAK;uBAAC,MAAM;gBAIN,OAAO;sBADb,KAAK;uBAAC,SAAS;gBAIT,OAAO;sBADb,KAAK;uBAAC,SAAS;gBAIT,cAAc;sBADpB,MAAM;uBAAC,kBAAkB;gBAInB,eAAe;sBADrB,MAAM;uBAAC,mBAAmB","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport { UpgradeDialogComponent } from '../../dialogs/upgrade-dialog/upgrade-dialog.component';\nimport { EaCService } from '../../services/eac.service';\nimport { ApplicationsFlowState } from '../../state/applications-flow.state';\n\n@Component({\n  selector: 'lcu-project-info-card',\n  templateUrl: './project-info-card.component.html',\n  styleUrls: ['./project-info-card.component.scss']\n})\nexport class ProjectInfoCardComponent implements OnInit {\n  \n  @Input('description')\n  public Description: string;\n  \n  @Input('image')\n  public Image: string;\n\n  @Input('is-editable')\n  public IsEditable: boolean;\n\n  @Input('is-shareable')\n  public IsShareable: boolean;\n\n  @Input('name')\n  public Name: string;\n\n  @Input('subtext')\n  public Subtext: string;\n\n  @Input('version')\n  public Version: string;\n\n  @Output('left-click-event')\n  public LeftClickEvent: EventEmitter<{}>;\n\n  @Output('right-click-event')\n  public RightClickEvent: EventEmitter<{}>;\n\n  public get State(): ApplicationsFlowState{\n    return this.eacSvc.State;\n  }\n\n  public SkeletonEffect: string;\n\n\n  constructor(protected eacSvc: EaCService,protected dialog: MatDialog,) {\n    this.LeftClickEvent = new EventEmitter();\n\n    this.RightClickEvent = new EventEmitter();\n\n    this.SkeletonEffect = 'wave';\n   }\n\n  public ngOnInit(): void {\n    // console.log(\"loading = \", this.Loading)\n    // console.log(\"is shareable: \", this.IsShareable);\n    // console.log(\"is editable: \", this.IsEditable);\n  }\n\n\n\n  public LeftIconClicked(){\n    this.LeftClickEvent.emit({});\n  }\n\n  public RightIconClicked(){\n    console.log(\"share clicked\")\n    this.RightClickEvent.emit({});\n  }\n\n  public UpgradeClicked(){\n    const dialogRef = this.dialog.open(UpgradeDialogComponent, {\n      width: '600px',\n      data: {\n      },\n    });\n\n    dialogRef.afterClosed().subscribe((result) => {\n      // console.log('The dialog was closed');\n      // console.log(\"result:\", result)\n    });\n\n  }\n\n}\n","<mat-card class=\"project-info-card\">\n  <!-- SKELETON CONTENT -->\n  <ng-container *ngIf=\"State?.Loading\">\n    <div class=\"header-img-container\" fxLayout=\"row\">\n      <skeleton-avatar\n        class=\"round-project-img\"\n        [effect]=\"SkeletonEffect\"\n        [size]=\"75\"\n      ></skeleton-avatar>\n    </div>\n\n    <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n      <mat-card-title\n        skeleton-text\n        [effect]=\"SkeletonEffect\"\n        class=\"project-card-name\"\n      >\n        Name of card\n      </mat-card-title>\n\n      <mat-card-subtitle\n        skeleton-text\n        [effect]=\"SkeletonEffect\"\n        class=\"project-card-description\"\n      >\n        Description Text\n      </mat-card-subtitle>\n\n      <mat-card-subtitle class=\"project-card-host\">\n        <div skeleton-text [effect]=\"SkeletonEffect\" class=\"host-anchor\">\n          https://www.fathym.com\n        </div>\n      </mat-card-subtitle>\n    </mat-card-header>\n    <mat-card-content class=\"card-content-container\">\n      <div\n        skeleton-block\n        [effect]=\"SkeletonEffect\"\n        class=\"stats-container\"\n      ></div>\n\n      <div\n        class=\"promo-container-skeleton\"\n        fxLayout=\"column\"\n        fxLayoutAlign=\"center center\"\n      >\n        <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">\n          Access exclusive tools & insights\n        </div>\n\n        <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n          <mat-icon\n            skeleton-text\n            [effect]=\"SkeletonEffect\"\n            class=\"skeleton-item\"\n            >emoji_events</mat-icon\n          >\n\n          <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">\n            Upgrade to premium now\n          </div>\n        </div>\n      </div>\n    </mat-card-content>\n    <mat-card-actions\n      class=\"actions-container-skeleton\"\n      fxLayoutAlign=\"center center\"\n    >\n      <div\n        skeleton-text\n        [effect]=\"SkeletonEffect\"\n        class=\"skeleton-item\"\n        action\n        mat-button\n      >\n        <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\"\n          >outbox</mat-icon\n        >\n        Unpack\n      </div>\n    </mat-card-actions>\n  </ng-container>\n  <!-- END SKELETON CONTENT -->\n\n  <!-- ACTUAL CONTENT -->\n\n  <ng-container *ngIf=\"!State?.Loading\">\n    <div class=\"header-img-container\" fxLayout=\"row\">\n      <div class=\"round-project-img\" fxLayoutAlign=\"center center\">\n        <mat-icon *ngIf=\"!Image\" class=\"temp-icon\">flutter_dash</mat-icon>\n        <img\n          *ngIf=\"Image\"\n          [src]=\"Image\"\n          [alt]=\"Name\"\n          style=\"width: 75px; height: 75px; border-radius: 40px; \"\n        />\n      </div>\n    </div>\n\n    <div\n      class=\"icon-btn-container\"\n      fxLayout=\"row\"\n      fxLayoutAlign=\"space-between center\"\n    >\n      <button\n        *ngIf=\"IsEditable\"\n        mat-icon-button\n        id=\"left-icon\"\n        (click)=\"LeftIconClicked()\"\n      >\n        <mat-icon>edit</mat-icon>\n      </button>\n      <button\n        *ngIf=\"IsShareable\"\n        mat-icon-button\n        id=\"right-icon\"\n        (click)=\"RightIconClicked()\"\n      >\n        <mat-icon>share</mat-icon>\n      </button>\n    </div>\n\n    <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n      <mat-card-title class=\"project-card-name\" *ngIf=\"Name\">\n        {{ Name }}\n      </mat-card-title>\n\n      <mat-card-subtitle class=\"project-card-description\" *ngIf=\"Description\">\n        {{ Description }}\n      </mat-card-subtitle>\n\n      <mat-card-subtitle class=\"project-card-version\" *ngIf=\"Version\">\n        {{ Version }}\n      </mat-card-subtitle>\n\n      <mat-card-subtitle class=\"project-card-host\">\n        <a\n          class=\"host-anchor\"\n          *ngIf=\"Subtext\"\n          [href]=\"'https://' + Subtext\"\n          target=\"_blank\"\n        >\n          {{ Subtext }}\n        </a>\n      </mat-card-subtitle>\n    </mat-card-header>\n\n    <mat-card-content class=\"card-content-container\">\n      <div class=\"stats-container\">\n        <ng-content select=\"[stats]\"></ng-content>\n      </div>\n\n      <!-- <div class=\"promo-container\"> -->\n      <!-- <ng-content  select=\"[promo]\"></ng-content> -->\n      <div\n        class=\"promo-container\"\n        fxLayout=\"column\"\n        fxLayoutAlign=\"center center\"\n        (click)=\"UpgradeClicked()\"\n      >\n        <div>Access exclusive tools & insights</div>\n\n        <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n          <mat-icon class=\"gold-icon\">emoji_events</mat-icon>\n\n          <div class=\"upgrade-text\" (click)=\"UpgradeClicked()\">\n            Upgrade to premium now\n          </div>\n        </div>\n      </div>\n      <!-- </div> -->\n    </mat-card-content>\n    <mat-card-actions class=\"actions-container\">\n      <ng-content select=\"[action]\"></ng-content>\n    </mat-card-actions>\n  </ng-container>\n</mat-card>\n"]}
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"project-info-card.component.js","sourceRoot":"","sources":["../../../../../../projects/common/src/lib/elements/project-info-card/project-info-card.component.ts","../../../../../../projects/common/src/lib/elements/project-info-card/project-info-card.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAE/E,OAAO,EAAE,sBAAsB,EAAE,MAAM,uDAAuD,CAAC;;;;;;;;;;AAS/F,MAAM,OAAO,wBAAwB;IAoCnC,YAAsB,MAAkB,EAAW,MAAiB;QAA9C,WAAM,GAAN,MAAM,CAAY;QAAW,WAAM,GAAN,MAAM,CAAW;QAClE,IAAI,CAAC,cAAc,GAAG,IAAI,YAAY,EAAE,CAAC;QAEzC,IAAI,CAAC,eAAe,GAAG,IAAI,YAAY,EAAE,CAAC;QAE1C,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;IAC9B,CAAC;IAbF,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;IAC3B,CAAC;IAaM,QAAQ;QACb,0CAA0C;QAC1C,mDAAmD;QACnD,iDAAiD;IACnD,CAAC;IAIM,eAAe;QACpB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC/B,CAAC;IAEM,gBAAgB;QACrB,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAA;QAC5B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAChC,CAAC;IAEM,cAAc;QACnB,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,sBAAsB,EAAE;YACzD,KAAK,EAAE,OAAO;YACd,IAAI,EAAE,EACL;SACF,CAAC,CAAC;QAEH,SAAS,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YAC3C,wCAAwC;YACxC,iCAAiC;QACnC,CAAC,CAAC,CAAC;IAEL,CAAC;;qHAzEU,wBAAwB;yGAAxB,wBAAwB,2ZCXrC,ukKAiLA;2FDtKa,wBAAwB;kBALpC,SAAS;+BACE,uBAAuB;yHAO1B,WAAW;sBADjB,KAAK;uBAAC,aAAa;gBAIb,KAAK;sBADX,KAAK;uBAAC,OAAO;gBAIP,UAAU;sBADhB,KAAK;uBAAC,aAAa;gBAIb,WAAW;sBADjB,KAAK;uBAAC,cAAc;gBAId,IAAI;sBADV,KAAK;uBAAC,MAAM;gBAIN,OAAO;sBADb,KAAK;uBAAC,SAAS;gBAIT,OAAO;sBADb,KAAK;uBAAC,SAAS;gBAIT,cAAc;sBADpB,MAAM;uBAAC,kBAAkB;gBAInB,eAAe;sBADrB,MAAM;uBAAC,mBAAmB","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { MatDialog } from '@angular/material/dialog';\nimport { UpgradeDialogComponent } from '../../dialogs/upgrade-dialog/upgrade-dialog.component';\nimport { EaCService } from '../../services/eac.service';\nimport { ApplicationsFlowState } from '../../state/applications-flow.state';\n\n@Component({\n  selector: 'lcu-project-info-card',\n  templateUrl: './project-info-card.component.html',\n  styleUrls: ['./project-info-card.component.scss']\n})\nexport class ProjectInfoCardComponent implements OnInit {\n  \n  @Input('description')\n  public Description: string;\n  \n  @Input('image')\n  public Image: string;\n\n  @Input('is-editable')\n  public IsEditable: boolean;\n\n  @Input('is-shareable')\n  public IsShareable: boolean;\n\n  @Input('name')\n  public Name: string;\n\n  @Input('subtext')\n  public Subtext: string;\n\n  @Input('version')\n  public Version: string;\n\n  @Output('left-click-event')\n  public LeftClickEvent: EventEmitter<{}>;\n\n  @Output('right-click-event')\n  public RightClickEvent: EventEmitter<{}>;\n\n  public get State(): ApplicationsFlowState{\n    return this.eacSvc.State;\n  }\n\n  public SkeletonEffect: string;\n\n\n  constructor(protected eacSvc: EaCService,protected dialog: MatDialog,) {\n    this.LeftClickEvent = new EventEmitter();\n\n    this.RightClickEvent = new EventEmitter();\n\n    this.SkeletonEffect = 'wave';\n   }\n\n  public ngOnInit(): void {\n    // console.log(\"loading = \", this.Loading)\n    // console.log(\"is shareable: \", this.IsShareable);\n    // console.log(\"is editable: \", this.IsEditable);\n  }\n\n\n\n  public LeftIconClicked(){\n    this.LeftClickEvent.emit({});\n  }\n\n  public RightIconClicked(){\n    console.log(\"share clicked\")\n    this.RightClickEvent.emit({});\n  }\n\n  public UpgradeClicked(){\n    const dialogRef = this.dialog.open(UpgradeDialogComponent, {\n      width: '600px',\n      data: {\n      },\n    });\n\n    dialogRef.afterClosed().subscribe((result) => {\n      // console.log('The dialog was closed');\n      // console.log(\"result:\", result)\n    });\n\n  }\n\n}\n","<mat-card class=\"project-info-card\">\n  <!-- SKELETON CONTENT -->\n  <ng-container *ngIf=\"State?.Loading\">\n    <div class=\"header-img-container\" fxLayout=\"row\">\n      <skeleton-avatar\n        class=\"round-project-img\"\n        [effect]=\"SkeletonEffect\"\n        [size]=\"75\"\n      ></skeleton-avatar>\n    </div>\n\n    <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n      <mat-card-title\n        skeleton-text\n        [effect]=\"SkeletonEffect\"\n        class=\"project-card-name\"\n      >\n        Name of card\n      </mat-card-title>\n\n      <mat-card-subtitle\n        skeleton-text\n        [effect]=\"SkeletonEffect\"\n        class=\"project-card-description\"\n      >\n        Description Text\n      </mat-card-subtitle>\n\n      <mat-card-subtitle class=\"project-card-host\">\n        <div skeleton-text [effect]=\"SkeletonEffect\" class=\"host-anchor\">\n          https://www.fathym.com\n        </div>\n      </mat-card-subtitle>\n    </mat-card-header>\n    <mat-card-content class=\"card-content-container\">\n      <div\n        skeleton-block\n        [effect]=\"SkeletonEffect\"\n        class=\"stats-container\"\n      ></div>\n\n      <div\n        class=\"promo-container-skeleton\"\n        fxLayout=\"column\"\n        fxLayoutAlign=\"center center\"\n      >\n        <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">\n          Access exclusive tools & insights\n        </div>\n\n        <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n          <mat-icon\n            skeleton-text\n            [effect]=\"SkeletonEffect\"\n            class=\"skeleton-item\"\n            >emoji_events</mat-icon\n          >\n\n          <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">\n            Upgrade to premium now\n          </div>\n        </div>\n      </div>\n    </mat-card-content>\n    <mat-card-actions\n      class=\"actions-container-skeleton\"\n      fxLayoutAlign=\"center center\"\n    >\n      <div\n        skeleton-text\n        [effect]=\"SkeletonEffect\"\n        class=\"skeleton-item\"\n        action\n        mat-button\n      >\n        <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\"\n          >outbox</mat-icon\n        >\n        Unpack\n      </div>\n    </mat-card-actions>\n  </ng-container>\n  <!-- END SKELETON CONTENT -->\n\n  <!-- ACTUAL CONTENT -->\n\n  <ng-container *ngIf=\"!State?.Loading\">\n    <div class=\"header-img-container\" fxLayout=\"row\">\n      <div class=\"round-project-img\" fxLayoutAlign=\"center center\">\n        <mat-icon *ngIf=\"!Image\" class=\"temp-icon\">flutter_dash</mat-icon>\n        <img\n          *ngIf=\"Image\"\n          [src]=\"Image\"\n          [alt]=\"Name\"\n          style=\"width: 75px; border-radius: 40px; \"\n        />\n      </div>\n    </div>\n\n    <div\n      class=\"icon-btn-container\"\n      fxLayout=\"row\"\n      fxLayoutAlign=\"space-between center\"\n    >\n      <button\n        *ngIf=\"IsEditable\"\n        mat-icon-button\n        id=\"left-icon\"\n        (click)=\"LeftIconClicked()\"\n      >\n        <mat-icon>edit</mat-icon>\n      </button>\n      <button\n        *ngIf=\"IsShareable\"\n        mat-icon-button\n        id=\"right-icon\"\n        (click)=\"RightIconClicked()\"\n      >\n        <mat-icon>share</mat-icon>\n      </button>\n    </div>\n\n    <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n      <mat-card-title class=\"project-card-name\" *ngIf=\"Name\">\n        {{ Name }}\n      </mat-card-title>\n\n      <mat-card-subtitle class=\"project-card-description\" *ngIf=\"Description\">\n        {{ Description }}\n      </mat-card-subtitle>\n\n      <mat-card-subtitle class=\"project-card-version\" *ngIf=\"Version\">\n        {{ Version }}\n      </mat-card-subtitle>\n\n      <mat-card-subtitle class=\"project-card-host\">\n        <a\n          class=\"host-anchor\"\n          *ngIf=\"Subtext\"\n          [href]=\"'https://' + Subtext\"\n          target=\"_blank\"\n        >\n          {{ Subtext }}\n        </a>\n      </mat-card-subtitle>\n    </mat-card-header>\n\n    <mat-card-content class=\"card-content-container\">\n      <div class=\"stats-container\">\n        <ng-content select=\"[stats]\"></ng-content>\n      </div>\n\n      <!-- <div class=\"promo-container\"> -->\n      <!-- <ng-content  select=\"[promo]\"></ng-content> -->\n      <div\n        class=\"promo-container\"\n        fxLayout=\"column\"\n        fxLayoutAlign=\"center center\"\n        (click)=\"UpgradeClicked()\"\n      >\n        <div>Access exclusive tools & insights</div>\n\n        <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n          <mat-icon class=\"gold-icon\">emoji_events</mat-icon>\n\n          <div class=\"upgrade-text\" (click)=\"UpgradeClicked()\">\n            Upgrade to premium now\n          </div>\n        </div>\n      </div>\n      <!-- </div> -->\n    </mat-card-content>\n    <mat-card-actions class=\"actions-container\">\n      <ng-content select=\"[action]\"></ng-content>\n    </mat-card-actions>\n  </ng-container>\n</mat-card>\n"]}
|
|
@@ -3710,10 +3710,10 @@ class UpgradeDialogComponent {
|
|
|
3710
3710
|
}
|
|
3711
3711
|
}
|
|
3712
3712
|
UpgradeDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: UpgradeDialogComponent, deps: [{ token: i1$4.MatDialogRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
3713
|
-
UpgradeDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: UpgradeDialogComponent, selector: "lcu-upgrade-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<div fxLayout=\"row\" fxLayoutAlign=\"space-around center\"
|
|
3713
|
+
UpgradeDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: UpgradeDialogComponent, selector: "lcu-upgrade-dialog", ngImport: i0, template: "<div class=\"dialog-header\" fxLayoutAlign=\"end center\">\n <button mat-icon-button id=\"close-upgrade-button\" (click)=\"CloseDialog()\">\n <mat-icon>cancel</mat-icon>\n </button>\n</div>\n\n<div fxLayout=\"row\" fxLayoutAlign=\"space-around center\" id=\"upgrade-content\">\n \n <div class=\"upgrade-container\" fxLayout=\"column\" fxLayoutAlign=\"center start\">\n <div class=\"x-large\">Wow!</div>\n <div class=\"x-large\">Fathym Premium is Free During Beta!</div>\n <div class=\"large\">Really...no credit card required.</div>\n </div>\n <div class=\"upgrade-container\">\n <img src=\"./assets/images/Happy_Lady.png\" id=\"upgrade-promo-image\" alt=\"Fathym Premium Free During Beta\">\n </div>\n</div>\n", styles: ["::ng-deep .mat-dialog-container{padding:5px!important}#upgrade-content{margin-top:-35px;padding:20px}.upgrade-container{padding:10px}#upgrade-promo-image{border-radius:5px;width:280px}.x-large{font-size:x-large;font-weight:700;margin:5px 0}.large{font-size:large;font-weight:700;margin:5px 0}\n"], components: [{ type: i2$1.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"] }], directives: [{ type: i5$1.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: i5$1.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"] }] });
|
|
3714
3714
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: UpgradeDialogComponent, decorators: [{
|
|
3715
3715
|
type: Component,
|
|
3716
|
-
args: [{ selector: 'lcu-upgrade-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<div fxLayout=\"row\" fxLayoutAlign=\"space-around center\"
|
|
3716
|
+
args: [{ selector: 'lcu-upgrade-dialog', template: "<div class=\"dialog-header\" fxLayoutAlign=\"end center\">\n <button mat-icon-button id=\"close-upgrade-button\" (click)=\"CloseDialog()\">\n <mat-icon>cancel</mat-icon>\n </button>\n</div>\n\n<div fxLayout=\"row\" fxLayoutAlign=\"space-around center\" id=\"upgrade-content\">\n \n <div class=\"upgrade-container\" fxLayout=\"column\" fxLayoutAlign=\"center start\">\n <div class=\"x-large\">Wow!</div>\n <div class=\"x-large\">Fathym Premium is Free During Beta!</div>\n <div class=\"large\">Really...no credit card required.</div>\n </div>\n <div class=\"upgrade-container\">\n <img src=\"./assets/images/Happy_Lady.png\" id=\"upgrade-promo-image\" alt=\"Fathym Premium Free During Beta\">\n </div>\n</div>\n", styles: ["::ng-deep .mat-dialog-container{padding:5px!important}#upgrade-content{margin-top:-35px;padding:20px}.upgrade-container{padding:10px}#upgrade-promo-image{border-radius:5px;width:280px}.x-large{font-size:x-large;font-weight:700;margin:5px 0}.large{font-size:large;font-weight:700;margin:5px 0}\n"] }]
|
|
3717
3717
|
}], ctorParameters: function () { return [{ type: i1$4.MatDialogRef }]; } });
|
|
3718
3718
|
|
|
3719
3719
|
class ProjectInfoCardComponent {
|
|
@@ -3751,10 +3751,10 @@ class ProjectInfoCardComponent {
|
|
|
3751
3751
|
}
|
|
3752
3752
|
}
|
|
3753
3753
|
ProjectInfoCardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: ProjectInfoCardComponent, deps: [{ token: EaCService }, { token: i1$4.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
|
|
3754
|
-
ProjectInfoCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: ProjectInfoCardComponent, selector: "lcu-project-info-card", inputs: { Description: ["description", "Description"], Image: ["image", "Image"], IsEditable: ["is-editable", "IsEditable"], IsShareable: ["is-shareable", "IsShareable"], Name: ["name", "Name"], Subtext: ["subtext", "Subtext"], Version: ["version", "Version"] }, outputs: { LeftClickEvent: "left-click-event", RightClickEvent: "right-click-event" }, ngImport: i0, template: "<mat-card class=\"project-info-card\">\n <!-- SKELETON CONTENT -->\n <ng-container *ngIf=\"State?.Loading\">\n <div class=\"header-img-container\" fxLayout=\"row\">\n <skeleton-avatar\n class=\"round-project-img\"\n [effect]=\"SkeletonEffect\"\n [size]=\"75\"\n ></skeleton-avatar>\n </div>\n\n <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n <mat-card-title\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"project-card-name\"\n >\n Name of card\n </mat-card-title>\n\n <mat-card-subtitle\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"project-card-description\"\n >\n Description Text\n </mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-host\">\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"host-anchor\">\n https://www.fathym.com\n </div>\n </mat-card-subtitle>\n </mat-card-header>\n <mat-card-content class=\"card-content-container\">\n <div\n skeleton-block\n [effect]=\"SkeletonEffect\"\n class=\"stats-container\"\n ></div>\n\n <div\n class=\"promo-container-skeleton\"\n fxLayout=\"column\"\n fxLayoutAlign=\"center center\"\n >\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">\n Access exclusive tools & insights\n </div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"skeleton-item\"\n >emoji_events</mat-icon\n >\n\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">\n Upgrade to premium now\n </div>\n </div>\n </div>\n </mat-card-content>\n <mat-card-actions\n class=\"actions-container-skeleton\"\n fxLayoutAlign=\"center center\"\n >\n <div\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"skeleton-item\"\n action\n mat-button\n >\n <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\"\n >outbox</mat-icon\n >\n Unpack\n </div>\n </mat-card-actions>\n </ng-container>\n <!-- END SKELETON CONTENT -->\n\n <!-- ACTUAL CONTENT -->\n\n <ng-container *ngIf=\"!State?.Loading\">\n <div class=\"header-img-container\" fxLayout=\"row\">\n <div class=\"round-project-img\" fxLayoutAlign=\"center center\">\n <mat-icon *ngIf=\"!Image\" class=\"temp-icon\">flutter_dash</mat-icon>\n <img\n *ngIf=\"Image\"\n [src]=\"Image\"\n [alt]=\"Name\"\n style=\"width: 75px;
|
|
3754
|
+
ProjectInfoCardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.2", type: ProjectInfoCardComponent, selector: "lcu-project-info-card", inputs: { Description: ["description", "Description"], Image: ["image", "Image"], IsEditable: ["is-editable", "IsEditable"], IsShareable: ["is-shareable", "IsShareable"], Name: ["name", "Name"], Subtext: ["subtext", "Subtext"], Version: ["version", "Version"] }, outputs: { LeftClickEvent: "left-click-event", RightClickEvent: "right-click-event" }, ngImport: i0, template: "<mat-card class=\"project-info-card\">\n <!-- SKELETON CONTENT -->\n <ng-container *ngIf=\"State?.Loading\">\n <div class=\"header-img-container\" fxLayout=\"row\">\n <skeleton-avatar\n class=\"round-project-img\"\n [effect]=\"SkeletonEffect\"\n [size]=\"75\"\n ></skeleton-avatar>\n </div>\n\n <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n <mat-card-title\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"project-card-name\"\n >\n Name of card\n </mat-card-title>\n\n <mat-card-subtitle\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"project-card-description\"\n >\n Description Text\n </mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-host\">\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"host-anchor\">\n https://www.fathym.com\n </div>\n </mat-card-subtitle>\n </mat-card-header>\n <mat-card-content class=\"card-content-container\">\n <div\n skeleton-block\n [effect]=\"SkeletonEffect\"\n class=\"stats-container\"\n ></div>\n\n <div\n class=\"promo-container-skeleton\"\n fxLayout=\"column\"\n fxLayoutAlign=\"center center\"\n >\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">\n Access exclusive tools & insights\n </div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"skeleton-item\"\n >emoji_events</mat-icon\n >\n\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">\n Upgrade to premium now\n </div>\n </div>\n </div>\n </mat-card-content>\n <mat-card-actions\n class=\"actions-container-skeleton\"\n fxLayoutAlign=\"center center\"\n >\n <div\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"skeleton-item\"\n action\n mat-button\n >\n <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\"\n >outbox</mat-icon\n >\n Unpack\n </div>\n </mat-card-actions>\n </ng-container>\n <!-- END SKELETON CONTENT -->\n\n <!-- ACTUAL CONTENT -->\n\n <ng-container *ngIf=\"!State?.Loading\">\n <div class=\"header-img-container\" fxLayout=\"row\">\n <div class=\"round-project-img\" fxLayoutAlign=\"center center\">\n <mat-icon *ngIf=\"!Image\" class=\"temp-icon\">flutter_dash</mat-icon>\n <img\n *ngIf=\"Image\"\n [src]=\"Image\"\n [alt]=\"Name\"\n style=\"width: 75px; border-radius: 40px; \"\n />\n </div>\n </div>\n\n <div\n class=\"icon-btn-container\"\n fxLayout=\"row\"\n fxLayoutAlign=\"space-between center\"\n >\n <button\n *ngIf=\"IsEditable\"\n mat-icon-button\n id=\"left-icon\"\n (click)=\"LeftIconClicked()\"\n >\n <mat-icon>edit</mat-icon>\n </button>\n <button\n *ngIf=\"IsShareable\"\n mat-icon-button\n id=\"right-icon\"\n (click)=\"RightIconClicked()\"\n >\n <mat-icon>share</mat-icon>\n </button>\n </div>\n\n <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n <mat-card-title class=\"project-card-name\" *ngIf=\"Name\">\n {{ Name }}\n </mat-card-title>\n\n <mat-card-subtitle class=\"project-card-description\" *ngIf=\"Description\">\n {{ Description }}\n </mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-version\" *ngIf=\"Version\">\n {{ Version }}\n </mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-host\">\n <a\n class=\"host-anchor\"\n *ngIf=\"Subtext\"\n [href]=\"'https://' + Subtext\"\n target=\"_blank\"\n >\n {{ Subtext }}\n </a>\n </mat-card-subtitle>\n </mat-card-header>\n\n <mat-card-content class=\"card-content-container\">\n <div class=\"stats-container\">\n <ng-content select=\"[stats]\"></ng-content>\n </div>\n\n <!-- <div class=\"promo-container\"> -->\n <!-- <ng-content select=\"[promo]\"></ng-content> -->\n <div\n class=\"promo-container\"\n fxLayout=\"column\"\n fxLayoutAlign=\"center center\"\n (click)=\"UpgradeClicked()\"\n >\n <div>Access exclusive tools & insights</div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon class=\"gold-icon\">emoji_events</mat-icon>\n\n <div class=\"upgrade-text\" (click)=\"UpgradeClicked()\">\n Upgrade to premium now\n </div>\n </div>\n </div>\n <!-- </div> -->\n </mat-card-content>\n <mat-card-actions class=\"actions-container\">\n <ng-content select=\"[action]\"></ng-content>\n </mat-card-actions>\n </ng-container>\n</mat-card>\n", styles: [".project-info-card{margin:20px;padding:0}.round-project-img{background-color:#fff;width:75px;height:75px;border-radius:40px;text-align:center;margin-top:20px;border:2px solid white}.temp-icon{height:50px;width:50px;font-size:50px}.icon-btn-container{margin:5px}.project-card-header{text-align:center;margin-top:50px}.host-anchor{text-decoration:none;color:#4a918e}.header-img-container{background-color:#a4bab3;height:60px;border-radius:2px 2px 0 0;margin-top:-.5px!important;margin-right:-.5px;justify-content:center}.project-card-name{font-size:17px;font-weight:600}.card-content-container{margin-bottom:0!important}.stats-container{border-top:1px solid #b9dddd}.promo-container{cursor:pointer}.gold-icon{color:#d4af37}.upgrade-text{font-weight:700;margin-left:10px;cursor:pointer}mat-card-actions{margin-bottom:-1px!important;margin-left:0!important;margin-right:-.5px!important}.promo-container-skeleton{margin:5px}.actions-container{padding:0!important}.actions-container-skeleton{padding:0!important;border-top:1px solid #b9dddd}.info-card-btn{width:100%;border-radius:0 0 2px 2px;border-top:1px solid #b9dddd}.skeleton-item{margin:5px}\n"], components: [{ type: i4.MatCard, selector: "mat-card", exportAs: ["matCard"] }, { type: i4$4.SkeletonAvatarComponent, selector: "skeleton-avatar", inputs: ["size", "color", "showIcon", "iconColor", "borderRadius", "effect"] }, { type: i4.MatCardHeader, selector: "mat-card-header" }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i2$1.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"] }], directives: [{ type: i4$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5$1.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: i5$1.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.MatCardTitle, selector: "mat-card-title, [mat-card-title], [matCardTitle]" }, { type: i4$4.SkeletonTextDirective, selector: "[skeleton-text]", inputs: ["effect"] }, { type: i4.MatCardSubtitle, selector: "mat-card-subtitle, [mat-card-subtitle], [matCardSubtitle]" }, { type: i4.MatCardContent, selector: "mat-card-content, [mat-card-content], [matCardContent]" }, { type: i4.MatCardActions, selector: "mat-card-actions", inputs: ["align"], exportAs: ["matCardActions"] }] });
|
|
3755
3755
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: ProjectInfoCardComponent, decorators: [{
|
|
3756
3756
|
type: Component,
|
|
3757
|
-
args: [{ selector: 'lcu-project-info-card', template: "<mat-card class=\"project-info-card\">\n <!-- SKELETON CONTENT -->\n <ng-container *ngIf=\"State?.Loading\">\n <div class=\"header-img-container\" fxLayout=\"row\">\n <skeleton-avatar\n class=\"round-project-img\"\n [effect]=\"SkeletonEffect\"\n [size]=\"75\"\n ></skeleton-avatar>\n </div>\n\n <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n <mat-card-title\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"project-card-name\"\n >\n Name of card\n </mat-card-title>\n\n <mat-card-subtitle\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"project-card-description\"\n >\n Description Text\n </mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-host\">\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"host-anchor\">\n https://www.fathym.com\n </div>\n </mat-card-subtitle>\n </mat-card-header>\n <mat-card-content class=\"card-content-container\">\n <div\n skeleton-block\n [effect]=\"SkeletonEffect\"\n class=\"stats-container\"\n ></div>\n\n <div\n class=\"promo-container-skeleton\"\n fxLayout=\"column\"\n fxLayoutAlign=\"center center\"\n >\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">\n Access exclusive tools & insights\n </div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"skeleton-item\"\n >emoji_events</mat-icon\n >\n\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">\n Upgrade to premium now\n </div>\n </div>\n </div>\n </mat-card-content>\n <mat-card-actions\n class=\"actions-container-skeleton\"\n fxLayoutAlign=\"center center\"\n >\n <div\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"skeleton-item\"\n action\n mat-button\n >\n <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\"\n >outbox</mat-icon\n >\n Unpack\n </div>\n </mat-card-actions>\n </ng-container>\n <!-- END SKELETON CONTENT -->\n\n <!-- ACTUAL CONTENT -->\n\n <ng-container *ngIf=\"!State?.Loading\">\n <div class=\"header-img-container\" fxLayout=\"row\">\n <div class=\"round-project-img\" fxLayoutAlign=\"center center\">\n <mat-icon *ngIf=\"!Image\" class=\"temp-icon\">flutter_dash</mat-icon>\n <img\n *ngIf=\"Image\"\n [src]=\"Image\"\n [alt]=\"Name\"\n style=\"width: 75px;
|
|
3757
|
+
args: [{ selector: 'lcu-project-info-card', template: "<mat-card class=\"project-info-card\">\n <!-- SKELETON CONTENT -->\n <ng-container *ngIf=\"State?.Loading\">\n <div class=\"header-img-container\" fxLayout=\"row\">\n <skeleton-avatar\n class=\"round-project-img\"\n [effect]=\"SkeletonEffect\"\n [size]=\"75\"\n ></skeleton-avatar>\n </div>\n\n <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n <mat-card-title\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"project-card-name\"\n >\n Name of card\n </mat-card-title>\n\n <mat-card-subtitle\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"project-card-description\"\n >\n Description Text\n </mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-host\">\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"host-anchor\">\n https://www.fathym.com\n </div>\n </mat-card-subtitle>\n </mat-card-header>\n <mat-card-content class=\"card-content-container\">\n <div\n skeleton-block\n [effect]=\"SkeletonEffect\"\n class=\"stats-container\"\n ></div>\n\n <div\n class=\"promo-container-skeleton\"\n fxLayout=\"column\"\n fxLayoutAlign=\"center center\"\n >\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">\n Access exclusive tools & insights\n </div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"skeleton-item\"\n >emoji_events</mat-icon\n >\n\n <div skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\">\n Upgrade to premium now\n </div>\n </div>\n </div>\n </mat-card-content>\n <mat-card-actions\n class=\"actions-container-skeleton\"\n fxLayoutAlign=\"center center\"\n >\n <div\n skeleton-text\n [effect]=\"SkeletonEffect\"\n class=\"skeleton-item\"\n action\n mat-button\n >\n <mat-icon skeleton-text [effect]=\"SkeletonEffect\" class=\"skeleton-item\"\n >outbox</mat-icon\n >\n Unpack\n </div>\n </mat-card-actions>\n </ng-container>\n <!-- END SKELETON CONTENT -->\n\n <!-- ACTUAL CONTENT -->\n\n <ng-container *ngIf=\"!State?.Loading\">\n <div class=\"header-img-container\" fxLayout=\"row\">\n <div class=\"round-project-img\" fxLayoutAlign=\"center center\">\n <mat-icon *ngIf=\"!Image\" class=\"temp-icon\">flutter_dash</mat-icon>\n <img\n *ngIf=\"Image\"\n [src]=\"Image\"\n [alt]=\"Name\"\n style=\"width: 75px; border-radius: 40px; \"\n />\n </div>\n </div>\n\n <div\n class=\"icon-btn-container\"\n fxLayout=\"row\"\n fxLayoutAlign=\"space-between center\"\n >\n <button\n *ngIf=\"IsEditable\"\n mat-icon-button\n id=\"left-icon\"\n (click)=\"LeftIconClicked()\"\n >\n <mat-icon>edit</mat-icon>\n </button>\n <button\n *ngIf=\"IsShareable\"\n mat-icon-button\n id=\"right-icon\"\n (click)=\"RightIconClicked()\"\n >\n <mat-icon>share</mat-icon>\n </button>\n </div>\n\n <mat-card-header class=\"project-card-header\" fxLayoutAlign=\"center center\">\n <mat-card-title class=\"project-card-name\" *ngIf=\"Name\">\n {{ Name }}\n </mat-card-title>\n\n <mat-card-subtitle class=\"project-card-description\" *ngIf=\"Description\">\n {{ Description }}\n </mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-version\" *ngIf=\"Version\">\n {{ Version }}\n </mat-card-subtitle>\n\n <mat-card-subtitle class=\"project-card-host\">\n <a\n class=\"host-anchor\"\n *ngIf=\"Subtext\"\n [href]=\"'https://' + Subtext\"\n target=\"_blank\"\n >\n {{ Subtext }}\n </a>\n </mat-card-subtitle>\n </mat-card-header>\n\n <mat-card-content class=\"card-content-container\">\n <div class=\"stats-container\">\n <ng-content select=\"[stats]\"></ng-content>\n </div>\n\n <!-- <div class=\"promo-container\"> -->\n <!-- <ng-content select=\"[promo]\"></ng-content> -->\n <div\n class=\"promo-container\"\n fxLayout=\"column\"\n fxLayoutAlign=\"center center\"\n (click)=\"UpgradeClicked()\"\n >\n <div>Access exclusive tools & insights</div>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <mat-icon class=\"gold-icon\">emoji_events</mat-icon>\n\n <div class=\"upgrade-text\" (click)=\"UpgradeClicked()\">\n Upgrade to premium now\n </div>\n </div>\n </div>\n <!-- </div> -->\n </mat-card-content>\n <mat-card-actions class=\"actions-container\">\n <ng-content select=\"[action]\"></ng-content>\n </mat-card-actions>\n </ng-container>\n</mat-card>\n", styles: [".project-info-card{margin:20px;padding:0}.round-project-img{background-color:#fff;width:75px;height:75px;border-radius:40px;text-align:center;margin-top:20px;border:2px solid white}.temp-icon{height:50px;width:50px;font-size:50px}.icon-btn-container{margin:5px}.project-card-header{text-align:center;margin-top:50px}.host-anchor{text-decoration:none;color:#4a918e}.header-img-container{background-color:#a4bab3;height:60px;border-radius:2px 2px 0 0;margin-top:-.5px!important;margin-right:-.5px;justify-content:center}.project-card-name{font-size:17px;font-weight:600}.card-content-container{margin-bottom:0!important}.stats-container{border-top:1px solid #b9dddd}.promo-container{cursor:pointer}.gold-icon{color:#d4af37}.upgrade-text{font-weight:700;margin-left:10px;cursor:pointer}mat-card-actions{margin-bottom:-1px!important;margin-left:0!important;margin-right:-.5px!important}.promo-container-skeleton{margin:5px}.actions-container{padding:0!important}.actions-container-skeleton{padding:0!important;border-top:1px solid #b9dddd}.info-card-btn{width:100%;border-radius:0 0 2px 2px;border-top:1px solid #b9dddd}.skeleton-item{margin:5px}\n"] }]
|
|
3758
3758
|
}], ctorParameters: function () { return [{ type: EaCService }, { type: i1$4.MatDialog }]; }, propDecorators: { Description: [{
|
|
3759
3759
|
type: Input,
|
|
3760
3760
|
args: ['description']
|
|
@@ -5251,7 +5251,7 @@ class BuildPipelineFormComponent {
|
|
|
5251
5251
|
// console.log("response: ", response);
|
|
5252
5252
|
this.HostingDetails.Loading = false;
|
|
5253
5253
|
const hostOption = (_b = (_a = this.HostingDetails) === null || _a === void 0 ? void 0 : _a.HostingOptions) === null || _b === void 0 ? void 0 : _b.find((ho) => ho.Path === this.DevOpsAction.Path);
|
|
5254
|
-
this.BuildPipeline = hostOption.Lookup;
|
|
5254
|
+
this.BuildPipeline = hostOption === null || hostOption === void 0 ? void 0 : hostOption.Lookup;
|
|
5255
5255
|
// console.log("Build Pipeline HERE= ", this.BuildPipeline);
|
|
5256
5256
|
this.setupControlsForForm();
|
|
5257
5257
|
}, (err) => {
|