/* | |
* 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; | |
} | |
} |