-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* Optimize random display
- Loading branch information
Showing
17 changed files
with
284 additions
and
194 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,36 +1,7 @@ | ||
import ini from "ini"; | ||
import { remote } from "electron"; | ||
import useEnvironment from "../configuration/useEnvironment.hook"; | ||
|
||
const cache = new WeakMap(); | ||
import getCharacterDefinition from "./util/getCharacterDefinition"; | ||
|
||
export default function useCharacterDefinition(character) { | ||
const fs = remote.require("fs"); | ||
const path = remote.require("path"); | ||
const environment = useEnvironment(); | ||
|
||
if (cache.has(character)) { | ||
return cache.get(character); | ||
} | ||
|
||
if (!character) { | ||
return null; | ||
} | ||
|
||
if (character.random) { | ||
return null; | ||
} | ||
|
||
if (!character.definition) { | ||
return null; | ||
} | ||
|
||
const definitionPath = path.resolve(environment.currentDirectory, "chars", character.definition); | ||
if (!fs.existsSync(definitionPath)) { | ||
return null; | ||
} | ||
|
||
const definition = ini.parse(fs.readFileSync(definitionPath, "utf-8")); | ||
cache.set(character, definition); | ||
return definition; | ||
return getCharacterDefinition(character, environment.currentDirectory); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,38 +1,7 @@ | ||
import ini from "ini"; | ||
import useCharacterDefinition from "./useCharacterDefinition.hook"; | ||
import getObjectPropertyValueCaseInsensitive from "./util/getObjectPropertyValueCaseInsensitive"; | ||
|
||
const infoKeys = ["Info", "info"]; | ||
const nameKeys = ["displayname", "Displayname", "DisplayName", "name", "Name"]; | ||
import useEnvironment from "../configuration/useEnvironment.hook"; | ||
import getCharacterName from "./util/getCharacterName"; | ||
|
||
export default function useCharacterName(character) { | ||
const definition = useCharacterDefinition(character); | ||
|
||
if (!character) { | ||
return "Unknown"; | ||
} | ||
|
||
if (character.random) { | ||
return "Random"; | ||
} | ||
|
||
if (!definition) { | ||
return "Unknown"; | ||
} | ||
|
||
const info = getObjectPropertyValueCaseInsensitive(definition, "info"); | ||
if (!info) { | ||
return "Unknown"; | ||
} | ||
|
||
const displayName = getObjectPropertyValueCaseInsensitive(info, "displayname"); | ||
if (displayName) { | ||
return ini.unsafe(displayName); | ||
} | ||
const name = getObjectPropertyValueCaseInsensitive(info, "name"); | ||
if (name) { | ||
return ini.unsafe(name); | ||
} | ||
|
||
return "Unknown"; | ||
const environment = useEnvironment(); | ||
return getCharacterName(character, environment.currentDirectory); | ||
} |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
import getSelectableCharactersFromCategories from "./util/getSelectableCharactersFromCategories"; | ||
import useCategories from "../configuration/useCategories.hook"; | ||
import getCharacterName from "./util/getCharacterName"; | ||
import useEnvironment from "../configuration/useEnvironment.hook"; | ||
|
||
export default function useSelectableCharacterNames() { | ||
const environment = useEnvironment(); | ||
const categories = useCategories(); | ||
|
||
const names = []; | ||
const selectableCharacters = getSelectableCharactersFromCategories(categories); | ||
for (const character of selectableCharacters) { | ||
const name = getCharacterName(character, environment.currentDirectory); | ||
names.push(name); | ||
} | ||
|
||
return names; | ||
} |
23 changes: 23 additions & 0 deletions
23
src/character/useSelectableCharacterNamesFromCategory.hook.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
import getSelectableCharactersFromCategory from "./util/getSelectableCharactersFromCategory"; | ||
import getCharacterName from "./util/getCharacterName"; | ||
import useEnvironment from "../configuration/useEnvironment.hook"; | ||
|
||
const cache = new WeakMap(); | ||
|
||
export default function useSelectableCharacterNamesFromCategory(category) { | ||
const environment = useEnvironment(); | ||
|
||
if (cache.has(category)) { | ||
return cache.get(category); | ||
} | ||
|
||
const names = []; | ||
const selectableCharacters = getSelectableCharactersFromCategory(category); | ||
for (const character of selectableCharacters) { | ||
const name = getCharacterName(character, environment.currentDirectory); | ||
names.push(name); | ||
} | ||
|
||
cache.set(category, names); | ||
return names; | ||
} |
28 changes: 28 additions & 0 deletions
28
src/character/util/__tests__/getSelectableCharactersFromCategory.test.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
import getSelectableCharactersFromCategory from "../getSelectableCharactersFromCategory"; | ||
|
||
describe("getSelectableCharactersFromCategory()", () => { | ||
const characterA = { definition: "A" }; | ||
const characterB = { definition: "B" }; | ||
const characterC = { definition: "C" }; | ||
const characterD = { definition: "D" }; | ||
const characterE = { | ||
definition: "E", | ||
styles: [characterD] | ||
}; | ||
|
||
it("should return all characters", () => { | ||
const category = { | ||
characters: [characterA, characterB, characterC] | ||
}; | ||
const characters = getSelectableCharactersFromCategory(category); | ||
expect(characters).toEqual([characterA, characterB, characterC]); | ||
}); | ||
|
||
it("should return all characters including sub characters", () => { | ||
const category = { | ||
characters: [characterA, characterB, characterE] | ||
}; | ||
const characters = getSelectableCharactersFromCategory(category); | ||
expect(characters).toEqual([characterA, characterB, characterE, characterD]); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
import ini from "ini"; | ||
import { remote } from "electron"; | ||
|
||
const cache = new WeakMap(); | ||
|
||
export default function useCharacterDefinition(character, currentDirectory) { | ||
const fs = remote.require("fs"); | ||
const path = remote.require("path"); | ||
|
||
if (cache.has(character)) { | ||
return cache.get(character); | ||
} | ||
|
||
if (!character) { | ||
return null; | ||
} | ||
|
||
if (character.random) { | ||
return null; | ||
} | ||
|
||
if (!character.definition) { | ||
return null; | ||
} | ||
|
||
const definitionPath = path.resolve(currentDirectory, "chars", character.definition); | ||
if (!fs.existsSync(definitionPath)) { | ||
return null; | ||
} | ||
|
||
const definition = ini.parse(fs.readFileSync(definitionPath, "utf-8")); | ||
cache.set(character, definition); | ||
return definition; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,34 @@ | ||
import ini from "ini"; | ||
import getCharacterDefinition from "./getCharacterDefinition"; | ||
import getObjectPropertyValueCaseInsensitive from "./getObjectPropertyValueCaseInsensitive"; | ||
|
||
export default function getCharacterName(character, currentDirectory) { | ||
if (!character) { | ||
return "Unknown"; | ||
} | ||
|
||
if (character.random) { | ||
return "Random"; | ||
} | ||
|
||
const definition = getCharacterDefinition(character, currentDirectory); | ||
if (!definition) { | ||
return "Unknown"; | ||
} | ||
|
||
const info = getObjectPropertyValueCaseInsensitive(definition, "info"); | ||
if (!info) { | ||
return "Unknown"; | ||
} | ||
|
||
const displayName = getObjectPropertyValueCaseInsensitive(info, "displayname"); | ||
if (displayName) { | ||
return ini.unsafe(displayName); | ||
} | ||
const name = getObjectPropertyValueCaseInsensitive(info, "name"); | ||
if (name) { | ||
return ini.unsafe(name); | ||
} | ||
|
||
return "Unknown"; | ||
} |
Oops, something went wrong.