SalesPoint Framework v3.1

data.stdforms.twotableformsheet
Class CDBStrategy

java.lang.Object
  extended bysale.stdforms.FormSheetStrategy
      extended bydata.stdforms.twotableformsheet.MoveStrategy
          extended bydata.stdforms.twotableformsheet.CDBStrategy
All Implemented Interfaces:
ProcessErrorCodes, Serializable

public class CDBStrategy
extends MoveStrategy

MoveStrategy for a Catalog source and a DataBasket destination.

Since:
v2.0
Author:
Steffen Zschaler
See Also:
Serialized Form

Nested Class Summary
 
Nested classes inherited from class sale.stdforms.FormSheetStrategy
FormSheetStrategy.ErrorHandler
 
Field Summary
 
Fields inherited from class sale.stdforms.FormSheetStrategy
DEFAULT_ERROR_HANDLER, m_ehErrHandler, MSG_POPUP_ERROR_HANDLER
 
Fields inherited from interface sale.ProcessErrorCodes
DATABASKET_CONFLICT_ERROR, DUPLICATE_KEY_EXCEPTION, ERR_INTERNAL, ERR_LOWERBOUND, ERR_NOERROR, ERR_UPPERBOUND, NOT_ENOUGH_ELEMENTS_ERROR, REMOVE_VETO_EXCEPTION
 
Constructor Summary
CDBStrategy()
           
 
Method Summary
protected  int checkMoveToDest(SaleProcess p, SalesPoint sp, Catalog cSource, DataBasket dbDest, CatalogItem ci)
          Check whether the indicated move is allowable.
protected  int checkMoveToSource(SaleProcess p, SalesPoint sp, Catalog cSource, DataBasket dbDest, CatalogItem ci)
          Check whether the indicated move is allowable.
protected  Gate getCheckMoveToDestGate(SaleProcess p, SalesPoint sp, Catalog cSource, DataBasket dbDest, CatalogItem ci, TwoTableFormSheet ttfs)
          Get the first gate of the sub-process that will move items from the source to the destination.
protected  Gate getCheckMoveToSourceGate(SaleProcess p, SalesPoint sp, Catalog cSource, DataBasket dbDest, CatalogItem ci, TwoTableFormSheet ttfs)
          Get the first gate of the sub-process that will move items from the destination to the source.
 Transition getMoveToDestProcess(SaleProcess p, SalesPoint sp, Catalog cSource, DataBasket dbDest, CatalogItem ci, TwoTableFormSheet ttfs)
          Get the sub-process that will move items from the source to the destination.
 Transition getMoveToSourceProcess(SaleProcess p, SalesPoint sp, Catalog cSource, DataBasket dbDest, CatalogItem ci, TwoTableFormSheet ttfs)
          Get the sub-process that will move items from the destination to the source.
protected  void moveToDest(SaleProcess p, SalesPoint sp, Catalog cSource, DataBasket dbDest, CatalogItem ci)
          Move the indicated item from source to destination.
protected  void moveToSource(SaleProcess p, SalesPoint sp, Catalog cSource, DataBasket dbDest, CatalogItem ci)
          Move the indicated item from the destination to the source.
 
Methods inherited from class data.stdforms.twotableformsheet.MoveStrategy
canMoveToDest, canMoveToSource
 
Methods inherited from class sale.stdforms.FormSheetStrategy
error, setErrorHandler
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Constructor Detail

CDBStrategy

public CDBStrategy()
Method Detail

getMoveToDestProcess

public Transition getMoveToDestProcess(SaleProcess p,
                                       SalesPoint sp,
                                       Catalog cSource,
                                       DataBasket dbDest,
                                       CatalogItem ci,
                                       TwoTableFormSheet ttfs)
Get the sub-process that will move items from the source to the destination.

Parameters:
p - the process into which the sub-process wil be embedded.
sp - the SalesPoint, if any, at which the FormSheet is being displayed.
cSource - the source Catalog.
dbDest - the destination DataBasket.
ci - the CatalogItem that is selected in the source.
ttfs - the FormSheet that triggers the process.
Override:
Never

getCheckMoveToDestGate

protected Gate getCheckMoveToDestGate(SaleProcess p,
                                      SalesPoint sp,
                                      Catalog cSource,
                                      DataBasket dbDest,
                                      CatalogItem ci,
                                      TwoTableFormSheet ttfs)
Get the first gate of the sub-process that will move items from the source to the destination.

This Gate will check whether the move is allowable, and if so, will trigger a Transition that performs it.

