get_lang('CertificateSetting');
$enable = $plugin->get('enable_plugin_customcertificate') == 'true';
$accessUrlId = api_get_current_access_url_id();
$course_info = api_get_course_info();
if ($isDefault === 1) {
$courseId = 0;
$courseCode = '';
$sessionId = 0;
$enableCourse = false;
$useDefault = true;
$defaultCertificate = 1;
$nameTools = $plugin->get_lang('CertificateSettingDefault');
$urlParams = '?default=1';
} else {
$courseId = api_get_course_int_id();
$courseCode = api_get_course_id();
$sessionId = api_get_session_id();
$enableCourse = api_get_course_setting('customcertificate_course_enable', $course_info) == 1 ? true : false;
$useDefault = api_get_course_setting('use_certificate_default', $course_info) == 1 ? true : false;
$defaultCertificate = 0;
$urlParams = '?'.api_get_cidreq();
}
if (!$enable) {
api_not_allowed(true, $plugin->get_lang('ToolDisabled'));
}
if (!$enableCourse && !$useDefault) {
api_not_allowed(true, $plugin->get_lang('ToolDisabledCourse'));
}
if ($enableCourse && $useDefault) {
api_not_allowed(true, $plugin->get_lang('ToolUseDefaultSettingCourse'));
}
$allow = api_is_platform_admin() || api_is_teacher();
if (!$allow) {
api_not_allowed(true);
}
$table = Database::get_main_table(CustomCertificatePlugin::TABLE_CUSTOMCERTIFICATE);
$htmlHeadXtra[] = api_get_js_simple(
api_get_path(WEB_PLUGIN_PATH).'customcertificate/resources/js/certificate.js'
);
$htmlHeadXtra[] = api_get_css_asset('cropper/dist/cropper.min.css');
$htmlHeadXtra[] = api_get_asset('cropper/dist/cropper.min.js');
$htmlHeadXtra[] = api_get_css(
api_get_path(WEB_PLUGIN_PATH).'customcertificate/resources/css/form.css'
);
$htmlHeadXtra[] = '';
// Get info certificate
$infoCertificate = CustomCertificatePlugin::getInfoCertificate($courseId, $sessionId, $accessUrlId);
$form = new FormValidator(
'formEdit',
'post',
api_get_self().$urlParams,
null,
['class' => 'form-vertical']
);
if ($form->validate()) {
$formValues = $form->getSubmitValues();
if (empty($formValues['contents'])) {
$contents = '';
} else {
$contents = $formValues['contents'];
}
$check = Security::check_token('post');
if ($check) {
$date_start = str_replace('/', '-', $formValues['date_start']);
$date_end = str_replace('/', '-', $formValues['date_end']);
$params = [
'access_url_id' => api_get_current_access_url_id(),
'c_id' => $formValues['c_id'],
'session_id' => $formValues['session_id'],
'content_course' => $formValues['content_course'],
'contents_type' => (int) $formValues['contents_type'],
'contents' => $contents,
'date_change' => intval($formValues['date_change']),
'date_start' => date("Y-m-d", strtotime($date_start)),
'date_end' => date("Y-m-d", strtotime($date_end)),
'place' => $formValues['place'],
'type_date_expediction' => (int) $formValues['type_date_expediction'],
'day' => $formValues['day'],
'month' => $formValues['month'],
'year' => $formValues['year'],
'signature_text1' => $formValues['signature_text1'],
'signature_text2' => $formValues['signature_text2'],
'signature_text3' => $formValues['signature_text3'],
'signature_text4' => $formValues['signature_text4'],
'margin_left' => (int) $formValues['margin_left'],
'margin_right' => (int) $formValues['margin_right'],
'certificate_default' => 0,
];
if (intval($formValues['default_certificate'] == 1)) {
$params['certificate_default'] = 1;
}
// Insert or Update
if ($infoCertificate['id'] > 0) {
$certificateId = $infoCertificate['id'];
Database::update($table, $params, ['id = ?' => $certificateId]);
} else {
$certificateId = Database::insert($table, $params);
}
// Image manager
$fieldList = [
'logo_left',
'logo_center',
'logo_right',
'seal',
'signature1',
'signature2',
'signature3',
'signature4',
'background',
];
foreach ($fieldList as $field) {
$checkLogo[$field] = false;
if (!empty($formValues['remove_'.$field]) || $_FILES[$field]['size']) {
checkInstanceImage(
$certificateId,
$infoCertificate[$field],
$field
);
}
if ($_FILES[$field]['size']) {
$newPicture = api_upload_file(
'certificates',
$_FILES[$field],
$certificateId,
$formValues[$field.'_crop_result']
);
if ($newPicture) {
$sql = "UPDATE $table
SET $field = '".$newPicture['path_to_save']."'
WHERE id = $certificateId";
Database::query($sql);
$checkLogo[$field] = true;
}
}
}
// Certificate Default
if (intval($formValues['use_default'] == 1)) {
$infoCertificateDefault = CustomCertificatePlugin::getInfoCertificateDefault($accessUrlId);
if (!empty($infoCertificateDefault)) {
foreach ($fieldList as $field) {
if (!empty($infoCertificateDefault[$field]) && !$checkLogo[$field]) {
$sql = "UPDATE $table
SET $field = '".$infoCertificateDefault[$field]."'
WHERE id = $certificateId";
Database::query($sql);
}
}
}
}
Display::addFlash(Display::return_message(get_lang('Saved')));
Security::clear_token();
header('Location: '.api_get_self().$urlParams);
exit;
}
}
if (empty($infoCertificate)) {
$infoCertificate = CustomCertificatePlugin::getInfoCertificateDefault($accessUrlId);
if (empty($infoCertificate)) {
$infoCertificate = [
'type_date_expediction' => '',
'year' => '',
'month' => '',
'day' => '',
'date_change' => '',
];
}
$useDefault = true;
}
// Display the header
Display::display_header($nameTools);
$actionsLeft = Display::url(
Display::return_icon('certificate.png', get_lang('Certificate'), '', ICON_SIZE_MEDIUM),
'print_certificate.php'.$urlParams
);
if (!empty($courseId) && !$useDefault) {
$actionsLeft .= Display::url(
Display::return_icon('delete.png', $plugin->get_lang('DeleteCertificate'), '', ICON_SIZE_MEDIUM),
'delete_certificate.php'.$urlParams,
['id' => 'delete_certificate']
);
}
echo Display::toolbarAction(
'toolbar-document',
[$actionsLeft]
);
if ($useDefault && $courseId > 0) {
echo Display::return_message(get_lang('InfoFromDefaultCertificate'), 'info');
}
// Student and course section
$form->addHtml('
');
$form->addHtml('');
// Contents section
$form->addHtml('