2014-01-19 19:30:21 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace FML\Elements;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Dictionary Element
|
|
|
|
*
|
|
|
|
* @author steeffeen
|
2014-04-13 18:21:40 +02:00
|
|
|
* @copyright FancyManiaLinks Copyright © 2014 Steffen Schröder
|
|
|
|
* @license http://www.gnu.org/licenses/ GNU General Public License, Version 3
|
2014-01-19 19:30:21 +01:00
|
|
|
*/
|
|
|
|
class Dico {
|
|
|
|
/**
|
|
|
|
* Czech Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const LANG_CZECH = 'cz';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Danish Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const LANG_DANISH = 'da';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* German Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const LANG_GERMAN = 'de';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* English Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const LANG_ENGLISH = 'en';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Spanish Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const LANG_SPANISH = 'es';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* French Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const LANG_FRENCH = 'fr';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Hungarian Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const LANG_HUNGARIAN = 'hu';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Italian Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const LANG_ITALIAN = 'it';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Japanese Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const LANG_JAPANESE = 'jp';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Korean Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const LANG_KOREAN = 'kr';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Norwegian Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const LANG_NORWEGIAN = 'nb';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Dutch Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const LANG_DUTCH = 'nl';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Polish Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const LANG_POLISH = 'pl';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Portuguese Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const LANG_PORTUGUESE = 'pt';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Brazilian Portuguese Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const LANG_BRAZILIAN_PORTUGUESE = 'pt_BR';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Romanian Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const LANG_ROMANIAN = 'ro';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Russian Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const LANG_RUSSIAN = 'ru';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Slovak Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const LANG_SLOVAK = 'sk';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Turkish Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const LANG_TURKISH = 'tr';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Chinese Language
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
const LANG_CHINESE = 'zh';
|
|
|
|
|
2014-01-21 20:30:40 +01:00
|
|
|
/*
|
2014-01-19 19:30:21 +01:00
|
|
|
* Protected Properties
|
|
|
|
*/
|
|
|
|
protected $tagName = 'dico';
|
|
|
|
protected $entries = array();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a new Dictionary Object
|
|
|
|
*
|
|
|
|
* @return \FML\Elements\Dico
|
|
|
|
*/
|
|
|
|
public static function create() {
|
|
|
|
$dico = new Dico();
|
|
|
|
return $dico;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Construct a new Dictionary Object
|
|
|
|
*/
|
|
|
|
public function __construct() {
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the translatable Entry for the specific Language
|
|
|
|
*
|
|
|
|
* @param string $language Language Id
|
|
|
|
* @param string $entryId Entry Id
|
|
|
|
* @param string $entryValue Translated Entry Value
|
|
|
|
* @return \FML\Elements\Dico
|
|
|
|
*/
|
|
|
|
public function setEntry($language, $entryId, $entryValue) {
|
|
|
|
$language = (string) $language;
|
|
|
|
$entryId = (string) $entryId;
|
|
|
|
$entryValue = (string) $entryValue;
|
|
|
|
if (!isset($this->entries[$language]) && $entryValue) {
|
|
|
|
$this->entries[$language] = array();
|
|
|
|
}
|
|
|
|
if ($entryValue) {
|
|
|
|
$this->entries[$language][$entryId] = $entryValue;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
if (isset($this->entries[$language][$entryId])) {
|
|
|
|
unset($this->entries[$language][$entryId]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove Entries of the given Id
|
|
|
|
*
|
|
|
|
* @param string $entryId Entry Id that should be removed
|
|
|
|
* @param string $language (optional) Only remove Entries of the given Language
|
|
|
|
* @return \FML\Elements\Dico
|
|
|
|
*/
|
|
|
|
public function removeEntry($entryId, $language = null) {
|
|
|
|
$entryId = (string) $entryId;
|
|
|
|
if ($language) {
|
|
|
|
$language = (string) $language;
|
|
|
|
if (isset($this->entries[$language])) {
|
|
|
|
unset($this->entries[$language][$entryId]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
foreach ($this->entries as $language => $entries) {
|
|
|
|
if (isset($entries[$entryId])) {
|
|
|
|
unset($entries[$language][$entryId]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove Entries of the given Language
|
|
|
|
*
|
|
|
|
* @param string $language Language of which all Entries should be removed
|
|
|
|
* @param string $entryId (optional) Only remove the given Entry Id
|
|
|
|
* @return \FML\Elements\Dico
|
|
|
|
*/
|
|
|
|
public function removeLanguage($language, $entryId = null) {
|
|
|
|
$language = (string) $language;
|
|
|
|
if (isset($this->entries[$language])) {
|
|
|
|
if ($entryId) {
|
|
|
|
$entryId = (string) $entryId;
|
|
|
|
unset($this->entries[$language][$entryId]);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
unset($this->entries[$language]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove all Entries from the Dictionary
|
|
|
|
*
|
|
|
|
* @return \FML\Elements\Dico
|
|
|
|
*/
|
|
|
|
public function removeEntries() {
|
|
|
|
$this->entries = array();
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Render the Dico XML Element
|
|
|
|
*
|
|
|
|
* @param \DOMDocument $domDocument DomDocument for which the Dico XML Element should be rendered
|
|
|
|
* @return \DOMElement
|
|
|
|
*/
|
|
|
|
public function render(\DOMDocument $domDocument) {
|
|
|
|
$xmlElement = $domDocument->createElement($this->tagName);
|
|
|
|
foreach ($this->entries as $language => $entries) {
|
|
|
|
$languageElement = $domDocument->createElement('language');
|
|
|
|
$languageElement->setAttribute('id', $language);
|
|
|
|
foreach ($entries as $entryId => $entryValue) {
|
|
|
|
$entryElement = $domDocument->createElement($entryId, $entryValue);
|
|
|
|
$languageElement->appendChild($entryElement);
|
|
|
|
}
|
|
|
|
$xmlElement->appendChild($languageElement);
|
|
|
|
}
|
|
|
|
return $xmlElement;
|
|
|
|
}
|
|
|
|
}
|