Files
ProxyPanel/app/Http/Controllers/Admin/CouponController.php
2020-08-05 03:51:27 +08:00

206 lines
7.4 KiB
PHP
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
<?php
namespace App\Http\Controllers\Admin;
use App\Http\Controllers\Controller;
use App\Models\Coupon;
use DB;
use Exception;
use Illuminate\Http\JsonResponse;
use Illuminate\Http\Request;
use Log;
use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
use Redirect;
use Response;
use Validator;
/**
* 优惠券控制器
*
* Class CouponController
*
* @package App\Http\Controllers\Controller
*/
class CouponController extends Controller {
// 优惠券列表
public function couponList(Request $request): \Illuminate\Http\Response {
$sn = $request->input('sn');
$type = $request->input('type');
$status = $request->input('status');
$query = Coupon::query();
if(isset($sn)){
$query->where('sn', 'like', '%'.$sn.'%');
}
if(isset($type)){
$query->whereType($type);
}
if(isset($status)){
$query->whereStatus($status);
}
$view['couponList'] = $query->orderByDesc('id')->paginate(15)->appends($request->except('page'));
return Response::view('admin.coupon.couponList', $view);
}
// 添加商品
public function addCoupon(Request $request) {
if($request->isMethod('POST')){
Validator::make($request->all(), [
'name' => 'required',
'sn' => 'unique:coupon',
'type' => 'required|integer|between:1,3',
'usage_count' => 'required|integer',
'num' => 'required|integer|min:1',
'amount' => 'required_unless:type,2|numeric|min:0.01|nullable',
'discount' => 'required_if:type,2|numeric|between:1,9.9|nullable',
'available_start' => 'required|date|before_or_equal:available_end',
'available_end' => 'required|date|after_or_equal:available_start',
], [
'name.required' => '请填入卡券名称',
'type.required' => '请选择卡券类型',
'type.integer' => '卡券类型不合法,请重选',
'type.between' => '卡券类型不合法,请重选',
'usage_count.required' => '请选择卡券用途',
'usage_count.integer' => '卡券用途不合法,请重选',
'usage_count.between' => '卡券用途不合法,请重选',
'num.required' => '请填写卡券数量',
'num.integer' => '卡券数量不合法',
'num.min' => '卡券数量不合法最小1',
'amount.required_unless' => '请填入卡券面值',
'amount.numeric' => '卡券金额不合法',
'amount.min' => '卡券金额不合法最小0.01',
'discount.required_if' => '请填入卡券折扣',
'discount.numeric' => '卡券折扣不合法',
'discount.between' => '卡券折扣不合法有效范围1 ~ 9.9',
'available_start.required' => '请填入有效期',
'available_start.date' => '有效期不合法',
'available_start.before_or_equal' => '有效期不合法',
'available_end.required' => '请填入有效期',
'available_end.date' => '有效期不合法',
'available_end.after_or_equal' => '有效期不合法'
]);
$type = $request->input('type');
// 优惠卷LOGO
$logo = '';
if($request->hasFile('logo')){
$logo = $this->uploadFile($request->file('logo'));
if(!$logo){
return Redirect::back()->withInput()->withErrors('LOGO不合法');
}
}
try{
DB::beginTransaction();
$num = $request->input('num');
for($i = 0; $i < $num; $i++){
$obj = new Coupon();
$obj->name = $request->input('name');
$obj->logo = $logo;
$obj->sn = $num == 1 && $request->input('sn')? $request->input('sn') : makeRandStr(8);
$obj->type = $type;
$obj->usage_count = $request->input('usage_count');
$obj->amount = $type == 2? 0 : $request->input('amount');
$obj->discount = $type != 2? 0 : $request->input('discount');
$obj->rule = $request->input('rule');
$obj->available_start = strtotime(date('Y-m-d 00:00:00',
strtotime($request->input('available_start'))));
$obj->available_end = strtotime(date('Y-m-d 23:59:59',
strtotime($request->input('available_end'))));
$obj->status = 0;
$obj->save();
}
DB::commit();
return Redirect::back()->with('successMsg', '生成成功');
}catch(Exception $e){
DB::rollBack();
Log::error('生成优惠券失败:'.$e->getMessage());
return Redirect::back()->withInput()->withErrors('生成失败:'.$e->getMessage());
}
}else{
return Response::view('admin.coupon.addCoupon');
}
}
// 删除优惠券
public function delCoupon(Request $request): JsonResponse {
Coupon::query()->whereId($request->input('id'))->delete();
return Response::json(['status' => 'success', 'data' => '', 'message' => '删除成功']);
}
// 导出卡券
public function exportCoupon(): void {
$voucherList = Coupon::type(1)->whereStatus(0)->get();
$discountCouponList = Coupon::type(2)->whereStatus(0)->get();
$refillList = Coupon::type(3)->whereStatus(0)->get();
$filename = '卡券'.date('Ymd').'.xlsx';
$spreadsheet = new Spreadsheet();
$spreadsheet->getProperties()
->setCreator('ProxyPanel')
->setLastModifiedBy('ProxyPanel')
->setTitle('邀请码')
->setSubject('邀请码')
->setDescription('')
->setKeywords('')
->setCategory('');
// 抵用券
$spreadsheet->setActiveSheetIndex(0);
$sheet = $spreadsheet->getActiveSheet();
$sheet->setTitle('抵用券');
$sheet->fromArray(['名称', '使用次数', '有效期', '券码', '金额(元)', '使用限制(元)'], null);
foreach($voucherList as $k => $vo){
$dateRange = date('Y-m-d', $vo->available_start).' ~ '.date('Y-m-d', $vo->available_end);
$sheet->fromArray([$vo->name, $vo->usage_count, $dateRange, $vo->sn, $vo->amount, $vo->rule], null,
'A'.($k + 2));
}
// 折扣券
$spreadsheet->createSheet(1);
$spreadsheet->setActiveSheetIndex(1);
$sheet = $spreadsheet->getActiveSheet();
$sheet->setTitle('折扣券');
$sheet->fromArray(['名称', '使用次数', '有效期', '券码', '折扣(折)', '使用限制(元)'], null);
foreach($discountCouponList as $k => $vo){
$dateRange = date('Y-m-d', $vo->available_start).' ~ '.date('Y-m-d', $vo->available_end);
$sheet->fromArray([$vo->name, $vo->usage_count, $dateRange, $vo->sn, $vo->discount, $vo->rule], null,
'A'.($k + 2));
}
// 充值券
$spreadsheet->createSheet(2);
$spreadsheet->setActiveSheetIndex(2);
$sheet = $spreadsheet->getActiveSheet();
$sheet->setTitle('充值券');
$sheet->fromArray(['名称', '有效期', '券码', '金额(元)'], null);
foreach($refillList as $k => $vo){
$dateRange = date('Y-m-d', $vo->available_start).' ~ '.date('Y-m-d', $vo->available_end);
$sheet->fromArray([$vo->name, $dateRange, $vo->sn, $vo->amount], null, 'A'.($k + 2));
}
// 指针切换回第一个sheet
$spreadsheet->setActiveSheetIndex(0);
header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'); // 输出07Excel文件
//header('Content-Type:application/vnd.ms-excel'); // 输出Excel03版本文件
header('Content-Disposition: attachment;filename="'.$filename.'"');
header('Cache-Control: max-age=0');
$writer = new Xlsx($spreadsheet);
$writer->save('php://output');
}
}