123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213 |
- <?php
- /* For licensing terms, see /license.txt */
- /**
- * Management of legal conditions.
- *
- * @package chamilo.admin
- */
- $cidReset = true;
- require_once __DIR__.'/../inc/global.inc.php';
- $this_section = SECTION_PLATFORM_ADMIN;
- api_protect_admin_script();
- if (api_get_setting('allow_terms_conditions') !== 'true') {
- api_not_allowed(true);
- }
- // Create the form
- $form = new FormValidator('addlegal');
- $defaults = [];
- $term_preview = [
- 'type' => 0,
- 'content' => '',
- 'changes' => '',
- ];
- $extraField = new ExtraField('terms_and_condition');
- $types = LegalManager::getTreatmentTypeList();
- foreach ($types as $variable => $name) {
- $label = 'PersonalData'.ucfirst($name).'Title';
- $params = [
- 'variable' => $variable,
- 'display_text' => $label,
- 'field_type' => ExtraField::FIELD_TYPE_TEXTAREA,
- 'default_value' => '',
- 'visible' => true,
- 'changeable' => true,
- 'filter' => true,
- 'visible_to_self' => true,
- 'visible_to_others' => true,
- ];
- $extraField->save($params);
- }
- if ($form->validate()) {
- $check = Security::check_token('post');
- if ($check) {
- $values = $form->getSubmitValues();
- $lang = $values['language'];
- // language id
- $lang = api_get_language_id($lang);
- $type = 0;
- if (isset($values['type'])) {
- $type = $values['type'];
- }
- $content = '';
- if (isset($values['content'])) {
- $content = $values['content'];
- }
- $changes = '';
- if (isset($values['changes'])) {
- $changes = $values['changes'];
- }
- $submit = $values['send'];
- $default['content'] = $content;
- if (isset($values['language'])) {
- if ($submit == 'back') {
- header('Location: legal_add.php');
- exit;
- } elseif ($submit === 'save') {
- $id = LegalManager::add($lang, $content, $type, $changes, $values);
- if (!empty($id)) {
- Display::addFlash(Display::return_message(get_lang('TermAndConditionSaved'), 'success'));
- } else {
- Display::addFlash(Display::return_message(get_lang('TermAndConditionNotSaved'), 'warning'));
- }
- Security::clear_token();
- $tok = Security::get_token();
- header('Location: legal_list.php?sec_token='.$tok);
- exit();
- } elseif ($submit === 'preview') {
- $defaults['type'] = $type;
- $defaults['content'] = $content;
- $defaults['changes'] = $changes;
- $term_preview = $defaults;
- $term_preview['type'] = (int) $_POST['type'];
- } else {
- $my_lang = $_POST['language'];
- if (isset($_POST['language'])) {
- $all_langs = api_get_languages();
- if (in_array($my_lang, $all_langs['folder'])) {
- $language = api_get_language_id($my_lang);
- $term_preview = LegalManager::get_last_condition($language);
- $defaults = $term_preview;
- if (!$term_preview) {
- // there are not terms and conditions
- $term_preview['type'] = -1;
- $defaults['type'] = 0;
- }
- }
- }
- }
- }
- }
- }
- $form->setDefaults($defaults);
- if (isset($_POST['send'])) {
- Security::clear_token();
- }
- $token = Security::get_token();
- $form->addElement('hidden', 'sec_token');
- $defaults['sec_token'] = $token;
- $form->addElement('header', get_lang('DisplayTermsConditions'));
- $jqueryReady = '';
- if (isset($_POST['language'])) {
- $form->addElement('static', Security::remove_XSS($_POST['language']));
- $form->addElement('hidden', 'language', Security::remove_XSS($_POST['language']));
- $form->addHtmlEditor(
- 'content',
- get_lang('Content'),
- true,
- false,
- ['ToolbarSet' => 'terms_and_conditions', 'Width' => '100%', 'Height' => '250']
- );
- $form->addElement('radio', 'type', '', get_lang('HTMLText'), '0');
- $form->addElement('radio', 'type', '', get_lang('PageLink'), '1');
- $preview = LegalManager::show_last_condition($term_preview);
- if ($term_preview['type'] != -1) {
- $preview = LegalManager::replaceTags($preview);
- $form->addElement('label', get_lang('Preview'), $preview);
- }
- $termId = isset($term_preview['id']) ? $term_preview['id'] : 0;
- $returnParams = $extraField->addElements(
- $form,
- $termId,
- [],
- false,
- false,
- [],
- [],
- [],
- false,
- true,
- [],
- [],
- false,
- [],
- [],
- false,
- true
- );
- $jqueryReady = $returnParams['jquery_ready_content'];
- $form->addElement('textarea', 'changes', get_lang('ExplainChanges'), ['width' => '20']);
- // Submit & preview button
- $buttons = '<div class="row" align="center">
- <div class="formw">
- <button type="submit" class="btn btn-default back" name="send" value="back">'.get_lang('Back').'</button>
- <button type="submit" class="btn btn-default search" name="send" value="preview">'.get_lang('Preview').'</button>
- <button type="submit" class="btn btn-primary save" name="send" value="save">'.get_lang('Save').'</button>
- </div>
- </div>';
- $form->addElement('html', $buttons);
- } else {
- $form->addSelectLanguage('language', get_lang('Language'), null, []);
- $form->addButtonSearch(get_lang('Load'), 'send');
- }
- $tool_name = get_lang('AddTermsAndConditions');
- $interbreadcrumb[] = ['url' => 'index.php', 'name' => get_lang('PlatformAdmin')];
- // the $jquery_ready_content variable collects all functions that will be load in the $(document).ready javascript function
- $htmlHeadXtra[] = '<script>
- $(document).ready(function(){
- '.$jqueryReady.'
- });
- </script>';
- Display::display_header($tool_name);
- echo '<script>
- function sendlang() {
- document.addlegal.sec_token.value=\''.$token.'\';
- document.addlegal.submit();
- }
- </script>';
- // action menu
- echo '<div class="actions">';
- echo '<a href="'.api_get_path(WEB_CODE_PATH).'admin/legal_list.php">'.
- Display::return_icon('search.gif', get_lang('EditTermsAndConditions'), '').
- get_lang('AllVersions').'</a>';
- echo '</div>';
- $form->setDefaults($defaults);
- $form->display();
- Display::display_footer();
|