Skip to content
Snippets Groups Projects
forms.php 5.75 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.dynamic_forms.php");
    
    $form=null;
    
    if($_REQUEST['id'] && !($form=DynamicForm::lookup($_REQUEST['id'])))
    
    Jared Hancock's avatar
    Jared Hancock committed
        $errors['err']='Unknown or invalid dynamic form ID.';
    
    if($_POST) {
        $fields = array('title', 'notes', 'instructions');
    
        $required = array('title');
    
        $form_fields = array();
    
    Jared Hancock's avatar
    Jared Hancock committed
        switch(strtolower($_POST['do'])) {
            case 'update':
                foreach ($fields as $f)
    
                    if (in_array($f, $required) && !$_POST[$f])
                        $errors[$f] = sprintf('%s is required',
                            mb_convert_case($f, MB_CASE_TITLE));
                    elseif (isset($_POST[$f]))
    
    Jared Hancock's avatar
    Jared Hancock committed
                        $form->set($f, $_POST[$f]);
    
                $form->save(true);
    
                $names = array();
    
    Jared Hancock's avatar
    Jared Hancock committed
                foreach ($form->getDynamicFields() as $field) {
                    $id = $field->get('id');
    
                    if ($_POST["delete-$id"] == 'on' && $field->isDeletable()) {
    
    Jared Hancock's avatar
    Jared Hancock committed
                        $field->delete();
    
                        // Don't bother updating the field
    
    Jared Hancock's avatar
    Jared Hancock committed
                        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"]);
    
    Jared Hancock's avatar
    Jared Hancock committed
                    # TODO: make sure all help topics still have all required fields
    
                    if (!$field->isRequirementForced())
                        $field->set('required', $_POST["required-$id"] == 'on' ?  1 : 0);
                    if (!$field->isPrivacyForced())
                        $field->set('private', $_POST["private-$id"] == 'on' ?  1 : 0);
                    foreach (array('sort','label') as $f) {
                        if (isset($_POST["$f-$id"])) {
                            $field->set($f, $_POST["$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');
    
    Jared Hancock's avatar
    Jared Hancock committed
                    if ($field->isValid())
    
                        $form_fields[] = $field;
    
                    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'));
    
    Jared Hancock's avatar
    Jared Hancock committed
                }
                break;
            case 'add':
    
                $form = DynamicForm::create();
                foreach ($fields as $f) {
                    if (in_array($f, $required) && !$_POST[$f])
                        $errors[$f] = sprintf('%s is required',
                            mb_convert_case($f, MB_CASE_TITLE));
                    elseif (isset($_POST[$f]))
                        $form->set($f, $_POST[$f]);
                }
    
                break;
    
            case 'mass_process':
                if(!$_POST['ids'] || !is_array($_POST['ids']) || !count($_POST['ids'])) {
                    $errors['err'] = 'You must select at least one API key';
                } else {
                    $count = count($_POST['ids']);
                    switch(strtolower($_POST['a'])) {
                        case 'delete':
                            $i=0;
                            foreach($_POST['ids'] as $k=>$v) {
                                if(($t=DynamicForm::lookup($v)) && $t->delete())
                                    $i++;
                            }
                            if ($i && $i==$count)
                                $msg = 'Selected custom forms deleted successfully';
                            elseif ($i > 0)
                                $warn = "$i of $count selected forms deleted";
                            elseif (!$errors['err'])
                                $errors['err'] = 'Unable to delete selected custom forms';
                            break;
                    }
                }
    
    Jared Hancock's avatar
    Jared Hancock committed
                break;
        }
    
        if ($form) {
            for ($i=0; isset($_POST["sort-new-$i"]); $i++) {
                if (!$_POST["label-new-$i"])
                    continue;
                $field = DynamicFormField::create(array(
    
    Peter Rotich's avatar
    Peter Rotich committed
                    'sort'=>$_POST["sort-new-$i"] ? $_POST["sort-new-$i"] : ++$max_sort,
    
    Jared Hancock's avatar
    Jared Hancock committed
                    'label'=>$_POST["label-new-$i"],
                    'type'=>$_POST["type-new-$i"],
                    'name'=>$_POST["name-new-$i"],
                    'private'=>$_POST["private-new-$i"] == 'on' ? 1 : 0,
                    'required'=>$_POST["required-new-$i"] == 'on' ? 1 : 0
                ));
    
                $field->setForm($form);
    
    Jared Hancock's avatar
    Jared Hancock committed
                if ($field->isValid())
    
                    $form_fields[] = $field;
    
                else
                    $errors["new-$i"] = $field->errors();
    
    Jared Hancock's avatar
    Jared Hancock committed
            }
            // XXX: Move to an instrumented list that can handle this better
    
            if (!$errors) {
    
                $form->_dfields = $form->_fields = null;
    
                $form->save(true);
                foreach ($form_fields as $field) {
                    $field->set('form_id', $form->get('id'));
                    $field->save();
                }
    
                // No longer adding a new form
                unset($_REQUEST['a']);
    
        if ($errors)
            $errors['err'] = 'Unable to commit form. Check validation errors';
    
        else
            $msg = 'Custom form successfully updated';
    
    $page='dynamic-forms.inc.php';
    
    Jared Hancock's avatar
    Jared Hancock committed
    if($form || ($_REQUEST['a'] && !strcasecmp($_REQUEST['a'],'add')))
    
        $page='dynamic-form.inc.php';
    
    $ost->addExtraHeader('<meta name="tip-namespace" content="forms" />');
    
    $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');
    ?>