<template>
  <div class="all-group">
    <!-- 样式修改 -->
    <div class="message-list">
      <a-checkbox
        v-model:checked="checkAll"
        :indeterminate="indeterminate"
        @change="onCheckAllChange"
        :disabled="promptWord.checked"
      >
        全选
      </a-checkbox>
    </div>
    <div class="warp" v-if="options.length">
      <a-checkbox-group
        v-model:value="checkedList"
        :options="options"
        :disabled="promptWord.checked"
      >
        <slot></slot>
      </a-checkbox-group>
      <!-- <ns-checkbox-group v-model:value="checkedList" :options="options" /> -->
    </div>
    <div class="no-warp" v-if="!options.length">
      <ul class="prompt-information">
        <ns-icon class="icon" name="account1" size="25" style="margin-right: 5px" />
        <li>暂无数据, 请先维护</li
        ><li @click="jumpMaintenanceInformation()">{{ promptWord.maintenanceInformation }}</li></ul
      >
    </div>
    <p class="remark-prompt">{{ promptWord.message }}</p>
  </div>
</template>

<script lang="ts">
  import { defineComponent, toRefs, reactive, watch, computed, ref } from 'vue';
  import { http } from '/nerv-lib/util/http';
  import { useRouter } from 'vue-router';
  export default defineComponent({
    name: 'NsCheckboxAllGroup',
    props: {
      api: String,
      field: String,
      title: String,
      message: String,
      maintenanceInformation: String, //没有数据的情况下的维护信息
      route: String, //维护信息跳转的路由
      optionsName: Array,
      resultField: String,
      checked: String,
      options: Array
    },
    setup(props) {
      const options = ref([]); //创建options接受请求回来的值
      const state = reactive({
        indeterminate: false,
        checkAll: false,
        checkedList: [],
      });
      const router = useRouter();
      // 获取标题和备注信息
      const promptWord = computed(() => {
        return props;
      });
      //   获取后端的区域
      const getData = () => {
        options.value = [];
        if(props.options){
          options.value= props.options
        }
        http.get(props.api).then((res) => {
          if (promptWord.value.resultField == 'data') {
            res.data.forEach((element) => {
              element['label'] = element[promptWord.value.optionsName[0]];
              element['value'] = element[promptWord.value.optionsName[1]];
            });
            options.value = res.data;
          } else {
            res.data.data.forEach((element) => {
              element['label'] = element[promptWord.value.optionsName[0]];
              element['value'] = element[promptWord.value.optionsName[1]];
            });
            options.value = res.data.data;
          }
        });
      };
      const jumpMaintenanceInformation = () => {
        router.push(props.route);
      };
      getData();
      // 全选的时候会触发这个方法
      const onCheckAllChange = (e: any) => {
        state.checkedList = [];
        if (e.target.checked) {
          (state.indeterminate = false),
            options.value.forEach((item) => {
              state.checkedList.push(item['value']);
            });
        }
        state.indeterminate = false;
      };
      //   监听选中的数据
      watch(
        () => state.checkedList,
        (val) => {
          state.indeterminate = !!val.length && val.length < options.value.length;
          state.checkAll = val.length === options.value.length;
        }
      );

      return {
        ...toRefs(state),
        onCheckAllChange,
        promptWord,
        options,
        jumpMaintenanceInformation,
      };
    },
  });
</script>
<style lang="less" scoped>
  .all-group {
    // margin-left: 22.22%;
  }
  .warp {
    width: 100%;
    height: 100%;
    border: 1px solid #dcdfe2;
    background: #f8f9fc;
  }
  .no-warp {
    width: 100%;
    height: 100px;
    border: 1px solid #dcdfe2;
    background: #f8f9fc;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    .prompt-information {
      list-style: none;
      display: flex;
      padding-left: 7px;
      //   position: absolute;
      //   left: 50%;
      //   top: 40%;
      li:nth-of-type(1) {
        color: #828282;
      }
      li:nth-of-type(2) {
        color: #6865ea;
      }
    }
  }
  .message-list {
    display: flex;
  }
  .message-list p {
    margin-right: 5px;
    color: #606060;
  }
  .ant-checkbox-group {
    margin: 22px 18px 26px !important;
  }

  :deep(.ant-checkbox-group-item) {
    margin-right: 110px !important;
  }

  .remark-prompt {
    font-family: PingFang SC;
    font-style: normal;
    font-weight: normal;
    font-size: 14px;
    line-height: 22px;

    color: #c1c1c1;
    margin-top: 7px;
  }
</style>