create-pixi-vn 2.0.6 → 2.0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (66) hide show
  1. package/package.json +1 -1
  2. package/template-react-vite-muijoy/src/components/menus/choice-menus.tsx +1 -1
  3. package/template-react-vite-muijoy/src/components/menus/main-menu.tsx +5 -2
  4. package/template-react-vite-muijoy/src/components/menus/settings/menus/history.tsx +2 -5
  5. package/template-react-vite-muijoy/src/components/menus/settings/system-controls.tsx +2 -2
  6. package/template-react-vite-muijoy/src/components/modals/input-request-dialogues.tsx +1 -1
  7. package/template-react-vite-muijoy/src/components/quick-tools.tsx +5 -5
  8. package/template-react-vite-muijoy/src/components/screens/narration/index.tsx +1 -1
  9. package/template-react-vite-muijoy/src/components/screens/narration/narration-cards.tsx +1 -1
  10. package/template-react-vite-muijoy/src/constants.ts +2 -0
  11. package/template-react-vite-muijoy/src/lib/hooks/hotkeys-hooks.ts +5 -5
  12. package/template-react-vite-muijoy/src/lib/hooks/props-hooks.ts +4 -2
  13. package/template-react-vite-muijoy/src/lib/hooks/save-hooks.tsx +7 -7
  14. package/template-react-vite-muijoy/src/lib/query/{interface-query.ts → narration-query.ts} +13 -14
  15. package/template-react-vite-muijoy/src/lib/query/save-query.ts +4 -4
  16. package/template-react-vite-muijoy/src/lib/query/settings-query.ts +2 -2
  17. package/template-react-vite-muijoy/src/routes/__root.tsx +2 -2
  18. package/template-react-vite-muijoy-ink/src/components/menus/choice-menus.tsx +1 -1
  19. package/template-react-vite-muijoy-ink/src/components/menus/main-menu.tsx +5 -2
  20. package/template-react-vite-muijoy-ink/src/components/menus/settings/menus/history.tsx +2 -5
  21. package/template-react-vite-muijoy-ink/src/components/menus/settings/system-controls.tsx +2 -2
  22. package/template-react-vite-muijoy-ink/src/components/modals/input-request-dialogues.tsx +1 -1
  23. package/template-react-vite-muijoy-ink/src/components/quick-tools.tsx +5 -5
  24. package/template-react-vite-muijoy-ink/src/components/screens/narration/index.tsx +1 -1
  25. package/template-react-vite-muijoy-ink/src/components/screens/narration/narration-cards.tsx +1 -1
  26. package/template-react-vite-muijoy-ink/src/constants.ts +2 -0
  27. package/template-react-vite-muijoy-ink/src/lib/hooks/hotkeys-hooks.ts +5 -5
  28. package/template-react-vite-muijoy-ink/src/lib/hooks/props-hooks.ts +4 -2
  29. package/template-react-vite-muijoy-ink/src/lib/hooks/save-hooks.tsx +7 -7
  30. package/template-react-vite-muijoy-ink/src/lib/query/{interface-query.ts → narration-query.ts} +13 -14
  31. package/template-react-vite-muijoy-ink/src/lib/query/save-query.ts +4 -4
  32. package/template-react-vite-muijoy-ink/src/lib/query/settings-query.ts +2 -2
  33. package/template-react-vite-muijoy-ink/src/routes/__root.tsx +2 -2
  34. package/template-react-vite-muijoy-ink-tauri/package-lock.json +8 -8
  35. package/template-react-vite-muijoy-ink-tauri/src/components/menus/choice-menus.tsx +1 -1
  36. package/template-react-vite-muijoy-ink-tauri/src/components/menus/main-menu.tsx +5 -2
  37. package/template-react-vite-muijoy-ink-tauri/src/components/menus/settings/menus/history.tsx +2 -5
  38. package/template-react-vite-muijoy-ink-tauri/src/components/menus/settings/system-controls.tsx +2 -2
  39. package/template-react-vite-muijoy-ink-tauri/src/components/modals/input-request-dialogues.tsx +1 -1
  40. package/template-react-vite-muijoy-ink-tauri/src/components/quick-tools.tsx +5 -5
  41. package/template-react-vite-muijoy-ink-tauri/src/components/screens/narration/index.tsx +1 -1
  42. package/template-react-vite-muijoy-ink-tauri/src/components/screens/narration/narration-cards.tsx +1 -1
  43. package/template-react-vite-muijoy-ink-tauri/src/constants.ts +2 -0
  44. package/template-react-vite-muijoy-ink-tauri/src/lib/hooks/hotkeys-hooks.ts +5 -5
  45. package/template-react-vite-muijoy-ink-tauri/src/lib/hooks/props-hooks.ts +4 -2
  46. package/template-react-vite-muijoy-ink-tauri/src/lib/hooks/save-hooks.tsx +7 -7
  47. package/template-react-vite-muijoy-ink-tauri/src/lib/query/{interface-query.ts → narration-query.ts} +13 -14
  48. package/template-react-vite-muijoy-ink-tauri/src/lib/query/save-query.ts +4 -4
  49. package/template-react-vite-muijoy-ink-tauri/src/lib/query/settings-query.ts +2 -2
  50. package/template-react-vite-muijoy-ink-tauri/src/routes/__root.tsx +2 -2
  51. package/template-react-vite-muijoy-tauri/src/components/menus/choice-menus.tsx +1 -1
  52. package/template-react-vite-muijoy-tauri/src/components/menus/main-menu.tsx +5 -2
  53. package/template-react-vite-muijoy-tauri/src/components/menus/settings/menus/history.tsx +2 -5
  54. package/template-react-vite-muijoy-tauri/src/components/menus/settings/system-controls.tsx +2 -2
  55. package/template-react-vite-muijoy-tauri/src/components/modals/input-request-dialogues.tsx +1 -1
  56. package/template-react-vite-muijoy-tauri/src/components/quick-tools.tsx +5 -5
  57. package/template-react-vite-muijoy-tauri/src/components/screens/narration/index.tsx +1 -1
  58. package/template-react-vite-muijoy-tauri/src/components/screens/narration/narration-cards.tsx +1 -1
  59. package/template-react-vite-muijoy-tauri/src/constants.ts +2 -0
  60. package/template-react-vite-muijoy-tauri/src/lib/hooks/hotkeys-hooks.ts +5 -5
  61. package/template-react-vite-muijoy-tauri/src/lib/hooks/props-hooks.ts +4 -2
  62. package/template-react-vite-muijoy-tauri/src/lib/hooks/save-hooks.tsx +7 -7
  63. package/template-react-vite-muijoy-tauri/src/lib/query/{interface-query.ts → narration-query.ts} +13 -14
  64. package/template-react-vite-muijoy-tauri/src/lib/query/save-query.ts +4 -4
  65. package/template-react-vite-muijoy-tauri/src/lib/query/settings-query.ts +2 -2
  66. package/template-react-vite-muijoy-tauri/src/routes/__root.tsx +2 -2
