功能变化: 文件上传支持音视频
parent
b3c744e855
commit
aeb6cb9810
|
@ -42,6 +42,7 @@
|
||||||
"ua-parser-js": "^0.7.20",
|
"ua-parser-js": "^0.7.20",
|
||||||
"viser-vue": "^2.4.8",
|
"viser-vue": "^2.4.8",
|
||||||
"vue": "2.7.14",
|
"vue": "2.7.14",
|
||||||
|
"vue-core-video-player": "^0.2.0",
|
||||||
"vue-echarts": "^6.5.4",
|
"vue-echarts": "^6.5.4",
|
||||||
"vue-grid-layout": "^2.4.0",
|
"vue-grid-layout": "^2.4.0",
|
||||||
"vue-html2pdf": "^1.8.0",
|
"vue-html2pdf": "^1.8.0",
|
||||||
|
|
|
@ -36,11 +36,33 @@
|
||||||
<i class="el-icon-plus avatar-uploader-icon" v-else/>
|
<i class="el-icon-plus avatar-uploader-icon" v-else/>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
<template v-else-if="_elProps.listType === 'video'">
|
||||||
|
<div class="avatar-item-wrapper">
|
||||||
|
<div class="status-uploading" v-if="avatarLoading!=null">
|
||||||
|
<el-progress type="circle" :percentage="avatarLoading" :width="70"/>
|
||||||
|
</div>
|
||||||
|
<div v-if="avatarUrl!=null" class="avatar">
|
||||||
|
<img src="./play-back.png">
|
||||||
|
<div class="preview" @click.stop="" >
|
||||||
|
<i class="el-icon-video-camera" @click="previewAvatar"></i>
|
||||||
|
<i class="el-icon-delete" v-if="!disabled" @click="removeAvatar"></i>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<i class="el-icon-plus avatar-uploader-icon" v-else/>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
</el-upload>
|
</el-upload>
|
||||||
<el-dialog :visible.sync="dialogVisible" v-bind="preview" append-to-body >
|
<el-dialog :visible.sync="dialogVisible" v-bind="preview" append-to-body >
|
||||||
<div style="text-align: center">
|
<div style="text-align: center" v-if="_elProps.listType === 'avatar'">
|
||||||
<img style="max-width: 100%;" :src="dialogImageUrl" alt="">
|
<img style="max-width: 100%;" :src="dialogImageUrl" alt="">
|
||||||
</div>
|
</div>
|
||||||
|
<div style="text-align: center" v-else>
|
||||||
|
<div id="player" v-if="dialogVisible">
|
||||||
|
<div class="player-container">
|
||||||
|
<vue-core-video-player style="max-width: 100%;" :src="dialogImageUrl" autoplay :loop="true"/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</el-dialog>
|
</el-dialog>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
@ -169,6 +191,8 @@ export default {
|
||||||
uploadClass () {
|
uploadClass () {
|
||||||
if (this._elProps.listType === 'avatar') {
|
if (this._elProps.listType === 'avatar') {
|
||||||
return 'avatar-uploader'
|
return 'avatar-uploader'
|
||||||
|
} else if (this._elProps.listType === 'video') {
|
||||||
|
return 'avatar-uploader'
|
||||||
} else if (this._elProps.listType === 'picture-card') {
|
} else if (this._elProps.listType === 'picture-card') {
|
||||||
if (this.fileList && this._elProps.limit !== 0 && this.fileList.length >= this._elProps.limit) {
|
if (this.fileList && this._elProps.limit !== 0 && this.fileList.length >= this._elProps.limit) {
|
||||||
return 'image-uploader hide-plus'
|
return 'image-uploader hide-plus'
|
||||||
|
@ -189,7 +213,7 @@ export default {
|
||||||
showFileList: true,
|
showFileList: true,
|
||||||
action: '',
|
action: '',
|
||||||
onPreview: (file) => {
|
onPreview: (file) => {
|
||||||
if (this._elProps.listType === 'picture-card' || this._elProps.listType === 'picture' || this._elProps.listType === 'avatar') {
|
if (this._elProps.listType === 'picture-card' || this._elProps.listType === 'picture' || this._elProps.listType === 'avatar' || this._elProps.listType === 'video') {
|
||||||
this.dialogImageUrl = file.url
|
this.dialogImageUrl = file.url
|
||||||
this.dialogVisible = true
|
this.dialogVisible = true
|
||||||
} else {
|
} else {
|
||||||
|
@ -215,6 +239,7 @@ export default {
|
||||||
const limitTip = this.computeFileSize(limit)
|
const limitTip = this.computeFileSize(limit)
|
||||||
const fileSizeTip = this.computeFileSize(file.size)
|
const fileSizeTip = this.computeFileSize(file.size)
|
||||||
this.$message({ message: '文件大小不能超过' + limitTip + ',当前文件大小:' + fileSizeTip, type: 'warning' })
|
this.$message({ message: '文件大小不能超过' + limitTip + ',当前文件大小:' + fileSizeTip, type: 'warning' })
|
||||||
|
return false
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -286,7 +311,7 @@ export default {
|
||||||
this.$set(this, 'fileList', fileList)
|
this.$set(this, 'fileList', fileList)
|
||||||
},
|
},
|
||||||
handleUploadProgress (event, file, fileList) {
|
handleUploadProgress (event, file, fileList) {
|
||||||
if (this._elProps.listType === 'avatar') {
|
if (this._elProps.listType === 'avatar' || this._elProps.listType === 'video') {
|
||||||
log.debug('progress', event, file)
|
log.debug('progress', event, file)
|
||||||
this.avatarLoading = Math.floor(event.percent)
|
this.avatarLoading = Math.floor(event.percent)
|
||||||
if (event.percent === 100) {
|
if (event.percent === 100) {
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 42 KiB |
|
@ -35,9 +35,11 @@ import md5 from 'js-md5'
|
||||||
// websocket
|
// websocket
|
||||||
import websocket from '@/api/websocket'
|
import websocket from '@/api/websocket'
|
||||||
import util from '@/libs/util'
|
import util from '@/libs/util'
|
||||||
|
import VueCoreVideoPlayer from 'vue-core-video-player'
|
||||||
// 引入echarts
|
// 引入echarts
|
||||||
import * as echarts from 'echarts' // 注册echarts组件
|
import * as echarts from 'echarts' // 注册echarts组件
|
||||||
|
|
||||||
|
Vue.use(VueCoreVideoPlayer)
|
||||||
// 核心插件
|
// 核心插件
|
||||||
Vue.use(d2Admin)
|
Vue.use(d2Admin)
|
||||||
Vue.use(VXETable)
|
Vue.use(VXETable)
|
||||||
|
|
Loading…
Reference in New Issue