mirror of
https://github.com/PhotonVision/photonvision
synced 2026-06-28 02:11:40 +00:00
Does the following: - Adjusts the shade of red buttons and banners to increase readability and reduce eye strain   - Cleans up factory reset and camera deletion modals   - Removes matchCamerasOnlyByPath as it is no longer used and throws errors in the console  - Limits the criteria to flag a camera mismatch in Camera Matching to only what is necessary based on camera type and highlights differences in table properties (testing on this is appreciated)  - Only displays both saved vs. current info in camera matching if there is a difference between the two  - Some general code cleanup (reduced unnecessary padding/margin/row-col statements, style="display:flex;" -> class="d-flex", etc. - Moves Compact Mode button to the bottom away from all the menu items (cleaner imo, open to thoughts) - Establishes a general spacing format for cards and pages and applies this to existing cards and pages to create a consistent look and feel to the UI (e.g. keeping things in line and less erratic spacing/placement of UI elements)     - Delete protection for camera matching modules - Anti-backend-spam for activate/deactivate/delete modules to hopefully prevent any odd behavior from button spamming - Enforces a common camera stream size on camera matching view (NEEDS MORE TESTING)  https://private-user-images.githubusercontent.com/29715865/400783758-dc99c151-b8a7-4367-a173-74c2fc5b2666.mp4?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MzYyNTc3NzEsIm5iZiI6MTczNjI1NzQ3MSwicGF0aCI6Ii8yOTcxNTg2NS80MDA3ODM3NTgtZGM5OWMxNTEtYjhhNy00MzY3LWExNzMtNzRjMmZjNWIyNjY2Lm1wND9YLUFtei1BbGdvcml0aG09QVdTNC1ITUFDLVNIQTI1NiZYLUFtei1DcmVkZW50aWFsPUFLSUFWQ09EWUxTQTUzUFFLNFpBJTJGMjAyNTAxMDclMkZ1cy1lYXN0LTElMkZzMyUyRmF3czRfcmVxdWVzdCZYLUFtei1EYXRlPTIwMjUwMTA3VDEzNDQzMVomWC1BbXotRXhwaXJlcz0zMDAmWC1BbXotU2lnbmF0dXJlPWMwOWM1MDc2ZTVlOWZhM2MxYjAwZjAyZTc2MTYyZTk1ZTVmOGFhZmVkMzlmODRlZTk1ODVlOTk2ZGQzZmM0Y2EmWC1BbXotU2lnbmVkSGVhZGVycz1ob3N0In0.ovtRnObwbkEfljr9d5fqaory0nH91LWJSSkmrUUe_4Y
72 lines
2.6 KiB
Vue
72 lines
2.6 KiB
Vue
<script setup lang="ts">
|
|
import { PVCameraInfo } from "@/types/SettingTypes";
|
|
|
|
const { camera } = defineProps({
|
|
camera: {
|
|
type: PVCameraInfo,
|
|
required: true
|
|
}
|
|
});
|
|
|
|
const cameraInfoFor: any = (camera: PVCameraInfo) => {
|
|
if (camera.PVUsbCameraInfo) {
|
|
return camera.PVUsbCameraInfo;
|
|
}
|
|
if (camera.PVCSICameraInfo) {
|
|
return camera.PVCSICameraInfo;
|
|
}
|
|
if (camera.PVFileCameraInfo) {
|
|
return camera.PVFileCameraInfo;
|
|
}
|
|
return {};
|
|
};
|
|
</script>
|
|
|
|
<template>
|
|
<div>
|
|
<v-simple-table dense :style="{ backgroundColor: 'var(--v-primary-base)' }">
|
|
<tbody>
|
|
<tr v-if="cameraInfoFor(camera).dev !== undefined && cameraInfoFor(camera).dev !== null">
|
|
<td>Device Number:</td>
|
|
<td>{{ cameraInfoFor(camera).dev }}</td>
|
|
</tr>
|
|
<tr v-if="cameraInfoFor(camera).name !== undefined && cameraInfoFor(camera).name !== null">
|
|
<td>Name:</td>
|
|
<td>{{ cameraInfoFor(camera).name }}</td>
|
|
</tr>
|
|
<tr>
|
|
<td>Type:</td>
|
|
<td v-if="camera.PVUsbCameraInfo" class="mb-3">USB Camera</td>
|
|
<td v-else-if="camera.PVCSICameraInfo" class="mb-3">CSI Camera</td>
|
|
<td v-else-if="camera.PVFileCameraInfo" class="mb-3">File Camera</td>
|
|
<td v-else>Unidentified Camera Type</td>
|
|
</tr>
|
|
<tr v-if="cameraInfoFor(camera).baseName !== undefined && cameraInfoFor(camera).baseName !== null">
|
|
<td>Base Name:</td>
|
|
<td>{{ cameraInfoFor(camera).baseName }}</td>
|
|
</tr>
|
|
<tr v-if="cameraInfoFor(camera).vendorId !== undefined && cameraInfoFor(camera).vendorId !== null">
|
|
<td>Vendor ID:</td>
|
|
<td>{{ cameraInfoFor(camera).vendorId }}</td>
|
|
</tr>
|
|
<tr v-if="cameraInfoFor(camera).productId !== undefined && cameraInfoFor(camera).productId !== null">
|
|
<td>Product ID:</td>
|
|
<td>{{ cameraInfoFor(camera).productId }}</td>
|
|
</tr>
|
|
<tr v-if="cameraInfoFor(camera).path !== undefined && cameraInfoFor(camera).path !== null">
|
|
<td>Path:</td>
|
|
<td style="word-break: break-all">{{ cameraInfoFor(camera).path }}</td>
|
|
</tr>
|
|
<tr v-if="cameraInfoFor(camera).otherPaths !== undefined && cameraInfoFor(camera).otherPaths !== null">
|
|
<td>Other Paths:</td>
|
|
<td>{{ cameraInfoFor(camera).otherPaths }}</td>
|
|
</tr>
|
|
<tr v-if="cameraInfoFor(camera).uniquePath !== undefined && cameraInfoFor(camera).uniquePath !== null">
|
|
<td>Unique Path:</td>
|
|
<td style="word-break: break-all">{{ cameraInfoFor(camera).uniquePath }}</td>
|
|
</tr>
|
|
</tbody>
|
|
</v-simple-table>
|
|
</div>
|
|
</template>
|