Example #1
0
 public static function doSelectFiltered(Criteria $criteria, $con = null)
 {
     $dept = sfContext::getInstance()->getUser()->getAttribute('department', null, 'bo');
     $depts = $dept->getChildRecurs(array());
     $criteria->add(VDepartmentPeer::ID, $depts, Criteria::IN);
     $tmp_depts = VDepartmentPeer::doSelect($criteria);
     $depts = array();
     foreach ($tmp_depts as $key => $val) {
         $pi = $val->getParentalIndex();
         $prefix = '';
         for ($i = 0; $i < $val->level - 1; $i++) {
             $prefix .= ParamsPeer::retrieveByCode('tree_node_mark')->getValue();
         }
         $val->setName($prefix . $val->getName());
         $val->setCode($prefix . $val->getCode());
         $depts[$pi] = $val;
     }
     ksort($depts);
     $result = array();
     foreach ($depts as $r) {
         $result[] = $r;
     }
     return $result;
 }
Example #2
0
 public function filter($c, $filters)
 {
     $filters_key = array_keys($filters);
     foreach ($filters_key as $key) {
         $value = $filters[$key];
         if ($value == '' || $value == null) {
             continue;
         }
         if ($key == 'writer_name') {
             $column = VOpacDigitalPeer::getTableMap()->getColumn('WRITER_NAME');
         } elseif ($key == 'department_id') {
             if ($filters[$key] == 1) {
                 $c->addJoin(VOpacDigitalPeer::CATALOG_ID, CatalogPeer::ID);
                 $c->addJoin(DepartmentPeer::ID, VOpacDigitalPeer::DEPARTMENT_ID);
                 $column = DepartmentPeer::getTableMap()->getColumn('ID');
             } else {
                 $c->addJoin(VOpacDigitalPeer::CATALOG_ID, CatalogPeer::ID);
                 $c->addJoin(DepartmentPeer::ID, VOpacDigitalPeer::DEPARTMENT_ID);
                 $c->addJoin(VDepartmentPeer::ID, DepartmentPeer::PARENT);
                 $column = VDepartmentPeer::getTableMap()->getColumn('ID');
             }
         } elseif ($key == 'cat_category_id') {
             $c->addJoin(VOpacDigitalPeer::CATALOG_ID, CatalogPeer::ID);
             $c->addJoin(CatCategoryPeer::ID, VOpacDigitalPeer::CAT_CATEGORY_ID);
             $column = CatCategoryPeer::getTableMap()->getColumn('ID');
         } elseif ($key == 'publisher_name') {
             $column = VOpacDigitalPeer::getTableMap()->getColumn('PUBLISHER_NAME');
         } elseif ($key == 'title') {
             $column = VOpacDigitalPeer::getTableMap()->getColumn('TITLE');
         } elseif ($key == 'keyword') {
             $c->addJoin(CatalogPeer::ID, VOpacDigitalPeer::CATALOG_ID);
             $column = CatalogPeer::getTableMap()->getColumn('SEARCH_KEYWORDS');
         } elseif ($key == 'synopsis') {
             $c->addJoin(CatalogPeer::ID, VOpacDigitalPeer::CATALOG_ID);
             $column = CatalogPeer::getTableMap()->getColumn('SYNOPSIS');
         } elseif ($key == 'published_location') {
             $column = VOpacDigitalPeer::getTableMap()->getColumn('PUBLISHED_LOCATION');
         } elseif ($key == 'published_year') {
             $column = VOpacDigitalPeer::getTableMap()->getColumn('PUBLISHED_YEAR');
         }
         $name = $column->getFullyQualifiedName();
         $creoleType = $column->getCreoleType();
         if ($creoleType == CreoleTypes::TIMESTAMP) {
             $from = $value['from'];
             $to = $value['to'];
             if ($from != '' && $from != null) {
                 $c->add($name, $from, Criteria::GREATER_EQUAL);
             }
             if ($to != '' && $to != null) {
                 $c->add($name, $to, Criteria::LESS_EQUAL);
             }
         } else {
             if ($creoleType == CreoleTypes::INTEGER || $creoleType == CreoleTypes::BIGINT) {
                 $c->add($name, $value, Criteria::EQUAL);
             } else {
                 if ($creoleType == CreoleTypes::VARCHAR) {
                     $c->add($name, "%{$value}%", Criteria::LIKE);
                 } else {
                     if ($creoleType == CreoleTypes::NUMERIC) {
                         $c->add($name, $value, Criteria::EQUAL);
                     }
                 }
             }
         }
     }
 }
Example #3
0
 public function fromArray($arr, $keyType = BasePeer::TYPE_PHPNAME)
 {
     $keys = VDepartmentPeer::getFieldNames($keyType);
     if (array_key_exists($keys[0], $arr)) {
         $this->setId($arr[$keys[0]]);
     }
     if (array_key_exists($keys[1], $arr)) {
         $this->setCode($arr[$keys[1]]);
     }
     if (array_key_exists($keys[2], $arr)) {
         $this->setNumCode($arr[$keys[2]]);
     }
     if (array_key_exists($keys[3], $arr)) {
         $this->setName($arr[$keys[3]]);
     }
     if (array_key_exists($keys[4], $arr)) {
         $this->setParent($arr[$keys[4]]);
     }
     if (array_key_exists($keys[5], $arr)) {
         $this->setDescription($arr[$keys[5]]);
     }
 }
