收款單控制層

package com.jieling.controller;


import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.jieling.common.BaseContext;
import com.jieling.common.R;
import com.jieling.dao.Jxc_b_receiptsDao;
import com.jieling.dao.Jxc_m_receipttypeDao;
import com.jieling.dao.basicDataDao.M_provinceDao;
import com.jieling.domain.Jxc_b_receipts;
import com.jieling.domain.Jxc_m_receipttype;
import com.jieling.domain.S_department;
import com.jieling.domain.basicDataDomain.M_manager;
import com.jieling.domain.basicDataDomain.M_province;
import com.jieling.dto.ReceiptsDto;
import com.jieling.dto.basicDataDTO.GoodsDto;
import com.jieling.dto.basicDataDTO.ManagerDto;
import com.jieling.dto.basicDataDTO.ProvinceDto;
import com.jieling.dto.basicDataDTO.SuppliersDto;
import com.jieling.service.IJxc_b_receiptsService;
import com.jieling.utils.DocumentCodeUtils;
import com.jieling.utils.POIUtils;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
import org.apache.ibatis.logging.stdout.StdOutImpl;
import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;

import javax.servlet.http.HttpServletRequest;
import java.math.BigDecimal;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
import java.util.ArrayList;
import java.util.List;

/**
 * <p>
 * 收款單
 * 前端控制器
 * </p>
 *
 * @author 梁勇文
 * @since 2023-05-03
 */
@RestController
@Slf4j
@RequestMapping("/api/receipts")
public class Jxc_b_receiptsController {

    @Autowired
    private IJxc_b_receiptsService receiptsService;//收款單

    @Autowired
    private Jxc_b_receiptsDao receiptsDao;
    @Autowired
    private Jxc_m_receipttypeDao receipttypeDao;//單據(jù)類型

    @Autowired
    private M_provinceDao provinceDao;//省區(qū)名稱

    //根據(jù)ID查找
    @GetMapping("/{id}")
    public R<Jxc_b_receipts> getById(@PathVariable String id) {
        Jxc_b_receipts receipts = receiptsService.getById(id);
        if (receipts != null) {
            return R.success(receipts);
        }
        return R.error("沒有數(shù)據(jù)");
    }

    //分頁(yè)查詢
    @PostMapping("/page")
    public R<Page> page(@RequestBody ReceiptsDto receiptsDto) {
        //ReceiptsDto receiptsDto1 = new ReceiptsDto();
        //1、判空
        //單據(jù)日期
        LocalDate[] daterange = receiptsDto.getDaterange();
        if (receiptsDto.getDaterange().length > 0) {

            receiptsDto.setStrDate(daterange[0]);//開始時(shí)間
            receiptsDto.setEndDate(daterange[1]);//結(jié)束時(shí)間
        }
        //是否審核
        if (receiptsDto.getHasExamine() != null) {
            //是否審核
            receiptsDto.setHasExamine(receiptsDto.getHasExamine());
        }
        //單據(jù)編號(hào)
        if (StringUtils.isNotEmpty(receiptsDto.getBillNo())) {
            receiptsDto.setBillNo(receiptsDto.getBillNo());
        }
        //省區(qū)

        if (StringUtils.isNotEmpty(receiptsDto.getMpGuid())) {
            receiptsDto.setMpGuid(receiptsDto.getMpGuid());
        }
        //大區(qū)
        if (StringUtils.isNotEmpty(receiptsDto.getMaGuid())) {
            receiptsDto.setMaGuid(receiptsDto.getMaGuid());
            System.out.println("進(jìn)來了。弄慰。柏副。" + receiptsDto.getMaGuid());
        }
        //客戶名稱
        if (StringUtils.isNotEmpty(receiptsDto.getCustomerName())) {
            receiptsDto.setCustomerName(receiptsDto.getCustomerName());
        }
        //所屬系統(tǒng)
        if (StringUtils.isNotEmpty(receiptsDto.getPriceGroupMainGuid())) {
            receiptsDto.setPriceGroupMainGuid(receiptsDto.getPriceGroupMainGuid());
        }
        //回款名稱
        if (StringUtils.isNotEmpty(receiptsDto.getReturnAmontName())) {
            receiptsDto.setReturnAmontName(receiptsDto.getReturnAmontName());
        }
        //收支方式
        if (StringUtils.isNotEmpty(receiptsDto.getMSettleGuid())) {
            receiptsDto.setMSettleGuid(receiptsDto.getMSettleGuid());
        }
        //收支賬戶
        //        mAccountGuid
        System.out.println("收支賬戶GUID是:" + receiptsDto.getMAccountGuid());

        System.out.println("收支賬戶名稱是:" + receiptsDto.getMAccountName());
        if (StringUtils.isNotEmpty(receiptsDto.getMAccountGuid())) {
            receiptsDto.setMAccountGuid(receiptsDto.getMAccountGuid());
        }
        //收款類型
        //客戶類型
        //備注
        if (StringUtils.isNotEmpty(receiptsDto.getRemark())) {
            receiptsDto.setRemark(receiptsDto.getRemark());
        }
        Page<ReceiptsDto> receiptsDtoPage = new Page<>(receiptsDto.getPage(), receiptsDto.getPageSize());
        receiptsDao.getAll(receiptsDtoPage, receiptsDto);
        long total = receiptsDtoPage.getTotal();
        if (total == 0) {
            return R.error("該查詢條件下沒有數(shù)據(jù)");
        }
        return R.success(receiptsDtoPage);
    }

