浏览代码

后台,轮播图

lizhen_gitee 1 年之前
父节点
当前提交
a2c29ffb8d

+ 1 - 0
application/admin/controller/Banner.php

@@ -23,6 +23,7 @@ class Banner extends Backend
         parent::_initialize();
         $this->model = new \app\admin\model\Banner;
         $this->view->assign("statusList", $this->model->getStatusList());
+        $this->view->assign("typeList", $this->model->getTypeList());
     }
 
     public function import()

+ 7 - 4
application/admin/lang/zh-cn/banner.php

@@ -1,14 +1,17 @@
 <?php
 
 return [
-    'Id'         => '主键ID',
+    'Id'         => 'ID',
     'Title'      => '标题',
     'Image'      => '图片',
     'Url'        => '链接地址',
     'Status'     => '状态',
-    'Status 1'   => '有效',
-    'Status 0'   => '无效',
+    'Status 1'   => '上架',
+    'Status 0'   => '下架',
     'Weigh'      => '权重排序',
     'Createtime' => '创建时间',
-    'Updatetime' => '更新时间'
+    'Updatetime' => '更新时间',
+    'Type'       => '位置',
+    'Type 1'     => '首页',
+    'Type 2'     => '动态页'
 ];

+ 15 - 1
application/admin/model/Banner.php

@@ -25,7 +25,8 @@ class Banner extends Model
 
     // 追加属性
     protected $append = [
-        'status_text'
+        'status_text',
+        'type_text'
     ];
     
 
@@ -43,6 +44,11 @@ class Banner extends Model
         return ['1' => __('Status 1'), '0' => __('Status 0')];
     }
 
+    public function getTypeList()
+    {
+        return ['1' => __('Type 1'), '2' => __('Type 2')];
+    }
+
 
     public function getStatusTextAttr($value, $data)
     {
@@ -52,6 +58,14 @@ class Banner extends Model
     }
 
 
+    public function getTypeTextAttr($value, $data)
+    {
+        $value = $value ? $value : (isset($data['type']) ? $data['type'] : '');
+        $list = $this->getTypeList();
+        return isset($list[$value]) ? $list[$value] : '';
+    }
+
+
 
 
 }

+ 13 - 1
application/admin/view/banner/add.html

@@ -23,7 +23,7 @@
     <div class="form-group">
         <label class="control-label col-xs-12 col-sm-2">{:__('Url')}:</label>
         <div class="col-xs-12 col-sm-8">
-            <input id="c-url" data-rule="" class="form-control" name="row[url]" type="text" value="">
+            <input id="c-url" data-rule="required" class="form-control" name="row[url]" type="text" value="">
         </div>
     </div>
     <div class="form-group">
@@ -44,6 +44,18 @@
             <input id="c-weigh" data-rule="required" class="form-control" name="row[weigh]" type="number" value="0">
         </div>
     </div>
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('Type')}:</label>
+        <div class="col-xs-12 col-sm-8">
+                        
+            <select  id="c-type" data-rule="required" class="form-control selectpicker" name="row[type]">
+                {foreach name="typeList" item="vo"}
+                    <option value="{$key}" {in name="key" value="1"}selected{/in}>{$vo}</option>
+                {/foreach}
+            </select>
+
+        </div>
+    </div>
     <div class="form-group layer-footer">
         <label class="control-label col-xs-12 col-sm-2"></label>
         <div class="col-xs-12 col-sm-8">

+ 13 - 1
application/admin/view/banner/edit.html

@@ -23,7 +23,7 @@
     <div class="form-group">
         <label class="control-label col-xs-12 col-sm-2">{:__('Url')}:</label>
         <div class="col-xs-12 col-sm-8">
-            <input id="c-url" data-rule="" class="form-control" name="row[url]" type="text" value="{$row.url|htmlentities}">
+            <input id="c-url" data-rule="required" class="form-control" name="row[url]" type="text" value="{$row.url|htmlentities}">
         </div>
     </div>
     <div class="form-group">
@@ -44,6 +44,18 @@
             <input id="c-weigh" data-rule="required" class="form-control" name="row[weigh]" type="number" value="{$row.weigh|htmlentities}">
         </div>
     </div>
+    <div class="form-group">
+        <label class="control-label col-xs-12 col-sm-2">{:__('Type')}:</label>
+        <div class="col-xs-12 col-sm-8">
+                        
+            <select  id="c-type" data-rule="required" class="form-control selectpicker" name="row[type]">
+                {foreach name="typeList" item="vo"}
+                    <option value="{$key}" {in name="key" value="$row.type"}selected{/in}>{$vo}</option>
+                {/foreach}
+            </select>
+
+        </div>
+    </div>
     <div class="form-group layer-footer">
         <label class="control-label col-xs-12 col-sm-2"></label>
         <div class="col-xs-12 col-sm-8">

+ 2 - 1
public/assets/js/backend/banner.js

@@ -28,11 +28,12 @@ define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefin
                         {field: 'id', title: __('Id')},
                         {field: 'title', title: __('Title'), operate: 'LIKE'},
                         {field: 'image', title: __('Image'), operate: false, events: Table.api.events.image, formatter: Table.api.formatter.image},
-                        {field: 'url', title: __('Url'), operate: false, formatter: Table.api.formatter.url},
+                        {field: 'url', title: __('Url'), operate: 'LIKE', formatter: Table.api.formatter.url},
                         {field: 'status', title: __('Status'), searchList: {"1":__('Status 1'),"0":__('Status 0')}, formatter: Table.api.formatter.status},
                         {field: 'weigh', title: __('Weigh'), operate: false},
                         {field: 'createtime', title: __('Createtime'), operate:'RANGE', addclass:'datetimerange', autocomplete:false, formatter: Table.api.formatter.datetime},
                         {field: 'updatetime', title: __('Updatetime'), operate:'RANGE', addclass:'datetimerange', autocomplete:false, formatter: Table.api.formatter.datetime},
+                        {field: 'type', title: __('Type'), searchList: {"1":__('Type 1'),"2":__('Type 2')}, formatter: Table.api.formatter.normal},
                         {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
                     ]
                 ]