c81b00c56bfa8bdcb8125db1746493da.json 36 KB

1
  1. {"remainingRequest":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/node_modules/vue-loader/lib/index.js??vue-loader-options!/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/src/views/account/camera/index.vue?vue&type=template&id=a36f5fb8&scoped=true","dependencies":[{"path":"/Users/caoge/Desktop/地质现场/VehicleMonitor-WEB/src/views/account/camera/index.vue","mtime":1708395041885},{"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-container">
  <div class="dashboard-text">
    <div style="padding: 15px; background: #fff; margin-top: -15px">
      <el-row :gutter="24" type="flex" style="flex-wrap: wrap">
        <!-- <el-select
          v-model="queryParams.railwayCode"
          placeholder="请选择线路"
          style="width: 220px; padding: 0 10px"
          clearable
        >
          <el-option
            v-for="item in lineWayData"
            :key="item.railwayCode"
            :label="item.railwayName"
            :value="item.railwayCode"
          />
        </el-select> -->
        <el-input placeholder="请输入摄像机编码" style="width: 220px;padding: 0 10px" v-model="queryParams.cameraCode"></el-input>
        <el-input placeholder="请输入测点名称" style="width: 220px;padding: 0 10px" v-model="queryParams.stationName"></el-input>
        <el-select
          v-model="queryParams.lineDir"
          placeholder="请选择行别"
          style="width: 220px; padding: 0 10px"
          clearable
        >
          <el-option
            v-for="item in lineDir"
            :key="item.dictValue"
            :label="item.dictLabel"
            :value="item.dictValue"
          />
        </el-select>
        <div :span="12">
          <div style="display: flex; align-items: center; margin-top: 2px">
            <el-input
              v-model="queryParams.beginMileBD"
              placeholder="请输入起始里程"
              style="width: 220px; padding: 0 10px; position: relative"
              clearable
            >
              <template slot="append">km</template></el-input
            >
            <div
              style="
                width: 5px;
                height: 1px;
                background-color: #888;
                position: absolute;
                left: 880px;
              "
            />
            <el-input
              v-model="queryParams.endMileBD"
              placeholder="请输入结束里程"
              style="width: 220px; padding: 0 10px"
              clearable
            >
              <template slot="append">km</template></el-input
            >
          </div>
        </div>
        <div
          :span="6"
          justify="end"
          style="display: flex; margin-top: 2px"
          type="flex"
        >
          <div
            class="search_btn"
            style="margin-left: 10px; cursor: pointer"
            @click="handleQuery"
          >
            查询
          </div>
          <div
            class="reset_btn"
            style="margin-left: 10px; cursor: pointer"
            @click="reset"
          >
            重置
          </div>
        </div>
      </el-row>
    </div>

    <div style="padding: 20px; background: #fff; margin-top: 15px">
      <div class="cardHeadr">
        <div style="font-size: 18px; float: right; display: flex">
          <div class="addBtn" @click="addEquipment">
            <span class="icon font_family">&#xe604;</span>
            新增
          </div>
          <div class="addBtn" @click="delCameraList">
            <span class="icon font_family">&#xe607;</span>
            批量删除
          </div>
          <div class="addBtn" @click="importLoadIn">
            <span class="icon font_family">&#xe606;</span>
            导入
          </div>
          <div class="addBtn" @click="uploadOut">
            <span class="icon font_family">&#xe605;</span>
            导出
          </div>
          <div class="addBtn" @click="downloadOut">
            <span class="icon font_family">&#xe603;</span>
            下载模板
          </div>
        </div>
      </div>
      <el-table
        :data="tableData"
        style="width: 100%"
        @selection-change="handleSelectionChange"
      >
        <el-table-column type="selection" width="35" />
        <el-table-column
          prop="cameraCode"
          label="摄像机编码"
          width="175"
          align="center"
          fixed="left"
        />
        <el-table-column
          prop="installMiles"
          label="安装里程位置(km)"
          width="175"
          align="center"
          fixed="left"
        />
        <!-- <el-table-column prop="railwayName" label="线路" align="center" /> -->
        <el-table-column prop="stationName" label="测点名称" align="center" width="160px"/>
        <el-table-column prop="lineDir" label="行别" align="center">
          <templats slot-scope="scope">
            <span v-if="scope.row.lineDir == 1">上行</span>
            <span v-if="scope.row.lineDir == 2">下行</span>
          </templats>
        </el-table-column>
        <el-table-column
          prop="beginMiles"
          label="监控里程范围(km)"
          align="center"
          width="185"
        >
          <template slot-scope="scope">
            <span v-if="scope.row.beginMiles && scope.row.endMiles"
              >{{ scope.row.beginMiles }} ～ {{ scope.row.endMiles }}</span
            >
            <span v-else />
          </template>
        </el-table-column>
        <!-- v-if="this.startStatus == 1" -->          
        <!-- <el-table-column
          prop="startRecording"
          label="录像开启状态"
          width="175"
          align="center"
          v-if="this.startStatus == 1"
        >
          <template slot-scope="scope">
            <el-switch
              v-model="scope.row.startRecording"
              active-color="#006AEA"
              :active-value="1"
              :inactive-value="2"
              inactive-color="#CDCDCD"
              @change="handleStatusChange(scope.row)"
            />
          </template>
        </el-table-column> -->
        <el-table-column
          prop="enableOrNot"
          label="摄像机启用状态"
          width="175"
          align="center"
        >
          <template slot-scope="scope">
            <el-switch
              v-model="scope.row.enableOrNot"
              active-color="#006AEA"
              :active-value="1"
              :inactive-value="2"
              inactive-color="#CDCDCD"
              @change="handleEnableChange(scope.row)"
            />
          </template>
        </el-table-column>
        <el-table-column
          prop="installLongitude"
          label="经纬度"
          width="185"
          align="center"
        >
          <template slot-scope="scope">
            <span
              v-if="scope.row.installLongitude && scope.row.installLatitude"
              >{{ scope.row.installLongitude }} ,
              {{ scope.row.installLatitude }}</span
            >
            <span v-else />
          </template>
        </el-table-column>
        <!-- <el-table-column
          prop="versionNum"
          label="相机版本号"
          align="center"
          width="160"
        />
        <el-table-column
          prop="versionName"
          label="相机版本名称"
          align="center"
          width="160"
        /> -->
        <!-- <el-table-column
          prop="remark"
          label="备注"
          align="center"
          width="160"
          show-overflow-tooltip
        /> -->
        <el-table-column
          prop="createTime"
          label="创建时间"
          align="center"
          width="155"
        />
        <el-table-column
          label="操作"
          align="center"
          fixed="right"
          width="220"
        >
          <template slot-scope="scope">
            <div class="operateBtn" style="display: flex">
              <div type="text" @click="editEquip(scope.row)">修改</div>
              <div type="text" @click="delCamera(scope.row)">
                <span>删除</span>
              </div>
              <div type="text" @click="lokDetailInfo(scope.row)">
                详情查看
              </div>
              <div   type="text" @click="updateFileItem(scope.row)">
                 <div v-if="name==='chengbingxin'">视频上传</div>
              </div>
            </div>
          </template>
        </el-table-column>
      </el-table>

      <el-row type="flex" justify="end" style="margin-top: 10px">
        <el-pagination
          :page-sizes="[10, 15, 20]"
          layout="total, sizes, prev, pager, next, jumper"
          :total="total"
          @size-change="handleSizeChange"
          @current-change="handleCurrentChange"
        />
      </el-row>
    </div>
    <!-- 新增编辑弹窗 -->
    <el-dialog
      v-if="dialogFormVisible"
      :title="title"
      :visible.sync="dialogFormVisible"
      @close="CloseIn"
      width="836px"
    >
      <el-form
        ref="form"
        :model="form"
        :rules="rules"
        style="padding: 0 10px; margin-left: -20px"
      >
        <el-row :gutter="24">
          <el-col :span="12">
            <el-form-item
              label="相机编码"
              label-width="120px"
              prop="cameraCode"
            >
              <el-input
                v-model="form.cameraCode"
                autocomplete="off"
                placeholder="请输入相机编码"
                onkeyup="this.value"
                @input="descInput"
              />
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="相机通道" label-width="120px" prop="channel">
              <el-input
                v-model="form.channel"
                autocomplete="off"
                placeholder="请输入相机通道"
              />
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="线路" label-width="120px" prop="railwayCode">
              <el-select
                v-model="form.railwayCode"
                placeholder="请选择线路"
                style="width: 100%"
              >
                <el-option
                  v-for="item in lineWayData"
                  :key="item.railwayCode"
                  :label="item.railwayName"
                  :value="item.railwayCode"
                />
              </el-select>
            </el-form-item>
          </el-col>

          <el-col :span="12">
            <el-form-item label="行别" label-width="120px" prop="lineDirName">
              <!-- <el-select v-model="form.lineDirName" @change="handleChange"> -->
              <el-select
                v-model="form.lineDirName"
                style="width: 100%"
                placeholder="请选择行别"
                @change="$forceUpdate()"
              >
                <el-option
                  v-for="item in lineDir"
                  :key="item.dictValue"
                  :label="item.dictLabel"
                  :value="item.dictValue"
                />
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item
              label="安装里程位置"
              label-width="120px"
              prop="installMileBD"
            >
              <el-input
                v-model="form.installMileBD"
                placeholder="请输入安装里程位置"
                autocomplete="off"
                oninput="value=value.replace(/[^\d^\.]+/g,'').replace('.','$#$').replace(/\./g,'').replace('$#$','.')"
              >
                <template slot="append">km</template>
              </el-input>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item
              label="起始里程"
              label-width="120px"
              prop="beginMile"
            >
              <el-input
                v-model="form.beginMileBD"
                style="width: 99%"
                oninput="value=value.replace(/[^\d^\.]+/g,'').replace('.','$#$').replace(/\./g,'').replace('$#$','.')"
                placeholder="请输入起始里程"
              >
                <template slot="append">km</template>
              </el-input>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="结束里程" label-width="120px" prop="endMile">
              <el-input
                v-model="form.endMileBD"
                style="width: 99%"
                oninput="value=value.replace(/[^\d^\.]+/g,'').replace('.','$#$').replace(/\./g,'').replace('$#$','.')"
                placeholder="请输入结束里程"
              >
                <template slot="append">km</template>
              </el-input>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item
              label="经度"
              label-width="120px"                
              prop="installLongitude"                
            >
              <el-input
                v-model="form.installLongitude"
                placeholder="请输入经度" 
                type="number" max="90"                                                                       
              />
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item
              label="纬度"
              label-width="120px"                
              prop="installLatitude"                
            >
              <el-input
                v-model="form.installLatitude"
                placeholder="请输入纬度"
                type="number" max="180"                               
              />
            </el-form-item>
          </el-col>
          <!-- <el-col :span="12">
            <el-form-item label="状态" label-width="120px" prop="enableOrNot">
                <el-radio v-model="form.enableOrNot" :label="1" @change="$forceUpdate()">启用</el-radio>
                <el-radio v-model="form.enableOrNot" :label="2" @change="$forceUpdate()">停用</el-radio>
            </el-form-item>
          </el-col> -->
          <el-col :span="12">
            <el-form-item
              label="测点名称"
              label-width="120px"                
              prop="stationName"                
            >
            <el-input
                v-model="form.stationName"
                placeholder="请输入测点名称"                                              
              />
           </el-form-item>  
          </el-col>
          <el-col :span="12">
            <el-form-item label="状态" label-width="120px" prop="enableOrNot">
                <el-radio v-model="form.enableOrNot" :label="1" @change="$forceUpdate()">启用</el-radio>
                <el-radio v-model="form.enableOrNot" :label="2" @change="$forceUpdate()">停用</el-radio>
            </el-form-item>
          </el-col>
          <el-col :span="12">
            <el-form-item label="监视方向" label-width="120px" prop="monitoringDirectionName">
              <el-select
                v-model="form.monitoringDirectionName"
                style="width: 100%"
                placeholder="请选择监视方向"
                @change="$forceUpdate()"
              >
                <el-option
                  v-for="item in firectionData"
                  :key="item.dictValue"
                  :label="item.dictLabel"
                  :value="item.dictValue"
                />
              </el-select>
            </el-form-item>
          </el-col>
        </el-row>
      </el-form>
      <div slot="footer" class="dialog-footer" style="text-align: center">
        <el-button
          class="search_btna"
          style="line-heigth: 0"
          :disabled="disabledSave"
          @click="submint"
          >保存</el-button
        >
        <el-button @click="closeDia">取 消</el-button>
      </div>
    </el-dialog>
    <!-- 上传 -->
    <el-dialog
      :visible.sync="uploadDialog"
      title="相机导入"
      width="620px"
      @close="falseShowUpload"
    >
      <el-upload
        class="upload-demo"
        style="text-align: center"
        drag
        action="#"
        :http-request="uploadHttpRequest"
        :auto-upload="false"
        :file-list="fileList"
        :on-change="uploadFileList"
      >
        <i class="el-icon-upload" />
        <div class="el-upload__text">将文件拖到此处，或<em>点击上传</em></div>
        <!-- <div class="el-upload__tip">只能上传xls/xlsx文件,且不超过500kb</div> -->
      </el-upload>
      <div class="hxj">支持扩展名：.xlsx</div>
      <div
        class="hxj"
        style="width: 620px; text-align: center; margin-left: -20px"
      >
        请先下载模板，根据模板内容填写，再上传文件
        <span class="xzmba" @click="downloadOut">下载模板</span>
      </div>
      <div slot="footer" class="dialog-footer">
        <el-button class="search_btna" @click="uploadSubmitDialog"
          >确定</el-button
        >
        <el-button class="reset_btna" @click="falseShowUpload"
          >取 消</el-button
        >
      </div>
    </el-dialog>
    <!-- 详情 -->
    <el-dialog :visible.sync="detailDialog" title="详情查看" width="836px">
      <div class="dialog_box">
        <el-form style="padding: 0 10px; margin-left: -20px">
          <el-row :gutter="24">
            <el-col :span="12">
              <el-form-item
                label="相机编码:"
                label-width="120px"
                prop="cameraCode"
              >
                <el-input
                  v-model="detailData.cameraCode"
                  autocomplete="off"
                  disabled
                />
                <!-- <span>{{ detailData.cameraCode }}</span> -->
              </el-form-item>
            </el-col>
            <el-col :span="12">
              <el-form-item
                label="相机通道："
                label-width="120px"
                prop="cameraCode"
              >
                <el-input
                  v-model="detailData.channel"
                  autocomplete="off"
                  disabled
                />
                <!-- <span>{{ detailData.channel }}</span> -->
              </el-form-item>
            </el-col>
            <el-col :span="12">
              <el-form-item
                label="线路："
                label-width="120px"
                prop="cameraName"
              >
                <el-input
                  v-model="detailData.railwayName"
                  autocomplete="off"
                  disabled
                />
                <!-- <span>{{ detailData.railwayCode }}</span> -->
              </el-form-item>
            </el-col>
            <el-col :span="12">
              <el-form-item
                label="行别:"
                label-width="120px"
                prop="cameraCode"
              >
                <el-input
                  v-model="detailData.lineDir == 1 ? '上行' : '下行'"
                  autocomplete="off"
                  disabled
                />
                <!-- <span v-if="detailData.lineDir == 1">上行</span>
                <span v-if="detailData.lineDir == 2">下行</span> -->
              </el-form-item>
            </el-col>
            <el-col :span="12">
              <el-form-item
                label="安装里程位置:"
                label-width="120px"
                prop="installs"
              >
                <el-input
                  v-model="detailData.installMiles"
                  autocomplete="off"
                  disabled
                >
                  <template slot="append">m</template>
                </el-input>
                <!-- <span>{{ detailData.installs }}</span> -->
              </el-form-item>
            </el-col>
            <el-col :span="12">
              <el-form-item
                label="监控里程范围:"
                label-width="120px"
                prop="begins"
              >
                <el-input v-model="pjJkfw" autocomplete="off" disabled>
                  <template slot="append">m</template>
                </el-input>
                <!-- <span>{{ detailData.begins }}</span> -->
                <!-- <span>{{ detailData.beginMiles }}～ {{detailData.endMiles}}</span> -->
              </el-form-item>
            </el-col>
            <el-col :span="12">
              <el-form-item
                label="经纬度:"
                label-width="120px"
                prop="cameraCode"
              >
                <el-input v-model="pjjwd" autocomplete="off" disabled />
                <!-- <span
                  >{{ detailData.installLongitude }}，{{
                    detailData.installLatitude
                  }}</span
                > -->
              </el-form-item>
            </el-col>
            <el-col :span="12">
              <el-form-item
                label="测点名称："
                label-width="120px"
                prop="stationName"
              >
                <el-input
                  v-model="detailData.stationName"
                  autocomplete="off"
                  disabled
                />
                <!-- <span>{{ detailData.railwayCode }}</span> -->
              </el-form-item>
            </el-col>
            <el-col :span="12">
              <el-form-item
                label="摄像机开启状态:"
                label-width="120px"
                prop="enableOrNot"
              >
                <el-input v-model="detailData.enableOrNot==1?'已开启':'未开启'" autocomplete="off" disabled />
                <!-- <span
                  >{{ detailData.installLongitude }}，{{
                    detailData.installLatitude
                  }}</span
                > -->
              </el-form-item>
            </el-col>
            <el-col :span="12">
              <el-form-item label="监视方向" label-width="120px" prop="lineDirName">
                <el-select
                  v-model="detailData.monitoringDirection==1?'上行':detailData.monitoringDirection==2?'下行':detailData.monitoringDirection==3?'双线':''"
                  style="width: 100%"
                  placeholder="请选择监视方向"
                  @change="$forceUpdate()"
                  disabled
                >
                  <el-option
                    v-for="item in firectionData"
                    :key="item.dictValue"
                    :label="item.dictLabel"
                    :value="item.dictValue"
                  />
                </el-select>
              </el-form-item>
            </el-col>
            <!-- <el-col :span="12">
              <el-form-item
                label="是否开启录像:"
                label-width="120px"
                prop="cameraCode"
              >
                <el-input
                  v-model="detailData.startRecording == 1 ? '开启' : '不开启'"
                  autocomplete="off"
                  disabled
                /></el-form-item>
            </el-col> -->
            <!-- <el-col :span="12">
              <el-form-item
                label="创建者:"
                label-width="120px"
                prop="cameraCode"
              >
                <el-input
                  v-model="detailData.createBy"
                  autocomplete="off"
                  disabled
                />
              </el-form-item>
            </el-col> -->
            <!-- <el-col :span="12">
              <el-form-item
                label="创建时间:"
                label-width="120px"
                prop="cameraCode"
              >
                <el-input
                  v-model="detailData.createTime"
                  autocomplete="off"
                  disabled
                />
              </el-form-item>
            </el-col> -->
            <!-- <el-col :span="12">
              <el-form-item
                label="更新者:"
                label-width="120px"
                prop="cameraCode"
              >
                <el-input
                  v-model="detailData.updateBy"
                  autocomplete="off"
                  disabled
                />
              </el-form-item>
            </el-col> -->
            <!-- <el-col :span="12">
              <el-form-item
                label="更新时间:"
                label-width="120px"
                prop="cameraCode"
              >
                <el-input
                  v-model="detailData.updateTime"
                  autocomplete="off"
                  disabled
                />
              </el-form-item>
            </el-col> -->
            <!-- <el-col :span="12">
              <el-form-item
                label="相机版本号:"
                label-width="120px"
                prop="cameraCode"
              >
                <el-input
                  v-model="detailData.versionNum"
                  autocomplete="off"
                  disabled
                />
              </el-form-item>
            </el-col> -->
            <!-- <el-col :span="12">
              <el-form-item
                label="相机版本名称:"
                label-width="120px"
                prop="cameraCode"
              >
                <el-input
                  v-model="detailData.versionName"
                  autocomplete="off"
                  disabled
                />
              </el-form-item>
            </el-col> -->
            <!-- <el-col :span="24">
              <el-form-item
                label="备注:"
                label-width="120px"
                prop="cameraCode"
              >
                <el-input
                  v-model="detailData.remark"
                  type="textarea"
                  autocomplete="off"
                  disabled
                />
              </el-form-item>
            </el-col> -->
          </el-row>
        </el-form>
      </div>
    </el-dialog>
  </div>
  
  <el-dialog title="视频上传"  v-if="dialogVisible" :visible.sync="dialogVisible" width="800px">
    <div style="text-align: center">
      <el-upload
        class="upload-demo"
        :limit="1"
        drag
        :action="uploadUrl"
        :multiple="true"
        :before-upload="beforeUpload"
      >
        <i class="el-icon-upload"></i>
        <div class="el-upload__text">将文件拖到此处，或<em>点击上传</em></div>
        <div style="margin-top: 10px; font-size: 12px" slot="tip">
          请上传视频格式文件
        </div>
      </el-upload>
    </div>
    <span slot="footer" class="dialog-footer">
      <el-button @click="dialogVisible = false">取 消</el-button>
      <el-button type="primary" @click="goClick">确 定</el-button>
    </span>
  </el-dialog>
</div>
"},null]}