@@ -5,10 +5,10 @@ import { useNarrationFunctions } from "@/lib/hooks/narration-hooks";
5
5
  import { useSetSearchParamState } from "@/lib/hooks/navigation-hooks";
6
6
  import { useGameProps } from "@/lib/hooks/props-hooks";
7
7
  import { useWheelActions } from "@/lib/hooks/quick-tools-hooks";
8
- import { useQueryCanGoBack } from "@/lib/query/interface-query";
8
+ import { useQueryCanGoBack } from "@/lib/query/narration-query";
9
9
  import {
10
- LAST_SAVE_USE_QUEY_KEY,
11
- SAVES_USE_QUEY_KEY,
10
+ LAST_SAVE_USE_QUERY_KEY,
11
+ SAVES_USE_QUERY_KEY,
12
12
  useQueryLastSave,
13
13
  } from "@/lib/query/save-query";
14
14
  import { AutoSettings } from "@/lib/stores/auto-settings-store";
@@ -105,8 +105,8 @@ export function QuickTools() {
105
105
  className="h-5 px-1 text-[10px] sm:h-6 sm:px-2 sm:text-xs"
106
106
  onClick={() => {
107
107
  const savePromise = saveGameToIndexDB().then((save) => {
108
- queryClient.setQueryData([SAVES_USE_QUEY_KEY, save.id], save);
109
- queryClient.setQueryData([LAST_SAVE_USE_QUEY_KEY], save);
108
+ queryClient.setQueryData([SAVES_USE_QUERY_KEY, save.id], save);
109
+ queryClient.setQueryData([LAST_SAVE_USE_QUERY_KEY], save);
110
110
  });
111
111
  toast.promise(savePromise, {
112
112
  loading: t("saving"),
@@ -1,7 +1,7 @@
1
1
  import { ChoiceMenu } from "@/components/menus/choice-menus";
2
2
  import { NarrationCards } from "@/components/screens/narration/narration-cards";
3
3
  import { ResizableHandle, ResizablePanel, ResizablePanelGroup } from "@/components/ui/resizable";
4
- import { useQueryDialogue } from "@/lib/query/interface-query";
4
+ import { useQueryDialogue } from "@/lib/query/narration-query";
5
5
 
6
6
  export function NarrationScreen() {
7
7
  const { data: { animatedText, text } = {} } = useQueryDialogue();
@@ -6,7 +6,7 @@ import { Image } from "@/components/ui/image";
6
6
  import { ResizableHandle, ResizablePanel, ResizablePanelGroup } from "@/components/ui/resizable";
7
7
  import { ScrollArea } from "@/components/ui/scroll-area";
8
8
  import { useNarrationPointerHandlers } from "@/lib/hooks/narration-hooks";
9
- import { useQueryDialogue } from "@/lib/query/interface-query";
9
+ import { useQueryDialogue } from "@/lib/query/narration-query";
10
10
  import { TextDisplaySettings } from "@/lib/stores/text-display-settings-store";
11
11
  import { useSelector } from "@tanstack/react-store";
12
12
  import { type RefObject, useCallback, useRef } from "react";
@@ -9,5 +9,7 @@ export const SFX_CHANNEL_NAME = "sfx";
9
9
 
10
10
  export const SKIP_DELAY = 100;
11
11
 
12
+ export const INTERFACE_DATA_USE_QUERY_KEY = "interface_data_use_query_key";
13
+
12
14
  /** Text-shadow that outlines text with black so it remains legible over any image or canvas background. */
13
15
  export const overlayTextShadowClass = "[text-shadow:0_0_3px_black,0_0_6px_black]";
@@ -2,10 +2,10 @@ import { useAlertDialog } from "@/components/providers/alert-dialog-provider";
2
2
  import { useNarrationFunctions } from "@/lib/hooks/narration-hooks";
3
3
  import { useSetSearchParamState } from "@/lib/hooks/navigation-hooks";
4
4
  import { useGameProps } from "@/lib/hooks/props-hooks";
5
- import { useQueryInputValue } from "@/lib/query/interface-query";
5
+ import { useQueryInputValue } from "@/lib/query/narration-query";
6
6
  import {
7
- LAST_SAVE_USE_QUEY_KEY,
8
- SAVES_USE_QUEY_KEY,
7
+ LAST_SAVE_USE_QUERY_KEY,
8
+ SAVES_USE_QUERY_KEY,
9
9
  useQueryLastSave,
10
10
  } from "@/lib/query/save-query";
11
11
  import { QuickActionsWheelState } from "@/lib/stores/quick-actions-wheel-store";
@@ -47,8 +47,8 @@ export function useSaveHotkeys(): null {
47
47
  return;
48
48
  }
49
49
  const savePromise = saveGameToIndexDB().then((save) => {
50
- queryClient.setQueryData([SAVES_USE_QUEY_KEY, save.id], save);
51
- queryClient.setQueryData([LAST_SAVE_USE_QUEY_KEY], save);
50
+ queryClient.setQueryData([SAVES_USE_QUERY_KEY, save.id], save);
51
+ queryClient.setQueryData([LAST_SAVE_USE_QUERY_KEY], save);
52
52
  });
53
53
  toast.promise(savePromise, {
54
54
  loading: t("saving"),
@@ -1,4 +1,4 @@
1
- import { INTERFACE_DATA_USE_QUEY_KEY } from "@/lib/query/interface-query";
1
+ import { INTERFACE_DATA_USE_QUERY_KEY } from "@/constants";
2
2
  import type { StepLabelProps } from "@drincs/pixi-vn";
3
3
  import { useQueryClient } from "@tanstack/react-query";
4
4
  import { useNavigate } from "@tanstack/react-router";
@@ -18,7 +18,9 @@ export function useGameProps(): StepLabelProps {
18
18
  toast,
19
19
  invalidateInterfaceData: async (delay: number = 0) => {
20
20
  if (delay > 0) await new Promise((resolve) => setTimeout(resolve, delay));
21
- return await queryClient.invalidateQueries({ queryKey: [INTERFACE_DATA_USE_QUEY_KEY] });
21
+ return await queryClient.invalidateQueries({
22
+ queryKey: [INTERFACE_DATA_USE_QUERY_KEY],
23
+ });
22
24
  },
23
25
  };
24
26
  }
@@ -2,7 +2,7 @@ import { SaveNameInput } from "@/components/menus/save-menu/save-forms";
2
2
  import { useAlertDialog } from "@/components/providers/alert-dialog-provider";
3
3
  import { useSetSearchParamState } from "@/lib/hooks/navigation-hooks";
4
4
  import { useGameProps } from "@/lib/hooks/props-hooks";
5
- import { LAST_SAVE_USE_QUEY_KEY, SAVES_USE_QUEY_KEY } from "@/lib/query/save-query";
5
+ import { LAST_SAVE_USE_QUERY_KEY, SAVES_USE_QUERY_KEY } from "@/lib/query/save-query";
6
6
  import {
7
7
  addRefreshSave,
8
8
  deleteSaveFromIndexDB,
@@ -62,8 +62,8 @@ export function useSaveActions() {
62
62
  onConfirm: () =>
63
63
  deleteSaveFromIndexDB(id)
64
64
  .then(() => {
65
- queryClient.setQueryData([SAVES_USE_QUEY_KEY, id], null);
66
- queryClient.invalidateQueries({ queryKey: [LAST_SAVE_USE_QUEY_KEY] });
65
+ queryClient.setQueryData([SAVES_USE_QUERY_KEY, id], null);
66
+ queryClient.invalidateQueries({ queryKey: [LAST_SAVE_USE_QUERY_KEY] });
67
67
  toast.success(t("success_delete"));
68
68
  return true;
69
69
  })
@@ -95,8 +95,8 @@ export function useSaveActions() {
95
95
  id,
96
96
  name: tempSaveNameRef.current,
97
97
  }).then((save) => {
98
- queryClient.setQueryData([SAVES_USE_QUEY_KEY, save.id], save);
99
- queryClient.setQueryData([LAST_SAVE_USE_QUEY_KEY], save);
98
+ queryClient.setQueryData([SAVES_USE_QUERY_KEY, save.id], save);
99
+ queryClient.setQueryData([LAST_SAVE_USE_QUERY_KEY], save);
100
100
  });
101
101
  toast.promise(savePromise, {
102
102
  loading: t("saving"),
@@ -138,8 +138,8 @@ export function useSaveActions() {
138
138
  id,
139
139
  name: tempSaveNameRef.current,
140
140
  }).then((save) => {
141
- queryClient.setQueryData([SAVES_USE_QUEY_KEY, save.id], save);
142
- queryClient.setQueryData([LAST_SAVE_USE_QUEY_KEY], save);
141
+ queryClient.setQueryData([SAVES_USE_QUERY_KEY, save.id], save);
142
+ queryClient.setQueryData([LAST_SAVE_USE_QUERY_KEY], save);
143
143
  });
144
144
  toast.promise(savePromise, {
145
145
  loading: t("saving"),
@@ -1,22 +1,21 @@
1
+ import { INTERFACE_DATA_USE_QUERY_KEY } from "@/constants";
1
2
  import { type CharacterInterface, narration, stepHistory } from "@drincs/pixi-vn";
2
3
  import { useQuery, useQueryClient } from "@tanstack/react-query";
3
4
  import { useTranslation } from "react-i18next";
4
5
 
5
- export const INTERFACE_DATA_USE_QUEY_KEY = "interface_data_use_quey_key";
6
-
7
- const CAN_GO_BACK_USE_QUEY_KEY = "can_go_back_use_quey_key";
6
+ const CAN_GO_BACK_USE_QUERY_KEY = "can_go_back_use_query_key";
8
7
  export function useQueryCanGoBack() {
9
8
  return useQuery({
10
- queryKey: [INTERFACE_DATA_USE_QUEY_KEY, CAN_GO_BACK_USE_QUEY_KEY],
9
+ queryKey: [INTERFACE_DATA_USE_QUERY_KEY, CAN_GO_BACK_USE_QUERY_KEY],
11
10
  queryFn: async () => stepHistory.canGoBack,
12
11
  });
13
12
  }
14
13
 
15
- const CHOICE_MENU_OPTIONS_USE_QUEY_KEY = "choice_menu_options_use_quey_key";
14
+ const CHOICE_MENU_OPTIONS_USE_QUERY_KEY = "choice_menu_options_use_query_key";
16
15
  export function useQueryChoiceMenuOptions() {
17
16
  const { t } = useTranslation(["narration"]);
18
17
  return useQuery({
19
- queryKey: [INTERFACE_DATA_USE_QUEY_KEY, CHOICE_MENU_OPTIONS_USE_QUEY_KEY],
18
+ queryKey: [INTERFACE_DATA_USE_QUERY_KEY, CHOICE_MENU_OPTIONS_USE_QUERY_KEY],
20
19
  queryFn: async () =>
21
20
  narration.choices?.map((option) => ({
22
21
  ...option,
@@ -28,10 +27,10 @@ export function useQueryChoiceMenuOptions() {
28
27
  });
29
28
  }
30
29
 
31
- const INPUT_VALUE_USE_QUEY_KEY = "input_value_use_quey_key";
30
+ const INPUT_VALUE_USE_QUERY_KEY = "input_value_use_query_key";
32
31
  export function useQueryInputValue<T>() {
33
32
  return useQuery({
34
- queryKey: [INTERFACE_DATA_USE_QUEY_KEY, INPUT_VALUE_USE_QUEY_KEY],
33
+ queryKey: [INTERFACE_DATA_USE_QUERY_KEY, INPUT_VALUE_USE_QUERY_KEY],
35
34
  queryFn: async () => ({
36
35
  isRequired: narration.isRequiredInput,
37
36
  type: narration.inputType,
@@ -45,13 +44,13 @@ type DialogueModel = {
45
44
  text?: string;
46
45
  character?: CharacterInterface;
47
46
  };
48
- const DIALOGUE_USE_QUEY_KEY = "dialogue_use_quey_key";
47
+ const DIALOGUE_USE_QUERY_KEY = "dialogue_use_query_key";
49
48
  export function useQueryDialogue() {
50
49
  const { t } = useTranslation(["narration"]);
51
50
  const queryClient = useQueryClient();
52
51
 
53
52
  return useQuery<DialogueModel>({
54
- queryKey: [INTERFACE_DATA_USE_QUEY_KEY, DIALOGUE_USE_QUEY_KEY],
53
+ queryKey: [INTERFACE_DATA_USE_QUERY_KEY, DIALOGUE_USE_QUERY_KEY],
55
54
  queryFn: async ({ queryKey }) => {
56
55
  const dialogue = narration.dialogue;
57
56
  let text = dialogue?.text;
@@ -90,21 +89,21 @@ export function useQueryDialogue() {
90
89
  });
91
90
  }
92
91
 
93
- const CAN_GO_NEXT_USE_QUEY_KEY = "can_go_next_use_quey_key";
92
+ const CAN_GO_NEXT_USE_QUERY_KEY = "can_go_next_use_query_key";
94
93
  export function useQueryCanGoNext() {
95
94
  return useQuery({
96
- queryKey: [INTERFACE_DATA_USE_QUEY_KEY, CAN_GO_NEXT_USE_QUEY_KEY],
95
+ queryKey: [INTERFACE_DATA_USE_QUERY_KEY, CAN_GO_NEXT_USE_QUERY_KEY],
97
96
  queryFn: async () => narration.canContinue && !narration.isRequiredInput,
98
97
  });
99
98
  }
100
99
 
101
- const NARRATIVE_HISTORY_USE_QUEY_KEY = "narrative_history_use_quey_key";
100
+ const NARRATIVE_HISTORY_USE_QUERY_KEY = "narrative_history_use_query_key";
102
101
  export function useQueryNarrativeHistory({ searchString }: { searchString?: string }) {
103
102
  const { t } = useTranslation(["narration"]);
104
103
  const normalizedSearch = searchString?.toLowerCase().trim();
105
104
 
106
105
  return useQuery({
107
- queryKey: [INTERFACE_DATA_USE_QUEY_KEY, NARRATIVE_HISTORY_USE_QUEY_KEY],
106
+ queryKey: [INTERFACE_DATA_USE_QUERY_KEY, NARRATIVE_HISTORY_USE_QUERY_KEY],
108
107
  queryFn: async () => {
109
108
  const promises = stepHistory.narrativeHistory.map(async (step) => {
110
109
  const character = step.dialogue?.character;
@@ -1,18 +1,18 @@
1
1
  import { getLastSaveFromIndexDB, getSaveFromIndexDB } from "@/lib/utils/save-utility";
2
2
  import { useQuery } from "@tanstack/react-query";
3
3
 
4
- export const SAVES_USE_QUEY_KEY = "saves_use_quey_key";
4
+ export const SAVES_USE_QUERY_KEY = "saves_use_query_key";
5
5
  export function useQuerySaves({ id }: { id: number }) {
6
6
  return useQuery({
7
- queryKey: [SAVES_USE_QUEY_KEY, id],
7
+ queryKey: [SAVES_USE_QUERY_KEY, id],
8
8
  queryFn: async () => (await getSaveFromIndexDB(id)) || null,
9
9
  });
10
10
  }
11
11
 
12
- export const LAST_SAVE_USE_QUEY_KEY = "last_save_use_quey_key";
12
+ export const LAST_SAVE_USE_QUERY_KEY = "last_save_use_query_key";
13
13
  export function useQueryLastSave() {
14
14
  return useQuery({
15
- queryKey: [LAST_SAVE_USE_QUEY_KEY],
15
+ queryKey: [LAST_SAVE_USE_QUERY_KEY],
16
16
  queryFn: async () => (await getLastSaveFromIndexDB()) || null,
17
17
  });
18
18
  }
@@ -1,11 +1,11 @@
1
1
  import { useQuery } from "@tanstack/react-query";
2
2
  import { getCurrentWindow } from "@tauri-apps/api/window";
3
3
 
4
- export const IS_FULL_SCREEN_MODE_USE_QUEY_KEY = "is_full_screen_mode_use_quey_key";
4
+ export const IS_FULL_SCREEN_MODE_USE_QUERY_KEY = "is_full_screen_mode_use_query_key";
5
5
 
6
6
  export function useQueryIsFullModeScreen() {
7
7
  return useQuery({
8
- queryKey: [IS_FULL_SCREEN_MODE_USE_QUEY_KEY],
8
+ queryKey: [IS_FULL_SCREEN_MODE_USE_QUERY_KEY],
9
9
  queryFn: async () => {
10
10
  if (window.__TAURI__) {
11
11
  return getCurrentWindow().isFullscreen();
@@ -2,10 +2,10 @@ import { PendingComponent } from "@/components/loading";
2
2
  import { SettingsDialogue } from "@/components/menus/settings";
3
3
  import { OfflineAllert } from "@/components/modals/error-allerts";
4
4
  import { RootProvider } from "@/components/providers/root-provider";
5
+ import { INTERFACE_DATA_USE_QUERY_KEY } from "@/constants";
5
6
  import { useConfirmBackNavigation } from "@/lib/hooks/navigation-hooks";
6
7
  import { useAutoSaveOnPageClose } from "@/lib/hooks/save-hooks";
7
8
  import { useI18n } from "@/lib/i18n";
8
- import { INTERFACE_DATA_USE_QUEY_KEY } from "@/lib/query/interface-query";
9
9
  import { SearchParams } from "@/lib/stores/search-param-store";
10
10
  import { defineAssets } from "@/lib/utils/assets-utility";
11
11
  import { initializeIndexedDB } from "@/lib/utils/db-utility";
@@ -30,7 +30,7 @@ export const Route = createRootRouteWithContext<RouterContext>()({
30
30
  const isRefreshSaveExist = await loadRefreshSave();
31
31
  if (isRefreshSaveExist) {
32
32
  await context.queryClient.invalidateQueries({
33
- queryKey: [INTERFACE_DATA_USE_QUEY_KEY],
33
+ queryKey: [INTERFACE_DATA_USE_QUERY_KEY],
34
34
  });
35
35
  }
36
36
  }