123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406 |
- <?php
- namespace app\api\controller\company;
- use app\common\controller\Apic;
- use think\Db;
- use think\Exception;
- use GuzzleHttp\Client;
- /**
- * 套餐管理
- */
- class Package extends Apic
- {
- protected $noNeedLogin = [];
- protected $noNeedRight = '*';
- //列表
- public function lists(){
- $status = input('status',1);
- $keyword = input('keyword','');
- $where = [
- 'p.company_id' => $this->auth->company_id,
- 'p.status' => $status,
- ];
- if(!empty($keyword)){
- $where['p.title|p.info'] = ['LIKE','%'.$keyword.'%'];
- }
- $list = Db::name('package')->alias('p')
- ->field('p.*,type.title as servicetype_title')
- ->join('servicetype type','p.servicetype_id = type.id','LEFT')
- ->where($where)->order('p.id desc')->autopage()->select();
- //追加赠送
- if(!empty($list)){
- $package_ids = array_column($list,'id');
- $gift = Db::name('package_gift')->alias('gift')
- ->field('gift.*,coupons.name,coupons.info,coupons.days')
- ->join('coupons','gift.coupon_id = coupons.id','LEFT')
- ->where('gift.package_id','IN',$package_ids)
- ->where('coupons.status',1)
- ->select();
- foreach($list as $key => &$val){
- $val['gift'] = [];
- foreach($gift as $k => $v){
- if($val['id'] == $v['package_id']){
- $val['gift'][] = $v;
- }
- }
- }
- }
- $list = list_domain_image($list,['images','content_images']);
- $this->success(1,$list);
- }
- //新增
- public function add(){
- Db::startTrans();
- try {
- //验证
- if($this->auth->type != 1){
- throw new Exception('只有门店老板才能设置');
- }
- $field = ['title','info','servicetype_id','images','price','oldprice','num','content','content_images','type'];
- $data = request_post_hub($field);
- $data['company_id'] = $this->auth->company_id;
- $data['createtime'] = time();
- $data['updatetime'] = time();
- $data['status'] = 1;
- $package_id = Db::name('package')->insertGetId($data);
- if (!$package_id) {
- throw new Exception('添加套餐失败');
- }
- $fileName = md5($package_id);
- $fileUrl = '/uploads/package/'.$fileName.'.png';
- Db::name('package')->where('id',$package_id)->update(['mini_code'=>$fileUrl]);
- if (isset($data['type']) && $data['type'] == 2) {
- $gift_data = input('gift_data','','trim');
- $gift_data = json_decode(htmlspecialchars_decode($gift_data),true);
- if(is_array($gift_data) && !empty($gift_data)){
- $package_gift = [];
- foreach($gift_data as $key => $val){
- $package_gift[] = [
- 'package_id' => $package_id,
- 'coupon_id' => $val['coupon_id'],
- 'number' => $val['number'],
- ];
- }
- if(!empty($package_gift)){
- $rs_gift = Db::name('package_gift')->insertAll($package_gift);
- if($rs_gift === false){
- Db::rollback();
- $this->error('添加失败');
- }
- }
- }
- }
- Db::commit();
- //生成小程序码
- $this->getMiniCode($package_id,[],$this->auth->company_id);
- $this->success('添加成功');
- } catch (Exception $e) {
- Db::rollback();
- $this->error($e->getMessage());
- }
- }
- //上下架
- public function changestatus(){
- //验证
- if($this->auth->type != 1){
- $this->error('只有门店老板才能设置');
- }
- $id = input('id',0);
- $status = Db::name('package')->where('id',$id)->value('status');
- $new_status = $status == 1 ? 0 : 1;
- $info = Db::name('package')->where('id',$id)->update(['status'=>$new_status,'updatetime'=>time()]);
- $this->success();
- }
- //详情
- public function info(){
- $id = input('id',0);
- $info = Db::name('package')->alias('p')
- ->field('p.*,type.title as servicetype_title')
- ->join('servicetype type','p.servicetype_id = type.id','LEFT')
- ->where('p.id',$id)->find();
- //追加赠送
- if(!empty($info)){
- $gift = Db::name('package_gift')->alias('gift')
- ->field('gift.*,coupons.name,coupons.info,coupons.days')
- ->join('coupons','gift.coupon_id = coupons.id','LEFT')
- ->where('gift.package_id',$id)
- ->where('coupons.status',1)
- ->select();
- $info['gift'] = [];
- if (!empty($gift)) {
- foreach($gift as $k => $v){
- $info['gift'][] = $v;
- }
- }
- }
- $info = info_domain_image($info,['images','content_images']);
- $this->success(1,$info);
- }
- //编辑
- public function edit(){
- Db::startTrans();
- try {
- //验证
- if($this->auth->type != 1){
- throw new Exception('只有门店老板才能设置');
- }
- $id = input('id','');
- $check = Db::name('package')->where('id',$id)->where('company_id',$this->auth->company_id)->lock(true)->find();
- if(empty($check)){
- throw new Exception('不存在的套餐');
- }
- //
- $field = ['title','info','servicetype_id','images','price','oldprice','num','content','content_images'];
- $data = request_post_hub($field);
- $data['updatetime'] = time();
- $fileName = md5($id);
- $fileUrl = '/uploads/package/'.$fileName.'.png';
- $data['mini_code'] = $fileUrl;
- $packageRes = Db::name('package')->where('id',$id)->update($data);
- if (!$packageRes) {
- throw new Exception('套餐编辑失败');
- }
- if ($check['type'] == 2) {
- $packageGiftWhere['package_id'] = $id;
- $packageGiftData = Db::name('package_gift')->where($packageGiftWhere)->select();
- $gift_data = input('gift_data','','trim');
- $gift_data = json_decode(htmlspecialchars_decode($gift_data),true);
- if(is_array($gift_data) && !empty($gift_data)) {
- $packageGiftCouponIds = array_column($packageGiftData,'coupon_id');
- $postCouponIds = array_column($gift_data,'coupon_id');
- $package_gift = [];
- $same = [];
- $different = [];
- foreach ($gift_data as $key => $val) {
- if (in_array($val['coupon_id'], $packageGiftCouponIds)) {
- $same[] = [
- 'package_id' => $id,
- 'coupon_id' => $val['coupon_id'],
- 'number' => $val['number'],
- ];
- } else {
- $different[] = [
- 'package_id' => $id,
- 'coupon_id' => $val['coupon_id'],
- 'number' => $val['number'],
- ];
- }
- }
- if (!empty($same)) {//相同的更新
- foreach ($same as $sameKey => $sameVal) {
- $sameWhere['package_id'] = $sameVal['package_id'];
- $sameWhere['coupon_id'] = $sameVal['coupon_id'];
- $sameData['number'] = $sameVal['number'];
- Db::name('package_gift')->where($sameWhere)->update($sameData);
- }
- }
- if (!empty($different)) {//新增的添加
- $packageGiftRes = Db::name('package_gift')->where($sameWhere)->insertAll($different);
- if (!$packageGiftRes) {
- throw new Exception('套餐卡券添加失败');
- }
- }
- //多余的删除
- $delIds = array_diff($packageGiftCouponIds,$postCouponIds);
- if (!empty($delIds)) {
- $packageGiftDelWhere['package_id'] = $id;
- $packageGiftDelWhere['coupon_id'] = ['in',$delIds];
- Db::name('package_gift')->where($packageGiftDelWhere)->delete();
- }
- } else {
- if (!empty($packageGiftData)) {
- $packageGiftDelRes = Db::name('package_gift')->where($packageGiftWhere)->delete();
- if (!$packageGiftDelRes) {
- throw new Exception('删除卡券失败');
- }
- }
- }
- }
- Db::commit();
- //生成小程序码
- $this->getMiniCode($id,$check,$this->auth->company_id);
- $this->success('编辑成功');
- } catch (Exception $e) {
- Db::rollback();
- $this->error($e->getMessage());
- }
- }
- //删除
- public function delete(){
- //验证
- if($this->auth->type != 1){
- $this->error('只有门店老板才能设置');
- }
- $id = input('id','');
- $check = Db::name('package')->where('id',$id)->where('company_id',$this->auth->company_id)->find();
- if(empty($check)){
- $this->error('不存在的套餐');
- }
- Db::name('package')->where('id',$id)->delete();
- Db::name('package_gift')->where('package_id',$id)->delete();
- $this->success('删除成功');
- }
- //仅返回套餐二维码
- private function getMiniCode($id,$package = [],$companyid)
- {
- $httpStr = $_SERVER['REQUEST_SCHEME'].'://'.$_SERVER['HTTP_HOST'];
- if (empty($package) || empty($package['mini_code'])) {
- $client = new Client();
- $tk = getAccessToken();
- $miniCodeConfig = config('param.mini_code');
- $miniCodeConfig['scene'] = 'id='.$id.'&shopId='.$companyid;
- $res2 = $client->request('POST', 'https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token='.$tk, [
- 'json' => $miniCodeConfig,
- ]);
- $fileName = md5($id);
- $fileUrl = '/uploads/package/'.$fileName.'.png';
- $code = $res2->getBody()->getContents();
- file_put_contents(ROOT_PATH.'/public'.$fileUrl,$code);
- $miniCode = $httpStr.$fileUrl;
- } else {
- $miniCode = $httpStr.$package['mini_code'];
- }
- return $miniCode;
- }
- //生成视频分享海报
- public function showposter() {
- $id = input('id', 0, 'intval'); //id
- if (!$id) {
- $this->error('参数缺失');
- }
- $info = Db::name('package')->where('id',$id)->find();
- if (!$info) {
- $this->error('套餐不存在');
- }
- $inviteimage = $this->getMiniCode($id,$info,$this->auth->company_id);
- $package_image = explode(',',$info['images'])[0];
- $data = [
- [
- "left"=> "0px",
- "top"=> "0px",
- "type"=> "img",
- "width"=> "320px",
- "height"=> "290px",
- "src"=> one_domain_image($package_image)//"https://metavision.oss-cn-hongkong.aliyuncs.com/uploads/20220615/f00cb545deb4c4e7296f444239d83e84.jpg"
- ],
- [
- "left"=> "10px",
- "top"=> "370px",
- "type"=> "img",
- "width"=> "45px",
- "height"=> "45px",
- "src"=> one_domain_image($this->auth->company->image)//"https://metavision.oss-cn-hongkong.aliyuncs.com/uploads/20220615/f00cb545deb4c4e7296f444239d83e84.jpg"
- ],
- [
- "left"=> "10px",
- "top"=> "330px",
- "type"=> "nickname",
- "width"=> "166px",
- "height"=> "38px",
- "size"=> "11px",
- "color"=> "#333333",
- "content" => (iconv_strlen($info['title'], 'utf-8') <= 12 ? $info['title'] : mb_substr($info['title'], 0, 12) )
- ],
- [
- "left"=> "60px",
- "top"=> "385px",
- "type"=> "nickname",
- "width"=> "166px",
- "height"=> "38px",
- "size"=> "10px",
- "color"=> "#666666",
- "content" => (iconv_strlen($this->auth->company->name, 'utf-8') <= 8 ? $this->auth->company->name : mb_substr($this->auth->company->name, 0, 8))
- ],
- [
- "left"=> "195px",
- "top"=> "300px",
- "type"=> "img",
- "width"=> "110px",
- "height"=> "110px",
- "src"=> httpurllocal($inviteimage)//"https://metavision.oss-cn-hongkong.aliyuncs.com/uploads/20220615/f00cb545deb4c4e7296f444239d83e84.jpg"
- ],
- [
- "left"=> "200px",
- "top"=> "420px",
- "type"=> "nickname",
- "width"=> "166px",
- "height"=> "38px",
- "size"=> "9px",
- "color"=> "#666666",
- "content" => '长按扫码查看详情',
- ],
- ];
- $data = json_encode($data, 320);
- $poster = [
- 'id' => 1,
- 'title' => '测试',
- 'waittext' => '您的专属海报正在拼命生成中,请等待片刻...',
- 'bg_image' => '/assets/img/posterbg.png',
- 'data' => $data,
- 'status' => 'normal',
- 'weigh' => 0,
- 'createtime' => 1653993709,
- 'updatetime' => 1653994259,
- ];
- $image = new \addons\poster\library\Image();
- $imgurl = $image->createPosterImage($poster, $this->auth->getUser());
- if (!$imgurl) {
- $this->error('生成海报出错');
- }
- $imgurl = $_SERVER["REQUEST_SCHEME"]."://".$_SERVER["HTTP_HOST"] . '/' . $imgurl;
- //echo '<html><body><img src="'.$imgurl.'"></body></html>';exit;
- $this->success('', $imgurl);
- }
- }
|