Framework  3.9
DateOfBirthFieldRenderer Class Reference

Field renderer for date of birth data fields. More...

+ Inheritance diagram for DateOfBirthFieldRenderer:
+ Collaboration diagram for DateOfBirthFieldRenderer:

Public Member Functions

 DateFieldRenderer (&$parent)
 
 addValidatorsToForm ($field, $required=false)
 This method is called by the AutoForm to add any default input validators that are required by the FieldRenderer. More...
 
 setMinimumAge ($min, $message="")
 
 renderScript ($field)
 FieldRenderers can override this method to provide any Javascript that their control requires for an edit form. More...
 
 renderField ($field)
 FieldRenderers must override this method to provide the HTML implementation of the control used to edit the field. More...
 
 renderSearchScript ($field, $mode)
 FieldRenderers can override this method to provide any Javascript that the control requires when being used in a search form. More...
 
 renderSearchField ($field, $mode)
 FieldRenderers must override this method to provide the HTML implementation of the control displayed for the field in a search form. More...
 
 renderReadOnly ($field)
 
 format ($value)
 
 preProcess ($field="")
 FieldRenderers can override this method to provide behavior that occurs prior to the saving of the parent form's target object to the database. More...
 
- Public Member Functions inherited from FieldRenderer
 FieldRenderer ($parent)
 Constructor. More...
 
 _printLabel ($field, $colspan=1, $styles="", $annotation="")
 Internal method to generate the HTML for the field label. More...
 
 _getLabel ($field, $addSuffix=true)
 
 _startField ($field, $styles="")
 Internal method to generate the starting HTML for the field (including the label) More...
 
 _endField ($field)
 Internal method to generate the closing HTML for the field. More...
 
 addSearchValidatorsToForm ($field, $mode, $required=false)
 For SearchForm, the validator field needs to match the name tag in the form which is in the format field:mode. More...
 
 formatName ($item, $name)
 Formats the given DataItem based on the supplied format string. More...
 
 renderOnSubmitHandler ($field)
 FieldRenderers can override this method to provide any Javascript that must be executed when the form is submitted on the client. More...
 
 postProcess ($field="")
 FieldRenderers can override this method to provide behavior that occurs after the parent form's target object has been saved to the database. More...
 

Public Attributes

 $template = ""
 
 $minimumAge = 0
 
 $minimumAgeMessage = ""
 
- Public Attributes inherited from FieldRenderer
 $parent = null
 
 $labelSuffix = ""
 
 $colspan = 1
 
 $annotateBefore = false
 
 $annotateNextLine = true
 
 $hideLabel = false
 
 $onPreProcess = null
 callback hook for processing prior to saving the form's data object - individual renderers may override with custom processing More...
 
 $onPostProcess = null
 callback hook for processing after saving the form's data object - individual renderers may override with custom processing More...
 

Detailed Description

Field renderer for date of birth data fields.

Renders with date format validation and separate dropdowns for month, day and year.

Definition at line 44 of file date_of_birth_field_renderer.inc.

Member Function Documentation

◆ addValidatorsToForm()

DateOfBirthFieldRenderer::addValidatorsToForm (   $field,
  $required = false 
)

This method is called by the AutoForm to add any default input validators that are required by the FieldRenderer.

Fields that need custom validation or a custom required validator should override this function.

Parameters
string$fieldthe field name
boolean$required- whether the field is required

Reimplemented from FieldRenderer.

Definition at line 55 of file date_of_birth_field_renderer.inc.

56  {
57  $label = isset($this->label) ? $this->label : $this->parent->prettifyFieldName($field);
58 
59  if($required)
60  {
61  $this->parent->validator->add(new RequiredValidator("{$field}_mm", "$label Month"));
62  $this->parent->validator->add(new RequiredValidator("{$field}_dd", "$label Day"));
63  $this->parent->validator->add(new RequiredValidator("{$field}_yy", "$label Year"));
64  }
65 
66  if ($this->minimumAge)
67  {
68  $this->parent->validator->add(new MinimumAgeValidator($field, $label, $this->minimumAge, $this->minimumAgeMessage));
69  }
70  }
AgeRangeValidator can be used with DateOfBirth fields.
Definition: validation.inc:390
RequiredField Validator.
Definition: validation.inc:76

◆ DateFieldRenderer()

DateOfBirthFieldRenderer::DateFieldRenderer ( $parent)

Definition at line 50 of file date_of_birth_field_renderer.inc.

51  {
52  $this->FieldRenderer($parent);
53  }
FieldRenderer($parent)
Constructor.

◆ format()

DateOfBirthFieldRenderer::format (   $value)

Definition at line 147 of file date_of_birth_field_renderer.inc.

148  {
149  return DateTypeRenderer::format($value, $this->template);
150  }
static format($date, $template="")

◆ preProcess()

DateOfBirthFieldRenderer::preProcess (   $field = "")

FieldRenderers can override this method to provide behavior that occurs prior to the saving of the parent form's target object to the database.

For example, the FileUploadFieldRenderer overrides this method to process the uploading of the file and then store the location in the associated field in the target object.

Parameters
string$fieldthe field name

Reimplemented from FieldRenderer.

Definition at line 152 of file date_of_birth_field_renderer.inc.

