2009-03-25 03:37:49 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
2009-04-17 02:26:40 +00:00
|
|
|
* Editable Literal Field. A literal field is just a blank slate where
|
|
|
|
* you can add your own HTML / Images / Flash
|
2009-03-25 03:37:49 +00:00
|
|
|
*
|
2009-04-17 02:26:40 +00:00
|
|
|
* @package userforms
|
2009-03-25 03:37:49 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
class EditableLiteralField extends EditableFormField {
|
|
|
|
|
|
|
|
static $db = array(
|
|
|
|
'Content' => 'Text'
|
|
|
|
);
|
|
|
|
|
2009-03-25 05:25:50 +00:00
|
|
|
static $singular_name = 'HTML Block';
|
2009-03-25 03:37:49 +00:00
|
|
|
|
2009-04-17 02:26:40 +00:00
|
|
|
static $plural_name = 'HTML Blocks';
|
2009-03-25 03:37:49 +00:00
|
|
|
|
|
|
|
function ExtraOptions() {
|
|
|
|
// eventually replace hard-coded "Fields"?
|
|
|
|
$baseName = "Fields[$this->ID]";
|
|
|
|
|
|
|
|
$extraFields = new FieldSet();
|
|
|
|
$extraFields->push(new TextareaField($baseName . "[Content]", "Text", 4, 20, $this->Content));
|
|
|
|
|
|
|
|
return $extraFields;
|
|
|
|
}
|
|
|
|
|
|
|
|
function populateFromPostData($data) {
|
|
|
|
$this->Content = $data['Content'];
|
|
|
|
parent::populateFromPostData($data);
|
|
|
|
}
|
|
|
|
|
|
|
|
function createField() {
|
|
|
|
return new LiteralField("LiteralField[$this->ID]",
|
2009-04-13 21:53:18 +00:00
|
|
|
"<div class='field text'><label class='left'>$this->Title</label><div class='middleColumn literalFieldArea'>". $this->Content."</div></div>");
|
2009-03-25 03:37:49 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
?>
|