Browse Source

feat(api): 添加订单管理功能和公共接口

- 新增订单管理相关接口和功能,包括订单列表、详情和创建
- 添加获取全部课程列表和班级列表的公共接口
- 在路由中注册新接口
- 实现订单管理的服务层逻辑
master
liutong 10 months ago
parent
commit
03c3ab95a9
  1. 18
      niucloud/app/api/controller/apiController/Common.php
  2. 120
      niucloud/app/api/controller/apiController/OrderTable.php
  3. 12
      niucloud/app/api/route/route.php
  4. 5
      niucloud/app/model/order_table/OrderTable.php
  5. 26
      niucloud/app/service/api/apiService/CommonService.php
  6. 128
      niucloud/app/service/api/apiService/OrderTableService.php

18
niucloud/app/api/controller/apiController/Common.php

@ -92,5 +92,23 @@ class Common extends BaseApiService
return success($res['data']);
}
//获取全部课程列表
public function getCourseAll(Request $request)
{
$where = [];
$res = (new CommonService())->getCourseAllList($where);
return success($res);
}
//获取全部班级列表
public function getClassAll(Request $request)
{
$where = [
'status' => $request->param('status', '')
];
$res = (new CommonService())->getClassAllList($where);
return success($res);
}
}

120
niucloud/app/api/controller/apiController/OrderTable.php

@ -0,0 +1,120 @@
<?php
// +----------------------------------------------------------------------
// | Niucloud-admin 企业快速开发的多应用管理平台
// +----------------------------------------------------------------------
// | 官方网址:https://www.niucloud.com
// +----------------------------------------------------------------------
// | niucloud团队 版权所有 开源版本可自由商用
// +----------------------------------------------------------------------
// | Author: Niucloud Team
// +----------------------------------------------------------------------
namespace app\api\controller\apiController;
use app\Request;
use app\service\api\apiService\CampusService;
use app\service\api\apiService\ChatService;
use app\service\api\apiService\CommonService;
use app\service\api\apiService\CourseService;
use app\service\api\apiService\OrderTableService;
use core\base\BaseApiService;
/**
* 订单-控制器相关接口
* Class Personnel
* @package app\api\controller\apiController
*/
class OrderTable extends BaseApiService
{
//订单-列表
public function index(Request $request)
{
$resource_id = $request->param('resource_id', '');//客户资源表school_customer_resources表id(两个参数2选1)
$staff_id = $request->param('staff_id', '');//员工表school_personnel表id(两个参数2选1)
if (empty($resource_id) && empty($staff_id)) {
return fail('缺少参数');
}
$where = [
'resource_id' => $resource_id,
'staff_id' => $staff_id,
];
$res = (new OrderTableService())->getList($where);
return success($res);
}
//订单-详情
public function info(Request $request)
{
$resource_id = $request->param('resource_id', '');//客户资源表school_customer_resources表id(两个参数2选1)
$staff_id = $request->param('staff_id', '');//员工表school_personnel表id(两个参数2选1)
if (empty($resource_id) && empty($staff_id)) {
return fail('缺少参数');
}
$where = [
'resource_id' => $resource_id,
'staff_id' => $staff_id,
];
$res = (new OrderTableService())->getInfo($where);
if (!$res['code']) {
return fail($res['msg']);
}
return success($res['data']);
}
//订单-创建
public function add(Request $request)
{
$params = $request->params([
["payment_type", ""], // 付款类型必填验证
["course_id", ""], // 课程ID必填验证
["class_id", ""], // 班级ID必填验证
["staff_id", ""], // 员工ID必填验证
["resource_id", ""], // 客户资源表ID必填验证
]);
foreach($params as $k=>$v){
if(empty($v)){
return fail('缺少参数');
}
}
$course = \app\model\course\Course::where('id', $params['course_id'])->find();
if (!$course) {
return fail('课程不存在');
}
$course = $course->toArray();
$order_amount = $course['price'];//课程的价格
$data = [
'payment_type' => $params['payment_type'],//付款类型: cash-现金支付, scan_code-扫码支付, subscription-订阅支付
'order_amount' => $order_amount,//订单金额
'course_id' => $params['course_id'],//课程ID
'class_id' => $params['class_id'],//班级ID
'staff_id' => $params['staff_id'],//员工表ID
'resource_id' => $params['resource_id'],//客户资源表id
];
$res = (new OrderTableService())->addData($data);
if (!$res['code']) {
return fail($res['msg']);
}
return success([]);
}
}

12
niucloud/app/api/route/route.php

