Newer
Older
DH_Apicture / src / views / pictureOnMap / page / components / DialogTabs / component / PointAndLine.vue
@ZZJ ZZJ 21 days ago 22 KB 修改中文字段
<template>
  <div id="PointAndLine">
    <div class="items-content">
      <div class="contentitem" v-for="p in GXOBJ" :key="p" v-show="p.name != 'geometry'" :class="[p.type]">
        <el-tooltip class="item" effect="light" placement="top" :content="p.name">
          <div class="name gxname">{{ p.name }}</div>
        </el-tooltip>
        <div v-if="p.type == 'img'">
          <div class="">
            <el-image
              v-for="i in p.value.split(',')"
              :key="i"
              style="width: 100px; height: 100px; margin-left: 5px"
              :src="i"
              :zoom-rate="1.2"
              :max-scale="7"
              :min-scale="0.2"
              :preview-src-list="p.value.split(',')"
              :initial-index="4"
              fit="cover"
            />
          </div>
        </div>
        <el-tooltip
          v-else
          popper-class="custom-tooltip"
          class="item"
          effect="light"
          placement="top"
          :content="typeof p.value == 'number' ? p.value.toFixed(3) : p.value || '-'"
        >
          <div class="value gxvalue">:{{ typeof p.value == 'number' ? p.value.toFixed(3) : p.value || '-' }}</div>
        </el-tooltip>
      </div>

      <div class="buttoncss" v-if="typearr.includes(dataCode)">
        <el-button type="primary" @click="guanxianAnalysis('up')">上游分析</el-button>
        <el-button type="primary" @click="guanxianAnalysis('down')">下游分析</el-button>
        <!-- <el-button type="primary" @click="guanxianAnalysis('updown')" >上下游分析</el-button>
              <el-button type="primary" @click="guanxianAnalysis('connectivity')">连通性分析</el-button> -->
        <!-- <el-button type="primary"  @click="guanxianAnalysis('question')">问题分析</el-button> -->
      </div>
    </div>
  </div>
</template>

<script setup name="PointAndLine">
import bus from '@/bus';
import {
  downStreamAnalyse,
  upStreamAnalyse,
  connectAnalyse,
  selectByPointNumber,
  getByPipeLineCode,
} from '@/api/MonitorAssetsOnMap';
const { proxy } = getCurrentInstance();
const { ownership } = proxy.useDict('ownership');
const props = defineProps({
  // 数据id
  dataID: {
    type: String,
  },
  dataCode: {
    type: String,
  },
  // 默认打开tabs的key
  RefreshName: {
    type: String,
  },
  tabsType: {
    type: String,
  },
  typeName: {
    type: String,
  },
  Getproperties: {
    type: Object,
  },
});

const typearr = ['pipeline_point', 'pipeline_info', 'pipeline_info_text'];

const setnamobj = ref([]);
const GXOBJ = ref();
// [
//   { name: '湖泊名称', value: '' },
//   { name: '湖泊类型', value: '' },
//   { name: '所属水系', value: '' },
//   { name: '境内面积km²', value: '' },
//   { name: '总面积km²', value: '' },
//   { name: '湖泊库容(万m³)', value: '' },
//   { name: '总库容(万m³)', value: '' },
//   { name: '岸线长度km', value: '' },
//   { name: '水质目标', value: '' },
//   { name: '常水位(m)', value: '' },
//   { name: '生态水位(m)', value: '' },
//   { name: '控制水位(m)', value: '' },
//   { name: '管理部门', value: '', type: '' },
//   { name: '描述', value: '', type: 'textarea' },
//   { name: '图片', value: '1,2', type: 'img' },
// ]
/**
 * 根据经纬度和属性区分名称
 * @param {Object} properties - 包含其他属性的对象
 */
