Browse Source

瀑布流后台管理及瀑布流列表插入广告

dev
李可松 5 years ago
parent
commit
f9a911352e
  1. 17
      MySQL_change.sql
  2. 71
      app/AdminAgent/Controllers/WaterfallAdController.php
  3. 35
      app/Http/Controllers/Api/AgentProductController.php
  4. 6
      app/Models/WaterfallAd.php
  5. 8
      resources/lang/zh_CN/waterfall-ad.php

17
MySQL_change.sql

@ -85,7 +85,6 @@ ENGINE=InnoDB
ALTER TABLE `agent_products`
ADD COLUMN `stock` INT(10) NOT NULL DEFAULT '0' COMMENT '库存' AFTER `sale`;
#################################################################
# 10:42 ‎2021/‎08/‎21
ALTER TABLE `orders`
CHANGE COLUMN `order_no` `order_no` CHAR(22) NOT NULL COMMENT '订单号' COLLATE 'utf8_general_ci' AFTER `agent_id`;
@ -96,15 +95,20 @@ ALTER TABLE `orders`
# 10:35 ‎2021/‎08/‎22
ALTER TABLE `slides`
CHANGE COLUMN `url` `picture` VARCHAR(255) NOT NULL COMMENT '轮播图地址' COLLATE 'utf8_general_ci' AFTER `title`,
ADD COLUMN `type` TINYINT NOT NULL DEFAULT '0' COMMENT '链接类型,0:链接产品详情;1:链接到webview url' AFTER `sort`,
ADD COLUMN `type` TINYINT NOT NULL DEFAULT '0' COMMENT '链接类型,0:链接到内部页面;1:链接到webview url' AFTER `sort`,
ADD COLUMN `url` VARCHAR(255) NOT NULL DEFAULT '' COMMENT '链接地址' AFTER `type`;
#################################################################
# 23:43 ‎2021/‎08/‎22
CREATE TABLE `waterfall_ads` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`agent_id` INT(11) NOT NULL COMMENT '代理商ID',
`id` INT(10) NOT NULL AUTO_INCREMENT,
`agent_id` INT(10) NOT NULL COMMENT '代理商ID',
`title` VARCHAR(255) NOT NULL DEFAULT '' COMMENT '广告名称' COLLATE 'utf8_general_ci',
`picture` VARCHAR(255) NOT NULL COMMENT '广告图片' COLLATE 'utf8_general_ci',
`agent_product_id` INT(11) NOT NULL COMMENT '链接到产品',
`type` TINYINT(3) NOT NULL DEFAULT '0' COMMENT '链接类型,0:链接到内部页面;1:链接到外部url',
`url` VARCHAR(50) NOT NULL COMMENT '链接' COLLATE 'utf8_general_ci',
`status` TINYINT(3) NOT NULL DEFAULT '1' COMMENT '0:未启用,1:启用',
`sort` SMALLINT(5) NOT NULL DEFAULT '255' COMMENT '排序,越小越靠前',
`created_at` TIMESTAMP NULL DEFAULT NULL,
`updated_at` TIMESTAMP NULL DEFAULT NULL,
PRIMARY KEY (`id`) USING BTREE,
@ -112,5 +116,4 @@ CREATE TABLE `waterfall_ads` (
)
COMMENT='瀑布流内嵌广告'
COLLATE='utf8_general_ci'
ENGINE=InnoDB
;
ENGINE=InnoDB;

71
app/AdminAgent/Controllers/WaterfallAdController.php

