Add student_follow_page_add_LP_acquisition_info conf setting - refs BT#18671
Add column "Acquisition" in student LPs table to display info about a lo adquisition. Requires DB changes:
INSERT INTO extra_field (extra_field_type, field_type, variable, display_text, default_value, field_order, visible_to_self, visible_to_others, changeable, filter, created_at) VALUES
(0, 3, 'acquisition', 'Acquisition', '', 0, 1, 0, 0, 0, NOW());
SET @ef_id = LAST_INSERT_ID();
INSERT INTO extra_field_options (field_id, option_value, display_text, priority, priority_message, option_order) VALUES
(@ef_id, '1', 'Acquired', NULL, NULL, 1),
(@ef_id, '2', 'In the process of acquisition', NULL, NULL, 2),
(@ef_id, '3', 'Not acquired', NULL, NULL, 3);
4 years ago
|
|
|
<?php
|
|
|
|
|
|
|
|
/* For licensing terms, see /license.txt */
|
|
|
|
|
|
|
|
use Chamilo\CourseBundle\Entity\CItemProperty;
|
|
|
|
|
Add student_follow_page_add_LP_acquisition_info conf setting - refs BT#18671
Add column "Acquisition" in student LPs table to display info about a lo adquisition. Requires DB changes:
INSERT INTO extra_field (extra_field_type, field_type, variable, display_text, default_value, field_order, visible_to_self, visible_to_others, changeable, filter, created_at) VALUES
(0, 3, 'acquisition', 'Acquisition', '', 0, 1, 0, 0, 0, NOW());
SET @ef_id = LAST_INSERT_ID();
INSERT INTO extra_field_options (field_id, option_value, display_text, priority, priority_message, option_order) VALUES
(@ef_id, '1', 'Acquired', NULL, NULL, 1),
(@ef_id, '2', 'In the process of acquisition', NULL, NULL, 2),
(@ef_id, '3', 'Not acquired', NULL, NULL, 3);
4 years ago
|
|
|
/**
|
|
|
|
* Class StudentFollowPage.
|
|
|
|
*/
|
|
|
|
class StudentFollowPage
|
|
|
|
{
|
|
|
|
const VARIABLE_ACQUISITION = 'acquisition';
|
|
|
|
|
|
|
|
public static function getLpSubscription(
|
|
|
|
array $lpInfo,
|
|
|
|
int $studentId,
|
|
|
|
int $courseId,
|
|
|
|
int $sessionId = 0
|
|
|
|
): string {
|
|
|
|
$em = Database::getManager();
|
|
|
|
|
|
|
|
if ($lpInfo['subscribe_users']) {
|
|
|
|
$itemRepo = $em->getRepository(CItemProperty::class);
|
|
|
|
$itemProperty = $itemRepo->findByUserSuscribedToItem(
|
|
|
|
'learnpath',
|
|
|
|
$lpInfo['iid'],
|
|
|
|
api_get_user_entity($studentId),
|
|
|
|
api_get_course_entity($courseId),
|
|
|
|
api_get_session_entity($sessionId)
|
|
|
|
);
|
|
|
|
|
|
|
|
if (null === $itemProperty) {
|
|
|
|
return '-';
|
|
|
|
}
|
|
|
|
|
|
|
|
return "{$itemProperty->getInsertUser()->getCompleteName()}<br>"
|
|
|
|
.Display::tag(
|
|
|
|
'small',
|
|
|
|
api_convert_and_format_date($itemProperty->getInsertDate(), DATE_TIME_FORMAT_LONG)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$subscriptionEvent = Event::findUserSubscriptionToCourse($studentId, $courseId, $sessionId);
|
|
|
|
|
|
|
|
if (empty($subscriptionEvent)) {
|
|
|
|
return '-';
|
|
|
|
}
|
|
|
|
|
|
|
|
$creator = api_get_user_entity($subscriptionEvent['default_user_id']);
|
|
|
|
|
|
|
|
return "{$creator->getCompleteName()}<br>"
|
|
|
|
.Display::tag(
|
|
|
|
'small',
|
|
|
|
api_convert_and_format_date($subscriptionEvent['default_date'], DATE_TIME_FORMAT_LONG)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
Add student_follow_page_add_LP_acquisition_info conf setting - refs BT#18671
Add column "Acquisition" in student LPs table to display info about a lo adquisition. Requires DB changes:
INSERT INTO extra_field (extra_field_type, field_type, variable, display_text, default_value, field_order, visible_to_self, visible_to_others, changeable, filter, created_at) VALUES
(0, 3, 'acquisition', 'Acquisition', '', 0, 1, 0, 0, 0, NOW());
SET @ef_id = LAST_INSERT_ID();
INSERT INTO extra_field_options (field_id, option_value, display_text, priority, priority_message, option_order) VALUES
(@ef_id, '1', 'Acquired', NULL, NULL, 1),
(@ef_id, '2', 'In the process of acquisition', NULL, NULL, 2),
(@ef_id, '3', 'Not acquired', NULL, NULL, 3);
4 years ago
|
|
|
public static function getLpAcquisition(
|
|
|
|
array $lpInfo,
|
|
|
|
int $studentId,
|
|
|
|
int $courseId,
|
|
|
|
int $sessionId = 0
|
|
|
|
): string {
|
|
|
|
$tblLpView = Database::get_course_table(TABLE_LP_VIEW);
|
|
|
|
|
|
|
|
$sessionCondition = api_get_session_condition($sessionId);
|
|
|
|
|
|
|
|
$sql = "SELECT iid FROM $tblLpView
|
|
|
|
WHERE c_id = $courseId AND lp_id = {$lpInfo['iid']} AND user_id = $studentId $sessionCondition
|
|
|
|
ORDER BY view_count DESC";
|
|
|
|
$lpView = Database::fetch_assoc(Database::query($sql));
|
|
|
|
|
|
|
|
if (empty($lpView)) {
|
|
|
|
return '-';
|
|
|
|
}
|
|
|
|
|
|
|
|
$extraField = new ExtraField('lp_view');
|
|
|
|
$field = $extraField->get_handler_field_info_by_field_variable(self::VARIABLE_ACQUISITION);
|
|
|
|
|
|
|
|
$extraFieldValue = new ExtraFieldValue('lp_view');
|
|
|
|
$value = $extraFieldValue->get_values_by_handler_and_field_variable($lpView['iid'], self::VARIABLE_ACQUISITION);
|
|
|
|
|
|
|
|
$return = '';
|
|
|
|
|
|
|
|
if (empty($value)) {
|
|
|
|
$return .= '-';
|
|
|
|
} else {
|
|
|
|
$optionSelected = array_filter(
|
|
|
|
$field['options'],
|
|
|
|
function (array $option) use ($value) {
|
|
|
|
return $option['option_value'] == $value['value'];
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
if (empty($optionSelected)) {
|
|
|
|
$return .= '-';
|
|
|
|
} else {
|
|
|
|
$optionSelected = current($optionSelected);
|
|
|
|
$valueComment = json_decode($value['comment'], true);
|
|
|
|
|
|
|
|
$register = api_get_user_entity($valueComment['user']);
|
|
|
|
|
|
|
|
$return .= $optionSelected['display_text'].'<br>'
|
|
|
|
.Display::tag('small', $register->getCompleteName()).'<br>'
|
|
|
|
.Display::tag(
|
|
|
|
'small',
|
|
|
|
api_convert_and_format_date($valueComment['datetime'], DATE_TIME_FORMAT_LONG)
|
|
|
|
).'<br>';
|
Add student_follow_page_add_LP_acquisition_info conf setting - refs BT#18671
Add column "Acquisition" in student LPs table to display info about a lo adquisition. Requires DB changes:
INSERT INTO extra_field (extra_field_type, field_type, variable, display_text, default_value, field_order, visible_to_self, visible_to_others, changeable, filter, created_at) VALUES
(0, 3, 'acquisition', 'Acquisition', '', 0, 1, 0, 0, 0, NOW());
SET @ef_id = LAST_INSERT_ID();
INSERT INTO extra_field_options (field_id, option_value, display_text, priority, priority_message, option_order) VALUES
(@ef_id, '1', 'Acquired', NULL, NULL, 1),
(@ef_id, '2', 'In the process of acquisition', NULL, NULL, 2),
(@ef_id, '3', 'Not acquired', NULL, NULL, 3);
4 years ago
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$editUrl = api_get_path(WEB_AJAX_PATH).'student_follow_page.ajax.php?'
|
|
|
|
.http_build_query(['lp_view' => $lpView['iid'], 'a' => 'form_adquisition']);
|
|
|
|
|
|
|
|
$return .= Display::url(
|
|
|
|
Display::return_icon('edit.png', get_lang('Edit'), [], ICON_SIZE_TINY),
|
|
|
|
$editUrl,
|
|
|
|
['class' => 'ajax', 'data-title' => $lpInfo['lp_name']]
|
Add student_follow_page_add_LP_acquisition_info conf setting - refs BT#18671
Add column "Acquisition" in student LPs table to display info about a lo adquisition. Requires DB changes:
INSERT INTO extra_field (extra_field_type, field_type, variable, display_text, default_value, field_order, visible_to_self, visible_to_others, changeable, filter, created_at) VALUES
(0, 3, 'acquisition', 'Acquisition', '', 0, 1, 0, 0, 0, NOW());
SET @ef_id = LAST_INSERT_ID();
INSERT INTO extra_field_options (field_id, option_value, display_text, priority, priority_message, option_order) VALUES
(@ef_id, '1', 'Acquired', NULL, NULL, 1),
(@ef_id, '2', 'In the process of acquisition', NULL, NULL, 2),
(@ef_id, '3', 'Not acquired', NULL, NULL, 3);
4 years ago
|
|
|
);
|
|
|
|
|
|
|
|
return '<div id="acquisition-'.$lpView['iid'].'">'.$return.'</div>';
|
|
|
|
}
|
|
|
|
}
|