You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

GitSearchPage.java 2.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. /*
  2. * Copyright 2011 gitblit.com.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. package com.gitblit.wicket.pages;
  17. import org.apache.wicket.PageParameters;
  18. import org.apache.wicket.markup.html.link.BookmarkablePageLink;
  19. import com.gitblit.Constants;
  20. import com.gitblit.wicket.WicketUtils;
  21. import com.gitblit.wicket.panels.SearchPanel;
  22. public class GitSearchPage extends RepositoryPage {
  23. public GitSearchPage(PageParameters params) {
  24. super(params);
  25. String value = WicketUtils.getSearchString(params);
  26. String type = WicketUtils.getSearchType(params);
  27. Constants.SearchType searchType = Constants.SearchType.forName(type);
  28. int pageNumber = WicketUtils.getPage(params);
  29. int prevPage = Math.max(0, pageNumber - 1);
  30. int nextPage = pageNumber + 1;
  31. SearchPanel search = new SearchPanel("searchPanel", repositoryName, objectId, value,
  32. searchType, getRepository(), -1, pageNumber - 1, getRepositoryModel().showRemoteBranches);
  33. boolean hasMore = search.hasMore();
  34. add(search);
  35. add(new BookmarkablePageLink<Void>("firstPageTop", GitSearchPage.class,
  36. WicketUtils.newSearchParameter(repositoryName, objectId, value, searchType))
  37. .setEnabled(pageNumber > 1));
  38. add(new BookmarkablePageLink<Void>("prevPageTop", GitSearchPage.class,
  39. WicketUtils.newSearchParameter(repositoryName, objectId, value, searchType,
  40. prevPage)).setEnabled(pageNumber > 1));
  41. add(new BookmarkablePageLink<Void>("nextPageTop", GitSearchPage.class,
  42. WicketUtils.newSearchParameter(repositoryName, objectId, value, searchType,
  43. nextPage)).setEnabled(hasMore));
  44. add(new BookmarkablePageLink<Void>("firstPageBottom", GitSearchPage.class,
  45. WicketUtils.newSearchParameter(repositoryName, objectId, value, searchType))
  46. .setEnabled(pageNumber > 1));
  47. add(new BookmarkablePageLink<Void>("prevPageBottom", GitSearchPage.class,
  48. WicketUtils.newSearchParameter(repositoryName, objectId, value, searchType,
  49. prevPage)).setEnabled(pageNumber > 1));
  50. add(new BookmarkablePageLink<Void>("nextPageBottom", GitSearchPage.class,
  51. WicketUtils.newSearchParameter(repositoryName, objectId, value, searchType,
  52. nextPage)).setEnabled(hasMore));
  53. }
  54. @Override
  55. protected String getPageName() {
  56. return getString("gb.search");
  57. }
  58. }