Explorar o código

网站管理上传图片

lcmxs hai 1 ano
pai
achega
bd8bc3f088
Modificáronse 2 ficheiros con 146 adicións e 87 borrados
  1. 8 1
      src/api/portal/WEBSITE/WEBSITE.js
  2. 138 86
      src/views/WEBSITE/index.vue

+ 8 - 1
src/api/portal/WEBSITE/WEBSITE.js

@@ -3,7 +3,7 @@ import request from '@/utils/request'
 // 查询网站管理列表
 export function listWEBSITE(query) {
   return request({
-    url: '/portal/business/WEBSITE/list',
+    url: '/business/WEBSITE/list',
     method: 'get',
     params: query
   })
@@ -51,3 +51,10 @@ export function delWEBSITE(websitePicture) {
     method: 'get'
   })
 }
+export function upload(data) {
+  return request({
+    url: 'common/upload',
+    method: 'post',
+    data:data
+  })
+}

+ 138 - 86
src/views/WEBSITE/index.vue

@@ -1,94 +1,86 @@
 <template>
   <div class="app-container">
     <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
+      <el-form-item label="网址名" prop="websiteName">
+        <el-input v-model="queryParams.websiteName"></el-input>
+      </el-form-item>
       <el-form-item>
-        <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
-        <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
+        <el-button type="primary" icon="el-icon-search" @click="handleQuery">搜索</el-button>
+        <el-button icon="el-icon-refresh"  @click="resetQuery">重置</el-button>
       </el-form-item>
     </el-form>
 
     <el-row :gutter="10" class="mb8">
-      <el-col :span="1.5">
-        <el-button
-          type="primary"
-          plain
-          icon="el-icon-plus"
-          size="mini"
-          @click="handleAdd"
-          v-hasPermi="['business:WEBSITE:add']"
-        >新增</el-button>
-      </el-col>
-      <el-col :span="1.5">
-        <el-button
-          type="success"
-          plain
-          icon="el-icon-edit"
-          size="mini"
-          :disabled="single"
-          @click="handleUpdate"
-          v-hasPermi="['business:WEBSITE:edit']"
-        >修改</el-button>
-      </el-col>
+<!--      <el-col :span="1.5">-->
+<!--        <el-button-->
+<!--          type="primary"-->
+<!--          plain-->
+<!--          icon="el-icon-plus"-->
+<!--          size="mini"-->
+<!--          @click="handleAdd"-->
+<!--          v-hasPermi="['business:WEBSITE:add']"-->
+<!--        >新增</el-button>-->
+<!--      </el-col>-->
+<!--      <el-col :span="1.5">-->
+<!--        <el-button-->
+<!--          type="primary"-->
+<!--          plain-->
+<!--          icon="el-icon-edit"-->
+<!--          :disabled="single"-->
+<!--          @click="handleUpdate"-->
+<!--          v-hasPermi="['business:WEBSITE:edit']"-->
+<!--        >修改</el-button>-->
+<!--      </el-col>-->
       <el-col :span="1.5">
         <el-button
           type="danger"
           plain
           icon="el-icon-delete"
-          size="mini"
           :disabled="multiple"
           @click="handleDelete"
           v-hasPermi="['business:WEBSITE:remove']"
         >删除</el-button>
       </el-col>
-      <el-col :span="1.5">
-        <el-button
-          type="warning"
-          plain
-          icon="el-icon-download"
-          size="mini"
-          @click="handleExport"
-          v-hasPermi="['business:WEBSITE:export']"
-        >导出</el-button>
-      </el-col>
+<!--      <el-col :span="1.5">-->
+<!--        <el-button-->
+<!--          type="warning"-->
+<!--          plain-->
+<!--          icon="el-icon-download"-->
+<!--          size="mini"-->
+<!--          @click="handleExport"-->
+<!--          v-hasPermi="['business:WEBSITE:export']"-->
+<!--        >导出</el-button>-->
+<!--      </el-col>-->
       <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
     </el-row>
 
