wymeditor.inc in Wysiwyg 6.2
Same filename and directory in other branches
Editor integration functions for WYMeditor.
File
editors/wymeditor.incView source
<?php
/**
* @file
* Editor integration functions for WYMeditor.
*/
/**
* Plugin implementation of hook_editor().
*/
function wysiwyg_wymeditor_editor() {
$editor['wymeditor'] = array(
'title' => 'WYMeditor',
'vendor url' => 'https://wymeditor.github.io/wymeditor/',
'download url' => 'https://github.com/wymeditor/wymeditor/releases',
'libraries' => array(
'min' => array(
'title' => 'Minified',
'files' => array(
'jquery.wymeditor.min.js',
),
),
'src' => array(
'title' => 'Source',
'files' => array(
'jquery.wymeditor.js',
),
),
),
'verified version range' => array(
'0.5',
'1.1.1',
),
'version callback' => 'wysiwyg_wymeditor_version',
'themes callback' => 'wysiwyg_wymeditor_themes',
'settings form callback' => 'wysiwyg_wymeditor_settings_form',
'settings callback' => 'wysiwyg_wymeditor_settings',
'plugin callback' => '_wysiwyg_wymeditor_plugins',
'versions' => array(
'0.5-rc1' => array(
'js files' => array(
'wymeditor.js',
),
),
'1.0.0a1' => array(
'js files' => array(
'wymeditor-1.js',
),
'css files' => array(
'wymeditor.css',
),
),
),
);
return $editor;
}
/**
* Detect editor version.
*
* @param $editor
* An array containing editor properties as returned from hook_editor().
*
* @return
* The installed editor version.
*/
function wysiwyg_wymeditor_version(&$editor) {
$script = $editor['library path'] . '/jquery.wymeditor.js';
if (!file_exists($script)) {
$script = $editor['library path'] . '/wymeditor/jquery.wymeditor.js';
if (!file_exists($script)) {
return;
}
$editor['library path'] .= '/wymeditor';
$editor['editor path'] .= '/wymeditor';
}
$script = fopen($script, 'r');
for ($i = 0; $i < 189; $i++) {
$line = fgets($script);
if (preg_match('@version\\s+([0-9\\.]+(?:-?[a-z0-9\\.]+)?[^\\.])@', $line, $version)) {
fclose($script);
return trim($version[1]);
}
}
fclose($script);
}
/**
* Determine available editor themes or check/reset a given one.
*
* @param $editor
* A processed hook_editor() array of editor properties.
* @param $profile
* A wysiwyg editor profile.
*
* @return
* An array of theme names. The first returned name should be the default
* theme name.
*/
function wysiwyg_wymeditor_themes($editor, $profile) {
return array(
'compact',
'default',
'minimal',
'silver',
'twopanels',
);
}
/**
* Enhances the editor profile settings form for WYMeditor.
*
* @see http://wymeditor.readthedocs.org/en/latest/version_1.0_and_0.5/getting_started/customize.html
*/
function wysiwyg_wymeditor_settings_form(&$form, &$form_state) {
$profile = $form_state['wysiwyg_profile'];
$settings = $profile->settings;
$settings += array(
'block_formats' => 'p,blockquote,pre,h2,h3,h4,h5,h6,div',
);
$form['css']['#description'] = t('Note: WYMeditor can only load a single stylesheet into the editor.');
$form['css']['block_formats'] = array(
'#type' => 'textfield',
'#title' => t('Block formats'),
'#default_value' => $settings['block_formats'],
'#size' => 40,
'#maxlength' => 250,
'#description' => t('Comma separated list of HTML block formats. Possible values: <code>@format-list</code>.', array(
'@format-list' => 'p,h1,h2,h3,h4,h5,h6,blockquote,pre,th',
)),
);
}
/**
* Return runtime editor settings for a given wysiwyg profile.
*
* @param $editor
* A processed hook_editor() array of editor properties.
* @param $config
* An array containing wysiwyg editor profile settings.
* @param $theme
* The name of a theme/GUI/skin to use.
*
* @return
* A settings array to be populated in
* Drupal.settings.wysiwyg.configs.{editor}
*/
function wysiwyg_wymeditor_settings($editor, $config, $theme) {
// @todo Setup $library in wysiwyg_load_editor() already.
$library = isset($editor['library']) ? $editor['library'] : key($editor['libraries']);
$settings = array(
'basePath' => base_path() . $editor['library path'] . '/',
'wymPath' => $editor['libraries'][$library]['files'][0],
// WYMeditor's update event handler will revert the field contents if
// changes were made after it was detached. Wysiwyg takes care of submit
// events anyway so make sure WYMeditor does not bind it anywhere.
'updateSelector' => '#wysiwyg-no-element',
'updateEvent' => 'wysiwyg-no-event',
'skin' => $theme,
);
if (version_compare($editor['installed version'], '1.0.0-b5', '>=')) {
drupal_add_css($editor['library path'] . '/skins/' . $settings['skin'] . '/skin.css');
}
else {
// @todo Does not work in Drupal; jQuery can live anywhere.
$settings['jQueryPath'] = base_path() . 'misc/jquery.js';
}
if (isset($config['language'])) {
$settings['lang'] = $config['language'];
}
// Add configured buttons.
$settings['toolsItems'] = array();
if (!empty($config['buttons'])) {
$buttoninfo = _wysiwyg_wymeditor_button_info($editor['installed version']);
$plugins = wysiwyg_get_plugins($editor['name']);
foreach ($config['buttons'] as $plugin => $buttons) {
foreach ($buttons as $button => $enabled) {
// Iterate separately over buttons and extensions properties.
foreach (array(
'buttons',
'extensions',
) as $type) {
// Skip unavailable plugins.
if (!isset($plugins[$plugin][$type][$button])) {
continue;
}
// Add buttons.
if ($type == 'buttons') {
// Merge meta-data for internal default buttons.
if (isset($buttoninfo[$button])) {
$buttoninfo[$button] += array(
'name' => $button,
);
$settings['toolsItems'][] = $buttoninfo[$button];
}
else {
$settings['toolsItems'][] = array(
'name' => $button,
'title' => $plugins[$plugin][$type][$button],
'css' => 'wym_tools_' . $button,
);
}
}
}
}
}
}
if (!empty($config['block_formats'])) {
$containers = array(
'p' => 'Paragraph',
'h1' => 'Heading_1',
'h2' => 'Heading_2',
'h3' => 'Heading_3',
'h4' => 'Heading_4',
'h5' => 'Heading_5',
'h6' => 'Heading_6',
'pre' => 'Preformatted',
'blockquote' => 'Blockquote',
'th' => 'Table_Header',
);
foreach (explode(',', preg_replace('@\\s+@', '', $config['block_formats'])) as $tag) {
if (isset($containers[$tag])) {
$settings['containersItems'][] = array(
'name' => strtoupper($tag),
'title' => $containers[$tag],
'css' => 'wym_containers_' . $tag,
);
}
}
}
// Add editor content stylesheet.
if (isset($config['css_setting'])) {
if ($config['css_setting'] == 'theme') {
// WYMeditor only supports one CSS file currently.
$css = wysiwyg_get_css();
$settings['stylesheet'] = reset($css);
}
elseif ($config['css_setting'] == 'self' && isset($config['css_path'])) {
$settings['stylesheet'] = strtr($config['css_path'], array(
'%b' => base_path(),
'%t' => path_to_theme(),
'%q' => variable_get('css_js_query_string', ''),
));
}
}
return $settings;
}
/**
* Return internal plugins for this editor; semi-implementation of hook_wysiwyg_plugin().
*/
function _wysiwyg_wymeditor_plugins($editor) {
$plugins = array(
'default' => array(
'buttons' => array(
'Bold' => t('Bold'),
'Italic' => t('Italic'),
'InsertOrderedList' => t('Numbered list'),
'InsertUnorderedList' => t('Bullet list'),
'Outdent' => t('Outdent'),
'Indent' => t('Indent'),
'Undo' => t('Undo'),
'Redo' => t('Redo'),
'CreateLink' => t('Link'),
'Unlink' => t('Unlink'),
'InsertImage' => t('Image'),
'Superscript' => t('Superscript'),
'Subscript' => t('Subscript'),
'ToggleHtml' => t('Source code'),
'Paste' => t('Paste'),
'InsertTable' => t('Table'),
'Preview' => t('Preview'),
),
'internal' => TRUE,
),
);
return $plugins;
}
/**
* Helper function to provide additional meta-data for internal default buttons.
*/
function _wysiwyg_wymeditor_button_info($version) {
$info = array(
'Bold' => array(
'title' => 'Strong',
'css' => 'wym_tools_strong',
),
'Italic' => array(
'title' => 'Emphasis',
'css' => 'wym_tools_emphasis',
),
'Superscript' => array(
'title' => 'Superscript',
'css' => 'wym_tools_superscript',
),
'Subscript' => array(
'title' => 'Subscript',
'css' => 'wym_tools_subscript',
),
'InsertOrderedList' => array(
'title' => 'Ordered_List',
'css' => 'wym_tools_ordered_list',
),
'InsertUnorderedList' => array(
'title' => 'Unordered_List',
'css' => 'wym_tools_unordered_list',
),
'Indent' => array(
'title' => 'Indent',
'css' => 'wym_tools_indent',
),
'Outdent' => array(
'title' => 'Outdent',
'css' => 'wym_tools_outdent',
),
'Undo' => array(
'title' => 'Undo',
'css' => 'wym_tools_undo',
),
'Redo' => array(
'title' => 'Redo',
'css' => 'wym_tools_redo',
),
'CreateLink' => array(
'title' => 'Link',
'css' => 'wym_tools_link',
),
'Unlink' => array(
'title' => 'Unlink',
'css' => 'wym_tools_unlink',
),
'InsertImage' => array(
'title' => 'Image',
'css' => 'wym_tools_image',
),
'InsertTable' => array(
'title' => 'Table',
'css' => 'wym_tools_table',
),
'Paste' => array(
'title' => 'Paste_From_Word',
'css' => 'wym_tools_paste',
),
'ToggleHtml' => array(
'title' => 'HTML',
'css' => 'wym_tools_html',
),
'Preview' => array(
'title' => 'Preview',
'css' => 'wym_tools_preview',
),
);
if (version_compare($version, '1.0.0-rc2', '>=')) {
foreach (array(
'CreateLink',
'InsertImage',
'InsertTable',
'Paste',
'Preview',
) as $button) {
$info[$button]['css'] .= ' wym_opens_dialog';
}
}
return $info;
}
Functions
Name | Description |
---|---|
wysiwyg_wymeditor_editor | Plugin implementation of hook_editor(). |
wysiwyg_wymeditor_settings | Return runtime editor settings for a given wysiwyg profile. |
wysiwyg_wymeditor_settings_form | Enhances the editor profile settings form for WYMeditor. |
wysiwyg_wymeditor_themes | Determine available editor themes or check/reset a given one. |
wysiwyg_wymeditor_version | Detect editor version. |
_wysiwyg_wymeditor_button_info | Helper function to provide additional meta-data for internal default buttons. |
_wysiwyg_wymeditor_plugins | Return internal plugins for this editor; semi-implementation of hook_wysiwyg_plugin(). |