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 {
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) {
organizationDirectorMapper.deleteByPrimaryKey(organizationDirector.getId());
}
Date now = new Date(); Date now = new Date();
if (organizationDirector.getId() != null) {
organizationDirector.setUpdateTime(now);
organizationDirectorMapper.updateByPrimaryKeySelective(organizationDirector);
} else {
organizationDirector.setId(distributedIdService.nextId()); organizationDirector.setId(distributedIdService.nextId());
organizationDirector.setCreateTime(now); organizationDirector.setCreateTime(now);
organizationDirector.setUpdateTime(now); organizationDirector.setUpdateTime(now);
organizationDirectorMapper.insertSelective(organizationDirector); 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);
} }
...@@ -619,7 +619,7 @@ ...@@ -619,7 +619,7 @@
showRowLines: true, showRowLines: true,
allowColumnReordering: true, allowColumnReordering: true,
showColumnLines: true, showColumnLines: true,
rowAlternationEnabled: true, //单双行颜色 // rowAlternationEnabled: true, //单双行颜色
noDataText: $translate.instant('NoDataText'), noDataText: $translate.instant('NoDataText'),
selectAllText: $translate.instant('SelectAll'), selectAllText: $translate.instant('SelectAll'),
searchPanel: { searchPanel: {
...@@ -805,24 +805,44 @@ ...@@ -805,24 +805,44 @@
allowHeaderFiltering: false, allowHeaderFiltering: false,
caption: $translate.instant('dateOfAppointment'), caption: $translate.instant('dateOfAppointment'),
dataType: "date", dataType: "date",
format: "yyyy-MM-dd" format: "yyyy/MM/dd"
}, },
{ {
dataField: "dateOfResignation", dataField: "dateOfResignation",
allowHeaderFiltering: false, allowHeaderFiltering: false,
caption: $translate.instant('dateOfResignation'), caption: $translate.instant('dateOfResignation'),
dataType: "date", dataType: "date",
format: "yyyy-MM-dd" format: "yyyy/MM/dd"
}, },
{ {
dataField: "executive", dataField: "isExecutive",
allowHeaderFiltering: false, allowHeaderFiltering: false,
caption: $translate.instant('executive'), caption: $translate.instant('executive'),
calculateDisplayValue: function (data) {
var importType1 = _.find(constant.organizationHK.executiveType, function (item) {
return item.id === data.isExecutive;
});
if (importType1) {
return importType1.name;
} else {
return '未知';
}
}
}, },
{ {
dataField: "otherRoles", dataField: "otherRoles",
allowHeaderFiltering: false, allowHeaderFiltering: false,
caption: $translate.instant('otherRoles'), caption: $translate.instant('otherRoles'),
calculateDisplayValue: function (data) {
var importType1 = _.find(constant.organizationHK.OtherRoles, function (item) {
return item.id === data.otherRoles;
});
if (importType1) {
return importType1.name;
} else {
return '未知';
}
}
}, },
{ {
dataField: "id", dataField: "id",
...@@ -857,7 +877,7 @@ ...@@ -857,7 +877,7 @@
showRowLines: true, showRowLines: true,
allowColumnReordering: true, allowColumnReordering: true,
showColumnLines: true, showColumnLines: true,
rowAlternationEnabled: true, //单双行颜色 // rowAlternationEnabled: true, //单双行颜色
noDataText: $translate.instant('NoDataText'), noDataText: $translate.instant('NoDataText'),
selectAllText: $translate.instant('SelectAll'), selectAllText: $translate.instant('SelectAll'),
searchPanel: { searchPanel: {
...@@ -892,7 +912,7 @@ ...@@ -892,7 +912,7 @@
pageSize: constant.page.logPageSize pageSize: constant.page.logPageSize
}, },
pager: { pager: {
showPageSizeSelector: true, showPageSizeSelector: false,
allowedPageSizes: constant.page.pageSizeArrary, allowedPageSizes: constant.page.pageSizeArrary,
showInfo: true showInfo: true
}, },
...@@ -1004,7 +1024,7 @@ ...@@ -1004,7 +1024,7 @@
showRowLines: true, showRowLines: true,
allowColumnReordering: true, allowColumnReordering: true,
showColumnLines: true, showColumnLines: true,
rowAlternationEnabled: true, //单双行颜色 // rowAlternationEnabled: true, //单双行颜色
noDataText: $translate.instant('NoDataText'), noDataText: $translate.instant('NoDataText'),
selectAllText: $translate.instant('SelectAll'), selectAllText: $translate.instant('SelectAll'),
searchPanel: { searchPanel: {
...@@ -1077,15 +1097,15 @@ ...@@ -1077,15 +1097,15 @@
}; };
$scope.saveDirector2 = function (directorEntity) { $scope.saveDirector2 = function (directorEntity) {
var director = _.find($scope.directorDatasource, function (item) { directorEntity.entityId = $scope.selectCompany.id;
return item.id === directorEntity.id; var directors = [];
}); directors.concat($scope.directorDatasource);
directors.push(directorEntity);
if (director) { orgHKService.updateDirectors(directors).success(function (res) {
$scope.directorDatasource = _.without($scope.directorDatasource, director); if (res && res.result) {
$scope.directorDatasource = res.data;
} }
$scope.directorDatasource.push(directorEntity); });
orgHKService.updateDirectors($scope.directorDatasource);
}; };
window.editDirector2 = function (id) { window.editDirector2 = function (id) {
...@@ -1105,9 +1125,10 @@ ...@@ -1105,9 +1125,10 @@
var director = _.find($scope.directorDatasource, function (item) { var director = _.find($scope.directorDatasource, function (item) {
return item.id === id; return item.id === id;
}); });
if (director > 0) { if (director) {
$scope.directorDatasource = _.without($scope.directorDatasource, director); $scope.directorDatasource = _.without($scope.directorDatasource, director);
} }
orgHKService.deleteDirector(id);
}; };
$scope.attachmentGridOptions = { $scope.attachmentGridOptions = {
...@@ -1165,7 +1186,7 @@ ...@@ -1165,7 +1186,7 @@
showRowLines: true, showRowLines: true,
allowColumnReordering: true, allowColumnReordering: true,
showColumnLines: true, showColumnLines: true,
rowAlternationEnabled: true, //单双行颜色 // rowAlternationEnabled: true, //单双行颜色
noDataText: $translate.instant('NoDataText'), noDataText: $translate.instant('NoDataText'),
selectAllText: $translate.instant('SelectAll'), selectAllText: $translate.instant('SelectAll'),
searchPanel: { searchPanel: {
...@@ -1243,7 +1264,7 @@ ...@@ -1243,7 +1264,7 @@
keyExpr: "shareholderName", keyExpr: "shareholderName",
columns: [ columns: [
{ {
dataField: "shareholderName", dataField: "entityName",
allowHeaderFiltering: false, allowHeaderFiltering: false,
caption: $translate.instant('shareholderName') caption: $translate.instant('shareholderName')
}, },
...@@ -1261,7 +1282,7 @@ ...@@ -1261,7 +1282,7 @@
showRowLines: true, showRowLines: true,
allowColumnReordering: true, allowColumnReordering: true,
showColumnLines: true, showColumnLines: true,
rowAlternationEnabled: true, //单双行颜色 // rowAlternationEnabled: true, //单双行颜色
noDataText: $translate.instant('NoDataText'), noDataText: $translate.instant('NoDataText'),
selectAllText: $translate.instant('SelectAll') selectAllText: $translate.instant('SelectAll')
}; };
...@@ -1275,7 +1296,7 @@ ...@@ -1275,7 +1296,7 @@
keyExpr: "subsidaryName", keyExpr: "subsidaryName",
columns: [ columns: [
{ {
dataField: "subsidaryName", dataField: "entityName",
allowHeaderFiltering: false, allowHeaderFiltering: false,
caption: $translate.instant('subsidaryName') caption: $translate.instant('subsidaryName')
}, },
...@@ -1293,7 +1314,7 @@ ...@@ -1293,7 +1314,7 @@
showRowLines: true, showRowLines: true,
allowColumnReordering: true, allowColumnReordering: true,
showColumnLines: true, showColumnLines: true,
rowAlternationEnabled: true, //单双行颜色 // rowAlternationEnabled: true, //单双行颜色
noDataText: $translate.instant('NoDataText'), noDataText: $translate.instant('NoDataText'),
selectAllText: $translate.instant('SelectAll') selectAllText: $translate.instant('SelectAll')
}; };
...@@ -1325,7 +1346,7 @@ ...@@ -1325,7 +1346,7 @@
showRowLines: true, showRowLines: true,
allowColumnReordering: true, allowColumnReordering: true,
showColumnLines: true, showColumnLines: true,
rowAlternationEnabled: true, //单双行颜色 // rowAlternationEnabled: true, //单双行颜色
noDataText: $translate.instant('NoDataText'), noDataText: $translate.instant('NoDataText'),
selectAllText: $translate.instant('SelectAll') selectAllText: $translate.instant('SelectAll')
}; };
...@@ -1469,32 +1490,22 @@ ...@@ -1469,32 +1490,22 @@
$scope.chart = new OrgChart(document.getElementById("tree"), { $scope.chart = new OrgChart(document.getElementById("tree"), {
template: "myTemplate", template: "myTemplate",
enableSearch: false, enableSearch: false,
// nodeMenu: {
// add: {text: "Add"},
// edit: {text: "Edit"},
// remove: {text: "Remove"}
// },
menu: { menu: {
// pdf: {text: "Export PDF"},
png: {text: "Export PNG"} png: {text: "Export PNG"}
// svg: {text: "Export SVG"},
// csv: {text: "Export CSV"}
}, },
linkBinding: { linkBinding: {
link_field_0: "percent" link_field_0: "percent"
}, },
nodeBinding: { nodeBinding: {
field_0: "name" field_0: "name"
// field_1: "title",
// img_0: "img"
}, },
// nodes: [ // nodes: [
// {id: 1, name: "Shareholder1", percent: "100%",spids:[]}, // {id: 1, name: "Shareholder1", percent: "100%", spids: []},
// {id: 2, name: "Shareholder2", percent: "100%"}, // {id: 2, name: "Shareholder2", percent: "100%"},
// {id: 3, name: "Shareholder3", percent: "100%"}, // {id: 3, name: "Shareholder3", percent: "100%"},
// {id: 4, pid: 1, spids: [2, 3], name: "Comapny", percent: ""}, // {id: 4, pid: 1, spids: [2, 3], name: "Comapny", percent: ""},
// {id: 5, pid: 4, name: "Subsidary1", percent: "100%"}, // {id: 5, pid: 4, name: "Subsidary1", percent: "100%"},
// // {id: 6, pid: 4, name: "Subsidary2", percent: "100%"} // {id: 6, pid: 4, name: "Subsidary2", percent: "100%"}
// ], // ],
nodes: nodesCotent, nodes: nodesCotent,
onExportStart: exportStart, onExportStart: exportStart,
...@@ -1511,35 +1522,54 @@ ...@@ -1511,35 +1522,54 @@
//第一次在加载时的元素 //第一次在加载时的元素
initialized = true; initialized = true;
} }
// nodesCotentValue = [
// {id: 1, name: "Shareholder1", percent: "100%", spids: []},
// {id: 2, name: "Shareholder2", percent: "100%"},
// {id: 3, name: "Shareholder3", percent: "100%"},
// {id: 4, pid: 1, spids: [2, 3], name: "Comapny", percent: ""},
// {id: 5, pid: 4, name: "Subsidary1", percent: "100%"},
// {id: 6, pid: 4, name: "Subsidary2", percent: "100%"}
// ];
// middleNode = {id: 4, pid: 1, spids: [2, 3], name: "Comapny", percent: "100%"}; // middleNode = {id: 4, pid: 1, spids: [2, 3], name: "Comapny", percent: "100%"};
if (middleNode && middleNode.id > 0) { if (middleNode && middleNode.id > 0) {
//check if there are more than 1 sub node,need change x coordinate
var subNodes = _.filter(nodesCotentValue, function (item) {
return item.id > middleNode.id;
});
var beforeNodes = _.filter(nodesCotentValue, function (item) {
return item.id < middleNode.id;
});
var haveMoreThanOneNode = false;
if (subNodes.length > 1) {
haveMoreThanOneNode = true;
}
var y = beforeNodes.length > 0 && subNodes.length > 0 ? 346 : 166;
for (var iii = 0; iii < subNodes.length; iii++) {
var value = 80 + 220 * iii;
var nodeSelector = "svg>g[link-id='[" + middleNode.id + "][" + subNodes[iii].id + "]']";
$(nodeSelector + ">g").attr("transform", "matrix(1,0,0,1," + value + "," + y + ") rotate(0)");
$(nodeSelector + ">g>text").text(subNodes[iii].percent + "%");
}
var middleNodeSelector = "svg>g[node-id=" + middleNode.id + "]>rect"; var middleNodeSelector = "svg>g[node-id=" + middleNode.id + "]>rect";
var polygon = makeSVG('polygon', {"points": '100,0 0,100 200,100', style: "fill:#ffff;stroke:#000;stroke-width:1", height: 115, width: 250}); var polygon = makeSVG('polygon', {"points": '100,0 0,100 200,100', style: "fill:#ffff;stroke:#000;stroke-width:1", height: 115, width: 250});
$(middleNodeSelector).css("fill", "transparent").css("stroke-width", 0).after(polygon); $(middleNodeSelector).css("fill", "transparent").css("stroke-width", 0).after(polygon);
var node = _.find(nodesCotentValue, function (item) { var node = _.find(nodesCotentValue, function (item) {
return item.id === 1; return item.id === 1;
}); });
var linkSelector = "svg>g[link-id='[1][" + middleNode.id + "]']"; var linkSelector = "svg>g[link-id='[1][" + middleNode.id + "]']";
$(linkSelector + ">g").attr("transform", "matrix(1,0,0,1,80,166) rotate(0)"); var linkXValue = 80;
// var linkRateG = makeSVG('g', {"transform": "matrix(1,0,0,1,100,166) rotate(0)"}); if (haveMoreThanOneNode) {
// $(linkSelector + ">path").after(linkRateG); linkXValue = linkXValue + 110;
}
$(linkSelector + ">g").attr("transform", "matrix(1,0,0,1," + linkXValue + ",166) rotate(0)");
var linkSelectorG = linkSelector + ">g"; var linkSelectorG = linkSelector + ">g";
// var linkRateText = makeSVG('text', {"text-anchor": "middle", "fill": "#aeaeae", "width": "290", "x": "0", "y": "0", "style": "font-size:10px"});
// $(linkSelectorG).append(linkRateText);
var linkSelectorGText = linkSelectorG + ">text"; var linkSelectorGText = linkSelectorG + ">text";
$(linkSelectorGText).text(node.percent + "%"); $(linkSelectorGText).text(node.percent + "%");
// var ellipse = makeSVG('ellipse', {"cx": '100', "cy": "50", "rx": "100", "ry": "50", style: "fill:blue;stroke:purple;stroke-width:2", height: 115, width: 250});
// var ellipse1 = makeSVG('ellipse', {"cx": '100', "cy": "50", "rx": "100", "ry": "50", style: "fill:blue;stroke:purple;stroke-width:2", height: 115, width: 250});
// var ellipse2 = makeSVG('ellipse', {"cx": '100', "cy": "50", "rx": "100", "ry": "50", style: "fill:blue;stroke:purple;stroke-width:2", height: 115, width: 250});
// $("svg>g[node-id=4]>rect").after(polygon);
// $("svg>g[node-id=4]>rect").after(ellipse);
// $("svg>g[node-id=5]>rect").after(ellipse1);
// $("svg>g[node-id=6]>rect").after(ellipse2);
// $("svg>g[node-id=5]").attr("transform","matrix(1, 0, 0, 1, 360, 0)");
// $("svg>g[node-id=6]").attr("transform","matrix(1, 0, 0, 1, 590, 0)");
if (middleNode.id > 2) { if (middleNode.id > 2) {
var count = 0; var count = 0;
for (var i = 2; i < middleNode.id; i++) { for (var i = 2; i < middleNode.id; i++) {
...@@ -1547,9 +1577,17 @@ ...@@ -1547,9 +1577,17 @@
return item.id === i; return item.id === i;
}); });
var nodeSelector = "svg>g[second-link-id='[" + middleNode.id + "][" + i + "]']"; var nodeSelector = "svg>g[second-link-id='[" + middleNode.id + "][" + i + "]']";
var value = 320 + 220 * count; var value = 0;
var value2 = 0;
if (haveMoreThanOneNode) {
value = 320 + 110 + 220 * count;
value2 = 100 + 110;
} else {
value = 320 + 220 * count;
value2 = 100;
}
$(nodeSelector + ">path").attr("stroke", "#000"); $(nodeSelector + ">path").attr("stroke", "#000");
$(nodeSelector + ">path").attr("d", "M100,180 L100,160 L" + value + ",160 L" + value + ",102"); $(nodeSelector + ">path").attr("d", "M" + value2 + ",180 L" + value2 + ",160 L" + value + ",160 L" + value + ",102");
count++; count++;
var val2 = value - 20; var val2 = value - 20;
var rateG = makeSVG('g', {"transform": "matrix(1,0,0,1," + val2 + ",128) rotate(0)"}); var rateG = makeSVG('g', {"transform": "matrix(1,0,0,1," + val2 + ",128) rotate(0)"});
...@@ -1562,11 +1600,6 @@ ...@@ -1562,11 +1600,6 @@
} }
} }
} }
// $("svg>g[second-link-id='[4][2]']>path").attr("d", "M210,180 L210,160 L440,160 L440,102");
// $("svg>g[second-link-id='[4][3]']>path").attr("d", "M210,180 L210,160 L660,160 L660,102");
// d: path(" M240 180 L240 160 L680 160 L680 120");
// M100,180 L100,160 L320,160 L320,102
// M100,180 L100,160 L540,160 L540,102
}; };
var makeSVG = function (tag, attrs) { var makeSVG = function (tag, attrs) {
...@@ -1599,17 +1632,9 @@ ...@@ -1599,17 +1632,9 @@
var initOrgChart = function (orgId) { var initOrgChart = function (orgId) {
orgHKService.getOrgTreeData(orgId).success(function (res) { orgHKService.getOrgTreeData(orgId).success(function (res) {
if (res && res.result) { if (res && res.result) {
if (res.data.length < 3) {
if (res.data.length === 1) {
middleNode = res.data[0];
} else {
middleNode = res.data[1];
}
} else {
middleNode = _.find(res.data, function (node) { middleNode = _.find(res.data, function (node) {
return node.spids && node.spids.length > 0; return node.isMiddleNode;
}); });
}
initOrgTree(res.data); initOrgTree(res.data);
nodesCotentValue = res.data; nodesCotentValue = res.data;
} }
...@@ -1620,7 +1645,6 @@ ...@@ -1620,7 +1645,6 @@
$scope.showPage4 = function () { $scope.showPage4 = function () {
showPage4 = true; showPage4 = true;
//todo:get node content @ here
initOrgChart($scope.selectCompany.id); initOrgChart($scope.selectCompany.id);
}; };
......
...@@ -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