net.purnama.pureff.dao.ItemInvoiceWarehouseInDao.java Source code

Java tutorial

Introduction

Here is the source code for net.purnama.pureff.dao.ItemInvoiceWarehouseInDao.java

Source

/*
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */
package net.purnama.pureff.dao;

import java.util.Calendar;
import java.util.List;
import net.purnama.pureff.entity.WarehouseEntity;
import net.purnama.pureff.entity.transactional.InvoiceWarehouseInEntity;
import net.purnama.pureff.entity.transactional.ItemInvoiceWarehouseInEntity;
import org.hibernate.Criteria;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.criterion.CriteriaSpecification;
import org.hibernate.criterion.Order;
import org.hibernate.criterion.Restrictions;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;

/**
 *
 * @author Purnama
 */
@Repository
public class ItemInvoiceWarehouseInDao {

    @Autowired
    private SessionFactory sessionFactory;

    public void addItemInvoiceWarehouseIn(ItemInvoiceWarehouseInEntity iteminvoicewarehousein) {
        Session session = this.sessionFactory.getCurrentSession();
        session.persist(iteminvoicewarehousein);
    }

    public List<ItemInvoiceWarehouseInEntity> getItemInvoiceWarehouseInList(
            InvoiceWarehouseInEntity invoicewarehousein) {
        Session session = this.sessionFactory.getCurrentSession();
        Criteria c = session.createCriteria(ItemInvoiceWarehouseInEntity.class);
        c.add(Restrictions.eq("invoicewarehousein", invoicewarehousein));
        c.addOrder(Order.asc("id"));
        c.setResultTransformer(CriteriaSpecification.DISTINCT_ROOT_ENTITY);
        return c.list();
    }

    public List<ItemInvoiceWarehouseInEntity> getItemInvoiceWarehouseInList(Calendar start, Calendar end,
            WarehouseEntity warehouse, WarehouseEntity origin, boolean status) {
        Session session = this.sessionFactory.getCurrentSession();

        Criteria c = session.createCriteria(ItemInvoiceWarehouseInEntity.class, "iteminvoicewarehousein");
        c.createAlias("iteminvoicewarehousein.invoicewarehousein", "invoicewarehousein");
        c.add(Restrictions.between("invoicewarehousein.date", start, end));
        if (warehouse != null) {
            c.add(Restrictions.eq("invoicewarehousein.warehouse", warehouse));
        }
        if (origin != null) {
            c.add(Restrictions.eq("invoicewarehousein.origin", origin));
        }
        c.add(Restrictions.eq("invoicewarehousein.status", status));
        c.addOrder(Order.asc("invoicewarehousein.date"));
        c.setResultTransformer(CriteriaSpecification.DISTINCT_ROOT_ENTITY);
        return c.list();
    }
}