| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540 | <template>  <view class="dust-detail">    <u-tabs      class="devic-box-tab"      :current="PageCur"      :list="tabList"      @click="NavChange"    ></u-tabs>    <view class="dust-content">      <view class="top-area" v-for="(item, index) in topList" :key="index">        <view class="top-title">          <view style="font-weight: bold">{{ item.label }}</view>        </view>        <view class="top-card">          <!-- <view class="card-item card-item1">            <view class="item-box item-box1">              <view class="box-val">{{ item.temperature || "--" }}</view>              <view class="box-name">温度(℃)</view>            </view>          </view> -->          <view class="card-item card-item1">            <view class="item-box item-box2">              <view class="box-val">{{ item.dustval || "--" }}</view>              <view class="box-name">粉尘浓度(mg/m³)</view>            </view>          </view>          <!-- <view class="card-item">            <view class="item-box item-box3">              <view class="box-val">{{ item.waterPressure || "--" }}</view>              <view class="box-name">喷雾水压(MPa)</view>            </view>          </view> -->          <!-- <view class="card-item">            <view class="item-box item-box4">              <view class="box-val">{{ item.atomizingState || "--" }}</view>              <view class="box-name">喷雾状态</view>            </view>          </view> -->        </view>        <view class="top-echart">          <LineChart            :chartData="option"            :style="{ width: '100%', height: '180px' }"          ></LineChart>        </view>      </view>      <view class="bot-area">        <view class="bot-title">          <view style="font-weight: bold">粉尘监控测点信息</view>        </view>        <view class="bot-content">          <view            class="card-b"            v-for="(item, index) in cardListDust"            :key="index"          >            <div class="item-l">              <div class="label-l">{{ item.label || "--" }}</div>              <div class="value-l">{{ item.value || "--" }}</div>            </div>            <div class="item-r">              <div                class="content-r"                v-for="(items, ind) in item.listR"                :key="ind"              >                <span>{{ `${items.label} : ` }}</span>                <span                  :class="{                    'status-f': items.value == 1,                    'status-l': items.value == 0,                  }"                  >{{ `${items.value}${items.dw}` || "--" }}</span                >              </div>            </div>          </view>        </view>      </view>    </view>  </view></template><script>import api from "@/api/api";export default {  name: "dustDetail",  props: {},  watch: {},  data() {    return {      option: {},      timer: "",      PageCur: "0",      tabList: [],      //喷粉选项数据      topList: [],      flag: true,      echartNow: [],      echartYc: [],      xData: [],      yDataN: [],      yDataY: [],      yDataS: [],      maxY: 0,      cardListDust: [],    };  },  beforeDestroy() {    this.myChart.clear();    this.myChart.dispose();    this.timer = null;    clearTimeout(this.timer);  },  mounted() {    this.getTabList();    this.getWindDeviceList();  },  methods: {    NavChange: function (item) {      clearTimeout(this.timer);      this.PageCur = item.index;      this.getMonitor(this.tabList[this.PageCur].deviceID, true);    },    getMonitor(deviceID, flag) {      let than = this;      than.timer = setTimeout(        async () => {          await than.getSysWarnList(deviceID, "dust");          if (than.timer) {            than.timer = null;          }          than.getMonitor(deviceID);        },        flag ? 0 : 3000      );    },    //获取顶部tab选项数据    getTabList() {      this.tabList = [];      new Promise((resolve, reject) => {        api          .sysTypeWarn({ type: "dust" })          .then((response) => {            if (response.data.code == 200 && response.data.result.length != 0) {              let result = response.data.result;              console.log(result, "粉尘菜单---------");              result.forEach((el) => {                this.tabList.push({                  name: el.systemname,                  warn: "低风险",                  deviceID: el.id,                  strtype: el.strtype,                });              });              this.getMonitor(this.tabList[0].deviceID, true);            } else {              reject(response);            }          })          .catch((error) => {            console.log("catch===>response", response);            reject(error);          });      });    },    //获取喷粉选项数据    getSysWarnList(id, type) {      let that = this;      new Promise((resolve, reject) => {        api          .sysWarn({ sysid: id, type: type })          .then((response) => {            if (response.data.code == 200) {              console.log(response.data, "喷粉选项数据---------");              let data = response.data.result.dust;              if (data.length != 0) {                that.topList = data.map((el) => {                  return {                    label: el.strinstallpos,                    temperature: el.readData.temperature,                    dustval: el.readData.dustval,                    waterPressure: el.readData.waterPressure,                    atomizingState: el.readData.atomizingState,                  };                });                data.forEach((v, index) => {                  if (that.flag) {                    that.echartNow = JSON.parse(v.readData.expectInfo)["list"];                    that.flag = false;                  }                  that.echartYc.push({                    time: JSON.parse(v.readData.expectInfo)["nowTime"],                    value: JSON.parse(v.readData.expectInfo)["nowVal"],                  });                  let setData = [...that.echartNow, ...that.echartYc].sort(                    (a, b) =>                      Date.parse(new Date(a.time)) -                      Date.parse(new Date(b.time))                  );                  that.xData = [];                  that.yDataS = [];                  that.yDataY = [];                  that.yDataN = [];                  setData.forEach((el) => {                    if (el.value && el.value != "0") {                      that.xData.push(el.time);                      that.yDataS.push(el.value);                      that.yDataY.push(                        JSON.parse(v.readData.expectInfo)["aveVal"]                      );                      that.yDataN.push(                        JSON.parse(v.readData.expectInfo)["fmin"]                          ? JSON.parse(v.readData.expectInfo)["fmin"]                          : 0                      );                    }                  });                  let max = that.yDataS.reduce((acr, cur) => {                    return acr > cur ? acr : cur;                  });                  that.maxY = that.formatRoundNum(max * 1.5);                  // console.log(that.xData, that.yDataS, that.yDataY, that.yDataN, '000')                  this.option = {                    categories: this.xData.slice(-3) || [],                    series: [                      {                        name: "预测值",                        data: this.yDataY.slice(-3) || [],                      },                      {                        name: "最新值",                        data: this.yDataN.slice(-3) || [],                      },                    ],                  };                });              }            } else {              reject(response);            }          })          .catch((error) => {            console.log("catch===>response", response);            reject(error);          });      });    },    //获取粉尘监控测点信息    getWindDeviceList() {      new Promise((resolve, reject) => {        api          .getDeviceVent({ devicetype: "dusting", pagetype: "normal" })          .then((response) => {            if (response.data.code == 200) {              let data = response.data.result;              if (data.msgTxt[0].datalist.length != 0) {                let list = data.msgTxt[0].datalist;                if (list.length > 0) {                  this.cardListDust = list.map((el) => {                    //lxh                    const readData = el.readData;                    el = Object.assign(el, readData);                    return {                      label: "通信状态",                      value: el.netStatus == "0" ? "断开" : "连接",                      listR: [                        {                          id: 0,                          label: "安装位置",                          dw: "",                          value: el.strinstallpos,                        },                        {                          id: 1,                          label: "粉尘浓度",                          dw: "(mg/m³)",                          value: el.dustval,                        },                        {                          id: 2,                          label: "巷道湿度",                          dw: "(RH)",                          value: el.humidity,                        },                        {                          id: 4,                          label: "巷道温度",                          dw: "(℃)",                          value: el.temperature,                        },                        {                          id: 3,                          label: "是否报警",                          dw: "",                          value:                            el.warnFlag == "0"                              ? "正常"                              : el.warnFlag == 1                              ? "报警"                              : el.warnFlag == 2                              ? "断开"                              : "未监测",                        },                      ],                    };                  });                }              }            } else {              reject(response);            }          })          .catch((error) => {            console.log("catch===>response", response);            reject(error);          });      });    },    formatRoundNum(num) {      let interger = Math.ceil(num);      let leng = String(interger).length;      return (        Math.ceil(interger / Math.pow(10, leng - 1)) * Math.pow(10, leng - 1)      );    },  },  computed: {},};</script><style lang="scss" scoped>.dust-detail {  position: relative;  // padding: 0px 10px;  box-sizing: border-box;  .devic-box-tab {    padding: 0px 10px !important;  }  .dust-content {    // height: 704px;    // padding: 0px 10px;    // box-sizing: border-box;    // overflow-y: auto;    height: 704px;    box-sizing: border-box;    overflow-y: auto;    .top-area {      width: 100%;      padding: 10px;      box-sizing: border-box;      background-color: #fff;      margin-bottom: 2px;      .top-title {        height: 28px;        margin-bottom: 10px;        display: flex;        justify-content: space-between;        align-items: center;      }      .top-card {        display: flex;        justify-content: space-between;        align-items: flex-start;        flex-wrap: wrap;        width: 100%;        margin-bottom: 10px;        .card-item {          width: calc(50% - 5px);          height: 60px;          border-radius: 5px;          background: linear-gradient(            to right,            rgba(55, 135, 254, 0.08),            rgba(4, 184, 255, 0.08),            rgba(60, 161, 237, 0.08)          );          .item-box {            display: flex;            flex-direction: column;            justify-content: center;            align-items: flex-start;            width: 100%;            height: 100%;            padding: 0px 15px;            .box-val {              height: 28px;              line-height: 28px;              color: #0eb4fc;              font-weight: bold;            }            .box-name {              font-size: 12px;            }          }          .item-box1 {            background: url("/static/wd.png") no-repeat right;            background-size: 30% 80%;          }          .item-box2 {            background: url("/static/dust.png") no-repeat right;            background-size: 30% 80%;          }          .item-box3 {            background: url("/static/pwsy.png") no-repeat right;            background-size: 30% 80%;          }          .item-box4 {            background: url("/static/pwzt.png") no-repeat right;            background-size: 30% 80%;          }        }        .card-item1 {          margin-bottom: 10px;        }      }      .top-echart {        height: 220px;      }    }    .bot-area {      width: 100%;      padding: 10px;      box-sizing: border-box;      background-color: #fff;      margin-bottom: 2px;      .bot-title {        height: 28px;        margin-bottom: 10px;        display: flex;        justify-content: space-between;        align-items: center;      }      .bot-content {        // height: calc(100% - 38px);        overflow-y: auto;        .card-b {          width: 100%;          height: 100px;          display: flex;          justify-content: space-between;          padding: 5px;          margin-bottom: 5px;          background: linear-gradient(            to right,            rgba(55, 135, 254, 0.08),            rgba(4, 184, 255, 0.08),            rgba(60, 161, 237, 0.08)          );          .item-l {            position: relative;            width: 80px;            height: 100%;            background: url("/static/bot-area.png") no-repeat center;            background-size: 100% 100%;            .label-l {              width: 100%;              position: absolute;              top: 7px;              font-size: 12px;              text-align: center;            }            .value-l {              width: 100%;              position: absolute;              top: 50px;              color: #0eb4fc;              text-align: center;            }          }          .item-r {            width: calc(100% - 100px);            height: 100%;            display: flex;            flex-direction: column;            justify-content: space-around;            .content-r {              display: flex;              span {                font-size: 12px;                &:first-child {                  display: inline-block;                  width: 68px;                }                &:last-child {                  display: inline-block;                  width: calc(100% - 68px);                  overflow: hidden;                  white-space: nowrap;                  /* 不换行 */                  /* 超出部分隐藏 */                  text-overflow: ellipsis;                  /* 使用省略符号 */                }              }              .status-f {                color: #ff0000;              }              .status-l {                color: #3df6ff;              }            }          }        }      }    }  }}</style>
 |