feat(期刊): 歌曲部分调整

dev
zhangjiabao 1 year ago
parent 40b00e0698
commit ba2b59a014

@ -0,0 +1,32 @@
/*
* @Description:
* @version: v1
* @Author: zhangjiabao
* @Date: 2024-01-19 23:38:16
*/
import request from "@/utils/request";
export default {
getList(data, page, size) {
return request({
url: `/luoo-music/cms/song/search/${page}/${size}`,
method: "post",
data: data
});
},
getByKeyword(keyword) {
return request({
url: `/luoo-music/cms/song/search/1/999`,
method: "post",
data: { keyword: keyword }
});
},
updateLyric(id, lyric) {
return request({
url: `/luoo-music/cms/song/update/lyric/${id}`,
method: "put",
params: {
lyric
}
});
}
};

@ -54,7 +54,11 @@
<el-table-column prop="name" label="歌曲名称"></el-table-column> <el-table-column prop="name" label="歌曲名称"></el-table-column>
<el-table-column prop="artist" label="歌手/乐队"></el-table-column> <el-table-column prop="artist" label="歌手/乐队"></el-table-column>
<el-table-column prop="album" label="所属专辑"></el-table-column> <el-table-column prop="album" label="所属专辑"></el-table-column>
<el-table-column prop="duration" label="时长"></el-table-column> <el-table-column prop="duration" label="时长">
<template slot-scope="scope">
<audio :src="scope.row.url" controls></audio>
</template>
</el-table-column>
</el-table> </el-table>
<el-form <el-form
style="width: calc(50% + 400px); margin: 15px 0 auto auto;" style="width: calc(50% + 400px); margin: 15px 0 auto auto;"

