@vendasta/store
Version:
Components and data for Store
214 lines • 24.6 kB
JavaScript
/**
* @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"> </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"> </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"]}