    //新增
    @PostMapping()
    public R<String> add(@RequestBody ReceiptsDto receiptsDto) {
        //用單據(jù)編號(hào)工具類生成單據(jù)編號(hào)
        //收款單的單據(jù)編號(hào)是CB
        DocumentCodeUtils utils = new DocumentCodeUtils();
        String documentCodeFormat = utils.documentCodeFormat("CB", receiptsDto.getMpGuid());
        receiptsDto.setBillNo(documentCodeFormat);
        boolean save = receiptsService.save(receiptsDto);
        if (!save) {
            return R.error("新增失敗了");
        }
        return R.success("新增成功了");
    }

    //修改
    @PutMapping("/{id}")
    public R<String> update(@PathVariable String id, @RequestBody ReceiptsDto receiptsDto) {
        log.info("id...{}", id);
        boolean b = receiptsService.updateById(receiptsDto);
        if (!b) {
            return R.error("修改失敗");
        }
        return R.success("修改成功");
    }

    //審核阔墩、撤回
    @PutMapping("/updateByHasExamine")
    public R<String> updateByHasExamine(HttpServletRequest request, @RequestBody ReceiptsDto receiptsDto) {
       // String id = (String) request.getSession().getAttribute("");
        String name = BaseContext.getCurrentName().getMmName();//獲取登錄人員的登錄名
        //則更新
        System.out.println("  主鍵id:" + receiptsDto.getReceiptsGuid());

        receiptsDto.setExUser(name);//設(shè)置審核人
        receiptsDto.setExDate(LocalDateTime.now());//設(shè)置審核時(shí)間
        boolean b = receiptsService.updateById(receiptsDto);
        if (b) {
            return R.success("修改成功");
        }
        return R.error("修改失敗");

    }

    //刪除
    @DeleteMapping("/{id}")
    public R<String> delete(@PathVariable String id) {
        boolean b = receiptsService.removeById(id);
        if (!b) {
            return R.error("刪除失敗");
        }
        return R.success("刪除成功");
    }

