408 lines
15 KiB
PHP
408 lines
15 KiB
PHP
<?php namespace Gdoo\Order\Controllers;
|
|
|
|
use DB;
|
|
use Request;
|
|
use Auth;
|
|
use Cache;
|
|
|
|
use Gdoo\Customer\Models\Customer;
|
|
use Gdoo\Product\Models\Product;
|
|
use Gdoo\Product\Models\ProductCategory;
|
|
use Gdoo\Stock\Models\Warehouse;
|
|
use Gdoo\Order\Models\CustomerOrder;
|
|
use Gdoo\Stock\Models\Stock;
|
|
|
|
use Gdoo\Produce\Services\ProduceService;
|
|
|
|
use Gdoo\Index\Controllers\DefaultController;
|
|
|
|
class PlanController extends DefaultController
|
|
{
|
|
public $permission = [
|
|
'producePlan',
|
|
];
|
|
|
|
/**
|
|
* 生产计划总表
|
|
*/
|
|
public function index()
|
|
{
|
|
// 开始天
|
|
$sdate = date('Y-m-d', strtotime("-1 day"));
|
|
// 结束天
|
|
$edate = date('Y-m-d', strtotime("+2 day"));
|
|
|
|
$search = search_form([], [[
|
|
'form_type' => 'date2',
|
|
'field' => 'date',
|
|
'name' => '计划日期',
|
|
'value' => [$sdate, $edate]
|
|
],[
|
|
'form_type' =>'select',
|
|
'field' => 'type',
|
|
'name' => '内销/外销',
|
|
'options' => [['id'=>1, 'name'=> '内销'], ['id'=>2, 'name'=> '外销']]
|
|
],[
|
|
'form_type' =>'dialog',
|
|
'field' => 'warehouse_id',
|
|
'name' => '仓库',
|
|
'options' => ['url' => 'stock/warehouse/dialog', 'query' => []]
|
|
],[
|
|
'form_type' =>'dialog',
|
|
'field' => 'category_id',
|
|
'name' => '产品类别',
|
|
'options' => ['url' => 'product/category/dialog', 'query' => []]
|
|
],
|
|
], 'model');
|
|
|
|
$query = [];
|
|
|
|
if (Request::method() == 'POST') {
|
|
foreach($search['where'] as $where) {
|
|
if ($where['active']) {
|
|
$query[$where['field']] = $where['search'];
|
|
}
|
|
}
|
|
|
|
if ($query['date']) {
|
|
$sdate = $query['date'][0];
|
|
$edate = $query['date'][1];
|
|
}
|
|
$rows = ProduceService::getPlanDetail($sdate, $edate, $query['warehouse_id'], $query['category_id'], $query['type']);
|
|
$json = ['data' => $rows, 'status' => true];
|
|
return $json;
|
|
}
|
|
|
|
$header = [
|
|
'table' => 'produce_data',
|
|
'master_table' => 'produce_data',
|
|
'buttons' => [],
|
|
'search_form' => $search,
|
|
'simple_search_form' => 0,
|
|
];
|
|
|
|
$header['left_buttons'] = [
|
|
['name' => '导出', 'color' => 'default', 'icon' => 'fa-mail-forward', 'action' => 'export', 'display' => 1],
|
|
];
|
|
|
|
return $this->display([
|
|
'search' => $search,
|
|
'header' => $header,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* 外销销售进度表
|
|
*/
|
|
public function export_sale()
|
|
{
|
|
// 开始天
|
|
$sdate = date('Y-m-01');
|
|
// 结束天
|
|
$edate = date('Y-m-d');
|
|
|
|
$options = option('flow.status');
|
|
|
|
$search = search_form([], [[
|
|
'form_type' => 'date2',
|
|
'field' => 'mm.created_dt',
|
|
'name' => '订单日期',
|
|
'value' => [$sdate, $edate]
|
|
],[
|
|
'form_type' => 'text',
|
|
'field' => 'mm.sn',
|
|
'name' => '单据编号',
|
|
],[
|
|
'form_type' =>'dialog',
|
|
'field' => 'mm.product_id',
|
|
'name' => '产品名称',
|
|
'options' => ['url' => 'product/product/dialog', 'query' => []]
|
|
],[
|
|
'form_type' =>'dialog',
|
|
'field' => 'mm.customer_id',
|
|
'name' => '客户',
|
|
'options' => ['url' => 'customer/customer/dialog', 'query' => []]
|
|
],[
|
|
'form_type' =>'select',
|
|
'field' => 'mm.status',
|
|
'name' => '状态',
|
|
'options' => $options
|
|
],
|
|
], 'model');
|
|
|
|
$query = $search['query'];
|
|
|
|
if (Request::method() == 'POST') {
|
|
$rows = [];
|
|
|
|
if ($query['filter'] == 1) {
|
|
|
|
$sql = "mm.status,
|
|
mm.id,
|
|
mm.sn,
|
|
mm.created_at,
|
|
mm.created_dt,
|
|
mm.customer_id,
|
|
mm.customer_name,
|
|
mm.customer_code,
|
|
mm.product_id,
|
|
mm.product_code,
|
|
mm.product_name,
|
|
mm.product_spec,
|
|
mm.quantity,
|
|
mm.batch_sn,
|
|
pp.plan_num,
|
|
r.storage_num
|
|
FROM (SELECT m.status,
|
|
m.id,
|
|
m.sn,
|
|
m.created_at,
|
|
".sql_year_month_day('m.created_at', 'ts')." AS created_dt,
|
|
m.customer_id,
|
|
c.name AS customer_name,
|
|
c.code AS customer_code,
|
|
d.product_id,
|
|
p.code AS product_code,
|
|
p.name AS product_name,
|
|
p.spec AS product_spec,
|
|
d.quantity,
|
|
d.batch_sn
|
|
FROM customer_order_data d
|
|
LEFT JOIN product p ON p.id = d.product_id
|
|
LEFT JOIN customer_order m ON m.id = d.order_id
|
|
LEFT JOIN customer c ON c.id = m.customer_id
|
|
WHERE m.type_id = 2) mm
|
|
|
|
LEFT JOIN (SELECT produce_plan_data.batch_sn,
|
|
produce_plan_data.product_id,
|
|
sum(isnull(produce_plan_data.plan_num, 0)) AS plan_num
|
|
FROM produce_plan_data
|
|
WHERE produce_plan_data.batch_sn IS NOT NULL AND produce_plan_data.plan_num IS NOT NULL
|
|
GROUP BY produce_plan_data.product_id, produce_plan_data.batch_sn) pp ON mm.product_id = pp.product_id AND mm.batch_sn = pp.batch_sn
|
|
|
|
LEFT JOIN (SELECT stock_record10_data.product_id,
|
|
stock_record10_data.batch_sn,
|
|
sum(isnull(stock_record10_data.quantity, 0)) AS storage_num
|
|
FROM stock_record10_data
|
|
GROUP BY stock_record10_data.product_id, stock_record10_data.batch_sn) r ON mm.product_id = r.product_id AND mm.batch_sn = r.batch_sn
|
|
";
|
|
|
|
$model = DB::query()->selectRaw($sql)
|
|
->orderBy('created_at', 'desc');
|
|
|
|
foreach ($search['where'] as $where) {
|
|
if ($where['active']) {
|
|
$model->search($where);
|
|
}
|
|
}
|
|
|
|
$rows = $model->get();
|
|
|
|
$options = $options->pluck('name', 'id');
|
|
$rows->transform(function($item) use($options) {
|
|
$item['status'] = $options[$item['status']];
|
|
return $item;
|
|
});
|
|
}
|
|
$json = ['data' => $rows, 'status' => true];
|
|
return $json;
|
|
}
|
|
|
|
$search['table'] = 'produce_plan';
|
|
return $this->display([
|
|
'search' => $search,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* 生产计划
|
|
*/
|
|
public function produce()
|
|
{
|
|
// 开始天
|
|
$sdate = date('Y-m-d', strtotime("-1 day"));
|
|
// 结束天
|
|
$edate = date('Y-m-d', strtotime("+2 day"));
|
|
|
|
$search = search_form([], [[
|
|
'form_type' => 'date2',
|
|
'field' => 'date',
|
|
'name' => '计划日期',
|
|
'value' => [$sdate, $edate]
|
|
],[
|
|
'form_type' =>'select',
|
|
'field' => 'type',
|
|
'name' => '内销/外销',
|
|
'options' => [['id'=>1, 'name'=> '内销'], ['id'=>2, 'name'=> '外销']]
|
|
],[
|
|
'form_type' =>'dialog',
|
|
'field' => 'category_id',
|
|
'name' => '产品类别',
|
|
'options' => ['url' => 'product/category/dialog', 'query' => []]
|
|
],
|
|
], 'model');
|
|
|
|
$query = [];
|
|
|
|
if (Request::method() == 'POST') {
|
|
foreach($search['where'] as $where) {
|
|
if ($where['active']) {
|
|
$query[$where['field']] = $where['search'];
|
|
}
|
|
}
|
|
|
|
if ($query['date']) {
|
|
$sdate = $query['date'][0];
|
|
$edate = $query['date'][1];
|
|
}
|
|
|
|
$dates = array_reverse(date_range($sdate, $edate));
|
|
$columns = [];
|
|
|
|
// 创建计划主表
|
|
foreach ($dates as $produce_dt) {
|
|
if ($produce_dt) {
|
|
|
|
$produce = DB::table('produce_data')
|
|
->where('date', $produce_dt)
|
|
->first();
|
|
|
|
$editable = false;
|
|
$btn = '';
|
|
|
|
if ($produce['status'] == 1) {
|
|
$btn = ' <a href="javascript:;" class="btn btn-default btn-xs disabled">已提交</a>';
|
|
} else {
|
|
if ($this->access['produce_save']) {
|
|
$btn .= ' <a href="javascript:;" data-toggle="produce_data" data-id="'.$produce_dt.'" data-action="save" class="btn btn-default btn-xs">保存</a>';
|
|
$editable = true;
|
|
}
|
|
if ($this->access['produce_submit']) {
|
|
$btn .= ' <a href="javascript:;" data-toggle="produce_data" data-id="'.$produce_dt.'" data-action="submit" class="btn btn-default btn-xs">提交</a>';
|
|
}
|
|
}
|
|
|
|
$_produce_dt = str_replace('-', '_', $produce_dt);
|
|
$columns[] = [
|
|
'headerName' => $produce_dt.$btn,
|
|
'cellRenderer' => 'htmlCellRenderer',
|
|
'children' => [
|
|
['cellClass' => 'text-right', 'headerName' => '发货计划', 'width' => 60, 'cellRenderer' => 'wfhjh', 'field' => 'wfhjh_num_'.$_produce_dt, 'type' => 'number', 'numberOptions' => ['places' => 0, 'default' => ''], 'calcFooter' => 'sum'],
|
|
['cellClass' => 'text-right', 'headerName' => '营销计划', 'width' => 60, 'field' => 'sale_plan_num_'.$_produce_dt, 'type' => 'number', 'numberOptions' => ['places' => 0, 'default' => ''], 'calcFooter' => 'sum', 'editable'=> $editable],
|
|
['cellClass' => 'text-right', 'headerName' => '生产计划', 'width' => 60, 'field' => 'produce_plan_num_'.$_produce_dt, 'type' => 'number', 'numberOptions' => ['places' => 0, 'default' => ''], 'calcFooter' => 'sum'],
|
|
['cellClass' => 'text-right', 'headerName' => '计划变更', 'width' => 60, 'field' => 'produce_bg_num_'.$_produce_dt, 'type' => 'number', 'numberOptions' => ['places' => 0, 'default' => ''], 'calcFooter' => 'sum'],
|
|
['cellClass' => 'text-right', 'headerName' => '成品入库', 'width' => 60, 'field' => 'rk_num_'.$_produce_dt, 'type' => 'number', 'numberOptions' => ['places' => 0, 'default' => ''], 'calcFooter' => 'sum'],
|
|
]
|
|
];
|
|
}
|
|
}
|
|
$rows = ProduceService::getPlanDetail($sdate, $edate, 0, $query['category_id'], $query['type']);
|
|
$json = ['columns' => $columns, 'data' => $rows, 'status' => true];
|
|
return $json;
|
|
}
|
|
|
|
$header = [
|
|
'table' => 'produce_data',
|
|
'master_table' => 'produce_data',
|
|
'buttons' => [],
|
|
'search_form' => $search,
|
|
'simple_search_form' => 0,
|
|
];
|
|
|
|
$header['left_buttons'] = [
|
|
['name' => '导出', 'color' => 'default', 'icon' => 'fa-mail-forward', 'action' => 'export', 'display' => 1],
|
|
];
|
|
|
|
return $this->display([
|
|
'search' => $search,
|
|
'header' => $header,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* 获取发货计划明细
|
|
*/
|
|
public function producePlan()
|
|
{
|
|
$query = Request::all();
|
|
if (Request::method() == 'POST') {
|
|
|
|
$sql = "d.product_id, SUM(isnull(d.delivery_quantity,0) - isnull(i.Num,0) - isnull(r.Num,0)) as fhjh_num, m.pay_dt,
|
|
m.plan_delivery_dt,m.export_country,c.name as customer_name,m.sn
|
|
FROM customer_order_data AS d
|
|
left JOIN customer_order AS m ON m.id = d.order_id
|
|
left JOIN customer as c ON m.customer_id = c.id
|
|
LEFT JOIN (select dd.sale_data_id,SUM(dd.quantity) Num
|
|
from stock_delivery_data dd,stock_delivery mm
|
|
where mm.id = dd.delivery_id
|
|
GROUP BY dd.sale_data_id
|
|
) as i ON i.sale_data_id = d.id
|
|
LEFT JOIN (select dd.sale_data_id, SUM(dd.quantity) Num
|
|
from stock_allocation_data dd, stock_allocation mm
|
|
where mm.id = dd.allocation_id
|
|
GROUP BY dd.sale_data_id
|
|
) as r ON r.sale_data_id = d.id
|
|
";
|
|
|
|
$date = str_replace('_', '-', $query['date']);
|
|
$model = DB::query()->selectRaw($sql);
|
|
$model->whereRaw('ISNULL(d.use_close, 0) = 0 and m.status > 0')
|
|
->where('plan_delivery_dt', $date)
|
|
->where('product_id', $query['product_id'])
|
|
->havingRaw('isnull(SUM(d.delivery_quantity),0) - isnull(i.Num,0) - isnull(r.Num,0) <> 0')
|
|
->groupBy(DB::raw('m.sn, d.product_id, d.delivery_quantity, i.Num, r.Num, m.pay_dt, m.plan_delivery_dt, m.export_country, c.name, m.sn'));
|
|
|
|
$rows = $model->get();
|
|
|
|
return ['data' => $rows];
|
|
}
|
|
return $this->render([
|
|
'query' => $query,
|
|
]);
|
|
}
|
|
|
|
// 保存生产计划
|
|
public function produce_save()
|
|
{
|
|
if (Request::method() == 'POST') {
|
|
$gets = Request::all();
|
|
$date = $gets['date'];
|
|
foreach ($gets['rows'] as $row) {
|
|
|
|
$has = DB::table('produce_data')
|
|
->where('product_id', $row['product_id'])
|
|
->where('date', $date)
|
|
->first();
|
|
|
|
if (empty($has)) {
|
|
$row['date'] = $date;
|
|
DB::table('produce_data')->insert($row);
|
|
} else {
|
|
if ($has['quantity'] > 0) {
|
|
DB::table('produce_data')->where('id', $has['id'])->update($row);
|
|
} else {
|
|
// 数量如果不大于0就删除
|
|
DB::table('produce_data')->where('id', $has['id'])->delete();
|
|
}
|
|
}
|
|
}
|
|
return $this->json('营销计划保存成功。', true);
|
|
}
|
|
}
|
|
|
|
// 提交生产计划
|
|
public function produce_submit()
|
|
{
|
|
if (Request::method() == 'POST') {
|
|
$gets = Request::all();
|
|
$count = DB::table('produce_data')->where('date', $gets['date'])->get();
|
|
if ($count > 0) {
|
|
DB::table('produce_data')->where('date', $gets['date'])->update(['status' => 1]);
|
|
return $this->json('营销计划提交成功。', true);
|
|
} else {
|
|
return $this->json('营销计划为空不能提交。', true);
|
|
}
|
|
}
|
|
}
|
|
}
|