Internal: Merge with 1.11.x

pull/3466/head
Julio Montoya 5 years ago
parent bc69d93c4e
commit 966b125849
  1. 4
      public/main/admin/course_list.php
  2. 4
      public/main/admin/course_list_admin.php
  3. 17
      public/main/forum/forumfunction.inc.php
  4. 2
      public/main/gradebook/lib/GradebookUtils.php
  5. 4
      public/main/inc/ajax/announcement.ajax.php
  6. 136
      public/main/inc/ajax/course_home.ajax.php
  7. 169
      public/main/inc/ajax/lp.ajax.php
  8. 10
      public/main/inc/ajax/model.ajax.php
  9. 8
      public/main/inc/ajax/record_audio_rtc.ajax.php
  10. 8
      public/main/inc/ajax/sequence.ajax.php
  11. 3
      public/main/inc/ajax/session.ajax.php
  12. 2
      public/main/inc/ajax/social.ajax.php
  13. 16
      public/main/inc/ajax/user_manager.ajax.php
  14. 86
      public/main/inc/lib/CoursesAndSessionsCatalog.class.php
  15. 23
      public/main/inc/lib/agenda.lib.php
  16. 9
      public/main/inc/lib/api.lib.php
  17. 4
      public/main/inc/lib/array.lib.php
  18. 83
      public/main/inc/lib/attendance.lib.php
  19. 87
      public/main/inc/lib/auth.lib.php
  20. 14
      public/main/inc/lib/certificate.lib.php
  21. 149
      public/main/inc/lib/course.lib.php
  22. 11
      public/main/inc/lib/course_category.lib.php
  23. 23
      public/main/inc/lib/course_request.lib.php
  24. 129
      public/main/inc/lib/events.lib.php
  25. 9
      public/main/inc/lib/formvalidator/Element/DateRangePicker.php
  26. 6
      public/main/inc/lib/formvalidator/Element/SelectAjax.php
  27. 81
      public/main/inc/lib/formvalidator/FormValidator.class.php
  28. 86
      public/main/inc/lib/pear/HTML/QuickForm.php
  29. 11
      public/main/inc/lib/pear/HTML/QuickForm/Page.php
  30. 1
      public/main/inc/lib/pear/HTML/QuickForm/Renderer.php
  31. 32
      public/main/inc/lib/pear/HTML/QuickForm/button.php
  32. 220
      public/main/inc/lib/pear/HTML/QuickForm/checkbox.php
  33. 54
      public/main/inc/lib/pear/HTML/QuickForm/element.php
  34. 4
      public/main/inc/lib/pear/HTML/QuickForm/email.php
  35. 1
      public/main/inc/lib/pear/HTML/QuickForm/file.php
  36. 325
      public/main/inc/lib/pear/HTML/QuickForm/group.php
  37. 10
      public/main/inc/lib/pear/HTML/QuickForm/header.php
  38. 18
      public/main/inc/lib/pear/HTML/QuickForm/hidden.php
  39. 10
      public/main/inc/lib/pear/HTML/QuickForm/hiddenselect.php
  40. 1
      public/main/inc/lib/pear/HTML/QuickForm/html.php
  41. 12
      public/main/inc/lib/pear/HTML/QuickForm/input.php
  42. 1
      public/main/inc/lib/pear/HTML/QuickForm/label.php
  43. 44
      public/main/inc/lib/pear/HTML/QuickForm/link.php
  44. 38
      public/main/inc/lib/pear/HTML/QuickForm/password.php
  45. 138
      public/main/inc/lib/pear/HTML/QuickForm/radio.php
  46. 134
      public/main/inc/lib/pear/HTML/QuickForm/select.php
  47. 66
      public/main/inc/lib/pear/HTML/QuickForm/text.php
  48. 119
      public/main/inc/lib/pear/HTML/QuickForm/textarea.php
  49. 22
      public/main/inc/lib/pear/HTML/Table.php
  50. 38
      public/main/inc/lib/pear/HTML/Table/Storage.php
  51. 47
      public/main/inc/lib/pear/Pager/Common.php
  52. 30
      public/main/inc/lib/pear/Text/Password.php

