瀏覽代碼

门店管理

DESKTOP-SVI9JE1\muzen 1 年之前
父節點
當前提交
80d6731d13
共有 2 個文件被更改,包括 316 次插入0 次删除
  1. 134 0
      src/views/operation/map/detail.vue
  2. 182 0
      src/views/operation/map/index.vue

+ 134 - 0
src/views/operation/map/detail.vue

@@ -0,0 +1,134 @@
+<template>
+  <div class='app-container'>
+    <el-form :model="form" ref="form" :rules="rules" label-width="100px" :disabled="disabled">
+      <el-form-item label="门店名称:" prop="name">
+        <el-input v-model="form.name" placeholder="请输入门店名称" />
+      </el-form-item>
+      <el-form-item label="门店图片:" prop="icon">
+        <Upload list-type="picture-card" :url="form.icon" @upload="upload" :disabled="disabled" />
+      </el-form-item>
+      <el-form-item label="联系电话:">
+        <el-input v-model="form.linkPhone" placeholder="请输入联系电话" />
+      </el-form-item>
+      <el-form-item label="城市筛选:" prop="cascader">
+        <el-cascader style="width: 100%" v-model="form.cascader" :options="options" placeholder="请选择省市区"
+          :props="{ value: 'id', label: 'name', children: 'childList', checkStrictly: true }" />
+      </el-form-item>
+      <el-form-item label="详细地址:" prop="address">
+        <el-input v-model="form.address" placeholder="请输入详细地址" />
+      </el-form-item>
+      <el-form-item label="经度:" prop="latitude">
+        <el-input v-model="form.latitude" placeholder="请输入经度" />
+      </el-form-item>
+      <el-form-item label="纬度:" prop="longitude">
+        <el-input v-model="form.longitude" placeholder="请输入纬度" />
+      </el-form-item>
+    </el-form>
+    <div class="form-btn">
+      <el-button @click="cancel">取消</el-button>
+      <el-button v-if="!disabled" type="primary" @click="getSubmit">确定</el-button>
+    </div>
+  </div>
+</template>
+
+<script>
+import { detail, options, submit } from '@/api/operation/map'
+export default {
+  data() {
+    return {
+      // 表单
+      form: {
+        status: 0
+      },
+      // 省市区
+      options: [],
+      // 校验
+      rules: {
+        name: [{
+          required: true, message: '请输入店铺名称', trigger: 'blur'
+        }],
+        icon: [{
+          required: true, message: '请上传店铺图片', trigger: 'change'
+        }],
+        cascader: [{
+          required: true, message: '请选择省市区', trigger: 'change'
+        }],
+        address: [{
+          required: true, message: '请输入详细地址', trigger: 'blur'
+        }],
+        latitude: [{
+          required: true, message: '请输入经度', trigger: 'blur'
+        }],
+        longitude: [{
+          required: true, message: '请输入纬度', trigger: 'blur'
+        }]
+      },
+      // 只读
+      disabled: false
+    }
+  },
+  mounted() {
+    this.getOptions()
+    if (this.$route.query.id) {
+      this.getDetail()
+      this.disabled = Boolean(this.$route.query.boolean)
+    }
+  },
+  methods: {
+    // 详情
+    getDetail() {
+      detail(this.$route.query.id).then(res => {
+        if (res.code === 0) {
+          this.form = res.data
+          this.form.cascader = [Number(res.data.province), Number(res.data.city), Number(res.data.area)]
+        }
+      })
+    },
+
+    // 上传
+    upload(e) {
+      this.form.icon = e.file
+    },
+
+    // 省市区
+    getOptions() {
+      options().then(res => {
+        if (res.code === 0) {
+          this.options = res.data
+        }
+      })
+    },
+
+    cancel() {
+      this.$tab.closeOpenPage("/operation/map")
+    },
+
+    // 提交
+    getSubmit() {
+      this.form.province = this.form.cascader[0]
+      this.form.city = this.form.cascader[1]
+      this.form.area = this.form.cascader[2]
+      submit(this.form).then(res => {
+        if (res.code === 0) {
+          this.$message.success('提交成功!')
+          this.cancel()
+        }
+      })
+    }
+  }
+}
+</script>
+
+<style lang="scss" scoped>
+.el-form {
+  .el-form-item {
+    width: 500px;
+  }
+}
+
+::v-deep .el-dialog__wrapper {
+  .el-dialog__body {
+    padding: 0;
+  }
+}
+</style>

+ 182 - 0
src/views/operation/map/index.vue

