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

org.dbflute.cbean.result.ResultBeanBuilder Maven / Gradle / Ivy

/*
 * Copyright 2014-2015 the original author or 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
 *
 *     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 org.dbflute.cbean.result;

import java.util.List;

import org.dbflute.cbean.ConditionBean;
import org.dbflute.cbean.paging.PagingBean;

/**
 * The builder of result bean.
 * @param  The type of entity.
 * @author jflute
 */
public class ResultBeanBuilder {

    // ===================================================================================
    //                                                                           Attribute
    //                                                                           =========
    protected final String _tableDbName; // null allowed

    // ===================================================================================
    //                                                                         Constructor
    //                                                                         ===========
    public ResultBeanBuilder(String tableDbName) {
        _tableDbName = tableDbName;
    }

    // ===================================================================================
    //                                                                                List
    //                                                                                ====
    /**
     * Build the result bean of list. {for CB}
     * @param cb The condition-bean. (NotNull)
     * @param selectedList The actually selected list of the entity. (NotNull)
     * @return The result bean of list. (NullAllowed: if null, treated as empty)
     */
    public ListResultBean buildListOfCB(ConditionBean cb, List selectedList) {
        ListResultBean rb = newListResultBean();
        rb.setTableDbName(_tableDbName);
        rb.setAllRecordCount(selectedList.size());
        rb.setOrderByClause(cb.getOrderByComponent());
        rb.setSelectedList(selectedList);
        return rb;
    }

    /**
     * Build the result bean of list with all record count, order-by clause. {for Nested}
     * @param inherited The result bean to inherit option info, e.g. all record count. (NotNull) 
     * @param selectedList The actually selected list of the entity. (NotNull)
     * @return The result bean of list. (NullAllowed: if null, treated as empty)
     */
    @SuppressWarnings("deprecation")
    public ListResultBean buildListInherited(ListResultBean inherited, List selectedList) {
        ListResultBean rb = newListResultBean();
        rb.setTableDbName(_tableDbName);
        rb.setAllRecordCount(inherited.getAllRecordCount());
        rb.setOrderByClause(inherited.getOrderByClause());
        rb.setSelectedList(selectedList);
        return rb;
    }

    /**
     * Build the result bean of list without order-by clause. {for Simple}
     * @param selectedList The actually selected list of the entity. (NotNull)
     * @return The result bean of list. (NullAllowed: if null, treated as empty)
     */
    public ListResultBean buildListSimply(List selectedList) {
        ListResultBean rb = newListResultBean();
        rb.setTableDbName(_tableDbName);
        rb.setAllRecordCount(selectedList.size());
        rb.setSelectedList(selectedList);
        return rb;
    }

    /**
     * Build the result bean of list as empty. {for Paging}
     * @param pb The bean of paging. (NotNull)
     * @return The result bean of list as empty. (NotNull)
     */
    public ListResultBean buildEmptyListOfPaging(PagingBean pb) {
        ListResultBean rb = newListResultBean();
        rb.setTableDbName(_tableDbName);
        rb.setOrderByClause(pb.getOrderByComponent());
        return rb;
    }

    /**
     * Build the result bean of list as empty. {for General}
     * @return The result bean of list as empty. (NotNull)
     */
    public ListResultBean buildEmptyListSimply() {
        ListResultBean rb = newListResultBean();
        rb.setTableDbName(_tableDbName);
        return rb;
    }

    protected ListResultBean newListResultBean() {
        return new ListResultBean();
    }

    // ===================================================================================
    //                                                                              Paging
    //                                                                              ======
    /**
     * Build the result bean of paging. {for Paging}
     * @param pb The bean of paging. (NotNull)
     * @param allRecordCount All record count.
     * @param selectedList The list of selected entity. (NotNull)
     * @return The result bean of paging. (NotNull)
     */
    public PagingResultBean buildPagingOfPaging(PagingBean pb, int allRecordCount, List selectedList) {
        PagingResultBean rb = newPagingResultBean();
        rb.setTableDbName(_tableDbName);
        rb.setAllRecordCount(allRecordCount);
        rb.setOrderByClause(pb.getOrderByComponent());
        rb.setSelectedList(selectedList);
        rb.setPageSize(pb.getFetchSize());
        rb.setCurrentPageNumber(pb.getFetchPageNumber());
        return rb;
    }

    /**
     * Build the result bean of paging. {for Simple}
     * @param pageSize The record count of one page.
     * @param pageNumber The number of current page.
     * @param allRecordCount All record count.
     * @param selectedList The list of selected entity. (NotNull)
     * @return The result bean of paging. (NotNull)
     */
    public PagingResultBean buildPagingSimply(int pageSize, int pageNumber, int allRecordCount, List selectedList) {
        PagingResultBean rb = newPagingResultBean();
        rb.setTableDbName(_tableDbName);
        rb.setAllRecordCount(allRecordCount);
        rb.setSelectedList(selectedList);
        rb.setPageSize(pageSize);
        rb.setCurrentPageNumber(pageNumber);
        return rb;
    }

    /**
     * Build the result bean of paging as empty. {for Empty}
     * @param pageSize The record count of one page.
     * @return The result bean of list as empty. (NotNull)
     */
    public ListResultBean buildEmptyPagingSimply(int pageSize) {
        PagingResultBean rb = newPagingResultBean();
        rb.setTableDbName(_tableDbName);
        rb.setPageSize(pageSize);
        rb.setCurrentPageNumber(1);
        return rb;
    }

    protected PagingResultBean newPagingResultBean() {
        return new PagingResultBean();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy