4 include_once(
"./Services/Tracking/classes/class.ilLPTableBaseGUI.php");
26 public function __construct($a_parent_obj, $a_parent_cmd, $a_ref_id, $a_print_mode =
false)
30 $ilCtrl = $DIC[
'ilCtrl'];
31 $objDefinition = $DIC[
'objDefinition'];
33 $this->
setId(
"trsmy");
35 $this->ref_id = $a_ref_id;
39 if (!$this->is_root) {
43 if (!$objDefinition->isContainer(
$type)) {
45 include_once
'./Services/Object/classes/class.ilObjectLP.php';
56 $this->
parseTitle($this->obj_id,
"trac_summary");
61 $this->
addColumn($this->lng->txt(
"title"),
"title");
70 $this->
addColumn($this->lng->txt(
"path"));
71 $this->
addColumn($this->lng->txt(
"action"));
77 $this->
setFormAction($ilCtrl->getFormActionByClass(get_class($this)));
78 $this->
setRowTemplate(
"tpl.trac_summary_row.html",
"Services/Tracking");
81 $this->
getItems($a_parent_obj->getObjId(), $a_ref_id);
91 $lng_map = array(
"user_total" =>
"users",
"first_access_min" =>
"trac_first_access",
92 "last_access_max" =>
"trac_last_access",
"mark" =>
"trac_mark",
"status" =>
"trac_status",
93 'status_changed_max' =>
'trac_status_changed',
94 "spent_seconds_avg" =>
"trac_spent_seconds",
"percentage_avg" =>
"trac_percentage",
95 "read_count_sum" =>
"trac_read_count",
"read_count_avg" =>
"trac_read_count",
96 "read_count_spent_seconds_avg" =>
"trac_read_count_spent_seconds" 100 $all = array(
"user_total");
104 include_once
'Services/Tracking/classes/class.ilObjUserTracking.php';
107 $all[] =
"read_count_sum";
108 $all[] =
"read_count_avg";
109 $default[] =
"read_count_sum";
113 $all[] =
"spent_seconds_avg";
114 $default[] =
"spent_seconds_avg";
120 $all[] =
"read_count_spent_seconds_avg";
127 $all[] =
"percentage_avg";
130 if ($this->is_root || !$this->olp || $this->olp->isActive()) {
132 $all[] =
'status_changed_max';
139 $privacy = array(
"gender",
"city",
"country",
"sel_country");
140 foreach ($privacy as $field) {
141 if (
$ilSetting->get(
"usr_settings_course_export_" . $field)) {
148 $default[] =
"percentage_avg";
149 $default[] =
"status";
153 $all[] =
"first_access_min";
154 $all[] =
"last_access_max";
157 $all[] =
"create_date_min";
158 $all[] =
"create_date_max";
161 foreach ($all as $column) {
165 if (substr($l, -3) ==
"avg") {
167 } elseif (substr($l, -3) ==
"sum" || $l ==
"user_total") {
171 if (isset($lng_map[$l])) {
177 if (in_array($column, array(
"read_count_avg",
"spent_seconds_avg",
"percentage_avg"))) {
183 "default" => (in_array($column, $default) ?
true :
false)
199 if ($this->is_root) {
200 return parent::initBaseFilter(
true,
false);
204 include_once
'Services/Tracking/classes/class.ilObjUserTracking.php';
211 "∑ " .
$lng->txt(
"users")
213 $this->
filter[
"user_total"] = $item->getValue();
220 "∑ " .
$lng->txt(
"trac_read_count")
222 $this->filter[
"read_count"] = $item->getValue();
231 "Ø " .
$lng->txt(
"trac_spent_seconds") .
" / " .
$lng->txt(
"user")
233 $this->filter[
"spent_seconds"][
"from"] = $item->getCombinationItem(
"from")->getValueInSeconds();
234 $this->filter[
"spent_seconds"][
"to"] = $item->getCombinationItem(
"to")->getValueInSeconds();
243 "Ø " .
$lng->txt(
"trac_percentage") .
" / " .
$lng->txt(
"user")
245 $this->filter[
"percentage"] = $item->getValue();
248 if ($this->is_root || !$this->olp || $this->olp->isActive()) {
249 include_once
"Services/Tracking/classes/class.ilLPStatus.php";
251 $item->setOptions(array(
"" =>
$lng->txt(
"trac_all"),
256 $this->filter[
"status"] = $item->getValue();
257 if ($this->filter[
"status"]) {
258 $this->filter[
"status"]--;
262 $this->filter[
"status_changed"] = $item->getDate();
270 $lng->txt(
"trac_mark")
272 $this->filter[
"mark"] = $item->getValue();
275 if (
$ilSetting->get(
"usr_settings_course_export_gender")) {
277 $item->setOptions(array(
278 "" =>
$lng->txt(
"trac_all"),
279 "n" =>
$lng->txt(
"gender_n"),
280 "m" =>
$lng->txt(
"gender_m"),
281 "f" =>
$lng->txt(
"gender_f"),
283 $this->filter[
"gender"] = $item->getValue();
286 if (
$ilSetting->get(
"usr_settings_course_export_city")) {
288 $this->filter[
"city"] = $item->getValue();
291 if (
$ilSetting->get(
"usr_settings_course_export_country")) {
293 $this->filter[
"country"] = $item->getValue();
296 if (
$ilSetting->get(
"usr_settings_course_export_sel_country")) {
299 $this->filter[
"sel_country"] = $item->getValue();
303 $this->filter[
"language"] = $item->getValue();
307 $this->filter[
"first_access"] = $item->getDate();
310 $this->filter[
"last_access"] = $item->getDate();
314 $this->filter[
"registration"] = $item->getDate();
323 include_once(
"./Services/Utilities/classes/class.ilCountry.php");
326 $options[
$c] =
$lng->txt(
"meta_c_" . $c);
343 $rbacsystem = $DIC[
'rbacsystem'];
345 include_once(
"./Services/Tracking/classes/class.ilTrQuery.php");
348 $preselected_obj_ids =
$filter = null;
356 $collection = $olp->getCollectionInstance();
357 $preselected_obj_ids[$a_object_id][] = $a_ref_id;
358 foreach ($collection->getItems() as $item => $item_info) {
360 if ($tmp_lp->isActive()) {
365 } elseif ($this->is_root) {
389 include_once(
"./Services/Tracking/classes/class.ilLearningProgressBaseGUI.php");
390 include_once(
"./Services/Tracking/classes/class.ilLPStatus.php");
395 $status_map = array();
397 foreach ($valid_status as $status) {
398 $status_map[$status] = $status_icons->renderIconForStatus($status);
402 $lng->loadLanguageModule(
"meta");
403 $languages = array();
404 foreach (
$lng->getInstalledLanguages() as $lang_key) {
405 $languages[$lang_key] =
$lng->txt(
"meta_l_" . $lang_key);
412 include_once
"Modules/Session/classes/class.ilObjSession.php";
414 $data[
"set"][$idx][
"title"] = $sess->getFirstAppointment()->appointmentToString();
422 foreach (
$result[
"ref_ids"] as $check_ref_id) {
423 include_once
'./Services/Tracking/classes/class.ilLearningProgressAccess.php';
430 foreach (array_keys(
$data[
"set"][$idx]) as $col_id) {
431 if (!in_array($col_id, array(
"type",
"title",
"obj_id",
"ref_id",
"offline"))) {
432 $data[
"set"][$idx][$col_id] = null;
435 $data[
"set"][$idx][
"privacy_conflict"] =
true;
441 $users_no =
$result[
"user_total"];
444 "n" =>
$lng->txt(
"gender_n"),
445 "m" =>
$lng->txt(
"gender_m"),
446 "f" =>
$lng->txt(
"gender_f"),
454 foreach (
$result[
"status"] as $status_code => $status_counter) {
456 if ($status_code ===
"" || !in_array($status_code, $valid_status)) {
458 unset(
$result[
"status"][$status_code]);
464 $data[
"set"][$idx][
"percentage_avg"] = null;
500 $counter = $others_counter = 0;
501 $others_sum = $overall;
503 foreach (
$data as $id => $count) {
509 if ($value_map && isset($value_map[$id])) {
510 $caption = $value_map[$id];
512 if ($caption ==
"") {
513 $caption =
$lng->txt(
"none");
522 $perc = round($count / $overall * 100);
524 "caption" => $caption,
525 "absolute" => $count,
526 "percentage" => $perc
528 $others_sum -= $count;
534 if ($others_counter) {
535 $perc = round($others_sum / $overall * 100);
537 "caption" => $others_counter .
" " .
$lng->txt(
"trac_others"),
538 "absolute" => $others_sum,
539 "percentage" => $perc
562 foreach ($value_map as $id => $caption) {
564 if (isset(
$data[$id])) {
567 $perc = round($count / $overall * 100);
570 "caption" => $caption,
571 "absolute" => $count,
572 "percentage" => $perc
586 $pos = strrpos($id,
"_");
587 if ($pos !==
false) {
588 $function = strtoupper(substr($id, $pos + 1));
589 if (in_array($function, array(
"MIN",
"MAX",
"SUM",
"AVG",
"COUNT"))) {
590 $id = substr($id, 0, $pos);
594 if (trim($value) ==
"") {
595 if ($id ==
"title") {
596 return "--" .
$lng->txt(
"none") .
"--";
601 case 'status_changed':
611 case "spent_seconds":
612 case "read_count_spent_seconds":
624 $value = $value .
"%";
646 $ilCtrl = $DIC[
'ilCtrl'];
648 $this->tpl->setVariable(
"ICON",
ilObject::_getIcon($a_set[
"obj_id"],
"tiny", $a_set[
"type"]));
649 $this->tpl->setVariable(
"ICON_ALT",
$lng->txt($a_set[
"type"]));
650 $this->tpl->setVariable(
"TITLE", $a_set[
"title"]);
652 if ($a_set[
"offline"] || $a_set[
"privacy_conflict"]) {
654 if ($a_set[
"offline"]) {
655 $mess[] =
$lng->txt(
"offline");
657 if ($a_set[
"privacy_conflict"]) {
658 $mess[] =
$lng->txt(
"status_no_permission");
660 $this->tpl->setCurrentBlock(
"status_bl");
661 $this->tpl->setVariable(
"TEXT_STATUS", implode(
", ", $mess));
662 $this->tpl->parseCurrentBlock();
677 case "percentage_avg":
679 $this->tpl->setVariable(strtoupper($c),
"");
685 $value = $this->
parseValue($c, $a_set[$c], $a_set[
"type"]);
686 $this->tpl->setVariable(strtoupper($c), $value);
691 if ($this->is_root) {
692 $path = $this->
buildPath($a_set[
"ref_ids"],
false,
true);
694 $this->tpl->setCurrentBlock(
"item_path");
695 foreach ($path as $ref_id => $path_item) {
696 $this->tpl->setVariable(
"PATH_ITEM", $path_item);
698 if (!$this->anonymized) {
699 $ilCtrl->setParameterByClass($ilCtrl->getCmdClass(),
'details_id', $ref_id);
700 $this->tpl->setVariable(
"URL_DETAILS", $ilCtrl->getLinkTargetByClass($ilCtrl->getCmdClass(),
'details'));
701 $ilCtrl->setParameterByClass($ilCtrl->getCmdClass(),
'details_id',
'');
702 $this->tpl->setVariable(
"TXT_DETAILS",
$lng->txt(
'trac_participants'));
704 $this->tpl->setVariable(
"URL_DETAILS",
ilLink::_getLink($ref_id, $a_set[
"type"]));
705 $this->tpl->setVariable(
"TXT_DETAILS",
$lng->txt(
'view'));
708 $this->tpl->parseCurrentBlock();
712 $this->tpl->setCurrentBlock(
"item_command");
713 $ilCtrl->setParameterByClass(get_class($this),
'hide', $a_set[
"obj_id"]);
714 $this->tpl->setVariable(
"HREF_COMMAND", $ilCtrl->getLinkTargetByClass(get_class($this),
'hide'));
715 $this->tpl->setVariable(
"TXT_COMMAND", $this->lng->txt(
'trac_hide'));
716 $this->tpl->parseCurrentBlock();
718 $this->tpl->touchBlock(
"path_action");
719 } elseif ($a_set[
"ref_ids"]) {
721 include_once
'./Services/Tree/classes/class.ilPathGUI.php';
723 $path = $path->getPath($this->ref_id, array_pop($a_set[
"ref_ids"]));
725 $this->tpl->setVariable(
'COLL_PATH', $this->lng->txt(
'path') .
': ' . $path);
733 foreach (
$data as $item) {
734 $this->tpl->setCurrentBlock($id .
"_row");
735 $this->tpl->setVariable(
"CAPTION", $item[
"caption"]);
736 $this->tpl->setVariable(
"ABSOLUTE", $item[
"absolute"]);
737 $this->tpl->setVariable(
"PERCENTAGE", $item[
"percentage"]);
738 $this->tpl->parseCurrentBlock();
741 $this->tpl->touchBlock($id);
748 if (in_array($a_name, array(
"country",
"gender",
"city",
"language",
"status",
"mark",
'sel_country'))) {
756 $pos = strrpos($a_field,
"_");
757 if ($pos !==
false) {
758 $function = strtoupper(substr($a_field, $pos + 1));
759 if (in_array($function, array(
"MIN",
"MAX",
"SUM",
"AVG",
"COUNT",
"TOTAL"))) {
773 $a_excel->
setCell($a_row, 0, $this->lng->txt(
"title"));
778 $label = $labels[
$c][
"txt"];
779 $label = str_replace(
"Ø", $this->lng->txt(
"trac_average"), $label);
780 $label = str_replace(
"∑", $this->lng->txt(
"trac_sum"), $label);
783 $a_excel->
setCell($a_row, $cnt, $label);
786 if ($c !=
"status") {
787 $a_excel->
setCell($a_row, $cnt, $label .
" #1");
788 $a_excel->
setCell($a_row, ++$cnt, $label .
" #1");
789 $a_excel->
setCell($a_row, ++$cnt, $label .
" #1 %");
790 $a_excel->
setCell($a_row, ++$cnt, $label .
" #2");
791 $a_excel->
setCell($a_row, ++$cnt, $label .
" #2");
792 $a_excel->
setCell($a_row, ++$cnt, $label .
" #2 %");
793 $a_excel->
setCell($a_row, ++$cnt, $label .
" #3");
794 $a_excel->
setCell($a_row, ++$cnt, $label .
" #3");
795 $a_excel->
setCell($a_row, ++$cnt, $label .
" #3 %");
796 $a_excel->
setCell($a_row, ++$cnt, $label .
" " . $this->lng->txt(
"trac_others"));
797 $a_excel->
setCell($a_row, ++$cnt, $label .
" " . $this->lng->txt(
"trac_others"));
798 $a_excel->
setCell($a_row, ++$cnt, $label .
" " . $this->lng->txt(
"trac_others") .
" %");
801 include_once(
"./Services/Tracking/classes/class.ilLearningProgressBaseGUI.php");
802 include_once(
"./Services/Tracking/classes/class.ilLPStatus.php");
808 foreach ($valid_status as $status) {
810 $a_excel->
setCell($a_row, ++$cnt, $text);
811 $a_excel->
setCell($a_row, ++$cnt, $text .
" %");
823 $a_excel->
setCell($a_row, 0, $a_set[
"title"]);
828 $val = $this->
parseValue($c, $a_set[$c], $a_set[
"type"]);
829 $a_excel->
setCell($a_row, $cnt, $val);
832 foreach ((array) $a_set[$c] as $idx => $value) {
833 if ($c ==
"status") {
834 $a_excel->
setCell($a_row, $cnt, (
int) $value[
"absolute"]);
835 $a_excel->
setCell($a_row, ++$cnt, $value[
"percentage"] .
"%");
837 $a_excel->
setCell($a_row, $cnt, $value[
"caption"]);
838 $a_excel->
setCell($a_row, ++$cnt, (
int) $value[
"absolute"]);
839 $a_excel->
setCell($a_row, ++$cnt, $value[
"percentage"] .
"%");
843 if (
sizeof($a_set[$c]) < 4 && $c !=
"status") {
844 for ($loop = 4; $loop >
sizeof($a_set[
$c]); $loop--) {
845 $a_excel->
setCell($a_row, $cnt,
"");
846 $a_excel->
setCell($a_row, ++$cnt,
"");
847 $a_excel->
setCell($a_row, ++$cnt,
"");
857 $a_csv->addColumn($this->lng->txt(
"title"));
861 $label = $labels[
$c][
"txt"];
862 $label = str_replace(
"Ø", $this->lng->txt(
"trac_average"), $label);
863 $label = str_replace(
"∑", $this->lng->txt(
"trac_sum"), $label);
866 $a_csv->addColumn($label);
868 if ($c !=
"status") {
869 $a_csv->addColumn($label .
" #1");
870 $a_csv->addColumn($label .
" #1");
871 $a_csv->addColumn($label .
" #1 %");
872 $a_csv->addColumn($label .
" #2");
873 $a_csv->addColumn($label .
" #2");
874 $a_csv->addColumn($label .
" #2 %");
875 $a_csv->addColumn($label .
" #3");
876 $a_csv->addColumn($label .
" #3");
877 $a_csv->addColumn($label .
" #3 %");
878 $a_csv->addColumn($label .
" " . $this->lng->txt(
"trac_others"));
879 $a_csv->addColumn($label .
" " . $this->lng->txt(
"trac_others"));
880 $a_csv->addColumn($label .
" " . $this->lng->txt(
"trac_others") .
" %");
883 include_once(
"./Services/Tracking/classes/class.ilLearningProgressBaseGUI.php");
884 include_once(
"./Services/Tracking/classes/class.ilLPStatus.php");
889 foreach ($valid_status as $status) {
891 $a_csv->addColumn($text);
892 $a_csv->addColumn($text .
" %");
903 $a_csv->addColumn($a_set[
"title"]);
907 $val = $this->
parseValue($c, $a_set[$c], $a_set[
"type"]);
908 $a_csv->addColumn($val);
910 foreach ((array) $a_set[$c] as $idx => $value) {
911 if ($c !=
"status") {
912 $a_csv->addColumn($value[
"caption"]);
914 $a_csv->addColumn((
int) $value[
"absolute"]);
915 $a_csv->addColumn($value[
"percentage"]);
917 if (
sizeof($a_set[$c]) < 4 && $c !=
"status") {
918 for ($loop = 4; $loop >
sizeof($a_set[
$c]); $loop--) {
919 $a_csv->addColumn(
"");
920 $a_csv->addColumn(
"");
921 $a_csv->addColumn(
"");
const LP_STATUS_COMPLETED_NUM
static _getIcon( $a_obj_id="", $a_size="big", $a_type="", $a_offline=false)
Get icon for repository item.
renderPercentages($id, $data)
Creates a path for a start and endnode.
const EXTENDED_DATA_LAST_ACCESS
buildPath($ref_ids)
Build path with deep-link.
setDefaultOrderField($a_defaultorderfield)
Set Default order field.
setExportFormats(array $formats)
Set available export formats.
const LP_MODE_MANUAL_BY_TUTOR
setPrintMode($a_value=false)
Toogle print mode.
fillRowCSV($a_csv, $a_set)
setShowTemplates($a_value)
Toggle templates.
const LP_STATUS_NOT_ATTEMPTED
static _getStatusText($a_status, $a_lng=null)
Get status alt text.
getItemsPercentages(array $data=null, $overall, array $value_map=null, $limit=3)
Render data as needed for summary list (based on grouped values)
searchObjects(array $filter, $permission, array $preset_obj_ids=null, $a_check_lp_activation=true)
Search objects that match current filters.
const LP_STATUS_IN_PROGRESS_NUM
const LP_MODE_COLLECTION_MANUAL
static getInstance(int $variant=ilLPStatusIcons::ICON_VARIANT_DEFAULT, ?\ILIAS\UI\Renderer $renderer=null, ?\ILIAS\UI\Factory $factory=null)
addFilterItemByMetaType($id, $type=self::FILTER_TEXT, $a_optional=false, $caption=null)
Add filter by standard type.
const EXTENDED_DATA_READ_COUNT
fillRowExcel(ilExcel $a_excel, &$a_row, $a_set)
parseTitle($a_obj_id, $action, $a_user_id=false)
getItems($a_object_id, $a_ref_id)
Build summary item rows for given object and filter(s.
getOrderDirection()
Get order direction.
static checkPermission($a_permission, $a_ref_id, $a_user_id=null)
wrapper for rbac access checks
static formatDate(ilDateTime $date, $a_skip_day=false, $a_include_wd=false, $include_seconds=false)
Format a date public.
const FILTER_NUMBER_RANGE
const LP_STATUS_IN_PROGRESS
fillHeaderExcel(ilExcel $a_excel, &$a_row)
const FILTER_DATETIME_RANGE
static secondsToString($seconds, $force_with_seconds=false, $a_lng=null)
converts seconds to string: Long: 7 days 4 hour(s) ...
getColumnCoord($a_col)
Get column "name" from number.
TableGUI class for learning progress.
setBold($a_coords)
Set cell(s) to bold.
static isObjectOffline($a_obj_id, $a_type=null)
const FILTER_DURATION_RANGE
static _lookupObjId($a_id)
parseValue($id, $value, $type)
isPercentageAvailable($a_obj_id)
getSelectedColumns()
Get selected columns.
setCell($a_row, $a_col, $a_value, $a_datatype=null)
Set cell value.
static stripSlashes($a_str, $a_strip_html=true, $a_allow="")
strip slashes if magic qoutes is enabled
static getObjectsSummaryForObject( $a_parent_obj_id, $a_parent_ref_id, $a_order_field="", $a_order_dir="", $a_offset=0, $a_limit=9999, array $a_filters=null, array $a_additional_fields=null, $a_preselected_obj_ids=null)
Get all aggregated tracking data for parent object.
__construct($a_parent_obj, $a_parent_cmd, $a_ref_id, $a_print_mode=false)
Constructor.
fillRow($a_set)
Fill table row.
setRowTemplate($a_template, $a_template_dir="")
Set row template.
static _lookupType($a_id, $a_reference=false)
lookup object type
const EXTENDED_DATA_SPENT_SECONDS
static supportsMark($a_obj_type)
const LP_STATUS_NOT_ATTEMPTED_NUM
setFormAction($a_form_action, $a_multipart=false)
Set Form action parameter.
static supportsSpentSeconds($a_obj_type)
__construct(Container $dic, ilPlugin $plugin)
addColumn( $a_text, $a_sort_field="", $a_width="", $a_is_checkbox_action_column=false, $a_class="", $a_tooltip="", $a_tooltip_with_html=false)
Add a column to the header.
setEnableHeader($a_enableheader)
Set Enable Header.
static getCountryCodes()
Get country codes (DIN EN 3166-1)
numericOrdering($a_field)
setMaxCount($a_max_count)
set max.
getCurrentFilter($as_query=false)
const LP_STATUS_COMPLETED
static getInstance($a_obj_id)
getItemsPercentagesStatus(array $data=null, $overall, array $value_map=null)
Render status data as needed for summary list (based on grouped values)
static _getLink($a_ref_id, $a_type='', $a_params=array(), $append="")
setLimit($a_limit=0, $a_default_limit=0)
const LP_STATUS_FAILED_NUM