forked from ZwiiCMS-Team/ZwiiCampus
Inscription okay
This commit is contained in:
parent
eca77f17e3
commit
0ae983d5ca
@ -118,10 +118,7 @@ class course extends common
|
|||||||
// Valeurs en sortie
|
// Valeurs en sortie
|
||||||
$this->addOutput([
|
$this->addOutput([
|
||||||
'title' => helper::translate('Contenus disponibles'),
|
'title' => helper::translate('Contenus disponibles'),
|
||||||
'view' => 'index',
|
'view' => 'index'
|
||||||
'vendor' => [
|
|
||||||
'datatables'
|
|
||||||
]
|
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -559,96 +556,29 @@ class course extends common
|
|||||||
$this->addOutput([
|
$this->addOutput([
|
||||||
'title' => sprintf(helper::translate('Inscriptions dans le contenu %s'), $this->getData(['course', $courseId, 'title'])),
|
'title' => sprintf(helper::translate('Inscriptions dans le contenu %s'), $this->getData(['course', $courseId, 'title'])),
|
||||||
'view' => 'users',
|
'view' => 'users',
|
||||||
'vendor' => [
|
|
||||||
'datatables'
|
|
||||||
]
|
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function usersAdd()
|
public function usersAdd()
|
||||||
{
|
{
|
||||||
|
|
||||||
// Contenu sélectionné
|
// Contenu sélectionné
|
||||||
$courseId = $this->getUrl(2);
|
$courseId = $this->getUrl(2);
|
||||||
|
|
||||||
// Liste des inscrits dans le contenu sélectionné.
|
// Inscription des utilisateurs cochés
|
||||||
$suscribers = $this->getData(['enrolment', $courseId]);
|
if (
|
||||||
$suscribers = array_keys($suscribers);
|
isset($_POST['courseUsersAddSubmit'])
|
||||||
|
) {
|
||||||
$users = array_diff_key($this->getData(['user']), array_flip($suscribers));
|
foreach ($_POST as $keyPost => $valuePost) {
|
||||||
|
// Exclure les variables post qui ne sont pas des userId et ne traiter que les non inscrits
|
||||||
// Tri du tableau par défaut par $userId
|
if ($this->getData(['user', $keyPost]) !== null
|
||||||
ksort($users);
|
&& $this->getData(['enrolment', $courseId, $keyPost]) === null
|
||||||
|
) {
|
||||||
if ($this->isPost()) {
|
$this->setData(['enrolment', $courseId, $keyPost, 'history', array()]);
|
||||||
if (
|
|
||||||
isset($_POST['courseUsersAddSubmit'])
|
|
||||||
) {
|
|
||||||
foreach ($_POST as $key => $value) {
|
|
||||||
// Exclure les variables post qui ne sont pas des userId
|
|
||||||
if (is_null(['user', $key])) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
$this->getData(['enrolment', $courseId, $key]);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// Traitement du filtre
|
|
||||||
if (
|
|
||||||
isset($_POST['courseFilterGroup'])
|
|
||||||
|| isset($_POST['courseFilterFirstName'])
|
|
||||||
|| isset($_POST['courseFilterLastName'])
|
|
||||||
) {
|
|
||||||
|
|
||||||
|
|
||||||
foreach ($users as $userId) {
|
|
||||||
|
|
||||||
// Compte les rôles
|
|
||||||
$profils[$this->getData(['user', $userId, 'group']) . $this->getData(['user', $userId, 'profil'])]++;
|
|
||||||
|
|
||||||
// Filtres
|
|
||||||
if ($this->isPost()) {
|
|
||||||
|
|
||||||
// Groupe et profils
|
|
||||||
$group = (string) $this->getData(['user', $userId, 'group']);
|
|
||||||
$profil = (string) $this->getData(['user', $userId, 'profil']);
|
|
||||||
$firstName = $this->getData(['user', $userId, 'firstname']);
|
|
||||||
$lastName = $this->getData(['user', $userId, 'lastname']);
|
|
||||||
if (
|
|
||||||
$this->getInput('courseFilterGroup', helper::FILTER_INT) > 0
|
|
||||||
&& $this->getInput('courseFilterGroup', helper::FILTER_STRING_SHORT) !== $group . $profil
|
|
||||||
)
|
|
||||||
continue;
|
|
||||||
// Première lettre du prénom
|
|
||||||
if (
|
|
||||||
$this->getInput('courseFilterFirstName', helper::FILTER_STRING_SHORT) !== 'all'
|
|
||||||
&& $this->getInput('courseFilterFirstName', helper::FILTER_STRING_SHORT) !== strtoupper(substr($firstName, 0, 1))
|
|
||||||
)
|
|
||||||
continue;
|
|
||||||
// Première lettre du nom
|
|
||||||
if (
|
|
||||||
$this->getInput('courseFilterLastName', helper::FILTER_STRING_SHORT) !== 'all'
|
|
||||||
&& $this->getInput('courseFilterLastName', helper::FILTER_STRING_SHORT) !== strtoupper(substr($lastName, 0, 1))
|
|
||||||
)
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// Construction du tableau
|
|
||||||
self::$courseUsers[] = [
|
|
||||||
$userId,
|
|
||||||
$this->getData(['user', $userId, 'firstname']),
|
|
||||||
$this->getData(['user', $userId, 'lastname']),
|
|
||||||
template::checkbox($userId, true, '', ['class' => 'checkboxSelect'])
|
|
||||||
];
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// Construit le tableau
|
|
||||||
|
|
||||||
// Liste des groupes et des profils
|
// Liste des groupes et des profils
|
||||||
$courseGroups = $this->getData(['profil']);
|
$courseGroups = $this->getData(['profil']);
|
||||||
foreach ($courseGroups as $groupId => $groupValue) {
|
foreach ($courseGroups as $groupId => $groupValue) {
|
||||||
@ -677,19 +607,26 @@ class course extends common
|
|||||||
self::$alphabet = array_combine($alphabet, self::$alphabet);
|
self::$alphabet = array_combine($alphabet, self::$alphabet);
|
||||||
self::$alphabet = array_merge(['all' => 'Tout'], self::$alphabet);
|
self::$alphabet = array_merge(['all' => 'Tout'], self::$alphabet);
|
||||||
|
|
||||||
// Ajoute les effectifs aux profils du sélecteur
|
// Liste des inscrits dans le contenu sélectionné.
|
||||||
foreach (self::$courseGroups as $groupId => $groupValue) {
|
$suscribers = $this->getData(['enrolment', $courseId]);
|
||||||
if ($groupId === 'all') {
|
$suscribers = array_keys($suscribers);
|
||||||
self::$courseGroups['all'] = self::$courseGroups['all'] . ' (' . array_sum($profils) . ')';
|
|
||||||
} else {
|
$users = array_diff_key($this->getData(['user']), array_flip($suscribers));
|
||||||
self::$courseGroups[$groupId] = self::$courseGroups[$groupId] . ' (' . $profils[$groupId] . ')';
|
|
||||||
}
|
// Tri du tableau par défaut par $userId
|
||||||
}
|
ksort($users);
|
||||||
|
|
||||||
foreach ($users as $userId => $userValue) {
|
foreach ($users as $userId => $userValue) {
|
||||||
|
|
||||||
|
// Compte les rôles
|
||||||
|
$profils[$this->getData(['user', $userId, 'group']) . $this->getData(['user', $userId, 'profil'])]++;
|
||||||
|
|
||||||
// Filtres
|
// Filtres
|
||||||
if ($this->isPost()) {
|
if (
|
||||||
|
isset($_POST['courseFilterGroup'])
|
||||||
|
|| isset($_POST['courseFilterFirstName'])
|
||||||
|
|| isset($_POST['courseFilterLastName'])
|
||||||
|
) {
|
||||||
|
|
||||||
// Groupe et profils
|
// Groupe et profils
|
||||||
$group = (string) $this->getData(['user', $userId, 'group']);
|
$group = (string) $this->getData(['user', $userId, 'group']);
|
||||||
@ -725,6 +662,15 @@ class course extends common
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Ajoute les effectifs aux profils du sélecteur
|
||||||
|
foreach (self::$courseGroups as $groupId => $groupValue) {
|
||||||
|
if ($groupId === 'all') {
|
||||||
|
self::$courseGroups['all'] = self::$courseGroups['all'] . ' (' . array_sum($profils) . ')';
|
||||||
|
} else {
|
||||||
|
self::$courseGroups[$groupId] = self::$courseGroups[$groupId] . ' (' . $profils[$groupId] . ')';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Valeurs en sortie
|
// Valeurs en sortie
|
||||||
$this->addOutput([
|
$this->addOutput([
|
||||||
'title' => helper::translate('Inscription en masse'),
|
'title' => helper::translate('Inscription en masse'),
|
||||||
@ -914,10 +860,7 @@ class course extends common
|
|||||||
// Valeurs en sortie
|
// Valeurs en sortie
|
||||||
$this->addOutput([
|
$this->addOutput([
|
||||||
'title' => helper::translate('Historique ') . $this->getData(['user', $userId, 'firstname']) . ' ' . $this->getData(['user', $userId, 'lastname']),
|
'title' => helper::translate('Historique ') . $this->getData(['user', $userId, 'firstname']) . ' ' . $this->getData(['user', $userId, 'lastname']),
|
||||||
'view' => 'userHistory',
|
'view' => 'userHistory'
|
||||||
'vendor' => [
|
|
||||||
'datatables'
|
|
||||||
]
|
|
||||||
]);
|
]);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -16,7 +16,7 @@ $(document).ready((function () {
|
|||||||
|
|
||||||
$("#courseFilterGroup, #courseFilterFirstName, #courseFilterLastName").change(function () {
|
$("#courseFilterGroup, #courseFilterFirstName, #courseFilterLastName").change(function () {
|
||||||
saveCheckboxState();
|
saveCheckboxState();
|
||||||
$("#courseUsersFilterForm").submit();
|
$("#courseUsersAddForm").submit();
|
||||||
|
|
||||||
});
|
});
|
||||||
var table = $('#dataTables').DataTable({
|
var table = $('#dataTables').DataTable({
|
||||||
|
Loading…
Reference in New Issue
Block a user