瀏覽代碼

Add search option for keymatch

Ryo Kuramoto 5 年之前
父節點
當前提交
c512fcacfb

+ 6 - 2
src/main/java/org/codelibs/fess/app/service/KeyMatchService.java

@@ -20,6 +20,7 @@ import java.util.List;
 import javax.annotation.Resource;
 
 import org.codelibs.core.beans.util.BeanUtil;
+import org.codelibs.core.lang.StringUtil;
 import org.codelibs.fess.Constants;
 import org.codelibs.fess.app.pager.KeyMatchPager;
 import org.codelibs.fess.es.config.cbean.KeyMatchCB;
@@ -74,8 +75,11 @@ public class KeyMatchService {
     }
 
     protected void setupListCondition(final KeyMatchCB cb, final KeyMatchPager keyMatchPager) {
-        if (keyMatchPager.id != null) {
-            cb.query().docMeta().setId_Equal(keyMatchPager.id);
+        if (StringUtil.isNotBlank(keyMatchPager.term)) {
+            cb.query().setTerm_Wildcard(keyMatchPager.term);
+        }
+        if (StringUtil.isNotBlank(keyMatchPager.query)) {
+            cb.query().setQuery_Wildcard(keyMatchPager.query);
         }
         // TODO Long, Integer, String supported only.
 

+ 2 - 2
src/main/java/org/codelibs/fess/app/web/admin/keymatch/AdminKeymatchAction.java

@@ -103,7 +103,7 @@ public class AdminKeymatchAction extends FessAdminAction {
         RenderDataUtil.register(data, "keyMatchItems", keyMatchService.getKeyMatchList(keyMatchPager)); // page navi
 
         // restore from pager
-        copyBeanToBean(keyMatchPager, form, op -> op.include("id"));
+        copyBeanToBean(keyMatchPager, form, op -> op.include("term", "query"));
     }
 
     // ===================================================================================
@@ -293,7 +293,7 @@ public class AdminKeymatchAction extends FessAdminAction {
             RenderDataUtil.register(data, "keyMatchItems", keyMatchService.getKeyMatchList(keyMatchPager)); // page navi
             }).useForm(SearchForm.class, setup -> {
             setup.setup(form -> {
-                copyBeanToBean(keyMatchPager, form, op -> op.include("id"));
+                copyBeanToBean(keyMatchPager, form, op -> op.include("term", "query"));
             });
         });
     }

+ 4 - 1
src/main/java/org/codelibs/fess/app/web/admin/keymatch/SearchForm.java

@@ -21,5 +21,8 @@ package org.codelibs.fess.app.web.admin.keymatch;
  */
 public class SearchForm {
 
-    public String id;
+    public String term;
+
+    public String query;
+
 }

+ 4 - 1
src/main/java/org/codelibs/fess/app/web/api/admin/keymatch/SearchBody.java

@@ -18,6 +18,9 @@ package org.codelibs.fess.app.web.api.admin.keymatch;
 import org.codelibs.fess.app.web.api.admin.BaseSearchBody;
 
 public class SearchBody extends BaseSearchBody {
-    public String id;
+
+    public String term;
+
+    public String query;
 
 }

+ 31 - 0
src/main/webapp/WEB-INF/view/admin/keymatch/admin_keymatch.jsp

@@ -36,6 +36,37 @@
 									</la:info>
 									<la:errors />
 								</div>
+								<la:form action="/admin/keymatch/"
+										 styleClass="form-horizontal">
+									<div class="form-group">
+										<label for="term" class="col-sm-2 control-label"><la:message
+												key="labels.key_match_term" /></label>
+										<div class="col-sm-10">
+											<la:text styleId="term" property="term" styleClass="form-control" />
+										</div>
+									</div>
+									<div class="form-group">
+										<label for="query" class="col-sm-2 control-label"><la:message
+												key="labels.key_match_query" /></label>
+										<div class="col-sm-10">
+											<la:text styleId="query" property="query" styleClass="form-control" />
+										</div>
+									</div>
+									<div class="form-group">
+										<div class="col-sm-offset-2 col-sm-10">
+											<button type="submit" class="btn btn-primary" id="submit"
+													name="search"
+													value="<la:message key="labels.crud_button_search" />">
+												<em class="fa fa-search"></em>
+												<la:message key="labels.crud_button_search" />
+											</button>
+											<button type="submit" class="btn btn-default" name="reset"
+													value="<la:message key="labels.crud_button_reset" />">
+												<la:message key="labels.crud_button_reset" />
+											</button>
+										</div>
+									</div>
+								</la:form>
 								<%-- List --%>
 								<c:if test="${keyMatchPager.allRecordCount == 0}">
 									<div class="row top10">