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

org.dominokit.domino.ui.pagination.ScrollingPagination Maven / Gradle / Ivy

package org.dominokit.domino.ui.pagination;

import elemental2.dom.HTMLAnchorElement;
import elemental2.dom.HTMLLIElement;
import org.dominokit.domino.ui.icons.Icons;
import org.dominokit.domino.ui.utils.DominoElement;

import java.util.stream.IntStream;

import static java.util.Objects.nonNull;
import static org.jboss.gwt.elemento.core.Elements.a;
import static org.jboss.gwt.elemento.core.Elements.li;

public class ScrollingPagination extends BasePagination {

    private DominoElement prevSet;
    private DominoElement firstPage;
    private DominoElement nextSet;
    private DominoElement lastPage;

    private DominoElement dotsElement;
    private DominoElement pagesCountPageElement;
    private DominoElement prevAnchor;
    private DominoElement prevSetAnchor;
    private DominoElement firstPageAnchor;
    private DominoElement dotsAnchor;
    private DominoElement nextAnchor;
    private DominoElement nextSetAnchor;
    private DominoElement lastPageAnchor;

    private int windowSize = 10;
    private int windowIndex = 0;

    public static ScrollingPagination create() {
        return new ScrollingPagination();
    }

    public static ScrollingPagination create(int pages) {
        return new ScrollingPagination(pages);
    }

    public static ScrollingPagination create(int pages, int pageSize) {
        return new ScrollingPagination(pages, pageSize);
    }

    public static ScrollingPagination create(int pages, int pageSize, int windowSize) {
        return new ScrollingPagination(pages, pageSize, windowSize);
    }

    public ScrollingPagination() {
        this(0, 10, 10);
    }

    public ScrollingPagination(int pages) {
        this(pages, 10, 10);
    }

    public ScrollingPagination(int pages, int pageSize) {
        this(pages, pageSize, 10);
    }

    public ScrollingPagination(int pages, int pageSize, int windowSize) {
        this.pagesCount = pages;
        this.pageSize = pageSize;
        this.windowSize = windowSize;
        init(this);
        updatePages(pages, pageSize);
    }

    public ScrollingPagination updatePages(int pages) {
        return updatePages(pages, pageSize);
    }

    @Override
    public ScrollingPagination updatePages(int pages, int pageSize) {
        this.pageSize = pageSize;
        this.pagesCount = pages;
        this.index = 1;
        allPages.clear();

        prevAnchor = DominoElement.of(a());
        prevElement = DominoElement.of(li().css("page-nav"))
                .appendChild(prevAnchor
                        .setTooltip("Previous page")
                        .appendChild(Icons.ALL.chevron_left()
                                .clickable())
                        .addClickListener(event -> moveToPage(index - 1, false)));

        prevSetAnchor = DominoElement.of(a());
        prevSet = DominoElement.of(li().css("page-nav"))
                .appendChild(prevSetAnchor
                        .setTooltip("Previous pages set")
                        .appendChild(Icons.ALL.first_page()
                                .clickable())
                        .addClickListener(event -> moveToPage((windowIndex * windowSize), false)));

        firstPageAnchor = DominoElement.of(a());
        firstPage = DominoElement.of(li().css("page-nav"))
                .appendChild(firstPageAnchor
                        .setTooltip("First page")
                        .appendChild(Icons.ALL.skip_previous()
                                .clickable())
                        .addClickListener(event -> moveToPage(1, false)));

        pagesElement.clearElement()
                .appendChild(firstPage)
                .appendChild(prevSet)
                .appendChild(prevElement);

        if (pages > 0) {
            IntStream.rangeClosed(1, pages).forEach(p -> DominoElement.of(li().css("page"))
                    .apply(element -> {
                        allPages.add(element);
                        pagesElement.appendChild(element
                                .appendChild(DominoElement.of(a())
                                        .setTextContent(p + "")
                                        .addClickListener(evt -> moveToPage(p, false)))
                                .toggleDisplay(p <= windowSize)
                        );
                    }));
        }

        if (pages > windowSize) {
            dotsAnchor = DominoElement.of(a());
            dotsElement = DominoElement.of(li().css("page"))
                    .appendChild(dotsAnchor
                            .setTooltip("Next pages set")
                            .setTextContent("...")
                            .addClickListener(evt -> moveToPage((windowIndex * windowSize) + windowSize + 1, false)));
            pagesElement.appendChild(dotsElement
            );
            pagesCountPageElement = DominoElement.of(li().css("page"))
                    .appendChild(DominoElement.of(a())
                            .setTextContent("" + pages)
                            .addClickListener(evt -> moveToPage(pages, false)));
            pagesElement.appendChild(pagesCountPageElement
            );
        }

        nextAnchor = DominoElement.of(a());
        nextElement = DominoElement.of(li().css("page-nav"))
                .appendChild(nextAnchor
                        .setTooltip("Next page")
                        .appendChild(Icons.ALL.chevron_right()
                                .clickable())
                        .addClickListener(event -> moveToPage(index + 1, false)));

        nextSetAnchor = DominoElement.of(a());
        nextSet = DominoElement.of(li().css("page-nav"))
                .appendChild(nextSetAnchor
                        .setTooltip("Next pages set")
                        .appendChild(Icons.ALL.last_page()
                                .clickable())
                        .addClickListener(event -> moveToPage((windowIndex * windowSize) + windowSize + 1, false)));

        lastPageAnchor = DominoElement.of(a());
        lastPage = DominoElement.of(li().css("page-nav"))
                .appendChild(lastPageAnchor
                        .setTooltip("Last page")
                        .appendChild(Icons.ALL.skip_next()
                                .clickable())
                        .addClickListener(event -> moveToPage(allPages.size(), false)));

        if (pages > 0) {
            moveToPage(1, true);
        }

        if (pages <= 0) {
            nextElement.disable();
            prevElement.disable();
        }

        pagesElement
                .appendChild(nextElement)
                .appendChild(nextSet)
                .appendChild(lastPage);

        return this;
    }

