审查视图

src/views/airtransport/confirmatory.vue 12.2 KB
小范 authored
1 2 3 4 5 6 7 8 9 10
<template>
    <el-container>
        <el-main>
            <el-row class="row-bg">
                <el-col :span="24">
                    <div class="grid-content content">进港确报申报</div>
                </el-col>
            </el-row>
            <el-row>
                <el-form :model="confirmatory" :rules="rules" ref="confirmatory" label-width="100%" class="demo-ruleForm">
11 12
                    <el-col :span="24">
                        <div class="grid-content content">航空器信息</div>
小范 authored
13
                    </el-col>
14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
                    <el-row>
                        <el-col :span="6">
                            <el-form-item label="航空器注册编号" prop="aircraftNo" label-width="130px">
                                <el-input v-model.trim="confirmatory.aircraftNo"  @input="e => confirmatory.aircraftNo=inputMe(e)"></el-input>
                            </el-form-item>
                        </el-col>
                        <el-col :span="6">
                            <el-form-item label="关区代码" prop="customDistrictNo" label-width="120px">
                                <el-input v-model="confirmatory.customDistrictNo" oninput="value=value.replace(/[^\d]/g,'')"
                                          maxLength='4'></el-input>
                            </el-form-item>
                        </el-col>
                    </el-row>
                    <el-col :span="24">
                        <div class="grid-content content">航空器动态信息</div>
                    </el-col>
                    <el-col :span="6">
                        <el-form-item label="进港航班号" prop="flightNo" label-width="130px">
小范 authored
32
                            <el-input v-model="confirmatory.flightNo"   @input="e => confirmatory.flightNo=inputMe(e)"></el-input>
小范 authored
33 34
                        </el-form-item>
                    </el-col>
35
                    <el-col :span="6">
小范 authored
36 37 38 39
                        <el-form-item label="航班日期" prop="flightDate" label-width="120px">
                            <el-date-picker
                                    v-model="confirmatory.flightDate"
                                    type="date"
小范 authored
40 41
                                    value-format="yyyyMMdd"
                                    format="yyyyMMdd"
42
                                    style="width:100%"
43 44
                                    placeholder="选择日期"
                                    :picker-options="pickerOptions">
小范 authored
45 46 47
                            </el-date-picker>
                        </el-form-item>
                    </el-col>
48 49 50 51
                    <el-col :span="6">
                        <el-form-item label="停机位" prop="stayid" label-width="120px">
                            <el-input v-model="confirmatory.stayid" oninput="value=value.replace(/[^\d]/g,'')"
                            ></el-input>
小范 authored
52 53
                        </el-form-item>
                    </el-col>
54
                    <el-col :span="6">
小范 authored
55
                        <el-form-item label="目的港" prop="arrivalPort" label-width="120px">
小范 authored
56 57
                            <el-input v-model="confirmatory.arrivalPort" @input="e => confirmatory.arrivalPort=inputMe(e)"
                                      maxLength='3'></el-input>
小范 authored
58 59
                        </el-form-item>
                    </el-col>
60
                    <el-col :span="6">
61
                        <el-form-item label="离港时间" prop="departuredatetime" label-width="130px">
62 63 64 65 66 67 68 69 70 71
                            <el-date-picker
                                    v-model="confirmatory.departuredatetime"
                                    type="datetime"
                                    placeholder="选择日期时间"
                                    value-format="yyyyMMddHHmmss"
                                    format="yyyyMMddHHmmss"
                                    style="width:100%">
                            </el-date-picker>
                        </el-form-item>
                    </el-col>
72
                    <el-col :span="6">
73
                        <el-form-item label="抵港时间" prop="arrivaldatetime" label-width="120px">
小范 authored
74 75
                            <el-date-picker
                                    v-model="confirmatory.arrivaldatetime"
76 77 78 79 80
                                    type="datetime"
                                    placeholder="选择日期时间"
                                    value-format="yyyyMMddHHmmss"
                                    format="yyyyMMddHHmmss"
                                    style="width:100%">
小范 authored
81
                            </el-date-picker>
小范 authored
82 83
                        </el-form-item>
                    </el-col>
84 85
                    <el-col :span="24">
                        <div class="grid-content content">备注信息</div>
小范 authored
86 87
                    </el-col>
                    <el-col :span="24">
88
                        <el-form-item label="备注" prop="meno" label-width="130px">
小范 authored
89 90 91 92 93 94 95
                            <el-input v-model="confirmatory.meno"></el-input>
                        </el-form-item>
                    </el-col>
                </el-form>
            </el-row>
            <el-row style="margin-left: 120px">
                <el-col :span="24">   <el-button type="primary" @click="submitForm('confirmatory')">保 存</el-button>
小范 authored
96
                    <el-button type="success" @click="sendForm('confirmatory')">保存并发送</el-button></el-col>
小范 authored
97
            </el-row>
小范 authored
98 99 100 101 102 103 104 105 106 107 108 109 110 111
            <!--对话提示框-->
            <el-row>
                <el-dialog
                        title="系统提示"
                        :visible.sync="centerDialogVisible"
                        width="30%"
                        center>
                    <span>{{msg}}</span>
                    <span slot="footer" class="dialog-footer">
                          <el-button @click="centerDialogVisible = false">取 消</el-button>
                        <el-button type="primary" @click="centerDialogVisible = false">确 定</el-button>
                      </span>
                </el-dialog>
            </el-row>
小范 authored
112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133
        </el-main>
    </el-container>
