|
@@ -39,174 +39,186 @@ import java.util.Map;
|
|
|
@RequestMapping("/equipment/passenger")
|
|
@RequestMapping("/equipment/passenger")
|
|
|
public class EquipmentPassengerController {
|
|
public class EquipmentPassengerController {
|
|
|
|
|
|
|
|
- @Autowired
|
|
|
|
|
- private EquipmentPassengerService equipmentPassengerService;
|
|
|
|
|
-
|
|
|
|
|
- @Autowired
|
|
|
|
|
- private EquipmentPassengerPeopleService equipmentPassengerPeopleService;
|
|
|
|
|
-
|
|
|
|
|
- @Autowired
|
|
|
|
|
- private SequenceService sequenceService;
|
|
|
|
|
-
|
|
|
|
|
- @Autowired
|
|
|
|
|
- private OauthService oauthService;
|
|
|
|
|
-
|
|
|
|
|
- @Permission(value = "equipment.passenger.find", tags = "查询人流采集设备")
|
|
|
|
|
- @PostMapping("/findPage")
|
|
|
|
|
- public Result findPage(@RequestBody QueryEquipmentPassengerParams params) {
|
|
|
|
|
-
|
|
|
|
|
- QueryWrapper<EquipmentPassenger> queryWrapper = new QueryWrapper<>();
|
|
|
|
|
-
|
|
|
|
|
- if (StringUtils.isNotBlank(params.getBrief())) {
|
|
|
|
|
- queryWrapper.like("brief", params.getBrief());
|
|
|
|
|
- }
|
|
|
|
|
- if (params.getPlaceBaseInfoId() != null) {
|
|
|
|
|
- queryWrapper.eq("place_base_info_id", params.getPlaceBaseInfoId());
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- Page<EquipmentPassenger> page = params.getPage();
|
|
|
|
|
- page.addOrder(OrderItem.desc("id"));
|
|
|
|
|
-
|
|
|
|
|
- Page<EquipmentPassenger> resultData = this.equipmentPassengerService.page(page, queryWrapper);
|
|
|
|
|
- QueryWrapper<EquipmentPassengerPeople> passengerWrapper;
|
|
|
|
|
- for (EquipmentPassenger equipment : resultData.getRecords()) {
|
|
|
|
|
- passengerWrapper = new QueryWrapper<>();
|
|
|
|
|
- passengerWrapper.eq("equipment_id", equipment.getId());
|
|
|
|
|
- passengerWrapper.eq("passenger_type", PassengerType.IN);
|
|
|
|
|
- if (params.getRangeDate() != null) {
|
|
|
|
|
- passengerWrapper.between("created_time", params.getRangeDate().getStatDate(), params.getRangeDate().getEndDate());
|
|
|
|
|
- }
|
|
|
|
|
- Long inPeopleCount = this.equipmentPassengerPeopleService.count(passengerWrapper);
|
|
|
|
|
-
|
|
|
|
|
-
|
|
|
|
|
- passengerWrapper = new QueryWrapper<>();
|
|
|
|
|
- passengerWrapper.eq("equipment_id", equipment.getId());
|
|
|
|
|
- passengerWrapper.eq("passenger_type", PassengerType.OUT);
|
|
|
|
|
- if (params.getRangeDate() != null) {
|
|
|
|
|
- passengerWrapper.between("created_time", params.getRangeDate().getStatDate(), params.getRangeDate().getEndDate());
|
|
|
|
|
- }
|
|
|
|
|
- Long outPeopleCount = this.equipmentPassengerPeopleService.count(passengerWrapper);
|
|
|
|
|
-
|
|
|
|
|
- equipment.setInPeopleCount(inPeopleCount);
|
|
|
|
|
- equipment.setOutPeopleCount(outPeopleCount);
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- return Result.instance(Result.Code.SUCCESS).setData(resultData);
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- @Permission(value = "equipment.passenger.find", tags = "查询人流采集设备详情")
|
|
|
|
|
- @PostMapping("/findDetail")
|
|
|
|
|
- public Result findDetail(Long id) {
|
|
|
|
|
-
|
|
|
|
|
- Date startTime = DateUtil.current();
|
|
|
|
|
-
|
|
|
|
|
- Map<String, Object> dataMap = new HashMap<>();
|
|
|
|
|
- QueryWrapper<EquipmentPassengerPeople> wrapper = new QueryWrapper<>();
|
|
|
|
|
- wrapper.eq("equipment_id", id);
|
|
|
|
|
- wrapper.eq("passenger_type", PassengerType.IN);
|
|
|
|
|
- Long inCount = this.equipmentPassengerPeopleService.count(wrapper);
|
|
|
|
|
-
|
|
|
|
|
- wrapper = new QueryWrapper<>();
|
|
|
|
|
- wrapper.eq("equipment_id", id);
|
|
|
|
|
- wrapper.eq("passenger_type", PassengerType.OUT);
|
|
|
|
|
- Long outCount = this.equipmentPassengerPeopleService.count(wrapper);
|
|
|
|
|
-
|
|
|
|
|
-
|
|
|
|
|
- wrapper = new QueryWrapper<>();
|
|
|
|
|
- wrapper.select("gender", "count(id) value");
|
|
|
|
|
- wrapper.eq("equipment_id", id);
|
|
|
|
|
- wrapper.groupBy("gender");
|
|
|
|
|
- List<Map<String, Object>> listGenders = this.equipmentPassengerPeopleService.listMaps(wrapper);
|
|
|
|
|
- for (Map<String, Object> genderMap : listGenders) {
|
|
|
|
|
- int genderValue = Integer.parseInt(genderMap.get("gender").toString());
|
|
|
|
|
- Gender gender = Gender.valueOf(genderValue);
|
|
|
|
|
- if (gender != null) {
|
|
|
|
|
- genderMap.put("name", gender.getText());
|
|
|
|
|
- }
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
-
|
|
|
|
|
- wrapper = new QueryWrapper<>();
|
|
|
|
|
- wrapper.select("from_source name", "count(id) value");
|
|
|
|
|
- wrapper.eq("equipment_id", id);
|
|
|
|
|
- wrapper.groupBy("from_source");
|
|
|
|
|
- wrapper.orderByDesc("value");
|
|
|
|
|
- wrapper.last("limit 8");
|
|
|
|
|
- List<Map<String, Object>> listFromSource = this.equipmentPassengerPeopleService.listMaps(wrapper);
|
|
|
|
|
-
|
|
|
|
|
-
|
|
|
|
|
- wrapper = new QueryWrapper<>();
|
|
|
|
|
- wrapper.select("AVG(unix_timestamp(created_time)) t", "passenger_type");
|
|
|
|
|
- wrapper.eq("equipment_id", id);
|
|
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private EquipmentPassengerService equipmentPassengerService;
|
|
|
|
|
+
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private EquipmentPassengerPeopleService equipmentPassengerPeopleService;
|
|
|
|
|
+
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private SequenceService sequenceService;
|
|
|
|
|
+
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private OauthService oauthService;
|
|
|
|
|
+
|
|
|
|
|
+ @Permission(value = "equipment.passenger.find", tags = "查询人流采集设备")
|
|
|
|
|
+ @PostMapping("/findPage")
|
|
|
|
|
+ public Result findPage(@RequestBody QueryEquipmentPassengerParams params) {
|
|
|
|
|
+
|
|
|
|
|
+ QueryWrapper<EquipmentPassenger> queryWrapper = new QueryWrapper<>();
|
|
|
|
|
+ queryWrapper.eq("is_deleted", 0);
|
|
|
|
|
+ queryWrapper.eq("supplier_type", 1);
|
|
|
|
|
+ if (StringUtils.isNotBlank(params.getBrief())) {
|
|
|
|
|
+ queryWrapper.like("name", params.getBrief());
|
|
|
|
|
+ }
|
|
|
|
|
+ if (params.getPlaceBaseInfoId() != null) {
|
|
|
|
|
+ queryWrapper.eq("org_id", params.getPlaceBaseInfoId());
|
|
|
|
|
+ }
|
|
|
|
|
+ if (params.getRangeDate() != null) {
|
|
|
|
|
+ if (params.getRangeDate().getStatDate() != null) {
|
|
|
|
|
+ queryWrapper.ge("create_date", params.getRangeDate().getStatDate());
|
|
|
|
|
+ }
|
|
|
|
|
+ if (params.getRangeDate().getEndDate() != null) {
|
|
|
|
|
+ queryWrapper.lt("create_date", params.getRangeDate().getEndDate());
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ Page<EquipmentPassenger> page = params.getPage();
|
|
|
|
|
+ page.addOrder(OrderItem.desc("id"));
|
|
|
|
|
+
|
|
|
|
|
+ Page<EquipmentPassenger> resultData = this.equipmentPassengerService.pageList(page, queryWrapper);
|
|
|
|
|
+ QueryWrapper<EquipmentPassengerPeople> passengerWrapper;
|
|
|
|
|
+ for (EquipmentPassenger equipment : resultData.getRecords()) {
|
|
|
|
|
+ passengerWrapper = new QueryWrapper<>();
|
|
|
|
|
+ passengerWrapper.eq("equipment_id", equipment.getId());
|
|
|
|
|
+ passengerWrapper.eq("passenger_type", PassengerType.IN);
|
|
|
|
|
+ if (params.getRangeDate() != null) {
|
|
|
|
|
+ passengerWrapper.between("created_time", params.getRangeDate().getStatDate(), params.getRangeDate().getEndDate());
|
|
|
|
|
+ }
|
|
|
|
|
+ Long inPeopleCount = this.equipmentPassengerPeopleService.count(passengerWrapper);
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+ passengerWrapper = new QueryWrapper<>();
|
|
|
|
|
+ passengerWrapper.eq("equipment_id", equipment.getId());
|
|
|
|
|
+ passengerWrapper.eq("passenger_type", PassengerType.OUT);
|
|
|
|
|
+ if (params.getRangeDate() != null) {
|
|
|
|
|
+ passengerWrapper.between("created_time", params.getRangeDate().getStatDate(), params.getRangeDate().getEndDate());
|
|
|
|
|
+ }
|
|
|
|
|
+ Long outPeopleCount = this.equipmentPassengerPeopleService.count(passengerWrapper);
|
|
|
|
|
+
|
|
|
|
|
+ equipment.setInPeopleCount(inPeopleCount);
|
|
|
|
|
+ equipment.setOutPeopleCount(outPeopleCount);
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ return Result.instance(Result.Code.SUCCESS).setData(resultData);
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ @Permission(value = "equipment.passenger.find", tags = "查询人流采集设备详情")
|
|
|
|
|
+ @PostMapping("/findDetail")
|
|
|
|
|
+ public Result findDetail(Long id, Long orgId) {
|
|
|
|
|
+ Date startTime = new Date();
|
|
|
|
|
+ Map<String, Object> dataMap = new HashMap<>();
|
|
|
|
|
+ dataMap.put("latLng", this.equipmentPassengerService.loadLatLng(id));
|
|
|
|
|
+ dataMap.put("visitorsList", this.equipmentPassengerService.numberOfHolidayVisitors(orgId));
|
|
|
|
|
+ //实时概况
|
|
|
|
|
+ dataMap.put("survey", this.equipmentPassengerService.realTimeSurvey(orgId));
|
|
|
|
|
+
|
|
|
|
|
+ QueryWrapper<EquipmentPassengerPeople> wrapper = new QueryWrapper<>();
|
|
|
|
|
+ wrapper.eq("equipment_id", id);
|
|
|
|
|
+ wrapper.eq("passenger_type", PassengerType.IN);
|
|
|
|
|
+ Long inCount = this.equipmentPassengerPeopleService.count(wrapper);
|
|
|
|
|
+
|
|
|
|
|
+ wrapper = new QueryWrapper<>();
|
|
|
|
|
+ wrapper.eq("equipment_id", id);
|
|
|
|
|
+ wrapper.eq("passenger_type", PassengerType.OUT);
|
|
|
|
|
+ Long outCount = this.equipmentPassengerPeopleService.count(wrapper);
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+ wrapper = new QueryWrapper<>();
|
|
|
|
|
+ wrapper.select("gender", "count(id) value");
|
|
|
|
|
+ wrapper.eq("equipment_id", id);
|
|
|
|
|
+ wrapper.groupBy("gender");
|
|
|
|
|
+ List<Map<String, Object>> listGenders = this.equipmentPassengerPeopleService.listMaps(wrapper);
|
|
|
|
|
+ for (Map<String, Object> genderMap : listGenders) {
|
|
|
|
|
+ int genderValue = Integer.parseInt(genderMap.get("gender").toString());
|
|
|
|
|
+ Gender gender = Gender.valueOf(genderValue);
|
|
|
|
|
+ if (gender != null) {
|
|
|
|
|
+ genderMap.put("name", gender.getText());
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+ wrapper = new QueryWrapper<>();
|
|
|
|
|
+ wrapper.select("from_source name", "count(id) value");
|
|
|
|
|
+ wrapper.eq("equipment_id", id);
|
|
|
|
|
+ wrapper.groupBy("from_source");
|
|
|
|
|
+ wrapper.orderByDesc("value");
|
|
|
|
|
+ wrapper.last("limit 8");
|
|
|
|
|
+ List<Map<String, Object>> listFromSource = this.equipmentPassengerPeopleService.listMaps(wrapper);
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+ wrapper = new QueryWrapper<>();
|
|
|
|
|
+ wrapper.select("AVG(unix_timestamp(created_time)) t", "passenger_type");
|
|
|
|
|
+ wrapper.eq("equipment_id", id);
|
|
|
// wrapper.inSql("face_id", "select face_id from equipment_passenger_people GROUP BY face_id HAVING count(face_id)> 1");
|
|
// wrapper.inSql("face_id", "select face_id from equipment_passenger_people GROUP BY face_id HAVING count(face_id)> 1");
|
|
|
- wrapper.groupBy("passenger_type");
|
|
|
|
|
- List<Map<String, Object>> listPassenger = this.equipmentPassengerPeopleService.listMaps(wrapper);
|
|
|
|
|
|
|
+ wrapper.groupBy("passenger_type");
|
|
|
|
|
+ List<Map<String, Object>> listPassenger = this.equipmentPassengerPeopleService.listMaps(wrapper);
|
|
|
|
|
|
|
|
- int avgInTime = 0;
|
|
|
|
|
- int avgOutTime = 0;
|
|
|
|
|
- for (Map<String, Object> avgMap : listPassenger) {
|
|
|
|
|
- int passengerTypeValue = Integer.parseInt(avgMap.get("passenger_type").toString());
|
|
|
|
|
- BigDecimal t = new BigDecimal(avgMap.get("t").toString());
|
|
|
|
|
- PassengerType passengerType = PassengerType.valueOf(passengerTypeValue);
|
|
|
|
|
- if (PassengerType.IN.equals(passengerType)) {
|
|
|
|
|
- avgInTime = t.intValue();
|
|
|
|
|
- }
|
|
|
|
|
- if (PassengerType.OUT.equals(passengerType)) {
|
|
|
|
|
- avgOutTime = t.intValue();
|
|
|
|
|
- }
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ int avgInTime = 0;
|
|
|
|
|
+ int avgOutTime = 0;
|
|
|
|
|
+ for (Map<String, Object> avgMap : listPassenger) {
|
|
|
|
|
+ int passengerTypeValue = Integer.parseInt(avgMap.get("passenger_type").toString());
|
|
|
|
|
+ BigDecimal t = new BigDecimal(avgMap.get("t").toString());
|
|
|
|
|
+ PassengerType passengerType = PassengerType.valueOf(passengerTypeValue);
|
|
|
|
|
+ if (PassengerType.IN.equals(passengerType)) {
|
|
|
|
|
+ avgInTime = t.intValue();
|
|
|
|
|
+ }
|
|
|
|
|
+ if (PassengerType.OUT.equals(passengerType)) {
|
|
|
|
|
+ avgOutTime = t.intValue();
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- Date endTime = DateUtil.current();
|
|
|
|
|
|
|
+ Date endTime = DateUtil.current();
|
|
|
|
|
|
|
|
- dataMap.put("inCount", inCount);
|
|
|
|
|
- dataMap.put("outCount", outCount);
|
|
|
|
|
- dataMap.put("listGenders", listGenders);
|
|
|
|
|
- dataMap.put("listFromSource", listFromSource);
|
|
|
|
|
- dataMap.put("avgStayTime", avgOutTime - avgInTime);
|
|
|
|
|
- dataMap.put("l", endTime.getTime() - startTime.getTime());
|
|
|
|
|
- return Result.instance(Result.Code.SUCCESS).setData(dataMap);
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ dataMap.put("inCount", inCount);
|
|
|
|
|
+ dataMap.put("outCount", outCount);
|
|
|
|
|
+ dataMap.put("listGenders", listGenders);
|
|
|
|
|
+ dataMap.put("listFromSource", listFromSource);
|
|
|
|
|
+ dataMap.put("avgStayTime", avgOutTime - avgInTime);
|
|
|
|
|
+ dataMap.put("l", endTime.getTime() - startTime.getTime());
|
|
|
|
|
+ return Result.instance(Result.Code.SUCCESS).setData(dataMap);
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- @Permission(value = "equipment.passenger.add", tags = "保存人流采集设备")
|
|
|
|
|
- @PostMapping("/save")
|
|
|
|
|
- public Result save(@Valid @RequestBody SaveEquipmentPassengerParams params) {
|
|
|
|
|
|
|
+ @Permission(value = "equipment.passenger.add", tags = "保存人流采集设备")
|
|
|
|
|
+ @PostMapping("/save")
|
|
|
|
|
+ public Result save(@Valid @RequestBody SaveEquipmentPassengerParams params) {
|
|
|
|
|
|
|
|
- this.equipmentPassengerService.save(this.buildEntity(this.sequenceService.nextId(), params));
|
|
|
|
|
|
|
+ this.equipmentPassengerService.save(this.buildEntity(this.sequenceService.nextId(), params));
|
|
|
|
|
|
|
|
- return Result.instance(Result.Code.MESSAGE_SUCCESS);
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ return Result.instance(Result.Code.MESSAGE_SUCCESS);
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- @Permission(value = "equipment.passenger.edit", tags = "编辑人流采集设备")
|
|
|
|
|
- @PostMapping("/updateById")
|
|
|
|
|
- public Result updateById(Long id, @Valid @RequestBody SaveEquipmentPassengerParams params) {
|
|
|
|
|
|
|
+ @Permission(value = "equipment.passenger.edit", tags = "编辑人流采集设备")
|
|
|
|
|
+ @PostMapping("/updateById")
|
|
|
|
|
+ public Result updateById(Long id, @Valid @RequestBody SaveEquipmentPassengerParams params) {
|
|
|
|
|
|
|
|
- this.equipmentPassengerService.updateById(this.buildEntity(id, params));
|
|
|
|
|
|
|
+ this.equipmentPassengerService.updateById(this.buildEntity(id, params));
|
|
|
|
|
|
|
|
- return Result.instance(Result.Code.MESSAGE_SUCCESS);
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ return Result.instance(Result.Code.MESSAGE_SUCCESS);
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
|
|
|
|
|
- private EquipmentPassenger buildEntity(Long id, @Valid SaveEquipmentPassengerParams params) {
|
|
|
|
|
|
|
+ private EquipmentPassenger buildEntity(Long id, @Valid SaveEquipmentPassengerParams params) {
|
|
|
|
|
|
|
|
- EquipmentPassenger entity = new EquipmentPassenger();
|
|
|
|
|
|
|
+ EquipmentPassenger entity = new EquipmentPassenger();
|
|
|
|
|
|
|
|
- BeanUtils.copyProperties(params, entity);
|
|
|
|
|
|
|
+ BeanUtils.copyProperties(params, entity);
|
|
|
|
|
|
|
|
- OauthInfo oauthInfo = this.oauthService.getAuth(ServletContext.getAccessToken());
|
|
|
|
|
|
|
+ OauthInfo oauthInfo = this.oauthService.getAuth(ServletContext.getAccessToken());
|
|
|
|
|
|
|
|
- entity.setCreatedTime(DateUtil.current());
|
|
|
|
|
- entity.setUpdatedTime(DateUtil.current());
|
|
|
|
|
- entity.setCreatedBy(oauthInfo.getId());
|
|
|
|
|
- entity.setUpdatedBy(oauthInfo.getId());
|
|
|
|
|
|
|
+ entity.setCreatedTime(DateUtil.current());
|
|
|
|
|
+ entity.setUpdatedTime(DateUtil.current());
|
|
|
|
|
+ entity.setCreatedBy(oauthInfo.getId());
|
|
|
|
|
+ entity.setUpdatedBy(oauthInfo.getId());
|
|
|
|
|
|
|
|
- entity.setId(id);
|
|
|
|
|
- return entity;
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ entity.setId(id);
|
|
|
|
|
+ return entity;
|
|
|
|
|
+ }
|
|
|
|
|
|
|
|
- @Permission(value = "equipment.passenger.delete", tags = "删除人流采集设备")
|
|
|
|
|
- @PostMapping("/deleteByIds")
|
|
|
|
|
- public Result deleteByIds(@RequestBody List<Long> ids) {
|
|
|
|
|
- this.equipmentPassengerService.removeByIds(ids);
|
|
|
|
|
- return Result.instance(Result.Code.MESSAGE_SUCCESS);
|
|
|
|
|
- }
|
|
|
|
|
|
|
+ @Permission(value = "equipment.passenger.delete", tags = "删除人流采集设备")
|
|
|
|
|
+ @PostMapping("/deleteByIds")
|
|
|
|
|
+ public Result deleteByIds(@RequestBody List<Long> ids) {
|
|
|
|
|
+ this.equipmentPassengerService.removeByIds(ids);
|
|
|
|
|
+ return Result.instance(Result.Code.MESSAGE_SUCCESS);
|
|
|
|
|
+ }
|
|
|
}
|
|
}
|