Cherry 1 rok pred
rodič
commit
dd1587379e

+ 2 - 95
README.md

@@ -1,97 +1,4 @@
 FastAdmin是一款基于ThinkPHP+Bootstrap的极速后台开发框架。
 
-
-## 主要特性
-
-* 基于`Auth`验证的权限管理系统
-    * 支持无限级父子级权限继承,父级的管理员可任意增删改子级管理员及权限设置
-    * 支持单管理员多角色
-    * 支持管理子级数据或个人数据
-* 强大的一键生成功能
-    * 一键生成CRUD,包括控制器、模型、视图、JS、语言包、菜单、回收站等
-    * 一键压缩打包JS和CSS文件,一键CDN静态资源部署
-    * 一键生成控制器菜单和规则
-    * 一键生成API接口文档
-* 完善的前端功能组件开发
-    * 基于`AdminLTE`二次开发
-    * 基于`Bootstrap`开发,自适应手机、平板、PC
-    * 基于`RequireJS`进行JS模块管理,按需加载
-    * 基于`Less`进行样式开发
-* 强大的插件扩展功能,在线安装卸载升级插件
-* 通用的会员模块和API模块
-* 共用同一账号体系的Web端会员中心权限验证和API接口会员权限验证
-* 二级域名部署支持,同时域名支持绑定到应用插件
-* 多语言支持,服务端及客户端支持
-* 支持大文件分片上传、剪切板粘贴上传、拖拽上传,进度条显示,图片上传前压缩
-* 支持表格固定列、固定表头、跨页选择、Excel导出、模板渲染等功能
-* 强大的第三方应用模块支持([CMS](https://www.fastadmin.net/store/cms.html)、[博客](https://www.fastadmin.net/store/blog.html)、[知识付费问答](https://www.fastadmin.net/store/ask.html)、[在线投票系统](https://www.fastadmin.net/store/vote.html)、[B2C商城](https://www.fastadmin.net/store/shopro.html)、[B2B2C商城](https://www.fastadmin.net/store/wanlshop.html))
-* 支持CMS、博客、知识付费问答无缝整合[Xunsearch全文搜索](https://www.fastadmin.net/store/xunsearch.html)
-* 第三方小程序支持([CMS小程序](https://www.fastadmin.net/store/cms.html)、[预订小程序](https://www.fastadmin.net/store/ball.html)、[问答小程序](https://www.fastadmin.net/store/ask.html)、[点餐小程序](https://www.fastadmin.net/store/unidrink.html)、[B2C小程序](https://www.fastadmin.net/store/shopro.html)、[B2B2C小程序](https://www.fastadmin.net/store/wanlshop.html)、[博客小程序](https://www.fastadmin.net/store/blog.html))
-* 整合第三方短信接口(阿里云、腾讯云短信)
-* 无缝整合第三方云存储(七牛云、阿里云OSS、又拍云)功能,支持云储存分片上传
-* 第三方富文本编辑器支持(Summernote、Kindeditor、百度编辑器)
-* 第三方登录(QQ、微信、微博)整合
-* 第三方支付(微信、支付宝)无缝整合,微信支持PC端扫码支付
-* 丰富的插件应用市场
-
-## 安装使用
-
-https://doc.fastadmin.net
-
-## 在线演示
-
-https://demo.fastadmin.net
-
-用户名:admin
-
-密 码:123456
-
-提 示:演示站数据无法进行修改,请下载源码安装体验全部功能
-
-## 界面截图
-![控制台](https://images.gitee.com/uploads/images/2020/0929/202947_8db2d281_10933.gif "控制台")
-
-## 问题反馈
-
-在使用中有任何问题,请使用以下联系方式联系我们
-
-交流社区: https://ask.fastadmin.net
-
-QQ 1 群(满)、QQ 2 群(满)、QQ 3 群(满)、QQ 4 群(满)、QQ 5 群(满)、QQ 6 群(满)、[QQ 7 群](https://www.fastadmin.net/goto/qun)。
-
-Github: https://github.com/karsonzhang/fastadmin
-
-Gitee: https://gitee.com/karson/fastadmin
-
-## 特别鸣谢
-
-感谢以下的项目,排名不分先后
-
-ThinkPHP:http://www.thinkphp.cn
-
-AdminLTE:https://adminlte.io
-
-Bootstrap:http://getbootstrap.com
-
-jQuery:http://jquery.com
-
-Bootstrap-table:https://github.com/wenzhixin/bootstrap-table
-
-Nice-validator: https://validator.niceue.com
-
-SelectPage: https://github.com/TerryZ/SelectPage
-
-Layer: https://layuion.com/layer/
-
-DropzoneJS: https://www.dropzonejs.com
-
-
-## 版权信息
-
-FastAdmin遵循Apache2开源协议发布,并提供免费使用。
-
-本项目包含的第三方源码和二进制文件之版权信息另行标注。
-
-版权所有Copyright © 2017-2022 by FastAdmin (https://www.fastadmin.net)
-
-All rights reserved。
+## (配置Supervision)
+php think queue:listen --queue shopro,yutang_order

+ 41 - 1
application/admin/controller/Prizelog.php

@@ -2,7 +2,10 @@
 
 namespace app\admin\controller;
 
+use app\admin\model\shopro\Express;
 use app\common\controller\Backend;
+use think\Db;
+use think\Exception;
 
 /**
  * 中奖记录
@@ -58,7 +61,7 @@ class Prizelog extends Backend
                     ->paginate($limit);
 
             foreach ($list as $row) {
-                $row->visible(['id','user_id','p_id','name','type','status','user_name','phone','city','address','createtime']);
+                $row->visible(['id','user_id','p_id','name','type','status','user_name','phone','city','address','createtime','express_no','express_name']);
                 $row->visible(['user']);
 				$row->getRelation('user')->visible(['username']);
             }
@@ -71,4 +74,41 @@ class Prizelog extends Backend
         return $this->view->fetch();
     }
 
+
+
+    /**
+     * 发货
+     */
+    public function send($ids)
+    {
+        $row = $this->model->get(['id' => $ids]);
+        if (!$row) {
+            $this->error(__('No Results were found'));
+        }
+
+        if ($this->request->isPost()) {
+            $params = $this->request->post('row/a');
+            if (empty($params)) {
+                $this->error(__('Parameter %s can not be empty', ''));
+            }
+            $params = $this->preExcludeFields($params);
+            //发货参数
+            $params['express_name'] = (new Express())->where('code',$params['express_code'])->value('name');
+            $params['status'] = 3;
+            Db::startTrans();
+            try {
+                $this->model->allowField(true)->isUpdate(true)->save($params);
+
+                Db::commit();
+                $this->success("成功", null, ['id' => $ids]);
+            } catch (Exception $e) {
+                Db::rollback();
+                $this->error('失败');
+            }
+        }
+
+        $this->view->assign("row", $row->toArray());
+        return $this->view->fetch();
+    }
+
 }

+ 30 - 1
application/admin/controller/shopro/Express.php

@@ -154,7 +154,7 @@ class Express extends Backend
 
     public function select()
     {
-            if ($this->request->isAjax()) {
+        if ($this->request->isAjax()) {
             $searchWhere = $this->request->request('searchWhere');
             list($where, $sort, $order, $offset, $limit) = $this->buildparams();
             $total = $this->model
@@ -182,4 +182,33 @@ class Express extends Backend
         }
     }
 
+    public function jsonselect()
+    {
+        if ($this->request->isAjax()) {
+            $searchWhere = $this->request->request('name');
+            list($where, $sort, $order, $offset, $limit) = $this->buildparams();
+            $total = $this->model
+                ->where($where)
+                ->whereOr('id', '=', $searchWhere)
+                ->whereOr('name', 'like', "%$searchWhere%")
+                ->whereOr('code', 'like', "%$searchWhere%")
+                ->order($sort, $order)
+                ->count();
+
+            $list = $this->model
+                ->field('name, code')
+                ->where($where)
+                ->whereOr('id', '=', $searchWhere)
+                ->whereOr('name', 'like', "%$searchWhere%")
+                ->whereOr('code', 'like', "%$searchWhere%")
+                ->order('weigh desc')
+                ->limit($offset, $limit)
+                ->select();
+
+            $list = collection($list)->toArray();
+            $result = array("total" => $total, "rows" => $list,"where"=>$searchWhere);
+
+            return json($result);
+        }
+    }
 }

+ 3 - 1
application/admin/lang/zh-cn/prizelog.php

@@ -11,6 +11,7 @@ return [
     'Status 0'      => '已抽奖',
     'Status 1'      => '已到账',
     'Status 2'      => '地址已提交',
+    'Status 3'      => '已发货',
     'User_name'     => '收件人姓名',
     'Phone'         => '手机号',
     'Province_id'   => '省',
@@ -19,5 +20,6 @@ return [
     'City'          => '省市区',
     'Address'       => '详细地址',
     'Createtime'    => '中奖时间',
-    'User.username' => '用户名'
+    'Express_name'  => '快递公司',
+    'Express_no'    => '快递单号',
 ];

+ 1 - 1
application/admin/model/PrizeLog.php

@@ -38,7 +38,7 @@ class PrizeLog extends Model
 
     public function getStatusList()
     {
-        return ['0' => __('Status 0'), '1' => __('Status 1'), '2' => __('Status 2')];
+        return ['0' => __('Status 0'), '1' => __('Status 1'), '2' => __('Status 2'), '3' => __('Status 3')];
     }
 
 

+ 35 - 0
application/admin/view/prizelog/send.html

@@ -0,0 +1,35 @@
+<!--<script src="/assets/libs/fastadmin-selectpage/selectpage.js"></script>-->
+<form id="edit-form" class="form-horizontal" role="form" data-toggle="validator" method="POST" action="">
+
+    {:token()}
+    <input type="hidden" name="row[id]" value="{$row.id}">
+
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">快递公司:</label>
+        <div class="col-xs-12 col-sm-8">
+            <input id="c-express_code" data-rule="required"
+                   data-source="shopro/express/jsonselect" data-pagination="true" data-page-size="10"  class="form-control selectpage" name="row[express_code]"
+                   type="text" data-field="name" data-primary-key="code" value="{$row.express_code|htmlentities}">
+        </div>
+    </div>
+
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">快递单号:</label>
+        <div class="col-xs-12 col-sm-8">
+            <input id="c-express_no" type="text" class="form-control" data-rule="required" name="row[express_no]"
+                   value="{$row.express_no|htmlentities}"/>
+        </div>
+    </div>
+
+    <div class="hide layer-footer">
+        <label class="control-label col-xs-12 col-sm-2"></label>
+        <div class="col-xs-12 col-sm-8">
+            <button type="submit" class="btn btn-primary btn-embossed ">{:__('OK')}</button>
+
+            <button type="reset" class="btn btn-primary btn-embossed btn-close" onclick="Layer.closeAll();">
+                {:__('Close')}
+            </button>
+        </div>
+    </div>
+</form>
+

+ 25 - 2
public/assets/js/backend/prizelog.js

@@ -10,6 +10,7 @@ define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefin
                     // edit_url: 'prizelog/edit',
                     // del_url: 'prizelog/del',
                     // multi_url: 'prizelog/multi',
+                    send_url: 'prizelog/send',
                     import_url: 'prizelog/import',
                     table: 'prize_log',
                 }
@@ -33,13 +34,32 @@ define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefin
                         {field: 'p_id', title: __('P_id')},
                         {field: 'name', title: __('Name'), operate: 'LIKE'},
                         {field: 'type', title: __('Type'), searchList: {"1":__('Type 1'),"2":__('Type 2')}, formatter: Table.api.formatter.normal},
-                        {field: 'status', title: __('Status'), searchList: {"0":__('Status 0'),"1":__('Status 1'),"2":__('Status 2')}, formatter: Table.api.formatter.status},
+                        {field: 'status', title: __('Status'), searchList: {"0":__('Status 0'),"1":__('Status 1'),"2":__('Status 2'),"3": __('Status 3')}, formatter: Table.api.formatter.status},
                         {field: 'user_name', title: __('User_name'), operate: 'LIKE'},
                         {field: 'phone', title: __('Phone'), operate: 'LIKE'},
                         {field: 'city', title: __('City'), operate: 'LIKE'},
                         {field: 'address', title: __('Address'), operate: 'LIKE'},
+                        {field: 'express_name', title: __('Express_name'), },
+                        {field: 'express_no', title: __('Express_no'), },
                         {field: 'createtime', title: __('Createtime'), operate:'RANGE', addclass:'datetimerange', autocomplete:false, formatter: Table.api.formatter.datetime},
-                       // {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
+                        {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate,
+                            buttons:[
+                                {
+                                    name:'send',
+                                    text: '立即发货',
+                                    classname: 'btn btn-xs btn-info btn-dialog',
+                                    icon: 'fa fa-rotate-left',
+                                    url: $.fn.bootstrapTable.defaults.extend.send_url,
+                                    visible:function(row){
+                                        if(row['status']==2 && row['type']==1){
+                                            return true;
+                                        }else{
+                                            return false;
+                                        }
+                                    },
+                                }
+                            ]
+                        }
                     ]
                 ]
             });
@@ -53,6 +73,9 @@ define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefin
         edit: function () {
             Controller.api.bindevent();
         },
+        send: function () {
+           Controller.api.bindevent();
+        },
         api: {
             bindevent: function () {
                 Form.api.bindevent($("form[role=form]"));