<template>
  <div class="app-container">
    <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
      <el-form-item label="设备名" prop="name">
        <el-input v-model="queryParams.name" placeholder="请输入设备名" clearable @keyup.enter.native="handleQuery" />
      </el-form-item>
      <el-form-item label="序列号" prop="devsn">
        <el-input v-model="queryParams.devsn" placeholder="请输入设备序列号" clearable @keyup.enter.native="handleQuery" />
      </el-form-item>
      <el-form-item>
        <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
        <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
      </el-form-item>
    </el-form>

    <el-row :gutter="10" class="mb8">
      <el-col :span="1.5">
        <el-button type="primary" plain icon="el-icon-plus" size="mini"  @click="handleAdd"
                   v-hasPermi="['web:camera:add']">新增</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button type="danger" plain icon="el-icon-delete" size="mini" :disabled="multiple" @click="handleDelete"
          v-hasPermi="['web:camera:remove']">删除</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button type="warning" plain icon="el-icon-download" size="mini" @click="handleExport"
          v-hasPermi="['web:camera:export']">导出</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button type="success" plain icon="el-icon-refresh" size="mini" @click="register"
          v-hasPermi="['web:camera:reboot']">重启服务</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button type="success" plain icon="el-icon-refresh" size="mini" @click="restartM3u8"
          v-hasPermi="['web:camera:m3u8']">重启视频服务</el-button>
      </el-col>
      <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
    </el-row>

    <el-table v-loading="loading" :data="cameraList" @selection-change="handleSelectionChange">
      <el-table-column type="selection" width="55" align="center" />
      <el-table-column min-width="60" align="center" label="序号">
        <template slot-scope="scope">
          <span>{{ (queryParams.page - 1) * queryParams.limit + scope.$index + 1 }}</span>
        </template>
      </el-table-column>
      <el-table-column label="设备名" align="center" prop="name" />
      <el-table-column label="设备ip" align="center" prop="ip" />
      <el-table-column label="设备序列号" align="center" prop="devsn" />
      <el-table-column label="首次注册时间" align="center" prop="firstTime"  width="220"/>
      <el-table-column label="心跳时间" align="center" prop="updateTime"  width="220"/>
      <el-table-column label="4G强度" align="center" prop="rssiLevel" />
      <el-table-column label="接入方式" align="center" prop="accessType">
        <template slot-scope="scope">
          <dict-tag :options="dict.type.camera_access_type" :value="scope.row.accessType"/>
        </template>
      </el-table-column>
      <el-table-column label="摄像机品牌" align="center" prop="brand">
        <template slot-scope="scope">
          <div v-for="item in brandList">
            {{(scope.row.brand == item.id)?item.name:''}}
          </div>
        </template>
      </el-table-column>
      <el-table-column label="状态" align="center" prop="status">
        <template slot-scope="scope">
          <span v-if="scope.row.status == 1">
            <el-tag type="success">在线</el-tag>
          </span>
          <span v-if="scope.row.status == 0">
            <el-tag type="info">离线</el-tag>
          </span>
        </template>
      </el-table-column>
      <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
        <template slot-scope="scope">
          <!--       <el-button
            size="mini"
            type="text"
            icon="el-icon-setting"
            @click="openFtpCfg(scope.row)"
            v-hasPermi="['web:camera:remove']"
          >FTP配置</el-button>
          <el-button
            size="mini"
            type="text"
            icon="el-icon-search"
            @click="showVideo(scope.row)"
            v-hasPermi="['web:camera:remove']"
          >查看视频</el-button> -->
          <el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)"
            v-hasPermi="['web:camera:edit']">修改</el-button>
          <!--   <el-button
            size="mini"
            type="text"
            icon="el-icon-refresh"
            @click="reboot(scope.row)"
            v-hasPermi="['web:camera:remove']"
            v-loading.fullscreen.lock="fullscreenLoading"
          >重启</el-button> -->
          <el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)"
            v-hasPermi="['web:camera:remove']">删除</el-button>


          <el-button size="mini" type="text" icon="el-icon-view" @click="playVideo(scope.row)"
            v-hasPermi="['web:camera:net']">播放视频</el-button>


          <el-button size="mini" type="text" icon="el-icon-setting" @click="setConfig(scope.row)"
            v-hasPermi="['web:camera:config']">参数</el-button>

          <el-dropdown size="mini" @command="(command) => handleCommand(command, scope.row)"
            v-hasPermi="['web:camera:4g']">
            <span class="el-dropdown-link">
              <i class="el-icon-d-arrow-right el-icon--right"></i>更多
            </span>
            <el-dropdown-menu slot="dropdown">
              <el-dropdown-item command="refreshRssi" icon="el-icon-s-operation">
                刷新4G信号</el-dropdown-item>
              <el-dropdown-item command="openFtpCfg" icon="el-icon-setting">FTP配置
              </el-dropdown-item>
              <el-dropdown-item command="showVideo" icon="el-icon-view">查看视频
              </el-dropdown-item>
              <el-dropdown-item command="showLog" icon="el-icon-view">查看日志
              </el-dropdown-item>
              <el-dropdown-item command="showDate" icon="el-icon-view">补光时间
              </el-dropdown-item>
              <el-dropdown-item command="reboot" icon="el-icon-refresh">重启
              </el-dropdown-item>
              <el-dropdown-item command="autocfg" icon="el-icon-refresh">自动重启配置
              </el-dropdown-item>
              <el-dropdown-item command="setTime" icon="el-icon-refresh">时间校准
              </el-dropdown-item>
            </el-dropdown-menu>
          </el-dropdown>
        </template>
      </el-table-column>
    </el-table>

    <pagination v-show="total > 0" :total="total" :page.sync="queryParams.page" :limit.sync="queryParams.limit"
      @pagination="getList" />

    <!-- 添加或修改摄像机对话框 -->
    <el-dialog  :title="title" :visible.sync="open" width="600px" append-to-body>
      <el-form ref="form" :model="form" :rules="rules" label-width="100px">
        <el-form-item label="设备名" prop="name">
          <el-input v-model="form.name" placeholder="请输入设备名" />
        </el-form-item>
        <el-form-item label="设备ip" prop="ip">
          <el-input v-model="form.ip" placeholder="请输入设备ip" />
        </el-form-item>
        <el-form-item label="设备端口" prop="port">
          <el-input v-model="form.port" placeholder="请输入设备端口" />
        </el-form-item>
        <el-form-item label="设备登录账号" prop="username">
          <el-input v-model="form.username" placeholder="请输入设备登录账号" />
        </el-form-item>
        <el-form-item label="设备登录密码" prop="password">
          <el-input v-model="form.password" placeholder="请输入设备登录密码" />
        </el-form-item>
        <el-form-item label="设备序列号" prop="devsn">
          <el-input v-model="form.devsn" placeholder="请输入设备序列号" />
        </el-form-item>
        <el-form-item label="接入方式" prop="accessType">
          <el-select v-model="form.accessType" placeholder="请选择接入方式">
            <el-option
              v-for="dict in dict.type.camera_access_type"
              :key="dict.value"
              :label="dict.label"
              :value="parseInt(dict.value)"
            ></el-option>
          </el-select>
        </el-form-item>
        <el-form-item label="摄像机品牌" prop="brand">
          <el-select v-model="form.brand" placeholder="请选择摄像机品牌">
            <el-option
              v-for="dict in brandList"
              :key="dict.id"
              :label="dict.name"
              :value="parseInt(dict.id)"
            ></el-option>
          </el-select>
        </el-form-item>
      </el-form>
      <div slot="footer" class="dialog-footer">
        <el-button type="primary" @click="submitForm">确 定</el-button>
        <el-button @click="cancel">取 消</el-button>
      </div>
    </el-dialog>

    <!-- ftp配置对话框 -->
    <el-dialog title="FTP配置" :visible.sync="ftp.open">
      <div class="container">
        <!-- 表单 -->
        <div class="ftpform">
          <el-form :model="ftp.form" :label-width="ftp.width">
            <el-form-item label="启用">
              <el-switch v-model="ftp.run"></el-switch>
            </el-form-item>
            <el-form-item label="服务器地址">
              <el-input v-model="ftp.form.address"></el-input>
            </el-form-item>
            <el-form-item label="服务器端口">
              <el-input v-model="ftp.form.port"></el-input>
            </el-form-item>
            <el-form-item label="用户名">
              <el-input v-model="ftp.form.username"></el-input>
            </el-form-item>
            <el-form-item label="密码">
              <el-input v-model="ftp.form.password"></el-input>
            </el-form-item>
            <el-form-item label="FTP图片路径">
              <el-input v-model="ftp.form.pathRule" type="textarea" :rows="3"></el-input>
            </el-form-item>
          </el-form>
        </div>
        <!-- 参考表格 -->
        <div class="table">
          <div class="head">路径配置参考</div>
          <div class="content">
            <div class="tips">
              <span>%Y: 年</span>
              <span>%M: 月</span>
              <span>%D: 日</span>
              <span>%h: 时</span>
              <span>%m: 分</span>
              <span>%s: 秒</span>
              <span>%u: 毫秒</span>
              <span>%c: 通道</span>
              <span>%n: 设备序列号</span>
              <span>%i: 设备ip</span>
              <span>%e: 事件名称</span>
              <span>%a: MAC地址</span>
            </div>
            <div class="notice">
              <div>注意: </div>
              <div>
                文件夹名以/隔开; 多个%%自动转为一个%;
                不可出现路径代码提示中没有的"%"+字符组合, 否则将保存失败!
              </div>
            </div>
          </div>
        </div>
      </div>
      <div slot="footer" class="dialog-footer">
        <el-button @click="ftp.open = false">取 消</el-button>
        <el-button type="primary" @click="ftpConfirm">确 定</el-button>
      </div>
    </el-dialog>
    <!-- 自动重启配置对话框 -->
    <el-dialog title="自动重启配置" :visible.sync="restartcfg.open">
      <div class="container">
        <!-- 表单 -->
        <div class="restartcfgform">
          <el-form>
            <el-form-item label="启用">
              <el-switch v-model="restartcfg.run"></el-switch>
            </el-form-item>
            <el-select v-model="restartcfg.form.uWeekDay" placeholder="选择星期">
              <el-option v-for="item in options" :key="item.value" :label="item.label" :value="parseInt(item.value)">
              </el-option>
            </el-select>
            <el-time-select v-model="restartcfg.form.uHour" :picker-options="{
              start: '00:00',
              step: '01:00',
              end: '23:00'
            }" placeholder="选择时间">
            </el-time-select>
          </el-form>
        </div>
      </div>
      <div slot="footer" class="dialog-footer">
        <el-button @click="restartcfg.open = false">取 消</el-button>
        <el-button type="primary" @click="restartcfgConfirm">确 定</el-button>
      </div>
    </el-dialog>
    <!-- 日志详情对话框 -->
    <el-dialog title="日志查询" :visible.sync="logform.open">
      <div >
        <!-- 表单 -->
        <el-form :model="logform.queryForm" ref="queryForm" size="small" :inline="true" label-width="200px">

          <el-date-picker v-model="timeStage" type="datetimerange" range-separator="至" start-placeholder="开始日期"
            end-placeholder="结束日期" @change="chooseTimeRange" :picker-options="setDateRange">
          </el-date-picker>
          <el-form-item>
            <el-button type="primary" icon="el-icon-search" size="mini" @click="handleAutoQuery">查询</el-button>
          </el-form-item>
          <el-table :data="logInfoList" stripe style="width: 100%">

            <el-table-column label="记录时间" align="center" prop="clogTime" />
            <el-table-column label="用户名" align="center" prop="coperUserName" />
            <el-table-column label="主类型" align="center" prop="cmainType" />
            <el-table-column label="次类型" align="center" prop="csubType" />
            <el-table-column label="远程IP" align="center" prop="cremoteIP" />

          </el-table>


        </el-form>

      </div>


    </el-dialog>
    <el-dialog title="查看时间" :visible.sync="updateDate.open">
      <div>
        <el-form  :model="updateDate.queryForm" label-width="80px">
          <el-form-item label="模式">
            <el-select v-model="updateDate.queryForm.emMode" placeholder="请选择模式" style="width: 200px;">
              <el-option
                v-for="item in modelList"
                :key="item.value"
                :label="item.label"
                :value="item.value">
              </el-option>
            </el-select>
          </el-form-item>
          <el-form-item label="预设亮度">
            <el-input-number v-model="updateDate.queryForm.nPreValue" controls-position="right" :min="1" :max="100"></el-input-number>
          </el-form-item>
          <el-form-item label="亮度">
            <el-input-number v-model="updateDate.queryForm.nBrightness" controls-position="right" :min="1" :max="100"></el-input-number>
          </el-form-item>
          <el-form-item v-if="updateDate.queryForm.emMode=='3'" label="时间段1">
            <el-time-picker
              size="small"
              align="center"
              format="HH:mm:ss"
              style="width: 150px;margin-right: 5px;"
              v-model="updateDate.queryForm.startTime1"
              :picker-options="{
                selectableRange: '00:00:00 - 23:59:59'
              }"
              placeholder="任意时间点">
            </el-time-picker>
            <el-time-picker
              size="small"
              align="center"
              style="width: 150px"
              v-model="updateDate.queryForm.endTime1"
              :picker-options="{
                selectableRange: '00:00:00 - 23:59:59'
              }"
              placeholder="任意时间点">
            </el-time-picker>
          </el-form-item>
          <el-form-item v-if="updateDate.queryForm.emMode=='3'" label="时间段2">
            <el-time-picker
              size="small"
              align="center"
              style="width: 150px;margin-right: 5px;"
              v-model="updateDate.queryForm.startTime2"
              :picker-options="{
                selectableRange: '00:00:00 - 23:59:59'
              }"
              placeholder="任意时间点">
            </el-time-picker>
            <el-time-picker
              size="small"
              align="center"
              style="width: 150px"
              v-model="updateDate.queryForm.endTime2"
              :picker-options="{
                selectableRange: '00:00:00 - 23:59:59'
              }"
              placeholder="任意时间点">
            </el-time-picker>
          </el-form-item>
        </el-form>
        <div slot="footer" class="dialog-footer">
          <el-button @click="updateDate.open = false">取 消</el-button>
          <el-button type="primary" @click="setLightCfg()">确 定</el-button>
        </div>
      </div>
    </el-dialog>

