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 3.0KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  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.CacheControl;
  21. import com.gitblit.wicket.CacheControl.LastModified;
  22. import com.gitblit.wicket.WicketUtils;
  23. import com.gitblit.wicket.panels.SearchPanel;
  24. @CacheControl(LastModified.REPOSITORY)
  25. public class GitSearchPage extends RepositoryPage {
  26. public GitSearchPage(PageParameters params) {
  27. super(params);
  28. String value = WicketUtils.getSearchString(params);
  29. String type = WicketUtils.getSearchType(params);
  30. Constants.SearchType searchType = Constants.SearchType.forName(type);
  31. int pageNumber = WicketUtils.getPage(params);
  32. int prevPage = Math.max(0, pageNumber - 1);
  33. int nextPage = pageNumber + 1;
  34. SearchPanel search = new SearchPanel("searchPanel", repositoryName, objectId, value,
  35. searchType, getRepository(), -1, pageNumber - 1, getRepositoryModel().showRemoteBranches);
  36. boolean hasMore = search.hasMore();
  37. add(search);
  38. add(new BookmarkablePageLink<Void>("firstPageTop", GitSearchPage.class,
  39. WicketUtils.newSearchParameter(repositoryName, objectId, value, searchType))
  40. .setEnabled(pageNumber > 1));
  41. add(new BookmarkablePageLink<Void>("prevPageTop", GitSearchPage.class,
  42. WicketUtils.newSearchParameter(repositoryName, objectId, value, searchType,
  43. prevPage)).setEnabled(pageNumber > 1));
  44. add(new BookmarkablePageLink<Void>("nextPageTop", GitSearchPage.class,
  45. WicketUtils.newSearchParameter(repositoryName, objectId, value, searchType,
  46. nextPage)).setEnabled(hasMore));
  47. add(new BookmarkablePageLink<Void>("firstPageBottom", GitSearchPage.class,
  48. WicketUtils.newSearchParameter(repositoryName, objectId, value, searchType))
  49. .setEnabled(pageNumber > 1));
  50. add(new BookmarkablePageLink<Void>("prevPageBottom", GitSearchPage.class,
  51. WicketUtils.newSearchParameter(repositoryName, objectId, value, searchType,
  52. prevPage)).setEnabled(pageNumber > 1));
  53. add(new BookmarkablePageLink<Void>("nextPageBottom", GitSearchPage.class,
  54. WicketUtils.newSearchParameter(repositoryName, objectId, value, searchType,
  55. nextPage)).setEnabled(hasMore));
  56. }
  57. @Override
  58. protected String getPageName() {
  59. return getString("gb.search");
  60. }
  61. @Override
  62. protected Class<? extends BasePage> getRepoNavPageClass() {
  63. return LogPage.class;
  64. }
  65. }