Merge branch 'feature_enhance_interface' of https://github.com/alibaba/nacos into feature_enhance_interface

This commit is contained in:
pbting 2019-09-06 12:19:53 +08:00
commit 5e7be63343
7 changed files with 48 additions and 16 deletions

View File

@ -163,4 +163,6 @@ public class Constants {
public static final String NUMBER_PATTERN = "^\\d+$"; public static final String NUMBER_PATTERN = "^\\d+$";
public static final String ANY_PATTERN = ".*";
} }

View File

@ -97,6 +97,7 @@ const I18N_CONF = {
pubNoData: 'No results found.', pubNoData: 'No results found.',
columnServiceName: 'Service Name', columnServiceName: 'Service Name',
groupName: 'Group Name', groupName: 'Group Name',
groupNamePlaceholder: 'Enter Group Name',
columnClusterCount: 'Cluster Count', columnClusterCount: 'Cluster Count',
columnIpCount: 'Instance Count', columnIpCount: 'Instance Count',
columnHealthyInstanceCount: 'Healthy Instance Count', columnHealthyInstanceCount: 'Healthy Instance Count',

View File

@ -96,7 +96,8 @@ const I18N_CONF = {
query: '查询', query: '查询',
pubNoData: '没有数据', pubNoData: '没有数据',
columnServiceName: '服务名', columnServiceName: '服务名',
groupName: '分组', groupName: '分组名称',
groupNamePlaceholder: '请输入分组名称',
columnClusterCount: '集群数目', columnClusterCount: '集群数目',
columnIpCount: '实例数', columnIpCount: '实例数',
columnHealthyInstanceCount: '健康实例数', columnHealthyInstanceCount: '健康实例数',

View File

@ -56,8 +56,11 @@ class ServiceList extends React.Component {
total: 0, total: 0,
pageSize: 10, pageSize: 10,
currentPage: 1, currentPage: 1,
keyword: '',
dataSource: [], dataSource: [],
search: {
serviceName: '',
groupName: '',
},
hasIpCount: !(localStorage.getItem('hasIpCount') === 'false'), hasIpCount: !(localStorage.getItem('hasIpCount') === 'false'),
}; };
this.field = new Field(this); this.field = new Field(this);
@ -78,13 +81,14 @@ class ServiceList extends React.Component {
} }
queryServiceList() { queryServiceList() {
const { currentPage, pageSize, keyword, withInstances = false, hasIpCount } = this.state; const { currentPage, pageSize, search, withInstances = false, hasIpCount } = this.state;
const parameter = [ const parameter = [
`hasIpCount=${hasIpCount}`, `hasIpCount=${hasIpCount}`,
`withInstances=${withInstances}`, `withInstances=${withInstances}`,
`pageNo=${currentPage}`, `pageNo=${currentPage}`,
`pageSize=${pageSize}`, `pageSize=${pageSize}`,
`keyword=${keyword}`, `serviceNameParam=${search.serviceName}`,
`groupNameParam=${search.groupName}`,
]; ];
request({ request({
url: `v1/ns/catalog/services?${parameter.join('&')}`, url: `v1/ns/catalog/services?${parameter.join('&')}`,
@ -164,6 +168,8 @@ class ServiceList extends React.Component {
serviceList, serviceList,
serviceName, serviceName,
serviceNamePlaceholder, serviceNamePlaceholder,
groupName,
groupNamePlaceholder,
hiddenEmptyService, hiddenEmptyService,
query, query,
create, create,
@ -172,7 +178,7 @@ class ServiceList extends React.Component {
sampleCode, sampleCode,
deleteAction, deleteAction,
} = locale; } = locale;
const { keyword, nowNamespaceName, nowNamespaceId, hasIpCount } = this.state; const { search, nowNamespaceName, nowNamespaceId, hasIpCount } = this.state;
const { init, getValue } = this.field; const { init, getValue } = this.field;
this.init = init; this.init = init;
this.getValue = getValue; this.getValue = getValue;
@ -214,8 +220,19 @@ class ServiceList extends React.Component {
<Input <Input
placeholder={serviceNamePlaceholder} placeholder={serviceNamePlaceholder}
style={{ width: 200 }} style={{ width: 200 }}
value={keyword} value={search.serviceName}
onChange={keyword => this.setState({ keyword })} onChange={serviceName => this.setState({ search: { ...search, serviceName } })}
onPressEnter={() =>
this.setState({ currentPage: 1 }, () => this.queryServiceList())
}
/>
</FormItem>
<FormItem label={groupName}>
<Input
placeholder={groupNamePlaceholder}
style={{ width: 200 }}
value={search.groupName}
onChange={groupName => this.setState({ search: { ...search, groupName } })}
onPressEnter={() => onPressEnter={() =>
this.setState({ currentPage: 1 }, () => this.queryServiceList()) this.setState({ currentPage: 1 }, () => this.queryServiceList())
} }

View File

@ -150,10 +150,13 @@ public class CatalogController {
List<ServiceDetailInfo> serviceDetailInfoList = new ArrayList<>(); List<ServiceDetailInfo> serviceDetailInfoList = new ArrayList<>();
int pageNo = Integer.parseInt(WebUtils.required(request, "pageNo")); int pageNo = Integer.parseInt(WebUtils.required(request, "pageNo"));
int pageSize = Integer.parseInt(WebUtils.required(request, "pageSize")); int pageSize = Integer.parseInt(WebUtils.required(request, "pageSize"));
String keyword = WebUtils.optional(request, "keyword", StringUtils.EMPTY); String serviceName = WebUtils.optional(request, "serviceNameParam", StringUtils.EMPTY);
String groupName = WebUtils.optional(request, "groupNameParam", StringUtils.EMPTY);
String param = StringUtils.isBlank(serviceName) && StringUtils.isBlank(groupName) ?
StringUtils.EMPTY : NamingUtils.getGroupedName(serviceName, groupName);
List<Service> serviceList = new ArrayList<>(8); List<Service> serviceList = new ArrayList<>(8);
serviceManager.getPagedService(namespaceId, pageNo, pageSize, keyword, StringUtils.EMPTY, serviceList, false); serviceManager.getPagedService(namespaceId, pageNo, pageSize, param, StringUtils.EMPTY, serviceList, false);
for (Service service : serviceList) { for (Service service : serviceList) {
ServiceDetailInfo serviceDetailInfo = new ServiceDetailInfo(); ServiceDetailInfo serviceDetailInfo = new ServiceDetailInfo();
@ -257,12 +260,16 @@ public class CatalogController {
int page = Integer.parseInt(WebUtils.required(request, "pageNo")); int page = Integer.parseInt(WebUtils.required(request, "pageNo"));
int pageSize = Integer.parseInt(WebUtils.required(request, "pageSize")); int pageSize = Integer.parseInt(WebUtils.required(request, "pageSize"));
String keyword = WebUtils.optional(request, "keyword", StringUtils.EMPTY); String serviceName = WebUtils.optional(request, "serviceNameParam", StringUtils.EMPTY);
String groupName = WebUtils.optional(request, "groupNameParam", StringUtils.EMPTY);
String param = StringUtils.isBlank(serviceName) && StringUtils.isBlank(groupName) ?
StringUtils.EMPTY : NamingUtils.getGroupedName(serviceName, groupName);
String containedInstance = WebUtils.optional(request, "instance", StringUtils.EMPTY); String containedInstance = WebUtils.optional(request, "instance", StringUtils.EMPTY);
boolean hasIpCount = Boolean.parseBoolean(WebUtils.optional(request, "hasIpCount", "false")); boolean hasIpCount = Boolean.parseBoolean(WebUtils.optional(request, "hasIpCount", "false"));
List<Service> services = new ArrayList<>(); List<Service> services = new ArrayList<>();
int total = serviceManager.getPagedService(namespaceId, page - 1, pageSize, keyword, containedInstance, services, hasIpCount); int total = serviceManager.getPagedService(namespaceId, page - 1, pageSize, param, containedInstance, services, hasIpCount);
if (CollectionUtils.isEmpty(services)) { if (CollectionUtils.isEmpty(services)) {
result.put("serviceList", Collections.emptyList()); result.put("serviceList", Collections.emptyList());

View File

@ -269,10 +269,10 @@ public class ServiceController {
Map<String, List<Service>> services = new HashMap<>(16); Map<String, List<Service>> services = new HashMap<>(16);
if (StringUtils.isNotBlank(namespaceId)) { if (StringUtils.isNotBlank(namespaceId)) {
services.put(namespaceId, serviceManager.searchServices(namespaceId, ".*" + expr + ".*")); services.put(namespaceId, serviceManager.searchServices(namespaceId, Constants.ANY_PATTERN + expr + Constants.ANY_PATTERN));
} else { } else {
for (String namespace : serviceManager.getAllNamespaces()) { for (String namespace : serviceManager.getAllNamespaces()) {
services.put(namespace, serviceManager.searchServices(namespace, ".*" + expr + ".*")); services.put(namespace, serviceManager.searchServices(namespace, Constants.ANY_PATTERN + expr + Constants.ANY_PATTERN));
} }
} }

View File

@ -674,7 +674,7 @@ public class ServiceManager implements RecordListener<Service> {
return serviceMap.get(namespaceId); return serviceMap.get(namespaceId);
} }
public int getPagedService(String namespaceId, int startPage, int pageSize, String keyword, String containedInstance, List<Service> serviceList, boolean hasIpCount) { public int getPagedService(String namespaceId, int startPage, int pageSize, String param, String containedInstance, List<Service> serviceList, boolean hasIpCount) {
List<Service> matchList; List<Service> matchList;
@ -682,8 +682,12 @@ public class ServiceManager implements RecordListener<Service> {
return 0; return 0;
} }
if (StringUtils.isNotBlank(keyword)) { if (StringUtils.isNotBlank(param)) {
matchList = searchServices(namespaceId, ".*" + keyword + ".*"); StringJoiner regex = new StringJoiner(Constants.SERVICE_INFO_SPLITER);
for (String s : param.split(Constants.SERVICE_INFO_SPLITER)) {
regex.add(StringUtils.isBlank(s) ? Constants.ANY_PATTERN : Constants.ANY_PATTERN + s + Constants.ANY_PATTERN);
}
matchList = searchServices(namespaceId, regex.toString());
} else { } else {
matchList = new ArrayList<>(chooseServiceMap(namespaceId).values()); matchList = new ArrayList<>(chooseServiceMap(namespaceId).values());
} }