cytoscape-angular
Version:
Angular 12+ components for cytoscape charting.
93 lines • 12.8 kB
JavaScript
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"]}