// +---------------------------------------------------------------------- declare (strict_types=1); namespace app\common\model; use cores\BaseModel; use app\common\library\helper; use app\common\enum\page\PageType as PageTypeEnum; /** * 店铺页面模型 * Class Page * @package app\common\model */ class Page extends BaseModel { // 定义表名 protected $name = 'page'; // 定义主键 protected $pk = 'page_id'; /** * 获取器:格式化页面数据 * @param string $json * @return array */ public function getPageDataAttr(string $json): array { // 数据转义 $array = helper::jsonDecode(htmlspecialchars_decode($json)); // 合并默认数据 return $this->_mergeDefaultData($array); } /** * 修改器:自动转换data为json格式 * @param array $value * @return string */ public function setPageDataAttr(array $value): string { return helper::jsonEncode($value ?: ['items' => []]); } /** * 页面标题栏默认数据 * @return array */ public function getDefaultPage(): array { return [ 'params' => [ 'name' => '页面名称', 'title' => '页面标题', 'shareTitle' => '分享标题' ], 'style' => [ 'titleTextColor' => 'black', 'titleBackgroundColor' => '#ffffff', ] ]; } /** * 页面diy元素默认数据 * @return array */ public function getDefaultItems(): array { return [ 'search' => [ 'name' => '搜索框', 'type' => 'search', 'params' => ['placeholder' => '请输入关键字进行搜索'], 'style' => [ 'textAlign' => 'left', 'searchStyle' => 'square' ] ], 'banner' => [ 'name' => '图片轮播', 'type' => 'banner', 'style' => [ 'btnColor' => '#ffffff', 'btnShape' => 'round', 'interval' => 2.5 ], 'data' => [ [ 'imgUrl' => base_url() . 'assets/store/img/diy/banner/01.png', 'link' => null ], [ 'imgUrl' => base_url() . 'assets/store/img/diy/banner/01.png', 'link' => null ] ] ], 'image' => [ 'name' => '图片', 'type' => 'image', 'style' => [ 'paddingTop' => 0, 'paddingLeft' => 0, 'background' => '#ffffff' ], 'data' => [ [ 'imgUrl' => base_url() . 'assets/store/img/diy/banner/01.png', 'imgName' => 'image-1.jpg', 'link' => null ] ] ], 'navBar' => [ 'name' => '导航组', 'type' => 'navBar', 'style' => ['rowsNum' => 4, 'background' => '#ffffff', 'paddingTop' => 0, 'textColor' => '#666666'], 'data' => [ [ 'imgUrl' => base_url() . 'assets/store/img/diy/navbar/01.png', 'imgName' => 'icon-1.png', 'link' => null, 'text' => '按钮文字1' ], [ 'imgUrl' => base_url() . 'assets/store/img/diy/navbar/01.png', 'imgName' => 'icon-2.jpg', 'link' => null, 'text' => '按钮文字2' ], [ 'imgUrl' => base_url() . 'assets/store/img/diy/navbar/01.png', 'imgName' => 'icon-3.jpg', 'link' => null, 'text' => '按钮文字3' ], [ 'imgUrl' => base_url() . 'assets/store/img/diy/navbar/01.png', 'imgName' => 'icon-4.jpg', 'link' => null, 'text' => '按钮文字4' ] ] ], 'blank' => [ 'name' => '辅助空白', 'type' => 'blank', 'style' => [ 'height' => 20, 'background' => '#ffffff' ] ], 'guide' => [ 'name' => '辅助线', 'type' => 'guide', 'style' => [ 'background' => '#ffffff', 'lineStyle' => 'solid', 'lineHeight' => 1, 'lineColor' => "#000000", 'paddingTop' => 10 ] ], 'video' => [ 'name' => '视频组', 'type' => 'video', 'params' => [ 'videoUrl' => 'http://wxsnsdy.tc.qq.com/105/20210/snsdyvideodownload?filekey=30280201010421301f0201690402534804102ca905ce620b1241b726bc41dcff44e00204012882540400.mp4', 'poster' => base_url() . 'assets/store/img/diy/video_poster.png', 'autoplay' => 0 ], 'style' => [ 'paddingTop' => 0, 'height' => 190 ] ], 'article' => [ 'name' => '文章组', 'type' => 'article', 'params' => [ 'source' => 'auto', // 数据来源 (choice指定 auto自动获取) 'auto' => [ 'category' => -1, // -1全部 'showNum' => 6 ] ], // '自动获取' => 默认数据 'defaultData' => [ [ 'title' => '此处显示文章标题', 'show_type' => 10, 'image' => base_url() . 'assets/store/img/diy/article/01.png', 'views_num' => 309 ], [ 'title' => '此处显示文章标题', 'show_type' => 10, 'image' => base_url() . 'assets/store/img/diy/article/01.png', 'views_num' => 309 ] ], // '手动选择' => 默认数据 'data' => [] ], 'notice' => [ 'name' => '店铺公告', 'type' => 'notice', 'params' => [ 'text' => '这里是第一条自定义公告的标题', // 公告内容 // 'icon' => base_url() . 'assets/store/img/diy/notice.png', 'link' => null, // 链接 'showIcon' => true, // 是否显示图标 'scrollable' => true // 是否滚动 ], 'style' => [ 'paddingTop' => 0, 'background' => '#fffbe8', 'textColor' => '#de8c17' ] ], 'richText' => [ 'name' => '富文本', 'type' => 'richText', 'params' => [ 'content' => '

