Newer
Older
urbanLifeline_YanAn / src / views / oneMap / components / FXHG.vue
@jimengfei jimengfei on 17 Oct 4 KB updata
<template>
  <div id="ZHPS">
    <!-- 汛情回顾头部日历 -->
    <TopTimePick @selectTime="selectTime" v-if="!showPanel" />
    <div :class="['LeftBox', 'animate__animated', showPanel ? 'animate__fadeOutLeft' : 'animate__fadeInLeft']">
      <xqhgLeftBox />
    </div>
    <div :class="['RightBox', 'animate__animated', showPanel ? 'animate__fadeOutRight' : 'animate__fadeInRight']">
      <xqRightBox />
    </div>
    <div :class="['BottomBox', 'animate__animated', showPanel ? 'animate__bounceInUp' : 'animate__bounceInUp']" v-if="showBottom">
      <sqhgBottomBox :checkTime="checkTime" />
    </div>
  </div>
  <div v-if="showPanel == false" class="bnt" @click="goBack">返回</div>
  <FHPL v-if="curType == true" />
</template>

<script setup name="ZHPS">
import { ref, reactive, toRefs, onMounted, onBeforeUnmount } from 'vue';
import FHPL from '@/views/oneMap/components/FHPL.vue';
import TopTimePick from '@/views/oneMap/components/topTimePick.vue';
import xqhgLeftBox from '@/views/oneMap/FloodStuationReview/xqhgLeftBox.vue';
import xqRightBox from '@/views/oneMap/FloodStuationReview/xqRightBox.vue';
import sqhgBottomBox from '@/views/oneMap/FloodStuationReview/sqhgBottomBox.vue';
import bus from '@/bus';
const AllData = reactive({});
const curType = ref(false);
const showPanel = ref(true); //面板展开收起
const showBottom = ref(true);
const control = ref('1');
// 面板内容展开收起控制
const props = defineProps({
  showPanel: {
    type: Boolean,
  },
});
let checkTime = ref('');
function goBack(params) {
  showPanel.value = true;
  showBottom.value = false;
  curType.value = true;
  bus.emit('SetLayerShow', ['蓝色地图']);
  if (newfiberMapbox.map.getLayer('dynamicRoute')) {
    newfiberMapbox.map.removeLayer('dynamicRoute');
    newfiberMapbox.map.removeLayer('dynamicRoute_Symbol');
    newfiberMapbox.map.removeSource('dynamicRoute');
    newfiberMapbox.map.removeSource('dynamicRoute_Symbol');
    clearInterval(window.routeTimer);
  }
  newfiberMapbox.map.setBearing(0);
}
function selectTime(time) {
  checkTime.value = time;
}
watch(
  () => props.showPanel,
  () => {
    showPanel.value = props.showPanel;
  },
  { immediate: true }
);
onMounted(() => {
  bus.emit('checkBottom', control.value);

  //接受日历
  bus.on('checkRili', params => {
    console.log(params, '接收paramsparamsparams');
  });

  let initePSTimer = setInterval(() => {
    if (!newfiberMapbox) return;
    bus.emit('SetLayerShow', ['白色地图']);
    bus.emit('setLayerVisible', { layername: 'pipeline_info_flow_ys', isCheck: true });
    //bus.emit('setLayerVisible', { layername: 'wsLine1', isCheck: true });
    clearInterval(initePSTimer);
  }, 100);
});
onBeforeUnmount(() => {
  bus.emit('setLayerVisible', { layername: 'pipeline_info_flow_ys', isCheck: false });
  //bus.emit('setLayerVisible', { layername: 'wsLine1', isCheck: false });
});
</script>

<style lang="scss" scoped>
#ZHPS {
  .LeftBox {
    width: 450px;
    height: calc(100% - 98px);
    position: absolute;
    left: 10px;
    top: 70px;
    background: linear-gradient(0deg, rgba(0, 93, 114, 0.8) 0%, rgba(0, 93, 114, 0.8) 100%);
    border-radius: 6px;
    border: 1px solid #47eef3;
    box-shadow: inset 0 0 5px 5px #47eef38a;
  }
  .RightBox {
    width: 450px;
    height: calc(100% - 98px);
    position: absolute;
    right: 10px;
    top: 70px;
    background: linear-gradient(0deg, rgba(0, 93, 114, 0.8) 0%, rgba(0, 93, 114, 0.8) 100%);
    border-radius: 6px;
    border: 1px solid #47eef3;
    box-shadow: inset 0 0 5px 5px #47eef38a;
    z-index: 120;
  }
  .BottomBox {
    width: 900px;
    height: 260px;
    position: absolute;
    right: 500px;
    bottom: 70px;
    background: linear-gradient(0deg, rgba(0, 93, 114, 0.8) 0%, rgba(0, 93, 114, 0.8) 100%);
    border-radius: 6px;
    border: 1px solid #47eef3;
    box-shadow: inset 0 0 5px 5px #47eef38a;
  }
}
.bnt {
  width: 62px;
  height: 62px;
  position: absolute;
  left: 520px;
  bottom: 340px;
  background: url('@/assets/images/fhpl/rkan_bnt.png') no-repeat;
  background-size: 100% 100%;
  cursor: pointer;

  font-family: Source Han Sans CN;
  font-weight: 500;
  font-size: 16px;
  color: #ffffff;
  line-height: 60px;
  padding-left: 14px;
}
</style>