Merge branch 'feature_enhance_interface' of https://github.com/alibaba/nacos into feature_enhance_interface
This commit is contained in:
commit
5e7be63343
@ -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 = ".*";
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -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',
|
||||||
|
@ -96,7 +96,8 @@ const I18N_CONF = {
|
|||||||
query: '查询',
|
query: '查询',
|
||||||
pubNoData: '没有数据',
|
pubNoData: '没有数据',
|
||||||
columnServiceName: '服务名',
|
columnServiceName: '服务名',
|
||||||
groupName: '分组',
|
groupName: '分组名称',
|
||||||
|
groupNamePlaceholder: '请输入分组名称',
|
||||||
columnClusterCount: '集群数目',
|
columnClusterCount: '集群数目',
|
||||||
columnIpCount: '实例数',
|
columnIpCount: '实例数',
|
||||||
columnHealthyInstanceCount: '健康实例数',
|
columnHealthyInstanceCount: '健康实例数',
|
||||||
|
@ -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())
|
||||||
}
|
}
|
||||||
|
@ -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());
|
||||||
|
@ -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));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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());
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user