瀏覽代碼

基础信息等 功能

zhangyanfang 4 年之前
父節點
當前提交
0ece794838

+ 71 - 0
_web/src/api/modular/system/contentControlApi.js

@ -0,0 +1,71 @@
import { axios } from '@/utils/request'
/**
 * 编辑基本信息
 *
 * @author yubaoshan
 * @date 2020/6/8 11:11
 */
export function addBasicInfo(parameter) {
    return axios({
        url: '/zjxl/basicInfo/addBasicInfo',
        method: 'post',
        params: parameter
    })
}
/**
 * 查询文章管理列表
 *
 * @author yubaoshan
 * @date 2020/6/8 11:11
 */
export function findArticleContentById(parameter) {
    return axios({
        url: '/zjxl/zjxlArticleContent/findArticleContentById',
        method: 'get',
        params: parameter
    })
}
/**
 * 添加文章
 *
 * @author yubaoshan
 * @date 2020/6/8 11:11
 */
export function addArticleContent(parameter) {
    return axios({
        url: '/zjxl/zjxlArticleContent/addArticleContent',
        method: 'post',
        params: parameter
    })
}
/**
 * 修改是否上线
 *
 * @author yubaoshan
 * @date 2020/6/8 11:11
 */
export function updateArticleContent(parameter) {
    return axios({
        url: '/zjxl/zjxlArticleContent/updateArticleContent',
        method: 'post',
        data: parameter
    })
}
/**
 * 删除文章管理
 *
 * @author yubaoshan
 * @date 2020/6/8 11:11
 */
export function deleteArticleContent(parameter) {
    return axios({
        url: '/zjxl/zjxlArticleContent/deleteArticleContent',
        method: 'post',
        data: parameter
    })
}

二進制
_web/src/assets/logo_dibu_img.png


+ 12 - 5
_web/src/layouts/UserLayout.vue

@ -1,7 +1,7 @@
<template>
  <div id="userLayout" :class="['user-layout-wrapper', device]">
    <div class="container">
      <div class="top">
      <!-- <div class="top">
        <div class="header">
          <a href="/">
            <img src="~@/assets/logo.png" class="logo" alt="logo">
@ -11,18 +11,20 @@
        <div class="desc">
          Guns 是华夏最具影响力的 Web 快速开发平台
        </div>
      </div>
      </div> -->
      <route-view></route-view>
      <div class="footer">
        <div class="links">
        <!-- <div class="links">
          <a href="_self">帮助</a>
          <a href="_self">隐私</a>
          <a href="_self">条款</a>
        </div>
        </div> -->
        <div class="copyright">
          Copyright © 2020 <a target="_blank" href="https://www.stylefeng.cn/">stylefeng</a> All rights reserved. Guns-Seperation v1.2
          <img class="dibu_logo" src="@/assets/logo_dibu_img.png" alt="">
              &emsp;众健信联(厦门)科技有限公司
          <!-- Copyright © 2020 <a target="_blank" href="https://www.stylefeng.cn/">stylefeng</a> All rights reserved. Guns-Seperation v1.2 -->
        </div>
      </div>
    </div>
@ -146,6 +148,11 @@ export default {
          color: rgba(0, 0, 0, 0.45);
          font-size: 14px;
        }
        .dibu_logo{
          width: 140px;
          vertical-align: sub;
          margin-right: 20px;
        }
      }
    }
  }

+ 209 - 0
_web/src/views/constrolContent/articleContent.vue

