Component Overview

Form components are the building blocks of your forms. Each component type serves a specific purpose and can be configured with various properties to meet your requirements.

Component Structure

All form components follow a consistent structure with common properties like type, name, class, and component-specific properties.

Available Component Types

{
  "components": [
    { "type": "text", "name": "firstName" },
    { "type": "textarea", "name": "description" },
    { "type": "radio", "name": "gender" },
    { "type": "checkbox", "name": "interests" },
    { "type": "toggle", "name": "notifications" },
    { "type": "switch", "name": "darkMode" },
    { "type": "selectPicker", "name": "country" },
    { "type": "datePicker", "name": "birthDate" },
    { "type": "filePicker", "name": "avatar" }
  ]
}

Dependencies

  • form: FormGroup (Required) - The parent Reactive Form group to which this input control belongs. Input must be in the form tag.
  • validatorSchema: (Required) - Validation name must be the same in the component JSON
  • name: (Required) - name must be the same as validation schema name

Validation Schema Support

All form components support validation schemas with specific data types. Each component section includes detailed information about supported validation schema types and how to configure them properly.

Text Field

The Text component is a reusable Angular form control designed for plain text input with customizable styling and configuration options. It is built to integrate seamlessly with Angular Reactive Forms, allowing developers to bind form controls, apply custom styles, and handle user input events efficiently.

Validation Schema Support

Supported Validation Types

This component supports the following validation schema types:

  • string: Text input with string validation rules
  • number: Numeric input with number validation rules
  • integer: Whole number input with integer validation rules

Note: The text component can handle various data types, but the validation schema determines the actual data type and validation rules applied.

Properties

Property Type Required Description
type string Required Must be "text"
name string Required Field name for form submission (must match validation schema name)
class array Optional Array of CSS class names to apply to the input field
style object Optional Inline styles object (e.g., {"margin":"10px"})
id string Optional ID applied to the input element
placeholder string Optional Placeholder text displayed when field is empty
default string Optional default value applied to the input
disabled boolean Optional Whether the input field is disabled. Does'nt bind value in form submission payload.
readOnly boolean Optional Whether the input field is disabled. But bind value in form submission payload.

Minimal Configuration

{
  "type": "text",
  "name": "text_field"
}

Output: <input class="input-custom fw-bold" name="text_field">

Minimal Configuration with Dependencies

{
  "type": "form",
  "validatorSchema": {
    "text_field": {
      "type": "string"
    }
  },
  "components": [
    {
      "type": "text",
      "name": "text_field"
    }
  ]
}

Maximal Configuration

{
  "type": "text",
  "name": "text_field",
  "default": "text input",
  "placeholder": "Enter text here",
  "id": "text_field",
  "class": ["input-custom", "fw-bold"],
  "style": { "style": "margin: 10px;" },
  "disabled": false
}

Output: <input class="input-custom fw-bold" placeholder="Enter text here" defaultValue="text input" id="test_field">

Textarea

Multi-line text input component for capturing longer text content such as descriptions, comments, and messages.

Validation Schema Support

Supported Validation Types

This component supports the following validation schema types:

  • string: Multi-line text input with string validation rules

Note: Textarea is designed specifically for string content and supports all string validation rules including length constraints, patterns, and format validation.

Properties

Property Type Required Description
type string Required Must be "textarea"
name string Required Field name for form submission (must match validation schema name)
class array Optional Array of CSS class names to apply to the textarea field
style object Optional Inline styles object (e.g., {"margin":"10px"})
id string Optional ID applied to the textarea element
placeholder string Optional Placeholder text displayed when field is empty
default string Optional default value applied to the textarea
disabled boolean Optional Whether the textarea field is disabled. Does'nt bind value in form submission payload.
readOnly boolean Optional Whether the textarea field is disabled. But bind value in form submission payload.

Minimal Configuration

{
  "type": "textarea",
  "name": "textarea_field"
}

