gdoo/app/Gdoo/Approach/Controllers/ApproachController.php

368 lines
14 KiB
PHP

<?php namespace Gdoo\Approach\Controllers;
use DB;
use Request;
use Validator;
use Gdoo\Approach\Models\Approach;
use Gdoo\Model\Grid;
use Gdoo\Model\Form;
use Gdoo\Index\Controllers\WorkflowController;
class ApproachController extends WorkflowController
{
public $permission = ['dialog', 'reference', 'useCount', 'serviceReview', 'serviceCostList', 'serviceCostDetail', 'product'];
public function indexAction()
{
// 客户权限
$region = regionCustomer('customer_id_customer');
$header = Grid::header([
'code' => 'approach',
'referer' => 1,
'search' => ['by' => ''],
]);
$cols = $header['cols'];
$cols['actions']['options'] = [[
'name' => '显示',
'action' => 'show',
'display' => $this->access['show'],
]];
$cols['master_product']['cellRenderer'] = 'htmlCellRenderer';
$cols['master_cash_amount']['cellRenderer'] = 'htmlCellRenderer';
$search = $header['search_form'];
$query = $search['query'];
if (Request::method() == 'POST') {
$model = DB::table($header['table'])->setBy($header);
foreach ($header['join'] as $join) {
$model->leftJoin($join[0], $join[1], $join[2], $join[3]);
}
$model->leftJoin(DB::raw('(SELECT sum(verification_cost) as master_cash_amount, min(date) as master_cash_date, apply_id FROM approach_review where status = 1 group by apply_id) as b'), 'approach.id', '=', 'b.apply_id');
$header['select'][] = 'b.master_cash_amount';
$header['select'][] = 'b.master_cash_date';
$model->orderBy($header['sort'], $header['order']);
foreach ($search['where'] as $where) {
if ($where['active']) {
$model->search($where);
}
}
if ($region['authorise']) {
foreach ($region['whereIn'] as $key => $where) {
$model->whereIn($key, $where);
}
}
$model->select($header['select']);
$rows = $model->paginate($query['limit'])->appends($query);
$items = Grid::dataFilters($rows, $header, function($item) {
$item['master_cash_amount'] = '<a href="javascript:;" data-toggle="event" data-action="fee_detail" data-master_id="'.$item['master_id'].'" class="option">'.$item['master_cash_amount'].'</a>';
$item['master_product'] = '<a href="javascript:;" data-toggle="event" data-action="product" data-master_id="'.$item['master_id'].'" class="option">明细</a>';
return $item;
});
return $items->toJson();
}
$header['buttons'] = [
// ['name' => '删除', 'icon' => 'fa-remove', 'action' => 'delete', 'display' => $this->access['delete']],
['name' => '导出', 'icon' => 'fa-share', 'action' => 'export', 'display' => 1],
];
$header['left_buttons'] = [
['name' => '批量编辑', 'color' => 'default', 'icon' => 'fa-pencil-square-o', 'action' => 'batchEdit', 'display' => $this->access['batchEdit']],
];
$header['cols'] = $cols;
$header['tabs'] = Approach::$tabs;
$header['bys'] = Approach::$bys;
$header['js'] = Grid::js($header);
return $this->display([
'header' => $header,
]);
}
// 新建促销
public function createAction($action = 'edit')
{
$id = (int) Request::get('id');
// 客户权限
$header['region'] = ['field' => 'customer_id'];
$header['authorise'] = ['action' => 'index', 'field' => 'created_id'];
$header['action'] = $action;
$header['code'] = 'approach';
$header['id'] = $id;
$form = Form::make($header);
$tpl = $action == 'print' ? 'print' : 'create';
return $this->display([
'form' => $form,
], $tpl);
}
// 编辑进店
public function editAction()
{
return $this->createAction();
}
// 审核进店
public function auditAction()
{
return $this->createAction('audit');
}
// 显示进店
public function showAction()
{
return $this->createAction('show');
}
// 显示进店
public function printAction()
{
$this->layout = 'layouts.print2';
print_prince($this->createAction('print'));
}
// 关闭操作
public function closeAction()
{
$gets = Request::all();
if (Request::method() == 'POST') {
$row = DB::table('approach')->where('id', $gets['id'])->first();
DB::table('approach')->where('id', $gets['id'])->update([
'is_close' => !$row['is_close']
]);
return $this->json('操作成功。', true);
}
}
// 产品明细
public function productAction()
{
$query = Request::all();
if (Request::method() == 'POST') {
$rows = DB::table('approach_data')
->leftJoin('product', 'product.id', '=', 'approach_data.product_id')
->where('approach_id', $query['id'])
->orderBy('product.code', 'asc')
->get(['product.*']);
return $this->json($rows, true);
}
return $this->render(['query' => $query]);
}
// 核销单选择
public function serviceReviewAction()
{
$header = Grid::header([
'code' => 'approach',
'prefix' => '',
]);
$search = $header['search_form'];
$query = $search['query'];
if (Request::method() == 'POST') {
if ($query['master']) {
$model = DB::table('approach');
foreach ($header['join'] as $join) {
$model->leftJoin($join[0], $join[1], $join[2], $join[3]);
}
$model->leftJoin('approach_market', 'approach_market.id', '=', 'approach.market_id')
->where('approach.status', 1)
->orderBy('approach.id', 'desc');
foreach ($search['where'] as $where) {
if ($where['active']) {
$model->search($where);
}
}
$model->selectRaw('
distinct(approach.id),
approach.id,
approach.sn,
approach.status,
approach.barcode_cast,
approach.apply2_money,
approach.created_at,
approach.customer_id,
customer_id_customer.region_id,
approach_market.name as market_name,
customer_id_region_id_customer_region.name as region_name,
customer_id_customer.code as customer_code,
customer_id_customer.name as customer_name,
customer_id_customer.warehouse_contact,
customer_id_customer.warehouse_phone,
customer_id_customer.warehouse_address
');
$rows = $model->get();
$rows = Grid::dataFilters($rows, $header);
} else {
$model = DB::table('approach_data')
->leftJoin('product', 'product.id', '=', 'approach_data.product_id')
->leftJoin('approach', 'approach.id', '=', 'approach_data.approach_id')
->leftJoin('product_unit', 'product_unit.id', '=', 'product.unit_id')
->whereIn('approach.id', (array)$query['ids']);
if ($query['sort'] && $query['order']) {
$model->orderBy($query['sort'], $query['order']);
}
foreach ($search['where'] as $where) {
if ($where['active']) {
$model->search($where);
}
}
$model->selectRaw("
approach_data.*,
approach.id as approach_id,
approach.sn as approach_sn,
product.code as product_code,
product.name as product_name,
product.spec as product_spec,
product.barcode as product_barcode,
product.unit_id as unit_id,
product_unit.name as product_unit,
product.weight
");
$rows = $model->get();
}
return $this->json($rows, true);
}
return $this->render([
'search' => $search,
'query' => $query,
]);
}
// 费用申请明细
public function serviceCostDetailAction()
{
$query = Request::all();
$customer_id = (int)$query['customer_id'];
$date = empty($query['date']) ? date('Y-m-d') : $query['date'];
$year = date('Y', strtotime($date));
if (Request::method() == 'POST') {
if ($query['type'] == 'promotion') {
$rows = DB::table('promotion')
->where('type_id', 2)
->whereRaw('customer_id=? and '.sql_year('actived_dt').'=? and isnull(is_close, 0) = 0 and isnull(status, 0) <> 0', [$customer_id, $year])
->get();
}
if ($query['type'] == 'approach') {
$rows = DB::table('approach')
->whereRaw('customer_id=? and '.sql_year('actived_dt').'=? and isnull(is_close, 0) = 0 and isnull(status, 0) <> 0', [$customer_id, $year])
->get();
}
if ($query['type'] == 'material') {
$rows = DB::table('promotion')
->where('type_id', 1)
->whereRaw('customer_id=? and '.sql_year('actived_dt').'=? and isnull(is_close, 0) = 0 and isnull(status, 0) <> 0', [$customer_id, $year])
->get();
}
return $this->json($rows, true);
}
$approach = DB::table('approach')
->whereRaw('customer_id=? and '.sql_year('actived_dt').'=? and isnull(is_close, 0) = 0 and isnull(status, 0) <> 0', [$customer_id, $year])
->selectRaw('sum(barcode_cast) as apply_money,sum(apply2_money) as support_money')
->first();
$promotion = DB::table('promotion')
->whereRaw('customer_id=? and '.sql_year('actived_dt').'=? and isnull(is_close, 0) = 0 and isnull(status, 0) <> 0', [$customer_id, $year])
->selectRaw('sum(apply_fee) as apply_money,sum(undertake_money) as support_money')
->first();
$apply_money = $approach['apply_money'] + $promotion['apply_money'];
$support_money = $approach['support_money'] + $promotion['support_money'];
// 发货
$delivery = DB::table('stock_delivery_data as d')
->leftJoin('stock_delivery as m', 'm.id', '=', 'd.delivery_id')
->leftJoin('product', 'product.id', '=', 'd.product_id')
->whereRaw('m.customer_id=? and '.sql_year('m.invoice_dt').'=? and d.product_id <> 20226 and isnull(product.product_type, 0) = 1', [$customer_id, $year])
->selectRaw('sum(isnull(d.money, 0) - isnull(d.other_money, 0)) money');
// 退货
$cancel = DB::table('stock_cancel_data as d')
->leftJoin('stock_cancel as m', 'm.id', '=', 'd.cancel_id')
->leftJoin('product', 'product.id', '=', 'd.product_id')
->whereRaw('m.customer_id=? and '.sql_year('m.invoice_dt').'=? and d.product_id <> 20226 and isnull(product.product_type, 0) = 1', [$customer_id, $year])
->selectRaw('sum(isnull(d.money, 0) - isnull(d.other_money, 0)) money');
// 直营
$direct = DB::table('stock_direct_data as d')
->leftJoin('stock_direct as m', 'm.id', '=', 'd.direct_id')
->leftJoin('product', 'product.id', '=', 'd.product_id')
->whereRaw('m.customer_id=? and '.sql_year('m.invoice_dt').'=? and d.product_id <> 20226 and isnull(product.product_type, 0) = 1', [$customer_id, $year])
->selectRaw('sum(isnull(d.money, 0) - isnull(d.other_money, 0)) money');
$rows = $cancel->unionAll($delivery)->unionAll($direct)->get();
$money = $rows->sum('money');
$apply_percent = $support_percent = 0;
if ($money > 0) {
$apply_percent = ($apply_money / $money) * 100;
$support_percent = ($support_money / $money) * 100;
}
$all = [
'money' => $money,
'apply_money' => $apply_money,
'support_money' => $support_money,
'apply_percent' => $apply_percent,
'support_percent' => $support_percent,
];
return $this->render([
'all' => $all,
'query' => $query,
]);
}
// 批量编辑
public function batchEditAction()
{
$gets = Request::all();
if (Request::method() == 'POST') {
$ids = explode(',', $gets['ids']);
DB::table('approach')->whereIn('id', $ids)->update([
$gets['field'] => $gets['search_0'],
]);
return $this->json('修改完成。', true);
}
$header = Grid::batchEdit([
'code' => 'approach',
'columns' => ['customer_id', 'tax_id'],
]);
return view('batchEdit', [
'gets' => $gets,
'header' => $header
]);
}
// 删除进店申请
public function deleteAction()
{
if (Request::method() == 'POST') {
$ids = Request::get('id');
return Form::remove(['code' => 'approach', 'ids' => $ids]);
}
}
}