Persist Items independly from Itemgroups
All checks were successful
E2E Testing / test (push) Successful in 1m40s
All checks were successful
E2E Testing / test (push) Successful in 1m40s
This commit is contained in:
parent
1b2fd273bf
commit
ddcbfc5bb3
@ -274,6 +274,7 @@ function recieveGameModelToStore(gameModel: StoredGameModel) {
|
|||||||
|
|
||||||
const itemgroupStorage = new ItemgroupStorage(path.join(projectDirectory, ModelComponentFileDirectory.ITEMGROUP_DIR_NAME))
|
const itemgroupStorage = new ItemgroupStorage(path.join(projectDirectory, ModelComponentFileDirectory.ITEMGROUP_DIR_NAME))
|
||||||
itemgroupStorage.storeItemgroups(gameModel.storedItemgroups);
|
itemgroupStorage.storeItemgroups(gameModel.storedItemgroups);
|
||||||
|
itemgroupStorage.storeItems(gameModel.storedItems)
|
||||||
}
|
}
|
||||||
|
|
||||||
/*function deleteComponent(component: DeleteModel) {
|
/*function deleteComponent(component: DeleteModel) {
|
||||||
|
@ -2,12 +2,13 @@
|
|||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
exports.StoredGameModel = void 0;
|
exports.StoredGameModel = void 0;
|
||||||
class StoredGameModel {
|
class StoredGameModel {
|
||||||
constructor(gameModelName, storedScriptAccounts, storedGamesystems, storedCharacters, storedItemgroups) {
|
constructor(gameModelName, storedScriptAccounts, storedGamesystems, storedCharacters, storedItemgroups, storedItems) {
|
||||||
this.gameModelName = gameModelName;
|
this.gameModelName = gameModelName;
|
||||||
this.storedGamesystems = storedGamesystems;
|
this.storedGamesystems = storedGamesystems;
|
||||||
this.storedScriptAccounts = storedScriptAccounts;
|
this.storedScriptAccounts = storedScriptAccounts;
|
||||||
this.storedCharacters = storedCharacters;
|
this.storedCharacters = storedCharacters;
|
||||||
this.storedItemgroups = storedItemgroups;
|
this.storedItemgroups = storedItemgroups;
|
||||||
|
this.storedItems = storedItems;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
exports.StoredGameModel = StoredGameModel;
|
exports.StoredGameModel = StoredGameModel;
|
||||||
|
@ -7,14 +7,16 @@ export class StoredGameModel {
|
|||||||
storedScriptAccounts: StoreComponent[]
|
storedScriptAccounts: StoreComponent[]
|
||||||
storedCharacters: StoreComponent[]
|
storedCharacters: StoreComponent[]
|
||||||
storedItemgroups: StoreComponent[]
|
storedItemgroups: StoreComponent[]
|
||||||
|
storedItems: StoreComponent[]
|
||||||
|
|
||||||
|
|
||||||
constructor(gameModelName: string, storedScriptAccounts: StoreComponent[], storedGamesystems: StoreComponent[],
|
constructor(gameModelName: string, storedScriptAccounts: StoreComponent[], storedGamesystems: StoreComponent[],
|
||||||
storedCharacters: StoreComponent[], storedItemgroups: StoreComponent[]) {
|
storedCharacters: StoreComponent[], storedItemgroups: StoreComponent[], storedItems: StoreComponent[]) {
|
||||||
this.gameModelName = gameModelName;
|
this.gameModelName = gameModelName;
|
||||||
this.storedGamesystems = storedGamesystems;
|
this.storedGamesystems = storedGamesystems;
|
||||||
this.storedScriptAccounts = storedScriptAccounts;
|
this.storedScriptAccounts = storedScriptAccounts;
|
||||||
this.storedCharacters = storedCharacters;
|
this.storedCharacters = storedCharacters;
|
||||||
this.storedItemgroups = storedItemgroups;
|
this.storedItemgroups = storedItemgroups;
|
||||||
|
this.storedItems = storedItems;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -16,7 +16,7 @@ class GameModelLoader {
|
|||||||
const storedScriptAccounts = this.loadScriptAccountComponents();
|
const storedScriptAccounts = this.loadScriptAccountComponents();
|
||||||
const storedGamesystems = this.loadGamesystems();
|
const storedGamesystems = this.loadGamesystems();
|
||||||
const storedCharacters = this.loadCharacters();
|
const storedCharacters = this.loadCharacters();
|
||||||
return new StoredGameModel_1.StoredGameModel(gameModelName, storedScriptAccounts, storedGamesystems, storedCharacters, []);
|
return new StoredGameModel_1.StoredGameModel(gameModelName, storedScriptAccounts, storedGamesystems, storedCharacters, [], []);
|
||||||
}
|
}
|
||||||
loadScriptAccountComponents() {
|
loadScriptAccountComponents() {
|
||||||
const scriptAccountDir = path.join(this.gameModelDir, ModelComponentFileDirectory_1.ModelComponentFileDirectory.SCRIPTACCOUNT_DIR_NAME);
|
const scriptAccountDir = path.join(this.gameModelDir, ModelComponentFileDirectory_1.ModelComponentFileDirectory.SCRIPTACCOUNT_DIR_NAME);
|
||||||
|
@ -22,7 +22,7 @@ export class GameModelLoader {
|
|||||||
const storedGamesystems = this.loadGamesystems();
|
const storedGamesystems = this.loadGamesystems();
|
||||||
const storedCharacters = this.loadCharacters()
|
const storedCharacters = this.loadCharacters()
|
||||||
|
|
||||||
return new StoredGameModel(gameModelName, storedScriptAccounts, storedGamesystems, storedCharacters, []);
|
return new StoredGameModel(gameModelName, storedScriptAccounts, storedGamesystems, storedCharacters, [], []);
|
||||||
}
|
}
|
||||||
|
|
||||||
private loadScriptAccountComponents() {
|
private loadScriptAccountComponents() {
|
||||||
|
@ -10,7 +10,6 @@ class ItemgroupStorage {
|
|||||||
FileUtils_1.FileUtils.prepareDirectoryFroWriting(this.itemgroupDir);
|
FileUtils_1.FileUtils.prepareDirectoryFroWriting(this.itemgroupDir);
|
||||||
}
|
}
|
||||||
storeItemgroups(itemgroups) {
|
storeItemgroups(itemgroups) {
|
||||||
console.log("Store Itemgroups");
|
|
||||||
itemgroups.forEach(itemgroup => {
|
itemgroups.forEach(itemgroup => {
|
||||||
this.storeItemgroup(itemgroup);
|
this.storeItemgroup(itemgroup);
|
||||||
});
|
});
|
||||||
@ -24,6 +23,9 @@ class ItemgroupStorage {
|
|||||||
FileUtils_1.FileUtils.prepareDirectoryFroWriting(completeItemgroupDirectory);
|
FileUtils_1.FileUtils.prepareDirectoryFroWriting(completeItemgroupDirectory);
|
||||||
fs.writeFileSync(completeFileName + ".json", itemgroup.jsonString, "utf-8");
|
fs.writeFileSync(completeFileName + ".json", itemgroup.jsonString, "utf-8");
|
||||||
}
|
}
|
||||||
|
storeItems(storedItems) {
|
||||||
|
storedItems.forEach(item => this.storeItemgroup(item));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
exports.ItemgroupStorage = ItemgroupStorage;
|
exports.ItemgroupStorage = ItemgroupStorage;
|
||||||
//# sourceMappingURL=ItemgroupStorage.js.map
|
//# sourceMappingURL=ItemgroupStorage.js.map
|
@ -13,7 +13,6 @@ export class ItemgroupStorage {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public storeItemgroups(itemgroups: StoreComponent[]) {
|
public storeItemgroups(itemgroups: StoreComponent[]) {
|
||||||
console.log("Store Itemgroups")
|
|
||||||
itemgroups.forEach(itemgroup => {
|
itemgroups.forEach(itemgroup => {
|
||||||
this.storeItemgroup(itemgroup)
|
this.storeItemgroup(itemgroup)
|
||||||
})
|
})
|
||||||
@ -31,4 +30,7 @@ export class ItemgroupStorage {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
storeItems(storedItems: StoreComponent[]) {
|
||||||
|
storedItems.forEach(item => this.storeItemgroup(item))
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -235,7 +235,9 @@ export class AppComponent implements OnInit{
|
|||||||
|
|
||||||
const itemSerializer = new ItemSerializer();
|
const itemSerializer = new ItemSerializer();
|
||||||
const storedItemgroups: StoreComponent[] = itemSerializer.serializeItemgroups(this.gameModel!.itemgroups);
|
const storedItemgroups: StoreComponent[] = itemSerializer.serializeItemgroups(this.gameModel!.itemgroups);
|
||||||
const storeModel = new StoredGameModel(this.gameModel.gameModelName, storedScriptAccounts, storedGamesystems, storedCharacters, storedItemgroups)
|
const storedItems: StoreComponent[] = itemSerializer.getSerializedItems()
|
||||||
|
|
||||||
|
const storeModel = new StoredGameModel(this.gameModel.gameModelName, storedScriptAccounts, storedGamesystems, storedCharacters, storedItemgroups, storedItems)
|
||||||
|
|
||||||
if(this.electronService.isElectron) {
|
if(this.electronService.isElectron) {
|
||||||
this.electronService.ipcRenderer.send('save-model', storeModel)
|
this.electronService.ipcRenderer.send('save-model', storeModel)
|
||||||
|
@ -9,6 +9,7 @@ import {Item} from "../game-model/inventory/Item";
|
|||||||
export class ItemSerializer {
|
export class ItemSerializer {
|
||||||
|
|
||||||
private serializedItemgroups: StoreComponent[] = []
|
private serializedItemgroups: StoreComponent[] = []
|
||||||
|
private serializedItems: StoreComponent[] = []
|
||||||
private static ignoredGroupKeys: string[] = ['type', 'unsaved', 'children', "itemgroup", "manuallyInheritedGroups", "hierarchyInheritedGroups", "items"]
|
private static ignoredGroupKeys: string[] = ['type', 'unsaved', 'children', "itemgroup", "manuallyInheritedGroups", "hierarchyInheritedGroups", "items"]
|
||||||
private static ignoredItemKeys: string[] = ['type', 'unsaved', 'hierarchyInheritedGroups']
|
private static ignoredItemKeys: string[] = ['type', 'unsaved', 'hierarchyInheritedGroups']
|
||||||
|
|
||||||
@ -73,7 +74,7 @@ export class ItemSerializer {
|
|||||||
const fileName = ItemSerializer.computeItemgroupPath(itemgroup, true);
|
const fileName = ItemSerializer.computeItemgroupPath(itemgroup, true);
|
||||||
itemgroup.items.forEach(item => {
|
itemgroup.items.forEach(item => {
|
||||||
const storeComponent = this.serializeSingleItem(fileName, item);
|
const storeComponent = this.serializeSingleItem(fileName, item);
|
||||||
this.serializedItemgroups.push(storeComponent)
|
this.serializedItems.push(storeComponent)
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
@ -100,4 +101,8 @@ export class ItemSerializer {
|
|||||||
|
|
||||||
return new StoreComponent(jsonString, itemFile, ModelComponentType.ITEM)
|
return new StoreComponent(jsonString, itemFile, ModelComponentType.ITEM)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
getSerializedItems() {
|
||||||
|
return this.serializedItems;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user