function Distinguishnames() {
  console.log('props', props);
  let properties = cleanKeyNames(props.Getproperties);
  console.log('properties', properties);
  // 假设GXOBJ.value 与本函数无关,如果它也需要被清空或重置,可以取消下面这行的注释
  GXOBJ.value = [];
  // 清除现有的 setnamobj.value(如果需要的话)
  setnamobj.value = [];
  switch (props.dataCode) {
    case 'pipeline_info_text':
      // setnamobj.value = [
      //   '管段编码',
      //   '起始井号',
      //   '终止井号',
      //   '管线材质',
      //   '管径',
      //   '起点埋深',
      //   '终点埋深',
      //   '起点高程',
      //   '终点高程',
      //   '管段类型',
      //   '道路名称',
      //   '管网归属',
      //   '测区',
      //   '维护管理单位',
      //   '管段长度',
      // ];
      pointOrline('line');

      return;
    case 'pipeline_info':
      pointOrline('line');

      // setnamobj.value = [
      //   '管段编码',
      //   '起始井号',
      //   '终止井号',
      //   '管线材质',
      //   '管径',
      //   '起点埋深',
      //   '终点埋深',
      //   '起点高程',
      //   '终点高程',
      //   '管段类型',
      //   '道路名称',
      //   '管网归属',
      //   '测区',
      //   '维护管理单位',
      //   '管段长度',
      // ];
      return;
    case 'pipeline_point':
      pointOrline('point');
      // let nameobj = [
      //   '设施编号',
      //   '地面高程',
      //   '井盖尺寸',
      //   '井盖材质',
      //   '井深',
      //   '井径',
      //   '特征',
      //   '类型',
      //   '附属物',
      //   '管网归属',
      //   '维护管理单位',
      //   '道路名称',
      // ];

      // GXOBJ.value.push({ name: k, value: properties[k] });

      // let dmgc = '';
      // let js = '';
      // // 井底高程:地面高程-井深

      // for (var k in properties) {
      //   if (nameobj.includes(k)) {
      //     GXOBJ.value.push({ name: k, value: properties[k] });
      //   } //
      //   if (k == '地面高程') {
      //     dmgc = properties[k];
      //   }
      //   if (k == '井深') {
      //     js = properties[k];
      //   }
      // }
      // GXOBJ.value.push({ name: '井底高程', value: dmgc - js || 0 });

      return;
    // break;
    case '已建管网测点':
      setnamobj.value = ['站点名称', '站点编号'];

      GXOBJ.value = [
        { name: '站点名称', value: properties.st_name },
        { name: '站点编号', value: properties.st_code },
      ];

      break;
    case 'point':
      setnamobj.value = [
        '管段编码',
        '起始井号',
        '终止井号',
        '管线材质',
        '管径',
        '起点埋深',
        '终点埋深',
        '起点高程',
        '终点高程',
        '管段类型',
        '道路名称',
        '管网归属',
        '测区',
        '维护管理单位',
        '管段长度',
        '大管套小管',
        '断头管',
        '雨污混接',
        '管网逆坡',
      ];

      GXOBJ.value = [
        { name: '所在排水系统', value: properties.drainageSystem },
        { name: '起始井号', value: properties.startPointNumber },
        { name: '终止井号', value: properties.endPointNumber },
        { name: '管线材质', value: properties.pipelineTexture },
        { name: '管径', value: properties.pipelineDiameter },
        { name: '起点埋深', value: properties.startGroundDepth },
        { name: '终点埋深', value: properties.endGroundDepth },
        { name: '起点高程', value: properties.startCopNoseElevation },
        { name: '终点高程', value: properties.endCopNoseElevation },
        { name: '管段类型', value: properties.sectionType },
        { name: '道路名称', value: properties.roadName },
        {
          name: '管网归属',
          value:
            ownership.value.filter(item => {
              return item.value == properties.ownershipUnits;
            })[0].label || '-',
        },
        { name: '管段长度', value: properties.pipelineLength },
        { name: '建设年代', value: properties.constructionDate },
        // { name: "大管套小管", value: properties.bigCoverSmallReason  },
        // { name: "断头管", value: properties.cutOffReason},
        // { name: "雨污混接",  value: properties.mixReason  },
        // { name: "管网逆坡",  value: properties.reverseSlopeReason },
        // { name: "流向错误", value: properties.flowDirectionWrongReason  },
      ];
      if (properties.bigCoverSmallReason) {
        GXOBJ.value = [...GXOBJ.value, { name: '大管套小管', value: properties.bigCoverSmallReason }];
      }
      if (properties.cutOffReason) {
        GXOBJ.value = [...GXOBJ.value, { name: '断头管', value: properties.cutOffReason }];
      }
      if (properties.mixReason) {
        GXOBJ.value = [...GXOBJ.value, { name: '雨污混接', value: properties.mixReason }];
      }
      if (properties.reverseSlopeReason) {
        GXOBJ.value = [...GXOBJ.value, { name: '管网逆坡', value: properties.reverseSlopeReason }];
      }
      // if (properties.flowDirectionWrongReason) {
      //   GXOBJ.value = [...GXOBJ.value, { name: '流向错误', value: properties.flowDirectionWrongReason }];
      // }
      // 流向错误
      break;
    case '缺陷管点':
      setnamobj.value = [
        '填报单位',
        '所属流域',
        '投入使用年限',
        '管网是否已移交',
        '管道材质',
        '管道类型',
        '管道缺陷类型',
        '维护管理单位',
        '联系方式',
        '负责人',
        '道路名称',
        '需改造长度m',
        '需要改造内容',
      ];

      break;
    default:
      // 如果没有匹配到任何id,可以设置默认值或空数组
      setnamobj.value = [];
      console.log('未知的id:', props.dataCode);
      return;
  }

  setobj(properties);
}

