editMenu.vue 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. <template>
  2. <el-dropdown v-pdpath="'edit'">
  3. <span class="oper-span">
  4. 编辑
  5. <el-icon class="el-icon--right">
  6. <arrow-down />
  7. </el-icon>
  8. </span>
  9. <template #dropdown>
  10. <el-dropdown-menu>
  11. <!-- :disabled="!operateIsPermissionByPath('edit', menu.key)" -->
  12. <el-dropdown-item :disabled="!operateIsPermissionByPath('edit', menu.key)" v-for="menu in menus" :key="menu.key"
  13. @click="menu.onClick()">
  14. {{ menu.label }}
  15. </el-dropdown-item>
  16. </el-dropdown-menu>
  17. </template>
  18. </el-dropdown>
  19. </template>
  20. <script setup lang="ts">
  21. import { computed } from "vue";
  22. import { getFuseCodeLink, checkScenesOpen, MenuItem, getSWKKSyncLink } from "./help";
  23. import { showCaseScenes, addCaseScenes, shareCase, downloadCase } from "./quisk";
  24. import { RouteName, router } from "@/router";
  25. import { copyCase, getCaseSceneList } from "@/store/case";
  26. import { alert } from "@/helper/message";
  27. import { operateIsPermissionByPath } from "@/directive/permission";
  28. const props = defineProps<{
  29. caseId: number;
  30. title?: string;
  31. prevMenu?: MenuItem[];
  32. lastMenu?: MenuItem[];
  33. }>();
  34. const menus = computed(() => {
  35. if (!props.caseId) {
  36. return [];
  37. }
  38. const caseId = props.caseId;
  39. const fuseLink = getFuseCodeLink(caseId);
  40. return [
  41. ...(props.prevMenu || []).map((item) => ({
  42. ...item,
  43. onClick: () => item.onClick(caseId),
  44. })),
  45. {
  46. key: "scene",
  47. disabled: true,
  48. label: "场景管理",
  49. onClick: () =>
  50. showCaseScenes({
  51. caseId,
  52. onAddScenes: () => addCaseScenes({ caseId }),
  53. }),
  54. },
  55. {
  56. key: "fuse",
  57. label: "多元融合",
  58. onClick: () => checkScenesOpen(caseId, `${fuseLink}#fuseEdit/merge`),
  59. },
  60. {
  61. key: "view",
  62. label: "视图提取",
  63. onClick: () => checkScenesOpen(caseId, `${fuseLink}#sceneEdit/view`),
  64. },
  65. {
  66. key: "record",
  67. label: "屏幕录制",
  68. onClick: () => checkScenesOpen(caseId, `${fuseLink}#sceneEdit/record`),
  69. },
  70. {
  71. key: "file",
  72. label: "卷宗管理",
  73. onClick: () => {
  74. window.open(
  75. router.resolve({ name: RouteName.caseFile, params: { caseId: caseId } }).href
  76. );
  77. },
  78. },
  79. {
  80. key: "sync",
  81. label: "带看",
  82. onClick: async () => {
  83. const href = await getSWKKSyncLink(caseId);
  84. window.open(href);
  85. },
  86. },
  87. {
  88. key: "share",
  89. label: "分享",
  90. onClick: async () => {
  91. const scenes = await getCaseSceneList(caseId);
  92. if (!scenes.length) {
  93. alert("当前案件下无场景,请先添加场景。");
  94. } else {
  95. shareCase({ caseId: caseId });
  96. }
  97. },
  98. },
  99. // 参。。
  100. {
  101. key: "download",
  102. label: "下载",
  103. onClick: async () => {
  104. const scenes = await getCaseSceneList(caseId);
  105. if (!scenes.length) {
  106. alert("当前案件下无场景,请先添加场景。");
  107. } else {
  108. // console.log('props.title', props)
  109. // debugger
  110. downloadCase({ caseId, title: props.title });
  111. }
  112. },
  113. },
  114. ...(props.lastMenu || []).map((item) => ({
  115. ...item,
  116. onClick: () => item.onClick(caseId),
  117. })),
  118. ];
  119. });
  120. </script>