This commit is contained in:
2023-07-12 16:50:56 +08:00
8 changed files with 109 additions and 23 deletions

View File

@@ -1,5 +1,6 @@
package com.jsowell.api.uniapp; package com.jsowell.api.uniapp;
import com.alibaba.fastjson2.JSON;
import com.alibaba.fastjson2.JSONObject; import com.alibaba.fastjson2.JSONObject;
import com.jsowell.common.annotation.Anonymous; import com.jsowell.common.annotation.Anonymous;
import com.jsowell.common.core.controller.BaseController; import com.jsowell.common.core.controller.BaseController;
@@ -70,6 +71,31 @@ public class PersonPileController extends BaseController {
return response; return response;
} }
/**
* 用户解绑个人桩
* @return
*/
@RequestMapping("/userUnbindPile")
public RestApiResponse<?> userUnbindPile(HttpServletRequest request, @RequestBody PileMemberBindingDTO dto) {
logger.info("用户解绑个人桩信息 params:{}", JSONObject.toJSONString(dto));
RestApiResponse<?> response = null;
try {
String memberId = getMemberIdByAuthorization(request);
dto.setMemberId(memberId);
int i = pileService.userUnbindPile(dto);
response = new RestApiResponse<>(i);
} catch (BusinessException e) {
logger.error("用户解绑个人桩 error, ", e);
response = new RestApiResponse<>(e.getCode(), e.getMessage());
} catch (Exception e) {
logger.error("用户解绑个人桩 error, ", e);
response = new RestApiResponse<>(ReturnCodeEnum.CODE_UNBIND_PILE_ERROR);
}
logger.info("用户解绑个人桩 result:{}", response);
return response;
}
/** /**
* 个人桩管理员下发给其他用户 * 个人桩管理员下发给其他用户
* *

View File

@@ -49,11 +49,7 @@ import org.springframework.stereotype.Service;
import javax.annotation.Resource; import javax.annotation.Resource;
import java.math.BigDecimal; import java.math.BigDecimal;
import java.util.Date; import java.util.*;
import java.util.HashMap;
import java.util.List;
import java.util.Locale;
import java.util.Map;
import java.util.concurrent.CompletableFuture; import java.util.concurrent.CompletableFuture;
import java.util.concurrent.ExecutionException; import java.util.concurrent.ExecutionException;
import java.util.stream.Collectors; import java.util.stream.Collectors;
@@ -297,6 +293,34 @@ public class PileService {
return pileMemberRelationService.insertPileMemberRelation(pileMemberRelation); return pileMemberRelationService.insertPileMemberRelation(pileMemberRelation);
} }
/**
* 用户解绑个人桩
* @param dto
*
*/
public int userUnbindPile(PileMemberBindingDTO dto) {
// 查询该用户的身份,是管理员还是普通用户
PileMemberRelation relation = new PileMemberRelation();
relation.setPileSn(dto.getPileSn());
relation.setMemberId(dto.getMemberId());
PileMemberRelation pileMemberRelation = pileMemberRelationService.selectPileMemberRelation(relation);
if (pileMemberRelation == null) {
throw new BusinessException(ReturnCodeEnum.CODE_THIS_PILE_INFO_IS_NULL);
}
String type = pileMemberRelation.getType();
List<Integer> idList = new ArrayList<>();
// 管理员解绑则会将此桩下面所有用户解绑
if (StringUtils.equals(Constants.ONE, type)) {
List<PileMemberRelation> pileMemberRelations = pileMemberRelationService.selectPileMemberRelationByPileSn(dto.getPileSn());
idList = pileMemberRelations.stream().map(PileMemberRelation::getId).collect(Collectors.toList());
}else {
idList.add(pileMemberRelation.getId());
}
return pileMemberRelationService.deleteRelationByIds(idList);
}
/** /**
* 个人桩管理员下发给其他用户使用 * 个人桩管理员下发给其他用户使用
* *

View File

@@ -112,7 +112,7 @@ public enum ReturnCodeEnum {
CODE_NO_REAL_TIME_INFO("00400006", "未查到充电枪口实时信息"), CODE_NO_REAL_TIME_INFO("00400006", "未查到充电枪口实时信息"),
CODE_BINDING_PERSONAL_PILE_ERROR("00400007", "获取个人桩枪口实时数据异常"), CODE_BINDING_PERSONAL_PILE_ERROR("00400007", "绑定个人桩异常!"),
CODE_ADMIN_ISSUE_ERROR("00400008", "桩管理员下发个人桩异常"), CODE_ADMIN_ISSUE_ERROR("00400008", "桩管理员下发个人桩异常"),
@@ -120,6 +120,10 @@ public enum ReturnCodeEnum {
CODE_GET_PERSONAL_PILE_CONNECTOR_INFO_ERROR("00400010", "获取个人桩枪口实时数据异常"), CODE_GET_PERSONAL_PILE_CONNECTOR_INFO_ERROR("00400010", "获取个人桩枪口实时数据异常"),
CODE_THIS_PILE_INFO_IS_NULL("00400011", "未查到该桩信息!"),
CODE_UNBIND_PILE_ERROR("00400012", "解绑个人桩异常!"),
/* 个人桩 end */ /* 个人桩 end */
CODE_THIS_CARNO_HAS_BEEN_BINDING("00500001", "当前车牌号已经绑定,请检查!"), CODE_THIS_CARNO_HAS_BEEN_BINDING("00500001", "当前车牌号已经绑定,请检查!"),