</template>
<style scoped>
    .grid-content {
        height: 36px;
        line-height: 36px;
    }
    .el-dialog__body{text-align: center}
    .content {
        border-left: 4px #409EFF solid;
        padding-left: 10px;
        background-color: #f9fafc;
        margin-bottom: 2px
    }

    .row-bg{
        background-color: white;
    }
    .el-col{margin-right: 0px;}
</style>
<script>
小范 authored
134
    import {addConfirm, sendConfirmIn} from "../../api/transport";
135
    import loginUserInfo from '../../api/base'
小范 authored
136
小范 authored
137 138 139
    export default {
        data(){
            return{
140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164
                pickerOptions: {
                    disabledDate(time) {
                        return time.getTime() > Date.now();
                    },
                    shortcuts: [{
                        text: '今天',
                        onClick(picker) {
                            picker.$emit('pick', new Date());
                        }
                    }, {
                        text: '昨天',
                        onClick(picker) {
                            const date = new Date();
                            date.setTime(date.getTime() - 3600 * 1000 * 24);
                            picker.$emit('pick', date);
                        }
                    }, {
                        text: '明天',
                        onClick(picker) {
                            const date = new Date();
                            date.setTime(date.getTime() + 3600 * 1000 * 24);
                            picker.$emit('pick', date);
                        }
                    }]
                },
小范 authored
165 166 167 168 169 170 171 172 173 174
                confirmatory:{
                    aircraftNo:undefined,
                    flightNo:undefined,
                    flightDate:undefined,
                    departuredatetime:undefined,
                    arrivalPort:undefined,
                    customDistrictNo:undefined,
                    arrivaldatetime:undefined,
                    stayid:undefined,
                    meno:undefined,
175
                    accessFlag: '0',
176 177
                    createBy:loginUserInfo.username,
                    updateBy:loginUserInfo.username,
小范 authored
178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193
                },
                rules: {
                    aircraftNo: [
                        {required: true, message: '请输入', trigger: 'blur'}
                    ],
                    flightNo: [
                        {required: true, message: '请输入', trigger: 'blur'}
                    ],
                    flightDate: [
                        {required: true, message: '请选择', trigger: 'change'}
                    ],
                    departuredatetime: [
                        {required: true, message: '请输入', trigger: 'blur'}
                    ],
                    arrivalPort: [
                        {required: true, message: '请输入(三字码)', trigger: 'blur'},
小范 authored
194
                        { pattern: /^[A-Z]{3}$/, message: '请输入(三字码)', trigger: 'blur' }
小范 authored
195 196
                    ],
                    customDistrictNo: [
小范 authored
197 198
                        {required: true, message: '请输入', trigger: 'blur'},
                        { pattern: /^[0-9]{4}$/, message: '请输入正确关区', trigger: 'blur' }
小范 authored
199 200 201 202 203
                    ],
                    arrivaldatetime: [
                        {required: true, message: '请选择', trigger: 'blur'}
                    ],
                    stayid: [
小范 authored
204
                        {required: true, message: '请选择', trigger: 'blur'},
205
                        // { pattern: /^[0-9]{6}$/, message: '请输入正确机坪号码', trigger: 'blur' }
小范 authored
206 207
                    ],
                },
小范 authored
208 209 210
                tableData:[],
                msg:undefined,
                centerDialogVisible:false,
小范 authored
211 212 213
            }
        },
        methods:{
小范 authored
214
            //新增进港确报申报(保存按钮)
小范 authored
215 216 217
            submitForm(formName) {
                this.$refs[formName].validate((valid) => {
                    if (valid) {
小范 authored
218 219 220 221 222
                        addConfirm(this.confirmatory).then(res=>{
                            let response=res.data;
                            if(response.code=='200'){
                                this.centerDialogVisible=true;
                                this.msg=response.msg;
小范 authored
223
                                this.$router.push({path:'/queryConfirmatory',query:{flightNo:this.confirmatory.flightNo,flightDate:this.confirmatory.flightDate}});
小范 authored
224 225 226 227
                            }else{
                                this.msg=response.msg;
                            }
                        });
小范 authored
228 229 230 231 232 233
                    } else {
                        console.log('error submit!!');
                        return false;
                    }
                });
            },
小范 authored
234 235 236 237
            //新增进港确报申报(保存并发送按钮)
            sendForm(formName) {
                this.$refs[formName].validate((valid) => {
                    if (valid) {
238 239 240
                        console.log(this.confirmatory)
                        this.confirmatory.createBy=loginUserInfo.username
小范 authored
241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256
                        sendConfirmIn(this.confirmatory).then(res=>{
                            let response=res.data;
                            if(response.code=='200'){
                                this.centerDialogVisible=true;
                                this.msg=response.msg;
                                this.$router.push({path:'/queryConfirmatory',query:{flightNo:this.confirmatory.flightNo,flightDate:this.confirmatory.flightDate}});
                            }else{
                                this.msg=response.msg;
                            }
                        });
                    } else {
                        console.log('error submit!!');
                        return false;
                    }
                });
            },
小范 authored
257 258 259
            //加载默认值
            defaultData(){
                if(this.$route.query!=null){
小范 authored
260
                    Object.assign(this.confirmatory, this.$route.query);
小范 authored
261
                }
小范 authored
262
            },
小范 authored
263 264
            // 过滤中英文
            inputMe(e){
小范 authored
265
                return e.replace(/[^a-zA-Z0-9.-]/g,'').toUpperCase();
小范 authored
266 267 268 269
            }
        },
        mounted(){
            this.defaultData();
小范 authored
270 271
        }
    }
小范 authored
272
</script>