'HTMLText', // From CustomSettings 'HideFromReports' => 'Boolean(0)' // from CustomSettings ); private static $defaults = array( 'HideFromReports' => false ); /** * Returns the {@see HtmlEditorConfig} instance to use for sanitisation * * @return HtmlEditorConfig */ protected function getEditorConfig() { $editorConfig = $this->config()->editor_config; if($editorConfig) return HtmlEditorConfig::get($editorConfig); return HtmlEditorConfig::get_active(); } /** * Safely sanitise html content, if enabled * * @param string $content Raw html * @return string Safely sanitised html */ protected function sanitiseContent($content) { // Check if sanitisation is enabled if(!HtmlEditorField::config()->sanitise_server_side) return $content; // Perform sanitisation $htmlValue = Injector::inst()->create('HTMLValue', $content); $santiser = Injector::inst()->create('HtmlEditorSanitiser', $this->getEditorConfig()); $santiser->sanitise($htmlValue); return $htmlValue->getContent(); } /** * Get HTML Content of this literal field * * @return string */ public function getContent() { // Apply html editor sanitisation rules $content = $this->getField('Content'); return $this->sanitiseContent($content); } /** * Set the content with the given value * * @param string $content */ public function setContent($content) { // Apply html editor sanitisation rules $content = $this->sanitiseContent($content); $this->setField('Content', $content); } /** * @return FieldList */ public function getCMSFields() { $fields = parent::getCMSFields(); $fields->removeByName('Default'); $fields->removeByName('Validation'); $fields->addFieldsToTab('Root.Main', array( HTMLEditorField::create('Content', _t('EditableLiteralField.CONTENT', 'HTML')) ->setRows(4) ->setColumns(20), CheckboxField::create( 'HideFromReports', _t('EditableLiteralField.HIDEFROMREPORT', 'Hide from reports?') ) )); return $fields; } public function getFormField() { // Build label and css classes $label = ''; $classes = $this->ExtraClass; if(empty($this->Title)) { $classes .= " nolabel"; } else { $label = ""; } $field = new LiteralField( "LiteralField[{$this->ID}]", sprintf( "
%s
%s
". "
", Convert::raw2htmlname($this->Name), Convert::raw2att($classes), $label, $this->Content ) ); // When dealing with literal fields there is no further customisation that can be added at this point return $field; } public function showInReports() { return ! $this->HideFromReports; } }