Merge branch '1.10.x' of https://github.com/chamilo/chamilo-lms into tempTademi

1.10.x
José Loguercio 9 years ago
commit 7df8f87875
  1. 16
      app/Migrations/Schema/V110/Version20150603181728.php
  2. 86
      documentation/changelog.html
  3. 28
      main/admin/user_edit.php
  4. 4
      main/auth/external_login/facebook.inc.php
  5. 2
      main/auth/external_login/facebook.init.php
  6. 44
      main/course_info/infocours.php
  7. 25
      main/course_info/tools.php
  8. 13
      main/document/create_document.php
  9. 4
      main/document/edit_document.php
  10. 7
      main/exercice/exercise.class.php
  11. 14
      main/gradebook/lib/GradebookUtils.php
  12. 3
      main/gradebook/lib/be/category.class.php
  13. 13
      main/gradebook/lib/be/exerciselink.class.php
  14. 12
      main/inc/ajax/course_home.ajax.php
  15. 9
      main/inc/lib/api.lib.php
  16. 12
      main/inc/lib/login.lib.php
  17. 4
      main/inc/lib/pear/Pager/Sliding.php
  18. 4
      main/inc/lib/sessionmanager.lib.php
  19. 6
      main/inc/lib/tracking.lib.php
  20. 40
      main/inc/lib/usergroup.lib.php
  21. 4
      main/inc/lib/usermanager.lib.php
  22. 135
      main/inc/local.inc.php
  23. 4608
      main/install/database.sql
  24. 5
      main/install/index.php
  25. 6
      main/lang/brazilian/trad4all.inc.php
  26. 52
      main/lang/dutch/trad4all.inc.php
  27. 11
      main/lang/english/trad4all.inc.php
  28. 11
      main/lang/french/trad4all.inc.php
  29. 2
      main/lang/german/trad4all.inc.php
  30. 19
      main/lang/spanish/trad4all.inc.php
  31. 319
      main/mySpace/myStudents.php
  32. 3
      main/mySpace/user_edit.php
  33. 584
      main/newscorm/learnpath.class.php
  34. 42
      main/newscorm/lp_add_item.php
  35. 42
      main/newscorm/lp_edit_item.php
  36. 37
      main/newscorm/lp_move_item.php
  37. 3
      main/newscorm/resourcelinker.inc.php
  38. 56
      main/survey/survey.lib.php
  39. 2
      main/template/default/mail/reset_password.tpl
  40. 24
      main/tracking/courseLog.php
  41. 2
      main/webservices/lp.php
  42. 9
      main/webservices/registration.soap.php
  43. 1
      main/work/downloadfolder.inc.php
  44. 2
      plugin/ticket/config.install.php
  45. 1
      plugin/ticket/config.php
  46. 11
      plugin/ticket/database.php
  47. 2
      plugin/ticket/install.php
  48. 2
      plugin/ticket/plugin.php
  49. 4
      plugin/ticket/src/assign_tickets.php
  50. 3
      plugin/ticket/src/course_user_list.php
  51. 3
      plugin/ticket/src/myticket.php
  52. 8
      plugin/ticket/src/report.php
  53. 29
      plugin/ticket/src/ticket.class.php
  54. 14
      plugin/ticket/src/ticket_assign_log.php
  55. 2
      plugin/ticket/src/ticket_plugin.class.php
  56. 7
      plugin/ticket/src/tutor_report.lib.php
  57. 2
      plugin/ticket/start.php
  58. 2
      plugin/ticket/uninstall.php
  59. 10
      tests/main/survey/survey.lib.test.php

