array( 'title' => t('Administer access rulesets'), 'description' => t('Add, delete and edit custom access rulesets.'), ), ); } /** * Implementation of hook_ctools_plugin_directory() to let the system know * we implement task and task_handler plugins. */ function ctools_access_ruleset_ctools_plugin_directory($module, $plugin) { // Most of this module is implemented as an export ui plugin, and the // rest is in ctools/includes/ctools_access_ruleset.inc if ($module == 'ctools' && ($plugin == 'export_ui' || $plugin == 'access')) { return 'plugins/' . $plugin; } } /** * Implementation of hook_panels_dashboard_blocks(). * * Adds page information to the Panels dashboard. */ function ctools_access_ruleset_panels_dashboard_blocks(&$vars) { $vars['links']['ctools_access_ruleset'] = array( 'title' => l(t('Custom ruleset'), 'admin/structure/ctools-rulesets/add'), 'description' => t('Custom rulesets are combinations of access plugins you can use for access control, selection criteria and pane visibility.'), ); // Load all mini panels and their displays. ctools_include('export'); $items = ctools_export_crud_load_all('ctools_access_ruleset'); $count = 0; $rows = array(); foreach ($items as $item) { $rows[] = array( check_plain($item->admin_title), array( 'data' => l(t('Edit'), "admin/structure/ctools-rulesets/list/$item->name/edit"), 'class' => 'links', ), ); // Only show 10. if (++$count >= 10) { break; } } if ($rows) { $content = theme('table', array('rows' => $rows, 'attributes' => array('class' => 'panels-manage'))); } else { $content = '

' . t('There are no custom rulesets.') . '

'; } $vars['blocks']['ctools_access_ruleset'] = array( 'title' => t('Manage custom rulesets'), 'link' => l(t('Go to list'), 'admin/structure/ctools-rulesets'), 'content' => $content, 'class' => 'dashboard-ruleset', 'section' => 'right', ); }