    @Override
    void moveToPage(int page, boolean silent) {
        if (page > 0 && page <= pagesCount) {

            index = page;
            if (markActivePage) {
                gotoPage(allPages.get(page - 1));
            }

            if (!silent) {
                pageChangedCallBack.onPageChanged(page);
            }

            if (page == pagesCount) {
                nextElement.disable();
                nextSet.disable();
                lastPage.disable();
            } else {
                nextElement.enable();
                nextSet.enable();
                lastPage.enable();
            }


            if (page == 1) {
                prevElement.disable();
                prevSet.disable();
                firstPage.disable();
            } else {
                prevElement.enable();
                prevSet.enable();
                firstPage.enable();
            }

            showPageWindow(page);

        }
    }

    private void showPageWindow(int page) {
        if (page % windowSize == 0) {
            showWindow((page / windowSize) - 1);
        } else {
            showWindow(page / windowSize);
        }

        if (windowIndex == 0) {
            prevSet.disable();
        } else {
            prevSet.enable();
        }

        int windowCount = (allPages.size() / windowSize) + (allPages.size() % windowSize > 0 ? 1 : 0);
        if (windowIndex >= windowCount - 1) {
            nextSet.disable();
            if(nonNull(dotsElement) && nonNull(pagesCountPageElement)){
                dotsElement.hide();
                pagesCountPageElement.hide();
            }

        } else {
            nextSet.enable();
            if(nonNull(dotsElement) && nonNull(pagesCountPageElement)){
                dotsElement.show();
                pagesCountPageElement.show();
            }
        }

    }

    private void showWindow(int index) {

        if (index != this.windowIndex) {
            int windowMinLimit = windowIndex * windowSize;
            int windowMaxLimit = windowMinLimit + windowSize;

            for (int i = windowMinLimit; i < windowMaxLimit; i++) {
                allPages.get(i).hide();
            }

            int targetWindowMinLimit = index * windowSize;
            int targetWindowMaxLimit = targetWindowMinLimit + windowSize;

            for (int i = targetWindowMinLimit; i < targetWindowMaxLimit; i++) {
                allPages.get(i).show();
            }

            this.windowIndex = index;
        }
    }

    public DominoElement getPrevAnchor() {
        return prevAnchor;
    }

    public DominoElement getPrevSetAnchor() {
        return prevSetAnchor;
    }

    public DominoElement getFirstPageAnchor() {
        return firstPageAnchor;
    }

    public DominoElement getDotsAnchor() {
        return dotsAnchor;
    }

    public DominoElement getNextAnchor() {
        return nextAnchor;
    }

    public DominoElement getNextSetAnchor() {
        return nextSetAnchor;
    }

    public DominoElement getLastPageAnchor() {
        return lastPageAnchor;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy