Skip to content
Snippets Groups Projects
lists.php 8.39 KiB
Newer Older
  • Learn to ignore specific revisions
  • Jared Hancock's avatar
    Jared Hancock committed
    <?php
    require('admin.inc.php');
    
    require_once(INCLUDE_DIR.'class.list.php');
    
    
    Jared Hancock's avatar
    Jared Hancock committed
    
    $list=null;
    
    $criteria=array();
    if ($_REQUEST['id'])
        $criteria['id'] = $_REQUEST['id'];
    elseif ($_REQUEST['type'])
        $criteria['type'] = $_REQUEST['type'];
    
    if ($criteria) {
        $list = DynamicList::lookup($criteria);
    
    Peter Rotich's avatar
    Peter Rotich committed
        if ($list)
             $form = $list->getForm();
        else
    
            $errors['err']=sprintf(__('%s: Unknown or invalid ID.'),
                __('custom list'));
    
    Peter Rotich's avatar
    Peter Rotich committed
    }
    
    $errors = array();
    $max_isort = 0;
    
    
    Jared Hancock's avatar
    Jared Hancock committed
    if($_POST) {
        switch(strtolower($_POST['do'])) {
            case 'update':
    
                if (!$list)
    
                    $errors['err']=sprintf(__('%s: Unknown or invalid ID.'),
                        __('custom list'));
    
                elseif ($list->update($_POST, $errors)) {
                    // Update items
                    $items = array();
    
                    foreach ($list->getAllItems() as $item) {
                        $id = $item->getId();
    
                        if ($_POST["delete-item-$id"] == 'on' && $item->isDeletable()) {
    
                            $item->delete();
                            continue;
                        }
    
                        $ht = array(
                                'value' => $_POST["value-$id"],
                                'abbrev' => $_POST["abbrev-$id"],
                                'sort' => $_POST["sort-$id"],
                                );
                        $value = mb_strtolower($ht['value']);
                        if (!$value)
    
                            $errors["value-$id"] = __('Value required');
    
                        elseif (in_array($value, $items))
    
                            $errors["value-$id"] = __('Value already in-use');
    
                        elseif ($item->update($ht, $errors)) {
                            if ($_POST["disable-$id"] == 'on')
                                $item->disable();
                            elseif(!$item->isEnabled() && $item->isEnableable())
                                $item->enable();
    
                            $item->save();
                            $items[] = $value;
                        }
    
                        $max_isort = max($max_isort, $_POST["sort-$id"]);
    
                    // Update properties
                    if (!$errors && ($form = $list->getForm())) {
                        $names = array();
                        foreach ($form->getDynamicFields() as $field) {
                            $id = $field->get('id');
                            if ($_POST["delete-prop-$id"] == 'on' && $field->isDeletable()) {
                                $field->delete();
                                // Don't bother updating the field
                                continue;
                            }
                            if (isset($_POST["type-$id"]) && $field->isChangeable())
                                $field->set('type', $_POST["type-$id"]);
                            if (isset($_POST["name-$id"]) && !$field->isNameForced())
                                $field->set('name', $_POST["name-$id"]);
    
                            foreach (array('sort','label') as $f) {
                                if (isset($_POST["prop-$f-$id"])) {
                                    $field->set($f, $_POST["prop-$f-$id"]);
                                }
                            }
                            if (in_array($field->get('name'), $names))
    
                                $field->addError(__('Field variable name is not unique'), 'name');
    
                            if (preg_match('/[.{}\'"`; ]/u', $field->get('name')))
    
                                $field->addError(__('Invalid character in variable name. Please use letters and numbers only.'), 'name');
    
                            if ($field->get('name'))
                                $names[] = $field->get('name');
                            if ($field->isValid())
                                $field->save();
                            else
                                # notrans (not shown)
                                $errors["field-$id"] = 'Field has validation errors';
                            // Keep track of the last sort number
                            $max_sort = max($max_sort, $field->get('sort'));
    
    
                    if ($errors)
    
                         $errors['err'] = $errors['err'] ?: sprintf(__('Unable to update %s. Correct error(s) below and try again!'),
                            __('custom list items'));
    
                    else {
                        $list->_items = null;
    
                        $msg = sprintf(__('Successfully updated %s'),
                            __('this custom list'));
    
    
                } elseif ($errors)
    
                    $errors['err'] = $errors['err'] ?: sprintf(__('Unable to update %s. Correct error(s) below and try again!'),
    
                        __('this custom list'));
    
                    $errors['err']=sprintf(__('Unable to update %s.'), __('this custom list'))
                        .' '.__('Internal error occurred');
    
    Jared Hancock's avatar
    Jared Hancock committed
                break;
            case 'add':
    
                if ($list=DynamicList::add($_POST, $errors)) {
    
                     $msg = sprintf(__('Successfully added %s'),
                        __('this custom list'));
    
                } elseif ($errors) {
    
                    $errors['err']=sprintf(__('Unable to add %s. Correct error(s) below and try again.'),
    
                        __('this custom list'));
    
                } else {
    
                    $errors['err']=sprintf(__('Unable to add %s.'), __('this custom list'))
                        .' '.__('Internal error occurred');
    
    Jared Hancock's avatar
    Jared Hancock committed
                break;
    
    
            case 'mass_process':
                if(!$_POST['ids'] || !is_array($_POST['ids']) || !count($_POST['ids'])) {
    
                    $errors['err'] = sprintf(__('You must select at least %s'),
                        __('one custom list'));
    
                } else {
                    $count = count($_POST['ids']);
                    switch(strtolower($_POST['a'])) {
                        case 'delete':
                            $i=0;
                            foreach($_POST['ids'] as $k=>$v) {
                                if(($t=DynamicList::lookup($v)) && $t->delete())
                                    $i++;
                            }
                            if ($i && $i==$count)
    
                                $msg = sprintf(__('Successfully deleted %s'),
                                    _N('selected custom list', 'selected custom lists', $count));
    
                                $warn = sprintf(__('%1$d of %2$d %3$s deleted'), $i, $count,
                                    _N('selected custom list', 'selected custom lists', $count));
    
                            elseif (!$errors['err'])
    
                                $errors['err'] = sprintf(__('Unable to delete %s — they may be in use on a custom form'),
                                    _N('selected custom list', 'selected custom lists', $count));
    
            for ($i=0; isset($_POST["sort-new-$i"]); $i++) {
    
    Jared Hancock's avatar
    Jared Hancock committed
                if (!$_POST["value-new-$i"])
                    continue;
    
    
                $list->addItem(array(
                            'value' => $_POST["value-new-$i"],
                            'abbrev' =>$_POST["abbrev-new-$i"],
    
                            'sort' => $_POST["sort-new-$i"] ?: ++$max_isort,
                            ), $errors);
    
            for ($i=0; isset($_POST["prop-sort-new-$i"]); $i++) {
                if (!$_POST["prop-label-new-$i"])
    
                    continue;
                $field = DynamicFormField::create(array(
    
                    'form_id' => $form->get('id'),
                    'sort' => $_POST["prop-sort-new-$i"] ?: ++$max_sort,
                    'label' => $_POST["prop-label-new-$i"],
                    'type' => $_POST["type-new-$i"],
                    'name' => $_POST["name-new-$i"],
    
                ));
                $field->setForm($form);
                if ($field->isValid())
                    $field->save();
                else
                    $errors["new-$i"] = $field->errors();
            }
            // XXX: Move to an instrumented list that can handle this better
            if (!$errors)
                $form->_dfields = $form->_fields = null;
        }
    
    Jared Hancock's avatar
    Jared Hancock committed
    }
    
    $page='dynamic-lists.inc.php';
    
    if($list || ($_REQUEST['a'] && !strcasecmp($_REQUEST['a'],'add'))) {
    
    Jared Hancock's avatar
    Jared Hancock committed
        $page='dynamic-list.inc.php';
    
    Peter Rotich's avatar
    Peter Rotich committed
        $ost->addExtraHeader('<meta name="tip-namespace" content="manage.custom_list" />',
            "$('#content').data('tipNamespace', 'manage.custom_list');");
    
    $nav->setTabActive('manage');
    
    Jared Hancock's avatar
    Jared Hancock committed
    require(STAFFINC_DIR.'header.inc.php');
    require(STAFFINC_DIR.$page);
    include(STAFFINC_DIR.'footer.inc.php');
    ?>