| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466 | <template>    <div class="content main">        <organ-tree @organId="currentOrganId"></organ-tree>        <div class="content-right">            <div class="search">                <el-radio-group v-model="chargeStatus" @change="changeRadio" class="zz-tab-button">                    <el-radio-button label="1">未交账单</el-radio-button>                    <el-radio-button label="2">已交账单</el-radio-button>                </el-radio-group>                <el-input                    clearable                    placeholder="输入费用名称"                    class="search-input"                    v-trim                    v-model.trim="mixins_query.chargeName"                ></el-input>                <el-select v-model="mixins_querys.chargeType" placeholder="费用类型" clearable class="width120">                    <el-option label="物业费" :value="1"></el-option>                    <el-option label="水费" :value="2"></el-option>                    <el-option label="电费" :value="3"></el-option>                    <el-option label="卫生费" :value="6"></el-option>                    <el-option label="车位管理费" :value="4"></el-option>                    <el-option label="其他费用" :value="7"></el-option>                </el-select>                <!-- 已交 -->                <template v-if="chargeStatus == 2">                    <el-select v-model="mixins_query.payType" class="width120" placeholder="缴费方式" clearable>                        <el-option label="微信" :value="1"></el-option>                        <el-option label="支付宝" :value="2"></el-option>                        <el-option label="现金" :value="3"></el-option>                        <el-option label="刷卡" :value="6"></el-option>                        <el-option label="其他" :value="5"></el-option>                    </el-select>                    <el-date-picker                        v-model="times"                        value-format="yyyy-MM-dd"                        type="daterange"                        range-separator="至"                        start-placeholder="选择开始日期"                        end-placeholder="选择结束日期"                        @change="effectiveDateToggle"                    ></el-date-picker>                </template>                <el-date-picker                    v-else                    v-model="times"                    value-format="yyyy-MM"                    type="monthrange"                    range-separator="至"                    start-placeholder="选择开始月"                    end-placeholder="选择结束月"                    @change="effectiveDateToggle"                ></el-date-picker>                <el-button class="search-btn" type="primary" @click="mixins_search()" icon="el-icon-search">搜索</el-button>                <div class="search-icon">                    <el-tooltip                        v-show="chargeStatus == 1 && chiData.type === 'room'"                        class="item"                        effect="light"                        placement="bottom"                        content="临时收款"                    >                        <i class="zoniot_font zoniot-icon-linshishoukuan" @click="collections('temporary')"></i>                    </el-tooltip>                    <el-tooltip v-show="chargeStatus == 1" class="item" effect="light" placement="bottom" content="批量收款">                        <i class="zoniot_font zoniot-icon-piliangshoukuan" @click="collections('bulk')"></i>                    </el-tooltip>                    <el-tooltip class="item" effect="light" placement="bottom" content="导出">                        <i class="zoniot_font zoniot-icon-daochu2" @click="exportExcel"></i>                    </el-tooltip>                </div>            </div>            <zz-table                v-if="statusTable"                :settings="{ showCheckbox: chargeStatus == 1, showIndex: chargeStatus == 2, stripe: true }"                :cols="chargeStatus == 1 ? cols : statusCols"                :data="mixins_list"                :pageset="mixins_pageset"                @page-change="pageChange"                :selectable="selectable"                @selection-change="selectionChange"            >                <template slot-scope="scope" slot="payBeginTime">                    {{ typeTimeTransition(scope.row.payBeginTime, scope.row.payEndTime) }}                </template>                <template slot-scope="scope" slot="opt">                    <div class="opt">                        <el-tooltip v-show="chargeStatus == 1" class="item" effect="light" placement="bottom" content="收款">                            <i class="zoniot_font zoniot-icon-shoukuan" @click="collections('single', scope.row)"></i>                        </el-tooltip>                        <el-tooltip v-show="chargeStatus == 1" class="item" effect="light" placement="bottom" content="修改金额">                            <i class="zoniot_font zoniot-icon-koufeijilu" @click="editAmount(scope.row)"></i>                        </el-tooltip>                        <el-tooltip v-show="chargeStatus == 2" class="item" effect="light" placement="bottom" content="详情">                            <i class="zoniot_font zoniot-icon-xiangqing" @click="lookDetails(scope.row)"></i>                        </el-tooltip>                    </div>                </template>            </zz-table>        </div>    </div></template><script>import list from '@/utils/list.js';export default {    mixins: [list],    name: 'propertyFee',    data() {        return {            mixins_querys: {                chargeType: ''            },            currentId: '',            cols: [                {                    label: '订单号',                    prop: 'billNumber'                },                {                    label: '地址',                    prop: 'assets'                },                {                    label: '业主',                    prop: 'residentName',                    width: '100'                },                {                    label: '费用名称',                    prop: 'chargeName',                    width: '200'                },                {                    label: '计费日期',                    prop: 'payBeginTime',                    slot: 'payBeginTime',                    width: '150'                },                {                    label: '费用金额(元)',                    prop: 'amount'                },                {                    label: '滞纳金(元)',                    prop: 'lateFee'                },                {                    label: '应收金额(元)',                    prop: 'receivableAmount'                },                {                    label: '缴费状态',                    prop: 'chargeStatusDict'                },                {                    label: '操作',                    prop: 'id',                    slot: 'opt'                }            ],            statusCols: [                {                    label: '订单号',                    prop: 'billNumber'                },                {                    label: '地址',                    prop: 'assets'                },                {                    label: '住户',                    prop: 'residentName'                },                {                    label: '费用名称',                    prop: 'chargeName'                },                {                    label: '计费日期',                    prop: 'payBeginTime',                    slot: 'payBeginTime',                    width: '150'                },                {                    label: '应收金额(元)',                    prop: 'receivableAmount'                },                {                    label: '实收金额(元)',                    prop: 'receivedAmount'                },                {                    label: '付款方式',                    prop: 'payTypeDict'                },                {                    label: '缴费状态',                    prop: 'chargeStatusDict'                },                {                    label: '缴费时间',                    prop: 'chargeDate',                    width: '150'                },                {                    label: '操作',                    prop: 'id',                    slot: 'opt'                }            ],            chargeStatus: 1,            chiData: {                type: '',                value: '',                address: ''            },            mixins_post: 'post',            selectRow: [],            statusTable: true,            times: []        };    },    methods: {        mixins_search() {            this.mixins_pageset.pageNum = 1;            if (!!this.mixins_querys.chargeType) {                this.mixins_query.chargeType = this.mixins_querys.chargeType;            } else {                this.mixins_query.chargeType = '1,2,3,4,5,6,7';            }            if (this.chargeStatus == 1) {                this.mixins_query.payType = '';            }            this.getList();        },        editAmount(row) {            new Promise((resolve) => {                this.$store.dispatch('addPopup', {                    url: '/payService/propertyFee/stepPage/editAmount.vue',                    width: '550px',                    height: '180px',                    props: {                        data: row,                        callback: resolve                    },                    title: '修改应收金额'                });            }).then(() => {                this.mixins_search();            });        },        collections(todo, row) {            new Promise((resolve) => {                let title = '',                    hideStar,                    height = '230px',                    width = '900px';                if (todo == 'temporary') {                    title = '设置收费项目';                    hideStar = false;                    height = '270px';                    width = '550px';                } else if (todo == 'bulk') {                    if (!this.selectRow.length) {                        this.$message.error('您尚未选择要收款项,请选择后再操作批量');                        return;                    }                    let tag = false;                    this.selectRow.map((item) => {                        if (this.selectRow[0].houseId == item.houseId) {                            tag = true;                        } else {                            tag = false;                        }                    });                    if (!tag) {                        this.$message.error('选择同一房间后再操作批量');                        return;                    }                    title = '批量收款';                    hideStar = true;                    height = '528px';                    width = '900px';                } else if (todo == 'single') {                    title = '收款';                    hideStar = true;                    height = '614px';                    width = '614px';                }                this.$store.dispatch('addPopup', {                    url: '/payService/propertyFee/stepPage/' + todo + '.vue',                    // url: '/payService/propertyFee/stepPage/single.vue',                    width: width,                    height: height,                    props: {                        data: row,                        selectRow: this.selectRow,                        chiData: this.chiData,                        tabList: todo,                        communityId: this.mixins_query.communityId,                        callback: resolve                    },                    hideStar: hideStar,                    title: title                });            }).then(() => {                this.mixins_search();            });        },        effectiveDateToggle(va) {            let arr = va;            if (!arr) {                arr = ['', ''];            }            this.mixins_query.startTime = arr[0];            this.mixins_query.endTime = arr[1];        },        lookDetails(row) {            new Promise((resolve) => {                this.$store.dispatch('addPopup', {                    url: '/payService/propertyFee/stepPage/details.vue',                    width: '615px',                    height: '581px',                    props: {                        id: row.id,                        callback: resolve                    },                    showConfirmButton: true,                    showCancelButton: true,                    hideStar: true,                    title: '账单详情'                });            }).then(() => {                this.mixins_search();            });        },        selectionChange(val) {            this.selectRow = val;        },        currentOrganId(data) {            this.currentId = data || '';        },        changeRadio() {            this.statusTable = false;            this.$nextTick(() => {                this.statusTable = true;            });            this.times = [];            this.Object_Set(['startTime', 'endTime', 'chargeStatus'], ['', '', this.chargeStatus]);            this.mixins_search();        },        exportExcel() {            this.__exportExcel('/sc-charge/charge/bill/export/excel', this.mixins_query);        },        typeTimeTransition(start, end) {            let text = '';            if (!!end) {                let f = new Date(start).getMonth(),                    l = new Date(end).getMonth();                if (f == l) {                    text = `${this.$moment(new Date(start)).format('YYYY年M月')}`;                } else {                    text = `${this.$moment(new Date(start)).format('YYYY年M月')}-${this.$moment(new Date(end)).format('YYYY年M月')}`;                }            }            return text;        },        selectable(row, index) {            return true;        },        Object_Set(thisObj, val, editThisObj) {            if (thisObj instanceof Array && val instanceof Array) {                if (!!editThisObj) {                    thisObj.map((item, index) => {                        this[editThisObj][item] = val[index];                    });                } else {                    thisObj.map((item, index) => {                        this['mixins_query'][item] = val[index];                    });                }            } else {                if (!!editThisObj) {                    this[editThisObj][thisObj] = val;                } else {                    this['mixins_query'][thisObj] = val;                }            }        }    },    watch: {        currentId(newValue, oldValue) {            this.Object_Set(['communityId', 'buildingId', 'unitName', 'houseId'], ['', '', '', '']);            if (newValue.type) {                this.chiData.type = newValue.type;                if (newValue.type === 'community') {                    this.Object_Set(['communityId'], [newValue.communityId]);                    this.Object_Set(['value', 'address'], [newValue.communityId, newValue.communityName], 'chiData');                } else if (newValue.type === 'building') {                    this.Object_Set(['communityId', 'buildingId'], [newValue.communityId, newValue.buildingId]);                    this.Object_Set(                        ['value', 'address'],                        [newValue.buildingId, newValue.communityName + ' ' + newValue.buildingName],                        'chiData'                    );                } else if (newValue.type === 'unit') {                    this.Object_Set(                        ['communityId', 'buildingId', 'unitName'],                        [newValue.communityId, newValue.buildingId, newValue.unitId]                    );                    this.Object_Set(                        ['value', 'address'],                        [                            newValue.buildingId + ':' + newValue.unitId,                            newValue.communityName + ' ' + newValue.buildingName + ' ' + newValue.unitName                        ],                        'chiData'                    );                } else if (newValue.type === 'room') {                    this.Object_Set(                        ['communityId', 'buildingId', 'unitName', 'houseId'],                        [newValue.communityId, newValue.buildingId, newValue.unitId, newValue.houseId]                    );                    this.Object_Set(                        ['value', 'address'],                        [                            newValue.houseId,                            newValue.communityName + ' ' + newValue.buildingName + ' ' + newValue.unitName + ' ' + newValue.houseName                        ],                        'chiData'                    );                }            }            this.mixins_search();        }    },    created() {        this.mixins_dataUrl = '/sc-charge/charge/bill/page'; // 分页查询接口        this.mixins_query = {            chargeStatus: this.chargeStatus,            chargeType: '1,2,3,4,5,6,7',            payType: ''        };    }};</script><style lang='scss' scoped >@import '@assets/css/public-style.scss';.search {    .zz-tab-button {        margin-right: 20px;    }    .width120 {        width: rem(120);    }}</style>
 |