123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014 |
- <?php
- /* For licensing terms, see /license.txt */
- use Chamilo\CoreBundle\Entity\ExtraFieldSavedSearch;
- $cidReset = true;
- require_once 'main/inc/global.inc.php';
- $htmlHeadXtra[] = '<link href="'. api_get_path(WEB_PATH) .'web/assets/cropper/dist/cropper.min.css" rel="stylesheet">';
- $htmlHeadXtra[] = '<script src="'. api_get_path(WEB_PATH) .'web/assets/cropper/dist/cropper.min.js"></script>';
- $htmlHeadXtra[] ='<script>
- $(document).ready(function() {
- /*$("#filiere_panel").hide();
- $("#dispo_panel").hide();
- $("#dispo_pendant_panel").hide();
- $("#niveau_panel").hide();
- $("#methode_panel").hide();
- $("#themes_panel").hide();
- $("#objectifs_panel").hide();*/
-
- $("#filiere").on("click", function() {
- $("#filiere_panel").toggle();
- return false;
- });
-
- $("#dispo").on("click", function() {
- $("#dispo_panel").toggle();
- return false;
- });
-
- $("#dispo_pendant").on("click", function() {
- $("#dispo_pendant_panel").toggle();
- return false;
- });
-
- $("#niveau").on("click", function() {
- $("#niveau_panel").toggle();
- return false;
- });
-
- $("#methode").on("click", function() {
- $("#methode_panel").toggle();
- return false;
- });
-
- $("#themes").on("click", function() {
- $("#themes_panel").toggle();
- return false;
- });
-
- $("#objectifs").on("click", function() {
- $("#objectifs_panel").toggle();
- return false;
- });
- });
- </script>';
- api_block_anonymous_users();
- $allowToSee = api_is_drh() || api_is_student_boss() || api_is_platform_admin();
- if ($allowToSee === false) {
- api_not_allowed(true);
- }
- $userId = api_get_user_id();
- $userInfo = api_get_user_info();
- $userToLoad = isset($_GET['user_id']) ? $_GET['user_id'] : '';
- $userToLoadInfo = [];
- if ($userToLoad) {
- $userToLoadInfo = api_get_user_info($userToLoad);
- }
- $action = isset($_GET['action']) ? $_GET['action'] : '';
- switch ($action) {
- case 'subscribe_user':
- $sessionId = isset($_GET['session_id']) ? $_GET['session_id'] : '';
- SessionManager::subscribe_users_to_session(
- $sessionId,
- [$userToLoad],
- SESSION_VISIBLE_READ_ONLY,
- false
- );
- Display::addFlash(Display::return_message(get_lang('UserAdded')));
- header("Location: ".api_get_self().'?user_id='.$userToLoad.'#session-table');
- exit;
- break;
- case 'unsubscribe_user':
- $sessionId = isset($_GET['session_id']) ? $_GET['session_id'] : '';
- SessionManager::unsubscribe_user_from_session($sessionId, $userToLoad);
- Display::addFlash(Display::return_message(get_lang('Unsubscribed')));
- header("Location: ".api_get_self().'?user_id='.$userToLoad.'#session-table');
- break;
- }
- $em = Database::getManager();
- $formSearch = new FormValidator('load', 'get', api_get_self());
- $formSearch->addHeader(get_lang('LoadDiagnosis'));
- if (!empty($userInfo)) {
- $users = [];
- switch ($userInfo['status']) {
- case DRH:
- $users = UserManager::get_users_followed_by_drh($userId);
- break;
- case STUDENT_BOSS:
- $users = UserManager::getUsersFollowedByStudentBoss($userId);
- break;
- }
- if (!empty($users)) {
- $userList = [];
- foreach ($users as $user) {
- $userList[$user['user_id']] = api_get_person_name($user['firstname'], $user['lastname']);
- }
- $formSearch->addSelect('user_id', get_lang('User'), $userList);
- }
- }
- if ($userToLoad) {
- $formSearch->setDefaults(['user_id' => $userToLoad]);
- }
- $formSearch->addButtonSearch(get_lang('ShowDiagnostic'), 'save');
- $form = new FormValidator('search', 'post', api_get_self().'?user_id='.$userToLoad.'#session-table');
- $form->addHeader(get_lang('Diagnosis'));
- $form->addHidden('user_id', $userToLoad);
- /** @var ExtraFieldSavedSearch $saved */
- $search = [
- 'user' => $userToLoad
- ];
- $items = $em->getRepository('ChamiloCoreBundle:ExtraFieldSavedSearch')->findBy($search);
- if (empty($items)) {
- Display::addFlash(Display::return_message('NoData'));
- }
- $defaults = [];
- $tagsData = [];
- if (!empty($items)) {
- /** @var ExtraFieldSavedSearch $item */
- foreach ($items as $item) {
- $variable = 'extra_'.$item->getField()->getVariable();
- if ($item->getField()->getFieldType() == ExtraField::FIELD_TYPE_TAG) {
- $tagsData[$variable] = $item->getValue();
- }
- $defaults[$variable] = $item->getValue();
- }
- }
- $extraField = new ExtraField('session');
- $extraFieldValue = new ExtraFieldValue('session');
- $theme = 'theme_fr';
- if ($userToLoadInfo) {
- $lang = $userToLoadInfo['language'];
- switch ($lang) {
- case 'french2':
- case 'french':
- $theme = 'theme_fr';
- break;
- case 'german2':
- case 'german':
- $theme = 'theme_de';
- break;
- }
- }
- $extraFieldUser = new ExtraField('user');
- $userForm = new FormValidator('user_form', 'post', api_get_self());
- $userForm->addHtml('<div class="panel-group" id="search_extrafield" role="tablist" aria-multiselectable="true">');
- $userForm->addHtml('<div class="panel panel-default">');
- $userForm->addHtml('<div class="panel-heading"><a role="button" data-toggle="collapse" data-parent="#search_extrafield" href="#collapseOne" aria-expanded="true" aria-controls="collapseOne">' . get_lang('Filiere') . '</a></div>');
- $userForm->addHtml('<div id="collapseOne" class="panel-collapse collapse in" role="tabpanel" aria-labelledby="headingOne">');
- $userForm->addHtml('<div class="panel-body"><p class="text-info">' . get_lang('FiliereExplanation') .'</p>');
- $fieldsToShow = [
- 'statusocial',
- 'filiere_user',
- 'filiereprecision',
- 'filiere_want_stage',
- ];
- $forceShowFields = true;
- $filter = false;
- $extra = $extraFieldUser->addElements(
- $userForm,
- $userToLoad,
- [],
- $filter,
- true,
- $fieldsToShow,
- $fieldsToShow,
- [],
- [],
- false,
- $forceShowFields, //$forceShowFields = false
- [],
- [],
- $fieldsToShow
- );
- $userForm->addHtml('</div></div></div>');
- $userForm->addHtml('<div class="panel panel-default">');
- $userForm->addHtml('<div class="panel-heading"><a role="button" data-toggle="collapse" data-parent="#search_extrafield" href="#collapseThree" aria-expanded="true" aria-controls="collapseThree">' . get_lang('DisponibilitePendantMonStage') . '</a></div>');
- $userForm->addHtml('<div id="collapseThree" class="panel-collapse collapse in" role="tabpanel" aria-labelledby="headingThree">');
- $userForm->addHtml('<div class="panel-body"><p class="text-info">' . get_lang('DisponibilitePendantMonStageExplanation') . '</p>');
- $fieldsToShow = [
- 'datedebutstage',
- 'datefinstage',
- 'poursuiteapprentissagestage',
- 'heures_disponibilite_par_semaine_stage'
- ];
- $extra = $extraFieldUser->addElements(
- $userForm,
- $userToLoad,
- [],
- $filter,
- true,
- $fieldsToShow,
- $fieldsToShow,
- [],
- [],
- false,
- $forceShowFields, //$forceShowFields = false
- [],
- [],
- $fieldsToShow
- );
- $userForm->addHtml('</div></div></div>');
- $userForm->addHtml('<div class="panel panel-default">');
- $userForm->addHtml('<div class="panel-heading"><a role="button" data-toggle="collapse" data-parent="#search_extrafield" href="#collapseSix" aria-expanded="true" aria-controls="collapseSix">' . get_lang('ObjectifsApprentissage') . '</a></div>');
- $userForm->addHtml('<div id="collapseSix" class="panel-collapse collapse in" role="tabpanel" aria-labelledby="headingSix">');
- $userForm->addHtml('<div class="panel-body"><p class="text-info">' . get_lang('ObjectifsApprentissageExplanation') . '</p>');
- $fieldsToShow = [
- 'objectif_apprentissage'
- ];
- $extra = $extraFieldUser->addElements(
- $userForm,
- $userToLoad,
- [],
- $filter,
- false,
- $fieldsToShow,
- $fieldsToShow,
- $defaults,
- [],
- false,
- $forceShowFields,//$forceShowFields = false
- [],
- [],
- $fieldsToShow
- );
- $userForm->addHtml('</div></div></div>');
- $userForm->addHtml('<div class="panel panel-default">');
- $userForm->addHtml('<div class="panel-heading"><a role="button" data-toggle="collapse" data-parent="#search_extrafield" href="#collapseSeven" aria-expanded="true" aria-controls="collapseSeven">' . get_lang('MethodeTravail') . '</a></div>');
- $userForm->addHtml('<div id="collapseSeven" class="panel-collapse collapse in" role="tabpanel" aria-labelledby="headingSeven">');
- $userForm->addHtml('<div class="panel-body"><p class="text-info">' . get_lang('MethodeTravailExplanation') . '</p>');
- $fieldsToShow = [
- 'methode_de_travaille',
- 'accompagnement'
- ];
- $extra = $extraFieldUser->addElements(
- $userForm,
- $userToLoad,
- [],
- $filter,
- true,
- $fieldsToShow,
- $fieldsToShow,
- [],
- [],
- false,
- $forceShowFields, //$forceShowFields = false
- [],
- [],
- $fieldsToShow
- );
- $userForm->addHtml('</div></div></div>');
- $form->addHtml('<div class="panel panel-default">');
- $form->addHtml('<div class="panel-heading"><a role="button" data-toggle="collapse" data-parent="#search_extrafield" href="#collapseTwo" aria-expanded="true" aria-controls="collapseTwo">' . get_lang('DisponibiliteAvant') . '</a></div>');
- $form->addHtml('<div id="collapseTwo" class="panel-collapse collapse in" role="tabpanel" aria-labelledby="headingTwo">');
- $form->addHtml('<div class="panel-body"><p class="text-info">' . get_lang('DisponibiliteAvantExplanation') . '</p>');
- // Session fields
- $showOnlyThisFields = [
- 'access_start_date',
- 'access_end_date'
- ];
- $extra = $extraField->addElements(
- $form,
- '',
- [],
- false, //filter
- true,
- $showOnlyThisFields,
- $showOnlyThisFields,
- $defaults,
- [],
- false, //$orderDependingDefaults
- true, // force
- [], // $separateExtraMultipleSelect
- []
- );
- $fieldsToShow = [
- 'heures_disponibilite_par_semaine',
- ];
- $extra = $extraFieldUser->addElements(
- $form,
- $userToLoad,
- [],
- $filter,
- true,
- $fieldsToShow,
- $fieldsToShow,
- [],
- [],
- false,
- $forceShowFields //$forceShowFields = false
- );
- $form->addHtml('</div></div></div>');
- $form->addHtml('<div class="panel panel-default">');
- $form->addHtml('<div class="panel-heading"><a role="button" data-toggle="collapse" data-parent="#search_extrafield" href="#collapseFour" aria-expanded="true" aria-controls="collapseFour">' . get_lang('ThemesObjectifs') . '</a></div>');
- $form->addHtml('<div id="collapseFour" class="panel-collapse collapse in" role="tabpanel" aria-labelledby="headingFour">');
- $form->addHtml('<div class="panel-body"><p class="text-info">' . get_lang('ThemesObjectifsExplanation') . '</p>');
- $showOnlyThisFields = [
- 'domaine',
- 'filiere',
- $theme,
- ];
- $extra = $extraField->addElements(
- $form,
- '',
- [],
- false, //filter
- true,
- $showOnlyThisFields,
- $showOnlyThisFields,
- $defaults,
- [],
- false, //$orderDependingDefaults
- true, // force
- [ 'domaine' => 3, $theme => 5], // $separateExtraMultipleSelect
- [
- 'domaine' => [
- get_lang('Domaine').' 1',
- get_lang('Domaine').' 2',
- get_lang('Domaine').' 3'
- ],
- $theme => [
- get_lang('ThemeField').' 1',
- get_lang('ThemeField').' 2',
- get_lang('ThemeField').' 3',
- get_lang('ThemeField').' 4',
- get_lang('ThemeField').' 5'
- ],
- ]
- );
- $form->addHtml('</div></div></div>');
- $form->addHtml('<div class="panel panel-default">');
- $form->addHtml('<div class="panel-heading"><a role="button" data-toggle="collapse" data-parent="#search_extrafield" href="#collapseFive" aria-expanded="true" aria-controls="collapseFive">' . get_lang('NiveauLangue') . '</a></div>');
- $form->addHtml('<div id="collapseFive" class="panel-collapse collapse in" role="tabpanel" aria-labelledby="headingFive">');
- $form->addHtml('<div class="panel-body"><p class="text-info">' . get_lang('NiveauLangueExplanation') . '</p>');
- $showOnlyThisFields = [
- 'ecouter',
- 'lire',
- 'participer_a_une_conversation',
- 's_exprimer_oralement_en_continu',
- 'ecrire'
- ];
- $extra = $extraField->addElements(
- $form,
- '',
- [],
- false, //filter
- true,
- $showOnlyThisFields,
- $showOnlyThisFields,
- $defaults,
- [],
- false, //$orderDependingDefaults
- true, // force
- [ 'domaine' => 3, $theme => 5], // $separateExtraMultipleSelect
- [
- 'domaine' => [
- get_lang('Domaine').' 1',
- get_lang('Domaine').' 2',
- get_lang('Domaine').' 3'
- ],
- $theme => [
- get_lang('Theme').' 1',
- get_lang('Theme').' 2',
- get_lang('Theme').' 3',
- get_lang('Theme').' 4',
- get_lang('Theme').' 5'
- ],
- ]
- );
- $form->addHtml('</div></div></div>');
- $form->addButtonSave(get_lang('SaveDiagnosticChanges'), 'save');
- $form->addButtonSearch(get_lang('SearchSessions'), 'search');
- $extraFieldsToFilter = $extraField->get_all(array('variable = ?' => 'temps_de_travail'));
- $extraFieldToSearch = array();
- if (!empty($extraFieldsToFilter)) {
- foreach ($extraFieldsToFilter as $filter) {
- $extraFieldToSearch[] = $filter['id'];
- }
- }
- $extraFieldListToString = implode(',', $extraFieldToSearch);
- $result = SessionManager::getGridColumns('simple', $extraFieldsToFilter);
- $columns = $result['columns'];
- $column_model = $result['column_model'];
- $form->setDefaults($defaults);
- /** @var HTML_QuickForm_select $element */
- $domaine1 = $form->getElementByName('extra_domaine[0]');
- $domaine2 = $form->getElementByName('extra_domaine[1]');
- $domaine3 = $form->getElementByName('extra_domaine[2]');
- $userForm->setDefaults($defaults);
- $domainList = array_merge(
- is_object($domaine1) ? $domaine1->getValue() : [],
- is_object($domaine3) ? $domaine3->getValue() : [],
- is_object($domaine2) ? $domaine2->getValue() : []
- );
- $themeList = [];
- $extraField = new ExtraField('session');
- $resultOptions = $extraField->searchOptionsFromTags('extra_domaine', 'extra_'.$theme, $domainList);
- if ($resultOptions) {
- $resultOptions = array_column($resultOptions, 'tag', 'id');
- $resultOptions = array_filter($resultOptions);
- for ($i = 0; $i < 5; $i++) {
- /** @var HTML_QuickForm_select $theme */
- $themeElement = $form->getElementByName('extra_'.$theme.'['.$i.']');
- foreach ($resultOptions as $key => $value) {
- $themeElement->addOption($value, $value);
- }
- }
- }
- $filterToSend = '';
- if ($formSearch->validate()) {
- $formSearchParams = $formSearch->getSubmitValues();
- }
- // Search filter
- $filters = [];
- foreach ($defaults as $key => $value) {
- if (substr($key, 0, 6) != 'extra_' && substr($key, 0, 7) != '_extra_') {
- continue;
- }
- if (!empty($value)) {
- $filters[$key] = $value;
- }
- }
- $filterToSend = [];
- if (!empty($filters)) {
- $filterToSend = ['groupOp' => 'AND'];
- if ($filters) {
- $count = 1;
- $countExtraField = 1;
- foreach ($result['column_model'] as $column) {
- if ($count > 5) {
- if (isset($filters[$column['name']])) {
- $defaultValues['jqg'.$countExtraField] = $filters[$column['name']];
- $filterToSend['rules'][] = ['field' => $column['name'], 'op' => 'cn', 'data' => $filters[$column['name']]];
- }
- $countExtraField++;
- }
- $count++;
- }
- }
- }
- $params = [];
- if ($form->validate()) {
- $params = $form->getSubmitValues();
- $save = false;
- $search = false;
- if (isset($params['search'])) {
- unset($params['search']);
- $search = true;
- }
- if (isset($params['save'])) {
- $save = true;
- unset($params['save']);
- }
- $form->setDefaults($params);
- $filters = [];
- // Search
- if ($search) {
- // Parse params.
- foreach ($params as $key => $value) {
- if (substr($key, 0, 6) != 'extra_' && substr($key, 0, 7) != '_extra_') {
- continue;
- }
- if (!empty($value)) {
- $filters[$key] = $value;
- }
- }
- $filterToSend = [];
- if (!empty($filters)) {
- $filterToSend = ['groupOp' => 'AND'];
- if ($filters) {
- $count = 1;
- $countExtraField = 1;
- foreach ($result['column_model'] as $column) {
- if ($count > 5) {
- if (isset($filters[$column['name']])) {
- $defaultValues['jqg'.$countExtraField] = $filters[$column['name']];
- $filterToSend['rules'][] = [
- 'field' => $column['name'],
- 'op' => 'cn',
- 'data' => $filters[$column['name']]
- ];
- }
- $countExtraField++;
- }
- $count++;
- }
- }
- }
- }
- if ($save) {
- $userData = $params;
- // Update extra_heures_disponibilite_par_semaine
- $extraFieldValue = new ExtraFieldValue('user');
- $userDataToSave = [
- 'item_id' => $userToLoad,
- 'extra_heures_disponibilite_par_semaine' => isset($userData['extra_heures_disponibilite_par_semaine']) ? $userData['extra_heures_disponibilite_par_semaine'] : ''
- ];
- $extraFieldValue->saveFieldValues($userDataToSave, true, false, ['heures_disponibilite_par_semaine']);
- // Save session search
- /** @var \Chamilo\UserBundle\Entity\User $user */
- $user = $em->getRepository('ChamiloUserBundle:User')->find($userToLoad);
- $extraFieldValueSession = new ExtraFieldValue('session');
- $sessionFields = [
- 'extra_access_start_date',
- 'extra_access_end_date',
- 'extra_filiere',
- 'extra_domaine',
- 'extra_domaine[0]',
- 'extra_domaine[1]',
- 'extra_domaine[3]',
- 'extra_temps_de_travail',
- //'extra_competenceniveau',
- 'extra_'.$theme,
- 'extra_ecouter',
- 'extra_lire',
- 'extra_participer_a_une_conversation',
- 'extra_s_exprimer_oralement_en_continu',
- 'extra_ecrire'
- ];
- foreach ($userData as $key => $value) {
- $found = strpos($key, '__persist__');
- if ($found === false) {
- continue;
- }
- }
- if (isset($userData['extra_filiere_want_stage']) &&
- isset($userData['extra_filiere_want_stage']['extra_filiere_want_stage'])
- ) {
- $wantStage = $userData['extra_filiere_want_stage']['extra_filiere_want_stage'];
- if ($wantStage === 'yes') {
- if (isset($userData['extra_filiere_user'])) {
- $userData['extra_filiere'] = [];
- $userData['extra_filiere']['extra_filiere'] = $userData['extra_filiere_user']['extra_filiere_user'];
- }
- }
- }
- // save in ExtraFieldSavedSearch.
- foreach ($userData as $key => $value) {
- if (substr($key, 0, 6) != 'extra_' && substr($key, 0, 7) != '_extra_') {
- continue;
- }
- if (!in_array($key, $sessionFields)) {
- continue;
- }
- $field_variable = substr($key, 6);
- $extraFieldInfo = $extraFieldValueSession
- ->getExtraField()
- ->get_handler_field_info_by_field_variable($field_variable);
- if (!$extraFieldInfo) {
- continue;
- }
- $extraFieldObj = $em->getRepository('ChamiloCoreBundle:ExtraField')->find($extraFieldInfo['id']);
- $search = [
- 'field' => $extraFieldObj,
- 'user' => $user
- ];
- /** @var ExtraFieldSavedSearch $saved */
- $saved = $em->getRepository('ChamiloCoreBundle:ExtraFieldSavedSearch')->findOneBy($search);
- if ($saved) {
- $saved
- ->setField($extraFieldObj)
- ->setUser($user)
- ->setValue($value)
- ;
- $em->merge($saved);
- } else {
- $saved = new ExtraFieldSavedSearch();
- $saved
- ->setField($extraFieldObj)
- ->setUser($user)
- ->setValue($value)
- ;
- $em->persist($saved);
- }
- $em->flush();
- }
- Display::addFlash(Display::return_message(get_lang('Saved'), 'success'));
- header('Location: '.api_get_self().'?user_id='.$userToLoad);
- exit;
- }
- }
- $view = $form->returnForm();
- $jsTag = '';
- if (!empty($tagsData)) {
- foreach ($tagsData as $extraField => $tags) {
- foreach ($tags as $tag) {
- $tag = api_htmlentities($tag);
- // $jsTag .= "$('#$extraField')[0].addItem('$tag', '$tag');";
- }
- }
- }
- $htmlHeadXtra[] ='<script>
- $(function() {
- '.$extra['jquery_ready_content'].'
- '.$jsTag.'
- });
- </script>';
- if (!empty($filterToSend)) {
- // Get start and end date from ExtraFieldSavedSearch
- $defaultExtraStartDate = isset($defaults['extra_access_start_date']) ? $defaults['extra_access_start_date'] : '';
- $defaultExtraEndDate = isset($defaults['extra_access_end_date']) ? $defaults['extra_access_end_date'] : '';
- $userStartDate = isset($params['extra_access_start_date']) ? $params['extra_access_start_date'] : $defaultExtraStartDate;
- $userEndDate = isset($params['extra_access_end_date']) ? $params['extra_access_end_date'] : $defaultExtraEndDate;
- // Minus 3 days
- $date = new DateTime($userStartDate);
- $date->sub(new DateInterval('P3D'));
- $userStartDateMinus = $date->format('Y-m-d h:i:s');
- // Plus 2 days
- $date = new DateTime($userEndDate);
- $date->add(new DateInterval('P2D'));
- $userEndDatePlus = $date->format('Y-m-d h:i:s');
- // Ofaj fix
- $userStartDateMinus = api_get_utc_datetime(substr($userStartDateMinus, 0, 11).'00:00:00');
- $userEndDatePlus = api_get_utc_datetime(substr($userEndDatePlus, 0, 11). '23:59:59');
- // Special OFAJ date logic
- $sql = " AND (
- (s.access_start_date >= '$userStartDateMinus' AND s.access_end_date < '$userEndDatePlus') OR
- (s.access_start_date >= '$userStartDateMinus' AND (s.access_end_date = '' OR s.access_end_date IS NULL)) OR
- ((s.access_start_date = '' OR s.access_start_date IS NULL) AND (s.access_end_date = '' OR s.access_end_date IS NULL))
- )";
- $deleteFiliere = false;
- $extraFieldOptions = new ExtraFieldOption('session');
- $extraFieldSession = new ExtraField('session');
- // Special filters
- // see https://task.beeznest.com/issues/10849#change-81902
- foreach ($filterToSend['rules'] as &$filterItem) {
- if (isset($filterItem['field']))
- switch ($filterItem['field']) {
- case 'extra_ecouter':
- case 'extra_lire':
- case 'extra_participer_a_une_conversation':
- case 'extra_s_exprimer_oralement_en_continu':
- case 'extra_ecrire':
- $selectedValue = '';
- $fieldExtra = str_replace('extra_', '', $filterItem['field']);
- $extraFieldSessionData = $extraFieldSession->get_handler_field_info_by_field_variable($fieldExtra);
- if (is_array($filterItem['data'])) {
- $myOrder = [];
- foreach ($filterItem['data'] as $option) {
- foreach ($extraFieldSessionData['options'] as $optionValue) {
- if ($option == $optionValue['option_value']) {
- $myOrder[$optionValue['option_order']] = $optionValue['option_value'];
- }
- }
- }
- if (!empty($myOrder)) {
- // Taking last from list
- $selectedValue = end($myOrder);
- }
- } else {
- $selectedValue = $filterItem['data'];
- }
- $newOptions = array_column(
- $extraFieldSessionData['options'],
- 'option_value',
- 'option_order'
- );
- $searchOptions = [];
- for ($i = 1; $i < count($newOptions); $i++) {
- if ($selectedValue == $newOptions[$i]) {
- if (isset($newOptions[$i-1])) {
- $searchOptions[] = $newOptions[$i-1];
- }
- if (isset($newOptions[$i])) {
- $searchOptions[] = $newOptions[$i];
- }
- if (isset($newOptions[$i+1])) {
- $searchOptions[] = $newOptions[$i+1];
- }
- break;
- }
- }
- $filterItem['data'] = $searchOptions;
- break;
- case 'extra_domaine':
- // Special condition see:
- // https://task.beeznest.com/issues/10849#note-218
- // Remove filiere
- $list = [
- 'vie-quotidienne',
- //'competente-dans-mon-domaine-de-specialite',
- 'arrivee-sur-mon-poste-de-travail'
- ];
- $deleteFiliere = false;
- if (is_array($filterItem['data'])) {
- $myOrder = [];
- foreach ($filterItem['data'] as $option) {
- if (in_array($option, $list)) {
- $deleteFiliere = true;
- break;
- }
- }
- } else {
- if (in_array($filterItem['data'], $list)) {
- $deleteFiliere = true;
- }
- }
- break;
- }
- if ($deleteFiliere) {
- foreach ($filterToSend['rules'] as &$filterItem) {
- if (isset($filterItem['field']) && $filterItem['field'] == 'extra_filiere') {
- $filterItem = [];
- }
- }
- }
- }
- if ($userStartDate && !empty($userStartDate)) {
- $filterToSend['custom_dates'] = $sql;
- }
- $filterToSend = json_encode($filterToSend);
- $url = api_get_path(WEB_AJAX_PATH).'model.ajax.php?a=get_sessions&_search=true&load_extra_field='.$extraFieldListToString.'&_force_search=true&rows=20&page=1&sidx=&sord=asc&filters2='.$filterToSend;
- } else {
- $url = api_get_path(WEB_AJAX_PATH).'model.ajax.php?a=get_sessions&_search=true&load_extra_field='.$extraFieldListToString.'&_force_search=true&rows=20&page=1&sidx=&sord=asc';
- }
- // Autowidth
- $extra_params['autowidth'] = 'true';
- // height auto
- $extra_params['height'] = 'auto';
- $extra_params['postData'] = array(
- 'filters' => array(
- "groupOp" => "AND",
- "rules" => $result['rules']
- )
- );
- $sessionByUserList = SessionManager::get_sessions_by_user($userToLoad, true, true);
- $sessionUserList = array();
- if (!empty($sessionByUserList)) {
- foreach ($sessionByUserList as $sessionByUser) {
- $sessionUserList[] = (string) $sessionByUser['session_id'];
- }
- }
- $action_links = 'function action_formatter(cellvalue, options, rowObject) {
- var sessionList = '.json_encode($sessionUserList).';
- var id = options.rowId.toString();
- if (sessionList.indexOf(id) == -1) {
- return \'<a href="'.api_get_self().'?action=subscribe_user&user_id='.$userToLoad.'&session_id=\'+id+\'">'.Display::return_icon('add.png', addslashes(get_lang('Subscribe')),'',ICON_SIZE_SMALL).'</a>'.'\';
- } else {
- return \'<a href="'.api_get_self().'?action=unsubscribe_user&user_id='.$userToLoad.'&session_id=\'+id+\'">'.Display::return_icon('delete.png', addslashes(get_lang('Delete')),'',ICON_SIZE_SMALL).'</a>'.'\';
- }
- }';
- $htmlHeadXtra[] = api_get_jqgrid_js();
- $griJs = Display::grid_js(
- 'sessions',
- $url,
- $columns,
- $column_model,
- $extra_params,
- array(),
- $action_links,
- true
- );
- $grid = '<div id="session-table" class="table-responsive">';
- $grid .= Display::grid_html('sessions');
- $grid .= '</div>';
- $htmlHeadXtra[] ='<style>
- .control-label {
- width: 25% !important;
- }
- </style>';
- $htmlHeadXtra[] ='<script>
- $(document).ready(function() {
- var blocks = [
- "#collapseOne",
- "#collapseTwo",
- "#collapseThree",
- "#collapseFour",
- "#collapseFive",
- "#collapseSix",
- "#collapseSeven"
- ];
-
- $.each(blocks, function( index, value ) {
- $(value).collapse("hide");
- });
- });
- </script>';
- $tpl = new Template(get_lang('Diagnosis'));
- if (empty($items)) {
- $view = '';
- $grid = '';
- $griJs = '';
- }
- $tpl->assign('form', $view);
- $tpl->assign('form_search', $formSearch->returnForm().$userForm->returnForm());
- $table = new HTML_Table(array('class' => 'data_table'));
- $column = 0;
- $row = 0;
- $total = '0';
- $sumHours = '0';
- $numHours = '0';
- $field = 'heures_disponibilite_par_semaine';
- $extraField = new ExtraFieldValue('user');
- $data = $extraField->get_values_by_handler_and_field_variable($userToLoad, $field);
- $availableHoursPerWeek = 0;
- function dateDiffInWeeks($date1, $date2)
- {
- if ($date1 > $date2) {
- return dateDiffInWeeks($date2, $date1);
- }
- $first = new \DateTime($date1);
- $second = new \DateTime($date2);
- return floor($first->diff($second)->days / 7);
- }
- if ($data) {
- $availableHoursPerWeek = $data['value'];
- $numberWeeks = 0;
- if ($form->validate()) {
- $formData = $form->getSubmitValues();
- if (isset($formData['extra_access_start_date']) && isset($formData['extra_access_end_date'])) {
- $startDate = $formData['extra_access_start_date'];
- $endDate = $formData['extra_access_end_date'];
- $numberWeeks = dateDiffInWeeks($startDate, $endDate);
- }
- } else {
- if ($defaults) {
- if (isset($defaults['extra_access_start_date']) && isset($defaults['extra_access_end_date'])) {
- $startDate = $defaults['extra_access_start_date'];
- $endDate = $defaults['extra_access_end_date'];
- $numberWeeks = dateDiffInWeeks($startDate, $endDate);
- }
- }
- }
- $total = $numberWeeks * $availableHoursPerWeek;
- $sessions = SessionManager::getSessionsFollowedByUser($userToLoad);
- if ($sessions) {
- $sessionFieldValue = new ExtraFieldValue('session');
- foreach ($sessions as $session) {
- $sessionId = $session['id'];
- $data = $sessionFieldValue->get_values_by_handler_and_field_variable(
- $sessionId,
- 'temps_de_travail'
- );
- if ($data) {
- $sumHours += $data['value'];
- }
- }
- }
- }
- $numHours = $total - $sumHours;
- $headers = array(
- get_lang('TotalAvailableHours') => $total,
- get_lang('SumHoursSessionsSubscribed') => $sumHours,
- get_lang('CountHoursAvailable') => $numHours
- );
- foreach ($headers as $header => $value) {
- $table->setCellContents($row, 0, $header);
- $table->updateCellAttributes($row, 0, 'width="250px"');
- $table->setCellContents($row, 1, $value);
- $row++;
- }
- $button = '';
- if ($userToLoad) {
- $button = Display::url(
- get_lang('OfajEndOfLearnPath'),
- api_get_path(WEB_CODE_PATH).'messages/new_message.php?prefill=ofaj&send_to_user='.$userToLoad,
- ['class' => 'btn btn-default']
- );
- $button .= '<br /><br />';
- }
- $userReportButton = Display::url(
- get_lang('DiagnosticValidateLearningPath'),
- api_get_path(WEB_CODE_PATH).'mySpace/myStudents.php?student='.$userToLoad,
- ['class' => 'btn btn-primary']
- );
- $tpl->assign('grid', $grid.$button.$table->toHtml().$userReportButton);
- $tpl->assign('grid_js', $griJs);
- $content = $tpl->fetch('default/user_portal/search_extra_field.tpl');
- $tpl->assign('content', $content);
- $tpl->display_one_col_template();
|