@ -0,0 +1,209 @@
<template>
  <div>
    <a-card :bordered="false">
      <div class="table-page-search-wrapper">
        <a-form layout="inline">
          <a-row :gutter="48">
            <a-col :md="8" :sm="32">
              <a-form-item label="标题">
                <a-input v-model="queryParam.searchValue" allow-clear placeholder="请输入标题、内容" />
              </a-form-item>
            </a-col>
            <a-col :md="8" :sm="32">
              <a-form-item label="类型">
                <a-select v-model="queryParam.type" placeholder="请选择类型" allow-clear>
                  <a-select-option
                    v-for="(item,index) in typeDictTypeDropDown"
                    :key="index"
                    :value="item.code"
                  >{{ item.value }}</a-select-option>
                </a-select>
              </a-form-item>
            </a-col>
            <a-col :md="8" :sm="32">
              <a-button type="primary" @click="$refs.table.refresh(true)">搜索</a-button>
              <a-button type="primary" style="margin-left: 8px" @click="$refs.detailsOplog.details()">新增</a-button>
            </a-col>
          </a-row>
        </a-form>
        <!-- 表格 -->
        <s-table
          ref="table"
          size="default"
          :pagination="false"
          :loading="loading"
          :columns="columns"
          :data="loadData"
          :rowKey="(record) => record.sessionId"
        >
          <span slot="lastLoginAddress" slot-scope="text">
            <ellipsis :length="20" tooltip>{{ text }}</ellipsis>
          </span>
          <span slot="lastLoginBrowser" slot-scope="text">
            <ellipsis :length="20" tooltip>{{ text }}</ellipsis>
          </span>
          <span slot="action" slot-scope="text, record">
            <a-popconfirm
              v-if="hasPerm('sysOnlineUser:forceExist')"
              placement="topRight"
              title="是否确认下线该条目?"
              @confirm="() => forceExist(record)"
            >
              <a class="mr5">下线</a>
            </a-popconfirm>
            <a class="mr5" @click="$refs.detailsOplog.details(record)">编辑</a>
            <a-popconfirm
              v-if="hasPerm('sysOnlineUser:forceExist')"
              placement="topRight"
              title="是否确认删除该条目?"
              @confirm="() => forceExist(record)"
            >
              <a class="mr5">删除</a>
            </a-popconfirm>
          </span>
        </s-table>
      </div>
      <details-oplog ref="detailsOplog" />
    </a-card>
  </div>
</template>
<script>
import { STable, Ellipsis } from '@/components'
import { sysDictTypeDropDown } from '@/api/modular/system/dictManage'
import {
  findArticleContentById,
  addArticleContent,
  updateArticleContent,
  deleteArticleContent
} from '@/api/modular/system/contentControlApi'
import detailsOplog from './details'
export default {
  components: {
    STable,
    detailsOplog,
    Ellipsis
  },
  data () {
    return {
      // 查询参数
      queryParam: {},
      typeDictTypeDropDown: [],
      // 表头
      columns: [
        {
          title: '序号',
          dataIndex: 'setIndex'
        },
        {
          title: '标题',
          dataIndex: 'nickName'
        },
        {
          title: '封面',
          dataIndex: 'lastLoginIp'
        },
        {
          title: '摘要',
          dataIndex: 'lastLoginTime'
        },
        {
          title: '内容类型',
          dataIndex: 'lastLoginAddress',
          scopedSlots: { customRender: 'lastLoginAddress' }
        },
        {
          title: '分类',
          dataIndex: 'type'
        },
        {
          title: '子分类',
          dataIndex: 'childType'
        },
        {
          title: '排序',
          dataIndex: 'index'
        }
      ],
      loading: true,
      loadData: parameter => {
        const params = {
          articleContentTitle: '',
          id: ''
        }
        return findArticleContentById(Object.assign(parameter, params)).then(res => {
          if (this.hasPerm('sysOnlineUser:list')) {
            if (res.data.length > 0) {
              const list = res.data.rows
              list.map((item, index) => {
                item.setIndex = index + 1
                return item
              })
            }
            return res.data
          } else {
            return new Promise((resolve, reject) => {
              return resolve()
            })
          }
        })
      },
      selectedRows: []
    }
  },
  created () {
    this.sysDictTypeDropDown() // 先注释
    if (this.hasPerm('sysOnlineUser:forceExist')) {
      this.columns.push({
        title: '操作',
        width: '150px',
        dataIndex: 'action',
        scopedSlots: { customRender: 'action' }
      })
    }
  },
  methods: {
    forceExist (record) {
      const params = {
        id: '',
        isLine: 0 // 0是未上线,1是上线
      }
      updateArticleContent(params)
        .then(res => {
          if (res.success) {
            this.$message.success('强制下线成功')
            // 重新加载表格
            this.loadDataList()
          } else {
            this.$message.error('强制下线失败:' + res.message)
          }
        })
        .catch(err => {
          this.$message.error('强制下线错误:' + err.message)
        })
    },
    sysDictTypeDropDown () {
      sysDictTypeDropDown({ code: 'notice_type' }).then(res => {
        this.typeDictTypeDropDown = res.data
      })
    },
    addArticleContent () {
      addArticleContent({ code: 'notice_type' }).then(res => {
        this.typeDictTypeDropDown = res.data
      })
    },
    deleteArticleContent () {
      deleteArticleContent({ code: 'notice_type' }).then(res => {
        this.typeDictTypeDropDown = res.data
      })
    }
  }
}
</script>
<style lang="less">
.mr5 {
  margin-right: 5px;
}
</style>