<!--    <el-dialog title="播放视频" :visible.sync="videoData.open">
      <div>
        <video
          id="my-video"
          class="video-js vjs-default-skin"
          controls
          preload="auto"
          width="500px"
        >
          <source src="http://192.168.1.219/hls/192_168_1_40/live.m3u8" type="application/x-mpegURL" />
        </video>
      </div>
    </el-dialog>-->

    <el-dialog
      title="播放视频"
      :visible.sync="videoData.open"
      :close-on-click-modal="false"
      :append-to-body="true"
      @close="closeVideo"
      align="center"
    >
      <div v-html="videoHtml">
      </div>
    </el-dialog>

    <el-dialog  title="水尺参数" :visible.sync="configopen" width="600px" append-to-body>
      <el-form ref="cform" :model="configform" label-width="100px">
        <el-form-item label="总长度" prop="tLen">
          <el-input type="number" v-model="configform.tlen" placeholder="某一时刻水位+水位上水尺长度(单位米)" />
        </el-form-item>
        <el-form-item label="出水长度" prop="cLen">
          <el-input type="number" v-model="configform.clen" placeholder="某一时刻水面上水尺长度(单位米)" />
        </el-form-item>
        <el-form-item label="出水长度" prop="cP">
          <el-input type="number" v-model="configform.cp" placeholder="水面上的水尺长度对应像素" />
        </el-form-item>
      </el-form>
      <div slot="footer" class="dialog-footer">
        <el-button type="primary" @click="configSubmit">确 定</el-button>
      </div>
    </el-dialog>

  </div>
