UNPKG

cytoscape-angular

Version:
93 lines 12.8 kB
export class FormInfo { constructor(title, fieldsets, showSubmitButton = false, submitText = 'Submit', disableSubmitOnFormInvalid = false, /* if the model has a property that isn't in a fieldset, but it in an fieldset created by the form */ otherFieldsetTitle = null) { this.title = title; this.fieldsets = fieldsets; this.showSubmitButton = showSubmitButton; this.submitText = submitText; this.disableSubmitOnFormInvalid = disableSubmitOnFormInvalid; this.otherFieldsetTitle = otherFieldsetTitle; } } export class FieldsetInfo { constructor(legend, fieldInfos, displayOnlyIfProperties) { this.legend = legend; this.fieldInfos = fieldInfos; this.displayOnlyIfProperties = displayOnlyIfProperties; } showFieldsetForModel(model) { if (!this.displayOnlyIfProperties) { return true; } for (const fieldInfo of this.fieldInfos) { for (const modelProperty of Object.keys(model)) { if (fieldInfo.modelProperty === modelProperty) { return true; } } } return false; } } export class FieldInfo { constructor(/* label to show the user next to the field, can be a function for i18n/dynamic labels */ label, /* The form has a model, this is the name of the property on the form's model object that this field */ modelProperty, /* computed from the model property type by default */ type, /* The tooltip to display on hover */ tooltip, /* The list of Angular Form Validators for the control or a function that returns such an array */ validators, /* disable the field if it's not valid */ disableWhenInvalid = false, /* If true and model[modelProperty] is undefined, don't create a field.*/ hideWhenNoModelProperty = true, /* Input only - by default the label is used as a placeholder and floats (how to downcast in a template?) */ placeholder, /* Input only - same as HTML input (how to downcast in a template?) */ inputType = 'text', /* Input only - same as HTML input (how to downcast in a template?) */ inputSize = 8, /* Select only either an array of object or the name of a model property or function that is/returns an array of objects */ options, /* In an options object, what field to display to the user (or function that returns a string given the option object and the model) */ optionArrayLabelField, /* In an options object, what field to return for the value of the option (or function that returns a string given the option object and the model) */ optionArrayValueField) { this.label = label; this.modelProperty = modelProperty; this.type = type; this.tooltip = tooltip; this.validators = validators; this.disableWhenInvalid = disableWhenInvalid; this.hideWhenNoModelProperty = hideWhenNoModelProperty; this.placeholder = placeholder; this.inputType = inputType; this.inputSize = inputSize; this.options = options; this.optionArrayLabelField = optionArrayLabelField; this.optionArrayValueField = optionArrayValueField; this.fieldTypes = {}; } fieldType(model) { const cached = this.fieldTypes[this.modelProperty]; if (cached) { return cached; } else { const fieldValueType = typeof model[this.modelProperty]; const result = this.type ? this.type : (this.options ? 'options' : fieldValueType); this.fieldTypes[this.modelProperty] = result; return result; } } setValue(newValue, model, modelChange) { model[this.modelProperty] = newValue; modelChange.emit({ property: this.modelProperty, value: newValue }); } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-info.js","sourceRoot":"","sources":["../../../../../projects/cytoscape-angular/src/lib/fluid-form/form-info.ts"],"names":[],"mappings":"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","sourcesContent":["/* tslint:disable:ban-types */\nimport { AsyncValidatorFn, ValidatorFn } from '@angular/forms'\nimport { EventEmitter } from '@angular/core'\n\nexport type FieldType = 'ShapePolygonPoints' | 'percent' | 'NodeShape'| 'LineStyle' | 'TextTransformation' | 'FontStyle' | 'FontWeight' | 'options' | 'Colour' | 'undefined' | 'object' | 'boolean' | 'number' | 'string' | 'function' | 'symbol' | 'bigint'\n\nexport class FormInfo {\n  constructor(public title: string,\n              public fieldsets: FieldsetInfo[],\n              public showSubmitButton = false,\n              public submitText = 'Submit',\n              public disableSubmitOnFormInvalid = false,\n              /* if the model has a property that isn't in a fieldset, but it in an fieldset created by the form */\n              public otherFieldsetTitle = null) {\n  }\n}\n\nexport class FieldsetInfo {\n  constructor(public legend: string,\n              public fieldInfos: FieldInfo[],\n              public displayOnlyIfProperties?: string[]) {\n  }\n\n  showFieldsetForModel(model: object): boolean {\n    if (!this.displayOnlyIfProperties) {\n      return true\n    }\n    for (const fieldInfo of this.fieldInfos) {\n      for (const modelProperty of Object.keys(model)) {\n        if (fieldInfo.modelProperty === modelProperty) {\n          return true\n        }\n      }\n    }\n    return false\n  }\n}\n\nexport class FieldInfo {\n  private fieldTypes = {}\n  updateOn: 'change' | 'blur' | 'submit' // same as AbstractControlOptions\n  asyncValidators: AsyncValidatorFn[] | Function\n\n  constructor(/* label to show the user next to the field, can be a function for i18n/dynamic labels */\n              public label?: string | Function,\n              /* The form has a model, this is the name of the property on the form's model object that this field */\n              public modelProperty?: string,\n              /* computed from the model property type by default */\n              public type?: FieldType,\n              /* The tooltip to display on hover */\n              public tooltip?: string,\n              /* The list of Angular Form Validators for the control or a function that returns such an array */\n              public validators?: ValidatorFn[] | Function,\n              /* disable the field if it's not valid */\n              public disableWhenInvalid = false,\n              /* If true and model[modelProperty] is undefined, don't create a field.*/\n              public hideWhenNoModelProperty = true,\n              /* Input only - by default the label is used as a placeholder and floats (how to downcast in a template?) */\n              public placeholder?: string,\n              /* Input only - same as HTML input (how to downcast in a template?) */\n              public inputType: string = 'text',\n              /* Input only - same as HTML input (how to downcast in a template?) */\n              public inputSize: number = 8,\n              /* Select only either an array of object or the name of a model property or function that is/returns an array of objects */\n              public options?: object[] | string,\n              /* In an options object, what field to display to the user (or function that returns a string\n              given the option object and the model) */\n              public optionArrayLabelField?: string | Function,\n              /* In an options object, what field to return for the value of the option\n              (or function that returns a string given the option object and the model) */\n              public optionArrayValueField?: string | Function\n  ) {\n  }\n\n  fieldType(model: object): FieldType {\n    const cached = this.fieldTypes[this.modelProperty]\n    if (cached) {\n      return cached\n    } else {\n      const fieldValueType = typeof model[this.modelProperty]\n      const result = this.type ? this.type : (this.options ? 'options' : fieldValueType)\n      this.fieldTypes[this.modelProperty] = result\n      return result\n    }\n  }\n\n  setValue(newValue: any, model: object, modelChange: EventEmitter<any>) {\n    model[this.modelProperty] = newValue\n    modelChange.emit({property: this.modelProperty, value: newValue})\n  }\n}\n\n\n"]}