2020-12-08 08:11:04 +00:00
|
|
|
|
<?php
|
|
|
|
|
namespace app\controller\manager;
|
|
|
|
|
|
|
|
|
|
use app\model\{AchievementInfo, Category, Achievement as MAchievement, Log};
|
|
|
|
|
use app\validate\Achievement as VAchievement;
|
|
|
|
|
use think\facade\Db;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 业绩管理
|
|
|
|
|
* Class Achievement
|
|
|
|
|
* @package app\controller\manager
|
|
|
|
|
*/
|
|
|
|
|
class Achievement extends Base
|
|
|
|
|
{
|
|
|
|
|
protected $validate;
|
|
|
|
|
public function initialize()
|
|
|
|
|
{
|
|
|
|
|
parent::initialize();
|
|
|
|
|
$this->validate = new VAchievement();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/****************************
|
|
|
|
|
* 业绩
|
|
|
|
|
****************************/
|
|
|
|
|
public function add()
|
|
|
|
|
{
|
|
|
|
|
$categoryId = input('param.category_id/d', 0);
|
|
|
|
|
$category = Category::getById($categoryId);
|
|
|
|
|
if(empty($category)) {
|
|
|
|
|
return $this->json(1, '无此栏目信息');
|
|
|
|
|
}
|
|
|
|
|
if(request()->isPost()) {
|
|
|
|
|
$params = input('post.item/a', []);
|
|
|
|
|
$params = arrayHtmlFilter($params);
|
|
|
|
|
if($this->validate->checkAchievement($params)) {
|
|
|
|
|
$data = [
|
|
|
|
|
'title' => $params['title'],
|
|
|
|
|
'visible' => $params['visible'],
|
|
|
|
|
'category_id' => $categoryId,
|
|
|
|
|
'summary' => $params['summary'] ?? '',
|
|
|
|
|
'description' => $params['description'] ?? '',
|
|
|
|
|
'create_time' => time(),
|
|
|
|
|
];
|
|
|
|
|
$newItem = MAchievement::create($data);
|
|
|
|
|
Log::write('achievement', 'add', '新增业绩,ID:'.$newItem->id);
|
|
|
|
|
} else {
|
|
|
|
|
return $this->json(2, $this->validate->getError());
|
|
|
|
|
}
|
|
|
|
|
return $this->json();
|
|
|
|
|
} else {
|
|
|
|
|
$this->data['category'] = $category;
|
|
|
|
|
return $this->view();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function edit()
|
|
|
|
|
{
|
|
|
|
|
$id = input('param.id/d', 0);
|
|
|
|
|
$item = MAchievement::getById($id);
|
|
|
|
|
if(count($item) == 0) {
|
|
|
|
|
return $this->json(1, '该业绩信息不存在');
|
|
|
|
|
}
|
|
|
|
|
if(request()->isPost()) {
|
|
|
|
|
$params = input('post.item/a', []);
|
|
|
|
|
$params = arrayHtmlFilter($params);
|
|
|
|
|
if($this->validate->checkAchievement($params)) {
|
|
|
|
|
$data = [
|
|
|
|
|
'title' => $params['title'],
|
|
|
|
|
'visible' => $params['visible'],
|
|
|
|
|
'summary' => $params['summary'] ?? '',
|
|
|
|
|
'description' => $params['description'] ?? '',
|
|
|
|
|
];
|
|
|
|
|
MAchievement::updateById($item['id'] ,$data);
|
|
|
|
|
Log::write('achievement', 'add', '修改业绩,ID:'.$item['id']);
|
|
|
|
|
} else {
|
|
|
|
|
return $this->json(2, $this->validate->getError());
|
|
|
|
|
}
|
|
|
|
|
return $this->json();
|
|
|
|
|
} else {
|
|
|
|
|
$this->data['item'] = $item;
|
|
|
|
|
return $this->view();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function sort()
|
|
|
|
|
{
|
|
|
|
|
if(request()->isPost()) {
|
|
|
|
|
$id = input('post.id/d');
|
|
|
|
|
$sort = input('post.sort');
|
|
|
|
|
$num = input('post.num/d', 1);
|
|
|
|
|
if($num <= 0){
|
|
|
|
|
$num = 1;
|
|
|
|
|
}
|
|
|
|
|
if(!in_array($sort, ['up', 'down'], true)){
|
|
|
|
|
return $this->json(2, '参数错误');
|
|
|
|
|
}
|
|
|
|
|
$item = MAchievement::getById($id);
|
|
|
|
|
if(empty($item)){
|
|
|
|
|
return $this->json(3, '该业绩信息不存在');
|
|
|
|
|
}
|
|
|
|
|
if($sort == 'up'){ // sort 变大
|
|
|
|
|
$where = "category_id='{$item['category_id']}' and sort > {$item['sort']}";
|
|
|
|
|
$order = "sort asc";
|
|
|
|
|
}else{ // sort 变小
|
|
|
|
|
$where = "category_id='{$item['category_id']}' and sort < {$item['sort']}";
|
|
|
|
|
$order = "sort desc";
|
|
|
|
|
}
|
|
|
|
|
$forSortItems = MAchievement::getListByWhereAndOrder($where, $order, $num);
|
|
|
|
|
if(!empty($forSortItems)){
|
|
|
|
|
$updateData = [];
|
|
|
|
|
$forSortCount = count($forSortItems);
|
|
|
|
|
for($i = 0; $i < $forSortCount; $i++){
|
|
|
|
|
if($i == 0){
|
|
|
|
|
$updateData[] = [
|
|
|
|
|
'id' => $forSortItems[$i]['id'],
|
|
|
|
|
'sort' => $item['sort']
|
|
|
|
|
];
|
|
|
|
|
}else{
|
|
|
|
|
$updateData[] = [
|
|
|
|
|
'id' => $forSortItems[$i]['id'],
|
|
|
|
|
'sort' => $forSortItems[$i - 1]['sort']
|
|
|
|
|
];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
$updateData[] = [
|
|
|
|
|
'id' => $item['id'],
|
|
|
|
|
'sort' => $forSortItems[$i - 1]['sort']
|
|
|
|
|
];
|
|
|
|
|
if(!empty($updateData)){
|
|
|
|
|
$model = new MAchievement();
|
|
|
|
|
$model->saveAll($updateData);
|
|
|
|
|
$sortStr = $sort == 'up' ? '上移' : '下调';
|
|
|
|
|
Log::write('achievement', 'sort', "业绩排序,ID:{$id} ,{$sortStr}了{$num}位");
|
|
|
|
|
return $this->json();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return $this->json(4, '无须调整排序!');
|
|
|
|
|
}
|
|
|
|
|
return $this->json(1, '无此操作');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function del()
|
|
|
|
|
{
|
|
|
|
|
if(request()->isPost()) {
|
|
|
|
|
$id = input('param.id/d', 0);
|
|
|
|
|
$item = MAchievement::getById($id);
|
|
|
|
|
if(count($item) == 0) {
|
|
|
|
|
return $this->json(2, '该业绩信息不存在');
|
|
|
|
|
}
|
|
|
|
|
Db::startTrans();
|
|
|
|
|
try {
|
|
|
|
|
MAchievement::destroy($id);
|
|
|
|
|
$hasInfo = AchievementInfo::hasByAchievementId($id);
|
|
|
|
|
if($hasInfo > 0) {
|
|
|
|
|
AchievementInfo::delByAchievementId($id);
|
|
|
|
|
}
|
|
|
|
|
Log::write('achievement','del', '删除业绩,ID:'.$id);
|
|
|
|
|
Db::commit();
|
|
|
|
|
} catch (\Exception $e) {
|
|
|
|
|
Db::rollback();
|
|
|
|
|
return $this->json(3, '删除失败,'.$e->getMessage());
|
|
|
|
|
}
|
|
|
|
|
return $this->json();
|
|
|
|
|
}
|
|
|
|
|
return $this->json(1, '无此操作');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/****************************
|
|
|
|
|
* 业绩详情
|
|
|
|
|
****************************/
|
|
|
|
|
|
|
|
|
|
public function info()
|
|
|
|
|
{
|
|
|
|
|
$achievementId = input('param.achievement_id/d', 0);
|
|
|
|
|
$achievement = MAchievement::getById($achievementId);
|
|
|
|
|
$infoItems = [];
|
|
|
|
|
$categoryId = $achievement['category_id'] ?? 0;
|
|
|
|
|
if($achievement) {
|
|
|
|
|
$infoItems = AchievementInfo::getByAchievementId($achievementId);
|
|
|
|
|
}
|
|
|
|
|
$this->data['achievement'] = $achievement;
|
|
|
|
|
$this->data['categoryId'] = $categoryId;
|
|
|
|
|
$this->data['items'] = $infoItems;
|
|
|
|
|
return $this->view();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function infoAdd()
|
|
|
|
|
{
|
|
|
|
|
$achievementId = input('param.achievement_id/d', 0);
|
|
|
|
|
$achievement = MAchievement::getById($achievementId);
|
|
|
|
|
if(empty($achievement)) {
|
|
|
|
|
return $this->json(2, '无此业绩信息');
|
|
|
|
|
}
|
|
|
|
|
if(request()->isPost()) {
|
|
|
|
|
$params = input('post.item/a', []);
|
|
|
|
|
$params = arrayHtmlFilter($params);
|
|
|
|
|
if($this->validate->checkAchievementInfo($params)) {
|
|
|
|
|
$data = [
|
|
|
|
|
'achievement_id' => $achievementId,
|
|
|
|
|
'title' => $params['title'],
|
|
|
|
|
'order_company' => $params['order_company'],
|
|
|
|
|
'goods_model' => $params['goods_model'],
|
|
|
|
|
'goods_amount' => $params['goods_amount'],
|
|
|
|
|
'visible' => $params['visible'],
|
|
|
|
|
'owner' => $params['owner'] ?? '',
|
|
|
|
|
'owner_tel' => $params['owner_tel'] ?? '',
|
|
|
|
|
'owner_email' => $params['owner_email'] ?? '',
|
|
|
|
|
'create_time' => time(),
|
|
|
|
|
];
|
|
|
|
|
$newItem = AchievementInfo::create($data);
|
|
|
|
|
Log::write('achievement', 'infoAdd', '新增业绩项目,ID:'.$newItem->id);
|
|
|
|
|
} else {
|
|
|
|
|
return $this->json(2, $this->validate->getError());
|
|
|
|
|
}
|
|
|
|
|
return $this->json();
|
|
|
|
|
} else {
|
|
|
|
|
$this->data['achievementId'] = $achievementId;
|
|
|
|
|
$this->data['achievement'] = $achievement;
|
|
|
|
|
return $this->view();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function infoEdit()
|
|
|
|
|
{
|
|
|
|
|
$id = input('param.id/d', 0);
|
|
|
|
|
$item = AchievementInfo::getById($id);
|
|
|
|
|
if(count($item) == 0) {
|
|
|
|
|
return $this->json(1, '该业务项目不存在');
|
|
|
|
|
}
|
|
|
|
|
if(request()->isPost()) {
|
|
|
|
|
$params = input('post.item/a', []);
|
|
|
|
|
$params = arrayHtmlFilter($params);
|
|
|
|
|
if($this->validate->checkAchievementInfo($params)) {
|
|
|
|
|
$data = [
|
|
|
|
|
'title' => $params['title'],
|
|
|
|
|
'order_company' => $params['order_company'],
|
|
|
|
|
'goods_model' => $params['goods_model'],
|
|
|
|
|
'goods_amount' => $params['goods_amount'],
|
|
|
|
|
'visible' => $params['visible'],
|
|
|
|
|
'owner' => $params['owner'] ?? '',
|
|
|
|
|
'owner_tel' => $params['owner_tel'] ?? '',
|
|
|
|
|
'owner_email' => $params['owner_email'] ?? '',
|
|
|
|
|
];
|
|
|
|
|
AchievementInfo::updateById($id, $data);
|
|
|
|
|
Log::write('achievement', 'infoEdit', '修改业绩项目,ID:'.$id);
|
|
|
|
|
} else {
|
|
|
|
|
return $this->json(2, $this->validate->getError());
|
|
|
|
|
}
|
|
|
|
|
return $this->json();
|
|
|
|
|
} else {
|
|
|
|
|
$this->data['item'] = $item;
|
|
|
|
|
return $this->view();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function infoSort()
|
|
|
|
|
{
|
|
|
|
|
if(request()->isPost()) {
|
|
|
|
|
$id = input('post.id/d');
|
|
|
|
|
$sort = input('post.sort');
|
|
|
|
|
$num = input('post.num/d', 1);
|
|
|
|
|
if($num <= 0){
|
|
|
|
|
$num = 1;
|
|
|
|
|
}
|
|
|
|
|
if(!in_array($sort, ['up', 'down'], true)){
|
|
|
|
|
return $this->json(2, '参数错误');
|
|
|
|
|
}
|
|
|
|
|
$item = AchievementInfo::getById($id);
|
|
|
|
|
if(empty($item)){
|
|
|
|
|
return $this->json(3, '该业绩项目信息不存在');
|
|
|
|
|
}
|
|
|
|
|
if($sort == 'up'){
|
2020-12-08 08:17:58 +00:00
|
|
|
|
$where = "achievement_id='{$item['achievement_id']}' and sort > {$item['sort']}";
|
2020-12-08 08:11:04 +00:00
|
|
|
|
$order = "sort asc";
|
|
|
|
|
}else{
|
2020-12-08 08:17:58 +00:00
|
|
|
|
$where = "achievement_id='{$item['achievement_id']}' and sort < {$item['sort']}";
|
2020-12-08 08:11:04 +00:00
|
|
|
|
$order = "sort desc";
|
|
|
|
|
}
|
|
|
|
|
$forSortItems = AchievementInfo::getListByWhereAndOrder($where, $order, $num);
|
|
|
|
|
if(!empty($forSortItems)){
|
|
|
|
|
$updateData = [];
|
|
|
|
|
$forSortCount = count($forSortItems);
|
|
|
|
|
for($i = 0; $i < $forSortCount; $i++){
|
|
|
|
|
if($i == 0){
|
|
|
|
|
$updateData[] = [
|
|
|
|
|
'id' => $forSortItems[$i]['id'],
|
|
|
|
|
'sort' => $item['sort']
|
|
|
|
|
];
|
|
|
|
|
}else{
|
|
|
|
|
$updateData[] = [
|
|
|
|
|
'id' => $forSortItems[$i]['id'],
|
|
|
|
|
'sort' => $forSortItems[$i - 1]['sort']
|
|
|
|
|
];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
$updateData[] = [
|
|
|
|
|
'id' => $item['id'],
|
|
|
|
|
'sort' => $forSortItems[$i - 1]['sort']
|
|
|
|
|
];
|
|
|
|
|
if(!empty($updateData)){
|
|
|
|
|
$model = new AchievementInfo();
|
|
|
|
|
$model->saveAll($updateData);
|
|
|
|
|
$sortStr = $sort == 'up' ? '上移' : '下调';
|
|
|
|
|
Log::write('achievement', 'infoSort', "业绩项目排序,ID:{$id} ,{$sortStr}了{$num}位");
|
|
|
|
|
return $this->json();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return $this->json(4, '无须调整排序!');
|
|
|
|
|
}
|
|
|
|
|
return $this->json(1, '无此操作');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public function infoDel()
|
|
|
|
|
{
|
|
|
|
|
if(request()->isPost()) {
|
|
|
|
|
$infoIds = [];
|
|
|
|
|
$ids = input('post.ids', []);
|
|
|
|
|
$id = input('post.id', 0);
|
|
|
|
|
if(!empty($ids)) {
|
|
|
|
|
if(is_array($ids)) {
|
|
|
|
|
$infoIds = $ids;
|
|
|
|
|
} else {
|
|
|
|
|
$infoIds = explode(',', $ids);
|
|
|
|
|
}
|
|
|
|
|
} elseif($id > 0) {
|
|
|
|
|
$infoIds[] = $id;
|
|
|
|
|
}
|
|
|
|
|
if(count($infoIds) > 0) {
|
|
|
|
|
AchievementInfo::destroy($infoIds);
|
|
|
|
|
Log::write('achievement','infoDel', '删除业绩项目,IDs:'.implode(',', $infoIds));
|
|
|
|
|
return $this->json();
|
|
|
|
|
}
|
|
|
|
|
return $this->json(2, '参数错误');
|
|
|
|
|
}
|
|
|
|
|
return $this->json(1, '无此操作');
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|