tom
2023-12-06 9e968679ed2e6937aeb7b50a6c450d5d19251f42
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
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
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
<!doctype html>
<html>
    <head>
        <meta charset="utf-8"><meta http-equiv="Expires" content="0"><meta http-equiv="Pragma" content="no-cache"><meta http-equiv="Cache-control" content="no-cache"><meta http-equiv="Cache" content="no-cache">
        <title>收款明细</title>
        <script src="../../../js/vue/vue.js"></script>
        <script src="../../../js/vue/element-ui/lib/index.js"></script>
        <script src="../../../js/vue/page.js?v=20220425"></script>
        <script src="../../../js/myelement.js?v=20220425"></script>
        <!-- <script src="../../../data/data.js?v=20220425"></script> -->
        <script src="../setting.js"></script>
        
        
        <link href="../../../js/vue/element-ui/lib/theme-chalk/index.css" rel="stylesheet">
        <link href="../../../css/myelement.css?v=20220425" rel="stylesheet">
        <link href="../../../css/iconfont.css" rel="stylesheet">
        <link href="../../../css/page.css?v=20220425" rel="stylesheet">
        <link href="//at.alicdn.com/t/font_2374495_m41u3ygyb2q.css" rel="stylesheet">
    </head>
    
    <body>
        <div id="vbody">
            <div id="page_root">
                <div class="topbar">
                    <span>{{title}}</span>
                
                    <div style="float: right; margin-right: 24px;">
                        <el-button-group style="margin-left: 3px;">
                            <el-button icon="el-icon-refresh" @click="onRefresh">刷新</el-button>
                        </el-button-group>
                    </div>
                </div>
                <div class="topbar-line">
                    <div class="query-icon">
                        <i class="iconfont icon-query"></i>
                    </div>
                    <div class="query-bar" style="width: 95%;" >
                        <el-form label-position='right' :inline="true" :model="formInline" class="demo-form-inline">
                            <el-row>
                                <el-col :span="5">
                                    <el-form-item label="客户名称:" label-width="80px" style="line-height: 40px;">
                                        <el-input size="mini" v-model="formInline.field4" style="width: 140px;"></el-input>
                                        <el-button  style="padding: 5px;" @click="popupCustomerList">*</el-button><!-- icon="el-icon-share" -->
                                    </el-form-item>
                                </el-col>
                        
                                <el-col :span="5">
                                    <el-form-item label="年份:" label-width="80px" style="line-height: 40px;">
                                        <el-select v-model="formInline.field1" placeholder="请选择" style="width: 140px;">
                                            <el-option
                                              v-for="item in year"
                                              :key="item.value"
                                              :label="item.label"
                                              :value="item.value">
                                            </el-option>
                                        </el-select>
                                    </el-form-item>
                                </el-col>
                                <el-col :span="5">
                                    <el-form-item label="月份:" label-width="80px" style="line-height: 40px;">
                                        <el-select v-model="formInline.field12" placeholder="请选择" style="width: 140px;">
                                            <el-option
                                              v-for="item in month"
                                              :key="item.value"
                                              :label="item.label"
                                              :value="item.value">
                                            </el-option>
                                        </el-select>
                                    </el-form-item>
                                </el-col>
                                <el-col :span="5">
                                    <el-form-item label="省份:" label-width="80px"  style="line-height: 40px;">
                                        <el-select v-model="formInline.field10" placeholder="请选择" style="width: 140px;">
                                            <el-option
                                              v-for="item in provinces"
                                              :key="item.value"
                                              :label="item.label"
                                              :value="item.value">
                                            </el-option>
                                          </el-select>
                                    </el-form-item>
                                </el-col>
                                <el-col :span="4">
                                    <el-form-item>
                                        <el-button @click="onQuery">查 询</el-button>
                                        <el-button @click="onInitQuery">重 置</el-button>
                                    </el-form-item>
                                </el-col>
                            </el-row>
                        </el-form>
                    </div>
                </div>
            
                <div class="versionNo">
                    <h-table
                        v-if="isRefresh"
                        ref="table1"
                        :table-fields="tableFields" 
                        :table-data="tableData" 
                        :is-edit-table-data="isEditTableData"
                        :pagesize="pagesize_top"
                        :pagenum="pagenum"
                        :total="total"
                        :table-height="tableHeight3"
                        :is-highlight-row="false"
                        :is-pagination = "false"
                    
                        v-on:row-click="rowClick"
                        v-on:cell-click="cellClick"
                    >
                    </h-table>
                </div>
            
                <div >
                    <div class="versionNo" style="width: 47%; display: inline-block;  border: 1px solid #ccc">
                        <div style="height: 30px;line-height: 30px;padding: 0 20px;" align="center">
                            <div style="float:left">开票明细&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</div>
                            <div align="center">
                                <i class="iconfont icon-upward"  style="font-size: 16px;color: #10AE99;"></i>
                            </div>
                        </div>
                        <h-table
                            v-if="isRefresh"
                            ref="table2"
                            :table-fields="tableFieldsLeftone" 
                            :table-data="tableDataleftone_new" 
                            :is-edit-table-data="isEditTableData"
                            :pagesize="pagesize"
                            :pagenum="pagenum"
                            :is-pagination = "false"
                            :total="total"
                            :table-height="tableHeight2"
                            :is-highlight-row="false"
                            v-on:get-data="getData"
                        
                            v-on:row-click="rowClick"
                            v-on:cell-click="cellClickLeftone"
                        >
                        </h-table>
                        <div style="height: 30px;line-height: 30px;padding: 0 20px;" align="center">
                            <div style="float:left">单个发票明细</div>
                            <div align="center">
                                <i class="iconfont icon-upward"  style="font-size: 16px;color: #10AE99;"></i>
                            </div>
                        </div>
                        <h-table
                            v-if="isRefresh"
                            ref="table2"
                            :table-fields="tableFieldsLefttwo" 
                            :table-data="tableDatalefttwo_new" 
                            :is-edit-table-data="isEditTableData"
                            :pagesize="pagesize"
                            :pagenum="pagenum"
                            :is-pagination = "false"
                            :total="total"
                            :table-height="tableHeight2"
                            :is-highlight-row="false"
                            
                            v-on:row-click="rowClick"
                            v-on:cell-click="cellClicklefttwo"
                        >
                        </h-table>
                    </div>
                    
                    <div class="versionNo" style="width: 47%; display: inline-block; border: 1px solid #ccc">
                        <div style="height: 30px;line-height: 30px;padding: 0 20px;" align="center">
                            <div style="float:left">收款明细&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;</div>
                            <div align="center">
                                <i class="iconfont icon-upward"  style="font-size: 16px;color: #75ae0a;"></i>
                            </div>
                        </div>
                        <h-table
                            v-if="isRefresh"
                            ref="table2"
                            :table-fields="tableFieldsRightone" 
                            :table-data="tableDatarightone_new" 
                            :is-edit-table-data="isEditTableData"
                            :pagesize="pagesize"
                            :pagenum="pagenum"
                            :is-pagination = "false"
                            :total="total"
                            :table-height="tableHeight2"
                            :is-highlight-row="false"
                            v-on:get-data="getData"
                        
                            v-on:row-click="rowClick"
                            v-on:cell-click="cellClickrightone"
                        >
                        </h-table>
                        <div style="height: 30px;line-height: 30px;padding: 0 20px;" >
                            <div style="float:left">单个收款明细</div>
                            <div align="center">
                                <i class="iconfont icon-upward"  style="font-size: 16px;color: #75ae0a;"></i>
                            </div>
                        </div>
                        <h-table
                            v-if="isRefresh"
                            ref="table2"
                            :table-fields="tableFieldsRighttwo" 
                            :table-data="tableDatarighttwo_new" 
                            :is-edit-table-data="isEditTableData"
                            :pagesize="pagesize"
                            :pagenum="pagenum"
                            :is-pagination = "false"
                            :total="total"
                            :table-height="tableHeight2"
                            :is-highlight-row="false"
                            v-on:get-data="getData"
                        
                            v-on:row-click="rowClick"
                            v-on:cell-click="cellClickrighttwo"
                        >
                        </h-table>
                    </div>
                </div>
            </div>
            
            <div id="page_loading" style="position: absolute; top:0px; width: 100vw; height: 100vh;">
                <div class="spinner">
                  <div class="cube1"></div>
                  <div class="cube2"></div>
                </div>
            </div>
        </div>    
        
        <script type="text/javascript">
            var role = Root.role;
            var setting = getSetting("summary_book", role.code);
            new Vue({
                el: "#vbody",
                data: {
                    page: setting.page,
                    title: "收款明细",
                    year: [],
                    month: [],
                    formInline: {},
                    
                    isRefresh: true,
                    tableFields: [],
                    
                    tableFieldsLeftone: [],
                    tableFieldsLefttwo: [],
                    tableFieldsRightone: [],
                    tableFieldsRighttwo: [],
                    
                    operationtype: "",
                    tableData_old: [],
                    tableData_new: [],
                    
                    tableDataleftone_new: [],
                    tableDataleftone_old: [],
                    tableDatarightone_new: [],
                    tableDatarightone_old: [],
                    tableDatalefttwo_new: [],
                    tableDatalefttwo_old: [],
                    tableDatarighttwo_new: [],
                    tableDatarighttwo_old: [],
                    tableDataproduct_new:[],
                    tableDataproduct_old:[],
                    
                    tableData2: [],
                    tableData: [],
                    tableHeight2: 50,
                    tableHeight3: 50,
                    isEditTableData:false,
                    
                    pagesize_top:2,
                    pagesize: 3,
                    pagenum: 1,
                    total: 0,
                    selectrow: {},
                    
                    popupByFieldsDialog: false,
                    tableFields1: [
                        {field: "field1", name: "客户代码", isshow: "T", align: "center", required: true},
                        {field: "field2", name: "客户名称", isshow: "T", align: "center", required: true},
                    ],
                    pagesize_gh: 10,
                    pagenum_gh: 1,
                    total_gh: 0,
                    tableHeight_cus: 350,
                    selectcusrow: {},
                    
                    selectFormField:{},
                },
                created() {
                    this.provinces = dataRoot.database.province;
                    this.year = dataRoot.database.years;
                    this.month = dataRoot.database.months;
                    
                    this.tableFields = dataRootFields.tableFields.summaryBook_;
                    this.tableData_new = dataRoot.database.feesum_detail;
                    this.tableData_old = clone(dataRoot.database.feesum_detail);
                    this.tableData2 = this.tableData_new;
                    
                    this.tableFieldsLeftone = dataRootFields.tableFields.leftone_;
                    this.tableDataleftone_new = dataRoot.database.leftone;
                    this.tableDataleftone_old = clone(dataRoot.database.leftone);
                    
                    this.tableFieldsLefttwo = dataRootFields.tableFields.lefttwo_;
                    this.tableDatarightone_new = dataRoot.database.rightone;
                    this.tableDatarightone_old = clone(dataRoot.database.rightone);
                    
                    this.tableFieldsRightone = dataRootFields.tableFields.rightone_;
                    this.tableDatalefttwo_new = dataRoot.database.lefttwo;
                    this.tableDatalefttwo_old = clone(dataRoot.database.lefttwo);
                    
                    this.tableFieldsRighttwo = dataRootFields.tableFields.righttwo_;
                    this.tableDatarighttwo_new = dataRoot.database.righttwo;
                    this.tableDatarighttwo_old = clone(dataRoot.database.righttwo);
                    
                    this.tableDataproduct_new = dataRoot.database.product;
                    this.tableDataproduct_old = clone(dataRoot.database.product);
                },
                
                mounted() {
                    this.initTableData();
                    this.$nextTick(() => { // 以服务的方式调用的 Loading 需要异步关闭
                        document.getElementById('page_root').style.display =  "block";
                        document.getElementById('page_loading').style.display =  "none";
                    });
                },
                
                methods:{
                    //表格
                
                    initTableData() {
                        let me = this;
                        this.total = this.tableData2.length;
                        this.tableData = this.tableData2.slice((this.pagenum-1)*this.pagesize, this.pagenum * this.pagesize);
                        
                        if(this.tableData.length > 0){
                            this.$nextTick(function(){
                                this.isRefresh = true;
                                this.$nextTick(function(){
                                  let header_height = me.$refs.table1.$el.getElementsByClassName('el-table__header-wrapper')[0].offsetHeight;
                                  let row_height = me.$refs.table1.$el.getElementsByClassName('el-table__row')[0].offsetHeight || 40;
                                  let body_width = me.$refs.table1.$el.getElementsByClassName('el-table__body')[0].offsetWidth;
                                  let body_wrapper_width = me.$refs.table1.$el.getElementsByClassName('el-table__body-wrapper')[0].offsetWidth;
                                  this.tableHeight2 = header_height + (row_height * this.pagesize) + this.pagesize/4.5;
                                  this.tableHeight3 = header_height + (row_height * this.pagesize_top) + this.pagesize_top/4.5;
                                  this.tableHeight2 += 20
                                  
                                })
                            })
                        }
                    },
                    
                    getData(page) {
                        this.pagesize = page.pagesize;
                        this.pagenum = page.pagenum;
                        this.doQuery();
                    },
                    
                    cellClick(obj) {
                        if(obj.column.property == "field1") {
                            this.selectrow = obj.row;
                            this.openMsg4("disabled", obj.row);
                        }
                    },
                    cellClickLeftone(obj) {
                        if(obj.column.property == "field3") {
                            this.selectrow = obj.row;
                            this.openMsg5("disabled", obj.row);
                        }
                    },
                    
                    cellClickrightone(obj) {
                        if(obj.column.property == "field3") {
                            this.selectrow = obj.row;
                            this.openMsg2("disabled", obj.row);
                        }
                    },
                    cellClicklefttwo(obj) {
                        if(obj.column.property == "field2") {
                            this.selectrow = obj.row;
                            this.openMsg1("disabled", obj.row);
                        }
                        if(obj.column.property == "field6") {
                            this.selectrow = obj.row;
                            this.openMsg3("disabled", obj.row);
                        }
                    },
                    cellClickrighttwo(obj) {
                        if(obj.column.property == "field2") {
                            this.selectrow = obj.row;
                            this.openMsg1("disabled", obj.row);
                        }
                        if(obj.column.property == "field6") {
                            this.selectrow = obj.row;
                            this.openMsg3("disabled", obj.row);
                        }
                    },
                    rowClick(obj) {
                        this.selectrow = obj.row;
                    },
                    //查询条件中客户弹窗
                    popupCustomerList(event) {
                        let me = this;
                        Root.showPopup({
                             
                            url: "../md/customer/popup/customer_list.html",
                            width: 800,
                            height: 550,
                            callback: function(obj, callback) {
                                let formInline_ = clone(me.formInline);
                                formInline_.field4 = obj.row.field2;
                                me.formInline = formInline_;
                                if (callback) {
                                    callback();
                                }
                            }
                        });
                    },
                    //表单
                    showPopup(obj) {
                        this.selectFormField = obj.obj;
                        this.popupByFieldsDialog = true;
                    },
                    
                    onDownload() {
                        Root.message('这是一条消息提示');
                    },
                    onUpload() {
                        
                    },
                    onQuery() {
                        this.pagenum = 1;
                        this.doQuery();
                    },
                    doQuery() {
                            let result = this.tableData_new.filter(item => {
                                let bo = true;
                                for(var k in this.formInline) {
                                    let k_val = this.formInline[k];
                                    if (k == "field11" && k_val != {}) {
                                        let bo_ = true;
                                        let itemTime = new Date(item[k]);
                                        if (k_val.begtime) {
                                            let begTime_val = new Date(k_val.begtime);
                                            bo_ = itemTime >= begTime_val;
                                        }
                                        if (bo_ && k_val.endtime) {
                                            let endTime_val = new Date(k_val.endtime);
                                            bo_ = itemTime <= endTime_val;
                                        }
                                        
                                        if (!bo_) {
                                            return false;
                                        }
                                    }
                                    else if (k != "field11") {
                                        let bo_ = item[k].toLowerCase().indexOf(k_val.toLowerCase()) > -1;
                                        if (!bo_) {
                                            return false;
                                        }
                                    }
                                }
                                return bo;
                            });
                            this.tableData2 = result;
                            this.initTableData();
                    },
                    
                    onInitQuery() {
                        this.formInline = {field11: {}};
                        this.tableData2 = this.tableData_new;
                        this.initTableData();
                    },
                    onRefresh() {
                        this.formInline = {field11: {}};
                        this.tableData_new = this.tableData_old;
                        this.tableData2 = this.tableData_new;
                        this.initTableData();
                    },
                    openMsg1(code, row) {
                        let me = this;
                        Root.popupParames = {
                            width: "1080px",
                            //height: "580px",
                            url: "../md/product/product/product_edit.html",
                            callback: function(obj, callback) {
                                me.saveRowTable_popup(obj);
                                if (callback) {
                                    callback();
                                }
                            }
                        };
                        if (code == "disabled") {
                            Root.popupParames.data = row;
                            Root.popupParames.disabled = true;
                        }
                        Root.showPopup(Root.popupParames);
                    },
                    openMsg2(code, row) {
                        let me = this;
                        Root.popupParames = {
                            width: "900px",
                            //height: "580px",
                            url: "../finance/receipt/receipt_edit.html",
                            callback: function(obj, callback) {
                                me.saveRowTable_popup(obj);
                                if (callback) {
                                    callback();
                                }
                            }
                        };
                         if (code == "disabled") {
                            Root.popupParames.data = row;
                            Root.popupParames.disabled = true;
                        }
                        
                        Root.popupParames.tableFields = this.tableFields1;
                        Root.showPopup(Root.popupParames);
                    },
                    
                    openMsg3(code, row) {
                        let me = this;
                        Root.popupParames = {
                            width: "900px",
                            //height: "580px",
                            url: "../agreement/apply/apply_edit.html",
                            callback: function(obj, callback) {
                                me.saveRowTable_popup(obj);
                                if (callback) {
                                    callback();
                                }
                            }
                        };
                        if (code == "disabled") {
                            Root.popupParames.data = row;
                            Root.popupParames.disabled = true;
                        }
                        
                        Root.showPopup(Root.popupParames);
                    },
                    openMsg4(code, row) {
                        let me = this;
                        Root.popupParames = {
                            width: "900px",
                            //height: "580px",
                            url: "../order/sorder/sorder_edit.html",
                            callback: function(obj, callback) {
                                me.saveRowTable_popup(obj);
                                if (callback) {
                                    callback();
                                }
                            }
                        };
                        if (code == "disabled") {
                            Root.popupParames.data = row;
                            Root.popupParames.disabled = true;
                        }
                        Root.popupParames.tableFields = this.tableFields1;
                        Root.showPopup(Root.popupParames);
                    },
                    openMsg5(code, row) {
                        let me = this;
                        Root.popupParames = {
                            width: "1080px",
                            //height: "580px",
                            url: "../tool/popup_invoice.html",
                            callback: function(obj, callback) {
                                me.saveRowTable_popup(obj);
                                if (callback) {
                                    callback();
                                }
                            }
                        };
                         if (code == "disabled") {
                            Root.popupParames.data = row;
                            Root.popupParames.disabled = true;
                        }
                        Root.popupParames.tableFields = this.tableFields1;
                        Root.showPopup(Root.popupParames);
                    },
                    saveRowTable_popup(obj) {
                        
                    },
                }
            });
        </script>
        <style>
            
        </style>
    </body>
</html>