'dd/mm/yy', 'dd-mm-yy' => 'dd-mm-yy', 'mm/dd/yy' => 'mm/dd/yy', 'mm-dd-yy' => 'mm-dd-yy', 'MM d, yy' => 'MM d, yy' ); function getFieldConfiguration() { $defaultToToday = ($this->getSetting('DefaultToToday')) ? $this->getSetting('DefaultToToday') : false; $defaultDateFormat = ($this->getSetting('DateFormat')) ? $this->getSetting('DateFormat') : 'dd/mm/yy'; $dateFormatConf = new DropdownField("Fields[$this->ID][CustomSettings][DateFormat]", 'Date format', $this->dateFormats, $defaultDateFormat); return new FieldSet( new CheckboxField("Fields[$this->ID][CustomSettings][DefaultToToday]", _t('EditableFormField.DEFAULTTOTODAY', 'Default to Today?'), $defaultToToday), $dateFormatConf ); } function populateFromPostData($data) { $fieldPrefix = 'Default-'; if(empty($data['Default']) && !empty($data[$fieldPrefix.'Year']) && !empty($data[$fieldPrefix.'Month']) && !empty($data[$fieldPrefix.'Day'])) { $data['Default'] = $data['Year'] . '-' . $data['Month'] . '-' . $data['Day']; } parent::populateFromPostData($data); } /** * Return the form field. * * @todo Make a jQuery safe form field. The current CalendarDropDown * breaks on the front end. */ public function getFormField() { // scripts for jquery date picker Requirements::javascript(THIRDPARTY_DIR .'/jquery-ui/jquery.ui.core.js'); Requirements::javascript(THIRDPARTY_DIR .'/jquery-ui/jquery.ui.datepicker.js'); $dateFormat = $this->getSetting('DateFormat'); Requirements::customScript(<<getSetting('DefaultToToday')) ? date('d/m/Y') : $this->Default; return new DateField( $this->Name, $this->Title, $default); } /** * Return the validation information related to this field. This is * interrupted as a JSON object for validate plugin and used in the * PHP. * * @see http://docs.jquery.com/Plugins/Validation/Methods * @return Array */ public function getValidation() { return array( 'date' => true ); } }