<template>
  <div class="div-add">
    <button class="add" @click="addModal">添加</button>
    <a-popconfirm
      title="是否提交以上修改?"
      placement="bottomLeft"
      ok-text="确定"
      cancel-text="取消"
      @confirm="sendTable">
      <button class="add" style="margin-left: 20px">执行</button>
    </a-popconfirm>
  </div>
  <div class="buttons">
    <span style="color: red; padding-top: 20px">*以下修改需执行后生效</span>
    <div class="plans">
      <button class="plan enabled" style="margin-right: 10px" @click="togglePlan(1)">
        计划启用
      </button>
      <button class="plan disabled" @click="togglePlan(3)"> 计划禁用 </button>
    </div>
  </div>
  <table class="custom-table table1">
    <thead>
      <tr :style="{ background: 'rgba(35,45,69)' }">
        <th>序号</th>
        <th>执行时间</th>
        <th>计划名称</th>
        <th>状态</th>
        <th>操作</th>
      </tr>
    </thead>
    <tbody>
      <tr v-for="(row, index) in dataSource" :key="index">
        <td>{{ index + 1 }}</td>
        <td>{{ row.startTime }}</td>
        <td>{{ row.planName }}</td>
        <td>
          <button
            :style="{
              'font-size': '12px',
              width: '5em',
              background: 'rgb(47, 47, 47)',
              color: setStateColor(row.executeStatus.value),
              border: '1px solid',
            }">
            {{ setStateText(row.executeStatus.value) }}
          </button>
        </td>
        <td>
          <div class="tabReboot" @click="startPlan(row)">启用</div>
          <a-popconfirm
            title="此操作将移除该数据"
            ok-text="确定"
            cancel-text="取消"
            @confirm="deletePlan(row)">
            <div class="tabDelete">删除</div>
          </a-popconfirm>
        </td>
      </tr>
    </tbody>
  </table>
  <div class="out-dialog" v-if="addVisible">
    <div class="content" v-if="addVisible">
      <div class="div-operation"></div>
      <span class="text-operation">计划库</span>
    </div>
    <div style="margin-top: 20px">
      <a-transfer
        v-model:target-keys="targetKeys"
        :data-source="transferData"
        show-search
        :filter-option="filterOption"
        :render="(item: any) => item.title"
        @change="handleChange"
        :style="{ color: 'rgba(255,255,255,1)' }"
        @search="handleSearch"
        :listStyle="{ border: '2px solid rgba(25,74,125,1)', height: 'calc(100vh - 200px)' }" />
    </div>
    <div style="width: 100%; height: 60px"></div>
    <div class="button-box">
      <button class="cancel" @click="addVisible = false">取消</button>
      <button class="execute" @click="sendPlan">确定</button>
    </div>
  </div>
</template>