Output: <textarea id="undefined" placeholder="undefined" rows="1" name="textarea_field" class="textarea-custom textarea-scrollbar"></textarea>

Minimal Configuration with Dependencies

{
  "type": "form",
  "validatorSchema": {
    "textarea_field": {
      "type": "string"
    }
  },
  "components": [
    {
      "type": "textarea",
      "name": "textarea_field"
    }
  ]
}

Maximal Configuration

{
  "type": "textarea",
  "name": "textarea_field",
  "default": "text input",
  "placeholder": "Enter text here",
  "id": "text_field",
  "class": ["input-custom", "fw-bold"],
  "style": { "margin": "10px;" },
  "disabled": false,
  "readOnly": true
}

Output: <textarea id="text_field" placeholder="Enter text here" rows="1" name="textarea_field" class="textarea-custom textarea-scrollbar fw-bold" style="{"margin":"10px"}" readonly="true"></textarea>

Radio

Radio button component for single-choice selection from a predefined list of options.

Validation Schema Support

Supported Validation Types

This component supports the following validation schema types:

  • string: Text-based option values with string validation rules
  • number: Numeric option values with number validation rules
  • integer: Whole number option values with integer validation rules
  • boolean: True/false option values with boolean validation rules

Note: Radio buttons support multiple data types depending on the option values defined in the dpRule. The validation schema should match the data type of the selected option values.

Properties

Property Type Required Description
type string Required Must be "radio"
name string Required Field name for form submission (must match validation schema name)
class array Optional Array of CSS class names to apply to the radio field
style object Optional Inline styles object (e.g., {"margin":"10px"})
id string Optional ID applied to the radio element
default string Optional default value applied to the radio (string or number)
disabled boolean Optional Whether the radio field is disabled. Does'nt bind value in form submission payload.
readOnly boolean Optional Whether the radio field is disabled. But bind value in form submission payload.
dpRule object Required Data population rule defining how options are populated (static or dynamic)

Data Population Strategies

Static Data Population

{
  "type": "radio",
  "name": "radio_field",
  "dpRule": {
    "type": "static",
    "options": [
      {
        "label": "Yes",
        "value": "yes"
      },
      {
        "label": "No",
        "value": "no"
      }
    ]
  }
}

API-based Data Population

{
  "type": "radio",
  "name": "radio_field",
  "dpRule": {
    "type": "dynamic",
    "apiEndpoint": ""
  }
}

API Requirements

  • API must be GET endpoint.
  • Expected response format:
{
  "code": "000",
  "message": "Success",
  "data": {
    "type": "group",
    "components": [
      {
        "label": "Yes",
        "value": "yes"
      },
      {
        "label": "No",
        "value": "no"
      }
    ]
  }
}

Minimal Configuration with Dependencies

{
  "type": "form",
  "validatorSchema": {
    "radio_field": {
      "type": "string"
    }
  },
  "components": [
        {
  "type": "radio",
      "name": "radio_field",
      "default": "yes",
      "dpRule": {
        "type": "static",
  "options": [
          {
            "label": "Yes",
            "value": "yes"
          },
          {
            "label": "No",
            "value": "no"
          }
        ]
      }
    }
  ]
}

Maximal Configuration

{
  "type": "radio",
  "id": "radio_field",
  "name": "radio_field",
  "class": ["input-custom", "fw-bold"],
  "style": { "margin": "10px;" },
  "disabled": false,
  "readOnly": true,
  "dpRule": {
    "type": "static",
  "options": [
      {
        "label": "Yes",
        "value": "yes"
      },
      {
        "label": "No",
        "value": "no"
      }
    ]
  }
}

Output: <input type="radio" class="radio-primary" name="radio_field" disabled=true>

Checkbox

Checkbox component for multiple-choice selection or boolean (true/false) values.

Validation Schema Support

Supported Validation Types

This component supports the following validation schema types:

  • array: Multiple selection with array validation rules
  • number: Numeric values in array with number validation rules
  • integer: Whole number values in array with integer validation rules
  • string: Text values in array with string validation rules

