feat: Implement WebcamFileSource for life webcam capture #12

Open
busti wants to merge 51 commits from busti/proto/frontend into jedi/proto/frontend
2 changed files with 123 additions and 58 deletions
Showing only changes of commit 02e41214d2 - Show all commits

View file

@ -4,38 +4,48 @@
<div class="row"> <div class="row">
<div class="col"> <div class="col">
<div class="card"> <div class="card">
<div class="card-header">Inventory</div> <div class="card-header">Edit Item</div>
<div class="card-body"> <div class="card-body">
<table class="table table-striped"> <div class="mb-3">
<thead> <span class="badge bg-dark" v-for="(tag, index) in item.tags" :key="index">
<tr> {{ tag }}
<th>Item</th> </span>
<th>Quantity</th> </div>
<th>Owner</th> <div class="mb-3">
<th>Actions</th> <span class="badge bg-dark" v-for="(property, index) in item.properties" :key="index">
</tr> {{ property.name }}={{ property.value }}
</thead> </span>
<tbody> </div>
<tr v-for="item in inventory_items" :key="item.id"> <div class="mb-3">
<td>{{ item.name }}</td> <label for="name" class="form-label">Name</label>
<td>{{ item.quantity }}</td> <input type="text" class="form-control" id="name" name="name"
<td>{{ item.owner }}</td> placeholder="Enter item name" v-model="item.name">
<td> </div>
<a href="#"> <div class="mb-3">
<b-icon-pencil-square></b-icon-pencil-square> <label for="description" class="form-label">Description</label>
</a> <textarea class="form-control" id="description" name="description"
<a href="#"> placeholder="Enter description" v-model="item.description"></textarea>
<b-icon-trash></b-icon-trash> </div>
</a> <div class="mb-3">
</td> <label for="quantity" class="form-label">Quantity</label>
</tr> <input type="number" class="form-control" id="quantity" name="quantity"
</tbody> placeholder="Enter quantity" v-model="item.quantity">
</table> </div>
</div> <div class="mb-3">
<div class="card"> <label for="price" class="form-label">Price</label>
<button class="btn" @click="getInventoryItems">Refresh</button> <input type="number" class="form-control" id="price" name="price"
<router-link to="/inventory/new" class="btn btn-primary">Add</router-link> placeholder="Enter price" v-model="item.price">
</div>
<div class="mb-3">
<label for="image" class="form-label">Image</label>
<input type="text" class="form-control" id="image" name="image"
placeholder="Enter image" v-model="item.image">
</div>
</div> </div>
<!--div class="card">
<button type="submit" class="btn btn-primary" @click="updateInventoryItem(item)">Update
</button>
</div-->
</div> </div>
</div> </div>
</div> </div>
@ -46,10 +56,26 @@
<script> <script>
import * as BIcons from "bootstrap-icons-vue"; import * as BIcons from "bootstrap-icons-vue";
import BaseLayout from "@/components/BaseLayout.vue"; import BaseLayout from "@/components/BaseLayout.vue";
import TagField from "@/components/TagField.vue";
import PropertyField from "@/components/PropertyField.vue";
export default { export default {
name: "InventoryDetail", name: "InventoryDetail",
data() {
return {
item: {
name: "",
description: "",
quantity: 0,
price: 0,
image: "",
tags: [],
properties: []
}
}
},
components: { components: {
PropertyField, TagField,
BaseLayout, BaseLayout,
...BIcons ...BIcons
}, },

View file

@ -4,37 +4,55 @@
<div class="row"> <div class="row">
<div class="col"> <div class="col">
<div class="card"> <div class="card">
<div class="card-header">Inventory</div> <div class="card-header">Edit Item</div>
<div class="card-body"> <div class="card-body">
<table class="table table-striped"> <div class="mb-3">
<thead> <ul>
<tr> <li v-for="tag in item.tags" :key="tag">
<th>Item</th> {{ tag }}
<th>Quantity</th> </li>
<th>Owner</th> </ul>
<th>Actions</th> <label for="tags" class="form-label">Tags</label>
</tr> <tag-field :value="item.tags"></tag-field>
</thead> </div>
<tbody> <div class="mb-3">
<tr v-for="item in inventory_items" :key="item.id"> <ul>
<td>{{ item.name }}</td> <li v-for="property in item.properties" :key="property">
<td>{{ item.quantity }}</td> {{ property.name }}: {{ property.value }}
<td>{{ item.owner }}</td> </li>
<td> </ul>
<a href="#"> <label for="property" class="form-label">Property</label>
<b-icon-pencil-square></b-icon-pencil-square> <property-field :value="item.properties"></property-field>
</a> </div>
<a href="#"> <div class="mb-3">
<b-icon-trash></b-icon-trash> <label for="name" class="form-label">Name</label>
</a> <input type="text" class="form-control" id="name" name="name"
</td> placeholder="Enter item name" v-model="item.name">
</tr> </div>
</tbody> <div class="mb-3">
</table> <label for="description" class="form-label">Description</label>
<textarea class="form-control" id="description" name="description"
placeholder="Enter description" v-model="item.description"></textarea>
</div>
<div class="mb-3">
<label for="quantity" class="form-label">Quantity</label>
<input type="number" class="form-control" id="quantity" name="quantity"
placeholder="Enter quantity" v-model="item.quantity">
</div>
<div class="mb-3">
<label for="price" class="form-label">Price</label>
<input type="number" class="form-control" id="price" name="price"
placeholder="Enter price" v-model="item.price">
</div>
<div class="mb-3">
<label for="image" class="form-label">Image</label>
<input type="text" class="form-control" id="image" name="image"
placeholder="Enter image" v-model="item.image">
</div>
</div> </div>
<div class="card"> <div class="card">
<button class="btn" @click="getInventoryItems">Refresh</button> <button type="submit" class="btn btn-primary" @click="updateInventoryItem(item)">Update
<router-link to="/inventory/new" class="btn btn-primary">Add</router-link> </button>
</div> </div>
</div> </div>
</div> </div>
@ -45,14 +63,35 @@
<script> <script>
import * as BIcons from "bootstrap-icons-vue"; import * as BIcons from "bootstrap-icons-vue";
import {mapActions} from "vuex";
import BaseLayout from "@/components/BaseLayout.vue"; import BaseLayout from "@/components/BaseLayout.vue";
import TagField from "@/components/TagField.vue";
import PropertyField from "@/components/PropertyField.vue";
export default { export default {
name: "InventoryEdit", name: "InventoryEdit",
data() {
return {
item: {
name: "",
description: "",
quantity: 0,
price: 0,
image: "",
tags: [],
properties: []
}
}
},
components: { components: {
BaseLayout, BaseLayout,
TagField,
PropertyField,
...BIcons ...BIcons
}, },
methods: {
...mapActions(["updateInventoryItem"]),
},
} }
</script> </script>