@ -28,7 +28,16 @@ class Version20150603181728 extends AbstractMigrationChamilo
*/
public function up(Schema $schema)
{
$this->addSql('ALTER TABLE c_lp ADD max_attempts INT NOT NULL, ADD subscribe_users INT NOT NULL DEFAULT 0');
$table = $schema->getTable('c_lp');
if (!$table->hasColumn('max_attempts')) {
$this->addSql('ALTER TABLE c_lp ADD max_attempts INT NOT NULL');
}
if (!$table->hasColumn('subscribe_users')) {
$this->addSql('ALTER TABLE c_lp ADD subscribe_users INT NOT NULL DEFAULT 0');
}
$this->addSql('
ALTER TABLE c_item_property
MODIFY c_id INT DEFAULT NULL,
@ -64,7 +73,10 @@ class Version20150603181728 extends AbstractMigrationChamilo
$this->addSql("DELETE FROM c_item_property WHERE c_id = 0");
// Remove inconsistencies about non-existing users
$this->addSql("DELETE FROM course_rel_user WHERE user_id = 0");
$this->addSql('ALTER TABLE c_item_property ADD CONSTRAINT FK_1D84C18191D79BD3 FOREIGN KEY (c_id) REFERENCES course (id)');
$this->addSql("DELETE FROM c_item_property WHERE c_id NOT IN (SELECT id FROM course)");
$this->addSql('ALTER TABLE c_item_property ADD CONSTRAINT FK_1D84C18191D79BD3 FOREIGN KEY (c_id) REFERENCES course(id)');
$this->addSql('ALTER TABLE c_item_property ADD CONSTRAINT FK_1D84C181330D47E9 FOREIGN KEY (to_group_id) REFERENCES c_group_info (iid)');
$this->addSql('ALTER TABLE c_item_property ADD CONSTRAINT FK_1D84C18129F6EE60 FOREIGN KEY (to_user_id) REFERENCES user (id)');
$this->addSql('ALTER TABLE c_item_property ADD CONSTRAINT FK_1D84C1819C859CC3 FOREIGN KEY (insert_user_id) REFERENCES user (id)');

@ -46,6 +46,92 @@
<p><i>Note: most #wxyz references are issue numbers you can find in <a href="http://support.chamilo.org/projects/chamilo-18/issues" target="_blank">our public bug tracking system</a>. Some references marked BT#xyz are developments made externally for BeezNest customers and integrated into Chamilo. The details of these tasks cannot be seen for confidentiality reasons, but the code change is public and can be reviewed by anyone.</i></p>
<p>&nbsp;</p>
<a name="1.10.6"></a>
<h1>Chamilo 1.10.6 - ???, ?? of April 2016</h1>
<h3>Release notes - summary</h3>
<p>Chamilo 1.10.6 is a minor, bugfix release of the 1.10.x branch, with a few new features and bugfixes on top of 1.10.4.</p>
<h3>Release name</h3>
<p><a href="http://www.openstreetmap.org/node/1947201#map=14/51.3786/-2.3580">NNNh</a> .....</p>
<h3>Security fixes</h3>
<ul>
<li>None that we know of.</li>
</ul>
<h3>Possibly breaking changes</h3>
<ul>
<li>None that we know of.</li>
</ul>
<h3>Notable new Features</h3>
<h4>For end-users, teachers and Chamilo admins</h4>
<ul>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/10729dea98234918de3e7e8c8718503ba5e2efbd">10729dea</a> - <a href="https://task.beeznest.com/issues/10952">BT#10952</a>) Add multiple attachment in agenda</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/940fbdd51c97e6feecebbd156130ba8818d98ad8">940fbdd5</a> - <a href="https://task.beeznest.com/issues/10052">BT#10052</a>) Adding setting "exercise_enable_category_order"</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/6b51fae1a37d3c7b3f7c656e3631cb2eb50d028e">6b51fae1</a> - <a href="https://task.beeznest.com/issues/10052">BT#10052</a>) Add function needed for BT#10052</li>
</ul>
<h4>For developers and sysadmins</h4>
<ul>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/7b82a178a2059ca4784d66419ad8887d0745a5a0">7b82a178</a> - <a href="https://task.beeznest.com/issues/11005">BT#11005</a>) Save track_e_course_access before removing the session information</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/12c7e7eccbf933ccf29306dcb720972792a9f8f2">12c7e7ec</a> - <a href="https://support.chamilo.org/issues/8175">#8175</a>) Use custom CKEditor</li>
</ul>
<h3>Improvements (minor features) and debug</h3>
<ul>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/37d5af337e3ea895f6b5b7dec55e9dc4dbecfe2e">37d5af33</a>) Fix forms when adding/editing lp items</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/36635d142199d3c8e6a5adbfd1b531dbbe85d318">36635d14</a>) Fix URL for create forum in lp</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/1f0c917fc949132afbc50f070dd2bb3ef25f18a6">1f0c917f</a>) Fix report titles.</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/90da1acf4666c7ec7e295d1d739cc0eb207cb68b">90da1acf</a>) Use api_get_course_info</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/ece4c9d8f227f8fcf39bc4a2c995af8eb35c9d3b">ece4c9d8</a>) If in a session show all LPs not only LP added in session.</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/5bcac3efc308d4c2dc4a6708f59b16bbc02c4206">5bcac3ef</a>) Fix constructor</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/33dafb19fa049fa9b70263d4daf9fc0b8ab6292a">33dafb19</a> - <a href="https://task.beeznest.com/issues/11062">BT#11062</a>) Change scrollbar to scrollbar-light</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/405b2c7bdf7918ef5a7c12f56a7b305eb74f3dd1">405b2c7b</a>) Add SMTP debug information</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/10f30d19c69e5880cdca9d7adc19c1ccadb766ec">10f30d19</a>) Fix link</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/5e5859107b0d6d247626bce7f6d1e308dc009bfc">5e585910</a>) Fix social group doesnt show in group list when adding an image (1.10.x)</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/f34bae386d81c613c11411c921d81e7d9656cfd0">f34bae38</a> - <a href="https://support.chamilo.org/issues/8188">#8188</a>) Fix menu tabs (broken in 1.10.4)</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/88b3acf7002421f9e7c60b1619d507bfd15c9d9d">88b3acf7</a> - <a href="https://support.chamilo.org/issues/8185">#8185</a>) Update bower assets</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/cede17daf3925bfe56b108476dfb33140023d164">cede17da</a>) Use 1 setting instead of 2</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/7f42c3251a15e3b91bc114fdd3db5ec8cb6dc04f">7f42c325</a>) Use __construct</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/997288805472841bbfc3bf3caedf996f1db0acba">99728880</a> - <a href="https://support.chamilo.org/issues/8157">#8157</a>) Replace mysql with pdo_mysql extension</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/c002d1e8f752b14e111e43ee65926eba37e558f7">c002d1e8</a>) Fix fatal error.</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/64f6ccf359425a726f4be99df86c371ad59e9c16">64f6ccf3</a> - <a href="https://task.beeznest.com/issues/11021">BT#11021</a>) Remove button for download video file in lp</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/380db06ab13e4524247999e92cb4065aeaf12ef1">380db06a</a> - <a href="https://task.beeznest.com/issues/11021">BT#11021</a>) Fix template for jplayer viewer</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/ecf16fb37b0e14bd54ec624bf6055925f8d26366">ecf16fb3</a> - <a href="https://task.beeznest.com/issues/11021">BT#11021</a>) Show lp video items in iframe</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/615a1224e97b16a510a65b1f9fe389f74aec011c">615a1224</a> - <a href="https://task.beeznest.com/issues/10936">BT#10936</a>) Set user id from function</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/a231628dc85d72a6728c6b2a3360d8c94011817e">a231628d</a> - <a href="https://task.beeznest.com/issues/10936">BT#10936</a>) Fix fatal error</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/db12470781fa479ed7c25d0a61af62eda07cb2af">db124707</a> - <a href="https://task.beeznest.com/issues/10936">BT#10936</a>) Fix fatal error</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/8f864966c9bc725047b09270e21db891399fb1ab">8f864966</a> - <a href="https://support.chamilo.org/issues/8173">#8173</a>) Fix Renaming a document in upload document's form</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/8f652341004346d57558183aa9f9134a97a58339">8f652341</a>) Fix select bootstrap overflow visible</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/cec0161eff56dd0a81c778bfe24a2e7d618f1691">cec0161e</a> - <a href="https://support.chamilo.org/issues/8166">#8166</a>) Fix create course when doesn't exists an admin with id 1</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/55c17b801c573e1f65fd036efaf1cd114040d3db">55c17b80</a> - <a href="https://task.beeznest.com/issues/10997">BT#10997</a>) Fix Migrations</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/a1f5d466b7baec90de31b31a40a09f606e728404">a1f5d466</a> - <a href="https://support.chamilo.org/issues/8024">#8024</a>) Add clock-exercise.png</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/d46b5c15141020c681d26fb46bd9242a6e5e12a1">d46b5c15</a> - <a href="https://support.chamilo.org/issues/8024">#8024</a>) Fixed css clock CT#8024</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/4292a69177fb993561ad07aadce77fedfe0b4244">4292a691</a> - <a href="https://support.chamilo.org/issues/8154">#8154</a>) Fix attached files in mail</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/6c56132f69b3124ed36d6a0f577b95bed6888580">6c56132f</a> - <a href="https://task.beeznest.com/issues/10997">BT#10997</a>) Remove condition hiding the user ID when teacher cannot subscribe students to course, because it causes the user_id data to be nullified, which prevents links to work properly</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/bdb5a042a50d40c40b8775b241deb5b97b998d57">bdb5a042</a> - <a href="https://task.beeznest.com/issues/10979">BT#10979</a>) Fix and remove E_NOTICE when search_enabled is true</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/798b6f52089b52092cd597b76eef0ec9e3a41c16">798b6f52</a> - <a href="https://support.chamilo.org/issues/8135">#8135</a>) Fix previous/next buttons in calendar</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/28117fcfc2e04dcaa2528e589a45fcd72787db1f">28117fcf</a>) Fix issue with foreign keys when removing URLs and avoid a notice</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/767d99cf540650ac8b43690986690f6c0964bb15">767d99cf</a> - <a href="https://task.beeznest.com/issues/10927">BT#10927</a>) Add from and too</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/44706ef925530c642933112adc084cb313e05148">44706ef9</a> - <a href="https://support.chamilo.org/issues/8140">#8140</a>) Remove user from all portals</li>
<li>(<a href="https://github.com/chamilo/chamilo-lms/commit/9f4f4a53ded2d67fd9416a8d10137277bcd5fefa">9f4f4a53</a> - <a href="https://task.beeznest.com/issues/10979">BT#10979</a>) Fix E_NOTICEs when search_enabled is true</li>
</ul>
<h3>Stylesheets and theming</h3>
<ul>
<li>None that we know of.</li>
</ul>
<h3>Web services</h3>
<ul>
<li>None that we know of.</li>
</ul>
<h3>Removals</h3>
<ul>
<li>None that we know of.</li>
</ul>
<h3>Known issues</h3>
<ul>
<li>IMS/QTI import/export has issues</li>
<li>In Internet Explorer 9, learning paths might not show other pages than the first to be opened. We lacked computers with IE9 at the time of release of 1.10.4. Guaranteeing IE9 support will likely require additional services. See <a href="https://support.chamilo.org/issues/8075">the corresponding bug report</a></li>
</ul>
<a name="1.10.4"></a>
<h1>Chamilo 1.10.4 - Bath, 22th of March 2016</h1>

@ -209,19 +209,19 @@ $form->addElement('text', 'phone', get_lang('PhoneNumber'));
$form->addElement('file', 'picture', get_lang('AddPicture'), array('id' => 'picture', 'class' => 'picture-form'));
$allowed_picture_types = array ('jpg', 'jpeg', 'png', 'gif');
$form->addHtml(''
. '<div class="form-group">'
. '<label for="cropImage" id="labelCropImage" class="col-sm-2 control-label"></label>'
. '<div class="col-sm-8">'
. '<div id="cropImage" class="cropCanvas">'
. '<img id="previewImage" >'
. '</div>'
. '<div>'
. '<button class="btn btn-primary hidden" name="cropButton" id="cropButton"><em class="fa fa-crop"></em> '.get_lang('CropYourPicture').'</button>'
. '</div>'
. '</div>'
. '</div>'
. '');
$form->addHtml('<div class="form-group">
<label for="cropImage" id="labelCropImage" class="col-sm-2 control-label"></label>
<div class="col-sm-8">
<div id="cropImage" class="cropCanvas">
<img id="previewImage" >
</div>
<div>
<button class="btn btn-primary hidden" name="cropButton" id="cropButton">
<em class="fa fa-crop"></em> '.get_lang('CropYourPicture').'</button>
</div>
</div>
</div>');
$form->addHidden('cropResult', '');
$form->addRule(
@ -402,7 +402,7 @@ if ($form->validate()) {
$_FILES['picture']['name'],
$_FILES['picture']['tmp_name'],
$user['cropResult']
);
}

@ -48,10 +48,10 @@ function facebookConnect()
// see if we have a session
if (isset($session)) {
// graph api request for user data
$request = new FacebookRequest($session, 'GET', '/me');
$request = new FacebookRequest($session, 'GET', '/me?fields=id,first_name,last_name,email,locale');
$response = $request->execute();
// get response
$graphObject = $response->getGraphObject();
$graphObject = $response->getGraphObject(Facebook\GraphUser::className());
$username = changeToValidChamiloLogin($graphObject->getProperty('email'));
$email = $graphObject->getProperty('email');
$locale = $graphObject->getProperty('locale');

@ -22,5 +22,5 @@
* See facebook section of the auth.conf.php file
*/
require_once dirname(__FILE__) . '/../../../app/config/auth.conf.php';
require dirname(__FILE__) . '/../../../app/config/auth.conf.php';

@ -176,8 +176,8 @@ $form->addElement(
$categories,
['style'=>'width:350px', 'id'=>'category_code']
);
$form->addElement('select_language', 'course_language', array(get_lang('Ln'), get_lang('TipLang')));
$form->addElement('select_language', 'course_language', array(get_lang('Ln'), get_lang('TipLang')));
$form->addText('department_name', get_lang('Department'), false);
$form->applyFilter('department_name', 'html_filter');
$form->applyFilter('department_name', 'trim');
@ -187,23 +187,29 @@ $form->applyFilter('department_url', 'html_filter');
// Picture
$form->addElement('file', 'picture', get_lang('AddPicture'), array('id' => 'picture', 'class' => 'picture-form'));
$form->addHtml(''
. '<div class="form-group">'
. '<label for="cropImage" id="labelCropImage" class="col-sm-2 control-label"></label>'
. '<div class="col-sm-8">'
. '<div id="cropImage" class="cropCanvas">'
. '<img id="previewImage" >'
. '</div>'
. '<div>'
. '<button class="btn btn-primary hidden" type="button" name="cropButton" id="cropButton"><em class="fa fa-crop"></em> '.get_lang('CropYourPicture').'</button>'
. '</div>'
. '</div>'
. '</div>'
. '');
$form->addHtml('<div class="form-group">
<label for="cropImage" id="labelCropImage" class="col-sm-2 control-label">
</label>
<div class="col-sm-8">
<div id="cropImage" class="cropCanvas">
<img id="previewImage" >
</div>
<div>
<button class="btn btn-primary hidden" type="button" name="cropButton" id="cropButton">
<em class="fa fa-crop"></em> '.get_lang('CropYourPicture').'
</button>
</div>
</div>
</div>
');
$form->addHidden('cropResult', '');
$allowed_picture_types = array ('jpg', 'jpeg', 'png', 'gif');
$form->addRule('picture', get_lang('OnlyImagesAllowed').' ('.implode(',', $allowed_picture_types).')', 'filetype', $allowed_picture_types);
//$form->addElement('html', '<div class="form-group "><div class="col-md-2"></div> <div class="col-md-8 help-image">'.get_lang('UniqueAnswerImagePreferredSize200x150').'</div></div>');
$form->addRule(
'picture',
get_lang('OnlyImagesAllowed').' ('.implode(',', $allowed_picture_types).')',
'filetype',
$allowed_picture_types
);
$form->addElement('checkbox', 'delete_picture', null, get_lang('DeletePicture'));
if (api_get_setting('pdf_export_watermark_by_course') == 'true') {
@ -279,8 +285,6 @@ if (api_get_setting('documents_default_visibility_defined_in_course') == 'true')
);
$form->addGroup($group, '', array(get_lang("DocumentsDefaultVisibility")), '');
$form->addButtonSave(get_lang('SaveSettings'),'submit_save');
$form->addElement('html', '</div></div>');
}
@ -480,7 +484,7 @@ $form->setDefaults($values);
// Validate form
if ($form->validate() && is_settings_editable()) {
$updateValues = $form->exportValues();
// update course picture
$picture = $_FILES['picture'];
if (!empty($picture['name'])) {
@ -491,7 +495,7 @@ if ($form->validate() && is_settings_editable()) {
$updateValues['cropResult']
);
}
$visibility = $updateValues['visibility'];
$deletePicture = isset($updateValues['delete_picture']) ? $updateValues['delete_picture'] : '';

@ -49,15 +49,14 @@ switch ($action) {
$currentUrl = api_get_self().'?action=edit_icon&id=' . $id.'&'.api_get_cidreq();
$form = new FormValidator('icon_edit', 'post', $currentUrl);
$form->addElement('header', get_lang('EditIcon'));
$form->addHeader(get_lang('EditIcon'));
$form->addHtml('<div class="col-md-7">');
$form->addElement('text', 'name', get_lang('Name'));
$form->addElement('text', 'link', get_lang('Links'));
$form->addText('name', get_lang('Name'));
$form->addText('link', get_lang('Links'));
$allowed_picture_types = array ('jpg', 'jpeg', 'png');
$form->addElement('file', 'icon', get_lang('CustomIcon'));
$form->addFile('icon', get_lang('CustomIcon'));
$form->addRule('icon', get_lang('OnlyImagesAllowed').' ('.implode(',', $allowed_picture_types).')', 'filetype', $allowed_picture_types);
$form->addElement(
'select',
$form->addSelect(
'target',
get_lang('LinkTarget'),
[
@ -65,14 +64,12 @@ switch ($action) {
'_blank' => get_lang('LinkOpenBlank')
]
);
$form->addElement(
'select',
$form->addSelect(
'visibility',
get_lang('Visibility'),
array(1 => get_lang('Visible'), 0 => get_lang('Invisible'))
);
$form->addElement(
'textarea',
$form->addTextarea(
'description',
get_lang('Description'),
array('rows' => '3', 'cols' => '40')
@ -118,12 +115,8 @@ switch ($action) {
$iconsTools .= Display::page_header(get_lang('CustomizeIcons'), null, 'h4');
$iconsTools .= '<div class="row">';
foreach ($toolList as $tool) {
if ($tool['id']>20) {
$toolIconName = $tool['name'];
} else {
$toolIconName = get_lang('Tool'.api_underscore_to_camel_case($tool['name']));
}
$toolIconName = 'Tool' . api_underscore_to_camel_case($tool['name']);
$toolIconName = isset($$toolIconName) ? get_lang($toolIconName) : $tool['name'];
$iconsTools .= '<div class="col-md-2">';
$iconsTools .= '<div class="items-tools">';

@ -22,12 +22,11 @@ var hide_bar = function() {
}
$(document).ready(function() {
$(".scrollbar-macosx").scrollbar();
$(".scrollbar-light").scrollbar();
if ($(window).width() <= 785 ) {
hide_bar();
}
}
$("#hide_bar_template").click(function() {
@ -445,7 +444,7 @@ if ($form->validate()) {
$values = $form->exportValues();
$readonly = isset($values['readonly']) ? 1 : 0;
$values['title'] = trim($values['title']);
if (!empty($values['dirValue'])) {
$dir = $values['dirValue'];
}
@ -617,9 +616,9 @@ if ($form->validate()) {
$actionsLeft = '<a href="document.php?curdirpath='.Security::remove_XSS($dir).'">'.
Display::return_icon('back.png',get_lang('Back').' '.get_lang('To').' '.get_lang('DocumentsOverview'),'',ICON_SIZE_MEDIUM).'</a>';
}
echo $toolbar = Display::toolbarAction('actions-documents', array(0 => $actionsLeft, 1 => ''));
if ($is_certificate_mode) {
$all_information_by_create_certificate = DocumentManager::get_all_info_to_certificate(api_get_user_id(), api_get_course_id());
@ -636,7 +635,7 @@ if ($form->validate()) {
<div id="template_col" class="col-md-2">
<div class="panel panel-default">
<div class="panel-body">
<div id="frmModel" class="items-templates scrollbar-macosx"></div>
<div id="frmModel" class="items-templates scrollbar-light"></div>
</div>
</div>
</div>

@ -38,7 +38,7 @@ var hide_bar = function() {
}
$(document).ready(function() {
$(".scrollbar-macosx").scrollbar();
$(".scrollbar-light").scrollbar();
if ($(window).width() <= 785 ) {
hide_bar();
@ -537,7 +537,7 @@ if ($owner_id == api_get_user_id() ||
<div id="template_col" class="col-md-2">
<div class="panel panel-default">
<div class="panel-body">
<div id="frmModel" class="items-templates scrollbar-macosx"></div>
<div id="frmModel" class="items-templates scrollbar-light"></div>
</div>
</div>
</div>

@ -132,6 +132,7 @@ class Exercise
$id = intval($id);
if (empty($this->course_id)) {
return false;
}
$sql = "SELECT * FROM $TBL_EXERCISES WHERE c_id = ".$this->course_id." AND id = ".$id;
@ -1717,7 +1718,7 @@ class Exercise
Database::query($sql);
if ($this->specialCategoryOrders) {
$sql = "UPDATE $TBL_EXERCICES
$sql = "UPDATE $TBL_EXERCISES
SET question_selection_type= ".intval($this->getQuestionSelectionType())."
WHERE id = ".$this->id." AND c_id = ".$this->course_id;
Database::query($sql);
@ -5797,10 +5798,10 @@ class Exercise
*/
private function setMediaList($questionList)
{
$mediaList= array();
$mediaList = array();
if (!empty($questionList)) {
foreach ($questionList as $questionId) {
$objQuestionTmp = Question::read($questionId);
$objQuestionTmp = Question::read($questionId, $this->course_id);
// If a media question exists
if (isset($objQuestionTmp->parent_id) && $objQuestionTmp->parent_id != 0) {

@ -369,11 +369,12 @@ class GradebookUtils
/**
* Checks if a resource is in the unique gradebook of a given course
* @param string Course code
* @param int Resource type (use constants defined in linkfactory.class.php)
* @param int Resource ID in the corresponding tool
* @param int Session ID (optional - 0 if not defined)
* @return int false on error or array of resource
* @param string $course_code Course code
* @param int $resource_type Resource type (use constants defined in linkfactory.class.php)
* @param int $resource_id Resource ID in the corresponding tool
* @param int $session_id Session ID (optional - 0 if not defined)
*
* @return array false on error or array of resource
*/
public static function is_resource_in_course_gradebook($course_code, $resource_type, $resource_id, $session_id = 0)
{
@ -390,6 +391,7 @@ class GradebookUtils
return false;
}
$row = Database::fetch_array($res, 'ASSOC');
return $row;
}
@ -769,7 +771,7 @@ class GradebookUtils
$row = Database::fetch_array($res);
$category_id = $row['id'];
}
return $category_id;
}

@ -897,6 +897,8 @@ class Category implements GradebookItem
if (!empty($cats)) {
/** @var Category $cat */
foreach ($cats as $cat) {
$cat->set_session_id($session_id);
$cat->set_course_code($course_code);
$cat->setStudentList($this->getStudentList());
$score = $cat->calc_score(
$stud_id,
@ -2299,5 +2301,4 @@ class Category implements GradebookItem
{
$this->studentList = $list;
}
}

@ -173,7 +173,8 @@ class ExerciseLink extends AbstractLink
exe_exo_id = ".(int)$this->get_ref_id();
$result = Database::query($sql);
$number=Database::fetch_row($result);
return ($number[0] != 0);
return $number[0] != 0;
}
/**
@ -192,7 +193,7 @@ class ExerciseLink extends AbstractLink
/* the following query should be similar (in conditions) to the one used
in exercice/exercice.php, look for note-query-exe-results marker*/
$session_id = api_get_session_id();
$session_id = $this->get_session_id();
$courseId = $this->getCourseId();
$exercise = new Exercise($courseId);
$exercise->read($this->get_ref_id());
@ -207,8 +208,8 @@ class ExerciseLink extends AbstractLink
orig_lp_item_id = 0 AND
status <> 'incomplete' AND
session_id = $session_id AND
c_id = $courseId
";
c_id = $courseId
";
} else {
$lpId = null;
if (!empty($exercise->lpList)) {
@ -223,8 +224,8 @@ class ExerciseLink extends AbstractLink
orig_lp_id = $lpId AND
status <> 'incomplete' AND
session_id = $session_id AND
c_id = $courseId
";
c_id = $courseId
";
}
if (!empty($stud_id) && $type != 'ranking') {

@ -70,11 +70,13 @@ switch ($action) {
$tbl_course_description = Database::get_course_table(TABLE_COURSE_DESCRIPTION);
$course_info = api_get_course_info($_GET['code']);
if ($course_info['visibility'] != COURSE_VISIBILITY_OPEN_WORLD) {
if (api_is_anonymous()) {
exit;
}
}
if (
api_get_setting('course_catalog_hide_private') === 'true' &&
$course_info['visibility'] == COURSE_VISIBILITY_REGISTERED
) {
echo get_lang('PrivateAccess');
break;
}
//echo Display::tag('h2', $course_info['name']);
//echo '<br />';

@ -8047,6 +8047,15 @@ function api_mail_html(
// Send the mail message.
if (!$mail->Send()) {
error_log('ERROR: mail not sent to '.$recipient_name.' ('.$recipient_email.') because of '.$mail->ErrorInfo.'<br />');
if ($mail->SMTPDebug) {
error_log(
"Connection details :: " .
"Protocol: " . $mail->Mailer . ' :: ' .
"Host/Port: " . $mail->Host . ':' . $mail->Port . ' :: ' .
"Authent/Open: " . ($mail->SMTPAuth?'Authent':'Open') . ' :: ' .
($mail->SMTPAuth?" User/Pass: " . $mail->Username . ':' . $mail->Password:'')
);
}
return 0;
}

@ -154,7 +154,8 @@ class Login
PERSON_NAME_EMAIL_ADDRESS
);
$email_admin = api_get_setting('emailAdministrator');
$email_body = nl2br($email_body);
$result = @api_mail_html(
'',
$email_to,
@ -196,13 +197,20 @@ class Login
$url = api_get_path(WEB_CODE_PATH).'auth/reset.php?token='.$uniqueId;
$mailTemplate = new Template(null, false, false, false, false, false);
$mailLayout = $mailTemplate->get_template('mail/reset_password.tpl');
$mailTemplate->assign('complete_user_name', $user->getCompleteName());
$mailTemplate->assign('link', $url);
$mailLayout = $mailTemplate->get_template('mail/reset_password.tpl');
$mailSubject = get_lang('ResetPasswordInstructions');
$mailBody = $mailTemplate->fetch($mailLayout);
$mailBody = nl2br($mailBody);
$mailBody = sprintf(
get_lang('ResetPasswordCommentWithUrl'),
$url
);
api_mail_html(
$user->getCompleteName(),

@ -49,8 +49,6 @@
*/
class Pager_Sliding extends Pager_Common
{
// {{{ Pager_Sliding()
/**
* Constructor
*
@ -58,7 +56,7 @@ class Pager_Sliding extends Pager_Common
*
* @access public
*/
function Pager_Sliding($options = array())
public function __construct($options = array())
{
//set default Pager_Sliding options
$this->_delta = 2;

@ -1255,9 +1255,7 @@ class SessionManager
$result = Database::query($sql);
$session = Database::fetch_assoc($result);
//We are not using this becaouse the range its to small and no other date match the condition of this function
//$clicks = Tracking::get_total_clicks($info['user_id'], $courseId, $sessionId, $info['login_course_date'], $info['logout_course_date']);
#building array to display
// building array to display
$return[] = array(
'user_id' => $info['user_id'],
'logindate' => $info['login_course_date'],

@ -1419,7 +1419,6 @@ class Tracking
}
$sql .= $condition_user;
$rs = Database::query($sql);
$row = Database::fetch_array($rs);
@ -2761,7 +2760,7 @@ class Tracking
*/
public static function get_time_spent_in_lp($student_id, $course_code, $lp_ids = array(), $session_id = null)
{
$course = CourseManager :: get_course_information($course_code);
$course = api_get_course_info($course_code);
$student_id = intval($student_id);
$total_time = 0;
@ -6499,6 +6498,9 @@ class TrackingCourseLog
$user_row[]= $user['count_assignments'];
$user_row[]= $user['count_messages'];
$userGroupManager = new UserGroup();
$user_row[] = $userGroupManager->getLabelsFromNameList($user['user_id'], UserGroup::NORMAL_CLASS);
if (empty($session_id)) {
$user_row[]= $user['survey'];
}

@ -516,7 +516,7 @@ class UserGroup extends Model
* Get the group list for a user
* @param int $userId The user ID
* @param int $filterByType Optional. The type of group
* @return type
* @return array
*/
public function getUserGroupListByUser($userId, $filterByType = null)
{
@ -2356,5 +2356,43 @@ class UserGroup extends Model
$res = Database::query($sql);
return $res;
}
/**
* Filter the groups/classes info to get a name list only
* @param int $userId The user ID
* @param int $filterByType Optional. The type of group
* @return array
*/
public function getNameListByUser($userId, $filterByType = null)
{
$userClasses = $this->getUserGroupListByUser($userId, $filterByType);
return array_column($userClasses, 'name');
}
/**
* Get the HTML necessary for display the groups/classes name list
* @param int $userId The user ID
* @param int $filterByType Optional. The type of group
* @return string
*/
public function getLabelsFromNameList($userId, $filterByType = null)
{
$groupsNameListParsed = $this->getNameListByUser($userId, $filterByType);
if (empty($groupsNameListParsed)) {
return '';
}
$nameList = '<ul class="list-unstyled">';
foreach ($groupsNameListParsed as $name) {
$nameList .= '<li>' . Display::span($name, ['class' => 'label label-info']) . '</li>';
}
$nameList .= '</ul>';
return $nameList;
}
}

@ -396,7 +396,7 @@ class UserManager
$url = api_get_access_url($access_url_id);
}
} else {
$url = $_configuration['root_web'];
$url = api_get_path(WEB_PATH);
}
$tplContent = new Template(null, false, false, false, false, false);
// variables for the default template
@ -946,6 +946,8 @@ class UserManager
} else {
$emailbody = get_lang('Dear')." ".stripslashes(api_get_person_name($firstname, $lastname)).",\n\n".get_lang('YouAreReg')." ".api_get_setting('siteName')." ".get_lang('WithTheFollowingSettings')."\n\n".get_lang('Username')." : ".$username.(($reset_password > 0) ? "\n".get_lang('Pass')." : ".stripslashes($original_password) : "")."\n\n".get_lang('Address')." ".api_get_setting('siteName')." ".get_lang('Is')." : ".$_configuration['root_web']."\n\n".get_lang('Problem')."\n\n".get_lang('SignatureFormula').",\n\n".api_get_person_name(api_get_setting('administratorName'), api_get_setting('administratorSurname'))."\n".get_lang('Manager')." ".api_get_setting('siteName')."\nT. ".api_get_setting('administratorTelephone')."\n".get_lang('Email')." : ".api_get_setting('emailAdministrator');
}
$emailbody = nl2br($emailbody);
api_mail_html(
$recipient_name,
$email,

@ -839,8 +839,69 @@ if (isset($uidReset) && $uidReset) {
$is_allowedCreateCourse = isset($_SESSION['is_allowedCreateCourse']) ? $_SESSION['is_allowedCreateCourse'] : false;
}
/* COURSE INIT */
if (!isset($_SESSION['login_as'])) {
$save_course_access = true;
$_course = Session::read('_course');
if ($_course && isset($_course['real_id'])) {
// The value $_dont_save_user_course_access should be added before the call of global.inc.php see the main/inc/chat.ajax.php file
// Disables the updates in the TRACK_E_COURSE_ACCESS table
if (isset($_dont_save_user_course_access) && $_dont_save_user_course_access == true) {
$save_course_access = false;
}
if ($save_course_access) {
$course_tracking_table = Database:: get_main_table(TABLE_STATISTIC_TRACK_E_COURSE_ACCESS);
/*
* When $_configuration['session_lifetime'] is too big 100 hours (in order to let users take exercises with no problems)
* the function Tracking::get_time_spent_on_the_course() returns big values (200h) due the condition:
* login_course_date > now() - INTERVAL $session_lifetime SECOND
*
*/
/*
if (isset($_configuration['session_lifetime'])) {
$session_lifetime = $_configuration['session_lifetime'];
} else {
$session_lifetime = 3600; // 1 hour
}*/
$session_lifetime = 3600; // 1 hour
$time = api_get_utc_datetime();
if (isset($_user['user_id']) && !empty($_user['user_id'])) {
//We select the last record for the current course in the course tracking table
//But only if the login date is < than now + max_life_time
$sql = "SELECT course_access_id
FROM $course_tracking_table
WHERE
user_id = ".intval($_user['user_id'])." AND
c_id = ".$_course['real_id']." AND
session_id = ".api_get_session_id()." AND
login_course_date > '$time' - INTERVAL $session_lifetime SECOND
ORDER BY login_course_date DESC LIMIT 0,1";
$result = Database::query($sql);
if (Database::num_rows($result) > 0) {
$i_course_access_id = Database::result($result, 0, 0);
// We update the course tracking table
$sql = "UPDATE $course_tracking_table
SET logout_course_date = '$time', counter = counter+1
WHERE
course_access_id = ".intval($i_course_access_id)." AND
session_id = ".api_get_session_id();
Database::query($sql);
} else {
$ip = api_get_real_ip();
$sql = "INSERT INTO $course_tracking_table (c_id, user_ip, user_id, login_course_date, logout_course_date, counter, session_id)
VALUES('".$_course['real_id']."', '".$ip."', '".$_user['user_id']."', '$time', '$time', '1','".api_get_session_id()."')";
Database::query($sql);
}
}
}
}
}
/* COURSE INIT */
if (isset($cidReset) && $cidReset) {
// Course session data refresh requested or empty data
if ($cidReq) {
@ -948,7 +1009,6 @@ if (isset($cidReset) && $cidReset) {
$_cid = -1; // Set default values
$_course = -1;
} else {
$_cid = $_SESSION['_cid'];
$_course = $_SESSION['_course'];
@ -979,65 +1039,6 @@ if (isset($cidReset) && $cidReset) {
Session::write('_gid', $_gid);
}
}
if (!isset($_SESSION['login_as'])) {
$save_course_access = true;
//The value $_dont_save_user_course_access should be added before the call of global.inc.php see the main/inc/chat.ajax.php file
//Disables the updates in the TRACK_E_COURSE_ACCESS table
if (isset($_dont_save_user_course_access) && $_dont_save_user_course_access == true) {
$save_course_access = false;
}
if ($save_course_access) {
$course_tracking_table = Database :: get_main_table(TABLE_STATISTIC_TRACK_E_COURSE_ACCESS);
/*
* When $_configuration['session_lifetime'] is too big 100 hours (in order to let users take exercises with no problems)
* the function Tracking::get_time_spent_on_the_course() returns big values (200h) due the condition:
* login_course_date > now() - INTERVAL $session_lifetime SECOND
*
*/
/*
if (isset($_configuration['session_lifetime'])) {
$session_lifetime = $_configuration['session_lifetime'];
} else {
$session_lifetime = 3600; // 1 hour
}*/
$session_lifetime = 3600; // 1 hour
$course_code = $_course['sysCode'];
$time = api_get_utc_datetime();
if (isset($_user['user_id']) && !empty($_user['user_id'])) {
//We select the last record for the current course in the course tracking table
//But only if the login date is < than now + max_life_time
$sql = "SELECT course_access_id
FROM $course_tracking_table
WHERE
user_id = ".intval($_user['user_id'])." AND
c_id = ".$_course['real_id']." AND
session_id = ".api_get_session_id()." AND
login_course_date > '$time' - INTERVAL $session_lifetime SECOND
ORDER BY login_course_date DESC LIMIT 0,1";
$result = Database::query($sql);
if (Database::num_rows($result) > 0) {
$i_course_access_id = Database::result($result, 0, 0);
//We update the course tracking table
$sql = "UPDATE $course_tracking_table SET logout_course_date = '$time', counter = counter+1
WHERE course_access_id = ".intval($i_course_access_id)." AND session_id = ".api_get_session_id();
Database::query($sql);
} else {
$ip = api_get_real_ip();
$sql="INSERT INTO $course_tracking_table (c_id, user_ip, user_id, login_course_date, logout_course_date, counter, session_id)" .
"VALUES('".$_course['real_id']."', '".$ip."', '".$_user['user_id']."', '$time', '$time', '1','".api_get_session_id()."')";
Database::query($sql);
}
}
}
}
}
}
@ -1053,12 +1054,12 @@ $is_courseTutor = false; //course teacher - some rights
$is_courseMember = false; //course student
$is_courseCoach = false; //course coach
*/
//Course - User permissions
$is_sessionAdmin = false;
$is_courseCoach = false; //course coach
$is_courseAdmin = false;
$is_courseTutor = false;
$is_courseMember = false;
// Course - User permissions
$is_sessionAdmin = false;
$is_courseCoach = false; //course coach
$is_courseAdmin = false;
$is_courseTutor = false;
$is_courseMember = false;
if ((isset($uidReset) && $uidReset) || (isset($cidReset) && $cidReset)) {
if (isset($_cid) && $_cid) {

File diff suppressed because it is too large Load Diff

@ -27,6 +27,7 @@ define('MAX_FORM_FIELD_LENGTH', 80);
// Including necessary libraries.
require_once '../inc/lib/api.lib.php';
require_once '../inc/lib/text.lib.php';
api_check_php_version('../inc/');
@ -209,6 +210,9 @@ if ($installType == 'update' && in_array($my_old_version, $update_from_version_8
}
}
$session_lifetime = 360000;
if (!isset($_GET['running'])) {
$dbHostForm = 'localhost';
$dbUsernameForm = 'root';
@ -246,7 +250,6 @@ if (!isset($_GET['running'])) {
$allowSelfReg = 1;
$allowSelfRegProf = 1;
$encryptPassForm = 'sha1';
$session_lifetime = 360000;
if (!empty($_GET['profile'])) {
$installationProfile = api_htmlentities($_GET['profile'], ENT_QUOTES);
}

@ -7552,4 +7552,10 @@ $MessagingGDCProjectNumberComment = "Você precisa registrar um projeto no Googl
$MessagingGDCApiKeyTitle = "Key API do Google Developer Console para o Google Cloud Mensagens";
$MessagingGDCApiKeyComment = "Você precisa ativar a API do Google Cloud Mensagens e criar uma credencial para Android";
$Overwrite = "Sobrescrever";
$TheLogoMustBeSizeXAndFormatY = "O logotipo deve ser de %s px no tamanho e no formato %s";
$ResetToTheOriginalLogo = "Logotipo original recuperado";
$NewLogoUpdated = "Novo logotipo carregado";
$CurrentLogo = "Logo atual";
$UpdateLogo = "Logotipo atualização";
$FollowedStudentBosses = "chefes de estudantes seguiram";
?>

@ -5558,14 +5558,66 @@ $Pediaphon = "Gebruik Pediaphon audiodiensten";
$HelpPediaphon = "Ondersteunt teksten van ettelijke duizenden karakters, in diverse mannelijke of vrouwelijke stemmen (afhankelijke van de taal). Audio bestanden zullen gegenereerd en automatisch opgeslagen worden in je huidige Chamilo map.";
$FirstSelectALanguage = "Kies een taal";
$MoveUserStats = "Verplaats resultaten van een gebruiker van/naar een sessie";
$CompareUserResultsBetweenCoursesAndCoursesInASession = "Met deze geavanceerde tool wordt het mogelijk de resultaten van gebruikers beter te volgen als je van een cursusbenadering naar een sessiebenadering evolueert. In de meeste gevallen heb je deze tool niet nodig.
Op dit scherm kun je de resultaten vergelijken tussen gebruikers van losse cursussen versus cursussen in de context van een sessie.
Eens beslist, wordt het mogelijk om de vorderingsgegevens van studenten (resultaten van oefeningen en leerpad-opvolging) over te dragen van een cursus naar een sessie.";
$PDFExportWatermarkEnableTitle = "Watermerk inschakelen voor PDF export";
$PDFExportWatermarkEnableComment = "Als je deze optie inschakelt, kun je een afbeelding of tekst opladen die dan automatisch als watermerk op als je geëxporteerde PDF-documenten zal verschijnen.";
$AddWaterMark = "Watermerk afbeelding opladen";
$PDFExportWatermarkByCourseTitle = "Watermerk per cursus toestaan";
$PDFExportWatermarkByCourseComment = "Als deze optie ingeschakeld is, kunnen instructeurs een eigen watermerk toevoegen aan de documenten in hun cursussen.";
$PDFExportWatermarkTextTitle = "PDF Watermerk tekst";
$PDFExportWatermarkTextComment = "Deze tekst zal toegevoegd worden als watermerk op alle als PDF geëxporteerde documenten.";
$ExerciseMinScoreTitle = "Minimumscore voor oefeningen";
$ExerciseMinScoreComment = "Bepaal een minimumscore (typisch 0) voor alle oefeningen op dit platform. Dit bepaalt hoe de eindresultaten zullen worden weergegeven aan gebruikers en instructeurs.";
$ExerciseMaxScoreTitle = "Maximale score van de oefeningen";
$ExerciseMaxScoreComment = "Bepaal een maximumscore (typisch 10, 20 of 100) voor alle oefeningen op dit platform. Dit zal bepalen hoe de eindresultaten weergegeven zullen worden aan gebruikers en instructeurs.";
$AddPicture = "Voeg een afbeelding toe";
$LPAutoLaunch = "Auto-start functie van leerpad inschakelen";
$UseMaxScore100 = "Gebruik standaard maximumscore van 100";
$EnableLPAutoLaunch = "Sta automatisch laden van leerpaden toe.";
$DisableLPAutoLaunch = "Schakel automatisch laden van leerpaden uit";
$TheLPAutoLaunchSettingIsONStudentsWillBeRedirectToAnSpecificLP = "De auto-start functie van het leerpad is ingeschakeld. Wanneer studenten deze cursus openen, zullen ze automatisch doorgezonden worden naar het leerpad wat is aangeduid als auto-start.";
$UniqueAnswerNoOption = "Uniek antwoord met onbekend";
$MultipleAnswerTrueFalse = "Meerkeuze met waar/nietwaar/ik weet het niet";
$MultipleAnswerCombinationTrueFalse = "Combinatie waar/niet waar/ik weet het niet";
$DontKnow = "Ik weet het niet";
$ExamNotAvailableAtThisTime = "Het examen is op dit ogenblik niet beschikbaar";
$LoginOrEmailAddress = "Gebruikersnaam of email adres";
$Activate = "Activeer";
$Deactivate = "Deactiveer";
$ConfigLearnpath = "Leerpad instellingen";
$CareersAndPromotions = "Carrières en promoties";
$Careers = "Carrières";
$Promotions = "Promoties";
$Updated = "Update is gelukt";
$Career = "Carrière";
$SubscribeSessionsToPromotions = "Schrijf sessies in op promoties";
$SessionsInPlatform = "Sessies niet ingeschreven";
$FirstLetterSessions = "Eerste letter van sessienaam";
$SessionsInPromotion = "Sessies in deze promotie";
$SubscribeSessionsToPromotion = "Schrijf sessie in promotie in";
$NoEndTime = "Geen eindtijd";
$SubscribeUsersToClass = "Schrijf gebruikers in voor klas";
$SubscribeClassToCourses = "Schrijf klas in voor cursussen";
$SubscribeClassToSessions = "Schrijf klas in voor sessies";
$SessionsInGroup = "Sessies in groep";
$CoursesInGroup = "Cursussen in groep";
$UsersInGroup = "Gebruikers in groep";
$UsersInPlatform = "Gebruikers in platform";
$Profile = "Profiel";
$CreatedAt = "Gemaakt in";
$UpdatedAt = "Bijgewerkt op";
$CreatedOn = "Gemaakt op";
$UpdatedOn = "Bijgewerkt op";
$Paint = "Schilderen";
$MyResults = "Mijn resultaten";
$LearningPaths = "Leerpaden";
$AllLearningPaths = "Alle leerpaden";
$ByCourse = "Per cursus";
$MyQCM = "Mijn meerkeuzevragen";
$LearnpathUpdated = "Leerpad bijgewerkt";
$YouNeedToCreateACareerFirst = "Je moet een carrière aanmaken voor je promoties kunt toevoegen (promoties zijn sub-elementen van een carrière)";
$PDFWaterMarkHeader = "Watermerk hoofding in geëxporteerde PDF's";
$False = "Niet waar";
$DoubtScore = "Ik weet het niet";

@ -7627,4 +7627,15 @@ $NewLogoUpdated = "New logo uploaded";
$CurrentLogo = "Current logo";
$UpdateLogo = "Update logo";
$FollowedStudentBosses = "Followed student bosses";
$DatabaseManager = "Database manager";
$CourseTemplate = "Course template";
$PickACourseAsATemplateForThisNewCourse = "Pick a course as template for this new course";
$TeacherCanSelectCourseTemplateTitle = "Teacher can select a course as template";
$TeacherCanSelectCourseTemplateComment = "Allow pick a course as template for the new course that teacher is creating";
$TheForumAutoLaunchSettingIsOnStudentsWillBeRedirectToTheForumTool = "The forum's auto-launch setting is on. Students will be redirected to the forum tool when entering this course.";
$RedirectToForumList = "Redirect to forums list";
$EnableForumAutoLaunch = "Enable forum auto-launch";
$NowDownloadYourCertificateClickHere = "You can now download your certificate by clicking here";
$AdditionallyYouHaveObtainedTheFollowingSkills = "Additionally, you have achieved the following skills";
$IHaveObtainedSkillXOnY = "I have achieved skill %s on %s";
?>

@ -7614,4 +7614,15 @@ $NewLogoUpdated = "Nouveau logo envoyé";
$CurrentLogo = "Logo actif";
$UpdateLogo = "Changer le logo";
$FollowedStudentBosses = "Chefs d'apprenants suivis";
$DatabaseManager = "Gestion de la base de données";
$CourseTemplate = "Modèle de cours";
$PickACourseAsATemplateForThisNewCourse = "Choisissez un cours comme modèle de base pour ce nouveau cours";
$TeacherCanSelectCourseTemplateTitle = "L'enseignant peut choisir un cours comme modèle";
$TeacherCanSelectCourseTemplateComment = "Permettre le choix d'un cours comme modèle lors de la création d'un nouveau cours par l'enseignant. Dans ce cas, les ressources du cours modèle seront copiées automatiquement comme base du nouveau cours.";
$TheForumAutoLaunchSettingIsOnStudentsWillBeRedirectToTheForumTool = "La fonctionnalité auto-démarrage du forum est activée. Les apprenants seront redirigés vers la liste de forums automatiquement lorsqu'ils entreront dans ce cours.";
$RedirectToForumList = "Rediriger ver la liste de forums";
$EnableForumAutoLaunch = "Activar l'auto-démarrage des forums";
$NowDownloadYourCertificateClickHere = "Télécharge ton certificat en cliquant ici";
$AdditionallyYouHaveObtainedTheFollowingSkills = "En plus, tu as acquis les compétences suivantes";
$IHaveObtainedSkillXOnY = "J'ai acquis la compétence %s sur %s";
?>

@ -2,7 +2,7 @@
/*
for more information: see languages.txt in the lang folder.
*/
$OpenBadgesBannerText = "Sie können Badges für die Kompetenzen erstellen, die die User erlernen. Diese werden im Userprofil angezeigt und dienen als Anzeige und Anerkennung des Fortschritts. Für mehr Informationen gehen Sie bitte auf <a href=\"http://http://openbadges.org/\">http://http://openbadges.org/</a>.";
$OpenBadgesBannerText = "Sie können Badges für die Kompetenzen erstellen, die die User erlernen. Diese werden im Userprofil angezeigt und dienen als Anzeige und Anerkennung des Fortschritts. Für mehr Informationen gehen Sie bitte auf <a href=\"http://openbadges.org/\">http://openbadges.org/</a>.";
$OpenBadgesIntroduction = "Sie können jetzt Badges für die Fähigkeiten erstellen, die die User im Verlauf Ihrer Kurse auf dem virtuellen Campus erwerben.";
$DesignANewBadgeComment = "Entwerfe ein neues Badge, lade es aus dem Designtool herunter und lade es auf die Plattform hoch.";
$TheBadgesWillBeSentToThatBackpack = "Die Badges werden in den Rucksack gesendet.";

@ -388,7 +388,7 @@ $ExerciseAutoLaunch = "Modo de lanzamiento automático de exámenes";
$AllowFastExerciseEdition = "Activar modo de edición rápida de exámenes";
$Username = "Nombre de usuario";
$SignIn = "Ingresar";
$YouAreReg = "Está registrado a";
$YouAreReg = "Ha sido registrado a la plataforma";
$ManageQuestionCategories = "Gestionar categorías globales de preguntas";
$ManageCourseFields = "Gestor de campos de cursos";
$ManageQuestionFields = "Gestor de campos de preguntas";
@ -2241,7 +2241,7 @@ $NumberOfSession = "Número de sesiones";
$DeleteSelectedSessionCategory = "Eliminar solo las categorias seleccionadas sin sesiones";
$DeleteSelectedFullSessionCategory = "Eliminar las categorias seleccionadas con las sesiones";
$EditTopRegister = "Editar Aviso";
$InsertTabs = "Insertar Tabs";
$InsertTabs = "Insertar pestaña o enlace";
$EditTabs = "Editar Tabs";
$AnnEmpty = "Los anuncios han sido borrados";
$AnnouncementModified = "El anuncio ha sido modificado";
@ -3959,7 +3959,7 @@ $MailHasBeenSent = "Recibirá un correo electrónico recordándole su nombre de
$PersonalSettings = "Sus datos han sido registrados.";
$Problem = "Para cualquier aclaración no dude en contactar con nosotros.";
$Is = "es";
$Address = "La dirección de";
$Address = "El enlace para acceder a la plataforma";
$FieldTypeFile = "Subida de archivo";
$YourReg = "Su registro en";
$UserFree = "El nombre de usuario que eligió ya existe. Use el botón de 'Atrás' de su navegador y elija uno diferente.";
@ -6918,7 +6918,7 @@ $SentAtX = "Enviado el: %s";
$dateTimeFormatShort = "%d %b %Y a las %I:%M %p";
$dateTimeFormatShortTimeFirst = "%I:%M %p, %d %b %Y";
$LoginToVote = "Debe estar conectado para poder votar";
$AddInMenu = "Agregar en el menu";
$AddInMenu = "Insertar en el menú principal";
$AllowUsersToChangeEmailWithNoPasswordTitle = "Permitir que los usuarios puedan cambiar su correo electrónico sin necesidad de solicitar la contraseña";
$AllowUsersToChangeEmailWithNoPasswordComment = "Cuando se modifica la cuenta del usuario";
$EnableHelpLinkTitle = "Habilitar el vínculo de ayuda";
@ -7652,4 +7652,15 @@ $NewLogoUpdated = "Nuevo logo subido";
$CurrentLogo = "Logo activo";
$UpdateLogo = "Cambiar el logo";
$FollowedStudentBosses = "Superiores de estudiante seguidos";
$DatabaseManager = "Gestor de base de datos";
$CourseTemplate = "Plantilla de curso";
$PickACourseAsATemplateForThisNewCourse = "Elegir un curso como plantilla para este nuevo curso";
$TeacherCanSelectCourseTemplateTitle = "El profesor puede seleccionar un curso como plantilla";
$TeacherCanSelectCourseTemplateComment = "Permitir elegir un curso como plantilla para el nuevo curso que el profesor está creando";
$TheForumAutoLaunchSettingIsOnStudentsWillBeRedirectToTheForumTool = "El parámetro de arranque automático del foro está activado. Los estudiantes serán redirigidos directamente a la herramienta de foro cuando entren a este curso.";
$RedirectToForumList = "Redirigir a la lista de foros";
$EnableForumAutoLaunch = "Activar auto-arranque de foro";
$NowDownloadYourCertificateClickHere = "Puedes descargar tu certificado haciendo clic aquí";
$AdditionallyYouHaveObtainedTheFollowingSkills = "Adicionalmente, has obtenido las competencias siguientes";
$IHaveObtainedSkillXOnY = "He logrado la competencia %s en %s";
?>

@ -35,6 +35,10 @@ function show_image(image,width,height) {
$export = isset($_GET['export']) ? $_GET['export'] : false;
$sessionId = isset($_GET['id_session']) ? intval($_GET['id_session']) : 0;
$origin = isset($_GET['origin']) ? Security::remove_XSS($_GET['origin']) : '';
$course_code = isset($_GET['course']) ? Security :: remove_XSS($_GET['course']) : null;
// time spent on the course
$courseInfo = api_get_course_info($course_code);
if (empty($sessionId)) {
$sessionId = api_get_session_id();
@ -54,29 +58,24 @@ if (isset ($_GET['from']) && $_GET['from'] == 'myspace') {
}
$nameTools = get_lang('StudentDetails');
$get_course_code = isset($_GET['course']) ? Security :: remove_XSS($_GET['course']) : '';
$em = Database::getManager();
if (isset($_GET['details'])) {
if ($origin == 'user_course') {
$course_info = CourseManager :: get_course_information($get_course_code);
if (empty ($cidReq)) {
$interbreadcrumb[] = array (
"url" => api_get_path(WEB_COURSE_PATH) . $course_info['directory'],
'name' => $course_info['title']
"url" => api_get_path(WEB_COURSE_PATH) . $courseInfo['directory'],
'name' => $courseInfo['title']
);
}
$interbreadcrumb[] = array (
"url" => "../user/user.php?cidReq=" . $get_course_code,
"url" => "../user/user.php?cidReq=" . $course_code,
"name" => get_lang("Users")
);
} else
if ($origin == 'tracking_course') {
$course_info = CourseManager :: get_course_information($get_course_code);
$interbreadcrumb[] = array (
"url" => "../tracking/courseLog.php?cidReq=".$get_course_code.'&id_session=' . api_get_session_id(),
"url" => "../tracking/courseLog.php?cidReq=".$course_code.'&id_session=' . api_get_session_id(),
"name" => get_lang("Tracking")
);
} else
@ -171,19 +170,16 @@ $check = Security::check_token('get');
if ($check) {
switch ($_GET['action']) {
case 'reset_lp':
$course = isset($_GET['course']) ? $_GET['course'] : "";
$lp_id = isset($_GET['lp_id']) ? intval($_GET['lp_id']) : "";
if (api_is_allowed_to_edit() &&
!empty($course) &&
!empty($lp_id) &&
!empty($student_id)
) {
$course_info = api_get_course_info($course);
Event::delete_student_lp_events(
$student_id,
$lp_id,
$course_info,
$courseInfo,
$sessionId
);
@ -256,13 +252,14 @@ while ($row = Database :: fetch_array($rs)) {
}
}
// Get the list of sessions where the user is subscribed as student
$sql = 'SELECT session_id, c_id
FROM '.Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER).'
WHERE user_id=' . intval($user_info['user_id']);
$rs = Database::query($sql);
$tmp_sessions = array();
while ($row = Database :: fetch_array($rs)) {
while ($row = Database :: fetch_array($rs, 'ASSOC')) {
$tmp_sessions[] = $row['session_id'];
if ($drh_can_access_all_courses) {
if (in_array($row['session_id'], $tmp_sessions)) {
@ -276,6 +273,8 @@ while ($row = Database :: fetch_array($rs)) {
}
}
}
$isDrhOfCourse = CourseManager::isUserSubscribedInCourseAsDrh(
api_get_user_id(),
api_get_course_info()
@ -355,7 +354,6 @@ if (!empty($student_id)) {
// get average of score and average of progress by student
$avg_student_progress = $avg_student_score = 0;
$course_code = isset($_GET['course']) ? Security :: remove_XSS($_GET['course']) : null;
if (CourseManager :: is_user_subscribed_in_course($user_info['user_id'], $course_code, true)) {
@ -377,9 +375,6 @@ if (!empty($student_id)) {
$avg_student_progress = round($avg_student_progress, 2);
// time spent on the course
$courseInfo = api_get_course_info($course_code);
$time_spent_on_the_course = 0;
if (!empty($courseInfo)) {
$time_spent_on_the_course = api_time_to_hms(
@ -438,41 +433,37 @@ if (!empty($student_id)) {
$avg_student_score
);
//Show title
$info_course = CourseManager :: get_course_information($course_code);
$coachs_name = '';
$session_name = '';
$nb_login = Tracking :: count_login_per_student($user_info['user_id'], $info_course['real_id']);
//$nb_login = Tracking :: count_login_per_student($user_info['user_id'], $courseInfo['real_id']);
//get coach and session_name if there is one and if session_mode is activated
if ($sessionId > 0) {
/*if ($sessionId > 0) {
$session_info = api_get_session_info($sessionId);
$session_coach_id = $session_info['session_admin_id'];
$course_coachs = api_get_coachs_from_course($sessionId, $info_course['real_id']);
$nb_login = '';
$course_coachs = api_get_coachs_from_course($sessionId, $courseInfo['real_id']);
// $nb_login = '';
if (!empty($course_coachs)) {
$info_tutor_name = array();
foreach ($course_coachs as $course_coach) {
$info_tutor_name[] = api_get_person_name($course_coach['firstname'], $course_coach['lastname']);
}
$info_course['tutor_name'] = implode(",",$info_tutor_name);
$courseInfo['tutor_name'] = implode(",", $info_tutor_name);
} elseif ($session_coach_id != 0) {
$session_coach_id = intval($session_info['id_coach']);
$coach_info = api_get_user_info($session_coach_id);
$info_course['tutor_name'] = $coach_info['complete_name'];
$courseInfo['tutor_name'] = $coach_info['complete_name'];
}
$coachs_name = $info_course['tutor_name'];
$coachs_name = $courseInfo['tutor_name'];
$session_name = $session_info['name'];
} // end
} // end*/
$info_course = CourseManager :: get_course_information($get_course_code);
$table_title = Display::return_icon('user.png', get_lang('User'), array(), ICON_SIZE_SMALL).$user_info['complete_name'];
echo Display::page_subheader($table_title);
$userPicture = UserManager::getUserPicture($user_info['user_id']);
$userGroupManager = new UserGroup();
$userGroups = $userGroupManager->getUserGroupListByUser($user_info['user_id'], UserGroup::NORMAL_CLASS);
$userGroups = $userGroupManager->getNameListByUser($user_info['user_id'], UserGroup::NORMAL_CLASS);
?>
<img src="<?php echo $userPicture ?>">
<div class="row">
@ -573,14 +564,21 @@ if (!empty($student_id)) {
echo get_lang('Score').' ';
Display :: display_icon('info3.gif', get_lang('ScormAndLPTestTotalAverage'), array ('align' => 'absmiddle', 'hspace' => '3px')); ?>
</td>
<td align="left"><?php if (is_numeric($avg_student_score)) { echo $avg_student_score.'%';} else { echo $avg_student_score ;} ?></td>
<td align="left"><?php
if (is_numeric($avg_student_score)) {
echo $avg_student_score.'%';
} else {
echo $avg_student_score;
}
?>
</td>
</tr>
<?php
if (!empty($nb_login)) {
/*if (!empty($nb_login)) {
echo '<tr><td align="right">'.get_lang('CountToolAccess').'</td>';
echo '<td align="left"> '.$nb_login.'</td>';
echo '</tr>';
}
}*/
} ?>
</tbody>
</table>
@ -594,7 +592,7 @@ if (!empty($student_id)) {
<tbody>
<?php foreach ($userGroups as $class) { ?>
<tr>
<td><?php echo $class['name'] ?></td>
<td><?php echo $class ?></td>
</tr>
<?php } ?>
</tbody>
@ -604,56 +602,51 @@ if (!empty($student_id)) {
</div>
<?php
$table_title = '';
/*$table_title = '';
if (!empty($sessionId)) {
$session_name = api_get_session_name($sessionId);
$table_title = $session_name ? Display::return_icon('session.png', get_lang('Session'), array(), ICON_SIZE_SMALL).' '.$session_name.' ':'';
$table_title = $session_name ? Display::return_icon('session.png', get_lang('Session'), array(), ICON_SIZE_SMALL).' '.$session_name.' ':'';
}
if (!empty($info_course['title'])) {
$table_title .= $info_course ? Display::return_icon('course.png', get_lang('Course'), array(), ICON_SIZE_SMALL).' '.$info_course['title'].' ':'';
if (!empty($courseInfo['title'])) {
$table_title .= $courseInfo ? Display::return_icon('course.png', get_lang('Course'), array(), ICON_SIZE_SMALL).' '.$courseInfo['title'].' ':'';
}
echo Display::page_subheader($table_title);
echo Display::page_subheader($table_title);*/
if (empty($_GET['details'])) {
$csv_content[] = array();
$csv_content[] = array(
get_lang('Session', ''),
get_lang('Course', ''),
get_lang('Time', ''),
get_lang('Progress', ''),
get_lang('Score', ''),
get_lang('AttendancesFaults', ''),
get_lang('Session'),
get_lang('Course'),
get_lang('Time'),
get_lang('Progress'),
get_lang('Score'),
get_lang('AttendancesFaults'),
get_lang('Evaluations')
);
$attendance = new Attendance();
foreach ($courses_in_session as $sessionId => $courses) {
$session_name = '';
$access_start_date = '';
$access_end_date = '';
$date_session = '';
$title = Display::return_icon('course.png', get_lang('Courses'), array(), ICON_SIZE_SMALL).' '.get_lang('Courses');
foreach ($courses_in_session as $key => $courses) {
$sessionId = $key;
$session_info = api_get_session_info($sessionId);
$session_name = '';
if ($session_info) {
$session_name = $session_info['name'];
}
$access_start_date = '';
if (!empty($session_info['access_start_date']) && $session_info['access_start_date'] != '0000-00-00') {
$access_start_date = api_format_date($session_info['access_start_date'], DATE_FORMAT_SHORT);
}
if (!empty($session_info['access_start_date']) && $session_info['access_start_date'] != '0000-00-00') {
$access_start_date = api_format_date($session_info['access_start_date'], DATE_FORMAT_SHORT);
}
if (!empty($session_info['access_end_date']) && $session_info['access_end_date'] != '0000-00-00') {
$access_end_date = api_format_date($session_info['access_end_date'], DATE_FORMAT_SHORT);
}
$access_end_date = '';
if (!empty($session_info['access_end_date']) && $session_info['access_end_date'] != '0000-00-00') {
$access_end_date = api_format_date($session_info['access_end_date'], DATE_FORMAT_SHORT);
}
$date_session = '';
if (!empty($access_start_date) && !empty($access_end_date)) {
$date_session = get_lang('From') . ' ' . $access_start_date . ' ' . get_lang('Until') . ' ' . $access_end_date;
}
$title = '';
if (empty($sessionId)) {
$title = Display::return_icon('course.png', get_lang('Courses'), array(), ICON_SIZE_SMALL).' '.get_lang('Courses');
} else {
if (!empty($access_start_date) && !empty($access_end_date)) {
$date_session = get_lang('From') . ' ' . $access_start_date . ' ' . get_lang('Until') . ' ' . $access_end_date;
}
$title = Display::return_icon('session.png', get_lang('Session'), array(), ICON_SIZE_SMALL).' '.$session_name.($date_session?' ('.$date_session.')':'');
}
@ -676,62 +669,61 @@ if (!empty($student_id)) {
if (!empty($courses)) {
foreach ($courses as $courseId) {
$courseInfo = api_get_course_info_by_id($courseId);
$courseId = $courseInfo['real_id'];
$course_code = $courseInfo['code'];
if (CourseManager :: is_user_subscribed_in_course($student_id, $course_code, true)) {
$course_info = CourseManager :: get_course_information($course_code);
$courseInfoItem = api_get_course_info_by_id($courseId);
$courseId = $courseInfoItem['real_id'];
$courseCodeItem = $courseInfoItem['code'];
if (CourseManager :: is_user_subscribed_in_course($student_id, $courseCodeItem, true)) {
$time_spent_on_course = api_time_to_hms(
Tracking :: get_time_spent_on_the_course($user_info['user_id'], $courseId, $sessionId)
);
// get average of faults in attendances by student
$results_faults_avg = $attendance->get_faults_average_by_course($student_id, $course_code, $sessionId);
$results_faults_avg = $attendance->get_faults_average_by_course($student_id, $courseCodeItem, $sessionId);
if (!empty($results_faults_avg['total'])) {
if (api_is_drh()) {
$attendances_faults_avg = '<a title="'.get_lang('GoAttendance').'" href="'.api_get_path(WEB_CODE_PATH).'attendance/index.php?cidReq='.$course_code.'&id_session='.$sessionId.'&student_id='.$student_id.'">'.$results_faults_avg['faults'].'/'.$results_faults_avg['total'].' ('.$results_faults_avg['porcent'].'%)</a>';
$attendances_faults_avg =
'<a title="'.get_lang('GoAttendance').'" href="'.api_get_path(WEB_CODE_PATH).'attendance/index.php?cidReq='.$courseCodeItem.'&id_session='.$sessionId.'&student_id='.$student_id.'">'.
$results_faults_avg['faults'].'/'.$results_faults_avg['total'].' ('.$results_faults_avg['porcent'].'%)</a>';
} else {
$attendances_faults_avg = $results_faults_avg['faults'].'/'.$results_faults_avg['total'].' ('.$results_faults_avg['porcent'].'%)';
$attendances_faults_avg =
$results_faults_avg['faults'].'/'.
$results_faults_avg['total'].
' ('.$results_faults_avg['porcent'].'%)'
;
}
} else {
$attendances_faults_avg = '0/0 (0%)';
}
// Get evaluations by student
$cats = Category::load(null, null, $course_code, null, null, $sessionId);
$cats = Category::load(null, null, $courseCodeItem, null, null, $sessionId);
$scoretotal = array();
if (isset($cats) && isset($cats[0])) {
if (!empty($sessionId)) {
$scoretotal= $cats[0]->calc_score($student_id, null, $course_code, $sessionId);
$scoretotal= $cats[0]->calc_score($student_id, null, $courseCodeItem, $sessionId);
} else {
$scoretotal= $cats[0]->calc_score($student_id, null, $course_code);
$scoretotal= $cats[0]->calc_score($student_id, null, $courseCodeItem);
}
}
$scoretotal_display = '0/0 (0%)';
if (!empty($scoretotal)) {
$scoretotal_display = round(
$scoretotal[0],
1
).'/'.
round(
$scoretotal[1],
1
).' ('.
round(($scoretotal[0] / $scoretotal[1]) * 100, 2).' %)';
$scoretotal_display =
round($scoretotal[0], 1 ).'/'.
round($scoretotal[1], 1).
' ('.round(($scoretotal[0] / $scoretotal[1]) * 100, 2).' %)';
}
$progress = Tracking::get_avg_student_progress($user_info['user_id'], $course_code, null, $sessionId);
$score = Tracking :: get_avg_student_score($user_info['user_id'], $course_code, null, $sessionId);
$progress = Tracking::get_avg_student_progress($user_info['user_id'], $courseCodeItem, null, $sessionId);
$score = Tracking :: get_avg_student_score($user_info['user_id'], $courseCodeItem, null, $sessionId);
$progress = empty($progress) ? '0%' : $progress.'%';
$score = empty($score) ? '0%' : $score.'%';
$csv_content[] = array(
$session_name,
$course_info['title'],
$courseInfoItem['title'],
$time_spent_on_course,
$progress,
$score,
@ -740,7 +732,8 @@ if (!empty($student_id)) {
);
echo '<tr>
<td ><a href="' . api_get_path(WEB_COURSE_PATH) . $course_info['directory'] .'/?id_session=' . $sessionId . '">'.$course_info['title'].'</a></td>
<td ><a href="' .$courseInfoItem['course_public_url'] .'?id_session=' . $sessionId . '">'.
$courseInfoItem['title'].'</a></td>
<td >'.$time_spent_on_course .'</td>
<td >'.$progress.'</td>
<td >'.$score.'</td>
@ -748,10 +741,10 @@ if (!empty($student_id)) {
<td >'.$scoretotal_display.'</td>';
if (isset($_GET['id_coach']) && intval($_GET['id_coach']) != 0) {
echo '<td width="10"><a href="'.api_get_self().'?student='.$user_info['user_id'].'&details=true&course='.$course_info['code'].'&id_coach='.Security::remove_XSS($_GET['id_coach']).'&origin='.$origin.'&id_session='.$sessionId.'#infosStudent">
echo '<td width="10"><a href="'.api_get_self().'?student='.$user_info['user_id'].'&details=true&course='.$courseInfoItem['code'].'&id_coach='.Security::remove_XSS($_GET['id_coach']).'&origin='.$origin.'&id_session='.$sessionId.'#infosStudent">
'.Display::return_icon('2rightarrow.png', get_lang('Details')).'</a></td>';
} else {
echo '<td width="10"><a href="'.api_get_self().'?student='.$user_info['user_id'].'&details=true&course='.$course_info['code'].'&origin='.$origin.'&id_session='.$sessionId.'#infosStudent">
echo '<td width="10"><a href="'.api_get_self().'?student='.$user_info['user_id'].'&details=true&course='.$courseInfoItem['code'].'&origin='.$origin.'&id_session='.$sessionId.'#infosStudent">
'.Display::return_icon('2rightarrow.png', get_lang('Details')).'</a></td>';
}
echo '</tr>';
@ -781,25 +774,29 @@ if (!empty($student_id)) {
get_lang('LastConnexion')
);
$query = $em
->createQuery('
if (empty($sessionId)) {
$query = $em->createQuery('
SELECT lp FROM ChamiloCourseBundle:CLp lp
WHERE lp.sessionId = :session AND lp.cId = :course
WHERE lp.sessionId = 0 AND lp.cId = :course
ORDER BY lp.displayOrder ASC
');
if (empty($sessionId)) {
$query->setParameters([
'session' => 0,
'course' => $info_course['real_id']
'course' => $courseInfo['real_id']
]);
} else {
$query = $em->createQuery('
SELECT lp FROM ChamiloCourseBundle:CLp lp
WHERE lp.cId = :course
ORDER BY lp.displayOrder ASC
');
$query->setParameters([
'session' => $sessionId,
'course' => $info_course['real_id']
'course' => $courseInfo['real_id']
]);
}
$rs_lp = $query->getResult();
if (count($rs_lp) > 0) {
?>
<!-- LPs-->
@ -807,22 +804,54 @@ if (!empty($student_id)) {
<table class="table table-striped table-hover">
<thead>
<tr>
<th><?php echo get_lang('Learnpaths');?></th>
<th><?php
<th><?php echo get_lang('LearningPath');?></th>
<th>
<?php
echo get_lang('Time').' ';
Display :: display_icon('info3.gif', get_lang('TotalTimeByCourse'), array ('align' => 'absmiddle', 'hspace' => '3px')); ?></th>
<th><?php
Display:: display_icon(
'info3.gif',
get_lang('TotalTimeByCourse'),
array('align' => 'absmiddle', 'hspace' => '3px')
);
?>
</th>
<th>
<?php
echo get_lang('AverageScore').' ';
Display :: display_icon('info3.gif', get_lang('AverageIsCalculatedBasedInAllAttempts'), array ( 'align' => 'absmiddle', 'hspace' => '3px')); ?></th>
Display:: display_icon(
'info3.gif',
get_lang('AverageIsCalculatedBasedInAllAttempts'),
array('align' => 'absmiddle', 'hspace' => '3px')
);
?>
</th>
<th><?php
echo get_lang('LatestAttemptAverageScore').' ';
Display :: display_icon('info3.gif', get_lang('AverageIsCalculatedBasedInTheLatestAttempts'), array ( 'align' => 'absmiddle', 'hspace' => '3px')); ?></th>
Display::display_icon(
'info3.gif',
get_lang('AverageIsCalculatedBasedInTheLatestAttempts'),
array('align' => 'absmiddle', 'hspace' => '3px')
);
?>
</th>
<th><?php
echo get_lang('Progress').' ';
Display :: display_icon('info3.gif', get_lang('LPProgressScore'), array ('align' => 'absmiddle','hspace' => '3px')); ?></th>
Display:: display_icon(
'info3.gif',
get_lang('LPProgressScore'),
array('align' => 'absmiddle', 'hspace' => '3px')
);
?>
</th>
<th><?php
echo get_lang('LastConnexion').' ';
Display :: display_icon('info3.gif', get_lang('LastTimeTheCourseWasUsed'), array ('align' => 'absmiddle','hspace' => '3px')); ?></th>
Display:: display_icon(
'info3.gif',
get_lang('LastTimeTheCourseWasUsed'),
array('align' => 'absmiddle', 'hspace' => '3px')
);
?>
</th>
<?php
echo '<th>'.get_lang('Details').'</th>';
if (api_is_allowed_to_edit()) {
@ -900,8 +929,11 @@ if (!empty($student_id)) {
true
);
if ($i % 2 == 0) $css_class = "row_even";
else $css_class = "row_odd";
if ($i % 2 == 0) {
$css_class = "row_even";
} else {
$css_class = "row_odd";
}
$i++;
@ -925,6 +957,7 @@ if (!empty($student_id)) {
$score = $score.'%';
}
}
echo Display::tag('td', $score);
if (!is_null($score_latest)) {
@ -951,7 +984,7 @@ if (!empty($student_id)) {
$from ='&from=myspace';
}
$link = Display::url(
Display::return_icon('2rightarrow.png'),
Display::return_icon('2rightarrow.png', get_lang('Details')),
'lp_tracking.php?cidReq='.Security::remove_XSS($_GET['course']).'&course='.Security::remove_XSS($_GET['course']).$from.'&origin='.$origin.'&lp_id='.$learnpath->getId().'&student_id='.$user_info['user_id'].'&id_session='.$sessionId
);
echo Display::tag('td', $link);
@ -961,7 +994,7 @@ if (!empty($student_id)) {
echo '<td>';
if ($any_result === true) {
echo '<a href="myStudents.php?action=reset_lp&sec_token='.$token.'&cidReq='.Security::remove_XSS($_GET['course']).'&course='.Security::remove_XSS($_GET['course']).'&details='.Security::remove_XSS($_GET['details']).'&origin='.$origin.'&lp_id='.$learnpath->getId().'&student='.$user_info['user_id'].'&details=true&id_session='.$sessionId.'">';
echo Display::return_icon('clean.png',get_lang('Clean'),'',ICON_SIZE_SMALL).'</a>';
echo Display::return_icon('clean.png', get_lang('Clean'),'',ICON_SIZE_SMALL).'</a>';
echo '</a>';
}
echo '</td>';
@ -970,8 +1003,6 @@ if (!empty($student_id)) {
$data_learnpath[$i][] = $lp_name;
$data_learnpath[$i][] = $progress . '%';
}
} else {
//echo '<tr><td colspan="6">'.get_lang('NoLearnpath').'</td></tr>';
}
?>
</tbody>
@ -1006,7 +1037,7 @@ if (!empty($student_id)) {
$t_quiz = Database :: get_course_table(TABLE_QUIZ_TEST);
$sql = "SELECT quiz.title, id FROM " . $t_quiz . " AS quiz
WHERE
quiz.c_id = ".$info_course['real_id']." AND
quiz.c_id = ".$courseInfo['real_id']." AND
(quiz.session_id = $sessionId OR quiz.session_id = 0) AND
active IN (0, 1)
ORDER BY quiz.title ASC ";
@ -1016,11 +1047,33 @@ if (!empty($student_id)) {
if (Database :: num_rows($result_exercices) > 0) {
while ($exercices = Database :: fetch_array($result_exercices)) {
$exercise_id = intval($exercices['id']);
$count_attempts = Tracking::count_student_exercise_attempts($student_id, $courseInfo['real_id'], $exercise_id, 0, 0, $sessionId, 2);
$score_percentage = Tracking::get_avg_student_exercise_score($student_id, $course_code, $exercise_id, $sessionId, 1, 0);
$count_attempts = Tracking::count_student_exercise_attempts(
$student_id,
$courseInfo['real_id'],
$exercise_id,
0,
0,
$sessionId,
2
);
$score_percentage = Tracking::get_avg_student_exercise_score(
$student_id,
$course_code,
$exercise_id,
$sessionId,
1,
0
);
if (!isset($score_percentage) && $count_attempts > 0) {
$scores_lp = Tracking::get_avg_student_exercise_score($student_id, $course_code, $exercise_id, $sessionId, 2, 1);
$scores_lp = Tracking::get_avg_student_exercise_score(
$student_id,
$course_code,
$exercise_id,
$sessionId,
2,
1
);
$score_percentage = $scores_lp[0];
$lp_name = $scores_lp[1];
} else {
@ -1059,11 +1112,11 @@ if (!empty($student_id)) {
$sql = 'SELECT exe_id FROM ' . $tbl_stats_exercices . '
WHERE
exe_exo_id ="'.$exercise_id.'" AND
exe_user_id ="'.$student_id.'" AND
c_id = '.$courseInfo['real_id'].' AND
session_id ="'.$sessionId.'" AND
status = ""
exe_exo_id = "'.$exercise_id.'" AND
exe_user_id ="'.$student_id.'" AND
c_id = '.$courseInfo['real_id'].' AND
session_id ="'.$sessionId.'" AND
status = ""
ORDER BY exe_date DESC
LIMIT 1';
$result_last_attempt = Database::query($sql);
@ -1105,13 +1158,13 @@ if (!empty($student_id)) {
<?php
}
//@when using sessions we do not show the survey list
// @when using sessions we do not show the survey list
if (empty($sessionId)) {
$survey_list = SurveyManager::get_surveys($course_code, $sessionId);
$survey_data = array();
foreach($survey_list as $survey) {
$user_list = SurveyManager::get_people_who_filled_survey($survey['survey_id'], false, $info_course['real_id']);
$user_list = SurveyManager::get_people_who_filled_survey($survey['survey_id'], false, $courseInfo['real_id']);
$survey_done = Display::return_icon("accept_na.png", get_lang('NoAnswer'), array(), ICON_SIZE_SMALL);
if (in_array($student_id, $user_list)) {
$survey_done = Display::return_icon("accept.png", get_lang('Answered'), array(), ICON_SIZE_SMALL);
@ -1158,13 +1211,13 @@ if (!empty($student_id)) {
</thead>
<tbody>
<?php
$csv_content[] = array ();
$nb_assignments = Tracking::count_student_assignments($student_id, $course_code, $sessionId);
$messages = Tracking::count_student_messages($student_id, $course_code, $sessionId);
$links = Tracking::count_student_visited_links($student_id, $info_course['real_id'], $sessionId);
$chat_last_connection = Tracking::chat_last_connection($student_id, $info_course['real_id'], $sessionId);
$documents = Tracking::count_student_downloaded_documents($student_id, $info_course['real_id'], $sessionId);
$uploaded_documents = Tracking::count_student_uploaded_documents($student_id, $course_code, $sessionId);
$csv_content[] = array();
$nb_assignments = Tracking::count_student_assignments($student_id, $course_code, $sessionId);
$messages = Tracking::count_student_messages($student_id, $course_code, $sessionId);
$links = Tracking::count_student_visited_links($student_id, $courseInfo['real_id'], $sessionId);
$chat_last_connection = Tracking::chat_last_connection($student_id, $courseInfo['real_id'], $sessionId);
$documents = Tracking::count_student_downloaded_documents($student_id, $courseInfo['real_id'], $sessionId);
$uploaded_documents = Tracking::count_student_uploaded_documents($student_id, $course_code, $sessionId);
$csv_content[] = array(
get_lang('OtherTools')

@ -180,7 +180,8 @@ if ($form->validate()) {
api_get_setting('siteName')."\nT. ".
api_get_setting('administratorTelephone')."\n" .
get_lang('Email') ." : ".api_get_setting('emailAdministrator');
$emailbody = nl2br($emailbody);
api_mail_html(
api_get_person_name($userInfo['firstname'], $userInfo['lastname'], null, PERSON_NAME_EMAIL_ADDRESS),
$email,

@ -6484,7 +6484,6 @@ class learnpath
$item_title = Security::remove_XSS($item_title);
$item_description = Security::remove_XSS($item_description);
$legend = '<legend>';
if ($id != 0 && is_array($extra_info))
$parent = $extra_info['parent_item_id'];
else
@ -6518,90 +6517,101 @@ class learnpath
$arrLP = isset($this->arrMenu) ? $this->arrMenu : null;
unset ($this->arrMenu);
$form = new FormValidator('quiz_form', 'POST', api_get_self() . '?' .$_SERVER['QUERY_STRING']);
$defaults = [];
if ($action == 'add') {
$legend .= get_lang('CreateTheExercise') . '&nbsp;:';
$legend = get_lang('CreateTheExercise');
} elseif ($action == 'move') {
$legend .= get_lang('MoveTheCurrentExercise') . '&nbsp;:';
$legend = get_lang('MoveTheCurrentExercise');
} else {
$legend .= get_lang('EditCurrentExecice') . '&nbsp;:';
$legend = get_lang('EditCurrentExecice');
}
if (isset ($_GET['edit']) && $_GET['edit'] == 'true') {
$legend .= Display :: return_warning_message(get_lang('Warning') . ' ! ' . get_lang('WarningEditingDocument'));
}
$legend .= '</legend>';
$return = '';
$return .= '<div class="sectioncomment">';
$return .= '<form method="POST">';
$return .= $legend;
$return .= '<table class="lp_form">';
$form->addHeader($legend);
if ($action != 'move') {
$return .= '<tr>';
$return .= '<td class="label"><label for="idTitle">' . get_lang('Title') . '</label></td>';
$return .= '<td class="input"><input id="idTitle" name="title" size="44" type="text" value="' . $item_title . '" /></td>';
$return .= '</tr>';
$form->addText('title', get_lang('Title'), true, ['id' => 'idTitle']);
$defaults['title'] = $item_title;
}
$return .= '<tr>';
$return .= '<td class="label"><label for="idParent">' . get_lang('Parent') . '</label></td>';
$return .= '<td class="input">';
// Select for Parent item, root or chapter
$return .= '<select id="idParent" style="width:100%;" name="parent" onChange="javascript: load_cbo(this.value);" size="1">';
$return .= '<option class="top" value="0">' . $this->name . '</option>';
$selectParent = $form->addSelect(
'parent',
get_lang('Parent'),
[],
['id' => 'idParent', 'onchange' => 'load_cbo(this.value);']
);
$selectParent->addOption($this->name, 0);
$arrHide = array (
$id
);
for ($i = 0; $i < count($arrLP); $i++) {
if ($action != 'add') {
if (($arrLP[$i]['item_type'] == 'dokeos_module' || $arrLP[$i]['item_type'] == 'dokeos_chapter' || $arrLP[$i]['item_type'] == 'dir') && !in_array($arrLP[$i]['id'], $arrHide) && !in_array($arrLP[$i]['parent_item_id'], $arrHide)) {
$return .= '<option ' . (($parent == $arrLP[$i]['id']) ? 'selected="selected" ' : '') . 'style="padding-left:' . ($arrLP[$i]['depth'] * 10) . 'px;" value="' . $arrLP[$i]['id'] . '">' . $arrLP[$i]['title'] . '</option>';
if (
(
$arrLP[$i]['item_type'] == 'dokeos_module' ||
$arrLP[$i]['item_type'] == 'dokeos_chapter' ||
$arrLP[$i]['item_type'] == 'dir'
) &&
!in_array($arrLP[$i]['id'], $arrHide) &&
!in_array($arrLP[$i]['parent_item_id'], $arrHide)
) {
$selectParent->addOption(
$arrLP[$i]['title'],
$arrLP[$i]['id'],
['style' => 'padding-left: ' . (20 + $arrLP[$i]['depth'] * 20) . 'px']
);
if ($parent == $arrLP[$i]['id']) {
$selectParent->setSelected($arrLP[$i]['id']);
}
} else {
$arrHide[] = $arrLP[$i]['id'];
}
} else {
if ($arrLP[$i]['item_type'] == 'dokeos_module' || $arrLP[$i]['item_type'] == 'dokeos_chapter' || $arrLP[$i]['item_type'] == 'dir')
$return .= '<option ' . (($parent == $arrLP[$i]['id']) ? 'selected="selected" ' : '') . 'style="padding-left:' . ($arrLP[$i]['depth'] * 10) . 'px;" value="' . $arrLP[$i]['id'] . '">' . $arrLP[$i]['title'] . '</option>';
if (
$arrLP[$i]['item_type'] == 'dokeos_module' ||
$arrLP[$i]['item_type'] == 'dokeos_chapter' ||
$arrLP[$i]['item_type'] == 'dir'
) {
$selectParent->addOption(
$arrLP[$i]['title'],
$arrLP[$i]['id'], ['style' => 'padding-left: ' . (20 + $arrLP[$i]['depth'] * 20) . 'px']
);
if ($parent == $arrLP[$i]['id']) {
$selectParent->setSelected($arrLP[$i]['id']);
}
}
}
}
if (is_array($arrLP)) {
reset($arrLP);
}
$return .= '</select>';
$return .= '</td>';
$return .= '</tr>';
$return .= '<tr>';
$return .= '<td class="label"><label for="previous">' . get_lang('Position') . '</label></td>';
$return .= '<td class="input">';
$selectPrevious = $form->addSelect('previous', get_lang('Position'), [], ['id' => 'previous']);
$selectPrevious->addOption(get_lang('FirstPosition'), 0);
$return .= '<select class="learnpath_item_form" style="width:100%;" id="previous" name="previous" size="1">';
$return .= '<option class="top" value="0">' . get_lang('FirstPosition') . '</option>';
for ($i = 0; $i < count($arrLP); $i++) {
if ($arrLP[$i]['parent_item_id'] == $parent && $arrLP[$i]['id'] != $id) {
$selectPrevious->addOption(get_lang('After') . ' "' . $arrLP[$i]['title'] . '"', $arrLP[$i]['id']);
if (is_array($extra_info)) {
if ($extra_info['previous_item_id'] == $arrLP[$i]['id']) {
$selected = 'selected="selected" ';
$selectPrevious->setSelected($arrLP[$i]['id']);
}
} elseif ($action == 'add') {
$selected = 'selected="selected" ';
} else {
$selected = '';
$selectPrevious->setSelected($arrLP[$i]['id']);
}
$return .= '<option ' . $selected . 'value="' . $arrLP[$i]['id'] . '">' . get_lang('After') . ' "' . $arrLP[$i]['title'] . '"</option>';
}
}
$return .= '</select>';
$return .= '</td>';
$return .= '</tr>';
if ($action != 'move') {
$id_prerequisite = 0;
if (is_array($arrLP)) {
@ -6644,7 +6654,6 @@ class learnpath
$return .= "</select></td>";
*/
$return .= '</tr>';
/*$return .= '<tr>';
$return .= '<td class="label"><label for="maxTimeAllowed">' . get_lang('MaxTimeAllowed') . '</label></td>';
$return .= '<td class="input"><input name="maxTimeAllowed" style="width:98%;" id="maxTimeAllowed" value="' . $extra_info['max_time_allowed'] . '" /></td>';
@ -6656,34 +6665,29 @@ class learnpath
$return .= '</tr>'; */
}
$return .= '<tr>';
if ($action == 'add') {
$return .= '<td>&nbsp;</td><td><button class="save" name="submit_button" type="submit">' . get_lang('AddExercise') . '</button></td>';
$form->addButtonSave(get_lang('AddExercise'), 'submit_button');
} else {
$return .= '<td>&nbsp;</td><td><button class="save" name="submit_button" type="submit">' . get_lang('EditCurrentExecice') . '</button></td>';
$form->addButtonSave(get_lang('EditCurrentExecice'), 'submit_button');
}
$return .= '</tr>';
$return .= '</table>';
if ($action == 'move') {
$return .= '<input name="title" type="hidden" value="' . $item_title . '" />';
$return .= '<input name="description" type="hidden" value="' . $item_description . '" />';
$form->addHidden('title', $item_title);
$form->addHidden('description', $item_description);
}
if (is_numeric($extra_info)) {
$return .= '<input name="path" type="hidden" value="' . $extra_info . '" />';
$form->addHidden('path', $extra_info);
} elseif (is_array($extra_info)) {
$return .= '<input name="path" type="hidden" value="' . $extra_info['path'] . '" />';
$form->addHidden('path', $extra_info['path']);
}
$return .= '<input name="type" type="hidden" value="' . TOOL_QUIZ . '" />';
$return .= '<input name="post_time" type="hidden" value="' . time() . '" />';
$form->addHidden('type', TOOL_QUIZ);
$form->addHidden('post_time', time());
$return .= '</form>';
$return .= '</div>';
$form->setDefaults($defaults);
return $return;
return '<div class="sectioncomment">' . $form->returnForm() . '</div>';
}
/**
@ -6899,8 +6903,6 @@ class learnpath
$item_description = '';
}
$legend = '<legend>';
if ($id != 0 && is_array($extra_info)) {
$parent = $extra_info['parent_item_id'];
} else {
@ -6936,30 +6938,32 @@ class learnpath
$arrLP = isset($this->arrMenu) ? $this->arrMenu : null;
unset($this->arrMenu);
if ($action == 'add')
$legend .= get_lang('CreateTheForum') . '&nbsp;:';
elseif ($action == 'move') $legend .= get_lang('MoveTheCurrentForum') . '&nbsp;:';
else
$legend .= get_lang('EditCurrentForum') . '&nbsp;:';
if ($action == 'add') {
$legend = get_lang('CreateTheForum');
} elseif ($action == 'move') {
$legend = get_lang('MoveTheCurrentForum');
} else {
$legend = get_lang('EditCurrentForum');
}
$legend .= '</legend>';
$return = '<div class="sectioncomment">';
$return .= '<form method="POST">';
$return .= $legend;
$return .= '<table class="lp_form">';
$form = new FormValidator('forum_form', 'POST', api_get_self() . '?' .$_SERVER['QUERY_STRING']);
$defaults = [];
$form->addHeader($legend);
if ($action != 'move') {
$return .= '<tr>';
$return .= '<td class="label"><label for="idTitle">' . get_lang('Title') . '</label></td>';
$return .= '<td class="input"><input id="idTitle" size="44" name="title" type="text" value="' . $item_title . '" class="learnpath_item_form" /></td>';
$return .= '</tr>';
$form->addText('title', get_lang('Title'), true, ['id' => 'idTitle', 'class' => 'learnpath_item_form']);
$defaults['title'] = $item_title;
}
$return .= '<tr>';
$return .= '<td class="label"><label for="idParent">' . get_lang('Parent') . '</label></td>';
$return .= '<td class="input">';
$return .= '<select id="idParent" style="width:100%;" name="parent" onChange="javascript: load_cbo(this.value);" class="learnpath_item_form" size="1">';
$return .= '<option class="top" value="0">' . $this->name . '</option>';
$selectParent = $form->addSelect(
'parent',
get_lang('Parent'),
[],
['id' => 'idParent', 'onchange' => 'load_cbo(this.value);', 'class' => 'learnpath_item_form']
);
$selectParent->addOption($this->name, 0);
$arrHide = array(
$id
);
@ -6968,47 +6972,61 @@ class learnpath
for ($i = 0; $i < count($arrLP); $i++) {
if ($action != 'add') {
if (($arrLP[$i]['item_type'] == 'dokeos_module' || $arrLP[$i]['item_type'] == 'dokeos_chapter' || $arrLP[$i]['item_type'] == 'dir') && !in_array($arrLP[$i]['id'], $arrHide) && !in_array($arrLP[$i]['parent_item_id'], $arrHide)) {
$return .= '<option ' . (($parent == $arrLP[$i]['id']) ? 'selected="selected" ' : '') . 'style="padding-left:' . ($arrLP[$i]['depth'] * 10) . 'px;" value="' . $arrLP[$i]['id'] . '">' . $arrLP[$i]['title'] . '</option>';
$selectParent->addOption(
$arrLP[$i]['title'],
$arrLP[$i]['id'],
['style' => 'padding-left: ' . (20 + $arrLP[$i]['depth'] * 20) . 'px']
);
if ($parent == $arrLP[$i]['id']) {
$selectParent->setSelected($arrLP[$i]['id']);
}
} else {
$arrHide[] = $arrLP[$i]['id'];
}
} else {
if ($arrLP[$i]['item_type'] == 'dokeos_module' || $arrLP[$i]['item_type'] == 'dokeos_chapter' || $arrLP[$i]['item_type'] == 'dir')
$return .= '<option ' . (($parent == $arrLP[$i]['id']) ? 'selected="selected" ' : '') . 'style="padding-left:' . ($arrLP[$i]['depth'] * 10) . 'px;" value="' . $arrLP[$i]['id'] . '">' . $arrLP[$i]['title'] . '</option>';
if (
$arrLP[$i]['item_type'] == 'dokeos_module' ||
$arrLP[$i]['item_type'] == 'dokeos_chapter' ||
$arrLP[$i]['item_type'] == 'dir'
) {
$selectParent->addOption(
$arrLP[$i]['title'],
$arrLP[$i]['id'],
['style' => 'padding-left: ' . (20 + $arrLP[$i]['depth'] * 20) . 'px']
);
if ($parent == $arrLP[$i]['id']) {
$selectParent->setSelected($arrLP[$i]['id']);
}
}
}
}
if (is_array($arrLP)) {
reset($arrLP);
}
$return .= '</select>';
$return .= '</td>';
$return .= '</tr>';
$return .= '<tr>';
$return .= '<td class="label"><label for="previous">' . get_lang('Position') . '</label></td>';
$return .= '<td class="input">';
$return .= '<select id="previous" name="previous" style="width:100%;" size="1" class="learnpath_item_form">';
$return .= '<option class="top" value="0">' . get_lang('FirstPosition') . '</option>';
$selectPrevious = $form->addSelect(
'previous',
get_lang('Position'),
[],
['id' => 'previous', 'class' => 'learnpath_item_form']
);
$selectPrevious->addOption(get_lang('FirstPosition'), 0);
for ($i = 0; $i < count($arrLP); $i++) {
if ($arrLP[$i]['parent_item_id'] == $parent && $arrLP[$i]['id'] != $id) {
if ($extra_info['previous_item_id'] == $arrLP[$i]['id'])
$selected = 'selected="selected" ';
elseif ($action == 'add') $selected = 'selected="selected" ';
else
$selected = '';
$selectPrevious->addOption(get_lang('After') . ' "' . $arrLP[$i]['title'] . '"', $arrLP[$i]['id']);
$return .= '<option ' . $selected . 'value="' . $arrLP[$i]['id'] . '">' .
get_lang('After') . ' "' . $arrLP[$i]['title'] . '"</option>';
if (isset($extra_info['previous_item_id']) && $extra_info['previous_item_id'] == $arrLP[$i]['id']) {
$selectPrevious->setSelected($arrLP[$i]['id']);
} elseif ($action == 'add') {
$selectPrevious->setSelected($arrLP[$i]['id']);
}
}
}
$return .= '</select>';
$return .= '</td>';
$return .= '</tr>';
if ($action != 'move') {
$return .= '<tr>';
$return .= '</tr>';
$id_prerequisite = 0;
if (is_array($arrLP)) {
foreach ($arrLP as $key => $value) {
@ -7022,40 +7040,35 @@ class learnpath
$arrHide = array();
for ($i = 0; $i < count($arrLP); $i++) {
if ($arrLP[$i]['id'] != $id && $arrLP[$i]['item_type'] != 'dokeos_chapter') {
if ($extra_info['previous_item_id'] == $arrLP[$i]['id'])
if (isset($extra_info['previous_item_id']) && $extra_info['previous_item_id'] == $arrLP[$i]['id'])
$s_selected_position = $arrLP[$i]['id'];
elseif ($action == 'add') $s_selected_position = 0;
$arrHide[$arrLP[$i]['id']]['value'] = $arrLP[$i]['title'];
}
}
$return .= '</tr>';
}
$return .= '<tr>';
if ($action == 'add') {
$return .= '<td>&nbsp;</td><td><button class="save" name="submit_button" type="submit"> ' . get_lang('AddForumToCourse') . ' </button></td>';
$form->addButtonSave(get_lang('AddForumToCourse'), 'submit_button');
} else {
$return .= '<td>&nbsp;</td><td><button class="save" name="submit_button" type="submit"> ' . get_lang('EditCurrentForum') . ' </button></td>';
$form->addButtonSave(get_lang('EditCurrentForum'), 'submit_button');
}
$return .= '</tr>';
$return .= '</table>';
if ($action == 'move') {
$return .= '<input name="title" type="hidden" value="' . $item_title . '" />';
$return .= '<input name="description" type="hidden" value="' . $item_description . '" />';
$form->addHidden('title', $item_title);
$form->addHidden('description', $item_description);
}
if (is_numeric($extra_info)) {
$return .= '<input name="path" type="hidden" value="' . $extra_info . '" />';
$form->addHidden('path', $extra_info);
} elseif (is_array($extra_info)) {
$return .= '<input name="path" type="hidden" value="' . $extra_info['path'] . '" />';
$form->addHidden('path', $extra_info['path']);
}
$return .= '<input name="type" type="hidden" value="' . TOOL_FORUM . '" />';
$return .= '<input name="post_time" type="hidden" value="' . time() . '" />';
$return .= '</form>';
$return .= '</div>';
$form->addHidden('type', TOOL_FORUM);
$form->addHidden('post_time', time());
$form->setDefaults($defaults);
return $return;
return '<div class="sectioncomment">' . $form->returnForm() . '</div>';
}
/**
@ -7090,8 +7103,6 @@ class learnpath
$item_description = '';
}
$return = null;
if ($id != 0 && is_array($extra_info)) {
$parent = $extra_info['parent_item_id'];
} else {
@ -7127,33 +7138,69 @@ class learnpath
$arrLP = isset($this->arrMenu) ? $this->arrMenu : null;
unset ($this->arrMenu);
$return .= '<form method="POST">';
if ($action == 'add')
$return .= '<legend>' . get_lang('CreateTheForum') . '</legend>';
elseif ($action == 'move') $return .= '<p class="lp_title">' . get_lang('MoveTheCurrentForum') . '&nbsp;:</p>';
else
$return .= '<legend>' . get_lang('EditCurrentForum') . '</legend>';
$form = new FormValidator('thread_form', 'POST', api_get_self() . '?' .$_SERVER['QUERY_STRING']);
$defaults = [];
if ($action == 'add') {
$legend = get_lang('CreateTheForum');
} elseif ($action == 'move') {
$legend = get_lang('MoveTheCurrentForum');
} else {
$legend = get_lang('EditCurrentForum');
}
$form->addHeader($legend);
$selectParent = $form->addSelect(
'parent',
get_lang('Parent'),
[],
['id' => 'idParent', 'onchange' => 'load_cbo(this.value);']
);
$selectParent->addOption($this->name, 0);
$return .= '<table cellpadding="0" cellspacing="0" class="lp_form">';
$return .= '<tr>';
$return .= '<td class="label"><label for="idParent">' . get_lang('Parent') . '</label></td>';
$return .= '<td class="input">';
$return .= '<select id="idParent" name="parent" onChange="javascript: load_cbo(this.value);" size="1">';
$return .= '<option class="top" value="0">' . $this->name . '</option>';
$arrHide = array (
$id
);
for ($i = 0; $i < count($arrLP); $i++) {
if ($action != 'add') {
if (($arrLP[$i]['item_type'] == 'dokeos_module' || $arrLP[$i]['item_type'] == 'dokeos_chapter' || $arrLP[$i]['item_type'] == 'dir') && !in_array($arrLP[$i]['id'], $arrHide) && !in_array($arrLP[$i]['parent_item_id'], $arrHide)) {
$return .= '<option ' . (($parent == $arrLP[$i]['id']) ? 'selected="selected" ' : '') . 'style="padding-left:' . ($arrLP[$i]['depth'] * 10) . 'px;" value="' . $arrLP[$i]['id'] . '">' . $arrLP[$i]['title'] . '</option>';
if (
(
$arrLP[$i]['item_type'] == 'dokeos_module' ||
$arrLP[$i]['item_type'] == 'dokeos_chapter' ||
$arrLP[$i]['item_type'] == 'dir'
) &&
!in_array($arrLP[$i]['id'], $arrHide) &&
!in_array($arrLP[$i]['parent_item_id'], $arrHide)
) {
$selectParent->addOption(
$arrLP[$i]['title'],
$arrLP[$i]['id'],
['style' => 'padding-left: ' . (20 + $arrLP[$i]['depth'] * 20) . 'px']
);
if ($parent == $arrLP[$i]['id']) {
$selectParent->setSelected($arrLP[$i]['id']);
}
} else {
$arrHide[] = $arrLP[$i]['id'];
}
} else {
if ($arrLP[$i]['item_type'] == 'dokeos_module' || $arrLP[$i]['item_type'] == 'dokeos_chapter' || $arrLP[$i]['item_type'] == 'dir')
$return .= '<option ' . (($parent == $arrLP[$i]['id']) ? 'selected="selected" ' : '') . 'style="padding-left:' . ($arrLP[$i]['depth'] * 10) . 'px;" value="' . $arrLP[$i]['id'] . '">' . $arrLP[$i]['title'] . '</option>';
if (
$arrLP[$i]['item_type'] == 'dokeos_module' ||
$arrLP[$i]['item_type'] == 'dokeos_chapter' ||
$arrLP[$i]['item_type'] == 'dir'
) {
$selectParent->addOption(
$arrLP[$i]['title'],
$arrLP[$i]['id'],
['style' => 'padding-left: ' . (20 + $arrLP[$i]['depth'] * 20) . 'px']
);
if ($parent == $arrLP[$i]['id']) {
$selectParent->setSelected($arrLP[$i]['id']);
}
}
}
}
@ -7161,35 +7208,27 @@ class learnpath
reset($arrLP);
}
$return .= '</select>';
$return .= '</td>';
$return .= '</tr>';
$return .= '<tr>';
$return .= '<td class="label"><label for="previous">' . get_lang('Position') . '</label></td>';
$return .= '<td class="input">';
$return .= '<select id="previous" name="previous" size="1">';
$return .= '<option class="top" value="0">' . get_lang('FirstPosition') . '</option>';
$selectPrevious = $form->addSelect('previous', get_lang('Position'), [], ['id' => 'previous']);
$selectPrevious->addOption(get_lang('FirstPosition'), 0);
for ($i = 0; $i < count($arrLP); $i++) {
if ($arrLP[$i]['parent_item_id'] == $parent && $arrLP[$i]['id'] != $id) {
if ($extra_info['previous_item_id'] == $arrLP[$i]['id'])
$selected = 'selected="selected" ';
elseif ($action == 'add') $selected = 'selected="selected" ';
else
$selected = '';
$selectPrevious->addOption(
get_lang('After') . ' "' . $arrLP[$i]['title'] . '"',
$arrLP[$i]['id']
);
$return .= '<option ' . $selected . 'value="' . $arrLP[$i]['id'] . '">' . get_lang('After') . ' "' . $arrLP[$i]['title'] . '"</option>';
if ($extra_info['previous_item_id'] == $arrLP[$i]['id']) {
$selectPrevious->setSelected($arrLP[$i]['id']);
} elseif ($action == 'add') {
$selectPrevious->setSelected($arrLP[$i]['id']);
}
}
}
$return .= '</select>';
$return .= '</td>';
$return .= '</tr>';
if ($action != 'move') {
$return .= '<tr>';
$return .= '<td class="label"><label for="idTitle">' . get_lang('Title') . '</label></td>';
$return .= '<td class="input"><input id="idTitle" name="title" type="text" value="' . $item_title . '" /></td>';
$return .= '</tr>';
$return .= '<tr>';
$return .= '</tr>';
$form->addText('title', get_lang('Title'), true, ['id' => 'idTitle']);
$defaults['title'] = $item_title;
$id_prerequisite = 0;
if ($arrLP != null) {
@ -7202,6 +7241,8 @@ class learnpath
}
$arrHide = array();
$s_selected_position = 0;
for ($i = 0; $i < count($arrLP); $i++) {
if ($arrLP[$i]['id'] != $id && $arrLP[$i]['item_type'] != 'dokeos_chapter') {
if ($extra_info['previous_item_id'] == $arrLP[$i]['id'])
@ -7212,48 +7253,44 @@ class learnpath
}
}
$return .= '<tr>';
$return .= '<td class="label"><label for="idPrerequisites">' . get_lang('LearnpathPrerequisites') . '</label></td>';
$return .= '<td class="input"><select name="prerequisites" id="prerequisites"><option value="0">' . get_lang('NoPrerequisites') . '</option>';
$selectPrerequisites = $form->addSelect(
'prerequisites',
get_lang('LearnpathPrerequisites'),
[],
['id' => 'prerequisites']
);
$selectPrerequisites->addOption(get_lang('NoPrerequisites'), 0);
foreach ($arrHide as $key => $value) {
$selectPrerequisites->addOption($value['value'], $key);
if ($key == $s_selected_position && $action == 'add') {
$return .= '<option value="' . $key . '" selected="selected">' . $value['value'] . '</option>';
}
elseif ($key == $id_prerequisite && $action == 'edit') {
$return .= '<option value="' . $key . '" selected="selected">' . $value['value'] . '</option>';
} else {
$return .= '<option value="' . $key . '">' . $value['value'] . '</option>';
$selectPrerequisites->setSelected($key);
} elseif ($key == $id_prerequisite && $action == 'edit') {
$selectPrerequisites->setSelected($key);
}
}
$return .= "</select></td>";
$return .= '</tr>';
}
$return .= '<tr>';
$return .= '<td></td><td>
<button class="save" name="submit_button" type="submit" value="'.get_lang('Ok').'" />'.get_lang('Ok').'</button></td>';
$return .= '</tr>';
$return .= '</table>';
$form->addButtonSave(get_lang('Ok'), 'submit_button');
if ($action == 'move') {
$return .= '<input name="title" type="hidden" value="' . $item_title . '" />';
$return .= '<input name="description" type="hidden" value="' . $item_description . '" />';
$form->addHidden('title', $item_title);
$form->addHidden('description', $item_description);
}
if (is_numeric($extra_info)) {
$return .= '<input name="path" type="hidden" value="' . $extra_info . '" />';
$form->addHidden('path', $extra_info);
}
elseif (is_array($extra_info)) {
$return .= '<input name="path" type="hidden" value="' . $extra_info['path'] . '" />';
$form->addHidden('path', $extra_info['path']);
}
$return .= '<input name="type" type="hidden" value="' . TOOL_THREAD . '" />';
$return .= '<input name="post_time" type="hidden" value="' . time() . '" />';
$return .= '</form>';
$return .= '</div>';
$form->addHidden('type', TOOL_THREAD);
$form->addHidden('post_time', time());
$form->setDefaults($defaults);
return $return;
return $form->returnForm();
}
/**
@ -7341,7 +7378,7 @@ class learnpath
//$arrHide = array($id);
$arrHide[0]['value'] = Security :: remove_XSS($this->name);
$arrHide[0]['padding'] = 3;
$arrHide[0]['padding'] = 20;
$charset = api_get_system_encoding();
if ($item_type != 'module' && $item_type != 'dokeos_module') {
@ -7349,7 +7386,7 @@ class learnpath
if ($action != 'add') {
if (($arrLP[$i]['item_type'] == 'dokeos_module' || $arrLP[$i]['item_type'] == 'dokeos_chapter' || $arrLP[$i]['item_type'] == 'dir') && !in_array($arrLP[$i]['id'], $arrHide) && !in_array($arrLP[$i]['parent_item_id'], $arrHide)) {
$arrHide[$arrLP[$i]['id']]['value'] = $arrLP[$i]['title'];
$arrHide[$arrLP[$i]['id']]['padding'] = 3 + $arrLP[$i]['depth'] * 10;
$arrHide[$arrLP[$i]['id']]['padding'] = 20 + $arrLP[$i]['depth'] * 20;
if ($parent == $arrLP[$i]['id']) {
$s_selected_parent = $arrHide[$arrLP[$i]['id']];
}
@ -7357,7 +7394,7 @@ class learnpath
} else {
if ($arrLP[$i]['item_type'] == 'dokeos_module' || $arrLP[$i]['item_type'] == 'dokeos_chapter' || $arrLP[$i]['item_type'] == 'dir') {
$arrHide[$arrLP[$i]['id']]['value'] = $arrLP[$i]['title'];
$arrHide[$arrLP[$i]['id']]['padding'] = 3 + $arrLP[$i]['depth'] * 10;
$arrHide[$arrLP[$i]['id']]['padding'] = 20 + $arrLP[$i]['depth'] * 20;
if ($parent == $arrLP[$i]['id']) {
$s_selected_parent = $arrHide[$arrLP[$i]['id']];
}
@ -7596,13 +7633,13 @@ class learnpath
}
$arrHide[0]['value'] = $this->name;
$arrHide[0]['padding'] = 3;
$arrHide[0]['padding'] = 20;
for ($i = 0; $i < count($arrLP); $i++) {
if ($action != 'add') {
if (($arrLP[$i]['item_type'] == 'dokeos_module' || $arrLP[$i]['item_type'] == 'dokeos_chapter' || $arrLP[$i]['item_type'] == 'dir') && !in_array($arrLP[$i]['id'], $arrHide) && !in_array($arrLP[$i]['parent_item_id'], $arrHide)) {
$arrHide[$arrLP[$i]['id']]['value'] = $arrLP[$i]['title'];
$arrHide[$arrLP[$i]['id']]['padding'] = 3 + $arrLP[$i]['depth'] * 10;
$arrHide[$arrLP[$i]['id']]['padding'] = 20 + $arrLP[$i]['depth'] * 20;
if ($parent == $arrLP[$i]['id']) {
$s_selected_parent = $arrHide[$arrLP[$i]['id']];
}
@ -7610,7 +7647,7 @@ class learnpath
} else {
if ($arrLP[$i]['item_type'] == 'dokeos_module' || $arrLP[$i]['item_type'] == 'dokeos_chapter' || $arrLP[$i]['item_type'] == 'dir') {
$arrHide[$arrLP[$i]['id']]['value'] = $arrLP[$i]['title'];
$arrHide[$arrLP[$i]['id']]['padding'] = 3 + $arrLP[$i]['depth'] * 10;
$arrHide[$arrLP[$i]['id']]['padding'] = 20 + $arrLP[$i]['depth'] * 20;
if ($parent == $arrLP[$i]['id']) {
$s_selected_parent = $arrHide[$arrLP[$i]['id']];
}
@ -7618,7 +7655,7 @@ class learnpath
}
}
$parent_select = $form->addElement('select', 'parent', get_lang('Parent'), '', 'class="form-control" id="idParent" " onchange="javascript: load_cbo(this.value);"');
$parent_select = $form->addSelect('parent', get_lang('Parent'), [], ['id' => 'idParent', 'onchange' => 'javascript: load_cbo(this.value);']);
$my_count=0;
foreach ($arrHide as $key => $value) {
if ($my_count!=0) {
@ -7656,11 +7693,11 @@ class learnpath
}
}
$position = $form->addElement('select', 'previous', get_lang('Position'), '', 'id="previous" class="form-control"');
$position = $form->addSelect('previous', get_lang('Position'), [], ['id' => 'previous']);
$position->addOption(get_lang('FirstPosition'), 0);
foreach ($arrHide as $key => $value) {
$padding = isset($value['padding']) ? $value['padding']: 0;
$padding = isset($value['padding']) ? $value['padding']: 20;
$position->addOption($value['value'], $key, 'style="padding-left:' . $padding . 'px;"');
}
@ -7827,7 +7864,8 @@ class learnpath
$item_url = '';
}
$legend = '<legend>';
$form = new FormValidator('edit_link', 'POST', api_get_self() . '?' .$_SERVER['QUERY_STRING']);
$defaults = [];
if ($id != 0 && is_array($extra_info)) {
$parent = $extra_info['parent_item_id'];
@ -7862,47 +7900,69 @@ class learnpath
$arrLP = isset($this->arrMenu) ? $this->arrMenu : null;
unset ($this->arrMenu);
if ($action == 'add')
$legend .= get_lang('CreateTheLink') . '&nbsp;:';
elseif ($action == 'move') $legend .= get_lang('MoveCurrentLink') . '&nbsp;:';
else
$legend .= get_lang('EditCurrentLink') . '&nbsp;:';
$legend .= '</legend>';
if ($action == 'add') {
$legend = get_lang('CreateTheLink');
} elseif ($action == 'move') {
$legend = get_lang('MoveCurrentLink');
} else {
$legend = get_lang('EditCurrentLink');
}
$return = '<div class="sectioncomment">';
$return .= '<form method="POST">';
$return .= $legend;
$return .= '<table>';
$form->addHeader($legend);
if ($action != 'move') {
$return .= '<tr>';
$return .= '<td class="label"><label for="idTitle">' . get_lang('Title') . '</label></td>';
$return .= '<td class="input"><input id="idTitle" name="title" size="44" type="text" value="' . $item_title . '" class="learnpath_item_form"/></td>';
$return .= '</tr>';
$form->addText('title', get_lang('Title'), true, ['class' => 'learnpath_item_form']);
$defaults['title'] = $item_title;
}
$return .= '<tr>';
$return .= '<td class="label"><label for="idParent">' . get_lang('Parent') . '</label></td>';
$return .= '<td class="input">';
$return .= '<select id="idParent" style="width:100%;" name="parent" onChange="javascript: load_cbo(this.value);" class="learnpath_item_form" size="1">';
$return .= '<option class="top" value="0">' . $this->name . '</option>';
$selectParent = $form->addSelect(
'parent',
get_lang('Parent'),
[],
['id' => 'idParent', 'onchange' => 'load_cbo(this.value);', 'class' => 'learnpath_item_form']
);
$selectParent->addOption($this->name, 0);
$arrHide = array(
$id
);
$parent_item_id = $_SESSION['parent_item_id'];
$parent_item_id = isset($_SESSION['parent_item_id']) ? $_SESSION['parent_item_id'] : 0;
for ($i = 0; $i < count($arrLP); $i++) {
if ($action != 'add') {
if (($arrLP[$i]['item_type'] == 'dokeos_module' || $arrLP[$i]['item_type'] == 'dokeos_chapter' || $arrLP[$i]['item_type'] == 'dir') && !in_array($arrLP[$i]['id'], $arrHide) && !in_array($arrLP[$i]['parent_item_id'], $arrHide)) {
$return .= '<option ' . (($parent == $arrLP[$i]['id']) ? 'selected="selected" ' : '') . 'style="padding-left:' . ($arrLP[$i]['depth'] * 10) . 'px;" value="' . $arrLP[$i]['id'] . '">' . $arrLP[$i]['title'] . '</option>';
if (
(
$arrLP[$i]['item_type'] == 'dokeos_module' ||
$arrLP[$i]['item_type'] == 'dokeos_chapter' ||
$arrLP[$i]['item_type'] == 'dir'
) &&
!in_array($arrLP[$i]['id'], $arrHide) &&
!in_array($arrLP[$i]['parent_item_id'], $arrHide)
) {
$selectParent->addOption(
$arrLP[$i]['title'],
$arrLP[$i]['id'],
['style' => 'padding-left: ' . (20 + $arrLP[$i]['depth'] * 20) . 'px;']
);
if ($parent == $arrLP[$i]['id']) {
$selectParent->setSelected($arrLP[$i]['id']);
}
} else {
$arrHide[] = $arrLP[$i]['id'];
}
} else {
if ($arrLP[$i]['item_type'] == 'dokeos_module' || $arrLP[$i]['item_type'] == 'dokeos_chapter' || $arrLP[$i]['item_type'] == 'dir')
$return .= '<option ' . (($parent_item_id == $arrLP[$i]['id']) ? 'selected="selected" ' : '') . 'style="padding-left:' . ($arrLP[$i]['depth'] * 10) . 'px;" value="' . $arrLP[$i]['id'] . '">' . $arrLP[$i]['title'] . '</option>';
if ($arrLP[$i]['item_type'] == 'dokeos_module' || $arrLP[$i]['item_type'] == 'dokeos_chapter' || $arrLP[$i]['item_type'] == 'dir') {
$selectParent->addOption(
$arrLP[$i]['title'],
$arrLP[$i]['id'],
['style' => 'padding-left: ' . (20 + $arrLP[$i]['depth'] * 20) . 'px']
);
if ($parent_item_id == $arrLP[$i]['id']) {
$selectParent->setSelected($arrLP[$i]['id']);
}
}
}
}
@ -7910,36 +7970,36 @@ class learnpath
reset($arrLP);
}
$return .= '</select>';
$return .= '</td>';
$return .= '</tr>';
$return .= '<tr>';
$return .= '<td class="label"><label for="previous">' . get_lang('Position') . '</label></td>';
$return .= '<td class="input">';
$selectPrevious = $form->addSelect(
'previous',
get_lang('Position'),
[],
['id' => 'previous', 'class' => 'learnpath_item_form']
);
$selectPrevious->addOption(get_lang('FirstPosition'), 0);
$return .= '<select id="previous" name="previous" style="width:100%;" size="1" class="learnpath_item_form">';
$return .= '<option class="top" value="0">' . get_lang('FirstPosition') . '</option>';
for ($i = 0; $i < count($arrLP); $i++) {
if ($arrLP[$i]['parent_item_id'] == $parent && $arrLP[$i]['id'] != $id) {
if ($extra_info['previous_item_id'] == $arrLP[$i]['id'])
$selected = 'selected="selected" ';
elseif ($action == 'add')
$selected = 'selected="selected" ';
else
$selected = '';
$selectPrevious->addOption($arrLP[$i]['title'], $arrLP[$i]['id']);
$return .= '<option ' . $selected . 'value="' . $arrLP[$i]['id'] . '">' . get_lang('After') . ' "' . $arrLP[$i]['title'] . '"</option>';
if ($extra_info['previous_item_id'] == $arrLP[$i]['id']) {
$selectPrevious->setSelected($arrLP[$i]['id']);
} elseif ($action == 'add') {
$selectPrevious->setSelected($arrLP[$i]['id']);
}
}
}
$return .= '</select>';
$return .= '</td>';
$return .= '</tr>';
if ($action != 'move') {
$return .= '<tr>';
$return .= '<td class="label"><label for="idURL">' . get_lang('Url') . '</label></td>';
$return .= '<td class="input"><input' . (is_numeric($extra_info) ? ' disabled="disabled"' : '') . ' id="idURL" name="url" style="width:99%;" type="text" value="' . $item_url . '" class="learnpath_item_form" /></td>';
$return .= '</tr>';
$urlAttributes = ['class' => 'learnpath_item_form'];
if (is_numeric($extra_info)) {
$urlAttributes['disabled'] = 'disabled';
}
$form->addElement('url', 'url', get_lang('Url'), $urlAttributes);
$defaults['url'] = $item_url;
$id_prerequisite = 0;
if (is_array($arrLP)) {
foreach ($arrLP as $key => $value) {
@ -7960,34 +8020,30 @@ class learnpath
}
}
$return .= '</tr>';
}
$return .= '<tr>';
if ($action == 'add') {
$return .= '<td>&nbsp;</td><td><button class="save" name="submit_button" type="submit">' . get_lang('AddLinkToCourse') . '</button></td>';
$form->addButtonSave(get_lang('AddLinkToCourse'), 'submit_button');
} else {
$return .= '<td>&nbsp;</td><td><button class="save" name="submit_button" type="submit">' . get_lang('EditCurrentLink') . '</button></td>';
$form->addButtonSave(get_lang('EditCurrentLink'), 'submit_button');
}
$return .= '</tr>';
$return .= '</table>';
if ($action == 'move') {
$return .= '<input name="title" type="hidden" value="' . $item_title . '" />';
$return .= '<input name="description" type="hidden" value="' . $item_description . '" />';
$form->addHidden('title', $item_title);
$form->addHidden('description', $item_description);
}
if (is_numeric($extra_info)) {
$return .= '<input name="path" type="hidden" value="' . $extra_info . '" />';
$form->addHidden('path', $extra_info);
} elseif (is_array($extra_info)) {
$return .= '<input name="path" type="hidden" value="' . $extra_info['path'] . '" />';
$form->addHidden('path', $extra_info['path']);
}
$return .= '<input name="type" type="hidden" value="' . TOOL_LINK . '" />';
$return .= '<input name="post_time" type="hidden" value="' . time() . '" />';
$return .= '</form>';
$return .= '</div>';
$form->addHidden('type', TOOL_LINK);
$form->addHidden('post_time', time());
return $return;
$form->setDefaults($defaults);
return '<div class="sectioncomment">' . $form->returnForm() . '</div>';
}
/**
@ -8847,7 +8903,15 @@ class learnpath
//First add link
$return .= '<li class="lp_resource_element">';
$return .= Display::return_icon('forum_new_small.gif');
$return .= '<a href="' . api_get_path(WEB_CODE_PATH) . 'forum/index.php?' . api_get_cidreq() . '&action=add&content=forum&origin=learnpath&lp_id=' . $this->lp_id . '" title="' . get_lang('CreateANewForum') . '">' . get_lang('CreateANewForum') . '</a>';
$return .= Display::url(
get_lang('CreateANewForum'),
api_get_path(WEB_CODE_PATH) . 'forum/index.php?' . api_get_cidreq() . '&' . http_build_query([
'action' => 'add',
'content' => 'forum',
'lp_id' => $this->lp_id
]),
['title' => get_lang('CreateANewForum')]
);
$return .= '</li>';
$return .= '<script>

@ -25,25 +25,33 @@ $learnPath = $_SESSION['oLP'];
$htmlHeadXtra[] = '<script>'.
$learnPath->get_js_dropdown_array() .
"
function load_cbo(id) {
if (!id) {
return false;
}
var cbo = document.getElementById('previous');
for(var i = cbo.length - 1; i > 0; i--) {
cbo.options[i] = null;
}
'function load_cbo(id){' ."\n" .
'if (!id) {return false;}'.
'var cbo = document.getElementById(\'previous\');' .
'for(var i = cbo.length - 1; i > 0; i--) {' .
'cbo.options[i] = null;' .
'}' ."\n" .
'var k=0;' .
'for(var i = 1; i <= child_name[id].length; i++){' ."\n" .
' cbo.options[i] = new Option(child_name[id][i-1], child_value[id][i-1]);' ."\n" .
' k=i;' ."\n" .
'}' ."\n" .
//'if( typeof cbo != "undefined" ) {'."\n" .
'cbo.options[k].selected = true;'."\n" .
//'}'."\n" .
'$(\'#previous\').selectpicker(\'refresh\');' .
'}
var k=0;
for(var i = 1; i <= child_name[id].length; i++){
var option = new Option(child_name[id][i - 1], child_value[id][i - 1]);
option.style.paddingLeft = '40px';
cbo.options[i] = option;
k = i;
}
cbo.options[k].selected = true;
$('#previous').selectpicker('refresh');
}
" .
'
$(function() {
if ($(\'#previous\')) {
if(\'parent is\'+$(\'#idParent\').val()) {

@ -26,25 +26,33 @@ include 'resourcelinker.inc.php';
$htmlHeadXtra[] = '
<script>'.$_SESSION['oLP']->get_js_dropdown_array().
"
function load_cbo(id) {
if (!id) {
return false;
}
var cbo = document.getElementById('previous');
for(var i = cbo.length - 1; i > 0; i--) {
cbo.options[i] = null;
}
'function load_cbo(id){' ."\n" .
'if (!id) {return false;}'.
'var cbo = document.getElementById(\'previous\');' .
'for(var i = cbo.length - 1; i > 0; i--) {' .
'cbo.options[i] = null;' .
'}' ."\n" .
'var k=0;' .
'for(var i = 1; i <= child_name[id].length; i++){' ."\n" .
' cbo.options[i] = new Option(child_name[id][i-1], child_value[id][i-1]);' ."\n" .
' k=i;' ."\n" .
'}' ."\n" .
//'if( typeof cbo != "undefined" ) {'."\n" .
'cbo.options[k].selected = true;'."\n" .
//'}'."\n" .
'$(\'#previous\').selectpicker(\'refresh\');' .
'}
var k=0;
for(var i = 1; i <= child_name[id].length; i++){
var option = new Option(child_name[id][i - 1], child_value[id][i - 1]);
option.style.paddingLeft = '20px';
cbo.options[i] = option;
k = i;
}
cbo.options[k].selected = true;
$('#previous').selectpicker('refresh');
}
" .
'
$(document).on("ready", function() {
CKEDITOR.on("instanceReady", function (e) {
showTemplates("content_lp");

@ -22,19 +22,30 @@ include 'resourcelinker.inc.php';
/* Header and action code */
$htmlHeadXtra[] = '<script type="text/javascript">'.
$_SESSION['oLP']->get_js_dropdown_array() .
'function load_cbo(id){' ."\n" .
'if (!id) {return false;}'.
'var cbo = document.getElementById(\'previous\');' .
'for(var i = cbo.length - 1; i > 0; i--) {' .
'cbo.options[i] = null;' .
'}' ."\n" .
'var k=0;' .
'for(var i = 1; i <= child_name[id].length; i++){' ."\n" .
' cbo.options[i] = new Option(child_name[id][i-1], child_value[id][i-1]);' ."\n" .
' k=i;' ."\n" .
'}' ."\n" .
'cbo.options[k].selected = true;'."\n" .
'}'."\n" .
"
function load_cbo(id) {
if (!id) {
return false;
}
var cbo = document.getElementById('previous');
for(var i = cbo.length - 1; i > 0; i--) {
cbo.options[i] = null;
}
var k=0;
for(var i = 1; i <= child_name[id].length; i++) {
cbo.options[i] = new Option(child_name[id][i - 1], child_value[id][i - 1]);
k=i;
}
cbo.options[k].selected = true;
$('#previous').selectpicker('refresh');
}
" .
"\n" .
'$().ready(function() {'."\n" .
'if ($(\'#previous\')) {'."\n" .
'if(\'parent is\'+$(\'#idParent\').val()) {'.

@ -1709,7 +1709,8 @@ function rl_get_resource_link_for_learnpath($course_id, $learnpath_id, $id_in_pa
);
$documentPathInfo = pathinfo($documentInfo['absolute_path']);
$jplayer_supported_files = ['mp4', 'ogv', 'flv', 'm4v'];
$showDirectUrl = !in_array($documentPathInfo['extension'], $jplayer_supported_files);
$extension = isset($documentPathInfo['extension']) ? $documentPathInfo['extension'] : '';
$showDirectUrl = !in_array($extension, $jplayer_supported_files);
if ($showDirectUrl) {
$link = $documentInfo['direct_url'] . '?';

@ -161,7 +161,7 @@ class SurveyManager
$return['survey_type'] = $return['survey_type'];
$return['one_question_per_page'] = $return['one_question_per_page'];
$return['show_form_profile'] = $return['show_form_profile'];
$return['input_name_list'] = isset($return['input_name_list']) ? $return['input_name_list'] : null;
$return['input_name_list'] = isset($return['input_name_list']) ? $return['input_name_list'] : null;
$return['shuffle'] = $return['shuffle'];
$return['parent_id'] = $return['parent_id'];
$return['survey_version'] = $return['survey_version'];
@ -368,7 +368,7 @@ class SurveyManager
}
if (!isset($values['anonymous']) ||
isset($values['anonymous']) && $values['anonymous'] == ''
(isset($values['anonymous']) && $values['anonymous'] == '')
) {
$values['anonymous'] = 0;
}
@ -387,7 +387,7 @@ class SurveyManager
if ($values['show_form_profile'] == 1) {
$fields = explode(',',$values['input_name_list']);
$field_values = '';
foreach ($fields as & $field) {
foreach ($fields as &$field) {
if ($field != '') {
if (!isset($values[$field]) ||
(isset($values[$field]) && $values[$field] == '')
@ -835,25 +835,6 @@ class SurveyManager
Database::query($sql);
}
/**
* Gets a complete structure of a survey
* (all survey information, all question information of all the questions
* and all the options of all the questions.
*
* @param integer $survey_id the id of the survey
* @param boolean $shared this parameter determines if we have to get the
* information of a survey from the central (shared) database or from the
* course database
*
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
* @version February 2007
*/
public static function get_complete_survey_structure($survey_id, $shared = 0)
{
$structure = SurveyManager::get_survey($survey_id, $shared);
$structure['questions'] = SurveyManager::get_questions($survey_id);
}
/***
* SURVEY QUESTION FUNCTIONS
*/
@ -1073,7 +1054,6 @@ class SurveyManager
}
}
$additional = array();
$course_id = api_get_course_int_id();
if (!$empty_answer) {
@ -1633,17 +1613,17 @@ class SurveyManager
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
* @version February 2007
*/
static function get_people_who_filled_survey($survey_id, $all_user_info = false, $course_id = null)
public static function get_people_who_filled_survey($survey_id, $all_user_info = false, $course_id = null)
{
// Database table definition
$table_survey_answer = Database :: get_course_table(TABLE_SURVEY_ANSWER);
$table_user = Database :: get_main_table(TABLE_MAIN_USER);
$table_survey_answer = Database:: get_course_table(TABLE_SURVEY_ANSWER);
$table_user = Database:: get_main_table(TABLE_MAIN_USER);
// Variable initialisation
$return = array();
if (empty($course_id)) {
$course_id = api_get_course_int_id();
$course_id = api_get_course_int_id();
} else {
$course_id = intval($course_id);
}
@ -1675,7 +1655,7 @@ class SurveyManager
return $return;
}
static function survey_generation_hash_available()
public static function survey_generation_hash_available()
{
if (extension_loaded('mcrypt')) {
return true;
@ -1683,13 +1663,13 @@ class SurveyManager
return false;
}
static function generate_survey_hash($survey_id, $course_id, $session_id, $group_id)
public static function generate_survey_hash($survey_id, $course_id, $session_id, $group_id)
{
$hash = hash('sha512', api_get_security_key().'_'.$course_id.'_'.$session_id.'_'.$group_id.'_'.$survey_id);
return $hash;
}
static function validate_survey_hash($survey_id, $course_id, $session_id, $group_id, $hash)
public static function validate_survey_hash($survey_id, $course_id, $session_id, $group_id, $hash)
{
$survey_generated_hash = self::generate_survey_hash($survey_id, $course_id, $session_id, $group_id);
if ($survey_generated_hash == $hash) {
@ -1698,7 +1678,7 @@ class SurveyManager
return false;
}
static function generate_survey_link($survey_id, $course_id, $session_id, $group_id)
public static function generate_survey_link($survey_id, $course_id, $session_id, $group_id)
{
$code = self::generate_survey_hash($survey_id, $course_id, $session_id, $group_id);
return api_get_path(WEB_CODE_PATH).'survey/link.php?h='.$code.'&i='.$survey_id.'&c='.intval($course_id).'&s='.intval($session_id).'&g='.$group_id;
@ -3230,7 +3210,7 @@ class SurveyUtil
* @param boolean Whether to display user fields or not
* @return string One line of the csv file
*/
static function export_complete_report_row_xls(
public static function export_complete_report_row_xls(
$survey_data,
$possible_options,
$answers_of_user,
@ -3301,7 +3281,7 @@ class SurveyUtil
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
* @version February 2007
*/
static function display_comparative_report()
public static function display_comparative_report()
{
// Allowed question types for comparative report
$allowed_question_types = array(
@ -3351,7 +3331,7 @@ class SurveyUtil
echo get_lang('SelectYAxis').': ';
echo '<select name="yaxis">';
echo '<option value="">---</option>';
foreach ($questions as $key => & $question) {
foreach ($questions as $key => &$question) {
if (in_array($question['type'], $allowed_question_types)) {
echo '<option value="'.$question['question_id'].'"';
if (isset($_GET['yaxis']) && $_GET['yaxis'] == $question['question_id']) {
@ -3534,7 +3514,7 @@ class SurveyUtil
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
* @version February 2007 - Updated March 2008
*/
static function get_answers_of_question_by_user($survey_id, $question_id)
public static function get_answers_of_question_by_user($survey_id, $question_id)
{
$course_id = api_get_course_int_id();
$table_survey_answer = Database :: get_course_table(TABLE_SURVEY_ANSWER);
@ -3566,7 +3546,7 @@ class SurveyUtil
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
* @version February 2007
*/
static function comparative_check($answers_x, $answers_y, $option_x, $option_y, $value_x = 0, $value_y = 0)
public static function comparative_check($answers_x, $answers_y, $option_x, $option_y, $value_x = 0, $value_y = 0)
{
if ($value_x == 0) {
$check_x = $option_x;
@ -3605,7 +3585,7 @@ class SurveyUtil
*
* @todo use survey_id parameter instead of $_GET
*/
static function get_survey_invitations_data()
public static function get_survey_invitations_data()
{
$course_id = api_get_course_int_id();
// Database table definition
@ -3642,7 +3622,7 @@ class SurveyUtil
* @author Patrick Cool <patrick.cool@UGent.be>, Ghent University
* @version January 2007
*/
static function get_number_of_survey_invitations()
public static function get_number_of_survey_invitations()
{
$course_id = api_get_course_int_id();

@ -1,4 +1,4 @@
<p>{{ 'Dear' }} {{ complete_user_name }}</p>
<p>
{{ 'ResetPasswordCommentWithUrl'|get_lang|format(link) }}
{{ 'ResetPasswordCommentWithUrl'| get_lang | format(link) | nl2br }}
</p>

@ -425,36 +425,38 @@ if (count($a_students) > 0) {
$headers['student_publication'] = get_lang('Student_publication');
$table->set_header(10, get_lang('Messages'), false);
$headers['messages'] = get_lang('Messages');
$table->set_header(11, get_lang('Classes'));
$headers['clasess'] = get_lang('Classes');
if (empty($session_id)) {
$table->set_header(11, get_lang('Survey'), false);
$table->set_header(12, get_lang('Survey'), false);
$headers['survey'] = get_lang('Survey');
$table->set_header(12, get_lang('FirstLoginInCourse'), false);
$table->set_header(13, get_lang('FirstLoginInCourse'), false);
$headers['first_login'] = get_lang('FirstLoginInCourse');
$table->set_header(13, get_lang('LatestLoginInCourse'), false);
$table->set_header(14, get_lang('LatestLoginInCourse'), false);
$headers['latest_login'] = get_lang('LatestLoginInCourse');
if (isset($_GET['additional_profile_field']) and is_numeric($_GET['additional_profile_field'])) {
$table->set_header(14, $extra_info['display_text'], false);
$table->set_header(15, $extra_info['display_text'], false);
$headers['display_text'] = $extra_info['display_text'];
$table->set_header(15, get_lang('Details'), false);
$table->set_header(16, get_lang('Details'), false);
$headers['details'] = get_lang('Details');
} else {
$table->set_header(14, get_lang('Details'), false);
$table->set_header(15, get_lang('Details'), false);
$headers['details'] = get_lang('Details');
}
} else {
$table->set_header(11, get_lang('FirstLoginInCourse'), false);
$table->set_header(12, get_lang('FirstLoginInCourse'), false);
$headers['first_login'] = get_lang('FirstLoginInCourse');
$table->set_header(12, get_lang('LatestLoginInCourse'), false);
$table->set_header(13, get_lang('LatestLoginInCourse'), false);
$headers['latest_login'] = get_lang('LatestLoginInCourse');
if (isset($_GET['additional_profile_field']) and is_numeric($_GET['additional_profile_field'])) {
$table->set_header(13, $extra_info['display_text'], false);
$table->set_header(14, $extra_info['display_text'], false);
$headers['display_text'] = $extra_info['display_text'];
$table->set_header(14, get_lang('Details'), false);
$table->set_header(15, get_lang('Details'), false);
$headers['Details'] = get_lang('Details');
} else {
$table->set_header(13, get_lang('Details'), false);
$table->set_header(14, get_lang('Details'), false);
$headers['Details'] = get_lang('Details');
}
}

@ -45,7 +45,7 @@ function WSHelperVerifyKey($params)
// if we are behind a reverse proxy, assume it will send the
// HTTP_X_FORWARDED_FOR header and use this IP instead
if (!empty($_SERVER['HTTP_X_FORWARDED_FOR'])) {
list($ip1, $ip2) = explode(',', $_SERVER['HTTP_X_FORWARDED_FOR']);
list($ip1) = explode(',', $_SERVER['HTTP_X_FORWARDED_FOR']);
$ip = trim($ip1);
}
if ($debug)

@ -5860,6 +5860,7 @@ $server->register('WSListCourses',
// define the method WSListCourses
function WSListCourses($params)
{
global $debug;
if (!WSHelperVerifyKey($params)) {
return returnError(WS_ERROR_SECRET_KEY);
}
@ -5872,9 +5873,11 @@ function WSListCourses($params)
$from = isset($params['from']) ? $params['from'] : null;
$to = isset($params['to']) ? $params['to'] : null;
error_log(print_r($params,1));
error_log($from);
error_log($to);
if ($debug) {
error_log(print_r($params, 1));
error_log($from);
error_log($to);
}
$courses = CourseManager::get_courses_list($from, $to);

@ -182,6 +182,7 @@ if (!empty($files)) {
//start download of created file
$name = $fileName .'.zip';
if (Security::check_abs_path($temp_zip_file, api_get_path(SYS_ARCHIVE_PATH))) {
DocumentManager::file_send_for_download($temp_zip_file, true, $name);
@unlink($temp_zip_file);

@ -8,7 +8,5 @@
*/
require_once '../../main/inc/global.inc.php';
require_once api_get_path(LIBRARY_PATH).'plugin.class.php';
require_once 'src/ticket.class.php';
require_once 'src/ticket_plugin.class.php';

@ -4,6 +4,7 @@
/**
* @package chamilo.plugin.ticket
*/
/* Tables names constants */
define('PLUGIN_NAME', 'ticket');
define('TABLE_TICKET_ASSIGNED_LOG', 'plugin_ticket_assigned_log');

@ -1,4 +1,6 @@
<?php
/* For licensing terms, see /license.txt */
/**
* Contains the SQL for the tickets management plugin database structure
*/
@ -42,6 +44,7 @@ $categoRow = array(
$objPlugin->get_lang('VirtualCampus') => $objPlugin->get_lang('TicketsAboutVirtualCampus'),
$objPlugin->get_lang('OnlineEvaluation') => $objPlugin->get_lang('TicketsAboutOnlineEvaluation')
);
$i = 1;
foreach ($categoRow as $category => $description) {
//Online evaluation requires a course
@ -67,7 +70,7 @@ foreach ($categoRow as $category => $description) {
Database::insert($table, $attributes);
$i++;
}
//END default categories
$table = Database::get_main_table(TABLE_TICKET_MESSAGE);
$sql = "CREATE TABLE IF NOT EXISTS ".$table." (
id int UNSIGNED NOT NULL AUTO_INCREMENT,
@ -117,6 +120,7 @@ $sql = "CREATE TABLE IF NOT EXISTS ".$table." (
sys_lastedit_datetime datetime DEFAULT NULL,
PRIMARY KEY (id))";
Database::query($sql);
//Default Priorities
$defaultPriorities = array(
'NRM' => $objPlugin->get_lang('PriorityNormal'),
@ -134,7 +138,6 @@ foreach ($defaultPriorities as $pId => $priority) {
Database::insert($table, $attributes);
$i++;
}
//End
$table = Database::get_main_table(TABLE_TICKET_PROJECT);
$sql = "CREATE TABLE IF NOT EXISTS ".$table." (
@ -150,6 +153,7 @@ $sql = "CREATE TABLE IF NOT EXISTS ".$table." (
sys_lastedit_datetime datetime DEFAULT NULL,
PRIMARY KEY (id))";
Database::query($sql);
//Default Project Table Ticket
$attributes = array(
'id' => 1,
@ -157,7 +161,6 @@ $attributes = array(
'name' => 'Ticket System'
);
Database::insert($table, $attributes);
//END
//STATUS
$table = Database::get_main_table(TABLE_TICKET_STATUS);
@ -168,6 +171,7 @@ $sql = "CREATE TABLE IF NOT EXISTS ".$table." (
description varchar(255) DEFAULT NULL,
PRIMARY KEY (id))";
Database::query($sql);
//Default status
$defaultStatus = array(
'NAT' => $objPlugin->get_lang('StatusNew'),
@ -187,7 +191,6 @@ foreach ($defaultStatus as $abr => $status) {
Database::insert($table, $attributes);
$i ++;
}
//END
$table = Database::get_main_table(TABLE_TICKET_TICKET);
$sql = "CREATE TABLE IF NOT EXISTS ".$table." (

@ -7,5 +7,5 @@
* @package chamilo.plugin.ticket
*/
require_once dirname(__FILE__).'/config.php';
require_once __DIR__.'/config.php';
TicketPlugin::create()->install();

@ -4,5 +4,5 @@
/**
* @package chamilo.plugin.ticket
*/
require_once dirname(__FILE__).'/config.php';
require_once __DIR__.'/config.php';
$plugin_info = TicketPlugin::create()->get_info();

@ -1,5 +1,6 @@
<?php
/* For licensing terms, see /license.txt */
/**
*
* @package chamilo.plugin.ticket
@ -64,7 +65,8 @@ while ($row = Database::fetch_assoc($result_forum)) {
echo '</select></div><div>';
echo '<div class="row">
<div class="formw">
<button class="save" name="edit" type="button" value="' . get_lang('Edit') . '" onClick="save(' . "$id" . ');">' . get_lang('Edit') . '</button>
<button class="save" name="edit" type="button" value="' . get_lang('Edit') . '" onClick="save(' . "$id" . ');">' .
get_lang('Edit') . '</button>
</div>
</div>';
echo '</form>';

@ -18,8 +18,6 @@ foreach ($coursesList as $key => $course) {
$courseInfo = CourseManager::get_course_information($course['code']);
$arrCourseList[$courseInfo['code']] = $courseInfo['title'];
}
//End Course List
$userLabel = Display::tag('label', get_lang('User'), array('class' => 'control-label'));
$personName = api_get_person_name($userInfo['firstname'], $userInfo['lastname']);
@ -40,6 +38,7 @@ $courseControl = Display::div($courseSelect, array('class' => 'controls'));
$userDiv = Display::div($userLabel . " " . $userControl, array('class' => 'control-group'));
$courseDiv = Display::div($courseLabel . " " . $courseControl, array('class' => 'control-group'));
echo $userDiv;
echo $courseDiv;

@ -194,7 +194,8 @@ if (isset($_GET['action'])) {
break;
}
}
//$nameTools = api_xml_http_response_encode($plugin->get_lang('MyTickets'));
// $nameTools = api_xml_http_response_encode($plugin->get_lang('MyTickets'));
$user_id = api_get_user_id();
$isAdmin = api_is_platform_admin();

@ -4,6 +4,7 @@
/**
* @package chamilo.plugin.ticket
*/
$language_file = array('trad4all');
$cidReset = true;
require_once '../config.php';
@ -14,7 +15,7 @@ api_block_anonymous_users();
if (!api_is_allowed_to_edit()) {
api_not_allowed();
}
//$nameTools = api_xml_http_response_encode(get_lang('Soporte Virtual'));
$this_section = 'Reports';
unset($_SESSION['this_section']);
@ -24,7 +25,8 @@ $(document).ready(function(){
$( "#keyword_start_date_start" ).datepicker({ dateFormat: ' . "'yy-mm-dd'" . ' });
$( "#keyword_start_date_end" ).datepicker({ dateFormat: ' . "'yy-mm-dd'" . ' });
});
function validate(){
function validate() {
if( $("#keyword_start_date_start").val() != "" && $("#keyword_start_date_end").val() != ""){
datestart = $("#keyword_start_date_start").val();
dateend = $("#keyword_start_date_end").val();
@ -35,6 +37,7 @@ function validate(){
}
}
}
function load_course_list (div_course,my_user_id) {
$.ajax({
contentType: "application/x-www-form-urlencoded",
@ -84,6 +87,7 @@ $tools['quiz'] = array('id' => 'quiz', 'name' => get_lang('Quiz'));
$tools['student_publication'] = array('id' => 'student_publication', 'name' => get_lang('Student_publication'));
$tools['user'] = array('id' => 'user', 'name' => get_lang('User'));
$tools['forum'] = array('id' => 'forum', 'name' => get_lang('Forum'));
/**
* Returns the escaped string.
* @param string $s

@ -336,8 +336,8 @@ class TicketManager
$obj = Database::fetch_object($result);
$message_id = $obj->total_messages + 1;
$now = api_get_utc_datetime();
$sql_insert_message = "INSERT INTO $table_support_messages (
// insert msg
$sql = "INSERT INTO $table_support_messages (
ticket_id,
message_id,
subject,
@ -360,16 +360,19 @@ class TicketManager
'" . $now . "',
'$status'
)";
Database::query($sql_insert_message);
$sql_update_total_message = "UPDATE $table_support_tickets
SET sys_lastedit_user_id ='$user_id',
sys_lastedit_datetime ='$now',
total_messages = (
SELECT COUNT(*) as total_messages
FROM $table_support_messages
WHERE ticket_id ='$ticket_id'
) WHERE ticket_id ='$ticket_id' ";
Database::query($sql_update_total_message);
Database::query($sql);
// update_total_message
$sql = "UPDATE $table_support_tickets
SET sys_lastedit_user_id ='$user_id',
sys_lastedit_datetime ='$now',
total_messages = (
SELECT COUNT(*) as total_messages
FROM $table_support_messages
WHERE ticket_id ='$ticket_id'
)
WHERE ticket_id ='$ticket_id' ";
Database::query($sql);
$sql_message_att_id = "SELECT COUNT(*) as total_attach
FROM $table_support_message_attachments
@ -1239,6 +1242,7 @@ class TicketManager
$sql .= " AND ticket.project_id != '' ";
$res = Database::query($sql);
$obj = Database::fetch_object($res);
return $obj->unread;
}
@ -1512,7 +1516,6 @@ class TicketManager
}
}
//$sql .= " ORDER BY col$column $direction";
$sql .= " LIMIT $from,$number_of_items";
$result = Database::query($sql);

@ -4,7 +4,9 @@
/**
* @package chamilo.plugin.ticket
*/
require_once '../config.php';
$plugin = TicketPlugin::create();
$ticket_id = intval($_POST['ticket_id']);
@ -22,9 +24,15 @@ $history = TicketManager::get_assign_log($ticket_id);
?>
<?php for ($k = 0; $k < count($history); $k++) { ?>
<tr>
<td width="125px"><?php echo api_convert_encoding($history[$k]['assignuser'], 'UTF-8', $charset); ?></td>
<td width="100px"><?php echo api_convert_encoding($history[$k]['assigned_date'], 'UTF-8', $charset); ?></td>
<td width="125px"><?php echo api_convert_encoding($history[$k]['insertuser'], 'UTF-8', $charset); ?></td>
<td width="125px">
<?php echo api_convert_encoding($history[$k]['assignuser'], 'UTF-8', $charset); ?>
</td>
<td width="100px">
<?php echo api_convert_encoding($history[$k]['assigned_date'], 'UTF-8', $charset); ?>
</td>
<td width="125px">
<?php echo api_convert_encoding($history[$k]['insertuser'], 'UTF-8', $charset); ?>
</td>
</tr>
<?php } ?>
</table>

@ -58,7 +58,7 @@ class TicketPlugin extends Plugin
$settings = $this->get_settings();
$plugSetting = current($settings);
//Delete settings
// Delete settings
$sql = "DELETE FROM $tblSettings WHERE variable = 'ticket_tool_enable'";
Database::query($sql);

@ -32,8 +32,9 @@ function initializeReport($course_code)
if (intval($obj->cant) != $weeksCount) {
if (intval($obj->cant) > $weeksCount) {
$sql = "DELETE FROM $table_reporte_semanas WHERE week_id > $weeksCount AND course_code = '$course_code'";
Database::query("DELETE FROM $table_reporte_semanas WHERE week_id > $weeksCount AND course_code = '$course_code'");
$sql = "DELETE FROM $table_reporte_semanas
WHERE week_id > $weeksCount AND course_code = '$course_code'";
Database::query($sql);
} else {
for ($i = $obj->cant + 1; $i <= $weeksCount; $i++) {
if (!Database::query("INSERT INTO $table_reporte_semanas (week_id, course_code, forum_id, work_id, quiz_id, pc_id)
@ -139,7 +140,6 @@ function showResults($courseInfo, $weeksCount, $page)
<option value="14" ' . (($weeksCount == 14) ? 'selected="selected"' : "") . '>14 weeks</option>
</select>';
if ($weeksCount == 14) {
$html .= '<span style="float:right;"><a href="tutor.php?page=' . (($page == 1) ? 2 : 1) . '">' . (($page == 1) ? "Siguiente" : "Anterior") . '</a></span>';
}
@ -196,6 +196,7 @@ function showStudentResult($datos, $pagina)
$fila.= '<td align="center">' . (($dato['thread_ok'] == 1) ? Display::return_icon('check.png') : Display::return_icon('aspa.png')) . '</td>';
}
$fila.= '</tr>';
return $fila;
}

@ -6,7 +6,7 @@
* @package chamilo.plugin.ticket
*/
$course_plugin = 'ticket'; //needed in order to load the plugin lang variables
require_once dirname(__FILE__).'/config.php';
require_once __DIR__.'/config.php';
$tool_name = get_lang('Ticket');
$tpl = new Template($tool_name);

@ -7,5 +7,5 @@
* the global database and the courses tables
* @package chamilo.plugin.ticket
*/
require_once dirname(__FILE__).'/config.php';
require_once __DIR.'/config.php';
TicketPlugin::create()->uninstall();

@ -182,16 +182,6 @@ class TestSurvey extends UnitTestCase {
}
public function testGetCompleteSurveyStructure() {
$survey_id='';
$shared=0;
$res = $this->smanager->get_complete_survey_structure($survey_id, $shared);
$this->assertNull($res);
$this->assertTrue($res=== null);
//var_dump($res);
}
public function testIconQuestion() {
$type='open';
$res = $this->smanager->icon_question($type);

Loading…
Cancel
Save