All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.micronaut.data.model.Slice Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2017-2020 original authors
 *
 * 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
 *
 * https://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 io.micronaut.data.model;

import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
import io.micronaut.context.annotation.DefaultImplementation;
import io.micronaut.core.annotation.NonNull;
import io.micronaut.core.annotation.ReflectiveAccess;
import io.micronaut.core.annotation.TypeHint;
import io.micronaut.serde.annotation.Serdeable;

import java.util.Iterator;
import java.util.List;
import java.util.function.Function;

/**
 * Inspired by the Spring Data's {@code Slice} and GORM's {@code PagedResultList}, this models a type that supports
 * pagination operations.
 *
 * 

A slice is a result list associated with a particular {@link Pageable}

* * @param The generic type * @author graemerocher * @since 1.0.0 */ @JsonIgnoreProperties(ignoreUnknown = true) @TypeHint(Slice.class) @JsonDeserialize(as = DefaultSlice.class) @Serdeable @DefaultImplementation(DefaultSlice.class) public interface Slice extends Iterable { /** * @return The content. */ @NonNull List getContent(); /** * @return The pageable for this slice. */ @NonNull Pageable getPageable(); /** * @return The page number */ default int getPageNumber() { return getPageable().getNumber(); } /** * Determine whether there is a next page. * * @since 4.8.0 * @return Whether there exist a next page. */ default boolean hasNext() { return getContent().size() == getSize(); } /** * Determine whether there is a previous page. * * @since 4.8.0 * @return Whether there exist a previous page. */ default boolean hasPrevious() { return getOffset() > 0; } /** * Create a pageable for querying the next page of data. *

A pageable may be created even if the end of data was reached to accommodate for * cases when new data might be added to the repository. Use {@link #hasNext()} to * verify if you have reached the end.

* * @return The next pageable */ default @NonNull Pageable nextPageable() { return getPageable().next(); } /** * Create a pageable for querying the previous page of data. *

A pageable may be created even if the end of data was reached to accommodate for * cases when new data might be added to the repository. Use {@link #hasPrevious()} to * verify if you have reached the end.

* * @return The previous pageable */ default @NonNull Pageable previousPageable() { return getPageable().previous(); } /** * @return The offset. */ default long getOffset() { return getPageable().getOffset(); } /** * @return The size of the slice. */ default int getSize() { return getPageable().getSize(); } /** * @return Whether the slice is empty */ default boolean isEmpty() { return getContent().isEmpty(); } /** * @return The sort */ @JsonIgnore default @NonNull Sort getSort() { return getPageable(); } /** * @return The page of elements */ default int getNumberOfElements() { return getContent().size(); } @Override @NonNull default Iterator iterator() { return getContent().iterator(); } /** * Maps the content with the given function. * * @param function The function to apply to each element in the content. * @param The type returned by the function * @return A new slice with the mapped content */ default @NonNull Slice map(Function function) { List content = getContent().stream().map(function).toList(); return new DefaultSlice<>(content, getPageable()); } /** * Creates a slice from the given content and pageable. * @param content The content * @param pageable The pageable * @param The generic type * @return The slice */ @ReflectiveAccess static @NonNull Slice of(@NonNull List content, @NonNull Pageable pageable) { return new DefaultSlice<>(content, pageable); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy