{"remainingRequest":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/vue-loader/lib/index.js??vue-loader-options!/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/src/views/dashboard/index.vue?vue&type=template&id=106c86ed&scoped=true","dependencies":[{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/src/views/dashboard/index.vue","mtime":1708395041887},{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/cache-loader/dist/cjs.js","mtime":1708395146433},{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/vue-loader/lib/loaders/templateLoader.js","mtime":1708395147801},{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/cache-loader/dist/cjs.js","mtime":1708395146433},{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/vue-loader/lib/index.js","mtime":1708395147382}],"contextDependencies":[],"result":[{"type":"Buffer","data":"base64:
<div class="dashboard">
  <div style="width: 100%;height: 50px;"></div>
  <div class="content">
    <div class="left-map">
      <div style="width: 3px;height: 16px;background-color: #2250C8;position: absolute;left: 15px;top: 14px;"></div>
      <span style="font-size: 16px;font-weight: 500;position: absolute;left: 22px;top: 12px;">线路实况</span>
      <div class="cameraBtn">
        <!-- <el-select></el-select>
        <el-select></el-select> -->
        <el-input size="small" v-model="searchInfo.camera" placeholder="输入摄像机编号"     clearable></el-input>
        <el-input size="small" v-model="searchInfo.vehicle" placeholder="输入机车编号"     clearable></el-input>
        <el-button @click="highlighPanel" size="small" type="primary">
          <i class="el-icon-search"></i>
        </el-button>
        <img src="/map/camera.png" :style="cameraShow ? { opacity: 0.6 } : { opacity: 1 }" width="32" height="32" alt=""
          @click="showCamera">
      </div>
      <iframe ref="mapRef" style="width: 100%;height: 100%;" src="/SH-demo(1).html" frameborder="0"></iframe>
    </div>
    <div class="right-msg">
      <div class="msgStatistics">
        <div style="width: 3px;height: 16px;background-color: #2250C8;position: absolute;left: 15px;top: 14px;"></div>
        <span style="font-size: 16px;font-weight: 500;position: absolute;left: 22px;top: 12px;">设备状态</span>
        <div class="left">
          <img src="../../assets/编组201.png" style="position: absolute;right: 25px;top: 29px;">
          <span style="color:#333333;font-size:12px;position: absolute;top: 18px;left: 77px;">在线</span>
          <span style="color:#333333;font-size:12px;position: absolute;bottom: 18px;left: 77px;">离线</span>
          <span
            style="color:#333333;font-size:12px;position: absolute;bottom: 10px;right: 16px;font-weight: 600;">接入摄像机</span>
          <!-- <span style="color: #00974D;line-height: 22px;font-size: 16px;font-weight: 600;text-shadow: 0px 2px 2px rgba(161,158,158,0.5);position: absolute;left: 33px;top: 13px;">{{ msgStatisticsData.online||0 }}{{ '台' }}</span>
            <span style="color: #FF0000;line-height: 22px;font-size: 16px;font-weight: 600;text-shadow: 0px 2px 2px rgba(161,158,158,0.5);position: absolute;left: 33px;bottom: 13px;">{{ msgStatisticsData.offline ||0}}{{ '台' }}</span>
            <span style="color: #2250C8;line-height: 22px;font-size: 16px;font-weight: 600;text-shadow: 0px 2px 2px rgba(161,158,158,0.5);position: absolute;right: 42px;top: 13px;">{{ msgStatisticsData.countAllCamera||0}}{{ '台' }}</span> -->
          <div class="onlineNum" style="width: 40%;height: 50%;text-align: center;">
            <span
              style="color: #00974D;line-height: 55px;font-size: 16px;font-weight: 600;text-shadow: 0px 2px 2px rgba(161,158,158,0.5);cursor: pointer;"
              @click="toCameraMonitoring('2')">{{ msgStatisticsData.online || 0 }}{{ '台' }}</span>
          </div>
          <div class="offlineNum" style="width: 40%;height: 50%;text-align: center;">
            <span
              style="color: #FF0000;line-height: 55px;font-size: 16px;font-weight: 600;text-shadow: 0px 2px 2px rgba(161,158,158,0.5);cursor: pointer;"
              @click="toCameraMonitoring('1')">{{ msgStatisticsData.offline || 0 }}{{ '台' }}</span>
          </div>
          <div class="cameraNum" style="position: absolute;right: 5px;top:0;width: 40%;height: 50%;text-align: center;">
            <span
              style="color: #2250C8;line-height: 55px;font-size: 16px;font-weight: 600;text-shadow: 0px 2px 2px rgba(161,158,158,0.5);">{{
                msgStatisticsData.countAllCamera || 0 }}{{ '台' }}</span>
          </div>
        </div>
        <div class="right">
          <img src="../../assets/编组202.png" style="position: absolute;left: 25px;top: 29px;">
          <span style="color:#333333;font-size:12px;position: absolute;top: 18px;right: 77px;">在线</span>
          <span style="color:#333333;font-size:12px;position: absolute;bottom: 18px;right: 77px;">离线</span>
          <span
            style="color:#333333;font-size:12px;position: absolute;bottom: 10px;left: 24px;font-weight: 600;">车载终端</span>
          <!-- <span style="color: #00974D;line-height: 22px;font-size: 16px;font-weight: 600;text-shadow: 0px 2px 2px rgba(161,158,158,0.5);position: absolute;right: 33px;top: 13px;">{{ msgStatisticsData.OFFLINETERMINAL ||0}}{{ '台' }}</span>
            <span style="color: #FF0000;line-height: 22px;font-size: 16px;font-weight: 600;text-shadow: 0px 2px 2px rgba(161,158,158,0.5);position: absolute;right: 33px;bottom: 13px;">{{ msgStatisticsData.ONLINETERMINAL ||0}}{{ '台' }}</span>
            <span style="color: #2250C8;line-height: 22px;font-size: 16px;font-weight: 600;text-shadow: 0px 2px 2px rgba(161,158,158,0.5);position: absolute;left: 37px;top: 13px;">{{ msgStatisticsData.COUNTALLTERMINAL ||0}}{{ '台' }}</span> -->
          <div class="terminalNum"
            style="position: absolute;left: 5px;top:0;width: 40%;height: 50%;text-align: center;">
            <span
              style="color: #2250C8;line-height: 55px;font-size: 16px;font-weight: 600;text-shadow: 0px 2px 2px rgba(161,158,158,0.5);">{{
                msgStatisticsData.COUNTALLTERMINAL || 0 }}{{ '台' }}</span>
          </div>
          <div class="onlineNum" style="width: 40%;height: 50%;text-align: center;float: right;">
            <span
              style="color: #00974D;line-height: 55px;font-size: 16px;font-weight: 600;text-shadow: 0px 2px 2px rgba(161,158,158,0.5);cursor: pointer;"
              @click="toVehicleMonitoring('1')">{{ msgStatisticsData.OFFLINETERMINAL || 0 }}{{ '台' }}</span>
          </div>
          <div class="offlineNum"
            style="width: 40%;height: 50%;text-align: center;position: absolute;right: 0;bottom: 0;">
            <span
              style="color: #FF0000;line-height: 55px;font-size: 16px;font-weight: 600;text-shadow: 0px 2px 2px rgba(161,158,158,0.5);cursor: pointer;"
              @click="toVehicleMonitoring('2')">{{ msgStatisticsData.ONLINETERMINAL || 0 }}{{ '台' }}</span>
          </div>
        </div>
      </div>
      <div class="systemMsg">
        <div style="width: 3px;height: 16px;background-color: #2250C8;position: absolute;left: 15px;top: 14px;"></div>
        <span style="font-size: 16px;font-weight: 500;position: absolute;left: 22px;top: 12px;">接入系统状态</span>
        <div style="width: 100%;height: 77px;"></div>
        <div class="tongji">
          <div class="total">
            <img src="../../assets/group4.png">
            <span
              style="position: absolute;font-size: 20px;line-height: 22px;font-weight: 600;color: #696969;left: 61px;">{{
                sysMsg.countAllMonitor }}<span style="font-size: 16px;font-weight: 400;color: #696969;">{{ '套'
}}</span></span>
            <span
              style="font-size: 14px;font-weight: 400;color: #484646;line-height: 22px;position: absolute;left: 60px;top: 20px;">接入监测系统</span>
          </div>
          <div class="online">
            <img src="../../assets/group5.png">
            <span
              style="position: absolute;font-size: 20px;line-height: 22px;font-weight: 600;color: #696969;left: 61px;">{{
                sysMsg.onlineMonitor }}<span style="font-size: 16px;font-weight: 400;color: #696969;">{{ '套'
}}</span></span>
            <span
              style="font-size: 14px;font-weight: 400;color: #484646;line-height: 22px;position: absolute;left: 60px;top: 20px;">在线</span>
          </div>
          <div class="offline">
            <img src="../../assets/group6.png">
            <span
              style="position: absolute;font-size: 20px;line-height: 22px;font-weight: 600;color: #696969;left: 61px;">{{
                sysMsg.offlineMonitor }}<span style="font-size: 16px;font-weight: 400;color: #696969;">{{ '套'
}}</span></span>
            <span
              style="font-size: 14px;font-weight: 400;color: #484646;line-height: 22px;position: absolute;left: 60px;top: 20px;">离线</span>
          </div>
        </div>
        <div class="msgItem" v-for="item in sysMsg.monitorSystemList.slice(0, 3)">
          <div class="blueDrop"></div>
          <div style="width: 100%;height: 10px;"></div>
          <div class="sysName">{{ item.monitorSystemName }}</div>
          <div class="sysState">
            <span style="padding-left: 14px;font-size: 14px;color: rgba(0, 0, 0, 0.88);font-weight: 400;">状态:</span>
            <span style="padding-left: 14px;color: #00974D;font-size: 14px;font-weight: 400;"
              v-if="item.status == 1">在线</span>
            <span style="padding-left: 14px;color: red;font-size: 14px;font-weight: 400;" v-else>离线</span>
            <span style="padding-left: 80px;font-size: 14px;color: rgba(0, 0, 0, 0.88);font-weight: 400;">未解除报警:</span>
            <span style="padding-left: 14px;font-size: 14px;color: blue;font-weight: 400;cursor: pointer;"
              @click="toAlarmList(item)">{{ item.countAlarm || 0 }}</span>
            <span style="position: absolute;right:15px;color: #2250C8;font-size: 12px;font-weight: 500;cursor: pointer;"
              @click="showDetaileDialog(item)">详情</span>
          </div>
        </div>
        <div class="more" @click="goMore">更多></div>
        <el-dialog width="836px" title="详情查看" :visible.sync="isShowDialog">
          <el-form style="padding: 0 10px; margin-left: -20px" label-width="120px" ref="ruleForm" :model="detaileMsg"
            label-position="top">
            <el-row :gutter="24">
              <el-col :span="12">
                <el-form-item label="监测系统名称:">
                  <el-input v-model="detaileMsg.monitorSystemName" autocomplete="off" disabled />
                </el-form-item>
              </el-col>
              <el-col :span="12">
                <el-form-item label="监测系统编码:">
                  <el-input v-model="detaileMsg.clientId" autocomplete="off" disabled />
                </el-form-item>
              </el-col>
            </el-row>
            <el-row :gutter="24">
              <el-col :span="12">
                <el-form-item label="正式环境密钥:">
                  <el-input v-model="detaileMsg.clientSecret" autocomplete="off" disabled />
                </el-form-item>
              </el-col>
              <el-col :span="12">
                <el-form-item label="测试环境密钥:">
                  <el-input v-model="detaileMsg.testSecret" autocomplete="off" disabled />
                </el-form-item>
              </el-col>
            </el-row>
            <el-row :gutter="24">
              <el-col :span="12">
                <el-form-item label="报警信息生成机制:">
                  <el-input v-model="detaileMsg.alarmGenerate" autocomplete="off" disabled type="textarea"
                    style="height:50px" />
                </el-form-item>
              </el-col>
              <el-col :span="12">
                <el-form-item label="报警解除机制:">
                  <el-input v-model="detaileMsg.alarmRelease" autocomplete="off" disabled type="textarea" />
                </el-form-item>
              </el-col>
            </el-row>
            <el-row :gutter="24">
              <el-col :span="12">
                <el-form-item label="系统简介:">
                  <el-input v-model="detaileMsg.systemIntroduce" autocomplete="off" disabled type="textarea" />
                </el-form-item>
              </el-col>
              <el-col :span="12">
                <el-form-item label="报警信息内容:">
                  <el-input v-model="detaileMsg.alarmContent" autocomplete="off" disabled type="textarea" />
                </el-form-item>
              </el-col>
            </el-row>
            <el-row :gutter="24">
              <el-col :span="24">
                <el-form-item label="报警对应的处理措施:">
                  <el-input v-model="detaileMsg.treateMeasure" autocomplete="off" disabled type="textarea" />
                </el-form-item>
              </el-col>
            </el-row>
          </el-form>
        </el-dialog>
      </div>
      <div class="alarmMsg">
        <div style="width: 3px;height: 16px;background-color: #2250C8;position: absolute;left: 15px;top: 14px;"></div>
        <span style="font-size: 16px;font-weight: 500;position: absolute;left: 22px;top: 12px;">报警信息</span>
        <div style="width: 100%;height: 53px;"></div>
        <div class="switchButton">
          <div class="all" @click="selectAlarmType('1', '')"
            :style="buttonIndex == 1 ? 'border-color:#C9D5F5;color:#2250C8' : ''">全部</div>
          <div class="unreleased" @click="selectAlarmType('2', 2)"
            :style="buttonIndex == 2 ? 'border-color:#C9D5F5;color:#2250C8' : ''">未解除</div>
          <div class="released" @click="selectAlarmType('3', 1)"
            :style="buttonIndex == 3 ? 'border-color:#C9D5F5;color:#2250C8' : ''">已解除</div>
        </div>
        <div class="alarmMsgItem" v-for="item in alarmListData">
          <img src="../../assets/报警.png">
          <span class="isLock1" v-if="item.isRelease == 1">已解除</span>
          <span class="isLock" v-if="item.isRelease == 2">未解除</span>
          <div style="width: 100%;height: 7px;"></div>
          <div class="railwayName">{{ item.alarmTypeName }}</div>
          <div class="content">
            <!-- <div style="left: 0;top: 0;">{{ item.lineDirName + ',里程位置' + item.alarmMiles + ',' + item.alarmTypeName }}</div>
              <div style="left: 0;top: 19px;">{{ item.alarmTime }}</div>
              <div style="left: 0;top: 38px;" v-if="item.sourceName">{{ '来源:' + item.sourceName }}</div>
              <div style="left: 0;top: 38px;" v-else>{{ '来源:' }}</div> -->

            <div style="left: 0;top: 19px;overflow: hidden;white-space: nowrap;text-overflow: ellipsis;"
              :title="item.sourceName + ' ' + item.alarmTime" v-if="item.sourceName">{{ item.sourceName }} {{
                item.alarmTime }}</div>
            <div style="left: 0;top: 19px;" v-else>{{ }} {{ item.alarmTime }}</div>
            <div style="left: 0;top: 38px;" v-if="item.alarmLevel == 1">{{ item.lineDirName + ' ' + item.alarmMiles +
              ',' + item.alarmTypeName + ' ' + '一级报警' }}</div>
            <div style="left: 0;top: 38px;" v-if="item.alarmLevel == 2">{{ item.lineDirName + ' ' + item.alarmMiles +
              ',' + item.alarmTypeName + ' ' + '二级报警' }}</div>
            <div style="left: 0;top: 38px;" v-if="item.alarmLevel == 3">{{ item.lineDirName + ' ' + item.alarmMiles +
              ',' + item.alarmTypeName + ' ' + '三级报警' }}</div>
          </div>
          <div class="detailsBtn" @click="seeDetail(item)">
            查看详情
          </div>
        </div>
        <div class="more" @click="goAlarmList">更多></div>
      </div>
    </div>
  </div>
  <el-dialog width="65%" :visible="dialogInfo.show" @close="dialogInfo.show = false, dialogInfo.data = {}">
    <template #title>
      <div :style="`opacity: ${Object.keys(dialogInfo.data).length === 0 ? '1' : '0'};`">视频加载中...</div>
    </template>
    <div class="video" v-loading="Object.keys(dialogInfo.data).length === 0">
      <div v-for="item in dialogInfo.data.data" :key="item">
        <div>
          <VideoLine :showElectric="false" :items="false" :camera-code="item.cameraCode ? item.cameraCode : ''">
          </VideoLine>
          <Video :src="item.url"></Video>
        </div>
      </div>
    </div>
  </el-dialog>
</div>
"},null]}