<script setup lang="ts">
  import { ref, onMounted } from 'vue';
  // 请求
  import { http } from '/nerv-lib/util/http';
  import { ventilating } from '/@/api/ventilatingSystem';
  import { planManage } from '/@/api/planManage';
  import { message } from 'ant-design-vue';
  // 全局变量
  import { items } from '/@/store/item';

  // 初始化 ===========================================================

  const props = defineProps({
    // 分区结构(照明区域 > 照明回路)
    status: {
      type: Array,
      default: () => {
        [];
      },
    },
    type: {
      type: Number,
    },
  });
  let url = '';
  // 全局变量
  const state = items();
  onMounted(() => {
    // 计划表格
    getTable();
    // 穿梭框原始数据
    getLeftPlan();
    let type = props.type;
    if (type == 3) {
      url = ventilating.submitTableData1;
    } else if (type == 4) {
      url = ventilating.submitTableData2;
    } else if (type == 5) {
      url = ventilating.submitTableData3;
    }
  });

  // tab页部分 ========================================================

  // 设置枚举的颜色 与 文本
  const setStateColor = (state: number) => {
    if (state == 0) {
      return '#ccc';
    } else if (state == 1) {
      return 'orange';
    } else if (state == 2) {
      return 'rgb(57, 215, 187)';
    } else if (state == 3) {
      return 'rgb(255, 0, 0)';
    }
  };
  // 设置枚举的文本
  const setStateText = (state: number) => {
    const res = props.status.find((item: any) => {
      return item.value == state;
    });
    return res.label;
  };
  // 计划启用/禁用事件
  const togglePlan = (state: number) => {
    dataSource.value.forEach((item: any) => {
      item.executeStatus.value = state;
    });
  };

  // 表格数据
  const dataSource = ref([]);
  // 获得表格数据
  const getTable = () => {
    http
      .get(planManage.getTableData, {
        projectId: state.projectId,
        siteId: state.siteId,
        // 设备类型(1照明,2空调,3排风扇,4风幕机,5电动窗,6进水阀,7排水泵)
        deviceType: props.type,
      })
      .then((res) => {
        dataSource.value = res.data;
      });
  };
  // 删除表格中的计划(将当前任意状态,修改为未启用 =0)
  const deletePlan = (row: any) => {
    row.executeStatus.value = 0;
  };
  // 重启表格中的计划(将当前任意状态,修改为待执行 = 1)
  const startPlan = (row: any) => {
    if (row.executeStatus.value == 1) {
      return message.info('该数据已是待执行状态,无需再次修改');
    }
    row.executeStatus.value = 1;
  };
  // 将对表格的修改统一发送
  const sendTable = () => {
    http
      .post(
        url + `?projectId=${state.projectId}${state.siteId ? `&siteId=${state.siteId}` : ''}`,
        dataSource.value,
      )
      .then(() => {
        message.success('操作成功');
        getTable();
        getLeftPlan();
      });
  };

  // tab页弹窗部分 ====================================================

  // 添加弹窗控制变量
  const addVisible = ref(false);
  // 打开弹窗
  const addModal = () => {
    addVisible.value = true;
  };

  // 穿梭框部分 =======================================================

  // 穿梭框数据
  const transferData = ref([]) as any;
  // 获得穿梭框原始数据
  const getLeftPlan = () => {
    http
      .get(planManage.getTransData, {
        projectId: state.projectId,
        siteId: state.siteId,
        // 设备类型(1照明,2空调,3排风扇,4风幕机,5电动窗,6进水阀,7排水泵)
        deviceType: props.type,
      })
      .then((res) => {
        let arr: Array<Object> = [];
        res.data.forEach((item: any) => {
          arr.push({
            key: item.id,
            title: item.planName,
          });
        });
        transferData.value = arr;
      });
  };

  const handleChange = (keys: string[], direction: string, moveKeys: string[]) => {
    console.log(keys, direction, moveKeys);
  };
  const handleSearch = (dir: string, value: string) => {
    console.log('search:', dir, value);
  };
  // 穿梭框选中数据
  const targetKeys = ref<string[]>([]);
  // 将穿梭框选中的计划提交
  const sendPlan = () => {
    if (targetKeys.value.length < 1) {
      return message.info('没有选择任何计划');
    }
    http.post(planManage.submitTransData, targetKeys.value).then(() => {
      message.success('添加成功');
      // 如果发送成功,则刷新表格
      getTable();
      getLeftPlan();
    });
  };

  const filterOption = (inputValue: string, option: any) => {
    return option.description.indexOf(inputValue) > -1;
  };
</script>
<style lang="less" scoped>
  @import '../../style/dialogStyle.less';
  .buttons {
    display: flex;
    justify-content: space-between;
    .plan {
      border: none;
      font-size: 14px;
      font-weight: 400;
      border-radius: 5px;
      width: 88px;
      height: 32px;
      color: white;
      cursor: pointer;
      margin: 15px 0;
      vertical-align: middle;
    }
    .plan.enabled {
      background: linear-gradient(180deg, rgba(103, 222, 0, 1) 0%, rgba(0, 181, 6, 1) 100%);
    }
    .plan.disabled {
      background-color: red;
    }
    .plan:disabled {
      cursor: not-allowed;
    }
  }
  // 右下角添加按钮
  .div-add {
    height: 64px;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    position: fixed;
    bottom: 0;
    right: 0;
    margin-right: 10px;
    .add {
      width: 74px;
      height: 40px;
      opacity: 1;
      border-radius: 4px;
      background: rgba(67, 136, 251, 1);
      border: rgba(67, 136, 251, 1);
      font-size: 14px;
      font-weight: 400;
      color: rgba(255, 255, 255, 1);
      cursor: pointer;
    }
  }
  // 表格
  .custom-table {
    border-collapse: collapse;
    width: 416px;
    height: 40px;
    color: rgba(255, 255, 255, 1);
  }
  .custom-table th,
  .custom-table td {
    border: 1px solid rgba(163, 192, 243, 1);
    text-align: left;
    padding: 8px;
    text-align: center;
  }
  .table1 {
    width: 100%;
    border: 1px solid rgba(255, 255, 255);
    border-radius: 5px;
    background: rgba(255, 255, 255, 0.1);
    // 表格中的操作按钮
    .tabReboot,
    .tabDelete {
      border: none;
      display: inline-block;
      background-color: rgba(0, 0, 0, 0);
      font-size: 14px;
      font-weight: 400;
      letter-spacing: 0;
      line-height: 20px;
      color: rgba(67, 136, 251, 1);
      cursor: pointer;
    }
    .tabReboot {
      margin-right: 8px;
    }
    .tabReboot::active {
      color: white !important;
    }
    .tabDelete::active {
      color: white;
    }
  }
  ::v-deep(.ant-transfer) {
    // 屏蔽自带的hover效果
    .ant-transfer-list-content-item:hover {
      background: black;
    }
  }
</style>