153  {
154  trace("Preprocessing data of birth", 3);
155 
156  $mm = checkNumeric($_POST["{$field}_mm"]);
157  $dd = checkNumeric($_POST["{$field}_dd"]);
158  $yy = checkNumeric($_POST["{$field}_yy"]);
159 
160  if ($mm < 10) $mm = "0{$mm}";
161  if ($dd < 10) $dd = "0{$dd}";
162 
163  $dob = "$yy-$mm-$dd";
164 
165  trace("** Preprocessing date of birth: $dob", 3);
166 
167  $this->parent->data->set($field, $dob);
168  }
checkNumeric($p)
Security helper function.
Definition: functions.inc:630
trace($msg, $lvl=3, $callStack=null)
Send output to the trace log.
Definition: functions.inc:1010

◆ renderField()

DateOfBirthFieldRenderer::renderField (   $field)

FieldRenderers must override this method to provide the HTML implementation of the control used to edit the field.

Parameters
string$fieldthe field name

Reimplemented from FieldRenderer.

Definition at line 83 of file date_of_birth_field_renderer.inc.

84  {
85  $obj = $this->parent->data;
86  if ($obj instanceof CompositeDataItem)
87  {
88  $obj = $obj->findSubObject($field);
89  }
90 
91  $month = intval($obj->format("{{$field}:n}"));
92  $day = intval($obj->format("{{$field}:j}"));
93  $year = intval($obj->format("{{$field}:Y}"));
94 
95  trace("** Month: $month, Day: $day, Year: $year, Field: {$obj->$field}", 3);
96 
97  $this->_startField($field);
98  $default = !$month ? " selected" : "";
99 
100  echo "<select id='{$this->parent->id}_{$field}_mm' type='text' name='{$field}_mm'><option value='' disabled {$default}>Month</option>";
101 
102  for($i = 1; $i <= 12; ++$i)
103  {
104  $mm = new DateTime("{$i}/1/1971");
105  $monthName = $mm->format("M");
106  option($i, $monthName, $month);
107  }
108 
109  $default = !$day ? " selected" : "";
110  echo "</select> / <select id='{$this->parent->id}_{$field}_dd' type='text' name='{$field}_dd'><option value='' disabled {$default}>Day</option>";
111 
112  for($i = 1; $i < 32; ++$i)
113  {
114  option($i, $i, $day);
115  }
116 
117  $default = !$year ? " selected" : "";
118  echo "</select> / <select id='{$this->parent->id}_{$field}_yy' type='text' name='{$field}_yy'><option value='' disabled {$default}>Year</option>";
119 
120  for($i = date('Y'); $i >= 1900; --$i)
121  {
122  option($i, $i, $year);
123  }
124 
125  echo "</select>";
126 
127  $this->_endField($field);
128  }
_startField($field, $styles="")
Internal method to generate the starting HTML for the field (including the label)
_endField($field)
Internal method to generate the closing HTML for the field.
option($value, $text, $sel="")
Write out an option tag, marking as selected if applicable.
Definition: functions.inc:888

◆ renderReadOnly()

DateOfBirthFieldRenderer::renderReadOnly (   $field)

Definition at line 138 of file date_of_birth_field_renderer.inc.

139  {
140  $this->_startField($field);
141 
142  echo $this->format($this->parent->data->get($field));
143 
144  $this->_endField($field);
145  }

◆ renderScript()

DateOfBirthFieldRenderer::renderScript (   $field)

FieldRenderers can override this method to provide any Javascript that their control requires for an edit form.

Parameters
string$fieldthe field name

Reimplemented from FieldRenderer.

Definition at line 79 of file date_of_birth_field_renderer.inc.

80  {
81  }

◆ renderSearchField()

DateOfBirthFieldRenderer::renderSearchField (   $field,
  $mode 
)

FieldRenderers must override this method to provide the HTML implementation of the control displayed for the field in a search form.

Parameters
string$fieldthe field name

Reimplemented from FieldRenderer.

Definition at line 134 of file date_of_birth_field_renderer.inc.

135  {
136  }

◆ renderSearchScript()

DateOfBirthFieldRenderer::renderSearchScript (   $field,
  $mode 
)

FieldRenderers can override this method to provide any Javascript that the control requires when being used in a search form.

Parameters
string$fieldthe field name
string$modethe search mode for the specific field ('equal', 'like', 'from', 'to', 'range')

Reimplemented from FieldRenderer.

Definition at line 130 of file date_of_birth_field_renderer.inc.

131  {
132  }

◆ setMinimumAge()

DateOfBirthFieldRenderer::setMinimumAge (   $min,
  $message = "" 
)

Definition at line 72 of file date_of_birth_field_renderer.inc.

73  {
74  $this->minimumAge = $min;
75  $this->minimumAgeMessage = $message ? $message : "You must be at least {$min} years of age";
76  return $this;
77  }

Member Data Documentation

◆ $minimumAge

DateOfBirthFieldRenderer::$minimumAge = 0

Definition at line 47 of file date_of_birth_field_renderer.inc.

◆ $minimumAgeMessage

DateOfBirthFieldRenderer::$minimumAgeMessage = ""

Definition at line 48 of file date_of_birth_field_renderer.inc.

◆ $template

DateOfBirthFieldRenderer::$template = ""

Definition at line 46 of file date_of_birth_field_renderer.inc.


The documentation for this class was generated from the following file: