Revision 1983
Added by Luisehahne about 12 years ago
| class.wb.php | ||
|---|---|---|
| 30 | 30 |
|
| 31 | 31 |
class wb extends SecureForm |
| 32 | 32 |
{
|
| 33 |
/** @var object instance of the database object */ |
|
| 34 |
protected $_oDb = null; |
|
| 35 |
/** @var object instance holds several values from the application global scope */ |
|
| 36 |
protected $_oReg = null; |
|
| 37 |
/** @var object instance holds all of the translations */ |
|
| 38 |
protected $_oTrans = null; |
|
| 33 | 39 |
|
| 34 | 40 |
public $password_chars = 'a-zA-Z0-9\_\-\!\#\*\+\@\$\&\:'; // General initialization function |
| 35 | 41 |
|
| 36 | 42 |
// performed when frontend or backend is loaded. |
| 37 | 43 |
public function __construct($mode = SecureForm::FRONTEND) {
|
| 38 | 44 |
parent::__construct($mode); |
| 45 |
|
|
| 46 |
$this->_oDb = WbDatabase::getInstance(); |
|
| 47 |
$this->_oReg = WbAdaptor::getInstance(); |
|
| 48 |
$this->_oTrans = Translate::getInstance(); |
|
| 39 | 49 |
} |
| 40 | 50 |
|
| 41 | 51 |
/** |
| 42 | 52 |
* |
| 43 | 53 |
* |
| 54 |
* @return object instance of the database object of all visible languages with defined fields |
|
| 55 |
* |
|
| 56 |
*/ |
|
| 57 |
public function getAvailableLanguagesObjectInstance( ) {
|
|
| 58 |
|
|
| 59 |
$sql = 'SELECT `directory`,`name` ' |
|
| 60 |
. 'FROM `'.$this->_oDb->TablePrefix.'addons` ' |
|
| 61 |
. 'WHERE `type` = \'language\' ' |
|
| 62 |
. 'ORDER BY `directory`'; |
|
| 63 |
return ($this->_oDb->query($sql)); |
|
| 64 |
} |
|
| 65 |
|
|
| 66 |
|
|
| 67 |
/** |
|
| 68 |
* |
|
| 69 |
* |
|
| 70 |
* @return array of all visible languages with defined fields |
|
| 71 |
* |
|
| 72 |
*/ |
|
| 73 |
public function getAvailableLanguages( ) {
|
|
| 74 |
$aRetval = array(); |
|
| 75 |
if($oRes = $this->getAvailableLanguagesObjectInstance()) |
|
| 76 |
{
|
|
| 77 |
while($aRow = $oRes->fetchRow(MYSQL_ASSOC)) |
|
| 78 |
{
|
|
| 79 |
$aRetval[$aRow['directory']] = $aRow['name']; |
|
| 80 |
} |
|
| 81 |
} |
|
| 82 |
|
|
| 83 |
return ( $aRetval); |
|
| 84 |
} |
|
| 85 |
|
|
| 86 |
/** |
|
| 87 |
* |
|
| 88 |
* |
|
| 44 | 89 |
* @return array of first visible language pages with defined fields |
| 45 | 90 |
* |
| 46 | 91 |
*/ |
| 47 |
public function GetLanguagesDetailsInUsed ( ) {
|
|
| 48 |
global $database; |
|
| 92 |
public function getLanguagesDetailsInUsed ( ) {
|
|
| 93 |
// global $database;
|
|
| 49 | 94 |
$aRetval = array(); |
| 50 |
$sql =
|
|
| 51 |
'SELECT DISTINCT `language`'.
|
|
| 52 |
', `page_id`,`level`,`parent`,`root_parent`,`page_code`,`link`,`language`'.
|
|
| 53 |
', `visibility`,`viewing_groups`,`viewing_users`,`position` '.
|
|
| 54 |
'FROM `'.TABLE_PREFIX.'pages` '.
|
|
| 55 |
'WHERE `level`= \'0\' '.
|
|
| 56 |
'AND `root_parent`=`page_id` '.
|
|
| 57 |
'AND `visibility`!=\'none\' '.
|
|
| 58 |
'AND `visibility`!=\'hidden\' '.
|
|
| 59 |
'GROUP BY `language` '.
|
|
| 60 |
'ORDER BY `position`';
|
|
| 61 |
|
|
| 62 |
if($oRes = $database->query($sql))
|
|
| 95 |
$sql = 'SELECT DISTINCT `language`, `page_id`, `level`, `parent`, `root_parent`, '
|
|
| 96 |
. '`page_code`, `link`, `language`, `visibility`, '
|
|
| 97 |
. '`viewing_groups`,`viewing_users`,`position` '
|
|
| 98 |
. 'FROM `'.$this->_oDb->TablePrefix.'pages` '
|
|
| 99 |
. 'WHERE `level`= \'0\' '
|
|
| 100 |
. 'AND `root_parent`=`page_id` '
|
|
| 101 |
. 'AND `visibility`!=\'none\' '
|
|
| 102 |
. 'AND `visibility`!=\'hidden\' '
|
|
| 103 |
. 'GROUP BY `language` '
|
|
| 104 |
. 'ORDER BY `position`';
|
|
| 105 |
if($oRes = $this->_oDb->query($sql))
|
|
| 106 |
{
|
|
| 107 |
while($aRow = $oRes->fetchRow(MYSQL_ASSOC))
|
|
| 63 | 108 |
{
|
| 64 |
while($page = $oRes->fetchRow(MYSQL_ASSOC)) |
|
| 65 |
{
|
|
| 66 |
if(!$this->page_is_visible($page)) {continue;}
|
|
| 67 |
$aRetval[$page['language']] = $page; |
|
| 68 |
} |
|
| 109 |
if(!$this->page_is_visible($aRow)) {continue;}
|
|
| 110 |
$aRetval[$aRow['language']] = $aRow; |
|
| 69 | 111 |
} |
| 112 |
} |
|
| 70 | 113 |
return $aRetval; |
| 71 | 114 |
} |
| 72 | 115 |
|
| 116 |
|
|
| 117 |
|
|
| 118 |
|
|
| 73 | 119 |
/** |
| 74 | 120 |
* |
| 75 | 121 |
* |
| 76 | 122 |
* @return comma separate list of first visible languages |
| 77 | 123 |
* |
| 78 | 124 |
*/ |
| 79 |
public function GetLanguagesInUsed ( ) {
|
|
| 80 |
return implode(',', array_keys($this->GetLanguagesDetailsInUsed()));
|
|
| 125 |
public function getLanguagesInUsed ( ) {
|
|
| 126 |
$aRetval = array_keys($this->getLanguagesDetailsInUsed()) ; |
|
| 127 |
if(sizeof($aRetval)==0) { return null; }
|
|
| 128 |
return implode(',', $aRetval);
|
|
| 81 | 129 |
} |
| 82 | 130 |
|
| 83 | 131 |
|
Also available in: Unified diff
! /framework/class.wb.php::getLanguagesDetailsInUsed() optimized
+ /framework/class.wb.php::getAvailableLanguagesObjectInstance()
! /framework/class.wb.php::getLanguagesInUsed() method optimized
! /framework/class.frontend.php update changes made in class.wb.php
! /framework/functions.php::rebuild_all_accessfiles() is no longer creating FolderProtectFiles