Skip to content

Date Editor (flatpickr)

ghiscoding edited this page Dec 12, 2022 · 2 revisions
index

Information

The Date Editor is provided through an external library named Flatpickr and all options from that library can be added to your editorOptions (see below Editor Options), so in order to add things like minimum date, disabling dates, ... just review all the Flatpickr Examples and then add them into editorOptions. Also just so you know, editorOptions is use by all other editors as well to expose external library like Flatpickr, Multiple-Select.js, etc...

Demo

Demo Page | Demo Component

Editor Options

You can use any of the Flatpickr options by adding them to editorOptions as shown below.

FlatpickrOption Interface.

defineGrid() {
  const columnDefinitions = [
    {
      id: 'title', name: 'Title', field: 'title', 
      editor: {
        model: Editors.date, 
        editorOptions: {
          editorOptions: {
            minDate: 'today',
            disable: [(date: Date) => this.isWeekendDay(date)], // disable weekend days (Sat, Sunday)
        } as FlatpickrOption,
      },
    },
  ];
}

/** Returns true when it's a weekend day (Saturday, Sunday) */
isWeekendDay(date: Date): boolean {
  return (date.getDay() === 0 || date.getDay() === 6);
}

Custom Validator

You can add a Custom Validator from an external function or inline (inline is shown below and comes from Example 3)

defineGrid() {
  const columnDefinitions = [
    {
      id: 'title', name: 'Title', field: 'title', 
      editor: {
        model: Editors.date, 
        required: true, 
        validator: (value, args) => {
          const dataContext = args && args.item;
          if (dataContext && (dataContext.completed && !value)) {
            return { valid: false, msg: 'You must provide a "Finish" date when "Completed" is checked.' };
          }
          return { valid: true, msg: '' };
        }
      },
    },
  ];
}
Clone this wiki locally