1
0

header.vue 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. <template>
  2. <div class="header-top" :style="{flexDirection: route.name == 'drawShareFile'?'row-reverse':'row'}">
  3. <el-button type="primary" v-show="route.name != 'drawShareFile'" plain @click="emit('backPage')">返 回</el-button>
  4. <h2 v-if="route.name == 'drawShareFile'">现场勘查平面图</h2>
  5. <h2 v-else>创建{{ BoardTypeDesc[type] }}</h2>
  6. <div class="right-pano">
  7. <div class="actions">
  8. <i
  9. class="iconfont icon-repeal"
  10. @click="emit('back')"
  11. :class="{ disable: backDisabled }"
  12. />
  13. <i
  14. class="iconfont icon-recover"
  15. @click="emit('forward')"
  16. :class="{ disable: forwardDisabled }"
  17. />
  18. <el-popover placement="bottom-start" trigger="hover" width="300">
  19. <template #reference>
  20. <i class="iconfont icon-keyboard" />
  21. </template>
  22. <h4 class="quistart-title">快捷键</h4>
  23. <el-form ref="form" label-width="70px" class="quistart">
  24. <el-form-item label="撤销">
  25. <el-input model-value="Ctrl + Z" disabled />
  26. </el-form-item>
  27. <el-form-item label="重做">
  28. <el-input model-value="Ctrl + Y" disabled />
  29. </el-form-item>
  30. <el-form-item label="删除">
  31. <el-input model-value="Backspace、Delete" disabled />
  32. </el-form-item>
  33. <el-form-item label="中心定位">
  34. <el-input model-value="Space" disabled />
  35. </el-form-item>
  36. </el-form>
  37. </el-popover>
  38. </div>
  39. <el-button type="primary" plain @click="emit('save')">保存</el-button>
  40. <el-button plain @click="emit('export')">导出</el-button>
  41. </div>
  42. </div>
  43. </template>
  44. <script setup lang="ts">
  45. import { RouteName, router } from "@/router";
  46. import { BoardType } from "@/store/caseFile";
  47. import { BoardTypeDesc } from "@/constant/caseFile";
  48. import { onMounted, onUnmounted } from "vue";
  49. import { inputIng } from "./c";
  50. const route = router.currentRoute.value;
  51. const props = defineProps<{
  52. type: BoardType;
  53. forwardDisabled?: boolean;
  54. backDisabled?: boolean;
  55. }>();
  56. const emit = defineEmits<{
  57. (e: "backPage"): void;
  58. (e: "forward"): void;
  59. (e: "back"): void;
  60. (e: "viewInit"): void;
  61. (e: "save"): void;
  62. (e: "export"): void;
  63. }>();
  64. const keydownHandler = (ev: KeyboardEvent) => {
  65. if (ev.keyCode === 32) {
  66. emit("viewInit");
  67. } else if (["Control", "Ctrl"].includes(ev.key)) {
  68. const downKey = ev.key;
  69. const secondaryHandler = (ev: KeyboardEvent) => {
  70. if (!inputIng.value) {
  71. if (ev.key.toUpperCase() === "Y" && !props.forwardDisabled) {
  72. emit("forward");
  73. } else if (ev.key.toUpperCase() === "Z" && !props.backDisabled) {
  74. emit("back");
  75. }
  76. }
  77. };
  78. window.addEventListener("keydown", secondaryHandler);
  79. window.addEventListener("keyup", function upHandler(ev) {
  80. if (ev.key === downKey) {
  81. window.removeEventListener("keydown", secondaryHandler);
  82. window.removeEventListener("keyup", upHandler);
  83. }
  84. });
  85. }
  86. };
  87. onMounted(() => window.addEventListener("keydown", keydownHandler));
  88. onUnmounted(() => window.removeEventListener("keydown", keydownHandler));
  89. </script>
  90. <style scoped lang="scss">
  91. .header-top {
  92. position: relative;
  93. h2 {
  94. position: absolute;
  95. text-align: center;
  96. left: 0;
  97. right: 0;
  98. color: #fff;
  99. pointer-events: none;
  100. }
  101. }
  102. .right-pano {
  103. display: flex;
  104. align-items: center;
  105. }
  106. .actions {
  107. margin-right: 60px;
  108. display: flex;
  109. align-items: center;
  110. color: #fff;
  111. font-size: 15px;
  112. > * {
  113. cursor: pointer;
  114. }
  115. > *:not(:last-child) {
  116. margin-right: 32px;
  117. }
  118. }
  119. .quistart {
  120. padding: 12px 16px;
  121. }
  122. .quistart-title {
  123. color: rgba(0, 0, 0, 0.85);
  124. margin-bottom: 7px;
  125. padding: 5px 16px 4px;
  126. font-weight: 500;
  127. font-size: 16px;
  128. font-weight: normal;
  129. border-bottom: 1px solid #f0f0f0;
  130. }
  131. </style>
  132. <style lang="scss">
  133. .header-top {
  134. .el-button--primary:focus,
  135. .el-button--primary:active,
  136. .el-button--primary:hover,
  137. .el-button--primary:focus {
  138. --el-button-hover-text-color: var(--el-color-primary);
  139. --el-button-hover-bg-color: var(--el-fill-color-blank);
  140. --el-button-hover-border-color: var(--el-color-primary);
  141. --el-button-active-text-color: var(--el-color-primary);
  142. --el-button-active-border-color: var(--el-color-primary);
  143. --el-button-active-bg-color: var(--el-fill-color-blank);
  144. }
  145. }
  146. </style>