A Flatfile plugin for string configuration and validation
npm i @flatfile/plugin-validate-string
The @flatfile/plugin-validate-string
plugin for string configuration and validation. This plugin combines multiple string validations in a single configuration, including regex pattern matching, length validation, case sensitivity, trimming options, and custom transformations.
Event Type:
listener.on('commit:created')
To install the plugin, use npm:
npm install @flatfile/plugin-validate-string
import { FlatfileListener } from '@flatfile/listener';
import { validateString } from '@flatfile/plugin-validate-string';
const listener = new FlatfileListener();
const stringConfig = {
fields: ['name'],
minLength: 2,
maxLength: 50,
caseType: 'titlecase',
errorMessages: {
length: 'Name must be between 2 and 50 characters',
case: 'Name must be in Title Case',
},
};
listener.use(validateString(stringConfig));
Pattern usage:
const config = {
fields: ['email'],
pattern: 'email' // Uses predefined email pattern
};
// Or with a custom pattern:
const customConfig = {
fields: ['customField'],
pattern: /^[A-Z]{3}-\d{2}$/ // Custom pattern for format like 'ABC-12'
};
The validateString
accepts a StringValidationConfig
object with the following properties:
fields
: string[] - Fields to validatesheetSlug
: string - Sheet slug to validate (defaults to '**' all sheets)pattern
: RegExp - A regular expression pattern to match againstpattern
: keyof typeof commonRegexPatterns | RegExp - A regular expression pattern to match against. You can use one of the predefined patterns ('email', 'phone', 'url') or provide a custom RegExp. The predefined patterns are:
email
: Validates email addressesphone
: Validates phone numbers (10-14 digits, optional '+' prefix)url
: Validates URLs (with or without protocol)minLength
: number - Minimum length of the stringmaxLength
: number - Maximum length of the stringexactLength
: number - Exact required length of the stringcaseType
: 'lowercase' | 'uppercase' | 'titlecase' - Enforces specific case typetrim
: { leading?: boolean, trailing?: boolean } - Trims whitespaceemptyStringAllowed
: boolean - Whether empty strings are allowederrorMessages
: Object with custom error messages for different validationsThe plugin processes each record in the Flatfile import, applying the configured validations to the specified fields. If a validation fails, an error is added to the record for that field. If a custom transformation is specified and all validations pass, the transformed value is set for the field.
The plugin uses the recordHook
to process individual records, allowing for efficient and flexible validation and transformation of string fields during the import process.