    /**
     * 上傳excel文件導(dǎo)入數(shù)據(jù)
     *
     * @param file
     * @return
     * @throws Exception
     */
    @PostMapping("/upload")
    public R<String> upload(@RequestParam("file") MultipartFile file) throws Exception {
        if (file.isEmpty()) {
            return R.error("上傳文件失敗音半,請(qǐng)選擇文件");
        }
        int add = 0;
        List<String[]> list = POIUtils.readExcel(file);
        List<ReceiptsDto> receiptsDtoList = new ArrayList<>();
        if (list != null && list.size() > 0) {
            // 遍歷讀取電子表
            for (String[] strings : list) {
                //創(chuàng)建對(duì)象
                ReceiptsDto receiptsDto = new ReceiptsDto();

                //省區(qū)名稱
                receiptsDto.setMpName(strings[0]);
                //客戶名稱
                receiptsDto.setMCustomerName(strings[1]);
                //單據(jù)日期
                receiptsDto.setBillDate(LocalDateTime.parse(strings[2]));
                //支票號(hào)
                receiptsDto.setBillNo(strings[3]);
                //回款名稱
                receiptsDto.setReturnAmontName(strings[4]);
                //結(jié)算方式
                receiptsDto.setMSettleName(strings[5]);
                //收支賬戶
                receiptsDto.setMAccountName(strings[6]);
                //實(shí)收金額
                BigDecimal incomeDecimal = new BigDecimal(strings[7]);
                receiptsDto.setIncomeAmount(incomeDecimal);
                //流水類型
                receiptsDto.setFlowType(Integer.valueOf(strings[8]));
                //付款單號(hào)
                receiptsDto.setSbCode(strings[9]);
                //備注
                receiptsDto.setRemark(strings[10]);
                //添加到receiptsDtoList集合中
                receiptsDtoList.add(receiptsDto);
            }
        }
        // 調(diào)用服務(wù)
        add = receiptsService.add(receiptsDtoList);
        return R.success("導(dǎo)入成功挪凑,導(dǎo)入了:" + add + "條數(shù)據(jù)");
    }

    private String getString(String string) {

        if ("".equals(string)) {
            string = "0";
        }
        return string;
    }


}



?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市茵休,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌手蝎,老刑警劉巖榕莺,帶你破解...
    沈念sama閱讀 211,496評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異棵介,居然都是意外死亡钉鸯,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,187評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門邮辽,熙熙樓的掌柜王于貴愁眉苦臉地迎上來唠雕,“玉大人,你說我怎么就攤上這事吨述⊙艺觯” “怎么了?”我有些...
    開封第一講書人閱讀 157,091評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵揣云,是天一觀的道長(zhǎng)捕儒。 經(jīng)常有香客問我,道長(zhǎng)邓夕,這世上最難降的妖魔是什么刘莹? 我笑而不...
    開封第一講書人閱讀 56,458評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮焚刚,結(jié)果婚禮上点弯,老公的妹妹穿的比我還像新娘。我一直安慰自己矿咕,他們只是感情好蒲拉,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,542評(píng)論 6 385
  • 文/花漫 我一把揭開白布肃拜。 她就那樣靜靜地躺著,像睡著了一般雌团。 火紅的嫁衣襯著肌膚如雪燃领。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,802評(píng)論 1 290
  • 那天锦援,我揣著相機(jī)與錄音猛蔽,去河邊找鬼。 笑死灵寺,一個(gè)胖子當(dāng)著我的面吹牛曼库,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播略板,決...
    沈念sama閱讀 38,945評(píng)論 3 407
  • 文/蒼蘭香墨 我猛地睜開眼毁枯,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了叮称?” 一聲冷哼從身側(cè)響起种玛,我...
    開封第一講書人閱讀 37,709評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎瓤檐,沒想到半個(gè)月后赂韵,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,158評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡挠蛉,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,502評(píng)論 2 327
  • 正文 我和宋清朗相戀三年祭示,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片谴古。...
    茶點(diǎn)故事閱讀 38,637評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡质涛,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出掰担,到底是詐尸還是另有隱情蹂窖,我是刑警寧澤,帶...
    沈念sama閱讀 34,300評(píng)論 4 329
  • 正文 年R本政府宣布恩敌,位于F島的核電站瞬测,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏纠炮。R本人自食惡果不足惜月趟,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,911評(píng)論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望恢口。 院中可真熱鬧孝宗,春花似錦、人聲如沸耕肩。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,744評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至婚被,卻和暖如春狡忙,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背址芯。 一陣腳步聲響...
    開封第一講書人閱讀 31,982評(píng)論 1 266
  • 我被黑心中介騙來泰國(guó)打工灾茁, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人谷炸。 一個(gè)月前我還...
    沈念sama閱讀 46,344評(píng)論 2 360
  • 正文 我出身青樓北专,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親旬陡。 傳聞我的和親對(duì)象是個(gè)殘疾皇子拓颓,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,500評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容