link scenarios to backend

This commit is contained in:
2025-03-15 11:23:55 +02:00
parent 6aad752ce3
commit 2a44578430
13 changed files with 233 additions and 75 deletions
+19 -6
View File
@@ -1,4 +1,6 @@
const collection = 'scenarios';
/**
* Scenarios manager class, контролен клас за управление на игрови сценарии
*/
@@ -18,7 +20,9 @@ class ScenariosManager{
* @param {Scenario} data the scenario, данни за сценария
*/
this.create = async function(ctx, data){
data.id = (await db.getLastId(collection)) + 1;
await db.create(collection, data);
return data;
}
/**
@@ -27,7 +31,8 @@ class ScenariosManager{
* @returns {Scenario}
*/
this.read = async function(id){
id = parseInt(id);
return await db.get(collection, {id});
}
/**
@@ -36,7 +41,11 @@ class ScenariosManager{
* @param {Scenario} data the scenario
*/
this.update = async function(ctx, data){
data.id = parseInt(data.id);
let object = await this.read(data.id);
data = Object.assign(object, data);
await db.update(collection, {id: data.id}, data);
return data;
}
/**
@@ -44,7 +53,8 @@ class ScenariosManager{
* @param {Number} id scenario ID, идентификатор на сценарий
*/
this.remove = async function(id){
id = parseInt(id);
await db.remove(collection, {id});
}
/**
@@ -52,8 +62,11 @@ class ScenariosManager{
* @param {Query} query criteria, критерии - заявка към базата от данни
* @returns {Scenario[]}
*/
this.list = async function(query){
this.list = async function(query = {}){
return await db.list(collection, {
query,
project: { name:1, id:1, sceneThumb: '$scenes.data.environment'}
});
}
}