+ 124 - 0
_web/src/views/constrolContent/details.vue

@ -0,0 +1,124 @@
<template>
  <a-modal
    title="内容管理"
    :width="900"
    :visible="visible"
    :confirmLoading="confirmLoading"
    @cancel="handleCancel"
  >
    <a-form :form="form">
      <a-form-item label="销售咨询" :labelCol="labelCol" :wrapperCol="wrapperCol" has-feedback>
        <a-input
          placeholder="请输入职位名称"
          v-decorator="['name', {rules: [{required: true, message: '请输入职位名称'}]}]"
        />
      </a-form-item>
      <a-form-item label="上传二维码" :labelCol="labelCol" :wrapperCol="wrapperCol" has-feedback>
        <a-upload
          name="file"
          list-type="picture-card"
          class="avatar-uploader"
          :show-upload-list="false"
          action="http://192.168.131.126:8080/api/sysFileInfo/upload"
          :before-upload="beforeUpload"
          @change="handleChange"
        >
          <img v-if="imageUrl" :src="imageUrl" alt="avatar" />
          <div v-else>
            <a-icon :type="loading ? 'loading' : 'plus'" />
          </div>
        </a-upload>
        <div class="ant-upload-text">请上传250*250规格图像</div>
      </a-form-item>
      <a-form-item label="销售咨询" :labelCol="labelCol" :wrapperCol="wrapperCol" has-feedback>
        <a-input
          placeholder="请输入职位名称"
          v-decorator="['name', {rules: [{required: true, message: '请输入职位名称'}]}]"
        />
      </a-form-item>
      <a-form-item label="销售咨询" :labelCol="labelCol" :wrapperCol="wrapperCol" has-feedback>
        <a-input
          placeholder="请输入职位名称"
          v-decorator="['name', {rules: [{required: true, message: '请输入职位名称'}]}]"
        />
      </a-form-item>
      <a-form-item label="销售咨询" :labelCol="labelCol" :wrapperCol="wrapperCol" has-feedback>
        <a-input
          placeholder="请输入职位名称"
          v-decorator="['name', {rules: [{required: true, message: '请输入职位名称'}]}]"
        />
      </a-form-item>
    </a-form>
  </a-modal>
