123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105 |
- <?php
- /* For licensing terms, see /license.txt */
- /**
- * @package chamilo.admin
- */
- // Language files that need to be included.
- $language_file = array('admin');
- $cidReset = true;
- require_once '../inc/global.inc.php';
- require_once api_get_path(LIBRARY_PATH).'skill.lib.php';
- require_once api_get_path(LIBRARY_PATH).'gradebook.lib.php';
- $this_section = SECTION_PLATFORM_ADMIN;
- api_protect_admin_script();
- if (api_get_setting('allow_skills_tool') != 'true') {
- api_not_allowed();
- }
- //Adds the JS needed to use the jqgrid
- $htmlHeadXtra[] = api_get_jqgrid_js();
- $action = isset($_REQUEST['action']) ? $_REQUEST['action'] : 'display';
- // setting breadcrumbs
- $tool_name = get_lang('SkillsAndGradebooks');
- $interbreadcrumb[]=array('url' => 'index.php','name' => get_lang('PlatformAdmin'));
- if ($action == 'add_skill') {
- $interbreadcrumb[]=array('url' => 'skills_gradebook.php','name' => get_lang('SkillsAndGradebooks'));
- $tool_name = get_lang('Add');
- }
- Display::display_header($tool_name);
- //jqgrid will use this URL to do the selects
- $url = api_get_path(WEB_AJAX_PATH).'model.ajax.php?a=get_gradebooks';
- //The order is important you need to check the the $column variable in the model.ajax.php file
- $columns = array(get_lang('Name'), get_lang('CertificatesFiles'), get_lang('Skills'), get_lang('Actions'));
- //Column config
- $column_model = array(
- array('name'=>'name', 'index'=>'name', 'width'=>'150', 'align'=>'left'),
- array('name'=>'certificate', 'index'=>'certificate', 'width'=>'25', 'align'=>'left', 'sortable'=>'false'),
- array('name'=>'skills', 'index'=>'skills', 'width'=>'300', 'align'=>'left', 'sortable'=>'false'),
- array('name'=>'actions', 'index'=>'actions', 'width'=>'30', 'align'=>'left','formatter'=>'action_formatter','sortable'=>'false')
- );
- //Autowidth
- $extra_params['autowidth'] = 'true';
- //height auto
- $extra_params['height'] = 'auto';
- //With this function we can add actions to the jgrid (edit, delete, etc)
- $action_links = 'function action_formatter(cellvalue, options, rowObject) {
- //certificates
- if (rowObject[4] == 1) {
- return \'<a href="?action=add_skill&id=\'+options.rowId+\'">'.Display::return_icon('add.png', get_lang('AddSkill'),'',ICON_SIZE_SMALL).'</a>'.'\';
- } else {
- return \''.Display::return_icon('add_na.png', get_lang('YourGradebookFirstNeedsACertificateInOrderToBeLinkedToASkill'),'',ICON_SIZE_SMALL).''.'\';
- }
- }';
- ?>
- <script>
- $(function() {
- <?php
- // grid definition see the $career->display() function
- echo Display::grid_js('gradebooks', $url, $columns, $column_model, $extra_params, array(), $action_links,true);
- ?>
- });
- </script>
- <?php
- $gradebook = new Gradebook();
-
- switch($action) {
- case 'display':
- $gradebook->display();
- break;
- case 'add_skill':
- $id = isset($_REQUEST['id']) ? $_REQUEST['id'] : null;
- $gradebook_info = $gradebook->get($id);
- $url = api_get_self().'?action='.$action.'&id='.$id;
- $form = $gradebook->show_skill_form($id, $url, $gradebook_info['name']);
- if ($form->validate()) {
- $values = $form->exportValues();
- $res = $gradebook->update_skills_to_gradebook($values['id'], $values['skill']);
- if ($res) {
- Display::display_confirmation_message(get_lang('ItemAdded'));
- }
- }
- $form->display();
- //echo Display::tag('h2',$gradebook_info['name']);
- break;
- }
- Display::display_footer();
|