Commit 30a6d8cd authored by frank.xa.zhang's avatar frank.xa.zhang

fixed shareholder structure -- frank

parent 943fbc69
...@@ -196,4 +196,10 @@ public class OrganizationHKController { ...@@ -196,4 +196,10 @@ public class OrganizationHKController {
return organizationHKService.deleteShareholder(id); return organizationHKService.deleteShareholder(id);
} }
@RequestMapping(value = "deleteDirector",method =RequestMethod.DELETE)
public @ResponseBody OperationResultDto deleteDirector(@RequestParam("id")Long id){
logger.info("GET /api/v1/orgHK/deleteDirector");
return organizationHKService.deleteDirector(id);
}
} }
...@@ -97,7 +97,7 @@ public class OrganizationHKServiceImpl { ...@@ -97,7 +97,7 @@ public class OrganizationHKServiceImpl {
public List<OrganizationHKDto> getOrgInfo() { public List<OrganizationHKDto> getOrgInfo() {
List<OrganizationHKDto> organizationHKDtos = new ArrayList<>(); List<OrganizationHKDto> organizationHKDtos = new ArrayList<>();
OrganizationHKExample organizationHKExample =new OrganizationHKExample(); OrganizationHKExample organizationHKExample = new OrganizationHKExample();
organizationHKExample.createCriteria().andIsActiveEqualTo(true); organizationHKExample.createCriteria().andIsActiveEqualTo(true);
List<OrganizationHK> organizationHKS = organizationHKMapper.selectByExample(organizationHKExample); List<OrganizationHK> organizationHKS = organizationHKMapper.selectByExample(organizationHKExample);
OrganizationShareholderExample organizationShareholderExample = new OrganizationShareholderExample(); OrganizationShareholderExample organizationShareholderExample = new OrganizationShareholderExample();
...@@ -304,7 +304,7 @@ public class OrganizationHKServiceImpl { ...@@ -304,7 +304,7 @@ public class OrganizationHKServiceImpl {
public OrganizationHKDto getSingleOrgByOrgId(Long orgId) { public OrganizationHKDto getSingleOrgByOrgId(Long orgId) {
OrganizationHK organizationHK = organizationHKMapper.selectByPrimaryKey(orgId); OrganizationHK organizationHK = organizationHKMapper.selectByPrimaryKey(orgId);
OrganizationHKDto result =organizationHKTMapper.toOrganizationHKDto(organizationHK); OrganizationHKDto result = organizationHKTMapper.toOrganizationHKDto(organizationHK);
Assert.notNull(result, "result is null"); Assert.notNull(result, "result is null");
result.setLevel(result.getLevel() == null ? 0 : result.getLevel()); result.setLevel(result.getLevel() == null ? 0 : result.getLevel());
result.setParentName(""); result.setParentName("");
...@@ -482,27 +482,24 @@ public class OrganizationHKServiceImpl { ...@@ -482,27 +482,24 @@ public class OrganizationHKServiceImpl {
public OperationResultDto<Object> updateDirectors(List<OrganizationDirectorDto> organizationDirectorDtos) { public OperationResultDto<Object> updateDirectors(List<OrganizationDirectorDto> organizationDirectorDtos) {
OperationResultDto<Object> resultDto = new OperationResultDto<>(); OperationResultDto<Object> resultDto = new OperationResultDto<>();
organizationDirectorDtos.forEach(a -> { organizationDirectorDtos.forEach(a -> {
OrganizationDirector organizationDirector; OrganizationDirector organizationDirector = organizationDirectorTMapper.toOrganizationDirector(a);
try { Date now = new Date();
organizationDirector = CommonUtils.copyProperties(a, new OrganizationDirector());
} catch (Exception ex) {
organizationDirector = new OrganizationDirector();
organizationDirector.setDirectorName(a.getDirectorName());
organizationDirector.setDateOfAppointment(new Date(a.getDateOfAppointment()));
organizationDirector.setDateOfResignation(new Date(a.getDateOfResignation()));
organizationDirector.setResidency(a.getResidency());
organizationDirector.setEntityId(Long.valueOf(a.getEntityId()));
}
if (organizationDirector.getId() != null) { if (organizationDirector.getId() != null) {
organizationDirectorMapper.deleteByPrimaryKey(organizationDirector.getId()); organizationDirector.setUpdateTime(now);
organizationDirectorMapper.updateByPrimaryKeySelective(organizationDirector);
} else {
organizationDirector.setId(distributedIdService.nextId());
organizationDirector.setCreateTime(now);
organizationDirector.setUpdateTime(now);
organizationDirectorMapper.insertSelective(organizationDirector);
} }
Date now = new Date();
organizationDirector.setId(distributedIdService.nextId());
organizationDirector.setCreateTime(now);
organizationDirector.setUpdateTime(now);
organizationDirectorMapper.insertSelective(organizationDirector);
}); });
OrganizationDirectorExample organizationDirectorExample = new OrganizationDirectorExample();
organizationDirectorExample.createCriteria().andEntityIdEqualTo(Long.valueOf(organizationDirectorDtos.get(0).getEntityId())).andIsDeleteEqualTo(false);
List<OrganizationDirector> organizationDirectors = organizationDirectorMapper.selectByExample(organizationDirectorExample);
List<OrganizationDirectorDto> organizationDirectorDtoList = organizationDirectors.stream().map(organizationDirectorTMapper::toOrganizationDirectorDto).collect(Collectors.toList());
resultDto.setResult(true); resultDto.setResult(true);
resultDto.setData(organizationDirectorDtoList);
return resultDto; return resultDto;
} }
...@@ -660,6 +657,7 @@ public class OrganizationHKServiceImpl { ...@@ -660,6 +657,7 @@ public class OrganizationHKServiceImpl {
orgShareholderTreeDataDto.setPercent(shareholderDto.getVotingPercentage()); orgShareholderTreeDataDto.setPercent(shareholderDto.getVotingPercentage());
// orgShareholderTreeDataDto.setPid(shareholderDtos.size() + 1); // orgShareholderTreeDataDto.setPid(shareholderDtos.size() + 1);
orgShareholderTreeDataDto.setSpids(Collections.emptyList()); orgShareholderTreeDataDto.setSpids(Collections.emptyList());
orgShareholderTreeDataDto.setIsMiddleNode(false);
orgShareholderTreeDataDtos.add(orgShareholderTreeDataDto); orgShareholderTreeDataDtos.add(orgShareholderTreeDataDto);
if (i > 1) { if (i > 1) {
parentIds.add(i); parentIds.add(i);
...@@ -668,6 +666,7 @@ public class OrganizationHKServiceImpl { ...@@ -668,6 +666,7 @@ public class OrganizationHKServiceImpl {
} }
//todo: add organization node //todo: add organization node
OrgShareholderTreeDataDto treeDataDto = new OrgShareholderTreeDataDto(); OrgShareholderTreeDataDto treeDataDto = new OrgShareholderTreeDataDto();
int middleNodeId = i;
treeDataDto.setId(i); treeDataDto.setId(i);
treeDataDto.setName(organizationHK.getName()); treeDataDto.setName(organizationHK.getName());
treeDataDto.setPercent(""); treeDataDto.setPercent("");
...@@ -676,16 +675,19 @@ public class OrganizationHKServiceImpl { ...@@ -676,16 +675,19 @@ public class OrganizationHKServiceImpl {
treeDataDto.setSpids(parentIds); treeDataDto.setSpids(parentIds);
} }
i++; i++;
treeDataDto.setIsMiddleNode(true);
orgShareholderTreeDataDtos.add(treeDataDto); orgShareholderTreeDataDtos.add(treeDataDto);
//todo: add subsidary nodes //todo: add subsidary nodes
for (SubsidaryDto subsidaryDto : subsidaryDtos) { for (SubsidaryDto subsidaryDto : subsidaryDtos) {
OrgShareholderTreeDataDto orgShareholderTreeDataDto = new OrgShareholderTreeDataDto(); OrgShareholderTreeDataDto orgShareholderTreeDataDto = new OrgShareholderTreeDataDto();
orgShareholderTreeDataDto.setId(i); orgShareholderTreeDataDto.setId(i);
orgShareholderTreeDataDto.setName(subsidaryDto.getEntityName()); orgShareholderTreeDataDto.setName(subsidaryDto.getEntityName());
orgShareholderTreeDataDto.setPercent(subsidaryDto.getVotingPercentage()); orgShareholderTreeDataDto.setPercent(subsidaryDto.getVotingPercentage());
orgShareholderTreeDataDto.setPid(0); orgShareholderTreeDataDto.setPid(middleNodeId);
orgShareholderTreeDataDto.setSpids(Collections.emptyList()); orgShareholderTreeDataDto.setSpids(Collections.emptyList());
orgShareholderTreeDataDto.setIsMiddleNode(false);
orgShareholderTreeDataDtos.add(orgShareholderTreeDataDto); orgShareholderTreeDataDtos.add(orgShareholderTreeDataDto);
i++; i++;
} }
...@@ -706,7 +708,7 @@ public class OrganizationHKServiceImpl { ...@@ -706,7 +708,7 @@ public class OrganizationHKServiceImpl {
} }
public OperationResultDto deleteShareholder(Long id) { public OperationResultDto deleteShareholder(Long id) {
OperationResultDto resultDto =new OperationResultDto(); OperationResultDto resultDto = new OperationResultDto();
OrganizationShareholder organizationShareholder = organizationShareholderMapper.selectByPrimaryKey(id); OrganizationShareholder organizationShareholder = organizationShareholderMapper.selectByPrimaryKey(id);
organizationShareholder.setIsDelete(true); organizationShareholder.setIsDelete(true);
organizationShareholder.setUpdateTime(new Date()); organizationShareholder.setUpdateTime(new Date());
...@@ -714,4 +716,14 @@ public class OrganizationHKServiceImpl { ...@@ -714,4 +716,14 @@ public class OrganizationHKServiceImpl {
resultDto.setResult(true); resultDto.setResult(true);
return resultDto; return resultDto;
} }
public OperationResultDto deleteDirector(Long id) {
OperationResultDto resultDto = new OperationResultDto();
OrganizationDirector organizationDirector = organizationDirectorMapper.selectByPrimaryKey(id);
organizationDirector.setIsDelete(true);
organizationDirector.setUpdateTime(new Date());
organizationDirectorMapper.updateByPrimaryKeySelective(organizationDirector);
resultDto.setResult(true);
return resultDto;
}
} }
...@@ -15,4 +15,5 @@ public class OrgShareholderTreeDataDto { ...@@ -15,4 +15,5 @@ public class OrgShareholderTreeDataDto {
String percent; String percent;
Integer pid; Integer pid;
List<Integer> spids; List<Integer> spids;
Boolean isMiddleNode;
} }
\ No newline at end of file
...@@ -16,7 +16,7 @@ public class OrganizationDirectorDto { ...@@ -16,7 +16,7 @@ public class OrganizationDirectorDto {
String residency; String residency;
String dateOfAppointment; String dateOfAppointment;
String dateOfResignation; String dateOfResignation;
String isExecutive; Integer isExecutive;
String otherRoles; Integer otherRoles;
String isDelete; String isDelete;
} }
package pwc.taxtech.atms.organization.mapper; package pwc.taxtech.atms.organization.mapper;
import org.mapstruct.Mapper; import org.mapstruct.Mapper;
import org.mapstruct.Mapping;
import org.mapstruct.factory.Mappers; import org.mapstruct.factory.Mappers;
import pwc.taxtech.atms.organization.dpo.OrgDirectorDto; import pwc.taxtech.atms.organization.dpo.OrgDirectorDto;
import pwc.taxtech.atms.organization.dpo.OrganizationDirectorDto; import pwc.taxtech.atms.organization.dpo.OrganizationDirectorDto;
...@@ -10,7 +11,13 @@ import pwc.taxtech.atms.organization.entity.OrganizationDirector; ...@@ -10,7 +11,13 @@ import pwc.taxtech.atms.organization.entity.OrganizationDirector;
public interface OrganizationDirectorTMapper { public interface OrganizationDirectorTMapper {
OrganizationDirectorTMapper ORGANIZATION_DIRECTOR_T_MAPPER = Mappers.getMapper(OrganizationDirectorTMapper.class); OrganizationDirectorTMapper ORGANIZATION_DIRECTOR_T_MAPPER = Mappers.getMapper(OrganizationDirectorTMapper.class);
@Mapping(source = "dateOfAppointment", target = "dateOfAppointment", dateFormat = "yyyy/MM/dd")
@Mapping(source = "dateOfResignation", target = "dateOfResignation", dateFormat = "yyyy/MM/dd")
OrganizationDirectorDto toOrganizationDirectorDto(OrganizationDirector organizationDirector); OrganizationDirectorDto toOrganizationDirectorDto(OrganizationDirector organizationDirector);
OrgDirectorDto toOrgDirectorDto(OrganizationDirector organizationDirector); OrgDirectorDto toOrgDirectorDto(OrganizationDirector organizationDirector);
@Mapping(source = "dateOfAppointment", target = "dateOfAppointment", dateFormat = "yyyy/MM/dd")
@Mapping(source = "dateOfResignation", target = "dateOfResignation", dateFormat = "yyyy/MM/dd")
OrganizationDirector toOrganizationDirector(OrganizationDirectorDto organizationDirectorDto);
} }
...@@ -16,16 +16,18 @@ commonModule.controller('editOrganizationDirectorModalController', ['$scope', '$ ...@@ -16,16 +16,18 @@ commonModule.controller('editOrganizationDirectorModalController', ['$scope', '$
}, },
close: function () { close: function () {
$scope.onClose(); $scope.onClose();
$scope.editModelD = {};
$scope.modalInstance.close(); $scope.modalInstance.close();
}, },
cancel: function () { cancel: function () {
$scope.onClose(); $scope.onClose();
$scope.editModelD = {};
$scope.modalInstance.cancel(); $scope.modalInstance.cancel();
}, },
save: function () { save: function () {
var dxResult = DevExpress.validationEngine.validateGroup($('#directorControlForm').dxValidationGroup("instance")).isValid; var dxResult = DevExpress.validationEngine.validateGroup($('#directorControlForm').dxValidationGroup("instance")).isValid;
if (dxResult) { if (dxResult) {
if (!$scope.editModelD.id) { if (!$scope.editModelD.id && $scope.parentPage !== ".system-manage") {
$scope.editModelD.id = PWC.newGuid(); $scope.editModelD.id = PWC.newGuid();
} }
$scope.onSave({directorEntity: $scope.editModelD}); $scope.onSave({directorEntity: $scope.editModelD});
...@@ -84,7 +86,7 @@ commonModule.controller('editOrganizationDirectorModalController', ['$scope', '$ ...@@ -84,7 +86,7 @@ commonModule.controller('editOrganizationDirectorModalController', ['$scope', '$
executiveOption: { executiveOption: {
bindingOptions: { bindingOptions: {
dataSource: 'dropdownDatasource.executiveTypeList', dataSource: 'dropdownDatasource.executiveTypeList',
value: 'editModelD.executive' value: 'editModelD.isExecutive'
}, },
onSelectionChanged: function (args) { onSelectionChanged: function (args) {
// $scope.editModel.executive = args.selectedItem.id; // $scope.editModel.executive = args.selectedItem.id;
......
...@@ -62,11 +62,14 @@ webservices.factory('orgHKService', ['$http', 'apiConfig', function ($http, apiC ...@@ -62,11 +62,14 @@ webservices.factory('orgHKService', ['$http', 'apiConfig', function ($http, apiC
getOrgList: function (type) { getOrgList: function (type) {
return $http.get('/org/display?useType=' + type, apiConfig.create()); return $http.get('/org/display?useType=' + type, apiConfig.create());
}, },
getOrgsListInfo:function () { getOrgsListInfo: function () {
return $http.get('/orgHK/getOrgsListInfo', apiConfig.create()); return $http.get('/orgHK/getOrgsListInfo', apiConfig.create());
}, },
deleteShareholder:function (id) { deleteShareholder: function (id) {
return $http.delete('/orgHK/deleteShareholder?id='+id,apiConfig.create()); return $http.delete('/orgHK/deleteShareholder?id=' + id, apiConfig.create());
},
deleteDirector: function (id) {
return $http.delete('/orgHK/deleteDirector?id=' + id, apiConfig.create());
} }
} }
}]); }]);
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment