Merge pull request #8359 from creative-commoners/pulls/4/HTMLEditorSchema

Add schema information for HTMLEditorField
This commit is contained in:
Robbie Averill 2018-09-10 09:53:12 +02:00 committed by GitHub
commit b555bb83b8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 32 additions and 0 deletions

View File

@ -224,4 +224,17 @@ abstract class HTMLEditorConfig
* Initialise the editor on the client side * Initialise the editor on the client side
*/ */
abstract public function init(); abstract public function init();
/**
* Provide additional schema data for the field this object configures
*
* @return array
*/
public function getConfigSchemaData()
{
return [
'attributes' => $this->getAttributes(),
'editorjs' => null,
];
}
} }

View File

@ -3,6 +3,7 @@
namespace SilverStripe\Forms\HTMLEditor; namespace SilverStripe\Forms\HTMLEditor;
use SilverStripe\Assets\Shortcodes\ImageShortcodeProvider; use SilverStripe\Assets\Shortcodes\ImageShortcodeProvider;
use SilverStripe\Forms\FormField;
use SilverStripe\Forms\TextareaField; use SilverStripe\Forms\TextareaField;
use SilverStripe\ORM\DataObject; use SilverStripe\ORM\DataObject;
use SilverStripe\ORM\DataObjectInterface; use SilverStripe\ORM\DataObjectInterface;
@ -23,6 +24,10 @@ class HTMLEditorField extends TextareaField
'Value' => 'HTMLText', 'Value' => 'HTMLText',
]; ];
protected $schemaDataType = FormField::SCHEMA_DATA_TYPE_HTML;
protected $schemaComponent = 'HtmlEditorField';
/** /**
* Use TinyMCE's GZIP compressor * Use TinyMCE's GZIP compressor
* *
@ -185,4 +190,12 @@ class HTMLEditorField extends TextareaField
$this->getEditorConfig()->init(); $this->getEditorConfig()->init();
return parent::Field($properties); return parent::Field($properties);
} }
public function getSchemaStateDefaults()
{
$stateDefaults = parent::getSchemaStateDefaults();
$config = $this->getEditorConfig();
$stateDefaults['data'] = $config->getConfigSchemaData();
return $stateDefaults;
}
} }

View File

@ -751,6 +751,12 @@ class TinyMCEConfig extends HTMLEditorConfig
Requirements::javascript($this->getScriptURL()); Requirements::javascript($this->getScriptURL());
} }
public function getConfigSchemaData()
{
$data = parent::getConfigSchemaData();
$data['editorjs'] = $this->getScriptURL();
return $data;
}
/** /**
* Get the current tinyMCE language * Get the current tinyMCE language