LinYeFangHuo/src/views/preview/suspenseIndex.vue

118 lines
3.3 KiB
Vue

<template>
<div
:class="`go-preview ${chartEditStore.editCanvasConfig.previewScaleType}`"
@mousedown="dragCanvas"
>
<template v-if="showEntity">
<!-- -->
<div ref="entityRef" class="go-preview-entity">
<!-- 缩放层 -->
<div ref="previewRef" class="go-preview-scale">
<!-- 展示层 -->
<div :style="previewRefStyle" v-if="show">
<!-- -->
<preview-render-list></preview-render-list>
</div>
</div>
</div>
</template>
<template v-else>
<!-- -->
<div ref="previewRef" class="go-preview-scale">
<!-- 展示层 -->
<div :style="previewRefStyle" v-if="show">
<!-- -->
<preview-render-list></preview-render-list>
</div>
</div>
</template>
</div>
</template>
<script setup lang="ts">
import { computed, watch } from 'vue';
import { PreviewRenderList } from './components/PreviewRenderList';
import { getFilterStyle, setTitle } from '@/utils';
import {
getEditCanvasConfigStyle,
getSessionStorageInfo,
keyRecordHandle,
dragCanvas,
} from './utils';
import { useComInstall } from './hooks/useComInstall.hook';
import { useScale } from './hooks/useScale.hook';
import { useStore } from './hooks/useStore.hook';
import { PreviewScaleEnum } from '@/enums/styleEnum';
import type { ChartEditStorageType } from './index.d';
import { useChartEditStore } from '@/store/modules/chartEditStore/chartEditStore';
import { useRoute } from 'vue-router';
// const localStorageInfo: ChartEditStorageType = getSessionStorageInfo() as ChartEditStorageType
const route = useRoute();
await getSessionStorageInfo();
const chartEditStore = useChartEditStore() as unknown as ChartEditStorageType;
console.log('chartEditStore', chartEditStore);
setTitle(`预览-${chartEditStore.editCanvasConfig.projectName}`);
const previewRefStyle = computed(() => {
return {
overflow: 'hidden',
...getEditCanvasConfigStyle(chartEditStore.editCanvasConfig),
...getFilterStyle(chartEditStore.editCanvasConfig),
};
});
const showEntity = computed(() => {
const type = chartEditStore.editCanvasConfig.previewScaleType;
return type === PreviewScaleEnum.SCROLL_Y || type === PreviewScaleEnum.SCROLL_X;
});
useStore(chartEditStore);
const { entityRef, previewRef } = useScale(chartEditStore);
const { show } = useComInstall(chartEditStore);
// 开启键盘监听
keyRecordHandle();
watch(
() => route.fullPath,
(newValue) => {
location.reload();
},
);
</script>
<style lang="scss" scoped>
@include go('preview') {
position: relative;
height: 100vh;
width: 100vw;
@include background-image('background-image');
&.fit,
&.full {
display: flex;
align-items: center;
justify-content: center;
overflow: hidden;
.go-preview-scale {
transform-origin: center center;
}
}
&.scrollY {
overflow-x: hidden;
.go-preview-scale {
transform-origin: left top;
}
}
&.scrollX {
overflow-y: hidden;
.go-preview-scale {
transform-origin: left top;
}
}
.go-preview-entity {
overflow: hidden;
}
}
</style>