mirror of
https://gitee.com/ShopeX/OMS
synced 2026-03-22 18:35:35 +08:00
399 lines
12 KiB
PHP
399 lines
12 KiB
PHP
<?php
|
||
/**
|
||
* Copyright © ShopeX (http://www.shopex.cn). All rights reserved.
|
||
* See LICENSE file for license details.
|
||
*/
|
||
|
||
|
||
class purchase_ctl_admin_supplier extends desktop_controller{
|
||
|
||
var $name = "供应商";
|
||
var $workground = "purchase_manager";
|
||
|
||
/*
|
||
* 供应商列表显示
|
||
*/
|
||
function index(){
|
||
|
||
$singleselect = $_GET['singleselect'];
|
||
if (!$singleselect){
|
||
$actions =
|
||
array(
|
||
array(
|
||
'label'=>'添加供应商',
|
||
'href'=>'index.php?app=purchase&ctl=admin_supplier&act=addsupplier',
|
||
'target' => '_blank',
|
||
),
|
||
array(
|
||
'label' => '导出模板',
|
||
'href' => 'index.php?app=purchase&ctl=admin_supplier&act=exportTemplate',
|
||
'target' => '_blank',
|
||
),
|
||
array(
|
||
'label' => '同步至第三方仓储',
|
||
'submit' => 'index.php?app=purchase&ctl=admin_supplier&act=syncSupplier',
|
||
'target' => 'dialog::{width:400,height:200,title:\'同步至第三方仓储\'}',
|
||
),
|
||
);
|
||
$export = true;
|
||
$import = true;
|
||
$filter = true;
|
||
}
|
||
$export = kernel::single('desktop_user')->has_permission('supplier_export');#增加导出供应商品权限
|
||
$params =
|
||
array(
|
||
'title'=>$this->name,
|
||
'actions' => $actions,
|
||
'use_buildin_new_dialog' => false,
|
||
'use_buildin_set_tag'=>false,
|
||
'use_buildin_recycle'=>true,
|
||
'use_buildin_export'=>$export,
|
||
'use_buildin_import'=>$import,
|
||
'use_buildin_filter'=>$filter,
|
||
'finder_cols'=>'column_edit,name,brief,arrive_days,operator,credit_lv,telphone,addr,zip,bank,fax',
|
||
'orderBy' => 'supplier_id desc',
|
||
);
|
||
$this->finder('purchase_mdl_supplier', $params);
|
||
|
||
}
|
||
|
||
/*
|
||
* 导出模板
|
||
*/
|
||
function exportTemplate(){
|
||
header("Content-Type: text/csv");
|
||
$filename = "供应商模板.csv";
|
||
$encoded_filename = urlencode($filename);
|
||
$encoded_filename = str_replace("+", "%20", $encoded_filename);
|
||
|
||
$ua = $_SERVER["HTTP_USER_AGENT"];
|
||
if (preg_match("/MSIE/", $ua)) {
|
||
header('Content-Disposition: attachment; filename="' . $encoded_filename . '"');
|
||
} else if (preg_match("/Firefox/", $ua)) {
|
||
header('Content-Disposition: attachment; filename*="utf8\'\'' . $filename . '"');
|
||
} else {
|
||
header('Content-Disposition: attachment; filename="' . $filename . '"');
|
||
}
|
||
|
||
header('Cache-Control:must-revalidate,post-check=0,pre-check=0');
|
||
header('Expires:0');
|
||
header('Pragma:public');
|
||
//采购-供应商管理-供应商-模板导出
|
||
$logParams = array(
|
||
'app' => $this->app->app_id,
|
||
'ctl' => trim($_GET['ctl']),
|
||
'act' => trim($_GET['act']),
|
||
'modelFullName' => '',
|
||
'type' => 'export',
|
||
'params' => array(),
|
||
);
|
||
ome_operation_log::insert('purchase_supplierManager_supplier_template_export', $logParams);
|
||
$oSupplier = $this->app->model('supplier');
|
||
$title = $oSupplier->exportTemplate('supplier');
|
||
echo '"'.implode('","',$title).'"';
|
||
}
|
||
|
||
/**
|
||
* 添加供应商
|
||
* @param array
|
||
* @return string
|
||
*/
|
||
function addsupplier(){
|
||
|
||
//调用ome/model/supplier模块
|
||
$oSuuplier = $this->app->model("supplier");
|
||
|
||
if ($_POST['addSubmit']=="do"){
|
||
|
||
unset($_POST['addSubmit']);
|
||
$gotourl = 'index.php?app=purchase&ctl=admin_supplier';
|
||
$this->begin($gotourl);
|
||
//表单验证
|
||
$oSuuplier->validate($_POST);
|
||
$result = $oSuuplier->save_supplierDo($_POST);
|
||
$message = $result ? '保存成功' : '保存失败';
|
||
$this->end($result, app::get('base')->_($message));
|
||
|
||
}else{
|
||
|
||
//信用等级
|
||
$this->pagedata['credit_lev'] = $oSuuplier->getCreditlve();
|
||
//供应品牌
|
||
$this->pagedata['brand'] = $this->app->model("supplier")->getBrand();
|
||
|
||
//显示添加供应商窗口
|
||
$this->singlepage('admin/supplier/add_supplier.html');
|
||
}
|
||
|
||
}
|
||
|
||
/**
|
||
* 编辑供应商
|
||
*
|
||
* @param number
|
||
* @return boolean
|
||
*/
|
||
function editsupplier($supplier_id){
|
||
|
||
if($_POST['arrive_days'] == ''){
|
||
$_POST['arrive_days'] = NULL;
|
||
}
|
||
|
||
//供应商业务模块加载
|
||
$oSupplier = $this->app->model("supplier");
|
||
|
||
if ($_POST['editSubmit']=="do"){
|
||
|
||
unset($_POST['editSubmit']);
|
||
$gotourl = 'index.php?app=purchase&ctl=admin_supplier';
|
||
//echo "<script>$$('.dialog').getLast().retrieve('instance').close();</scr"+"ipt>";
|
||
$this->begin($gotourl);
|
||
//TODO:
|
||
//表单验证
|
||
$oSupplier->validate($_POST);
|
||
$result = $oSupplier->save_supplierDo($_POST,true);
|
||
$msg = $result ? '成功' : '失败';
|
||
$this->end($result, app::get('base')->_('修改'.$msg));
|
||
|
||
|
||
}else{
|
||
|
||
//获取供应商详情
|
||
$filter = array("supplier_id"=>$supplier_id);
|
||
$supplierDetail = $oSupplier->dump($filter,'*');
|
||
|
||
//信用等级
|
||
$this->pagedata['credit_lev'] = $oSupplier->getCreditlve();
|
||
|
||
//读取供应商提供的品牌
|
||
$oBrand = $this->app->model('supplier_brand');
|
||
$filter = array("supplier_id"=>$supplier_id);
|
||
$brand_detail = $oBrand->getlist('*',$filter);
|
||
$oBrandlist = $this->app->model('supplier');
|
||
$brand_detail = array_column($brand_detail, 'brand_id');
|
||
$this->pagedata['brand_detail'] = $brand_detail;
|
||
//读取品牌数据表
|
||
$brandlist = $oBrandlist->getBrand();
|
||
|
||
$supplierDetail['contacter'] = unserialize($supplierDetail['contacter']);
|
||
if (!strstr($supplierDetail['area'],":")){
|
||
$supplierDetail['area_defined'] = true;
|
||
}
|
||
$this->pagedata['detail'] = $supplierDetail;
|
||
$this->pagedata['brandselect'] = $brand;
|
||
$this->pagedata['brandlist'] = $brandlist;
|
||
$this->pagedata['brand_checkbox'] = $brand_checkbox;
|
||
$this->singlepage('admin/supplier/edit_supplier.html');
|
||
}
|
||
}
|
||
|
||
/*
|
||
* 获取采购员 getOperator
|
||
*/
|
||
|
||
public function getOperator()
|
||
{
|
||
$sid = $_GET['sid'];
|
||
if (!is_numeric($sid)) die;
|
||
|
||
$oSupplier = $this->app->model("supplier");
|
||
$operator = $oSupplier->supplier_detail($sid, 'operator');
|
||
if (!$operator['operator']) $operator['operator'] = '未知';
|
||
|
||
echo json_encode($operator);
|
||
}
|
||
|
||
/*
|
||
* 供应商所有采购单预付款
|
||
* @package balance
|
||
* @param int
|
||
*/
|
||
|
||
public function balance($supplier_id=null)
|
||
{
|
||
$oSupplier = $this->app->model("supplier");
|
||
$result = $oSupplier->get_balance($supplier_id);
|
||
//供应商名称
|
||
$supplier = $oSupplier->supplier_detail($supplier_id, 'name');
|
||
|
||
$this->pagedata['supplier_name'] = $supplier['name'];
|
||
$this->pagedata['balance'] = $result;
|
||
$this->display('admin/supplier/balance.html');
|
||
}
|
||
|
||
/*
|
||
* 验证添加的供应商是否存在
|
||
* is_supplier
|
||
*/
|
||
|
||
public function is_supplier()
|
||
{
|
||
$bn = $_POST['bn'];
|
||
$name = $_POST['name'];
|
||
$oSupplier = $this->app->model("supplier");
|
||
if ( $oSupplier->dump(array('bn'=>$bn), 'supplier_id') or $oSupplier->dump(array('name'=>$name), 'supplier_id') )
|
||
{
|
||
die('1');#已存在
|
||
}
|
||
else
|
||
{
|
||
die('0');#未存在
|
||
}
|
||
}
|
||
|
||
|
||
/*
|
||
* 商品历史价格查询
|
||
*/
|
||
/**
|
||
* history_price
|
||
* @param mixed $supplier_id ID
|
||
* @param mixed $goods_id ID
|
||
* @return mixed 返回值
|
||
*/
|
||
public function history_price($supplier_id,$goods_id)
|
||
{
|
||
if(!is_numeric($goods_id) or !is_numeric($supplier_id)) die('访问出错');
|
||
|
||
$basicMaterialObj = app::get('material')->model('basic_material');
|
||
|
||
$oSupplier = $this->app->model("supplier");
|
||
|
||
$his_price = $oSupplier->history_price_search($supplier_id,$goods_id);
|
||
|
||
if ($his_price)
|
||
foreach ($his_price as $k=>$v)
|
||
{
|
||
$products = $basicMaterialObj->dump(array('bm_id'=>$v['product_id']), 'bm_id, material_bn, material_name');
|
||
|
||
$v['name'] = $products['material_name'];
|
||
$v['bn'] = $products['material_bn'];
|
||
$price[] = $v;
|
||
}
|
||
|
||
$this->pagedata['his_price'] = $price;
|
||
$this->display('admin/supplier/history_price.html');
|
||
}
|
||
|
||
/*
|
||
* 品牌选择 choice_brand
|
||
*/
|
||
|
||
public function choice_brand()
|
||
{
|
||
$oBrand = $this->app->model("supplier");
|
||
|
||
//获取品牌
|
||
$this->pagedata['brand'] = $oBrand->getBrand();
|
||
$this->display('admin/supplier/choice_brand.html');
|
||
}
|
||
|
||
/*
|
||
* 供应商查找
|
||
*/
|
||
function getSupplier(){
|
||
|
||
$name = $_GET['name'];
|
||
if ($name){
|
||
$supplier = $this->app->model('supplier');
|
||
$data = $supplier->getSupplier($name);
|
||
|
||
echo "window.autocompleter_json=".json_encode($data);
|
||
}
|
||
}
|
||
|
||
/*
|
||
* 供应商查找 by id
|
||
*/
|
||
function getSupplierById(){
|
||
|
||
$supplier_id = $_POST['id'];
|
||
if ($supplier_id){
|
||
$supplier = $this->app->model('supplier');
|
||
$data = $supplier->dump(array('supplier_id'=>$supplier_id), 'supplier_id,name');
|
||
|
||
//echo json_encode($data);
|
||
echo "{id:'".$data['supplier_id']."',name:'".$data['name']."'}";
|
||
}
|
||
}
|
||
|
||
|
||
/**
|
||
* 同步仓储
|
||
* @param
|
||
* @return
|
||
* @access public
|
||
* @author sunjing@shopex.cn
|
||
*/
|
||
function syncSupplier()
|
||
{
|
||
$wms_list = kernel::single('channel_func')->getWmsChannelList();
|
||
$channelObj = app::get('channel')->model('channel');
|
||
|
||
$third_wmslist = array();
|
||
|
||
foreach($wms_list as $wms){
|
||
|
||
if ($wms['adapter']!='selfwms'){
|
||
$wms_id = $wms['wms_id'];
|
||
|
||
$third_wmslist[]=$wms_id;
|
||
}
|
||
}
|
||
$supplier_id = serialize($_POST['supplier_id']);
|
||
|
||
$channel = $channelObj->getlist('channel_name,channel_id',array('channel_id'=>$third_wmslist),0,-1);
|
||
|
||
$this->pagedata['supplier_id'] = $supplier_id;
|
||
$this->pagedata['channel'] = $channel;
|
||
|
||
$this->display('admin/supplier/sync_branch.html');
|
||
}
|
||
|
||
|
||
/**
|
||
* 同步供应商至仓库
|
||
* @param type $varname description
|
||
* @return type description
|
||
* @access public
|
||
* @author sunjing@shopex.cn
|
||
*/
|
||
function do_syncSupplier()
|
||
{
|
||
|
||
$supplier_id = unserialize($_POST['supplier_id']);
|
||
|
||
$wms_id = $_POST['wms_id'];
|
||
$supplier = $this->app->model('supplier');
|
||
$rs = array('rsp'=>'succ','msg'=>'同步发起成功');
|
||
foreach ($supplier_id as $id ) {
|
||
|
||
$data = $supplier->dump(array('supplier_id'=>$id), 'bn,name,area,addr');
|
||
|
||
$result = kernel::single('console_event_trigger_supplier')->create($wms_id, $data, false);
|
||
if ($result && $result['error_code'] == 'w402') {
|
||
$rs = array('rsp'=>'fail','msg'=>$result['msg']);
|
||
break;
|
||
}
|
||
}
|
||
echo json_encode($rs);
|
||
}
|
||
|
||
|
||
/**
|
||
* Short description.
|
||
* @param type $varname description
|
||
* @return type description
|
||
* @access public
|
||
* @author cyyr24@sina.cn
|
||
*/
|
||
function test()
|
||
{
|
||
$supplier = $this->app->model('supplier');
|
||
$data = $supplier->dump(array('supplier_id'=>5), 'bn,name,area,addr');
|
||
|
||
$result = kernel::single('console_event_trigger_supplier')->create(3, $data, false);
|
||
print_r($result);
|
||
}
|
||
}
|
||
?>
|