mirror of
https://github.com/PhotonVision/photonvision
synced 2026-06-27 02:01:40 +00:00
[PhotonClient] Vite and Typescript complete refactor (#884)
This commit is contained in:
70
photon-client/src/views/DashboardView.vue
Normal file
70
photon-client/src/views/DashboardView.vue
Normal file
@@ -0,0 +1,70 @@
|
||||
<script setup lang="ts">
|
||||
import { computed } from "vue";
|
||||
import CamerasCard from "@/components/dashboard/CamerasCard.vue";
|
||||
import CameraAndPipelineSelectCard from "@/components/dashboard/CameraAndPipelineSelectCard.vue";
|
||||
import StreamConfigCard from "@/components/dashboard/StreamConfigCard.vue";
|
||||
import PipelineConfigCard from "@/components/dashboard/ConfigOptions.vue";
|
||||
import { useCameraSettingsStore } from "@/stores/settings/CameraSettingsStore";
|
||||
import { useStateStore } from "@/stores/StateStore";
|
||||
|
||||
const cameraViewType = computed<number[]>({
|
||||
get: (): number[] => {
|
||||
// Only show the input stream in Color Picking Mode
|
||||
if(useStateStore().colorPickingMode) return [0];
|
||||
|
||||
// Only show the output stream in Driver Mode or Calibration Mode
|
||||
if(useCameraSettingsStore().isDriverMode || useCameraSettingsStore().isCalibrationMode) return [1];
|
||||
|
||||
const ret: number[] = [];
|
||||
if(useCameraSettingsStore().currentPipelineSettings.inputShouldShow) {
|
||||
ret.push(0);
|
||||
}
|
||||
if(useCameraSettingsStore().currentPipelineSettings.outputShouldShow) {
|
||||
ret.push(1);
|
||||
}
|
||||
|
||||
if(ret.length === 0) return [0];
|
||||
|
||||
return ret;
|
||||
},
|
||||
set: v => {
|
||||
useCameraSettingsStore().changeCurrentPipelineSetting({
|
||||
inputShouldShow: v.includes(0),
|
||||
outputShouldShow: v.includes(1)
|
||||
}, true);
|
||||
}
|
||||
});
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<v-container
|
||||
class="pa-3"
|
||||
fluid
|
||||
>
|
||||
<v-row
|
||||
no-gutters
|
||||
align="center"
|
||||
justify="center"
|
||||
>
|
||||
<v-col
|
||||
cols="12"
|
||||
class="pb-3 pr-lg-3"
|
||||
lg="8"
|
||||
align-self="stretch"
|
||||
>
|
||||
<CamerasCard v-model="cameraViewType" />
|
||||
</v-col>
|
||||
<v-col
|
||||
cols="12"
|
||||
class="pb-3"
|
||||
lg="4"
|
||||
style="display: flex; flex-direction: column"
|
||||
align-self="stretch"
|
||||
>
|
||||
<CameraAndPipelineSelectCard />
|
||||
<StreamConfigCard v-model="cameraViewType" />
|
||||
</v-col>
|
||||
</v-row>
|
||||
<PipelineConfigCard />
|
||||
</v-container>
|
||||
</template>
|
||||
Reference in New Issue
Block a user