/* * Copyright 2011 gitblit.com. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.gitblit.wicket.pages; import org.apache.wicket.PageParameters; import org.apache.wicket.markup.html.link.BookmarkablePageLink; import com.gitblit.Constants; import com.gitblit.wicket.CacheControl; import com.gitblit.wicket.CacheControl.LastModified; import com.gitblit.wicket.WicketUtils; import com.gitblit.wicket.panels.SearchPanel; @CacheControl(LastModified.REPOSITORY) public class GitSearchPage extends RepositoryPage { public GitSearchPage(PageParameters params) { super(params); String value = WicketUtils.getSearchString(params); String type = WicketUtils.getSearchType(params); Constants.SearchType searchType = Constants.SearchType.forName(type); int pageNumber = WicketUtils.getPage(params); int prevPage = Math.max(0, pageNumber - 1); int nextPage = pageNumber + 1; SearchPanel search = new SearchPanel("searchPanel", repositoryName, objectId, value, searchType, getRepository(), -1, pageNumber - 1, getRepositoryModel().showRemoteBranches); boolean hasMore = search.hasMore(); add(search); add(new BookmarkablePageLink<Void>("firstPageTop", GitSearchPage.class, WicketUtils.newSearchParameter(repositoryName, objectId, value, searchType)) .setEnabled(pageNumber > 1)); add(new BookmarkablePageLink<Void>("prevPageTop", GitSearchPage.class, WicketUtils.newSearchParameter(repositoryName, objectId, value, searchType, prevPage)).setEnabled(pageNumber > 1)); add(new BookmarkablePageLink<Void>("nextPageTop", GitSearchPage.class, WicketUtils.newSearchParameter(repositoryName, objectId, value, searchType, nextPage)).setEnabled(hasMore)); add(new BookmarkablePageLink<Void>("firstPageBottom", GitSearchPage.class, WicketUtils.newSearchParameter(repositoryName, objectId, value, searchType)) .setEnabled(pageNumber > 1)); add(new BookmarkablePageLink<Void>("prevPageBottom", GitSearchPage.class, WicketUtils.newSearchParameter(repositoryName, objectId, value, searchType, prevPage)).setEnabled(pageNumber > 1)); add(new BookmarkablePageLink<Void>("nextPageBottom", GitSearchPage.class, WicketUtils.newSearchParameter(repositoryName, objectId, value, searchType, nextPage)).setEnabled(hasMore)); } @Override protected String getPageName() { return getString("gb.search"); } @Override protected Class<? extends BasePage> getRepoNavPageClass() { return LogPage.class; } }