-<!--    <el-table v-loading="loading" :data="WEBSITEList" @selection-change="handleSelectionChange">-->
-<!--      <el-table-column type="selection" width="55" align="center" />-->
-<!--      <el-table-column label="网站背景图" align="center" prop="websitePicture">-->
-<!--        <template slot-scope="scope">-->
-<!--          <dict-tag :options="dict.type.${column.dictType}" :value="scope.row.websitePicture"/>-->
-<!--        </template>-->
-<!--      </el-table-column>-->
-<!--      <el-table-column label="网站昵称" align="center" prop="websiteName">-->
-<!--        <template slot-scope="scope">-->
-<!--          <dict-tag :options="dict.type.${column.dictType}" :value="scope.row.websiteName"/>-->
-<!--        </template>-->
-<!--      </el-table-column>-->
-<!--      <el-table-column label="主键id" align="center" prop="id">-->
-<!--        <template slot-scope="scope">-->
-<!--          <dict-tag :options="dict.type.${column.dictType}" :value="scope.row.id"/>-->
-<!--        </template>-->
-<!--      </el-table-column>-->
-<!--      <el-table-column label="操作" align="center" class-name="small-padding fixed-width">-->
-<!--        <template slot-scope="scope">-->
-<!--          <el-button-->
-<!--            size="mini"-->
-<!--            type="text"-->
-<!--            icon="el-icon-edit"-->
-<!--            @click="handleUpdate(scope.row)"-->
-<!--            v-hasPermi="['business:WEBSITE:edit']"-->
-<!--          >修改</el-button>-->
-<!--          <el-button-->
-<!--            size="mini"-->
-<!--            type="text"-->
-<!--            icon="el-icon-delete"-->
-<!--            @click="handleDelete(scope.row)"-->
-<!--            v-hasPermi="['business:WEBSITE:remove']"-->
-<!--          >删除</el-button>-->
-<!--        </template>-->
-<!--      </el-table-column>-->
-<!--    </el-table>-->
+    <el-table v-loading="loading" :data="WEBSITEList" @selection-change="handleSelectionChange">
+      <el-table-column type="selection" width="55" align="center" />
+      <el-table-column label="网址名字" align="center" prop="websiteName"/>
+      <el-table-column label="背景图片" align="center" prop="websiteUrl">
+        <template slot-scope="scope">
+          <img :src="scope.row.websiteUrl" alt="背景图片" style="max-width: 100px; max-height: 100px;" />
+        </template>
+      </el-table-column>
+      <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
+        <template slot-scope="scope">
+          <el-button
+            size="mini"
+            type="text"
+            icon="el-icon-edit"
+            @click="handleUpdate(scope.row)"
+            v-hasPermi="['business:WEBSITE:edit']"
+          >修改</el-button>
+          <el-button
+            size="mini"
+            type="text"
+            icon="el-icon-delete"
+            @click="handleDelete(scope.row)"
+            v-hasPermi="['business:WEBSITE:remove']"
+          >删除</el-button>
+        </template>
+      </el-table-column>
+    </el-table>
 
     <pagination
       v-show="total>0"
@@ -101,22 +93,71 @@
     <!-- 添加或修改网站管理对话框 -->
     <el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
       <el-form ref="form" :model="form" :rules="rules" label-width="80px">
+        <el-row>
+          <el-col :span="12">
+            <el-form-item label="链接名称" prop="websiteName">
+              <el-input v-model="form.websiteName" placeholder="请输入链接名称" />
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-form-item label="封面图" prop="websiteUrl">
+          <el-upload
+            action="#"
+            list-type="picture-card"
+            :limit="1"
+            :auto-upload="true"
+            :http-request="httprequest"
+            :before-upload="beforeupload"
+            :file-list="fileList"
+          >
+            <i slot="default" class="el-icon-plus"></i>
+            <div slot="file" slot-scope="{ file }">
+              <img class="el-upload-list__item-thumbnail" :src="file.url" />
+
+              <!-- 放大预览 -->
+              <span class="el-upload-list__item-actions">
+                <span
+                  class="el-upload-list__item-preview"
+                  @click="handlePictureCardPreview(file)"
+                >
+                  <i class="el-icon-zoom-in"></i>
+                </span>
+                <!-- 删除图片 -->
+                <span
+                  v-if="!disabled"
+                  class="el-upload-list__item-delete"
+                  @click="handleRemove(file)"
+                >
+                  <i class="el-icon-delete"></i>
+                </span>
+              </span>
+            </div>
+          </el-upload>
+        </el-form-item>
       </el-form>
