@vendasta/store
Version:
Components and data for Store
77 lines • 41.2 kB
JavaScript
import { Input, Component, ViewChild } from '@angular/core';
import { FormGroup } from '@angular/forms';
import * as i0 from "@angular/core";
import * as i1 from "@vendasta/galaxy/form-field";
import * as i2 from "@angular/material/select";
import * as i3 from "@angular/material/core";
import * as i4 from "@vendasta/forms";
import * as i5 from "@angular/material/checkbox";
import * as i6 from "@vendasta/galaxy/uploader";
import * as i7 from "@angular/common";
import * as i8 from "@angular/forms";
import * as i9 from "@angular/material/input";
import * as i10 from "@angular/cdk/text-field";
import * as i11 from "@ngx-translate/core";
export class FieldComponent {
get isValid() {
return this.form.controls[this.field.id].valid || this.form.controls[this.field.id].pristine;
}
showCheckboxError(field) {
return (this.form.controls[field].errors && this.form.controls[field].errors.required && this.form.controls[field].touched);
}
getValue() {
return this.form.controls[this.field.id].value;
}
dropdownAnswer() {
const answer = this.getValue();
return ((this.field.options || []).find((option) => option.value === answer) || { label: answer }).label;
}
multidropdownAnswer() {
const answer = this.getValue();
return (answer || [])
.map((a) => ((this.field.options || []).find((option) => option.value === a) || { name: a }).name)
.join(', ');
}
checkboxAnswer() {
const answer = this.getValue();
return answer ? 'Yes' : 'No';
}
fileUploadAnswer() {
const answer = this.getValue();
return answer.map((a) => (a.name ? a.name : a.url ? a.url : a)).join(', ');
}
// Load form values into galaxy uploader to get any cached values
uploadedFiles() {
return this.form.controls[this.field.id].value;
}
// Handle deleting file from both galaxy uploader component, and order-form form values
deleteFile(event) {
const filterOutDeletedFile = this.form.controls[this.field.id].value.filter((file) => file.name !== event.name && file.url !== event.url);
this.form.controls[this.field.id].setValue(filterOutDeletedFile);
// Tell galaxy uploader about delete so it can handle maxFiles properly
this.glxyUploader.deleteFile(event);
}
// Manually update order-form form with events from galaxy file uploader
onUpload(event) {
const uploadedFiles = this.form.controls[this.field.id].value;
uploadedFiles.push({
name: event.name,
url: event.url,
});
this.form.controls[this.field.id].setValue(uploadedFiles);
}
}
FieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: FieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
FieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.2", type: FieldComponent, selector: "app-order-field", inputs: { field: "field", form: "form" }, viewQueries: [{ propertyName: "glxyUploader", first: true, predicate: ["glxyUploader"], descendants: true }], ngImport: i0, template: "<ng-container [ngSwitch]=\"field.controlType\" [formGroup]=\"form\">\n <ng-container *ngIf=\"!field.hidden\">\n <div class=\"office-text\" *ngIf=\"field.forOfficeUseOnly\">\n * {{ 'FRONTEND.STORE.ORDER_FORM.HIDDEN_FROM_END_USERS' | translate }}:\n </div>\n <div class=\"office-text\" *ngIf=\"field.officeEditableOnly\">\n * {{ 'FRONTEND.STORE.ORDER_FORM.OFFICE_EDITABLE_ONLY' | translate }}:\n </div>\n\n <ng-container *ngSwitchCase=\"'dropdown'\">\n <ng-container *ngIf=\"!field.allowMultiples\">\n <div class=\"display\">\n <glxy-form-field>\n <glxy-label>\n {{ field.label | translate }}{{ field.required ? '*' : '' }}\n </glxy-label>\n <mat-select matInput [formControlName]=\"field.id\" [id]=\"field.id\">\n <mat-option\n *ngFor=\"let option of field.options\"\n [value]=\"option.value\"\n >\n {{ option.label }}\n </mat-option>\n </mat-select>\n <glxy-hint position=\"below\" *ngIf=\"field.description\">\n {{ field.description }}\n </glxy-hint>\n </glxy-form-field>\n </div>\n <div class=\"print\">\n <div class=\"label\">{{ field.label | translate }}:</div>\n <div class=\"answer\">{{ dropdownAnswer() }}</div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"field.allowMultiples\">\n <div class=\"display\">\n <glxy-input-tags\n [id]=\"field.id\"\n [formControlName]=\"field.id\"\n label=\"{{ field.label | translate }}{{\n field.required ? ' *' : ''\n }}\"\n [hint]=\"field.description\"\n [required]=\"field.required\"\n [options]=\"field.options\"\n [allowDuplicates]=\"field.allowDuplicates\"\n [maxFields]=\"field.maxChoices\"\n ></glxy-input-tags>\n </div>\n <div class=\"print\">\n <div class=\"label\">{{ field.label | translate }}:</div>\n <div class=\"answer\">{{ multidropdownAnswer() }}</div>\n </div>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'textbox'\">\n <div class=\"display\">\n <glxy-form-field\n [prefixText]=\"field.prefix\"\n [suffixText]=\"field.suffix\"\n >\n <glxy-label>\n {{ field.label | translate }}{{ field.required ? ' *' : '' }}\n </glxy-label>\n <input\n matInput\n [type]=\"field.textboxType\"\n [id]=\"field.id\"\n [formControlName]=\"field.id\"\n [pattern]=\"field.regexValidator || ''\"\n [readonly]=\"field.displayOnly\"\n [ngClass]=\"{ 'display-only': field.displayOnly }\"\n />\n <glxy-hint position=\"below\" *ngIf=\"field.description\">\n {{ field.description }}\n </glxy-hint>\n <glxy-error *ngIf=\"form.controls[field.id].hasError('pattern')\">\n {{ field.regexErrorMessage }}\n </glxy-error>\n </glxy-form-field>\n </div>\n <div class=\"print\">\n <div class=\"label\">{{ field.label | translate }}:</div>\n <div class=\"answer\">{{ getValue() }}</div>\n </div>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'checkbox'\">\n <div class=\"display\">\n <glxy-form-field>\n <mat-checkbox\n [formControlName]=\"field.id\"\n [id]=\"field.id\"\n ngControlDefault\n >\n {{ field.label | translate }}{{ field.required ? ' *' : '' }}\n <extended *ngIf=\"field.description\">\n {{ field.description }}\n </extended>\n </mat-checkbox>\n <glxy-error *ngIf=\"showCheckboxError(field.id)\" class=\"checkboxError\">\n {{ 'FRONTEND.STORE.REQUIRED' | translate }}\n </glxy-error>\n </glxy-form-field>\n </div>\n <div class=\"print\">\n <div class=\"label\">{{ field.label | translate }}:</div>\n <div class=\"answer\">{{ checkboxAnswer() }}</div>\n </div>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'textarea'\">\n <span class=\"display\">\n <glxy-form-field>\n <glxy-label>\n {{ field.label | translate }}{{ field.required ? ' *' : '' }}\n </glxy-label>\n <textarea\n matInput\n [formControlName]=\"field.id\"\n [id]=\"field.id\"\n cdkTextareaAutosize\n ></textarea>\n <glxy-hint position=\"below\" *ngIf=\"field.description\">\n {{ field.description }}\n </glxy-hint>\n </glxy-form-field>\n </span>\n <div class=\"print\">\n <div class=\"label\">{{ field.label | translate }}:</div>\n <div class=\"answer\">{{ getValue() }}</div>\n </div>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'file'\">\n <span class=\"display\">\n <glxy-form-field>\n <glxy-label>\n {{ field.label | translate }}{{ field.required ? ' *' : '' }}\n </glxy-label>\n <glxy-hint position=\"below\" *ngIf=\"field.description\">\n {{ field.description }}\n </glxy-hint>\n <ng-container *ngIf=\"!field.disabled\">\n <glxy-uploader\n #glxyUploader\n [uploadUrl]=\"field.uploadUrl\"\n [maxFiles]=\"field.numFiles\"\n (fileUploaded)=\"onUpload($event)\"\n ></glxy-uploader>\n <glxy-uploader-list\n [files]=\"uploadedFiles() || []\"\n (fileDeleted)=\"deleteFile($event)\"\n ></glxy-uploader-list>\n </ng-container>\n <ng-container *ngIf=\"field.disabled\">\n <ng-container *ngIf=\"!uploadedFiles().length\">—</ng-container>\n <ng-container *ngIf=\"uploadedFiles().length\">\n <ul class=\"file-static-list\">\n <li *ngFor=\"let file of uploadedFiles()\">\n <a href=\"{{ file.url }}\" target=\"_blank\">{{ file.name }}</a>\n </li>\n </ul>\n </ng-container>\n </ng-container>\n </glxy-form-field>\n </span>\n <div class=\"print\">\n <div class=\"label\">{{ field.label | translate }}:</div>\n <div class=\"answer\">{{ fileUploadAnswer() }}</div>\n </div>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'vbcuser'\">\n <div class=\"display\">\n <glxy-form-field>\n <glxy-label>\n {{ field.label | translate }}{{ field.required ? ' *' : '' }}\n </glxy-label>\n <mat-select matInput [formControlName]=\"field.id\" [id]=\"field.id\">\n <mat-option\n *ngFor=\"let option of field.options\"\n [value]=\"option.value\"\n [disabled]=\"option.disabled\"\n >\n {{ option.label | translate }}\n </mat-option>\n </mat-select>\n <glxy-hint position=\"below\" *ngIf=\"field.description\">\n {{ field.description }}\n </glxy-hint>\n </glxy-form-field>\n </div>\n <div class=\"print\">\n <div class=\"label\">{{ field.label | translate }}:</div>\n <div class=\"answer\">{{ dropdownAnswer() }}</div>\n </div>\n </ng-container>\n </ng-container>\n</ng-container>\n", styles: [".office-text{font-size:13px;color:#9e9e9e;color:var(--tertiary-text-color, #9e9e9e);margin-bottom:-24px}.office-text+.office-text{margin-top:24px}@media print{.office-text{margin:0}}.display-only{color:rgba(0,0,0,.38)}.file-static-list{margin:0;padding:0;list-style:none}@media print{.display{display:none}}.print{display:none}@media print{.print{display:flex;outline:1px solid;margin-top:1px;margin-left:1px;page-break-inside:avoid}.print .label{flex-basis:30%;padding:8px;font-weight:500;border-right:1px solid black}.print .answer{flex-basis:70%;padding:8px}}\n"], components: [{ type: i1.FormFieldComponent, selector: "glxy-form-field", inputs: ["label", "disabled", "required", "clearable", "maxWidth", "minWidth", "hasMargins", "smallMargin", "hideInputDecoration", "showLabel", "horizontalLayout", "prefixIcon", "suffixIcon", "prefixText", "suffixText"] }, { type: i2.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { type: i3.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { type: i4.GlxyInputTagsComponent, selector: "glxy-input-tags", inputs: ["options", "hint", "label", "required", "maxFields", "allowDuplicates", "allowCustomTags", "customTagLength", "loading", "disabled", "appearance"] }, { type: i5.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex", "aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { type: i6.GalaxyUploaderComponent, selector: "glxy-uploader", inputs: ["maxFiles", "maxFileSize", "accept", "uploadUrl", "numParallel", "autoUpload", "files", "hintText", "buttonText", "descriptionText"], outputs: ["fileUploadErrored", "fileUploaded", "filesChanged"] }, { type: i6.GalaxyUploaderListComponent, selector: "glxy-uploader-list", inputs: ["files"], outputs: ["fileDeleted"] }], directives: [{ type: i7.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i8.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i8.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i1.LabelDirective, selector: "glxy-label, [glxyLabel]" }, { type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i8.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.HintDirective, selector: "glxy-hint, [glxyHint]", inputs: ["align"] }, { type: i8.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { type: i9.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i8.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i1.ErrorDirective, selector: "glxy-error, [glxyError]" }, { type: i1.ExtendedDirective, selector: "extended, [glxyExtended]" }, { type: i10.CdkTextareaAutosize, selector: "textarea[cdkTextareaAutosize]", inputs: ["cdkAutosizeMinRows", "cdkAutosizeMaxRows", "cdkTextareaAutosize", "placeholder"], exportAs: ["cdkTextareaAutosize"] }], pipes: { "translate": i11.TranslatePipe } });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: FieldComponent, decorators: [{
type: Component,
args: [{ selector: 'app-order-field', template: "<ng-container [ngSwitch]=\"field.controlType\" [formGroup]=\"form\">\n <ng-container *ngIf=\"!field.hidden\">\n <div class=\"office-text\" *ngIf=\"field.forOfficeUseOnly\">\n * {{ 'FRONTEND.STORE.ORDER_FORM.HIDDEN_FROM_END_USERS' | translate }}:\n </div>\n <div class=\"office-text\" *ngIf=\"field.officeEditableOnly\">\n * {{ 'FRONTEND.STORE.ORDER_FORM.OFFICE_EDITABLE_ONLY' | translate }}:\n </div>\n\n <ng-container *ngSwitchCase=\"'dropdown'\">\n <ng-container *ngIf=\"!field.allowMultiples\">\n <div class=\"display\">\n <glxy-form-field>\n <glxy-label>\n {{ field.label | translate }}{{ field.required ? '*' : '' }}\n </glxy-label>\n <mat-select matInput [formControlName]=\"field.id\" [id]=\"field.id\">\n <mat-option\n *ngFor=\"let option of field.options\"\n [value]=\"option.value\"\n >\n {{ option.label }}\n </mat-option>\n </mat-select>\n <glxy-hint position=\"below\" *ngIf=\"field.description\">\n {{ field.description }}\n </glxy-hint>\n </glxy-form-field>\n </div>\n <div class=\"print\">\n <div class=\"label\">{{ field.label | translate }}:</div>\n <div class=\"answer\">{{ dropdownAnswer() }}</div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"field.allowMultiples\">\n <div class=\"display\">\n <glxy-input-tags\n [id]=\"field.id\"\n [formControlName]=\"field.id\"\n label=\"{{ field.label | translate }}{{\n field.required ? ' *' : ''\n }}\"\n [hint]=\"field.description\"\n [required]=\"field.required\"\n [options]=\"field.options\"\n [allowDuplicates]=\"field.allowDuplicates\"\n [maxFields]=\"field.maxChoices\"\n ></glxy-input-tags>\n </div>\n <div class=\"print\">\n <div class=\"label\">{{ field.label | translate }}:</div>\n <div class=\"answer\">{{ multidropdownAnswer() }}</div>\n </div>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'textbox'\">\n <div class=\"display\">\n <glxy-form-field\n [prefixText]=\"field.prefix\"\n [suffixText]=\"field.suffix\"\n >\n <glxy-label>\n {{ field.label | translate }}{{ field.required ? ' *' : '' }}\n </glxy-label>\n <input\n matInput\n [type]=\"field.textboxType\"\n [id]=\"field.id\"\n [formControlName]=\"field.id\"\n [pattern]=\"field.regexValidator || ''\"\n [readonly]=\"field.displayOnly\"\n [ngClass]=\"{ 'display-only': field.displayOnly }\"\n />\n <glxy-hint position=\"below\" *ngIf=\"field.description\">\n {{ field.description }}\n </glxy-hint>\n <glxy-error *ngIf=\"form.controls[field.id].hasError('pattern')\">\n {{ field.regexErrorMessage }}\n </glxy-error>\n </glxy-form-field>\n </div>\n <div class=\"print\">\n <div class=\"label\">{{ field.label | translate }}:</div>\n <div class=\"answer\">{{ getValue() }}</div>\n </div>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'checkbox'\">\n <div class=\"display\">\n <glxy-form-field>\n <mat-checkbox\n [formControlName]=\"field.id\"\n [id]=\"field.id\"\n ngControlDefault\n >\n {{ field.label | translate }}{{ field.required ? ' *' : '' }}\n <extended *ngIf=\"field.description\">\n {{ field.description }}\n </extended>\n </mat-checkbox>\n <glxy-error *ngIf=\"showCheckboxError(field.id)\" class=\"checkboxError\">\n {{ 'FRONTEND.STORE.REQUIRED' | translate }}\n </glxy-error>\n </glxy-form-field>\n </div>\n <div class=\"print\">\n <div class=\"label\">{{ field.label | translate }}:</div>\n <div class=\"answer\">{{ checkboxAnswer() }}</div>\n </div>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'textarea'\">\n <span class=\"display\">\n <glxy-form-field>\n <glxy-label>\n {{ field.label | translate }}{{ field.required ? ' *' : '' }}\n </glxy-label>\n <textarea\n matInput\n [formControlName]=\"field.id\"\n [id]=\"field.id\"\n cdkTextareaAutosize\n ></textarea>\n <glxy-hint position=\"below\" *ngIf=\"field.description\">\n {{ field.description }}\n </glxy-hint>\n </glxy-form-field>\n </span>\n <div class=\"print\">\n <div class=\"label\">{{ field.label | translate }}:</div>\n <div class=\"answer\">{{ getValue() }}</div>\n </div>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'file'\">\n <span class=\"display\">\n <glxy-form-field>\n <glxy-label>\n {{ field.label | translate }}{{ field.required ? ' *' : '' }}\n </glxy-label>\n <glxy-hint position=\"below\" *ngIf=\"field.description\">\n {{ field.description }}\n </glxy-hint>\n <ng-container *ngIf=\"!field.disabled\">\n <glxy-uploader\n #glxyUploader\n [uploadUrl]=\"field.uploadUrl\"\n [maxFiles]=\"field.numFiles\"\n (fileUploaded)=\"onUpload($event)\"\n ></glxy-uploader>\n <glxy-uploader-list\n [files]=\"uploadedFiles() || []\"\n (fileDeleted)=\"deleteFile($event)\"\n ></glxy-uploader-list>\n </ng-container>\n <ng-container *ngIf=\"field.disabled\">\n <ng-container *ngIf=\"!uploadedFiles().length\">—</ng-container>\n <ng-container *ngIf=\"uploadedFiles().length\">\n <ul class=\"file-static-list\">\n <li *ngFor=\"let file of uploadedFiles()\">\n <a href=\"{{ file.url }}\" target=\"_blank\">{{ file.name }}</a>\n </li>\n </ul>\n </ng-container>\n </ng-container>\n </glxy-form-field>\n </span>\n <div class=\"print\">\n <div class=\"label\">{{ field.label | translate }}:</div>\n <div class=\"answer\">{{ fileUploadAnswer() }}</div>\n </div>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'vbcuser'\">\n <div class=\"display\">\n <glxy-form-field>\n <glxy-label>\n {{ field.label | translate }}{{ field.required ? ' *' : '' }}\n </glxy-label>\n <mat-select matInput [formControlName]=\"field.id\" [id]=\"field.id\">\n <mat-option\n *ngFor=\"let option of field.options\"\n [value]=\"option.value\"\n [disabled]=\"option.disabled\"\n >\n {{ option.label | translate }}\n </mat-option>\n </mat-select>\n <glxy-hint position=\"below\" *ngIf=\"field.description\">\n {{ field.description }}\n </glxy-hint>\n </glxy-form-field>\n </div>\n <div class=\"print\">\n <div class=\"label\">{{ field.label | translate }}:</div>\n <div class=\"answer\">{{ dropdownAnswer() }}</div>\n </div>\n </ng-container>\n </ng-container>\n</ng-container>\n", styles: [".office-text{font-size:13px;color:#9e9e9e;color:var(--tertiary-text-color, #9e9e9e);margin-bottom:-24px}.office-text+.office-text{margin-top:24px}@media print{.office-text{margin:0}}.display-only{color:rgba(0,0,0,.38)}.file-static-list{margin:0;padding:0;list-style:none}@media print{.display{display:none}}.print{display:none}@media print{.print{display:flex;outline:1px solid;margin-top:1px;margin-left:1px;page-break-inside:avoid}.print .label{flex-basis:30%;padding:8px;font-weight:500;border-right:1px solid black}.print .answer{flex-basis:70%;padding:8px}}\n"] }]
}], propDecorators: { field: [{
type: Input
}], form: [{
type: Input
}], glxyUploader: [{
type: ViewChild,
args: ['glxyUploader']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field.component.js","sourceRoot":"","sources":["../../../../../../../libs/store/src/lib/order-form/fields/field.component.ts","../../../../../../../libs/store/src/lib/order-form/fields/field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Input, Component, ViewChild } from '@angular/core';\nimport { FormGroup } from '@angular/forms';\n\n@Component({\n  selector: 'app-order-field',\n  styleUrls: ['./field.component.scss'],\n  templateUrl: './field.component.html',\n})\nexport class FieldComponent {\n  @Input() field: any; // avoid checking union type in template\n  @Input() form: FormGroup;\n\n  @ViewChild('glxyUploader') glxyUploader;\n\n  get isValid(): boolean {\n    return this.form.controls[this.field.id].valid || this.form.controls[this.field.id].pristine;\n  }\n\n  showCheckboxError(field): boolean {\n    return (\n      this.form.controls[field].errors && this.form.controls[field].errors.required && this.form.controls[field].touched\n    );\n  }\n\n  getValue(): any {\n    return this.form.controls[this.field.id].value;\n  }\n\n  dropdownAnswer(): string {\n    const answer = this.getValue();\n    return ((this.field.options || []).find((option) => option.value === answer) || { label: answer }).label;\n  }\n\n  multidropdownAnswer(): string {\n    const answer = this.getValue();\n    return (answer || [])\n      .map((a) => ((this.field.options || []).find((option) => option.value === a) || { name: a }).name)\n      .join(', ');\n  }\n\n  checkboxAnswer(): string {\n    const answer = this.getValue();\n    return answer ? 'Yes' : 'No';\n  }\n\n  fileUploadAnswer(): string {\n    const answer = this.getValue();\n    return answer.map((a) => (a.name ? a.name : a.url ? a.url : a)).join(', ');\n  }\n\n  // Load form values into galaxy uploader to get any cached values\n  uploadedFiles(): any[] {\n    return this.form.controls[this.field.id].value;\n  }\n\n  // Handle deleting file from both galaxy uploader component, and order-form form values\n  deleteFile(event: any): void {\n    const filterOutDeletedFile = this.form.controls[this.field.id].value.filter(\n      (file) => file.name !== event.name && file.url !== event.url,\n    );\n\n    this.form.controls[this.field.id].setValue(filterOutDeletedFile);\n    // Tell galaxy uploader about delete so it can handle maxFiles properly\n    this.glxyUploader.deleteFile(event);\n  }\n\n  // Manually update order-form form with events from galaxy file uploader\n  onUpload(event: any): void {\n    const uploadedFiles = this.form.controls[this.field.id].value;\n\n    uploadedFiles.push({\n      name: event.name,\n      url: event.url,\n    });\n\n    this.form.controls[this.field.id].setValue(uploadedFiles);\n  }\n}\n","<ng-container [ngSwitch]=\"field.controlType\" [formGroup]=\"form\">\n  <ng-container *ngIf=\"!field.hidden\">\n    <div class=\"office-text\" *ngIf=\"field.forOfficeUseOnly\">\n      * {{ 'FRONTEND.STORE.ORDER_FORM.HIDDEN_FROM_END_USERS' | translate }}:\n    </div>\n    <div class=\"office-text\" *ngIf=\"field.officeEditableOnly\">\n      * {{ 'FRONTEND.STORE.ORDER_FORM.OFFICE_EDITABLE_ONLY' | translate }}:\n    </div>\n\n    <ng-container *ngSwitchCase=\"'dropdown'\">\n      <ng-container *ngIf=\"!field.allowMultiples\">\n        <div class=\"display\">\n          <glxy-form-field>\n            <glxy-label>\n              {{ field.label | translate }}{{ field.required ? '*' : '' }}\n            </glxy-label>\n            <mat-select matInput [formControlName]=\"field.id\" [id]=\"field.id\">\n              <mat-option\n                *ngFor=\"let option of field.options\"\n                [value]=\"option.value\"\n              >\n                {{ option.label }}\n              </mat-option>\n            </mat-select>\n            <glxy-hint position=\"below\" *ngIf=\"field.description\">\n              {{ field.description }}\n            </glxy-hint>\n          </glxy-form-field>\n        </div>\n        <div class=\"print\">\n          <div class=\"label\">{{ field.label | translate }}:</div>\n          <div class=\"answer\">{{ dropdownAnswer() }}</div>\n        </div>\n      </ng-container>\n      <ng-container *ngIf=\"field.allowMultiples\">\n        <div class=\"display\">\n          <glxy-input-tags\n            [id]=\"field.id\"\n            [formControlName]=\"field.id\"\n            label=\"{{ field.label | translate }}{{\n              field.required ? ' *' : ''\n            }}\"\n            [hint]=\"field.description\"\n            [required]=\"field.required\"\n            [options]=\"field.options\"\n            [allowDuplicates]=\"field.allowDuplicates\"\n            [maxFields]=\"field.maxChoices\"\n          ></glxy-input-tags>\n        </div>\n        <div class=\"print\">\n          <div class=\"label\">{{ field.label | translate }}:</div>\n          <div class=\"answer\">{{ multidropdownAnswer() }}</div>\n        </div>\n      </ng-container>\n    </ng-container>\n\n    <ng-container *ngSwitchCase=\"'textbox'\">\n      <div class=\"display\">\n        <glxy-form-field\n          [prefixText]=\"field.prefix\"\n          [suffixText]=\"field.suffix\"\n        >\n          <glxy-label>\n            {{ field.label | translate }}{{ field.required ? ' *' : '' }}\n          </glxy-label>\n          <input\n            matInput\n            [type]=\"field.textboxType\"\n            [id]=\"field.id\"\n            [formControlName]=\"field.id\"\n            [pattern]=\"field.regexValidator || ''\"\n            [readonly]=\"field.displayOnly\"\n            [ngClass]=\"{ 'display-only': field.displayOnly }\"\n          />\n          <glxy-hint position=\"below\" *ngIf=\"field.description\">\n            {{ field.description }}\n          </glxy-hint>\n          <glxy-error *ngIf=\"form.controls[field.id].hasError('pattern')\">\n            {{ field.regexErrorMessage }}\n          </glxy-error>\n        </glxy-form-field>\n      </div>\n      <div class=\"print\">\n        <div class=\"label\">{{ field.label | translate }}:</div>\n        <div class=\"answer\">{{ getValue() }}</div>\n      </div>\n    </ng-container>\n\n    <ng-container *ngSwitchCase=\"'checkbox'\">\n      <div class=\"display\">\n        <glxy-form-field>\n          <mat-checkbox\n            [formControlName]=\"field.id\"\n            [id]=\"field.id\"\n            ngControlDefault\n          >\n            {{ field.label | translate }}{{ field.required ? ' *' : '' }}\n            <extended *ngIf=\"field.description\">\n              {{ field.description }}\n            </extended>\n          </mat-checkbox>\n          <glxy-error *ngIf=\"showCheckboxError(field.id)\" class=\"checkboxError\">\n            {{ 'FRONTEND.STORE.REQUIRED' | translate }}\n          </glxy-error>\n        </glxy-form-field>\n      </div>\n      <div class=\"print\">\n        <div class=\"label\">{{ field.label | translate }}:</div>\n        <div class=\"answer\">{{ checkboxAnswer() }}</div>\n      </div>\n    </ng-container>\n\n    <ng-container *ngSwitchCase=\"'textarea'\">\n      <span class=\"display\">\n        <glxy-form-field>\n          <glxy-label>\n            {{ field.label | translate }}{{ field.required ? ' *' : '' }}\n          </glxy-label>\n          <textarea\n            matInput\n            [formControlName]=\"field.id\"\n            [id]=\"field.id\"\n            cdkTextareaAutosize\n          ></textarea>\n          <glxy-hint position=\"below\" *ngIf=\"field.description\">\n            {{ field.description }}\n          </glxy-hint>\n        </glxy-form-field>\n      </span>\n      <div class=\"print\">\n        <div class=\"label\">{{ field.label | translate }}:</div>\n        <div class=\"answer\">{{ getValue() }}</div>\n      </div>\n    </ng-container>\n\n    <ng-container *ngSwitchCase=\"'file'\">\n      <span class=\"display\">\n        <glxy-form-field>\n          <glxy-label>\n            {{ field.label | translate }}{{ field.required ? ' *' : '' }}\n          </glxy-label>\n          <glxy-hint position=\"below\" *ngIf=\"field.description\">\n            {{ field.description }}\n          </glxy-hint>\n          <ng-container *ngIf=\"!field.disabled\">\n            <glxy-uploader\n              #glxyUploader\n              [uploadUrl]=\"field.uploadUrl\"\n              [maxFiles]=\"field.numFiles\"\n              (fileUploaded)=\"onUpload($event)\"\n            ></glxy-uploader>\n            <glxy-uploader-list\n              [files]=\"uploadedFiles() || []\"\n              (fileDeleted)=\"deleteFile($event)\"\n            ></glxy-uploader-list>\n          </ng-container>\n          <ng-container *ngIf=\"field.disabled\">\n            <ng-container *ngIf=\"!uploadedFiles().length\">&mdash;</ng-container>\n            <ng-container *ngIf=\"uploadedFiles().length\">\n              <ul class=\"file-static-list\">\n                <li *ngFor=\"let file of uploadedFiles()\">\n                  <a href=\"{{ file.url }}\" target=\"_blank\">{{ file.name }}</a>\n                </li>\n              </ul>\n            </ng-container>\n          </ng-container>\n        </glxy-form-field>\n      </span>\n      <div class=\"print\">\n        <div class=\"label\">{{ field.label | translate }}:</div>\n        <div class=\"answer\">{{ fileUploadAnswer() }}</div>\n      </div>\n    </ng-container>\n\n    <ng-container *ngSwitchCase=\"'vbcuser'\">\n      <div class=\"display\">\n        <glxy-form-field>\n          <glxy-label>\n            {{ field.label | translate }}{{ field.required ? ' *' : '' }}\n          </glxy-label>\n          <mat-select matInput [formControlName]=\"field.id\" [id]=\"field.id\">\n            <mat-option\n              *ngFor=\"let option of field.options\"\n              [value]=\"option.value\"\n              [disabled]=\"option.disabled\"\n            >\n              {{ option.label | translate }}\n            </mat-option>\n          </mat-select>\n          <glxy-hint position=\"below\" *ngIf=\"field.description\">\n            {{ field.description }}\n          </glxy-hint>\n        </glxy-form-field>\n      </div>\n      <div class=\"print\">\n        <div class=\"label\">{{ field.label | translate }}:</div>\n        <div class=\"answer\">{{ dropdownAnswer() }}</div>\n      </div>\n    </ng-container>\n  </ng-container>\n</ng-container>\n"]}