@lowcodeunit/applications-flow-common 1.34.60-social-ui-bug-fixes → 1.34.63-lets-get-social-ish
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lcu.api.mjs +5 -4
- package/esm2020/lib/applications-flow.module.mjs +42 -26
- package/esm2020/lib/controls/devops-source-control-form/devops-source-control-form.component.mjs +3 -3
- package/esm2020/lib/controls/dfs-modifiers-form/dfs-modifiers-form.component.mjs +277 -0
- package/esm2020/lib/controls/security-toggle/security-toggle.component.mjs +2 -2
- package/esm2020/lib/dialogs/build-pipeline-dialog/build-pipeline-dialog.component.mjs +10 -3
- package/esm2020/lib/dialogs/custom-domain-dialog/custom-domain-dialog.component.mjs +3 -3
- package/esm2020/lib/dialogs/dfs-modifiers-dialog/dfs-modifiers-dialog.component.mjs +109 -0
- package/esm2020/lib/dialogs/feed-header-dialog/feed-header-dialog.component.mjs +280 -0
- package/esm2020/lib/dialogs/source-control-dialog/source-control-dialog.component.mjs +10 -3
- package/esm2020/lib/elements/feed-card-sm/feed-card-sm.component.mjs +2 -2
- package/esm2020/lib/elements/feed-header/feed-header.component.mjs +131 -0
- package/esm2020/lib/elements/main-feed-card/main-feed-card.component.mjs +2 -2
- package/esm2020/lib/elements/project-info-card/project-info-card.component.mjs +2 -2
- package/esm2020/lib/elements/projects/controls/git-auth/git-auth.component.mjs +3 -2
- package/esm2020/lib/elements/projects/controls/tabs/dfs-modifiers/dfs-modifiers.component.mjs +3 -3
- package/esm2020/lib/elements/projects/controls/tabs/domains/domains.component.mjs +2 -2
- package/esm2020/lib/elements/skeleton-feed-card/skeleton-feed-card.component.mjs +2 -2
- package/esm2020/lib/models/user-feed.model.mjs +3 -1
- package/esm2020/lib/services/applications-flow.service.mjs +16 -6
- package/esm2020/lib/services/eac.service.mjs +28 -5
- package/esm2020/lib/services/project.service.mjs +50 -3
- package/esm2020/lib/state/applications-flow.state.mjs +1 -1
- package/fesm2015/lowcodeunit-applications-flow-common.mjs +2407 -1700
- package/fesm2015/lowcodeunit-applications-flow-common.mjs.map +1 -1
- package/fesm2020/lowcodeunit-applications-flow-common.mjs +2373 -1687
- package/fesm2020/lowcodeunit-applications-flow-common.mjs.map +1 -1
- package/lcu.api.d.ts +4 -3
- package/lib/applications-flow.module.d.ts +21 -18
- package/lib/controls/dfs-modifiers-form/dfs-modifiers-form.component.d.ts +62 -0
- package/lib/dialogs/build-pipeline-dialog/build-pipeline-dialog.component.d.ts +2 -0
- package/lib/dialogs/dfs-modifiers-dialog/dfs-modifiers-dialog.component.d.ts +41 -0
- package/lib/dialogs/feed-header-dialog/feed-header-dialog.component.d.ts +71 -0
- package/lib/dialogs/source-control-dialog/source-control-dialog.component.d.ts +1 -0
- package/lib/elements/{gh-control/gh-control.component.d.ts → feed-header/feed-header.component.d.ts} +9 -7
- package/lib/models/user-feed.model.d.ts +17 -0
- package/lib/services/applications-flow.service.d.ts +4 -1
- package/lib/services/eac.service.d.ts +7 -4
- package/lib/services/project.service.d.ts +5 -3
- package/lib/state/applications-flow.state.d.ts +2 -1
- package/package.json +1 -1
- package/esm2020/lib/elements/flow-tool/flow-tool.component.mjs +0 -75
- package/esm2020/lib/elements/gh-control/gh-control.component.mjs +0 -107
- package/lib/elements/flow-tool/flow-tool.component.d.ts +0 -28
|
@@ -55,7 +55,7 @@ export class DomainsComponent {
|
|
|
55
55
|
config() {
|
|
56
56
|
this.Config = new CardFormConfigModel({
|
|
57
57
|
Icon: 'head',
|
|
58
|
-
Title: '
|
|
58
|
+
Title: '',
|
|
59
59
|
Subtitle: 'In order to use a custom domain, create a CNAME dns record pointing desired subdomain to ' + this.HostDNSInstance + '.',
|
|
60
60
|
FormActions: {
|
|
61
61
|
Message: 'Changes will be applied to your next deployment',
|
|
@@ -137,4 +137,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
|
|
|
137
137
|
type: Input,
|
|
138
138
|
args: ['data']
|
|
139
139
|
}] } });
|
|
140
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"domains.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/common/src/lib/elements/projects/controls/tabs/domains/domains.component.ts","../../../../../../../../../projects/common/src/lib/elements/projects/controls/tabs/domains/domains.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FormsService } from './../../../../../services/forms.service';\nimport { CardFormConfigModel } from './../../../../../models/card-form-config.model';\nimport { Component, Input, OnInit } from '@angular/core';\nimport {\n  AbstractControl,\n  FormControl,\n  FormGroup,\n  Validators,\n} from '@angular/forms';\nimport { EaCService } from '../../../../../services/eac.service';\nimport { EaCHost, EaCProjectAsCode } from '@semanticjs/common';\n\n@Component({\n  selector: 'lcu-domains',\n  templateUrl: './domains.component.html',\n  styleUrls: ['./domains.component.scss'],\n})\nexport class DomainsComponent implements OnInit {\n  /**\n   * Card / Form Config\n   */\n  public Config: CardFormConfigModel;\n\n  /**\n   * FormGroup\n   */\n  public Form: FormGroup;\n\n  /**\n   * Form name\n   */\n  protected formName: string;\n\n  /**\n   * When form is dirty, ties into formsService.DisableForms\n   */\n  public IsDirty: boolean;\n\n  /**\n   * Access form control for root directory\n   */\n  public get Domain(): AbstractControl {\n    return this.Form.get('domain');\n  }\n\n  @Input('data')\n  public Data: {\n    Hosts: { [lookup: string]: EaCHost };\n    PrimaryHost: string;\n    Project: EaCProjectAsCode;\n    ProjectLookup: string;\n  };\n\n  public get Host(): EaCHost {\n    return this.Data?.Hosts[this.HostLookup];\n  }\n\n  public get HostLookup(): string {\n    // let hostKeys = Object.keys(this.Data?.Hosts || {});\n\n    // hostKeys = hostKeys.filter(hk => hk.indexOf('|') < 0);\n\n    // return hostKeys[0];\n    return this.PrimaryHost;\n  }\n\n  public get HostDNSInstance(): string {\n    return this.Host ? this.Host?.HostDNSInstance : null;\n  }\n\n  public get PrimaryHost(): string {\n    return this.Data.PrimaryHost;\n  }\n\n  public get Project(): EaCProjectAsCode {\n    return this.Data.Project;\n  }\n\n  public get ProjectLookup(): string {\n    return this.Data.ProjectLookup;\n  }\n\n  constructor(\n    protected formsService: FormsService,\n    protected eacSvc: EaCService,\n    \n  ) {}\n\n  public ngOnInit(): void {\n    this.formName = 'DomainForm';\n\n    this.setupForm();\n\n    this.config();\n  }\n\n  protected config(): void {\n    this.Config = new CardFormConfigModel({\n      Icon: 'head',\n      Title: 'Domains',\n      Subtitle:\n        'In order to use a custom domain, create a CNAME dns record pointing desired subdomain to ' + this.HostDNSInstance + '.',\n      FormActions: {\n        Message: 'Changes will be applied to your next deployment',\n        Actions: [\n          {\n            Label: 'Reset',\n            Color: 'warn',\n            ClickEvent: () => this.resetForm(),\n            // use arrow function, so 'this' refers to ProjectNameComponent\n            // if we used ClickeEvent: this.clearForm, then 'this' would refer to this current Actions object\n            Type: 'RESET',\n          },\n          {\n            Label: 'Save',\n            Color: 'accent',\n            ClickEvent: () => this.save(),\n            Type: 'SAVE',\n          },\n        ],\n      },\n    });\n  }\n\n  protected setupForm(): void {\n    this.Form = new FormGroup({\n      domain: new FormControl(this.HostLookup || '', {\n        validators: [Validators.required, Validators.minLength(3)],\n        updateOn: 'change',\n      }),\n    });\n\n    this.formsService.Form = { Id: this.formName, Form: this.Form };\n    this.onChange();\n  }\n\n  protected onChange(): void {\n    this.Form.valueChanges.subscribe((val: any) => {\n      if (this.formsService.ForRealThough(this.formName, this.Form)) {\n        this.IsDirty = true;\n        // disable all forms except the current form being edited\n        this.formsService.DisableForms(this.formName);\n      } else {\n        this.IsDirty = false;\n        // enable all forms\n        this.formsService.DisableForms(false);\n      }\n    });\n  }\n\n  /**\n   * Reset form controls back to previous values\n   */\n  protected resetForm(): void {\n    // enable all forms\n    // this.formsService.DisableForms(false);\n\n    this.formsService.ResetFormValues(this.formName);\n  }\n\n  /**\n   * Save changes\n   */\n  protected save(): void {\n    this.eacSvc.SaveProjectAsCode({\n      ProjectLookup: this.ProjectLookup,\n      Project: {\n        ...this.Project,\n        // Hosts: [...this.Project.Hosts, this.Domain.value],\n        Hosts: [this.Domain.value],\n      },\n    });\n    this.formsService.UpdateValuesReference({\n      Id: this.formName,\n      Form: this.Form,\n    });\n  }\n}\n","<form\n  fxLayout=\"row\"\n  fxLayout.lt-md=\"column\"\n  class=\"padding-top-3\"\n  [formGroup]=\"Form\">\n  <div>\n    <lcu-form-card \n    [config]=\"Config\"\n    [form]=\"Form\"\n    [is-dirty]=\"IsDirty\"\n    >\n      <div fxLayout=\"column\">\n        <div fxLayout=\"row\">\n          <div fxFlex fxLayout=\"row\">\n            <mat-form-field fxFlex appearance=\"fill\" class=\"margin-right-3\">\n              <mat-icon\n                matSuffix\n                [ngClass]=\"Domain.valid ? 'valid-control' : 'invalid-control'\"\n              >\n                {{ Domain.valid ? \"check_circle\" : \"error_outline\" }}\n              </mat-icon>\n              <input\n                type=\"text\"\n                matInput\n                [placeholder]=\"Domain.invalid || Domain.disabled ? '/' : ''\"\n                formControlName=\"domain\"\n              />\n\n              <mat-hint>\n                These domains are assigned to your deployments. Optionally, \n                a different Git branch or a redirection to another domain \n                can be configured for each one.\n              </mat-hint>\n\n              <mat-error *ngIf=\"Domain.hasError('required')\">\n                Domain is required\n              </mat-error>\n            </mat-form-field>\n\n            <button mat-icon-button [cdkCopyToClipboard]=\"HostDNSInstance\" matTooltip=\"Copy subdomain to clipboard\">\n              <mat-icon>content_copy</mat-icon>\n            </button>\n\n          </div>\n          <!-- <button mat-button color=\"accent\">Add</button> -->\n        </div>\n      </div>\n      <!-- <div class=\"card-divider\"></div> -->\n    </lcu-form-card>\n  </div>\n</form>\n"]}
|
|
140
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"domains.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/common/src/lib/elements/projects/controls/tabs/domains/domains.component.ts","../../../../../../../../../projects/common/src/lib/elements/projects/controls/tabs/domains/domains.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FormsService } from './../../../../../services/forms.service';\nimport { CardFormConfigModel } from './../../../../../models/card-form-config.model';\nimport { Component, Input, OnInit } from '@angular/core';\nimport {\n  AbstractControl,\n  FormControl,\n  FormGroup,\n  Validators,\n} from '@angular/forms';\nimport { EaCService } from '../../../../../services/eac.service';\nimport { EaCHost, EaCProjectAsCode } from '@semanticjs/common';\n\n@Component({\n  selector: 'lcu-domains',\n  templateUrl: './domains.component.html',\n  styleUrls: ['./domains.component.scss'],\n})\nexport class DomainsComponent implements OnInit {\n  /**\n   * Card / Form Config\n   */\n  public Config: CardFormConfigModel;\n\n  /**\n   * FormGroup\n   */\n  public Form: FormGroup;\n\n  /**\n   * Form name\n   */\n  protected formName: string;\n\n  /**\n   * When form is dirty, ties into formsService.DisableForms\n   */\n  public IsDirty: boolean;\n\n  /**\n   * Access form control for root directory\n   */\n  public get Domain(): AbstractControl {\n    return this.Form.get('domain');\n  }\n\n  @Input('data')\n  public Data: {\n    Hosts: { [lookup: string]: EaCHost };\n    PrimaryHost: string;\n    Project: EaCProjectAsCode;\n    ProjectLookup: string;\n  };\n\n  public get Host(): EaCHost {\n    return this.Data?.Hosts[this.HostLookup];\n  }\n\n  public get HostLookup(): string {\n    // let hostKeys = Object.keys(this.Data?.Hosts || {});\n\n    // hostKeys = hostKeys.filter(hk => hk.indexOf('|') < 0);\n\n    // return hostKeys[0];\n    return this.PrimaryHost;\n  }\n\n  public get HostDNSInstance(): string {\n    return this.Host ? this.Host?.HostDNSInstance : null;\n  }\n\n  public get PrimaryHost(): string {\n    return this.Data.PrimaryHost;\n  }\n\n  public get Project(): EaCProjectAsCode {\n    return this.Data.Project;\n  }\n\n  public get ProjectLookup(): string {\n    return this.Data.ProjectLookup;\n  }\n\n  constructor(\n    protected formsService: FormsService,\n    protected eacSvc: EaCService,\n    \n  ) {}\n\n  public ngOnInit(): void {\n    this.formName = 'DomainForm';\n\n    this.setupForm();\n\n    this.config();\n  }\n\n  protected config(): void {\n    this.Config = new CardFormConfigModel({\n      Icon: 'head',\n      Title: '',\n      Subtitle:\n        'In order to use a custom domain, create a CNAME dns record pointing desired subdomain to ' + this.HostDNSInstance + '.',\n      FormActions: {\n        Message: 'Changes will be applied to your next deployment',\n        Actions: [\n          {\n            Label: 'Reset',\n            Color: 'warn',\n            ClickEvent: () => this.resetForm(),\n            // use arrow function, so 'this' refers to ProjectNameComponent\n            // if we used ClickeEvent: this.clearForm, then 'this' would refer to this current Actions object\n            Type: 'RESET',\n          },\n          {\n            Label: 'Save',\n            Color: 'accent',\n            ClickEvent: () => this.save(),\n            Type: 'SAVE',\n          },\n        ],\n      },\n    });\n  }\n\n  protected setupForm(): void {\n    this.Form = new FormGroup({\n      domain: new FormControl(this.HostLookup || '', {\n        validators: [Validators.required, Validators.minLength(3)],\n        updateOn: 'change',\n      }),\n    });\n\n    this.formsService.Form = { Id: this.formName, Form: this.Form };\n    this.onChange();\n  }\n\n  protected onChange(): void {\n    this.Form.valueChanges.subscribe((val: any) => {\n      if (this.formsService.ForRealThough(this.formName, this.Form)) {\n        this.IsDirty = true;\n        // disable all forms except the current form being edited\n        this.formsService.DisableForms(this.formName);\n      } else {\n        this.IsDirty = false;\n        // enable all forms\n        this.formsService.DisableForms(false);\n      }\n    });\n  }\n\n  /**\n   * Reset form controls back to previous values\n   */\n  protected resetForm(): void {\n    // enable all forms\n    // this.formsService.DisableForms(false);\n\n    this.formsService.ResetFormValues(this.formName);\n  }\n\n  /**\n   * Save changes\n   */\n  protected save(): void {\n    this.eacSvc.SaveProjectAsCode({\n      ProjectLookup: this.ProjectLookup,\n      Project: {\n        ...this.Project,\n        // Hosts: [...this.Project.Hosts, this.Domain.value],\n        Hosts: [this.Domain.value],\n      },\n    });\n    this.formsService.UpdateValuesReference({\n      Id: this.formName,\n      Form: this.Form,\n    });\n  }\n}\n","<form\n  fxLayout=\"row\"\n  fxLayout.lt-md=\"column\"\n  class=\"padding-top-3\"\n  [formGroup]=\"Form\">\n  <div>\n    <lcu-form-card \n    [config]=\"Config\"\n    [form]=\"Form\"\n    [is-dirty]=\"IsDirty\"\n    >\n      <div fxLayout=\"column\">\n        <div fxLayout=\"row\">\n          <div fxFlex fxLayout=\"row\">\n            <mat-form-field fxFlex appearance=\"fill\" class=\"margin-right-3\">\n              <mat-icon\n                matSuffix\n                [ngClass]=\"Domain.valid ? 'valid-control' : 'invalid-control'\"\n              >\n                {{ Domain.valid ? \"check_circle\" : \"error_outline\" }}\n              </mat-icon>\n              <input\n                type=\"text\"\n                matInput\n                [placeholder]=\"Domain.invalid || Domain.disabled ? '/' : ''\"\n                formControlName=\"domain\"\n              />\n\n              <mat-hint>\n                These domains are assigned to your deployments. Optionally, \n                a different Git branch or a redirection to another domain \n                can be configured for each one.\n              </mat-hint>\n\n              <mat-error *ngIf=\"Domain.hasError('required')\">\n                Domain is required\n              </mat-error>\n            </mat-form-field>\n\n            <button mat-icon-button [cdkCopyToClipboard]=\"HostDNSInstance\" matTooltip=\"Copy subdomain to clipboard\">\n              <mat-icon>content_copy</mat-icon>\n            </button>\n\n          </div>\n          <!-- <button mat-button color=\"accent\">Add</button> -->\n        </div>\n      </div>\n      <!-- <div class=\"card-divider\"></div> -->\n    </lcu-form-card>\n  </div>\n</form>\n"]}
|