这里是文本的内容

' ], 'style' => [ 'paddingTop' => 0, 'paddingLeft' => 0, 'background' => '#ffffff' ] ], 'window' => [ 'name' => '图片橱窗', 'type' => 'window', 'style' => [ 'paddingTop' => 0, 'paddingLeft' => 0, 'background' => '#ffffff', 'layout' => 2 // 布局方式: -1橱窗 ], 'data' => [ [ 'imgUrl' => base_url() . 'assets/store/img/diy/window/01.jpg', 'link' => null ], [ 'imgUrl' => base_url() . 'assets/store/img/diy/window/02.jpg', 'link' => null ], [ 'imgUrl' => base_url() . 'assets/store/img/diy/window/03.jpg', 'link' => null ], [ 'imgUrl' => base_url() . 'assets/store/img/diy/window/04.jpg', 'link' => null ] ], 'dataNum' => 4 ], 'hotZone' => [ 'name' => '热区', 'type' => 'hotZone', 'style' => [ 'paddingTop' => 0, 'paddingLeft' => 0, 'background' => '#ffffff' ], 'data' => [ 'imgUrl' => base_url() . 'assets/store/img/diy/banner/01.png', 'imgName' => 'image-1.jpg', 'maps' => [ [ 'width' => 300, 'height' => 100, 'left' => 0, 'top' => 0, 'link' => null, 'key' => 1 ], ] ] ], 'goods' => [ 'name' => '商品组', 'type' => 'goods', 'params' => [ 'source' => 'auto', // 数据来源 (choice手动选择 auto自动获取) 'auto' => [ 'category' => 0, // 商品分类 0为全部 'goodsSort' => 'all', // 商品排序 (all默认 sales销量 price价格) 'showNum' => 6 // 显示数量 ] ], 'style' => [ 'background' => '#F6F6F6', 'display' => 'list', // 显示类型 (list列表平铺 slide横向滑动) 'column' => 2, // 分列数量 'show' => [ // 显示内容 'goodsName', 'goodsPrice', 'linePrice', 'sellingPoint', 'goodsSales' ] ], // '自动获取' => 默认数据 'defaultData' => [ [ 'goods_name' => '此处显示商品名称', 'goods_image' => base_url() . 'assets/store/img/diy/goods/01.png', 'goods_price_min' => '99.00', 'line_price_min' => '139.00', 'selling_point' => '此款商品美观大方 不容错过', 'goods_sales' => 100, ], [ 'goods_name' => '此处显示商品名称', 'goods_image' => base_url() . 'assets/store/img/diy/goods/01.png', 'goods_price_min' => '99.00', 'line_price_min' => '139.00', 'selling_point' => '此款商品美观大方 不容错过', 'goods_sales' => 100, ], [ 'goods_name' => '此处显示商品名称', 'goods_image' => base_url() . 'assets/store/img/diy/goods/01.png', 'goods_price_min' => '99.00', 'line_price_min' => '139.00', 'selling_point' => '此款商品美观大方 不容错过', 'goods_sales' => 100, ], [ 'goods_name' => '此处显示商品名称', 'goods_image' => base_url() . 'assets/store/img/diy/goods/01.png', 'goods_price_min' => '99.00', 'line_price_min' => '139.00', 'selling_point' => '此款商品美观大方 不容错过', 'goods_sales' => 100, ] ], // '手动选择' => 默认数据 'data' => [ [ 'goods_name' => '此处显示商品名称', 'goods_image' => base_url() . 'assets/store/img/diy/goods/01.png', 'goods_price_min' => '99.00', 'line_price_min' => '139.00', 'selling_point' => '此款商品美观大方 不容错过', 'goods_sales' => 100 ], [ 'goods_name' => '此处显示商品名称', 'goods_image' => base_url() . 'assets/store/img/diy/goods/01.png', 'goods_price_min' => '99.00', 'line_price_min' => '139.00', 'selling_point' => '此款商品美观大方 不容错过', 'goods_sales' => 100 ] ] ], 'service' => [ 'name' => '在线客服', 'type' => 'service', 'params' => [ 'type' => 'chat', // '客服类型' => chat在线聊天,phone拨打电话 'image' => base_url() . 'assets/store/img/diy/service.png', 'tel' => '' // 电话号吗 ], 'style' => [ 'right' => 1, 'bottom' => 10, 'opacity' => 100 ] ], 'officialAccount' => [ 'name' => '关注公众号', 'type' => 'officialAccount', 'params' => [], 'style' => [] ], 'shop' => [ 'name' => '线下门店', 'type' => 'shop', 'params' => [ 'source' => 'auto', // choice; auto 'auto' => ['showNum' => 6] ], 'style' => [ 'show' => ['logo', 'address', 'phone'], // 显示内容 'background' => '#ffffff', // 背景颜色 ], // '自动获取' => 默认数据 'defaultData' => [ [ 'shop_name' => '此处显示门店名称', 'logo_url' => base_url() . 'assets/store/img/diy/circular.png', 'phone' => '010-6666666', 'region' => [ 'province' => 'xxx省', 'city' => 'xxx市', 'region' => 'xxx区' ], 'address' => 'xxx街道', ], [ 'shop_name' => '此处显示门店名称', 'logo_url' => base_url() . 'assets/store/img/diy/circular.png', 'phone' => '010-6666666', 'region' => [ 'province' => 'xxx省', 'city' => 'xxx市', 'region' => 'xxx区' ], 'address' => 'xxx街道', ], ], // '手动选择' => 默认数据 'data' => [ [ 'shop_name' => '此处显示门店名称', 'logo_url' => base_url() . 'assets/store/img/diy/circular.png', 'phone' => '010-6666666', 'region' => [ 'province' => 'xxx省', 'city' => 'xxx市', 'region' => 'xxx区' ], 'address' => 'xxx街道', ], ] ], 'bargain' => [ 'name' => '砍价商品组', 'type' => 'bargain', 'params' => [ 'source' => 'auto', // 数据来源 choice:手动 auto:自动 'auto' => [ 'goodsSort' => 'all', // 商品排序 all; sales; price 'showNum' => 6 ] ], 'style' => [ 'background' => '#F6F6F6', 'show' => [ 'goodsName', 'peoples', 'floorPrice', 'originalPrice' ] ], 'demo' => [ 'helpsCount' => 2, 'helpList' => [ ['user' => ['avatar_url' => 'http://tva1.sinaimg.cn/large/0060lm7Tly1g4c7zrytvvj30dw0dwwes.jpg']], ['user' => ['avatar_url' => 'http://tva1.sinaimg.cn/large/0060lm7Tly1g4c7zs2u5ej30b40b4dfx.jpg']], ] ], // '自动获取' => 默认数据 'defaultData' => [ [ 'goods_name' => '此处是砍价商品', 'goods_image' => base_url() . 'assets/store/img/diy/goods/01.png', 'floor_price' => '0.01', 'original_price' => '139.00', ], [ 'goods_name' => '此处是砍价商品', 'goods_image' => base_url() . 'assets/store/img/diy/goods/01.png', 'floor_price' => '0.01', 'original_price' => '139.00', ], ], // '手动选择' => 默认数据 'data' => [ [ 'goods_name' => '此处是砍价商品', 'goods_image' => base_url() . 'assets/store/img/diy/goods/01.png', 'floor_price' => '0.01', 'original_price' => '139.00', ], [ 'goods_name' => '此处是砍价商品', 'goods_image' => base_url() . 'assets/store/img/diy/goods/01.png', 'floor_price' => '0.01', 'original_price' => '139.00', ], ] ], 'sharp' => [ 'name' => '整点秒杀', 'type' => 'sharp', 'params' => ['showNum' => 6], 'style' => [ 'background' => '#ffffff', 'column' => 3, // 2列和3列 'show' => ['goodsName', 'seckillPrice', 'originalPrice'] ], // '手动选择' => 默认数据 'data' => [ [ 'goods_name' => '此处是秒杀商品', 'goods_image' => base_url() . 'assets/store/img/diy/goods/01.png', 'seckill_price_min' => '69.00', 'original_price' => '139.00', ], [ 'goods_name' => '此处是秒杀商品', 'goods_image' => base_url() . 'assets/store/img/diy/goods/01.png', 'seckill_price_min' => '69.00', 'original_price' => '139.00', ], [ 'goods_name' => '此处是秒杀商品', 'goods_image' => base_url() . 'assets/store/img/diy/goods/01.png', 'seckill_price_min' => '69.00', 'original_price' => '139.00', ], ] ], 'groupon' => [ 'name' => '拼团商品组', 'type' => 'groupon', 'params' => [ 'source' => 'auto', // 数据来源:choice手动 auto自动 'auto' => [ 'goodsSort' => 'all', // 商品排序:all sales price 'showNum' => 6 ] ], 'style' => [ 'background' => '#F5F5F8', // 背景颜色 'paddingY' => 12, // 上下边距 'paddingX' => 12, // 左右边距 'display' => 'card', // 商品样式:flat扁平 card卡片 'itemBorderRadius' => 'round', // 边角样式:right直角 round圆角 'itemMargin' => 10, // 商品间距 'show' => [ 'goodsName', 'button', 'peoples', 'activeSales', 'grouponPrice', 'originalPrice', ] ], // '自动获取' => 默认数据 'defaultData' => [ [ 'goods_name' => '此处是拼团商品', 'goods_image' => base_url() . 'assets/store/img/diy/goods/01.png', 'show_people' => '3', 'active_sales' => '120', 'groupon_price' => '99.00', 'original_price' => '139.00', ], [ 'goods_name' => '此处是拼团商品', 'goods_image' => base_url() . 'assets/store/img/diy/goods/01.png', 'show_people' => '3', 'active_sales' => '120', 'groupon_price' => '99.00', 'original_price' => '139.00', ], ], // '手动选择' => 默认数据 'data' => [ [ 'goods_name' => '此处是拼团商品', 'goods_image' => base_url() . 'assets/store/img/diy/goods/01.png', 'show_people' => '3', 'active_sales' => '120', 'groupon_price' => '99.00', 'original_price' => '139.00', ], [ 'goods_name' => '此处是拼团商品', 'goods_image' => base_url() . 'assets/store/img/diy/goods/01.png', 'show_people' => '3', 'active_sales' => '120', 'groupon_price' => '99.00', 'original_price' => '139.00', ], ] ], 'coupon' => [ 'name' => '优惠券组', 'type' => 'coupon', 'style' => [ 'paddingTop' => 10, 'background' => '#ffffff', 'marginRight' => 20, 'couponBgColor' => '#ffa708', 'receiveBgColor' => '#717070' ], 'params' => ['showNum' => 5], 'data' => [ [ 'reduce_price' => '10', 'min_price' => '100.00' ], [ 'reduce_price' => '10', 'min_price' => '100.00' ], [ 'reduce_price' => '10', 'min_price' => '100.00' ] ] ], 'special' => [ 'name' => '头条快报', 'type' => 'special', 'params' => [ 'source' => 'auto', 'auto' => [ 'category' => -1, // 文章分类ID -1为全部 'showNum' => 6 ], 'display' => 1, // 显示行数 'image' => base_url() . 'assets/store/img/diy/special.png', ], 'style' => [ 'background' => '#ffffff', // 背景颜色 'textColor' => '#141414', // 文字颜色 'paddingTop' => 0, // 上下边距 ], // '自动获取' => 默认数据 'defaultData' => [ ['title' => '张小龙4小时演讲:你和高手之间,隔着“简单”二字'], ['title' => '张小龙4小时演讲:你和高手之间,隔着“简单”二字'] ], // '手动选择' => 默认数据 'data' => [] ], 'ICPLicense' => [ 'name' => '备案号', 'type' => 'ICPLicense', 'params' => [ 'text' => '网站备案号:粤ICP备10000000号-1', 'link' => 'https://beian.miit.gov.cn/', ], 'style' => [ 'fontSize' => '13', // 文字大小 'textAlign' => 'center', // 文字对齐 'textColor' => '#696969', // 文字颜色 'paddingTop' => 6, // 上下边距 'paddingLeft' => 0, // 左右边距 'background' => '#ffffff', // 背景颜色 ] ], ]; } /** * diy页面详情 * @param int $pageId * @return static|array|null */ public static function detail(int $pageId) { return static::get(['page_id' => $pageId]); } /** * diy页面详情 * @return static|array|null */ public static function getHomePage() { return static::get(['page_type' => PageTypeEnum::HOME]); } /** * 合并默认数据 * @param $array * @return mixed */ private function _mergeDefaultData($array) { $array['page'] = array_merge_multiple($this->getDefaultPage(), $array['page']); $defaultItems = $this->getDefaultItems(); foreach ($array['items'] as &$item) { if (isset($defaultItems[$item['type']])) { array_key_exists('data', $item) && $defaultItems[$item['type']]['data'] = []; $item = array_merge_multiple($defaultItems[$item['type']], $item); } } return $array; } }