|
@@ -0,0 +1,241 @@
|
|
|
+<template>
|
|
|
+ <div>
|
|
|
+ <el-form ref="form" v-loading="addLoading" :model="form" style="width: 100%;padding: 5px" :rules="rules">
|
|
|
+ <el-row>
|
|
|
+ <el-col style="padding-bottom: 10px">
|
|
|
+ <span class="card_title">意向金登记</span>
|
|
|
+ <el-card shadow="always" style="padding: 15px 5px 5px 15px">
|
|
|
+ <el-row>
|
|
|
+ <el-col :span="3" class="col-txt"><span>意向金编号:</span></el-col>
|
|
|
+ <el-col :span="3" class="col-txt"><span>{{ serialNumber }}</span></el-col>
|
|
|
+ </el-row>
|
|
|
+ <el-row>
|
|
|
+ <el-col :span="3" class="col-txt"><span>*应收定金(元)</span></el-col>
|
|
|
+ <el-col :span="9" class="col-input">
|
|
|
+ <el-form-item>
|
|
|
+ <el-input v-model="form.receivableMoney" />
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :span="3" class="col-txt"><span>*实收金额(元)</span></el-col>
|
|
|
+ <el-col :span="9" class="col-input">
|
|
|
+ <el-form-item>
|
|
|
+ <el-input v-model="form.receivedAmount" />
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ </el-row>
|
|
|
+ <el-row>
|
|
|
+ <el-col :span="3" class="col-txt"><span>*收款方式</span></el-col>
|
|
|
+ <el-col :span="9" class="col-input">
|
|
|
+ <el-form-item>
|
|
|
+ <el-select
|
|
|
+ v-model="form.paymentMethod"
|
|
|
+ :popper-append-to-body="false"
|
|
|
+ popper-class="statistic_base"
|
|
|
+ placeholder=""
|
|
|
+ filterable
|
|
|
+ >
|
|
|
+ <el-option
|
|
|
+ v-for="item in dc_data.PAYMENT_METHODS"
|
|
|
+ :key="item.value"
|
|
|
+ popper-class="statistic_base"
|
|
|
+ :popper-append-to-body="false"
|
|
|
+ :label="item.label"
|
|
|
+ :value="item.value"
|
|
|
+ />
|
|
|
+ </el-select>
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ <el-col :span="3" class="col-txt"><span>收款时间</span></el-col>
|
|
|
+ <el-col :span="9" class="col-input">
|
|
|
+ <el-form-item>
|
|
|
+ <el-date-picker
|
|
|
+ v-model="form.collectionTime"
|
|
|
+ type="date"
|
|
|
+ placeholder="年月日"
|
|
|
+ value-format="yyyy-MM-dd"
|
|
|
+ />
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ </el-row>
|
|
|
+ <el-row>
|
|
|
+ <el-col :span="3" class="col-txt"><span>备注</span></el-col>
|
|
|
+ <el-col :span="21" class="col-input">
|
|
|
+ <el-form-item>
|
|
|
+ <el-input v-model="form.remark" type="textarea" :autosize="{ minRows: 2, maxRows: 100}" placeholder="请输入内容" />
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ </el-row>
|
|
|
+ <el-row>
|
|
|
+ <el-col :span="3" class="col-txt"><span>附件</span></el-col>
|
|
|
+ <el-col :span="21" class="col-input">
|
|
|
+ <el-form-item>
|
|
|
+ <el-upload
|
|
|
+ class="upload-demo"
|
|
|
+ action="/server/wx/fileController/uploadImage"
|
|
|
+ :http-request="uploadPhoto"
|
|
|
+ :before-remove="beforeRemove"
|
|
|
+ multiple
|
|
|
+ :file-list="fileList"
|
|
|
+ >
|
|
|
+ <el-button size="small" type="primary">点击上传</el-button>
|
|
|
+ <div slot="file" slot-scope="{file}" style="overflow:hidden;white-space: nowrap;text-overflow:ellipsis">
|
|
|
+ <el-tooltip class="item" effect="dark" :content="file.name" placement="top-start">
|
|
|
+ <a :href="file.url">{{ file.name }}</a>
|
|
|
+ </el-tooltip>
|
|
|
+ <span class="el-upload-list__item-actions">
|
|
|
+ <i class="el-icon-delete" @click="handlePictureRemove(file,fileList)" />
|
|
|
+ </span>
|
|
|
+ </div>
|
|
|
+ </el-upload>
|
|
|
+ </el-form-item>
|
|
|
+ </el-col>
|
|
|
+ </el-row>
|
|
|
+ </el-card>
|
|
|
+ </el-col>
|
|
|
+ </el-row>
|
|
|
+ </el-form>
|
|
|
+ <div style="text-align: right">
|
|
|
+ <el-button @click="cancel">取 消</el-button>
|
|
|
+ <el-button type="primary" @click="confirmSubmit()">提 交</el-button>
|
|
|
+ </div>
|
|
|
+
|
|
|
+ </div>
|
|
|
+</template>
|
|
|
+
|
|
|
+<script>
|
|
|
+import Base from '@/views/base/base'
|
|
|
+import BaseData from '@/views/base/baseData'
|
|
|
+import { upload } from '@/static/utils/channel'
|
|
|
+
|
|
|
+export default {
|
|
|
+ name: 'AddIntentionalDepositVue',
|
|
|
+ components: { },
|
|
|
+ mixins: [Base, BaseData],
|
|
|
+ data() {
|
|
|
+ return {
|
|
|
+ dc_key: ['PAYMENT_METHODS'],
|
|
|
+ form: {
|
|
|
+
|
|
|
+ },
|
|
|
+ rules: {
|
|
|
+ receivableMoney: [{ required: true, trigger: 'blur', message: '请输入应收定金' }],
|
|
|
+ receivedAmount: [{ required: true, trigger: 'blur', message: '请输入实收金额' }],
|
|
|
+ paymentMethod: [{ required: true, trigger: 'change', message: '请输入实收金额' }],
|
|
|
+ collectionTime: [{ required: true, trigger: 'blur', message: '请选择收款时间' }]
|
|
|
+ },
|
|
|
+ addLoading: false,
|
|
|
+ serialNumber: '',
|
|
|
+ fileList: [],
|
|
|
+ customerManagementId: ''
|
|
|
+ }
|
|
|
+ },
|
|
|
+ mounted() {
|
|
|
+
|
|
|
+ },
|
|
|
+ methods: {
|
|
|
+ initData(data) {
|
|
|
+ this.customerManagementId = data.id
|
|
|
+ this.initDict(this.dc_key).then(res => {
|
|
|
+ this.getByCustomerManagementId(data)
|
|
|
+ })
|
|
|
+ },
|
|
|
+ handleChange(value) {
|
|
|
+
|
|
|
+ },
|
|
|
+ getByCustomerManagementId(val) {
|
|
|
+ const data = {
|
|
|
+ customerManagementId: val.id
|
|
|
+ }
|
|
|
+ this.baseRequest('getByCustomerManagementId', data).then(res => {
|
|
|
+ if (res.data) {
|
|
|
+ this.form = res.data
|
|
|
+ this.serialNumber = this.form.serialNumber
|
|
|
+ this.form.paymentMethod = this.form.paymentMethod + ''
|
|
|
+ if (this.form.fileList) {
|
|
|
+ this.fileList = JSON.parse(this.form.fileList)
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ this.getSerialNumber(val)
|
|
|
+ this.getFQById(val)
|
|
|
+ }
|
|
|
+ })
|
|
|
+ },
|
|
|
+ getSerialNumber(val) {
|
|
|
+ const data = {
|
|
|
+ customerManagementId: val.id
|
|
|
+ }
|
|
|
+ this.baseRequest('getSerialNumber', data).then(res => {
|
|
|
+ this.serialNumber = res.data
|
|
|
+ })
|
|
|
+ },
|
|
|
+ getFQById(val) {
|
|
|
+ const data = {
|
|
|
+ id: val.discId
|
|
|
+ }
|
|
|
+ this.baseFQRequest('getById', data).then(res => {
|
|
|
+ this.$set(this.form, 'receivableMoney', res.data.subscriptionFunds)
|
|
|
+ })
|
|
|
+ },
|
|
|
+ confirmSubmit: function() {
|
|
|
+ const _this = this
|
|
|
+ this.$refs.form.validate(valid => {
|
|
|
+ if (valid) {
|
|
|
+ let soaUrl = 'add'
|
|
|
+ // 已收取状态
|
|
|
+ if (_this.form.id) {
|
|
|
+ soaUrl = 'edit'
|
|
|
+ }
|
|
|
+ const extraData = {
|
|
|
+ customerManagementId: this.customerManagementId,
|
|
|
+ serialNumber: _this.serialNumber,
|
|
|
+ fileList: JSON.stringify(_this.fileList)
|
|
|
+ }
|
|
|
+ const postData = Object.assign({}, _this.form, extraData)
|
|
|
+ this.baseRequest(soaUrl, postData).then(res => {
|
|
|
+ if (res.data.code === 200) {
|
|
|
+ _this.$message({
|
|
|
+ message: '新增成功',
|
|
|
+ type: 'success'
|
|
|
+ })
|
|
|
+ _this.cancel()
|
|
|
+ } else {
|
|
|
+ _this.$message({
|
|
|
+ message: res.msg,
|
|
|
+ type: 'warning'
|
|
|
+ })
|
|
|
+ }
|
|
|
+ }).catch(err => {
|
|
|
+ _this.$message({
|
|
|
+ message: err,
|
|
|
+ type: 'warning'
|
|
|
+ })
|
|
|
+ })
|
|
|
+ } else {
|
|
|
+ console.log('error submit!!')
|
|
|
+ return false
|
|
|
+ }
|
|
|
+ })
|
|
|
+ },
|
|
|
+ cancel() {
|
|
|
+ this.$emit('cancel')
|
|
|
+ },
|
|
|
+
|
|
|
+ uploadPhoto: function(param) {
|
|
|
+ upload(param, true).then((res) => {
|
|
|
+ this.fileList.push(res)
|
|
|
+ })
|
|
|
+ },
|
|
|
+ baseRequest(opUrl, postData) {
|
|
|
+ return this.$channel.globeRequest('IntentionalDepositController', opUrl, postData, 'project')
|
|
|
+ },
|
|
|
+ baseFQRequest: function(opUrl, postData) {
|
|
|
+ return this.$channel.baseRequest('ParkFloorDiscController', opUrl, postData, 'User')
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+}
|
|
|
+</script>
|
|
|
+
|
|
|
+<style scoped>
|
|
|
+
|
|
|
+</style>
|