Example #4
0
 public static function retrieveByPKs($pks, $con = null)
 {
     if ($con === null) {
         $con = Propel::getConnection(self::DATABASE_NAME);
     }
     $objs = null;
     if (empty($pks)) {
         $objs = array();
     } else {
         $criteria = new Criteria();
         $criteria->add(VDepartmentPeer::ID, $pks, Criteria::IN);
         $objs = VDepartmentPeer::doSelect($criteria, $con);
     }
     return $objs;
 }
Example #5
0
 public function filterPerSource($c, $filters)
 {
     $filters_key = array_keys($filters);
     foreach ($filters_key as $key) {
         $value = $filters[$key];
         if ($value == '' || $value == null) {
             continue;
         }
         if ($key == 'writer_id') {
             $c->addJoin(VCatalogPerSourcePeer::CATALOG_ID, CatalogPeer::ID);
             $c->addJoin(CatalogWriterPeer::CATALOG_ID, CatalogPeer::ID);
             $column = CatalogWriterPeer::getTableMap()->getColumn('WRITER_ID');
         } elseif ($key == 'code') {
             $c->addJoin(VCatalogPerSourcePeer::CATALOG_ID, CatalogPeer::ID);
             $column = CatalogPeer::getTableMap()->getColumn('CODE');
         } elseif ($key == 'title') {
             $c->addJoin(VCatalogPerSourcePeer::CATALOG_ID, CatalogPeer::ID);
             $column = CatalogPeer::getTableMap()->getColumn('TITLE');
         } elseif ($key == 'writer') {
             $c->addJoin(VCatalogPerSourcePeer::CATALOG_ID, CatalogPeer::ID);
             $c->addJoin(CatalogWriterPeer::CATALOG_ID, CatalogPeer::ID);
             $c->addJoin(WriterPeer::ID, CatalogWriterPeer::WRITER_ID);
             $column = WriterPeer::getTableMap()->getColumn('NAME');
         } elseif ($key == 'publisher') {
             $c->addJoin(VCatalogPerSourcePeer::CATALOG_ID, CatalogPeer::ID);
             $c->addJoin(PublisherPeer::ID, CatalogPeer::PUBLISHER_ID);
             $column = PublisherPeer::getTableMap()->getColumn('NAME');
         } elseif ($key == 'cat_category_id') {
             $c->addJoin(VCatalogPerSourcePeer::CATALOG_ID, CatalogPeer::ID);
             $column = CatalogPeer::getTableMap()->getColumn('CAT_CATEGORY_ID');
         } elseif ($key == 'publisher_id') {
             $c->addJoin(VCatalogPerSourcePeer::CATALOG_ID, CatalogPeer::ID);
             $column = CatalogPeer::getTableMap()->getColumn('PUBLISHER_ID');
         } elseif ($key == 'YEAR_ADDED') {
             $column = VCatalogPerSourcePeer::getTableMap()->getColumn('YEAR_ADDED');
         } elseif ($key == 'department_id') {
             if ($filters[$key] == 1) {
                 $c->addJoin(VCatalogPerSourcePeer::CATALOG_ID, CatalogPeer::ID);
                 $c->addJoin(DepartmentPeer::ID, VCatalogPerSourcePeer::DEPARTMENT_ID);
                 $column = DepartmentPeer::getTableMap()->getColumn('ID');
             } else {
                 $c->addJoin(VCatalogPerSourcePeer::CATALOG_ID, CatalogPeer::ID);
                 $c->addJoin(DepartmentPeer::ID, VCatalogPerSourcePeer::DEPARTMENT_ID);
                 $c->addJoin(VDepartmentPeer::ID, DepartmentPeer::PARENT);
                 $column = VDepartmentPeer::getTableMap()->getColumn('ID');
             }
         } else {
             $column = VCatalogPerSourcePeer::getTableMap()->getColumn($key);
         }
         $name = $column->getFullyQualifiedName();
         $creoleType = $column->getCreoleType();
         if ($creoleType == CreoleTypes::TIMESTAMP) {
             $from = $value['from'];
             $to = $value['to'];
             if ($from != '' && $from != null) {
                 $c->add($name, $from, Criteria::GREATER_EQUAL);
             }
             if ($to != '' && $to != null) {
                 $c->add($name, $to, Criteria::LESS_EQUAL);
             }
         } else {
             if ($creoleType == CreoleTypes::INTEGER || $creoleType == CreoleTypes::BIGINT) {
                 $c->add($name, $value, Criteria::EQUAL);
             } else {
                 if ($creoleType == CreoleTypes::VARCHAR) {
                     $c->add($name, "%{$value}%", Criteria::LIKE);
                 } else {
                     if ($creoleType == CreoleTypes::NUMERIC) {
                         $c->add($name, $value, Criteria::EQUAL);
                     }
                 }
             }
         }
     }
 }