@netgrif/components-core
Version:
Netgrif Application engine frontend core Angular library
99 lines • 14.7 kB
JavaScript
import { Validators } from '@angular/forms';
import { ComponentPrefixes } from '../../models/component';
import { DataField } from '../../models/abstract-data-field';
export var TextFieldView;
(function (TextFieldView) {
TextFieldView["DEFAULT"] = "default";
TextFieldView["TEXTAREA"] = "textarea";
TextFieldView["RICHTEXTAREA"] = "richtextarea";
TextFieldView["HTMLTEXTAREA"] = "htmltextarea";
})(TextFieldView || (TextFieldView = {}));
/**
* A collection of Text field component names supported by the application engine.
*/
export var TextFieldComponent;
(function (TextFieldComponent) {
TextFieldComponent["PASSWORD"] = "password";
TextFieldComponent["TEXT_AREA"] = "textarea";
TextFieldComponent["RICH_TEXT_AREA"] = "richtextarea";
TextFieldComponent["HTML_TEXT_AREA"] = "htmltextarea";
TextFieldComponent["DASHBOARD_LINE_CHART"] = "dashboard_line_chart";
TextFieldComponent["DASHBOARD_PIE_CHART"] = "dashboard_pie_chart";
TextFieldComponent["DASHBOARD_BAR_CHART"] = "dashboard_bar_chart";
TextFieldComponent["DASHBOARD_IFRAME"] = "dashboard_iframe";
TextFieldComponent["DASHBOARD_PORTAL"] = "dashboard_portal";
})(TextFieldComponent || (TextFieldComponent = {}));
export var TextAreaHeight;
(function (TextAreaHeight) {
TextAreaHeight[TextAreaHeight["OUTLINE"] = 20] = "OUTLINE";
TextAreaHeight[TextAreaHeight["FILL_STANDARD"] = 22] = "FILL_STANDARD";
})(TextAreaHeight || (TextAreaHeight = {}));
export var TextFieldValidation;
(function (TextFieldValidation) {
TextFieldValidation["REQUIRED"] = "required";
TextFieldValidation["MIN_LENGTH"] = "minLength";
TextFieldValidation["MAX_LENGTH"] = "maxLength";
TextFieldValidation["VALID_MIN_LENGTH"] = "minlength";
TextFieldValidation["VALID_MAX_LENGTH"] = "maxlength";
TextFieldValidation["PATTERN"] = "pattern";
TextFieldValidation["REGEX"] = "regex";
TextFieldValidation["VALID_TEL_NUMBER"] = "validTelNumber";
TextFieldValidation["TEL_NUMBER"] = "telNumber";
TextFieldValidation["EMAIL"] = "email";
})(TextFieldValidation || (TextFieldValidation = {}));
export class TextField extends DataField {
static FIELD_HEIGHT = 67;
constructor(stringId, title, value, behavior, placeholder, description, layout, validations, _component, parentTaskId) {
super(stringId, title, value, behavior, placeholder, description, layout, validations, _component, parentTaskId);
}
getTypedComponentType() {
return ComponentPrefixes.TEXT + this.getComponentType();
}
resolveValidations() {
const result = [];
this.validations.forEach(item => {
if (item.validationRule.includes(TextFieldValidation.MIN_LENGTH)) {
const tmp = item.validationRule.split(' ');
if (tmp[1] !== undefined) {
const length = parseInt(tmp[1], 10);
if (!isNaN(length)) {
result.push(Validators.minLength(length));
}
}
}
else if (item.validationRule.includes(TextFieldValidation.MAX_LENGTH)) {
const tmp = item.validationRule.split(' ');
if (tmp[1] !== undefined) {
const length = parseInt(tmp[1], 10);
if (!isNaN(length)) {
result.push(Validators.maxLength(length));
}
}
}
else if (item.validationRule.includes(TextFieldValidation.REGEX)) {
if (item.validationRule.startsWith('regex ')) {
result.push(Validators.pattern(new RegExp(item.validationRule.substring(6, item.validationRule.length))));
}
else if (item.validationRule.startsWith('regex("')) {
result.push(Validators.pattern(new RegExp(item.validationRule.substring(7, item.validationRule.length - 2))));
}
}
else if (item.validationRule.includes(TextFieldValidation.EMAIL)) {
result.push(Validators.email);
}
else if (item.validationRule.includes(TextFieldValidation.TEL_NUMBER)) {
result.push(this.validTelNumber);
}
});
return result;
}
validTelNumber(fc) {
if (!(new RegExp(/^(?:\+?(\d{1,3}))?([-. (]*(\d{3})[-. )]*)?((\d{3})[-. ]*(\d{2,4})(?:[-.x ]*(\d+))?)$/).test(fc.value))) {
return ({ validTelNumber: true });
}
else {
return null;
}
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-field.js","sourceRoot":"","sources":["../../../../../../../projects/netgrif-components-core/src/lib/data-fields/text-field/models/text-field.ts"],"names":[],"mappings":"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","sourcesContent":["import {Behavior} from '../../models/behavior';\nimport {FormControl, ValidatorFn, Validators} from '@angular/forms';\nimport {Layout} from '../../models/layout';\nimport {Validation} from '../../models/validation';\nimport {Component, ComponentPrefixes} from '../../models/component';\nimport {DataField} from '../../models/abstract-data-field';\n\nexport enum TextFieldView {\n    DEFAULT = 'default',\n    TEXTAREA = 'textarea',\n    RICHTEXTAREA = 'richtextarea',\n    HTMLTEXTAREA = 'htmltextarea'\n}\n\n/**\n * A collection of Text field component names supported by the application engine.\n */\nexport enum TextFieldComponent {\n    PASSWORD = 'password',\n    TEXT_AREA = 'textarea',\n    RICH_TEXT_AREA = 'richtextarea',\n    HTML_TEXT_AREA = 'htmltextarea',\n    DASHBOARD_LINE_CHART = 'dashboard_line_chart',\n    DASHBOARD_PIE_CHART = 'dashboard_pie_chart',\n    DASHBOARD_BAR_CHART = 'dashboard_bar_chart',\n    DASHBOARD_IFRAME = 'dashboard_iframe',\n    DASHBOARD_PORTAL = 'dashboard_portal',\n}\n\nexport enum TextAreaHeight {\n    OUTLINE = 20,\n    FILL_STANDARD = 22\n}\n\nexport enum TextFieldValidation {\n    REQUIRED = 'required',\n    MIN_LENGTH = 'minLength',\n    MAX_LENGTH = 'maxLength',\n    VALID_MIN_LENGTH = 'minlength',\n    VALID_MAX_LENGTH = 'maxlength',\n    PATTERN = 'pattern',\n    REGEX = 'regex',\n    VALID_TEL_NUMBER = 'validTelNumber',\n    TEL_NUMBER = 'telNumber',\n    EMAIL = 'email'\n}\n\nexport class TextField extends DataField<string> {\n    public static FIELD_HEIGHT = 67;\n\n    constructor(stringId: string, title: string, value: string, behavior: Behavior, placeholder?: string,\n                description?: string, layout?: Layout, validations?: Array<Validation>, _component?: Component,\n                parentTaskId?: string) {\n        super(stringId, title, value, behavior, placeholder, description, layout, validations, _component, parentTaskId);\n    }\n\n    public getTypedComponentType(): string {\n        return ComponentPrefixes.TEXT + this.getComponentType();\n    }\n    protected resolveValidations(): Array<ValidatorFn> {\n        const result = [];\n\n        this.validations.forEach(item => {\n            if (item.validationRule.includes(TextFieldValidation.MIN_LENGTH)) {\n                const tmp = item.validationRule.split(' ');\n                if (tmp[1] !== undefined) {\n                    const length = parseInt(tmp[1], 10);\n                    if (!isNaN(length)) {\n                        result.push(Validators.minLength(length));\n                    }\n                }\n            } else if (item.validationRule.includes(TextFieldValidation.MAX_LENGTH)) {\n                const tmp = item.validationRule.split(' ');\n                if (tmp[1] !== undefined) {\n                    const length = parseInt(tmp[1], 10);\n                    if (!isNaN(length)) {\n                        result.push(Validators.maxLength(length));\n                    }\n                }\n            } else if (item.validationRule.includes(TextFieldValidation.REGEX)) {\n                if (item.validationRule.startsWith('regex ')) {\n                    result.push(Validators.pattern(new RegExp(item.validationRule.substring(6, item.validationRule.length ))));\n                } else if (item.validationRule.startsWith('regex(\"')) {\n                    result.push(Validators.pattern(new RegExp(item.validationRule.substring(7, item.validationRule.length - 2))));\n                }\n            } else if (item.validationRule.includes(TextFieldValidation.EMAIL)) {\n                result.push(Validators.email);\n            } else if (item.validationRule.includes(TextFieldValidation.TEL_NUMBER)) {\n                result.push(this.validTelNumber);\n            }\n        });\n\n        return result;\n    }\n\n    private validTelNumber(fc: FormControl) {\n        if (!(new RegExp(/^(?:\\+?(\\d{1,3}))?([-. (]*(\\d{3})[-. )]*)?((\\d{3})[-. ]*(\\d{2,4})(?:[-.x ]*(\\d+))?)$/).test(fc.value))) {\n            return ({validTelNumber: true});\n        } else {\n            return null;\n        }\n    }\n}\n"]}