annotate sites/all/modules/ctools/includes/export-ui.inc @ 0:ff03f76ab3fe

initial version
author danieleb <danielebarchiesi@me.com>
date Wed, 21 Aug 2013 18:51:11 +0100
parents
children
rev   line source
danielebarchiesi@0 1 <?php
danielebarchiesi@0 2
danielebarchiesi@0 3 /**
danielebarchiesi@0 4 * @file
danielebarchiesi@0 5 * Provide a tool for creating UIs for exportable objects.
danielebarchiesi@0 6 *
danielebarchiesi@0 7 * See Advanced Help for documentation.
danielebarchiesi@0 8 */
danielebarchiesi@0 9
danielebarchiesi@0 10 /**
danielebarchiesi@0 11 * Process an export-ui plugin to provide it with defaults.
danielebarchiesi@0 12 */
danielebarchiesi@0 13 function ctools_export_ui_process(&$plugin, $info) {
danielebarchiesi@0 14 ctools_include('export');
danielebarchiesi@0 15
danielebarchiesi@0 16 $plugin += array(
danielebarchiesi@0 17 'has menu' => TRUE,
danielebarchiesi@0 18 'title' => $plugin['name'],
danielebarchiesi@0 19 'export' => array(),
danielebarchiesi@0 20 'allowed operations' => array(),
danielebarchiesi@0 21 'menu' => array(),
danielebarchiesi@0 22 'redirect' => array(),
danielebarchiesi@0 23 'form' => array(),
danielebarchiesi@0 24 'strings' => array(),
danielebarchiesi@0 25 'list' => NULL,
danielebarchiesi@0 26 'access' => 'administer site configuration',
danielebarchiesi@0 27 );
danielebarchiesi@0 28
danielebarchiesi@0 29 // Provide CRUD access defaults based on the base 'access' setting:
danielebarchiesi@0 30 $plugin += array(
danielebarchiesi@0 31 'create access' => $plugin['access'],
danielebarchiesi@0 32 'delete access' => $plugin['access'],
danielebarchiesi@0 33 );
danielebarchiesi@0 34
danielebarchiesi@0 35 if (empty($plugin['has menu'])) {
danielebarchiesi@0 36 return;
danielebarchiesi@0 37 }
danielebarchiesi@0 38
danielebarchiesi@0 39 // The following keys are required and the plugin cannot be processed
danielebarchiesi@0 40 // without them.
danielebarchiesi@0 41 $keys = array(
danielebarchiesi@0 42 'title singular',
danielebarchiesi@0 43 'title plural',
danielebarchiesi@0 44 'title singular proper',
danielebarchiesi@0 45 'title plural proper',
danielebarchiesi@0 46 'schema',
danielebarchiesi@0 47 );
danielebarchiesi@0 48
danielebarchiesi@0 49 foreach ($keys as $key) {
danielebarchiesi@0 50 if (empty($plugin[$key])) {
danielebarchiesi@0 51 drupal_set_message(t('The plugin definition of @plugin is missing the %key key.', array('%key' => $key, '@plugin' => $plugin['name'])), 'error');
danielebarchiesi@0 52 }
danielebarchiesi@0 53 }
danielebarchiesi@0 54
danielebarchiesi@0 55 // If we're on the modules page and building a menu, there is a design flaw
danielebarchiesi@0 56 // in Drupal core that causes modules to be installed but the schema does
danielebarchiesi@0 57 // not become available until AFTER menu rebuild. This helps smooth that
danielebarchiesi@0 58 // out. This is a HACK but it should work:
danielebarchiesi@0 59 $schema = ctools_export_get_schema($plugin['schema']);
danielebarchiesi@0 60
danielebarchiesi@0 61 if (empty($schema)) {
danielebarchiesi@0 62 // If we're updating the schema may not have been read yet, so don't report this error in that case.
danielebarchiesi@0 63 if (!defined('MAINTENANCE_MODE')) {
danielebarchiesi@0 64 drupal_set_message(t('The plugin definition of @plugin cannot locate schema %schema.', array('%schema' => $plugin['schema'], '@plugin' => $plugin['name'])), 'error');
danielebarchiesi@0 65 }
danielebarchiesi@0 66 return;
danielebarchiesi@0 67 }
danielebarchiesi@0 68
danielebarchiesi@0 69 if (empty($schema['export'])) {
danielebarchiesi@0 70 drupal_set_message(t('The plugin definition of @plugin uses %schema, but it has no export section.', array('%schema' => $plugin['schema'], '@plugin' => $plugin['name'])), 'error');
danielebarchiesi@0 71 return;
danielebarchiesi@0 72 }
danielebarchiesi@0 73 $plugin['export'] += $schema['export'];
danielebarchiesi@0 74
danielebarchiesi@0 75 $plugin['export'] += array(
danielebarchiesi@0 76 // Add the identifier key from the schema so we don't have to call
danielebarchiesi@0 77 // ctools_export_get_schema() just for that.
danielebarchiesi@0 78 'key' => $schema['export']['key'],
danielebarchiesi@0 79 );
danielebarchiesi@0 80
danielebarchiesi@0 81 // Add some default fields that appear often in exports
danielebarchiesi@0 82 // If these use different keys they can easily be specified in the
danielebarchiesi@0 83 // $plugin.
danielebarchiesi@0 84
danielebarchiesi@0 85 if (empty($plugin['export']['admin_title']) && !empty($schema['fields']['admin_title'])) {
danielebarchiesi@0 86 $plugin['export']['admin_title'] = 'admin_title';
danielebarchiesi@0 87 }
danielebarchiesi@0 88 if (empty($plugin['export']['admin_description']) && !empty($schema['fields']['admin_description'])) {
danielebarchiesi@0 89 $plugin['export']['admin_description'] = 'admin_description';
danielebarchiesi@0 90 }
danielebarchiesi@0 91
danielebarchiesi@0 92 // Define allowed operations, and the name of the operations.
danielebarchiesi@0 93 $plugin['allowed operations'] += array(
danielebarchiesi@0 94 'edit' => array('title' => t('Edit')),
danielebarchiesi@0 95 'enable' => array('title' => t('Enable'), 'ajax' => TRUE, 'token' => TRUE),
danielebarchiesi@0 96 'disable' => array('title' => t('Disable'), 'ajax' => TRUE, 'token' => TRUE),
danielebarchiesi@0 97 'revert' => array('title' => t('Revert')),
danielebarchiesi@0 98 'delete' => array('title' => t('Delete')),
danielebarchiesi@0 99 'clone' => array('title' => t('Clone')),
danielebarchiesi@0 100 'import' => array('title' => t('Import')),
danielebarchiesi@0 101 'export' => array('title' => t('Export')),
danielebarchiesi@0 102 );
danielebarchiesi@0 103
danielebarchiesi@0 104 $plugin['menu'] += array(
danielebarchiesi@0 105 'menu item' => str_replace(' ', '-', $plugin['name']),
danielebarchiesi@0 106 'menu prefix' => 'admin/structure',
danielebarchiesi@0 107 'menu title' => $plugin['title'],
danielebarchiesi@0 108 'menu description' => '',
danielebarchiesi@0 109 );
danielebarchiesi@0 110 $base_path = ctools_export_ui_plugin_base_path($plugin);
danielebarchiesi@0 111 $prefix_count = count(explode('/', $plugin['menu']['menu prefix']));
danielebarchiesi@0 112
danielebarchiesi@0 113 $plugin['menu'] += array(
danielebarchiesi@0 114 // Default menu items that should be declared.
danielebarchiesi@0 115 'items' => array(),
danielebarchiesi@0 116 );
danielebarchiesi@0 117
danielebarchiesi@0 118 $plugin['menu']['items'] += array(
danielebarchiesi@0 119 'list callback' => array(),
danielebarchiesi@0 120 'list' => array(),
danielebarchiesi@0 121 'add' => array(),
danielebarchiesi@0 122 'edit callback' => array(),
danielebarchiesi@0 123 'edit' => array(),
danielebarchiesi@0 124 );
danielebarchiesi@0 125
danielebarchiesi@0 126 $plugin['menu']['items']['list callback'] += array(
danielebarchiesi@0 127 'path' => '',
danielebarchiesi@0 128 // Menu items are translated by the menu system.
danielebarchiesi@0 129 // TODO: We need more flexibility in title. The title of the admin page
danielebarchiesi@0 130 // is not necessarily the title of the object, plus we need
danielebarchiesi@0 131 // plural, singular, proper, not proper, etc.
danielebarchiesi@0 132 'title' => $plugin['menu']['menu title'],
danielebarchiesi@0 133 'description' => $plugin['menu']['menu description'],
danielebarchiesi@0 134 'page callback' => 'ctools_export_ui_switcher_page',
danielebarchiesi@0 135 'page arguments' => array($plugin['name'], 'list'),
danielebarchiesi@0 136 'access callback' => 'ctools_export_ui_task_access',
danielebarchiesi@0 137 'access arguments' => array($plugin['name'], 'list'),
danielebarchiesi@0 138 'type' => MENU_NORMAL_ITEM,
danielebarchiesi@0 139 );
danielebarchiesi@0 140
danielebarchiesi@0 141 $plugin['menu']['items']['list'] += array(
danielebarchiesi@0 142 'path' => 'list',
danielebarchiesi@0 143 'title' => 'List',
danielebarchiesi@0 144 'page callback' => 'ctools_export_ui_switcher_page',
danielebarchiesi@0 145 'page arguments' => array($plugin['name'], 'list'),
danielebarchiesi@0 146 'access callback' => 'ctools_export_ui_task_access',
danielebarchiesi@0 147 'access arguments' => array($plugin['name'], 'list'),
danielebarchiesi@0 148 'type' => MENU_DEFAULT_LOCAL_TASK,
danielebarchiesi@0 149 'weight' => -10,
danielebarchiesi@0 150 );
danielebarchiesi@0 151
danielebarchiesi@0 152 $plugin['menu']['items']['add'] += array(
danielebarchiesi@0 153 'path' => 'add',
danielebarchiesi@0 154 'title' => 'Add',
danielebarchiesi@0 155 'page callback' => 'ctools_export_ui_switcher_page',
danielebarchiesi@0 156 'page arguments' => array($plugin['name'], 'add'),
danielebarchiesi@0 157 'access callback' => 'ctools_export_ui_task_access',
danielebarchiesi@0 158 'access arguments' => array($plugin['name'], 'add'),
danielebarchiesi@0 159 'type' => MENU_LOCAL_ACTION,
danielebarchiesi@0 160 );
danielebarchiesi@0 161
danielebarchiesi@0 162 $plugin['menu']['items']['edit callback'] += array(
danielebarchiesi@0 163 'path' => 'list/%ctools_export_ui',
danielebarchiesi@0 164 'page callback' => 'ctools_export_ui_switcher_page',
danielebarchiesi@0 165 'page arguments' => array($plugin['name'], 'edit', $prefix_count + 2),
danielebarchiesi@0 166 'load arguments' => array($plugin['name']),
danielebarchiesi@0 167 'access callback' => 'ctools_export_ui_task_access',
danielebarchiesi@0 168 'access arguments' => array($plugin['name'], 'edit', $prefix_count + 2),
danielebarchiesi@0 169 'type' => MENU_CALLBACK,
danielebarchiesi@0 170 );
danielebarchiesi@0 171
danielebarchiesi@0 172 $plugin['menu']['items']['edit'] += array(
danielebarchiesi@0 173 'path' => 'list/%ctools_export_ui/edit',
danielebarchiesi@0 174 'title' => 'Edit',
danielebarchiesi@0 175 'page callback' => 'ctools_export_ui_switcher_page',
danielebarchiesi@0 176 'page arguments' => array($plugin['name'], 'edit', $prefix_count + 2),
danielebarchiesi@0 177 'load arguments' => array($plugin['name']),
danielebarchiesi@0 178 'access callback' => 'ctools_export_ui_task_access',
danielebarchiesi@0 179 'access arguments' => array($plugin['name'], 'edit', $prefix_count + 2),
danielebarchiesi@0 180 'type' => MENU_DEFAULT_LOCAL_TASK,
danielebarchiesi@0 181 'weight' => -10,
danielebarchiesi@0 182 );
danielebarchiesi@0 183
danielebarchiesi@0 184 if ($plugin['allowed operations']['import']) {
danielebarchiesi@0 185 $plugin['menu']['items'] += array('import' => array());
danielebarchiesi@0 186 $plugin['menu']['items']['import'] += array(
danielebarchiesi@0 187 'path' => 'import',
danielebarchiesi@0 188 'title' => 'Import',
danielebarchiesi@0 189 'page callback' => 'ctools_export_ui_switcher_page',
danielebarchiesi@0 190 'page arguments' => array($plugin['name'], 'import'),
danielebarchiesi@0 191 'access callback' => 'ctools_export_ui_task_access',
danielebarchiesi@0 192 'access arguments' => array($plugin['name'], 'import'),
danielebarchiesi@0 193 'type' => MENU_LOCAL_ACTION,
danielebarchiesi@0 194 );
danielebarchiesi@0 195 }
danielebarchiesi@0 196
danielebarchiesi@0 197 if ($plugin['allowed operations']['export']) {
danielebarchiesi@0 198 $plugin['menu']['items'] += array('export' => array());
danielebarchiesi@0 199 $plugin['menu']['items']['export'] += array(
danielebarchiesi@0 200 'path' => 'list/%ctools_export_ui/export',
danielebarchiesi@0 201 'title' => 'Export',
danielebarchiesi@0 202 'page callback' => 'ctools_export_ui_switcher_page',
danielebarchiesi@0 203 'page arguments' => array($plugin['name'], 'export', $prefix_count + 2),
danielebarchiesi@0 204 'load arguments' => array($plugin['name']),
danielebarchiesi@0 205 'access callback' => 'ctools_export_ui_task_access',
danielebarchiesi@0 206 'access arguments' => array($plugin['name'], 'export', $prefix_count + 2),
danielebarchiesi@0 207 'type' => MENU_LOCAL_TASK,
danielebarchiesi@0 208 );
danielebarchiesi@0 209 }
danielebarchiesi@0 210
danielebarchiesi@0 211 if ($plugin['allowed operations']['revert']) {
danielebarchiesi@0 212 $plugin['menu']['items'] += array('revert' => array());
danielebarchiesi@0 213 $plugin['menu']['items']['revert'] += array(
danielebarchiesi@0 214 'path' => 'list/%ctools_export_ui/revert',
danielebarchiesi@0 215 'title' => 'Revert',
danielebarchiesi@0 216 'page callback' => 'ctools_export_ui_switcher_page',
danielebarchiesi@0 217 // Note: Yes, 'delete' op is correct.
danielebarchiesi@0 218 'page arguments' => array($plugin['name'], 'delete', $prefix_count + 2),
danielebarchiesi@0 219 'load arguments' => array($plugin['name']),
danielebarchiesi@0 220 'access callback' => 'ctools_export_ui_task_access',
danielebarchiesi@0 221 'access arguments' => array($plugin['name'], 'revert', $prefix_count + 2),
danielebarchiesi@0 222 'type' => MENU_CALLBACK,
danielebarchiesi@0 223 );
danielebarchiesi@0 224 }
danielebarchiesi@0 225
danielebarchiesi@0 226 if ($plugin['allowed operations']['delete']) {
danielebarchiesi@0 227 $plugin['menu']['items'] += array('delete' => array());
danielebarchiesi@0 228 $plugin['menu']['items']['delete'] += array(
danielebarchiesi@0 229 'path' => 'list/%ctools_export_ui/delete',
danielebarchiesi@0 230 'title' => 'Delete',
danielebarchiesi@0 231 'page callback' => 'ctools_export_ui_switcher_page',
danielebarchiesi@0 232 'page arguments' => array($plugin['name'], 'delete', $prefix_count + 2),
danielebarchiesi@0 233 'load arguments' => array($plugin['name']),
danielebarchiesi@0 234 'access callback' => 'ctools_export_ui_task_access',
danielebarchiesi@0 235 'access arguments' => array($plugin['name'], 'delete', $prefix_count + 2),
danielebarchiesi@0 236 'type' => MENU_CALLBACK,
danielebarchiesi@0 237 );
danielebarchiesi@0 238 }
danielebarchiesi@0 239
danielebarchiesi@0 240 if ($plugin['allowed operations']['clone']) {
danielebarchiesi@0 241 $plugin['menu']['items'] += array('clone' => array());
danielebarchiesi@0 242 $plugin['menu']['items']['clone'] += array(
danielebarchiesi@0 243 'path' => 'list/%ctools_export_ui/clone',
danielebarchiesi@0 244 'title' => 'Clone',
danielebarchiesi@0 245 'page callback' => 'ctools_export_ui_switcher_page',
danielebarchiesi@0 246 'page arguments' => array($plugin['name'], 'clone', $prefix_count + 2),
danielebarchiesi@0 247 'load arguments' => array($plugin['name']),
danielebarchiesi@0 248 'access callback' => 'ctools_export_ui_task_access',
danielebarchiesi@0 249 'access arguments' => array($plugin['name'], 'clone', $prefix_count + 2),
danielebarchiesi@0 250 'type' => MENU_CALLBACK,
danielebarchiesi@0 251 );
danielebarchiesi@0 252 }
danielebarchiesi@0 253
danielebarchiesi@0 254 if ($plugin['allowed operations']['enable']) {
danielebarchiesi@0 255 $plugin['menu']['items'] += array('enable' => array());
danielebarchiesi@0 256 $plugin['menu']['items']['enable'] += array(
danielebarchiesi@0 257 'path' => 'list/%ctools_export_ui/enable',
danielebarchiesi@0 258 'title' => 'Enable',
danielebarchiesi@0 259 'page callback' => 'ctools_export_ui_switcher_page',
danielebarchiesi@0 260 'page arguments' => array($plugin['name'], 'enable', $prefix_count + 2),
danielebarchiesi@0 261 'load arguments' => array($plugin['name']),
danielebarchiesi@0 262 'access callback' => 'ctools_export_ui_task_access',
danielebarchiesi@0 263 'access arguments' => array($plugin['name'], 'enable', $prefix_count + 2),
danielebarchiesi@0 264 'type' => MENU_CALLBACK,
danielebarchiesi@0 265 );
danielebarchiesi@0 266 }
danielebarchiesi@0 267
danielebarchiesi@0 268 if ($plugin['allowed operations']['disable']) {
danielebarchiesi@0 269 $plugin['menu']['items'] += array('disable' => array());
danielebarchiesi@0 270 $plugin['menu']['items']['disable'] += array(
danielebarchiesi@0 271 'path' => 'list/%ctools_export_ui/disable',
danielebarchiesi@0 272 'title' => 'Disable',
danielebarchiesi@0 273 'page callback' => 'ctools_export_ui_switcher_page',
danielebarchiesi@0 274 'page arguments' => array($plugin['name'], 'disable', $prefix_count + 2),
danielebarchiesi@0 275 'load arguments' => array($plugin['name']),
danielebarchiesi@0 276 'access callback' => 'ctools_export_ui_task_access',
danielebarchiesi@0 277 'access arguments' => array($plugin['name'], 'disable', $prefix_count + 2),
danielebarchiesi@0 278 'type' => MENU_CALLBACK,
danielebarchiesi@0 279 );
danielebarchiesi@0 280 }
danielebarchiesi@0 281
danielebarchiesi@0 282 // Define some redirects that should happen after edit/add/clone/delete operations.
danielebarchiesi@0 283 $plugin['redirect'] += array(
danielebarchiesi@0 284 'add' => $base_path,
danielebarchiesi@0 285 'clone' => $base_path,
danielebarchiesi@0 286 'edit' => $base_path,
danielebarchiesi@0 287 'delete' => $base_path,
danielebarchiesi@0 288 'revert' => $base_path,
danielebarchiesi@0 289 'import' => $base_path,
danielebarchiesi@0 290 );
danielebarchiesi@0 291
danielebarchiesi@0 292 // Define form elements.
danielebarchiesi@0 293 $plugin['form'] += array(
danielebarchiesi@0 294 'settings' => function_exists($plugin['name'] . '_form') ? $plugin['name'] . '_form' : '',
danielebarchiesi@0 295 'validate' => function_exists($plugin['name'] . '_form_validate') ? $plugin['name'] . '_form_validate' : '',
danielebarchiesi@0 296 'submit' => function_exists($plugin['name'] . '_form_submit') ? $plugin['name'] . '_form_submit' : '',
danielebarchiesi@0 297 );
danielebarchiesi@0 298
danielebarchiesi@0 299 // Define strings.
danielebarchiesi@0 300
danielebarchiesi@0 301 // For all strings, %title may be filled in at a later time via str_replace
danielebarchiesi@0 302 // since we do not know the title now.
danielebarchiesi@0 303 $plugin['strings'] += array(
danielebarchiesi@0 304 'title' => array(),
danielebarchiesi@0 305 'confirmation' => array(),
danielebarchiesi@0 306 'help' => array(),
danielebarchiesi@0 307 'message' => array(),
danielebarchiesi@0 308 );
danielebarchiesi@0 309
danielebarchiesi@0 310 // Strings used in drupal_set_title().
danielebarchiesi@0 311 $plugin['strings']['title'] += array(
danielebarchiesi@0 312 'add' => t('Add a new @plugin', array('@plugin' => $plugin['title singular'])),
danielebarchiesi@0 313 // The "%title" will be replaced in ctools_export_ui_form(), as in this
danielebarchiesi@0 314 // stage we dont have the specific exportable object.
danielebarchiesi@0 315 'edit' => t('Edit @plugin %title', array('@plugin' => $plugin['title singular'])),
danielebarchiesi@0 316 'clone' => t('Clone @plugin %title', array('@plugin' => $plugin['title singular'])),
danielebarchiesi@0 317
danielebarchiesi@0 318 'import' => t('Import @plugin', array('@plugin' => $plugin['title singular'])),
danielebarchiesi@0 319 'export' => t('Export @plugin %title', array('@plugin' => $plugin['title singular'])),
danielebarchiesi@0 320 );
danielebarchiesi@0 321
danielebarchiesi@0 322 // Strings used in confirmation pages.
danielebarchiesi@0 323 $plugin['strings']['confirmation'] += array(
danielebarchiesi@0 324 'revert' => array(),
danielebarchiesi@0 325 'delete' => array(),
danielebarchiesi@0 326 'add' => array(),
danielebarchiesi@0 327 'edit' => array(),
danielebarchiesi@0 328 );
danielebarchiesi@0 329
danielebarchiesi@0 330 $plugin['strings']['confirmation']['revert'] += array(
danielebarchiesi@0 331 'question' => t('Are you sure you want to revert %title?'),
danielebarchiesi@0 332 'information' => t('This action will permanently remove any customizations made to this item.'),
danielebarchiesi@0 333 'success' => t('The item has been reverted.'),
danielebarchiesi@0 334 );
danielebarchiesi@0 335
danielebarchiesi@0 336 $plugin['strings']['confirmation']['delete'] += array(
danielebarchiesi@0 337 'question' => t('Are you sure you want to delete %title?'),
danielebarchiesi@0 338 'information' => t('This action will permanently remove this item from your database..'),
danielebarchiesi@0 339 'success' => t('The item has been deleted.'),
danielebarchiesi@0 340 );
danielebarchiesi@0 341
danielebarchiesi@0 342 $plugin['strings']['confirmation']['add'] += array(
danielebarchiesi@0 343 'success' => t('%title has been created.'),
danielebarchiesi@0 344 'fail' => t('%title could not be created.'),
danielebarchiesi@0 345 );
danielebarchiesi@0 346
danielebarchiesi@0 347 $plugin['strings']['confirmation']['edit'] += array(
danielebarchiesi@0 348 'success' => t('%title has been updated.'),
danielebarchiesi@0 349 'fail' => t('%title could not be updated.'),
danielebarchiesi@0 350 );
danielebarchiesi@0 351
danielebarchiesi@0 352 // Strings used in $forms.
danielebarchiesi@0 353 $plugin['strings']['help'] += array(
danielebarchiesi@0 354 'import' => t('You can import an exported definition by pasting the exported object code into the field below.'),
danielebarchiesi@0 355 );
danielebarchiesi@0 356
danielebarchiesi@0 357 // Strings used in drupal_set_message().
danielebarchiesi@0 358 $plugin['strings']['message'] += array(
danielebarchiesi@0 359 'enable' => t('@plugin %title was enabled.', array('@plugin' => $plugin['title singular proper'])),
danielebarchiesi@0 360 'disable' => t('@plugin %title was disabled.', array('@plugin' => $plugin['title singular proper'])),
danielebarchiesi@0 361 'no items' => t('There are no @titles to display.', array('@titles' => $plugin['title plural'])),
danielebarchiesi@0 362 );
danielebarchiesi@0 363 }
danielebarchiesi@0 364
danielebarchiesi@0 365 /**
danielebarchiesi@0 366 * Get the class to handle creating a list of exportable items.
danielebarchiesi@0 367 *
danielebarchiesi@0 368 * If a plugin does not define a lister class at all, then the default
danielebarchiesi@0 369 * lister class will be used.
danielebarchiesi@0 370 *
danielebarchiesi@0 371 * @return
danielebarchiesi@0 372 * Either the lister class or FALSE if one could not be had.
danielebarchiesi@0 373 */
danielebarchiesi@0 374 function ctools_export_ui_get_handler($plugin) {
danielebarchiesi@0 375 $cache = &drupal_static(__FUNCTION__, array());
danielebarchiesi@0 376 if (empty($cache[$plugin['name']])) {
danielebarchiesi@0 377 // If a list class is not specified by the plugin, fall back to the
danielebarchiesi@0 378 // default ctools_export_ui plugin instead.
danielebarchiesi@0 379 if (empty($plugin['handler'])) {
danielebarchiesi@0 380 $default = ctools_get_export_ui('ctools_export_ui');
danielebarchiesi@0 381 $class = ctools_plugin_get_class($default, 'handler');
danielebarchiesi@0 382 }
danielebarchiesi@0 383 else {
danielebarchiesi@0 384 $class = ctools_plugin_get_class($plugin, 'handler');
danielebarchiesi@0 385 }
danielebarchiesi@0 386
danielebarchiesi@0 387 if ($class) {
danielebarchiesi@0 388 $cache[$plugin['name']] = new $class();
danielebarchiesi@0 389 $cache[$plugin['name']]->init($plugin);
danielebarchiesi@0 390 }
danielebarchiesi@0 391 }
danielebarchiesi@0 392 return !empty($cache[$plugin['name']]) ? $cache[$plugin['name']] : FALSE;
danielebarchiesi@0 393 }
danielebarchiesi@0 394
danielebarchiesi@0 395 /**
danielebarchiesi@0 396 * Get the base path from a plugin.
danielebarchiesi@0 397 *
danielebarchiesi@0 398 * @param $plugin
danielebarchiesi@0 399 * The plugin.
danielebarchiesi@0 400 *
danielebarchiesi@0 401 * @return
danielebarchiesi@0 402 * The menu path to the plugin's list.
danielebarchiesi@0 403 */
danielebarchiesi@0 404 function ctools_export_ui_plugin_base_path($plugin) {
danielebarchiesi@0 405 return $plugin['menu']['menu prefix'] . '/' . $plugin['menu']['menu item'];
danielebarchiesi@0 406 }
danielebarchiesi@0 407
danielebarchiesi@0 408 /**
danielebarchiesi@0 409 * Get the path to a specific menu item from a plugin.
danielebarchiesi@0 410 *
danielebarchiesi@0 411 * @param $plugin
danielebarchiesi@0 412 * The plugin name.
danielebarchiesi@0 413 * @param $item_id
danielebarchiesi@0 414 * The id in the menu items from the plugin.
danielebarchiesi@0 415 * @param $export_key
danielebarchiesi@0 416 * The export key of the item being edited, if it exists.
danielebarchiesi@0 417 * @return
danielebarchiesi@0 418 * The menu path to the plugin's list.
danielebarchiesi@0 419 */
danielebarchiesi@0 420 function ctools_export_ui_plugin_menu_path($plugin, $item_id, $export_key = NULL) {
danielebarchiesi@0 421 $path = $plugin['menu']['items'][$item_id]['path'];
danielebarchiesi@0 422 if ($export_key) {
danielebarchiesi@0 423 $path = str_replace('%ctools_export_ui', $export_key, $path);
danielebarchiesi@0 424 }
danielebarchiesi@0 425 return ctools_export_ui_plugin_base_path($plugin) . '/' . $path;
danielebarchiesi@0 426 }
danielebarchiesi@0 427
danielebarchiesi@0 428 /**
danielebarchiesi@0 429 * Helper function to include CTools plugins and get an export-ui exportable.
danielebarchiesi@0 430 *
danielebarchiesi@0 431 * @param $plugin_name
danielebarchiesi@0 432 * The plugin that should be laoded.
danielebarchiesi@0 433 */
danielebarchiesi@0 434 function ctools_get_export_ui($plugin_name) {
danielebarchiesi@0 435 ctools_include('plugins');
danielebarchiesi@0 436 return ctools_get_plugins('ctools', 'export_ui', $plugin_name);
danielebarchiesi@0 437
danielebarchiesi@0 438 }
danielebarchiesi@0 439
danielebarchiesi@0 440 /**
danielebarchiesi@0 441 * Helper function to include CTools plugins and get all export-ui exportables.
danielebarchiesi@0 442 */
danielebarchiesi@0 443 function ctools_get_export_uis() {
danielebarchiesi@0 444 ctools_include('plugins');
danielebarchiesi@0 445 return ctools_get_plugins('ctools', 'export_ui');
danielebarchiesi@0 446 }
danielebarchiesi@0 447
danielebarchiesi@0 448 /**
danielebarchiesi@0 449 * Main page callback to manipulate exportables.
danielebarchiesi@0 450 *
danielebarchiesi@0 451 * This simply loads the object defined in the plugin and hands it off to
danielebarchiesi@0 452 * a method based upon the name of the operation in use. This can easily
danielebarchiesi@0 453 * be used to add more ops.
danielebarchiesi@0 454 */
danielebarchiesi@0 455 function ctools_export_ui_switcher_page($plugin_name, $op) {
danielebarchiesi@0 456 $args = func_get_args();
danielebarchiesi@0 457 $js = !empty($_REQUEST['js']);
danielebarchiesi@0 458
danielebarchiesi@0 459 // Load the $plugin information
danielebarchiesi@0 460 $plugin = ctools_get_export_ui($plugin_name);
danielebarchiesi@0 461 $handler = ctools_export_ui_get_handler($plugin);
danielebarchiesi@0 462
danielebarchiesi@0 463 if ($handler) {
danielebarchiesi@0 464 $method = $op . '_page';
danielebarchiesi@0 465 if (method_exists($handler, $method)) {
danielebarchiesi@0 466 // replace the first two arguments:
danielebarchiesi@0 467 $args[0] = $js;
danielebarchiesi@0 468 $args[1] = $_POST;
danielebarchiesi@0 469 return call_user_func_array(array($handler, $method), $args);
danielebarchiesi@0 470 }
danielebarchiesi@0 471 }
danielebarchiesi@0 472 else {
danielebarchiesi@0 473 return t('Configuration error. No handler found.');
danielebarchiesi@0 474 }
danielebarchiesi@0 475 }