$set_info) {
$set_info += array('status' => 'default');
$path = RULES_ADMIN_SET_PATH .'/'. $name;
$ops = array();
if ($set_info['status'] == 'custom') {
$ops[] = l(t('delete'), $path .'/delete', array('query' => drupal_get_destination()));
}
else if ($set_info['status'] == 'altered') {
$ops[] = l(t('revert'), $path .'/revert', array('query' => drupal_get_destination()));
}
$categories = isset($set_info['categories']) ? array_map('check_plain', $set_info['categories']) : array();
$rows[] = array(
l($set_info['label'], $path .'/edit'),
check_plain($name),
implode(', ', $categories),
theme('rules_admin_configuration_status', $set_info['status']),
implode(' ', $ops),
);
}
if (empty($rows)) {
$rows[] = array(array('data' => t('There are no rule sets.'), 'colspan' => 6));
}
return theme('table', $header, $rows, array('class' => 'rules-sets-configurations'));
}
/**
* Shows the delete form for items
*/
function rules_admin_item_form_delete(&$form_state, $item_type, $item) {
$form = array();
$form_state['item'] = $item;
$form_state['item_type'] = $item_type;
$path = array();
$path['path'] = isset($_GET['destination']) ? $_GET['destination'] : RULES_ADMIN_PATH;
return confirm_form($form,
t('Are you sure you want to delete %label?', array('%label' => rules_get_element_label($item))),
$path,
t('This action cannot be undone.'), t('Delete'), t('Cancel')
);
}
function rules_admin_item_form_delete_submit($form, &$form_state) {
rules_item_delete($form_state['item_type'], $form_state['item']['name']);
rules_clear_cache();
drupal_set_message(t("%label has been deleted.", array('%label' => rules_get_element_label($form_state['item']))));
$form_state['redirect'] = RULES_ADMIN_PATH;
}
/**
* Shows the revert form for items
*/
function rules_admin_item_form_revert(&$form_state, $item_type, $item) {
$form = array();
$form_state['item'] = $item;
$form_state['item_type'] = $item_type;
$path = array();
$path['path'] = isset($_GET['destination']) ? $_GET['destination'] : RULES_ADMIN_PATH;
return confirm_form($form,
t('Are you sure you want to revert %label?', array('%label' => rules_get_element_label($item))),
$path,
t('This action cannot be undone.'), t('Revert'), t('Cancel')
);
}
function rules_admin_item_form_revert_submit($form, &$form_state) {
rules_item_delete($form_state['item_type'], $form_state['item']['name']);
rules_clear_cache();
drupal_set_message(t("%label has been reverted.", array('%label' => rules_get_element_label($form_state['item']))));
$form_state['redirect'] = RULES_ADMIN_PATH;
}
/**
* Item type callback: Deleted rule set
*/
function rules_item_rule_set_delete($set_name) {
// Delete all rules belonging to this set too
$rules = rules_get_configured_items('rules');
foreach ($rules as $name => $rule) {
if ($rule['#set'] == $set_name) {
rules_item_delete('rules', $name);
}
}
}
/**
* Shows the rule set edit page form
*/
function rules_admin_form_edit_rule_set(&$form_state, $set_info) {
$form_state['set'] = $set_info;
$form = rules_admin_form_rule_set_settings($set_info);
$form['active_header'] = array('#value' => '
'. t('Active rules') .'
');
$form['active'] = rules_admin_overview_table(array('set' => $set_info['name'], 'active' => TRUE));
$form['active']['#suffix'] = '
';
$form['inactive_header'] = array('#value' => ''. t('Inactive rules') .'
');
$form['inactive'] = rules_admin_overview_table(array('set' => $set_info['name'], 'active' => FALSE));
if (variable_get('rules_show_fixed', FALSE)) {
$form['fixed_header'] = array('#value' => ''. t('Fixed rules') .'
');
$form['fixed'] = rules_admin_overview_table(array('set' => $set_info['name'], 'active' => TRUE, 'fixed' => TRUE));
}
return $form;
}
/**
* Returns the form for the settings of a rule set
*/
function rules_admin_form_rule_set_settings($set_info = array(), $add = FALSE) {
$form['settings'] = array(
'#type' => 'fieldset',
'#title' => t('Rule set settings'),
'#collapsible' => TRUE,
);
$form['settings']['label'] = array(
'#title' => t('Label'),
'#type' => 'textfield',
'#description' => t('Choose an appropriate label for this rule set.'),
'#default_value' => isset($set_info['label']) ? $set_info['label'] : '',
'#required' => TRUE,
);
if ($add) {
$form['settings']['name'] = array(
'#title' => t('Machine readable name'),
'#type' => 'textfield',
'#description' => t('Specify a unique name containing only alphanumeric characters, and underscores.'),
'#default_value' => isset($set_info['name']) ? $set_info['name'] : '',
'#required' => TRUE,
);
}
$form['settings']['categories'] = array(
'#type' => 'textfield',
'#title' => t('Categories'),
'#default_value' => isset($set_info['categories']) ? implode(', ', $set_info['categories']) : '',
'#description' => t('A comma-separated list of terms describing this rule set. Example: funny, bungee jumping.'),
'#autocomplete_path' => RULES_ADMIN_PATH .'/autocomplete',
);
$form['settings']['button'] = array('#type' => 'submit', '#weight' => 10, '#value' => t('Save changes'));
return $form;
}
function rules_admin_form_edit_rule_set_submit($form, &$form_state) {
$set_info = $form_state['set'];
$set_info['label'] = $form_state['values']['label'];
if (!isset($set_info['status']) || $set_info['status'] == 'default') {
$set_info['status'] = 'altered';
}
$set_info['categories'] = array_filter(array_map('trim', explode(',', $form_state['values']['categories'])));
unset($set_info['name']);
rules_item_save('rule_sets', $form_state['set']['name'], $set_info);
drupal_set_message(t("The rule set %label has been updated.", array('%label' => $set_info['label'])));
}
/**
* Form for adding a rule set
*/
function rules_admin_form_add_rule_set(&$form_state) {
//in case of non-js we degrade to a multistep form
$set_info = isset($form_state['set']) ? $form_state['set'] : array('arguments' => array());
$form = rules_admin_form_rule_set_settings($set_info, TRUE);
unset($form['settings']['button']);
//add form for specifying arguments
$form['args'] = array(
'#type' => 'fieldset',
'#title' => t('Arguments'),
'#collapsible' => TRUE,
'#prefix' => '',
'#suffix' => '
',
'#tree' => TRUE,
'#theme' => 'rules_admin_form_arguments',
'#description' => t('You may specify some arguments, which have to be passed to the rule set when it is invoked. For each argument you have to specify a certain data type, a label and a unique machine readable name containing only alphanumeric characters, and underscores.'),
);
foreach ($set_info['arguments'] as $name => $info) {
$form['settings']['args'][$name] = _rules_admin_form_argument($name, $info);
}
for ($i = 0; $i < 3; $i++) {
$form['args'][$i] = _rules_admin_form_argument();
}
$form['args']['rules_more'] = array(
'#type' => 'submit',
'#value' => t('More arguments'),
'#description' => t("If the amount of boxes above isn't enough, click here to add more arguments."),
'#weight' => 1,
'#submit' => array('rules_admin_form_add_rule_set_rebuild'), // If no javascript action.
'#ahah' => array(
'path' => RULES_ADMIN_SET_PATH .'/js',
'wrapper' => 'rules-set-args',
'method' => 'replace',
),
);
$form['button'] = array('#type' => 'submit', '#weight' => 10, '#value' => t('Save'));
return $form;
}
/**
* Validates the set and builds it -> $form_state['set']
*/
function rules_admin_form_add_rule_set_validate($form, &$form_state) {
if (!eregi('^[0-9a-z_]*$', $form_state['values']['name'])) {
form_set_error('name', t('The name may contain only digits, numbers and underscores.'));
}
//validate the arguments
unset($form_state['values']['args']['rules_more']);
foreach ($form_state['values']['args'] as $i => $values) {
if (array_filter($values)) {
foreach (array('name', 'type', 'label') as $key) {
if (!$values[$key]) {
form_set_error(implode('][', array('args', $i, $key)), t('All fields of an argument are required.'));
}
}
if (!eregi('^[0-9a-z_]*$', $values['name'])) {
form_set_error(implode('][', array('args', $i, 'name')), t('The name may contain only digits, numbers and underscores.'));
}
}
else {
unset($form_state['values']['args'][$i]);
}
}
//build the set
$set_info = array('arguments' => array());
$set_info['label'] = $form_state['values']['label'];
$set_info['name'] = $form_state['values']['name'];
foreach ($form_state['values']['args'] as $i => $values) {
if (isset($set_info['arguments'][ $values['name'] ])) {
form_set_error('args]['. $i .'][name', t('Each name may be used only once.'));
}
else {
$set_info['arguments'][ $values['name'] ] = array(
'label' => $values['label'],
'type' => $values['type'],
);
}
}
$form_state['set'] = $set_info;
}
function rules_admin_form_add_rule_set_rebuild($form, &$form_state) {
$form_state['rebuild'] = TRUE;
}
function _rules_admin_form_argument($name = '', $info = array()) {
$form = array();
$form['label'] = array(
'#type' => 'textfield',
'#title' => t('Label'),
'#size' => 40,
'#default_value' => isset($info['label']) ? $info['label'] : '',
);
$options = rules_extract_property(array_filter(rules_get_data_types(), 'rules_admin_element_filter'), 'label');
$options = array_map('drupal_ucfirst', $options);
asort($options);
$form['type'] = array(
'#type' => 'select',
'#title' => t('Data type'),
'#options' => array(0 => '--') + $options,
'#default_value' => isset($info['type']) ? $info['type'] : '',
);
$form['name'] = array(
'#type' => 'textfield',
'#title' => t('Machine readable variable name'),
'#size' => 40,
'#default_value' => $name,
);
return $form;
}
/**
* A generic AHAH JS callback. Gets the cached form and passes it to the given callback
* to alter it. The callback returns the a reference on the to be rendered form,
* which is rendered and returned to the JS.
*/
function rules_admin_form_js($callback) {
$form_state = array('submitted' => FALSE);
$form_build_id = $_POST['form_build_id'];
// Add the new element to the stored form. Without adding the element to the
// form, Drupal is not aware of this new elements existence and will not
// process it. We retreive the cached form, add the element, and resave.
$form = form_get_cache($form_build_id, $form_state);
$render = &$callback($form);
form_set_cache($form_build_id, $form, $form_state);
$form += array(
'#post' => $_POST,
'#programmed' => FALSE,
);
// Rebuild the form.
$form = form_builder($_POST['form_id'], $form, $form_state);
// Render the new output.
print drupal_to_js(array('data' => drupal_render($render), 'status' => TRUE));
exit();
}
/**
* rules AHAH JS callback for adding arguments
*/
function &rules_admin_form_add_rule_set_add_arguments(&$form) {
$start = count($form['args']) - 1;
for ($i = $start; $i - $start < 3; $i++) {
$form['args'][$i] = _rules_admin_form_argument();
}
return $form['args'];
}
/**
* Themes the rules set arguments adding form
*/
function theme_rules_admin_form_arguments($form) {
drupal_add_js(drupal_get_path('module', 'rules_admin') .'/rules_admin.js', 'module');
$rows = array();
$headers = array(
t('Data type'),
t('Label'),
t('Machine readable name'),
);
$button = drupal_render($form['rules_more']);
unset($form['rules_more']);
foreach (element_children($form) as $key) {
// No need to print the field title every time.
unset($form[$key]['label']['#title'], $form[$key]['name']['#title'], $form[$key]['type']['#title']);
// Build the table row.
$row = array(
'data' => array(
array('data' => drupal_render($form[$key]['type']), 'class' => 'rules-argument-data-type'),
array('data' => drupal_render($form[$key]['label']), 'class' => 'rules-argument-label'),
array('data' => drupal_render($form[$key]['name']), 'class' => 'rules-argument-name'),
),
);
// Add additional attributes to the row, such as a class for this row.
if (isset($form[$key]['#attributes'])) {
$row = array_merge($row, $form[$key]['#attributes']);
}
$rows[] = $row;
}
$output = theme('table', $headers, $rows);
$output .= drupal_render($form) . $button;
return $output;
}
function rules_admin_form_add_rule_set_submit($form, &$form_state) {
$set_info = $form_state['set'];
$set_info['status'] = 'custom';
$set_info['categories'] = array_filter(array_map('trim', explode(',', $form_state['values']['categories'])));
unset($set_info['name']);
rules_item_save('rule_sets', 'rules_'. $form_state['set']['name'], $set_info);
drupal_set_message(t("The rule set %label has been added.", array('%label' => $set_info['label'])));
$form_state['redirect'] = RULES_ADMIN_SET_PATH;
}