2021-05-19 17:21:51 -05:00
|
|
|
<template>
|
2023-05-16 23:38:31 -05:00
|
|
|
<div v-if="appErrors.length > 0" class="error-container" :style="theme"><Error :errors="appErrors" /></div>
|
|
|
|
<template v-else>
|
|
|
|
<div id="modal-root" :style="theme" />
|
|
|
|
<div class="app" :style="theme" :class="{ useHeader }">
|
|
|
|
<Nav v-if="useHeader" />
|
|
|
|
<Game />
|
|
|
|
<TPS v-if="unref(showTPS)" />
|
|
|
|
<GameOverScreen />
|
|
|
|
<NaNScreen />
|
|
|
|
<component :is="gameComponent" />
|
|
|
|
</div>
|
|
|
|
</template>
|
2021-05-19 17:21:51 -05:00
|
|
|
</template>
|
|
|
|
|
2022-03-19 23:59:52 -05:00
|
|
|
<script setup lang="tsx">
|
2023-05-16 23:38:31 -05:00
|
|
|
import "@fontsource/roboto-mono";
|
|
|
|
import Error from "components/Error.vue";
|
2022-03-19 23:59:52 -05:00
|
|
|
import { jsx } from "features/feature";
|
2023-05-16 23:38:31 -05:00
|
|
|
import state from "game/state";
|
2022-03-19 23:59:52 -05:00
|
|
|
import { coerceComponent, render } from "util/vue";
|
2023-05-16 23:38:31 -05:00
|
|
|
import { CSSProperties, watch } from "vue";
|
2022-02-27 13:49:34 -06:00
|
|
|
import { computed, toRef, unref } from "vue";
|
2022-02-27 16:04:56 -06:00
|
|
|
import Game from "./components/Game.vue";
|
|
|
|
import GameOverScreen from "./components/GameOverScreen.vue";
|
|
|
|
import NaNScreen from "./components/NaNScreen.vue";
|
|
|
|
import Nav from "./components/Nav.vue";
|
|
|
|
import TPS from "./components/TPS.vue";
|
2022-03-02 20:12:56 -06:00
|
|
|
import projInfo from "./data/projInfo.json";
|
2021-09-05 18:53:04 -05:00
|
|
|
import themes from "./data/themes";
|
2022-03-19 23:59:52 -05:00
|
|
|
import settings, { gameComponents } from "./game/settings";
|
First pass at typescript support
Oh man did this end up requiring a *ton* of other work as well.
There's still a few typing issues I still can't quite work out,
and others I'd like to improve when I have time. In fact, this version
doesn't even really work, it has a stack overflow error caused by
a tooltip for some reason have a tree inside it, which in turn has
another tooltip, etc. There's also 17 errors that I *really* feel like
shouldn't be there, but they are, and 113 warnings - mostly using !
to assert that things are non-null. Lots of work left to do, to sum up.
The reason I'm committing this now is because I really need to get to
work on my game jam, and since it won't use a tree or really many of
TMT-X's features, I can get away with using a broken engine :)
2021-08-16 23:30:54 -05:00
|
|
|
import "./main.css";
|
2021-05-19 23:27:23 -05:00
|
|
|
|
2022-03-02 20:12:56 -06:00
|
|
|
const useHeader = projInfo.useHeader;
|
2022-06-25 22:34:18 -05:00
|
|
|
const theme = computed(() => themes[settings.theme].variables as CSSProperties);
|
2022-01-13 22:25:47 -06:00
|
|
|
const showTPS = toRef(settings, "showTPS");
|
2023-05-16 23:38:31 -05:00
|
|
|
const appErrors = toRef(state, "errors");
|
2022-03-19 23:59:52 -05:00
|
|
|
|
|
|
|
const gameComponent = computed(() => {
|
2022-12-20 21:26:25 -06:00
|
|
|
return coerceComponent(jsx(() => (<>{gameComponents.map(render)}</>)));
|
2022-03-19 23:59:52 -05:00
|
|
|
});
|
2021-05-19 17:21:51 -05:00
|
|
|
</script>
|
|
|
|
|
2021-06-11 23:38:16 -05:00
|
|
|
<style scoped>
|
2021-07-24 17:08:52 -05:00
|
|
|
.app {
|
First pass at typescript support
Oh man did this end up requiring a *ton* of other work as well.
There's still a few typing issues I still can't quite work out,
and others I'd like to improve when I have time. In fact, this version
doesn't even really work, it has a stack overflow error caused by
a tooltip for some reason have a tree inside it, which in turn has
another tooltip, etc. There's also 17 errors that I *really* feel like
shouldn't be there, but they are, and 113 warnings - mostly using !
to assert that things are non-null. Lots of work left to do, to sum up.
The reason I'm committing this now is because I really need to get to
work on my game jam, and since it won't use a tree or really many of
TMT-X's features, I can get away with using a broken engine :)
2021-08-16 23:30:54 -05:00
|
|
|
background-color: var(--background);
|
2021-09-04 16:51:41 -05:00
|
|
|
color: var(--foreground);
|
First pass at typescript support
Oh man did this end up requiring a *ton* of other work as well.
There's still a few typing issues I still can't quite work out,
and others I'd like to improve when I have time. In fact, this version
doesn't even really work, it has a stack overflow error caused by
a tooltip for some reason have a tree inside it, which in turn has
another tooltip, etc. There's also 17 errors that I *really* feel like
shouldn't be there, but they are, and 113 warnings - mostly using !
to assert that things are non-null. Lots of work left to do, to sum up.
The reason I'm committing this now is because I really need to get to
work on my game jam, and since it won't use a tree or really many of
TMT-X's features, I can get away with using a broken engine :)
2021-08-16 23:30:54 -05:00
|
|
|
display: flex;
|
|
|
|
flex-flow: column;
|
|
|
|
min-height: 100%;
|
|
|
|
height: 100%;
|
2021-07-24 17:08:52 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
#modal-root {
|
|
|
|
position: absolute;
|
First pass at typescript support
Oh man did this end up requiring a *ton* of other work as well.
There's still a few typing issues I still can't quite work out,
and others I'd like to improve when I have time. In fact, this version
doesn't even really work, it has a stack overflow error caused by
a tooltip for some reason have a tree inside it, which in turn has
another tooltip, etc. There's also 17 errors that I *really* feel like
shouldn't be there, but they are, and 113 warnings - mostly using !
to assert that things are non-null. Lots of work left to do, to sum up.
The reason I'm committing this now is because I really need to get to
work on my game jam, and since it won't use a tree or really many of
TMT-X's features, I can get away with using a broken engine :)
2021-08-16 23:30:54 -05:00
|
|
|
min-height: 100%;
|
|
|
|
height: 100%;
|
2023-02-20 21:42:18 -06:00
|
|
|
color: var(--foreground);
|
2021-05-19 23:27:23 -05:00
|
|
|
}
|
2023-05-16 23:38:31 -05:00
|
|
|
|
|
|
|
.error-container {
|
|
|
|
background: var(--background);
|
|
|
|
overflow: auto;
|
|
|
|
width: 100%;
|
|
|
|
height: 100%;
|
|
|
|
}
|
|
|
|
|
|
|
|
.error-container > .error {
|
|
|
|
position: static;
|
|
|
|
}
|
2021-05-19 17:21:51 -05:00
|
|
|
</style>
|