<?php
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
/**
* Contains the Translation2_Decorator_DefaultText class
*
* PHP versions 4 and 5
*
* LICENSE: Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR "AS IS" AND ANY EXPRESS OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
* IN NO EVENT SHALL THE FREEBSD PROJECT OR CONTRIBUTORS BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* @category Internationalization
* @package Translation2
* @author Lorenzo Alberton <l.alberton@quipo.it>
* @author Rolf 'Red' Ochsenbein <red@raven.ch>
* @copyright 2004-2007 Lorenzo Alberton, Rolf 'Red' Ochsenbein
* @license http://www.debian.org/misc/bsd.license BSD License (3 Clause)
* @version CVS: $Id: DefaultText.php 305985 2010-12-05 22:55:33Z clockwerx $
* @link http://pear.php.net/package/Translation2
*/
/**
* Load Translation2 decorator base class
*/
require_once 'Translation2/Decorator.php';
/**
* Decorator to provide a fallback text for empty strings.
*
* If the string is empty, return the <parameter>defaultText</parameter> parameter.
* If the <parameter>defaultText</parameter> parameter is empty too, then return
* "$emptyPostfix.$outputString.$emptyPrefix", the three variables
* being class properties you can set to a custom string.
*
* @category Internationalization
* @package Translation2
* @author Lorenzo Alberton <l.alberton@quipo.it>
* @author Rolf 'Red' Ochsenbein <red@raven.ch>
* @copyright 2004-2007 Lorenzo Alberton, Rolf 'Red' Ochsenbein
* @license http://www.debian.org/misc/bsd.license BSD License (3 Clause)
* @version CVS: $Id: DefaultText.php 305985 2010-12-05 22:55:33Z clockwerx $
* @link http://pear.php.net/package/Translation2
*/
class Translation2_Decorator_DefaultText extends Translation2_Decorator
{
// {{{ class vars
/**
* String appended to the returned string when the string is empty
* and it's replaced by its $stringID. It can be used to mark unreplaced
* strings.
* @var string
* @access protected
*/
var $emptyPostfix = '';
/**
* String prepended to the returned string when the string is empty
* and it's replaced by its $stringID. It can be used to mark unreplaced
* strings.
* @var string
* @access protected
*/
var $emptyPrefix = '';
/**
* String to output when there was no translation
* %stringID% will be replaced with the stringID
* %stringID_url% will replaced with a urlencoded stringID
* %url% will be replaced with the targeted url
* @var string
* @access protected
*/
//var $outputString = '%stringID%<a href="%url%">(T)</a>';
var $outputString = '%stringID%';
/**
* Targeted URL of strings without translations
* @var string
* @access protected
*/
var $url = '#';
// }}}
// {{{ get()
/**
* Get translated string
*
* If the string is empty, return the $defaultText if not empty,
* the $stringID otherwise.
*
* @param string $stringID string ID
* @param string $pageID page/group ID
* @param string $langID language ID
* @param string $defaultText Text to display when the string is empty
*
* @return string
*/
function get($stringID, $pageID = TRANSLATION2_DEFAULT_PAGEID, $langID = null, $defaultText = '')
{
if ($pageID == TRANSLATION2_DEFAULT_PAGEID) {
$pageID = $this->translation2->currentPageID;
}
$str = $this->translation2->get($stringID, $pageID, $langID);
if (!empty($str)) {
return $str;
}
if (!empty($defaultText)) {
return $this->_replaceParams($defaultText);
}
$search = array(
'%stringID%',
'%stringID_url%',
'%pageID_url%',
'%url%'
);
$replace = array(
$stringID,
urlencode($stringID),
urlencode($pageID),
$this->url
);
return $this->_replaceParams(
$this->emptyPrefix
.str_replace($search, $replace, $this->outputString)
.$this->emptyPostfix
);
//$str = (empty($defaultText) ? $this->emptyPrefix.$stringID.$this->emptyPostfix : $defaultText);
}
// }}}
// {{{ getPage()
/**
* Replace empty strings with their $stringID
*
* @param string $pageID page/group ID
* @param string $langID language ID
*
* @return array
*/
function getPage($pageID = TRANSLATION2_DEFAULT_PAGEID, $langID = null)
{
$data = $this->translation2->getPage($pageID, $langID);
return $this->replaceEmptyStringsWithKeys($data);
}
// }}}
// {{{ getStringID
/**
* Get the stringID for the given string. This method is the reverse of get().
* If the requested string is unknown to the system,
* the requested string will be returned.
*
* @param string $string This is NOT the stringID, this is a real string.
* The method will search for its matching stringID,
* and then it will return the associate string in the
* selected language.
* @param string $pageID page/group ID
*
* @return string
*/
function &getStringID($string, $pageID = TRANSLATION2_DEFAULT_PAGEID)
{
if ($pageID == TRANSLATION2_DEFAULT_PAGEID) {
$pageID = $this->translation2->currentPageID;
}
$stringID = $this->storage->getStringID($string, $pageID);
if (empty($stringID)) {
$stringID = $string;
}
return $stringID;
}
}
?>
Copyright 2K16 - 2K18 Indonesian Hacker Rulez