Package org.sab.invsys.persistence.model.order.sales

Examples of org.sab.invsys.persistence.model.order.sales.SalesOrder


  public SalesOrderUI findByOrderId(String orderId) {
    return soMapper.toUIBean(soRepository.findByOrderId(orderId));
  }

  public List<SalesOrderItemsUI> findItemsByOrderId(int orderId) {
    return itemsMapper.toUIBean(itemsRepository.findBySo(new SalesOrder(
        new Long(orderId))));
  }
View Full Code Here


        new Long(orderId))));
  }

  @Transactional
  public SalesOrderUI update(SalesOrderUI uiBean) {
    SalesOrder so = soMapper.toPersistenceBean(uiBean);
    Set<SalesOrderItems> items = so.getItems();

    SalesOrder existing = soRepository.findByOrderId(uiBean.getOrderId());
    if (existing == null) {
      return null;
    }

    existing.setComments(so.getComments());
    existing.setDiscount(so.getDiscount());
    existing.setDueDate(so.getDueDate());
    existing.setOrderDate(so.getOrderDate());
    existing.setReferenceNumber(so.getReferenceNumber());
    existing.setTotal(so.getTotal());

    User user = userRepository.findByUsername(uiBean.getUserName());
    existing.setUser(user);
    existing.setItems(null);

    long total = 0;
    SalesOrder saved = soRepository.save(existing);
    if (items != null && items.size() > 0) {
      List<SalesOrderItems> existingItems = itemsRepository
          .findBySo(saved);

      Map<String, SalesOrderItems> SalesdItemsMap = new HashMap<String, SalesOrderItems>();
      for (SalesOrderItems pim : items) {
        SalesdItemsMap.put(pim.getProduct().getProductName(), pim);
      }
      Map<String, SalesOrderItems> existingItemsMap = new HashMap<String, SalesOrderItems>();
      for (SalesOrderItems i : existingItems) {
        existingItemsMap.put(i.getProduct().getProductName(), i);
      }

      /* Delete Sales Order Items */
      List<SalesOrderItems> deleteItems = new ArrayList<SalesOrderItems>();
      for (SalesOrderItems deleteItem : existingItems) {
        if (!SalesdItemsMap.containsKey(deleteItem.getProduct()
            .getProductName())) {
          deleteItems.add(deleteItem);
        }
      }
      itemsRepository.delete(deleteItems);

      /* Updating/Inserting Sales Order Items */
      List<SalesOrderItems> toBeSavedItems = new ArrayList<SalesOrderItems>();
      for (SalesOrderItems item : items) {
        SalesOrderItems existingItem = existingItemsMap.get(item
            .getProduct().getProductName());
        Product product = productRepository.findByProductName(item
            .getProduct().getProductName());
        SalesOrder order = soRepository.findByOrderId(uiBean
            .getOrderId());
        if (existingItem != null) {
          existingItem.setQuantity(item.getQuantity());
          existingItem.setUnitPrice(item.getUnitPrice());
          existingItem.setDiscount(item.getDiscount());
View Full Code Here

  private Logger logger = Logger.getLogger(ProductService.class);

  @Transactional
  public SalesOrderUI create(SalesOrderUI uiBean) {
    SalesOrder so = soMapper.toPersistenceBean(uiBean);
    Set<SalesOrderItems> items = so.getItems();
    so.setItems(null);

    long total = 0;
    if (items != null && items.size() > 0) {
      for (SalesOrderItems item : items) {
        total += item.getQuantity() * item.getUnitPrice() * ( 100 - item.getDiscount() ) / 100 ;
      }
    }
    so.setTotal(total);
   
    User user = userRepository.findByUsername(uiBean.getUserName());
    so.setUser(user);

    SalesOrder saved = soRepository.save(so);
    if (items != null && items.size() > 0) {
      for (SalesOrderItems item : items) {
        logger.debug("Item :: " + item);
        Product product = productRepository.findByProductName(item
            .getProduct().getProductName());
        item.setProduct(product);
        SalesOrder order = soRepository.findByOrderId(uiBean
            .getOrderId());
        item.setSo(order);
        logger.debug("Item :: " + item);
      }
      itemsRepository.save(items);
View Full Code Here

  public Page<SalesOrderUI> toUIBean(Page<SalesOrder> data, Pageable pageable) {
    return new PageImpl<SalesOrderUI>(toUIBean(data.getContent()));
  }

  public SalesOrder toPersistenceBean(SalesOrderUI ui) {
    SalesOrder data = new SalesOrder();

    if (ui != null) {
      data.setComments(ui.getComments());
      data.setCreateadBy(ui.getCreateadBy());
      data.setCreatedDate(ui.getCreatedDate());
      data.setDiscount(ui.getDiscount());
      data.setDueDate(ui.getDueDate());
      data.setId(ui.getId());
      data.setModifiedBy(ui.getModifiedBy());
      data.setModifiedDate(ui.getModifiedDate());
      data.setOrderDate(ui.getOrderDate());
      data.setOrderId(ui.getOrderId());
      data.setOrderType(ui.getOrderType());
      data.setReferenceNumber(ui.getReferenceNumber());

      User user = new User();
      user.setUsername(ui.getUserName());
      data.setUser(user);

      if (ui.getCharges() != null && ui.getCharges().size() > 0) {
        SalesOrderChargesMapper chargeMapper = new SalesOrderChargesMapper();
        Set<SalesOrderCharges> charges = new HashSet<SalesOrderCharges>(
            chargeMapper.toPersistenceBean(ui.getCharges()));
        data.setCharges(charges);
      }
      if (ui.getSoldItems() != null && ui.getSoldItems().size() > 0) {
        SalesOrderItemsMapper itemsMapper = new SalesOrderItemsMapper();
        List<SalesOrderItems> pItems = itemsMapper.toPersistenceBean(ui
            .getSoldItems());
        Set<SalesOrderItems> items = new HashSet<SalesOrderItems>();
        if (pItems != null) {
          items.addAll(pItems);
        }
        data.setItems(items);
      }
      if (ui.getTaxes() != null && ui.getTaxes().size() > 0) {
        SalesOrderTaxesMapper taxMapper = new SalesOrderTaxesMapper();
        Set<SalesOrderTaxes> taxes = new HashSet<SalesOrderTaxes>(
            taxMapper.toPersistenceBean(ui.getTaxes()));
        data.setTaxes(taxes);
      }
    }

    return data;
  }
View Full Code Here

TOP

Related Classes of org.sab.invsys.persistence.model.order.sales.SalesOrder

Copyright © 2018 www.massapicom. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.