@ -155,7 +155,7 @@ function get_course_data($from, $number_of_items, $column, $direction, $dataFunc
);
$actions[] = Display::url(
Display::return_icon('statistics.png', get_lang('Reporting')),
$path.'tracking/courseLog.php?'.api_get_cidreq_params($courseCode)
$path.'tracking/courseLog.php?'.api_get_cidreq_params($courseId)
);
$actions[] = Display::url(
Display::return_icon('edit.png', get_lang('Edit')),
@ -163,7 +163,7 @@ function get_course_data($from, $number_of_items, $column, $direction, $dataFunc
);
$actions[] = Display::url(
Display::return_icon('backup.png', get_lang('Create a backup')),
$path.'coursecopy/create_backup.php?'.api_get_cidreq_params($courseCode)
$path.'coursecopy/create_backup.php?'.api_get_cidreq_params($courseId)
);
$actions[] = Display::url(
Display::return_icon('delete.png', get_lang('Delete')),

@ -171,7 +171,7 @@ function get_course_data($from, $number_of_items, $column, $direction, $dataFunc
);*/
$actions[] = Display::url(
Display::return_icon('statistics.png', get_lang('Tracking')),
$path.'tracking/courseLog.php?'.api_get_cidreq_params($courseCode)
$path.'tracking/courseLog.php?'.api_get_cidreq_params($courseId)
);
$actions[] = Display::url(
Display::return_icon('edit.png', get_lang('Edit')),
@ -179,7 +179,7 @@ function get_course_data($from, $number_of_items, $column, $direction, $dataFunc
);
$actions[] = Display::url(
Display::return_icon('backup.png', get_lang('CreateBackup')),
$path.'coursecopy/create_backup.php?'.api_get_cidreq_params($courseCode)
$path.'coursecopy/create_backup.php?'.api_get_cidreq_params($courseId)
);
$actions[] = Display::url(
Display::return_icon('delete.png', get_lang('Delete')),

@ -5822,10 +5822,10 @@ function get_name_thread_by_id($thread_id)
*
* @return string
*/
function get_all_post_from_user($user_id, $course_code)
function get_all_post_from_user($user_id, $courseId)
{
$j = 0;
$forums = get_forums('', $course_code);
$forums = get_forums($courseId);
krsort($forums);
$forum_results = '';
@ -5846,7 +5846,7 @@ function get_all_post_from_user($user_id, $course_code)
}
if ($i <= 4) {
$post_list = get_thread_user_post_limit(
$course_code,
$courseId,
$thread['thread_id'],
$user_id,
1
@ -5880,7 +5880,7 @@ function get_all_post_from_user($user_id, $course_code)
$forum_results .= '<div id="social-forum-title">'.
Display::return_icon('forum.gif', get_lang('Forum')).'&nbsp;'.Security::remove_XSS($forum['forum_title'], STUDENT).
'<div style="float:right;margin-top:-35px">
<a href="../forum/viewforum.php?'.api_get_cidreq_params($course_code).'&forum='.$forum['forum_id'].' " >'.
<a href="../forum/viewforum.php?'.api_get_cidreq_params($courseId).'&forum='.$forum['forum_id'].' " >'.
get_lang('See forum').'
</a>
</div></div>';
@ -5905,19 +5905,18 @@ function get_all_post_from_user($user_id, $course_code)
*
* @return array
*/
function get_thread_user_post_limit($course_code, $thread_id, $user_id, $limit = 10)
function get_thread_user_post_limit($courseId, $thread_id, $user_id, $limit = 10)
{
$table_posts = Database::get_course_table(TABLE_FORUM_POST);
$table_users = Database::get_main_table(TABLE_MAIN_USER);
$course_info = api_get_course_info($course_code);
$course_id = $course_info['real_id'];
$courseId = (int) $courseId;
$sql = "SELECT * FROM $table_posts posts
LEFT JOIN $table_users users
LEFT JOIN $table_users users
ON posts.poster_id=users.user_id
WHERE
posts.c_id = $course_id AND
posts.c_id = $courseId AND
posts.thread_id='".Database::escape_string($thread_id)."' AND
posts.poster_id='".Database::escape_string($user_id)."'
ORDER BY posts.post_id DESC LIMIT $limit ";

@ -257,7 +257,7 @@ class GradebookUtils
}
$courseParams = api_get_cidreq_params(
$cat->get_course_code(),
$cat->getCourseId(),
$cat->get_session_id()
);

@ -1,9 +1,7 @@
<?php
/* For licensing terms, see /license.txt */
/**
* Responses to AJAX calls.
*/
use Chamilo\CoreBundle\Framework\Container;
require_once __DIR__.'/../global.inc.php';

@ -131,10 +131,146 @@ switch ($action) {
'tclass' => $requested_class,
'message' => $requested_message,
'view' => $requested_view,
'fclass' => $requested_fa_class,
];
echo json_encode($response);
}
break;
case 'set_visibility_for_all':
require_once __DIR__.'/../global.inc.php';
$course_id = api_get_course_int_id();
$sessionId = api_get_session_id();
$allowEditionInSession = api_get_configuration_value('allow_edit_tool_visibility_in_session');
$response = [];
$tools_ids = json_decode($_GET['tools_ids']);
$em = Database::getManager();
$repository = $em->getRepository('ChamiloCourseBundle:CTool');
// Allow tool visibility in sessions.
if (api_is_allowed_to_edit(null, true)) {
if (is_array($tools_ids) && count($tools_ids) != 0) {
$total_tools = count($tools_ids);
for ($i = 0; $i < $total_tools; $i++) {
$tool_id = (int) $tools_ids[$i];
$criteria = [
'cId' => $course_id,
'sessionId' => 0,
'iid' => $tool_id,
];
/** @var CTool $tool */
$tool = $repository->findOneBy($criteria);
$visibility = $tool->getVisibility();
if ($allowEditionInSession && !empty($sessionId)) {
$criteria = [
'cId' => $course_id,
'sessionId' => $sessionId,
'name' => $tool->getName(),
];
/** @var CTool $tool */
$toolInSession = $repository->findOneBy($criteria);
if ($toolInSession) {
// Use the session
$tool = $toolInSession;
$visibility = $toolInSession->getVisibility();
} else {
// Creates new row in c_tool
$toolInSession = clone $tool;
$toolInSession->setIid(0);
$toolInSession->setId(0);
$toolInSession->setVisibility(0);
$toolInSession->setSessionId($session_id);
$em->persist($toolInSession);
$em->flush();
// Update id with iid
$toolInSession->setId($toolInSession->getIid());
$em->persist($toolInSession);
$em->flush();
// $tool will be updated later
$tool = $toolInSession;
}
}
$toolImage = $tool->getImage();
$customIcon = $tool->getCustomIcon();
if (api_get_setting('homepage_view') != 'activity_big') {
$toolImage = Display::return_icon(
$toolImage,
null,
null,
null,
null,
true
);
$inactiveImage = str_replace('.gif', '_na.gif', $toolImage);
} else {
// Display::return_icon() also checks in the app/Resources/public/css/themes/{theme}/icons folder
$toolImage = (substr($toolImage, 0, strpos($toolImage, '.'))).'.png';
$toolImage = Display::return_icon(
$toolImage,
get_lang(ucfirst($tool->getName())),
null,
ICON_SIZE_BIG,
null,
true
);
$inactiveImage = str_replace('.png', '_na.png', $toolImage);
}
if (isset($customIcon) && !empty($customIcon)) {
$toolImage = CourseHome::getCustomWebIconPath().$customIcon;
$inactiveImage = CourseHome::getCustomWebIconPath().CourseHome::getDisableIcon($customIcon);
}
$requested_image = $visibility == 0 ? $toolImage : $inactiveImage;
$requested_class = $visibility == 0 ? '' : 'text-muted';
$requested_message = $visibility == 0 ? 'is_active' : 'is_inactive';
$requested_view = $visibility == 0 ? 'visible.png' : 'invisible.png';
$requestedVisible = $visibility == 0 ? 1 : 0;
$requested_view = $visibility == 0 ? 'visible.png' : 'invisible.png';
$requested_fa_class = $visibility == 0 ? 'fa fa-eye '.$requested_class : 'fa fa-eye-slash '.$requested_class;
$requestedVisible = $visibility == 0 ? 1 : 0;
// HIDE AND REACTIVATE TOOL
if ($tool_id == strval(intval($tool_id))) {
$tool->setVisibility($requestedVisible);
$em->persist($tool);
$em->flush();
// Also hide the tool in all sessions
if ($allowEditionInSession && empty($sessionId)) {
$criteria = [
'cId' => $course_id,
'name' => $tool->getName(),
];
/** @var CTool $toolItem */
$tools = $repository->findBy($criteria);
foreach ($tools as $toolItem) {
$toolSessionId = $toolItem->getSessionId();
if (!empty($toolSessionId)) {
$toolItem->setVisibility($requestedVisible);
$em->persist($toolItem);
}
}
$em->flush();
}
}
$response[] = [
'image' => $requested_image,
'tclass' => $requested_class,
'message' => $requested_message,
'view' => $requested_view,
'fclass' => $requested_fa_class,
'id' => $tool_id,
];
}
}
}
echo json_encode($response);
break;
case 'show_course_information':
require_once __DIR__.'/../global.inc.php';

@ -91,60 +91,22 @@ switch ($action) {
break;
case 'update_lp_item_order':
if (api_is_allowed_to_edit(null, true)) {
// $new_order gets a value like "647|0^648|0^649|0^"
$new_order = $_POST['new_order'];
$sections = explode('^', $new_order);
$sections = array_filter($sections);
// We have to update parent_item_id, previous_item_id, next_item_id, display_order in the database
$itemList = new LpItemOrderList();
$orderList = [];
foreach ($sections as $items) {
if (!empty($items)) {
list($id, $parent_id) = explode('|', $items);
$item = new LpOrderItem($id, $parent_id);
$itemList->add($item);
}
}
list($id, $parentId) = explode('|', $items);
$parents = $itemList->getListOfParents();
foreach ($parents as $parentId) {
$sameParentLpItemList = $itemList->getItemWithSameParent($parentId);
$previous_item_id = 0;
for ($i = 0; $i < count($sameParentLpItemList->list); $i++) {
$item_id = $sameParentLpItemList->list[$i]->id;
// display_order
$display_order = $i + 1;
$itemList->setParametersForId($item_id, $display_order, 'display_order');
// previous_item_id
$itemList->setParametersForId($item_id, $previous_item_id, 'previous_item_id');
$previous_item_id = $item_id;
// next_item_id
$next_item_id = 0;
if ($i < count($sameParentLpItemList->list) - 1) {
$next_item_id = $sameParentLpItemList->list[$i + 1]->id;
}
$itemList->setParametersForId($item_id, $next_item_id, 'next_item_id');
}
$orderList[$id] = $parentId;
}
$table = Database::get_course_table(TABLE_LP_ITEM);
foreach ($itemList->list as $item) {
$params = [];
$params['display_order'] = $item->display_order;
$params['previous_item_id'] = $item->previous_item_id;
$params['next_item_id'] = $item->next_item_id;
$params['parent_item_id'] = $item->parent_item_id;
learnpath::sortItemByOrderList($orderList);
Database::update(
$table,
$params,
[
'iid = ? AND c_id = ? ' => [
intval($item->id),
$courseId,
],
]
);
}
echo Display::return_message(get_lang('Saved.'), 'confirm');
echo Display::return_message(get_lang('Saved'), 'confirm');
}
break;
case 'record_audio':
@ -164,11 +126,11 @@ switch ($action) {
foreach (['video', 'audio'] as $type) {
if (isset($_FILES["${type}-blob"])) {
$fileName = $_POST["${type}-filename"];
//$file = $_FILES["${type}-blob"]["tmp_name"];
$file = $_FILES["${type}-blob"];
$title = $_POST['audio-title'];
$fileInfo = pathinfo($fileName);
$file['name'] = 'rec_'.date('Y-m-d_His').'_'.uniqid().'.'.$fileInfo['extension'];
$file['name'] = $title.'.'.$fileInfo['extension'];
$file['file'] = $file;
$result = DocumentManager::upload_document(
@ -199,17 +161,8 @@ switch ($action) {
break;
case 'get_forum_thread':
// FORUM - LP connection disabled
if (empty($lpId) || empty($lpItemId)) {
echo json_encode([
'error' => true,
]);
break;
}
$lpId = isset($_GET['lp']) ? (int) $_GET['lp'] : 0;
$lpItemId = isset($_GET['lp_item']) ? (int) $_GET['lp_item'] : 0;
$lpId = isset($_GET['lp']) ? intval($_GET['lp']) : 0;
$lpItemId = isset($_GET['lp_item']) ? intval($_GET['lp_item']) : 0;
$sessionId = api_get_session_id();
if (empty($lpId) || empty($lpItemId)) {
@ -360,101 +313,3 @@ switch ($action) {
default:
echo '';
}
exit;
/**
* Class LpItemOrderList
* Classes to create a special data structure to manipulate LP Items
* used only in this file.
*
* @todo move in a file
* @todo use PSR
*/
class LpItemOrderList
{
public $list = [];
public function __construct()
{
$this->list = [];
}
/**
* @param array $list
*/
public function add($list)
{
$this->list[] = $list;
}
/**
* @param int $parentId
*
* @return LpItemOrderList
*/
public function getItemWithSameParent($parentId)
{
$list = new LpItemOrderList();
for ($i = 0; $i < count($this->list); $i++) {
if ($this->list[$i]->parent_item_id == $parentId) {
$list->add($this->list[$i]);
}
}
return $list;
}
/**
* @return array
*/
public function getListOfParents()
{
$result = [];
foreach ($this->list as $item) {
if (!in_array($item->parent_item_id, $result)) {
$result[] = $item->parent_item_id;
}
}
return $result;
}
/**
* @param int $id
* @param int $value
* @param string $parameter
*/
public function setParametersForId($id, $value, $parameter)
{
for ($i = 0; $i < count($this->list); $i++) {
if ($this->list[$i]->id == $id) {
$this->list[$i]->$parameter = $value;
break;
}
}
}
}
/**
* Class LpOrderItem.
*/
class LpOrderItem
{
public $id = 0;
public $parent_item_id = 0;
public $previous_item_id = 0;
public $next_item_id = 0;
public $display_order = 0;
/**
* LpOrderItem constructor.
*
* @param int $id
* @param int $parentId
*/
public function __construct($id = 0, $parentId = 0)
{
$this->id = $id;
$this->parent_item_id = $parentId;
}
}

@ -454,9 +454,7 @@ switch ($action) {
$sessionIdList = array_column($sessionList, 'id');
$courseCodeList = [];
foreach ($sessionList as $session) {
$courses = SessionManager::get_course_list_by_session_id(
$session['id']
);
$courses = SessionManager::get_course_list_by_session_id($session['id']);
$courseCodeList = array_merge(
$courseCodeList,
array_column($courses, 'code')
@ -515,7 +513,8 @@ switch ($action) {
null,
$courseCodeList,
$userIdList,
$sessionIdList
$sessionIdList,
['where' => $whereCondition, 'extra' => $extra_fields]
);
} else {
$count = CourseManager::get_count_user_list_from_course_code(
@ -523,7 +522,8 @@ switch ($action) {
['ruc'],
$courseCodeList,
$userIdList,
$sessionIdList
$sessionIdList,
['where' => $whereCondition, 'extra' => $extra_fields]
);
}
break;

@ -56,7 +56,13 @@ switch ($type) {
0,
'overwrite',
false,
in_array($tool, ['document', 'exercise'])
in_array($tool, ['document', 'exercise']),
'file',
true,
api_get_user_id(),
$courseInfo,
api_get_session_id(),
api_get_group_id()
);
$error = empty($uploadedDocument) || !is_array($uploadedDocument);

@ -30,7 +30,6 @@ $sequenceResourceRepository = $em->getRepository('ChamiloCoreBundle:SequenceReso
switch ($action) {
case 'graph':
api_block_anonymous_users();
api_protect_admin_script();
/** @var Sequence $sequence */
$sequence = $sequenceRepository->find($sequenceId);
@ -46,10 +45,6 @@ switch ($action) {
$graphImage = '';
try {
$graphImage = $graphviz->createImageSrc($graph);
//echo $graphviz->createScript($graph);
//$graphviz->display($graph);
echo Display::img(
$graphImage,
get_lang('GraphDependencyTree'),
@ -434,7 +429,6 @@ switch ($action) {
$sequenceList = $sequenceResourceRepository->checkRequirementsForUser($sequences, $type, $userId);
$allowSubscription = $sequenceResourceRepository->checkSequenceAreCompleted($sequenceList);
$courseController = new CoursesController();
$view = new Template(null, false, false, false, false, false);
$view->assign('sequences', $sequenceList);
$view->assign('sequence_type', $type);
@ -443,7 +437,7 @@ switch ($action) {
if ($allowSubscription) {
$view->assign(
'subscribe_button',
$courseController->getRegisteredInSessionButton(
CoursesAndSessionsCatalog::getRegisteredInSessionButton(
$id,
$resourceName,
false

@ -267,9 +267,7 @@ switch ($action) {
if ('get_basic_course_documents_list' === $action) {
$courseInfo = api_get_course_info_by_id($course->getId());
$exists = DocumentManager::folderExists('/basic-course-documents', $courseInfo, $session->getId(), 0);
if (!$exists) {
$courseDir = $courseInfo['directory'].'/document';
$sysCoursePath = api_get_path(SYS_COURSE_PATH);
@ -303,6 +301,7 @@ switch ($action) {
false,
$session->getId()
);
$documentAndFolders = array_filter(
$documentAndFolders,
function (array $documentData) {

@ -142,7 +142,7 @@ switch ($action) {
if (api_is_user_of_course($course_id, api_get_user_id())) {
//------Forum messages
$forum_result = get_all_post_from_user($user_id, $course_code);
$forum_result = get_all_post_from_user($user_id, $course_id);
$all_result_data = 0;
if ('' != $forum_result) {
echo '<div id="social-forum-main-title">';

@ -227,18 +227,6 @@ switch ($action) {
false,
$additionalParameters
);
/*$result = api_mail_html(
$recipientName,
$user_info['mail'],
$subject,
$body,
$sender_name,
$emailAdmin,
null,
null,
$additionalParameters
);*/
Event::addEvent(LOG_USER_ENABLE, LOG_USER_ID, $user_id);
} else {
Event::addEvent(LOG_USER_DISABLE, LOG_USER_ID, $user_id);
@ -253,6 +241,7 @@ switch ($action) {
api_block_anonymous_users(false);
$status = isset($_REQUEST['status']) ? (int) $_REQUEST['status'] : DRH;
$active = isset($_REQUEST['active']) ? (int) $_REQUEST['active'] : null;
$criteria = new Criteria();
$criteria
@ -267,6 +256,9 @@ switch ($action) {
Criteria::expr()->eq('status', $status)
);
if (null !== $active) {
$criteria->andWhere(Criteria::expr()->eq('active', $active));
}
$users = UserManager::getRepository()->matching($criteria);
if (!$users->count()) {

@ -6,7 +6,6 @@ use Doctrine\ORM\Query\Expr\Join;
/**
* @todo change class name
* Class CoursesAndSessionsCatalog
*/
class CoursesAndSessionsCatalog
{
@ -259,10 +258,11 @@ class CoursesAndSessionsCatalog
$urlCondition = ' (access_url_id = '.$urlId.' OR access_url_id = 1) ';
}
$sql = "SELECT COUNT(*) FROM $tbl_course course
$sql = "SELECT COUNT(*)
FROM $tbl_course course
INNER JOIN $tbl_url_rel_course as url_rel_course
ON (url_rel_course.c_id = course.id)
WHERE access_url_id = '.$urlId.' ";
WHERE access_url_id = $urlId";
$result = Database::query($sql);
list($num_records) = Database::fetch_row($result);
@ -278,7 +278,8 @@ class CoursesAndSessionsCatalog
ORDER BY RAND()
LIMIT 0, $randomValue";
} else {
$sql = "SELECT id, id as real_id FROM $tbl_course course
$sql = "SELECT id, id as real_id
FROM $tbl_course course
WHERE
RAND()*$num_records< $randomValue
$avoidCoursesCondition
@ -319,7 +320,7 @@ class CoursesAndSessionsCatalog
$conditionCode .= " category_code='$categoryCode' ";
}
if (empty($categoryCode) || $categoryCode == 'ALL') {
if (empty($categoryCode) || $categoryCode === 'ALL') {
$sql = "SELECT *, id as real_id
FROM $tbl_course course
WHERE
@ -343,7 +344,8 @@ class CoursesAndSessionsCatalog
$urlCondition = ' access_url_id = '.$urlId.' ';
if ($categoryCode !== 'ALL') {
$sql = "SELECT *, course.id real_id FROM $tbl_course as course
$sql = "SELECT *, course.id real_id
FROM $tbl_course as course
INNER JOIN $tbl_url_rel_course as url_rel_course
ON (url_rel_course.c_id = course.id)
WHERE
@ -445,7 +447,8 @@ class CoursesAndSessionsCatalog
$categoryFilter = ' AND category_code = "'.$categoryCode.'" ';
}
$sql = "SELECT DISTINCT course.*, $injectExtraFields
//$sql = "SELECT DISTINCT course.*, $injectExtraFields
$sql = "SELECT DISTINCT(course.id)
FROM $courseTable course
$sqlInjectJoins
WHERE (
@ -472,7 +475,7 @@ class CoursesAndSessionsCatalog
$urlCondition = ' (access_url_id = '.$urlId.' OR access_url_id = 1) AND ';
}
$sql = "SELECT DISTINCT course.*, $injectExtraFields
$sql = "SELECT DISTINCT(course.id)
FROM $courseTable as course
INNER JOIN $tbl_url_rel_course as url_rel_course
ON (url_rel_course.c_id = course.id)
@ -498,9 +501,15 @@ class CoursesAndSessionsCatalog
$result = Database::query($sql);
$courses = [];
while ($row = Database::fetch_array($result)) {
$row['registration_code'] = !empty($row['registration_code']);
$courseId = $row['id'];
$courseInfo = api_get_course_info_by_id($courseId);
if (empty($courseInfo)) {
continue;
}
$courseCode = $courseInfo['code'];
$countUsers = CourseManager::get_user_list_from_course_code(
$row['code'],
$courseCode,
0,
null,
null,
@ -508,29 +517,18 @@ class CoursesAndSessionsCatalog
true
);
$connectionsLastMonth = Tracking::get_course_connections_count(
$row['id'],
$courseId,
0,
api_get_utc_datetime(time() - (30 * 86400))
);
$ranking = CourseManager::get_course_ranking($row['id'], 0);
$courses[] = [
'real_id' => $row['id'],
'point_info' => $ranking,
'code' => $row['code'],
'directory' => $row['directory'],
'visual_code' => $row['visual_code'],
'title' => $row['title'],
'tutor' => $row['tutor_name'],
'subscribe' => $row['subscribe'],
'unsubscribe' => $row['unsubscribe'],
'registration_code' => $row['registration_code'],
'creation_date' => $row['creation_date'],
'visibility' => $row['visibility'],
'count_users' => $countUsers,
'category_code' => $row['category_code'],
'count_connections' => $connectionsLastMonth,
];
$courseInfo['point_info'] = CourseManager::get_course_ranking($courseId, 0);
$courseInfo['tutor'] = $courseInfo['tutor_name'];
$courseInfo['registration_code'] = !empty($courseInfo['registration_code']);
$courseInfo['count_users'] = $countUsers;
$courseInfo['count_connections'] = $connectionsLastMonth;
$courses[] = $courseInfo;
}
return $courses;
@ -714,36 +712,6 @@ class CoursesAndSessionsCatalog
public static function browseSessions($date = null, $limit = [], $returnQueryBuilder = false, $getCount = false)
{
$urlId = api_get_current_access_url_id();
/*$dql = "SELECT $select
FROM ChamiloCoreBundle:Session s
WHERE EXISTS
(
SELECT url.sessionId FROM ChamiloCoreBundle:AccessUrlRelSession url
WHERE url.sessionId = s.id AND url.accessUrlId = $urlId
) AND
s.nbrCourses > 0
";
if (!is_null($date)) {
$date = Database::escape_string($date);
$dql .= "
AND (
(s.accessEndDate IS NULL)
OR
(
s.accessStartDate IS NOT NULL AND
s.accessEndDate IS NOT NULL AND
s.accessStartDate <= '$date' AND s.accessEndDate >= '$date')
OR
(
s.accessStartDate IS NULL AND
s.accessEndDate IS NOT NULL AND
s.accessEndDate >= '$date'
)
)
";
}*/
$em = Database::getManager();
$qb = $em->createQueryBuilder();
$qb2 = $em->createQueryBuilder();

@ -1075,21 +1075,7 @@ class Agenda
break;
case 'course':
$courseId = api_get_course_int_id();
$sessionId = api_get_session_id();
$isAllowToEdit = api_is_allowed_to_edit(null, true);
if (false == $isAllowToEdit && !empty($sessionId)) {
$allowDhrToEdit = api_get_configuration_value('allow_agenda_edit_for_hrm');
if ($allowDhrToEdit) {
$isHrm = SessionManager::isUserSubscribedAsHRM(
$sessionId,
api_get_user_id()
);
if ($isHrm) {
$isAllowToEdit = true;
}
}
}
$isAllowToEdit = $this->getIsAllowedToEdit();
if (!empty($courseId) && $isAllowToEdit) {
// Delete
@ -3146,6 +3132,13 @@ class Agenda
Display::return_icon('1day.png', get_lang('Sessions plan calendar'), [], ICON_SIZE_MEDIUM),
$codePath."calendar/planification.php"
);
if (api_is_student_boss() || api_is_platform_admin()) {
$actionsLeft .= Display::url(
Display::return_icon('calendar-user.png', get_lang('MyStudentsSchedule'), [], ICON_SIZE_MEDIUM),
$codePath.'mySpace/calendar_plan.php'
);
}
}
if (api_is_platform_admin() ||

@ -2121,19 +2121,19 @@ function api_get_anonymous_id()
}
/**
* @param string $courseCode
* @param int $courseId
* @param int $sessionId
* @param int $groupId
*
* @return string
*/
function api_get_cidreq_params($courseCode, $sessionId = 0, $groupId = 0)
function api_get_cidreq_params($courseId, $sessionId = 0, $groupId = 0)
{
$courseCode = !empty($courseCode) ? htmlspecialchars($courseCode) : '';
$courseId = !empty($courseId) ? (int) $courseId :0;
$sessionId = !empty($sessionId) ? (int) $sessionId : 0;
$groupId = !empty($groupId) ? (int) $groupId : 0;
$url = 'cid='.$courseCode;
$url = 'cid='.$courseId;
$url .= '&sid='.$sessionId;
$url .= '&gid='.$groupId;
@ -3401,6 +3401,7 @@ function api_display_tool_title($title_element)
if (is_string($title_element)) {
$tit = $title_element;
unset($title_element);
$title_element = [];
$title_element['mainTitle'] = $tit;
}
echo '<h3>';

@ -52,11 +52,11 @@ function msort($array, $id = 'id', $order = 'desc')
$index = 0;
foreach ($array as $item) {
if ('desc' == $order) {
if ($item[$id] < $array[$lowest_id][$id]) {
if (strip_tags($item[$id]) < strip_tags($array[$lowest_id][$id])) {
$lowest_id = $index;
}
} else {
if (isset($item[$id]) && $item[$id] > $array[$lowest_id][$id]) {
if (isset($item[$id]) && strip_tags($item[$id]) > strip_tags($array[$lowest_id][$id])) {
$lowest_id = $index;
}
}

@ -279,6 +279,31 @@ class Attendance
return $attendances;
}
/**
* Get the attendances by id to display on the current page.
*
* @param int $attendanceId
*
* @return array attendance data
*/
public function get_attendance_by_id($attendanceId)
{
$tbl_attendance = Database::get_course_table(TABLE_ATTENDANCE);
$attendanceId = (int) $attendanceId;
$course_id = api_get_course_int_id();
$attendance_data = [];
$sql = "SELECT * FROM $tbl_attendance
WHERE c_id = $course_id AND id = '$attendanceId'";
$res = Database::query($sql);
if (Database::num_rows($res) > 0) {
while ($row = Database::fetch_array($res)) {
$attendance_data = $row;
}
}
return $attendance_data;
}
/**
* Add attendances sheet inside table. This is the *list of* dates, not
* a specific date in itself.
@ -1196,15 +1221,24 @@ class Attendance
public function get_users_attendance_sheet(
$attendanceId,
$user_id = 0,
$groupId = 0
$groupId = 0,
$course_id = 0,
DateTime $startDate = null,
DateTime $endDate = null
) {
//Get actual course or by course_id
$course_id = (0 == $course_id) ? api_get_course_int_id() : (int) $course_id;
$tbl_attendance_sheet = Database::get_course_table(TABLE_ATTENDANCE_SHEET);
$tbl_attendance_calendar = Database::get_course_table(TABLE_ATTENDANCE_CALENDAR);
$attendance_calendar = $this->get_attendance_calendar(
$attendanceId,
'all',
null,
$groupId
$groupId,
true,
$course_id,
$startDate,
$endDate
);
$calendar_ids = [];
// get all dates from calendar by current attendance
@ -1212,7 +1246,16 @@ class Attendance
$calendar_ids[] = $cal['id'];
}
$course_id = api_get_course_int_id();
$whereDate = '';
if (!empty($startDate)) {
$whereDate .= " AND cal.date_time >= '".$startDate->format('Y-m-d H:i:s')."'";
}
if (!empty($endDate)) {
$whereDate .= " AND cal.date_time <= '".$endDate->format('Y-m-d H:i:s')."'";
}
// moved at start of this function
// $course_id = api_get_course_int_id();
$data = [];
if (empty($user_id)) {
@ -1248,16 +1291,13 @@ class Attendance
att.c_id = $course_id AND
cal.c_id = $course_id AND
att.user_id = '$user_id' AND
att.attendance_calendar_id IN (".implode(',', $calendar_ids).')
ORDER BY date_time';
att.attendance_calendar_id IN (".implode(',', $calendar_ids).")
$whereDate
ORDER BY date_time";
$res = Database::query($sql);
if (Database::num_rows($res) > 0) {
while ($row = Database::fetch_array($res)) {
$row['date_time'] = api_convert_and_format_date(
$row['date_time'],
null,
date_default_timezone_get()
);
$row['date_time'] = api_convert_and_format_date($row['date_time'], null, date_default_timezone_get());
$data[$user_id][] = $row;
}
}
@ -1413,6 +1453,9 @@ class Attendance
* @param int $calendar_id
* @param int $groupId
* @param bool $showAll = false show group calendar items or not
* @param int $course_id
* @param DateTime $startDate Filter calendar with a start date
* @param DateTime $endDate Filter calendar with a end date
*
* @return array attendance calendar data
*/
@ -1421,16 +1464,27 @@ class Attendance
$type = 'all',
$calendar_id = null,
$groupId = 0,
$showAll = false
$showAll = false,
$course_id = 0,
DateTime $startDate = null,
DateTime $endDate = null
) {
$tbl_attendance_calendar = Database::get_course_table(TABLE_ATTENDANCE_CALENDAR);
$tbl_acrg = Database::get_course_table(TABLE_ATTENDANCE_CALENDAR_REL_GROUP);
$attendanceId = (int) $attendanceId;
$course_id = api_get_course_int_id();
$course_id = (0 == $course_id) ? api_get_course_int_id() : (int) $course_id;
$whereDate = '';
if (!empty($startDate)) {
$whereDate .= " AND c.date_time >= '".$startDate->format('Y-m-d H:i:s')."'";
}
if (!empty($endDate)) {
$whereDate .= " AND c.date_time <= '".$endDate->format('Y-m-d H:i:s')."'";
}
if ($showAll) {
$sql = "SELECT * FROM $tbl_attendance_calendar c
WHERE c_id = $course_id AND attendance_id = '$attendanceId'";
WHERE c_id = $course_id
AND attendance_id = '$attendanceId'
$whereDate";
} else {
$sql = "SELECT * FROM $tbl_attendance_calendar c
WHERE
@ -1440,6 +1494,7 @@ class Attendance
SELECT calendar_id FROM $tbl_acrg
WHERE c_id = $course_id AND group_id != 0 AND group_id IS NOT NULL
)
$whereDate
";
}

@ -18,76 +18,12 @@ class Auth
{
}
/**
* retrieves all the courses that the user has already subscribed to.
*
* @param int $user_id
*
* @return array an array containing all the information of the courses of the given user
*/
public function get_courses_of_user($user_id)
{
$TABLECOURS = Database::get_main_table(TABLE_MAIN_COURSE);
$TABLECOURSUSER = Database::get_main_table(TABLE_MAIN_COURSE_USER);
$avoidCoursesCondition = CoursesAndSessionsCatalog::getAvoidCourseCondition();
$visibilityCondition = CourseManager::getCourseVisibilitySQLCondition('course', true);
$tblCourseCategory = Database::get_main_table(TABLE_MAIN_CATEGORY);
// Secondly we select the courses that are in a category (user_course_cat<>0) and
// sort these according to the sort of the category
$user_id = (int) $user_id;
$sql = "SELECT
course.code k,
course.visual_code vc,
course.subscribe subscr,
course.unsubscribe unsubscr,
course.title i,
course.tutor_name t,
category.code cat,
course.directory dir,
course_rel_user.status status,
course_rel_user.sort sort,
course_rel_user.user_course_cat user_course_cat
FROM $TABLECOURS as course
LEFT JOIN $tblCourseCategory category
ON course.category_id = category.id,
$TABLECOURSUSER course_rel_user
WHERE
course.id = course_rel_user.c_id AND
course_rel_user.relation_type <> ".COURSE_RELATION_TYPE_RRHH." AND
course_rel_user.user_id = '".$user_id."'
$avoidCoursesCondition
$visibilityCondition
ORDER BY course_rel_user.sort ASC";
$result = Database::query($sql);
$courses = [];
while ($row = Database::fetch_array($result)) {
//we only need the database name of the course
$courses[] = [
'code' => $row['k'],
'visual_code' => $row['vc'],
'title' => $row['i'],
'directory' => $row['dir'],
'status' => $row['status'],
'tutor' => $row['t'],
'subscribe' => $row['subscr'],
'category' => $row['cat'],
'unsubscribe' => $row['unsubscr'],
'sort' => $row['sort'],
'user_course_category' => $row['user_course_cat'],
];
}
return $courses;
}
/**
* This function get all the courses in the particular user category.
*
* @return array
*/
public function get_courses_in_category()
public function getCoursesInCategory()
{
$user_id = api_get_user_id();
@ -169,7 +105,7 @@ class Auth
$table = Database::get_main_table(TABLE_MAIN_COURSE_USER);
$current_user_id = api_get_user_id();
$all_user_courses = $this->get_courses_of_user($current_user_id);
$all_user_courses = CourseManager::getCoursesByUserCourseCategory($current_user_id);
// we need only the courses of the category we are moving in
$user_courses = [];
@ -238,7 +174,7 @@ class Auth
public function move_category($direction, $category2move)
{
$userId = api_get_user_id();
$userCategories = CourseManager::get_user_course_categories(api_get_user_id());
$userCategories = CourseManager::get_user_course_categories($userId);
$categories = array_values($userCategories);
$previous = null;
@ -290,7 +226,6 @@ class Auth
*/
public function store_edit_course_category($title, $category_id)
{
// protect data
$title = Database::escape_string($title);
$category_id = (int) $category_id;
$result = false;
@ -355,9 +290,8 @@ class Auth
id= $categoryId AND
user_id= $userId";
$resultQuery = Database::query($sql);
$result = Database::fetch_array($resultQuery, 'ASSOC');
return $result;
return Database::fetch_array($resultQuery, 'ASSOC');
}
/**
@ -412,7 +346,6 @@ class Auth
// protect data
$current_user_id = api_get_user_id();
$category_title = Database::escape_string($category_title);
$result = false;
// step 1: we determine the max value of the user defined course categories
$sql = "SELECT sort FROM $table
@ -430,15 +363,19 @@ class Auth
title='".$category_title."'
ORDER BY sort DESC";
$rs = Database::query($sql);
if (0 == Database::num_rows($rs)) {
$result = false;
if (Database::num_rows($rs) == 0) {
$sql = "INSERT INTO $table (user_id, title,sort)
VALUES ('".$current_user_id."', '".api_htmlentities($category_title, ENT_QUOTES, api_get_system_encoding())."', '".$nextsort."')";
VALUES ('".$current_user_id."', '".api_htmlentities(
$category_title,
ENT_QUOTES,
api_get_system_encoding()
)."', '".$nextsort."')";
$resultQuery = Database::query($sql);
if (Database::affected_rows($resultQuery)) {
$result = true;
}
} else {
$result = false;
}
return $result;

@ -1,6 +1,8 @@
<?php
/* For licensing terms, see /license.txt */
use Endroid\QrCode\ErrorCorrectionLevel;
use Endroid\QrCode\QrCode;
/**
@ -513,13 +515,17 @@ class Certificate extends Model
// Make sure HTML certificate is generated
if (!empty($text) && !empty($path)) {
$qrCode = new QrCode($text);
//$qrCode->setEncoding('UTF-8');
$qrCode->setSize(120);
$qrCode->setMargin(5);
$qrCode->setWriterByName('png');
$qrCode->setErrorCorrectionLevel(ErrorCorrectionLevel::MEDIUM());
$qrCode->setForegroundColor(['r' => 0, 'g' => 0, 'b' => 0, 'a' => 0]);
$qrCode->setBackgroundColor(['r' => 255, 'g' => 255, 'b' => 255, 'a' => 0]);
$qrCode->setValidateResult(false);
$qrCode->writeFile($path);
//L low, M - Medium, L large error correction
//return QrCode::png($text, $path, 'M', 2, 2);
return file_exists($path);
return true;
}
return false;

@ -2357,13 +2357,13 @@ class CourseManager
$tbl_session_course_user = Database::get_main_table(TABLE_MAIN_SESSION_COURSE_USER);
$sql = "SELECT DISTINCT
u.user_id,
u.id as user_id,
u.lastname,
u.firstname,
u.username
FROM $tbl_user u
INNER JOIN $tbl_session_course_user scu
ON (u.user_id = scu.user_id)
ON (u.id = scu.user_id)
WHERE
scu.session_id = $session_id AND
scu.c_id = $courseId AND
@ -2821,8 +2821,10 @@ class CourseManager
}
if (api_strcasecmp($course_title_precedent, $course_title) < 0) {
$course_found = true;
$course_sort = $courses['sort'];
if (0 == $counter) {
if (!empty($courses['sort'])) {
$course_sort = $courses['sort'];
}
if ($counter == 0) {
$sql = "UPDATE $TABLECOURSUSER
SET sort = sort+1
WHERE
@ -2970,39 +2972,52 @@ class CourseManager
$courseTable = Database::get_main_table(TABLE_MAIN_COURSE);
$tbl_course_field = Database::get_main_table(TABLE_EXTRA_FIELD);
$tbl_course_field_value = Database::get_main_table(TABLE_EXTRA_FIELD_VALUES);
//we filter the courses from the URL
$join_access_url = $where_access_url = '';
if (api_get_multiple_access_url()) {
$access_url_id = api_get_current_access_url_id();
if (-1 != $access_url_id) {
$tbl_url_course = Database::get_main_table(TABLE_MAIN_ACCESS_URL_REL_COURSE);
$join_access_url = "LEFT JOIN $tbl_url_course url_rel_course
ON url_rel_course.c_id = tcfv.item_id ";
$where_access_url = " AND access_url_id = $access_url_id ";
}
}
$extraFieldType = EntityExtraField::COURSE_FIELD_TYPE;
$courseList = [];
// get course list auto-register
$sql = "SELECT DISTINCT(c.id)
FROM $tbl_course_field_value tcfv
INNER JOIN $tbl_course_field tcf
ON tcfv.field_id = tcf.id $join_access_url
INNER JOIN $courseTable c
ON (c.id = tcfv.item_id)
WHERE
tcf.extra_field_type = $extraFieldType AND
tcf.variable = 'special_course' AND
tcfv.value = 1 $where_access_url";
$sql = "SELECT id FROM $tbl_course_field
WHERE extra_field_type = $extraFieldType AND
variable = 'special_course'";
$result = Database::query($sql);
$courseList = [];
if (Database::num_rows($result) > 0) {
while ($row = Database::fetch_array($result)) {
$courseList[] = $row['id'];
$row = Database::fetch_assoc($result);
// Get list of special courses (appear to all)
// Note: The value is better indexed as string, so
// using '1' instead of integer is more efficient
$sql = "SELECT DISTINCT(item_id) as cid
FROM $tbl_course_field_value
WHERE field_id = ".$row['id']." AND value = '1'";
$result = Database::query($sql);
while ($row = Database::fetch_assoc($result)) {
$courseList[] = $row['cid'];
}
if (count($courseList) < 1) {
return $courseList;
}
if (api_get_multiple_access_url()) {
//we filter the courses by the active URL
$coursesSelect = '';
if (count($courseList) == 1) {
$coursesSelect = $courseList[0];
} else {
$coursesSelect = implode(',', $courseList);
}
$access_url_id = api_get_current_access_url_id();
if ($access_url_id != -1) {
$sql = "SELECT c_id FROM $tbl_url_course
WHERE access_url_id = $access_url_id
AND c_id IN ($coursesSelect)";
$result = Database::query($sql);
while ($row = Database::fetch_assoc($result)) {
$courseList[] = $row['c_id'];
}
}
}
}
@ -3305,14 +3320,6 @@ class CourseManager
*/
public static function update_attributes($id, $attributes)
{
$courseCategory = CourseCategory::getCategory($attributes['category_code']);
unset($attributes['category_code']);
if (!empty($courseCategory)) {
$attributes['category_id'] = $courseCategory['id'];
}
$id = (int) $id;
$table = Database::get_main_table(TABLE_MAIN_COURSE);
$sql = "UPDATE $table SET ";
@ -3403,7 +3410,7 @@ class CourseManager
/**
* Gets extra field value data and formatted values of a course
* for extra fields listed in configuration.php in My_course_course_extrafields_to_be_presented
* for extra fields listed in configuration.php in my_course_course_extrafields_to_be_presented
* (array of variables as value of key 'fields').
*
* @param $courseId int The numeric identifier of the course
@ -3413,7 +3420,7 @@ class CourseManager
public static function getExtraFieldsToBePresented($courseId)
{
$extraFields = [];
$fields = api_get_configuration_sub_value('My_course_course_extrafields_to_be_presented/fields');
$fields = api_get_configuration_sub_value('my_course_course_extrafields_to_be_presented/fields');
if (!empty($fields) && is_array($fields)) {
$extraFieldManager = new ExtraField('course');
$dataAndFormattedValues = $extraFieldManager->getDataAndFormattedValues($courseId);
@ -3909,7 +3916,7 @@ class CourseManager
'not_category' => [],
];
$collapsable = api_get_configuration_value('allow_user_course_category_collapsable');
$stok = Security::get_token();
$stok = Security::get_existing_token();
while ($row = Database::fetch_array($result)) {
// We simply display the title of the category.
$courseInCategory = self::returnCoursesCategories(
@ -4302,11 +4309,7 @@ class CourseManager
return '';
}
$userInCourseStatus = self::getUserInCourseStatus(
$user_id,
$course_info['real_id']
);
$userInCourseStatus = self::getUserInCourseStatus($user_id, $course_info['real_id']);
$course_info['status'] = empty($session_id) ? $userInCourseStatus : STUDENT;
$course_info['id_session'] = $session_id;
@ -6067,7 +6070,7 @@ class CourseManager
public static function getCourseUsers($filterByActive = null)
{
// This would return only the users from real courses:
$userList = self::get_user_list_from_course_code(
return self::get_user_list_from_course_code(
api_get_course_id(),
api_get_session_id(),
null,
@ -6081,8 +6084,6 @@ class CourseManager
[],
$filterByActive
);
return $userList;
}
/**
@ -6115,7 +6116,7 @@ class CourseManager
*
* @return HTML_QuickForm_element
*/
public static function addUserGroupMultiSelect(&$form, $alreadySelected)
public static function addUserGroupMultiSelect(&$form, $alreadySelected, $addShortCut = false)
{
$userList = self::getCourseUsers(true);
$groupList = self::getCourseGroups();
@ -6131,13 +6132,50 @@ class CourseManager
$result[$content['value']] = $content['content'];
}
return $form->addElement(
$multiple = $form->addElement(
'advmultiselect',
'users',
get_lang('Users'),
$result,
['select_all_checkbox' => true]
['select_all_checkbox' => true, 'id' => 'users']
);
$sessionId = api_get_session_id();
if ($addShortCut && empty($sessionId)) {
$addStudents = [];
foreach ($userList as $user) {
if ($user['status_rel'] == STUDENT) {
$addStudents[] = $user['user_id'];
}
}
if (!empty($addStudents)) {
$form->addHtml(
'<script>
$(function() {
$("#add_students").on("click", function() {
var addStudents = '.json_encode($addStudents).';
$.each(addStudents, function( index, value ) {
var option = $("#users option[value=\'USER:"+value+"\']");
if (option.val()) {
$("#users_to").append(new Option(option.text(), option.val()))
option.remove();
}
});
return false;
});
});
</script>'
);
$form->addLabel(
'',
Display::url(get_lang('AddStudent'), '#', ['id' => 'add_students', 'class' => 'btn btn-primary'])
);
}
}
return $multiple;
}
/**
@ -6955,13 +6993,24 @@ class CourseManager
private static function checkCreateCourseAccessUrlParam($_configuration, $accessUrlId, $param, $msgLabel)
{
if (isset($_configuration[$accessUrlId][$param]) && $_configuration[$accessUrlId][$param] > 0) {
$num = null;
switch ($param) {
case 'hosting_limit_courses':
$num = self::count_courses($accessUrlId);
if ($num >= $_configuration[$accessUrlId][$param]) {
break;
case 'hosting_limit_active_courses':
$num = self::countActiveCourses($accessUrlId);
break;
}
if ($num && $num >= $_configuration[$accessUrlId][$param]) {
api_warn_hosting_contact($param);
Display::addFlash(
Display::return_message($msgLabel)
);
return true;
}
}

@ -158,9 +158,8 @@ class CourseCategory
ORDER BY t1.parent_id, t1.tree_pos";
$result = Database::query($sql);
$categories = Database::store_result($result, 'ASSOC');
return $categories;
return Database::store_result($result, 'ASSOC');
}
/**
@ -469,9 +468,8 @@ class CourseCategory
foreach ($parents as $category) {
$categories[] = $category['code'];
}
$categoriesInString = implode(' > ', $categories).' > ';
return $categoriesInString;
return implode(' > ', $categories).' > ';
}
return null;
@ -710,6 +708,11 @@ class CourseCategory
$conditions = " INNER JOIN $table a ON (c.id = a.course_category_id)";
$whereCondition = " AND a.access_url_id = ".api_get_current_access_url_id();
$allowBaseCategories = api_get_configuration_value('allow_base_course_category');
if ($allowBaseCategories) {
$whereCondition = " AND (a.access_url_id = ".api_get_current_access_url_id()." OR a.access_url_id = 1) ";
}
$keyword = Database::escape_string($keyword);
$sql = "SELECT c.*, c.name as text

@ -611,11 +611,20 @@ class CourseRequestManager
$email_body .= get_lang('Email', null, $email_language).': '.api_get_setting('emailAdministrator', null, $email_language)."\n";
$email_body .= "\n".get_lang('CourseRequestLegalNote', null, $email_language)."\n";
$sender_name = api_get_person_name(api_get_setting('administratorName'), api_get_setting('administratorSurname'), null, PERSON_NAME_EMAIL_ADDRESS);
$sender_name = api_get_person_name(
api_get_setting('administratorName'),
api_get_setting('administratorSurname'),
null,
PERSON_NAME_EMAIL_ADDRESS
);
$sender_email = api_get_setting('emailAdministrator');
$recipient_name = api_get_person_name($user_info['firstname'], $user_info['lastname'], null, PERSON_NAME_EMAIL_ADDRESS);
$recipient_name = api_get_person_name(
$user_info['firstname'],
$user_info['lastname'],
null,
PERSON_NAME_EMAIL_ADDRESS
);
$recipient_email = $user_info['mail'];
$extra_headers = 'Bcc: '.$sender_email;
$additionalParameters = [
'smsType' => SmsPlugin::COURSE_OPENING_REQUEST_CODE_REJECTED,
@ -697,9 +706,13 @@ class CourseRequestManager
PERSON_NAME_EMAIL_ADDRESS
);
$sender_email = api_get_setting('emailAdministrator');
$recipient_name = api_get_person_name($user_info['firstname'], $user_info['lastname'], null, PERSON_NAME_EMAIL_ADDRESS);
$recipient_name = api_get_person_name(
$user_info['firstname'],
$user_info['lastname'],
null,
PERSON_NAME_EMAIL_ADDRESS
);
$recipient_email = $user_info['mail'];
$extra_headers = 'Bcc: '.$sender_email;
$additionalParameters = [
'smsType' => SmsPlugin::COURSE_OPENING_REQUEST_CODE,

@ -508,6 +508,7 @@ class Event
$position = Database::escape_string($position);
$now = api_get_utc_datetime();
$course_id = (int) $course_id;
$recording = api_get_configuration_value('quiz_answer_extra_recording') == true;
// check user_id or get from context
if (empty($user_id)) {
@ -613,13 +614,14 @@ class Event
error_log("Insert attempt with id #$attempt_id");
}
if (defined('ENABLED_LIVE_EXERCISE_TRACKING')) {
if ($recording) {
if ($debug) {
error_log("Saving e attempt recording ");
}
$attempt_recording = [
'exe_id' => $attempt_id,
'question_id' => $question_id,
'answer' => $answer,
'marks' => $score,
'insert_date' => $now,
'author' => '',
@ -640,10 +642,11 @@ class Event
]
);
if (defined('ENABLED_LIVE_EXERCISE_TRACKING')) {
if ($recording) {
$attempt_recording = [
'exe_id' => $exe_id,
'question_id' => $question_id,
'answer' => $answer,
'marks' => $score,
'insert_date' => $now,
'author' => '',
@ -2042,6 +2045,7 @@ class Event
* @param int $sessionId The session in which to add the time (if any)
* @param string $virtualTime The amount of time to be added,
* in a hh:mm:ss format. If int, we consider it is expressed in hours.
* @param int $workId Student publication id result
*
* @return true on successful insertion, false otherwise
*/
@ -2049,8 +2053,13 @@ class Event
$courseId,
$userId,
$sessionId,
$virtualTime = ''
$virtualTime,
$workId
) {
if (empty($virtualTime)) {
return false;
}
$courseId = (int) $courseId;
$userId = (int) $userId;
$sessionId = (int) $sessionId;
@ -2062,6 +2071,7 @@ class Event
false
);
$ip = api_get_real_ip();
$params = [
'login_course_date' => $loginDate,
'logout_course_date' => $logoutDate,
@ -2069,11 +2079,50 @@ class Event
'user_id' => $userId,
'counter' => 0,
'c_id' => $courseId,
'user_ip' => api_get_real_ip(),
'user_ip' => $ip,
];
$courseTrackingTable = Database::get_main_table(TABLE_STATISTIC_TRACK_E_COURSE_ACCESS);
Database::insert($courseTrackingTable, $params);
// Time should also be added to the track_e_login table so as to
// affect total time on the platform
$params = [
'login_user_id' => $userId,
'login_date' => $loginDate,
'user_ip' => $ip,
'logout_date' => $logoutDate,
];
$platformTrackingTable = Database::get_main_table(TABLE_STATISTIC_TRACK_E_LOGIN);
Database::insert($platformTrackingTable, $params);
if (Tracking::minimumTimeAvailable($sessionId, $courseId)) {
$workId = (int) $workId;
$uniqueId = time();
$logInfo = [
'c_id' => $courseId,
'session_id' => $sessionId,
'tool' => TOOL_STUDENTPUBLICATION,
'date_reg' => $loginDate,
'action' => 'add_work_start_'.$workId,
'action_details' => $virtualTime,
'user_id' => $userId,
'current_id' => $uniqueId,
];
self::registerLog($logInfo);
$logInfo = [
'c_id' => $courseId,
'session_id' => $sessionId,
'tool' => TOOL_STUDENTPUBLICATION,
'date_reg' => $logoutDate,
'action' => 'add_work_end_'.$workId,
'action_details' => $virtualTime,
'user_id' => $userId,
'current_id' => $uniqueId,
];
self::registerLog($logInfo);
}
return true;
}
@ -2100,18 +2149,24 @@ class Event
$courseId,
$userId,
$sessionId = 0,
$virtualTime = ''
$virtualTime,
$workId
) {
if (empty($virtualTime)) {
return false;
}
$originalVirtualTime = $virtualTime;
$courseTrackingTable = Database::get_main_table(TABLE_STATISTIC_TRACK_E_COURSE_ACCESS);
$platformTrackingTable = Database::get_main_table(TABLE_STATISTIC_TRACK_E_LOGIN);
$courseId = (int) $courseId;
$userId = (int) $userId;
$sessionId = (int) $sessionId;
// Change $virtualTime format from hh:mm:ss to hhmmss which is the
// format returned by SQL for a subtraction of two datetime values
// @todo make sure this is portable between DBMSes
// @todo make sure this is portable between DBMSes
if (preg_match('/:/', $virtualTime)) {
list($h, $m, $s) = preg_split('/:/', $virtualTime);
$virtualTime = $h * 3600 + $m * 60 + $s;
@ -2140,9 +2195,55 @@ class Event
$courseAccessId = $row[0];
$sql = "DELETE FROM $courseTrackingTable
WHERE course_access_id = $courseAccessId";
Database::query($sql);
}
$sql = "SELECT login_id
FROM $platformTrackingTable
WHERE
login_user_id = $userId AND
(UNIX_TIMESTAMP(logout_date) - UNIX_TIMESTAMP(login_date)) = '$virtualTime'
ORDER BY login_date DESC LIMIT 0,1";
$result = Database::query($sql);
if (Database::num_rows($result) > 0) {
$row = Database::fetch_row($result);
$loginAccessId = $row[0];
$sql = "DELETE FROM $platformTrackingTable
WHERE login_id = $loginAccessId";
Database::query($sql);
}
if (Tracking::minimumTimeAvailable($sessionId, $courseId)) {
$workId = (int) $workId;
$sql = "SELECT id FROM track_e_access_complete
WHERE
tool = '".TOOL_STUDENTPUBLICATION."' AND
c_id = $courseId AND
session_id = $sessionId AND
user_id = $userId AND
action_details = '$originalVirtualTime' AND
action = 'add_work_start_$workId' ";
$result = Database::query($sql);
$result = Database::fetch_array($result);
if ($result) {
$sql = 'DELETE FROM track_e_access_complete WHERE id = '.$result['id'];
Database::query($sql);
}
return $result;
$sql = "SELECT id FROM track_e_access_complete
WHERE
tool = '".TOOL_STUDENTPUBLICATION."' AND
c_id = $courseId AND
session_id = $sessionId AND
user_id = $userId AND
action_details = '$originalVirtualTime' AND
action = 'add_work_end_$workId' ";
$result = Database::query($sql);
$result = Database::fetch_array($result);
if ($result) {
$sql = 'DELETE FROM track_e_access_complete WHERE id = '.$result['id'];
Database::query($sql);
}
}
return false;
@ -2161,6 +2262,14 @@ class Event
$sessionId = api_get_session_id();
$courseId = api_get_course_int_id();
if (isset($logInfo['c_id']) && !empty($logInfo['c_id'])) {
$courseId = $logInfo['c_id'];
}
if (isset($logInfo['session_id']) && !empty($logInfo['session_id'])) {
$sessionId = $logInfo['session_id'];
}
if (!Tracking::minimumTimeAvailable($sessionId, $courseId)) {
return false;
}
@ -2169,10 +2278,10 @@ class Event
return false;
}
$loginAs = true === (int) Session::read('login_as');
$loginAs = (int) Session::read('login_as') === true;
$logInfo['user_id'] = api_get_user_id();
$logInfo['date_reg'] = api_get_utc_datetime();
$logInfo['user_id'] = isset($logInfo['user_id']) ? $logInfo['user_id'] : api_get_user_id();
$logInfo['date_reg'] = isset($logInfo['date_reg']) ? $logInfo['date_reg'] : api_get_utc_datetime();
$logInfo['tool'] = !empty($logInfo['tool']) ? $logInfo['tool'] : '';
$logInfo['tool_id'] = !empty($logInfo['tool_id']) ? (int) $logInfo['tool_id'] : 0;
$logInfo['tool_id_detail'] = !empty($logInfo['tool_id_detail']) ? (int) $logInfo['tool_id_detail'] : 0;
@ -2186,7 +2295,7 @@ class Event
$logInfo['login_as'] = $loginAs;
$logInfo['info'] = !empty($logInfo['info']) ? $logInfo['info'] : '';
$logInfo['url'] = $_SERVER['REQUEST_URI'];
$logInfo['current_id'] = Session::read('last_id', 0);
$logInfo['current_id'] = isset($logInfo['current_id']) ? $logInfo['current_id'] : Session::read('last_id', 0);
$id = Database::insert('track_e_access_complete', $logInfo);
if ($id && empty($logInfo['current_id'])) {

@ -1,4 +1,5 @@
<?php
/* For licensing terms, see /license.txt */
/**
@ -64,7 +65,6 @@ class DateRangePicker extends HTML_QuickForm_text
$end = isset($dates[1]) ? $dates[1] : '';
$pattern = 'yyyy-MM-dd HH:mm';
if ('false' === $this->getAttribute('timePicker') &&
false === strpos($this->getAttribute('format'), 'HH:mm')) {
$pattern = 'yyyy-MM-dd';
@ -182,12 +182,17 @@ class DateRangePicker extends HTML_QuickForm_text
$timePicker = 'false';
}
$timeIncrement = 30;
if (api_get_configuration_value('timepicker_increment')) {
$timeIncrement = api_get_configuration_value('timepicker_increment');
}
// timeFormat: 'hh:mm'
$js .= "<script>
$(function() {
$('#$id').daterangepicker({
timePicker: $timePicker,
timePickerIncrement: 30,
timePickerIncrement: $timeIncrement,
timePicker12Hour: false,
$defaultDates
$maxDate

@ -1,4 +1,5 @@
<?php
/* For licensing terms, see /license.txt */
/**
@ -74,6 +75,10 @@ class SelectAjax extends HTML_QuickForm_select
$max = $this->getAttribute('maximumSelectionLength');
$max = !empty($max) ? "maximumSelectionLength: $max, " : '';
// wait XX milliseconds before triggering the request
$delay = (int) $this->getAttribute('delay');
$delay = (0 !== $delay) ? "delay: $delay, " : '';
$html = <<<JS
<script>
$(function(){
@ -86,6 +91,7 @@ class SelectAjax extends HTML_QuickForm_select
tags: $tags,
ajax: {
url: $url,
{$delay}
dataType: 'json',
data: function(params) {
return {

@ -12,6 +12,7 @@ class FormValidator extends HTML_QuickForm
public const LAYOUT_BOX = 'box';
public const LAYOUT_BOX_NO_LABEL = 'box-no-label';
public const LAYOUT_BOX_SEARCH = 'box-search';
public const LAYOUT_GRID = 'grid';
public $with_progress_bar = false;
private $layout;
@ -48,14 +49,23 @@ class FormValidator extends HTML_QuickForm
$this->setLayout($layout);
// Form template
$formTemplate = $this->getFormTemplate();
switch ($layout) {
case self::LAYOUT_HORIZONTAL:
$attributes['class'] = 'form-horizontal';
break;
case self::LAYOUT_INLINE:
case self::LAYOUT_BOX:
$attributes['class'] = 'form-inline';
break;
case self::LAYOUT_BOX:
$attributes['class'] = 'form-inline-box';
break;
case self::LAYOUT_GRID:
$attributes['class'] = 'form-grid';
$formTemplate = $this->getGridFormTemplate();
break;
}
parent::__construct($name, $method, $action, $target, $attributes, $trackSubmit);
@ -63,15 +73,13 @@ class FormValidator extends HTML_QuickForm
// Modify the default templates
$renderer = &$this->defaultRenderer();
// Form template
$formTemplate = $this->getFormTemplate();
$renderer->setFormTemplate($formTemplate);
// Element template
if (isset($attributes['class']) && 'form-inline' == $attributes['class']) {
if (isset($attributes['class']) && $attributes['class'] == 'form-inline') {
$elementTemplate = ' {label} {element} ';
$renderer->setElementTemplate($elementTemplate);
} elseif (isset($attributes['class']) && 'form-search' == $attributes['class']) {
} elseif (isset($attributes['class']) && $attributes['class'] == 'form-search') {
$elementTemplate = ' {label} {element} ';
$renderer->setElementTemplate($elementTemplate);
} else {
@ -84,13 +92,6 @@ class FormValidator extends HTML_QuickForm
//Display a gray div in the buttons + makes the button available when scrolling
$templateBottom = '<div class="form-actions bottom_actions bg-form">{label} {element}</div>';
$renderer->setElementTemplate($templateBottom, 'submit_fixed_in_bottom');
//When you want to group buttons use something like this
/* $group = array();
$group[] = $form->createElement('button', 'mark_all', get_lang('Select all'));
$group[] = $form->createElement('button', 'unmark_all', get_lang('Unselect all'));
$form->addGroup($group, 'buttons_in_action');
*/
$renderer->setElementTemplate($templateSimple, 'buttons_in_action');
$templateSimpleRight = '<div class="form-actions"> <div class="pull-right">{label} {element}</div></div>';
@ -126,6 +127,31 @@ EOT;
</form>';
}
/**
* @return string
*/
public function getGridFormTemplate()
{
return '
<style>
.form_list {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));;
grid-gap: 10px 30px;
gap: 10px 30px;
}
.form_list .input-group {
display:block;
}
</style>
<form{attributes}>
<div class="form_list">
{content}
</div>
{hidden}
</form>';
}
/**
* @todo this function should be added in the element class
*
@ -973,7 +999,12 @@ EOT;
*/
public function addHtml($snippet)
{
if (empty($snippet)) {
return false;
}
$this->addElement('html', $snippet);
return true;
}
/**
@ -1176,7 +1207,8 @@ EOT;
$returnValue = '';
/** @var HTML_QuickForm_element $element */
foreach ($this->_elements as $element) {
foreach ($this->_elements as &$element) {
$element->setLayout($this->getLayout());
$elementError = parent::getElementError($element->getName());
if (!is_null($elementError)) {
$returnValue .= Display::return_message($elementError, 'warning').'<br />';
@ -1188,12 +1220,8 @@ EOT;
// Add div-element which is to hold the progress bar
$id = $this->getAttribute('id');
if (isset($this->with_progress_bar) && $this->with_progress_bar) {
// Deprecated
// $icon = Display::return_icon('progress_bar.gif');
// @todo improve UI
$returnValue .= '<br />
<div id="loading_div_'.$id.'" class="loading_div" style="display:none;margin-left:40%; margin-top:10px; height:50px;">
<div class="wobblebar-loader"></div>
</div>
@ -1296,6 +1324,25 @@ EOT;
);
}
/**
* @param string $name
* @param string $label
* @param array $attributes
* @param bool $required
*
* @return HTML_QuickForm_element
*/
public function addNumeric($name, $label, $attributes = [], $required = false)
{
$element = $this->addElement('Number', $name, $label, $attributes);
if ($required) {
$this->addRule($name, get_lang('ThisFieldIsRequired'), 'required');
}
return $element;
}
/**
* Adds a text field for alphanumeric characters to the form.
* A trim-filter is attached to the field.

@ -1,4 +1,5 @@
<?php
/**
* Create, validate and process HTML forms
*
@ -62,6 +63,8 @@ define('QUICKFORM_INVALID_DATASOURCE', -9);
class HTML_QuickForm extends HTML_Common
{
const MAX_ELEMENT_ARGUMENT = 10;
private $dateTimePickerLibraryAdded;
private $token;
/**
* Array containing the form fields
@ -213,7 +216,8 @@ class HTML_QuickForm extends HTML_Common
* @param string $action (optional)Form's action
* @param string $target (optional)Form's target defaults to '_self'
* @param mixed $attributes (optional)Extra attributes for <form> tag
* @param bool $trackSubmit (optional)Whether to track if the form was submitted by adding a special hidden field
* @param bool $trackSubmit (optional)Whether to track if the form was submitted by adding a
* special hidden field
* @access public
*/
public function __construct(
@ -224,7 +228,9 @@ class HTML_QuickForm extends HTML_Common
$attributes = null,
$trackSubmit = false
) {
$this->token = null;
parent::__construct($attributes);
$method = (strtoupper($method) == 'GET') ? 'get' : 'post';
$action = ($action == '') ? api_get_self() : $action;
$target = empty($target) ? array() : array('target' => $target);
@ -236,7 +242,7 @@ class HTML_QuickForm extends HTML_Common
'action' => $action,
'method' => $method,
'name' => $formName,
'id' => $form_id
'id' => $form_id,
) + $target;
$this->updateAttributes($attributes);
if (!$trackSubmit || isset($_REQUEST['_qf__' . $formName])) {
@ -267,6 +273,28 @@ class HTML_QuickForm extends HTML_Common
}
}
public function protect()
{
$token = $this->getSubmitValue('protect_token');
if (null === $token) {
$token = Security::get_token();
} else {
$token = Security::get_existing_token();
}
$this->addHidden('protect_token', $token);
$this->setToken($token);
}
public function setToken($token)
{
$this->token = $token;
}
public function getToken()
{
return $this->token;
}
/**
* Returns the current API version
*
@ -359,21 +387,6 @@ class HTML_QuickForm extends HTML_Common
}
}
/**
* @param string $elementName
* @param string $defaultValue
*/
public function setDefault($elementName, $defaultValue)
{
if (!$this->elementExists($elementName)) {
throw new \Exception('Element does not exists');
}
$element = $this->getElement($elementName);
$this->_defaultValues[$elementName] = $defaultValue;
$element->onQuickFormEvent('updateValue', null, $this);
}
/**
* Initializes constant form values.
* These values won't get overridden by POST or GET vars
@ -663,6 +676,7 @@ class HTML_QuickForm extends HTML_Common
}
// If not done, the elements will appear in reverse order
ksort($this->_elements);
return $element;
}
@ -696,8 +710,8 @@ class HTML_QuickForm extends HTML_Common
if ($createElement) {
return $this->createElement('group', $name, $groupLabel, $elements, $separator, $appendName);
}
$group = & $this->addElement('group', $name, $groupLabel, $elements, $separator, $appendName);
return $group;
return $this->addElement('group', $name, $groupLabel, $elements, $separator, $appendName);
}
/**
@ -824,7 +838,7 @@ class HTML_QuickForm extends HTML_Common
}
$fileValue = eval($code . " return \$v;\n}\n");
if (null !== $fileValue) {
$value = null === $value? $fileValue: self::arrayMerge($value, $fileValue);
$value = null === $value? $fileValue: HTML_QuickForm::arrayMerge($value, $fileValue);
}
}
}
@ -1001,12 +1015,13 @@ class HTML_QuickForm extends HTML_Common
* To validate grouped elements as separated entities,
* use addGroupRule instead of addRule.
*
* @param string $element Form element name
* @param string|array $element Form element name
* @param string $message Message to display for invalid data
* @param string $type Rule type, use getRegisteredRules() to get types
* @param string $format (optional)Required for extra rule data
* @param string $validation (optional)Where to perform validation: "server", "client"
* @param boolean $reset Client-side validation: reset the form element to its original value if there is an error?
* @param boolean $reset Client-side validation: reset the form element to its original value if there is an
* error?
* @param boolean $force Force the rule to be applied, even if the target form element does not exist
* @param array|string $dependent needed when comparing values
* @since 1.0
@ -1080,7 +1095,8 @@ class HTML_QuickForm extends HTML_Common
* @param string $format (optional)Required for extra rule data
* @param int $howmany (optional)How many valid elements should be in the group
* @param string $validation (optional)Where to perform validation: "server", "client"
* @param bool $reset Client-side: whether to reset the element's value to its original state if validation failed.
* @param bool $reset Client-side: whether to reset the element's value to its original state if
* validation failed.
* @since 2.5
* @access public
* @throws HTML_QuickForm_Error
@ -1265,7 +1281,7 @@ class HTML_QuickForm extends HTML_Common
if (!isset($a[$k])) {
$a[$k] = array();
}
$a[$k] = self::arrayMerge($a[$k], $v);
$a[$k] = HTML_QuickForm::arrayMerge($a[$k], $v);
}
} else {
$a[$k] = $v;
@ -1410,6 +1426,14 @@ class HTML_QuickForm extends HTML_Common
return false;
}
if (null !== $this->getToken()) {
$check = Security::check_token('form', $this);
Security::clear_token();
if (false === $check) {
return false;
}
}
$registry =& HTML_QuickForm_RuleRegistry::singleton();
foreach ($this->_rules as $target => $rules) {
@ -1567,7 +1591,7 @@ class HTML_QuickForm extends HTML_Common
if (!is_callable($callback)) {
throw new \Exception("Callback function does not exist in QuickForm::process()");
}
$values = ($mergeFiles === true) ? self::arrayMerge($this->_submitValues, $this->_submitFiles) : $this->_submitValues;
$values = ($mergeFiles === true) ? HTML_QuickForm::arrayMerge($this->_submitValues, $this->_submitFiles) : $this->_submitValues;
return call_user_func($callback, $values);
}
@ -1583,9 +1607,11 @@ class HTML_QuickForm extends HTML_Common
public function accept(&$renderer)
{
$renderer->startForm($this);
/** @var HTML_QuickForm_element $element */
foreach (array_keys($this->_elements) as $key) {
$element =& $this->_elements[$key];
$elementName = $element->getName();
$element->setLayout($this->getLayout());
$required = ($this->isElementRequired($elementName) && !$element->isFrozen());
$error = $this->getElementError($elementName);
$element->accept($renderer, $required, $error);
@ -1652,7 +1678,7 @@ class HTML_QuickForm extends HTML_Common
"\t" => '\t',
"'" => "\\'",
'"' => '\"',
'\\' => '\\\\'
'\\' => '\\\\',
);
foreach ($this->_rules as $elementName => $rules) {
@ -1734,7 +1760,7 @@ class HTML_QuickForm extends HTML_Common
*/
public function getSubmitValues($mergeFiles = false)
{
return $mergeFiles ? self::arrayMerge($this->_submitValues, $this->_submitFiles): $this->_submitValues;
return $mergeFiles ? HTML_QuickForm::arrayMerge($this->_submitValues, $this->_submitFiles): $this->_submitValues;
}
/**
@ -1810,7 +1836,7 @@ class HTML_QuickForm extends HTML_Common
$value = $this->_elements[$key]->exportValue($this->_submitValues, true);
if (is_array($value)) {
// This shit throws a bogus warning in PHP 4.3.x
$values = self::arrayMerge($values, $value);
$values = HTML_QuickForm::arrayMerge($values, $value);
}
}
} else {
@ -1885,7 +1911,7 @@ class HTML_QuickForm extends HTML_Common
}
// If this is an error object, then grab the corresponding error code
if (self::isError($value)) {
if (HTML_QuickForm::isError($value)) {
$value = $value->getCode();
}
@ -1938,7 +1964,7 @@ class HTML_QuickForm_Error extends PEAR_Error
$debuginfo = null
) {
if (is_int($code)) {
parent::__construct(self::errorMessage($code), $code, $mode, $level, $debuginfo);
parent::__construct(HTML_QuickForm::errorMessage($code), $code, $mode, $level, $debuginfo);
} else {
parent::__construct("Invalid error code: $code", QUICKFORM_ERROR, $mode, $level, $debuginfo);
}

@ -1,5 +1,4 @@
<?php
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
/**
* Class representing a page of a multipage form.
@ -71,6 +70,7 @@ class HTML_QuickForm_Page extends HTML_QuickForm
* Registers a handler for a specific action.
*
* @access public
*
* @param string name of the action
* @param HTML_QuickForm_Action the handler for the action
*/
@ -87,7 +87,9 @@ class HTML_QuickForm_Page extends HTML_QuickForm
* method will be called.
*
* @access public
*
* @param string Name of the action
*
* @throws PEAR_Error
*/
function handle($actionName)
@ -104,7 +106,9 @@ class HTML_QuickForm_Page extends HTML_QuickForm
* Returns a name for a submit button that will invoke a specific action.
*
* @access public
*
* @param string Name of the action
*
* @return string "name" attribute for a submit button
*/
function getButtonName($actionName)
@ -119,6 +123,7 @@ class HTML_QuickForm_Page extends HTML_QuickForm
* The method is NOT intended for general usage.
*
* @param array 'submit' values
*
* @access public
*/
function loadValues($values)
@ -130,7 +135,6 @@ class HTML_QuickForm_Page extends HTML_QuickForm
}
}
/**
* Builds a form.
*
@ -148,7 +152,6 @@ class HTML_QuickForm_Page extends HTML_QuickForm
$this->_formBuilt = true;
}
/**
* Checks whether the form was already built.
*
@ -169,6 +172,7 @@ class HTML_QuickForm_Page extends HTML_QuickForm
* be passed to the script.
*
* @access public
*
* @param string default action name
*/
function setDefaultAction($actionName)
@ -198,6 +202,7 @@ class HTML_QuickForm_Page extends HTML_QuickForm
}
}
}
return $values;
}
}

@ -1,5 +1,4 @@
<?php
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
/**
* An abstract base class for QuickForm renderers

@ -213,12 +213,9 @@ class HTML_QuickForm_button extends HTML_QuickForm_input
$size = $this->calculateSize();
$attributes = $this->getAttributes();
$template = ' {element} ';
switch ($layout) {
case FormValidator::LAYOUT_INLINE:
return '
{element}
';
break;
case FormValidator::LAYOUT_HORIZONTAL:
if (isset($attributes['custom']) && $attributes['custom'] == true) {
$template = '
@ -226,14 +223,6 @@ class HTML_QuickForm_button extends HTML_QuickForm_input
{element}
';
} else {
if(isset($attributes['data-block']) && $attributes['data-block'] == true){
$template = '
<div class="form-group text-center">
{icon}
{element}
</div>
';
} else {
$template = '
<div class="form-group {error_class}">
<label {label-for} class="col-sm-'.$size[0].' control-label" >
@ -243,9 +232,11 @@ class HTML_QuickForm_button extends HTML_QuickForm_input
<div class="col-sm-'.$size[1].'">
{icon}
{element}
<!-- BEGIN label_2 -->
<p class="help-block">{label_2}</p>
<!-- END label_2 -->
<!-- BEGIN error -->
<span class="help-inline help-block">{error}</span>
<!-- END error -->
@ -258,18 +249,15 @@ class HTML_QuickForm_button extends HTML_QuickForm_input
</div>';
}
}
return $template;
break;
case FormValidator::LAYOUT_BOX:
return '{element}';
break;
case FormValidator::LAYOUT_INLINE:
case FormValidator::LAYOUT_GRID:
case FormValidator::LAYOUT_BOX_NO_LABEL:
return '<div class="input-group mt-3">
{element}
</div>
';
default:
$template = ' {element} ';
break;
}
return $template;
}
}

@ -1,6 +1,6 @@
<?php
/**
* HTML class for a checkbox type field
* HTML class for a checkbox type field.
*
* PHP versions 4 and 5
*
@ -11,54 +11,56 @@
* send a note to license@php.net so we can mail you a copy immediately.
*
* @category HTML
* @package HTML_QuickForm
*
* @author Adam Daniel <adaniel1@eesus.jnj.com>
* @author Bertrand Mansion <bmansion@mamasam.com>
* @author Alexey Borzov <avb@php.net>
* @copyright 2001-2009 The PHP Group
* @license http://www.php.net/license/3_01.txt PHP License 3.01
*
* @version CVS: $Id: checkbox.php,v 1.23 2009/04/04 21:34:02 avb Exp $
* @link http://pear.php.net/package/HTML_QuickForm
*
* @see http://pear.php.net/package/HTML_QuickForm
*/
/**
* HTML class for a checkbox type field
* HTML class for a checkbox type field.
*
* @category HTML
* @package HTML_QuickForm
*
* @author Adam Daniel <adaniel1@eesus.jnj.com>
* @author Bertrand Mansion <bmansion@mamasam.com>
* @author Alexey Borzov <avb@php.net>
*
* @version Release: 3.2.11
*
* @since 1.0
*/
class HTML_QuickForm_checkbox extends HTML_QuickForm_input
{
/**
* Checkbox display text
* @var string
* Checkbox display text.
*
* @var string
*
* @since 1.1
* @access private
*/
public $_text = '';
public $labelClass;
public $checkboxClass;
// }}}
// {{{ constructor
/**
* Class constructor
* Class constructor.
*
* @param string $elementName (optional)Input field name attribute
* @param string $elementLabel (optional)Input field value
* @param string $text (optional)Checkbox display text
* @param mixed $attributes (optional)Either a typical HTML attribute string
* or an associative array
*
* @param string $elementName (optional)Input field name attribute
* @param string $elementLabel (optional)Input field value
* @param string $text (optional)Checkbox display text
* @param mixed $attributes (optional)Either a typical HTML attribute string
* or an associative array
* @since 1.0
* @access public
* @return void
*
* @return void
*/
public function __construct(
$elementName = null,
@ -83,55 +85,50 @@ class HTML_QuickForm_checkbox extends HTML_QuickForm_input
$this->setType('checkbox');
if (!isset($attributes['value'])) {
$this->updateAttributes(array('value' => 1));
$this->updateAttributes(['value' => 1]);
} else {
$this->updateAttributes(array('value' => $attributes['value']));
$this->updateAttributes(['value' => $attributes['value']]);
}
$this->_generateId();
}
/**
* Sets whether a checkbox is checked
* Sets whether a checkbox is checked.
*
* @param bool $checked Whether the field is checked or not
*
* @param bool $checked Whether the field is checked or not
* @since 1.0
* @access public
* @return void
*
* @return void
*/
function setChecked($checked)
public function setChecked($checked)
{
if (!$checked) {
$this->removeAttribute('checked');
} else {
$this->updateAttributes(array('checked' => 'checked'));
$this->updateAttributes(['checked' => 'checked']);
}
} //end func setChecked
// }}}
// {{{ getChecked()
}
/**
* Returns whether a checkbox is checked
* Returns whether a checkbox is checked.
*
* @since 1.0
* @access public
* @return bool
*
* @return bool
*/
function getChecked()
public function getChecked()
{
return (bool)$this->getAttribute('checked');
} //end func getChecked
// }}}
// {{{ toHtml()
return (bool) $this->getAttribute('checked');
}
/**
* Returns the checkbox element in HTML
* Returns the checkbox element in HTML.
*
* @since 1.0
* @access public
* @return string
*
* @return string
*/
public function toHtml()
{
@ -143,8 +140,8 @@ class HTML_QuickForm_checkbox extends HTML_QuickForm_input
$labelClass = $this->labelClass;
$checkClass = $this->checkboxClass;
$name = $this->_attributes['name'];
$label ='<div id="'.$name.'" class="'.$checkClass.'">
<label class="'.$labelClass.'">' .
$label = '<div id="'.$name.'" class="'.$checkClass.'">
<label class="'.$labelClass.'">'.
HTML_QuickForm_input::toHtml().' '.$this->_text.
'</label>
</div>
@ -153,7 +150,7 @@ class HTML_QuickForm_checkbox extends HTML_QuickForm_input
return $label;
}
return HTML_QuickForm_input::toHtml() . $label;
return HTML_QuickForm_input::toHtml().$label;
}
/**
@ -164,7 +161,6 @@ class HTML_QuickForm_checkbox extends HTML_QuickForm_input
public function getTemplate($layout)
{
$size = $this->calculateSize();
switch ($layout) {
case FormValidator::LAYOUT_INLINE:
return '
@ -172,17 +168,17 @@ class HTML_QuickForm_checkbox extends HTML_QuickForm_input
<label {label-for} >
<!-- BEGIN required --><span class="form_required">*</span><!-- END required -->
{label}
</label>
</label>
</div>
<div class="input-group {error_class}">
{element}
<div class="input-group {error_class}">
{element}
</div>
';
break;
case FormValidator::LAYOUT_HORIZONTAL:
return '
<div class="form-group row {error_class}">
<label {label-for} class="col-sm-'.$size[0].' col-form-label {extra_label_class}" >
<div class="form-group {error_class}">
<label {label-for} class="col-sm-'.$size[0].' control-label {extra_label_class}" >
<!-- BEGIN required --><span class="form_required">*</span><!-- END required -->
{label}
</label>
@ -212,102 +208,99 @@ class HTML_QuickForm_checkbox extends HTML_QuickForm_input
{element}
</div>';
break;
case FormValidator::LAYOUT_GRID:
case FormValidator::LAYOUT_BOX:
return '
<div class="input-group">
<label>{label}</label>
{icon}
{element}
</div>';
break;
}
}
/**
* Returns the value of field without HTML tags
* Returns the value of field without HTML tags.
*
* @since 1.0
* @access public
* @return string
*
* @return string
*/
function getFrozenHtml()
public function getFrozenHtml()
{
if ($this->getChecked()) {
return '<code>[x]</code>' .
$this->_getPersistantData();
} else {
return '<code>[ ]</code>';
return '<code>[x]</code>'.
$this->_getPersistantData();
}
} //end func getFrozenHtml
// }}}
// {{{ setText()
return '<code>[ ]</code>';
}
/**
* Sets the checkbox text
* Sets the checkbox text.
*
* @param string $text
*
* @param string $text
* @since 1.1
* @access public
* @return void
*
* @return void
*/
function setText($text)
public function setText($text)
{
$this->_text = $text;
} //end func setText
// }}}
// {{{ getText()
}
/**
* Returns the checkbox text
* Returns the checkbox text.
*
* @since 1.1
* @access public
* @return string
*
* @return string
*/
function getText()
public function getText()
{
return $this->_text;
} //end func getText
// }}}
// {{{ setValue()
}
/**
* Sets the value of the form element
* Sets the value of the form element.
*
* @param string $value Default value of the form element
*
* @param string $value Default value of the form element
* @since 1.0
* @access public
* @return void
*
* @return void
*/
function setValue($value)
public function setValue($value)
{
return $this->setChecked($value);
} // end func setValue
// }}}
// {{{ getValue()
}
/**
* Returns the value of the form element
* Returns the value of the form element.
*
* @since 1.0
* @access public
* @return bool
*
* @return bool
*/
function getValue()
public function getValue()
{
return $this->getChecked();
} // end func getValue
// }}}
// {{{ onQuickFormEvent()
}
/**
* Called by HTML_QuickForm whenever form event is made on this element
* Called by HTML_QuickForm whenever form event is made on this element.
*
* @param string $event Name of event
* @param mixed $arg event arguments
* @param object &$caller calling object
*
* @param string $event Name of event
* @param mixed $arg event arguments
* @param object &$caller calling object
* @since 1.0
* @access public
* @return void
*
* @return void
*/
function onQuickFormEvent($event, $arg, &$caller)
public function onQuickFormEvent($event, $arg, &$caller)
{
switch ($event) {
case 'updateValue':
@ -335,21 +328,20 @@ class HTML_QuickForm_checkbox extends HTML_QuickForm_input
default:
parent::onQuickFormEvent($event, $arg, $caller);
}
return true;
} // end func onQuickFormEvent
// }}}
// {{{ exportValue()
return true;
}
/**
* Return true if the checkbox is checked, null if it is not checked (getValue() returns false)
*/
function exportValue(&$submitValues, $assoc = false)
/**
* Return true if the checkbox is checked, null if it is not checked (getValue() returns false).
*/
public function exportValue(&$submitValues, $assoc = false)
{
$value = $this->_findValue($submitValues);
if (null === $value) {
$value = $this->getChecked()? true: null;
$value = $this->getChecked() ? true : null;
}
return $this->_prepareValue($value, $assoc);
}
}

@ -1,4 +1,5 @@
<?php
/**
* Base class for form elements
*
@ -38,7 +39,6 @@ class HTML_QuickForm_element extends HTML_Common
private $layout;
private $icon;
private $template;
private $button;
private $customFrozenTemplate = '';
protected $inputSize;
@ -111,23 +111,6 @@ class HTML_QuickForm_element extends HTML_Common
}
}
/**
* @return boolean
*/
public function getButton()
{
return $this->button;
}
/**
* @param boolean $button
*/
public function setButton($button): void
{
$this->button = $button;
}
/**
* @return null
*/
@ -260,9 +243,7 @@ class HTML_QuickForm_element extends HTML_Common
*/
public function getCleanValue()
{
$value = $this->cleanValueFromParameter($this->getValue());
return $value;
return $this->cleanValueFromParameter($this->getValue());
}
/**
@ -272,9 +253,7 @@ class HTML_QuickForm_element extends HTML_Common
*/
public function cleanValueFromParameter($value)
{
$value = @htmlspecialchars($value, ENT_COMPAT, HTML_Common::charset());
return $value;
return @htmlspecialchars($value, ENT_COMPAT, HTML_Common::charset());
}
/**
@ -334,21 +313,21 @@ class HTML_QuickForm_element extends HTML_Common
{
if (!$this->_persistantFreeze) {
return '';
} else {
$id = $this->getAttribute('id');
return '<input' . $this->_getAttrString(array(
'type' => 'hidden',
'name' => $this->getName(),
'value' => $this->getValue()
) + (isset($id)? array('id' => $id): array())) . ' />';
}
$id = $this->getAttribute('id');
return '<input' . $this->_getAttrString(array(
'type' => 'hidden',
'name' => $this->getName(),
'value' => $this->getValue()
) + (isset($id)? array('id' => $id): array())) . ' />';
}
/**
* Returns whether or not the element is frozen
*
* @since 1.3
* @access public
* @return bool
*/
public function isFrozen()
@ -362,10 +341,8 @@ class HTML_QuickForm_element extends HTML_Common
*
* @param bool $persistant True if persistant value
* @since 2.0
* @access public
* @return void
*/
function setPersistantFreeze($persistant=false)
public function setPersistantFreeze($persistant=false)
{
$this->_persistantFreeze = $persistant;
}
@ -376,8 +353,6 @@ class HTML_QuickForm_element extends HTML_Common
* @param string $label Display text for the element
* @param string $label_for Optionally add a "for" attribute
* @since 1.3
* @access public
* @return void
*/
public function setLabel($label, $labelFor = null)
{
@ -391,7 +366,6 @@ class HTML_QuickForm_element extends HTML_Common
* Returns display text for the element
*
* @since 1.3
* @access public
* @return string
*/
public function getLabel()
@ -402,10 +376,9 @@ class HTML_QuickForm_element extends HTML_Common
/**
* Returns "for" attribute for the element
*
* @access public
* @return string
*/
function getLabelFor()
public function getLabelFor()
{
return $this->_label_for;
}
@ -541,6 +514,7 @@ class HTML_QuickForm_element extends HTML_Common
if (null === $value) {
$value = $this->getValue();
}
return $this->_prepareValue($value, $assoc);
}

@ -44,7 +44,7 @@ class HTML_QuickForm_email extends HTML_QuickForm_input
* @access public
* @return void
*/
function setSize($size)
public function setSize($size)
{
$this->updateAttributes(array('size'=>$size));
}
@ -57,7 +57,7 @@ class HTML_QuickForm_email extends HTML_QuickForm_input
* @access public
* @return void
*/
function setMaxlength($maxlength)
public function setMaxlength($maxlength)
{
$this->updateAttributes(array('maxlength'=>$maxlength));
}

@ -267,7 +267,6 @@ class HTML_QuickForm_file extends HTML_QuickForm_input
var $inputFile = $(\'#'.$id.'\'),
$image = $(\'#'.$id.'_preview_image\'),
$input = $(\'[name="'.$id.'_crop_result"]\'),
$inputForResource = $(\'[name="'.$id.'_crop_result_for_resource"]\'),
$cropButton = $(\'#'.$id.'_crop_button\'),
$formGroup = $(\'#'.$id.'-form-group\');

@ -1,8 +1,7 @@
<?php
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
/**
* HTML class for a form element group
* HTML class for a form element group.
*
* PHP versions 4 and 5
*
@ -13,83 +12,93 @@
* send a note to license@php.net so we can mail you a copy immediately.
*
* @category HTML
* @package HTML_QuickForm
*
* @author Adam Daniel <adaniel1@eesus.jnj.com>
* @author Bertrand Mansion <bmansion@mamasam.com>
* @author Alexey Borzov <avb@php.net>
* @copyright 2001-2009 The PHP Group
* @license http://www.php.net/license/3_01.txt PHP License 3.01
*
* @version CVS: $Id: group.php,v 1.40 2009/04/04 21:34:03 avb Exp $
* @link http://pear.php.net/package/HTML_QuickForm
*
* @see http://pear.php.net/package/HTML_QuickForm
*/
/**
* HTML class for a form element group
* HTML class for a form element group.
*
* @category HTML
* @package HTML_QuickForm
*
* @author Adam Daniel <adaniel1@eesus.jnj.com>
* @author Bertrand Mansion <bmansion@mamasam.com>
* @author Alexey Borzov <avb@php.net>
*
* @version Release: 3.2.11
*
* @since 1.0
*/
class HTML_QuickForm_group extends HTML_QuickForm_element
{
/**
* Name of the element
* @var string
* Name of the element.
*
* @var string
*
* @since 1.0
* @access private
*/
private $_name = '';
/**
* Array of grouped elements
* @var array
* Array of grouped elements.
*
* @var array
*
* @since 1.0
* @access private
*/
private $_elements = array();
private $_elements = [];
/**
* String to separate elements
* @var mixed
* String to separate elements.
*
* @var mixed
*
* @since 2.5
* @access public
*/
public $_separator = null;
/**
* Required elements in this group
* @var array
* Required elements in this group.
*
* @var array
*
* @since 2.5
* @access private
*/
private $_required = array();
/**
* Whether to change elements' names to $groupName[$elementName] or leave them as is
* @var bool
* @since 3.0
* @access private
*/
private $_required = [];
/**
* Whether to change elements' names to $groupName[$elementName] or leave them as is.
*
* @var bool
*
* @since 3.0
*/
private $_appendName = true;
/**
* Class constructor
*
* @param string $elementName (optional)Group name
* @param array $elementLabel (optional)Group label
* @param array $elements (optional)Group elements
* @param mixed $separator (optional)Use a string for one separator,
* use an array to alternate the separators.
* @param bool $appendName (optional)whether to change elements' names to
* the form $groupName[$elementName] or leave
* them as is.
* Class constructor.
*
* @param string $elementName (optional)Group name
* @param array $elementLabel (optional)Group label
* @param array $elements (optional)Group elements
* @param mixed $separator (optional)Use a string for one separator,
* use an array to alternate the separators
* @param bool $appendName (optional)whether to change elements' names to
* the form $groupName[$elementName] or leave
* them as is
*
* @since 1.0
* @access public
* @return void
*
* @return void
*/
public function __construct(
$elementName = null,
@ -103,10 +112,10 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
if (isset($elements) && is_array($elements)) {
$this->setElements($elements);
}
$this->_separator = '';
if (isset($separator)) {
$this->_separator = $separator;
} else {
$this->_separator = '';
}
if (isset($appendName)) {
$this->_appendName = $appendName;
@ -114,39 +123,41 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
}
/**
* Sets the group name
* Sets the group name.
*
* @param string $name Group name
*
* @param string $name Group name
* @since 1.0
* @access public
* @return void
*
* @return void
*/
function setName($name)
public function setName($name)
{
$this->_name = $name;
}
/**
* Returns the group name
* Returns the group name.
*
* @since 1.0
* @access public
* @return string
*
* @return string
*/
function getName()
public function getName()
{
return $this->_name;
}
/**
* Sets values for group's elements
* Sets values for group's elements.
*
* @param mixed Values for group's elements
*
* @since 1.0
* @access public
* @return void
*
* @return void
*/
function setValue($value)
public function setValue($value)
{
$this->_createElementsIfNotExist();
foreach (array_keys($this->_elements) as $key) {
@ -155,10 +166,9 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
if (null !== $v) {
$this->_elements[$key]->onQuickFormEvent('setGroupValue', $v, $this);
}
} else {
$elementName = $this->_elements[$key]->getName();
$index = strlen($elementName) ? $elementName : $key;
$index = strlen($elementName) ? $elementName : $key;
if (is_array($value)) {
if (isset($value[$index])) {
$this->_elements[$key]->onQuickFormEvent('setGroupValue', $value[$index], $this);
@ -171,23 +181,23 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
}
/**
* Returns the value of the group
* Returns the value of the group.
*
* @since 1.0
* @access public
* @return mixed
*
* @return mixed
*/
function getValue()
public function getValue()
{
$value = null;
foreach (array_keys($this->_elements) as $key) {
$element =& $this->_elements[$key];
$element = &$this->_elements[$key];
switch ($element->getType()) {
case 'radio':
$v = $element->getChecked()? $element->getValue(): null;
$v = $element->getChecked() ? $element->getValue() : null;
break;
case 'checkbox':
$v = $element->getChecked()? true: null;
$v = $element->getChecked() ? true : null;
break;
default:
$v = $element->getValue();
@ -198,7 +208,7 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
$value = $v;
} else {
if (!is_array($value)) {
$value = is_null($value)? array(): array($value);
$value = is_null($value) ? [] : [$value];
}
if ('' === $elementName) {
$value[] = $v;
@ -208,18 +218,20 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
}
}
}
return $value;
}
/**
* Sets the grouped elements
* Sets the grouped elements.
*
* @param array $elements Array of elements
*
* @param array $elements Array of elements
* @since 1.1
* @access public
* @return void
*
* @return void
*/
function setElements($elements)
public function setElements($elements)
{
$this->_elements = array_values($elements);
if ($this->_flagFrozen) {
@ -228,15 +240,16 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
}
/**
* Gets the grouped elements
* Gets the grouped elements.
*
* @since 2.4
* @access public
* @return array
*
* @return array
*/
function &getElements()
public function &getElements()
{
$this->_createElementsIfNotExist();
return $this->_elements;
}
@ -245,29 +258,29 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
* Will return 'mixed' if elements contained in the group
* are of different types.
*
* @access public
* @return string group elements type
* @return string group elements type
*/
function getGroupType()
public function getGroupType()
{
$this->_createElementsIfNotExist();
$prevType = '';
foreach (array_keys($this->_elements) as $key) {
$type = $this->_elements[$key]->getType();
if ($type != $prevType && $prevType != '') {
if ($type != $prevType && '' != $prevType) {
return 'mixed';
}
$prevType = $type;
}
return $type;
}
/**
* Returns Html for the group
* Returns Html for the group.
*
* @since 1.0
* @access public
* @return string
*
* @return string
*/
public function toHtml()
{
@ -279,20 +292,21 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
}
/**
* Returns the element name inside the group such as found in the html form
* Returns the element name inside the group such as found in the html form.
*
* @param mixed $index Element name or element index in the group
*
* @param mixed $index Element name or element index in the group
* @since 3.0
* @access public
* @return mixed string with element name, false if not found
*
* @return mixed string with element name, false if not found
*/
function getElementName($index)
public function getElementName($index)
{
$this->_createElementsIfNotExist();
$elementName = false;
if (is_int($index) && isset($this->_elements[$index])) {
$elementName = $this->_elements[$index]->getName();
if (isset($elementName) && $elementName == '') {
if (isset($elementName) && '' == $elementName) {
$elementName = $index;
}
if ($this->_appendName) {
@ -302,7 +316,6 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
$elementName = $this->getName().'['.$elementName.']';
}
}
} elseif (is_string($index)) {
foreach (array_keys($this->_elements) as $key) {
$elementName = $this->_elements[$key]->getName();
@ -316,19 +329,20 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
}
}
}
return $elementName;
}
/**
* Returns the value of field without HTML tags
* Returns the value of field without HTML tags.
*
* @since 1.3
* @access public
* @return string
*
* @return string
*/
function getFrozenHtml()
public function getFrozenHtml()
{
$flags = array();
$flags = [];
$this->_createElementsIfNotExist();
foreach (array_keys($this->_elements) as $key) {
if (false === ($flags[$key] = $this->_elements[$key]->isFrozen())) {
@ -341,18 +355,20 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
$this->_elements[$key]->unfreeze();
}
}
return $html;
}
/**
* Called by HTML_QuickForm whenever form event is made on this element
* Called by HTML_QuickForm whenever form event is made on this element.
*
* @param string $event Name of event
* @param mixed $arg event arguments
* @param object &$caller calling object
*
* @param string $event Name of event
* @param mixed $arg event arguments
* @param object &$caller calling object
* @since 1.0
* @access public
* @return void
*
* @return void
*/
public function onQuickFormEvent($event, $arg, &$caller)
{
@ -367,9 +383,9 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
if (is_null($elementName)) {
$this->_elements[$key]->setName($this->getName());
} elseif ('' === $elementName) {
$this->_elements[$key]->setName($this->getName() . '[' . $key . ']');
$this->_elements[$key]->setName($this->getName().'['.$key.']');
} else {
$this->_elements[$key]->setName($this->getName() . '[' . $elementName . ']');
$this->_elements[$key]->setName($this->getName().'['.$elementName.']');
}
}
$this->_elements[$key]->onQuickFormEvent('updateValue', $arg, $caller);
@ -385,28 +401,30 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
return true;
}
/**
* Accepts a renderer
*
* @param HTML_QuickForm_Renderer renderer object
* @param bool Whether a group is required
* @param string An error message associated with a group
* @access public
* @return void
*/
/**
* Accepts a renderer.
*
* @param HTML_QuickForm_Renderer renderer object
* @param bool Whether a group is required
* @param string An error message associated with a group
*
* @return void
*/
public function accept(&$renderer, $required = false, $error = null)
{
$this->_createElementsIfNotExist();
$renderer->startGroup($this, $required, $error);
$name = $this->getName();
/** @var HTML_QuickForm_element $element */
foreach (array_keys($this->_elements) as $key) {
$element =& $this->_elements[$key];
$element = &$this->_elements[$key];
$element->setLayout($this->getLayout());
if ($this->_appendName) {
$elementName = $element->getName();
if (isset($elementName)) {
$element->setName($name . '['. (strlen($elementName)? $elementName: $key) .']');
$element->setName($name.'['.(strlen($elementName) ? $elementName : $key).']');
} else {
$element->setName($name);
}
@ -423,11 +441,11 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
$renderer->finishGroup($this);
}
/**
* As usual, to get the group's value we access its elements and call
* their exportValue() methods
*/
function exportValue(&$submitValues, $assoc = false)
/**
* As usual, to get the group's value we access its elements and call
* their exportValue() methods.
*/
public function exportValue(&$submitValues, $assoc = false)
{
$value = null;
foreach (array_keys($this->_elements) as $key) {
@ -436,9 +454,9 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
if (is_null($elementName)) {
$this->_elements[$key]->setName($this->getName());
} elseif ('' === $elementName) {
$this->_elements[$key]->setName($this->getName() . '[' . $key . ']');
$this->_elements[$key]->setName($this->getName().'['.$key.']');
} else {
$this->_elements[$key]->setName($this->getName() . '[' . $elementName . ']');
$this->_elements[$key]->setName($this->getName().'['.$elementName.']');
}
}
$v = $this->_elements[$key]->exportValue($submitValues, $assoc);
@ -448,7 +466,7 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
if (null !== $v) {
// Make $value an array, we will use it like one
if (null === $value) {
$value = array();
$value = [];
}
if ($assoc) {
// just like HTML_QuickForm::exportValues()
@ -465,36 +483,34 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
}
}
}
// do not pass the value through _prepareValue, we took care of this already
return $value;
}
/**
* Creates the group's elements.
*
* This should be overriden by child classes that need to create their
* elements. The method will be called automatically when needed, calling
* it from the constructor is discouraged as the constructor is usually
* called _twice_ on element creation, first time with _no_ parameters.
*
* @access private
* @abstract
*/
function _createElements()
/**
* Creates the group's elements.
*
* This should be overriden by child classes that need to create their
* elements. The method will be called automatically when needed, calling
* it from the constructor is discouraged as the constructor is usually
* called _twice_ on element creation, first time with _no_ parameters.
*
* @abstract
*/
public function _createElements()
{
// abstract
}
/**
* A wrapper around _createElements()
*
* This method calls _createElements() if the group's _elements array
* is empty. It also performs some updates, e.g. freezes the created
* elements if the group is already frozen.
*
* @access private
*/
function _createElementsIfNotExist()
/**
* A wrapper around _createElements().
*
* This method calls _createElements() if the group's _elements array
* is empty. It also performs some updates, e.g. freezes the created
* elements if the group is already frozen.
*/
public function _createElementsIfNotExist()
{
if (empty($this->_elements)) {
$this->_createElements();
@ -504,7 +520,7 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
}
}
function freeze()
public function freeze()
{
parent::freeze();
foreach (array_keys($this->_elements) as $key) {
@ -513,7 +529,7 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
}
}
function unfreeze()
public function unfreeze()
{
parent::unfreeze();
foreach (array_keys($this->_elements) as $key) {
@ -521,7 +537,7 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
}
}
function setPersistantFreeze($persistant = false)
public function setPersistantFreeze($persistant = false)
{
parent::setPersistantFreeze($persistant);
foreach (array_keys($this->_elements) as $key) {
@ -545,17 +561,17 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
<label {label-for} >
<!-- BEGIN required --><span class="form_required">*</span><!-- END required -->
{label}
</label>
</label>
</div>
<div class="input-group {error_class}">
<div class="input-group {error_class}">
{element}
</div>
';
break;
case FormValidator::LAYOUT_HORIZONTAL:
return '
<div class="form-group row {error_class}" id="'.$this->getName().'-group">
<label {label-for} class="col-sm-'.$size[0].' col-form-label {extra_label_class}" >
<div class="form-group {error_class}" id="'.$this->getName().'-group">
<label {label-for} class="col-sm-'.$size[0].' control-label {extra_label_class}" >
<!-- BEGIN required --><span class="form_required">*</span><!-- END required -->
{label}
</label>
@ -564,11 +580,11 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
{element}
<!-- BEGIN label_2 -->
<p class="help-block">{label_2}</p>
<p class="help-block">{label_2}</p>
<!-- END label_2 -->
<!-- BEGIN error -->
<span class="help-inline help-block">{error}</span>
<span class="help-inline help-block">{error}</span>
<!-- END error -->
</div>
<div class="col-sm-'.$size[2].'">
@ -585,6 +601,15 @@ class HTML_QuickForm_group extends HTML_QuickForm_element
{element}
</div>';
break;
case FormValidator::LAYOUT_BOX:
return '
<div class="input-group">
<label>{label}</label>
{icon}
{element}
</div>';
break;
}
}
}

@ -1,5 +1,4 @@
<?php
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
/**
* A pseudo-element used for adding headers to form
@ -32,8 +31,6 @@
*/
class HTML_QuickForm_header extends HTML_QuickForm_static
{
// {{{ constructor
/**
* Class constructor
*
@ -51,9 +48,6 @@ class HTML_QuickForm_header extends HTML_QuickForm_static
$this->_type = 'header';
}
// }}}
// {{{ accept()
/**
* Accepts a renderer
*
@ -65,8 +59,4 @@ class HTML_QuickForm_header extends HTML_QuickForm_static
{
$renderer->renderHeader($this);
} // end func accept
// }}}
} //end class HTML_QuickForm_header
?>

@ -1,5 +1,4 @@
<?php
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
/**
* HTML class for a hidden type element
@ -34,8 +33,6 @@
*/
class HTML_QuickForm_hidden extends HTML_QuickForm_input
{
// {{{ constructor
/**
* Class constructor
*
@ -54,23 +51,17 @@ class HTML_QuickForm_hidden extends HTML_QuickForm_input
$this->setValue($value);
} //end constructor
// }}}
// {{{ freeze()
/**
* Freeze the element so that only its value is returned
*
* @access public
* @return void
*/
function freeze()
public function freeze()
{
return false;
} //end func freeze
// }}}
// {{{ accept()
/**
* Accepts a renderer
*
@ -78,13 +69,8 @@ class HTML_QuickForm_hidden extends HTML_QuickForm_input
* @access public
* @return void
*/
//function accept(&$renderer)
function accept(&$renderer, $required=false, $error=null)
public function accept(&$renderer, $required = false, $error = null)
{
$renderer->renderHidden($this);
} // end func accept
// }}}
} //end class HTML_QuickForm_hidden
?>

@ -1,6 +1,5 @@
<?php
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
/**
* Hidden select pseudo-element
*
@ -38,8 +37,6 @@
*/
class HTML_QuickForm_hiddenselect extends HTML_QuickForm_select
{
// {{{ constructor
/**
* Class constructor
*
@ -61,9 +58,6 @@ class HTML_QuickForm_hiddenselect extends HTML_QuickForm_select
}
} //end constructor
// }}}
// {{{ toHtml()
/**
* Returns the SELECT in HTML
*
@ -100,8 +94,8 @@ class HTML_QuickForm_hiddenselect extends HTML_QuickForm_select
/**
* This is essentially a hidden element and should be rendered as one
*/
function accept(&$renderer)
public function accept(&$renderer)
{
$renderer->renderHidden($this);
}
}
}

@ -1,5 +1,4 @@
<?php
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
/**
* A pseudo-element used for adding raw HTML to form

@ -1,4 +1,5 @@
<?php
/**
* Base class for <input /> form elements
*
@ -33,7 +34,6 @@
*/
class HTML_QuickForm_input extends HTML_QuickForm_element
{
/**
* Sets the element type
*
@ -109,9 +109,9 @@ class HTML_QuickForm_input extends HTML_QuickForm_element
{
if ($this->isFrozen()) {
return $this->getFrozenHtml();
} else {
return $this->_getTabs() . '<input' . $this->_getAttrString($this->_attributes) . ' />';
}
return $this->_getTabs() . '<input' . $this->_getAttrString($this->_attributes) . ' />';
}
/**
@ -150,10 +150,10 @@ class HTML_QuickForm_input extends HTML_QuickForm_element
public function exportValue(&$submitValues, $assoc = false)
{
$type = $this->getType();
if ('reset' == $type || 'image' == $type || 'button' == $type || 'file' == $type) {
if ('reset' === $type || 'image' === $type || 'button' === $type || 'file' === $type) {
return null;
} else {
return parent::exportValue($submitValues, $assoc);
}
return parent::exportValue($submitValues, $assoc);
}
}

@ -1,4 +1,5 @@
<?php
/**
* HTML class for static data
* @example $form->addElement('label', 'My label', 'Content');

@ -1,5 +1,4 @@
<?php
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
/**
* HTML class for a link type field
@ -34,18 +33,13 @@
*/
class HTML_QuickForm_link extends HTML_QuickForm_static
{
// {{{ properties
/**
* Link display text
* @var string
* @since 1.0
* @access private
*/
var $_text = "";
// }}}
// {{{ constructor
var $_text = '';
/**
* Class constructor
@ -67,10 +61,7 @@ class HTML_QuickForm_link extends HTML_QuickForm_static
$this->_type = 'link';
$this->setHref($href);
$this->_text = $text;
} //end constructor
// }}}
// {{{ setName()
}
/**
* Sets the input field name
@ -84,10 +75,7 @@ class HTML_QuickForm_link extends HTML_QuickForm_static
function setName($name)
{
$this->updateAttributes(array('name'=>$name));
} //end func setName
// }}}
// {{{ getName()
}
/**
* Returns the element name
@ -100,10 +88,7 @@ class HTML_QuickForm_link extends HTML_QuickForm_static
function getName()
{
return $this->getAttribute('name');
} //end func getName
// }}}
// {{{ setValue()
}
/**
* Sets value for textarea element
@ -117,10 +102,7 @@ class HTML_QuickForm_link extends HTML_QuickForm_static
function setValue($value)
{
return;
} //end func setValue
// }}}
// {{{ getValue()
}
/**
* Returns the value of the form element
@ -133,11 +115,7 @@ class HTML_QuickForm_link extends HTML_QuickForm_static
function getValue()
{
return;
} // end func getValue
// }}}
// {{{ setHref()
}
/**
* Sets the links href
@ -151,10 +129,7 @@ class HTML_QuickForm_link extends HTML_QuickForm_static
function setHref($href)
{
$this->updateAttributes(array('href'=>$href));
} // end func setHref
// }}}
// {{{ toHtml()
}
/**
* Returns the textarea element in HTML
@ -171,10 +146,7 @@ class HTML_QuickForm_link extends HTML_QuickForm_static
$html .= $this->_text;
$html .= "</a>";
return $html;
} //end func toHtml
// }}}
// {{{ getFrozenHtml()
}
/**
* Returns the value of field without HTML tags (in this case, value is changed to a mask)

@ -1,5 +1,4 @@
<?php
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
/**
* HTML class for a password type field
@ -34,19 +33,19 @@
*/
class HTML_QuickForm_password extends HTML_QuickForm_text
{
// {{{ constructor
/**
* Class constructor
* @param string $elementName (optional)Input field name attribute
* @param string $elementLabel (optional)Input field label
* @param mixed $attributes (optional)Either a typical HTML attribute string
*
* @param string $elementName (optional)Input field name attribute
* @param string $elementLabel (optional)Input field label
* @param mixed $attributes (optional)Either a typical HTML attribute string
* or an associative array
*
* @throws
* @since 1.0
* @access public
* @throws
*/
public function __construct($elementName=null, $elementLabel=null, $attributes=null)
public function __construct($elementName = null, $elementLabel = null, $attributes = null)
{
$attributes['class'] = isset($attributes['class']) ? $attributes['class'] : 'form-control';
parent::__construct($elementName, $elementLabel, $attributes);
@ -56,41 +55,44 @@ class HTML_QuickForm_password extends HTML_QuickForm_text
/**
* Sets size of password element
*
* @param string $size Size of password field
* @param string $size Size of password field
*
* @return void
* @since 1.0
* @access public
* @return void
*/
public function setSize($size)
{
$this->updateAttributes(array('size'=>$size));
$this->updateAttributes(array('size' => $size));
}
/**
* Sets maxlength of password element
*
* @param string $maxlength Maximum length of password field
* @param string $maxlength Maximum length of password field
*
* @return void
* @since 1.0
* @access public
* @return void
*/
public function setMaxlength($maxlength)
{
$this->updateAttributes(array('maxlength'=>$maxlength));
$this->updateAttributes(array('maxlength' => $maxlength));
}
/**
* Returns the value of field without HTML tags (in this case, value is changed to a mask)
*
* @since 1.0
* @access public
* @return string
* @throws
* @since 1.0
* @access public
*/
public function getFrozenHtml()
{
$value = $this->getValue();
return ('' != $value? '**********': '&nbsp;') .
$this->_getPersistantData();
return ('' != $value ? '**********' : '&nbsp;').
$this->_getPersistantData();
}
}

@ -33,12 +33,6 @@
*/
class HTML_QuickForm_radio extends HTML_QuickForm_input
{
/**
* Radio display text
* @var string
* @since 1.1
* @access private
*/
public $_text = '';
public $labelClass;
public $radioClass;
@ -46,14 +40,14 @@ class HTML_QuickForm_radio extends HTML_QuickForm_input
/**
* Class constructor
*
* @param string Input field name attribute
* @param mixed Label(s) for a field
* @param string Text to display near the radio
* @param string Input field value
* @param mixed Either a typical HTML attribute string or an associative array
* @since 1.0
* @access public
* @param string Input field name attribute
* @param mixed Label(s) for a field
* @param string Text to display near the radio
* @param string Input field value
* @param mixed Either a typical HTML attribute string or an associative array
*
* @return void
* @since 1.0
*/
public function __construct(
$elementName = null,
@ -86,41 +80,11 @@ class HTML_QuickForm_radio extends HTML_QuickForm_input
$this->_generateId();
}
/**
* Sets whether radio button is checked
*
* @param bool $checked Whether the field is checked or not
* @since 1.0
* @access public
* @return void
*/
public function setChecked($checked)
{
if (!$checked) {
$this->removeAttribute('checked');
} else {
$this->updateAttributes(array('checked'=>'checked'));
}
}
/**
* Returns whether radio button is checked
*
* @since 1.0
* @access public
* @return string
*/
public function getChecked()
{
return $this->getAttribute('checked');
}
/**
* Returns the radio element in HTML
*
* @since 1.0
* @access public
* @return string
* @since 1.0
*/
public function toHtml()
{
@ -130,6 +94,7 @@ class HTML_QuickForm_radio extends HTML_QuickForm_input
$label = $this->_text;
if ($this->freezeSeeOnlySelected) {
$invisible = $this->getChecked() ? '' : ' style="display:none"';
return "<div $invisible>".HTML_QuickForm_input::toHtml().$this->_text."</div>";
}
} else {
@ -137,69 +102,82 @@ class HTML_QuickForm_radio extends HTML_QuickForm_input
$radioClass = $this->radioClass;
$label = '<div class="'.$radioClass.'">
<label class="'.$labelClass.'">' .
<label class="'.$labelClass.'">'.
HTML_QuickForm_input::toHtml().
''.
$this->_text .
$this->_text.
'</label>
</div>';
return $label;
}
return HTML_QuickForm_input::toHtml().$label;
return parent::toHtml().$label;
}
/**
* Returns the value of field without HTML tags
* Returns whether radio button is checked
*
* @return string
* @since 1.0
* @access public
*/
public function getChecked()
{
return $this->getAttribute('checked');
}
/**
* Returns the value of field without HTML tags
*
* @return string
* @since 1.0
*/
public function getFrozenHtml()
{
if ($this->getChecked()) {
return '<code>(x)</code>' .
$this->_getPersistantData();
} else {
return '<code>( )</code>';
return '<br /><code>(x)</code>'.
$this->_getPersistantData();
}
return '<br /><code>( )</code>';
}
/**
* Sets the radio text
* Returns the radio text
*
* @param string $text Text to display near the radio button
* @return string
* @since 1.1
* @access public
* @return void
*/
public function setText($text)
public function getText()
{
$this->_text = $text;
return $this->_text;
}
/**
* Returns the radio text
* Sets the radio text
*
* @param string $text Text to display near the radio button
*
* @return void
* @since 1.1
* @access public
* @return string
*/
public function getText()
public function setText($text)
{
return $this->_text;
$this->_text = $text;
}
/**
* Called by HTML_QuickForm whenever form event is made on this element
*
* @param string $event Name of event
* @param mixed $arg event arguments
* @param object &$caller calling object
* @param string $event Name of event
* @param mixed $arg event arguments
* @param object &$caller calling object
*
* @return void
* @since 1.0
* @access public
* @return void
*/
public function onQuickFormEvent($event, $arg, &$caller)
{
@ -234,14 +212,32 @@ class HTML_QuickForm_radio extends HTML_QuickForm_input
return true;
}
/**
* Returns the value attribute if the radio is checked, null if it is not
*/
/**
* Sets whether radio button is checked
*
* @param bool $checked Whether the field is checked or not
*
* @return void
* @since 1.0
* @access public
*/
public function setChecked($checked)
{
if (!$checked) {
$this->removeAttribute('checked');
} else {
$this->updateAttributes(array('checked' => 'checked'));
}
}
/**
* Returns the value attribute if the radio is checked, null if it is not
*/
public function exportValue(&$submitValues, $assoc = false)
{
$value = $this->_findValue($submitValues);
if (null === $value) {
$value = $this->getChecked()? $this->getValue(): null;
$value = $this->getChecked() ? $this->getValue() : null;
} elseif ($value != $this->getValue()) {
$value = null;
}
@ -249,7 +245,7 @@ class HTML_QuickForm_radio extends HTML_QuickForm_input
return $this->_prepareValue($value, $assoc);
}
/**
/**
* @return null
*/
public function getColumnsSize()

@ -42,8 +42,8 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
* @since 1.0
* @access private
*/
protected $_options = array();
private $_optgroups = array();
protected $_options = [];
private $_optgroups = [];
/**
* Default values of the SELECT
@ -79,8 +79,7 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
if (empty($attributes)) {
$attributes = []; // Initialize variable to avoid warning in PHP 7.1
}
$attributes['class'] = $oldClass . 'form-control selectpicker show-tick ';
$attributes['data-style'] = 'custom-select';
$attributes['class'] = $oldClass . ' selectpicker form-control';
$attributes['data-live-search'] = 'true';
if (isset($attributes['disable_js']) && $attributes['disable_js']) {
@ -99,11 +98,6 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
}
$columnsSize = isset($attributes['cols-size']) ? $attributes['cols-size'] : null;
$this->setColumnsSize($columnsSize);
$icon = isset($attributes['icon']) ? $attributes['icon'] : null;
$this->setIcon($icon);
if (!empty($icon)) {
unset($attributes['icon']);
}
parent::__construct($elementName, $elementLabel, $attributes);
$this->_persistantFreeze = true;
$this->_type = 'select';
@ -176,6 +170,7 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
// Warning: new API since release 2.3
$this->addOption($val, $key);
}
return true;
}
@ -199,7 +194,7 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
* @access public
* @return void
*/
function setSelected($values)
public function setSelected($values)
{
if (is_string($values) && $this->getMultiple()) {
$values = explode('[ ]?,[ ]?', $values);
@ -219,7 +214,7 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
* @access public
* @return void
*/
function setName($name)
public function setName($name)
{
$this->updateAttributes(array('name' => $name));
}
@ -231,7 +226,7 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
* @access public
* @return string
*/
function getName()
public function getName()
{
return $this->getAttribute('name');
}
@ -243,13 +238,13 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
* @access public
* @return string
*/
function getPrivateName()
public function getPrivateName()
{
if ($this->getAttribute('multiple')) {
return $this->getName() . '[]';
} else {
return $this->getName();
return $this->getName().'[]';
}
return $this->getName();
}
/**
@ -260,7 +255,7 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
* @access public
* @return void
*/
function setValue($value)
public function setValue($value)
{
$this->setSelected($value);
}
@ -272,7 +267,7 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
* @access public
* @return array of selected values
*/
function getValue()
public function getValue()
{
return $this->_values;
}
@ -285,7 +280,7 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
* @access public
* @return void
*/
function setSize($size)
public function setSize($size)
{
$this->updateAttributes(array('size' => $size));
}
@ -297,7 +292,7 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
* @access public
* @return int
*/
function getSize()
public function getSize()
{
return $this->getAttribute('size');
}
@ -310,7 +305,7 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
* @access public
* @return void
*/
function setMultiple($multiple)
public function setMultiple($multiple)
{
if ($multiple) {
$this->updateAttributes(array('multiple' => 'multiple'));
@ -326,9 +321,9 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
* @access public
* @return bool true if multiple select, false otherwise
*/
function getMultiple()
public function getMultiple()
{
return (bool)$this->getAttribute('multiple');
return (bool) $this->getAttribute('multiple');
}
/**
@ -342,7 +337,7 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
* @access public
* @return void
*/
function addOption($text, $value, $attributes = null, $return_array = false)
public function addOption($text, $value, $attributes = null, $return_array = false)
{
if (null === $attributes) {
$attributes = array('value' => (string)$value);
@ -377,7 +372,7 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
* @access public
* @return void
*/
function addOptGroup($options, $label)
public function addOptGroup($options, $label)
{
foreach ($options as $option) {
$this->addOption($option['text'], $option['value'], $option, true);
@ -397,10 +392,8 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
if ($this->_flagFrozen) {
return $this->getFrozenHtml();
} else {
$tabs = $this->_getTabs();
$tabs = $this->_getTabs();
$strHtml = '';
if ($this->getComment() != '') {
$strHtml .= $tabs . '<!-- ' . $this->getComment() . " //-->\n";
}
@ -438,7 +431,8 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
}
$strHtml .= "</optgroup>";
}
return $strHtml . $tabs . '</select>';
return $strHtml.$tabs.'</select>';
}
}
@ -449,7 +443,7 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
* @access public
* @return string
*/
function getFrozenHtml()
public function getFrozenHtml()
{
$value = array();
if (is_array($this->_values)) {
@ -480,6 +474,7 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
) + $idAttr) . ' />';
}
}
return $html;
}
@ -487,7 +482,7 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
* We check the options and return only the values that _could_ have been
* selected. We also return a scalar value if select is not "multiple"
*/
function exportValue(&$submitValues, $assoc = false)
public function exportValue(&$submitValues, $assoc = false)
{
$value = $this->_findValue($submitValues);
if (is_null($value)) {
@ -509,15 +504,19 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
$cleanValue = $value;
}
if (is_array($cleanValue) && !$this->getMultiple()) {
if (empty($cleanValue)) {
return $this->_prepareValue(null, $assoc);
}
return $this->_prepareValue($cleanValue[0], $assoc);
} else {
return $this->_prepareValue($cleanValue, $assoc);
}
}
function onQuickFormEvent($event, $arg, &$caller)
public function onQuickFormEvent($event, $arg, &$caller)
{
if ('updateValue' == $event) {
if ('updateValue' === $event) {
$value = $this->_findValue($caller->_constantValues);
if (null === $value) {
$value = $this->_findValue($caller->_submitValues);
@ -531,9 +530,9 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
$this->setValue($value);
}
return true;
} else {
return parent::onQuickFormEvent($event, $arg, $caller);
}
return parent::onQuickFormEvent($event, $arg, $caller);
}
/**
@ -542,41 +541,18 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
public function updateSelectWithSelectedOption(FormValidator $form)
{
$id = $this->getAttribute('id');
$form->addHtml('<script>
$form->addHtml(
'<script>
$(function(){
var optionClass = $("#'.$id.'").find("option:checked").attr("class");
$("#'.$id.'").attr("class", "form-control " + optionClass);
var optionClass = $("#'.$id.'").find("option:checked").attr("class");
$("#'.$id.'").attr("class", "form-control " + optionClass);
$("#'.$id.'").on("change", function() {
var optionClass = ($(this).find("option:checked").attr("class"));
var optionClass = ($(this).find("option:checked").attr("class"));
$(this).attr("class", "form-control " + optionClass);
});
});
</script>');
}
/**
* Show an icon at the left side of an input
* @return string
*/
public function getIconToHtml()
{
$icon = $this->getIcon();
$isButton = $this->getButton();
if (empty($icon)) {
return '';
}
$element = '<span class="input-group-text"><em class="fa fa-' . $icon . '"></em></span>';
if ($isButton) {
$element = '<button class="btn btn-outline-secondary" type="reset">
<em class="fa fa-' . $icon . '"></em>
</button>';
}
return '<div class="input-group-append">
' . $element . '
</div>';
</script>'
);
}
/**
@ -591,17 +567,18 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
switch ($layout) {
case FormValidator::LAYOUT_INLINE:
return '
<label class="sr-only" {label-for} >
<div class="form-group {error_class}">
<label {label-for} >
<!-- BEGIN required --><span class="form_required">*</span><!-- END required -->
{label}
</label>
</label>
{element}
';
</div>';
break;
case FormValidator::LAYOUT_HORIZONTAL:
return '
<div class="form-group row {error_class}">
<label {label-for} class="col-sm-'.$size[0].' col-form-label {extra_label_class}" >
<div class="form-group {error_class}">
<label {label-for} class="col-sm-'.$size[0].' control-label {extra_label_class}" >
<!-- BEGIN required --><span class="form_required">*</span><!-- END required -->
{label}
</label>
@ -630,17 +607,14 @@ class HTML_QuickForm_select extends HTML_QuickForm_element
{icon}
{element}
</div>';
case FormValidator::LAYOUT_BOX_SEARCH:
break;
case FormValidator::LAYOUT_GRID:
case FormValidator::LAYOUT_BOX:
return '
<div class="form-group row">
<label class="col-sm-2 col-form-label" {label-for}>{label}</label>
<div class="col-sm-8">
<div class="input-group">
{element}
{icon}
</div>
</div>
<div class="col-sm-2"></div>
<div class="input-group" style="z-index: auto">
<label>{label}</label>
{icon}
{element}
</div>';
break;
}

@ -83,21 +83,13 @@ class HTML_QuickForm_text extends HTML_QuickForm_input
public function getIconToHtml()
{
$icon = $this->getIcon();
$isButton = $this->getButton();
if (empty($icon)) {
return '';
}
$element = '<span class="input-group-text"><em class="fa fa-' . $icon . '"></em></span>';
if ($isButton) {
$element = '<button class="btn btn-outline-secondary" type="submit">
<em class="fa fa-' . $icon . '"></em>
</button>';
}
return '<div class="input-group-append">
' . $element . '
return '<div class="input-group-addon">
<em class="fa fa-'.$icon.'"></em>
</div>';
}
@ -111,20 +103,28 @@ class HTML_QuickForm_text extends HTML_QuickForm_input
$size = $this->calculateSize();
$attributes = $this->getAttributes();
$template = '<label {label-for}>{label}</label>
<div class="input-group">
{icon}
{element}
</div>';
switch ($layout) {
case FormValidator::LAYOUT_GRID:
case FormValidator::LAYOUT_INLINE:
return '
<label class="sr-only" {label-for} >
$template = '
<div class="form-group {error_class}">
<label {label-for} >
<!-- BEGIN required --><span class="form_required">*</span><!-- END required -->
{label}
</label>
</label>
{element}
';
</div>';
break;
case FormValidator::LAYOUT_HORIZONTAL:
return '
<div class="form-group row {error_class}">
<label {label-for} class="col-sm-'.$size[0].' col-form-label" >
$template = '
<div class="form-group {error_class}">
<label {label-for} class="col-sm-'.$size[0].' control-label" >
<!-- BEGIN required --><span class="form_required">*</span><!-- END required -->
{label}
</label>
@ -148,27 +148,23 @@ class HTML_QuickForm_text extends HTML_QuickForm_input
</div>';
break;
case FormValidator::LAYOUT_BOX_NO_LABEL:
return '
<label {label-for}>{label}</label>
<div class="input-group mb-3">
if (isset($attributes['custom']) && $attributes['custom'] == true) {
$template = '
<div class="input-group">
{icon}
{element}
</div>';
break;
case FormValidator::LAYOUT_BOX_SEARCH:
return '
<div class="form-group row">
<label class="col-sm-2 col-form-label" {label-for}>{label}</label>
<div class="col-sm-8">
<div class="input-group mb-3">
{element}
{icon}
</div>
<div class="input-group-btn">
<button class="btn btn-default" type="submit">
<em class="fa fa-search"></em>
</button>
</div>
<div class="col-sm-2"></div>
</div>';
</div>
';
}
break;
}
return $template;
}
/**
@ -204,8 +200,8 @@ class HTML_QuickForm_text extends HTML_QuickForm_input
{
if ($this->isFrozen()) {
return $this->getFrozenHtml();
} else {
return '<input '.$this->_getAttrString($this->_attributes).' />';
}
return '<input '.$this->_getAttrString($this->_attributes).' />';
}
}

@ -1,7 +1,7 @@
<?php
/**
* HTML class for a textarea type field.
* HTML class for a textarea type field
*
* PHP versions 4 and 5
*
@ -13,43 +13,36 @@
*
* @category HTML
* @package HTML_QuickForm
*
* @author Adam Daniel <adaniel1@eesus.jnj.com>
* @author Bertrand Mansion <bmansion@mamasam.com>
* @copyright 2001-2009 The PHP Group
* @license http://www.php.net/license/3_01.txt PHP License 3.01
*
* @version CVS: $Id: textarea.php,v 1.13 2009/04/04 21:34:04 avb Exp $
*
* @see http://pear.php.net/package/HTML_QuickForm
* @link http://pear.php.net/package/HTML_QuickForm
*/
/**
* HTML class for a textarea type field.
* HTML class for a textarea type field
*
* @category HTML
* @package HTML_QuickForm
*
* @author Adam Daniel <adaniel1@eesus.jnj.com>
* @author Bertrand Mansion <bmansion@mamasam.com>
*
* @version Release: 3.2.11
*
* @since 1.0
*/
class HTML_QuickForm_textarea extends HTML_QuickForm_element
{
/**
* Field value.
*
* @var string
*
* Field value
* @var string
* @since 1.0
* @access private
*/
public $_value;
/**
* Class constructor.
* Class constructor
*
* @param string $elementName Input field name attribute
* @param string|array $label Label(s) for a field
@ -78,23 +71,24 @@ class HTML_QuickForm_textarea extends HTML_QuickForm_element
}
/**
* Sets the input field name.
*
* @param string $name Input field name attribute
* Sets the input field name
*
* @param string $name Input field name attribute
* @since 1.0
* @access public
* @return void
*/
public function setName($name)
{
$this->updateAttributes(['name' => $name]);
$this->updateAttributes(array('name' => $name));
}
/**
* Returns the element name.
* Returns the element name
*
* @since 1.0
*
* @return string
* @access public
* @return string
*/
public function getName()
{
@ -102,11 +96,12 @@ class HTML_QuickForm_textarea extends HTML_QuickForm_element
}
/**
* Sets value for textarea element.
*
* @param string $value Value for textarea element
* Sets value for textarea element
*
* @param string $value Value for textarea element
* @since 1.0
* @access public
* @return void
*/
public function setValue($value)
{
@ -114,11 +109,11 @@ class HTML_QuickForm_textarea extends HTML_QuickForm_element
}
/**
* Returns the value of the form element.
* Returns the value of the form element
*
* @since 1.0
*
* @return string
* @access public
* @return string
*/
public function getValue()
{
@ -126,35 +121,37 @@ class HTML_QuickForm_textarea extends HTML_QuickForm_element
}
/**
* Sets height in rows for textarea element.
*
* @param string $rows Height expressed in rows
* Sets height in rows for textarea element
*
* @param string $rows Height expressed in rows
* @since 1.0
* @access public
* @return void
*/
public function setRows($rows)
{
$this->updateAttributes(['rows' => $rows]);
$this->updateAttributes(array('rows' => $rows));
}
/**
* Sets width in cols for textarea element.
*
* @param string $cols Width expressed in cols
* Sets width in cols for textarea element
*
* @param string $cols Width expressed in cols
* @since 1.0
* @access public
* @return void
*/
public function setCols($cols)
{
$this->updateAttributes(['cols' => $cols]);
$this->updateAttributes(array('cols' => $cols));
}
/**
* Returns the textarea element in HTML.
* Returns the textarea element in HTML
*
* @since 1.0
*
* @return string
* @access public
* @return string
*/
public function toHtml()
{
@ -162,33 +159,32 @@ class HTML_QuickForm_textarea extends HTML_QuickForm_element
return $this->getFrozenHtml();
} else {
return $this->_getTabs().
'<textarea'.$this->_getAttrString($this->_attributes).'>'.
'<textarea' . $this->_getAttrString($this->_attributes) . '>' .
// because we wrap the form later we don't want the text indented
// Modified by Ivan Tcholakov, 16-MAR-2010.
//preg_replace("/(\r\n|\n|\r)/", '&#010;', htmlspecialchars($this->_value)) .
preg_replace("/(\r\n|\n|\r)/", '&#010;', $this->getCleanValue()).
preg_replace("/(\r\n|\n|\r)/", '&#010;', $this->getCleanValue()) .
//
'</textarea>';
}
}
/**
* Returns the value of field without HTML tags (in this case, value is changed to a mask).
* Returns the value of field without HTML tags (in this case, value is changed to a mask)
*
* @since 1.0
*
* @return string
* @access public
* @return string
*/
public function getFrozenHtml()
{
$value = $this->getCleanValue();
if ($this->getAttribute('wrap') == 'off') {
$html = $this->_getTabs().'<pre>'.$value."</pre>\n";
$html = $this->_getTabs() . '<pre>' . $value."</pre>\n";
} else {
$html = nl2br($value)."\n";
}
return $html.$this->_getPersistantData();
return $html . $this->_getPersistantData();
}
/**
@ -199,7 +195,6 @@ class HTML_QuickForm_textarea extends HTML_QuickForm_element
public function getTemplate($layout)
{
$size = $this->getColumnsSize();
$custom = $this->getAttributes();
$this->removeAttribute('cols-size');
if (empty($size)) {
@ -218,9 +213,9 @@ class HTML_QuickForm_textarea extends HTML_QuickForm_element
</div>';
break;
case FormValidator::LAYOUT_HORIZONTAL:
$template = '
<div class="form-group row {error_class}">
<label {label-for} class="col-sm-'.$size[0].' col-form-label" >
return '
<div class="form-group {error_class}">
<label {label-for} class="col-sm-'.$size[0].' control-label" >
<!-- BEGIN required --><span class="form_required">*</span><!-- END required -->
{label}
</label>
@ -242,23 +237,23 @@ class HTML_QuickForm_textarea extends HTML_QuickForm_element
<!-- END label_3 -->
</div>
</div>';
if (isset($custom['data-block']) && $custom['data-block'] == true) {
$template = '
<label {label-for}>{label}</label>
<div class="card-textarea">
{element}
</div>
';
}
return $template;
break;
case FormValidator::LAYOUT_BOX_NO_LABEL:
return '
<label {label-for}>{label}</label>
<div class="input-group">
{icon}
{element}
</div>';
break;
case FormValidator::LAYOUT_GRID:
case FormValidator::LAYOUT_BOX:
return '
<label {label-for}>{label}</label>
<div class="input-group">
{label}
{icon}
{element}
</div>';

@ -923,7 +923,7 @@ class HTML_Table extends HTML_Common
* @access public
* @return string
*/
function toHtml()
public function toHtml()
{
$strHtml = '';
$tabs = $this->_getTabs();
@ -1023,6 +1023,24 @@ class HTML_Table extends HTML_Common
return $strHtml;
}
public function toArray()
{
$data = [];
$tBodyColCounts = array();
for ($i = 0; $i < $this->_tbodyCount; $i++) {
$tBodyColCounts[] = $this->_tbodies[$i]->getColCount();
}
$tBodyMaxColCount = 0;
if (count($tBodyColCounts) > 0) {
$tBodyMaxColCount = max($tBodyColCounts);
}
if ($this->getRowCount() > 0 && $tBodyMaxColCount > 0) {
for ($i = 0; $i < $this->_tbodyCount; $i++) {
$this->_tbodies[$i]->setAutoFill($this->_autoFill);
$data = $this->_tbodies[$i]->toArray();
}
}
?>
return $data;
}
}

@ -1,5 +1,4 @@
<?php
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
/**
* Storage class for HTML::Table data
@ -778,7 +777,6 @@ class HTML_Table_Storage extends HTML_Common
if (!empty($contents) || is_numeric($contents)) {
$strHtml .= $typeContent;
}
}
$strHtml .= $tabs . $tab . $extraTab . '</tr>' . $lnEnd;
}
@ -786,6 +784,42 @@ class HTML_Table_Storage extends HTML_Common
return $strHtml;
}
function toArray($tabs = null, $tab = null)
{
$data = [];
if ($this->_cols > 0) {
for ($i = 0 ; $i < $this->_rows ; $i++) {
$item = [];
for ($j = 0 ; $j < $this->_cols ; $j++) {
$contents = '';
if (isset($this->_structure[$i][$j]) && $this->_structure[$i][$j] == '__SPANNED__') {
continue;
}
if (isset($this->_structure[$i][$j]['contents'])) {
$contents = $this->_structure[$i][$j]['contents'];
}
if (is_object($contents)) {
if (method_exists($contents, 'toHtml')) {
$contents = $contents->toHtml();
} elseif (method_exists($contents, 'toString')) {
$contents = $contents->toString();
}
$item = $contents;
}
if (is_array($contents)) {
$contents = implode(', ', $contents);
}
$item[] = $contents;
}
$data[] = $item;
}
}
return $data;
}
/**
* Checks if rows or columns are spanned
* @param int $row Row index

@ -837,7 +837,7 @@ class Pager_Common
*/
function _renderLink($altText, $linkText)
{
if ($this->_httpMethod == 'GET') {
if ($this->_httpMethod === 'GET') {
if ($this->_append) {
$href = '?' . $this->_http_build_query_wrapper($this->_linkData);
} else {
@ -1020,6 +1020,7 @@ class Pager_Common
$qs = $_GET;
}
}
foreach ($this->_excludeVars as $exclude) {
$use_preg = $this->_isRegexp($exclude);
foreach (array_keys($qs) as $qs_item) {
@ -1039,6 +1040,7 @@ class Pager_Common
$this->_recursive_urldecode($this->_extraVars);
$qs = array_merge($qs, $this->_extraVars);
}
if (count($qs)
&& function_exists('get_magic_quotes_gpc')
&& -1 == version_compare(PHP_VERSION, '5.2.99')
@ -1121,16 +1123,16 @@ class Pager_Common
$this->_linkData[$this->_urlVar] = $this->getPreviousPageID();
$back = $this->_renderLink($this->_altPrev, $this->_prevImg)
. $this->_spacesBefore . $this->_spacesAfter;
} else if ($this->_prevImgEmpty !== null && $this->_totalPages > 1) {
$back = $this->_prevImgEmpty
. $this->_spacesBefore . $this->_spacesAfter;
} else {
if ($this->_prevImgEmpty !== null && $this->_totalPages > 1) {
$back = $this->_prevImgEmpty
. $this->_spacesBefore . $this->_spacesAfter;
}
}
return $back;
}
// }}}
// {{{ _getPageLinks()
/**
* Returns pages link
*
@ -1145,9 +1147,6 @@ class Pager_Common
return $this->raiseError($msg, ERROR_PAGER_NOT_IMPLEMENTED);
}
// }}}
// {{{ _getNextLink()
/**
* Returns next link
*
@ -1173,17 +1172,17 @@ class Pager_Common
$next = $this->_spacesAfter
. $this->_renderLink($this->_altNext, $this->_nextImg)
. $this->_spacesBefore . $this->_spacesAfter;
} else if ($this->_nextImgEmpty !== null && $this->_totalPages > 1) {
$next = $this->_spacesAfter
. $this->_nextImgEmpty
. $this->_spacesBefore . $this->_spacesAfter;
} else {
if ($this->_nextImgEmpty !== null && $this->_totalPages > 1) {
$next = $this->_spacesAfter
. $this->_nextImgEmpty
. $this->_spacesBefore . $this->_spacesAfter;
}
}
return $next;
}
// }}}
// {{{ _getFirstLinkTag()
/**
* Returns first link tag
*
@ -1209,9 +1208,6 @@ class Pager_Common
);
}
// }}}
// {{{ _getPrevLinkTag()
/**
* Returns previous link tag
*
@ -1439,9 +1435,6 @@ class Pager_Common
}
}
// }}}
// {{{ _http_build_query_wrapper()
/**
* This is a slightly modified version of the http_build_query() function;
* it heavily borrows code from PHP_Compat's http_build_query().
@ -1460,10 +1453,10 @@ class Pager_Common
return '';
}
$separator = ini_get('arg_separator.output');
if ($separator == '&amp;') {
if ($separator === '&amp;') {
$separator = '&'; //the string is escaped by htmlentities anyway...
}
$tmp = array ();
$tmp = [];
foreach ($data as $key => $val) {
if (is_scalar($val)) {
//array_push($tmp, $key.'='.$val);
@ -1477,12 +1470,10 @@ class Pager_Common
continue;
}
}
return implode($separator, $tmp);
}
// }}}
// {{{ __http_build_query()
/**
* Helper function
*

@ -187,7 +187,7 @@ class Text_Password {
$tmp = '';
for ($i = 0; $i < strlen($login); $i++) {
$next = ord($login{$i}) ^ $key;
$next = ord($login[$i]) ^ $key;
if ($next > 255) {
$next -= 255;
} elseif ($next < 0) {
@ -216,8 +216,8 @@ class Text_Password {
$login = strtolower($login);
for ($i = 0; $i < strlen($login); $i++) {
if ((ord($login{$i}) >= 97) && (ord($login{$i}) <= 122)) { // 65, 90 for uppercase
$next = ord($login{$i}) + $key;
if ((ord($login[$i]) >= 97) && (ord($login[$i]) <= 122)) { // 65, 90 for uppercase
$next = ord($login[$i]) + $key;
if ($next > 122) {
$next -= 26;
} elseif ($next < 97) {
@ -225,7 +225,7 @@ class Text_Password {
}
$tmp .= chr($next);
} else {
$tmp .= $login{$i};
$tmp .= $login[$i];
}
}
@ -249,8 +249,8 @@ class Text_Password {
$login = strtolower($login);
for ($i = 0; $i < strlen($login); $i++, $key++) {
if ((ord($login{$i}) >= 97) && (ord($login{$i}) <= 122)) { // 65, 90 for uppercase
$next = ord($login{$i}) + $key;
if ((ord($login[$i]) >= 97) && (ord($login[$i]) <= 122)) { // 65, 90 for uppercase
$next = ord($login[$i]) + $key;
if ($next > 122) {
$next -= 26;
} elseif ($next < 97) {
@ -258,7 +258,7 @@ class Text_Password {
}
$tmp .= chr($next);
} else {
$tmp .= $login{$i};
$tmp .= $login[$i];
}
}
@ -282,8 +282,8 @@ class Text_Password {
$login = strtolower($login);
for ($i = 0; $i < strlen($login); $i++, $key--) {
if ((ord($login{$i}) >= 97) && (ord($login{$i}) <= 122)) { // 65, 90 for uppercase
$next = ord($login{$i}) + $key;
if ((ord($login[$i]) >= 97) && (ord($login[$i]) <= 122)) { // 65, 90 for uppercase
$next = ord($login[$i]) + $key;
if ($next > 122) {
$next -= 26;
} elseif ($next < 97) {
@ -291,7 +291,7 @@ class Text_Password {
}
$tmp .= chr($next);
} else {
$tmp .= $login{$i};
$tmp .= $login[$i];
}
}
@ -313,7 +313,7 @@ class Text_Password {
$tmp = '';
for ($i = 0; $i < strlen($login); $i++) {
$next = ord($login{$i}) + $key;
$next = ord($login[$i]) + $key;
if ($next > 255) {
$next -= 255;
} elseif ($next < 0) {
@ -347,7 +347,7 @@ class Text_Password {
$tmp = '';
for ($i = 0; $i < strlen($login); $i++, $key++) {
$next = ord($login{$i}) + $key;
$next = ord($login[$i]) + $key;
if ($next > 255) {
$next -= 255;
} elseif ($next < 0) {
@ -381,7 +381,7 @@ class Text_Password {
$tmp = '';
for ($i = 0; $i < strlen($login); $i++, $key--) {
$next = ord($login{$i}) + $key;
$next = ord($login[$i]) + $key;
if ($next > 255) {
$next -= 255;
} elseif ($next < 0) {
@ -414,7 +414,7 @@ class Text_Password {
$tmp = array();
for ($i = 0; $i < strlen($login); $i++) {
$tmp[] = $login{$i};
$tmp[] = $login[$i];
}
shuffle($tmp);
@ -521,7 +521,7 @@ class Text_Password {
*/
for ($i = 0; $i < $length; $i++) {
$num = mt_rand(0, $GLOBALS['_Text_Password_NumberOfPossibleCharacters'] - 1);
$password .= $chars{$num};
$password .= $chars[$num];
}
/**

Loading…
Cancel
Save