Skip to content

Commit

Permalink
Change: EditorHomeを統合
Browse files Browse the repository at this point in the history
  • Loading branch information
sevenc-nanashi committed Oct 26, 2023
1 parent f06d284 commit 3a9ffa1
Show file tree
Hide file tree
Showing 6 changed files with 49 additions and 979 deletions.
2 changes: 1 addition & 1 deletion src/browser/contract.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { EngineInfo, EngineId } from "@/type/preload";

export const defaultEngine: EngineInfo = {
uuid: EngineId("074fc39e-678b-4c13-8916-ffca8d505d1d"),
host: "http://127.0.0.1:50021",
host: "http://192.168.1.2:50021",
name: "VOICEVOX Engine",
path: undefined,
executionEnabled: false,
Expand Down
6 changes: 3 additions & 3 deletions src/components/AudioDetail.vue
Original file line number Diff line number Diff line change
Expand Up @@ -98,10 +98,9 @@

<script setup lang="ts">
import { computed, nextTick, onMounted, onUnmounted, ref, watch } from "vue";
import { useQuasar } from "quasar";
import ToolTip from "./ToolTip.vue";
import AudioInfo from "./AudioInfo.vue";
import AudioAccent from "./AudioAccent.vue";
import AudioParameter from "./AudioParameter.vue";
import AccentPhrase from "./AccentPhrase.vue";
import { useStore } from "@/store";
import {
Expand All @@ -119,8 +118,9 @@ const props =
}>();
const store = useStore();
const $q = useQuasar();
const isMobile = import.meta.env.VITE_TARGET === "mobile";
const isMobile = computed(() => !$q.platform.is.desktop);
const supportedFeatures = computed(
() =>
Expand Down
4 changes: 1 addition & 3 deletions src/router/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,14 +5,12 @@ import {
RouteRecordRaw,
} from "vue-router";
import EditorHome from "@/views/EditorHome.vue";
import MobileEditorHome from "@/views/MobileEditorHome.vue";
import { isBrowser } from "@/type/preload";

const routes: Array<RouteRecordRaw> = [
{
path: "/home",
component:
import.meta.env.VITE_TARGET === "mobile" ? MobileEditorHome : EditorHome,
component: EditorHome,
props: (route) => ({ projectFilePath: route.query["projectFilePath"] }),
alias: "/",
},
Expand Down
4 changes: 2 additions & 2 deletions src/styles/variables.scss
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,11 @@ $window-border-width: 2px;
$header-height: var(--header-height);
$menubar-height: var(--menubar-height);
body {
&:not([data-target="mobile"]) {
&.desktop {
--header-height: 66px;
--menubar-height: 24px;
}
&[data-target="mobile"] {
&:not(.desktop) {
--header-height: 50px;
--menubar-height: 0px;
}
Expand Down
70 changes: 42 additions & 28 deletions src/views/EditorHome.vue
Original file line number Diff line number Diff line change
@@ -1,8 +1,9 @@
<template>
<menu-bar />
<menu-bar v-if="$q.platform.is.desktop" />

<q-layout reveal elevated container class="layout-container">
<header-bar />
<header-bar v-if="$q.platform.is.desktop" />
<mobile-header-bar v-else />

<q-page-container>
<q-page class="main-row-panes">
Expand Down Expand Up @@ -63,9 +64,9 @@
<q-splitter
:limits="[MIN_PORTRAIT_PANE_WIDTH, MAX_PORTRAIT_PANE_WIDTH]"
separator-class="home-splitter"
:separator-style="{ width: shouldShowPanes ? '3px' : '0' }"
:separator-style="{ width: shouldShowSidePanes ? '3px' : '0' }"
before-class="overflow-hidden"
:disable="!shouldShowPanes"
:disable="!shouldShowSidePanes"
:model-value="portraitPaneWidth"
@update:model-value="updatePortraitPane"
>
Expand All @@ -78,9 +79,11 @@
unit="px"
:limits="[audioInfoPaneMinWidth, audioInfoPaneMaxWidth]"
separator-class="home-splitter"
:separator-style="{ width: shouldShowPanes ? '3px' : '0' }"
:separator-style="{
width: shouldShowSidePanes ? '3px' : '0',
}"
class="full-width overflow-hidden"
:disable="!shouldShowPanes"
:disable="!shouldShowSidePanes"
:model-value="audioInfoPaneWidth"
@update:model-value="updateAudioInfoPane"
>
Expand Down Expand Up @@ -182,7 +185,7 @@
import path from "path";
import { computed, onBeforeUpdate, onMounted, ref, VNodeRef, watch } from "vue";
import draggable from "vuedraggable";
import { QResizeObserver } from "quasar";
import { QResizeObserver, useQuasar } from "quasar";
import cloneDeep from "clone-deep";
import Mousetrap from "mousetrap";
import { useStore } from "@/store";
Expand Down Expand Up @@ -215,13 +218,17 @@ import {
} from "@/type/preload";
import { isOnCommandOrCtrlKeyDown } from "@/store/utility";
import { parseCombo, setHotkeyFunctions } from "@/store/setting";
import MobileHeaderBar from "@/components/MobileHeaderBar.vue";
const props =
defineProps<{
projectFilePath: string;
}>();
const store = useStore();
const $q = useQuasar();
const isDesktop = computed(() => $q.platform.is.desktop);
const audioKeys = computed(() => store.state.audioKeys);
const uiLocked = computed(() => store.getters.UI_LOCKED);
Expand All @@ -234,7 +241,7 @@ const hotkeyMap = new Map<HotkeyAction, () => HotkeyReturnType>([
[
"テキスト欄にフォーカスを戻す",
() => {
if (activeAudioKey.value !== undefined) {
if (activeAudioKey.value != undefined) {
focusCell({ audioKey: activeAudioKey.value, focusTarget: "textField" });
}
return false; // this is the same with event.preventDefault()
Expand Down Expand Up @@ -312,7 +319,7 @@ const MIN_PORTRAIT_PANE_WIDTH = 0;
const MAX_PORTRAIT_PANE_WIDTH = 40;
const MIN_AUDIO_INFO_PANE_WIDTH = 160; // px
const MAX_AUDIO_INFO_PANE_WIDTH = 250;
const MIN_AUDIO_DETAIL_PANE_HEIGHT = 185; // px
const MIN_AUDIO_DETAIL_PANE_HEIGHT = isDesktop.value ? 185 : 220; // px
const MAX_AUDIO_DETAIL_PANE_HEIGHT = 500;
const portraitPaneWidth = ref(0);
Expand Down Expand Up @@ -398,7 +405,7 @@ const addAudioItem = async () => {
let presetKey: PresetKey | undefined = undefined;
let baseAudioItem: AudioItem | undefined = undefined;
if (prevAudioKey !== undefined) {
if (prevAudioKey != undefined) {
voice = store.state.audioItems[prevAudioKey].voice;
presetKey = store.state.audioItems[prevAudioKey].presetKey;
baseAudioItem = store.state.audioItems[prevAudioKey];
Expand Down Expand Up @@ -435,13 +442,35 @@ const duplicateAudioItem = async () => {
const shouldShowPanes = computed<boolean>(
() => store.getters.SHOULD_SHOW_PANES
);
const shouldShowSidePanes = computed<boolean>(
() => shouldShowPanes.value && $q.screen.gt.xs // 横幅がある程度大きいかどうか
);
const clamp = (value: number, min: number, max: number) =>
Math.max(Math.min(value, max), min);
watch(shouldShowPanes, (val, old) => {
if (val === old) return;
if (val) {
const clamp = (value: number, min: number, max: number) =>
Math.max(Math.min(value, max), min);
audioDetailPaneMinHeight.value = MIN_AUDIO_DETAIL_PANE_HEIGHT;
changeAudioDetailPaneMaxHeight(
resizeObserverRef.value?.$el.parentElement.clientHeight
);
audioDetailPaneHeight.value = clamp(
splitterPosition.value.audioDetailPaneHeight ??
MIN_AUDIO_DETAIL_PANE_HEIGHT,
audioDetailPaneMinHeight.value,
audioDetailPaneMaxHeight.value
);
} else {
audioDetailPaneHeight.value = 0;
audioDetailPaneMinHeight.value = 0;
audioDetailPaneMaxHeight.value = 0;
}
});
watch(shouldShowSidePanes, (val, old) => {
if (val === old) return;
if (val) {
// 設定ファイルを書き換えれば異常な値が入り得るのですべてclampしておく
portraitPaneWidth.value = clamp(
splitterPosition.value.portraitPaneWidth ?? DEFAULT_PORTRAIT_PANE_WIDTH,
Expand All @@ -456,26 +485,11 @@ watch(shouldShowPanes, (val, old) => {
);
audioInfoPaneMinWidth.value = MIN_AUDIO_INFO_PANE_WIDTH;
audioInfoPaneMaxWidth.value = MAX_AUDIO_INFO_PANE_WIDTH;
audioDetailPaneMinHeight.value = MIN_AUDIO_DETAIL_PANE_HEIGHT;
changeAudioDetailPaneMaxHeight(
resizeObserverRef.value?.$el.parentElement.clientHeight
);
audioDetailPaneHeight.value = clamp(
splitterPosition.value.audioDetailPaneHeight ??
MIN_AUDIO_DETAIL_PANE_HEIGHT,
audioDetailPaneMinHeight.value,
audioDetailPaneMaxHeight.value
);
} else {
portraitPaneWidth.value = 0;
audioInfoPaneWidth.value = 0;
audioInfoPaneMinWidth.value = 0;
audioInfoPaneMaxWidth.value = 0;
audioDetailPaneHeight.value = 0;
audioDetailPaneMinHeight.value = 0;
audioDetailPaneMaxHeight.value = 0;
}
});
Expand Down
Loading

0 comments on commit 3a9ffa1

Please sign in to comment.