12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499 |
- <?php
- /**
- * 易优CMS
- * ============================================================================
- * 版权所有 2016-2028 海口快推科技有限公司,并保留所有权利。
- * 网站地址: http://www.eyoucms.com
- * ----------------------------------------------------------------------------
- * 如果商业用途务必到官方购买正版授权, 以免引起不必要的法律纠纷.
- * ============================================================================
- * Author: 小虎哥 <1105415366@qq.com>
- * Date: 2018-4-3
- */
-
- namespace app\api\model\v1;
-
- use think\Db;
-
- /**
- * 小程序模型类
- */
- class Api extends Base
- {
- //初始化
- protected function initialize()
- {
- // 需要调用`Model`的`initialize`方法
- parent::initialize();
- }
-
- /**
- * 文档详情
- * @param int $aid 文档ID
- */
- public function getArchivesView($aid = '', $users = [])
- {
- $aid = intval($aid);
- $args = [$aid, $users];
- $cacheKey = 'api-'.md5(__CLASS__.__FUNCTION__.json_encode($args));
- $result = cache($cacheKey);
- if (true || empty($result)) {
- $detail = $this->getViewInfo($aid, $users);
- if (!empty($detail['detail'])) {
- if (0 <= $detail['detail']['arcrank']) { // 待审核稿件
- $detail['detail']['title'] = htmlspecialchars_decode($detail['detail']['title']);
- $add_time = $detail['detail']['add_time'];
- $detail['detail']['add_time_format'] = $this->time_format($add_time);
- $detail['detail']['add_time'] = date('Y-m-d H:i:s', $add_time); // 格式化发布时间,兼容早期开源小程序
- $detail['detail']['content'] = $this->html_httpimgurl($detail['detail']['content'], true); // 转换内容图片为http路径
-
- !empty($detail['product']) && $result['product'] = $detail['product']; // 推荐商品
- !empty($detail['coupon_list']) && $result['coupon_list'] = $detail['coupon_list']; // 优惠券列表
- } else {
- $detail['detail'] = [
- 'arcrank' => $detail['detail']['arcrank'],
- ];
- }
- }
-
- $result['detail']['data'] = !empty($detail['detail']) ? $detail['detail'] : false;
-
- cache($cacheKey, $result, null, 'archives');
- }
-
- if (!empty($result['detail']['data'])) {
- // 浏览量
- Db::name('archives')->where(['aid'=>$aid])->setInc('click');
- $result['detail']['data']['click'] += 1;
- eyou_statistics_data(1);
- }
-
- return $result;
- }
-
- /**
- * 获取单条文档记录
- * @author wengxianhu by 2017-7-26
- */
- private function getViewInfo($aid, $users = [])
- {
- $result = [];
- $detail = Db::name('archives')
- ->alias('a')
- ->field('a.aid,a.typeid,a.channel,a.title,a.litpic,a.author,a.click,a.arcrank,a.seo_title,a.seo_keywords,a.seo_description,a.users_price,a.users_discount_type,a.users_free,a.old_price,
- a.sales_num,a.virtual_sales,a.sales_all,a.stock_show,a.stock_count,a.prom_type,a.arc_level_id,a.downcount,a.add_time,a.attrlist_id,b.typename,a.restric_type,a.no_vip_pay')
- ->join('arctype b','a.typeid = b.id','left')
- ->where([
- 'a.aid' => $aid,
- 'a.status' => 1,
- 'a.is_del' => 0,
- ])
- ->find();
- if (!empty($detail)) {
- $detail['arc_level_value'] = 0;
- if (0 < $detail['arc_level_id']) {
- $detail['arc_level_value'] = Db::name('users_level')->where(['level_id'=>$detail['arc_level_id']])->value('level_value');
- }
- // 模型标题处理
- $channeltype_row = \think\Cache::get('extra_global_channeltype');
- $channeltypeInfo = !empty($channeltype_row[$detail['channel']]) ? $channeltype_row[$detail['channel']] : [];
- $detail['channel_ntitle'] = !empty($channeltypeInfo['ntitle']) ? $channeltypeInfo['ntitle'] : '文章';
- $detail['seo_title'] = $this->set_arcseotitle($detail['title'], $detail['seo_title']); // seo标题
- $detail['litpic'] = $this->get_default_pic($detail['litpic']); // 默认封面图
- // $detail['forward'] = Db::name('users_forward')->where('aid',$aid)->count(); // 转发记录,废弃了,有需要就通过请求传参进行判断是否要查表返回数据,或者写成标签apiForward
- $detail['content'] = '';
- if (1 == $detail['channel']) { // 文章模型
- unset($detail['sales_num']);
- unset($detail['virtual_sales']);
- unset($detail['sales_all']);
- unset($detail['stock_show']);
- unset($detail['stock_count']);
- unset($detail['prom_type']);
- unset($detail['downcount']);
- } else if (2 == $detail['channel']) { // 产品模型
- //检测是否安装秒杀插件
- if (is_dir('./weapp/Seckill/')) {
- $SeckillRow = model('Weapp')->getWeappList('Seckill');
- if (!empty($SeckillRow) && 1 != intval($SeckillRow['status'])) {
- $detail['seckill_goods_id'] = false;
- }else{
- $tagWeappSeckill = new \think\template\taglib\api\TagWeappSeckill;
- $detail['seckill_goods_id'] = $tagWeappSeckill->guideSeckill($aid);
- }
- } else {
- $detail['seckill_goods_id'] = false;
- }
-
- // 是否安装积分商城插件
- $detail['points_goods_id'] = false;
- $weappInfo = model('ShopPublicHandle')->getWeappPointsShop();
- if (!empty($weappInfo)) {
- // 调用积分商城逻辑层方法
- $pointsGoodsModel = new \app\plugins\model\PointsGoods();
- $detail['points_goods_id'] = $pointsGoodsModel->getPointsShopGoodsID($aid);
- }
-
- unset($detail['users_free']);
- unset($detail['downcount']);
- /*产品参数*/
- if (!empty($detail['attrlist_id'])) { // 新版参数
- $productAttrModel = new \app\home\model\ProductAttr;
- $attr_list = $productAttrModel->getProAttrNew($aid, 'a.attr_id,a.attr_name,b.attr_value,b.aid');
- } else { // 旧版参数
- $productAttrModel = new \app\home\model\ProductAttr;
- $attr_list = $productAttrModel->getProAttr($aid);
- }
- $attr_list = !empty($attr_list[$aid]) ? $attr_list[$aid] : [];
- foreach ($attr_list as $key => $val) {
- $val['attr_value'] = htmlspecialchars_decode($val['attr_value']);
- unset($val['aid']);
- $attr_list[$key] = $val;
- }
- $detail['attr_list'] = !empty($attr_list) ? $attr_list : false; //产品默认参数
-
- /*规格数据*/
- $detail['spec_attr'] = $this->getSpecAttr($aid, $users);
- /* END */
-
- // 产品相册
- $productImgModel = new \app\home\model\ProductImg;
- $image_list = $productImgModel->getProImg($aid, 'aid,image_url,intro');
- $image_list = !empty($image_list[$aid]) ? $image_list[$aid] : [];
- foreach ($image_list as $key => $val) {
- $val['image_url'] = $this->get_default_pic($val['image_url']);
- isset($val['intro']) && $val['intro'] = htmlspecialchars_decode($val['intro']);
- $image_list[$key] = $val;
- }
- $detail['image_list'] = !empty($image_list) ? $image_list : false;
-
- /*可控制的主表字段列表*/
- $detail['ifcontrolRow'] = Db::name('channelfield')->field('id,name')->where([
- 'channel_id' => $detail['channel'],
- 'ifmain' => 1,
- 'ifeditable' => 1,
- 'ifcontrol' => 0,
- 'status' => 1,
- ])->getAllWithIndex('name');
-
- // 设置默认原价
- $detail['old_price'] = $detail['users_price'];
- $detail['product_num'] = 1;
- $detail['spec_value_id'] = '';
-
- $result['product'] = $this->getRecomProduct();
- $result['coupon_list'] = $this->getCoupon($detail, $users);
- if ('v1.5.1' < getVersion()) {
- //总评论数
- $detail['comment_data_count'] = Db::name('shop_order_comment')->where(['product_id' => $aid, 'is_show' => 1])->count();
- $good_count = Db::name('shop_order_comment')->where(['product_id' => $aid, 'is_show' => 1, 'total_score' => ['egt', 4]])->count();
- //好评率
- $detail['comment_good_count'] = $good_count;
- $detail['comment_good_per'] = !empty($detail['comment_data_count']) ? round($good_count / $detail['comment_data_count'], 2) : 1;
- if ($detail['comment_data_count'] > 0) {
- $detail['comment_data'] = Db::name('shop_order_comment')
- ->alias('a')
- ->field('a.*,b.nickname,b.head_pic')
- ->join('users b', 'a.users_id = b.users_id', 'left')
- ->where(['a.product_id' => $aid, 'a.is_show' => 1])
- ->order('a.total_score asc')
- ->limit(2)
- ->select();
- foreach ($detail['comment_data'] as $k => $v) {
- if (1 == $v['is_anonymous']) {
- $v['nickname'] = '匿名用户';
- }
- $v['add_time'] = date('Y-m-d H:i:s', $v['add_time']);
- $v['content'] = unserialize($v['content']);
- $v['head_pic'] = get_default_pic($v['head_pic'], true);
- $detail['comment_data'][$k] = $v;
- }
- }
- }
-
- $detail['cart_total_num'] = 0;
- if (!empty($users['users_id'])) {
- //购物车数量
- $detail['cart_total_num'] = Db::name('shop_cart')->where(['users_id' => $users['users_id']])->sum('product_num');
- }
- } else if (3 == $detail['channel']) { // 图集模型
- unset($detail['users_price']);
- unset($detail['users_free']);
- unset($detail['old_price']);
- unset($detail['sales_num']);
- unset($detail['virtual_sales']);
- unset($detail['sales_all']);
- unset($detail['stock_show']);
- unset($detail['stock_count']);
- unset($detail['prom_type']);
- unset($detail['downcount']);
- // 图集相册
- $imagesUploadModel = new \app\home\model\ImagesUpload;
- $image_list = $imagesUploadModel->getImgUpload($aid, 'aid,image_url,intro');
- $image_list = !empty($image_list[$aid]) ? $image_list[$aid] : [];
- foreach ($image_list as $key => $val) {
- $val['image_url'] = $this->get_default_pic($val['image_url']);
- isset($val['intro']) && $val['intro'] = htmlspecialchars_decode($val['intro']);
- $image_list[$key] = $val;
- }
- $detail['image_list'] = !empty($image_list) ? $image_list : false;
- } else if (4 == $detail['channel']) { // 下载模型
- unset($detail['users_price']);
- unset($detail['users_free']);
- unset($detail['old_price']);
- unset($detail['sales_num']);
- unset($detail['virtual_sales']);
- unset($detail['sales_all']);
- unset($detail['stock_show']);
- unset($detail['stock_count']);
- unset($detail['prom_type']);
- if (0 == $detail['arc_level_id']) {
- $downloadFileModel = new \app\home\model\DownloadFile;
- $down_list = $downloadFileModel->getDownFile($aid);
- $down_list = !empty($down_list[$aid]) ? $down_list[$aid] : [];
- foreach ($down_list as $key => $val) {
- $val['file_url'] = handle_subdir_pic($val['file_url']);
- $down_list[$key] = $val;
- }
- } else {
- $down_list = false;
- }
- $detail['down_list'] = !empty($down_list) ? $down_list : false;
- } else if (5 == $detail['channel']) { // 视频模型
- unset($detail['sales_num']);
- unset($detail['virtual_sales']);
- unset($detail['sales_all']);
- unset($detail['stock_show']);
- unset($detail['stock_count']);
- unset($detail['prom_type']);
- unset($detail['downcount']);
- // 视频附件列表
- $mediaFileModel = new \app\home\model\MediaFile;
- $media_list = $mediaFileModel->getMediaFile($aid);
- foreach ($media_list as $key => $val) {
- $val['file_url'] = handle_subdir_pic($val['file_url'], 'media');
- $media_list[$key] = $val;
- }
- $detail['media_list'] = !empty($media_list) ? $media_list : false;
- //视频权限
- $media_info = [
- 'auth_type' => 1, // 所有人免费
- 'level_auth' => 1, // 1-会员级别达到要求 2-需要升级会员级别
- 'buy_auth' => 1, // 1-已购买 2-需要购买
- 'level_name' => '', // 会员等级名称
- ];
- if (0 < $detail['users_price'] && empty($detail['users_free'])) {
- if (empty($detail['arc_level_id'])) {
- //不限会员 付费
- $media_info['auth_type'] = 2;
- $media_info['buy_auth'] = 2;
- } else {
- //3-限制会员 付费
- $media_info['auth_type'] = 3;
- $media_info['level_auth'] = 2;
- $media_info['buy_auth'] = 2;
- }
- } else {
- if (0 < intval($detail['arc_level_id'])) { // 会员免费
- $media_info['auth_type'] = 4;
- $media_info['level_auth'] = 2;
- $media_info['buy_auth'] = 2;
- }
- }
- //指定会员情况下开启非会员付费
- if (!empty($detail['no_vip_pay'])){
- $media_info['buy_auth'] = 2;
- }
-
- if (in_array($media_info['auth_type'],[3,4])){
- $media_info['level_name'] = Db::name('users_level')->where('level_id',$detail['arc_level_id'])->value('level_name');
- }
- //如果权限里涉及会员的 判断一下用户是否达到会员权限
- if (1 < $media_info['level_auth'] && !empty($users['users_id'])){
- if ($detail['arc_level_value'] <= $users['level_value']){
- $media_info['level_auth'] = 1;
- }
- }
- //如果权限里涉及购买的 判断一下用户是否已经购买
- if (1 < $media_info['buy_auth'] && !empty($users['users_id'])){
- $where = [
- 'users_id' => $users['users_id'],
- 'product_id' => $aid,
- 'order_status' => 1
- ];
- // 存在数据则已付费
- $is_buy = Db::name('media_order')->where($where)->count();
- if (!empty($is_buy)){
- $media_info['buy_auth'] = 1;
- }
- }
- $detail['media_info'] = $media_info;
- }
- else {
- unset($detail['users_price']);
- unset($detail['users_free']);
- unset($detail['old_price']);
- unset($detail['sales_num']);
- unset($detail['virtual_sales']);
- unset($detail['sales_all']);
- unset($detail['stock_show']);
- unset($detail['stock_count']);
- unset($detail['prom_type']);
- unset($detail['downcount']);
- }
-
- // 获取自定义字段的数据
- $customField = [];
- $addtableName = $channeltypeInfo['table'].'_content';
- $detailRow = Db::name($addtableName)->field('id,aid,add_time,update_time', true)->where('aid', $aid)->find();
- if (!empty($detailRow)) {
- $fieldLogic = new \app\home\logic\FieldLogic();
- $detailExt = $fieldLogic->getChannelFieldList($detailRow, $detail['channel']); // 自定义字段的数据格式处理
- if (empty($channeltypeInfo['ifsystem'])) { // 自定义模型
- // 如果存在自定义字段content,默认作为文档的正文内容。
- // 如果不存在,将获取第一个html类型的内容,作为文档的正文内容。
- if (!isset($detailExt['content'])) {
- $contentField = Db::name('channelfield')->where([
- 'channel_id' => $detail['channel'],
- 'dtype' => 'htmltext',
- ])->getField('name');
- $detailExt['content'] = !empty($detailExt[$contentField]) ? $detailExt[$contentField] : '';
- }
- }
- $detail['content'] = $detailExt['content'];
- unset($detailExt['content']);
-
- // 手机端详情内容
- if (isset($detailExt['content_ey_m'])) {
- $detail['content'] = empty($detailExt['content_ey_m']) ? $detail['content'] : $detailExt['content_ey_m'];
- unset($detailExt['content_ey_m']);
- }
-
- if (!empty($detailExt)) {
- $field = 'name, title, dtype';
- $customField = Db::name('channelfield')->field($field)->where([
- 'name' => ['IN', array_keys($detailExt)],
- 'channel_id' => $detail['channel'],
- 'ifeditable' => 1
- ])->getAllWithIndex('name');
- if (!empty($customField)) {
- foreach ($customField as $key => $value) {
- if ('img' == $value['dtype']) {
- $customField[$key]['value'] = $this->get_default_pic($detailExt[$key]);
- } else if ('media' == $value['dtype']) {
- $customField[$key]['value'] = $this->get_default_pic($detailExt[$key]);
- } else if ('imgs' == $value['dtype']) {
- foreach ($detailExt[$key] as $kk => $vv) {
- $detailExt[$key][$kk]['image_url'] = $this->get_default_pic($vv['image_url']);
- }
- $customField[$key]['value'] = $detailExt[$key];
- } else {
- $customField[$key]['value'] = $detailExt[$key];
- }
- }
- }
- }
- $customField = array_values($customField);
- }
- $detail['customField'] = !empty($customField) ? $customField : false;
- $detail['users_discount_price'] = !empty($detail['users_price']) ? $detail['users_price'] : 0;
- if (!empty($detail['users_price']) && !empty($users['users_id']) && 0 === intval($detail['users_discount_type'])) {
- $discount = Db::name('users_level')->where('level_id',$users['level'])->value('discount');
- if (100 > $discount) {
- $detail['users_discount_price'] = sprintf("%.2f",$detail['users_price']*($discount/100));
- }
- }
-
- // 商品是 单规格 且 设置会员折扣价 则处理
- if (empty($detail['spec_attr']['spec_data']) && 1 === intval($detail['users_discount_type']) && !empty($users['level_id'])) {
- $detail['users_discount_price'] = model('ShopPublicHandle')->handleUsersDiscountPrice($aid, $users['level_id']);
- }
-
- $result['detail'] = $detail;
- }
-
- return $result;
- }
-
- /**
- * 留言栏目表单
- * @param int $typeid 栏目ID
- */
- public function getGuestbookForm($typeid)
- {
- $typeid = intval($typeid);
- if (empty($typeid)) {
- $typeid = Db::name('arctype')->where([
- 'current_channel' => 8,
- 'is_del' => 0,
- 'status' => 1,
- 'lang' => parent::$lang,
- ])->getField('id');
- }
-
- $attr_list = array();
- $typename = '';
- if (0 < $typeid) {
- $detail = Db::name('arctype')->field('id,id as typeid,typename,seo_title,seo_keywords,seo_description')->where([
- 'id' => $typeid,
- 'lang' => parent::$lang,
- ])->find();
- $detail['seo_title'] = $this->set_arcseotitle($detail['typename'], $detail['seo_title']);
- $attr_list = Db::name('GuestbookAttribute')->field('attr_id,attr_name,attr_input_type,attr_values')
- ->where([
- 'typeid' => $typeid,
- 'is_del' => 0,
- ])
- ->order('sort_order asc, attr_id asc')
- ->select();
- foreach ($attr_list as $key => $val) {
- if (in_array($val['attr_input_type'], array(1,3,4))) {
- $val['attr_values'] = explode(PHP_EOL, $val['attr_values']);
- $attr_list[$key] = $val;
- }
- }
- }
-
- /*表单令牌*/
- $token_name = md5('guestbookform_token_'.$typeid.md5(getTime().uniqid(mt_rand(), TRUE)));
- $token_value = md5($_SERVER['REQUEST_TIME_FLOAT']);
- $session_path = \think\Config::get('session.path');
- $session_file = ROOT_PATH . $session_path . "/sess_".$token_name;
- $fp = fopen($session_file, "w+");
- if (!empty($fp)) {
- if (fwrite($fp, $token_value)) {
- fclose($fp);
- }
- } else {
- file_put_contents ( $session_file, $token_value);
- }
- /*end*/
-
- $result = array(
- 'detail' => $detail,
- 'attr_list' => $attr_list,
- 'token' => [
- 'name' => '__token__'.$token_name,
- 'value' => $token_value,
- ],
- );
-
- return $result;
- }
-
- /**
- * 给指定留言添加表单值到 guestbook_attr
- * @param int $aid 留言id
- * @param int $typeid 留言栏目id
- */
- public function saveGuestbookAttr($post, $aid, $typeid, $form_type)
- {
- $attrArr = [];
- foreach ($post as $k => $v) {
- if (!strstr($k, 'attr_')) {
- continue;
- }
-
- $attr_id = str_replace('attr_', '', $k);
- is_array($v) && $v = implode(PHP_EOL, $v);
- $v = trim($v);
- $adddata = array(
- 'aid' => $aid,
- 'form_type' => $form_type,
- 'attr_id' => $attr_id,
- 'attr_value' => $v,
- 'lang' => parent::$lang,
- 'add_time' => getTime(),
- 'update_time' => getTime(),
- );
- Db::name('GuestbookAttr')->add($adddata);
- }
- }
-
- // 获取指定商品的规格数据
- public function getSpecAttr($aid = null, $users = [], $order2 = '')
- {
- $ReturnData = $SpecData = $SpecValue = $SelectSpecData = [];
- if (empty($aid)) return $ReturnData;
- if (empty($users['level_discount'])) $users['level_discount'] = 100;
- // 会员折扣率
- $SelectSpecData['users_discount'] = (intval($users['level_discount']) / 100);
-
- $SpecWhere = [
- 'aid' => $aid,
- 'lang' => get_home_lang(),
- 'spec_is_select' => 1,
- ];
- $order = 'spec_value_id asc, spec_id asc';
- $field = '*, false checked';
- $ProductSpecData = Db::name('product_spec_data')->field($field)->where($SpecWhere)->order($order)->select();
- foreach ($ProductSpecData as $key => $value) {
- $ProductSpecData[$key]['spec_image'] = !empty($value['spec_image']) ? get_default_pic($value['spec_image'], true) : '';
- }
- if (!empty($ProductSpecData)) {
- $ProductSpecData = group_same_key($ProductSpecData, 'spec_mark_id');
- foreach ($ProductSpecData as $key => $value) {
- // $value[0]['checked'] = true;
- $SpecData[] = [
- 'spec_value_id' => $value[0]['spec_value_id'],
- 'spec_mark_id' => $value[0]['spec_mark_id'],
- 'spec_name' => $value[0]['spec_name'],
- 'spec_data_new' => $value,
- ];
- }
-
- unset($SpecWhere['spec_is_select']);
- $order2 = !empty($order2) ? $order2 : 'seckill_price asc,spec_price asc';
- $ProductSpecValue = Db::name('product_spec_value')->where($SpecWhere)->order($order2)->select();
-
- if (!empty($ProductSpecValue)) {
- // 默认的规格值,取价格最低者
- $SelectSpecData['spec_value_id'] = explode('_', $ProductSpecValue[0]['spec_value_id']);
-
- // 若存在规格并且价格存在则覆盖原有价格
- $SelectSpecData['users_price'] = sprintf("%.2f", strval($ProductSpecValue[0]['spec_price']) * strval($SelectSpecData['users_discount']));
-
- // 产品原价
- $SelectSpecData['old_price'] = $ProductSpecValue[0]['spec_price'];
-
- // 若存在规格并且库存存在则覆盖原有库存
- $SelectSpecData['stock_count'] = $ProductSpecValue[0]['spec_stock'];
-
- // 价格及库存
- $SpecValue = $ProductSpecValue;
- }
- foreach ($SpecData as $key => $value) {
- foreach ($value['spec_data_new'] as $kk => $vv) {
- // 追加默认规格class
- if (in_array($vv['spec_value_id'], $SelectSpecData['spec_value_id'])) {
- $SpecData[$key]['spec_data_new'][$kk]['checked'] = true;
- }
- }
- }
- }
-
- $ReturnData = [
- 'spec_data' => $SpecData,
- 'spec_value' => $SpecValue,
- 'select_spec_data' => $SelectSpecData
- ];
-
- return $ReturnData;
- }
-
- /**
- * 购物车/用户中心/商品详情获取 可能你还想要
- */
- public function getRecomProduct($type = 1){
- // 查询条件
- $where = [
- 'channel' => 2,
- 'arcrank' => ['>', -1],
- 'lang' => self::$lang,
- 'status' => 1,
- 'is_del' => 0,
- ];
- // 数据排序
- if (1 == $type){
- //最新
- $order = [
- 'aid' => 'desc',
- ];
- }elseif (2 == $type){
- //推荐
- $where['is_recom'] = 1;
- $order = [
- 'sort_order' => 'asc',
- 'aid' => 'desc',
- ];
- }elseif (3 == $type){
- //最热
- $order = [
- 'click' => 'desc',
- 'aid' => 'desc',
- ];
- }else {
- $order = [
- 'sort_order' => 'asc',
- 'aid' => 'desc',
- ];
- }
-
- // 分页处理
- $limit ='0,6';
-
- // 查询数据
- $ArchivesData = Db::name('archives')->where($where)->order($order)->limit($limit)->select();
- if (!empty($ArchivesData)) {
- foreach ($ArchivesData as $key => $value) {
- $ArchivesData[$key]['litpic'] = $this->get_default_pic($value['litpic'], true); // 默认封面图
- }
- } else {
- $ArchivesData = [];
- }
-
- return [
- 'title' => '可能你还想要',
- 'list' => $ArchivesData,
- ];
- }
-
- //获取当前商品可用优惠券
- public function getCoupon($arcData = [],$users = [])
- {
- // 筛选条件
- $filter = [
- 'status' => 1
- ];
- $filter['start_date'] = ['<=',getTime()];
- $filter['end_date'] = ['>=',getTime()];
-
- $result = Db::name('shop_coupon')
- ->where($filter)
- ->where("coupon_type = '1' OR FIND_IN_SET('{$arcData['typeid']}', arctype_id) OR FIND_IN_SET('{$arcData['aid']}', product_id)")
- ->order('sort_order asc,coupon_id desc')
- ->select();
- $coupon_ids = [];
- if (!empty($result)) {
- foreach ($result as $k => $v) {
- $coupon_ids[] = $v['coupon_id'];
- $v['coupon_form_name'] = '满减券';
- switch ($v['use_type']) {
- case '1': // 固定期限有效
- $v['start_date'] = date('Y/m/d', $v['start_date']);
- $v['end_date'] = date('Y/m/d', $v['end_date']);
- $v['use_type_name'] = $v['start_date'] . '-' . $v['end_date'];
- break;
- case '2'; // 领取当天开始有效
- $v['use_type_name'] = '领取' . $v['valid_days'] . '天内有效';
- break;
- case '3'; // 领取次日开始有效
- $v['use_type_name'] = '领取次日开始' . $v['valid_days'] . '天内有效';
- break;
- }
- switch ($v['coupon_type']) {
- case '1':
- $v['coupon_type_name'] = '全部商品';
- break;
- case '2';
- $v['coupon_type_name'] = '指定商品';
- break;
- case '3';
- $v['coupon_type_name'] = '指定分类';
- break;
- }
- $result[$k] = $v;
- }
- }
- if (!empty($users)){
- $have_where['users_id'] = $users['users_id'];
- if (!empty($coupon_ids)) {
- $have_where['coupon_id'] = ['in',$coupon_ids];
- }
- $have_where['use_status'] = 0;
- $have = Db::name('shop_coupon_use')->where($have_where)->column('coupon_id');
- if (!empty($have)){
- foreach ($result as $k => $v ) {
- if (in_array($v['coupon_id'],$have)){
- $result[$k]['geted'] = 1;//当前还有已领取未使用的
- }
- }
- }
- }
-
- return $result;
- }
-
- /**
- * 获取秒杀商品详情
- */
- public function GetSharpGoods($aid = 0){
- $users = [];
- $aid = intval($aid);
- $args = [$aid, $users];
- $cacheKey = 'api-'.md5(__CLASS__.__FUNCTION__.json_encode($args));
- $result = cache($cacheKey);
- if (true || empty($result)) {
- $status = 0;
- $msg = 'OK';
- $detail = array();
- if (0 < $aid) {
- $detail = $this->getSharpInfo($aid, $users);
- if (!empty($detail)) {
- if (0 == $detail['arcrank']) {
- $status = 1;
- } else if (0 > $detail['arcrank']) {
- $msg = '文档审核中,无权查看!';
- } else if (0 < $detail['arcrank']) {
- $msg = '当前是游客,无权查看!';
- }
-
- $detail['add_time'] = date('Y-m-d H:i:s', $detail['add_time']); // 格式化发布时间
- $detail['update_time'] = date('Y-m-d H:i:s', $detail['update_time']); // 格式化更新时间
- $detail['content_1586404997'] = $this->html_httpimgurl($detail['content_1586404997'], true); // 转换内容图片为http路径
- $detail['seo_description'] = '';
-
-
- } else {
- $msg = '文档已删除!';
- }
- }
-
- $result = [
- 'conf' => [
- 'status' => $status,
- 'msg' => $msg,
- ],
- 'detail' => !empty($detail) ? $detail : [],
- ];
-
- cache($cacheKey, $result, null, 'archives');
- }
-
- return $result;
- }
-
- /**
- * 获取秒杀商品记录
- * @author wengxianhu by 2017-7-26
- */
- private function getSharpInfo($aid,$users = [])
- {
- $where = [
- 'a.status' => 1,
- 'a.is_del' => 0,
- 'a.aid' => $aid,
- ];
- $result = array();
- $row = Db::name('sharp_goods')
- ->alias('a')
- ->field('a.sharp_goods_id,a.limit,a.seckill_stock,a.seckill_price,a.sales,a.virtual_sales,a.is_sku,b.sales_actual,c.*')
- ->where($where)
- ->join('sharp_active_goods b','a.aid = b.aid','left')
- ->join('archives c','a.aid = c.aid','left')
- ->find();
- $channeltype_row = \think\Cache::get('extra_global_channeltype');
- if (!empty($row)) {
- if (0 < $row['virtual_sales']){
- $row['sales_actual'] = $row['sales_actual']+$row['virtual_sales'];
- }
- $row['seo_title'] = $this->set_arcseotitle($row['title'], $row['seo_title']);
- /*封面图*/
- if (empty($row['litpic'])) {
- $row['is_litpic'] = 0; // 无封面图
- } else {
- $row['is_litpic'] = 1; // 有封面图
- }
- $row['litpic'] = $this->get_default_pic($row['litpic'], true); // 默认封面图
-
- // 模型处理
- $channeltypeInfo = !empty($channeltype_row[$row['channel']]) ? $channeltype_row[$row['channel']] : [];
-
- /*产品参数*/
- if (!empty($row['attrlist_id'])){
- $productAttrModel = new \app\home\model\ProductAttr();
- $attr_list = $productAttrModel->getProAttrNew($aid);
- }else{
- $productAttrModel = new \app\home\model\ProductAttr();
- $attr_list = $productAttrModel->getProAttr($aid);
- }
- $attr_list = !empty($attr_list[$aid]) ? $attr_list[$aid] : [];
- foreach ($attr_list as $key => $val) {
- $attr_list[$key]['attr_value'] = htmlspecialchars_decode($val['attr_value']);
- }
- $row['attr_list'] = $attr_list;
-
- /*规格数据*/
- $row['spec_attr'] = $this->getSpecAttr($aid, $users);
- /* END */
-
- // 产品相册
- $image_list = [];
- $productImgModel = new \app\home\model\ProductImg();
- $image_list_tmp = $productImgModel->getProImg($aid);
- if (!empty($image_list_tmp[$aid])) {
- foreach ($image_list_tmp[$aid] as $key => $val) {
- $val['image_url'] = $this->get_default_pic($val['image_url'], true);
- $image_list[$key] = $val;
- }
- }
- $row['image_list'] = $image_list;
-
- /*可控制的主表字段列表*/
- $row['ifcontrolRow_1586404997'] = Db::name('channelfield')->field('id,name')->where([
- 'channel_id' => $row['channel'],
- 'ifmain' => 1,
- 'ifeditable' => 1,
- 'ifcontrol' => 0,
- 'status' => 1,
- ])->getAllWithIndex('name');
-
- // 设置默认原价
- $row['old_price'] = $row['users_price'];
- $row['product_num'] = 1;
- $row['spec_value_id'] = '';
-
- // 获取自定义字段的数据
- $class = '\app\home\model\\'.$channeltypeInfo['ctl_name'];
- $model = new $class();
- $extFields = Db::name($channeltypeInfo['table'].'_content')->getTableFields();
- $extFields = array_flip($extFields);
- unset($extFields['id']);
- $rowExt = $model->getInfo($aid);
- $rowExt_new = [];
- foreach ($extFields as $key => $val) {
- $rowExt_new[$key] = $rowExt[$key];
- }
- $rowExt = array_diff_key($rowExt_new, $row);
-
- if (!empty($rowExt)) {
- $fieldLogic = new \app\home\logic\FieldLogic();
- $rowExt = $fieldLogic->getChannelFieldList($rowExt, $row['channel']); // 自定义字段的数据格式处理
- }
- /*--end*/
-
- // 浏览量
- Db::name('archives')->where(['aid'=>$aid])->setInc('click');
- $row['click'] = $row['click'] + 1;
-
- $result = array_merge($rowExt, $row);
-
- if (!empty($channeltypeInfo['ifsystem']) && 1 == $channeltypeInfo['ifsystem']) {
- $content = $result['content'];
- unset($result['content']);
- } else {
- /*获取第一个html类型的内容,作为文档的内容*/
- $contentField = Db::name('channelfield')->where([
- 'channel_id' => $row['channel'],
- 'dtype' => 'htmltext',
- ])->getField('name');
- $content = !empty($rowExt[$contentField]) ? $rowExt[$contentField] : '';
- /*--end*/
- }
- $result['content_1586404997'] = $content;
- }
-
- return $result;
- }
-
- /**
- * 获取某个场次的秒杀信息
- * @param $item
- */
- public function getSharp($active_time_id=0,$aid=0)
- {
- //获取当时时间的整点时间戳
- $time = strtotime(date('Y-m-d'));
- $hour = date('H');
- $where['a.status'] = 1;
- $where['a.active_time_id'] = $active_time_id;
- $where['b.is_del'] = 0;
- $where['b.status'] = 1;
- //获取秒杀场次信息
- $active = Db::name('sharp_active_time')
- ->alias('a')
- ->where($where)
- ->field('a.active_time_id,a.active_id,a.active_time,b.active_date,c.sales_actual')
- ->join('sharp_active b','a.active_id = b.active_id')
- ->join('sharp_active_goods c','a.active_time_id = c.active_time_id')
- ->find();
- //正在进行时
- if ($active['active_date'] == $time && $active['active_time'] == $hour){
- $active['status'] = 10;
- } else if (($active['active_date'] == $time && $active['active_time'] > $hour) || $active['active_date'] > $time){
- //预告
- $active['status'] = 20;
- }else if (($active['active_date'] == $time && $active['active_time'] < $hour) || $active['active_date'] < $time){
- //过期
- $active['status'] = 30;
- }
- $date = date('Y-m-d'); //2020-12-15
- if ($active['active_time'] < 10){
- $active['active_time'] = '0'.$active['active_time'].':00';
- }else{
- $active['active_time'] = $active['active_time'].':00'; // 00:00
- }
- $data_time = $date.' '.$active['active_time']; //2020-15-2-15 15:00
- $time_plus = strtotime($data_time . "+1 hours"); //2020-15-2-15 15:00
- $time_plus = date('Y-m-d H:i',$time_plus); //2020-15-2-15 16:00
- if ( 10 == $active['status'] ){
- $arr = [
- $time_plus,$time_plus,$data_time];
- }else if ( 20 == $active['status'] ){
- $arr = [$data_time,$time_plus,$data_time];
- }else if ( 30 == $active['status'] ){
- $arr = [false,$time_plus,$data_time];
- }
- $active['count_down_time'] = $arr[0];
- $active['end_time'] = $arr[1];
- $active['start_time'] = $arr[2];
-
- return $active;
- }
-
- /**
- * 获取优惠券数量
- */
- public function getCouponCount($user)
- {
- if (false == $user){
- return 0;
- }else{
- $where['users_id'] = $user['users_id'];
- $where['use_status'] = 0;
- $where['end_time'] = ['>',getTime()];
- $count = Db::name('shop_coupon_use')->where($where)->count();
- return $count;
- }
- }
-
- /**
- * 获取评论列表
- */
- public function getGoodsCommentList($param = [] )
- {
- $page = empty($param['page']) ? 1: $param['page'];
- $type = empty($param['type']) ? 'all': $param['type'];
- $pagesize = empty($param['pagesize']) ? config('paginate.list_rows'): $param['pagesize'];
- $total_score = empty($param['total_score']) ? '': $param['total_score'];
- $goods_id = $param['aid'];
- $field='a.*,u.nickname,u.head_pic';
- // 筛选条件
- $condition = [
- 'a.product_id' => $goods_id,
- 'a.is_show' => 1,
- ];
- if (!empty($param['total_score'])) $condition['a.total_score'] = $param['total_score'];
- if ('img' == $type) $condition['a.upload_img'] = ['neq',''];
-
- $args = [$goods_id,$page,$pagesize,$total_score];
- $cacheKey = 'api-'.md5(__CLASS__.__FUNCTION__.json_encode($args));
- if (true || empty($result)) {
- $paginate = array(
- 'page' => $page,
- );
- $pages = Db::name('shop_order_comment')
- ->field($field)
- ->alias('a')
- ->join('users u','a.users_id = u.users_id','left')
- ->where($condition)
- ->order('a.add_time desc')
- ->paginate($pagesize, false, $paginate);
- $result = $pages->toArray();
-
- foreach ($result['data'] as $key => $val) {
- $val['head_pic'] = get_default_pic($val['head_pic'],true);
- if (isset($val['add_time'])) {
- $val['add_time'] = date('Y-m-d H:i:s', $val['add_time']);
- }
- if (!empty($val['upload_img'])){
- $val['upload_img'] = unserialize($val['upload_img']);
- $val['upload_img'] = explode(',',$val['upload_img']);
- foreach ($val['upload_img'] as $k => $v){
- $val['upload_img'][$k] = get_default_pic($v,true);
- }
- }
- if (!empty($val['content'])){
- $val['content'] = unserialize($val['content']);
- }
- $result['data'][$key] = $val;
- }
- $score_type = Db::name('shop_order_comment')
- ->where([
- 'product_id' => $goods_id,
- 'is_show' => 1,
- 'lang' => get_home_lang(),
- ])->field('count(*) as count,total_score')
- ->group('total_score')
- ->getAllWithIndex('total_score');
- $result['count']['goods'] = isset($score_type[1]) ? $score_type[1]['count'] : 0;
- $result['count']['middle'] = isset($score_type[2]) ? $score_type[2]['count'] : 0;
- $result['count']['bad'] = isset($score_type[3]) ? $score_type[3]['count'] : 0;
- $result['count']['all'] = $result['count']['goods']+$result['count']['middle']+$result['count']['bad'] ;
-
- cache($cacheKey, $result, null, 'getGoodsCommentList');
- $condition['a.upload_img'] = ['neq',''];
- $result['have_img_count'] = Db::name('shop_order_comment')->alias('a')->where($condition)->count();
- }
- return $result;
- }
-
- /**
- * 获取限时折扣商品详情
- */
- public function GetDiscountGoods($aid = 0,$users = []){
- $aid = intval($aid);
- $args = [$aid, $users];
- $cacheKey = 'api-'.md5(__CLASS__.__FUNCTION__.json_encode($args));
- $result = cache($cacheKey);
- if (true || empty($result)) {
- $detail = $this->getDiscountInfo($aid, $users);
- if (!empty($detail['detail'])) {
- if (0 <= $detail['detail']['arcrank']) { // 待审核稿件
- $detail['detail']['title'] = htmlspecialchars_decode($detail['detail']['title']);
- $detail['detail']['add_time'] = date('Y-m-d H:i:s', $detail['detail']['add_time']); // 格式化发布时间
- $detail['detail']['content'] = $this->html_httpimgurl($detail['detail']['content'], true); // 转换内容图片为http路径
- } else {
- $detail['detail'] = [
- 'arcrank' => $detail['detail']['arcrank'],
- ];
- }
- }
-
- $result = [
- 'detail' => [
- 'data' => !empty($detail['detail']) ? $detail['detail'] : false,
- ],
- 'product'=> !empty($detail['product']) ? $detail['product'] : [],
- 'coupon_list'=> !empty($detail['coupon_list']) ? $detail['coupon_list'] : [],
- ];
-
- cache($cacheKey, $result, null, 'archives');
- }
-
- return $result;
- }
-
- /**
- * 获取限时折扣商品记录
- */
- private function getDiscountInfo($aid,$users = [])
- {
- $where = [
- 'a.status' => 1,
- 'a.is_del' => 0,
- 'a.aid' => $aid,
- ];
- $result = [];
- $detail = Db::name('discount_goods')
- ->alias('a')
- ->field('a.discount_gid,a.discount_stock,a.discount_price,a.sales,a.virtual_sales,a.is_sku,b.sales_actual,c.*')
- ->where($where)
- ->join('discount_active_goods b','a.aid = b.aid','left')
- ->join('archives c','a.aid = c.aid','left')
- ->find();
-
- if (!empty($detail)) {
- // 模型标题处理
- $channeltype_row = \think\Cache::get('extra_global_channeltype');
- $channeltypeInfo = !empty($channeltype_row[$detail['channel']]) ? $channeltype_row[$detail['channel']] : [];
- $detail['channel_ntitle'] = !empty($channeltypeInfo['ntitle']) ? $channeltypeInfo['ntitle'] : '文章';
- $detail['seo_title'] = $this->set_arcseotitle($detail['title'], $detail['seo_title']); // seo标题
- $detail['litpic'] = $this->get_default_pic($detail['litpic']); // 默认封面图
- $detail['content'] = '';
-
- unset($detail['users_free']);
- unset($detail['downcount']);
-
- /*产品参数*/
- if (!empty($detail['attrlist_id'])){ // 新版参数
- $productAttrModel = new \app\home\model\ProductAttr;
- $attr_list = $productAttrModel->getProAttrNew($aid, 'a.attr_id,a.attr_name,b.attr_value,b.aid');
- }else{ // 旧版参数
- $productAttrModel = new \app\home\model\ProductAttr;
- $attr_list = $productAttrModel->getProAttr($aid);
- }
- $attr_list = !empty($attr_list[$aid]) ? $attr_list[$aid] : [];
- foreach ($attr_list as $key => $val) {
- $val['attr_value'] = htmlspecialchars_decode($val['attr_value']);
- unset($val['aid']);
- $attr_list[$key] = $val;
- }
- $detail['attr_list'] = !empty($attr_list) ? $attr_list : false;
-
-
- /*规格数据*/
- $detail['spec_attr'] = $this->getSpecAttr($aid, $users,'discount_price asc,spec_price asc');
- /* END */
-
- // 产品相册
- $productImgModel = new \app\home\model\ProductImg;
- $image_list = $productImgModel->getProImg($aid, 'aid,image_url,intro');
- $image_list = !empty($image_list[$aid]) ? $image_list[$aid] : [];
- foreach ($image_list as $key => $val) {
- $val['image_url'] = $this->get_default_pic($val['image_url']);
- isset($val['intro']) && $val['intro'] = htmlspecialchars_decode($val['intro']);
- $image_list[$key] = $val;
- }
-
- $detail['image_list'] = !empty($image_list) ? $image_list : false;
- /*可控制的主表字段列表*/
- $detail['ifcontrolRow'] = Db::name('channelfield')->field('id,name')->where([
- 'channel_id' => $detail['channel'],
- 'ifmain' => 1,
- 'ifeditable' => 1,
- 'ifcontrol' => 0,
- 'status' => 1,
- ])->getAllWithIndex('name');
-
- // 设置默认原价
- $detail['old_price'] = $detail['users_price'];
- $detail['product_num'] = 1;
- $detail['spec_value_id'] = '';
-
- $result['product'] = $this->getRecomProduct();
- $result['coupon_list'] = $this->getCoupon($detail,$users);
- if ('v1.5.1' < getVersion()) {
- //总评论数
- $detail['comment_data_count'] = Db::name('shop_order_comment')->where(['product_id'=>$aid,'is_show'=>1])->count();
- $good_count = Db::name('shop_order_comment')->where(['product_id'=>$aid,'is_show'=>1,'total_score'=>1])->count();
- //好评率
- $detail['comment_good_per'] = !empty($detail['comment_data_count']) ? round($good_count/$detail['comment_data_count'],2)*100 : 0;
- $detail['comment_good_per'] = $detail['comment_good_per'].'%';
- if ($detail['comment_data_count'] > 0){
- $detail['comment_data'] = Db::name('shop_order_comment')
- ->alias('a')
- ->field('a.*,b.nickname,b.head_pic')
- ->join('users b','a.users_id = b.users_id')
- ->where(['a.product_id'=>$aid,'a.is_show'=>1])
- ->order('a.total_score asc')
- ->limit(2)
- ->select();
- foreach ($detail['comment_data'] as $k => $v){
- if (1 == $v['is_anonymous']){
- $v['nickname'] = '匿名用户';
- }
- $v['add_time'] = date('Y-m-d H:i:s',$v['add_time']);
- $v['content'] = unserialize($v['content']);
- $v['head_pic'] = get_default_pic($v['head_pic'],true);
- $detail['comment_data'][$k] = $v;
- }
- }
- }
-
- $detail['cart_total_num'] = 0;
- if (!empty($users['users_id'])){
- //购物车数量
- $detail['cart_total_num'] = Db::name('shop_cart')->where(['users_id' => $users['users_id']])->sum('product_num');
- }
-
- // 获取自定义字段的数据
- $customField = [];
- $detailExt = Db::name($channeltypeInfo['table'].'_content')->field('id,aid,add_time,update_time', true)->where('aid', $aid)->find();
- if (!empty($detailExt)) {
- $fieldLogic = new \app\home\logic\FieldLogic();
- $detailExt = $fieldLogic->getChannelFieldList($detailExt, $detail['channel']); // 自定义字段的数据格式处理
- if (empty($channeltypeInfo['ifsystem'])) { // 自定义模型
- // 如果存在自定义字段content,默认作为文档的正文内容。
- // 如果不存在,将获取第一个html类型的内容,作为文档的正文内容。
- if (!isset($detailExt['content'])) {
- $contentField = Db::name('channelfield')->where([
- 'channel_id' => $detail['channel'],
- 'dtype' => 'htmltext',
- ])->getField('name');
- $detailExt['content'] = !empty($detailExt[$contentField]) ? $detailExt[$contentField] : '';
- }
- }
- $detail['content'] = $detailExt['content'];
- unset($detailExt['content']);
-
- if (!empty($detailExt)) {
- $field = 'name, title, dtype';
- $customField = Db::name('channelfield')->field($field)->where([
- 'name' => ['IN', array_keys($detailExt)],
- 'channel_id' => $detail['channel'],
- 'ifeditable' => 1
- ])->getAllWithIndex('name');
- if (!empty($customField)) {
- foreach ($customField as $key => $value) {
- if ('img' == $value['dtype']) {
- $customField[$key]['value'] = $this->get_default_pic($detailExt[$key]);
- } else if ('media' == $value['dtype']) {
- $customField[$key]['value'] = $this->get_default_pic($detailExt[$key]);
- } else if ('imgs' == $value['dtype']) {
- foreach ($detailExt[$key] as $kk => $vv) {
- $detailExt[$key][$kk]['image_url'] = $this->get_default_pic($vv['image_url']);
- }
- $customField[$key]['value'] = $detailExt[$key];
- } else {
- $customField[$key]['value'] = $detailExt[$key];
- }
- }
- }
- }
- $customField = array_values($customField);
- }
- $detail['customField'] = !empty($customField) ? $customField : false;
-
- // 浏览量
- Db::name('archives')->where(['aid'=>$aid])->setInc('click');
- $detail['click'] += 1;
-
- $result['detail'] = $detail;
- }
-
- return $result;
- }
-
- //添加文章评论
- public function addArticleComment($param = [],$users = [])
- {
- $users_level_id = !empty($users['level_id']) ? $users['level_id'] : 0;//0-游客
- $comment_level_data = Db::name('weapp_comment_level')->where('users_level_id',$users_level_id)->find();
- if (empty($comment_level_data['is_comment'])){
- return ['code'=>0, 'msg'=>'您没有评论权限'];
- }
- if (!empty($comment_level_data['is_review'])){
- $param['is_review'] = 0;
- }else{
- $param['is_review'] = 1;
- }
- $param['add_time'] = getTime();
- $param['update_time'] = getTime();
- $param['users_id'] = !empty($users['users_id']) ? $users['users_id'] : 0;
- $param['username'] = !empty($users['username']) ? $users['username'] : '游客';
- $param['provider'] = !empty($param['provider']) ? $param['provider'] : 'weixin';
- $param['users_ip'] = clientIP();
- if (!empty($param['content'])) {
- $content_tmp = filterNickname($param['content']);
- if ($content_tmp != $param['content']) {
- return ['code'=>0, 'msg'=>'不支持表情等特殊符号'];
- }
- }
- $comment_id = Db::name('weapp_comment')->insertGetId($param);
- if (false !== $comment_id){
- $data = ['code'=>1, 'is_show'=>0];
- if (empty($param['is_review'])) {
- $msg = '评论成功,进入待审核中';
- } else {
- $msg = '评论成功';
- $comment = Db::name('weapp_comment')
- ->alias('a')
- ->field('a.*,b.head_pic,b.nickname,b.sex')
- ->join('users b','a.users_id = b.users_id','left')
- ->find($comment_id);
- $comment['head_pic'] = $this->get_head_pic($comment['head_pic'], false, $comment['sex']);
- $comment['add_time_format'] = $this->time_format($comment['add_time']);
- $comment['add_time'] = date('Y-m-d', $comment['add_time']);
- $data['comment'] = $comment;
- $data['is_show'] = 1;
- }
- $data['msg'] = $msg;
-
- return $data;
- }
- return ['code'=>0, 'msg'=>'添加评论失败'];
- }
- /**
- * 索引页
- */
- public function getRepertory($page=1)
- {
- $paginate = array(
- 'page' => $page,
- );
- $allow_release_channel = config('global.allow_release_channel');
- $pages = Db::name('archives')->field('aid,typeid,title,channel,update_time')
- ->where([
- 'channel' => ['IN', $allow_release_channel],
- 'arcrank' => ['EGT', 0],
- 'is_del' => 0,
- 'lang' => parent::$lang,
- ])
- ->order('update_time desc')
- ->paginate(100, false, $paginate);
-
- $list = array();
- foreach ($pages->items() as $key => $val) {
- $path = '';
- if (1 == $val['channel']) {
- $path = '/pages/archives/article/view?aid='.$val['aid'].'&typeid='.$val['typeid'];
- } else if (2 == $val['channel']) {
- $path = '/pages/archives/product/view?aid='.$val['aid'].'&typeid='.$val['typeid'];
- } else if (3 == $val['channel']) {
- $path = '/pages/archives/images/view?aid='.$val['aid'].'&typeid='.$val['typeid'];
- } else if (4 == $val['channel']) {
- $path = '/pages/archives/download/view?aid='.$val['aid'].'&typeid='.$val['typeid'];
- } else if (5 == $val['channel']) {
- $path = '/pages/archives/media/view?aid='.$val['aid'].'&typeid='.$val['typeid'];
- } else if (6 == $val['channel']) {
- $path = '/pages/archives/single/view?typeid='.$val['typeid'];
- } else if (7 == $val['channel']) {
- $path = '/pages/archives/special/view?aid='.$val['aid'].'&typeid='.$val['typeid'];
- } else {
- $path = '/pages/archives/custom/view?aid='.$val['aid'].'&typeid='.$val['typeid'];
- }
-
- $arr = [
- 'title' => $val['title'],
- 'path' => $path,
- 'releaseDate' => MyDate('Y-m-d H:i:s', $val['update_time']),
- ];
- $list[] = $arr;
- }
- $result = array(
- 'totalPage' => $pages->lastPage(),
- 'current' => $page,
- 'list' => $list,
- );
- return $result;
- }
-
- /**
- * 发送微信小程序订阅消息
- */
- public function sendAppletsNotice($result_id, $send_scene = 0, $users = [])
- {
- $template_info = Db::name('applets_template')->where(['send_scene' => $send_scene])->find();
- if (empty($template_info)) {
- return ['code' => 0, 'msg' => '小程序消息模板不存在'];
- } else if (empty($template_info['is_open'])) {
- return ['code' => 0, 'msg' => '小程序消息模板没开启'];
- }
-
- $tokenData = get_weixin_access_token(true);
- if (!empty($tokenData['code'])) {
- $redata = $this->weixinTemplateKeywords($result_id, $template_info);
- $openid = Db::name('wx_users')->where(['users_id' => $users['users_id']])->value('openid');
- $post_data = [
- 'template_id' => $template_info['template_id'],
- 'page' => !empty($redata['pagepath']) ? $redata['pagepath'] : '/pages/index/index',
- 'touser' => $openid,
- 'data' => $redata['data'],
- 'miniprogram_state' => 'formal',
- 'lang' => 'zh_CN',
- ];
- $url = "https://api.weixin.qq.com/cgi-bin/message/subscribe/send?access_token=" . $tokenData['access_token'];
- $response = httpRequest($url, 'POST', json_encode($post_data, JSON_UNESCAPED_UNICODE));
- $params = json_decode($response, true);
- if (isset($params['errcode']) && empty($params['errcode'])) {
- return ['code' => 1, 'msg' => '发送成功'];
- }
- }
- $msg = !empty($params['errmsg']) ? $params['errmsg'] : $tokenData['msg'];
- return ['code' => 0, 'msg' => $msg];
- }
-
- private function weixinTemplateKeywords($result_id, $template_info)
- {
- $data = [];
- $pagepath = '';
- $tpl_data = json_decode($template_info['tpl_data'], true);
- $keywordsList = [];
- if (!empty($tpl_data['keywordsList'])) {
- foreach ($tpl_data['keywordsList'] as $key => $val) {
- $keywordsList[$val['rule'] . $val['kid']] = $val;
- }
- }
- $send_scene = $template_info['send_scene'];
- // 订单发货通知
- if (7 == $send_scene) {
- $pagepath = "/pages/order/detail?order_id={$result_id}";
- $orderInfo = Db::name('shop_order')->where(['order_id' => $result_id])->find();
- $orderDetailsInfo = Db::name('shop_order_details')->where(['order_id' => $orderInfo['order_id']])->order('details_id asc')->select();
- $product_name_new = msubstr($orderDetailsInfo[0]['product_name'], 0, 15);
- if ($product_name_new == $orderDetailsInfo[0]['product_name'] && count($orderDetailsInfo) == 1) {
- $product_name = $product_name_new;
- } else {
- $product_name = $product_name_new . '等...';
- }
- $data = [
- 'character_string1' => [
- 'value' => $orderInfo['order_code'],
- ],
- 'thing2' => [
- 'value' => $product_name,
- ],
- 'thing7' => [
- 'value' => $orderInfo['express_name'],
- ],
- 'character_string4' => [
- 'value' => $orderInfo['express_order'],
- ],
- 'date5' => [
- 'value' => MyDate('Y-m-d H:i:s', $orderInfo['express_time']),
- ],
- ];
- }
-
- return [
- 'data' => $data,
- 'pagepath' => $pagepath,
- ];
- }
-
- /**
- * 发送微信公众号模板消息
- */
- public function sendWechatNotice($result_id, $send_scene = 0, $users = [])
- {
- // 用户关注公众号则发送
- if (!empty($users['wechat_followed']) && !empty($users['wechat_open_id'])) {
- // 存在指定模板并已开启则发送
- $template_info = Db::name('wechat_template')->where(['send_scene' => $send_scene])->find();
- if (!empty($result_id) && !empty($template_info['is_open'])) {
- $tokenData = get_wechat_access_token();
- if (!empty($tokenData['code'])) {
- $redata = $this->wechatTemplateKeywords($result_id, $template_info);
- $post_data = [
- 'template_id' => $template_info['template_id'],
- 'touser' => $users['wechat_open_id'],
- 'data' => $redata['data'],
- 'client_msg_id' => md5(json_encode($redata)),
- ];
- $web_status = tpCache('web.web_status');
- if (!empty($web_status)) {
- $post_data['url'] = !empty($redata['gourl']) ? $redata['gourl'] : request()->domain() . $this->root_dir;
- }
- $url = "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" . $tokenData['access_token'];
- httpRequest($url, 'POST', json_encode($post_data, JSON_UNESCAPED_UNICODE));
- }
- }
- }
- }
-
- private function wechatTemplateKeywords($result_id, $template_info)
- {
- $data = [];
- $gourl = $pagepath = "";
- $tpl_data = json_decode($template_info['tpl_data'], true);
- $keywordsList = [];
- if (!empty($tpl_data['keywordsList'])) {
- foreach ($tpl_data['keywordsList'] as $key => $val) {
- $keywordsList[$val['rule']] = $val;
- }
- }
- $send_scene = $template_info['send_scene'];
- // 订单支付成功通知
- if (9 == $send_scene) {
- $pagepath = "/pages/order/detail?order_id={$result_id}";
- $gourl = url('user/Shop/shop_order_details', ['order_id' => $result_id]);
- $orderInfo = Db::name('shop_order')->where(['order_id' => $result_id])->find();
- $orderDetailsInfo = Db::name('shop_order_details')->where(['order_id' => $orderInfo['order_id']])->order('details_id asc')->select();
- $product_name_new = msubstr($orderDetailsInfo[0]['product_name'], 0, 22);
- if ($product_name_new == $orderDetailsInfo[0]['product_name'] && count($orderDetailsInfo) == 1) {
- $product_name = $product_name_new;
- } else {
- $product_name = $product_name_new . '等...';
- }
- $data = [
- 'first' => [
- 'value' => $template_info['template_title'],
- ],
- 'keyword1' => [
- 'value' => $orderInfo['order_code'],
- ],
- 'keyword2' => [
- 'value' => $product_name,
- ],
- 'keyword3' => [
- 'value' => count($orderDetailsInfo),
- ],
- 'keyword4' => [
- 'value' => "¥{$orderInfo['order_amount']}",
- ],
- 'keyword5' => [
- 'value' => MyDate('Y-m-d H:i:s', $orderInfo['pay_time']),
- ],
- 'remark' => [
- 'value' => !empty($keywordsList['remark']) ? $keywordsList['remark']['example'] : '请您登录商城查看订单并发货!',
- ],
- ];
- }
-
- return [
- 'data' => $data,
- 'pagepath' => $pagepath,
- 'gourl' => $gourl,
- ];
- }
- }
|