init files
Dieser Commit ist enthalten in:
		
							Ursprung
							
								
									46f679b77f
								
							
						
					
					
						Commit
						691c2ffaf0
					
				
					 29 geänderte Dateien mit 2654 neuen und 0 gelöschten Zeilen
				
			
		
							
								
								
									
										400
									
								
								classes/class.content_allocation.php
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										400
									
								
								classes/class.content_allocation.php
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,400 @@
 | 
			
		|||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Project: 
 | 
			
		||||
 * Contenido Content Management System
 | 
			
		||||
 * 
 | 
			
		||||
 * Description: 
 | 
			
		||||
 * Search articles by content allocation
 | 
			
		||||
 * 
 | 
			
		||||
 * Requirements: 
 | 
			
		||||
 * @con_php_req 5.0
 | 
			
		||||
 * 
 | 
			
		||||
 *
 | 
			
		||||
 * @package    Contenido Backend plugins
 | 
			
		||||
 * @version    0.7.8
 | 
			
		||||
 * @author     Marco Jahn
 | 
			
		||||
 * @copyright  four for business AG <www.4fb.de>
 | 
			
		||||
 * @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 "<!-- ";
 | 
			
		||||
            print $sql;
 | 
			
		||||
            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 "<!-- ";
 | 
			
		||||
            print $sql;
 | 
			
		||||
            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 "<!-- ";
 | 
			
		||||
            print $sql;
 | 
			
		||||
            print " -->";
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        return $sql;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										117
									
								
								classes/class.content_allocation_article.php
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										117
									
								
								classes/class.content_allocation_article.php
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,117 @@
 | 
			
		|||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Project: 
 | 
			
		||||
 * Contenido Content Management System
 | 
			
		||||
 * 
 | 
			
		||||
 * Description: 
 | 
			
		||||
 * Content Allocation article
 | 
			
		||||
 * 
 | 
			
		||||
 * Requirements: 
 | 
			
		||||
 * @con_php_req 5.0
 | 
			
		||||
 * 
 | 
			
		||||
 *
 | 
			
		||||
 * @package    Contenido Backend plugins
 | 
			
		||||
 * @version    0.2.1
 | 
			
		||||
 * @author     Marco Jahn
 | 
			
		||||
 * @copyright  four for business AG <www.4fb.de>
 | 
			
		||||
 * @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 = '<img src="' . $expandCollapseImg . '" border="0" style="vertical-align: middle;" width="11" height="11">';
 | 
			
		||||
 | 
			
		||||
            $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'] = '<input type="checkbox" name="allocation[]" value="' . $item_tmp['idpica_alloc'] . '" ' . $checked . ' />';
 | 
			
		||||
 | 
			
		||||
            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);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										114
									
								
								classes/class.content_allocation_complexlist.php
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										114
									
								
								classes/class.content_allocation_complexlist.php
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,114 @@
 | 
			
		|||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Project: 
 | 
			
		||||
 * Contenido Content Management System
 | 
			
		||||
 * 
 | 
			
		||||
 * Description: 
 | 
			
		||||
 * Content Allocation
 | 
			
		||||
 * 
 | 
			
		||||
 * Requirements: 
 | 
			
		||||
 * @con_php_req 5.0
 | 
			
		||||
 * 
 | 
			
		||||
 *
 | 
			
		||||
 * @package    Contenido Backend plugins
 | 
			
		||||
 * @version    0.2.1
 | 
			
		||||
 * @author     Marco Jahn
 | 
			
		||||
 * @copyright  four for business AG <www.4fb.de>
 | 
			
		||||
 * @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 = '<input type="checkbox" name="allocation[]" onClick="addToList(this);" ' . $checked . '" id="e' . $item_tmp['idpica_alloc'] . '" value="' . $item_tmp['idpica_alloc'] . '" />';
 | 
			
		||||
            $item = "\n<li style=\"border-bottom: 1px solid #B3B3B3\" baseClass=\"" . $bgcolor . "\" " . $li_closeElm . ">" . $checkbox . " " . $item_tmp['name'];
 | 
			
		||||
 | 
			
		||||
            $result .= $item;
 | 
			
		||||
 | 
			
		||||
            if ($item_tmp['children']) {
 | 
			
		||||
                $children = $this->_buildRenderTree($item_tmp['children']);
 | 
			
		||||
                $result .= "\n<ul>" . $children . "</li>";
 | 
			
		||||
            } else {
 | 
			
		||||
                $result .= "\n</li>";
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if ($oldIdSetter === true) {
 | 
			
		||||
            return "\n<ul id=\"finder\">" . $result . "\n</ul>";
 | 
			
		||||
        } else {
 | 
			
		||||
            return $result . "\n</ul>";
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    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;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										87
									
								
								classes/class.content_allocation_selectbox.php
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										87
									
								
								classes/class.content_allocation_selectbox.php
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,87 @@
 | 
			
		|||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Project: 
 | 
			
		||||
 * Contenido Content Management System
 | 
			
		||||
 * 
 | 
			
		||||
 * @package    Contenido Backend plugins
 | 
			
		||||
 * @version    0.2.1
 | 
			
		||||
 * @author     Marco Jahn
 | 
			
		||||
 * @copyright  four for business AG <www.4fb.de>
 | 
			
		||||
 * @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 .= '<option value="' . $item_tmp['idpica_alloc'] . '_' . $item_tmp['level'] . '">' . $spacer . $item_tmp['name'] . '</option>';
 | 
			
		||||
 | 
			
		||||
            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;
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										558
									
								
								classes/class.content_allocation_tree.php
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										558
									
								
								classes/class.content_allocation_tree.php
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,558 @@
 | 
			
		|||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Project: 
 | 
			
		||||
 * Contenido Content Management System
 | 
			
		||||
 * 
 | 
			
		||||
 * Description: 
 | 
			
		||||
 * Stores and handles content allocation management
 | 
			
		||||
 * 
 | 
			
		||||
 * Requirements: 
 | 
			
		||||
 * @con_php_req 5.0
 | 
			
		||||
 * 
 | 
			
		||||
 *
 | 
			
		||||
 * @package    Contenido Backend plugins
 | 
			
		||||
 * @version    0.10.1
 | 
			
		||||
 * @author     Marco Jahn
 | 
			
		||||
 * @copyright  four for business AG <www.4fb.de>
 | 
			
		||||
 * @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 "<!-- ";
 | 
			
		||||
            print $sql;
 | 
			
		||||
            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 "<!-- ";
 | 
			
		||||
                print_r($item);
 | 
			
		||||
                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;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										234
									
								
								classes/class.content_allocation_treeview.php
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										234
									
								
								classes/class.content_allocation_treeview.php
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,234 @@
 | 
			
		|||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Project: 
 | 
			
		||||
 * Contenido Content Management System
 | 
			
		||||
 * 
 | 
			
		||||
 * Description: 
 | 
			
		||||
 * Stores and handles content allocation management
 | 
			
		||||
 * 
 | 
			
		||||
 * Requirements: 
 | 
			
		||||
 * @con_php_req 5.0
 | 
			
		||||
 * 
 | 
			
		||||
 *
 | 
			
		||||
 * @package    Contenido Backend plugins
 | 
			
		||||
 * @version    0.2.3
 | 
			
		||||
 * @author     Marco Jahn
 | 
			
		||||
 * @copyright  four for business AG <www.4fb.de>
 | 
			
		||||
 * @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'] = '
 | 
			
		||||
					<table cellspacing="0" cellpaddin="0" border="0">
 | 
			
		||||
					<form name="rename" action="main.php" method="POST" onsubmit="return fieldCheck();">
 | 
			
		||||
					<input type="hidden" name="action" value="' . $action . '" />
 | 
			
		||||
					<input type="hidden" name="frame" value="' . $frame . '" />
 | 
			
		||||
					<input type="hidden" name="contenido" value="' . $sess->id . '" />
 | 
			
		||||
					<input type="hidden" name="area" value="' . $area . '" />
 | 
			
		||||
					<input type="hidden" name="step" value="storeRename" />
 | 
			
		||||
					<input type="hidden" name="treeItemPost[idpica_alloc]" value="' . $item_tmp['idpica_alloc'] . '" />
 | 
			
		||||
					<tr>
 | 
			
		||||
					<td class="text_medium"><input id="itemname" class="text_medium" type="text" name="treeItemPost[name]" value="' . $item_tmp['name'] . '"></td>
 | 
			
		||||
					<td> 
 | 
			
		||||
					<a href="main.php?action=' . $action . '&frame=' . $frame . '&area=' . $area . '&contenido=' . $sess->id . '"><img src="images/but_cancel.gif" border="0" /></a>
 | 
			
		||||
					<input type="image" src="images/but_ok.gif" />
 | 
			
		||||
					</td></tr>
 | 
			
		||||
					</form>
 | 
			
		||||
					</table>
 | 
			
		||||
					<script language="JavaScript">
 | 
			
		||||
						controller = document.getElementById("itemname");
 | 
			
		||||
						controller.focus();
 | 
			
		||||
						function fieldCheck() {
 | 
			
		||||
							if (controller.value == "") {
 | 
			
		||||
								alert("' . i18n("Please enter a category name", "content_allocation") . '");
 | 
			
		||||
								controller.focus();
 | 
			
		||||
								return false;
 | 
			
		||||
							}
 | 
			
		||||
						return true;
 | 
			
		||||
						}
 | 
			
		||||
					</script>';
 | 
			
		||||
            } 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 = '<a href="main.php?contenido=' . $sess->id . '&idart=' . $idart . '&action=' . $action . '&frame=' . $frame . '&area=' . $area . '&step=collapse&idpica_alloc=' . $item_tmp['idpica_alloc'] . '"><img src="' . $expandCollapseImg . '" border="0" style="vertical-align: middle; padding:4px;" width="7" height="7"></a>';
 | 
			
		||||
                } else {
 | 
			
		||||
                    $expandCollapseImg = 'images/spacer.gif';
 | 
			
		||||
                    $expandCollapse = '<img src="' . $expandCollapseImg . '" border="0" style="vertical-align: middle;" width="11" height="11">';
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                $item['ITEMNAME'] = $expandCollapse . ' ' . $item_tmp['name'];
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            $item['ITEMINDENT'] = $item_tmp['level'] * 15 + 3;
 | 
			
		||||
            $item['ACTION_CREATE'] = '<a href="main.php?contenido=' . $sess->id . '&action=' . $action . '&frame=' . $frame . '&area=' . $area . '&step=add&parentid=' . $item_tmp['idpica_alloc'] . '"><img src="images/folder_new.gif" border="0" title="' . i18n("New category", "content_allocation") . '" alt="' . i18n("New category", "content_allocation") . '" /></a>';
 | 
			
		||||
 | 
			
		||||
            $item['ACTION_RENAME'] = '<a href="main.php?contenido=' . $sess->id . '&action=' . $action . '&frame=' . $frame . '&area=' . $area . '&step=rename&idpica_alloc=' . $item_tmp['idpica_alloc'] . '"><img src="images/but_todo.gif" width="16" height="16" border="0" alt="' . i18n("Rename category", "content_allocation") . '" title="' . i18n("Rename category", "content_allocation") . '" /></a>';
 | 
			
		||||
            $item['ACTION_MOVE_UP'] = (count($result) >= 1) ? '<a href="main.php?contenido=' . $sess->id . '&action=' . $action . '&frame=' . $frame . '&area=' . $area . '&step=moveup&idpica_alloc=' . $item_tmp['idpica_alloc'] . '"><img src="images/folder_moveup.gif" border="0" alt="' . i18n("Move category up", "content_allocation") . '" title="' . i18n("Move category up", "content_allocation") . '" /></a>' : '<img src="images/spacer.gif" width="16" height="16" /></a>';
 | 
			
		||||
            $item['ACTION_MOVE_DOWN'] = (count($result) >= 1) ? '<img src="images/folder_movedown.gif" border="0" alt="' . i18n("Move category down", "content_allocation") . '" title="' . i18n("Move category down", "content_allocation") . '" />' : '<img src="images/spacer.gif" width="16" height="16" />';
 | 
			
		||||
            $item['ACTION_MOVE_DOWN'] = '';
 | 
			
		||||
 | 
			
		||||
            if ($item_tmp['online'] == 1) { // set offline
 | 
			
		||||
                $item['ACTION_ONOFFLINE'] = '<a href="main.php?contenido=' . $sess->id . '&action=' . $action . '&frame=' . $frame . '&area=' . $area . '&step=offline&idpica_alloc=' . $item_tmp['idpica_alloc'] . '""><img src="images/online.gif" alt="' . i18n("Set category offline", "content_allocation") . '" title="' . i18n("Set category offline", "content_allocation") . '"></a>';
 | 
			
		||||
            } else {
 | 
			
		||||
                $item['ACTION_ONOFFLINE'] = '<a href="main.php?contenido=' . $sess->id . '&action=' . $action . '&frame=' . $frame . '&area=' . $area . '&step=online&idpica_alloc=' . $item_tmp['idpica_alloc'] . '""><img src="images/offline.gif" alt="' . i18n("Set category online", "content_allocation") . '" title="' . i18n("Set category online", "content_allocation") . '"></a>';
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            if ($item_tmp['children']) {
 | 
			
		||||
                $item['ACTION_DELETE'] = '<img src="images/delete_inact.gif" border="0" alt="' . i18n("One or more subcategories exist, unable to delete", "content_allocation") . '" title="' . i18n("One or more subcategories exist, unable to delete", "content_allocation") . '">';
 | 
			
		||||
            } else {
 | 
			
		||||
                $item['ACTION_DELETE'] = '<a href="javascript://" onclick="box.confirm("' . i18n("Delete category", "content_allocation") . '", "' . i18n("Are you sure to delete the following category", "content_allocation") . ':<br><br><b>' . str_replace("'", "\'", $item_tmp['name']) . '</b>","deleteCategory(' . $item_tmp['idpica_alloc'] . ')");"><img src="images/delete.gif" border="0" alt="' . i18n("Delete category", "content_allocation") . '" title="' . i18n("Delete category", "content_allocation") . '"></a>';
 | 
			
		||||
            }
 | 
			
		||||
 | 
			
		||||
            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'] = '
 | 
			
		||||
					<table cellspacing="0" cellpaddin="0" border="0">
 | 
			
		||||
					<form name="create" action="main.php" method="POST" onsubmit="return fieldCheck();">
 | 
			
		||||
					<input type="hidden" name="action" value="' . $action . '" />
 | 
			
		||||
					<input type="hidden" name="frame" value="' . $frame . '" />
 | 
			
		||||
					<input type="hidden" name="contenido" value="' . $sess->id . '" />
 | 
			
		||||
					<input type="hidden" name="area" value="' . $area . '" />
 | 
			
		||||
					<input type="hidden" name="step" value="store" />
 | 
			
		||||
					<input type="hidden" name="treeItemPost[parentid]" value="' . $_GET['parentid'] . '" />
 | 
			
		||||
					<tr>
 | 
			
		||||
					<td class="text_medium"><input id="itemname" class="text_medium" type="text" name="treeItemPost[name]" value=""></td>
 | 
			
		||||
					<td> 
 | 
			
		||||
					<a href="main.php?action=' . $action . '&frame=' . $frame . '&area=' . $area . '&contenido=' . $sess->id . '"><img src="images/but_cancel.gif" border="0" /></a>
 | 
			
		||||
					<input type="image" src="images/but_ok.gif" />
 | 
			
		||||
					</td></tr>
 | 
			
		||||
					</form>
 | 
			
		||||
					</table>
 | 
			
		||||
					<script language="JavaScript">
 | 
			
		||||
						controller = document.getElementById("itemname");
 | 
			
		||||
						controller.focus();
 | 
			
		||||
						function fieldCheck() {
 | 
			
		||||
							if (controller.value == "") {
 | 
			
		||||
								alert("' . i18n("Please enter a category name", "content_allocation") . '");
 | 
			
		||||
								controller.focus();
 | 
			
		||||
								return false;
 | 
			
		||||
							}
 | 
			
		||||
						return true;
 | 
			
		||||
						}
 | 
			
		||||
					</script>';
 | 
			
		||||
                $item['ITEMINDENT'] = ($item_tmp['level'] + 1) * 15;
 | 
			
		||||
                $item['ACTION_CREATE'] = '<img src="images/spacer.gif" width="15" height="13" />';
 | 
			
		||||
                $item['ACTION_RENAME'] = '<img src="images/spacer.gif" width="23" height="14" />';
 | 
			
		||||
                $item['ACTION_MOVE_UP'] = '<img src="images/spacer.gif" width="15" height="13" />';
 | 
			
		||||
                $item['ACTION_MOVE_DOWN'] = '<img src="images/spacer.gif" width="15" height="13" />';
 | 
			
		||||
                $item['ACTION_MOVE_DOWN'] = '';
 | 
			
		||||
                $item['ACTION_DELETE'] = '<img src="images/spacer.gif" width="14" height="13" />';
 | 
			
		||||
                $item['ACTION_ONOFFLINE'] = '<img src="images/spacer.gif" width="11" height="12" />';
 | 
			
		||||
 | 
			
		||||
                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);
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										
											BIN
										
									
								
								images/arrow.gif
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										
											BIN
										
									
								
								images/arrow.gif
									
										
									
									
									
										Normale Datei
									
								
							
										
											Binäre Datei nicht angezeigt.
										
									
								
							| 
		 Nachher Breite: | Höhe: | Größe: 56 B  | 
							
								
								
									
										
											BIN
										
									
								
								images/call_contentallocation.gif
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										
											BIN
										
									
								
								images/call_contentallocation.gif
									
										
									
									
									
										Normale Datei
									
								
							
										
											Binäre Datei nicht angezeigt.
										
									
								
							| 
		 Nachher Breite: | Höhe: | Größe: 90 B  | 
							
								
								
									
										
											BIN
										
									
								
								images/normal.gif
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										
											BIN
										
									
								
								images/normal.gif
									
										
									
									
									
										Normale Datei
									
								
							
										
											Binäre Datei nicht angezeigt.
										
									
								
							| 
		 Nachher Breite: | Höhe: | Größe: 112 B  | 
							
								
								
									
										30
									
								
								includes/config.autoloader.php
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										30
									
								
								includes/config.autoloader.php
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,30 @@
 | 
			
		|||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * File:
 | 
			
		||||
 * config.autoloader.php
 | 
			
		||||
 *
 | 
			
		||||
 * @package Plugins
 | 
			
		||||
 * @subpackage Newsletter
 | 
			
		||||
 * @version $Rev: 128 $
 | 
			
		||||
 * @since 2.0
 | 
			
		||||
 * @author Ortwin Pinke <o.pinke@conlite.org>
 | 
			
		||||
 * @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'
 | 
			
		||||
);
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										65
									
								
								includes/config.plugin.php
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										65
									
								
								includes/config.plugin.php
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,65 @@
 | 
			
		|||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Project: 
 | 
			
		||||
 * Contenido Content Management System
 | 
			
		||||
 * 
 | 
			
		||||
 * Description: 
 | 
			
		||||
 * Config file for Content Allocation plugin
 | 
			
		||||
 * 
 | 
			
		||||
 * Requirements: 
 | 
			
		||||
 * @con_php_req 5.0
 | 
			
		||||
 * 
 | 
			
		||||
 *
 | 
			
		||||
 * @package    Contenido Backend plugins
 | 
			
		||||
 * @version    1.0.1
 | 
			
		||||
 * @author     unknown
 | 
			
		||||
 * @copyright  four for business AG <www.4fb.de>
 | 
			
		||||
 * @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");
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										67
									
								
								includes/functions.chains.php
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										67
									
								
								includes/functions.chains.php
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,67 @@
 | 
			
		|||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Project: 
 | 
			
		||||
 * Contenido Content Management System
 | 
			
		||||
 * 
 | 
			
		||||
 * Description: 
 | 
			
		||||
 * Chains for Content Allocation
 | 
			
		||||
 * 
 | 
			
		||||
 * Requirements: 
 | 
			
		||||
 * @con_php_req 5.0
 | 
			
		||||
 * 
 | 
			
		||||
 *
 | 
			
		||||
 * @package    Contenido Backend plugins
 | 
			
		||||
 * @version    1.0.1
 | 
			
		||||
 * @author     unknown
 | 
			
		||||
 * @copyright  four for business AG <www.4fb.de>
 | 
			
		||||
 * @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 '<a title="'.i18n("Content Allocation", "content_allocation").'" alt="'. i18n("Content Allocation", "content_allocation").'" href="'.$sess->url('main.php?area=con_contentallocation&action=con_edit&idart='.$idart.'&idartlang='.$idartlang.'&idcat='.$idcat.'&frame=4').'"><img src="plugins/content_allocation/images/call_contentallocation.gif"></a>';
 | 
			
		||||
 	
 | 
			
		||||
	} else {
 | 
			
		||||
		return "";	
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										132
									
								
								includes/include.contentallocation_article.php
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										132
									
								
								includes/include.contentallocation_article.php
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,132 @@
 | 
			
		|||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Project: 
 | 
			
		||||
 * Contenido Content Management System
 | 
			
		||||
 * 
 | 
			
		||||
 * Description: 
 | 
			
		||||
 * Content Allocation Articles
 | 
			
		||||
 * 
 | 
			
		||||
 * Requirements: 
 | 
			
		||||
 * @con_php_req 5.0
 | 
			
		||||
 * 
 | 
			
		||||
 *
 | 
			
		||||
 * @package    Contenido Backend plugins
 | 
			
		||||
 * @version    1.0.1
 | 
			
		||||
 * @author     unknown
 | 
			
		||||
 * @copyright  four for business AG <www.4fb.de>
 | 
			
		||||
 * @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 = "<div class=\"categorypath\">" . $catString . '/' . clHtmlSpecialChars($sArticleTitle) . "</div>";
 | 
			
		||||
 | 
			
		||||
// 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 = '<input type="hidden" name="action" value="storeallocation">
 | 
			
		||||
		<input type="hidden" name="idart" value="' . $idart . '">
 | 
			
		||||
		<input type="hidden" name="contenido" value="' . $sess->id . '">
 | 
			
		||||
		<input type="hidden" name="area" value="' . $area . '">
 | 
			
		||||
		<input type="hidden" name="frame" value="' . $frame . '">
 | 
			
		||||
		<input type="hidden" name="idcat" value="' . $idcat . '">';
 | 
			
		||||
    $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('<input type="image" src="images/but_ok.gif" />');
 | 
			
		||||
    $tpl->set('s', 'DIV', '<br>' . $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 = '<link rel="stylesheet" type="text/css" href="' . $cfg['pica']['style_complexlist'] . '"/>
 | 
			
		||||
	<script language="javascript" src="' . $cfg['pica']['script_complexlist'] . '"></script>';
 | 
			
		||||
    $oPage->addScript('style', $script);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
$oPage->setContent($sLocationString . $result . markSubMenuItem(5, true));
 | 
			
		||||
$oPage->render();
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										22
									
								
								includes/include.left_bottom.php
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										22
									
								
								includes/include.left_bottom.php
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,22 @@
 | 
			
		|||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 *
 | 
			
		||||
 * @package Plugins
 | 
			
		||||
 * @subpackage ContentAllocation
 | 
			
		||||
 * @version $Rev: 128 $
 | 
			
		||||
 * @since 2.0
 | 
			
		||||
 * @author Ortwin Pinke <o.pinke@conlite.org>
 | 
			
		||||
 * @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();
 | 
			
		||||
							
								
								
									
										39
									
								
								includes/include.left_top.php
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										39
									
								
								includes/include.left_top.php
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,39 @@
 | 
			
		|||
<?php
 | 
			
		||||
/**
 | 
			
		||||
 * Project: 
 | 
			
		||||
 * Contenido Content Management System
 | 
			
		||||
 * 
 | 
			
		||||
 * Description: 
 | 
			
		||||
 * Rendering left_top frame
 | 
			
		||||
 * 
 | 
			
		||||
 * Requirements: 
 | 
			
		||||
 * @con_php_req 5.0
 | 
			
		||||
 * 
 | 
			
		||||
 *
 | 
			
		||||
 * @package    Contenido Backend plugins
 | 
			
		||||
 * @version    1.0.1
 | 
			
		||||
 * @author     unknown
 | 
			
		||||
 * @copyright  four for business AG <www.4fb.de>
 | 
			
		||||
 * @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();
 | 
			
		||||
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										164
									
								
								includes/include.right_bottom.php
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										164
									
								
								includes/include.right_bottom.php
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,164 @@
 | 
			
		|||
<?php
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Project: 
 | 
			
		||||
 * Contenido Content Management System
 | 
			
		||||
 * 
 | 
			
		||||
 * Description: 
 | 
			
		||||
 * right_bottom frame for Content Allocation
 | 
			
		||||
 * 
 | 
			
		||||
 * Requirements: 
 | 
			
		||||
 * @con_php_req 5.0
 | 
			
		||||
 * 
 | 
			
		||||
 *
 | 
			
		||||
 * @package    Contenido Backend plugins
 | 
			
		||||
 * @version    1.0.1
 | 
			
		||||
 * @author     unknown
 | 
			
		||||
 * @copyright  four for business AG <www.4fb.de>
 | 
			
		||||
 * @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 = '<div style="width:410px;margin-bottom:20px;">';
 | 
			
		||||
    $sMessage = sprintf(i18n("New Category %s successfully stored!", "content_allocation"), $treeItem['name']);
 | 
			
		||||
    $notification->displayNotification("info", $sMessage);
 | 
			
		||||
    $pNotify .= '</div>';
 | 
			
		||||
    $oTree->storeItem($aPostTreeItem);
 | 
			
		||||
}
 | 
			
		||||
// rename item
 | 
			
		||||
if ($_POST['step'] == 'storeRename') {
 | 
			
		||||
    $pNotify = '<div style="width:410px;margin-bottom:20px;">';
 | 
			
		||||
    $sMessage = sprintf(i18n("Category %s successfully renamed!", "content_allocation"), $treeItem['name']);
 | 
			
		||||
    $notification->displayNotification("info", $sMessage);
 | 
			
		||||
    $pNotify .= '</div>';
 | 
			
		||||
    $oTree->storeItem($aPostTreeItem);
 | 
			
		||||
}
 | 
			
		||||
// rename item
 | 
			
		||||
if ($_GET['step'] == 'moveup') {
 | 
			
		||||
    $oTree->itemMoveUp($_GET['idpica_alloc']);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if ($_GET['step'] == 'deleteItem') { // delete item
 | 
			
		||||
    $pNotify = '<div style="width:410px;margin-bottom:20px;">';
 | 
			
		||||
    $sMessage = i18n("Category successfully deleted!", "content_allocation");
 | 
			
		||||
    $notification->displayNotification("info", $sMessage);
 | 
			
		||||
    $pNotify .= '</div>';
 | 
			
		||||
    $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 = '
 | 
			
		||||
		<table cellspacing="0" cellpaddin="0" border="0">
 | 
			
		||||
		<form name="create" action="main.php" method="POST" onsubmit="return fieldCheck();">
 | 
			
		||||
		<input type="hidden" name="action" value="' . $action . '" />
 | 
			
		||||
		<input type="hidden" name="frame" value="' . intval($frame) . '" />
 | 
			
		||||
		<input type="hidden" name="contenido" value="' . $sess->id . '" />
 | 
			
		||||
		<input type="hidden" name="area" value="' . $area . '" />
 | 
			
		||||
		<input type="hidden" name="step" value="store" />
 | 
			
		||||
		<input type="hidden" name="treeItemPost[parentid]" value="root" />
 | 
			
		||||
		<tr><td colspan="2" class="text_medium">' . i18n("Create new tree", "content_allocation") . '</td></tr>
 | 
			
		||||
		<tr>
 | 
			
		||||
			<td class="text_medium"><input id="itemname" class="text_medium" type="text" name="treeItemPost[name]" value=""></td>
 | 
			
		||||
			<td> <a href="main.php?action=' . $action . '&frame=' . $frame . '&area=' . $area . '&contenido=' . $sess->id . '"><img src="images/but_cancel.gif" border="0" /></a>
 | 
			
		||||
			<input type="image" src="images/but_ok.gif" /></td>
 | 
			
		||||
		</tr>
 | 
			
		||||
		</form>
 | 
			
		||||
		</table>
 | 
			
		||||
		<script language="JavaScript">
 | 
			
		||||
			controller = document.getElementById("itemname");
 | 
			
		||||
			controller.focus();
 | 
			
		||||
			function fieldCheck() {
 | 
			
		||||
				if (controller.value == "") {
 | 
			
		||||
					alert("' . i18n("Please enter a category name.", "content_allocation") . '");
 | 
			
		||||
					controller.focus();
 | 
			
		||||
					return false;
 | 
			
		||||
				}
 | 
			
		||||
                return true;
 | 
			
		||||
			}
 | 
			
		||||
		</script>';
 | 
			
		||||
    $oDiv->setContent($form);
 | 
			
		||||
    $sTemp = $oDiv->render();
 | 
			
		||||
} else {
 | 
			
		||||
    $newTree = '<a href="main.php?action=' . $action . '&step=createRoot&frame=' . $frame . '&area=' . $area . '&contenido=' . $sess->id . '"><img  src="images/folder_new.gif" border="0" style="vertical-align: middle; margin-right: 5px;">' . i18n("Create new tree", "content_allocation") . '</a><div style="height:10px"></div>';
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
$result = $oTree->renderTree(true);
 | 
			
		||||
 | 
			
		||||
if ($result === false) {
 | 
			
		||||
    $result = ' ';
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
$js = '
 | 
			
		||||
<script language="javascript">
 | 
			
		||||
/* Function for deleting categories*/
 | 
			
		||||
function deleteCategory(idpica_alloc) {
 | 
			
		||||
    var url = "main.php?area=' . $area . '&action=' . $action . '&step=deleteItem&idpica_alloc=" + idpica_alloc + "&frame=' . $frame . '&contenido=' . $sess->id . '";
 | 
			
		||||
    window.location.href = url;
 | 
			
		||||
}
 | 
			
		||||
</script>';
 | 
			
		||||
 | 
			
		||||
$oPage->addScript('deleteCategory', $js);
 | 
			
		||||
 | 
			
		||||
$oPage->setContent($pNotify . $newTree . $sTemp . '<br/>' . $result);
 | 
			
		||||
$oPage->render();
 | 
			
		||||
?>
 | 
			
		||||
							
								
								
									
										109
									
								
								locale/content_allocation.pot
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										109
									
								
								locale/content_allocation.pot
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -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 <EMAIL@ADDRESS>, 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 <EMAIL@ADDRESS>\n"
 | 
			
		||||
"Language-Team: LANGUAGE <LL@li.org>\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 ""
 | 
			
		||||
							
								
								
									
										
											BIN
										
									
								
								locale/de_DE/LC_MESSAGES/content_allocation.mo
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										
											BIN
										
									
								
								locale/de_DE/LC_MESSAGES/content_allocation.mo
									
										
									
									
									
										Normale Datei
									
								
							
										
											Binäre Datei nicht angezeigt.
										
									
								
							
							
								
								
									
										112
									
								
								locale/de_DE/LC_MESSAGES/content_allocation.po
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										112
									
								
								locale/de_DE/LC_MESSAGES/content_allocation.po
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -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 <EMAIL@ADDRESS>, 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 <translation@dceonline.de>\n"
 | 
			
		||||
"Language-Team: Ortwin Pinke <o.pinke@php-backoffice.de>\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"
 | 
			
		||||
							
								
								
									
										15
									
								
								locale/potfiles.txt
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										15
									
								
								locale/potfiles.txt
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -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
 | 
			
		||||
							
								
								
									
										133
									
								
								scripts/complexlist.js
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										133
									
								
								scripts/complexlist.js
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -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<uls.length;i++)
 | 
			
		||||
	{
 | 
			
		||||
		cssjs('add',uls[i],hideClass);
 | 
			
		||||
	}	
 | 
			
		||||
 | 
			
		||||
	// loop through all links of inside finder
 | 
			
		||||
	lis=document.getElementById('finder').getElementsByTagName('li');
 | 
			
		||||
	for(i=0;i<lis.length;i++)
 | 
			
		||||
	{
 | 
			
		||||
		var styleBgColor = lis[i].attributes["baseClass"].value
 | 
			
		||||
		
 | 
			
		||||
		// if the li containing the link has no nested list, skip this one
 | 
			
		||||
		if(!lis[i].getElementsByTagName('ul')[0])
 | 
			
		||||
		{
 | 
			
		||||
			//lis[i].className = "bright";
 | 
			
		||||
			//cssjs('add',lis[i],styleBgColor);
 | 
			
		||||
			lis[i].className = styleBgColor;
 | 
			
		||||
			continue;
 | 
			
		||||
		}
 | 
			
		||||
		
 | 
			
		||||
		var newa=document.createElement('a');
 | 
			
		||||
		newa.href='#';
 | 
			
		||||
		
 | 
			
		||||
		newa.appendChild(document.createTextNode(lis[i].firstChild.nextSibling.nodeValue));
 | 
			
		||||
		lis[i].replaceChild(newa,lis[i].firstChild.nextSibling);		
 | 
			
		||||
		// otherwise apply the parent class
 | 
			
		||||
		//alert(lis[i].innerHTML);
 | 
			
		||||
		cssjs('add',newa,styleBgColor);
 | 
			
		||||
		
 | 
			
		||||
		// if the user clicks on the link
 | 
			
		||||
		lis[i].getElementsByTagName('a')[0].onclick=function()
 | 
			
		||||
		{
 | 
			
		||||
			// loop through all lists inside finder
 | 
			
		||||
			for(var i=0;i<uls.length;i++)
 | 
			
		||||
			{
 | 
			
		||||
				// avoid the list connected to this link
 | 
			
		||||
				var found=false;
 | 
			
		||||
				for(j=0;j<uls[i].getElementsByTagName('ul').length;j++)
 | 
			
		||||
				{
 | 
			
		||||
					if(uls[i].getElementsByTagName('ul')[j] == 		
 | 
			
		||||
						this.parentNode.getElementsByTagName('ul')[0])
 | 
			
		||||
					{
 | 
			
		||||
						found=true;
 | 
			
		||||
						break;
 | 
			
		||||
					}
 | 
			
		||||
				}
 | 
			
		||||
				// and hide all others
 | 
			
		||||
				if(!found)
 | 
			
		||||
				{
 | 
			
		||||
					cssjs('add',uls[i],hideClass)
 | 
			
		||||
					cssjs('remove',uls[i],showClass)
 | 
			
		||||
					cssjs('remove',uls[i].parentNode.getElementsByTagName('a')[0],openClass)
 | 
			
		||||
					cssjs('add',uls[i].parentNode.getElementsByTagName('a')[0],parentClass)
 | 
			
		||||
					// remove all old "open" elements
 | 
			
		||||
					styleColor = uls[i].parentNode.getElementsByTagName('a')[0].style.backgroundColor;
 | 
			
		||||
					if (styleColor == "#E2E2E2" || styleColor == "rgb(226, 226, 226)") {
 | 
			
		||||
						uls[i].parentNode.getElementsByTagName('a')[0].style.backgroundColor = '';
 | 
			
		||||
					}
 | 
			
		||||
				}
 | 
			
		||||
			}
 | 
			
		||||
			
 | 
			
		||||
			// change the current link from parent to open 	
 | 
			
		||||
			cssjs('swap',this,parentClass,openClass)
 | 
			
		||||
			this.style.backgroundColor = "#E2E2E2";
 | 
			
		||||
			
 | 
			
		||||
			// show the current nested list 
 | 
			
		||||
			cssjs('add',this.parentNode.getElementsByTagName('ul')[0],showClass)
 | 
			
		||||
 | 
			
		||||
			// don't follow the real HREF of the link
 | 
			
		||||
			return false;
 | 
			
		||||
		}
 | 
			
		||||
	}	
 | 
			
		||||
	/*
 | 
			
		||||
	 * cssjs
 | 
			
		||||
	 * written by Christian Heilmann (http://icant.co.uk)
 | 
			
		||||
	 * eases the dynamic application of CSS classes via DOM
 | 
			
		||||
	 * parameters: action a, object o and class names c1 and c2 (c2 optional)
 | 
			
		||||
	 * actions: swap exchanges c1 and c2 in object o
 | 
			
		||||
	 *			add adds class c1 to object o
 | 
			
		||||
	 *			remove removes class c1 from object o
 | 
			
		||||
	 *			check tests if class c1 is applied to object o
 | 
			
		||||
	 * example:	cssjs('swap',document.getElementById('foo'),'bar','baz');
 | 
			
		||||
	 */
 | 
			
		||||
	function cssjs(a,o,c1,c2)
 | 
			
		||||
	{
 | 
			
		||||
		switch (a){
 | 
			
		||||
			case 'swap':
 | 
			
		||||
				o.className=!cssjs('check',o,c1)?o.className.replace(c2,c1):o.className.replace(c1,c2);
 | 
			
		||||
			break;
 | 
			
		||||
			case 'add':
 | 
			
		||||
				if(!cssjs('check',o,c1)){o.className+=o.className?' '+c1:c1;}
 | 
			
		||||
			break;
 | 
			
		||||
			case 'remove':
 | 
			
		||||
				var rep=o.className.match(' '+c1)?' '+c1:c1;
 | 
			
		||||
				o.className=o.className.replace(rep,'');
 | 
			
		||||
			break;
 | 
			
		||||
			case 'check':
 | 
			
		||||
				return new RegExp('\\b'+c1+'\\b').test(o.className)
 | 
			
		||||
			break;
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Check if the browser supports DOM, and start the script if it does.
 | 
			
		||||
if(document.getElementById && document.createTextNode)
 | 
			
		||||
{
 | 
			
		||||
	window.onload=ul2finder;
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										105
									
								
								style/complexlist.css
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										105
									
								
								style/complexlist.css
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,105 @@
 | 
			
		|||
.domenabled #finderparent {
 | 
			
		||||
	border: 0px solid #000;
 | 
			
		||||
	position: relative;
 | 
			
		||||
	/*min-height: 250px;*/
 | 
			
		||||
	height: 360px;
 | 
			
		||||
	width: 730px;
 | 
			
		||||
	overflow: auto;
 | 
			
		||||
	margin-bottom: 10px;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
.domenabled #finder {
 | 
			
		||||
	/*position:absolute;
 | 
			
		||||
	top:1em;
 | 
			
		||||
	left:1em;*/
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
.domenabled ul#finder,
 | 
			
		||||
.domenabled ul#finder li,
 | 
			
		||||
.domenabled ul#finder ul {
 | 
			
		||||
	width: 180px;
 | 
			
		||||
	list-style-type: none;
 | 
			
		||||
	margin: 0;
 | 
			
		||||
	padding: 0;
 | 
			
		||||
	line-height: 20px;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
.domenabled ul#finder ul.hidden {
 | 
			
		||||
	top: 0px;
 | 
			
		||||
	left: -1px;
 | 
			
		||||
	position: absolute;
 | 
			
		||||
	/*display: none;*/
 | 
			
		||||
	visibility: hidden;
 | 
			
		||||
	border-left: 5px #fff solid;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
.domenabled ul#finder ul.shown {
 | 
			
		||||
	top: 0px;
 | 
			
		||||
	left: 185px;
 | 
			
		||||
	position: absolute;
 | 
			
		||||
	float: left;
 | 
			
		||||
	/*border-left: 5px #fff solid;*/
 | 
			
		||||
	/*display: block;*/
 | 
			
		||||
	visibility: visible;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
.domenabled #finder a.open {
 | 
			
		||||
	background: url(../images/arrow.gif) no-repeat #CCCCCC 140px 50%;
 | 
			
		||||
	padding-right: 16px;
 | 
			
		||||
	padding-left: 0px;
 | 
			
		||||
	display: block;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
.domenabled ul#finder li a {
 | 
			
		||||
	color: #000;
 | 
			
		||||
	background: url(../images/normal.gif) no-repeat transparent 0 50%;
 | 
			
		||||
	/*adding-left: 16px;*/
 | 
			
		||||
	text-decoration: none;
 | 
			
		||||
	padding-right: 16px;
 | 
			
		||||
	padding-left: 0px;
 | 
			
		||||
	display: block;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
.domenabled ul#finder li a.dark {
 | 
			
		||||
	background: url(../images/arrow.gif) no-repeat #fff 170px 50%;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
.domenabled ul#finder li.dark,
 | 
			
		||||
.domenabled ul#finder li a.dark {
 | 
			
		||||
	background-color: #E2E2E2;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
.domenabled ul#finder li a.bright {
 | 
			
		||||
	background: url(../images/arrow.gif) no-repeat #ddd 170px 50%;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
.domenabled ul#finder li.bright,
 | 
			
		||||
.domenabled ul#finder li a.bright {
 | 
			
		||||
	background-color: #F4F4F7;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
.domenabled ul#finder li,
 | 
			
		||||
.domenabled ul#finder ul.hidden li,
 | 
			
		||||
.domenabled ul#finder ul.shown li {
 | 
			
		||||
	border: 1px #B3B3B3 solid;
 | 
			
		||||
	border-bottom: 0px;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
.domenabled ul#finder input {
 | 
			
		||||
	float: left;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#choosenList {
 | 
			
		||||
	border: 1px #B3B3B3 solid;
 | 
			
		||||
	background-color: #E2E2E2;
 | 
			
		||||
	width: 730px;
 | 
			
		||||
	padding: 5px;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#choosenList ul {
 | 
			
		||||
	margin: 0;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#choosenList li {
 | 
			
		||||
	list-style-type: square;
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										17
									
								
								templates/template.tree_article.html
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										17
									
								
								templates/template.tree_article.html
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,17 @@
 | 
			
		|||
<form method="post" action="main.php" name="contentallocation">
 | 
			
		||||
{HIDDENFIELDS}
 | 
			
		||||
<table border="0" cellpadding="2" cellspacing="0" width="500" style="border:0px; border-left:1px; border-bottom: 1px;border-color: #B3B3B3; border-style: solid;">
 | 
			
		||||
	<tr class="text_medium" style="font-weight:bold; background-color: #E2E2E2;">
 | 
			
		||||
		<td width="450" class="textg_medium" style="border: 0px; border-top:1px; border-right:1px; border-color: #B3B3B3; border-style: solid">{CATEGORY}</td>
 | 
			
		||||
		<td width="50" class="textg_medium" style="border: 0px; border-top:1px; border-right:1px; border-color: #B3B3B3; border-style: solid"> </td>
 | 
			
		||||
	</tr>
 | 
			
		||||
 | 
			
		||||
	<!-- BEGIN:BLOCK -->
 | 
			
		||||
	<tr style="background-color: {BACKGROUND_COLOR};" onmouseover="row.over(this)" onmouseout="row.out(this)" onclick="row.click(this)">
 | 
			
		||||
		<td style="border: 0px; border-top:1px; border-right:1px;border-color: #B3B3B3; border-style: solid; padding-left: {ITEMINDENT} ;">{ITEMNAME}</td>
 | 
			
		||||
		<td style="border: 0px; border-top:1px; border-right:1px; border-color: #B3B3B3; border-style: solid;">{CHECKBOX}</td>
 | 
			
		||||
	</tr>
 | 
			
		||||
	<!-- END:BLOCK -->
 | 
			
		||||
</table>
 | 
			
		||||
{DIV}
 | 
			
		||||
</form>
 | 
			
		||||
							
								
								
									
										76
									
								
								templates/template.tree_complexlist.html
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										76
									
								
								templates/template.tree_complexlist.html
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,76 @@
 | 
			
		|||
<form method="post" action="main.php" name="contentallocation">
 | 
			
		||||
{HIDDENFIELDS}
 | 
			
		||||
<div id="finderparent">
 | 
			
		||||
	{TREE}
 | 
			
		||||
</div>
 | 
			
		||||
<div id="choosenList">
 | 
			
		||||
	<ul id="choosenValues">
 | 
			
		||||
	</ul>
 | 
			
		||||
	<br /><a href="javascript:removeAll();">{REMOVE_ALL}</a>
 | 
			
		||||
</div>
 | 
			
		||||
{DIV}
 | 
			
		||||
</form>
 | 
			
		||||
 | 
			
		||||
<script language="javascript">
 | 
			
		||||
function addToList(obj) {
 | 
			
		||||
	var list = document.getElementById("choosenValues");
 | 
			
		||||
	var elmId = obj.attributes["id"].value;
 | 
			
		||||
	elmId = elmId.replace(/e/, "");
 | 
			
		||||
 | 
			
		||||
	if (obj.checked == false) {
 | 
			
		||||
		removeFromList(elmId);
 | 
			
		||||
	} else {
 | 
			
		||||
		if (obj.nextSibling.innerHTML == undefined) {
 | 
			
		||||
			text = obj.nextSibling.data;
 | 
			
		||||
		} else {
 | 
			
		||||
			text = obj.nextSibling.innerHTML;	
 | 
			
		||||
		}
 | 
			
		||||
		
 | 
			
		||||
		var removeLink = "<a href=\"javascript:removeFromList("+elmId+")\">[{REMOVE}]</a> " + text;
 | 
			
		||||
	
 | 
			
		||||
		listelm = document.createElement("LI");
 | 
			
		||||
		listelm.innerHTML = removeLink;
 | 
			
		||||
		listelm.id = "rl" + elmId;
 | 
			
		||||
		
 | 
			
		||||
		//list.appendChild(listelm);
 | 
			
		||||
		list.appendChild(listelm);
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function removeFromList (id) {
 | 
			
		||||
	var list = document.getElementById("choosenValues");
 | 
			
		||||
	var remElm = document.getElementById("rl" + id);
 | 
			
		||||
 | 
			
		||||
	if (remElm != null) {
 | 
			
		||||
		list.removeChild(remElm);
 | 
			
		||||
		var uncheckElm = document.getElementById("e" + id);
 | 
			
		||||
		uncheckElm.checked = false;
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function removeAll () {
 | 
			
		||||
	var list = document.getElementById("choosenValues");
 | 
			
		||||
 | 
			
		||||
	formElms = document.forms["contentallocation"].elements;
 | 
			
		||||
	
 | 
			
		||||
	for (i = 0; i < formElms.length; i++) {
 | 
			
		||||
		if (formElms[i].type == "checkbox") {
 | 
			
		||||
			formElms[i].checked = false;
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
	list.innerHTML = '';
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
{ARRAY_CHECKED_BOXES}
 | 
			
		||||
 | 
			
		||||
function listAllCheckedBoxes () {
 | 
			
		||||
	if (checkedBoxes.length == 0) return false;
 | 
			
		||||
	
 | 
			
		||||
	for (i = 0; i < checkedBoxes.length; i++) {
 | 
			
		||||
		obj = document.getElementById("e" + checkedBoxes[i]);
 | 
			
		||||
		addToList(obj);
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
listAllCheckedBoxes();
 | 
			
		||||
 | 
			
		||||
</script>
 | 
			
		||||
							
								
								
									
										13
									
								
								templates/template.tree_structure.html
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										13
									
								
								templates/template.tree_structure.html
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,13 @@
 | 
			
		|||
<table border="0" cellpadding="2" cellspacing="0" width="800" style="border:0px; border-left:1px; border-bottom: 1px;border-color: #B3B3B3; border-style: solid;">
 | 
			
		||||
	<tr class="text_medium" style="font-weight:bold; background-color: #E2E2E2;">
 | 
			
		||||
		<td width="600" class="textg_medium" style="border: 0px; border-top:1px; border-right:1px; border-color: #B3B3B3; border-style: solid">{CATEGORY}</td>
 | 
			
		||||
		<td width="200" class="textg_medium" style="border: 0px; border-top:1px; border-right:1px; border-color: #B3B3B3; border-style: solid">{ACTIONS}</td>
 | 
			
		||||
	</tr>
 | 
			
		||||
 | 
			
		||||
	<!-- BEGIN:BLOCK -->
 | 
			
		||||
	<tr style="background-color: {BACKGROUND_COLOR};" onmouseover="row.over(this)" onmouseout="row.out(this)" onclick="row.click(this)">
 | 
			
		||||
		<td style="border: 0px; border-top:0px; border-right:1px;border-color: #B3B3B3; border-style: solid; padding-left: {ITEMINDENT} ;">{ITEMNAME}</td>
 | 
			
		||||
		<td style="border: 0px; border-top:0px; border-right:1px; border-color: #B3B3B3; border-style: solid;">{ACTION_CREATE} {ACTION_RENAME} {ACTION_ONOFFLINE} {ACTION_MOVE_UP} {ACTION_MOVE_DOWN} {ACTION_DELETE}</td>
 | 
			
		||||
	</tr>
 | 
			
		||||
	<!-- END:BLOCK -->
 | 
			
		||||
</table>
 | 
			
		||||
							
								
								
									
										12
									
								
								xml/content_allocation.xml
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										12
									
								
								xml/content_allocation.xml
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,12 @@
 | 
			
		|||
<xml version="1.0" encoding="UTF-8">
 | 
			
		||||
<plugin>
 | 
			
		||||
	<main>Content Allocation</main>
 | 
			
		||||
    <content_allocation></content_allocation>
 | 
			
		||||
    
 | 
			
		||||
    
 | 
			
		||||
    <contenido>
 | 
			
		||||
    	<article>
 | 
			
		||||
    		<content_allocation>Content Allocation</content_allocation>
 | 
			
		||||
    	</article>
 | 
			
		||||
    </contenido>
 | 
			
		||||
</plugin>
 | 
			
		||||
							
								
								
									
										11
									
								
								xml/lang_de_DE.xml
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										11
									
								
								xml/lang_de_DE.xml
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,11 @@
 | 
			
		|||
<?xml version="1.0" encoding="ISO-8859-1"?>
 | 
			
		||||
<!-- Contenido XML language file -->
 | 
			
		||||
<language>
 | 
			
		||||
	<navigation>
 | 
			
		||||
		<extra>
 | 
			
		||||
			<content_allocation>
 | 
			
		||||
				<main>Content Allocation</main>
 | 
			
		||||
			</content_allocation>
 | 
			
		||||
		</extra>
 | 
			
		||||
	</navigation>
 | 
			
		||||
</language>
 | 
			
		||||
							
								
								
									
										11
									
								
								xml/lang_en_EN.xml
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										11
									
								
								xml/lang_en_EN.xml
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,11 @@
 | 
			
		|||
<?xml version="1.0" encoding="ISO-8859-1"?>
 | 
			
		||||
<!-- Contenido XML language file -->
 | 
			
		||||
<language>
 | 
			
		||||
	<navigation>
 | 
			
		||||
		<extra>
 | 
			
		||||
			<content_allocation>
 | 
			
		||||
				<main>Content Allocation</main>
 | 
			
		||||
			</content_allocation>
 | 
			
		||||
		</extra>
 | 
			
		||||
	</navigation>
 | 
			
		||||
</language>
 | 
			
		||||
							
								
								
									
										11
									
								
								xml/lang_en_US.xml
									
										
									
									
									
										Normale Datei
									
								
							
							
						
						
									
										11
									
								
								xml/lang_en_US.xml
									
										
									
									
									
										Normale Datei
									
								
							| 
						 | 
				
			
			@ -0,0 +1,11 @@
 | 
			
		|||
<?xml version="1.0" encoding="ISO-8859-1"?>
 | 
			
		||||
<!-- Contenido XML language file -->
 | 
			
		||||
<language>
 | 
			
		||||
	<navigation>
 | 
			
		||||
		<extra>
 | 
			
		||||
			<content_allocation>
 | 
			
		||||
				<main>Content Allocation</main>
 | 
			
		||||
			</content_allocation>
 | 
			
		||||
		</extra>
 | 
			
		||||
	</navigation>
 | 
			
		||||
</language>
 | 
			
		||||
		Laden …
	
	Tabelle hinzufügen
		
		In neuem Issue referenzieren