diff options
Diffstat (limited to 'bulk_approval.inc')
-rwxr-xr-x | bulk_approval.inc | 1259 |
1 files changed, 733 insertions, 526 deletions
diff --git a/bulk_approval.inc b/bulk_approval.inc index 625960f..55d35fc 100755 --- a/bulk_approval.inc +++ b/bulk_approval.inc @@ -1,618 +1,825 @@ -<?php +<?php - function lab_migration_bulk_approval_form($form, &$form_state) { - - $options_first =_bulk_list_of_labs(); +function lab_migration_bulk_approval_form($form, &$form_state) + { -$options_two = _ajax_bulk_get_experiment_list(); + $options_first = _bulk_list_of_labs(); -$selected = isset($form_state['values']['lab']) ? $form_state['values']['lab'] : key($options_first); + $options_two = _ajax_bulk_get_experiment_list(); -$select_two = isset($form_state['values']['lab_experiment_list']) ? $form_state['values']['lab_experiment_list'] : key($options_two); + $selected = isset($form_state['values']['lab']) ? $form_state['values']['lab'] : key($options_first); + $select_two = isset($form_state['values']['lab_experiment_list']) ? $form_state['values']['lab_experiment_list'] : key($options_two); - - $form = array(); - $form['lab'] = array( + $action_first = _bulk_list_lab_actions(); + $action_two = _bulk_list_experiment_actions(); + + $selected_action = isset($form_state['values']['lab_actions']) ? $form_state['values']['lab_actions'] : key($action_first); + + $form = array(); + $form['lab'] = array( '#type' => 'select', '#title' => t('Title of the lab'), - '#options' => _bulk_list_of_labs(), + '#options' => _bulk_list_of_labs(), '#default_value' => $selected, '#ajax' => array( - 'callback' => 'ajax_bulk_experiment_list_callback', + 'callback' => 'ajax_bulk_experiment_list_callback' ), - '#suffix' => '<div id="ajax_selected_lab"></div><div id="ajax_selected_lab_pdf"></div>', - - ); - - $form['lab_actions'] = array( + '#suffix' => '<div id="ajax_selected_lab"></div><div id="ajax_selected_lab_pdf"></div>' + ); + + $form['lab_actions'] = array( '#type' => 'select', - '#title' => t('Please select action'), - '#options' => _bulk_list_lab_actions(), + '#title' => t('Please select action for lab'), + '#options' => _bulk_list_lab_actions(), '#default_value' => 0, - '#prefix' => '<div id="ajax_selected_lab_action" style="color:red;">', + '#prefix' => '<div id="ajax_selected_lab_action" style="color:red;">', '#suffix' => '</div>', - '#states' => array('invisible' => array(':input[name="lab"]' => array('value' => 0),),), - - ); - $form['lab_experiment_list'] = array( + '#states' => array( + 'invisible' => array( + ':input[name="lab"]' => array( + 'value' => 0 + ) + ) + ) + ); + + $form['lab_experiment_list'] = array( '#type' => 'select', - '#title' => t('Titile of the experiment'), - '#options' => _ajax_bulk_get_experiment_list($selected), + '#title' => t('Titile of the experiment'), + '#options' => _ajax_bulk_get_experiment_list($selected), '#default_value' => isset($form_state['values']['lab_experiment_list']) ? $form_state['values']['lab_experiment_list'] : '', '#ajax' => array( - 'callback' => 'ajax_bulk_solution_list_callback', + 'callback' => 'ajax_bulk_solution_list_callback' ), '#prefix' => '<div id="ajax_selected_experiment">', '#suffix' => '</div>', - '#states' => array('invisible' => array(':input[name="lab"]' => array('value' => 0),),), - ); - $form['download_experiment'] = array( + '#states' => array( + 'invisible' => array( + ':input[name="lab"]' => array( + 'value' => 0 + ) + ) + ) + ); + + $form['download_experiment'] = array( '#type' => 'item', - '#markup' => '<div id="ajax_download_experiment"></div>', - ); - - $form['lab_experiment_actions'] = array( + '#markup' => '<div id="ajax_download_experiment"></div>' + ); + + $form['lab_experiment_actions'] = array( '#type' => 'select', - '#title' => t('Please select action'), - '#options' => _bulk_list_experiment_actions(), + '#title' => t('Please select action for lab experiment'), + '#options' => _bulk_list_experiment_actions(), '#default_value' => 0, - '#prefix' => '<div id="ajax_selected_lab_experiment_action" style="color:red;">', + '#prefix' => '<div id="ajax_selected_lab_experiment_action" style="color:red;">', '#suffix' => '</div>', - '#states' => array('invisible' => array(':input[name="lab"]' => array('value' => 0),),), - ); - - $form['lab_solution_list'] = array( + '#states' => array( + 'invisible' => array( + ':input[name="lab"]' => array( + 'value' => 0 + ) + ) + ) + ); + + $form['lab_solution_list'] = array( '#type' => 'select', '#title' => t('Solution'), - '#options' => _ajax_bulk_get_solution_list($select_two), + '#options' => _ajax_bulk_get_solution_list($select_two), '#default_value' => isset($form_state['values']['lab_solution_list']) ? $form_state['values']['lab_solution_list'] : '', '#ajax' => array( - 'callback' => 'ajax_bulk_solution_files_callback', + 'callback' => 'ajax_bulk_solution_files_callback' ), '#prefix' => '<div id="ajax_selected_solution">', '#suffix' => '</div>', - '#states' => array('invisible' => array(':input[name="lab"]' => array('value' => 0),),), - ); - - - $form['lab_experiment_solution_actions'] = array( + '#states' => array( + 'invisible' => array( + ':input[name="lab"]' => array( + 'value' => 0 + ) + ) + ) + ); + + $form['lab_experiment_solution_actions'] = array( '#type' => 'select', - '#title' => t('Please select action'), - '#options' => _bulk_list_solution_actions(), + '#title' => t('Please select action for solution'), + '#options' => _bulk_list_solution_actions(), '#default_value' => 0, - '#prefix' => '<div id="ajax_selected_lab_experiment_solution_action" style="color:red;">', + '#prefix' => '<div id="ajax_selected_lab_experiment_solution_action" style="color:red;">', '#suffix' => '</div>', - '#states' => array('invisible' => array(':input[name="lab"]' => array('value' => 0),),), - ); - - $form['download_solution'] = array( + '#states' => array( + 'invisible' => array( + ':input[name="lab"]' => array( + 'value' => 0 + ) + ) + ) + ); + + $form['download_solution'] = array( '#type' => 'item', - '#markup' => '<div id="ajax_download_experiment_solution"></div>', - ); - $form['edit_solution'] = array( + '#markup' => '<div id="ajax_download_experiment_solution"></div>' + ); + + $form['edit_solution'] = array( '#type' => 'item', - '#markup' => '<div id="ajax_edit_experiment_solution"></div>', - ); - $form['solution_files'] = array( + '#markup' => '<div id="ajax_edit_experiment_solution"></div>' + ); + + $form['solution_files'] = array( '#type' => 'item', - // '#title' => t('List of solution_files'), + // '#title' => t('List of solution files'), '#markup' => '<div id="ajax_solution_files"></div>', - '#states' => array('invisible' => array(':input[name="lab"]' => array('value' => 0),),), - ); - - - $form['message'] = array( - '#type' => 'textarea', - '#title' => t('If Dis-Approved please specify reason for Dis-Approval'), - '#prefix' => '<div id= "message_submit">', - '#states' => array('invisible' => array(':input[name="lab"]' => array('value' => 0,),),), - - ); - - $form['submit'] = array( - '#type' => 'submit', - '#value' => t('Submit'), - '#suffix' => '</div>', - '#states' => array('invisible' => array(':input[name="lab"]' => array('value' => 0,),),), - + '#states' => array( + 'invisible' => array( + ':input[name="lab"]' => array( + 'value' => 0 + ) + ) + ) ); - return $form; - } - /** - * Ajax callback triggered by select. - */ - function ajax_bulk_experiment_list_callback($form, $form_state) { - - $commands = array(); - $lab_default_value = $form_state['values']['lab']; - if($lab_default_value !=0){ - - - - - $commands[] = ajax_command_html('#ajax_selected_lab', l('Download', 'lab-migration/full-download/lab/' . $lab_default_value) . ' ' . t('(Download all the approved and unapproved solutions of the entire lab)') ); - - /*$commands[] = ajax_command_html('#ajax_selected_lab_pdf', l('Download PDF', 'lab-migration/generate-lab/' .$lab_default_value . '/1') . ' ' . t('(Download PDF of all the approved and unapproved solution of the entire lab)')); */ - - $form['lab_actions']['#options'] = _bulk_list_lab_actions(); - $form['lab_experiment_list']['#options'] = _ajax_bulk_get_experiment_list($lab_default_value); - $commands[] = ajax_command_data('#ajax_selected_lab', 'form_state_value_select', $form_state['values']['lab_experiment_list']); - $commands[] = ajax_command_replace('#ajax_selected_experiment',drupal_render($form['lab_experiment_list'])); - $commands[] = ajax_command_replace('#ajax_selected_lab_action',drupal_render($form['lab_actions'])); - $commands[] = ajax_command_html('#ajax_selected_solution', ''); - $commands[] = ajax_command_html('#ajax_selected_lab_experiment_action',''); - $commands[] = ajax_command_html('#ajax_selected_lab_experiment_solution_action',''); - $commands[] = ajax_command_html('#ajax_solution_files', ''); - $commands[] = ajax_command_html('#ajax_download_experiment_solution', ''); - $commands[] = ajax_command_html('#ajax_edit_experiment_solution', ''); - - }else - { - - $commands[] = ajax_command_html('#ajax_selected_lab', ''); - $commands[] = ajax_command_html('#ajax_selected_lab_pdf', ''); - $commands[] = ajax_command_data('#ajax_selected_lab', 'form_state_value_select', $form_state['values']['lab']); - $commands[] = ajax_command_html('#ajax_selected_experiment',''); - $commands[] = ajax_command_html('#ajax_selected_lab_action',''); - $commands[] = ajax_command_html('#ajax_selected_lab_experiment_action',''); - $commands[] = ajax_command_html('#ajax_download_experiment', ''); - $commands[] = ajax_command_html('#ajax_selected_lab_experiment_solution_action',''); - $commands[] = ajax_command_html('#ajax_solution_files', ''); - $commands[] = ajax_command_html('#ajax_download_experiment_solution', ''); - $commands[] = ajax_command_html('#ajax_edit_experiment_solution', ''); - - } - - return array('#type' => 'ajax', '#commands' => $commands); - } - - - - function ajax_bulk_solution_list_callback($form, $form_state) { - - $commands = array(); - $experiment_list_default_value = $form_state['values']['lab_experiment_list']; - //var_dump($lab_default_value); - if($experiment_list_default_value !=0){ - $form['lab_experiment_actions']['#options'] =_bulk_list_experiment_actions(); - $form['lab_solution_list']['#options'] = _ajax_bulk_get_solution_list($experiment_list_default_value); - - $commands[] = ajax_command_html('#ajax_download_experiment', l('Download Experiment', 'lab-migration/download/experiment/' . $experiment_list_default_value)); - - - $commands[] = ajax_command_data('#ajax_selected_experiment', 'form_state_value_select', $form_state['values']['lab_experiment_list']); - - $commands[] = ajax_command_html('#ajax_selected_experiment',drupal_render($form['lab_experiment_list'])); - $commands[] = ajax_command_html('#ajax_selected_lab_experiment_action',drupal_render($form['lab_experiment_actions'])); - $commands[] = ajax_command_html('#ajax_selected_solution',drupal_render($form['lab_solution_list'])); -$commands[] = ajax_command_html('#ajax_selected_lab_experiment_solution_action',''); - $commands[] = ajax_command_html('#ajax_solution_files', ''); - $commands[] = ajax_command_html('#ajax_download_experiment_solution', ''); - $commands[] = ajax_command_html('#ajax_edit_experiment_solution', ''); - - }else - { - $commands[] = ajax_command_html('#ajax_download_experiment', ''); - $commands[] = ajax_command_html('#ajax_selected_lab_experiment_action',''); - - $commands[] = ajax_command_html('#ajax_selected_solution',''); - $commands[] = ajax_command_html('#ajax_selected_lab_experiment_solution_action',''); - $commands[] = ajax_command_html('#ajax_solution_files', ''); - $commands[] = ajax_command_html('#ajax_download_experiment_solution', ''); - $commands[] = ajax_command_html('#ajax_edit_experiment_solution', ''); - // $commands[] = ajax_command_replace('#ajax_selected_experiment',drupal_render($form['lab_experiment_list'])); - - } - - return array('#type' => 'ajax', '#commands' => $commands); - } + $form['message'] = array( + '#type' => 'textarea', + '#title' => t('If Dis-Approved please specify reason for Dis-Approval'), + '#prefix' => '<div id= "message_submit">', + '#states' => array( + 'visible' => array( + array( + array( + ':input[name="lab_actions"]' => array( + 'value' => 3 + ) + ), + 'or', + array( + ':input[name="lab_experiment_actions"]' => array( + 'value' => 3 + ) + ), + 'or', + array( + ':input[name="lab_experiment_solution_actions"]' => array( + 'value' => 3 + ) + ) + ) + ), + 'or', + 'required' => array( + array( + array( + ':input[name="book_actions"]' => array( + 'value' => 3 + ) + ), + 'or', + array( + ':input[name="lab_experiment_actions"]' => array( + 'value' => 3 + ) + ), + 'or', + array( + ':input[name="lab_experiment_solution_actions"]' => array( + 'value' => 3 + ) + ) + ) + ) + ) + ); -function ajax_bulk_solution_files_callback($form, $form_state) { + $form['submit'] = array( + '#type' => 'submit', + '#value' => t('Submit'), + '#suffix' => '</div>', + '#states' => array( + 'invisible' => array( + ':input[name="lab"]' => array( + 'value' => 0 + ) + ) + ) + ); - $commands = array(); - $solution_list_default_value = $form_state['values']['lab_solution_list']; - //var_dump($lab_default_value); - if($solution_list_default_value !=0){ - $form['lab_experiment_solution_actions']['#options'] = _bulk_list_solution_actions(); - - $commands[] = ajax_command_html('#ajax_selected_lab_experiment_solution_action',drupal_render($form['lab_experiment_solution_actions'])); - /*************************************************************************************/ - //$solution_list_q = db_query("SELECT * FROM {lab_migration_solution_files} WHERE solution_id = %d", $form_state['values']['solution']); - $query = db_select('lab_migration_solution_files'); - $query->fields('lab_migration_solution_files'); - $query->condition('solution_id', $solution_list_default_value); - $solution_list_q = $query->execute(); - if ($solution_list_q) - { - $solution_files_rows = array(); - while ($solution_list_data = $solution_list_q->fetchObject()) - { - $solution_file_type = ''; - switch ($solution_list_data->filetype) - { - case 'S' : $solution_file_type = 'Source or Main file'; break; - case 'R' : $solution_file_type = 'Result file'; break; - case 'X' : $solution_file_type = 'xcos file'; break; - default : $solution_file_type = 'Unknown'; break; - } - $solution_files_rows[] = array(l($solution_list_data->filename, 'lab-migration/download/file/' . $solution_list_data->id), $solution_file_type); - } - - /* dependency files */ - //$dependency_q = db_query("SELECT * FROM {lab_migration_solution_dependency} WHERE solution_id = %d", $form_state['values']['solution']); - $query = db_select('lab_migration_solution_dependency'); - $query->fields('lab_migration_solution_dependency'); - $query->condition('solution_id', $solution_list_default_value); - $dependency_q = $query->execute(); - while ($dependency_data = $dependency_q->fetchObject()) - { - //$dependency_files_q = db_query("SELECT * FROM {lab_migration_dependency_files} WHERE id = %d", $dependency_data->dependency_id); - $query = db_select('lab_migration_dependency_files'); - $query->fields('lab_migration_dependency_files'); - $query->condition('id', $dependency_data->dependency_id); - $dependency_files_q = $query->execute(); - $dependency_files_data = $dependency_files_q->fetchObject(); - $solution_file_type = 'Dependency file'; - $solution_files_rows[] = array(l($dependency_files_data->filename, 'lab-migration/download/dependency/' . $dependency_files_data->dependency_id), $solution_file_type); - } - - /* creating list of files table */ - $solution_files_header = array('Filename', 'Type'); - $solution_files = theme('table', array('header' => $solution_files_header, 'rows' => $solution_files_rows)); - - } - $form['solution_files']['#title'] = 'List of solution files'; - $form['solution_files']['#markup'] = $solution_files; - $commands[] = ajax_command_html('#ajax_download_experiment_solution', l('Download Solution', 'lab-migration/download/solution/' . $solution_list_default_value)); - $commands[] = ajax_command_html('#ajax_edit_experiment_solution', l('Edit Solution', 'code-approval/editcode/' . $solution_list_default_value)); - // $commands[] = ajax_command_html('#ajax_solution_files', $solution_files); - $commands[] = ajax_command_html('#ajax_solution_files',drupal_render($form['solution_files'])); - - /*************************************************************************************/ - - + return $form; - - }else - { - $commands[] = ajax_command_html('#ajax_selected_lab_experiment_solution_action',''); - $commands[] = ajax_command_html('#ajax_download_experiment_solution', ''); - $commands[] = ajax_command_html('#ajax_edit_experiment_solution', ''); - $commands[] = ajax_command_html('#ajax_solution_files', ''); - } - - return array('#type' => 'ajax', '#commands' => $commands); - } -/************************************************************/ -function lab_migration_bulk_approval_form_validate($form, &$form_state){ -if(($form_state['values']['lab_actions'] == 0) && ($form_state['values']['lab_experiment_actions']== 0) && ($form_state['values']['lab_experiment_solution_actions'] == 0)) - drupal_set_message("Wrong selection of action. Please select any one action", 'error'); - return; - if(($form_state['values']['lab_actions'] != 0) && ($form_state['values']['lab_experiment_actions'] != 0) && ($form_state['values']['lab_experiment_solution_actions'] != 0)) - drupal_set_message("Wrong selection of action. Please select any one action"); - return; - if(($form_state['values']['lab_actions'] != 0) && ($form_state['values']['lab_experiment_actions'] !=0) && ($form_state['values']['lab_experiment_solution_actions'] == 0)) - drupal_set_message("Wrong selection of action. Please select any one action", 'error'); - return; - if(($form_state['values']['lab_actions'] != 0) && ($form_state['values']['lab_experiment_actions'] == 0) && ($form_state['values']['lab_experiment_solution_actions'] != 0)) - drupal_set_message("Wrong selection of action. Please select any one action", 'error'); - return; - -if(($form_state['values']['lab_actions'] == 0) && ($form_state['values']['lab_experiment_actions'] != 0) && ($form_state['values']['lab_experiment_solution_actions'] != 0)) - drupal_set_message("Wrong selection of action. Please select any one action", 'error'); - return; - } -function lab_migration_bulk_approval_form_submit($form, &$form_state){ - // var_dump($form_state['values']['lab_actions']); - // die; - global $user; - $root_path = lab_migration_path(); - - if ($form_state['clicked_button']['#value'] == 'Submit') - { - if ($form_state['values']['lab']) - lab_migration_del_lab_pdf($form_state['values']['lab']); - - if (user_access('lab migration bulk manage code')) - { - if (($form_state['values']['lab_actions'] == 1) && ($form_state['values']['lab_experiment_actions']== 0) && ($form_state['values']['lab_experiment_solution_actions'] == 0)) - { - - /* approving entire lab */ - // $experiment_q = db_query("SELECT * FROM {lab_migration_experiment} WHERE proposal_id = %d", $form_state['values']['lab']); - $query = db_select('lab_migration_experiment'); - $query->fields('lab_migration_experiment'); - $query->condition('proposal_id', $form_state['values']['lab']); - $experiment_q = $query->execute(); - while ($experiment_data =$experiment_q->fetchObject()) - { - // db_query("UPDATE {lab_migration_solution} SET approval_status = 1, approver_uid = %d WHERE experiment_id = %d AND approval_status = 0", $user->uid, $experiment_data->id); - db_query("UPDATE {lab_migration_solution} SET approval_status = 1, approver_uid = :approver_uid WHERE experiment_id = :experiment_id AND approval_status = 0", array(':approver_uid' => $user->uid, ':experiment_id' => $experiment_data->id)); - } - drupal_set_message(t('Approved Entire Lab.'), 'status'); - - /* email */ - $email_subject = t('Your uploaded solutions have been approved'); - $email_body = array(0 => t('Your all the uploaded solutions for the Lab have been approved.')); - - } elseif(($form_state['values']['lab_actions'] == 2) && ($form_state['values']['lab_experiment_actions']== 0) && ($form_state['values']['lab_experiment_solution_actions'] == 0)) { - - /* pending review entire lab */ - //$experiment_q = db_query("SELECT * FROM {lab_migration_experiment} WHERE proposal_id = %d", $form_state['values']['lab']); - $experiment_q = db_query("SELECT * FROM {lab_migration_experiment} WHERE proposal_id = :proposal_id", array(':proposal_id' => $form_state['values']['lab'])); - while ($experiment_data = $experiment_q->fetchObject()) - { - //db_query("UPDATE {lab_migration_solution} SET approval_status = 0 WHERE experiment_id = %d", $experiment_data->id); - db_query("UPDATE {lab_migration_solution} SET approval_status = 0 WHERE experiment_id = :experiment_id", array(":experiment_id" => $experiment_data->id)); - } - drupal_set_message(t('Pending Review Entire Lab.'), 'status'); - - /* email */ - $email_subject = t('Your uploaded solutions have been marked as pending'); - $email_body = array(0 => t('Your all the uploaded solutions for the Lab have been marked as pending to be review. You will be able to see the solutions after they have been approved by one of our reviewers.')); - - } elseif(($form_state['values']['lab_actions'] == 3) && ($form_state['values']['lab_experiment_actions']== 0) && ($form_state['values']['lab_experiment_solution_actions'] == 0)) { - - if (!user_access('lab migration bulk delete code')) - { - drupal_set_message(t('You do not have permission to Bulk Dis-Approved and Deleted Entire Lab.'), 'error'); - return; - } - - if (lab_migration_delete_lab($form_state['values']['lab'])) - { - drupal_set_message(t('Dis-Approved and Deleted Entire Lab.'), 'status'); - } else { - drupal_set_message(t('Error Dis-Approving and Deleting Entire Lab.'), 'error'); - } - - /* email */ - $email_subject = t('Your uploaded solutions have been marked as dis-approved'); - $email_body = array(0 =>t('Your all the uploaded solutions for the whole Lab have been marked as dis-approved. - -Reason for dis-approval: - -' . $form_state['values']['message'])); - - } elseif(($form_state['values']['lab_actions'] == 4) && ($form_state['values']['lab_experiment_actions']== 0) && ($form_state['values']['lab_experiment_solution_actions'] == 0)) { - - if (!user_access('lab migration bulk delete code')) - { - drupal_set_message(t('You do not have permission to Bulk Delete Entire Lab Including Proposal.'), 'error'); - return; - } - - /* check if dependency files are present */ - $dep_q = db_query("SELECT * FROM {lab_migration_dependency_files} WHERE proposal_id = :proposal_id", array(":proposal_id" => $form_state['values']['lab'])); - if ($dep_data = $dep_q->fetchObject()) - { - drupal_set_message(t("Cannot delete lab since it has dependency files that can be used by others. First delete the dependency files before deleting the lab."), 'error'); - return; - } - - if (lab_migration_delete_lab($form_state['values']['lab'])) - { - drupal_set_message(t('Dis-Approved and Deleted Entire Lab solutions.'), 'status'); - - $dir_path = $root_path . $form_state['values']['lab']; - if (is_dir($dir_path)) - { - $res = rmdir($dir_path); - if (!$res) - { - drupal_set_message(t("Cannot delete Lab directory : " . $dir_path . ". Please contact administrator."), 'error'); - return; - } - } else { - drupal_set_message(t("Lab directory not present : " . $dir_path . ". Skipping deleting lab directory."), 'status'); - } - - /* deleting full proposal */ - //$proposal_q = db_query("SELECT * FROM {lab_migration_proposal} WHERE id = %d", $form_state['values']['lab']); - $proposal_q = db_query("SELECT * FROM {lab_migration_proposal} WHERE id = :id", array(":id" => $form_state['values']['lab'])); - $proposal_data = $proposal_q->fetchObject(); - $proposal_id = $proposal_data->id; - db_query("DELETE FROM {lab_migration_experiment} WHERE proposal_id = :proposal_id",array(":proposal_id" => $proposal_id)); - db_query("DELETE FROM {lab_migration_proposal} WHERE id = :id", array(":id" => $proposal_id)); - - drupal_set_message(t('Deleted Lab Proposal.'), 'status'); - - /* email */ - $email_subject = t('Your uploaded solutions including the Lab proposal have been deleted'); - $email_body = array(0 =>t('Your all the uploaded solutions including the Lab proposal have been deleted permanently.')); - - } else { - drupal_set_message(t('Error Dis-Approving and Deleting Entire Lab.'), 'error'); - } - } elseif(($form_state['values']['lab_actions'] == 0) && ($form_state['values']['lab_experiment_actions']== 1 ) && ($form_state['values']['lab_experiment_solution_actions'] == 0)) { +/** + * Ajax callback triggered by select. + */ +function ajax_bulk_experiment_list_callback($form, $form_state) + { - db_query("UPDATE {lab_migration_solution} SET approval_status = 1, approver_uid = :approver_uid WHERE experiment_id = :experiment_id AND approval_status = 0", array(":approver_uid" => $user->uid, ":experiment_id"=> $form_state['values']['lab_experiment_list'])); - drupal_set_message(t('Approved Entire Experiment.'), 'status'); + $commands = array(); + $lab_default_value = $form_state['values']['lab']; + if ($lab_default_value != 0) + { + $commands[] = ajax_command_html('#ajax_selected_lab', l('Download', 'lab-migration/full-download/lab/' . $lab_default_value) . ' ' . t('(Download all the approved and unapproved solutions of the entire lab)')); + + /*$commands[] = ajax_command_html('#ajax_selected_lab_pdf', l('Download PDF', 'lab-migration/generate-lab/' .$lab_default_value . '/1') . ' ' . t('(Download PDF of all the approved and unapproved solution of the entire lab)')); */ + + $form['lab_actions']['#options'] = _bulk_list_lab_actions(); + $form['lab_experiment_list']['#options'] = _ajax_bulk_get_experiment_list($lab_default_value); + $commands[] = ajax_command_data('#ajax_selected_lab', 'form_state_value_select', $form_state['values']['lab_experiment_list']); + $commands[] = ajax_command_replace('#ajax_selected_experiment', drupal_render($form['lab_experiment_list'])); + $commands[] = ajax_command_replace('#ajax_selected_lab_action', drupal_render($form['lab_actions'])); + $commands[] = ajax_command_html('#ajax_selected_solution', ''); + $commands[] = ajax_command_html('#ajax_selected_lab_experiment_action', ''); + $commands[] = ajax_command_html('#ajax_selected_lab_experiment_solution_action', ''); + $commands[] = ajax_command_html('#ajax_solution_files', ''); + $commands[] = ajax_command_html('#ajax_download_experiment_solution', ''); + $commands[] = ajax_command_html('#ajax_edit_experiment_solution', ''); - /* email */ - $email_subject = t('Your uploaded solutions have been approved'); - $email_body = array(0 =>t('Your all the uploaded solutions for the experiment have been approved.')); + } + else + { - } elseif(($form_state['values']['lab_actions'] == 0) && ($form_state['values']['lab_experiment_actions']== 2) && ($form_state['values']['lab_experiment_solution_actions'] == 0)) { + $commands[] = ajax_command_html('#ajax_selected_lab', ''); + $commands[] = ajax_command_html('#ajax_selected_lab_pdf', ''); + $commands[] = ajax_command_data('#ajax_selected_lab', 'form_state_value_select', $form_state['values']['lab']); + $commands[] = ajax_command_html('#ajax_selected_experiment', ''); + $commands[] = ajax_command_html('#ajax_selected_lab_action', ''); + $commands[] = ajax_command_html('#ajax_selected_lab_experiment_action', ''); + $commands[] = ajax_command_html('#ajax_download_experiment', ''); + $commands[] = ajax_command_html('#ajax_selected_lab_experiment_solution_action', ''); + $commands[] = ajax_command_html('#ajax_solution_files', ''); + $commands[] = ajax_command_html('#ajax_download_experiment_solution', ''); + $commands[] = ajax_command_html('#ajax_edit_experiment_solution', ''); - db_query("UPDATE {lab_migration_solution} SET approval_status = 0 WHERE experiment_id = :experiment_id", array(":experiment_id" => $form_state['values']['lab_experiment_list'])); - drupal_set_message(t('Entire Experiment marked as Pending Review.'), 'status'); + } - /* email */ - $email_subject = t('Your uploaded solutions have been marked as pending'); - $email_body = array(0 =>t('Your all the uploaded solutions for the experiment have been marked as pending to be review.')); + return array( + '#type' => 'ajax', + '#commands' => $commands + ); + } - } elseif(($form_state['values']['lab_actions'] == 1) && ($form_state['values']['lab_experiment_actions']== 3) && ($form_state['values']['lab_experiment_solution_actions'] == 0)) { - if (!user_access('lab migration bulk delete code')) - { - drupal_set_message(t('You do not have permission to Bulk Dis-Approved and Deleted Entire Experiment.'), 'error'); - return; - } +function ajax_bulk_solution_list_callback($form, $form_state) + { - if (lab_migration_delete_experiment($form_state['values']['lab_experiment_list'])) - { - drupal_set_message(t('Dis-Approved and Deleted Entire Experiment.'), 'status'); - } else { - drupal_set_message(t('Error Dis-Approving and Deleting Entire Experiment.'), 'error'); - } + $commands = array(); + $experiment_list_default_value = $form_state['values']['lab_experiment_list']; + //var_dump($lab_default_value); + if ($experiment_list_default_value != 0) + { + $form['lab_experiment_actions']['#options'] = _bulk_list_experiment_actions(); + $form['lab_solution_list']['#options'] = _ajax_bulk_get_solution_list($experiment_list_default_value); - /* email */ - $email_subject = t('Your uploaded solutions have been marked as dis-approved'); - $email_body = array(0 => t('Your uploaded solutions for the entire experiment have been marked as dis-approved. + $commands[] = ajax_command_html('#ajax_download_experiment', l('Download Experiment', 'lab-migration/download/experiment/' . $experiment_list_default_value)); -Reason for dis-approval: + $commands[] = ajax_command_data('#ajax_selected_experiment', 'form_state_value_select', $form_state['values']['lab_experiment_list']); -' . $form_state['values']['message'])); + $commands[] = ajax_command_html('#ajax_selected_experiment', drupal_render($form['lab_experiment_list'])); + $commands[] = ajax_command_html('#ajax_selected_lab_experiment_action', drupal_render($form['lab_experiment_actions'])); + $commands[] = ajax_command_html('#ajax_selected_solution', drupal_render($form['lab_solution_list'])); + $commands[] = ajax_command_html('#ajax_selected_lab_experiment_solution_action', ''); + $commands[] = ajax_command_html('#ajax_solution_files', ''); + $commands[] = ajax_command_html('#ajax_download_experiment_solution', ''); + $commands[] = ajax_command_html('#ajax_edit_experiment_solution', ''); - } elseif(($form_state['values']['lab_actions'] == 0) && ($form_state['values']['lab_experiment_actions']== 0) && ($form_state['values']['lab_experiment_solution_actions'] == 1)) { + } + else + { + $commands[] = ajax_command_html('#ajax_download_experiment', ''); + $commands[] = ajax_command_html('#ajax_selected_lab_experiment_action', ''); + $commands[] = ajax_command_html('#ajax_selected_solution', ''); + $commands[] = ajax_command_html('#ajax_selected_lab_experiment_solution_action', ''); + $commands[] = ajax_command_html('#ajax_solution_files', ''); + $commands[] = ajax_command_html('#ajax_download_experiment_solution', ''); + $commands[] = ajax_command_html('#ajax_edit_experiment_solution', ''); + // $commands[] = ajax_command_replace('#ajax_selected_experiment',drupal_render($form['lab_experiment_list'])); - db_query("UPDATE {lab_migration_solution} SET approval_status = 1, approver_uid = :approver_uid WHERE id = :id", array(":approver_uid" => $user->uid,":id" => $form_state['values']['solution'])); - drupal_set_message(t('Solution approved.'), 'status'); + } - /* email */ - $email_subject = t('Your uploaded solution has been approved'); - $email_body = array(0 =>t('Your uploaded solution has been approved.')); + return array( + '#type' => 'ajax', + '#commands' => $commands + ); + } - } elseif(($form_state['values']['lab_actions'] == 0) && ($form_state['values']['lab_experiment_actions']== 0) && ($form_state['values']['lab_experiment_solution_actions'] == 2)) { +function ajax_bulk_solution_files_callback($form, $form_state) + { - db_query("UPDATE {lab_migration_solution} SET approval_status = 0 WHERE id = :id", array(":id" => $form_state['values']['lab_solution_list'])); - drupal_set_message(t('Solution marked as Pending Review.'), 'status'); + $commands = array(); + $solution_list_default_value = $form_state['values']['lab_solution_list']; + //var_dump($lab_default_value); + if ($solution_list_default_value != 0) + { + $form['lab_experiment_solution_actions']['#options'] = _bulk_list_solution_actions(); + + $commands[] = ajax_command_html('#ajax_selected_lab_experiment_solution_action', drupal_render($form['lab_experiment_solution_actions'])); + /*************************************************************************************/ + //$solution_list_q = db_query("SELECT * FROM {lab_migration_solution_files} WHERE solution_id = %d", $form_state['values']['solution']); + $query = db_select('lab_migration_solution_files'); + $query->fields('lab_migration_solution_files'); + $query->condition('solution_id', $solution_list_default_value); + $solution_list_q = $query->execute(); + if ($solution_list_q) + { + $solution_files_rows = array(); + while ($solution_list_data = $solution_list_q->fetchObject()) + { + $solution_file_type = ''; + switch ($solution_list_data->filetype) + { + case 'S': + $solution_file_type = 'Source or Main file'; + break; + case 'R': + $solution_file_type = 'Result file'; + break; + case 'X': + $solution_file_type = 'xcos file'; + break; + default: + $solution_file_type = 'Unknown'; + break; + } + $solution_files_rows[] = array( + l($solution_list_data->filename, 'lab-migration/download/file/' . $solution_list_data->id), + $solution_file_type + ); + } + + /* dependency files */ + //$dependency_q = db_query("SELECT * FROM {lab_migration_solution_dependency} WHERE solution_id = %d", $form_state['values']['solution']); + $query = db_select('lab_migration_solution_dependency'); + $query->fields('lab_migration_solution_dependency'); + $query->condition('solution_id', $solution_list_default_value); + $dependency_q = $query->execute(); + while ($dependency_data = $dependency_q->fetchObject()) + { + //$dependency_files_q = db_query("SELECT * FROM {lab_migration_dependency_files} WHERE id = %d", $dependency_data->dependency_id); + $query = db_select('lab_migration_dependency_files'); + $query->fields('lab_migration_dependency_files'); + $query->condition('id', $dependency_data->dependency_id); + $dependency_files_q = $query->execute(); + $dependency_files_data = $dependency_files_q->fetchObject(); + $solution_file_type = 'Dependency file'; + $solution_files_rows[] = array( + l($dependency_files_data->filename, 'lab-migration/download/dependency/' . $dependency_files_data->dependency_id), + $solution_file_type + ); + } + + /* creating list of files table */ + $solution_files_header = array( + 'Filename', + 'Type' + ); + $solution_files = theme('table', array( + 'header' => $solution_files_header, + 'rows' => $solution_files_rows + )); - /* email */ - $email_subject = t('Your uploaded solution has been marked as pending'); - $email_body = array(0 =>t('Your uploaded solution has been marked as pending to be review.')); + } + $form['solution_files']['#title'] = 'List of solution files'; + $form['solution_files']['#markup'] = $solution_files; + $commands[] = ajax_command_html('#ajax_download_experiment_solution', l('Download Solution', 'lab-migration/download/solution/' . $solution_list_default_value)); + $commands[] = ajax_command_html('#ajax_edit_experiment_solution', l('Edit Solution', 'code-approval/editcode/' . $solution_list_default_value)); + // $commands[] = ajax_command_html('#ajax_solution_files', $solution_files); + $commands[] = ajax_command_html('#ajax_solution_files', drupal_render($form['solution_files'])); - } elseif(($form_state['values']['lab_actions'] == 0) && ($form_state['values']['lab_experiment_actions']== 0) && ($form_state['values']['lab_experiment_solution_actions'] == 3)) { + /*************************************************************************************/ - if (lab_migration_delete_solution($form_state['values']['lab_solution_list'])) - { - drupal_set_message(t('Solution Dis-Approved and Deleted.'), 'status'); - } else { - drupal_set_message(t('Error Dis-Approving and Deleting Solution.'), 'error'); - } + } + else + { + $commands[] = ajax_command_html('#ajax_selected_lab_experiment_solution_action', ''); + $commands[] = ajax_command_html('#ajax_download_experiment_solution', ''); + $commands[] = ajax_command_html('#ajax_edit_experiment_solution', ''); + $commands[] = ajax_command_html('#ajax_solution_files', ''); + } - /* email */ - $email_subject = t('Your uploaded solution has been marked as dis-approved'); - $email_body = array(0 =>t('Your uploaded solution has been marked as dis-approved. + return array( + '#type' => 'ajax', + '#commands' => $commands + ); + } -Reason for dis-approval: +function lab_migration_bulk_approval_form_submit($form, $form_state) + { + // In most cases, it is recomended that you put this logic in form generation + // rather than the callback. Submit driven forms are an exception, because + // you may not want to return the form at all. + global $user; + $root_path = lab_migration_path(); -' . $form_state['values']['message'])); + if ($form_state['clicked_button']['#value'] == 'Submit') + { + if ($form_state['values']['lab']) + { + lab_migration_del_lab_pdf($form_state['values']['lab']); + } + if (user_access('lab migration bulk manage code')) + { + if (($form_state['values']['lab_actions'] == 1) && ($form_state['values']['lab_experiment_actions'] == 0) && ($form_state['values']['lab_experiment_solution_actions'] == 0)) + { + + /* approving entire lab */ + // $experiment_q = db_query("SELECT * FROM {lab_migration_experiment} WHERE proposal_id = %d", $form_state['values']['lab']); + $query = db_select('lab_migration_experiment'); + $query->fields('lab_migration_experiment'); + $query->condition('proposal_id', $form_state['values']['lab']); + $experiment_q = $query->execute(); + while ($experiment_data = $experiment_q->fetchObject()) + { + // db_query("UPDATE {lab_migration_solution} SET approval_status = 1, approver_uid = %d WHERE experiment_id = %d AND approval_status = 0", $user->uid, $experiment_data->id); + db_query("UPDATE {lab_migration_solution} SET approval_status = 1, approver_uid = :approver_uid WHERE experiment_id = :experiment_id AND approval_status = 0", array( + ':approver_uid' => $user->uid, + ':experiment_id' => $experiment_data->id + )); + } + drupal_set_message(t('Approved Entire Lab.'), 'status'); + + /* email */ + $email_subject = t('Your uploaded solutions have been approved'); + $email_body = array( + 0 => t('Your all the uploaded solutions for the Lab have been approved.') + ); + + } + elseif (($form_state['values']['lab_actions'] == 2) && ($form_state['values']['lab_experiment_actions'] == 0) && ($form_state['values']['lab_experiment_solution_actions'] == 0)) + { + + /* pending review entire lab */ + //$experiment_q = db_query("SELECT * FROM {lab_migration_experiment} WHERE proposal_id = %d", $form_state['values']['lab']); + $experiment_q = db_query("SELECT * FROM {lab_migration_experiment} WHERE proposal_id = :proposal_id", array( + ':proposal_id' => $form_state['values']['lab'] + )); + while ($experiment_data = $experiment_q->fetchObject()) + { + //db_query("UPDATE {lab_migration_solution} SET approval_status = 0 WHERE experiment_id = %d", $experiment_data->id); + db_query("UPDATE {lab_migration_solution} SET approval_status = 0 WHERE experiment_id = :experiment_id", array( + ":experiment_id" => $experiment_data->id + )); + } + drupal_set_message(t('Pending Review Entire Lab.'), 'status'); + + /* email */ + $email_subject = t('Your uploaded solutions have been marked as pending'); + $email_body = array( + 0 => t('Your all the uploaded solutions for the Lab have been marked as pending to be review. You will be able to see the solutions after they have been approved by one of our reviewers.') + ); + + } + elseif (($form_state['values']['lab_actions'] == 3) && ($form_state['values']['lab_experiment_actions'] == 0) && ($form_state['values']['lab_experiment_solution_actions'] == 0)) + { + if (!$form_state['values']['message']) + { + if (strlen(trim($form_state['values']['message'])) <= 30) + { + form_set_error('message', t('')); + drupal_set_message("Please mention the reason for disapproval.", 'error'); + return; + } + } + + if (!user_access('lab migration bulk delete code')) + { + drupal_set_message(t('You do not have permission to Bulk Dis-Approved and Deleted Entire Lab.'), 'error'); + return; + } + + if (lab_migration_delete_lab($form_state['values']['lab'])) + { + drupal_set_message(t('Dis-Approved and Deleted Entire Lab.'), 'status'); + } + else + { + drupal_set_message(t('Error Dis-Approving and Deleting Entire Lab.'), 'error'); + } + + /* email */ + $email_subject = t('Your uploaded solutions have been marked as dis-approved'); + $email_body = array( + 0 => t('Your all the uploaded solutions for the whole Lab have been marked as dis-approved. + + Reason for dis-approval: + + ' . $form_state['values']['message']) + ); + + } + elseif (($form_state['values']['lab_actions'] == 4) && ($form_state['values']['lab_experiment_actions'] == 0) && ($form_state['values']['lab_experiment_solution_actions'] == 0)) + { + + if (!user_access('lab migration bulk delete code')) + { + drupal_set_message(t('You do not have permission to Bulk Delete Entire Lab Including Proposal.'), 'error'); + return; + } + + /* check if dependency files are present */ + $dep_q = db_query("SELECT * FROM {lab_migration_dependency_files} WHERE proposal_id = :proposal_id", array( + ":proposal_id" => $form_state['values']['lab'] + )); + if ($dep_data = $dep_q->fetchObject()) + { + drupal_set_message(t("Cannot delete lab since it has dependency files that can be used by others. First delete the dependency files before deleting the lab."), 'error'); + return; + } + + if (lab_migration_delete_lab($form_state['values']['lab'])) + { + drupal_set_message(t('Dis-Approved and Deleted Entire Lab solutions.'), 'status'); + + $dir_path = $root_path . $form_state['values']['lab']; + if (is_dir($dir_path)) + { + $res = rmdir($dir_path); + if (!$res) + { + drupal_set_message(t("Cannot delete Lab directory : " . $dir_path . ". Please contact administrator."), 'error'); + return; + } + } + else + { + drupal_set_message(t("Lab directory not present : " . $dir_path . ". Skipping deleting lab directory."), 'status'); + } + + /* deleting full proposal */ + //$proposal_q = db_query("SELECT * FROM {lab_migration_proposal} WHERE id = %d", $form_state['values']['lab']); + $proposal_q = db_query("SELECT * FROM {lab_migration_proposal} WHERE id = :id", array( + ":id" => $form_state['values']['lab'] + )); + $proposal_data = $proposal_q->fetchObject(); + $proposal_id = $proposal_data->id; + db_query("DELETE FROM {lab_migration_experiment} WHERE proposal_id = :proposal_id", array( + ":proposal_id" => $proposal_id + )); + db_query("DELETE FROM {lab_migration_proposal} WHERE id = :id", array( + ":id" => $proposal_id + )); + + drupal_set_message(t('Deleted Lab Proposal.'), 'status'); + + /* email */ + $email_subject = t('Your uploaded solutions including the Lab proposal have been deleted'); + $email_body = array( + 0 => t('Your all the uploaded solutions including the Lab proposal have been deleted permanently.') + ); + + } + else + { + drupal_set_message(t('Error Dis-Approving and Deleting Entire Lab.'), 'error'); + } + + } + elseif (($form_state['values']['lab_actions'] == 0) && ($form_state['values']['lab_experiment_actions'] == 1) && ($form_state['values']['lab_experiment_solution_actions'] == 0)) + { + + db_query("UPDATE {lab_migration_solution} SET approval_status = 1, approver_uid = :approver_uid WHERE experiment_id = :experiment_id AND approval_status = 0", array( + ":approver_uid" => $user->uid, + ":experiment_id" => $form_state['values']['lab_experiment_list'] + )); + drupal_set_message(t('Approved Entire Experiment.'), 'status'); + + /* email */ + $email_subject = t('Your uploaded solutions have been approved'); + $email_body = array( + 0 => t('Your all the uploaded solutions for the experiment have been approved.') + ); + + } + elseif (($form_state['values']['lab_actions'] == 0) && ($form_state['values']['lab_experiment_actions'] == 2) && ($form_state['values']['lab_experiment_solution_actions'] == 0)) + { + + db_query("UPDATE {lab_migration_solution} SET approval_status = 0 WHERE experiment_id = :experiment_id", array( + ":experiment_id" => $form_state['values']['lab_experiment_list'] + )); + drupal_set_message(t('Entire Experiment marked as Pending Review.'), 'status'); + + /* email */ + $email_subject = t('Your uploaded solutions have been marked as pending'); + $email_body = array( + 0 => t('Your all the uploaded solutions for the experiment have been marked as pending to be review.') + ); + + } + elseif (($form_state['values']['lab_actions'] == 1) && ($form_state['values']['lab_experiment_actions'] == 3) && ($form_state['values']['lab_experiment_solution_actions'] == 0)) + { + + if (!user_access('lab migration bulk delete code')) + { + drupal_set_message(t('You do not have permission to Bulk Dis-Approved and Deleted Entire Experiment.'), 'error'); + return; + } + + if (lab_migration_delete_experiment($form_state['values']['lab_experiment_list'])) + { + drupal_set_message(t('Dis-Approved and Deleted Entire Experiment.'), 'status'); + } + else + { + drupal_set_message(t('Error Dis-Approving and Deleting Entire Experiment.'), 'error'); + } + + /* email */ + $email_subject = t('Your uploaded solutions have been marked as dis-approved'); + $email_body = array( + 0 => t('Your uploaded solutions for the entire experiment have been marked as dis-approved. + + Reason for dis-approval: + + ' . $form_state['values']['message']) + ); + + } + elseif (($form_state['values']['lab_actions'] == 0) && ($form_state['values']['lab_experiment_actions'] == 0) && ($form_state['values']['lab_experiment_solution_actions'] == 1)) + { + + db_query("UPDATE {lab_migration_solution} SET approval_status = 1, approver_uid = :approver_uid WHERE id = :id", array( + ":approver_uid" => $user->uid, + ":id" => $form_state['values']['solution'] + )); + drupal_set_message(t('Solution approved.'), 'status'); + + /* email */ + $email_subject = t('Your uploaded solution has been approved'); + $email_body = array( + 0 => t('Your uploaded solution has been approved.') + ); + + } + elseif (($form_state['values']['lab_actions'] == 0) && ($form_state['values']['lab_experiment_actions'] == 0) && ($form_state['values']['lab_experiment_solution_actions'] == 2)) + { + + db_query("UPDATE {lab_migration_solution} SET approval_status = 0 WHERE id = :id", array( + ":id" => $form_state['values']['lab_solution_list'] + )); + drupal_set_message(t('Solution marked as Pending Review.'), 'status'); + + /* email */ + $email_subject = t('Your uploaded solution has been marked as pending'); + $email_body = array( + 0 => t('Your uploaded solution has been marked as pending to be review.') + ); + + } + elseif (($form_state['values']['lab_actions'] == 0) && ($form_state['values']['lab_experiment_actions'] == 0) && ($form_state['values']['lab_experiment_solution_actions'] == 3)) + { + + if (lab_migration_delete_solution($form_state['values']['lab_solution_list'])) + { + drupal_set_message(t('Solution Dis-Approved and Deleted.'), 'status'); + } + else + { + drupal_set_message(t('Error Dis-Approving and Deleting Solution.'), 'error'); + } + + /* email */ + $email_subject = t('Your uploaded solution has been marked as dis-approved'); + $email_body = array( + 0 => t('Your uploaded solution has been marked as dis-approved. + + Reason for dis-approval: + + ' . $form_state['values']['message']) + ); + + } + else + { + + drupal_set_message("Please select any one action", 'error'); + return; + + } + + /****** sending email when everything done ******/ + if (isset($email_subject)) + { + /*$email_to = variable_get('lab_migration_emails', '') . ', ' . $user->mail; */ + // $email_to = "contact@scilab.in" . ', ' . $user->mail; + $email_to = "prashantsinalkar@gmail.com"; + $param['standard']['subject'] = $email_subject; + $param['standard']['body'] = $email_body; + if (!drupal_mail('lab_migration', 'standard', $email_to, language_default(), $param, variable_get('lab_migration_from_email', NULL), TRUE)) + drupal_set_message('Error sending email message.', 'error'); + } - } + } + else + { + drupal_set_message(t('You do not have permission to bulk manage code.'), 'error'); + } - /****** sending email when everything done ******/ - if ($email_subject) - { - /*$email_to = variable_get('lab_migration_emails', '') . ', ' . $user->mail; */ - // $email_to = "contact@scilab.in" . ', ' . $user->mail; - $email_to = "prashantsinalkar@gmail.com"; - $param['standard']['subject'] = $email_subject; - $param['standard']['body'] = $email_body; - if (!drupal_mail('lab_migration', 'standard', $email_to, language_default(), $param, variable_get('lab_migration_from_email', NULL), TRUE)) - drupal_set_message('Error sending email message.', 'error'); } - } else { - drupal_set_message(t('You do not have permission to bulk manage code.'), 'error'); - } - - } - } + return; + } /************************************************************/ function _bulk_list_of_labs() -{ - $lab_titles = array('0' => 'Please select...'); - //$lab_titles_q = db_query("SELECT * FROM {lab_migration_proposal} WHERE solution_display = 1 ORDER BY lab_title ASC"); - $query = db_select('lab_migration_proposal'); - $query->fields('lab_migration_proposal'); - $query->condition('approval_status', 2, '<>'); - $query->condition('solution_display', 1); - $query->orderBy('lab_title', 'ASC'); - $lab_titles_q = $query->execute(); - while ($lab_titles_data = $lab_titles_q->fetchObject()) { - $lab_titles[$lab_titles_data->id] = $lab_titles_data->lab_title . ' (Proposed by ' . $lab_titles_data->name . ')'; + $lab_titles = array( + '0' => 'Please select...' + ); + //$lab_titles_q = db_query("SELECT * FROM {lab_migration_proposal} WHERE solution_display = 1 ORDER BY lab_title ASC"); + $query = db_select('lab_migration_proposal'); + $query->fields('lab_migration_proposal'); + $query->condition('approval_status', 2, '<>'); + $query->condition('solution_display', 1); + $query->orderBy('lab_title', 'ASC'); + $lab_titles_q = $query->execute(); + while ($lab_titles_data = $lab_titles_q->fetchObject()) + { + $lab_titles[$lab_titles_data->id] = $lab_titles_data->lab_title . ' (Proposed by ' . $lab_titles_data->name . ')'; + } + return $lab_titles; } - return $lab_titles; -} - - - function _ajax_bulk_get_experiment_list($lab_default_value = ''){ - $experiments = array('0' => 'Please select...'); - //$experiments_q = db_query("SELECT * FROM {lab_migration_experiment} WHERE proposal_id = %d ORDER BY number ASC", $proposal_id); - $query = db_select('lab_migration_experiment'); - $query->fields('lab_migration_experiment'); - $query->condition('proposal_id', $lab_default_value); - $query->orderBy('number', 'ASC'); - $experiments_q = $query->execute(); - while ($experiments_data = $experiments_q->fetchObject()) + + +function _ajax_bulk_get_experiment_list($lab_default_value = '') { - $experiments[$experiments_data->id] = $experiments_data->number . '. ' . $experiments_data->title; + $experiments = array( + '0' => 'Please select...' + ); + //$experiments_q = db_query("SELECT * FROM {lab_migration_experiment} WHERE proposal_id = %d ORDER BY number ASC", $proposal_id); + $query = db_select('lab_migration_experiment'); + $query->fields('lab_migration_experiment'); + $query->condition('proposal_id', $lab_default_value); + $query->orderBy('number', 'ASC'); + $experiments_q = $query->execute(); + while ($experiments_data = $experiments_q->fetchObject()) + { + $experiments[$experiments_data->id] = $experiments_data->number . '. ' . $experiments_data->title; + } + return $experiments; } - return $experiments; - } + + function _bulk_list_lab_actions() -{ - $lab_actions = array(0 => 'Please select...'); - - + { + $lab_actions = array( + '' => 'Please Select .....' + ); + $lab_actions[1] = 'Approve Entire Lab'; $lab_actions[2] = 'Pending Review Entire Lab'; $lab_actions[3] = 'Dis-Approve Entire Lab (This will delete all the solutions in the lab)'; $lab_actions[4] = 'Delete Entire Lab Including Proposal'; - - - return $lab_actions; -} - -function _ajax_bulk_get_solution_list($lab_experiment_list=''){ - $solutions = array(0 => 'Please select...'); - // $solutions_q = db_query("SELECT * FROM {lab_migration_solution} WHERE experiment_id = %d ORDER BY - // CAST(SUBSTRING_INDEX(code_number, '.', 1) AS BINARY) ASC, - // CAST(SUBSTRING_INDEX(SUBSTRING_INDEX(code_number , '.', 2), '.', -1) AS UNSIGNED) ASC, - // CAST(SUBSTRING_INDEX(SUBSTRING_INDEX(code_number , '.', -1), '.', 1) AS UNSIGNED) ASC", $experiment_id); - - $query = db_select('lab_migration_solution'); - $query->fields('lab_migration_solution'); - $query->condition('experiment_id', $lab_experiment_list); - //$query->orderBy("CAST(SUBSTRING_INDEX(code_number, '.', 1) AS BINARY", "ASC"); - // $query->orderBy("CAST(SUBSTRING_INDEX(SUBSTRING_INDEX(code_number , '.', 2), '.', -1) AS UNSIGNED", "ASC"); - // $query->orderBy("CAST(SUBSTRING_INDEX(SUBSTRING_INDEX(code_number , '.', -1), '.', 1) AS UNSIGNED", "ASC"); - $solutions_q = $query->execute(); - while ($solutions_data = $solutions_q->fetchObject()) + + return $lab_actions; + } + +function _ajax_bulk_get_solution_list($lab_experiment_list = '') { - $solutions[$solutions_data->id] = $solutions_data->code_number . ' (' . $solutions_data->caption . ')'; + $solutions = array( + 0 => 'Please select...' + ); + // $solutions_q = db_query("SELECT * FROM {lab_migration_solution} WHERE experiment_id = %d ORDER BY + // CAST(SUBSTRING_INDEX(code_number, '.', 1) AS BINARY) ASC, + // CAST(SUBSTRING_INDEX(SUBSTRING_INDEX(code_number , '.', 2), '.', -1) AS UNSIGNED) ASC, + // CAST(SUBSTRING_INDEX(SUBSTRING_INDEX(code_number , '.', -1), '.', 1) AS UNSIGNED) ASC", $experiment_id); + + $query = db_select('lab_migration_solution'); + $query->fields('lab_migration_solution'); + $query->condition('experiment_id', $lab_experiment_list); + //$query->orderBy("CAST(SUBSTRING_INDEX(code_number, '.', 1) AS BINARY", "ASC"); + // $query->orderBy("CAST(SUBSTRING_INDEX(SUBSTRING_INDEX(code_number , '.', 2), '.', -1) AS UNSIGNED", "ASC"); + // $query->orderBy("CAST(SUBSTRING_INDEX(SUBSTRING_INDEX(code_number , '.', -1), '.', 1) AS UNSIGNED", "ASC"); + $solutions_q = $query->execute(); + while ($solutions_data = $solutions_q->fetchObject()) + { + $solutions[$solutions_data->id] = $solutions_data->code_number . ' (' . $solutions_data->caption . ')'; + } + return $solutions; } - return $solutions; - } - - function _bulk_list_experiment_actions() -{ - $lab_experiment_actions = array(0 => 'Please select...'); - - + +function _bulk_list_experiment_actions() + { + $lab_experiment_actions = array( + '' => 'Please Select .....' + ); + $lab_experiment_actions[1] = 'Approve Entire Experiment'; $lab_experiment_actions[2] = 'Pending Review Entire Experiment'; $lab_experiment_actions[3] = 'Dis-Approve Entire Experiment (This will delete all the solutions in the experiment)'; - - return $lab_experiment_actions; -} - function _bulk_list_solution_actions() -{ - $lab_solution_actions = array(0 => 'Please select...'); - - + + return $lab_experiment_actions; + } + +function _bulk_list_solution_actions() + { + $lab_solution_actions = array( + '' => 'Please Select .....' + ); $lab_solution_actions[1] = 'Approve Entire Solution'; $lab_solution_actions[2] = 'Pending Review Entire Solution'; $lab_solution_actions[3] = 'Dis-approve Solution (This will delete the solution)'; - - return $lab_solution_actions; -} + + return $lab_solution_actions; + } |