2008-09-29 03:18:23 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* EditableDateField
|
2009-04-17 02:26:40 +00:00
|
|
|
*
|
2008-09-29 03:18:23 +00:00
|
|
|
* Allows a user to add a date field to the Field Editor
|
2009-04-17 02:26:40 +00:00
|
|
|
*
|
2010-05-31 07:57:00 +00:00
|
|
|
* @todo Localization, Time Field / Date time field combinations. Set ranges of dates,
|
|
|
|
* set default date
|
|
|
|
*
|
2009-04-17 02:26:40 +00:00
|
|
|
* @package userforms
|
2008-09-29 03:18:23 +00:00
|
|
|
*/
|
2009-12-07 02:04:20 +00:00
|
|
|
|
2008-09-29 03:18:23 +00:00
|
|
|
class EditableDateField extends EditableFormField {
|
2009-04-21 03:44:13 +00:00
|
|
|
|
2009-05-06 03:34:40 +00:00
|
|
|
static $singular_name = 'Date Field';
|
2009-04-21 03:44:13 +00:00
|
|
|
|
2009-05-06 03:34:40 +00:00
|
|
|
static $plural_name = 'Date Fields';
|
2008-09-29 03:18:23 +00:00
|
|
|
|
2010-05-31 09:43:25 +00:00
|
|
|
function getFieldConfiguration() {
|
|
|
|
$defaultToToday = ($this->getSetting('DefaultToToday')) ? $this->getSetting('DefaultToToday') : false;
|
2010-11-15 23:23:11 +00:00
|
|
|
|
2010-05-31 09:43:25 +00:00
|
|
|
return new FieldSet(
|
2010-11-15 23:23:11 +00:00
|
|
|
new CheckboxField("Fields[$this->ID][CustomSettings][DefaultToToday]", _t('EditableFormField.DEFAULTTOTODAY', 'Default to Today?'), $defaultToToday)
|
2010-05-31 09:43:25 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2009-04-17 02:26:40 +00:00
|
|
|
function populateFromPostData($data) {
|
2008-09-29 03:18:23 +00:00
|
|
|
$fieldPrefix = 'Default-';
|
|
|
|
|
2009-05-06 03:34:40 +00:00
|
|
|
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);
|
2008-09-29 03:18:23 +00:00
|
|
|
}
|
|
|
|
|
2009-04-21 03:44:13 +00:00
|
|
|
/**
|
|
|
|
* Return the form field.
|
|
|
|
*
|
|
|
|
* @todo Make a jQuery safe form field. The current CalendarDropDown
|
|
|
|
* breaks on the front end.
|
|
|
|
*/
|
|
|
|
public function getFormField() {
|
2010-05-31 07:57:00 +00:00
|
|
|
// 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');
|
2010-11-12 03:28:42 +00:00
|
|
|
|
2010-11-15 23:23:11 +00:00
|
|
|
$dateFormat = DateField_View_JQuery::convert_iso_to_jquery_format(i18n::get_date_format());
|
|
|
|
|
2010-05-31 07:57:00 +00:00
|
|
|
Requirements::customScript(<<<JS
|
|
|
|
(function(jQuery) {
|
|
|
|
$(document).ready(function() {
|
2010-11-15 23:23:11 +00:00
|
|
|
$('input[name^=EditableDateField]').attr('autocomplete', 'off').datepicker({ dateFormat: '$dateFormat' });
|
2010-05-31 07:57:00 +00:00
|
|
|
});
|
|
|
|
})(jQuery);
|
|
|
|
JS
|
|
|
|
, 'UserFormsDate');
|
|
|
|
|
|
|
|
// css for jquery date picker
|
|
|
|
Requirements::css(THIRDPARTY_DIR .'/jquery-ui-themes/smoothness/jquery-ui-1.8rc3.custom.css');
|
|
|
|
|
2010-05-31 09:43:25 +00:00
|
|
|
$default = ($this->getSetting('DefaultToToday')) ? date('d/m/Y') : $this->Default;
|
|
|
|
|
|
|
|
return new DateField( $this->Name, $this->Title, $default);
|
2009-04-21 03:44:13 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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
|
|
|
|
);
|
2008-09-29 03:18:23 +00:00
|
|
|
}
|
2009-12-07 02:04:20 +00:00
|
|
|
}
|