2008-09-29 03:18:23 +00:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* Data received from a UserDefinedForm submission
|
2009-04-15 04:23:43 +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 SubmittedFormField extends DataObject {
|
2015-09-11 10:20:06 +12:00
|
|
|
|
2013-04-02 18:34:43 -07:00
|
|
|
private static $db = array(
|
2008-09-29 03:18:23 +00:00
|
|
|
"Name" => "Varchar",
|
|
|
|
"Value" => "Text",
|
2009-11-24 20:11:50 +00:00
|
|
|
"Title" => "Varchar(255)"
|
2008-09-29 03:18:23 +00:00
|
|
|
);
|
2015-09-11 10:20:06 +12:00
|
|
|
|
2013-04-02 18:34:43 -07:00
|
|
|
private static $has_one = array(
|
2008-09-29 03:18:23 +00:00
|
|
|
"Parent" => "SubmittedForm"
|
|
|
|
);
|
2013-03-05 10:45:54 +13:00
|
|
|
|
2013-04-02 18:34:43 -07:00
|
|
|
private static $summary_fields = array(
|
2013-09-05 09:46:38 +12:00
|
|
|
'Title' => 'Title',
|
2013-03-05 10:45:54 +13:00
|
|
|
'FormattedValue' => 'Value'
|
|
|
|
);
|
|
|
|
|
2013-05-13 14:32:41 +12:00
|
|
|
/**
|
|
|
|
* @param Member
|
|
|
|
*
|
|
|
|
* @return boolean
|
|
|
|
*/
|
|
|
|
public function canCreate($member = null) {
|
|
|
|
return $this->Parent()->canCreate();
|
|
|
|
}
|
|
|
|
|
2013-05-01 10:49:57 +12:00
|
|
|
/**
|
|
|
|
* @param Member
|
|
|
|
*
|
|
|
|
* @return boolean
|
|
|
|
*/
|
|
|
|
public function canView($member = null) {
|
|
|
|
return $this->Parent()->canView();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param Member
|
|
|
|
*
|
|
|
|
* @return boolean
|
|
|
|
*/
|
|
|
|
public function canEdit($member = null) {
|
|
|
|
return $this->Parent()->canEdit();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param Member
|
|
|
|
*
|
|
|
|
* @return boolean
|
|
|
|
*/
|
|
|
|
public function canDelete($member = null) {
|
|
|
|
return $this->Parent()->canDelete();
|
|
|
|
}
|
|
|
|
|
2010-05-16 03:55:03 +00:00
|
|
|
/**
|
|
|
|
* Generate a formatted value for the reports and email notifications.
|
|
|
|
* Converts new lines (which are stored in the database text field) as
|
|
|
|
* <brs> so they will output as newlines in the reports
|
|
|
|
*
|
2012-05-07 21:19:16 +12:00
|
|
|
* @return string
|
2010-05-16 03:55:03 +00:00
|
|
|
*/
|
2012-05-04 13:39:08 +12:00
|
|
|
public function getFormattedValue() {
|
2011-12-05 23:19:20 +13:00
|
|
|
return nl2br($this->dbObject('Value')->ATT());
|
2010-05-16 03:55:03 +00:00
|
|
|
}
|
2015-09-11 10:20:06 +12:00
|
|
|
|
2012-05-07 21:19:16 +12:00
|
|
|
/**
|
|
|
|
* Return the value of this submitted form field suitable for inclusion
|
|
|
|
* into the CSV
|
|
|
|
*
|
|
|
|
* @return Text
|
|
|
|
*/
|
|
|
|
public function getExportValue() {
|
|
|
|
return $this->Value;
|
|
|
|
}
|
2014-08-11 11:12:00 +12:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Find equivalent editable field for this submission.
|
|
|
|
*
|
|
|
|
* Note the field may have been modified or deleted from the original form
|
|
|
|
* so this may not always return the data you expect. If you need to save
|
2015-09-11 10:20:06 +12:00
|
|
|
* a particular state of editable form field at time of submission, copy
|
2014-08-11 11:12:00 +12:00
|
|
|
* that value to the submission.
|
|
|
|
*
|
|
|
|
* @return EditableFormField
|
|
|
|
*/
|
|
|
|
public function getEditableField() {
|
|
|
|
return $this->Parent()->Parent()->Fields()->filter(array(
|
|
|
|
'Name' => $this->Name
|
|
|
|
))->First();
|
|
|
|
}
|
2008-09-29 03:18:23 +00:00
|
|
|
}
|