<template>
  <div class="app-container">
    <el-button type="success" @click="handleSelectMember">
      {{ $t("添加会员") }}</el-button
    >
    <div class="container">
      <div v-if="memberList.length > 0">
        <div
          class="formBox"
          v-for="(item, index) in queryParamsList"
          :key="item.memberId"
        >
          <el-form
            :model="queryParamsList[index]"
            :ref="`queryForm${item.memberId}`"
            size="small"
            :inline="true"
            :rules="rules"
            label-width="168px"
          >
            <el-card class="box-card">
              <div slot="header" class="clearfix">
                <el-row :gutter="10">
                  <span class="card-title">{{ $t("基础信息") }}</span>
                  <el-button
                    style="padding: 0 10px"
                    @click="handleExpand(item)"
                    type="text"
                    >{{ item.expand ? $t("收起") : $t("展开")
                    }}<i
                      :class="
                        item.expand
                          ? 'el-icon-caret-top'
                          : 'el-icon-caret-bottom'
                      "
                    ></i
                  ></el-button>
                  <el-button
                    type="text"
                    @click="handleDelete(index, item)"
                    class="del-btn"
                    >{{ $t("删除") }}</el-button
                  >
                </el-row>
                <el-row :gutter="10">
                  <el-form-item :label="$t('会员名称')">
                    <el-input
                      :placeholder="$t('请输入会员名称')"
                      clearable
                      :disabled="true"
                      v-model="item.memberName"
                      onkeyup="this.value=this.value.replace(/(^\s*)|(\s*$)/g,'')"
                    />
                  </el-form-item>
                  <el-form-item :label="$t('当前积分')">
                    <el-input
                      :placeholder="$t('请输入当前积分')"
                      clearable
                      :disabled="true"
                      v-model="item.holdScore"
                      onkeyup="this.value=this.value.replace(/(^\s*)|(\s*$)/g,'')"
                    />
                  </el-form-item>
                  <el-form-item :label="$t('礼品选择')">
                    <el-input
                      :placeholder="$t('请选择礼品')"
                      clearable
                      :disabled="true"
                      v-model="item.rewardName"
                      onkeyup="this.value=this.value.replace(/(^\s*)|(\s*$)/g,'')"
                    />
                  </el-form-item>
                  <el-form-item :label="$t('礼品积分')">
                    <el-input
                      :placeholder="$t('请输入礼品积分')"
                      clearable
                      :disabled="true"
                      v-model="item.pointsRequire"
                      onkeyup="this.value=this.value.replace(/(^\s*)|(\s*$)/g,'')"
                    />
                  </el-form-item>
                  <el-form-item :label="$t('兑换数量')" prop="rewardCount">
                    <el-input
                      :placeholder="$t('请输入兑换数量')"
                      clearable
                      v-model.number="item.rewardCount"
                      @change="
                        (val) => {
                          handleRewardCount(item, index, val);
                        }
                      "
                      onkeyup="this.value=this.value.replace(/(^\s*)|(\s*$)/g,'')"
                    />
                  </el-form-item>
                  <el-form-item :label="$t('本次兑换积分')">
                    <el-input
                      :placeholder="$t('请输入本次兑换积分')"
                      clearable
                      :disabled="true"
                      v-model="item.spendCredit"
                      onkeyup="this.value=this.value.replace(/(^\s*)|(\s*$)/g,'')"
                    />
                  </el-form-item>
                  <el-form-item :label="$t('兑换后剩余积分')">
                    <el-input
                      :placeholder="$t('兑换后剩余积分')"
                      clearable
                      :disabled="true"
                      v-model="item.remainingPoints"
                      onkeyup="this.value=this.value.replace(/(^\s*)|(\s*$)/g,'')"
                    />
                  </el-form-item>
                </el-row>
                <el-row :gutter="10" v-show="item.expand">
                  <el-row>
                    <span class="card-title">{{ $t("详细信息") }}</span>
                  </el-row>
                  <el-row>
                    <el-form-item :label="$t('兑换方式')" prop="redeemType">
                      <dict-selector
                        clearable
                        :type="DICT_TYPE.WAY_OF_RECEIVING"
                        v-model="item.redeemType"
                      >
                      </dict-selector>
                    </el-form-item>
                    <el-form-item :label="$t('兑换入口')">
                      <dict-selector
                        clearable
                        :disabled="true"
                        v-model="item.entrance"
                        :type="DICT_TYPE.PLATFORM_TYPE"
                      >
                      </dict-selector>
                    </el-form-item>
                    <el-form-item :label="$t('费用')" required>
                      <el-row :gutter="10">
                        <el-col :span="12">
                          <el-form-item prop="expenses">
                            <el-input
                              v-model="item.expenses"
                              :placeholder="$t('请输入数字')"
                              clearable
                              onkeyup="this.value=this.value.replace(/(^\s*)|(\s*$)/g,'')"
                            />
                          </el-form-item>
                        </el-col>
                        <el-col :span="10">
                          <el-form-item prop="currency">
                            <el-select
                              v-model="item.currency"
                              :placeholder="$t('请选择币种')"
                            >
                              <el-option
                                v-for="nodeItem in currencyList"
                                :key="nodeItem.id"
                                :label="
                                  isChinese
                                    ? nodeItem.titleZh
                                    : nodeItem.titleEn
                                "
                                :value="nodeItem.id"
                              />
                            </el-select>
                          </el-form-item>
                        </el-col>
                      </el-row>
                    </el-form-item>
                    <el-form-item :label="$t('收件人姓名')" prop="recipientName"
                      ><el-input
                        :placeholder="$t('请输入收件人姓名')"
                        clearable
                        v-model="item.recipientName"
                        onkeyup="this.value=this.value.replace(/(^\s*)|(\s*$)/g,'')"
                      />
                    </el-form-item>
                    <el-form-item
                      :label="$t('收件人电话')"
                      prop="recipientPhoneNum"
                    >
                      <el-input
                        :placeholder="$t('请输入收件人电话')"
                        clearable
                        v-model="item.recipientPhoneNum"
                        onkeyup="this.value=this.value.replace(/(^\s*)|(\s*$)/g,'')"
                      />
                    </el-form-item>
                    <el-form-item
                      :label="$t('收件人地址')"
                      prop="recipientAddress"
                      v-if="item.redeemType != '1'"
                    >
                      <el-input
                        :placeholder="$t('请输入收件人地址')"
                        clearable
                        v-model="item.recipientAddress"
                        onkeyup="this.value=this.value.replace(/(^\s*)|(\s*$)/g,'')"
                      />
                    </el-form-item>
                    <el-form-item :label="$t('兑换人')">
                      <el-input
                        :placeholder="$t('请输入兑换人')"
                        clearable
                        v-model="item.redeemer"
                        onkeyup="this.value=this.value.replace(/(^\s*)|(\s*$)/g,'')"
                      />
                    </el-form-item>
                    <el-form-item :label="$t('兑换时间')">
                      <el-date-picker
                        type="date"
                        placement="bottom-start"
                        value-format="yyyy-MM-dd HH:mm:ss"
                        :placeholder="$t('选择兑换时间')"
                        v-model="item.redemptionTime"
                      ></el-date-picker>
                    </el-form-item>
                    <el-form-item
                      :label="$t('快递公司')"
                      v-if="item.redeemType != '1'"
                    >
                      <el-select
                        v-model="item.courierCompany"
                        :placeholder="$t('请选择快递公司')"
                      >
                        <el-option
                          v-for="nodeItem in expressList"
                          :key="nodeItem.id"
                          :label="nodeItem.companyName"
                          :value="nodeItem.id"
                        />
                      </el-select>
                    </el-form-item>
                    <el-form-item
                      :label="$t('快递单号')"
                      v-if="item.redeemType != '1'"
                    >
                      <el-input
                        :placeholder="$t('请输入快递单号')"
                        clearable
                        v-model="item.expressNo"
                        onkeyup="this.value=this.value.replace(/(^\s*)|(\s*$)/g,'')"
                      />
                    </el-form-item>
                    <el-form-item
                      :label="$t('快递日期')"
                      v-if="item.redeemType != '1'"
                    >
                      <el-date-picker
                        type="date"
                        :placeholder="$t('选择快递日期')"
                        v-model="item.expressDate"
                        value-format="yyyy-MM-dd HH:mm:ss"
                        placement="bottom-start"
                      ></el-date-picker>
                    </el-form-item>
                    <el-form-item :label="$t('快递寄出人')">
                      <el-input
                        :placeholder="$t('请输入快递寄出人')"
                        clearable
                        v-model="item.expressSender"
                        onkeyup="this.value=this.value.replace(/(^\s*)|(\s*$)/g,'')"
                      />
                    </el-form-item>
                    <el-form-item :label="$t('上传附件')">
                      <file-upload v-model="item.annex"></file-upload>
                    </el-form-item>
                    <el-form-item :label="$t('备注')">
                      <el-input
                        style="width: 500px"
                        type="textarea"
                        v-model="item.remark"
                      ></el-input>
                    </el-form-item>
                  </el-row>
                </el-row>
              </div>
            </el-card>
          </el-form>
        </div>
      </div>
      <div v-else class="emptyText">
        {{ $t("请先添加准备兑换礼品的会员") }}
      </div>
      <el-row justify="end" :gutter="20" type="flex" class="handleButton">
        <el-col :span="2">
          <el-button
            v-if="memberList.length > 0"
            type="primary"
            @click="handleBulkConversion"
            >{{ $t("确认兑换") }}</el-button
          >
        </el-col>
        <el-col :span="2">
          <el-button @click="handleBack">{{ $t("返回") }}</el-button>
        </el-col>
      </el-row>
    </div>

    <choose-Member
      :dialogVisible.sync="dialogVisible"
      @transferSelectMemberInfo="onGetSelectMemberInfo"
      :memberSelectList="memberList"
    >
    </choose-Member>
  </div>
