UNPKG

@vendasta/store

Version:

Components and data for Store

214 lines 24.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Input } from '@angular/core'; import { FormControl, FormGroup, Validators } from '@angular/forms'; export class DropDownFormSectionComponent { constructor() { this.startOpen = false; this.displayAutoTitle = false; this.titleText = ''; this.displayAutoDescription = true; this.descriptionText = ''; this.editingHint = ''; this.expandable = true; this.autoDescriptionText = ''; this.iconName = 'help_outline'; this.subscriptions = []; this.uniqueIndex = 1; this.autoTitleText = ''; } /** * @return {?} */ ngOnInit() { while (this.parentForm.controls.hasOwnProperty(this.titleText + this.uniqueIndex)) { this.uniqueIndex += 1; } this.parentForm.addControl(this.titleText + this.uniqueIndex, this.toFormGroup(this.fields)); /** @type {?} */ const form = (/** @type {?} */ (this.parentForm.controls[this.titleText + this.uniqueIndex])); for (const key in form.controls) { if (form.controls.hasOwnProperty(key)) { if (this.prepopulatedData != null && this.prepopulatedData.hasOwnProperty(key)) { form.controls[key].setValue(this.prepopulatedData[key]); } } } this.subscriptions.push(form.statusChanges.subscribe(change => { /** @type {?} */ let missingFields = false; for (const control in form.controls) { if (!form.controls[control].value || (form.controls[control].value.constructor === Array && !form.controls[control].value[0])) { this.iconName = 'help_outline'; missingFields = true; if (change === 'INVALID') { this.autoTitleText = '* Please fill out all required fields'; if (form.controls[control].dirty || form.controls[control].touched) { this.iconName = 'warning'; break; } } else { this.autoTitleText = 'Optional fields unanswered'; } } } if (!missingFields) { this.iconName = 'check_circle'; this.autoTitleText = 'Complete'; } })); if (this.displayAutoDescription) { this.subscriptions.push(form.valueChanges.subscribe(changes => { /** @type {?} */ let description = ''; for (const key in changes) { if (changes.hasOwnProperty(key) && changes[key] !== null && changes[key].length > 0) { if (changes[key][0].name) { for (const fileKey in changes[key]) { if (changes[key][fileKey] != null) { description += changes[key][fileKey].name; description += ', '; } } } else { description += changes[key]; description += ', '; } } } this.autoDescriptionText = description.substring(0, description.length - 2); })); } form.updateValueAndValidity({ onlySelf: false, emitEvent: true }); } /** * @param {?} formFields * @return {?} */ toFormGroup(formFields) { /** @type {?} */ const group = {}; formFields.forEach(field => { /** @type {?} */ let formControl; if (field.controlType === 'checkbox') { formControl = new FormControl(field.value); } else { formControl = field.required ? new FormControl(field.value, Validators.required) : new FormControl(field.value); } group[field.id] = formControl; this.subscriptions.push(formControl.valueChanges.subscribe(value => (field.value = value))); }); return new FormGroup(group); } /** * @return {?} */ ngOnDestroy() { this.subscriptions.forEach(subscription => subscription.unsubscribe()); } } DropDownFormSectionComponent.decorators = [ { type: Component, args: [{ selector: 'va-dropdown-form-section', template: ` <mat-card *ngIf="!expandable && !(expandable == undefined)" class="not-expandable-card"> <mat-icon class="not-expandable-icon valid"> check_circle</mat-icon> <mat-card-header *ngIf="!displayAutoTitle" class="not-expandable-header"> {{ titleText }} </mat-card-header> <mat-card-header *ngIf="displayAutoTitle" class="not-expandable-header valid"> <div class="title"> {{ titleText }}</div> <div *ngIf="titleText && autoTitleText">&nbsp;</div> <ng-container><i> Complete </i></ng-container> </mat-card-header> <mat-panel-description class="not-expandable-description"> {{ descriptionText }} </mat-panel-description> </mat-card> <mat-expansion-panel *ngIf="expandable || expandable == undefined" [expanded]="startOpen"> <mat-expansion-panel-header> <div class="dropdown-form-header"> <mat-icon [ngClass]="{invalid: iconName=='warning', valid: iconName=='check_circle', question: iconName=='help_outline'}"> {{ iconName }} </mat-icon> <mat-panel-title *ngIf="!displayAutoTitle"> {{ titleText }} </mat-panel-title> <mat-panel-title *ngIf="displayAutoTitle" [ngClass]="{valid: iconName=='check_circle', invalid: iconName=='warning'}"> <div class="title"> {{ titleText }}</div> <div *ngIf="titleText && autoTitleText"> &nbsp;</div> <ng-container><i> {{autoTitleText}} </i></ng-container> </mat-panel-title> <mat-panel-description *ngIf="displayAutoDescription" [ngClass]="{invalid: iconName=='warning'}"> {{ autoDescriptionText }} </mat-panel-description> <mat-panel-description *ngIf="!displayAutoDescription" [ngClass]="{invalid: iconName=='warning'}"> <i> {{descriptionText}} </i> </mat-panel-description> </div> </mat-expansion-panel-header> <div class="expansion-panel-body"> <va-field *ngFor="let field of fields" [field]="field" [form]="parentForm.controls[titleText + uniqueIndex]"></va-field> <p *ngIf="editingHint != ''" class="editing-hint"><i>{{ editingHint }}</i></p> </div> </mat-expansion-panel> `, styles: [":host-context(va-dropdown-form-section){font-size:14px}:host-context(va-dropdown-form-section) .expansion-panel-body{margin-top:-10px;display:block;width:60%}.mat-expanded,.mat-expansion-panel{transition:margin .4s}.dropdown-form-header{width:100%;display:flex}mat-panel-description{align-self:center;flex:inherit;display:initial;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}mat-panel-description.invalid{color:#c62828}mat-icon{margin-right:7px;-ms-grid-row-align:center;align-self:center}mat-icon.valid{color:#4caf50}mat-icon.invalid{color:#c62828}mat-icon.question{color:#9e9e9e}mat-panel-title{-ms-grid-row-align:center;align-self:center;flex:none;margin-right:20px}mat-panel-title.valid{color:#4caf50}mat-panel-title.invalid{color:#c62828}.editing-hint{color:#9e9e9e}.title{color:#212121}.not-expandable-card{background:#fff;cursor:default;font-size:15px;display:flex;height:48px;align-items:center;box-shadow:0 3px 1px -2px rgba(0,0,0,.2),0 2px 2px 0 rgba(0,0,0,.14),0 1px 5px 0 rgba(0,0,0,.12)}.not-expandable-card .not-expandable-icon{margin-left:24px}.not-expandable-card .not-expandable-header{display:flex}.not-expandable-card .not-expandable-description{margin-left:22px}.not-expandable-card .valid{color:#4caf50}"] }] } ]; /** @nocollapse */ DropDownFormSectionComponent.ctorParameters = () => []; DropDownFormSectionComponent.propDecorators = { prepopulatedData: [{ type: Input }], startOpen: [{ type: Input }], parentForm: [{ type: Input }], displayAutoTitle: [{ type: Input }], titleText: [{ type: Input }], displayAutoDescription: [{ type: Input }], descriptionText: [{ type: Input }], fields: [{ type: Input }], editingHint: [{ type: Input }], expandable: [{ type: Input }] }; if (false) { /** @type {?} */ DropDownFormSectionComponent.prototype.prepopulatedData; /** @type {?} */ DropDownFormSectionComponent.prototype.startOpen; /** @type {?} */ DropDownFormSectionComponent.prototype.parentForm; /** @type {?} */ DropDownFormSectionComponent.prototype.displayAutoTitle; /** @type {?} */ DropDownFormSectionComponent.prototype.titleText; /** @type {?} */ DropDownFormSectionComponent.prototype.displayAutoDescription; /** @type {?} */ DropDownFormSectionComponent.prototype.descriptionText; /** @type {?} */ DropDownFormSectionComponent.prototype.fields; /** @type {?} */ DropDownFormSectionComponent.prototype.editingHint; /** @type {?} */ DropDownFormSectionComponent.prototype.expandable; /** @type {?} */ DropDownFormSectionComponent.prototype.autoDescriptionText; /** @type {?} */ DropDownFormSectionComponent.prototype.iconName; /** @type {?} */ DropDownFormSectionComponent.prototype.subscriptions; /** @type {?} */ DropDownFormSectionComponent.prototype.uniqueIndex; /** @type {?} */ DropDownFormSectionComponent.prototype.autoTitleText; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-form-section.component.js","sourceRoot":"ng://@vendasta/store/","sources":["lib/order-form/dropdown-form-section/dropdown-form-section.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy, OnInit } from '@angular/core';\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\nimport { FieldBase } from '../fields/field-base';\nimport { Subscription } from 'rxjs';\n\n@Component({\n  selector: 'va-dropdown-form-section',\n  template: `\n    <mat-card *ngIf=\"!expandable && !(expandable == undefined)\" class=\"not-expandable-card\">\n      <mat-icon class=\"not-expandable-icon valid\"> check_circle</mat-icon>\n      <mat-card-header *ngIf=\"!displayAutoTitle\" class=\"not-expandable-header\">\n        {{ titleText }}\n      </mat-card-header>\n      <mat-card-header *ngIf=\"displayAutoTitle\" class=\"not-expandable-header valid\">\n        <div class=\"title\"> {{ titleText }}</div>\n        <div *ngIf=\"titleText && autoTitleText\">&nbsp;</div>\n        <ng-container><i> Complete </i></ng-container>\n      </mat-card-header>\n      <mat-panel-description class=\"not-expandable-description\">\n        {{ descriptionText }}\n      </mat-panel-description>\n    </mat-card>\n    <mat-expansion-panel *ngIf=\"expandable || expandable == undefined\" [expanded]=\"startOpen\">\n      <mat-expansion-panel-header>\n        <div class=\"dropdown-form-header\">\n          <mat-icon\n            [ngClass]=\"{invalid: iconName=='warning', valid: iconName=='check_circle', question: iconName=='help_outline'}\">\n            {{ iconName }}\n          </mat-icon>\n          <mat-panel-title *ngIf=\"!displayAutoTitle\">\n            {{ titleText }}\n          </mat-panel-title>\n          <mat-panel-title *ngIf=\"displayAutoTitle\"\n                           [ngClass]=\"{valid: iconName=='check_circle', invalid: iconName=='warning'}\">\n            <div class=\"title\"> {{ titleText }}</div>\n            <div *ngIf=\"titleText && autoTitleText\"> &nbsp;</div>\n            <ng-container><i> {{autoTitleText}} </i></ng-container>\n          </mat-panel-title>\n          <mat-panel-description *ngIf=\"displayAutoDescription\" [ngClass]=\"{invalid: iconName=='warning'}\">\n            {{ autoDescriptionText }}\n          </mat-panel-description>\n          <mat-panel-description *ngIf=\"!displayAutoDescription\" [ngClass]=\"{invalid: iconName=='warning'}\">\n            <i> {{descriptionText}} </i>\n          </mat-panel-description>\n        </div>\n      </mat-expansion-panel-header>\n      <div class=\"expansion-panel-body\">\n        <va-field *ngFor=\"let field of fields\" [field]=\"field\"\n                  [form]=\"parentForm.controls[titleText + uniqueIndex]\"></va-field>\n        <p *ngIf=\"editingHint != ''\" class=\"editing-hint\"><i>{{ editingHint }}</i></p>\n      </div>\n    </mat-expansion-panel>\n  `,\n  styleUrls: ['./dropdown-form-section.component.scss']\n})\nexport class DropDownFormSectionComponent implements OnInit, OnDestroy {\n  @Input() prepopulatedData: {};\n  @Input() startOpen = false;\n  @Input() parentForm: FormGroup;\n  @Input() displayAutoTitle = false;\n  @Input() titleText = '';\n  @Input() displayAutoDescription = true;\n  @Input() descriptionText = '';\n  @Input() fields: FieldBase<any>[];\n  @Input() editingHint = '';\n  @Input() expandable = true;\n  autoDescriptionText = '';\n  iconName = 'help_outline';\n  subscriptions: Subscription[] = [];\n  uniqueIndex = 1;\n  autoTitleText = '';\n\n  constructor() {}\n\n  ngOnInit(): void {\n    while (this.parentForm.controls.hasOwnProperty(this.titleText + this.uniqueIndex)) {\n      this.uniqueIndex += 1;\n    }\n    this.parentForm.addControl(this.titleText + this.uniqueIndex, this.toFormGroup(this.fields));\n    const form = this.parentForm.controls[this.titleText + this.uniqueIndex] as FormGroup;\n\n    for (const key in form.controls) {\n      if (form.controls.hasOwnProperty(key)) {\n        if (this.prepopulatedData != null && this.prepopulatedData.hasOwnProperty(key)) {\n          form.controls[key].setValue(this.prepopulatedData[key]);\n        }\n      }\n    }\n    this.subscriptions.push(\n      form.statusChanges.subscribe(change => {\n        let missingFields = false;\n        for (const control in form.controls) {\n          if (!form.controls[control].value || (form.controls[control].value.constructor === Array && !form.controls[control].value[0])) {\n            this.iconName = 'help_outline';\n            missingFields = true;\n            if (change === 'INVALID') {\n              this.autoTitleText = '* Please fill out all required fields';\n              if (form.controls[control].dirty || form.controls[control].touched) {\n                this.iconName = 'warning';\n                break;\n              }\n            } else {\n              this.autoTitleText = 'Optional fields unanswered';\n            }\n          }\n        }\n        if (!missingFields) {\n          this.iconName = 'check_circle';\n          this.autoTitleText = 'Complete';\n        }\n      })\n    );\n\n    if (this.displayAutoDescription) {\n      this.subscriptions.push(\n        form.valueChanges.subscribe(changes => {\n          let description = '';\n          for (const key in changes) {\n            if (changes.hasOwnProperty(key) && changes[key] !== null && changes[key].length > 0) {\n              if (changes[key][0].name) {\n                for (const fileKey in changes[key]) {\n                  if (changes[key][fileKey] != null) {\n                    description += changes[key][fileKey].name;\n                    description += ', ';\n                  }\n                }\n              } else {\n                description += changes[key];\n                description += ', ';\n              }\n            }\n          }\n          this.autoDescriptionText = description.substring(0, description.length - 2);\n        })\n      );\n    }\n    form.updateValueAndValidity({ onlySelf: false, emitEvent: true });\n  }\n\n  toFormGroup(formFields: FieldBase<any>[]): FormGroup {\n    const group: any = {};\n    formFields.forEach(field => {\n      let formControl: FormControl;\n      if (field.controlType === 'checkbox') {\n        formControl = new FormControl(field.value);\n      } else {\n        formControl = field.required ? new FormControl(field.value, Validators.required) : new FormControl(field.value);\n      }\n      group[field.id] = formControl;\n      this.subscriptions.push(formControl.valueChanges.subscribe(value => (field.value = value)));\n    });\n    return new FormGroup(group);\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach(subscription => subscription.unsubscribe());\n  }\n}\n"]}