+
       <div slot="footer" class="dialog-footer">
         <el-button type="primary" @click="submitForm">确 定</el-button>
         <el-button @click="cancel">取 消</el-button>
       </div>
     </el-dialog>
+
+    <el-dialog :visible.sync="dialogVisible" fullscreen append-to-body  @close="dialogVisible = false">
+      <img width="100%" :src="form.websiteUrl" alt="" />
+    </el-dialog>
   </div>
 </template>
 
 <script>
-import { listWEBSITE, getWEBSITE, delWEBSITE, addWEBSITE, updateWEBSITE } from "@/api/portal/WEBSITE/WEBSITE";
+import { listWEBSITE, getWEBSITE, delWEBSITE, updateWEBSITE, upload } from "@/api/portal/WEBSITE/WEBSITE";
 
 export default {
   name: "WEBSITE",
   data() {
     return {
+      fileList:[],
+      dialogVisible: false,
+      disabled: false,
       // 根路径
       baseURL: process.env.VUE_APP_BASE_API,
       // 遮罩层
@@ -141,7 +182,7 @@ export default {
       queryParams: {
         pageNum: 1,
         pageSize: 10,
-        websitePicture: null,
+        websiteUrl: null,
         websiteName: null,
         id: null
       },
@@ -149,7 +190,7 @@ export default {
       form: {},
       // 表单校验
       rules: {
-        websitePicture: [
+        websiteUrl: [
           { required: true, message: "网站背景图不能为空", trigger: "blur" }
         ],
         websiteName: [
@@ -165,6 +206,25 @@ export default {
     this.getList();
   },
   methods: {
+    httprequest(){},
+    //预览
+    handlePictureCardPreview(file) {
+      this.form.websiteUrl = file.url;
+      this.dialogVisible = true;
+    },
+    //删除
+    handleRemove(file) {
+      this.form.websiteUrl = "";
+      this.fileList = [];
+    },
+    //上传
+    beforeupload(file) {
+      let formData = new FormData();
+      formData.append("file", file);
+      upload(formData).then((res) => {
+        this.form.websiteUrl = res.url;
+      });
+    },
     /** 查询网站管理列表 */
     getList() {
       this.loading = true;
@@ -182,7 +242,7 @@ export default {
     // 表单重置
     reset() {
       this.form = {
-        websitePicture: null,
+        websiteUrl: null,
         websiteName: null,
         id: null
       };
@@ -200,7 +260,7 @@ export default {
     },
     /** 多选框选中数据 */
     handleSelectionChange(selection) {
-      this.ids = selection.map(item => item.websitePicture)
+      this.ids = selection.map(item => item.websiteUrl)
       this.single = selection.length!==1
       this.multiple = !selection.length
     },
@@ -213,8 +273,8 @@ export default {
     /** 修改按钮操作 */
     handleUpdate(row) {
       this.reset();
-      const websitePicture = row.websitePicture || this.ids
-      getWEBSITE(websitePicture).then(response => {
+      const id = row.id || this.ids;
+      getWEBSITE(id).then(response => {
         this.form = response.data;
         this.open = true;
         this.title = "修改网站管理";
@@ -224,25 +284,17 @@ export default {
     submitForm() {
       this.$refs["form"].validate(valid => {
         if (valid) {
-          if (this.form.websitePicture != null) {
             updateWEBSITE(this.form).then(response => {
               this.$modal.msgSuccess("修改成功");
               this.open = false;
               this.getList();
             });
-          } else {
-            addWEBSITE(this.form).then(response => {
-              this.$modal.msgSuccess("新增成功");
-              this.open = false;
-              this.getList();
-            });
-          }
         }
       });
     },
     /** 删除按钮操作 */
     handleDelete(row) {
-      const websitePictures = row.websitePicture || this.ids;
+      const websitePictures =  row.id || this.ids;
       this.$modal.confirm('是否确认删除网站管理编号为"' + websitePictures + '"的数据项?').then(function() {
         return delWEBSITE(websitePictures);
       }).then(() => {