toastnz / open-cms-preview
Force SilverStripe to open the CMS preview panel on any page with a form
Installs: 81
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 0
Language:JavaScript
Type:silverstripe-vendormodule
Requires
- php: >=8.3
- composer/installers: *
- silverstripe/cms: ^6
README
This module allows you to open the CMS preview panel from any page in the CMS that has a form.
Installation
To install the module, use Composer:
composer require toastnz/open-cms-preview
Usage
To use the module, simply add the following form field to any form in the CMS:
use Toast\OpenCmsPreview\Fields\OpenCmsPreview; public function getCMSFields() { $fields = parent::getCMSFields(); $fields->addFieldsToTab('Root.Main', [ OpenCmsPreview::create($this->getPreviewLink()); ]); return $fields; } public function getPreviewLink() { // Return the link to the page you want to preview }
Extending the controller
The module adds a new OpenCMSPreviewController to the window which you can extend to add custom functionality.
The refresh event is called when the Controller observes an ajax / fetch event with some basic and conditional checks to determine when the refresh should be called or prevented. You can use the on('beforeRefresh') event to add custom functionality before the refresh is called.
Additionally you can call event.preventRefresh(); to prevent the refresh from being called.
// Example usage window.OpenCMSPreviewController.on('beforeRefresh', (event) => { // This event data also includes the ajax / fetch response console.log(event.data); // Prevent the refresh from being called if some condition is met if (event.data.someKey == 'someValue') { event.preventRefresh(); } });
You also have access to a few other events:
// When the refresh is complete on('refresh', (iframeSrc) => {}); // Before the preview refresh script has run on('beforeRefresh', (event) => {}); // After the preview has been added to the page on('addPreview', (previewElement) => {}); // After the preview has been removed from the page on('removePreview', () => {});