Note: Checkboxes are designed for multiple selections and always return an array. The validation schema should use array type with appropriate item validation rules for the option values.

Properties

Property Type Required Description
type string Required Must be "checkbox"
name string Required Field name for form submission (must match validation schema name)
class array Optional Array of CSS class names to apply to the checkbox field
style object Optional Inline styles object (e.g., {"margin":"10px"})
id string Optional ID applied to the checkbox element
default array Optional default values applied to the checkbox (array of objects with label and value)
disabled boolean Optional Whether the checkbox field is disabled. Does'nt bind value in form submission payload.
readOnly boolean Optional Whether the checkbox field is disabled. But bind value in form submission payload.
dpRule object Required Data population rule defining how options are populated (static or dynamic)

Data Population Strategies

Static Data Population

{
  "type": "checkbox",
  "name": "checkbox_field",
  "dpRule": {
    "type": "static",
    "options": [
      {
        "label": "Yes",
        "value": "yes"
      },
      {
        "label": "No",
        "value": "no"
      }
    ]
  }
}

API-based Data Population

{
  "type": "checkbox",
  "name": "checkbox_field",
  "dpRule": {
    "type": "dynamic",
    "apiEndpoint": ""
  }
}

API Requirements

  • API must be GET endpoint.
  • Expected response format:
{
  "code": "000",
  "message": "Success",
  "data": {
    "type": "group",
    "components": [
      {
        "label": "Yes",
        "value": "yes"
      },
      {
        "label": "No",
        "value": "no"
      }
    ]
  }
}

Minimal Configuration with Dependencies

{
  "type": "form",
  "validatorSchema": {
    "checkbox_field": {
      "type": "string"
    }
  },
  "components": [
    {
      "type": "checkbox",
      "name": "checkbox_field",
      "default": ["yes"],
      "dpRule": {
        "type": "static",
        "options": [
          {
            "label": "Yes",
            "value": "yes"
          },
          {
            "label": "No",
            "value": "no"
          }
        ]
      }
    }
  ]
}

Maximal Configuration

{
  "type": "checkbox",
  "id": "checkbox_field",
  "name": "checkbox_field",
  "class": ["input-custom", "fw-bold"],
  "style": { "margin": "10px;" },
  "disabled": false,
  "readOnly": true,
  "dpRule": {
    "type": "static",
    "options": [
      {
        "label": "Yes",
        "value": "yes"
      },
      {
        "label": "No",
        "value": "no"
      }
    ]
  }
}

Output: <input type="checkbox" class="checkbox-primary" name="checkbox_field" disabled=true>

Toggle

Toggle switch component for binary on/off states with modern switch-style UI.

Validation Schema Support

Supported Validation Types

This component supports the following validation schema types:

  • string: Text-based toggle values with string validation rules
  • number: Numeric toggle values with number validation rules
  • integer: Whole number toggle values with integer validation rules
  • boolean: True/false toggle values with boolean validation rules

Note: Toggle components can be configured to work with various data types. The validation schema should match the expected data type of the toggle values.

Properties

Property Type Required Description
type string Required Must be "toggle"
name string Required Field name for form submission (must match validation schema name)
class array Optional Array of CSS class names to apply to the toggle field
style object Optional Inline styles object (e.g., {"margin":"10px"})
id string Optional ID applied to the toggle element
default boolean Optional default state applied to the toggle (true/false)
disabled boolean Optional Whether the toggle field is disabled. Does'nt bind value in form submission payload.
readOnly boolean Optional Whether the toggle field is disabled. But bind value in form submission payload.

Minimal Configuration

{
  "type": "toggle",
  "name": "toggle_field"
}

Minimal Configuration with Dependencies

{
  "type": "form",
  "validatorSchema": {
    "toggle_field": {
      "type": "string"
    }
  },
      "components": [
    {
      "type": "toggle",
      "name": "toggle_field"
    }
  ]
}

Maximal Configuration

