From c2f3993fc109876f4533d859acc1a7bbdc73e92f Mon Sep 17 00:00:00 2001 From: Dmitriy Simushev Date: Tue, 5 Feb 2013 08:25:34 +0000 Subject: [PATCH] Use 'pageAdd*' events instead of special plugins methods --- src/messenger/webim/libs/common/response.php | 110 +++++++++++-------- 1 file changed, 65 insertions(+), 45 deletions(-) diff --git a/src/messenger/webim/libs/common/response.php b/src/messenger/webim/libs/common/response.php index 288bbaac..ab39f83a 100644 --- a/src/messenger/webim/libs/common/response.php +++ b/src/messenger/webim/libs/common/response.php @@ -65,78 +65,98 @@ function topage($text) } /** - * Load additional CSS files, required by plugins, and build HTML code to include them + * Load additional CSS files, required by plugins, and build HTML code to + * include them + * + * Triggers 'pageAddCSS' and pass listeners associative array with + * following keys: + * - 'page': string, name of page to which CSS files will be attached. + * - 'js': array, with CSS files paths. Modify this array to add or remove + * additional CSS files. * * @param string $page_name CSS files load to this page * @return string HTML block of 'link' tags */ function get_additional_css($page_name) { - $method = $page_name . 'AddCss'; - $plugins = PluginManager::getAllPlugins(); + // Prepare event arguments array + $args = array( + 'page' => $page_name, + 'css' => array() + ); + + // Trigger event + $dispatcher = EventDispatcher::getInstance(); + $dispatcher->triggerEvent('pageAddCSS', $args); + + // Build resulting css list $result = array(); - // Check all plugins - foreach ($plugins as $plugin) { - if (is_callable(array($plugin, $method))) { - // Try to invoke '<$page_name>AddCss' method - $css_list = $plugin->$method(); - foreach ($css_list as $css) { - // Add script tag for each javascript file - $result[] = ''; - } - } + foreach($args['css'] as $css) { + $result[] = ''; } + return implode("\n", $result); } /** - * Load additional JavaScript files, required by plugins, and build HTML code to include them + * Load additional JavaScript files, required by plugins, and build HTML code + * to include them + * + * Triggers 'pageAddJS' and pass listeners associative array with + * following keys: + * - 'page': string, name of page to which JavaScript files will be attached. + * - 'js': array, with JavaScript files paths. Modify this array to add or + * remove additional JavaScript files. * * @param string $page_name JavaScript files load to this page * @return string HTML block of 'script' tags */ function get_additional_js($page_name) { - $method = $page_name . 'AddJs'; - $plugins = PluginManager::getAllPlugins(); + // Prepare event arguments array + $args = array( + 'page' => $page_name, + 'js' => array() + ); + + // Trigger event + $dispatcher = EventDispatcher::getInstance(); + $dispatcher->triggerEvent('pageAddJS', $args); + + // Build resulting css list $result = array(); - // Check all plugins - foreach ($plugins as $plugin) { - if (is_callable(array($plugin, $method))) { - // Try to invoke '<$page_name>AddJs' method - $js_list = $plugin->$method(); - foreach ($js_list as $js) { - // Add script tag for each javascript file - $result[] = ''; - } - } + foreach($args['js'] as $js) { + $result[] = ''; } + return implode("\n", $result); } + /** - * Build Javascript code that contains initializing options for JavaScript plugins + * Build Javascript code that contains initializing options for JavaScript + * plugins + * + * Triggers 'pageAddJSPluginOptions' and pass listeners associative array with + * following keys: + * - 'page': string, name of page at which plugins will work. + * - 'plugins': associative array, whose keys are plugins names and values are + * plugins options. Modify this array to add or change plugins options * * @param string $page_name Plugins initialize at this page * @return string JavaScript options block */ function get_js_plugin_options($page_name) { - $method = $page_name . 'AddJsPluginOptions'; - $plugins = PluginManager::getAllPlugins(); - $result = array(); - // Check all plugins - foreach ($plugins as $plugin) { - if (is_callable(array($plugin, $method))) { - // Try to invoke '<$page_name>AddJsPluginOptions' method - $js_plugins = $plugin->$method(); - foreach ($js_plugins as $js_plugin => $js_options) { - // Add plugin's initialization options code - if (empty($result[$js_plugin])) { - $result[$js_plugin] = array(); - } - $result[$js_plugin] = array_merge($result[$js_plugin], $js_options); - } - } - } - return json_encode($result); + // Prepare event arguments array + $args = array( + 'page' => $page_name, + 'plugins' => array() + ); + + // Trigger event + $dispatcher = EventDispatcher::getInstance(); + $dispatcher->triggerEvent('pageAddJSPluginOptions', $args); + + // Return encoded options + return json_encode($args['plugins']); } function no_field($key)