</template>
<script>
function getBase64 (img, callback) {
  const reader = new FileReader()
  reader.addEventListener('load', () => callback(reader.result))
  reader.readAsDataURL(img)
}
export default {
  data () {
    return {
      imageUrl: '',
      loading: false,
      labelCol: {
        xs: { span: 24 },
        sm: { span: 5 }
      },
      wrapperCol: {
        xs: { span: 24 },
        sm: { span: 15 }
      },
      visible: false,
      confirmLoading: false,
      form: this.$form.createForm(this)
    }
  },
  methods: {
    // 初始化方法
    details (record) {
      this.visible = true
      // setTimeout(() => {
      //   this.form.setFieldsValue({
      //     message: record.message
      //   })
      // }, 100)
    },
    handleCancel () {
      this.form.resetFields()
      this.visible = false
    },
    // 上传图片
    handleChange (info) {
      if (info.file.status === 'uploading') {
        this.loading = true
        return
      }
      if (info.file.status === 'done') {
        // Get this url from response in real world.
        // 获取图片传参
        console.log(info.fileList[info.fileList.length - 1].response.data)
        getBase64(info.file.originFileObj, imageUrl => {
          this.imageUrl = imageUrl
          this.loading = false
        })
      }
    },
    beforeUpload (file) {
      const isJpgOrPng = file.type === 'image/jpeg' || file.type === 'image/png'
      if (!isJpgOrPng) {
        this.$message.error('You can only upload JPG file!')
      }
      const isLt2M = file.size / 1024 / 1024 < 2
      if (!isLt2M) {
        this.$message.error('Image must smaller than 2MB!')
      }
      console.log(file)
      return isJpgOrPng && isLt2M
    }
  }
}
</script>

+ 168 - 0
_web/src/views/homeManager/baseInfoData.vue

@ -0,0 +1,168 @@
<template>
  <a-card :bordered="false">
    <a-spin :spinning="confirmLoading">
      <a-form :form="form">
        <a-form-item
          style="display: none;"
          :labelCol="labelCol"
          :wrapperCol="wrapperCol"
          has-feedback
        >
          <a-input v-decorator="['id']" />
        </a-form-item>
        <a-form-item label="销售咨询" :labelCol="labelCol" :wrapperCol="wrapperCol" has-feedback>
          <a-input
            placeholder="请输入职位名称"
            v-decorator="['name', {rules: [{required: false, message: '请输入职位名称'}]}]"
          />
        </a-form-item>
        <a-form-item label="公司地址" :labelCol="labelCol" :wrapperCol="wrapperCol" has-feedback>
          <a-input
            placeholder="请输入公司地址"
            v-decorator="['code', {rules: [{required: false, message: '请输入公司地址'}]}]"
          />
        </a-form-item>
        <a-form-item label="企业邮箱" :labelCol="labelCol" :wrapperCol="wrapperCol" has-feedback>
          <a-input
            placeholder="请输入企业邮箱"
            v-decorator="['code', {rules: [{required: false, message: '请输入企业邮箱'}]}]"
          />
        </a-form-item>
        <a-form-item label="备案信息" :labelCol="labelCol" :wrapperCol="wrapperCol" has-feedback>
          <a-input
            placeholder="请输入备案信息"
            v-decorator="['code', {rules: [{required: false, message: '请输入备案信息'}]}]"
          />
        </a-form-item>
        <a-form-item label="上传二维码" :labelCol="labelCol" :wrapperCol="wrapperCol" has-feedback>
          <a-upload
            name="file"
            list-type="picture-card"
            class="avatar-uploader"
            :show-upload-list="false"
            action="http://192.168.131.126:8080/api/sysFileInfo/upload"
            :before-upload="beforeUpload"
            @change="handleChange"
          >
            <img v-if="imageUrl" :src="imageUrl" alt="avatar" />
            <div v-else>
              <a-icon :type="loading ? 'loading' : 'plus'" />
            </div>
          </a-upload>
          <div class="ant-upload-text">请上传250*250规格图像</div>
        </a-form-item>
        <div style="text-align:center;">
          <a-button type="primary">编辑</a-button>
        </div>
      </a-form>
    </a-spin>
  </a-card>
