choosePerson.vue 4.92 KB
<template>
  <el-dialog v-model="show" title="出行人信息" center append-to-body>
    <el-button type="primary" plain @click="addPeopl">{{ languageFormat(language, "新增", "Add") }}</el-button>

    <el-form>
      <el-form-item prop="message">
        <div class="p_box">
          <div class="people">
            <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>
                    {{ it.name }}  {{ it.idCard }}
                  </div>
                </el-radio>
              </div>
            </el-radio-group>
          </div>
        </div>
      </el-form-item>
    </el-form>
    <template #footer>
      <div class="dialog-footer">
        <el-button @click="show = false">取 消</el-button>
        <el-button type="primary" @click="addPerson">完成</el-button>
      </div>
    </template>
  </el-dialog>


  <el-dialog v-model="showAdd" title="新增出行人" 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('护照只能购买成人票')
    } else if (res.data == 202) {
      proxy.$modal.msgError('此身份证不能购买老人票')
    } else if (res.data == 203) {
      proxy.$modal.msgError('此身份证不能购买儿童票')
    } 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('人员信息已存在')
        } else if (res.data == -101) {
          proxy.$modal.msgError('实名认证未通过')
        } 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">
.e_item{margin: 20px 20px 0 0;}
</style>