From ba2372400f436f59571c9e5c883d6f4b9d9e4ddd Mon Sep 17 00:00:00 2001 From: Justus Dieckmann Date: Mon, 10 Jun 2024 16:28:33 +0200 Subject: [PATCH] Email: add ##shortcourses## placeholder --- step/email/lang/de/lifecyclestep_email.php | 2 + step/email/lang/en/lifecyclestep_email.php | 2 + step/email/lib.php | 60 ++++++++-------------- 3 files changed, 24 insertions(+), 40 deletions(-) diff --git a/step/email/lang/de/lifecyclestep_email.php b/step/email/lang/de/lifecyclestep_email.php index b0fab933..f2710d1d 100644 --- a/step/email/lang/de/lifecyclestep_email.php +++ b/step/email/lang/de/lifecyclestep_email.php @@ -30,6 +30,7 @@ . '
' . 'Nachname des Empfängers: ##lastname##' . '
' . 'Link zur Antwortseite: ##link##' . '
' . 'Betroffene Kurse: ##courses##' + . '
' . 'Kurznamen betroffener Kurse: ##shortcourses##' . '

'; $string['email_content_html'] = 'HTML-Vorlage für Emails'; $string['email_content_html_help'] = 'Stellen sie die HTML-Vorlage für Emails ein. (in HTML-Format; falls gesetzt, wird es an Stelle der Klartext-Vorlage benutzt!)' . '

' . 'Sie können die folgenden Platzhalter benutzen:' @@ -45,6 +46,7 @@ . '
' . 'Nachname des Empfängers: ##lastname##' . '
' . 'Link zur Antwortseite: ##link##' . '
' . 'Betroffene Kurse: ##courses##' + . '
' . 'Kurznamen betroffener Kurse: ##shortcourses-html##' . '

'; $string['keep_course'] = 'Kurs behalten'; $string['pluginname'] = 'Email-Schritt'; diff --git a/step/email/lang/en/lifecyclestep_email.php b/step/email/lang/en/lifecyclestep_email.php index a0fd8ec4..e593339f 100644 --- a/step/email/lang/en/lifecyclestep_email.php +++ b/step/email/lang/en/lifecyclestep_email.php @@ -30,6 +30,7 @@ . '
' . 'Last name of recipient: ##lastname##' . '
' . 'Link to response page: ##link##' . '
' . 'Impacted courses: ##courses##' + . '
' . 'Short names of impacted courses: ##shortcourses##' . '

'; $string['email_content_html'] = 'Content HTML Template'; $string['email_content_html_help'] = 'Set the html template for the content of the email (HTML email, will be used instead of plaintext field if not empty!)' . '

' . 'You can use the following placeholders:' @@ -37,6 +38,7 @@ . '
' . 'Last name of recipient: ##lastname##' . '
' . 'Link to response page: ##link-html##' . '
' . 'Impacted courses: ##courses-html##' + . '
' . 'Short names of impacted courses: ##shortcourses-html##' . '

'; $string['email_responsetimeout'] = 'Time the user has for the response'; $string['email_subject'] = 'Subject template'; diff --git a/step/email/lib.php b/step/email/lib.php index f25b78bb..1dfcbbc2 100644 --- a/step/email/lib.php +++ b/step/email/lib.php @@ -27,7 +27,6 @@ use tool_lifecycle\local\manager\settings_manager; use tool_lifecycle\local\response\step_response; use tool_lifecycle\local\manager\step_manager; -use tool_lifecycle\local\manager\process_data_manager; use tool_lifecycle\settings_type; defined('MOODLE_INTERNAL') || die(); @@ -169,53 +168,34 @@ private function replace_placeholders($strings, $user, $stepid, $mailentries) { $patterns[] = '##link-html##'; $replacements[] = \html_writer::link($url, $url); - // Replace courses list. - $patterns[] = '##courses##'; - $courses = $mailentries; - $coursesstring = ''; - $coursesstring .= $this->parse_course(array_pop($courses)->courseid); - foreach ($courses as $entry) { - $coursesstring .= "\n" . $this->parse_course($entry->courseid); + $courses = []; + foreach ($mailentries as $entry) { + $courses[] = get_course($entry->courseid); } - $replacements[] = $coursesstring; - // Replace courses html. + // Replace courses list. + $coursesstrings = []; + foreach ($courses as $course) { + $coursesstrings[] = $course->fullname; + } + $patterns[] = '##courses##'; + $replacements[] = join("\n", $coursesstrings); $patterns[] = '##courses-html##'; - $courses = $mailentries; - $coursestabledata = []; - foreach ($courses as $entry) { - $coursestabledata[$entry->courseid] = $this->parse_course_row_data($entry->courseid); + $replacements[] = join("
", $coursesstrings); + + // Replace short courses list. + $coursesstrings = []; + foreach ($courses as $course) { + $coursesstrings[] = $course->shortname; } - $coursestable = new \html_table(); - $coursestable->data = $coursestabledata; - $replacements[] = \html_writer::table($coursestable); + $patterns[] = '##shortcourses##'; + $replacements[] = join("\n", $coursesstrings); + $patterns[] = '##shortcourses-html##'; + $replacements[] = join("
", $coursesstrings); return str_ireplace($patterns, $replacements, $strings); } - /** - * Parses a course for the non html format. - * @param int $courseid id of the course - * @return string - * @throws \dml_exception - */ - private function parse_course($courseid) { - $course = get_course($courseid); - $result = $course->fullname; - return $result; - } - - /** - * Parses a course for the html format. - * @param int $courseid id of the course - * @return array column of a course - * @throws \dml_exception - */ - private function parse_course_row_data($courseid) { - $course = get_course($courseid); - return [$course->fullname]; - } - /** * Defines which settings each instance of the subplugin offers for the user to define. * @return instance_setting[] containing settings keys and PARAM_TYPES