</template>
<script>
import { sysPosEdit } from '@/api/modular/system/posManage'
function getBase64 (img, callback) {
  const reader = new FileReader()
  reader.addEventListener('load', () => callback(reader.result))
  reader.readAsDataURL(img)
}
export default {
  data () {
    return {
      loading: false,
      imageUrl: '',
      labelCol: {
        xs: { span: 24 },
        sm: { span: 5 }
      },
      wrapperCol: {
        xs: { span: 24 },
        sm: { span: 15 }
      },
      visible: false,
      confirmLoading: false,
      form: this.$form.createForm(this)
    }
  },
  methods: {
    // 初始化方法
    edit (record) {
      this.visible = true
        setTimeout(() => {
          this.form.setFieldsValue(
            {
              id: record.id,
              name: record.name,
              code: record.code,
              sort: record.sort,
              remark: record.remark
            }
          )
        }, 100)
    },
    handleSubmit () {
      const {
        form: { validateFields }
      } = this
      this.confirmLoading = true
      validateFields((errors, values) => {
        if (!errors) {
          sysPosEdit(values)
            .then(res => {
              if (res.success) {
                this.$message.success('编辑成功')
                this.visible = false
                this.confirmLoading = false
                this.$emit('ok', values)
                this.form.resetFields()
              } else {
                this.$message.error('编辑失败:' + res.message)
              }
            })
            .finally(res => {
              this.confirmLoading = false
            })
        } else {
          this.confirmLoading = false
        }
      })
    },
    handleCancel () {
      this.form.resetFields()
      this.visible = false
    },
    // 上传图片
    handleChange (info) {
      if (info.file.status === 'uploading') {
        this.loading = true
        return
      }
      if (info.file.status === 'done') {
        // Get this url from response in real world.
        // 获取图片传参
        console.log(info.fileList[info.fileList.length - 1].response.data)
        getBase64(info.file.originFileObj, imageUrl => {
          this.imageUrl = imageUrl
          this.loading = false
        })
      }
    },
    beforeUpload (file) {
      const isJpgOrPng = file.type === 'image/jpeg' || file.type === 'image/png'
      if (!isJpgOrPng) {
        this.$message.error('You can only upload JPG file!')
      }
      const isLt2M = file.size / 1024 / 1024 < 2
      if (!isLt2M) {
        this.$message.error('Image must smaller than 2MB!')
      }
      console.log(file)
      return isJpgOrPng && isLt2M
    }
  }
}
</script>

+ 7 - 7
_web/src/views/userLoginReg/Login.vue

@ -54,7 +54,7 @@
            </a-input>
          </a-form-item>
        </a-tab-pane>
        <a-tab-pane key="tab2" tab="手机号登录">
        <!-- <a-tab-pane key="tab2" tab="手机号登录">
          <a-alert v-if="isLoginError" type="error" showIcon style="margin-bottom: 24px;" :message="this.accountLoginErrMsg" />
          <a-form-item v-if="tenantOpen">
            <a-select
@ -89,16 +89,16 @@
              ></a-button>
            </a-col>
          </a-row>
        </a-tab-pane>
        </a-tab-pane> -->
      </a-tabs>
      <a-form-item>
        <a-checkbox v-decorator="['rememberMe', { valuePropName: 'checked' }]">自动登录</a-checkbox>
        <router-link
        <!-- <a-checkbox v-decorator="['rememberMe', { valuePropName: 'checked' }]">自动登录</a-checkbox> -->
        <!-- <router-link
          :to="{ name: 'recover', params: { user: 'aaa'} }"
          class="forge-password"
          style="float: right;"
        >忘记密码</router-link>
        >忘记密码</router-link> -->
      </a-form-item>
      <a-form-item style="margin-top:24px">
@ -112,7 +112,7 @@
        >确定</a-button>
      </a-form-item>
      <div class="user-login-other">
      <!-- <div class="user-login-other">
        <span>其他登录方式</span>
        <a>
          <a-icon class="item-icon" type="alipay-circle"></a-icon>
@ -124,7 +124,7 @@
          <a-icon class="item-icon" type="weibo-circle"></a-icon>
        </a>
        <router-link class="register" :to="{ name: 'register' }">注册账户</router-link>
      </div>
      </div> -->
    </a-form>
    <two-step-captcha