parent
ba8d1ce3fb
commit
949f8cce6c
@ -0,0 +1,169 @@ |
||||
<?php |
||||
|
||||
/* For licensing terms, see /license.txt */ |
||||
|
||||
require_once __DIR__.'/../inc/global.inc.php'; |
||||
|
||||
api_protect_admin_script(); |
||||
|
||||
$isAgendaRemindersEnabled = api_get_configuration_value('agenda_reminders'); |
||||
|
||||
if (!$isAgendaRemindersEnabled) { |
||||
api_not_allowed(true); |
||||
} |
||||
|
||||
$tblPersonalAgenda = Database::get_main_table(TABLE_PERSONAL_AGENDA); |
||||
|
||||
$tags = AnnouncementManager::getTags(); |
||||
$tags[] = '((date_start))'; |
||||
$tags[] = '((date_end))'; |
||||
|
||||
$tagsHelp = '<strong>'.get_lang('Tags').'</strong>' |
||||
.'<pre>'.implode("\n", $tags).'</pre>'; |
||||
|
||||
$form = new FormValidator('agenda_reminders'); |
||||
$form->addHeader(get_lang('CsvImport')); |
||||
$form->addFile( |
||||
'events_file', |
||||
[get_lang('ImportAsCSV'), get_lang('ImportCSVFileLocation')], |
||||
['accept' => 'text/csv'] |
||||
); |
||||
$form->addRule('events_file', get_lang('ThisFieldIsRequired'), 'required'); |
||||
$form->addRule('events_file', get_lang('InvalidExtension'), 'filetype', ['csv']); |
||||
$form->addHeader(get_lang('AddEventInCourseCalendar')); |
||||
$form->addText( |
||||
'title', |
||||
[get_lang('ItemTitle'), get_lang('TagsCanBeUsed')], |
||||
true, |
||||
['cols-size' => [2, 7, 3]] |
||||
); |
||||
$form->applyFilter('title', 'trim'); |
||||
$form->addHtmlEditor( |
||||
'description', |
||||
[get_lang('Description'), null, $tagsHelp], |
||||
true, |
||||
false, |
||||
['ToolbarSet' => 'Minimal', 'cols-size' => [2, 7, 3]] |
||||
); |
||||
//$form->applyFilter('description', 'html_filter_teacher'); |
||||
|
||||
if ($isAgendaRemindersEnabled) { |
||||
$form->addHeader(get_lang('NotifyBeforeTheEventStarts')); |
||||
$form->addHtml('<div id="notification_list"></div>'); |
||||
$form->addButton('add_notification', get_lang('AddNotification'), 'bell-o')->setType('button'); |
||||
} |
||||
|
||||
$form->addHtml('<hr>'); |
||||
$form->addButtonImport(get_lang('Import')); |
||||
|
||||
if ($form->validate()) { |
||||
$values = $form->exportValues(); |
||||
$uploadInfo = pathinfo($_FILES['events_file']['name']); |
||||
$notificationCount = $_POST['notification_count'] ?? []; |
||||
$notificationPeriod = $_POST['notification_period'] ?? []; |
||||
|
||||
$reminders = $notificationCount ? array_map(null, $notificationCount, $notificationPeriod) : []; |
||||
|
||||
if ('csv' !== $uploadInfo['extension']) { |
||||
Display::addFlash( |
||||
Display::return_message(get_lang('NotCSV'), 'error') |
||||
); |
||||
|
||||
header('Location: '.api_get_self()); |
||||
exit; |
||||
} |
||||
|
||||
$csvEvents = Import::csvToArray($_FILES['events_file']['tmp_name']); |
||||
|
||||
if (empty($csvEvents)) { |
||||
exit; |
||||
} |
||||
|
||||
$agenda = new Agenda('personal'); |
||||
|
||||
$grouppedData = []; |
||||
|
||||
foreach ($csvEvents as $csvEvent) { |
||||
$hashDate = base64_encode($csvEvent['StartDate'].'||'.$csvEvent['EndDate']); |
||||
|
||||
$courseInfo = api_get_course_info($csvEvent['CourseCode']); |
||||
|
||||
if (!$courseInfo) { |
||||
continue; |
||||
} |
||||
|
||||
$userInfo = api_get_user_info_from_username($csvEvent['UserName']); |
||||
|
||||
if (!$userInfo) { |
||||
continue; |
||||
} |
||||
|
||||
$grouppedData[$courseInfo['code']][$hashDate][] = $userInfo['id']; |
||||
} |
||||
|
||||
foreach ($grouppedData as $courseCode => $eventInfo) { |
||||
foreach ($eventInfo as $hashDate => $userIdList) { |
||||
$dateRange = base64_decode($hashDate); |
||||
list($dateStart, $dateEnd) = explode('||', $dateRange); |
||||
|
||||
$dateStart = api_get_utc_datetime($dateStart); |
||||
$dateEnd = api_get_utc_datetime($dateEnd); |
||||
|
||||
$strDateStart = api_format_date($dateStart, DATE_TIME_FORMAT_LONG_24H); |
||||
$strDateEnd = api_format_date($dateEnd, DATE_TIME_FORMAT_LONG_24H); |
||||
|
||||
foreach ($userIdList as $userId) { |
||||
$title = AnnouncementManager::parseContent($userId, $values['title'], $courseCode); |
||||
$content = AnnouncementManager::parseContent($userId, $values['description'], $courseCode); |
||||
|
||||
$title = str_replace(['((date_start))', '((date_end))'], [$strDateStart, $strDateEnd], $title); |
||||
$content = str_replace(['((date_start))', '((date_end))'], [$strDateStart, $strDateEnd], $content); |
||||
|
||||
$attributes = [ |
||||
'user' => $userId, |
||||
'title' => $title, |
||||
'text' => $content, |
||||
'date' => $dateStart, |
||||
'enddate' => $dateEnd, |
||||
'all_day' => 0, |
||||
'color' => '', |
||||
]; |
||||
|
||||
$eventId = Database::insert($tblPersonalAgenda, $attributes); |
||||
|
||||
if ($isAgendaRemindersEnabled) { |
||||
foreach ($reminders as $reminder) { |
||||
$agenda->addReminder($eventId, $reminder[0], $reminder[1]); |
||||
} |
||||
} |
||||
} |
||||
} |
||||
} |
||||
|
||||
Display::addFlash( |
||||
Display::return_message(get_lang('FileImported'), 'success') |
||||
); |
||||
|
||||
header('Location: '.api_get_self()); |
||||
exit; |
||||
} |
||||
|
||||
$form->setDefaults( |
||||
[ |
||||
'title' => get_lang('ImportCourseAgendaReminderTitleDefault'), |
||||
'description' => get_lang('ImportCourseAgendaReminderDescriptionDefault'), |
||||
] |
||||
); |
||||
|
||||
$htmlHeadXtra[] = '<script>$(function () {' |
||||
.Agenda::getJsForReminders('#agenda_reminders_add_notification') |
||||
.'});</script>'; |
||||
|
||||
$pageTitle = get_lang('ImportCourseEvents'); |
||||
|
||||
$interbreadcrumb[] = ['url' => 'index.php', 'name' => get_lang('PlatformAdmin')]; |
||||
|
||||
$template = new Template($pageTitle); |
||||
$template->assign('header', $pageTitle); |
||||
$template->assign('content', $form->returnForm()); |
||||
$template->display_one_col_template(); |
||||
Loading…
Reference in new issue