Package org.openwms.common.location
Class LocationGroup
java.lang.Object
org.ameba.integration.jpa.BaseEntity
org.ameba.integration.jpa.ApplicationEntity
org.openwms.common.location.Target
org.openwms.common.location.LocationGroup
- All Implemented Interfaces:
- Serializable,- org.ameba.integration.TypedEntity<Long>
A LocationGroup is a logical group of 
Locations with same characteristics.- Author:
- Heiko Scherrer
- See Also:
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprivate AccountThe LocationGroup might be assigned to anAccount.private StringDescription of theLocationGroup.private @NotNull LocationGroupStateState of infeed, controlled by the subsystem only.private @NotNull LocationGroupStateState of outfeed.private StringA type can be assigned to aLocationGroup.static final intLength of the name field; used for telegram mapping and for column definition.private booleanIs theLocationGroupincluded in the calculation ofTransportUnits.private Set<LocationGroup> ChildLocationGroups.ChildLocations.private floatMaximum fill level of theLocationGroup.private @NotBlank @Size(min=1,max=255) StringUnique identifier of aLocationGroup.private @NotBlank StringThe operation mode is controlled by the subsystem and defines the physical mode aLocationGroupis currently able to operate in.private LocationGroupParentLocationGroup.private LocationGroupReferences theLocationGroupthat locked thisLocationGroupfor infeed.private LocationGroupReferences theLocationGroupthat locked thisLocationGroupfor outfeed.private SubsystemThe subsystem like a PLC, that manages thisLocationGroup.Fields inherited from class org.ameba.integration.jpa.ApplicationEntityC_ID
- 
Constructor SummaryConstructorsModifierConstructorDescriptionprotectedDear JPA...LocationGroup(@NotBlank String name) Create a newLocationGroupwith a unique name.
- 
Method SummaryModifier and TypeMethodDescriptionbooleanaddLocation(Location location) Add aLocationto the list of children.booleanaddLocationGroup(LocationGroup locationGroup) Add aLocationGroupto the list of children.voidchangeGroupStateIn(LocationGroupState newGroupStateIn) Change the infeed state of theLocationGroup.private voidchangeGroupStateIn(LocationGroupState newGroupStateIn, LocationGroup lockLG) Change the infeed state of theLocationGroup.voidchangeGroupStateOut(LocationGroupState newGroupStateOut) Change the outfeed state of theLocationGroup.(package private) voidchangeGroupStateOut(LocationGroupState gStateOut, LocationGroup lockLg) Set the outfeed state of theLocationGroup.voidchangeState(LocationGroupState stateIn, LocationGroupState stateOut) Tries to change thegroupStateInandgroupStateOutof theLocationGroup.booleanReturn theAccountthisLocationGroupis assigned to.Returns the description text.Returns the infeed state of theLocationGroup.Return the outfeed state of theLocationGroup.Returns the type of theLocationGroup.Return all childLocationGroup.Return allLocations.floatReturns the maximum fill level of theLocationGroup.
 The maximum fill level defines how manyLocations of theLocationGroupcan be occupied byTransportUnits.getName()Returns the name of theLocationGroup.intReturns the count of all subLocations.Get the current operation mode thisLocationGroupoperates in.Returns the parentLocationGroup.inthashCode()booleanCheck whether thisLocationGrouphasLocationGroups as children.booleanCheck whether thisLocationGrouphasLocations assigned.booleanWhether this LocationGroup has a parent LocationGroup or not.booleanCheck whether infeed is allowed for theLocationGroup.booleanCheck whether infeed of theLocationGroupis blocked.booleanReturns the locationGroupCountingActive.booleanCheck whether outfeed is allowed for theLocationGroup.booleanCheck whether outfeed of theLocationGroupis blocked.booleanremoveLocation(Location location) Remove aLocationfrom the list of children.booleanremoveLocationGroup(@NotNull LocationGroup locationGroup) Remove aLocationGroupfrom the list of children.voidsetAccount(Account account) Sets theAccountfor thisLocationGroup.voidsetDescription(String description) Set the description text.voidsetGroupType(String groupType) Set the type for theLocationGroup.voidsetLocationGroupCountingActive(boolean locationGroupCountingActive) Set the locationGroupCountingActive.voidsetLocationGroups(Set<LocationGroup> locationGroups) Sets the childLocationGroup.voidsetMaxFillLevel(float maxFillLevel) Set the maximum fill level for theLocationGroup.voidsetOperationMode(@NotBlank String operationMode) Set the current operation mode thisLocationGroupcan operate in.voidsetParent(LocationGroup parent) Sets the parentLocationGroupof thisLocationGroup.toString()Return the name of theLocationGroupas String.Methods inherited from class org.ameba.integration.jpa.ApplicationEntitygetPersistentKey, hasPersistentKey, onEntityPersist, onPersist, setPersistentKeyMethods inherited from class org.ameba.integration.jpa.BaseEntitygetCreatedBy, getCreateDt, getLastModifiedBy, getLastModifiedDt, getOl, getPk, isNew, setCreatedBy, setCreateDt, setLastModifiedBy, setLastModifiedDt, setOl