@ -1,3 +1,10 @@
<!--
* @Author: zhangjiabao
* @Date: 2024-01-24 10:09:33
* @LastEditors: zhangjiabao
* @LastEditTime: 2024-01-24 17:55:06
* @FilePath: /luoo_manage_fe/src/views/article/articleModify.vue
-->
<!-- <!--
* @Description: * @Description:
* @version: v1 * @version: v1
@ -33,7 +40,7 @@
<el-cascader <el-cascader
placeholder="请选择" placeholder="请选择"
:options="remoteTagList" :options="remoteTagList"
:props="{ multiple: true }" :props="{ multiple: true, checkStrictly: true }"
size="small" size="small"
v-model="selectTag" v-model="selectTag"
@change="handleTagSelectChange" @change="handleTagSelectChange"
@ -85,7 +92,12 @@
></el-col ></el-col
> >
<el-col :span="4" <el-col :span="4"
><el-button plain size="small" type="primary" icon="el-icon-zoom-in" ><el-button
plain
size="small"
type="primary"
icon="el-icon-zoom-in"
@click="handleMusicLibiraryAdd"
>曲库添加</el-button >曲库添加</el-button
> >
</el-col> </el-col>
@ -106,7 +118,7 @@
> >
<el-table-column label="排序" align="center" width="60"> <el-table-column label="排序" align="center" width="60">
<template slot-scope="scope"> <template slot-scope="scope">
<i class="el-icon-rank"></i> <i class="el-icon-sort"></i>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="picture" label="专辑封面" width="100px"> <el-table-column prop="picture" label="专辑封面" width="100px">
@ -124,7 +136,12 @@
<el-table-column prop="duration" label="时长"></el-table-column> <el-table-column prop="duration" label="时长"></el-table-column>
<el-table-column label="操作" width="300"> <el-table-column label="操作" width="300">
<template slot-scope="scope"> <template slot-scope="scope">
<el-button plain icon="el-icon-edit" type="primary" size="mini" <el-button
plain
icon="el-icon-edit"
type="primary"
size="mini"
@click="handleMusicModifyClick(scope.row)"
>编辑</el-button >编辑</el-button
> >
<el-button <el-button
@ -191,10 +208,98 @@
> >
</span> </span>
</el-dialog> </el-dialog>
<el-dialog
title="曲库添加"
:visible="true"
v-if="musicDialog.visible"
width="40%"
top="60px"
append-to-body
:before-close="handleMusicDialogBeforeClose"
>
<!-- <el-input v-model="musicDialog.keyword"></el-input> -->
<el-select
v-model="musicDialog.selected"
filterable
remote
reserve-keyword
placeholder="请输入关键词"
@change="handleMusicLibrarySelectChange"
:loading="musicDialog.selectLoading"
:remote-method="queryFromMusicLibrary"
>
<el-option
v-for="item in musicDialog.remoteResult"
:key="item.id"
:label="item.name"
:value="item"
>
</el-option
></el-select>
<el-table
style="margin-top:10px"
border
fit
strip
size="mini"
v-loading="musicDialog.tableLoading"
:header-cell-style="{ background: '#f5f7fa', color: '#606266' }"
:data="musicDialog.tableData"
>
<el-table-column align="center" label="序号" width="95">
<template slot-scope="scope">
{{ scope.$index + 1 }}
</template>
</el-table-column>
<el-table-column prop="name" label="歌曲名称"></el-table-column>
<el-table-column prop="artist" label="歌手/乐队"></el-table-column>
<el-table-column prop="album" label="所属专辑"></el-table-column>
<el-table-column prop="duration" label="时长"></el-table-column>
<el-table-column label="操作">
<template slot-scope="scope">
<el-button
size="mini"
plain
icon="el-icon-delete"
@click="handleMusicLibraryTableDelete(scope.row)"
type="danger"
>删除</el-button
>
</template>
</el-table-column>
</el-table>
<span slot="footer">
<el-button size="small" type="primary" @click="handleMusicDialogSubmit"
>保存</el-button
>
<el-button size="small" @click="handleMusicDialogCancel"
>取消</el-button
>
</span>
</el-dialog>
<el-dialog
title="信息编辑"
:visible="true"
v-if="musicModifyDialog.visible"
width="40%"
top="60px"
append-to-body
:before-close="handleMusicModifyDialogBeforeClose"
><MusicModify
:remoteTagData="remoteTagList"
:data="musicModifyDialog.data"
></MusicModify>
<span slot="footer">
<el-button size="small" type="primary">保存</el-button>
<el-button size="small">取消</el-button>
</span></el-dialog
>
</div> </div>
</template> </template>
<script> <script>
import musicApi from "@/api/musicV2";
import { MusicModify } from "./musicModify.vue";
import Sortable from "sortablejs"; import Sortable from "sortablejs";
import { quillEditor } from "vue-quill-editor"; import { quillEditor } from "vue-quill-editor";
import "quill/dist/quill.core.css"; import "quill/dist/quill.core.css";
@ -232,6 +337,18 @@ export default {
songId: null, songId: null,
data: "" data: ""
}, },
musicDialog: {
visible: false,
selected: null,
selectLoading: false,
tableLoading: false,
tableData: [],
remoteResult: []
},
musicModifyDialog: {
visible: false,
data: {}
},
coverUploadFileList: [], coverUploadFileList: [],
// editorOption // editorOption
// action: '/api/product/richtext_img_upload.do', // // action: '/api/product/richtext_img_upload.do', //
@ -262,7 +379,8 @@ export default {
this.syncTagDataToComponent(); this.syncTagDataToComponent();
}, },
components: { components: {
quillEditor quillEditor,
MusicModify
}, },
mounted() { mounted() {
// el-tabletbody // el-tabletbody
@ -275,14 +393,14 @@ export default {
animation: 150, animation: 150,
// odEndeltable使 // odEndeltable使
onEnd: ({ newIndex, oldIndex }) => { onEnd: ({ newIndex, oldIndex }) => {
const targetRow = this.data.songTableData[oldIndex]; const targetRow = this.data.songs[oldIndex];
this.data.songTableData.splice(oldIndex, 1); this.data.songs.splice(oldIndex, 1);
this.data.songTableData.splice(newIndex, 0, targetRow); this.data.songs.splice(newIndex, 0, targetRow);
console.table(this.data.songTableData);
} }
}); });
}, },
methods: { methods: {
// ************************* *************************
syncTagDataToComponent() { syncTagDataToComponent() {
// selectTag // selectTag
for (let i in this.data.tag) { for (let i in this.data.tag) {
@ -302,10 +420,84 @@ export default {
handleTagSelectChange(val) { handleTagSelectChange(val) {
let newTag = []; let newTag = [];
for (let i in val) { for (let i in val) {
newTag.push(val[i][1]); if (val[i].length === 1) {
newTag.push(val[i][0]);
} else {
newTag.push(val[i][1]);
}
} }
this.data.tag = newTag; this.data.tag = newTag;
}, },
queryFromMusicLibrary(keyword) {
// musicApi.getByKeyword(keyword).then(res => {
// if (res.code === 200) {
// this.musicDialog.remoteResult = res.data;
// } else {
// this.musicDialog.remoteResult = [];
// }
// });
this.musicDialog.selectLoading = true;
setTimeout(() => {
let musicList = [
{
album: "范特西",
artist: "周杰伦",
duration: "1h30min",
id: "1",
journal: [1, 2, 3],
lyric: "lllll llll lll",
name: "双节棍",
picture: "https://luoow.wxwenku.com/999/cover_min.jpg",
size: "1.3m",
state: "1",
tags: [3, 5, 11],
updateTime: "2023-01-01",
url:
"https://luoow.wxwenku.com/999/01._Belmondo_(Große_Liebe)_Annett_Louisan.mp3",
userId: "1"
},
{
album: "范特西1",
artist: "周杰伦1",
duration: "1h30min",
id: "2",
journal: [1, 2, 3],
lyric: "lllll llll lll",
name: "双节棍1",
picture: "https://luoow.wxwenku.com/999/cover_min.jpg",
size: "1.3m",
state: "1",
tags: [3, 5, 11],
updateTime: "2023-01-01",
url:
"https://luoow.wxwenku.com/999/01._Belmondo_(Große_Liebe)_Annett_Louisan.mp3",
userId: "1"
}
];
this.musicDialog.remoteResult = musicList;
this.musicDialog.selectLoading = false;
}, 1000);
},
handleMusicLibrarySelectChange(val) {
for (let i in this.musicDialog.tableData) {
if (this.musicDialog.tableData[i]["id"] === val["id"]) {
return;
}
}
this.musicDialog.tableData.push(val);
},
handleMusicLibraryTableDelete(row) {
let newList = [];
for (let i in this.musicDialog.tableData) {
let item = this.musicDialog.tableData[i];
if (item["id"] === row["id"]) {
continue;
}
newList.push(item);
}
this.musicDialog.tableData = newList;
},
// ************************* *************************
handleRemove(file, fileList) { handleRemove(file, fileList) {
console.log(file, fileList); console.log(file, fileList);
}, },
@ -322,6 +514,21 @@ export default {
beforeRemove(file, fileList) { beforeRemove(file, fileList) {
return this.$confirm(`确定移除 ${file.name}`); return this.$confirm(`确定移除 ${file.name}`);
}, },
// ************************* *************************
/**
* 曲库添加按扭点击事件
*/
handleMusicLibiraryAdd() {
this.musicDialog.visible = true;
},
/**
* 歌曲编辑按扭点击事件
*/
handleMusicModifyClick(row) {
this.musicModifyDialog.data = row;
this.musicModifyDialog.visible = true;
},
// ************************* *************************
/** /**
* 弹窗关闭按扭点击事件 * 弹窗关闭按扭点击事件
*/ */
@ -341,6 +548,23 @@ export default {
* 弹窗提交按扭点击事件 * 弹窗提交按扭点击事件
*/ */
handleLyricDialogSubmit() { handleLyricDialogSubmit() {
// musicApi
// .updateLyric(this.lyricDialog.songId, this.lyricDialog.data)
// .then(res => {
// if (res.code === 200) {
// for (let sIndex in this.data.songs) {
// if (this.data.songs[sIndex].id === this.lyricDialog.songId) {
// this.data.songs[sIndex].lyric = this.lyricDialog.data;
// }
// break;
// }
// this.lyricDialog.data = "";
// this.lyricDialog.songId = null;
// this.lyricDialog.visible = false;
// } else {
// this.$message.error(res.message);
// }
// });
for (let sIndex in this.data.songs) { for (let sIndex in this.data.songs) {
if (this.data.songs[sIndex].id === this.lyricDialog.songId) { if (this.data.songs[sIndex].id === this.lyricDialog.songId) {
this.data.songs[sIndex].lyric = this.lyricDialog.data; this.data.songs[sIndex].lyric = this.lyricDialog.data;
@ -366,6 +590,49 @@ export default {
this.lyricDialog.songId = row.id; this.lyricDialog.songId = row.id;
this.lyricDialog.data = row.lyric; this.lyricDialog.data = row.lyric;
this.lyricDialog.visible = true; this.lyricDialog.visible = true;
},
/**
* 弹窗关闭按扭点击事件
*/
handleMusicDialogBeforeClose(done) {
this.musicDialog.visible = false;
done();
},
/**
* 弹窗提交按扭点击事件
*/
handleMusicDialogSubmit() {
this.$message.success("music submit");
// let newList = []
for (let i in this.musicDialog.tableData) {
let item = this.musicDialog.tableData[i];
let isIn = false;
for (let j in this.data.songs) {
let itemInTable = this.data.songs[j];
if (itemInTable.id === item.id) {
isIn = true;
break;
}
}
if (!isIn) {
this.data.songs.push(item);
}
}
this.musicDialog.visible = false;
},
/**
* 弹窗取消按扭点击事件
*/
handleMusicDialogCancel() {
this.$message.success("music cancel");
this.musicDialog.visible = false;
},
/**
* 弹窗关闭按扭点击事件
*/
handleMusicModifyDialogBeforeClose(done) {
this.musicModifyDialog.visible = false;
done();
} }
} }
}; };

@ -401,14 +401,15 @@ export default {
state: "1", state: "1",
tags: [3, 5, 11], tags: [3, 5, 11],
updateTime: "2023-01-01", updateTime: "2023-01-01",
url: "/music/music", url:
"https://luoow.wxwenku.com/999/01._Belmondo_(Große_Liebe)_Annett_Louisan.mp3",
userId: "1" userId: "1"
} }
], ],
state: "1", state: "1",
status: "1", status: "1",
summary: "领军 \n 灵精了", summary: "领军 \n 灵精了",
tag: [3, 5, 11], tag: [1, 3, 5, 11],
userId: "1627863701048659968" userId: "1627863701048659968"
} }
], ],
@ -633,7 +634,6 @@ export default {
if (valid) { if (valid) {
// //
if (this.modifyDialog.type === 0) { if (this.modifyDialog.type === 0) {
console.log(this.$refs.modifyDialog.data); console.log(this.$refs.modifyDialog.data);
articleApi.add(this.$refs.modifyDialog.data).then(res => { articleApi.add(this.$refs.modifyDialog.data).then(res => {
if (res.code === 200) { if (res.code === 200) {

@ -0,0 +1,141 @@
<template>
<div>
<el-form
:model="data"
:rules="rules"
ref="musicModifyForm"
label-width="100px"
>
<el-form-item prop="name" label="歌曲名称">
<el-input
v-model="data.name"
size="small"
placeholder="请输入"
></el-input>
</el-form-item>
<el-form-item prop="artist" label="歌手/乐队">
<el-input
v-model="data.artist"
size="small"
placeholder="请输入"
></el-input>
</el-form-item>
<el-form-item prop="album" label="所属专辑">
<el-input
v-model="data.album"
size="small"
placeholder="请输入"
></el-input>
</el-form-item>
<el-form-item prop="tags" label="歌曲标签">
<el-cascader
placeholder="请选择"
:options="remoteTagList"
:props="{ multiple: true, checkStrictly: true }"
size="small"
v-model="selectTag"
@change="handleTagSelectChange"
filterable
></el-cascader>
</el-form-item>
<el-form-item prop="picture" label="上传封面">
<img
style="width: 170px;height: 120px;"
v-if="data.picture"
:src="data.picture"
/>
<el-upload
action="https://jsonplaceholder.typicode.com/posts/"
:on-preview="handlePreview"
:on-remove="handleRemove"
:before-remove="beforeRemove"
multiple
:limit="1"
:on-exceed="handleExceed"
:file-list="coverUploadFileList"
>
<el-button size="small" type="primary" icon="el-icon-receiving"
>上传图片</el-button
>
<div
slot="tip"
style="font-family: '微软雅黑', sans-serif; font-weight: 400; font-style: normal; color: #999999;"
>
支持格式.jpg, .png 单个文件不能超过5MB 建议图片分辨率640*520
</div>
</el-upload>
</el-form-item>
</el-form>
</div>
</template>
<script>
export default {
name: "MusicModify",
props: {
remoteTagList: {
type: Array,
default: []
},
data: {
type: Object,
default: {
album: null,
artist: null,
duration: null,
id: null,
journal: [],
lyric: null,
name: null,
picture: null,
size: null,
state: "1",
tags: [],
updateTime: null,
url: null,
userId: null
}
}
},
data() {
return {
selectTag: [],
rules: {}
};
},
filters: {},
created() {},
components: {},
mounted() {},
methods: {
handleTagSelectChange(val) {
let newTag = [];
for (let i in val) {
if (val[i].length === 1) {
newTag.push(val[i][0]);
} else {
newTag.push(val[i][1]);
}
}
this.data.tags = newTag;
},
// ************************* *************************
handleRemove(file, fileList) {
console.log(file, fileList);
},
handlePreview(file) {
console.log(file);
},
handleExceed(files, fileList) {
this.$message.warning(
`当前限制选择 1 个文件,本次选择了 ${
files.length
} 个文件共选择了 ${files.length + fileList.length} 个文件`
);
},
beforeRemove(file, fileList) {
return this.$confirm(`确定移除 ${file.name}`);
}
}
};
</script>
<style scoped></style>
Loading…
Cancel
Save