@ -183,6 +183,11 @@ Route::group(function () {
//获取微信小程序openid
Route::post('common/getMiniWxOpenId', 'apiController.Common/getMiniWxOpenId');
//公共端-获取全部课程列表
Route::get('common/getCourseAll', 'apiController.Common/getCourseAll');
//公共端-获取全部班级列表
Route::get('common/getClassAll', 'apiController.Common/getClassAll');
@ -267,6 +272,13 @@ Route::group(function () {
//员工端-用户聊天-修改未读消息数量
Route::post('chat/editUnreadCount', 'apiController.Chat/editUnreadCount');
//员工端-订单管理-列表
Route::get('orderTable', 'apiController.OrderTable/index');
//员工端-订单管理-详情
Route::get('orderTable/info', 'apiController.OrderTable/info');
//员工端-订单管理-创建
Route::post('orderTable/add', 'apiController.OrderTable/add');

5
niucloud/app/model/order_table/OrderTable.php

@ -78,19 +78,22 @@ class OrderTable extends BaseModel
//客户资源表-客户姓名
public function customerResources(){
return $this->hasOne(CustomerResources::class, 'id', 'resource_id')->joinType('left')->withField('name,id')->bind(['resource_id_name'=>'name']);
}
//课程表-课程名称
public function course(){
return $this->hasOne(Course::class, 'id', 'course_id')->joinType('left')->withField('course_name,id')->bind(['course_id_name'=>'course_name']);
}
//班级表-班级名称
public function classGrade(){
return $this->hasOne(ClassGrade::class, 'id', 'class_id')->joinType('left')->withField('class_name,id')->bind(['class_id_name'=>'class_name']);
}
//员工表-员工姓名
public function personnel(){
return $this->hasOne(Personnel::class, 'id', 'staff_id')->joinType('left')->withField('name,id')->bind(['staff_id_name'=>'name']);
}

26
niucloud/app/service/api/apiService/CommonService.php

@ -11,6 +11,8 @@
namespace app\service\api\apiService;
use app\model\class_grade\ClassGrade;
use app\model\course\Course;
use app\model\dict\Dict;
use app\model\member\Member;
use app\model\sys\SysConfig;
@ -265,5 +267,29 @@ class CommonService extends BaseApiService
];
}
//获取全部课程列表
public function getCourseAllList(array $where, string $field = '*')
{
$model = (new Course());
$res = $model->field($field)
->select()
->toArray();//员工信息
return $res;
}
//获取全部班级列表
public function getClassAllList(array $where, string $field = '*')
{
$model = (new ClassGrade());
if(!empty($where['status'])){
$model = $model->where('status',$where['status']);
}
$res = $model->field($field)
->select()
->toArray();//员工信息
return $res;
}
}

128
niucloud/app/service/api/apiService/OrderTableService.php

@ -0,0 +1,128 @@
<?php
// +----------------------------------------------------------------------
// | Niucloud-admin 企业快速开发的多应用管理平台
// +----------------------------------------------------------------------
// | 官方网址:https://www.niucloud.com
// +----------------------------------------------------------------------
// | niucloud团队 版权所有 开源版本可自由商用
// +----------------------------------------------------------------------
// | Author: Niucloud Team
// +----------------------------------------------------------------------
namespace app\service\api\apiService;
use app\model\campus\Campus;
use app\model\campus_person_role\CampusPersonRole;
use app\model\chat_friends\ChatFriends;
use app\model\chat_messages\ChatMessages;
use app\model\dict\Dict;
use app\model\order_table\OrderTable;
use core\base\BaseApiService;
use think\facade\Db;
/**
* 订单管理-控制器服务层
* Class MemberService
* @package app\service\api\member
*/
class OrderTableService extends BaseApiService
{
public function __construct()
{
parent::__construct();
}
//查询列表
public function getList(array $where)
{
$page_params = $this->getPageParam();//获取请求参数中的页码+分页数
$page = $page_params['page'];
$limit = $page_params['limit'];
$model = new OrderTable();
//员工表id
if (!empty($where['staff_id'])) {
$model = $model->where('staff_id', $where['staff_id']);
}
//客户资源表id
if (!empty($where['resource_id'])) {
$model = $model->where('resource_id', $where['resource_id']);
}
$data = $model
->append([
'customerResources',
'course',
'classGrade',
'personnel'
])
->order('id','desc')
->paginate([
'list_rows' => $limit,
'page' => $page,
])->toArray();
return $data;
}
//查询详情
public function getInfo(array $where)
{
$model = new OrderTable();
//判断用没有员工id
if (!empty($where['staff_id'])) {
$model = $model->where('staff_id', $where['staff_id']);
}
//判断用没有客户资源id
if (!empty($where['resource_id'])) {
$model = $model->where('resource_id', $where['resource_id']);
}
$data = $model
->append([
'customerResources',
'course',
'classGrade',
'personnel'
])
->find();
if ($data) {
$data = $data->toArray();
$res = [
'code' => 1,
'msg' => '操作成功',
'data' => $data
];
return $res;
} else {
$res = [
'code' => 0,
'msg' => '暂无数据',
'data' => []
];
return $res;
}
}
//创建订单
public function addData(array $data)
{
$success = OrderTable::create($data);
$res = [
'code' => 1,
'msg' => '操作成功',
'data' => []
];
if (!$success) {
$res = [
'code' => 0,
'msg' => '操作失败',
'data' => []
];
}
return $res;
}
}
Loading…
Cancel
Save