前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Ant Design Upload 组件封装

Ant Design Upload 组件封装

作者头像
lyudev
发布于 2022-08-04 02:58:04
发布于 2022-08-04 02:58:04
46800
代码可运行
举报
文章被收录于专栏:代码即数据代码即数据
运行总次数:0
代码可运行
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<template>
  <j-modal
    width="80%"
    :onclick="clickrow"
    :title="title"
    :maskClosable="false"
    switchFullscreen
    :visible.sync="editModalVisible"
    @cancel="handleCancleDbSync"
  >
    <template slot="footer">
      <a-button @click="handleCancleDbSync">
        关闭
      </a-button>
      <a-button type="primary" v-if="!disableSubmit" :loading="syncLoading" @click="handleDbSync">确认</a-button>
    </template>
    <vxe-grid
      ref="xTable"
      border
      resizable
      keep-source
      show-overflow
      height="600px"
      :customRow="rowClick"
      mode="row"
      align="center"
      :edit-rules="validRules"
      :edit-config="{trigger: 'click', mode: 'row',activeMethod: activeRowMethod}"
      :columns="tableColumn"
      :data="dataSource"
      @edit-closed="handle"
    >
    
      <template v-slot:operate="{ row }">
        <a-button type="primary" style="margin:0px 8px 0px 0px;" @click="handleResults(row)">查看文件</a-button>
      </template>
    </vxe-grid>
    <AssessmentFile ref="assessmentFile"  @ok="modalFormOk" @handleChange="changeName"></AssessmentFile>
  </j-modal>
</template>
<script>
import {  putAction, getAction, postAction } from '@/api/manage'
import { filterDictTextByCache } from '@/components/dict/JDictSelectUtil'
import JSelectMultiUser from '@/components/jeecgbiz/JSelectMultiUser'
import AssessmentFile from './AssessmentFile'
import { downFile } from '../../../../api/manage'
import {ACCESS_TOKEN} from "@/store/mutation-types"
import Vue from 'vue'
import { Modal } from 'ant-design-vue'
import eventBus from '@/utils/eventBus'
export default {
  name: 'AssessmentTaskModalUser',
  components: {
    JSelectMultiUser,
    AssessmentFile
  },

  data() {
    let ellipsis = (v,a=20) => (<j-ellipsis value={v} length={a}/>)
    return {
      Headertoken: {'X-Access-Token': Vue.ls.get(ACCESS_TOKEN)},
      editModalVisible: false,
      disableSubmit: false,
      title: '考核评分',
      id:'',
      //taskCode:'',
      //ifleaderuser:true,
      syncLoading: false,
      url: {
        completeUserTask: '/hr/assessment/task/completeUserTask',
        completeTask: '/hr/assessment/task/completeTask',
        taskresultquery: '/hr/assessment/taskresult/queryResult',
        uploadpdffile:'standlib/file/upload',
        update: '/hr/assessment/taskresult/updateFileIntoResult',
        list:'/hr/assessment/taskresult/listfile',
        exportXlsUrl: "/hr/maturity/task/exportXls",
        importExcelUrl: '/hr/maturity/task/importExcel',
        getDataSectionByPlanCode: '/hr/assessment/map/getDataSectionByPlanCode'
      },
      tableColumn: [
        { type: 'seq', width: 60 },
        ],
      validRules: {
        enterpriseWeight: [
          { validator: this.enterpriseWeight },
          { min: 0, type: 'number', message: '请填写大于0的数字' }
        ],
      },
      dataSource: [],
      formData: {},
      name:''
    }
  },
  methods: {
    handleResults(row) {
      this.id = row.id
      console.log(row)
      this.$refs.assessmentFile.loadData(row,'taskUser')
      this.$refs.assessmentFile.disableCheck = true
      this.$refs.assessmentFile.disableSubmit = true
      this.$refs.assessmentFile.title = '查看文件'
      this.$refs.assessmentFile.editModalHidden = true
    },

  }
}
</script>
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<template>
  <j-modal
    width='60%'
    :onclick='clickrow'
    :title='title'
    :maskClosable='false'
    switchFullscreen
    :visible.sync='editModalHidden'
    @cancel='handleCancleDbSync'
  >
    <template>
      <a-upload
        accept='.pdf'
        :multiple='false'
        :action='uploadpdffile'
        :headers='Headertoken'
        :default-file-list='defaultFileList'
        :file-list='fileList'
        @change='handleChange'
      >
        <a-button type='primary' icon='upload'> 上传</a-button>
      </a-upload>
    </template>
    <template slot='footer'>
      <a-button @click='handleCancleDbSync'>
        关闭
      </a-button>
    </template>
  </j-modal>