</template>
<script>
import { getRewardsDetails, bulkConversion } from "@/api/ecw/giftManagement";
import FileUpload from "@/components/FileUpload";
import chooseMember from "./components/chooseMember.vue";
import { getExpressPage } from "@/api/ecw/express";
import { getCurrencyList } from "@/api/ecw/currency";
import { getNowDateTime } from "@/utils/ruoyi";

export default {
  name: "giftManagementList",
  components: {
    chooseMember,
    FileUpload,
  },
  data() {
    var validatePass2 = (rule, value, callback) => {
      if (!this.quantityComputation) {
        return callback(
          new Error(this.$t("兑换积分大于当前总积分,请重新输入兑换数量"))
        );
      } else {
        return callback();
      }
    };
    return {
      env: process.env.NODE_ENV,
      // 是否显示弹出层
      dialogVisible: false,
      // 查询参数
      queryParamsList: [],
      // 网点
      nodeList: [],
      //快递公司列表
      expressList: [],
      memberList: [],
      currencyList: [],
      quantityComputation: null,
      checkFormResult: [],
      rules: {
        rewardCount: [
          {
            required: true,
            message: this.$t("请输入兑换数量"),
            trigger: "blur",
          },
          {
            validator: validatePass2,
            trigger: "blur",
          },
        ],
        expenses: [
          {
            required: true,
            message: this.$t("请输入费用"),
            trigger: "blur",
          },
          {
            pattern: /^\d+(\.\d{1,2})?$/,
            message: this.$t("请输入整数或保留小数点后两位"),
            trigger: "blur",
          },
        ],
        currency: [
          {
            required: true,
            message: this.$t("请选择币种"),
            trigger: "change",
          },
        ],
        redeemType: [
          {
            required: true,
            message: this.$t("请选择兑换方式"),
            trigger: "change",
          },
        ],
        recipientName: [
          {
            required: true,
            message: this.$t("请输入收件人姓名"),
            trigger: "blur",
          },
        ],
        recipientPhoneNum: [
          {
            required: true,
            message: this.$t("请输入收件人电话"),
            trigger: "blur",
          },
        ],
        recipientAddress: [
          {
            required: true,
            message: this.$t("请输入收件人地址"),
            trigger: "blur",
          },
        ],
      },
    };
  },
  computed: {
    isChinese() {
      return this.$i18n.locale === "zh_CN";
    },
  },
  created() {
    this.getRewardsDetailsAPI();
    this.getExpressList();
    this.currencyListAPI();
  },
  activated() {},
  methods: {
    handleRewardCount(item, index, value) {
      this.queryParamsList[index].spendCredit =
        this.queryParamsList[index].pointsRequire * value;
      this.queryParamsList[index].remainingPoints =
        this.queryParamsList[index].holdScore -
        this.queryParamsList[index].spendCredit;
      this.quantityComputation =
        this.queryParamsList[index].remainingPoints >= 0 ? true : false;
    },

    handleDelete(index, item) {
      this.$modal
        .confirm(this.$t("是否确认删除此数据"))
        .then(() => {
          this.queryParamsList.splice(index, 1);

          this.memberList = this.memberList.filter(
            (res) => res.id != item.memberId
          );

          this.$modal.msgSuccess(this.$t("删除成功"));
        })
        .catch(() => {});
    },
    handleExpand(item) {
      this.queryParamsList.forEach((element) => {
        if (element.memberId == item.memberId) {
          element.expand = !item.expand;
        }
      });
    },
    currencyListAPI() {
      getCurrencyList().then((res) => {
        this.currencyList = res.data;
      });
    },
    onGetSelectMemberInfo(data) {
      if (data.length > 0) {
        data.filter((item) => {
          let inculde = this.queryParamsList.some((itemQuery) => {
            return item.id == itemQuery.memberId;
          });
          if (!inculde) {
            let queryParams = {
              expand: true,
              memberId: item.id,
              holdScore: item.holdScore,
              rewardId: this.rewardsDetails.id,
              pointsRequire: this.rewardsDetails.pointsRequire,
              rewardCount: null,
              spendCredit: null, //本次兑换花费积分
              remainingPoints: null, //剩余积分
              redeemType: null,
              entrance: 1,
              expenses: null,
              currency: null,
              recipientName: null,
              recipientPhoneNum: null,
              recipientAddress: null,
              redeemer: this.$store.getters.name,
              redemptionTime: getNowDateTime("00:00:00"),
              courierCompany: null,
              expressNo: null,
              expressSender: this.$store.getters.name,
              expressDate: null,
              remark: null,
              annex: null,
            };
            if (this.isChinese) {
              queryParams.memberName = item.memberNameZh;
              queryParams.rewardName = this.rewardsDetails.titleZh;
            } else {
              queryParams.memberName = item.memberNameEn;
              queryParams.rewardName = this.rewardsDetails.titleEn;
            }
            this.memberList.push(item);
            this.queryParamsList.push({ ...queryParams });
          }
        });
      }
    },
    handleSelectMember() {
      this.dialogVisible = true;
    },
    getExpressList() {
      let params = {
        pageNo: 1,
        pageSize: 1000,
      };
      getExpressPage(params).then((res) => {
        this.expressList = res.data.list;
      });
    },
    getRewardsDetailsAPI() {
      let params = {
        id: this.$route.query.rewardsID,
      };
      getRewardsDetails(params).then((res) => {
        this.rewardsDetails = res.data;
      });
    },
    handleBack() {
      this.$store.dispatch("tagsView/delCurrentView");
    },
    checkForm(formName) {
      const result = new Promise((resolve, reject) => {
        this.$refs[formName][0].validate((valid) => {
          if (valid) {
            resolve();
          } else {
            reject();
          }
        });
      });
      this.checkFormResult.push(result);
    },
    handleBulkConversion() {
      this.queryParamsList.forEach((element) => {
        this.checkForm(`queryForm${element.memberId}`);
      });
      Promise.all(this.checkFormResult)
        .then((res) => {
          this.checkFormResult = [];
          let params = this.queryParamsList.map((item) => {
            if (item.redeemType == "1") {
              let {
                recipientAddress,
                expressNo,
                expressDate,
                courierCompany,
                ...itemNew
              } = item;
              return itemNew;
            } else {
              return item;
            }
          });
          bulkConversion(params).then((res) => {
            if (res.data.code == "0") {
              this.queryParamsList = [];
              this.memberList = [];
              this.$message.success(this.$t("兑换成功"));
            }
          });
        })
        .catch(() => {
          this.checkFormResult = [];
          this.$message.error(this.$t("兑换失败,请填写必要的信息"));
        });
    },
  },
};
</script>
<style scoped lang="scss">
.card-title {
  padding-right: 10px;
  border-right: 4px solid rgb(64, 158, 255);
  font-size: 16px;
  font-weight: 600;
}
.del-btn {
  color: red;
}
.app-container .el-date-editor.el-input,
.el-date-editor.el-input__inner {
  width: 194px;
}
.container {
  padding: 20px 0;
}
.emptyText {
  font-size: 20px;
  padding: 20px;
  line-height: 200px;
  text-align: center;
  color: #97a8be;
}
.handleButton {
  padding-right: 160px;
  margin-top: 50px;
  button {
    width: 100%;
  }
}
</style>