@@ -0,0 +1,182 @@
+<template>
+  <div class='app-container'>
+    <!-- 搜索 -->
+    <el-form inline size="mini">
+      <el-form-item label="门店名称:">
+        <el-input v-model="form.name" placeholder="请输入门店名称" clearable />
+      </el-form-item>
+      <el-form-item label="城市筛选:">
+        <el-cascader :options="options" placeholder="请选择省市区" @change="handleChange"
+          :props="{ value: 'id', label: 'name', children: 'childList', checkStrictly: true }" />
+      </el-form-item>
+      <el-form-item label="当前状态:">
+        <el-select v-model="form.status" placeholder="请选择当前状态" clearable>
+          <el-option v-for="item in statusOptions" :key="item.value" :label="item.label" :value="item.value" />
+        </el-select>
+      </el-form-item>
+      <el-form-item>
+        <el-button type="primary" icon="el-icon-search" @click="getSearch">搜索</el-button>
+        <el-button icon="el-icon-refresh" @click="getRefresh">重置</el-button>
+        <el-button type="primary" icon="el-icon-plus" plain @click="getDetail()">新增</el-button>
+      </el-form-item>
+    </el-form>
+    <!-- 列表 -->
+    <el-table :data="tableData" v-loading="loading">
+      <el-table-column label="序号" type="index" align="center" />
+      <el-table-column label="门店名称" prop="name" align="center" />
+      <el-table-column label="联系电话" prop="linkPhone" align="center">
+        <template slot-scope="scope">
+          {{ scope.row.linkPhone ? scope.row.linkPhone : '暂无联系电话' }}
+        </template>
+      </el-table-column>
+      <el-table-column label="门店图片" align="center" width="100px">
+        <template slot-scope="scope">
+          <el-image :src="scope.row.icon" />
+        </template>
+      </el-table-column>
+      <el-table-column label="地区" align="center" :formatter="areaFormatter" />
+      <el-table-column label="详细地址" prop="address" align="center" />
+      <el-table-column label="当前状态" prop="status" align="center" :formatter="statusFormatter" />
+      <el-table-column label="创建时间" prop="createTime" align="center" />
+      <el-table-column label="操作" align="center">
+        <template slot-scope="scope">
+          <el-button type="text" @click="getDetail(scope.row.id, true)">查看</el-button>
+          <el-button v-if="scope.row.status === 0" type="text" @click="getChange(scope.row.id, 1, '禁用')">禁用</el-button>
+          <span v-else style="margin-left: 10px;">
+            <el-button type="text" @click="getDetail(scope.row.id, true)">编辑</el-button>
+            <el-button type="text" @click="getChange(scope.row.id, 0, '启用')">启用</el-button>
+            <el-button type="delete" @click="getDelete(scope.row)">删除</el-button>
+          </span>
+        </template>
+      </el-table-column>
+    </el-table>
+    <pagination v-show="total > 0" :total="total" :page.sync="form.pageNum" :limit.sync="form.pageSize"
+      @pagination="getList" />
+  </div>
+</template>
+
+<script>
+import { list, options, change, remove } from '@/api/operation/map'
+export default {
+  data() {
+    return {
+      // 遮罩层
+      loading: false,
+      // 表单
+      form: {
+        pageNum: 1,
+        pageSize: 10
+      },
+      // 省市区
+      options: [],
+      // 列表
+      tableData: [],
+      // 当前状态
+      statusOptions: [{
+        value: 0,
+        label: '启用'
+      }, {
+        value: 1,
+        label: '禁用'
+      }]
+    }
+  },
+  async mounted() {
+    await this.getOptions()
+    this.getList()
+  },
+  methods: {
+    // 列表
+    getList() {
+      this.loading = true
+      list(this.form).then(res => {
+        if (res.code === 0) {
+          this.tableData = res.data.records
+          this.total = res.data.total
+          this.loading = false
+        }
+      })
+    },
+
+    // 搜索
+    getSearch() {
+      this.form.pageNum = 1
+      this.getList()
+    },
+
+    // 重置
+    getRefresh() {
+      this.form = {
+        pageNum: 1,
+        pageSize: 10
+      }
+      this.getList()
+    },
+
+    // 省市区
+    getOptions() {
+      return new Promise((reslove, reject) => {
+        options().then(res => {
+          if (res.code === 0) {
+            reslove(this.options = res.data)
+          }
+        })
+      })
+    },
+
+    // 选择省市区
+    handleChange(e) {
+      this.form.province = e[0]
+      this.form.city = e[1]
+      this.form.area = e[2]
+    },
+
+    // 新增、 编辑、 查看
+    getDetail(id, boolean) {
+      this.$router.push({
+        path: `/operation/map/detail`,
+        query: {
+          id: id,
+          boolean: boolean
+        }
+      })
+    },
+
+    // 启用 禁用
+    getChange(id, status, title) {
+      change(id, status).then(res => {
+        if (res.code === 0) {
+          this.$message.success(`${title}成功!`)
+          this.getList()
+        }
+      })
+    },
+
+    // 删除
+    getDelete(row) {
+      this.$confirm(`是否删除${row.name}?`, '提示', {
+        type: 'warning'
+      }).then(() => {
+        remove(row.id).then(res => {
+          if (res.code === 0) {
+            this.$message.success('删除成功!')
+            this.getList()
+          }
+        })
+      })
+    },
+
+    // 字典翻译
+    areaFormatter(row) {
+      let province = this.options.find(i => i.id == row.province)
+      let city = province.childList.find(i => i.id == row.city)
+      let area = city.childList.find(i => i.id == row.area)
+      return `${province.name}-${city.name}-${area.name}`
+    },
+
+    statusFormatter(row) {
+      return this.selectDictLabel(this.statusOptions, row.status)
+    }
+  }
+}
+</script>