mirror of
https://github.com/MrUnknownDE/VRCX.git
synced 2026-04-18 22:33:50 +02:00
Delete, Rename and Change description of worlds
This commit is contained in:
188
html/src/app.js
188
html/src/app.js
@@ -1410,6 +1410,31 @@ speechSynthesis.getVoices();
|
||||
}
|
||||
});
|
||||
|
||||
API.$on('WORLD:DELETE', function (args) {
|
||||
var { json } = args;
|
||||
this.cachedWorlds.delete(json.id);
|
||||
if ($app.worldDialog.ref.authorId === json.authorId) {
|
||||
var map = new Map();
|
||||
for (var ref of this.cachedWorlds.values()) {
|
||||
if (ref.authorId === json.authorId) {
|
||||
map.set(ref.id, ref);
|
||||
}
|
||||
}
|
||||
var array = Array.from(map.values());
|
||||
$app.setUserDialogWorlds(array);
|
||||
}
|
||||
});
|
||||
|
||||
API.$on('WORLD:SAVE', function (args) {
|
||||
var { json } = args;
|
||||
this.$emit('WORLD', {
|
||||
json,
|
||||
params: {
|
||||
worldId: json.id
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
API.applyWorld = function (json) {
|
||||
var ref = this.cachedWorlds.get(json.id);
|
||||
if (typeof ref === 'undefined') {
|
||||
@@ -1528,6 +1553,43 @@ speechSynthesis.getVoices();
|
||||
});
|
||||
};
|
||||
|
||||
/*
|
||||
params: {
|
||||
worldId: string
|
||||
}
|
||||
*/
|
||||
API.deleteWorld = function (params) {
|
||||
return this.call(`worlds/${params.worldId}`, {
|
||||
method: 'DELETE'
|
||||
}).then((json) => {
|
||||
var args = {
|
||||
json,
|
||||
params
|
||||
};
|
||||
this.$emit('WORLD:DELETE', args);
|
||||
return args;
|
||||
});
|
||||
};
|
||||
|
||||
/*
|
||||
params: {
|
||||
worldId: string
|
||||
}
|
||||
*/
|
||||
API.saveWorld = function (params) {
|
||||
return this.call(`worlds/${params.id}`, {
|
||||
method: 'PUT',
|
||||
params
|
||||
}).then((json) => {
|
||||
var args = {
|
||||
json,
|
||||
params
|
||||
};
|
||||
this.$emit('WORLD:SAVE', args);
|
||||
return args;
|
||||
});
|
||||
};
|
||||
|
||||
// API: Friend
|
||||
|
||||
API.friends200 = new Set();
|
||||
@@ -1919,8 +1981,7 @@ speechSynthesis.getVoices();
|
||||
*/
|
||||
API.deleteAvatar = function (params) {
|
||||
return this.call(`avatars/${params.avatarId}`, {
|
||||
method: 'DELETE',
|
||||
params
|
||||
method: 'DELETE'
|
||||
}).then((json) => {
|
||||
var args = {
|
||||
json,
|
||||
@@ -7369,7 +7430,7 @@ speechSynthesis.getVoices();
|
||||
});
|
||||
};
|
||||
|
||||
$app.methods.promptChangeDescription = function (avatar) {
|
||||
$app.methods.promptChangeAvatarDescription = function (avatar) {
|
||||
this.$prompt('Enter avatar description', 'Change Description', {
|
||||
distinguishCancelAndClose: true,
|
||||
confirmButtonText: 'OK',
|
||||
@@ -7394,6 +7455,56 @@ speechSynthesis.getVoices();
|
||||
});
|
||||
};
|
||||
|
||||
$app.methods.promptRenameWorld = function (world) {
|
||||
this.$prompt('Enter world name', 'Rename World', {
|
||||
distinguishCancelAndClose: true,
|
||||
confirmButtonText: 'OK',
|
||||
cancelButtonText: 'Cancel',
|
||||
inputValue: world.ref.name,
|
||||
inputErrorMessage: 'Valid name is required',
|
||||
callback: (action, instance) => {
|
||||
if (action === 'confirm' &&
|
||||
instance.inputValue !== world.ref.name) {
|
||||
API.saveWorld({
|
||||
id: world.id,
|
||||
name: instance.inputValue
|
||||
}).then((args) => {
|
||||
this.$message({
|
||||
message: 'World renamed',
|
||||
type: 'success'
|
||||
});
|
||||
return args;
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
};
|
||||
|
||||
$app.methods.promptChangeWorldDescription = function (world) {
|
||||
this.$prompt('Enter world description', 'Change Description', {
|
||||
distinguishCancelAndClose: true,
|
||||
confirmButtonText: 'OK',
|
||||
cancelButtonText: 'Cancel',
|
||||
inputValue: world.ref.description,
|
||||
inputErrorMessage: 'Valid description is required',
|
||||
callback: (action, instance) => {
|
||||
if (action === 'confirm' &&
|
||||
instance.inputValue !== world.ref.description) {
|
||||
API.saveWorld({
|
||||
id: world.id,
|
||||
description: instance.inputValue
|
||||
}).then((args) => {
|
||||
this.$message({
|
||||
message: 'World description changed',
|
||||
type: 'success'
|
||||
});
|
||||
return args;
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
||||
};
|
||||
|
||||
// App: Dialog
|
||||
|
||||
var adjustDialogZ = (el) => {
|
||||
@@ -7834,7 +7945,7 @@ speechSynthesis.getVoices();
|
||||
var map = new Map();
|
||||
for (var ref of API.cachedWorlds.values()) {
|
||||
if (ref.authorId === D.id) {
|
||||
map.set(ref.id, ref);
|
||||
API.cachedWorlds.delete(ref.id);
|
||||
}
|
||||
}
|
||||
API.bulk({
|
||||
@@ -8325,10 +8436,11 @@ speechSynthesis.getVoices();
|
||||
if (D.visible === false) {
|
||||
return;
|
||||
}
|
||||
if (command === 'Refresh') {
|
||||
D.loading = true;
|
||||
API.getWorld({
|
||||
worldId: D.id
|
||||
switch (command) {
|
||||
case 'Refresh':
|
||||
D.loading = true;
|
||||
API.getWorld({
|
||||
worldId: D.id
|
||||
}).catch((err) => {
|
||||
D.loading = false;
|
||||
D.visible = false;
|
||||
@@ -8343,17 +8455,26 @@ speechSynthesis.getVoices();
|
||||
if (args.cache) {
|
||||
API.getWorld(args.params);
|
||||
}
|
||||
}
|
||||
return args;
|
||||
});
|
||||
} else if (command === 'New Instance') {
|
||||
this.showNewInstanceDialog(D.$location.tag);
|
||||
} else if (command === 'Add Favorite') {
|
||||
this.showFavoriteDialog('world', D.id);
|
||||
} else {
|
||||
this.$confirm(`Continue? ${command}`, 'Confirm', {
|
||||
confirmButtonText: 'Confirm',
|
||||
cancelButtonText: 'Cancel',
|
||||
}
|
||||
return args;
|
||||
});
|
||||
break;
|
||||
case 'New Instance':
|
||||
this.showNewInstanceDialog(D.$location.tag);
|
||||
break;
|
||||
case 'Add Favorite':
|
||||
this.showFavoriteDialog('world', D.id);
|
||||
break;
|
||||
case 'Rename':
|
||||
this.promptRenameWorld(D);
|
||||
break;
|
||||
case 'Change Description':
|
||||
this.promptChangeWorldDescription(D);
|
||||
break;
|
||||
default:
|
||||
this.$confirm(`Continue? ${command}`, 'Confirm', {
|
||||
confirmButtonText: 'Confirm',
|
||||
cancelButtonText: 'Cancel',
|
||||
type: 'info',
|
||||
callback: (action) => {
|
||||
if (action !== 'confirm') {
|
||||
@@ -8384,14 +8505,27 @@ speechSynthesis.getVoices();
|
||||
message: 'Home world has been reset',
|
||||
type: 'success'
|
||||
});
|
||||
return args;
|
||||
});
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
return args;
|
||||
});
|
||||
break;
|
||||
case 'Delete':
|
||||
API.deleteWorld({
|
||||
worldId: D.id
|
||||
}).then((args) => {
|
||||
this.$message({
|
||||
message: 'World has been deleted',
|
||||
type: 'success'
|
||||
});
|
||||
D.visible = false;
|
||||
return args;
|
||||
});
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
});
|
||||
break;
|
||||
}
|
||||
};
|
||||
|
||||
@@ -8519,7 +8653,7 @@ speechSynthesis.getVoices();
|
||||
this.displayAvatarImages();
|
||||
break;
|
||||
case 'Change Description':
|
||||
this.promptChangeDescription(D);
|
||||
this.promptChangeAvatarDescription(D);
|
||||
break;
|
||||
case 'Add Favorite':
|
||||
this.showFavoriteDialog('avatar', D.id);
|
||||
|
||||
@@ -1139,6 +1139,9 @@ html
|
||||
el-dropdown-item(icon="el-icon-s-flag" command="New Instance" divided) New Instance
|
||||
el-dropdown-item(v-if="API.currentUser.$homeLocation && API.currentUser.$homeLocation.worldId === worldDialog.id" icon="el-icon-magic-stick" command="Reset Home" divided) Reset Home
|
||||
el-dropdown-item(v-else icon="el-icon-s-home" command="Make Home" divided) Make Home
|
||||
el-dropdown-item(icon="el-icon-edit" command="Rename") Rename
|
||||
el-dropdown-item(icon="el-icon-edit" command="Change Description") Change Description
|
||||
el-dropdown-item(v-if="API.currentUser.id === worldDialog.ref.authorId" icon="el-icon-delete" command="Delete" style="color:#F56C6C" divided) Delete
|
||||
el-tabs
|
||||
el-tab-pane(label="Instances")
|
||||
div.
|
||||
|
||||
Reference in New Issue
Block a user