Location: PHPKode > projects > Entier Studio > entierstudio/studio/classes/datas/data.RepositoryCoreElementRuledPropertySet.php
<?php
/**
 * Entier Studio
 *
 * LICENSE
 *
 *	Copyright 2006 Entier Studio team.
 *
 *	Licensed under the Apache License, Version 2.0 (the "License");
 *	you may not use this file except in compliance with the License.
 *	You may obtain a copy of the License at
 *
 *		http://www.apache.org/licenses/LICENSE-2.0
 *
 *	Unless required by applicable law or agreed to in writing, software
 *	distributed under the License is distributed on an "AS IS" BASIS,
 *	WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *	See the License for the specific language governing permissions and
 *	limitations under the License.
 *
 * @package    entier.studio
 * @copyright  Copyright (c) 2006 Entier Studio team. All rights reserved.
 * @version	   $Id: data.RepositoryCoreElementRuledPropertySet.php 81 2008-01-17 23:08:21Z yannromefort $
 */
//-----------------------------------------------------------------------------
//	namespace
if (!defined("DefRepositoryCoreElementRuledPropertySet")) {
    //-------------------------------------------------------------------------
    //	Define
    define("DefRepositoryCoreElementRuledPropertySet", "1");
    //-------------------------------------------------------------------------
    //	Class
    class RepositoryCoreElementRuledPropertySet extends RepositoryCoreElementPropertySet {
        //---------------------------------------------------------------------
        //	Constructor
        /*
        *
        * @param	integer	DictionaryPropertyValue		$DICPVALPKID
        * @param	integer	RepositoryCoreElement		$REPCELEPKID
        * @param	integer	RepositoryCoreElementType	$REPCELTPKID
        *
        */
        function RepositoryCoreElementRuledPropertySet($DICPVALPKID = 0, $REPCELEPKID = 0, $REPCELTPKID = 0) {
            //
            $this->m_tableSet[PRIMARYKEY] = "tbl_repository_core_element_property";
            $this->m_indexSet[PRIMARYKEY] = "REPCEPRPKID";
            $this->m_indexSet[FOREIGNKEY] = array(
                "REPCELTPKID",
                "DICPROPPKID"
            );
            $this->m_indexSet[NATURALKEY] = "DICPROPNAME";
            //
            $this->m_querySet["DICPVALPKID"] = $DICPVALPKID;
            $this->m_querySet["REPCELEPKID"] = $REPCELEPKID;
            $this->m_querySet["REPCELTPKID"] = $REPCELTPKID;
        }
        //---------------------------------------------------------------------
        //	Methods
        /*
        *
        * @access	protected
        *
        * @param	integer	index type
        * @param	integer	order type
        * @param	string	order mode
        *
        */
        function getSelectQuery($indexType = FOREIGNKEY, $orderType = NATURALKEY, $orderMode = "") {
            //
            switch ($indexType) {
                case REFLECTKEY:
                    /*
                    *
                    *	SELECT
                    *				tbl_dictionary_property_rule as t1
                    *			<-> tbl_dictionary_property	as t2
                    *			<-> tbl_repository_core_element_property as t3
                    *			<-  tbl_repository_core_element_property_value
                    *	ON
                    *			DICPVALPKID & REPCELEPKID
                    *
                    *   @see class RepositoryCoreElementPropertySet
                    *
                    */
                    $index1 = $this->m_querySet["DICPVALPKID"];
                    $index2 = $this->m_querySet["REPCELEPKID"];
                    $index3 = $this->m_querySet["REPCELTPKID"];
                    if (($index1 != 0) && ($index2 != 0) && ($index3 != 0)) {
                        //
                        $selectSQL = "SELECT 
											t2.DICPROPPKID,
											t2.DICPROPNAME,
											t2.DICPROPCODE, 
											t2.DICPROPTYPE, 
											t2.DICPTYPPKID, 
											t3.REPCEPRPKID, 
											t4.REPCEPVPKID, 
											t4.REPCELEPKID, 
											t4.DICPVALPKID, 
											t4.REPCEPVDATA 
										FROM 
											tbl_dictionary_property_rule as t1, 
											tbl_dictionary_property as t2, 
											tbl_repository_core_element_property as t3 
										LEFT JOIN 
											tbl_repository_core_element_property_value as t4 
										ON 
											t3.REPCEPRPKID=t4.REPCEPRPKID 
										AND 
											t4.REPCEPVSTAT>0 
										AND 
											t4.REPCELEPKID=$index2 
										WHERE 
											t1.DICPVALPKID=$index1 
										AND 
											t1.DICPRULTYPE=1
										AND 
											t1.DICPRULSTAT>0 
										AND 
											t1.DICPROPPKID= t2.DICPROPPKID 
										AND 
											t2.DICPROPSTAT>0 
										AND 
											t2.DICPROPPKID=t3.DICPROPPKID
										AND
											t3.REPCELTPKID=$index3 
										AND 
											t3.REPCEPRSTAT>0";
                        //
                        switch ($orderType) {
                            case PRIMARYKEY:
                                return ($selectSQL . " ORDER BY t3.REPCEPRPKID $orderMode");
                                //
                                
                            break;
                            case NATURALKEY:
                                return ($selectSQL . " ORDER BY t2.DICPROPNAME $orderMode");
                                //
                                
                            break;
                            default:
                                return ($selectSQL . " ORDER BY t2.DICPROPNAME");
                                //
                                
                            break;
                        }
                    }
                    //
                    
                break;
            }
            //
            return ("");
        }
    };
    //	Class
    //-------------------------------------------------------------------------
    
}
//	namespace
//-----------------------------------------------------------------------------
?>
Return current item: Entier Studio