- 
Field Details- 
nameUnique identifier of aLocationGroup.
- 
LENGTH_NAMEpublic static final int LENGTH_NAMELength of the name field; used for telegram mapping and for column definition.- See Also:
 
- 
accountThe LocationGroup might be assigned to anAccount.
- 
descriptionDescription of theLocationGroup.
- 
groupTypeA type can be assigned to aLocationGroup.
- 
locationGroupCountingActiveprivate boolean locationGroupCountingActiveIs theLocationGroupincluded in the calculation ofTransportUnits.
- 
operationModeThe operation mode is controlled by the subsystem and defines the physical mode aLocationGroupis currently able to operate in.
- 
groupStateInState of infeed, controlled by the subsystem only.
- 
stateInLockerReferences theLocationGroupthat locked thisLocationGroupfor infeed.
- 
groupStateOutState of outfeed.
- 
stateOutLockerReferences theLocationGroupthat locked thisLocationGroupfor outfeed.
- 
maxFillLevelprivate float maxFillLevelMaximum fill level of theLocationGroup.
- 
subsystemThe subsystem like a PLC, that manages thisLocationGroup.
- 
parentParentLocationGroup.
- 
locationGroupsChildLocationGroups.
- 
locationsChildLocations.
 
- 
- 
Constructor Details- 
LocationGroupprotected LocationGroup()Dear JPA...
- 
LocationGroupCreate a newLocationGroupwith a unique name.- Parameters:
- name- The name of the- LocationGroupmust not be null
 
 
- 
- 
Method Details- 
getNameReturns the name of theLocationGroup.- Returns:
- The name of the LocationGroup
 
- 
getAccountReturn theAccountthisLocationGroupis assigned to.- Returns:
- The Account
 
- 
setAccountSets theAccountfor thisLocationGroup.- Parameters:
- account- The- Accountto set for this- LocationGroup
 
- 
isInfeedAllowedpublic boolean isInfeedAllowed()Check whether infeed is allowed for theLocationGroup.- Returns:
- true if allowed, otherwise false.
 
- 
isInfeedBlockedpublic boolean isInfeedBlocked()Check whether infeed of theLocationGroupis blocked.- Returns:
- true if blocked, otherwise false.
 
- 
isOutfeedAllowedpublic boolean isOutfeedAllowed()Check whether outfeed is allowed for theLocationGroup.- Returns:
- true if allowed, otherwise false.
 
- 
isOutfeedBlockedpublic boolean isOutfeedBlocked()Check whether outfeed of theLocationGroupis blocked.- Returns:
- true if blocked, otherwise false.
 
- 
getOperationModeGet the current operation mode thisLocationGroupoperates in.- Returns:
- The operational mode
 
- 
setOperationModeSet the current operation mode thisLocationGroupcan operate in.- Parameters:
- operationMode- The mode as an extensible String
- See Also:
 
- 
getGroupStateInReturns the infeed state of theLocationGroup.- Returns:
- The state of infeed
 
- 
changeGroupStateInChange the infeed state of theLocationGroup.- Parameters:
- newGroupStateIn- The state to set
 
- 
changeGroupStateInChange the infeed state of theLocationGroup.- Parameters:
- newGroupStateIn- The state to set
- lockLG- The- LocationGroupthat wants to lock/unlock this- LocationGroup.
 
- 
getGroupStateOutReturn the outfeed state of theLocationGroup.- Returns:
- The state of outfeed
 