function pointOrline(type) {
  if (type == 'point') {
    // 井底高程:地面高程-井深
    let prams = {
      pointNumber: props.Getproperties['外业点号'],
    };
    selectByPointNumber(prams).then(res => {
      console.log(res.data);
      let obj = res.data;
      GXOBJ.value = [
        { name: '设施编号', value: obj.pointNumber || '-' },
        { name: '地面高程(m)', value: obj.groundElevation || '-' },
        { name: '井盖尺寸(m)', value: obj.manholeCoverSize || '-' },
        { name: '井盖材质', value: obj.pointTexture || '-' },
        { name: '井深(m)', value: obj.bottomBuriedDepth || '-' },
        { name: '井径(m)', value: obj.wellDiameter || '-' },
        { name: '特征', value: obj.features || '-' },
        { name: '坡度', value: obj.slope || '-' },
        { name: '类型', value: (obj.pointType = 'YS' ? '雨水' : '污水' || '-') },
        { name: '附属物', value: obj.appendage || '-' },
        {
          name: '管网归属',
          value:
            ownership.value.filter(item => {
              return item.value == obj.ownershipUnits;
            })[0].label || '-',
        },

        { name: '维护管理单位', value: obj.operationalUnits || '-' },
        { name: '道路名称', value: obj.roadName || '-' },
        { name: '井底高程(m)', value: obj.groundElevation - obj.bottomBuriedDepth || '-' },
      ];
    });
  }
  if (type == 'line') {
    let prams = {
      pipeLineCode: props.Getproperties['管段编码'],
    };
    getByPipeLineCode(prams).then(res => {
      console.log(res.data);

      let obj2 = res.data;
      GXOBJ.value = [
        { name: '排水系统', value: obj2.drainageSystem || '-' },
        { name: '管道类别', value: obj2.pipelineType == 'YS' ? '雨水' : '污水' || '-' },
        { name: '起点编号', value: obj2.startPointNumber || '-' },
        { name: '终点编号', value: obj2.endPointNumber || '-' },
        { name: '管线材质', value: obj2.pipelineTexture || '-' },
        { name: '管径(mm)', value: obj2.pipelineDiameter || '-' },
        { name: '起点埋深(m)', value: obj2.startGroundDepth || '-' },
        { name: '终点埋深(m)', value: obj2.endGroundDepth || '-' },
        { name: '起点高程(m)', value: obj2.startCopNoseElevation || '-' },
        { name: '终点高程(m)', value: obj2.endCopNoseElevation || '-' },
        { name: '道路名称', value: obj2.roadName || '-' },
        {
          name: '权属单位',
          value:
            ownership.value.filter(item => {
              return item.value == obj2.ownershipUnits;
            })[0].label || '-',
        },
        { name: '管段长度(m)', value: obj2.pipelineLength || '-' },
        { name: '断面类型', value: obj2.sectionType || '-' },
        { name: '管径宽(mm)', value: obj2.sectionDataTwo || '-' },
      ];
    });
  }
}

