diff --git a/classes/class.content_allocation.php b/classes/class.content_allocation.php
new file mode 100644
index 0000000..07a0736
--- /dev/null
+++ b/classes/class.content_allocation.php
@@ -0,0 +1,400 @@
+
+ * @license http://www.contenido.org/license/LIZENZ.txt
+ * @link http://www.4fb.de
+ * @link http://www.contenido.org
+ * @since file available since contenido release <= 4.6
+ *
+ * {@internal
+ * created 2005
+ * modified 2005-10-27, Willi Man, debug option
+ * modified 2005-11-16, Willi Man, new method findMatchingContentByContentAllocationByCategories
+ * modified 2005-11-21, Willi Man, new method findMarchingCOntentByContentAllocation_OR_Categories
+ * modified 2008-04-06, Holger Librenz, direct mysql_* calls remoced, using DB_ConLite:: methods instead
+ * modified 2008-07-02, Frederic Schneider, add security fix
+ *
+ * $Id: class.content_allocation.php 131 2019-07-07 18:14:22Z oldperl $:
+ * }}
+ *
+ */
+if (!defined('CON_FRAMEWORK')) {
+ die('Illegal call');
+}
+
+plugin_include('repository', 'custom/FrontendNavigation.php');
+
+class pApiContentAllocation {
+
+ /**
+ * References database object
+ *
+ * @var DB_ConLite
+ */
+ var $db = null;
+ var $table = null;
+ var $lang = null;
+ var $client = null;
+ var $treeObj = null;
+
+ /**
+ *
+ * @modified 27.10.2005 new class variable $this->bDebug (if true print debug information)
+ */
+ public function __construct() {
+ global $db, $cfg, $lang, $client;
+
+ $this->db = new DB_ConLite;
+ $this->table = $cfg['tab'];
+ $this->lang = $lang;
+ $this->client = $client;
+
+ # use this option carefully and only temporary.
+ # the hidden debug output as html-comments can cause display problems.
+ $this->bDebug = false;
+
+ $this->treeObj = new pApiTree('f31a4384-e5c1-4ede-b1bb-f43657ec73a5');
+ }
+
+ function storeAllocations($idartlang, $allocations) {
+ // empty before insert
+ $this->deleteAllocationsByIdartlang($idartlang);
+
+ if (is_array($allocations)) {
+ foreach ($allocations as $value) {
+ $sql = "INSERT INTO " . $this->table['pica_alloc_con'] . " (idpica_alloc, idartlang) VALUES (" . Contenido_Security::toInteger($value) . ", " . Contenido_Security::toInteger($idartlang) . ")";
+ $this->db->query($sql);
+ }
+ }
+ }
+
+ function deleteAllocations($idpica_alloc) {
+ $sql = "DELETE FROM " . $this->table['pica_alloc_con'] . " WHERE idpica_alloc = " . Contenido_Security::toInteger($idpica_alloc);
+ $this->db->query($sql);
+ }
+
+ function deleteAllocationsByIdartlang($idartlang) {
+ $sql = "DELETE FROM " . $this->table['pica_alloc_con'] . " WHERE idartlang = " . Contenido_Security::toInteger($idartlang);
+ $this->db->query($sql);
+ }
+
+ function loadAllocations($idartlang) {
+ //$sql = "SELECT idpica_alloc FROM " . $this->table['pica_alloc_con'] . " WHERE idartlang = " . Contenido_Security::toInteger($idartlang);
+ $this->db->query("-- pApiContentAllocation->loadAllocations()
+ SELECT
+ a.idpica_alloc
+ FROM
+ `{$this->table['pica_alloc']}` AS a
+ , `{$this->table['pica_alloc_con']}` AS b
+ WHERE
+ idartlang = $idartlang
+ AND a.idpica_alloc=b.idpica_alloc
+ ;");
+
+ $items = array();
+
+ while ($this->db->next_record()) {
+ $items[] = $this->db->f('idpica_alloc');
+ }
+ return $items;
+ }
+
+ function loadAllocationsWithNames($idartlang, $parent, $firstonly = false) {
+
+ global $cfg;
+
+ $sql = "SELECT " . $cfg['tab']['pica_alloc'] . ".idpica_alloc FROM " . $cfg['tab']['pica_alloc'] . "
+ INNER JOIN " . $cfg['tab']['pica_alloc_con'] . " ON
+ " . $cfg['tab']['pica_alloc'] . ".idpica_alloc = " . $cfg['tab']['pica_alloc_con'] . ".idpica_alloc
+ WHERE (" . $cfg['tab']['pica_alloc'] . ".parentid = " . Contenido_Security::toInteger($parent) . ") AND (" . $cfg['tab']['pica_alloc_con'] . ".idartlang=" . Contenido_Security::toInteger($idartlang) . ")
+ ORDER BY " . $cfg['tab']['pica_alloc'] . ".sortorder";
+
+ $this->db->query($sql);
+
+ while ($this->db->next_record()) {
+ $tmp[$this->db->f("idpica_alloc")] = $this->treeObj->_fetchItemNameLang($this->db->f("idpica_alloc"));
+
+ if ($firstonly) {
+ break;
+ }
+ }
+
+ return $tmp;
+ }
+
+ /**
+ * Build query to find matching content by content allocation
+ * @param array $restrictions
+ * @return string SQL
+ * @modified 17.11.2005 by Willi Man
+ */
+ function findMatchingContent($restrictions = null, $max = 0) {
+ if (!is_array($restrictions)) {
+ return false;
+ }
+
+ global $aCategoriesToExclude; # @see config.local.php!
+ $sql = $this->_buildQuery($restrictions, $aCategoriesToExclude, $max);
+
+ return $sql;
+ }
+
+ /**
+ * Build query to find matching content by content allocation
+ * @param array $restrictions
+ * @return string SQL
+ */
+ function _buildQuery($restrictions, $aCategoriesToExclude, $max) {
+
+ global $cfg;
+
+ $size = sizeof($restrictions);
+
+ if ($size == 0) {
+ return '';
+ }
+
+ $sql_concat = unserialize('a:78:{i:0;s:2:"aa";i:1;s:2:"ab";i:2;s:2:"ac";i:3;s:2:"ad";i:4;s:2:"ae";i:5;s:2:"af";i:6;s:2:"ag";i:7;s:2:"ah";i:8;s:2:"ai";i:9;s:2:"aj";i:10;s:2:"ak";i:11;s:2:"al";i:12;s:2:"am";i:13;s:2:"an";i:14;s:2:"ao";i:15;s:2:"ap";i:16;s:2:"aq";i:17;s:2:"ar";i:18;s:2:"as";i:19;s:2:"at";i:20;s:2:"au";i:21;s:2:"av";i:22;s:2:"aw";i:23;s:2:"ax";i:24;s:2:"ay";i:25;s:2:"az";i:26;s:2:"ca";i:27;s:2:"cb";i:28;s:2:"cc";i:29;s:2:"cd";i:30;s:2:"ce";i:31;s:2:"cf";i:32;s:2:"cg";i:33;s:2:"ch";i:34;s:2:"ci";i:35;s:2:"cj";i:36;s:2:"ck";i:37;s:2:"cl";i:38;s:2:"cm";i:39;s:2:"cn";i:40;s:2:"co";i:41;s:2:"cp";i:42;s:2:"cq";i:43;s:2:"cr";i:44;s:2:"cs";i:45;s:2:"ct";i:46;s:2:"cu";i:47;s:2:"cv";i:48;s:2:"cw";i:49;s:2:"cx";i:50;s:2:"cy";i:51;s:2:"cz";i:52;s:1:"a";i:53;s:1:"b";i:54;s:1:"c";i:55;s:1:"d";i:56;s:1:"e";i:57;s:1:"f";i:58;s:1:"g";i:59;s:1:"h";i:60;s:1:"i";i:61;s:1:"j";i:62;s:1:"k";i:63;s:1:"l";i:64;s:1:"m";i:65;s:1:"n";i:66;s:1:"o";i:67;s:1:"p";i:68;s:1:"q";i:69;s:1:"r";i:70;s:1:"s";i:71;s:1:"t";i:72;s:1:"u";i:73;s:1:"v";i:74;s:1:"w";i:75;s:1:"x";i:76;s:1:"y";i:77;s:1:"z";}');
+
+ $sqlTemplate = "SELECT cal.idart, cal.online, aa.idartlang, cat.idcat FROM {TABLES} WHERE {WHERE} ";
+
+ $tables = array();
+ $where = array();
+
+ for ($i = 0; $i < $size; $i++) {
+ if ($i == 0) { // first
+ $tables[] = " " . $cfg['tab']['pica_alloc_con'] . " AS " . $sql_concat[$i];
+ } else {
+ $tables[] = " LEFT JOIN " . $cfg['tab']['pica_alloc_con'] . " AS " . $sql_concat[$i] . " USING (idartlang)";
+ }
+ if (is_int((int) $restrictions[$i]) AND $restrictions[$i] > 0) {
+ $where[] = $sql_concat[$i] . ".idpica_alloc = " . $restrictions[$i];
+ }
+ }
+
+ # fetch only articles which are online
+ $where[] = 'cal.online = 1';
+
+ # fetch only articles which are not in following categories
+ if (count($aCategoriesToExclude) > 0) {
+ $where[] = "cat.idcat NOT IN (" . implode(',', $aCategoriesToExclude) . ")";
+ }
+
+ // join art_lang for idart
+ $tables[] = " LEFT JOIN " . $this->table['art_lang'] . " AS cal USING (idartlang)";
+ $tables[] = " LEFT JOIN " . $this->table['cat_art'] . " AS cart USING (idart)";
+ $tables[] = " LEFT JOIN " . $this->table['cat'] . " as cat USING (idcat)";
+
+ $tables = implode('', $tables);
+ $where = implode(' AND ', $where);
+
+ $sql = str_replace('{TABLES}', $tables, $sqlTemplate);
+ $sql = str_replace('{WHERE}', $where, $sql);
+
+ $sql .= " ORDER BY cal.published DESC";
+
+ if ($max != 0 && is_integer($max)) {
+ $sql .= " LIMIT " . $max;
+ }
+
+ if ($this->bDebug) {
+ print "";
+ } # @modified 27.10.2005
+
+ return $sql;
+ }
+
+ /**
+ * Search articles by content allocation and catgories
+ * @param array $aContentAllocation
+ * @param array $aCategories
+ *
+ * @return array of articles
+ */
+ function findMatchingContentByContentAllocationByCategories($aContentAllocation, $aCategories = array(), $iOffset = 0, $iNumOfRows = 0) {
+ if (!is_array($aContentAllocation)) {
+ return array();
+ }
+
+ for ($i = 0; $i < count($aContentAllocation); $i++) {
+ if (!is_int((int) $aContentAllocation[$i]) OR ! $aContentAllocation[$i] > 0) {
+ return array();
+ }
+ }
+
+ for ($i = 0; $i < count($aCategories); $i++) {
+ if (!is_int((int) $aCategories[$i]) OR ! $aCategories[$i] > 0) {
+ return array();
+ }
+ }
+
+ $sql = $this->_buildQuery_MatchingContentByContentAllocationByCategories($aContentAllocation, $aCategories, $iOffset, $iNumOfRows);
+
+ $this->db->query($sql);
+
+ $aResult = array();
+ while ($oRow = $this->db->getResultObject()) {
+ $aResult[] = $oRow;
+ }
+ return $aResult;
+ }
+
+ /**
+ * build SQL query to find articles by content allocation and catgories
+ *
+ */
+ function _buildQuery_MatchingContentByContentAllocationByCategories($aContentAllocation, $aCategories, $iOffset, $iNumOfRows) {
+
+ global $cfg;
+
+ $size = sizeof($aContentAllocation);
+
+ $sql_concat = unserialize('a:78:{i:0;s:2:"aa";i:1;s:2:"ab";i:2;s:2:"ac";i:3;s:2:"ad";i:4;s:2:"ae";i:5;s:2:"af";i:6;s:2:"ag";i:7;s:2:"ah";i:8;s:2:"ai";i:9;s:2:"aj";i:10;s:2:"ak";i:11;s:2:"al";i:12;s:2:"am";i:13;s:2:"an";i:14;s:2:"ao";i:15;s:2:"ap";i:16;s:2:"aq";i:17;s:2:"ar";i:18;s:2:"as";i:19;s:2:"at";i:20;s:2:"au";i:21;s:2:"av";i:22;s:2:"aw";i:23;s:2:"ax";i:24;s:2:"ay";i:25;s:2:"az";i:26;s:2:"ca";i:27;s:2:"cb";i:28;s:2:"cc";i:29;s:2:"cd";i:30;s:2:"ce";i:31;s:2:"cf";i:32;s:2:"cg";i:33;s:2:"ch";i:34;s:2:"ci";i:35;s:2:"cj";i:36;s:2:"ck";i:37;s:2:"cl";i:38;s:2:"cm";i:39;s:2:"cn";i:40;s:2:"co";i:41;s:2:"cp";i:42;s:2:"cq";i:43;s:2:"cr";i:44;s:2:"cs";i:45;s:2:"ct";i:46;s:2:"cu";i:47;s:2:"cv";i:48;s:2:"cw";i:49;s:2:"cx";i:50;s:2:"cy";i:51;s:2:"cz";i:52;s:1:"a";i:53;s:1:"b";i:54;s:1:"c";i:55;s:1:"d";i:56;s:1:"e";i:57;s:1:"f";i:58;s:1:"g";i:59;s:1:"h";i:60;s:1:"i";i:61;s:1:"j";i:62;s:1:"k";i:63;s:1:"l";i:64;s:1:"m";i:65;s:1:"n";i:66;s:1:"o";i:67;s:1:"p";i:68;s:1:"q";i:69;s:1:"r";i:70;s:1:"s";i:71;s:1:"t";i:72;s:1:"u";i:73;s:1:"v";i:74;s:1:"w";i:75;s:1:"x";i:76;s:1:"y";i:77;s:1:"z";}');
+
+ $sqlTemplate = "SELECT cal.idart, cal.online, aa.idartlang, cat.idcat, aa.idpica_alloc FROM {TABLES} WHERE {WHERE} ";
+
+ $tables = array();
+ $where = array();
+
+ for ($i = 0; $i < $size; $i++) {
+ if ($i == 0) { // first
+ $tables[] = " " . $cfg['tab']['pica_alloc_con'] . " AS " . $sql_concat[$i];
+ } else {
+ $tables[] = " LEFT JOIN " . $cfg['tab']['pica_alloc_con'] . " AS " . $sql_concat[$i] . " USING (idartlang)";
+ }
+ if (is_int((int) $aContentAllocation[$i]) AND $aContentAllocation[$i] > 0) {
+ $where[] = $sql_concat[$i] . ".idpica_alloc = " . $aContentAllocation[$i];
+ }
+ }
+
+ # fetch only articles which are online
+ $where[] = 'cal.online = 1';
+
+ # fetch only articles in following categories
+ if (count($aCategories) > 0) {
+ $where[] = "cat.idcat IN (" . implode(',', $aCategories) . ")";
+ }
+
+ // join art_lang for idart
+ $tables[] = " LEFT JOIN " . $this->table['art_lang'] . " AS cal USING (idartlang)";
+ $tables[] = " LEFT JOIN " . $this->table['cat_art'] . " AS cart USING (idart)";
+ $tables[] = " LEFT JOIN " . $this->table['cat'] . " as cat USING (idcat)";
+
+ $tables = implode('', $tables);
+ $where = implode(' AND ', $where);
+
+ $sql = str_replace('{TABLES}', $tables, $sqlTemplate);
+ $sql = str_replace('{WHERE}', $where, $sql);
+
+ $sql .= " ORDER BY cal.published DESC";
+
+ if (is_integer($iNumOfRows) AND $iNumOfRows > 0) {
+ $sql .= " LIMIT " . $iOffset . ", " . $iNumOfRows;
+ }
+
+ if ($this->bDebug) {
+ print "";
+ } # @modified 27.10.2005
+
+ return $sql;
+ }
+
+ /**
+ * Search articles by catgories without start articles
+ * @param array $aCategories
+ * @param int $iOffset
+ * @param int $iNumOfRows
+ * @param string $sResultType element of {article_id, object}
+ *
+ * @return array of articles
+ */
+ function findMatchingContentByCategories($aCategories = array(), $iOffset = 0, $iNumOfRows = 0, $sResultType = '') {
+
+ for ($i = 0; $i < count($aCategories); $i++) {
+ if (!is_int((int) $aCategories[$i]) OR ! $aCategories[$i] > 0) {
+ return array();
+ }
+ }
+
+ $sql = $this->_buildQuery_MatchingContentByCategories($aCategories, $iOffset, $iNumOfRows);
+
+ $this->db->query($sql);
+
+ $aResult = array();
+
+ while ($oRow = $this->db->getResultObject()) {
+ if ($sResultType == 'article_language_id') {
+ $aResult[] = $oRow->idartlang;
+ } else {
+ $aResult[] = $oRow;
+ }
+ }
+ return $aResult;
+ }
+
+ /**
+ * build SQL query to find articles by catgories
+ *
+ */
+ function _buildQuery_MatchingContentByCategories($aCategories, $iOffset, $iNumOfRows) {
+
+ if (count($aCategories) > 0) {
+ $sWHERE_Category_IN = " c.idcat IN (" . implode(',', $aCategories) . ") AND ";
+ } else {
+ $sWHERE_Category_IN = '';
+ }
+ if (is_integer($iNumOfRows) AND $iNumOfRows > 0) {
+ $sLimit = " LIMIT " . Contenido_Security::toInteger($iOffset) . ", " . Contenido_Security::toInteger($iNumOfRows);
+ } else {
+ $sLimit = '';
+ }
+
+ $sql = '
+ SELECT
+ a.idart, a.online, a.idartlang, c.idcat
+ FROM
+ ' . $this->table['art_lang'] . ' AS a,
+ ' . $this->table['art'] . ' AS b,
+ ' . $this->table['cat_art'] . ' AS c,
+ ' . $this->table['cat_lang'] . ' AS d
+ WHERE
+ ' . $sWHERE_Category_IN . '
+ b.idclient = ' . Contenido_Security::toInteger($this->client) . ' AND
+ a.idlang = ' . Contenido_Security::toInteger($this->lang) . ' AND
+ a.idartlang != d.startidartlang AND
+ a.online = 1 AND
+ c.idcat = d.idcat AND
+ b.idart = c.idart AND
+ a.idart = b.idart
+ ' . $sLimit . ' ';
+
+ if ($this->bDebug) {
+ print "";
+ }
+
+ return $sql;
+ }
+
+}
+
+?>
\ No newline at end of file
diff --git a/classes/class.content_allocation_article.php b/classes/class.content_allocation_article.php
new file mode 100644
index 0000000..c7e571c
--- /dev/null
+++ b/classes/class.content_allocation_article.php
@@ -0,0 +1,117 @@
+
+ * @license http://www.contenido.org/license/LIZENZ.txt
+ * @link http://www.4fb.de
+ * @link http://www.contenido.org
+ * @since file available since contenido release <= 4.6
+ *
+ * {@internal
+ * created unknown
+ * modified 2008-07-02, Frederic Schneider, add security fix
+ *
+ * $Id: class.content_allocation_article.php 128 2019-07-03 11:58:28Z oldperl $:
+ * }}
+ *
+ */
+if (!defined('CON_FRAMEWORK')) {
+ die('Illegal call');
+}
+
+class pApiContentAllocationArticle extends pApiTree {
+
+ var $tpl = null;
+ var $template = '';
+ var $load = array();
+
+ public function __construct($uuid) {
+ global $cfg;
+
+ parent::pApiTree($uuid);
+ $this->tpl = new Template;
+ $this->template = $cfg['pica']['treetemplate_article'];
+ }
+
+ function _buildRenderTree($tree) {
+ global $action, $frame, $area, $sess, $idart;
+
+ $result = array();
+ foreach ($tree as $item_tmp) {
+ $item = array();
+
+ $expandCollapseImg = 'images/spacer.gif';
+ $expandCollapse = '';
+
+ $item['ITEMNAME'] = $expandCollapse . ' ' . $item_tmp['name'];
+
+ $item['ITEMINDENT'] = $item_tmp['level'] * 15 + 3;
+
+ // set checked!
+ $checked = '';
+ if (in_array($item_tmp['idpica_alloc'], $this->load)) {
+ $checked = ' checked="checked"';
+ }
+ $item['CHECKBOX'] = '';
+
+ array_push($result, $item);
+
+ if ($item_tmp['children']) {
+ $children = $this->_buildRenderTree($item_tmp['children']);
+ $result = array_merge($result, $children);
+ }
+ }
+
+ return $result;
+ }
+
+ function setChecked($load) {
+ $this->load = $load;
+ }
+
+ function renderTree($return = true) {
+ $this->tpl->reset();
+
+ $tree = $this->fetchTree();
+ if ($tree === false) {
+ return false;
+ }
+
+ $tree = $this->_buildRenderTree($tree);
+
+ $even = true;
+ foreach ($tree as $item) {
+ $even = !$even;
+ $bgcolor = ($even) ? '#FFFFFF' : '#F1F1F1';
+ $this->tpl->set('d', 'BACKGROUND_COLOR', $bgcolor);
+ foreach ($item as $key => $value) {
+ $this->tpl->set('d', $key, $value);
+ }
+ $this->tpl->next();
+ }
+
+ $this->tpl->set('s', "CATEGORY", i18n("Category", "content_allocation"));
+
+ if ($return === true) {
+ return $this->tpl->generate($this->template, true);
+ } else {
+ $this->tpl->generate($this->template);
+ }
+ }
+
+}
+
+?>
\ No newline at end of file
diff --git a/classes/class.content_allocation_complexlist.php b/classes/class.content_allocation_complexlist.php
new file mode 100644
index 0000000..8879174
--- /dev/null
+++ b/classes/class.content_allocation_complexlist.php
@@ -0,0 +1,114 @@
+
+ * @license http://www.contenido.org/license/LIZENZ.txt
+ * @link http://www.4fb.de
+ * @link http://www.contenido.org
+ * @since file available since contenido release <= 4.6
+ *
+ * {@internal
+ * created unknown
+ * modified 2008-07-02, Frederic Schneider, add security fix
+ *
+ * $Id: class.content_allocation_complexlist.php 128 2019-07-03 11:58:28Z oldperl $:
+ * }}
+ *
+ */
+if (!defined('CON_FRAMEWORK')) {
+ die('Illegal call');
+}
+
+class pApiContentAllocationComplexList extends pApiTree {
+
+ var $idSetter = true;
+ var $load = array();
+
+ public function __construct($uuid) {
+ global $cfg;
+ parent::__construct($uuid);
+ }
+
+ public function _buildRenderTree($tree) {
+ global $action, $frame, $area, $sess, $idart;
+
+ $oldIdSetter = $this->idSetter;
+ $this->idSetter = false;
+
+ $result = '';
+
+ $even = true;
+
+ $levelElms = sizeof($tree);
+ $cnt = 1;
+ foreach ($tree as $item_tmp) {
+ $item = '';
+ $checked = '';
+ if (in_array($item_tmp['idpica_alloc'], $this->load)) {
+ $checked = ' checked="checked"';
+ }
+
+ $li_closeElm = '';
+ if ($cnt == $levelElms) {
+ $li_closeElm = 'style="border-bottom: 0;"';
+ }
+ $cnt++;
+
+ $even = !$even;
+ $bgcolor = ($even) ? 'bright' : 'dark';
+
+ // for wrapping purposes
+ $item_tmp['name'] = str_replace('-', '- ', $item_tmp['name']);
+
+ $checkbox = '';
+ $item = "\n
" . $checkbox . " " . $item_tmp['name'];
+
+ $result .= $item;
+
+ if ($item_tmp['children']) {
+ $children = $this->_buildRenderTree($item_tmp['children']);
+ $result .= "\n";
+ } else {
+ $result .= "\n";
+ }
+ }
+
+ if ($oldIdSetter === true) {
+ return "\n";
+ } else {
+ return $result . "\n";
+ }
+ }
+
+ public function setChecked($load) {
+ $this->load = $load;
+ }
+
+ public function renderTree($return = true) {
+ $tree = $this->fetchTree();
+ if ($tree === false) {
+ return false;
+ }
+
+ $tree = $this->_buildRenderTree($tree);
+ if ($return === true) {
+ return $tree;
+ }
+ }
+
+}
+
+?>
\ No newline at end of file
diff --git a/classes/class.content_allocation_selectbox.php b/classes/class.content_allocation_selectbox.php
new file mode 100644
index 0000000..9db8baa
--- /dev/null
+++ b/classes/class.content_allocation_selectbox.php
@@ -0,0 +1,87 @@
+
+ * @license http://www.contenido.org/license/LIZENZ.txt
+ * @link http://www.4fb.de
+ * @link http://www.contenido.org
+ * @since file available since contenido release <= 4.6
+ *
+ * $Id: class.content_allocation_selectbox.php 128 2019-07-03 11:58:28Z oldperl $:
+ */
+if (!defined('CON_FRAMEWORK')) {
+ die('Illegal call');
+}
+
+class pApiContentAllocationSelectBox extends pApiTree {
+
+ var $idSetter = true;
+ var $load = array();
+
+ public function __construct($uuid) {
+ global $cfg;
+
+ parent::__construct($uuid);
+ }
+
+ public function _buildRenderTree($tree) {
+ global $action, $frame, $area, $sess, $idart;
+
+ $oldIdSetter = $this->idSetter;
+ $this->idSetter = false;
+
+ $result = '';
+
+ $levelElms = sizeof($tree);
+ $cnt = 1;
+ foreach ($tree as $item_tmp) {
+ $item = '';
+
+ $spacer = '|-';
+ $spacer = str_pad($spacer, (($item_tmp['level'] + 1) * 2), "--", STR_PAD_RIGHT);
+
+ $result .= '';
+
+ if ($item_tmp['children']) {
+ $children = $this->_buildRenderTree($item_tmp['children']);
+ $result .= $children;
+ }
+ }
+
+ return $result;
+ }
+
+ public function setChecked($load) {
+ return false;
+ }
+
+ /**
+ *
+ * @modified 27.10.2005 $bUseTreeStatus = false (content allocation tree in selectbox is always expanded)
+ */
+ public function renderTree($return = true, $parentId = false, $bUseTreeStatus = false) {
+
+ $tree = $this->fetchTree($parentId, 0, $bUseTreeStatus);
+
+ if ($tree === false) {
+ return false;
+ }
+
+ $tree = $this->_buildRenderTree($tree);
+
+ if ($return === true) {
+ return $tree;
+ } else {
+ echo $tree;
+ }
+ }
+
+}
+
+?>
\ No newline at end of file
diff --git a/classes/class.content_allocation_tree.php b/classes/class.content_allocation_tree.php
new file mode 100644
index 0000000..9a02ae2
--- /dev/null
+++ b/classes/class.content_allocation_tree.php
@@ -0,0 +1,558 @@
+
+ * @license http://www.contenido.org/license/LIZENZ.txt
+ * @link http://www.4fb.de
+ * @link http://www.contenido.org
+ * @since file available since contenido release <= 4.6
+ *
+ * {@internal
+ * created unknown
+ * modified 2008-07-02, Frederic Schneider, add security fix
+ *
+ * $Id: class.content_allocation_tree.php 128 2019-07-03 11:58:28Z oldperl $:
+ * }}
+ *
+ */
+if (!defined('CON_FRAMEWORK')) {
+ die('Illegal call');
+}
+
+/**
+ * Todo
+ * addslashes to all string db inserts
+ * check if default language exists if new entry is added (otherwise)
+ */
+class pApiTree {
+
+ /**
+ *
+ */
+ var $db = null;
+
+ /**
+ *
+ */
+ var $table = null;
+
+ /**
+ *
+ */
+ var $lang = 1;
+
+ /**
+ *
+ */
+ var $client = 1;
+
+ /**
+ *
+ */
+ var $defaultLang = 1;
+
+ /**
+ *
+ */
+ var $logger = null;
+
+ /**
+ *
+ */
+ var $user = null;
+
+ /**
+ *
+ */
+ var $treeStatus = array();
+
+ /**
+ *
+ */
+ var $uuid = null;
+
+ /**
+ *
+ */
+ var $_arrInFilters = array('urlencode', 'clHtmlSpecialChars', 'addslashes');
+
+ /**
+ *
+ */
+ var $_arrOutFilters = array('stripslashes', 'htmldecode', 'urldecode');
+
+ public function __construct($uuid) {
+ global $db, $cfg, $lang, $client, $auth;
+
+ $this->db = new DB_ConLite;
+ $this->table = $cfg['tab'];
+ $this->lang = $lang;
+ $this->client = $client;
+ $this->bDebug = false;
+
+ $this->uuid = $uuid;
+
+ $this->user = new cApiUser($auth->auth["uid"]);
+ $this->loadTreeStatus();
+ }
+
+ /**
+ *
+ * @param mixed $parentId
+ * @param int $level
+ * @param boolean $bUseTreeStatus (if true use expand/collapsed status of the tree, otherwise not)
+ * @modified 27.10.2005 Willi Man
+ */
+ function fetchTree($parentId = false, $level = 0, $bUseTreeStatus = true) {
+
+ // fetch current lang category
+ $sql = "SELECT
+ tree.idpica_alloc, tree.parentid, tree.sortorder
+ FROM
+ " . $this->table['pica_alloc'] . " as tree";
+
+ if ($parentId === false) { // fetch from root node
+ $sql .= " WHERE tree.parentid = '0'";
+ } else { // fetch by given id
+ $sql .= " WHERE tree.parentid = " . Contenido_Security::toInteger($parentId);
+ }
+
+ $sql .= " ORDER BY sortorder ASC";
+
+ $this->db->query($sql);
+
+ $result_tmp = array(); // tmp result array
+ while ($this->db->next_record()) { // walk resultset
+ $item = $this->_fetchItemNameLang($this->db->f('idpica_alloc'));
+
+ $itemStatus = 'expanded';
+
+ if ($bUseTreeStatus) { # modified 27.10.2005
+ if (is_array($this->treeStatus) && array_key_exists($this->db->f('idpica_alloc'), $this->treeStatus)) {
+ $itemStatus = 'collapsed';
+ }
+ }
+
+ $rs = array(
+ 'idpica_alloc' => $this->db->f('idpica_alloc'),
+ 'parentid' => ($this->db->f('parentid') == NULL) ? false : $this->db->f('parentid'),
+ 'sortorder' => $this->db->f('sortorder'),
+ 'name' => $this->_outFilter($item['name']),
+ 'idlang' => $item['idlang'],
+ 'level' => $level,
+ 'status' => $itemStatus,
+ 'online' => $item['online']
+ );
+
+ array_push($result_tmp, $rs); // append recordset
+ }
+
+ if (count($result_tmp) > 0) {
+ $result = array(); // result array
+ foreach ($result_tmp as $rs) { // run results
+ $children = $this->fetchTree($rs['idpica_alloc'], $level + 1, $bUseTreeStatus);
+ if ($children !== false && $rs['status'] == 'expanded') {
+ $rs['children'] = $children;
+ }
+ array_push($result, $rs);
+ }
+ return $result;
+ } else {
+ return false;
+ }
+ }
+
+ /**
+ * Fetch content allocation tree
+ * Consider offline/online status
+ *
+ * @created 21.11.2005 Willi Man
+ *
+ * @param mixed $parentId
+ * @param int $level
+ * @return array with content allocation id's
+ */
+ function fetchTreeIds($parentId = false, $level = 0, $showOffline = false) {
+
+ // fetch current lang category
+ $sql = "SELECT
+ tree.idpica_alloc, tree.parentid, tree.sortorder
+ FROM
+ " . $this->table['pica_alloc'] . " as tree";
+
+ if ($parentId === false) { // fetch from root node
+ $sql .= " WHERE tree.parentid IS NULL";
+ } else { // fetch by given id
+ $sql .= " WHERE tree.parentid = " . Contenido_Security::toInteger($parentId);
+ }
+
+ $sql .= " ORDER BY sortorder ASC";
+
+ if ($this->bDebug) {
+ print "";
+ }
+
+ $this->db->query($sql);
+
+ $result_tmp = array(); // tmp result array
+ while ($this->db->next_record()) { // walk resultset
+ $item = $this->_fetchItemNameLang($this->db->f('idpica_alloc'));
+
+ if ($this->bDebug) {
+ print "";
+ }
+
+ if ($showOffline OR $item['online'] == 1) {
+ $rs = array(
+ 'idpica_alloc' => $this->db->f('idpica_alloc')
+ );
+
+ array_push($result_tmp, $rs); // append recordset
+ }
+ }
+
+ if (count($result_tmp) > 0) {
+ $result = array(); // result array
+ foreach ($result_tmp as $rs) { // run results
+ $children = $this->fetchTreeIds($rs['idpica_alloc'], $level + 1, $bUseTreeStatus);
+ if ($children !== false) {
+ $rs['children'] = $children;
+ }
+ array_push($result, $rs);
+ }
+ return $result;
+ } else {
+ return false;
+ }
+ }
+
+ function setTreeStatus($idpica_alloc) {
+ if (is_array($this->treeStatus) && array_key_exists($idpica_alloc, $this->treeStatus)) { // expand
+ unset($this->treeStatus[$idpica_alloc]);
+ } else { // collapse
+ $this->treeStatus[$idpica_alloc] = true;
+ }
+ $this->user->setProperty("expandstate", $this->_uuid, serialize($this->treeStatus));
+ }
+
+ function loadTreeStatus() {
+ $status = $this->user->getProperty("expandstate", $this->_uuid);
+ if ($status !== false) {
+ $this->treeStatus = unserialize($status);
+ }
+ }
+
+ function fetchParent($idpica_alloc) {
+ $sql = "SELECT idpica_alloc FROM " . $this->table['pica_alloc'] . " WHERE parentId = " . Contenido_Security::toInteger($idpica_alloc);
+ $this->db->query($sql);
+
+ if ($this->db->next_record()) {
+ return $this->fetchItem($this->db->f('idpica_alloc'));
+ } else {
+ return false;
+ }
+ }
+
+ function fetchParents() {
+
+ }
+
+ function fetchLevel($parentId = false, $showOffline = false) {
+ // fetch current lang category
+ $sql = "SELECT
+ tree.idpica_alloc, tree.parentid, tree.sortorder
+ FROM
+ " . $this->table['pica_alloc'] . " as tree
+ LEFT JOIN " . $this->table['pica_lang'] . " as treelang USING (idpica_alloc)";
+
+ if ($parentId === false) { // fetch from root node
+ $sql .= " WHERE tree.parentid IS NULL";
+ } else { // fetch by given id
+ $sql .= " WHERE tree.parentid = " . Contenido_Security::toInteger($parentId);
+ }
+
+ if ($showOffline === false) {
+ $sql .= " AND treelang.online = 1";
+ }
+
+ $sql .= " ORDER BY sortorder ASC";
+
+ $this->db->query($sql);
+
+ $result_tmp = array(); // tmp result array
+ while ($this->db->next_record()) { // walk resultset
+ $item = $this->_fetchItemNameLang($this->db->f('idpica_alloc'));
+
+ $itemStatus = 'expanded';
+ if (is_array($this->treeStatus) && array_key_exists($this->db->f('idpica_alloc'), $this->treeStatus)) {
+ $itemStatus = 'collapsed';
+ }
+
+ $rs = array(
+ 'idpica_alloc' => $this->db->f('idpica_alloc'),
+ 'parentid' => ($this->db->f('parentid') == NULL) ? false : $this->db->f('parentid'),
+ 'sortorder' => $this->db->f('sortorder'),
+ 'name' => $this->_outFilter($item['name']),
+ 'idlang' => $item['idlang'],
+ 'level' => 0,
+ 'status' => $itemStatus,
+ 'online' => $item['online']
+ );
+
+ array_push($result_tmp, $rs); // append recordset
+ }
+
+ return $result_tmp;
+ }
+
+ function storeItem($treeItem) {
+
+ if (!$treeItem['idpica_alloc']) { // insert
+ $treeItem['idpica_alloc'] = $this->db->nextid($this->table['pica_alloc']);
+ $treeItem['sortorder'] = $this->_fetchMaxOrder($treeItem['parentid']) + 1;
+
+ if ($treeItem['parentid'] == 'root') {
+ $treeItem['parentid'] = 'NULL';
+ }
+
+ $treeItem['name'] = $this->_inFilter($treeItem['name']);
+
+ $sql = "INSERT INTO " . $this->table['pica_alloc'] . "
+ (idpica_alloc, parentid, sortorder)
+ VALUES
+ (" . Contenido_Security::toInteger($treeItem['idpica_alloc']) . ", " . Contenido_Security::toInteger($treeItem['parentid']) . ", " . Contenido_Security::toInteger($treeItem['sortorder']) . ")";
+ $this->db->query($sql);
+
+ $sql = "INSERT INTO " . $this->table['pica_lang'] . "
+ (idpica_alloc, idlang, name)
+ VALUES
+ (" . Contenido_Security::toInteger($treeItem['idpica_alloc']) . ", " . Contenido_Security::toInteger($this->lang) . ", '" . Contenido_Security::escapeDB($treeItem['name'], $this->db) . "')";
+ $this->db->query($sql);
+ } else { // update
+ $treeItem['name'] = $this->_inFilter($treeItem['name']);
+
+ $sql = "SELECT * FROM " . $this->table['pica_lang'] . " WHERE idpica_alloc = " . Contenido_Security::toInteger($treeItem['idpica_alloc']) . " AND idlang = " . Contenido_Security::toInteger($this->lang);
+ $this->db->query($sql);
+
+ if ($this->db->num_rows() > 0) {
+ #Update existing translation
+ $sql = "UPDATE " . $this->table['pica_lang'] . " SET name = '" . Contenido_Security::escapeDB($treeItem['name'], $this->db) . "' WHERE idpica_alloc = " . Contenido_Security::toInteger($treeItem['idpica_alloc']) . "
+ AND idlang = " . Contenido_Security::toInteger($this->lang);
+ } else {
+ #Get current online status for item
+ $sql = "SELECT * FROM " . $this->table['pica_lang'] . " WHERE idpica_alloc = " . $treeItem['idpica_alloc'] . " ORDER BY idlang";
+ $this->db->query($sql);
+
+ if ($this->db->next_record()) {
+ $online_status = $this->db->f('online');
+ } else {
+ $online_status = 0;
+ }
+
+ #Insert new translation
+ $sql = "INSERT INTO " . $this->table['pica_lang'] . "(idpica_alloc, idlang, name, online) VALUES ( " . Contenido_Security::toInteger($treeItem['idpica_alloc']) . ", " . Contenido_Security::toInteger($this->lang) . ",
+ '" . Contenido_Security::escapeDB($treeItem['name'], $this->db) . "', " . Contenido_Security::toInteger($online_status) . ")";
+ }
+
+ $this->db->query($sql);
+ }
+
+ return $treeItem;
+ }
+
+ function setOnline($idpica_alloc) {
+ $this->_switchOnOffline($idpica_alloc, 1);
+ }
+
+ function setOffline($idpica_alloc) {
+ $this->_switchOnOffline($idpica_alloc, 0);
+ }
+
+ function _switchOnOffline($idpica_alloc, $status) {
+ $sql = "UPDATE " . $this->table['pica_lang'] . " SET online = " . Contenido_Security::toInteger($status) . " WHERE idpica_alloc = " . Contenido_Security::toInteger($idpica_alloc) . "
+ AND idlang = " . Contenido_Security::toInteger($this->lang);
+ $this->db->query($sql);
+ }
+
+ function itemMoveUp($idpica_alloc) {
+ $treeItem = $this->fetchItem($idpica_alloc);
+ $treeItem_old = $treeItem;
+ $treeItem['sortorder'] --;
+
+ if ($treeItem['sortorder'] < $treeItem_old['sortorder']) {
+ if ($treeItem['sortorder'] >= 1) {
+ $this->_decreaseOrder($treeItem['parentid'], $treeItem_old['sortorder']);
+ $this->_increaseOrder($treeItem['parentid'], $treeItem['sortorder']);
+ } else {
+ $treeItem['sortorder'] = $treeItem_old['sortorder'];
+ }
+ }
+
+ $sql = "UPDATE " . $this->table['pica_alloc'] . " SET sortorder = " . $treeItem['sortorder'] . " WHERE idpica_alloc = " . Contenido_Security::toInteger($idpica_alloc);
+ $this->db->query($sql);
+ }
+
+ function itemMoveDown() {
+
+ }
+
+ function deleteItem($idpica_alloc) {
+ $sql = "DELETE FROM " . $this->table['pica_alloc'] . " WHERE idpica_alloc = " . Contenido_Security::toInteger($idpica_alloc);
+ $this->db->query($sql);
+
+ $sql = "DELETE FROM " . $this->table['pica_lang'] . " WHERE idpica_alloc = " . Contenido_Security::toInteger($idpica_alloc);
+ $this->db->query($sql);
+
+ $sql = "DELETE FROM " . $this->table['pica_alloc_con'] . " WHERE idpica_alloc = " . Contenido_Security::toInteger($idpica_alloc);
+ $this->db->query($sql);
+ }
+
+ function fetchItem($idpica_alloc) {
+ $sql = "SELECT parentid, sortorder FROM " . $this->table['pica_alloc'] . " WHERE idpica_alloc = " . $idpica_alloc;
+ $this->db->query($sql);
+
+ $item = $this->_fetchItemNameLang($idpica_alloc);
+
+ if ($this->db->next_record()) {
+ $row = array(
+ 'idpica_alloc' => $idpica_alloc,
+ 'parentid' => ($this->db->f('parentid') == NULL) ? false : $this->db->f('parentid'),
+ 'sortorder' => $this->db->f('sortorder'),
+ 'name' => $item['name'],
+ 'idlang' => $item['idlang'],
+ 'online' => $item['online']
+ );
+ return $row;
+ } else {
+ return false;
+ }
+ }
+
+ function _fetchItemNameLang($idpica_alloc) {
+ $oDB = new DB_ConLite; // temp instance
+
+ $sSQL = "SELECT name, idlang, online FROM " . $this->table['pica_lang'] . " WHERE idpica_alloc = " . Contenido_Security::toInteger($idpica_alloc) . " AND idlang = " . Contenido_Security::toInteger($this->lang);
+ $oDB->query($sSQL);
+
+ $aResult = array();
+ if ($oDB->next_record()) { // item found for this language
+ $aResult['name'] = $this->_outFilter($oDB->f('name'));
+ $aResult['idlang'] = $oDB->f('idlang');
+ $aResult['online'] = $oDB->f('online');
+ } else { // no item in this language found
+ // fetch alternative language name
+ // HerrB, 2008-04-21: Get all translations, try to use defaultLang translation, use
+ // first available, otherwise. Only using defaultLang results in "ghost" elements, if
+ // created in a non-default language. See CON-110 for details.
+ $sSQL = "SELECT name, idlang, online FROM " . $this->table['pica_lang'] . " WHERE idpica_alloc = " . Contenido_Security::toInteger($idpica_alloc) . " ORDER BY idlang";
+ $oDB->query($sSQL);
+
+ $aNames = array();
+ while ($oDB->next_record()) {
+ $sKey = "k" . $oDB->f('idlang');
+
+ $aNames[$sKey] = array();
+ $aNames[$sKey]['name'] = $this->_outFilter($oDB->f('name'));
+ $aNames[$sKey]['idlang'] = $oDB->f('idlang');
+ $aNames[$sKey]['online'] = $oDB->f('online');
+ }
+
+ if ($aNames["k" . $this->defaultLang]) {
+ // defaultLang translation available
+ $aResult = $aNames["k" . $this->defaultLang];
+ } else {
+ // no defaultLang translation available, use first in line (reset returns first element)
+ $aResult = reset($aNames);
+ }
+ }
+ unset($oDB);
+ unset($aNames);
+
+ return $aResult;
+ }
+
+ function _fetchMaxOrder($parentId = false) {
+
+ if ($parentId == 'root') {
+ $parentId = false;
+ }
+
+ $sql = "SELECT MAX(sortorder) as max FROM " . $this->table['pica_alloc'];
+ if ($parentId === false) {
+ $sql .= " WHERE parentid = 0";
+ } else {
+ $sql .= " WHERE parentid = " . Contenido_Security::toInteger($parentId);
+ }
+ $this->db->query($sql);
+ if ($this->db->next_record()) {
+ return $this->db->f('max');
+ } else {
+ return 0;
+ }
+ }
+
+ function _decreaseOrder($parentId = false, $fromOrder) {
+ $sql = "UPDATE " . $this->table['pica_alloc'] . " SET sortorder = sortorder - 1 WHERE sortorder >= " . Contenido_Security::toInteger($fromOrder);
+ if ($parentId === false) {
+ $sql .= " AND parentid IS NULL";
+ } else {
+ $sql .= " AND parentid = " . Contenido_Security::toInteger($parentId);
+ }
+ $this->db->query($sql);
+ }
+
+ function _increaseOrder($parentId = false, $fromOrder) {
+ $sql = "UPDATE " . $this->table['pica_alloc'] . " SET sortorder = sortorder + 1 WHERE sortorder >= " . Contenido_Security::toInteger($fromOrder);
+ if ($parentId === false) {
+ $sql .= " AND parentid IS NULL";
+ } else {
+ $sql .= " AND parentid = " . Contenido_Security::toInteger($parentId);
+ }
+ $this->db->query($sql);
+ }
+
+ function setFilters($arrInFilters = array(), $arrOutFilters = array()) {
+ $this->_arrInFilters = $arrInFilters;
+ $this->_arrOutFilters = $arrOutFilters;
+ }
+
+ function _inFilter($data) {
+ foreach ($this->_arrInFilters as $_function) {
+ if (function_exists($_function)) {
+ $data = $_function($data);
+ }
+ }
+
+ return $data;
+ }
+
+ function _outFilter($data) {
+ foreach ($this->_arrOutFilters as $_function) {
+ if (function_exists($_function)) {
+ $data = $_function($data);
+ }
+ }
+
+ return $data;
+ }
+
+}
+
+?>
\ No newline at end of file
diff --git a/classes/class.content_allocation_treeview.php b/classes/class.content_allocation_treeview.php
new file mode 100644
index 0000000..517a54f
--- /dev/null
+++ b/classes/class.content_allocation_treeview.php
@@ -0,0 +1,234 @@
+
+ * @license http://www.contenido.org/license/LIZENZ.txt
+ * @link http://www.4fb.de
+ * @link http://www.contenido.org
+ * @since file available since contenido release <= 4.6
+ *
+ * {@internal
+ * created unknown
+ * modified 2008-06-26, Timo Trautmann, changed post var from treeItem to treeItemPost (security issue)
+ * modified 2008-07-02, Frederic Schneider, add security fix
+ *
+ * $Id: class.content_allocation_treeview.php 128 2019-07-03 11:58:28Z oldperl $:
+ * }}
+ *
+ */
+if (!defined('CON_FRAMEWORK')) {
+ die('Illegal call');
+}
+
+/**
+ * Todo
+ * - generalize this and papitree !!!!
+ * - Comments!
+ */
+class pApiContentAllocationTreeView extends pApiTree {
+
+ /**
+ *
+ */
+ var $tpl = null;
+
+ /**
+ *
+ */
+ var $template = '';
+
+ /**
+ *
+ */
+ public function __construct($uuid) {
+ global $cfg;
+
+ parent::__construct($uuid);
+ $this->tpl = new Template;
+ $this->template = $cfg['pica']['treetemplate'];
+ }
+
+ /**
+ *
+ */
+ function _buildRenderTree($tree) {
+ global $action, $frame, $area, $sess;
+ $result = array();
+ foreach ($tree as $item_tmp) {
+ $item = array();
+
+ // update item
+ if ($_GET['step'] == 'rename' && $item_tmp['idpica_alloc'] == $_GET['idpica_alloc']) {
+ $item = array();
+
+ $item['ITEMNAME'] = '
+
+ ';
+ } else {
+ if ($item_tmp['children'] || $item_tmp['status'] == 'collapsed') {
+ $expandCollapseImg = 'images/close_all.gif';
+ if ($item_tmp['status'] == 'collapsed') {
+ $expandCollapseImg = 'images/open_all.gif';
+ }
+
+ $expandCollapse = '';
+ } else {
+ $expandCollapseImg = 'images/spacer.gif';
+ $expandCollapse = '';
+ }
+
+ $item['ITEMNAME'] = $expandCollapse . ' ' . $item_tmp['name'];
+ }
+
+ $item['ITEMINDENT'] = $item_tmp['level'] * 15 + 3;
+ $item['ACTION_CREATE'] = '';
+
+ $item['ACTION_RENAME'] = '';
+ $item['ACTION_MOVE_UP'] = (count($result) >= 1) ? '' : '';
+ $item['ACTION_MOVE_DOWN'] = (count($result) >= 1) ? '' : '';
+ $item['ACTION_MOVE_DOWN'] = '';
+
+ if ($item_tmp['online'] == 1) { // set offline
+ $item['ACTION_ONOFFLINE'] = '';
+ } else {
+ $item['ACTION_ONOFFLINE'] = '';
+ }
+
+ if ($item_tmp['children']) {
+ $item['ACTION_DELETE'] = '';
+ } else {
+ $item['ACTION_DELETE'] = '
' . str_replace("'", "\'", $item_tmp['name']) . '","deleteCategory(' . $item_tmp['idpica_alloc'] . ')");">';
+ }
+
+ array_push($result, $item);
+
+ if ($item_tmp['children']) {
+ $children = $this->_buildRenderTree($item_tmp['children']);
+ $result = array_merge($result, $children);
+ }
+
+ // add new item -> show formular
+ if ($_GET['step'] == 'add' && $item_tmp['idpica_alloc'] == $_GET['parentid']) {
+ $item = array();
+
+ $item['ITEMNAME'] = '
+
+ ';
+ $item['ITEMINDENT'] = ($item_tmp['level'] + 1) * 15;
+ $item['ACTION_CREATE'] = '';
+ $item['ACTION_RENAME'] = '';
+ $item['ACTION_MOVE_UP'] = '';
+ $item['ACTION_MOVE_DOWN'] = '';
+ $item['ACTION_MOVE_DOWN'] = '';
+ $item['ACTION_DELETE'] = '';
+ $item['ACTION_ONOFFLINE'] = '';
+
+ array_push($result, $item);
+ }
+ }
+ return $result;
+ }
+
+ /**
+ *
+ */
+ function renderTree($return = true) {
+ $this->tpl->reset();
+
+ $tree = $this->fetchTree(false, 0, true); # modified 27.10.2005
+
+ if ($tree === false) {
+ return false;
+ }
+
+ $tree = $this->_buildRenderTree($tree);
+
+ $even = true;
+ foreach ($tree as $item) {
+ $even = !$even;
+ $bgcolor = ($even) ? '#FFFFFF' : '#F1F1F1';
+ $this->tpl->set('d', 'BACKGROUND_COLOR', $bgcolor);
+ foreach ($item as $key => $value) {
+ $this->tpl->set('d', $key, $value);
+ }
+ $this->tpl->next();
+ }
+
+ $this->tpl->set('s', 'CATEGORY', i18n("Category", "content_allocation"));
+ $this->tpl->set('s', 'ACTIONS', i18n("Actions", "content_allocation"));
+
+ if ($return === true) {
+ return $this->tpl->generate($this->template, true);
+ } else {
+ $this->tpl->generate($this->template);
+ }
+ }
+
+}
+
+?>
\ No newline at end of file
diff --git a/images/arrow.gif b/images/arrow.gif
new file mode 100644
index 0000000..5424e1d
Binary files /dev/null and b/images/arrow.gif differ
diff --git a/images/call_contentallocation.gif b/images/call_contentallocation.gif
new file mode 100644
index 0000000..8f5165a
Binary files /dev/null and b/images/call_contentallocation.gif differ
diff --git a/images/normal.gif b/images/normal.gif
new file mode 100644
index 0000000..035c42c
Binary files /dev/null and b/images/normal.gif differ
diff --git a/includes/config.autoloader.php b/includes/config.autoloader.php
new file mode 100644
index 0000000..efcd0cf
--- /dev/null
+++ b/includes/config.autoloader.php
@@ -0,0 +1,30 @@
+
+ * @copyright 2015 CL-Team
+ * @link http://www.conlite.org
+ *
+ * $Id: config.autoloader.php 128 2019-07-03 11:58:28Z oldperl $
+ */
+
+if(!defined('CON_FRAMEWORK')) {
+ die('Illegal call');
+}
+
+$sAutoloadClassPath = 'conlite/plugins/content_allocation/classes/';
+return array(
+ 'pApiContentAllocation' => $sAutoloadClassPath.'class.content_allocation.php',
+ 'pApiContentAllocationArticle' => $sAutoloadClassPath.'class.content_allocation_article.php',
+ 'pApiContentAllocationComplexList' => $sAutoloadClassPath.'class.content_allocation_complexlist.php',
+ 'pApiContentAllocationSelectBox' => $sAutoloadClassPath.'class.content_allocation_selectbox.php',
+ 'pApiTree' => $sAutoloadClassPath.'class.content_allocation_tree.php',
+ 'pApiContentAllocationTreeView' => $sAutoloadClassPath.'class.content_allocation_treeview.php'
+);
+?>
\ No newline at end of file
diff --git a/includes/config.plugin.php b/includes/config.plugin.php
new file mode 100644
index 0000000..40ec70b
--- /dev/null
+++ b/includes/config.plugin.php
@@ -0,0 +1,65 @@
+
+ * @license http://www.contenido.org/license/LIZENZ.txt
+ * @link http://www.4fb.de
+ * @link http://www.contenido.org
+ * @since file available since contenido release <= 4.6
+ *
+ * {@internal
+ * created unknown
+ * modified 2008-07-02, Frederic Schneider, add security fix
+ *
+ * $Id: config.plugin.php 128 2019-07-03 11:58:28Z oldperl $:
+ * }}
+ *
+ */
+
+if(!defined('CON_FRAMEWORK')) {
+ die('Illegal call');
+}
+
+
+// plugin includes
+plugin_include('content_allocation', 'classes/class.content_allocation_tree.php');
+plugin_include('content_allocation', 'classes/class.content_allocation_treeview.php');
+plugin_include('content_allocation', 'classes/class.content_allocation_article.php');
+plugin_include('content_allocation', 'classes/class.content_allocation.php');
+plugin_include('content_allocation', 'classes/class.content_allocation_complexlist.php');
+
+// plugin_variables
+$cfg['tab']['pica_alloc'] = $cfg['sql']['sqlprefix'].'_pica_alloc';
+$cfg['tab']['pica_alloc_con'] = $cfg['sql']['sqlprefix'].'_pica_alloc_con';
+$cfg['tab']['pica_lang'] = $cfg['sql']['sqlprefix'].'_pica_lang';
+
+$cfg['pica']['logpath'] = $cfg['path']['contenido'] . $cfg['path']['plugins'] . 'repository/log/data/';
+$cfg['pica']['loglevel'] = 'warn';
+$cfg['pica']['treetemplate'] = $cfg['path']['contenido'] . $cfg['path']['plugins'] . 'content_allocation/templates/template.tree_structure.html';
+$cfg['pica']['treetemplate_article'] = $cfg['path']['contenido'] . $cfg['path']['plugins'] . 'content_allocation/templates/template.tree_article.html';
+$cfg['pica']['treetemplate_complexlist'] = $cfg['path']['contenido'] . $cfg['path']['plugins'] . 'content_allocation/templates/template.tree_complexlist.html';
+
+$cfg['pica']['style_complexlist'] = $cfg['path']['contenido_fullhtml'] . $cfg['path']['plugins'] . 'content_allocation/style/complexlist.css';
+$cfg['pica']['script_complexlist'] = $cfg['path']['contenido_fullhtml'] . $cfg['path']['plugins'] . 'content_allocation/scripts/complexlist.js';
+
+// administration > users > area translations
+global $lngAct, $_cecRegistry;
+$lngAct['con_contentallocation']['storeallocation'] = i18n("Store content allocations", "content_allocation");
+
+plugin_include('content_allocation', 'includes/functions.chains.php');
+
+$_cecRegistry->addChainFunction("Contenido.Article.RegisterCustomTab", "pica_RegisterCustomTab");
+$_cecRegistry->addChainFunction("Contenido.Article.GetCustomTabProperties", "pica_GetCustomTabProperties");
+?>
\ No newline at end of file
diff --git a/includes/functions.chains.php b/includes/functions.chains.php
new file mode 100644
index 0000000..12c1486
--- /dev/null
+++ b/includes/functions.chains.php
@@ -0,0 +1,67 @@
+
+ * @license http://www.contenido.org/license/LIZENZ.txt
+ * @link http://www.4fb.de
+ * @link http://www.contenido.org
+ * @since file available since contenido release <= 4.6
+ *
+ * {@internal
+ * created unknown
+ * modified 2008-07-02, Frederic Schneider, add security fix
+ *
+ * $Id: functions.chains.php 128 2019-07-03 11:58:28Z oldperl $:
+ * }}
+ *
+ */
+
+if(!defined('CON_FRAMEWORK')) {
+ die('Illegal call');
+}
+
+function pica_RegisterCustomTab ()
+{
+ return array("con_contentallocation");
+}
+
+function pica_GetCustomTabProperties ($sIntName)
+{
+ if ($sIntName == "con_contentallocation")
+ {
+ return array("con_contentallocation", "con_edit", "");
+ }
+}
+
+function pica_ArticleListActions ($aActions)
+{
+ $aTmpActions["con_contentallocation"] = "con_contentallocation";
+
+ return $aTmpActions + $aActions;
+}
+
+function pica_RenderArticleAction ($idcat, $idart, $idartlang, $actionkey)
+{
+ global $sess;
+
+ if ($actionkey == "con_contentallocation")
+ {
+ return '';
+
+ } else {
+ return "";
+ }
+}
+?>
\ No newline at end of file
diff --git a/includes/include.contentallocation_article.php b/includes/include.contentallocation_article.php
new file mode 100644
index 0000000..4fbda48
--- /dev/null
+++ b/includes/include.contentallocation_article.php
@@ -0,0 +1,132 @@
+
+ * @license http://www.contenido.org/license/LIZENZ.txt
+ * @link http://www.4fb.de
+ * @link http://www.contenido.org
+ * @since file available since contenido release <= 4.6
+ *
+ * {@internal
+ * created unknown
+ * modified 2008-07-02, Frederic Schneider, add security fix
+ *
+ * $Id: include.contentallocation_article.php 128 2019-07-03 11:58:28Z oldperl $:
+ * }}
+ *
+ */
+if (!defined('CON_FRAMEWORK')) {
+ die('Illegal call');
+}
+
+// check requests
+Contenido_Security::checkRequests();
+
+if (!($perm->have_perm_area_action($area, "storeallocation") || $perm->have_perm_area_action_item($area, "storeallocation", $idcat))) {
+ $notification->displayNotification("error", i18n("Permission denied", "content_allocation"));
+ return;
+}
+
+cInclude("includes", "functions.pathresolver.php");
+
+function str_replace_recursive($array) {
+ if (!is_array($array))
+ return false;
+
+ $result = array();
+
+ foreach ($array as $value) {
+ $result[] = str_replace("e", "", $value);
+ }
+
+ return $result;
+}
+
+// fetch idartlang for idart
+$sql = "SELECT idartlang FROM " . $cfg['tab']['art_lang'] . " WHERE idart=" . Contenido_Security::toInteger($idart) . " AND idlang=" . Contenido_Security::toInteger($lang);
+$db->query($sql);
+$db->next_record();
+$this_idartlang = $db->f('idartlang');
+
+$oPage = new cPage;
+$oPage->setMargin(10);
+
+$oTree = new pApiContentAllocationComplexList('06bd456d-fe76-40cb-b041-b9ba90dc400a');
+$oAlloc = new pApiContentAllocation;
+
+if ($_POST['action'] == 'storeallocation') {
+ $oAlloc->storeAllocations($this_idartlang, $_POST['allocation']);
+}
+if ($_GET['step'] == 'collapse') {
+ $oTree->setTreeStatus($_GET['idpica_alloc']);
+}
+
+#build category path
+$catString = '';
+prCreateURLNameLocationString($idcat, '/', $catString);
+$oArticle = new Article($idart, $client, $lang);
+$sArticleTitle = $oArticle->getField('title');
+
+$sLocationString = "" . $catString . '/' . clHtmlSpecialChars($sArticleTitle) . "
";
+
+// load allocations
+$loadedAllocations = $oAlloc->loadAllocations($this_idartlang);
+
+$oTree->setChecked($loadedAllocations);
+$result = $oTree->renderTree(true);
+
+if ($result == false) {
+ $result = $notification->returnNotification("warning", i18n('There is no Content Allocation tree.', "content_allocation"));
+} else {
+ if (!is_object($tpl)) {
+ $tpl = new Template;
+ }
+ $hiddenfields = '
+
+
+
+
+ ';
+ $tpl->set('s', 'HIDDENFIELDS', $hiddenfields);
+
+
+ if (sizeof($loadedAllocations) > 0) {
+ $tpl->set('s', 'ARRAY_CHECKED_BOXES', 'var checkedBoxes = [' . implode(',', $loadedAllocations) . '];');
+ } else {
+ $tpl->set('s', 'ARRAY_CHECKED_BOXES', 'var checkedBoxes = [];');
+ }
+
+ $oDiv = new cHTMLDiv;
+ $oDiv->updateAttributes(array('style' => 'text-align: right; padding: 5px; width: 730px; border: 1px #B3B3B3 solid; background-color: #FFFFFF;'));
+ $oDiv->setContent('');
+ $tpl->set('s', 'DIV', '
' . $oDiv->render());
+
+ $tpl->set('s', 'TREE', $result);
+
+ $tpl->set('s', 'REMOVE_ALL', i18n("Remove all", "content_allocation"));
+ $tpl->set('s', 'REMOVE', i18n("Remove", "content_allocation"));
+
+ $result = $tpl->generate($cfg['pica']['treetemplate_complexlist'], true);
+
+ $script = '
+ ';
+ $oPage->addScript('style', $script);
+}
+
+
+$oPage->setContent($sLocationString . $result . markSubMenuItem(5, true));
+$oPage->render();
+?>
\ No newline at end of file
diff --git a/includes/include.left_bottom.php b/includes/include.left_bottom.php
new file mode 100644
index 0000000..6b52801
--- /dev/null
+++ b/includes/include.left_bottom.php
@@ -0,0 +1,22 @@
+
+ * @copyright 2017 CL-Team
+ * @link http://www.conlite.org
+ *
+ * $Id: include.left_bottom.php 128 2019-07-03 11:58:28Z oldperl $
+ */
+
+if(!defined('CON_FRAMEWORK')) {
+ die('Illegal call');
+}
+
+$oPage = new cPage();
+$oPage->setHtml5();
+
+$oPage->render();
\ No newline at end of file
diff --git a/includes/include.left_top.php b/includes/include.left_top.php
new file mode 100644
index 0000000..c1b7e79
--- /dev/null
+++ b/includes/include.left_top.php
@@ -0,0 +1,39 @@
+
+ * @license http://www.contenido.org/license/LIZENZ.txt
+ * @link http://www.4fb.de
+ * @link http://www.contenido.org
+ * @since file available since contenido release <= 4.6
+ *
+ * {@internal
+ * created unknown
+ * modified 2008-07-02, Frederic Schneider, add security fix
+ *
+ * $Id: include.left_top.php 128 2019-07-03 11:58:28Z oldperl $:
+ * }}
+ *
+ */
+
+if(!defined('CON_FRAMEWORK')) {
+ die('Illegal call');
+}
+
+$oPage = new UI_Left_Top;
+
+$oPage->render();
+
+?>
\ No newline at end of file
diff --git a/includes/include.right_bottom.php b/includes/include.right_bottom.php
new file mode 100644
index 0000000..06a5c35
--- /dev/null
+++ b/includes/include.right_bottom.php
@@ -0,0 +1,164 @@
+
+ * @license http://www.contenido.org/license/LIZENZ.txt
+ * @link http://www.4fb.de
+ * @link http://www.contenido.org
+ * @since file available since contenido release <= 4.6
+ *
+ * {@internal
+ * created unknown
+ * modified 2008-07-02, Frederic Schneider, add security fix
+ *
+ * $Id: include.right_bottom.php 128 2019-07-03 11:58:28Z oldperl $:
+ * }}
+ *
+ */
+if (!defined('CON_FRAMEWORK')) {
+ die('Illegal call');
+}
+
+if (isset($_REQUEST['treeItem'])) {
+ die('Illegal call!');
+}
+
+#added 24.06.08 timo.trautmann security fix filter submitted treeItemPost array before insertion, name also changed according to security fix
+$aPostTreeItem = array();
+if (!is_object($db)) {
+ $db = new DB_ConLite();
+}
+
+if (isset($_REQUEST['treeItemPost']['idpica_alloc'])) {
+ $aPostTreeItem['idpica_alloc'] = (int) $_REQUEST['treeItemPost']['idpica_alloc'];
+}
+
+if (isset($_REQUEST['treeItemPost']['parentid'])) {
+ $aPostTreeItem['parentid'] = (int) $_REQUEST['treeItemPost']['parentid'];
+}
+
+if (isset($_REQUEST['treeItemPost']['name'])) {
+ $sName = stripslashes($_REQUEST['treeItemPost']['name']);
+ $sName = $db->escape($sName);
+ $aPostTreeItem['name'] = $sName;
+}
+
+$_GET['idpica_alloc'] = (int) $_GET['idpica_alloc'];
+#end added 24.06.08 timo.trautmann
+
+$oPage = new cPage();
+$oPage->setMargin(10);
+$oPage->setMessageBox();
+$oTree = new pApiContentAllocationTreeView('f7771624-4874-4745-8b7e-21a49a71a447');
+
+// store item
+if ($_POST['step'] == 'store') {
+ $pNotify = '';
+ $sMessage = sprintf(i18n("New Category %s successfully stored!", "content_allocation"), $treeItem['name']);
+ $notification->displayNotification("info", $sMessage);
+ $pNotify .= '
';
+ $oTree->storeItem($aPostTreeItem);
+}
+// rename item
+if ($_POST['step'] == 'storeRename') {
+ $pNotify = '';
+ $sMessage = sprintf(i18n("Category %s successfully renamed!", "content_allocation"), $treeItem['name']);
+ $notification->displayNotification("info", $sMessage);
+ $pNotify .= '
';
+ $oTree->storeItem($aPostTreeItem);
+}
+// rename item
+if ($_GET['step'] == 'moveup') {
+ $oTree->itemMoveUp($_GET['idpica_alloc']);
+}
+
+if ($_GET['step'] == 'deleteItem') { // delete item
+ $pNotify = '';
+ $sMessage = i18n("Category successfully deleted!", "content_allocation");
+ $notification->displayNotification("info", $sMessage);
+ $pNotify .= '
';
+ $oTree->deleteItem($_GET['idpica_alloc']);
+}
+if ($_GET['step'] == 'collapse') {
+ $oTree->setTreeStatus($_GET['idpica_alloc']);
+}
+if ($_GET['step'] == 'online') {
+ $oTree->setOnline($_GET['idpica_alloc']);
+}
+if ($_GET['step'] == 'offline') {
+ $oTree->setOffline($_GET['idpica_alloc']);
+}
+
+$oDiv = new cHTMLDiv;
+$oDiv->updateAttributes(array('style' => 'padding: 5px; width: 400px; border: 1px #B3B3B3 solid; background-color: #FFFFFF;'));
+$sTemp = '';
+
+if ($_GET['step'] == 'createRoot') { // create new root item
+ $form = '
+
+ ';
+ $oDiv->setContent($form);
+ $sTemp = $oDiv->render();
+} else {
+ $newTree = '' . i18n("Create new tree", "content_allocation") . '';
+}
+
+$result = $oTree->renderTree(true);
+
+if ($result === false) {
+ $result = ' ';
+}
+
+$js = '
+';
+
+$oPage->addScript('deleteCategory', $js);
+
+$oPage->setContent($pNotify . $newTree . $sTemp . '
' . $result);
+$oPage->render();
+?>
\ No newline at end of file
diff --git a/locale/content_allocation.pot b/locale/content_allocation.pot
new file mode 100644
index 0000000..d7ac312
--- /dev/null
+++ b/locale/content_allocation.pot
@@ -0,0 +1,109 @@
+# SOME DESCRIPTIVE TITLE.
+# Copyright (C) YEAR THE PACKAGE'S COPYRIGHT HOLDER
+# This file is distributed under the same license as the PACKAGE package.
+# FIRST AUTHOR , YEAR.
+#
+#, fuzzy
+msgid ""
+msgstr ""
+"Project-Id-Version: PACKAGE VERSION\n"
+"Report-Msgid-Bugs-To: \n"
+"POT-Creation-Date: 2011-05-18 10:55+0200\n"
+"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
+"Last-Translator: FULL NAME \n"
+"Language-Team: LANGUAGE \n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=CHARSET\n"
+"Content-Transfer-Encoding: 8bit\n"
+
+#: includes/config.plugin.php:59
+msgid "Store content allocations"
+msgstr ""
+
+#: includes/include.contentallocation_article.php:86
+msgid "There is no Content Allocation tree."
+msgstr ""
+
+#: includes/include.contentallocation_article.php:111
+msgid "Remove all"
+msgstr ""
+
+#: includes/include.contentallocation_article.php:112
+msgid "Remove"
+msgstr ""
+
+#: includes/include.right_bottom.php:70
+#, php-format
+msgid "New Category %s successfully stored!"
+msgstr ""
+
+#: includes/include.right_bottom.php:78
+#, php-format
+msgid "Category %s successfully renamed!"
+msgstr ""
+
+#: includes/include.right_bottom.php:90
+msgid "Category successfully deleted!"
+msgstr ""
+
+#: includes/include.right_bottom.php:119 includes/include.right_bottom.php:142
+msgid "Create new tree"
+msgstr ""
+
+#: includes/include.right_bottom.php:132
+msgid "Please enter a category name."
+msgstr ""
+
+#: includes/functions.chains.php:61
+msgid "Content Allocation"
+msgstr ""
+
+#: classes/class.content_allocation_treeview.php:100
+#: classes/class.content_allocation_treeview.php:176
+msgid "Please enter a category name"
+msgstr ""
+
+#: classes/class.content_allocation_treeview.php:124
+msgid "New category"
+msgstr ""
+
+#: classes/class.content_allocation_treeview.php:126
+msgid "Rename category"
+msgstr ""
+
+#: classes/class.content_allocation_treeview.php:127
+msgid "Move category up"
+msgstr ""
+
+#: classes/class.content_allocation_treeview.php:128
+msgid "Move category down"
+msgstr ""
+
+#: classes/class.content_allocation_treeview.php:132
+msgid "Set category offline"
+msgstr ""
+
+#: classes/class.content_allocation_treeview.php:134
+msgid "Set category online"
+msgstr ""
+
+#: classes/class.content_allocation_treeview.php:138
+msgid "One or more subcategories exist, unable to delete"
+msgstr ""
+
+#: classes/class.content_allocation_treeview.php:140
+msgid "Delete category"
+msgstr ""
+
+#: classes/class.content_allocation_treeview.php:140
+msgid "Are you sure to delete the following category"
+msgstr ""
+
+#: classes/class.content_allocation_treeview.php:223
+#: classes/class.content_allocation_article.php:107
+msgid "Category"
+msgstr ""
+
+#: classes/class.content_allocation_treeview.php:224
+msgid "Actions"
+msgstr ""
diff --git a/locale/de_DE/LC_MESSAGES/content_allocation.mo b/locale/de_DE/LC_MESSAGES/content_allocation.mo
new file mode 100644
index 0000000..d6dd69c
Binary files /dev/null and b/locale/de_DE/LC_MESSAGES/content_allocation.mo differ
diff --git a/locale/de_DE/LC_MESSAGES/content_allocation.po b/locale/de_DE/LC_MESSAGES/content_allocation.po
new file mode 100644
index 0000000..943d23e
--- /dev/null
+++ b/locale/de_DE/LC_MESSAGES/content_allocation.po
@@ -0,0 +1,112 @@
+# SOME DESCRIPTIVE TITLE.
+# Copyright (C) YEAR THE PACKAGE'S COPYRIGHT HOLDER
+# This file is distributed under the same license as the PACKAGE package.
+# FIRST AUTHOR , YEAR.
+#
+msgid ""
+msgstr ""
+"Project-Id-Version: Contenido ContentAllocation\n"
+"Report-Msgid-Bugs-To: \n"
+"POT-Creation-Date: 2011-05-18 10:55+0200\n"
+"PO-Revision-Date: 2013-09-11 14:31+0100\n"
+"Last-Translator: Ortwin Pinke \n"
+"Language-Team: Ortwin Pinke \n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=iso-8859-1\n"
+"Content-Transfer-Encoding: 8bit\n"
+"X-Poedit-KeywordsList: i18n\n"
+"Language: de_DE\n"
+"X-Generator: Poedit 1.5.7\n"
+
+#: includes/config.plugin.php:59
+msgid "Store content allocations"
+msgstr "Content Allocation speichern"
+
+#: includes/include.contentallocation_article.php:86
+msgid "There is no Content Allocation tree."
+msgstr "Es existiert kein Content Allocation Baum"
+
+#: includes/include.contentallocation_article.php:111
+msgid "Remove all"
+msgstr "Alle entfernen"
+
+#: includes/include.contentallocation_article.php:112
+msgid "Remove"
+msgstr "Entfernen"
+
+#: includes/include.right_bottom.php:70
+#, php-format
+msgid "New Category %s successfully stored!"
+msgstr "Neue Kategorie %s gespeichert!"
+
+#: includes/include.right_bottom.php:78
+#, php-format
+msgid "Category %s successfully renamed!"
+msgstr "Kategorie %s umbenannt!"
+
+#: includes/include.right_bottom.php:90
+msgid "Category successfully deleted!"
+msgstr "Kategorie gelöscht!"
+
+#: includes/include.right_bottom.php:119 includes/include.right_bottom.php:142
+msgid "Create new tree"
+msgstr "Neuen Baum erstellen"
+
+#: includes/include.right_bottom.php:132
+msgid "Please enter a category name."
+msgstr "Bitte geben Sie einen Kategorienamen ein."
+
+#: includes/functions.chains.php:61
+msgid "Content Allocation"
+msgstr "Content Allocation"
+
+#: classes/class.content_allocation_treeview.php:100
+#: classes/class.content_allocation_treeview.php:176
+msgid "Please enter a category name"
+msgstr "Bitte geben Sie einen Kategorienamen ein"
+
+#: classes/class.content_allocation_treeview.php:124
+msgid "New category"
+msgstr "Neue Kategorie"
+
+#: classes/class.content_allocation_treeview.php:126
+msgid "Rename category"
+msgstr "Kategorie umbenennen"
+
+#: classes/class.content_allocation_treeview.php:127
+msgid "Move category up"
+msgstr "Kategorie aufwärts bewegen"
+
+#: classes/class.content_allocation_treeview.php:128
+msgid "Move category down"
+msgstr "Kategorie abwärts bewegen"
+
+#: classes/class.content_allocation_treeview.php:132
+msgid "Set category offline"
+msgstr "Kategorie offline schalten"
+
+#: classes/class.content_allocation_treeview.php:134
+msgid "Set category online"
+msgstr "Kategorie online schalten"
+
+#: classes/class.content_allocation_treeview.php:138
+msgid "One or more subcategories exist, unable to delete"
+msgstr ""
+"Es gibt eine oder mehrer Unterkategorien, Löschen nicht möglich"
+
+#: classes/class.content_allocation_treeview.php:140
+msgid "Delete category"
+msgstr "Lösche Kategorie"
+
+#: classes/class.content_allocation_treeview.php:140
+msgid "Are you sure to delete the following category"
+msgstr "Wollen Sie folgende Kategorien wirklich l&oeschen?"
+
+#: classes/class.content_allocation_treeview.php:223
+#: classes/class.content_allocation_article.php:107
+msgid "Category"
+msgstr "Kategorie"
+
+#: classes/class.content_allocation_treeview.php:224
+msgid "Actions"
+msgstr "Aktionen"
diff --git a/locale/potfiles.txt b/locale/potfiles.txt
new file mode 100644
index 0000000..f28d5fa
--- /dev/null
+++ b/locale/potfiles.txt
@@ -0,0 +1,15 @@
+./includes/config.plugin.php
+./includes/include.left_bottom.php
+./includes/include.left_top.php
+./includes/include.contentallocation_article.php
+./includes/include.right_bottom.php
+./includes/functions.chains.php
+./templates/template.tree_structure.html
+./templates/template.tree_complexlist.html
+./templates/template.tree_article.html
+./classes/class.content_allocation_tree.php
+./classes/class.content_allocation_treeview.php
+./classes/class.content_allocation.php
+./classes/class.content_allocation_article.php
+./classes/class.content_allocation_complexlist.php
+./classes/class.content_allocation_selectbox.php
diff --git a/scripts/complexlist.js b/scripts/complexlist.js
new file mode 100644
index 0000000..21bfa4c
--- /dev/null
+++ b/scripts/complexlist.js
@@ -0,0 +1,133 @@
+/*
+ * ul2finder
+ * written by Christian Heilmann (http://icant.co.uk)
+ * turns the nested list with the ID "finder" into a dynamic list
+ * uses the CSS classes defined in the variables
+ */
+function ul2finder()
+{
+ // Define variables used and classes to be applied/removed
+ var i,uls,als,finder;
+ var parentClass='parent';
+ var showClass='shown';
+ var hideClass='hidden';
+ var openClass='open';
+
+ // check if our finder list exists, if not, stop all activities
+ finder=document.getElementById('finder');
+ if(!finder){return;}
+
+ // add the class domenabled to the body
+ cssjs('add',document.body,'domenabled')
+
+ // loop through all lists inside finder, position and hide them
+ // by applying the class hidden
+ uls=document.getElementById('finder').getElementsByTagName('ul');
+ for(i=0;i
+{HIDDENFIELDS}
+
+
+ {CATEGORY} |
+ |
+
+
+
+
+ {ITEMNAME} |
+ {CHECKBOX} |
+
+
+
+{DIV}
+
\ No newline at end of file
diff --git a/templates/template.tree_complexlist.html b/templates/template.tree_complexlist.html
new file mode 100644
index 0000000..27df466
--- /dev/null
+++ b/templates/template.tree_complexlist.html
@@ -0,0 +1,76 @@
+
+
+
diff --git a/templates/template.tree_structure.html b/templates/template.tree_structure.html
new file mode 100644
index 0000000..900142c
--- /dev/null
+++ b/templates/template.tree_structure.html
@@ -0,0 +1,13 @@
+
+
+ {CATEGORY} |
+ {ACTIONS} |
+
+
+
+
+ {ITEMNAME} |
+ {ACTION_CREATE} {ACTION_RENAME} {ACTION_ONOFFLINE} {ACTION_MOVE_UP} {ACTION_MOVE_DOWN} {ACTION_DELETE} |
+
+
+
\ No newline at end of file
diff --git a/xml/content_allocation.xml b/xml/content_allocation.xml
new file mode 100644
index 0000000..59f1e3b
--- /dev/null
+++ b/xml/content_allocation.xml
@@ -0,0 +1,12 @@
+
+
+ Content Allocation
+
+
+
+
+
+ Content Allocation
+
+
+
\ No newline at end of file
diff --git a/xml/lang_de_DE.xml b/xml/lang_de_DE.xml
new file mode 100644
index 0000000..eb8c1f2
--- /dev/null
+++ b/xml/lang_de_DE.xml
@@ -0,0 +1,11 @@
+
+
+
+
+
+
+ Content Allocation
+
+
+
+
\ No newline at end of file
diff --git a/xml/lang_en_EN.xml b/xml/lang_en_EN.xml
new file mode 100644
index 0000000..eb8c1f2
--- /dev/null
+++ b/xml/lang_en_EN.xml
@@ -0,0 +1,11 @@
+
+
+
+
+
+
+ Content Allocation
+
+
+
+
\ No newline at end of file
diff --git a/xml/lang_en_US.xml b/xml/lang_en_US.xml
new file mode 100644
index 0000000..eb8c1f2
--- /dev/null
+++ b/xml/lang_en_US.xml
@@ -0,0 +1,11 @@
+
+
+
+
+
+
+ Content Allocation
+
+
+
+
\ No newline at end of file