182 lines
6.1 KiB
PHP
182 lines
6.1 KiB
PHP
<?php
|
|
/**
|
|
* Copyright 2014 Openstack Foundation
|
|
* 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.
|
|
**/
|
|
/**
|
|
* Class SapphireNewsRepository
|
|
*/
|
|
final class SapphireNewsRepository extends SapphireRepository {
|
|
|
|
public function __construct(){
|
|
parent::__construct(new News());
|
|
}
|
|
|
|
/**
|
|
* @return INews[]
|
|
*/
|
|
public function getFeaturedNews()
|
|
{
|
|
$query = new QueryObject(new News);
|
|
$query->addAddCondition(QueryCriteria::equal('Featured','1'));
|
|
$query->addAddCondition(QueryCriteria::equal('Approved','1'));
|
|
$query->addOrder(QueryOrder::asc('Rank'));
|
|
list($list,$count) = $this->getAll($query,0,1000);
|
|
return $list;
|
|
}
|
|
|
|
/**
|
|
* @return INews[]
|
|
*/
|
|
public function getRecentNews()
|
|
{
|
|
$query = new QueryObject(new News);
|
|
$query->addAddCondition(QueryCriteria::equal('Featured','0'));
|
|
$query->addAddCondition(QueryCriteria::equal('Slider','0'));
|
|
$query->addAddCondition(QueryCriteria::equal('Approved','1'));
|
|
$query->addOrder(QueryOrder::desc('Date'));
|
|
$query->addOrder(QueryOrder::asc('Rank'));
|
|
list($list,$count) = $this->getAll($query,0,1000);
|
|
return $list;
|
|
}
|
|
|
|
/**
|
|
* @return INews[]
|
|
*/
|
|
public function getStandByNews()
|
|
{
|
|
$query = new QueryObject(new News);
|
|
$query->addAddCondition(QueryCriteria::equal('Featured','0'));
|
|
$query->addAddCondition(QueryCriteria::equal('Slider','0'));
|
|
$query->addAddCondition(QueryCriteria::equal('Approved','0'));
|
|
$query->addOrder(QueryOrder::desc('Date'));
|
|
$query->addOrder(QueryOrder::asc('Rank'));
|
|
list($list,$count) = $this->getAll($query,0,1000);
|
|
return $list;
|
|
}
|
|
|
|
/**
|
|
* @return INews[]
|
|
*/
|
|
public function getSlideNews()
|
|
{
|
|
$query = new QueryObject(new News);
|
|
$query->addAddCondition(QueryCriteria::equal('Slider','1'));
|
|
$query->addAddCondition(QueryCriteria::equal('Approved','1'));
|
|
$query->addOrder(QueryOrder::asc('Rank'));
|
|
list($list,$count) = $this->getAll($query,0,1000);
|
|
return $list;
|
|
}
|
|
|
|
/**
|
|
* @return INews[]
|
|
*/
|
|
public function getNewsByID($articleID)
|
|
{
|
|
$query = new QueryObject(new News);
|
|
$query->addAddCondition(QueryCriteria::equal('ID',$articleID));
|
|
return $this->getBy($query);
|
|
}
|
|
|
|
/**
|
|
* @return INews[]
|
|
*/
|
|
public function getExpiredNews()
|
|
{
|
|
$today = date("Y-m-d");
|
|
$query = new QueryObject(new News);
|
|
$query->addAddCondition(QueryCriteria::lower('DateExpire',$today));
|
|
list($expired_articles,$count) = $this->getAll($query);
|
|
|
|
return $expired_articles;
|
|
}
|
|
|
|
public function getNewsToActivate()
|
|
{
|
|
$today = date("Y-m-d");
|
|
$query = new QueryObject(new News);
|
|
$query->addAddCondition(QueryCriteria::lower('DateEmbargo',$today));
|
|
$query->addAddCondition(QueryCriteria::equal('Approved',1));
|
|
list($activate_articles,$count) = $this->getAll($query);
|
|
|
|
return $activate_articles;
|
|
}
|
|
|
|
public function getArticlesBySection($section) {
|
|
$approved = $slider = $featured = 0;
|
|
if ($section == 'recent') {
|
|
$approved = 1;
|
|
} elseif ($section == 'slider') {
|
|
$slider = 1;
|
|
$approved = 1;
|
|
} elseif ($section == 'featured') {
|
|
$featured = 1;
|
|
$approved = 1;
|
|
}
|
|
|
|
$query = new QueryObject(new News);
|
|
$query->addAddCondition(QueryCriteria::equal('Slider',$slider));
|
|
$query->addAddCondition(QueryCriteria::equal('Approved',$approved));
|
|
$query->addAddCondition(QueryCriteria::equal('Featured',$featured));
|
|
$query->addOrder(QueryOrder::asc('Rank'));
|
|
list($articles,$count) = $this->getAll($query);
|
|
|
|
return $articles;
|
|
}
|
|
|
|
public function getArticlesToSort($article_id,$new_rank,$old_rank,$is_new,$is_remove,$type) {
|
|
|
|
$slider = $featured = $approved = 0;
|
|
if ($type == 'slider') {
|
|
$slider = 1;
|
|
$approved = 1;
|
|
} elseif ($type == 'featured') {
|
|
$featured = 1;
|
|
$approved = 1;
|
|
} elseif ($type == 'recent') {
|
|
$approved = 1;
|
|
}
|
|
|
|
$query = new QueryObject(new News);
|
|
$query->addAddCondition(QueryCriteria::notEqual('ID',$article_id));
|
|
$query->addAddCondition(QueryCriteria::equal('Slider',$slider));
|
|
$query->addAddCondition(QueryCriteria::equal('Featured',$featured));
|
|
$query->addAddCondition(QueryCriteria::equal('Approved',$approved));
|
|
|
|
if ($is_new) {
|
|
$query->addAddCondition(QueryCriteria::greaterOrEqual('Rank',$new_rank));
|
|
$rank_delta = 1;
|
|
} elseif ($is_remove) {
|
|
$query->addAddCondition(QueryCriteria::greaterOrEqual('Rank',$old_rank));
|
|
$rank_delta = -1;
|
|
} else {
|
|
if ($old_rank < $new_rank) {
|
|
$query->addAddCondition(QueryCriteria::greaterOrEqual('Rank',$old_rank));
|
|
$query->addAddCondition(QueryCriteria::lowerOrEqual('Rank',$new_rank));
|
|
$rank_delta = -1;
|
|
} else {
|
|
$query->addAddCondition(QueryCriteria::greaterOrEqual('Rank',$new_rank));
|
|
$query->addAddCondition(QueryCriteria::lowerOrEqual('Rank',$old_rank));
|
|
$rank_delta = 1;
|
|
}
|
|
}
|
|
|
|
list($other_articles,$count) = $this->getAll($query);
|
|
|
|
$return_array = array($other_articles,$rank_delta);
|
|
|
|
return $return_array;
|
|
}
|
|
|
|
public function deleteArticle($article_id) {
|
|
DataObject::delete_by_id('News',$article_id);
|
|
}
|
|
} |