</template>

<script>
import { formatDate } from "../../../utils/common";
import { Message } from 'element-ui'
import videojs from "video.js";
import "videojs-contrib-hls";

export default {
  name: "Camera",
  dicts: ['camera_access_type'],
  data() {
    return {
      videoHtml: '',
      // 遮罩层
      loading: true,

      fullscreenLoading: false,
      // 选中数组
      ids: [],
      // 非单个禁用
      single: true,
      // 非多个禁用
      multiple: true,
      // 显示搜索条件
      showSearch: true,
      // 总条数
      total: 0,
      // 摄像机表格数据
      cameraList: [],
      // 弹出层标题
      title: "",
      // 是否显示弹出层
      open: false,
      configopen: false,
      videoData:{
        open: false,
      },
      // 查询参数
      queryParams: {
        page: 1,
        limit: 10,
        name: null,
        ip: null,
        port: null,
        username: null,
        password: null,
        devsn: null,
        status: null
      },
      // 表单参数
      form: {},
      configform: {},
      // 表单校验
      rules: {
      },
      // ftp配置
      ftp: {
        open: false,
        form: {
          address: '',
          port: '',
          username: '',
          password: '',
          pathRule: '',
          isEnable: '',
          devsn: '',
          accessType: null,
          brand: null
        },
        run: false,
        width: '100px'
      },
      modelList:[
        {
          value: '0', label: '强制关闭'
        },
        {
          value: '1', label: '强制开启'
        },
        {
          value: '2', label: '自动'
        },
        {
          value: '3', label: '自动时间'
        }
      ],
      //自动重启设置
      restartcfg: {
        open: false,
        form: {
          id: '',
          bEnable: '',
          uHour: '',
          uWeekDay: '',
        },
        run: false,
      },
      //日志
      logform: {
        open: false,
        queryForm: {
          id: '',
          startTime: '',
          endTime: ''
        },

        run: false,
      },
      updateDate:{
        open: false,
        queryForm: {
          id: '',
          emMode: '',
          nPreValue: '1',
          nBrightness: '1',
          startTime1: new Date(2022, 9, 10, 18, 40),
          endTime1: new Date(2022, 9, 10, 18, 40),
          startTime2: new Date(2022, 9, 10, 18, 40),
          endTime2: new Date(2022, 9, 10, 18, 40),
        },
      },
      logInfoList: [],
      options: [{
        value: '0',
        label: '星期日'
      }, {
        value: '1',
        label: '星期一'
      }, {
        value: '2',
        label: '星期二'
      }, {
        value: '3',
        label: '星期三'
      }, {
        value: '4',
        label: '星期四'
      }, {
        value: '5',
        label: '星期五'
      }, {
        value: '6',
        label: '星期六'
      }],
      // 摄像机品牌列表
      brandList: [],
      timeStage: [],
      num: Date.now(),
      // 设置可选择的时间段,*** 必须在 data 返回数据 ***
      setDateRange: {

        // 设置不能选择的日期
        onPick: ({
          maxDate,
          minDate
        }) => {
          if (minDate) { //如果默认有最小日期
            this.choiceDate0 = minDate.getTime();
          } else { //如果最小日期被清空,则最小日期为当天
            this.choiceDate0 = new Date();
          }
          if (maxDate) {
            this.choiceDate0 = '';
          }
        },
        disabledDate: (time) => {
          let choiceDateTime = new Date(this.choiceDate0).getTime(); //选中的第一个日期
          if (this.choiceDate0) {
            //间隔15天,则加减14天---“这主要看需求”
            //14天的时间戳:14*24*3600*1000=1209600000
            return (time.getTime() > (choiceDateTime + 86400000)) || (time.getTime() < (choiceDateTime - 86400000));
          }
        },

      },
    };
  },
  created() {
    this.getList();
    this.geBrandList();
  },
  mounted() {
    this.$nextTick(() => {
      this.getVideo()
    })
  },
  methods: {
    /** 查询brand列表 */
    async geBrandList() {
      let res = await this.$axiosGet('/web/brand/brands');
      if(res.code === 0){
        this.brandList = res.data;
      }
    },

    /** 查询摄像机列表 */
    async getList() {
      this.loading = true;
      let res = await this.$axiosGet('/web/camera/list', this.queryParams);
      if (res.code === 0) {
        this.cameraList = res.data;
        this.total = res.count;
      }
      this.loading = false;
    },
    // 取消按钮
    cancel() {
      this.open = false;
      this.reset();
    },
    // 表单重置
    reset() {
      this.form = {
        id: null,
        name: null,
        ip: null,
        port: null,
        username: null,
        password: null,
        devsn: null,
        status: "0",
        accessType: null,
        brand: null
      };
      this.resetForm("form");
    },
    configreset() {
      this.configform = {
        id: null,
        lstart: null,
        tlen: null,
        clen: null,
        cp: null
      };
      this.resetForm("configform");
    },
    // 表单重置
    ftpCfgReset() {
      this.ftp.form = {
        address: '',
        port: '',
        username: '',
        password: '',
        pathRule: '',
        isEnable: '',
        devsn: ''
      };
      this.resetForm("form");
    },
    updateDateReset(){
      this.updateDate.queryForm= {
        id: '',
        emMode: '2',
        nPreValue: '1',
        nBrightness: '1',
        startTime1: new Date(2022, 9, 10, 18, 40),
        endTime1: new Date(2022, 9, 10, 18, 40),
        startTime2: new Date(2022, 9, 10, 18, 40),
        endTime2: new Date(2022, 9, 10, 18, 40),
      }

    },
    /** 搜索按钮操作 */
    handleQuery() {
      this.queryParams.page = 1;
      this.getList();
    },
    /** 重置按钮操作 */
    resetQuery() {
      this.resetForm("queryForm");
      this.handleQuery();
    },
    // 多选框选中数据
    handleSelectionChange(selection) {
      this.ids = selection.map(item => item.id)
      this.single = selection.length !== 1
      this.multiple = !selection.length
    },
    /** 新增按钮操作 */
    handleAdd() {
      this.reset();
      this.open = true;
      this.title = "添加摄像机";
    },
    // 更多操作触发
    handleCommand(command, row) {
      switch (command) {
        case "refreshRssi":
          this.refreshRssi(row);
          break;
        case "openFtpCfg":
          this.openFtpCfg(row);
          break;
        case "showVideo":
          this.showVideo(row);
          break;
        case "showLog":
          this.showLog(row);
          break;
        case "showDate":
          this.showDate(row);
          break;
        case "reboot":
          this.reboot(row);
          break;
        case "autocfg":
          this.autocfg(row);
          break;
        case "setTime":
          this.setTime(row);
          break;
        case "playVideo":
          this.playVideo(row);
          break;
        default:
          break;
      }
    },
     /** 播放视频 */
    playVideo(row){
      this.videoData.open = true;
      this.$nextTick(() => {
        this.getVideo('http://192.168.1.219/hls/192_168_1_40/live.m3u8')
      })
    },
    //初始化播放器
    getVideo(url) {
      this.videoHtml = '<video id="myVideo" width="810px" class="video-js vjs-default-skin" controls></video>';
      this.$nextTick(() => {
        let options = {
          autoplay: true, // 设置自动播放
          controls: true, // 显示播放的控件
          sources: [ //如果需要切换视频源,src需要动态设置
            {
              src: url,
              type: "application/x-mpegURL" // 告诉videojs,这是一个hls流
            }
          ]
        };
        // videoJs的第一个参数表示的是,文档中video的id
        setTimeout(() => {
          this.player = videojs("myVideo", options);
        },2000)
      })
    },
    //通过移除DOM彻底关闭视频,避免关闭窗口后依然获取视频流占用资源
    closeVideo() {
      if (this.player) {
        this.player.dispose(); // 该方法会重置videojs的内部状态并移除dom
        this.videoHtml = '';
      }
      //注意关闭窗口时间,要在控件销毁之后,否则会有问题
      this.videoData.open = false
    },


    /** 修改按钮操作 */
    async handleUpdate(row) {
      this.reset();
      const id = row.id || this.ids
      let res = await this.$axiosGet('/web/camera/info/' + id);
      if (res.code === 0) {
        this.form = res.data;
        this.open = true;
        this.title = "修改";
      }
    },
    setConfig(row){
      this.configreset();
      this.configform = row.paramsObject;
      this.configform.id = row.id;
      this.configopen = true;
    },
    async refreshRssi(row) {
      const id = row.id;
      const status = row.status;
      if (status != 1) {
        this.$modal.msg("设备未在线");
        return;
      }
      let res = await this.$axiosGet('/web/camera/refreshRssi/' + id);
      if (res.code === 0) {
        this.$modal.msgSuccess("执行成功");
        this.getList();
      }
    },
    async openFtpCfg(row) {
      this.ftpCfgReset();
      const id = row.id;
      const status = row.status;
      if (status != 1) {
        this.$modal.msg("设备未在线");
        return;
      }
      let res = await this.$axiosGet('/camera/ftp/getNetCfg', { 'cameraId': id });
      if (res.code === 0) {
        this.ftp.form = res.data;
        this.ftp.run = this.ftp.form.isEnable == 1;
        this.ftp.open = true;
      }
    },
    // 发送ftp配置表单
    async ftpConfirm() {
      this.ftp.form.isEnable = this.ftp.run ? 1 : 0;
      let res = await this.$axiosPost('/camera/ftp/editNetCfg', this.ftp.form);
      if (res.code === 0) {
        this.$modal.msgSuccess("修改成功");
        this.ftp.open = false;
      }
    },
    async autocfg(row) {

      this.restartcfg.form.id = row.id;

      const status = row.status;
      if (status != 1) {
        this.$modal.msg("设备未在线");
        return;
      }
      let res = await this.$axiosGet('/web/camera/getautocfg/' + this.restartcfg.form.id);

      if (res.code === 0) {

        this.restartcfg.form = res.data;
        if(this.restartcfg.form.uHour <10){
          this.restartcfg.form.uHour="0"+this.restartcfg.form.uHour+":00"
        }else{
           this.restartcfg.form.uHour+=":00"
        }
        this.restartcfg.form.id = row.id;
        this.restartcfg.run = this.restartcfg.form.bEnable == 1;
        this.restartcfg.open = true;
      }
    },
    async setTime(row) {
      const status = row.status;
      if (status != 1) {
        this.$modal.msg("设备未在线");
        return;
      }
      let res = await this.$axiosGet('/web/camera/setNowTime/' + row.id);
      if (res.code === 0) {
        this.$modal.msgSuccess("执行成功");
      }
    },

    //发送自动重启配置表单
    async restartcfgConfirm() {


      this.restartcfg.form.bEnable = this.restartcfg.run ? 1 : 0;
      this.restartcfg.form.uHour = this.restartcfg.form.uHour.substring(0, 2)
      let res = await this.$axiosPost('/web/camera/setautocfg', this.restartcfg.form);
      if (res.code === 0) {
        this.$modal.msgSuccess("修改成功");
        this.restartcfg.open = false;
      }
    },
    // 显示时间
    showDate(row){
      const status = row.status;
      if (status != 1) {
        this.$modal.msg("设备未在线");
        return;
      }
      // 重置表单
      this.updateDateReset()
      this.updateDate.queryForm.id = row.id;
      this.getLigntCfg(row.id);
    },
    // 查询时间
    async getLigntCfg(id){
      let res = await this.$axiosGet('/web/camera/getLigntCfg/' + id);
      if(res.code === 0){
        let objDate = res.data
        this.updateDate.queryForm.emMode = objDate.emMode + '';
        this.updateDate.queryForm.nPreValue = objDate.nPreValue;
        this.updateDate.queryForm.nBrightness = objDate.nBrightness;
        this.updateDate.queryForm.startTime1 = new Date(2022,12,12,objDate.startHour,objDate.startMinute,objDate.startSecond)
        this.updateDate.queryForm.endTime1 = new Date(2022,12,12,objDate.endHour,objDate.endMinute,objDate.endSecond)
        this.updateDate.queryForm.startTime2 = new Date(2022,12,12,objDate.startHour2,objDate.startMinute2,objDate.startSecond2)
        this.updateDate.queryForm.endTime2 = new Date(2022,12,12,objDate.endHour2,objDate.endMinute2,objDate.endSecond2)
        this.updateDate.open = true;
      }
    },
    //修改时间
    async setLightCfg(){
      let queryData = {
        id: this.updateDate.queryForm.id,
        emMode: this.updateDate.queryForm.emMode,
        nPreValue: this.updateDate.queryForm.nPreValue,
        nBrightness: this.updateDate.queryForm.nBrightness,
        startTime1:formatDate(this.updateDate.queryForm.startTime1).split(' ')[1],
        endTime1: formatDate(this.updateDate.queryForm.endTime1).split(' ')[1],
        startTime2: formatDate(this.updateDate.queryForm.startTime2).split(' ')[1],
        endTime2: formatDate(this.updateDate.queryForm.endTime2).split(' ')[1],
      };
      let res = await this.$axiosPost('/web/camera/setLightCfg',queryData);
      if (res.code === 0){
        Message.success(res.msg)
        this.updateDate.open = false;
      }else{
        Message.error(res.msg)
      }
    },
    reboot(row) {
      const id = row.id;
      const status = row.status;
      if (status != 1) {
        this.$modal.msg("设备未在线");
        return;
      }
      this.$modal.confirm('是否确认重启?').then(() => {
        this.exeReboot(id)
      }).catch(() => { });
    },
    async exeReboot(id) {
      const loading = this.$loading({
        lock: true,
        text: 'Loading',
        spinner: 'el-icon-loading',
        background: 'rgba(0, 0, 0, 0.7)'
      });
      // this.fullscreenLoading = true;
      let res = await this.$axiosGet('/web/camera/reboot/' + id);
      if (res.code === 0) {
        // this.fullscreenLoading = false;
        loading.close();
        this.$modal.msgSuccess("执行成功,请稍等几分钟后继续操作");
        this.getList();
      }
    },
    async showVideo(row) {
      const id = row.id
      const status = row.status;
      if (status != 1) {
        this.$modal.msg("设备未在线");
        return;
      }
      let res = await this.$axiosGet('/web/camera/showVideo/' + id);
      if (res.code === 500) {
        this.$modal.msg(res.msg);
      }
    },
    async showLog(row) {
      this.logform.queryForm.id = row.id
      const status = row.status;
      if (status != 1) {
        this.$modal.msg("设备未在线");
        return;
      }
      this.logform.open = true;
    },
    chooseTimeRange() {

      if (this.timeStage != null) {
        this.logform.queryForm.startTime = formatDate(this.timeStage[0], 'yyyy-MM-dd hh:mm:ss');
        this.logform.queryForm.endTime = formatDate(this.timeStage[1], 'yyyy-MM-dd hh:mm:ss');
      }



    },
    async handleAutoQuery() {
     if(this.timeStage == null || this.timeStage.length == 0 ){
        this.$modal.msg("请选择时间");
        return;
      }
      let res = await this.$axiosGet('/web/camera/getloginfo', this.logform.queryForm);

      if (res.code === 0) {
        this.logInfoList = res.data;
        this.$modal.msgSuccess("查询成功");
      }
    },
    async register() {
      let res = await this.$axiosGet('/web/camera/register');
      if (res.code === 0) {
        this.$modal.msgSuccess("执行成功");
      }
    },
    async restartM3u8() {
      let res = await this.$axiosGet('/web/camera/retartPullM3u8');
      if (res.code === 0) {
        this.$modal.msgSuccess("执行成功,请等待几分钟...");
      }
    },
    async addMethod() {
      let res = await this.$axiosPost('/web/camera/add', this.form);
      if (res.code === 0) {
        this.$modal.msgSuccess("新增成功");
        this.open = false;
        this.getList();
      }
    },
    async editMethod() {
      let res = await this.$axiosPost('/web/camera/edit', this.form);
      if (res.code === 0) {
        this.$modal.msgSuccess("修改成功");
        this.open = false;
        this.getList();
      }
    },
    /** 提交按钮 */
    submitForm() {
      this.$refs["form"].validate(valid => {
        if (valid) {
          if (this.form.id != null) {
            this.editMethod();
          } else {
            this.addMethod();
          }
        }
      });
    },
    async configSubmit() {
      let res = await this.$axiosPost('/web/camera/setConfig', this.configform);
      if (res.code === 0) {
        this.$modal.msgSuccess("设置成功");
        this.configopen = false;
      }
    },
    /** 删除按钮操作 */
    async handleDelete(row) {
      const ids = row.id || this.ids;
      let res = await this.$axiosDelete('/web/camera/delete/' + ids);
      if (res.code === 0) {
        this.$modal.msgSuccess("删除成功");
        this.getList();
      }
    },
    /** 导出按钮操作 */
    handleExport() {
      this.download('web/camera/export', {
        ...this.queryParams
      }, `camera_${new Date().getTime()}.xlsx`)
    }
  }
};
</script>

<style scoped>
.container {
  display: flex;
}

.ftpform {
  width: 300px;
  margin-right: 50px;
}

.ftpform .el-form {
  width: 100%;
}

.table {
  flex: 1;
}

.head {
  font-size: 24px;
  line-height: 36px;
  text-align: center;
  height: 36px;
  margin: 0 auto;
  border-radius: 2px;
  box-shadow:
    1px 1px 2px hsla(200, 88%, 55%, .22),
    inset -2px -2px 2px hsla(200, 88%, 55%, .22),
    inset 0 0 1px hsla(200, 88%, 55%, .22);
}

.tips {
  margin: 10px 0;
}

.tips span {
  display: grid;
  grid: 1fr/1fr 10px;
}

.notice {
  color: #f33;
  padding-right: 20px;
  display: flex;
}

.notice div:first-child {
  width: 80px;
}
</style>