function setobj(properties) {
  console.log('aaaa', properties, setnamobj.value);
  if (properties) {
    for (var k in properties) {
      if (setnamobj.value.includes(k)) {
        GXOBJ.value.push({ name: k, value: properties[k] });
      }
    }

    // 创建一个映射,用于快速查找setnamobj.value中元素的索引
    let indexMap = {};
    setnamobj.value.forEach((name, index) => {
      indexMap[name] = index;
    });

    // 使用sort方法和自定义比较函数来排序GXOBJ.value
    GXOBJ.value.sort((a, b) => {
      return indexMap[a.name] - indexMap[b.name];
    });
  }
}

function cleanKeyNames(obj) {
  let newObj = {};

  // 遍历输入对象的所有属性
  for (let key in obj) {
    // 假设“清理”过程就是去除键名中的换行符(尽管在标准情况下这是不必要的)
    let cleanKey = key.replace(/\n/g, ''); // 去除换行符

    // 将清理后的键名和原始属性值复制到新对象中
    newObj[cleanKey] = obj[key];
  }

  return newObj;
}

const key = '问题管线';
const isConnectivity = ref(false); //记录是否选择连通性分析
const oldConnectivityData = ref({}); //上一个择连通性分析数据
const guanxianAnalysis = async type => {
  let properties = props.Getproperties;

  // properties['起始外业点号'] = 'I2206PYS1010172';
  // properties['终止外业点号'] = 'I2206PYS1010221';
  console.log('properties123', properties);
  console.log('type123', type);
  let results = {};
  bus.emit('removeMapDatas', [key]);

  if (properties['管段编码']) {
    const startEnds = _.chunk(properties['管段编码'], properties['管段编码'].length / 2).map(o => o.join(''));
    properties['起始外业点号'] = startEnds[0];
    properties['终止外业点号'] = startEnds[1];
  }
  const methods = {
    up: upStreamAnalyse,
    down: downStreamAnalyse,
    connectivity: connectAnalyse,
    question: upStreamAnalyse,
  }[type];
  if (!isConnectivity.value && type == 'connectivity') {
    oldConnectivityData.value = properties;
    isConnectivity.value = true;
    proxy.$modal.msgWarning('请再次选择需要连通性分析的另一条管线或管点进行分析');
    bus.emit('closedia', [key]);

    return;
  } else if (isConnectivity.value) {
    //流通性分析 第二条管网
    proxy.$modal.msgSuccess('正在进行流通性分析······');

    isConnectivity.value = false;
    results = await methods({
      startPointNumber: oldConnectivityData.value['起始外业点号'] || properties['外业点号'],
      endPointNumber: properties['终止外业点号'] || properties['外业点号'],
    });
    oldConnectivityData.value = {};

    gx_DataFun(results, properties, type);
    bus.emit('closedia', [key]);
  } else if (type == 'updown') {
    let params = {
      startPointNumber: properties['起始外业点号'] || properties['外业点号'],
      endPointNumber: properties['终止外业点号'] || properties['外业点号'],
    };
    await upStreamAnalyse(params).then(res => {
      console.log('上下游1', res);
      gx_DataFun(res, properties, type);
    });
    await downStreamAnalyse(params).then(res => {
      console.log('上下游2', res);
      gx_DataFun(res, properties, type);
    });
  } else {
    oldConnectivityData.value = {};
    isConnectivity.value = false;
    proxy.$modal.msgSuccess('正在分析中······');
    results = await methods({
      startPointNumber: properties['起始外业点号'] || properties['外业点号'],
      endPointNumber: properties['终止外业点号'] || properties['外业点号'],
    });
    gx_DataFun(results, properties, type);
  }
};

