23ff9cdec1
Fix an error statement
237 lines
8.6 KiB
Vue
237 lines
8.6 KiB
Vue
<template>
|
||
<div id="app">
|
||
<el-container>
|
||
<el-main>
|
||
<el-upload
|
||
:auto-upload="false"
|
||
:on-change="handleFile"
|
||
:show-file-list="false"
|
||
action=""
|
||
drag
|
||
multiple>
|
||
<i class="el-icon-upload"></i>
|
||
<div class="el-upload__text">将文件拖到此处,或<em>点击选择</em></div>
|
||
<div class="el-upload__tip" slot="tip">本工具仅在浏览器内对文件进行解锁,无需消耗流量</div>
|
||
</el-upload>
|
||
|
||
<el-row id="app-control">
|
||
|
||
<el-button @click="handleDownloadAll" icon="el-icon-download" plain>下载全部</el-button>
|
||
<el-button @click="handleDeleteAll" icon="el-icon-delete" plain type="danger">删除全部</el-button>
|
||
|
||
</el-row>
|
||
<audio :autoplay="playing_auto" :src="playing_url" controls></audio>
|
||
|
||
|
||
<el-table :data="tableData" style="width: 100%">
|
||
|
||
<el-table-column label="图片">
|
||
<template slot-scope="scope">
|
||
<el-image :src="scope.row.picture" style="width: 100px; height: 100px"></el-image>
|
||
</template>
|
||
</el-table-column>
|
||
<el-table-column label="歌曲" sortable>
|
||
<template slot-scope="scope">
|
||
<span style="margin-left: 10px">{{ scope.row.title }}</span>
|
||
</template>
|
||
</el-table-column>
|
||
<el-table-column label="歌手" sortable>
|
||
<template slot-scope="scope">
|
||
<p>{{ scope.row.artist }}</p>
|
||
</template>
|
||
</el-table-column>
|
||
<el-table-column label="专辑" sortable>
|
||
<template slot-scope="scope">
|
||
<p>{{ scope.row.album }}</p>
|
||
</template>
|
||
</el-table-column>
|
||
<el-table-column label="操作">
|
||
<template slot-scope="scope">
|
||
<el-button @click="handlePlay(scope.$index, scope.row)"
|
||
circle icon="el-icon-video-play" type="success">
|
||
</el-button>
|
||
|
||
<el-button circle>
|
||
<el-link :download="scope.row.filename" :href="scope.row.file"
|
||
:underline="false" icon="el-icon-download">
|
||
|
||
</el-link>
|
||
</el-button>
|
||
|
||
<el-button @click="handleDelete(scope.$index, scope.row)"
|
||
circle icon="el-icon-delete" type="danger">
|
||
</el-button>
|
||
</template>
|
||
</el-table-column>
|
||
</el-table>
|
||
</el-main>
|
||
<el-footer id="app-footer">
|
||
<el-row>
|
||
音乐解锁:移除已购音乐的加密保护。
|
||
目前支持网易云音乐(ncm)和QQ音乐(qmc0, qmc3, qmcflac)。
|
||
</el-row>
|
||
<el-row>
|
||
<span>Copyright © 2019</span>
|
||
<a href="https://github.com/ix64" target="_blank">MengYX</a>
|
||
音乐解锁使用
|
||
<a href="https://github.com/ix64/unlock-music/blob/master/LICENSE" target="_blank">MIT许可协议</a>
|
||
开放
|
||
<a href="https://github.com/ix64/unlock-music" target="_blank">源代码</a>
|
||
</el-row>
|
||
</el-footer>
|
||
</el-container>
|
||
</div>
|
||
</template>
|
||
|
||
<script>
|
||
|
||
const NcmDecrypt = require("./plugins/ncm");
|
||
const QmcDecrypt = require("./plugins/qmc");
|
||
const RawDecrypt = require("./plugins/raw");
|
||
export default {
|
||
name: 'app',
|
||
components: {},
|
||
data() {
|
||
return {
|
||
activeIndex: '1',
|
||
tableData: [],
|
||
playing_url: "",
|
||
playing_auto: false,
|
||
}
|
||
},
|
||
mounted() {
|
||
this.$nextTick(function () {
|
||
this.finishLoad();
|
||
});
|
||
},
|
||
methods: {
|
||
finishLoad() {
|
||
|
||
this.$notify.info({
|
||
title: '离线使用',
|
||
message: "音乐解锁加载成功。我们使用PWA技术,可以添加到桌面或收藏夹,无网络状况下也能使用。",
|
||
duration: 30000,
|
||
position: 'top-left'
|
||
});
|
||
},
|
||
handleFile(file) {
|
||
let ext = file.name.substring(file.name.lastIndexOf(".") + 1, file.name.length).toLowerCase();
|
||
(async () => {
|
||
let data = null;
|
||
switch (ext) {
|
||
case "ncm":
|
||
data = await NcmDecrypt.Decrypt(file.raw);
|
||
break;
|
||
case "mp3":
|
||
case "flac":
|
||
data = await RawDecrypt.Decrypt(file.raw);
|
||
break;
|
||
case "qmc3":
|
||
case "qmc0":
|
||
case "qmcflac":
|
||
data = await QmcDecrypt.Decrypt(file.raw);
|
||
break;
|
||
default:
|
||
break;
|
||
}
|
||
if (null != data) {
|
||
this.tableData.push(data);
|
||
this.$notify.success({
|
||
title: '解锁成功',
|
||
message: '成功解锁 ' + data.title
|
||
});
|
||
let _rp_data = {
|
||
original: data.original,
|
||
title: data.title,
|
||
album: data.album,
|
||
artist: data.artist,
|
||
mime: data.mime
|
||
};
|
||
console.log(data);
|
||
_paq.push(["trackEvent", "Unlock", "Success", JSON.stringify(_rp_data)]);
|
||
} else {
|
||
this.$notify.error({
|
||
title: '错误',
|
||
message: '解析此文件时出现问题'
|
||
});
|
||
_paq.push(["trackEvent", "Unlock", "Error", file.name]);
|
||
}
|
||
|
||
|
||
})();
|
||
|
||
|
||
},
|
||
handlePlay(index, row) {
|
||
this.playing_url = row.file;
|
||
this.playing_auto = true;
|
||
},
|
||
handleDelete(index, row) {
|
||
console.log(index);
|
||
URL.revokeObjectURL(row.file);
|
||
URL.revokeObjectURL(row.picture);
|
||
this.tableData.splice(index, 1);
|
||
},
|
||
handleDeleteAll() {
|
||
this.tableData.forEach(value => {
|
||
URL.revokeObjectURL(value.file);
|
||
URL.revokeObjectURL(value.picture);
|
||
});
|
||
this.tableData = [];
|
||
},
|
||
handleDownloadAll() {
|
||
let index = 0;
|
||
let c = setInterval(() => {
|
||
if (index < this.tableData.length) {
|
||
let a = document.createElement('a');
|
||
a.href = this.tableData[index].file;
|
||
a.download = this.tableData[index].filename;
|
||
document.body.append(a);
|
||
a.click();
|
||
a.remove();
|
||
index++;
|
||
} else {
|
||
clearInterval(c);
|
||
}
|
||
|
||
}, 1000);
|
||
|
||
}
|
||
}
|
||
}
|
||
|
||
</script>
|
||
|
||
<style>
|
||
#app {
|
||
font-family: "Helvetica Neue", Helvetica, "PingFang SC",
|
||
"Hiragino Sans GB", "Microsoft YaHei", "微软雅黑", Arial, sans-serif;
|
||
-webkit-font-smoothing: antialiased;
|
||
-moz-osx-font-smoothing: grayscale;
|
||
text-align: center;
|
||
color: #2c3e50;
|
||
padding-top: 30px;
|
||
}
|
||
|
||
#app-footer a {
|
||
padding-left: 0.5em;
|
||
padding-right: 0.5em;
|
||
}
|
||
|
||
#app-footer {
|
||
text-align: center;
|
||
font-size: small;
|
||
}
|
||
|
||
.el-upload-dragger {
|
||
width: 80vw !important;
|
||
}
|
||
|
||
#app-control {
|
||
padding-top: 1em;
|
||
padding-bottom: 1em;
|
||
}
|
||
|
||
|
||
</style>
|