TextElementOperate.vue 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. <template>
  2. <div class="text-element-operate">
  3. <BorderLine
  4. class="operate-border-line"
  5. v-for="line in borderLines"
  6. :key="line.type"
  7. :type="line.type"
  8. :style="line.style"
  9. />
  10. <template v-if="!elementInfo.lock && (isActiveGroupElement || !isMultiSelect)">
  11. <ResizeHandler
  12. class="operate-resize-handler"
  13. v-for="point in textElementResizeHandlers"
  14. :key="point.direction"
  15. :type="point.direction"
  16. :style="point.style"
  17. @mousedown.stop="$event => scaleElement($event, elementInfo, point.direction)"
  18. />
  19. <RotateHandler
  20. class="operate-rotate-handler"
  21. :style="{ left: scaleWidth / 2 + 'px' }"
  22. @mousedown.stop="rotateElement(elementInfo)"
  23. />
  24. </template>
  25. </div>
  26. </template>
  27. <script lang="ts">
  28. import { computed, defineComponent, PropType } from 'vue'
  29. import { useStore } from '@/store'
  30. import { PPTTextElement } from '@/types/slides'
  31. import { OperateResizeHandler } from '@/types/edit'
  32. import useCommonOperate from '../hooks/useCommonOperate'
  33. import RotateHandler from './RotateHandler.vue'
  34. import ResizeHandler from './ResizeHandler.vue'
  35. import BorderLine from './BorderLine.vue'
  36. export default defineComponent({
  37. name: 'text-element-operate',
  38. inheritAttrs: false,
  39. components: {
  40. RotateHandler,
  41. ResizeHandler,
  42. BorderLine,
  43. },
  44. props: {
  45. elementInfo: {
  46. type: Object as PropType<PPTTextElement>,
  47. required: true,
  48. },
  49. isActiveGroupElement: {
  50. type: Boolean,
  51. required: true,
  52. },
  53. isMultiSelect: {
  54. type: Boolean,
  55. required: true,
  56. },
  57. rotateElement: {
  58. type: Function as PropType<(element: PPTTextElement) => void>,
  59. required: true,
  60. },
  61. scaleElement: {
  62. type: Function as PropType<(e: MouseEvent, element: PPTTextElement, command: OperateResizeHandler) => void>,
  63. required: true,
  64. },
  65. },
  66. setup(props) {
  67. const store = useStore()
  68. const canvasScale = computed(() => store.state.canvasScale)
  69. const scaleWidth = computed(() => props.elementInfo.width * canvasScale.value)
  70. const scaleHeight = computed(() => props.elementInfo.height * canvasScale.value)
  71. const { textElementResizeHandlers, borderLines } = useCommonOperate(scaleWidth, scaleHeight)
  72. return {
  73. scaleWidth,
  74. textElementResizeHandlers,
  75. borderLines,
  76. }
  77. },
  78. })
  79. </script>