123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261 |
- <?php
- /* For licensing terms, see /license.txt */
- use ChamiloSession as Session;
- /**
- * @package chamilo.admin
- */
- $cidReset = true;
- require_once __DIR__.'/../inc/global.inc.php';
- $this_section = SECTION_PLATFORM_ADMIN;
- $allowCareer = api_get_configuration_value('allow_session_admin_read_careers');
- api_protect_admin_script($allowCareer);
- // Add the JS needed to use the jqgrid
- $htmlHeadXtra[] = api_get_jqgrid_js();
- // setting breadcrumbs
- $interbreadcrumb[] = [
- 'url' => 'index.php',
- 'name' => get_lang('Administration'),
- ];
- $interbreadcrumb[] = [
- 'url' => 'career_dashboard.php',
- 'name' => get_lang('Careers and promotions'),
- ];
- $action = isset($_GET['action']) ? $_GET['action'] : null;
- $check = Security::check_token('request');
- $token = Security::get_token();
- if ($action == 'add') {
- $interbreadcrumb[] = ['url' => 'careers.php', 'name' => get_lang('Careers')];
- $tool_name = get_lang('Add');
- } elseif ($action == 'edit') {
- $interbreadcrumb[] = ['url' => 'careers.php', 'name' => get_lang('Careers')];
- $interbreadcrumb[] = ['url' => '#', 'name' => get_lang('Edit')];
- $tool_name = get_lang('Edit');
- } else {
- $tool_name = get_lang('Careers');
- }
- //jqgrid will use this URL to do the selects
- $url = api_get_path(WEB_AJAX_PATH).'model.ajax.php?a=get_careers';
- //The order is important you need to check the the $column variable in the model.ajax.php file
- $columns = [get_lang('Name'), get_lang('Description'), get_lang('Detail')];
- // Column config
- $column_model = [
- [
- 'name' => 'name',
- 'index' => 'name',
- 'width' => '200',
- 'align' => 'left',
- ],
- [
- 'name' => 'description',
- 'index' => 'description',
- 'width' => '400',
- 'align' => 'left',
- 'sortable' => 'false',
- ],
- [
- 'name' => 'actions',
- 'index' => 'actions',
- 'width' => '100',
- 'align' => 'left',
- 'formatter' => 'action_formatter',
- 'sortable' => 'false',
- ],
- ];
- $extra_params['autowidth'] = 'true';
- $extra_params['height'] = 'auto';
- $diagramLink = '';
- $allow = api_get_configuration_value('allow_career_diagram');
- if ($allow) {
- $diagramLink = '<a href="'.api_get_path(WEB_CODE_PATH).'admin/career_diagram.php?id=\'+options.rowId+\'">'.get_lang('Diagram').'</a>';
- }
- // With this function we can add actions to the jgrid (edit, delete, etc)
- if (api_is_platform_admin()) {
- $actionLinks = 'function action_formatter(cellvalue, options, rowObject) {
- return \'<a href="?action=edit&id=\'+options.rowId+\'">'.Display::return_icon('edit.png', get_lang('Edit'), '', ICON_SIZE_SMALL).'</a>'.
- $diagramLink.
- ' <a onclick="javascript:if(!confirm('."\'".addslashes(api_htmlentities(get_lang("Please confirm your choice"), ENT_QUOTES))."\'".')) return false;" href="?sec_token='.$token.'&action=copy&id=\'+options.rowId+\'">'.Display::return_icon('copy.png', get_lang('Copy'), '', ICON_SIZE_SMALL).'</a>'.
- ' <a onclick="javascript:if(!confirm('."\'".addslashes(api_htmlentities(get_lang("Please confirm your choice"), ENT_QUOTES))."\'".')) return false;" href="?sec_token='.$token.'&action=delete&id=\'+options.rowId+\'">'.Display::return_icon('delete.png', get_lang('Delete'), '', ICON_SIZE_SMALL).'</a>'.
- '\';
- }';
- } else {
- $actionLinks = "function action_formatter(cellvalue, options, rowObject) {
- return '".$diagramLink."';
- }";
- }
- $career = new Career();
- $content = '';
- $listUrl = api_get_self();
- // Action handling: Add
- switch ($action) {
- case 'add':
- api_protect_admin_script();
- if (api_get_session_id() != 0 &&
- !api_is_allowed_to_session_edit(false, true)
- ) {
- api_not_allowed();
- }
- Session::write('notebook_view', 'creation_date');
- $url = api_get_self().'?action='.Security::remove_XSS($_GET['action']);
- $form = $career->return_form($url, 'add');
- // The validation or display
- if ($form->validate()) {
- if ($check) {
- $values = $form->exportValues();
- $res = $career->save($values);
- if ($res) {
- Display::addFlash(
- Display::return_message(get_lang('Item added'), 'confirmation')
- );
- }
- }
- header('Location: '.$listUrl);
- exit;
- } else {
- $content .= '<div class="actions">';
- $content .= '<a href="'.api_get_self().'">'.
- Display::return_icon('back.png', get_lang('Back'), '', ICON_SIZE_MEDIUM).'</a>';
- $content .= '</div>';
- $form->addElement('hidden', 'sec_token');
- $form->setConstants(['sec_token' => $token]);
- $content .= $form->returnForm();
- }
- break;
- case 'edit':
- api_protect_admin_script();
- $id = isset($_GET['id']) ? (int) $_GET['id'] : 0;
- $careerInfo = $career->get($id);
- if (empty($careerInfo)) {
- api_not_allowed(true);
- }
- // Action handling: Editing
- $url = api_get_self().'?action=edit&id='.$id;
- $form = $career->return_form($url, 'edit');
- // The validation or display
- if ($form->validate()) {
- if ($check) {
- $values = $form->exportValues();
- $career->update_all_promotion_status_by_career_id($values['id'], $values['status']);
- $old_status = $career->get_status($values['id']);
- $res = $career->update($values);
- $values['item_id'] = $values['id'];
- $sessionFieldValue = new ExtraFieldValue('career');
- $sessionFieldValue->saveFieldValues($values);
- if ($res) {
- Display::addFlash(
- Display::return_message(get_lang('Career updated successfully'), 'confirmation')
- );
- if ($values['status'] && !$old_status) {
- Display::addFlash(
- Display::return_message(
- sprintf(get_lang('The <i>%s</i> career has been unarchived. This action has the consequence of making visible the career, its promotions and all the sessions registered into this promotion. You can undo this by archiving the career.'), $values['name']),
- 'confirmation',
- false
- )
- );
- } elseif (!$values['status'] && $old_status) {
- Display::addFlash(
- Display::return_message(
- sprintf(get_lang('The <i>%s</i> career has been archived. This action has the consequence of making invisible the career, its promotions and all the sessions registered into this promotion. You can undo this by unarchiving the career.'), $values['name']),
- 'confirmation',
- false
- )
- );
- }
- }
- }
- header('Location: '.$listUrl);
- exit;
- } else {
- $content .= '<div class="actions">';
- $content .= '<a href="'.api_get_self().'">'.Display::return_icon('back.png', get_lang('Back'), '', ICON_SIZE_MEDIUM).'</a>';
- $content .= '</div>';
- $form->addElement('hidden', 'sec_token');
- $form->setConstants(['sec_token' => $token]);
- $content .= $form->returnForm();
- }
- break;
- case 'delete':
- api_protect_admin_script();
- // Action handling: delete
- if ($check) {
- $res = $career->delete($_GET['id']);
- if ($res) {
- Display::addFlash(
- Display::return_message(get_lang('Item deleted'), 'confirmation')
- );
- }
- }
- header('Location: '.$listUrl);
- exit;
- break;
- case 'copy':
- api_protect_admin_script();
- if (api_get_session_id() != 0 && !api_is_allowed_to_session_edit(false, true)) {
- api_not_allowed(true);
- }
- if ($check) {
- $res = $career->copy($_GET['id'], true); //copy career and promotions inside
- if ($res) {
- Display::addFlash(
- Display::return_message(get_lang('Item copied'), 'confirmation')
- );
- }
- }
- header('Location: '.$listUrl);
- exit;
- break;
- default:
- $content = $career->display();
- break;
- }
- Display::display_header($tool_name);
- ?>
- <script>
- $(function() {
- <?php
- // grid definition see the $career->display() function
- echo Display::grid_js(
- 'careers',
- $url,
- $columns,
- $column_model,
- $extra_params,
- [],
- $actionLinks,
- true
- );
- ?>
- });
- </script>
- <?php
- echo $content;
- Display::display_footer();
|