{
  "type": "toggle",
  "id": "toggle_field",
  "name": "toggle_field",
  "default": true,
  "class": ["fw-bold"],
  "style": { "margin": "10px;" },
  "disabled": false,
  "readOnly": true
}

Output: <input type="checkbox" id="toggle_field" name="checkbox_field" class="switch switch-primary">

Switch

Switch component for single-choice selection from a predefined list of options.

Validation Schema Support

Supported Validation Types

This component supports the following validation schema types:

  • boolean: True/false switch values with boolean validation rules

Note: Switch components are designed for binary states and work best with boolean validation schemas.

Properties

Property Type Required Description
type string Required Must be "switch"
name string Required Field name for form submission (must match validation schema name)
class array Optional Array of CSS class names to apply to the switch field
style object Optional Inline styles object (e.g., {"margin":"10px"})
id string Optional ID applied to the switch element
default string Optional default value applied to the switch (string or number)
disabled boolean Optional Whether the switch field is disabled. Does'nt bind value in form submission payload.
readOnly boolean Optional Whether the switch field is disabled. But bind value in form submission payload.
dpRule object Required Data population rule defining how options are populated (static or dynamic)

Data Population Strategies

Static Data Population

{
  "type": "switch",
  "name": "switch_field",
  "dpRule": {
    "type": "static",
    "options": [
      {
        "label": "Yes",
        "value": "yes"
      },
      {
        "label": "No",
        "value": "no"
      }
    ]
  }
}

API-based Data Population

{
  "type": "switch",
  "name": "switch_field",
  "dpRule": {
    "type": "dynamic",
    "apiEndpoint": ""
  }
}

API Requirements

  • API must be GET endpoint.
  • Expected response format:
{
  "code": "000",
  "message": "Success",
  "data": {
    "type": "group",
    "components": [
      {
        "label": "Yes",
        "value": "yes"
      },
      {
        "label": "No",
        "value": "no"
      }
    ]
  }
}

Minimal Configuration with Dependencies

{
  "type": "form",
  "validatorSchema": {
    "switch_field": {
      "type": "string"
    }
  },
      "components": [
    {
      "type": "switch",
      "name": "switch_field",
      "default": "yes",
      "dpRule": {
        "type": "static",
        "options": [
          {
            "label": "Yes",
            "value": "yes"
          },
          {
            "label": "No",
            "value": "no"
          }
        ]
      }
    }
  ]
}

Maximal Configuration

{
  "type": "switch",
  "id": "switch_field",
  "name": "switch_field",
  "class": ["input-custom", "fw-bold"],
  "style": { "margin": "10px;" },
  "disabled": false,
  "readOnly": true,
  "dpRule": {
    "type": "static",
    "options": [
      {
        "label": "Yes",
        "value": "yes"
      },
      {
        "label": "No",
        "value": "no"
      }
    ]
  }
}

Output: <input type="radio" class="radio-primary" name="switch_field" disabled=true>

Select Picker

Select Picker component for single-choice selection from a predefined list of options.

Validation Schema Support

Supported Validation Types

This component supports the following validation schema types:

  • string: Text-based option values with string validation rules
  • number: Numeric option values with number validation rules
  • integer: Whole number option values with integer validation rules

Note: Select Picker supports multiple data types depending on the option values defined in the dpRule. The validation schema should match the data type of the selected option values.

Properties

Property Type Required Description
type string Required Must be "selectPicker"
name string Required Field name for form submission (must match validation schema name)
class array Optional Array of CSS class names to apply to the selectPicker field
style object Optional Inline styles object (e.g., {"margin":"10px"})
id string Optional ID applied to the selectPicker element
default object Optional default value applied to the selectPicker (object with label and value)
disabled boolean Optional Whether the selectPicker field is disabled. Does'nt bind value in form submission payload.
readOnly boolean Optional Whether the selectPicker field is disabled. But bind value in form submission payload.
dpRule object Required Data population rule defining how options are populated (static or dynamic)

Data Population Strategies