// 管线分析处理方法
const gx_DataFun = (results, properties, type) => {
  proxy.$modal.msgSuccess('分析完成!');

  const properKs = [
    { key: 'bigCoverSmallFlag', value: '大管套小管' },
    { key: 'cutOffFlag', value: '断头管' },
    { key: 'mixFlag', value: '雨污混接' },
    { key: 'reverseSlopeFlag', value: '管网逆坡' },
    // { key: 'flowDirectionWrongFlag', value: '流向错误' },
  ];
  //问题管线
  // errorText(i.properties)
  const questionLinePoints = results.data.pipelineInfoList
    .filter(i => properKs.map(k => eval(i[k.key])).filter(Boolean)[0])
    .map(i => ({
      ...turf.center(turf.feature(Terraformer.WKT.parse(i.geometrys))),
      properties: i,
    }))
    .map(i => ({
      ...i,
      properties: {
        ...i.properties,
        name: `${key}:\n${properKs
          .map((k, o) => eval(i.properties[k.key]) && k.value)
          .filter(Boolean)
          .map((k, o) => o + 1 + '、' + k)
          .join('\n')}`,
        geometrys: Terraformer.WKT.convert(i.geometry),
      },
    }));
  const siteKey = 'rainwater_pipeline_water_level';
  /*results.data.siteList = [
    {
      id: '2',
      stCode: '0236190002',
      name: '管网(雨水)楚平路与康福路交叉口',
      geometry: 'POINT(114.38523754387444 30.481550658487215)',
      pointType: siteKey,
      recordTime: '',
      siteData: {
        siteType: 'flow',
        monitorTargetType: 'pipeline',
        stName: '管网(雨水)楚平路与康福路交叉口',
        stCode: '0236190002',
        tt: '2024-10-31 10:35:00',
        ut: '2024-10-31 10:35:21',
        installHeight: '',
        onlineStatus: 'online',
        faultStatus: 'normal',
        dynamicTableMonitor: 'cond,cq1,sbl1,va,z',
        monitorPropertyList: [
          {
            monitorCode: 'z',
            monitorName: '水位1',
            unit: '(米)',
          },
          {
            monitorCode: 'va',
            monitorName: '流速1',
            unit: '(米/秒)',
          },
          {
            monitorCode: 'sbl1',
            monitorName: '小时水量1',
            unit: '(立方米/小时)',
          },
          {
            monitorCode: 'cq1',
            monitorName: '累计流量1',
            unit: '(立方米)',
          },
          {
            monitorCode: 'cond',
            monitorName: '电导率',
            unit: '(微西门/厘米)',
          },
        ],
        monitorValueList: [
          {
            monitorCode: 'z',
            monitorValue: '0.092',
            tt: '2024-11-04 17:00:00',
          },
          {
            monitorCode: 'va',
            monitorValue: '0.0',
            tt: '2024-11-04 17:00:00',
          },
          {
            monitorCode: 'sbl1',
            monitorValue: '0.0',
            tt: '2024-11-04 17:00:00',
          },
          {
            monitorCode: 'cq1',
            monitorValue: '75483.58521',
            tt: '2024-11-04 17:00:00',
          },
          {
            monitorCode: 'cond',
            monitorValue: '408.0',
            tt: '2024-11-04 17:00:00',
          },
        ],
        z: '0.092',
        va: '0.0',
        sbl1: '0.0',
        cq1: '75483.58521',
        cond: '408.0',
      },
      pipeWarn: {
        id: '1',
        delFlag: '',
        createBy: '',
        createTime: '',
        updateBy: '',
        updateTime: '',
        remark: '',
        status: '',
        siteRuleId: '',
        siteCode: '0236190002',
        locationId: '',
        warnTypeCode: 'GWGSWYX',
        warnLevel: '',
        warnDatetime: '',
        warnFormula: '',
        warnFactor: '',
        warnFactorValue: '',
        triggerRecognizedFlag: false,
        triggerWarnFactor: '',
        timeThreshold: '',
        confirmStatus: 0,
        createDatetime: '',
        warnTypeName: '管网高水位运行',
        warnFactorName: '',
        warnFormulaName: '',
        siteName: '',
        siteId: '',
        warnFactorValueName: '',
        concernStatus: false,
        warnMessage: '',
        warnEndDatetime: '',
        facilityTypeCode: '',
        regionName: '',
        locationName: '',
        partitionNames: '',
        lonLat: '',
        siteAsName: '',
        facilityTypeId: '',
        facilityAttrTypeName: '',
      },
    },
  ];*/
  const siteList = (results.data.siteList || [])
    .filter(i => i.geometry)
    .map(i =>
      turf.feature(Terraformer.WKT.parse(i.geometry), {
        ...i,
        type: i.pointType + '_' + i.pipeWarn.warnTypeCode,
        name: [i.pipeWarn.warnTypeName, '持续时间:' + (i.pipeWarn.duration || 0)].join('\n'),
      })
    );
  // const siteList = (results.data.siteList || []).filter(i => i.geometry).map(i => turf.feature(Terraformer.WKT.parse(i.geometry),({...i,type:siteKey,name:[i.name,i.pipeWarn.warnTypeName].concat(i.siteData.monitorPropertyList.map((o,o_idx) => `${o.monitorName}${o.unit}:\t${i.siteData.monitorValueList[o_idx].monitorValue}`)).join('\n')})))
  //上下游管线
  let pipelines = results.data.pipelineInfoList
    .map(i => turf.feature(Terraformer.WKT.parse(i.geometrys), { ...i, area: i.pipelineType == 'YS' ? '雨水' : '污水' }))
    .map(i => (i.properties.flowDirection == 1 ? turf.lineString(turf.getCoords(i).flat().reverse(), i.properties) : i));
  newfiberMap
    .getLayers()
    .filter(i => i.newfiberId == '水系流向')[0]
    .getSource()
    .setData(turf.featureCollection(pipelines));

  bus.emit('setGeoJSON', { json: turf.featureCollection(questionLinePoints), key });
  siteList.length && bus.emit('setGeoJSON', { json: turf.featureCollection(siteList), key: siteKey });
};

onMounted(() => {
  console.log('props', props);
  Distinguishnames();
});
</script>

<style lang="scss" scoped>
#PointAndLine {
  width: 100%;
  height: 100%;
  color: #ccefff;
}

.items-content {
  width: 100%;
  height: 100%;
  display: flex;
  padding: 0 10px;
  flex-wrap: wrap;
  overflow: hidden;
  overflow-y: auto;

  .contentitem {
    min-height: 30px;
    line-height: 30px;
    width: 50%;
    display: flex;

    .name {
      width: 80px;
      color: #ccefff;
      text-align: right;
    }

    .value {
      width: calc(90% - 80px);
      font-size: 12px;
      font-weight: bold;
      color: #ccefff;
    }

    .gxname {
      text-align: right;
      width: 110px;
    }

    .gxvalue {
      width: calc(90% - 100px);
      white-space: nowrap;
      /* 确保文本在一行内显示 */
      overflow: hidden;
      /* 隐藏超出容器宽度的文本 */
      text-overflow: ellipsis;
      /* 使用省略号表示被截断的文本 */
    }
  }
}

.img,
.textarea {
  width: 100% !important;
}

.buttoncss {
  width: 100%;
  margin-left: 55px;
}
</style>