@ -18,22 +18,23 @@ class WaterfallAdController extends AdminController
*/
protected function grid()
{
return Grid::make(new WaterfallAd(), function (Grid $grid) {
$grid->disableFilterButton();
return Grid::make(new WaterfallAd('agentProduct.product:id,title'), function (Grid $grid) {
$grid->model()->where('agent_id', Admin::user()->id)->orderBy('sort')->orderBy('id', 'DESC');
$grid->model()->where('agent_id', Admin::user()->id);
$grid->column('id')->sortable();
$grid->column('title');
$grid->column('picture')->image('', 60, 60);
$grid->column('type')->using(['链接内部页面', '链接网址']);
$grid->column('url');
$grid->column('status')->switch();
$grid->column('sort')->editable()->sortable()->width(120);
$grid->column('id')->sortable();
$grid->column('picture');
$grid->column('agent_product_id');
$grid->column('created_at');
$grid->column('updated_at')->sortable();
$grid->filter(function (Grid\Filter $filter) {
$grid->filter(function (Grid\Filter $filter) {
$filter->panel();
$filter->equal('id');
});
$filter->equal('id');
$filter->like('title');
});
});
}
@ -46,15 +47,19 @@ class WaterfallAdController extends AdminController
*/
protected function detail($id)
{
return Show::make($id, new WaterfallAd(), function (Show $show) {
return Show::make($id, new WaterfallAd('agentProduct.product:id,title'), function (Show $show) {
//不允许查看非自己的数据
if ($show->model()->agent_id != Admin::user()->id) {
Admin::exit('数据不存在');
}
$show->field('id');
$show->field('picture');
$show->field('agent_product_id');
$show->field('title');
$show->field('picture')->image('', 80, 80);
$show->field('type')->using(['链接内部页面', '链接网址']);
$show->field('url');
$show->field('status')->using(['禁用', '启用']);
$show->field('sort');
$show->field('created_at');
$show->field('updated_at');
});
@ -74,15 +79,47 @@ class WaterfallAdController extends AdminController
}
$form->display('id');
$form->text('picture');
$form->text('agent_product_id');
$form->text('title')->required();
$form->image('picture')
->required()->removable(false)->uniqueName();
$form->radio('type', '链接类型')
->options(['链接到内部页面', '链接到网址'])
->value(0)->default(0)
->when(0, function (Form $form) {
$form->text('url-0', '内部页面地址')
->customFormat(fn() => $this->type == 0 ? $this->url : '')
->help('格式如下:<br>产品详情页:/pages/goodsDetail/index?goods_id=产品ID
<br>文章详情页:/pages/notice/article?article_id=文章ID
<br>公告详情页:/pages/notice/notice?notice_id=公告ID');
})
->when(1, function (Form $form) {
$form->url('url-1', '链接到网址')
->placeholder('如:https://www.baidu.com/')
->customFormat(fn() => $this->type == 1 ? $this->url : '');
});
$form->text('sort')->default(255)->required();
})->saving(function (Form $form) {
//不允许修改非自己的数据
if ($form->isEditing() && $form->model()->agent_id != Admin::user()->id) {
return $form->response()->error('数据不存在');
}
//将null字段设置为空值,防止插入数据库出错
foreach ($form->input() as $k => $v) {
if (is_null($v)) {
$form->$k = '';
}
}
//处理特殊字段
$form->hidden(['agent_id', 'url']);
$form->agent_id = Admin::user()->id;
$form->status = $form->status ? 1 : 0;
$form->url = $form->{'url-' . $form->type};
$form->deleteInput(['url-0', 'url-1']);
//不允许编辑的字段
$form->ignore(['id', 'created_at', 'updated_at']);
})->deleting(function (Form $form) {
//不允许删除非自己的数据
if ($form->model()[0]['agent_id'] != Admin::user()->id) {

35
app/Http/Controllers/Api/AgentProductController.php

@ -5,6 +5,7 @@ use App\Common\ProductStatus;
use App\Http\Controllers\Controller;
use App\Models\AgentProduct;
use App\Models\UserFav;
use App\Models\WaterfallAd;
use Illuminate\Support\Facades\Storage;
/**
@ -26,6 +27,7 @@ class AgentProductController extends Controller
$list = AgentProduct::list()->where($where)->simplePaginate();
$list = $this->paginatePicAddHost($list);
$list = $this->insertAd($list);
return $this->success($list);
}
@ -99,4 +101,37 @@ class AgentProductController extends Controller
}
return $list;
}
//插入瀑布流广告
private function insertAd($list)
{
//插入瀑布流广告,分别在第8个和第16个插入,同时需要考虑到分页。当所有瀑布流广告插入完之后,再次循环插入
$list = $list->toArray();
if ($list['data']) {
$ad_total = WaterfallAd::where(['agent_id' => $this->agent_id, 'status' => 1])->count();
$page = (int)request()->input('page');
$start = ($page ? $page - 1 : 0) * 2 % $ad_total;
$ad = WaterfallAd::where(['agent_id' => $this->agent_id, 'status' => 1])
->orderBy('sort')->orderBy('id', 'DESC')
->offset($start)->limit(2)->get(['title', 'picture', 'type', 'url'])->toArray();
$prefix = Storage::disk('public')->url('');
//每隔8个插入广告
$gap = 4;
foreach ($ad as $k => &$v) {
$v['is_ad'] = true;
$v['picture'] = $prefix . $v['picture'];
//插入广告
$temp = $gap * ($k+1);
if (!empty($list['data'][$temp - 1]) && !empty($ad[$k])) {
array_splice($list['data'], $temp + $k, 0, [$ad[$k]]);
}
}
}
return $list;
}
}

6
app/Models/WaterfallAd.php

@ -10,5 +10,9 @@ class WaterfallAd extends Model
{
use HasDateTimeFormatter;
protected $table = 'waterfall_ads';
public function agentProduct()
{
return $this->belongsTo(AgentProduct::class);
}
}

8
resources/lang/zh_CN/waterfall-ad.php

@ -1,13 +1,17 @@
<?php
<?php
return [
'labels' => [
'WaterfallAd' => '产品列表内嵌广告',
'waterfall-ad' => '产品列表内嵌广告',
],
'fields' => [
'title' => '广告名称',
'agent_id' => '代理商ID',
'picture' => '广告图片',
'agent_product_id' => '链接到产品',
'type' => '链接',
'url' => '链接地址',
'sort' => '排序',
'status' => '状态',
],
'options' => [
],

Loading…
Cancel
Save