- 
changeGroupStateOutChange the outfeed state of theLocationGroup.- Parameters:
- newGroupStateOut- The state to set
 
- 
changeGroupStateOutSet the outfeed state of theLocationGroup.- Parameters:
- gStateOut- The state to set
- lockLg- The- LocationGroupthat wants to lock/unlock this- LocationGroup.
 
- 
getNoLocationspublic int getNoLocations()Returns the count of all subLocations.- Returns:
- The count of Locations belonging to thisLocationGroup
 
- 
getMaxFillLevelpublic float getMaxFillLevel()Returns the maximum fill level of theLocationGroup.
 The maximum fill level defines how manyLocations of theLocationGroupcan be occupied byTransportUnits.The maximum fill level is a value between 0 and 1 and represents a percentage value. - Returns:
- The maximum fill level
 
- 
setMaxFillLevelpublic void setMaxFillLevel(float maxFillLevel) Set the maximum fill level for theLocationGroup.Pass a value between 0 and 1. 
 For example maxFillLevel = 0.85 means: 85% of allLocations can be occupied.- Parameters:
- maxFillLevel- The maximum fill level
 
- 
getGroupTypeReturns the type of theLocationGroup.- Returns:
- The type of the LocationGroup
 
- 
setGroupTypeSet the type for theLocationGroup.- Parameters:
- groupType- The type of the- LocationGroup
 
- 
getDescriptionReturns the description text.- Returns:
- The Description as String
 
- 
setDescriptionSet the description text.- Parameters:
- description- The String to set as description text
 
- 
getParentReturns the parentLocationGroup.- Returns:
- The parent LocationGroup
 
- 
setParentSets the parentLocationGroupof thisLocationGroup.- Parameters:
- parent- The parent- LocationGroupto set
 
- 
getLocationGroupsReturn all childLocationGroup.- Returns:
- A set of all LocationGrouphaving this one as parent
 
- 
hasLocationGroupspublic boolean hasLocationGroups()Check whether thisLocationGrouphasLocationGroups as children.- Returns:
- true if LocationGroups are assigned, otherwise false
 
- 
setLocationGroupsSets the childLocationGroup.- Parameters:
- locationGroups- the set of LocationGroups to set
 
- 
addLocationGroupAdd aLocationGroupto the list of children.- Parameters:
- locationGroup- The- LocationGroupto be added as a child
- Returns:
- true if the LocationGroupwas new in the collection ofLocationGroups, otherwise false
 
- 
removeLocationGroupRemove aLocationGroupfrom the list of children.- Parameters:
- locationGroup- The- LocationGroupto be removed from the list of children
- Returns:
- true if the LocationGroupwas found and could be removed, otherwise false
 
- 
getLocationsReturn allLocations.- Returns:
- Locations
 
- 
hasLocationspublic boolean hasLocations()Check whether thisLocationGrouphasLocations assigned.- Returns:
- true if Locations are assigned, otherwise false
 
- 
addLocationAdd aLocationto the list of children.
- 
removeLocationRemove aLocationfrom the list of children.
- 
isLocationGroupCountingActivepublic boolean isLocationGroupCountingActive()Returns the locationGroupCountingActive.- Returns:
- The locationGroupCountingActive
 
- 
setLocationGroupCountingActivepublic void setLocationGroupCountingActive(boolean locationGroupCountingActive) Set the locationGroupCountingActive.- Parameters:
- locationGroupCountingActive- The locationGroupCountingActive to set
 
- 
hashCodepublic int hashCode()- Overrides:
- hashCodein class- org.ameba.integration.jpa.ApplicationEntity
- See Also:
 
- 
equals- Overrides:
- equalsin class- org.ameba.integration.jpa.ApplicationEntity
- See Also:
 
- 
toStringReturn the name of theLocationGroupas String.
- 
changeStateTries to change thegroupStateInandgroupStateOutof theLocationGroup. A state change is only allowed when the parentLocationGroups state is not blocked.- Parameters:
- stateIn- The new groupStateIn to set, or null
- stateOut- The new groupStateOut to set, or null
 
- 
hasParentpublic boolean hasParent()Whether this LocationGroup has a parent LocationGroup or not.- Returns:
- true If it has a parent
 
 
-