bind.vue 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. <template>
  2. <el-form ref="form" label-width="100px" class="camera-from">
  3. <el-form-item label="SN码:" class="mandatory">
  4. <el-input
  5. :modelValue="bindCamera.snCode"
  6. placeholder="请输入相机底部SN码,如214D5RE2G8"
  7. @update:modelValue="(val: string) => (bindCamera.snCode = val.trim())"
  8. ></el-input>
  9. </el-form-item>
  10. <el-form-item label="所属架构:" class="mandatory">
  11. <com-company v-model="bindCamera.deptId" hide-all />
  12. </el-form-item>
  13. <el-form-item label="管理员:" class="mandatory">
  14. <el-select v-model="bindCamera.userId" placeholder="请选择" style="width: 100%">
  15. <el-option
  16. v-for="item in users"
  17. :key="item.id"
  18. :label="item.nickName"
  19. :value="item.id"
  20. />
  21. </el-select>
  22. </el-form-item>
  23. </el-form>
  24. </template>
  25. <script setup lang="ts">
  26. import comCompany from "@/components/company-select/index.vue";
  27. import { Camera, addCamera } from "@/store/camera";
  28. import { UserInfo, getUsers } from "@/store/user";
  29. import { ref, watchEffect } from "vue";
  30. import { ElMessage } from "element-plus";
  31. import { QuiskExpose } from "@/helper/mount";
  32. const props = defineProps<{ camera?: Camera }>();
  33. const bindCamera = ref<Camera>(
  34. (props.camera ? { ...props.camera } : { cameraSn: "", snCode: "" }) as Camera
  35. );
  36. const users = ref<UserInfo[]>([]);
  37. watchEffect(async () => {
  38. if (bindCamera.value.deptId) {
  39. users.value = await getUsers(bindCamera.value.deptId);
  40. if (users.value.length === 1) {
  41. bindCamera.value.userId = users.value[0].id;
  42. }
  43. }
  44. });
  45. defineExpose<QuiskExpose>({
  46. async submit() {
  47. if (!bindCamera.value.snCode || !bindCamera.value.snCode.trim()) {
  48. ElMessage.error("SN码不能为空");
  49. throw "SN码不能为空";
  50. } else if (!bindCamera.value.userId) {
  51. ElMessage.error("请选择管理员");
  52. throw "请选择管理员";
  53. } else {
  54. await addCamera(bindCamera.value);
  55. return bindCamera.value;
  56. }
  57. },
  58. });
  59. </script>