</template>
<script>

import { ACCESS_TOKEN } from '@/store/mutation-types'
import Vue from 'vue'
import { Modal } from 'ant-design-vue'
import { postAction, getAction, deleteAction } from '@/api/manage'

export default {
  name: 'AssessmentFile',
  components: {},
  data() {
    return {
      editModalHidden: false,
      Headertoken: { 'X-Access-Token': Vue.ls.get(ACCESS_TOKEN) },
      url: {
        uploadpdffile: 'standlib/file/upload',
        update: '/hr/assessment/taskresult/updateFileIntoResult',
        userFileAdd: '/hr/taskFile/add',
        userTaskFile: '/hr/taskFile/list',
        userTaskFileDelete: '/hr/taskFile/delete',
        leaderFileAdd: '/hr/taskSummaryFile/add',
        leaderFileList: '/hr/taskSummaryFile/list',
        leaderFileDelete: '/hr/taskSummaryFile/delete'
      },
      rowId: '',
      defaultFileList: [],
      loadType: '',
      fileList: []
    }
  },
  methods: {
    uploadpdffile(row) {
      return `${window._CONFIG['domianURL']}/${this.url.uploadpdffile}`
    },
    handleCancleDbSync() {
      this.fileList = []
      this.defaultFileList = []
      this.disableSubmit = false
      this.editModalHidden = false
      this.$emit('handleChange', 'close')
    },
    loadData(instanceCode, type) {
      this.rowId = instanceCode.id
      this.loadType = type
      getAction(this.fileUrl().fileListUrl, { taskId: this.rowId }).then(res => {
        //console.log(res,'res')
        if (res.success) {
          for (var i = 0; i < res.result.length; i++) {
            var resuit = {
              uid: res.result[i].id,
              name: res.result[i].fileName,
              status: 'done',
              response: res.result[i].fileName, // custom error message to show
              url: window._CONFIG['domianURL'] + '/' + res.result[i].fileName
            }
            this.fileList.push(resuit)
            this.defaultFileList.push(resuit)
          }
        } else {
          this.$message.warning(res.message)
        }
      })
    },
    fileUrl() {
      var fileUrl = {
        addFileUrl: '',
        fileListUrl: '',
        deleteFileUrl: ''
      }
      if (this.loadType == 'taskUser') {
        fileUrl.addFileUrl = this.url.userFileAdd
        fileUrl.fileListUrl = this.url.userTaskFile
        fileUrl.deleteFileUrl = this.url.userTaskFileDelete
      }
      if (this.loadType == 'taskLeader') {
        fileUrl.addFileUrl = this.url.leaderFileAdd
        fileUrl.fileListUrl = this.url.leaderFileList
        fileUrl.deleteFileUrl = this.url.leaderFileDelete
      }
      return fileUrl
    },
    handleChange({ file, fileList }) {
      if (file.status === 'uploading') {
        console.log('uploading', file)
      } else if (file.status === 'done') {
        postAction(this.fileUrl().addFileUrl, {
          'id': new Date().valueOf(),
          'fileName': file.response.result.fileUrl,
          //'fileName': info.file.name,
          'taskId': this.rowId
        }).then(res => {
          if (res.success) {
            this.handleCancleDbSync()
            this.$message.success(res.message)
          } else {
            this.$message.success(res.message)
          }
        })
      } else if (file.status === 'error') {
        if (info.file.response.status === 500) {
          let data = info.file.response
          const token = Vue.ls.get(ACCESS_TOKEN)
          if (token && data.message.includes('Token失效')) {
            Modal.error({
              title: '登录已过期',
              content: '很抱歉,登录已过期,请重新登录',
              okText: '重新登录',
              mask: false,
              onOk: () => {
                store.dispatch('Logout').then(() => {
                  Vue.ls.remove(ACCESS_TOKEN)
                  window.location.reload()
                })
              }
            })
          }
        } else {
          this.$message.error(`文件上传失败: ${info.file.msg} `)
        }
      } else if (file.status === 'removed') {
        deleteAction(this.fileUrl().deleteFileUrl, {
          'id': file.uid
        }).then(res => {
          if (res.success) {
            this.$message.success(res.message)
          } else {
            this.$message.success(res.message)
          }
        })
      }
      this.fileList = fileList
      this.defaultFileList = fileList
    }
  }
}
</script>
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-07-27,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 代码即数据 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
photoshop学习笔记
窗口——工作区——复位基本功能:让软件界面恢复到默认的标准状态 所有的控制面板都在窗口菜单中,可以对其进行隐藏和显示 按下TAB键可以隐藏或显示工具箱,属性栏,控制面板 按下SHIFT+TAB键,可以只隐藏控制面板 新建文档: 基于互联网设计(屏幕显示):单位:像素,分辨率:72,颜色模式:RGB 基于印刷设计时:单位:毫米MM,分辨率:300,颜色模式:CMYK (一)矩形选框工具(椭圆选框)M 按SHIFT键可以强制为正方形(正圆) 按ALT键可以保持中心点不变 同时按下SHIFT+ALT键,可保持中心不变强制为正方形(正圆) (二)背景色 前景色填充:ALT+DELETE(删除) 背景色填充:CTRL+DELETE(删除) 按D键,恢复到默认的黑白色 按X键,前背景色的切换 (三)移动工具V 功能:移动对象 复制:按下ALT键用移动工具进行拖拽 (四)图层 新建图层:CTRL+ALT+SHIFT+N 图层编组:CTRL+G (五)保存和打开 保存:CTRL+S 可以把内容存储起来 另存为:CTRL+SHIFT+S,把文件重新保存一份 默认的格式:PSD(源文件格式) 打开的方式:CTRL+O 把文档拖拽至软件中也可以打开 (六):移动选取与移动内容的区别 移动选区:绘制选区后,用矩形选框工具指在选区内,会出现白色箭头,可以移动选区。(属性栏中必须选 中的新选区) 移动内容:绘制选区后,用移动工具指在选区内,会出现黑色箭头,可以移动选区内的内容。 (七)选区的修改 边界:会得到有一定宽度的环形区域,会有羽化效果 平滑:把直角选区变成圆角选区 扩展:均匀的扩大选区 收缩:均匀的缩小选区 (八)自由变换CTRL+T 按下SHIFT键,保持比例不变 按下ALT键,保持中心不变 调整四个角点可以调整整体比例,调整四个边点可以调整宽度和高度 按下SHIFT加工具本身的快捷键,可以切换选中的工具 CTRL+k:首选项 (九)羽化SHIFT+F6 羽化:让边缘变得柔和,半透明 选区的布尔运算:加选区,减选区,与选区相交 载入选区:按下CTRL键,点击图层缩略图可得到相应的选区 (十)常用快捷键 取消选区:CTRL+D 第一步撤销CTRL+Z,第二步以上的撤销CTRL+ALT+Z)默认撤销步数为20步。 放大:CTRL+”+” 缩小:CTRL+”-” 抓手工具:空格 CTRL+J:通过拷贝的图层(复制图层) 橡皮擦工具:E
HUC思梦
2020/09/03
3.4K0
2020版PS快捷键_ps应用快捷键大全
说明:为避免篇幅过大,本文快捷键是基于Windows系统下Photoshop 2020版本的。Mac系统下的快捷键可按以下方式进行对应:Ctrl→Command,Alt→Option。有不能对应的,本文会给出说明。部分项目附加英文是为了方便记忆快捷键。
全栈程序员站长
2022/11/11
1.7K0
2020版PS快捷键_ps应用快捷键大全
关于前端的photoshop初探的学习笔记
写在前边 这还是高三的时候暑假的时候学习这个软件时记的笔记呢,今天又在电脑上找到了它,总觉得不应该让他尘封在我的硬盘上,于是挂了出来。 温馨提示:比较乱,写给自己看的,看不下去,按ctrl+W 笔记内容 ps简介 可以用于合成。 可以三维 adobe bridge图像浏览器 可以直接将图片拖动到ps的编辑系统中。。但是是出于临时文件状态,还需要对他进行保存。。 网站上某些图片不能够拉动,但是可以利用截图功能来实现。。 两张图片同时拉倒一个文件中构成两个不同的图层。。打开文件的几种方法。。 ps数
Angel_Kitty
2018/04/09
2.4K0
数码照片处理基本技法
数码照片的大小和质量与其像素的大小和分辨率有密切关注。CS6在编辑图像之前,先设置图像的大小分辨率。
Java架构师必看
2021/03/22
1.2K0
数码照片处理基本技法
ps快捷键
基础操作: ctrl+0=显示全图; ctrl+=放大; ctrl-=缩小; ctrl+j:复制当前图层到一个新层 ; ctrl+1 =实际像素显示。
mcxfate
2020/08/01
4.2K0
【PS学习记录】污点修复工具 修复画笔工具 修补工具 内容感知移动工具
3.内容识别:点击需要修复的区域。软件会自动在他的周围进行取样,通过计算对其进行光线和明暗的匹配,并进行羽化融合
KEVINGUO_CN
2020/03/16
2.8K0
Adobe PS快捷键
PS快捷键是Photoshop为了提高绘图速度定义的快捷方式,它用一个或几个简单的字母来代替常用的命令。 多种工具共用一个快捷键的可同时按【Shift】加此快捷键选取;查看键盘所有快捷键:【Ctrl】+【Alt】+【Shift】+【K】。 工具使用快捷键 矩形、椭圆选框工具:【M】 套索、多边形套索、磁性套索:【L】 橡皮擦工具:【E】 裁剪工具:【C】 仿制图章、图案图章:【S】 画笔修复工具、修补工具:【J】 添加锚点工具:【+】 移动工具:【V】 历史记录画笔工具:【Y】 模糊
Vicsh
2018/05/16
7970
Photoshop ps 快捷键
ctrl+shift+n 新建图层 ctrl+alt+shift+t  再次变化应用(附加新图层) crtl+e  合并图层 ctrl+t  快速缩放、自由变换  ctrl+j  快速贴入图层(选区内的画面为内容新建一个图层) 【 或】 画笔放大缩小(失灵时,ctrl+ 空格) crtl+shift+i  反向选择 ctrl+D  取消选区选择 ctrl+鼠标左键选择图层选区  载入选区 空格键拖动  选区没画好空格键拖动 区域内拖动  已经画好选区了 alt+鼠标滚轮、ctrl+加号 ctrl + 加/减
卓越笔记
2023/02/18
9040
Photoshop ps 快捷键
一些实用的Photoshop快捷键
将所选文本的文字大小减小10 点像素 【Ctrl】+【Alt】+【Shift】+【<】
半夜喝可乐
2018/10/17
1.8K0
一些实用的Photoshop快捷键
PS干货分享--全版本下载 ps最新软件安装包
各版本软件获取:http://jiaocheng8.top/ps.html?0idshjbdg 干货分享: PS 怎么把字去掉不伤背景?使用抠图软件来将字进行去除,不仅会花费大量时间,而且会将背景或
木子学Lee
2023/03/02
1.4K0
PS干货分享--全版本下载 ps最新软件安装包
20种常用的 Ps技术
一种简单的数码照片后期润饰 1 打开图片,执行色像/饱和度(-40)降低饱和度。 2 新建一图层,将图层模式改为柔光,用画笔工具将需要润饰的部分画几下,这里可以利用色板方便的提取颜色 3 图片色彩过渡不够柔和,再执行一下滤镜下面的高斯模糊(+85)
WindCoder
2018/09/20
2.7K0
快速批量去除图片水印方法大全~~
去水印是不复杂啦,可几千页下来,自己用橡皮抹会抹抽筋的吧~~~哈哈哈,下边记录一下偶的心路过程~~~(汗,一副盗版光荣的样子,RP真是越来越差-_-!!) 所用软件:Adobe acrobat professional 7.0 和Adobe photoshop CS2 1。本来就是扫描之后存出来的PDF嘛,所以就用PRO7.0里的导出图片功能把所有的单页转回成图片先,自动按顺序命名,存在文件夹A中。 2。用CS2随便打开其中一页,例如第49页—用“吸管”工具选中那个水印的颜色为前景色。 3。CS菜单—窗口—勾选“动作”—出来个动作的小窗口。 4。动作—新建动作—命名为“去水印”—-开始“记录”(是为了以后那几千多页的,电脑傻的只会重复呢) 5。现在开始处理那第49页。菜单—选择—色彩范围—-颜色容差里偶写90(吼吼,可以变的啦,以选出那个大水印的全部颜色但是不会选中跟水印重复的字体颜色为标准)—-按“确定”。 6。菜单—选择—扩大选取(不然会有水印框框留在原处的) 7。按DELETE键删除选中的水印。(或者编辑—填充白色,反正弄完了看不见水印就好) 8。菜单–文件—存储为WEB所用格式JPG(黑白页面品质低点也没啥影响,反正一页变小点,一本书下来就轻便不少呢~~)—存到文件夹B。 9 动作小窗口—停止记录 10。文件—自动—批处理—源文件夹就选存有水印的文件夹A,目标文件就选处理好了没水印的文件夹B,错误嘛,“选记录到文件”,随便建个记事本文件记好了。 按了确定之后呢,就该聊天的聊天,该打牌的打牌咯,想睡觉的也可以去睡觉,哈哈哈哈哈哈,反正PS好之后自然会停止的。PRO7.0里就有从多个文件创建一个PDF的选项,可惜速度慢了点,闲的话就下个软件image2PDF啥的,西西,很容易就又整合成书了~~~
全栈程序员站长
2022/07/23
3K0
快速批量去除图片水印方法大全~~
Adobe Photoshop 2020软件安装教程--所有PS软件全版本!
在这新版本中,Adobe从命名上就做出了新的改变,去除了用了七八年的CC,新版直接就叫做Adobe Photoshop 2020。
用户10295662
2023/01/10
1.7K0
ps技巧第一章 原
1. 右击图层,选择转换为智能对象,然后选择滤镜 模糊 高斯模糊2像素 2. 选中图层的智能滤镜,然后设置前景色为黑色,选择硬度为0画笔工具进行部分涂抹,使图像清晰(或者使用渐变工具拖动)
tianyawhl
2019/04/04
4660
2020PS平面设计快捷键最新最全使用攻略
注意:【选择工具】的”自动选择“是没有勾选的,如果已经勾选,那么不需要加入Ctrl,直接按Shift来进行多选。
有趣的p图姐
2020/04/15
2.5K0
ps学习经验心得分享【萧蕊冰】
哈喽~我又来啦~今天我要来分享ps学习经验心得。从小了看,在UI设计中,PS软件是我们必备的软件之一;往大了说。PS不仅UI设计会用到,什么平面设计、工业设计、电商设计等等,跟设计相关的都会用到,所以PS是一个万能软件哈哈,那今天这篇萧蕊冰讲的就是ps学习经验心得分享。
萧蕊冰
2020/06/22
8100
PS技巧方法==软件安装包Photoshop最新版本下载安装
Photoshop是一款非常好用的图像编辑软件,很多小伙伴在遇到有图片需要进行编辑 工作 时,都会使用这款软件进行操作,但是也不妨有许多新手同学们第一次使用这款软件,软件强大的功能让他们有些不知如何操作,那么今天小编就为大家带来一种PS里 抠图 的步骤分享,希望使用这款软件的新用户们能从中学到更多关于Photoshop的知识!
木子学Lee
2023/03/26
1.1K0
PS技巧方法==软件安装包Photoshop最新版本下载安装
ps工具栏快捷键大全-详细介绍5种PS中常用的抠图技巧,助你快速抠出你想要的区域
  抠图是图像处理中最常做的操作之一,也是中最为常用的技术之一。抠图其实并不难,只要你有足够的耐心和细心,只须掌握PS中一些基础知识就能完美的抠出图片。本文详细介绍PS种常用的5种抠图技术,分别是利用魔术棒工具、快速选择工具、磁性套索工具、多边形套索工具 、内容识别填充进行抠图,助你快速抠出你想要的区域。
宜轩
2022/12/29
1.4K0
exposure2023最新版Ps滤镜磨皮插件
滤镜插件是ps的重要功能之一,它主要是用来制作不同的图片特效。那么,ps滤镜插件哪些好用,ps滤镜插件如何获取,下面我们一起来学习这些内容。
用户7442547
2022/11/22
1.4K0
小明加密通道进入_如何利用PS通道去除面部雀斑
今天,教大家如何去除雀斑,美颜,教程主要包括了对图层通道、滤镜的高反差保留,污点修复画笔工具,以及曲线等效果的应用。
全栈程序员站长
2022/07/05
2K0
小明加密通道进入_如何利用PS通道去除面部雀斑
相关推荐
photoshop学习笔记
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档