Parameters:
p - the process into which the sub-process wil be embedded.
sp - the SalesPoint, if any, at which the FormSheet is being displayed.
cSource - the source Catalog.
dbDest - the destination DataBasket.
ci - the CatalogItem that is selected in the source.
ttfs - the FormSheet that triggers the process.
Override:
Never Instead, override checkMoveToDest(sale.SaleProcess, sale.SalesPoint, data.Catalog, data.DataBasket, data.CatalogItem) and/or moveToDest(sale.SaleProcess, sale.SalesPoint, data.Catalog, data.DataBasket, data.CatalogItem).

checkMoveToDest

protected int checkMoveToDest(SaleProcess p,
                              SalesPoint sp,
                              Catalog cSource,
                              DataBasket dbDest,
                              CatalogItem ci)
                       throws InterruptedException
Check whether the indicated move is allowable. If so, return 0, otherwise return a non-zero error value that can be passed on to FormSheetStrategy.error(sale.SaleProcess, int). You can assume that you are at a Gate.

Parameters:
p - the process into which the sub-process wil be embedded.
sp - the SalesPoint, if any, at which the FormSheet is being displayed.
cSource - the source Catalog.
dbDest - the destination DataBasket.
ci - the CatalogItem that is selected in the source.
Throws:
InterruptedException
Override:
Sometimes The default implementation returns 0.

moveToDest

protected void moveToDest(SaleProcess p,
                          SalesPoint sp,
                          Catalog cSource,
                          DataBasket dbDest,
                          CatalogItem ci)
Move the indicated item from source to destination. You can assume that you are in a Transition.

Parameters:
p - the process into which the sub-process wil be embedded.
sp - the SalesPoint, if any, at which the FormSheet is being displayed.
cSource - the source Catalog.
dbDest - the destination DataBasket.
ci - the CatalogItem that is selected in the source.
Override:
Sometimes

getMoveToSourceProcess

public Transition getMoveToSourceProcess(SaleProcess p,
                                         SalesPoint sp,
                                         Catalog cSource,
                                         DataBasket dbDest,
                                         CatalogItem ci,
                                         TwoTableFormSheet ttfs)
Get the sub-process that will move items from the destination to the source.

Parameters:
p - the process into which the sub-process wil be embedded.
sp - the SalesPoint, if any, at which the FormSheet is being displayed.
cSource - the source Catalog.
dbDest - the destination DataBasket.
ci - the CatalogItem that is selected in the destination.
ttfs - the FormSheet that triggers the process.
Override:
Never

getCheckMoveToSourceGate

protected Gate getCheckMoveToSourceGate(SaleProcess p,
                                        SalesPoint sp,
                                        Catalog cSource,
                                        DataBasket dbDest,
                                        CatalogItem ci,
                                        TwoTableFormSheet ttfs)
Get the first gate of the sub-process that will move items from the destination to the source.

This Gate will check whether the move is allowable, and if so, will trigger a Transition that performs it.

Parameters:
p - the process into which the sub-process wil be embedded.
sp - the SalesPoint, if any, at which the FormSheet is being displayed.
cSource - the source Catalog.
dbDest - the destination DataBasket.
ci - the CatalogItem that is selected in the destination.
ttfs - the FormSheet that triggers the process.
Override:
Never Instead, override checkMoveToSource(sale.SaleProcess, sale.SalesPoint, data.Catalog, data.DataBasket, data.CatalogItem) and/or moveToSource(sale.SaleProcess, sale.SalesPoint, data.Catalog, data.DataBasket, data.CatalogItem).

checkMoveToSource

protected int checkMoveToSource(SaleProcess p,
                                SalesPoint sp,
                                Catalog cSource,
                                DataBasket dbDest,
                                CatalogItem ci)
                         throws InterruptedException
Check whether the indicated move is allowable. If so, return 0, otherwise return a non-zero error value that can be passed on to FormSheetStrategy.error(sale.SaleProcess, int). You can assume that you are at a Gate.

Parameters:
p - the process into which the sub-process wil be embedded.
sp - the SalesPoint, if any, at which the FormSheet is being displayed.
cSource - the source Catalog.
dbDest - the destination DataBasket.
ci - the CatalogItem that is selected in the destination.
Throws:
InterruptedException
Override:
Sometimes The default implementation returns ProcessErrorCodes.NOT_ENOUGH_ELEMENTS_ERROR if the destination DataBasket contains no entry that describes the given CatalogItem.

moveToSource

protected void moveToSource(SaleProcess p,
                            SalesPoint sp,
                            Catalog cSource,
                            DataBasket dbDest,
                            CatalogItem ci)
Move the indicated item from the destination to the source. You can assume that you are in a Transition.

Parameters:
p - the process into which the sub-process wil be embedded.
sp - the SalesPoint, if any, at which the FormSheet is being displayed.
cSource - the source Catalog.
dbDest - the destination DataBasket.
ci - the CatalogItem that is selected in the destination.
Override:
Sometimes

SalesPoint Framework v3.1