You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
197 lines
6.5 KiB
197 lines
6.5 KiB
<?php
|
|
/* For licensing terms, see /license.txt */
|
|
|
|
/**
|
|
* @package chamilo.admin
|
|
*/
|
|
|
|
$cidReset = true;
|
|
require_once __DIR__.'/../inc/global.inc.php';
|
|
|
|
$this_section = SECTION_PLATFORM_ADMIN;
|
|
api_protect_admin_script(true);
|
|
api_protect_limit_for_session_admin();
|
|
|
|
//Add the JS needed to use the jqgrid
|
|
$htmlHeadXtra[] = api_get_jqgrid_js();
|
|
// setting breadcrumbs
|
|
$interbreadcrumb[] = ['url' => 'index.php', 'name' => get_lang('PlatformAdmin')];
|
|
$action = isset($_GET['action']) ? Security::remove_XSS($_GET['action']) : null;
|
|
if ($action == 'add') {
|
|
$interbreadcrumb[] = ['url' => 'usergroups.php', 'name' => get_lang('Classes')];
|
|
$interbreadcrumb[] = ['url' => '#', 'name' => get_lang('Add')];
|
|
} elseif ($action == 'edit') {
|
|
$interbreadcrumb[] = ['url' => 'usergroups.php', 'name' => get_lang('Classes')];
|
|
$interbreadcrumb[] = ['url' => '#', 'name' => get_lang('Edit')];
|
|
} else {
|
|
$interbreadcrumb[] = ['url' => '#', 'name' => get_lang('Classes')];
|
|
}
|
|
|
|
// The header.
|
|
Display::display_header();
|
|
|
|
// Tool name
|
|
if ($action == 'add') {
|
|
$tool = 'Add';
|
|
$interbreadcrumb[] = ['url' => api_get_self(), 'name' => get_lang('Group')];
|
|
}
|
|
if ($action == 'edit') {
|
|
$tool = 'Modify';
|
|
$interbreadcrumb[] = ['url' => api_get_self(), 'name' => get_lang('Group')];
|
|
}
|
|
|
|
// jqgrid will use this URL to do the selects
|
|
|
|
$url = api_get_path(WEB_AJAX_PATH).'model.ajax.php?a=get_usergroups';
|
|
|
|
//The order is important you need to check the the $column variable in the model.ajax.php file
|
|
$columns = [
|
|
get_lang('Name'),
|
|
get_lang('Users'),
|
|
get_lang('Courses'),
|
|
get_lang('Sessions'),
|
|
get_lang('Type'),
|
|
get_lang('Actions'),
|
|
];
|
|
|
|
//Column config
|
|
$column_model = [
|
|
['name'=>'name', 'index'=>'name', 'width'=>'35', 'align'=>'left'],
|
|
['name'=>'users', 'index'=>'users', 'width'=>'15', 'align'=>'left'],
|
|
['name'=>'courses', 'index'=>'courses', 'width'=>'15', 'align'=>'left'],
|
|
['name'=>'sessions', 'index'=>'sessions', 'width'=>'15', 'align'=>'left'],
|
|
['name'=>'group_type', 'index'=>'group_type', 'width'=>'15', 'align'=>'center'],
|
|
['name'=>'actions', 'index'=>'actions', 'width'=>'20', 'align'=>'center', 'sortable'=>'false', 'formatter'=>'action_formatter'],
|
|
];
|
|
|
|
//Autowidth
|
|
$extra_params['autowidth'] = 'true';
|
|
//height auto
|
|
$extra_params['height'] = 'auto';
|
|
$extra_params['sortname'] = 'name';
|
|
$extra_params['sortorder'] = 'desc';
|
|
//With this function we can add actions to the jgrid
|
|
$action_links = 'function action_formatter (cellvalue, options, rowObject) {
|
|
return \''
|
|
.' <a href="add_users_to_usergroup.php?id=\'+options.rowId+\'">'.Display::return_icon('user_to_class.png', get_lang('SubscribeUsersToClass'), null, ICON_SIZE_MEDIUM).'</a>'
|
|
.' <a href="add_courses_to_usergroup.php?id=\'+options.rowId+\'">'.Display::return_icon('course_to_class.png', get_lang('SubscribeClassToCourses'), null, ICON_SIZE_MEDIUM).'</a>'
|
|
.' <a href="add_sessions_to_usergroup.php?id=\'+options.rowId+\'">'.Display::return_icon('sessions_to_class.png', get_lang('SubscribeClassToSessions'), null, ICON_SIZE_MEDIUM).'</a>'
|
|
.' <a href="?action=edit&id=\'+options.rowId+\'">'.Display::return_icon('edit.png', get_lang('Edit'), null, ICON_SIZE_SMALL).'</a>'
|
|
.' <a onclick="javascript:if(!confirm('."\'".addslashes(api_htmlentities(get_lang("ConfirmYourChoice"), ENT_QUOTES))."\'".')) return false;" href="?action=delete&id=\'+options.rowId+\'">'.Display::return_icon('delete.png', get_lang('Delete'), null, ICON_SIZE_SMALL).'</a>\';
|
|
}';
|
|
|
|
?>
|
|
<script>
|
|
$(function() {
|
|
<?php
|
|
// grid definition see the $usergroup>display() function
|
|
echo Display::grid_js(
|
|
'usergroups',
|
|
$url,
|
|
$columns,
|
|
$column_model,
|
|
$extra_params,
|
|
[],
|
|
$action_links,
|
|
true
|
|
);
|
|
?>
|
|
});
|
|
</script>
|
|
<?php
|
|
|
|
$usergroup = new UserGroup();
|
|
$usergroup->showGroupTypeSetting = true;
|
|
// Action handling: Adding a note
|
|
if ($action == 'add') {
|
|
if (api_get_session_id() != 0 && !api_is_allowed_to_session_edit(false, true)) {
|
|
api_not_allowed();
|
|
}
|
|
|
|
$form = new FormValidator(
|
|
'usergroup',
|
|
'post',
|
|
api_get_self().'?action='.$action
|
|
);
|
|
$usergroup->setForm($form, 'add');
|
|
|
|
// Setting the defaults
|
|
$form->setDefaults(['visibility' => 2]);
|
|
|
|
// The validation or display
|
|
if ($form->validate()) {
|
|
$values = $form->exportValues();
|
|
$res = $usergroup->save($values);
|
|
if ($res) {
|
|
echo Display::return_message(get_lang('ItemAdded'), 'confirmation');
|
|
} else {
|
|
echo Display::return_message(
|
|
Security::remove_XSS($values['name']).': '.
|
|
get_lang('AlreadyExists'),
|
|
'warning'
|
|
);
|
|
}
|
|
|
|
$usergroup->display();
|
|
} else {
|
|
echo '<div class="actions">';
|
|
echo '<a href="'.api_get_self().'">'.
|
|
Display::return_icon('back.png', get_lang('Back'), '', ICON_SIZE_MEDIUM).'</a>';
|
|
echo '</div>';
|
|
$token = Security::get_token();
|
|
$form->addElement('hidden', 'sec_token');
|
|
$form->setConstants(['sec_token' => $token]);
|
|
$form->display();
|
|
}
|
|
} elseif ($action == 'edit' && is_numeric($_GET['id'])) {
|
|
$id = intval($_GET['id']);
|
|
$form = new FormValidator(
|
|
'usergroup',
|
|
'post',
|
|
api_get_self().'?action='.$action.'&id='.$id
|
|
);
|
|
$defaults = $usergroup->get($id);
|
|
$usergroup->setForm($form, 'edit', $defaults);
|
|
|
|
// Setting the form elements
|
|
$form->addElement('hidden', 'id', $id);
|
|
|
|
// Setting the defaults
|
|
$form->setDefaults($defaults);
|
|
|
|
// The validation or display.
|
|
if ($form->validate()) {
|
|
$values = $form->getSubmitValues();
|
|
$res = $usergroup->update($values);
|
|
if ($res) {
|
|
echo Display::return_message(get_lang('Updated'), 'confirmation');
|
|
} else {
|
|
echo Display::return_message(
|
|
Security::remove_XSS($values['name']).': '.
|
|
get_lang('AlreadyExists'),
|
|
'warning'
|
|
);
|
|
}
|
|
|
|
$usergroup->display();
|
|
} else {
|
|
echo '<div class="actions">';
|
|
echo '<a href="'.api_get_self().'">'.Display::return_icon(
|
|
'back.png',
|
|
get_lang('Back'),
|
|
'',
|
|
ICON_SIZE_MEDIUM
|
|
).'</a>';
|
|
echo '</div>';
|
|
$form->display();
|
|
}
|
|
} elseif ($action == 'delete' && is_numeric($_GET['id'])) {
|
|
$res = $usergroup->delete($_GET['id']);
|
|
if ($res) {
|
|
echo Display::return_message(get_lang('Deleted'), 'confirmation');
|
|
}
|
|
$usergroup->display();
|
|
} else {
|
|
$usergroup->display();
|
|
}
|
|
Display :: display_footer();
|
|
|