package com.yanzhen.controller;
import com.github.pagehelper.PageInfo;
import com.yanzhen.model.PropertyInfo;
import com.yanzhen.model.PropertyType;
import com.yanzhen.model.RecordVo;
import com.yanzhen.model.Records;
import com.yanzhen.service.IPropertyInfoService;
import com.yanzhen.service.IPropertyTypeService;
import com.yanzhen.service.IRecordsService;
import com.yanzhen.util.JsonObject;
import com.yanzhen.util.R;
import io.swagger.annotations.ApiOperation;
import io.swagger.models.auth.In;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
import java.util.Arrays;
import java.util.Date;
import java.util.List;
/**
* <p>
* 前端控制器
* </p>
*
* @author kappy
* @since 2020-10-28
*/
@RestController
@RequestMapping("/records")
public class RecordsController {
private Logger log = LoggerFactory.getLogger(getClass());
@Resource
private IRecordsService recordsService;
@Resource
private IPropertyTypeService propertyTypeService;
@Resource
private IPropertyInfoService propertyInfoService;
/**
* 分页查询记录信息
* @param page
* @param limit
* @param recordVo
* @return
*/
@RequestMapping("/queryRecordsAll")
public JsonObject queryRecordsAll(@RequestParam(defaultValue = "1") Integer page,
@RequestParam(defaultValue = "15") Integer limit,
RecordVo recordVo){
JsonObject jsonObject=new JsonObject();
PageInfo <RecordVo> pageInfo=recordsService.findRecordsAll(page,limit,recordVo);
jsonObject.setCode(0);
jsonObject.setCount(pageInfo.getTotal());
jsonObject.setMsg("ok");
jsonObject.setData(pageInfo.getList());
return jsonObject;
}
/**
* 抄表的添加工作
*/
@RequestMapping("/add")
@Transactional(rollbackFor = {RuntimeException.class,Error.class})
public R add(@RequestBody Records records){
/*
步骤:
1、添加抄表记录信息
1.1 根据记录中的房子和类型查询上次抄表的度数以及相关时间信息
如果存在,需要获取上次的度数,上次时间
如果不存在 上次度数设置为0 上次时间使用本次时间
1.2 添加记录信息
2、添加物业收费信息
2.1 获取 上次到这次之间的度数信息
2.2 根据收费类型查询收费标准
2.3 用1的度数×2的的收费标准 获取相关费用
2.4 并设定为未缴费状态
2.5 添加工作
*/
//根据参数房子id和类型id 获取最后一次登记信息
Integer houId=records.getHouseId();
Integer typeId=records.getTypeId();
//获取最后一次记录信息
Records rec=recordsService.queryByHouIdAndTypeId(houId,typeId);
if(rec!=null){
//获取上次表的度数 上次抄表时间
records.setUpTime(rec.getOnTime());
records.setNum(rec.getNum2());
}else{
records.setUpTime(records.getOnTime());
records.setNum(0.0);
}
//添加记录信息到数据库
records.setCheckTime(new Date());
recordsService.add(records);
//2 添加费用信息
PropertyInfo info=new PropertyInfo();
info.setHouseId(houId);
info.setTypeId(typeId);
info.setStatus(0);//未缴费
if(rec!=null){//如果有上次时间
info.setStartDate(rec.getUpTime());
}else {
info.setStartDate(records.getOnTime());
}
info.setEndDate(records.getOnTime());
//根据类型的id查询类型的费用标准
PropertyType type=propertyTypeService.findById(new Long(typeId));
double price=type.getPrice();//u获取收费标准
//获取度数
double money=(records.getNum2()-records.getNum())*price;
info.setMoney(money);
info.setRemarks(records.getRemarks());
//添加记录信息
int num= propertyInfoService.add(info);
if(num>0){
return R.ok();
}else{
return R.fail("异常");
}
}
@RequestMapping("/deleteByIds")
@Transactional(rollbackFor = {RuntimeException.class,Error.class})
public R deleteByIds(String ids){
//把字符串转list集合
List<String> list=Arrays.asList(ids.split(","));
for(String id:list){
Long idLong=Long.parseLong(id);
//根据id获取对应的记录信息获取登记时间以及房子id
Records records=recordsService.findById(idLong);
//获取房子id
Integer houId=records.getHouseId();
//获取时间
Date onTime=records.getOnTime();
//删除登记表记录信息
recordsService.delete(idLong);
//物业收费信息表相关信息
propertyInfoService.deleteInfoByHouIdAndTime(houId ,onTime);
}
return R.ok();
}
//
// @ApiOperation(value = "更新")
// @RequestMapping("/update")
// public R update(@RequestBody Building building){
// int num=buildingService.updateData(building);
// if(num>0){
// return R.ok("修改成功",null);
// }else{
// return R.fail("修改失败");
// }
// }
//
// @ApiOperation(value = "查询分页数据")
// @ApiImplicitParams({
// @ApiImplicitParam(name = "page", value = "页码"),
// @ApiImplicitParam(name = "pageCount", value = "每页条数")
// })
// @GetMapping()
// public IPage<Building> findListByPage(@RequestParam Integer page,
// @RequestParam Integer pageCount){
// return buildingService.findListByPage(page, pageCount);
// }
//
// @ApiOperation(value = "id查询")
// @GetMapping("{id}")
// public Building findById(@PathVariable Long id){
// return buildingService.findById(id);
// }
}
没有合适的资源?快使用搜索试试~ 我知道了~
资源推荐
资源详情
资源评论
收起资源包目录
基于spring boot的小区物业管理系统 (365个子文件)
mvnw.cmd 6KB
layui.css 71KB
font-awesome.css 37KB
font-awesome.min.css 30KB
layuimini.css 17KB
wangEditor.css 17KB
wangEditor.min.css 15KB
layer.css 14KB
layui.mobile.css 10KB
zyupload-1.0.0.min.css 9KB
demo.css 8KB
laydate.css 7KB
default.css 4KB
iconfont.css 1KB
step.css 1KB
code.css 1KB
public.css 942B
treetable.css 294B
fontawesome-webfont.eot 162KB
iconfont.eot 41KB
59.gif 10KB
22.gif 10KB
24.gif 8KB
13.gif 7KB
16.gif 7KB
39.gif 6KB
64.gif 6KB
63.gif 6KB
50.gif 6KB
loading-0.gif 6KB
4.gif 6KB
1.gif 5KB
42.gif 5KB
71.gif 5KB
21.gif 5KB
20.gif 5KB
29.gif 5KB
70.gif 4KB
5.gif 4KB
17.gif 4KB
27.gif 4KB
9.gif 4KB
44.gif 4KB
11.gif 4KB
8.gif 4KB
3.gif 4KB
23.gif 4KB
34.gif 4KB
41.gif 4KB
38.gif 4KB
65.gif 3KB
32.gif 3KB
45.gif 3KB
7.gif 3KB
12.gif 3KB
26.gif 3KB
60.gif 3KB
2.gif 3KB
40.gif 3KB
25.gif 3KB
19.gif 3KB
66.gif 3KB
18.gif 3KB
46.gif 3KB
10.gif 3KB
28.gif 3KB
51.gif 3KB
57.gif 3KB
67.gif 3KB
0.gif 3KB
48.gif 3KB
43.gif 3KB
30.gif 2KB
61.gif 2KB
33.gif 2KB
69.gif 2KB
14.gif 2KB
47.gif 2KB
36.gif 2KB
49.gif 2KB
58.gif 2KB
6.gif 2KB
54.gif 2KB
53.gif 2KB
56.gif 2KB
62.gif 2KB
31.gif 2KB
55.gif 2KB
35.gif 2KB
15.gif 2KB
loading-2.gif 2KB
37.gif 1KB
68.gif 1KB
52.gif 777B
loading-1.gif 701B
.gitignore 395B
demo_index.html 22KB
PropertyIndex.html 15KB
welcome-3.html 12KB
login.html 10KB
共 365 条
- 1
- 2
- 3
- 4
资源评论
m0_53523936
- 粉丝: 0
- 资源: 1
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功