Static Data Population

{
  "type": "selectPicker",
  "name": "selectPicker_field",
  "dpRule": {
    "type": "static",
    "options": [
      {
        "label": "Yes",
        "value": "yes"
      },
      {
        "label": "No",
        "value": "no"
      }
    ]
  }
}

API-based Data Population

{
  "type": "selectPicker",
  "name": "selectPicker_field",
  "dpRule": {
    "type": "dynamic",
    "apiEndpoint": ""
  }
}

API Requirements

  • API must be GET endpoint.
  • Expected response format:
{
  "code": "000",
  "message": "Success",
  "data": {
    "type": "group",
    "components": [
      {
        "label": "Yes",
        "value": "yes"
      },
      {
        "label": "No",
        "value": "no"
      }
    ]
  }
}

Minimal Configuration with Dependencies

{
  "type": "form",
  "validatorSchema": {
    "selectPicker_field": {
      "type": "string"
    }
  },
      "components": [
    {
      "type": "selectPicker",
      "name": "selectPicker_field",
      "default": {
        "label": "Yes",
        "value": "yes"
      },
      "dpRule": {
        "type": "static",
        "options": [
          {
            "label": "Yes",
            "value": "yes"
          },
          {
            "label": "No",
            "value": "no"
          }
        ]
      }
    }
  ]
}

Maximal Configuration

{
  "type": "selectPicker",
  "id": "selectPicker_field",
  "name": "selectPicker_field",
  "class": ["input-custom", "fw-bold"],
  "style": { "margin": "10px;" },
  "disabled": false,
  "readOnly": true,
  "dpRule": {
    "type": "static",
    "options": [
      {
        "label": "Yes",
        "value": "yes"
      },
      {
        "label": "No",
        "value": "no"
      }
    ]
  }
}

Output: <input type="radio" class="radio-primary" name="selectPicker_field" disabled=true>

Date Picker

Date selection component that renders a single-date picker using Tempus Dominus with a light theme, calendar-only (no clock). It binds to an Angular ExtendedFormControl and writes a formatted date string into the form.

Validation Schema Support

Supported Validation Types

This component supports the following validation schema types:

  • string: Date values as formatted strings with string validation rules

Note: Date Picker always outputs formatted date strings. The validation schema should use string type with appropriate pattern validation for the expected date format.

Component Output

  • Form Value: The control value is a string formatted by config.format
  • Example: With format: "YYYY-MM-DD""2025-08-10"
  • Manual Typing: Typing manually also updates the control and marks it touched/dirty

Properties

Property Type Required Description
id string Required Unique component id; used to wire TD targets
type string Required Must be "datePicker"
name string Required Form control name
format string Required Output/display format used by TD and for form value (e.g., "YYYY-MM-DD")
placeholder string Optional Input placeholder text
default string Optional Initial value (must match format if provided)
readOnly boolean Optional Makes input non-editable while still focusable (default: false)
disabled boolean Optional Disables input/control (default: false)
locale string Optional TD localization (e.g., "en", "fr")
startOfTheWeek number Optional First day of week (0=Sunday, 1=Monday)
maxWeekdayLength number Optional Weekday label length (1–n)
dayViewHeaderFormat object Optional TD header format config (month/year tokens)
validators object Optional Validation rules (required, minDate, maxDate)
class array Optional Extra classes merged onto the input (default: "input-custom")
style object Optional Inline styles bound via [ngStyle] on the input
a11y object Optional Accessibility configuration (ariaLabel, ariaDescribedBy)
description string Optional When present, wired to aria-describedby
order number Optional Optional layout hint for renderers

Component Behavior

  • Tempus Dominus Integration: Initializes TD after view init with display.viewMode = 'calendar' and display.components.clock = false
  • Light Theme: Uses light theme with custom prev/next icons
  • Popup Positioning: Container: document.body to avoid z-index issues
  • Date Selection: Shows popup on field focus/calendar icon click, formats selected date using config.format
  • Z-Index Management: Popup's z-index and positioning adjusted to appear above modals