View File

@@ -71,4 +71,5 @@ public interface PileMemberRelationMapper
public int deletePileMemberRelationByIds(Integer[] ids); public int deletePileMemberRelationByIds(Integer[] ids);
int deleteRelationByIds(List<Integer> ids);
} }

View File

@@ -61,6 +61,9 @@ public interface IPileMemberRelationService
*/ */
public int deletePileMemberRelationByIds(Integer[] ids); public int deletePileMemberRelationByIds(Integer[] ids);
public int deleteRelationByIds(List<Integer> ids);
/** /**
* 删除桩与用户绑定关系信息 * 删除桩与用户绑定关系信息
* *

View File

@@ -96,6 +96,11 @@ public class PileMemberRelationServiceImpl implements IPileMemberRelationService
return pileMemberRelationMapper.deletePileMemberRelationByIds(ids); return pileMemberRelationMapper.deletePileMemberRelationByIds(ids);
} }
@Override
public int deleteRelationByIds(List<Integer> ids) {
return pileMemberRelationMapper.deleteRelationByIds(ids);
}
/** /**
* 删除桩与用户绑定关系信息 * 删除桩与用户绑定关系信息
* *

View File

@@ -85,5 +85,10 @@
</if> </if>
</select> </select>
<delete id="deleteRelationByIds">
delete from pile_member_relation where id in
<foreach item="id" collection="list" open="(" separator="," close=")">
#{id}
</foreach>
</delete>
</mapper> </mapper>

View File

@@ -54,10 +54,11 @@
<el-input v-model="dialogForm.socialCreditCode" maxlength="18"></el-input> <el-input v-model="dialogForm.socialCreditCode" maxlength="18"></el-input>
</el-form-item> </el-form-item>
<el-form-item label="统一社会信用证有效期"> <el-form-item label="统一社会信用证有效期">
<el-date-picker editable v-model="dialogForm.socialCreditCodeExpires" <el-date-picker editable v-model="dataValue"
type="date" type="date"
placeholder="有效期格式为20190909" placeholder="有效期格式为20190909"
format="yyyyMMdd" format="yyyyMMdd"
:disabled="dataDisabled"
value-format="yyyyMMdd"> value-format="yyyyMMdd">
</el-date-picker> </el-date-picker>
<el-checkbox v-model="pickerChecked" @change="dataChange">长期</el-checkbox> <el-checkbox v-model="pickerChecked" @change="dataChange">长期</el-checkbox>
@@ -74,10 +75,11 @@
<el-form-item label="法人身份证有效期" prop="legalCertIdExpires"> <el-form-item label="法人身份证有效期" prop="legalCertIdExpires">
<el-date-picker <el-date-picker
editable editable
v-model="dialogForm.legalCertIdExpires" v-model="addLegalCertIdDate"
type="date" type="date"
placeholder="有效期格式为20190909" placeholder="有效期格式为20190909"
format="yyyyMMdd" format="yyyyMMdd"
:disabled="addLegDisabled"
value-format="yyyyMMdd"> value-format="yyyyMMdd">
</el-date-picker> </el-date-picker>
<el-checkbox v-model="legalCertIdChecked" @change="legalCertIdaChange">长期</el-checkbox> <el-checkbox v-model="legalCertIdChecked" @change="legalCertIdaChange">长期</el-checkbox>
@@ -343,10 +345,11 @@
<el-form-item label="统一社会信用证有效期"> <el-form-item label="统一社会信用证有效期">
<el-date-picker <el-date-picker
editable editable
v-model="adapayCorpMember.socialCreditCodeExpires" v-model="updateSocialCreditCode"
type="date" type="date"
placeholder="有效期格式为20190909" placeholder="有效期格式为20190909"
format="yyyyMMdd" format="yyyyMMdd"
:disabled="dataDisabled"
value-format="yyyyMMdd"> value-format="yyyyMMdd">
</el-date-picker> </el-date-picker>
<el-checkbox v-model="adapaySocialCredChecked" @change="adapaySocialCredChange">长期</el-checkbox> <el-checkbox v-model="adapaySocialCredChecked" @change="adapaySocialCredChange">长期</el-checkbox>
@@ -363,10 +366,11 @@
<el-form-item label="法人身份证有效期"> <el-form-item label="法人身份证有效期">
<el-date-picker <el-date-picker
editable editable
v-model="adapayCorpMember.legalCertIdExpires" v-model="updatelegalCertId"
type="date" type="date"
placeholder="有效期格式为20190909" placeholder="有效期格式为20190909"
format="yyyyMMdd" format="yyyyMMdd"
:disabled="addLegDisabled"
value-format="yyyyMMdd"> value-format="yyyyMMdd">
</el-date-picker> </el-date-picker>
<el-checkbox v-model="adapayLegalCertIdChecked" @change="adapayLegalCertIdChange">长期</el-checkbox> <el-checkbox v-model="adapayLegalCertIdChecked" @change="adapayLegalCertIdChange">长期</el-checkbox>
@@ -455,6 +459,12 @@ export default {
props: ["merchantId"], props: ["merchantId"],
data() { data() {
return { return {
dataDisabled:false,
addLegDisabled:false,
updatelegalCertId:null,
updateSocialCreditCode:null,
addLegalCertIdDate:null,
dataValue:null,
adapayLegalCertIdChecked:false, adapayLegalCertIdChecked:false,
adapaySocialCredChecked:false, adapaySocialCredChecked:false,
pickerChecked:false,// 统一社会编码有效期 长期 pickerChecked:false,// 统一社会编码有效期 长期
@@ -704,32 +714,36 @@ export default {
methods: { methods: {
adapayLegalCertIdChange(e){ adapayLegalCertIdChange(e){
if(e===true){ if(e===true){
return this.adapayCorpMember.legalCertIdExpires = '20991231' this.addLegDisabled = true
} else { this.updatelegalCertId = '20991231'
return this.adapayCorpMember.legalCertIdExpires = '' } else{
this.addLegDisabled = false
} }
}, },
adapaySocialCredChange(e){ adapaySocialCredChange(e){
if(e===true){ if(e===true){
return this.adapayCorpMember.socialCreditCodeExpires = '20991231' this.dataDisabled = true
} else { this.updateSocialCreditCode = '20991231'
return this.adapayCorpMember.socialCreditCodeExpires = '' } else{
this.dataDisabled = false
} }
}, },
// 法人身份证有效期 当用户点击长期时出现的事件 // 法人身份证有效期 当用户点击长期时出现的事件
legalCertIdaChange(e){ legalCertIdaChange(e){
if(e===true){ if(e===true){
return this.dialogForm.legalCertIdExpires = '20991231' this.addLegalCertIdDate = '20991231'
this.addLegDisabled = true
} else { } else {
return this.dialogForm.legalCertIdExpires = '' this.addLegDisabled = false
} }
}, },
// 统一社会编码有效期 点击长期时出现的事件 // 统一社会编码有效期 点击长期时出现的事件
dataChange(e){ dataChange(e){
if(e===true){ if(e===true){
return this.dialogForm.socialCreditCodeExpires = '20991231' this.dataValue = '20991231'
this.dataDisabled = true
} else { } else {
return this.dialogForm.socialCreditCodeExpires = '' this.dataDisabled = false
} }
}, },
businessExceed(files) { businessExceed(files) {
@@ -821,6 +835,8 @@ export default {
this.uploadDisable = false this.uploadDisable = false
}, },
updateDialogForm(form){ updateDialogForm(form){
this.adapayCorpMember.legalCertIdExpires = this.updatelegalCertId
this.adapayCorpMember.socialCreditCodeExpires = this.updateSocialCreditCode
console.log(this.adapayCorpMember,'this.adapayCorpMember') console.log(this.adapayCorpMember,'this.adapayCorpMember')
this.adapayCorpMember.merchantId = this.merchantId this.adapayCorpMember.merchantId = this.merchantId
this.$refs[form].validate((valid) =>{ this.$refs[form].validate((valid) =>{
@@ -877,9 +893,11 @@ export default {
}, },
// 新建提交按钮 // 新建提交按钮
submitDialogForm(dialogForm){ submitDialogForm(dialogForm){
this.dialogForm.socialCreditCodeExpires = this.dataValue
this.dialogForm.legalCertIdExpires = this.addLegalCertIdDate
this.$refs[dialogForm].validate((valid) =>{ this.$refs[dialogForm].validate((valid) =>{
console.log(this.dialogForm,'this.dialogForm')
if (valid) { if (valid) {
console.log(this.dialogForm,'this.dialogForm')
console.log(valid,dialogForm) console.log(valid,dialogForm)
if (this.dialogForm.bankAcctType === '1') { if (this.dialogForm.bankAcctType === '1') {
if (!this.dialogForm.socialCreditCodeExpires) return this.$message.warning('请输入统一社会信用证有效期') if (!this.dialogForm.socialCreditCodeExpires) return this.$message.warning('请输入统一社会信用证有效期')
@@ -890,7 +908,7 @@ export default {
this.dialogForm.imgList = [this.idCardList[0].url,this.sideCardList[0].url,this.depositBankList[0].url,this.businessList[0].url] this.dialogForm.imgList = [this.idCardList[0].url,this.sideCardList[0].url,this.depositBankList[0].url,this.businessList[0].url]
} }
} }
// console.log('执行请求,创建成功') console.log('执行请求,创建成功')
createSettleAccount(this.dialogForm).then((response) =>{ createSettleAccount(this.dialogForm).then((response) =>{
console.log('新增',response); console.log('新增',response);
this.$message.success('新增成功,请勿重新提交') this.$message.success('新增成功,请勿重新提交')