修复因插入数字类型的ID导致其意外在末尾追加 .0 导致列表数据异常的问题
parent
0454d300ec
commit
8018d9b418
|
@ -5,6 +5,7 @@
|
|||
### 修复
|
||||
|
||||
- 修复列表名翻译显示
|
||||
- 修复因插入数字类型的ID导致其意外在末尾追加 .0 导致列表数据异常的问题,同时也可能导致同步数据丢失的问题(要完全修复这个问题还需要同时将移动端、同步服务更新到最新版本)
|
||||
|
||||
### 其他
|
||||
|
||||
|
|
|
@ -14,6 +14,18 @@ import { EventEmitter } from 'events'
|
|||
// musicOverwrite,
|
||||
// } from '@main/workers/dbService/modules/list'
|
||||
|
||||
// 兼容v2.3.0之前版本插入数字类型的ID导致其意外在末尾追加 .0 的问题,确保所有ID都是字符串类型
|
||||
const fixListIdType = (lists: LX.List.UserListInfo[] | LX.List.UserListInfoFull[]) => {
|
||||
for (const list of lists) {
|
||||
if (typeof list.sourceListId == 'number') {
|
||||
list.sourceListId = String(list.sourceListId)
|
||||
if (typeof list.id == 'number') {
|
||||
list.id = String(list.id)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
export class Event extends EventEmitter {
|
||||
list_changed() {
|
||||
this.emit('list_changed')
|
||||
|
@ -25,6 +37,7 @@ export class Event extends EventEmitter {
|
|||
* @param isRemote 是否属于远程操作
|
||||
*/
|
||||
async list_data_overwrite(listData: MakeOptional<LX.List.ListDataFull, 'tempList'>, isRemote: boolean = false) {
|
||||
fixListIdType(listData.userList)
|
||||
await global.lx.worker.dbService.listDataOverwrite(listData)
|
||||
this.emit('list_data_overwrite', listData, isRemote)
|
||||
this.list_changed()
|
||||
|
@ -37,6 +50,7 @@ export class Event extends EventEmitter {
|
|||
* @param isRemote 是否属于远程操作
|
||||
*/
|
||||
async list_create(position: number, lists: LX.List.UserListInfo[], isRemote: boolean = false) {
|
||||
fixListIdType(lists)
|
||||
await global.lx.worker.dbService.createUserLists(position, lists)
|
||||
this.emit('list_create', position, lists, isRemote)
|
||||
this.list_changed()
|
||||
|
|
|
@ -19,13 +19,20 @@ import {
|
|||
createMusicInfoByMusicInfoIdQueryStatement,
|
||||
} from './statements'
|
||||
|
||||
|
||||
const idFixRxp = /\.0$/
|
||||
/**
|
||||
* 获取用户列表
|
||||
* @returns
|
||||
*/
|
||||
export const queryAllUserList = () => {
|
||||
return createListQueryStatement().all() as LX.DBService.UserListInfo[]
|
||||
const list = createListQueryStatement().all() as LX.DBService.UserListInfo[]
|
||||
for (const info of list) {
|
||||
// 兼容v2.3.0之前版本插入数字类型的ID导致其意外在末尾追加 .0 的问题
|
||||
if (info.sourceListId?.endsWith('.0')) {
|
||||
info.sourceListId = info.sourceListId.replace(idFixRxp, '')
|
||||
}
|
||||
}
|
||||
return list
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
@ -174,7 +174,7 @@ export default {
|
|||
filterList(rawData) {
|
||||
return rawData.map(item => ({
|
||||
play_count: this.formatPlayCount(item.listen_num),
|
||||
id: item.list_id,
|
||||
id: String(item.list_id),
|
||||
author: item.username,
|
||||
name: item.title,
|
||||
// time: item.publish_time,
|
||||
|
|
|
@ -467,7 +467,7 @@ export default {
|
|||
list: body.abslist.map(item => {
|
||||
return {
|
||||
play_count: this.formatPlayCount(item.playcnt),
|
||||
id: item.playlistid,
|
||||
id: String(item.playlistid),
|
||||
author: decodeName(item.nickname),
|
||||
name: decodeName(item.name),
|
||||
total: item.songnum,
|
||||
|
|
|
@ -210,7 +210,7 @@ export default {
|
|||
// console.log(rawData)
|
||||
return rawData.map(item => ({
|
||||
play_count: formatPlayCount(item.playCount),
|
||||
id: item.playListId,
|
||||
id: String(item.playListId),
|
||||
author: item.createName,
|
||||
name: item.playListName,
|
||||
time: dateFormat(item.createTime, 'Y-M-D'),
|
||||
|
|
|
@ -130,7 +130,7 @@ export default {
|
|||
return {
|
||||
list: data.v_playlist.map(item => ({
|
||||
play_count: formatPlayCount(item.access_num),
|
||||
id: item.tid,
|
||||
id: String(item.tid),
|
||||
author: item.creator_info.nick,
|
||||
name: item.title,
|
||||
time: item.modify_time ? dateFormat(item.modify_time * 1000, 'Y-M-D') : '',
|
||||
|
@ -151,7 +151,7 @@ export default {
|
|||
return {
|
||||
list: content.v_item.map(({ basic }) => ({
|
||||
play_count: formatPlayCount(basic.play_cnt),
|
||||
id: basic.tid,
|
||||
id: String(basic.tid),
|
||||
author: basic.creator.nick,
|
||||
name: basic.title,
|
||||
// time: basic.publish_time,
|
||||
|
@ -304,7 +304,7 @@ export default {
|
|||
list: body.data.list.map(item => {
|
||||
return {
|
||||
play_count: formatPlayCount(item.listennum),
|
||||
id: item.dissid,
|
||||
id: String(item.dissid),
|
||||
author: item.creator.name,
|
||||
name: item.dissname,
|
||||
time: dateFormat(item.createtime, 'Y-M-D'),
|
||||
|
|
|
@ -232,7 +232,7 @@ export default {
|
|||
// console.log(rawData)
|
||||
return rawData.map(item => ({
|
||||
play_count: formatPlayCount(item.playCount),
|
||||
id: item.id,
|
||||
id: String(item.id),
|
||||
author: item.creator.nickname,
|
||||
name: item.name,
|
||||
time: item.createTime ? dateFormat(item.createTime, 'Y-M-D') : '',
|
||||
|
|
Loading…
Reference in New Issue