Minimal Configuration

{
  "id": "dob",
  "type": "datePicker",
  "name": "dob",
  "placeholder": "Select date",
  "format": "YYYY-MM-DD"
}

Maximal Configuration

{
  "id": "reservationDate",
  "type": "datePicker",
  "name": "reservationDate",
  "label": "Reservation date",
  "placeholder": "DD/MM/YYYY",
  "default": "2025-08-10",
  "readOnly": false,
  "disabled": false,
  "format": "YYYY-MM-DD",
  "locale": "en",
  "startOfTheWeek": 0,
  "maxWeekdayLength": 2,
  "dayViewHeaderFormat": {
    "month": "long",
    "year": "numeric"
  },
  "validators": {
    "required": false,
    "minDate": "2020-01-01",
    "maxDate": "2030-12-31"
  },
  "class": ["input-custom"],
  "style": { "minWidth": "220px" },
  "a11y": {
    "ariaLabel": "Choose reservation date",
    "ariaDescribedBy": "reservationHelpText"
  },
  "order": 10,
  "description": "Pick a date for your reservation"
}

Validation

  • Format: The value written is always formatted using config.format
  • Required/minDate/maxDate: Surfaced via shared form validation (ExtendedFormControl + getControlErrorMessage)
  • Hard Blocking: For blocking out-of-range dates at picker level, add TD restrictions in component

Practical Examples

Simple DOB Field

{
  "id": "dob",
  "type": "datePicker",
  "name": "dob",
  "placeholder": "YYYY-MM-DD",
  "format": "YYYY-MM-DD",
  "validators": { "required": true }
}

EU-style Date with Monday Week Start

{
  "id": "startDate",
  "type": "datePicker",
  "name": "startDate",
  "placeholder": "DD/MM/YYYY",
  "format": "DD/MM/YYYY",
  "locale": "en-GB",
  "startOfTheWeek": 1,
  "maxWeekdayLength": 2
}

With Bounds and Helper Text

{
  "id": "eventDate",
  "type": "datePicker",
  "name": "eventDate",
  "format": "YYYY-MM-DD",
  "validators": {
    "required": true,
    "minDate": "2025-01-01",
    "maxDate": "2026-12-31"
  },
  "placeholder": "Select event date",
  "description": "eventDateHelp",
  "a11y": { "ariaLabel": "Select event date" }
}

Accessibility

  • Calendar Icon: Configured as a label tied to the input with TD toggle attributes
  • ARIA Support: Provide a11y.ariaLabel and/or description/ariaDescribedBy for better screen-reader context
  • Z-Index: Popup gets very high z-index and fixed positioning to ensure visibility above modals

File Picker

File upload component with two skins: uploadCards (click-to-upload cards) and dropUploadCards (drag & drop + button). It validates file type and max size, shows upload progress UI, supports single/multiple files, and writes Base64 data into the bound form control.

Validation Schema Support

Supported Validation Types

This component supports the following validation schema types:

  • string: Base64 data URL strings with string validation rules

Note: File Picker outputs Base64 data URLs as strings. The validation schema should use string type with appropriate pattern validation for Base64 data URLs.

Component Output

  • Single File Mode: Form control value becomes a single Base64 data URL string (e.g., "...")
  • Multiple Files Mode: Form control value becomes an array of Base64 strings
  • File Deletion: When users delete a file from the UI, it is automatically removed from the form value

Properties

