choosePerson.vue 5.66 KB
<template>
  <el-dialog v-model="show" width="500" :title="languageFormat(language, '出行人信息', 'Travelers')" center
             append-to-body>
    <el-button type="primary" plain @click="addPeopl">{{ languageFormat(language, "新增", "Add") }}</el-button>
    <el-radio-group v-model="personId">
      <div v-for="(it, index) in personList" :key="index" class="e_item">
        <el-radio border :value="it.id" :disabled="hasPersonIds?.indexOf(it.id)!=-1">

          <div class="name">{{ it.name }}</div>
          <div class="code">
            <span v-if="it.idcType==0">{{ language == 0 ? '身份证' : 'ID number' }}</span>
            <span v-if="it.idcType==1">{{ language == 0 ? '护照' : 'Passport' }}</span>
            <span v-if="it.idcType==2">{{ language == 0 ? '其他' : 'Other' }}</span>

            {{ it.idCard }}
          </div>

        </el-radio>
      </div>
    </el-radio-group>
    <template #footer>
      <div class="dialog-footer">
        <el-button @click="show = false">{{ languageFormat(language, "取 消", "Cancel") }}</el-button>
        <el-button type="primary" @click="addPerson">{{ languageFormat(language, "完 成", "Ok") }}</el-button>
      </div>
    </template>
  </el-dialog>


  <el-dialog v-model="showAdd" :title="language ==0?'新增出行人':'Add traveler'" center append-to-body>
    <el-form
        ref="formRef" :model="form" label-width="100px" size="large"
        style="margin: 80px"
    >
      <el-form-item :label="language==0?'姓名':'name'" prop="name" required :show-message="false">
        <el-input v-model="form.name" :placeholder="language==0?'请输入':'Please input'"/>
      </el-form-item>
      <el-form-item :label="language==0?'证件类型':'ID Type'" prop="idcType" required :show-message="false">
        <el-select v-model="form.idcType" :placeholder="language==0?'请选择':'Please choose'">
          <el-option :label="language==0?'身份证':'Identity card'" value="0"/>
          <el-option :label="language==0?'护照':'Passport'" value="1"/>
          <el-option :label="language==0?'其他':'Other'" value="2"/>
        </el-select>
      </el-form-item>
      <el-form-item :label="language==0?'证件号':'ID number'" prop="idCard" required :show-message="false">
        <el-input v-model="form.idCard" :placeholder="language==0?'请输入证件号':'Please enter the ID after ah'"/>
      </el-form-item>
    </el-form>

    <template #footer>
      <div class="dialog-footer">
        <el-button class="can_pay" @click="showAdd = false">{{ language == 0 ? '取 消' : 'cancel' }}</el-button>
        <el-button class="pay" type="primary" @click="submit">{{ language == 0 ? '确 定' : 'confirm' }}</el-button>
      </div>
    </template>
  </el-dialog>

</template>

<script setup>
import {aadSceneCustomer, checkSceneCustomer, getMyFriends} from '/@/apiPc/booking'
import {languageFormat} from '/@/viewsPc/seat/utils/language'
import {onMounted, ref} from 'vue'
import {useStorage} from '@vueuse/core/index'
import _ from 'lodash'
import {getCurrentInstance} from '@vue/runtime-core'

const emit = defineEmits(['addPerson'])
const {proxy} = getCurrentInstance()

const show = ref(false)
const showAdd = ref(false)
const personList = ref([])
const personId = ref(null)
const hasPersonIds = ref(null)
const language = useStorage('language', 0)
const form = ref({})
const formRef = ref(null)


onMounted(() => {
  getData()
})

const getData = () => {
  getMyFriends().then((res) => {
    personList.value = res.data
  })
}

const addPeopl = () => {
  formRef.value?.resetFields()
  showAdd.value = true
}

const addPerson = () => {
  const person = _.find(personList.value, (it) => it.id == personId.value)

  checkSceneCustomer({
    customerId: person.id,
    gateType: currParams.gateType
  }).then((res) => {
    if (res.data == 201) {
      proxy.$modal.msgError(language.value == 0 ? '护照只能购买成人票' : 'Passport can only buy adult tickets')
    } else if (res.data == 202) {
      proxy.$modal.msgError(language.value == 0 ? '此身份证不能购买老人票' : 'This ID cannot buy senior tickets')
    } else if (res.data == 203) {
      proxy.$modal.msgError(language.value == 0 ? '此身份证不能购买儿童票' : 'This ID cannot buy child tickets')
    } else {
      show.value = false
      emit('addPerson', Object.assign(currParams, {
        customerId: person.id,
        name: person.name,
        idcType: person.idcType,
        idCard: person.idCard
      }))
    }
  })
}

const submit = () => {
  formRef.value.validate((valid) => {
    if (valid) {
      aadSceneCustomer(form.value).then(res => {
        if (res.data == -100) {
          proxy.$modal.msgError(language.value == 0 ? '人员信息已存在' : 'Person information already exists')
        } else if (res.data == -101) {
          proxy.$modal.msgError(language.value == 0 ? '实名认证未通过' : 'The real name authentication has not passed')
        } else {
          proxy.$modal.msgSuccess(language.value == 0 ? '添加成功' : 'successfully added')
          showAdd.value = false
          getData()
        }
      })
    } else {
      proxy.$modal.msgWarning(language.value == 0 ? '请完善信息' : 'Please complete the information')
    }
  })
}

let currParams
defineExpose({
  open: (params) => {
    currParams = params
    personId.value = params.customerId
    hasPersonIds.value = params.hasCustomerIds

    show.value = true
  }
})

</script>

<style scoped lang="scss">
.el-radio-group {
  display: block;
}

.e_item {
  margin: 20px 0 0 0;
  width: 100%;

  .el-radio {
    width: 100%;
    height: auto;
    padding: 10px;
  }

  .name {
    font-size: 16px;
  }

  .code {
    font-size: 14px;
    margin: 4px 0 0;
    color: #999;
  }
}
</style>