public function process() { $errors = array(); if (isset($_REQUEST['butt_del']) && $_REQUEST['butt_del'] && $_REQUEST['quote_id']) { $data = self::get_quote($_REQUEST['quote_id']); if (module_form::confirm_delete('quote_id', "Really delete quote: " . $data['name'], self::link_open($_REQUEST['quote_id']))) { $this->delete_quote($_REQUEST['quote_id']); set_message("quote deleted successfully"); redirect_browser($this->link_open(false)); } } else { if ("ajax_quote_list" == $_REQUEST['_process']) { $customer_id = isset($_REQUEST['customer_id']) ? (int) $_REQUEST['customer_id'] : 0; $res = module_quote::get_quotes(array('customer_id' => $customer_id)); $options = array(); foreach ($res as $row) { $options[$row['quote_id']] = $row['name']; } echo json_encode($options); exit; } else { if ("ajax_create_invoice" == $_REQUEST['_process']) { $quote_id = (int) $_REQUEST['quote_id']; $quote = self::get_quote($quote_id, true); $quote_tasks = self::get_tasks($quote_id); if (!$quote || $quote['quote_id'] != $quote_id) { exit; } // no permissions. if (!module_invoice::can_i('create', 'Invoices')) { exit; } // no permissions ob_start(); ?> <p><?php _e('Please select which tasks to generate an invoice for:'); ?> </p> <ul> <?php foreach ($quote['uninvoiced_quote_task_ids'] as $quote_task_id) { if (isset($quote_tasks[$quote_task_id])) { ?> <li> <input type="checkbox" id="invoice_create_task_<?php echo $quote_task_id; ?> " data-taskid="<?php echo $quote_task_id; ?> " class="invoice_create_task" name="invoice_quote_task_id[<?php echo $quote_task_id; ?> ]" value="1" <?php echo $quote_tasks[$quote_task_id]['fully_completed'] ? 'checked' : ''; ?> > <label for="invoice_create_task_<?php echo $quote_task_id; ?> "> (#<?php echo $quote_tasks[$quote_task_id]['task_order']; ?> ) <?php echo htmlspecialchars($quote_tasks[$quote_task_id]['description']); ?> </label> </li> <?php } } ?> </ul> <?php $html = ob_get_clean(); echo $html; exit; } else { if ("ajax_task" == $_REQUEST['_process']) { // we are requesting editing a task. $quote_id = (int) $_REQUEST['quote_id']; $quote = self::get_quote($quote_id, true); $quote_tasks = self::get_tasks($quote_id); if (!$quote || $quote['quote_id'] != $quote_id) { exit; } // no permissions. if (!self::can_i('edit', 'Quote Tasks')) { exit; } // no permissions if (isset($_REQUEST['toggle_completed'])) { $quote_task_id = (int) $_REQUEST['quote_task_id']; $task_data = $quote_tasks[$quote_task_id]; $result = array(); if ($task_data && $task_data['quote_id'] == $quote_id) { if ($task_data['invoiced'] && $task_data['fully_completed']) { // dont allow to 'uncompleted' fully completed invoice tasks } else { // it is editable. $task_data['fully_completed_t'] = 1; $task_data['fully_completed'] = $task_data['fully_completed'] ? 0 : 1; // save a single quote task $this->save_quote_tasks($quote_id, array('quote_task' => array($quote_task_id => $task_data))); $result['success'] = 1; $result['quote_id'] = $quote_id; $result['quote_task_id'] = $quote_task_id; } } echo json_encode($result); exit; } else { if (isset($_REQUEST['update_task_order'])) { // updating the task orders for this task.. $task_order = (array) $_REQUEST['task_order']; foreach ($task_order as $quote_task_id => $new_order) { if ((int) $new_order > 0 && isset($quote_tasks[$quote_task_id])) { update_insert('quote_task_id', $quote_task_id, 'quote_task', array('task_order' => (int) $new_order)); } } echo 'done'; } else { $quote_task_id = (int) $_REQUEST['quote_task_id']; $task_data = $quote_tasks[$quote_task_id]; $task_editable = true; // todo - load this select box in via javascript from existing one on page. $staff_members = module_user::get_staff_members(); $staff_member_rel = array(); foreach ($staff_members as $staff_member) { $staff_member_rel[$staff_member['user_id']] = $staff_member['name']; } // new different formats for quote data. $task_data['manual_task_type_real'] = $task_data['manual_task_type']; if ((!isset($task_data['manual_task_type']) || $task_data['manual_task_type'] < 0) && isset($quote['default_task_type'])) { // use the quote task type $task_data['manual_task_type'] = $quote['default_task_type']; } if (isset($_REQUEST['get_preview'])) { $after_quote_task_id = $quote_task_id; // this will put it right back where it started. $previous_quote_task_id = 0; $quote_tasks = self::get_tasks($quote_id); foreach ($quote_tasks as $k => $v) { // find out where this new task position is! if ($k == $quote_task_id) { $after_quote_task_id = $previous_quote_task_id; break; } $previous_quote_task_id = $k; } $create_invoice_button = ''; //if($quote['total_amount_invoicable'] > 0 && module_invoice::can_i('create','Invoices')){ if (count($quote['uninvoiced_quote_task_ids']) && module_invoice::can_i('create', 'Invoices')) { //href="'.module_invoice::link_generate('new',array('arguments'=>array( 'quote_id' => $quote_id, ))).'" $create_invoice_button = '<a class="submit_button save_button uibutton quote_generate_invoice_button" onclick="return ucm.quote.generate_invoice();">' . _l('Create Invoice') . '</a>'; } $result = array('quote_task_id' => $quote_task_id, 'after_quote_task_id' => $after_quote_task_id, 'html' => self::generate_task_preview($quote_id, $quote, $quote_task_id, $task_data), 'summary_html' => self::generate_quote_summary($quote_id, $quote), 'create_invoice_button' => $create_invoice_button); echo json_encode($result); } else { $show_task_numbers = module_config::c('quote_show_task_numbers', 1) && $quote['auto_task_numbers'] != 2; ob_start(); include 'pages/ajax_task_edit.php'; $result = array('quote_task_id' => $quote_task_id, 'hours' => isset($_REQUEST['hours']) ? (double) $_REQUEST['hours'] : 0, 'html' => ob_get_clean()); echo json_encode($result); } } } exit; } else { if ("save_quote" == $_REQUEST['_process']) { $save_status = $this->save_quote($_REQUEST['quote_id'], $_POST); $quote_id = isset($save_status['quote_id']) ? $save_status['quote_id'] : false; if (!$quote_id) { set_error('Failed to save quote'); redirect_browser(module_quote::link_open(false)); } // look for the new tasks flag. if (isset($_REQUEST['default_task_list_id']) && isset($_REQUEST['default_tasks_action'])) { switch ($_REQUEST['default_tasks_action']) { case 'insert_default': if ((int) $_REQUEST['default_task_list_id'] > 0) { $default = self::get_default_task($_REQUEST['default_task_list_id']); $task_data = $default['task_data']; $new_task_data = array('quote_task' => array()); foreach ($task_data as $task) { $task['quote_id'] = $quote_id; $new_task_data['quote_task'][] = $task; } $this->save_quote_tasks($quote_id, $new_task_data); } break; case 'save_default': $new_default_name = trim($_REQUEST['default_task_list_id']); if ($new_default_name != '') { // time to save it! $task_data = self::get_tasks($quote_id); $cached_task_data = array(); foreach ($task_data as $task) { unset($task['quote_task_id']); unset($task['date_done']); unset($task['invoice_id']); unset($task['task_order']); unset($task['create_user_id']); unset($task['update_user_id']); unset($task['date_created']); unset($task['date_updated']); $task['saved_time'] = time(); $cached_task_data[] = $task; /*$cached_task_data[] = array( 'hours' => $task['hours'], 'amount' => $task['amount'], 'billable' => $task['billable'], 'fully_completed' => $task['fully_completed'], 'description' => $task['description'], 'long_description' => $task['long_description'], 'date_due' => $task['date_due'], 'user_id' => $task['user_id'], 'approval_required' => $task['approval_required'], 'task_order' => $task['task_order'], 'saved_time' => time(), );*/ } self::save_default_tasks((int) $_REQUEST['default_task_list_id'], $new_default_name, $cached_task_data); unset($task_data); } break; } } if (isset($_REQUEST['save_ajax_task'])) { // do everything via ajax. trickery! if ($quote_id <= 0) { die('Shouldnt happen'); } //$result = $this->save_quote_tasks( $quote_id, $_POST ); $result = isset($save_status['task_result']) ? $save_status['task_result'] : false; $quote_data = self::get_quote($quote_id, false); $new_status = self::update_quote_completion_status($quote_id); $new_status = addcslashes(htmlspecialchars($new_status), "'"); //module_cache::clear_cache(); $new_quote_data = self::get_quote($quote_id, false); if ($quote_id != $_REQUEST['quote_id']) { ?> <script type="text/javascript"> top.location.href = '<?php echo $this->link_open($quote_id); ?> &added=true'; </script> <?php exit; } // we now have to edit the parent DOM to reflect these changes. // what were we doing? adding a new task? editing an existing task? switch ($result['status']) { case 'created': // we added a new task. // add a new task to the bottom (OR MID WAY!) through the task list. if ((int) $result['quote_task_id'] > 0) { ?> <script type="text/javascript"> parent.refresh_task_preview(<?php echo (int) $result['quote_task_id']; ?> ); parent.clear_create_form(); parent.ucm.add_message('<?php _e('New task created successfully'); ?> '); parent.ucm.display_messages(true); <?php if ($quote_data['status'] != $new_status) { ?> parent.jQuery('#status').val('<?php echo $new_status; ?> ').change(); <?php } ?> <?php if ($new_quote_data['date_approved'] != $quote_data['date_approved']) { ?> parent.jQuery('#date_approved').val('<?php echo print_date($new_quote_data['date_approved']); ?> ').change(); <?php } ?> </script> <?php } else { set_error('New task creation failed.'); ?> <script type="text/javascript"> top.location.href = '<?php echo $this->link_open($quote_id); ?> &added=true'; </script> <?php } break; case 'deleted': // we deleted a task. set_message('Task removed successfully'); ?> <script type="text/javascript"> top.location.href = '<?php echo $this->link_open($quote_id); ?> '; <?php if ($quote_data['status'] != $new_status) { ?> parent.jQuery('#status').val('<?php echo $new_status; ?> ').change(); <?php } ?> </script> <?php break; case 'error': set_error('Something happened while trying to save a task. Unknown error.'); // something happened, refresh the parent browser frame ?> <script type="text/javascript"> top.location.href = '<?php echo $this->link_open($quote_id); ?> '; </script> <?php break; case 'edited': // we changed a task (ie: completed?); // update this task above. if ((int) $result['quote_task_id'] > 0) { ?> <script type="text/javascript"> parent.canceledittask(); //parent.refresh_task_preview(<?php echo (int) $result['quote_task_id']; ?> ); parent.ucm.add_message('<?php _e('Task saved successfully'); ?> '); parent.ucm.display_messages(true); <?php if ($quote_data['status'] != $new_status) { ?> parent.jQuery('#status').val('<?php echo $new_status; ?> ').change(); <?php } ?> <?php if ($new_quote_data['date_approved'] != $quote_data['date_approved']) { ?> parent.jQuery('#date_approved').val('<?php echo print_date($new_quote_data['date_approved']); ?> ').change(); <?php } ?> </script> <?php } else { ?> <script type="text/javascript"> parent.canceledittask(); parent.ucm.add_error('<?php _e('Unable to save task'); ?> '); parent.ucm.display_messages(true); <?php if ($quote_data['status'] != $new_status) { ?> parent.jQuery('#status').val('<?php echo $new_status; ?> ').change(); <?php } ?> </script> <?php } break; default: ?> <script type="text/javascript"> parent.ucm.add_error('<?php _e('Unable to save task. Please check required fields.'); ?> '); parent.ucm.display_messages(true); </script> <?php break; } exit; } if (isset($_REQUEST['butt_print']) && $_REQUEST['butt_print']) { redirect_browser(module_quote::link_public_print($quote_id)); } if (isset($_REQUEST['butt_email']) && $_REQUEST['butt_email']) { redirect_browser(module_quote::link_generate($quote_id, array('arguments' => array('email' => 1)))); } if (isset($_REQUEST['butt_duplicate']) && $_REQUEST['butt_duplicate'] && module_quote::can_i('create', 'Quotes')) { $new_quote_id = module_quote::duplicate_quote($quote_id); set_message('Quote duplicated successfully'); redirect_browser(module_quote::link_generate($new_quote_id)); } set_message("Quote saved successfully"); //redirect_browser($this->link_open($quote_id)); redirect_browser(isset($_REQUEST['_redirect']) && !empty($_REQUEST['_redirect']) ? $_REQUEST['_redirect'] : $this->link_open($quote_id)); } } } } } if (!count($errors)) { redirect_browser($_REQUEST['_redirect']); exit; } print_error($errors, true); }