Property Type Required Description
id string Required Unique element/control id
type string Required Must be "filePicker"
name string Required Form control name (used to bind value)
skin object Optional UI skin configuration: {"type": "uploadCards" | "dropUploadCards"}
fileType string Required Allowed extensions (e.g., ".jpg,.png,.pdf")
fileSize number Required Max size per file in megabytes
multipleSelection boolean Optional Allow multiple file select/drag-drop (default: false)
label string Optional Optional visible label
placeholder string Optional Optional hint text
theme string Optional Progress bar accent color (default: "primary")
description boolean Optional Show helper text below button (default: false)
desc1 string Optional First line above button (default: "Drag & drop files")
desc2 string Optional Second line above button (default: "or")
btnText string Optional Button text/HTML (default: "Choose file")
desc3 string Optional Helper description when description = true
class array Optional Icon container classes
style object Optional Inline styles for icon container
btnclass array Optional Button classes (default: "btn btn-sm btn-secondary mt-1")
btnstyle object Optional Inline styles for the button
Divclass array Optional Wrapper classes for inner container
validators object Optional Validation rules (e.g., {"required": false})
constraints object Optional Mask/regex patterns (usually unused for files)
form object Optional Form configuration (e.g., {"defaultValue": null})
a11y object Optional Accessibility configuration (e.g., {"ariaLabel": "Upload files"})

Skin Types

uploadCards

Simple "attach" button that opens the OS file picker. Each selected file appears as a card with image/icon preview, progress, cancel, and then view/delete.

dropUploadCards

Drag & drop area with icon + helper text + button. Same upload card behavior as uploadCards. Adds visual highlight on drag-over.

Minimal Configuration

{
  "id": "fileUpload1",
  "type": "filePicker",
  "name": "upload",
  "skin": { "type": "dropUploadCards" },
  "fileType": ".jpg,.png",
  "fileSize": 5
}

Maximal Configuration

{
  "id": "fileUpload1",
  "type": "filePicker",
  "name": "upload",
  "label": "Attachments",
  "placeholder": "Select files",
  "skin": {
    "type": "dropUploadCards"
  },
  "theme": "primary",
  "fileType": ".jpg,.jpeg,.png,.svg,.pdf,.doc,.ppt,.xls",
  "fileSize": 10,
  "multipleSelection": true,
  "description": true,
  "desc1": "Drag & drop your files here",
  "desc2": "or",
  "btnText": "Browse files",
  "desc3": "Accepted: JPG, PNG, SVG, PDF up to 10 MB each",
  "class": ["ph", "ph-upload-simple", "icon", "icon-lg"],
  "style": { "opacity": "0.9" },
  "btnclass": ["btn", "btn-sm", "btn-secondary", "mt-1"],
  "btnstyle": { "minWidth": "160px" },
  "Divclass": ["d-flex","flex-column","custom-gap-10","flex-wrap","justify-content-center","align-items-center"],
  "validators": {
    "required": false
  },
  "constraints": {
    "maskPattern": null,
    "regexPattern": null
  },
  "form": {
    "defaultValue": null
  },
  "a11y": {
    "ariaLabel": "Upload attachments"
  }
}

Validation Rules

  • Type Check: File extension must match one of the fileType list (case-insensitive, leading dot optional)
  • Size Check: Each file must be ≤ fileSize MB. Exceeding files are rejected with toast error
  • Required: If validators.required = true, form validation ensures at least one Base64 value is present

Practical Examples

Single Image Upload

{
  "id": "avatar",
  "type": "filePicker",
  "name": "avatar",
  "skin": { "type": "uploadCards" },
  "fileType": ".png",
  "fileSize": 2,
  "multipleSelection": false,
  "validators": { "required": true }
}

Multiple Documents with Drag & Drop

{
  "id": "attachments",
  "type": "filePicker",
  "name": "attachments",
  "skin": { "type": "dropUploadCards" },
  "fileType": ".pdf,.doc,.docx,.ppt,.pptx,.xls,.xlsx",
  "fileSize": 10,
  "multipleSelection": true,
  "description": true,
  "desc1": "Drag & drop documents",
  "desc2": "or",
  "btnText": "Browse",
  "desc3": "PDF/DOC/PPT/XLS up to 10 MB each",
  "theme": "primary",
  "btnclass": ["btn", "btn-sm", "btn-secondary", "mt-1"],
  "Divclass": ["d-flex","flex-column","gap-2","justify-content-center","align-items-center"]
}