001// --------------------------------------------------------------------------------
002// Copyright 2002-2024 Echo Three, LLC
003//
004// Licensed under the Apache License, Version 2.0 (the "License");
005// you may not use this file except in compliance with the License.
006// You may obtain a copy of the License at
007//
008//     http://www.apache.org/licenses/LICENSE-2.0
009//
010// Unless required by applicable law or agreed to in writing, software
011// distributed under the License is distributed on an "AS IS" BASIS,
012// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013// See the License for the specific language governing permissions and
014// limitations under the License.
015// --------------------------------------------------------------------------------
016
017package com.echothree.model.control.sales.server.logic;
018
019import com.echothree.model.control.order.common.transfer.OrderLineTimeTransfer;
020import com.echothree.model.control.order.server.logic.OrderLineTimeLogic;
021import com.echothree.model.data.order.server.entity.OrderLine;
022import com.echothree.model.data.user.server.entity.UserVisit;
023import com.echothree.util.common.persistence.BasePK;
024import com.echothree.util.server.control.BaseLogic;
025import com.echothree.util.server.message.ExecutionErrorAccumulator;
026import java.util.List;
027
028public class SalesOrderLineTimeLogic
029        extends BaseLogic {
030
031    private SalesOrderLineTimeLogic() {
032        super();
033    }
034
035    private static class SalesOrderLineTimeLogicHolder {
036        static SalesOrderLineTimeLogic instance = new SalesOrderLineTimeLogic();
037    }
038
039    public static SalesOrderLineTimeLogic getInstance() {
040        return SalesOrderLineTimeLogicHolder.instance;
041    }
042    
043    public void createOrderLineTime(final ExecutionErrorAccumulator eea, final String orderName, final String orderLineSequence, final String orderTimeTypeName, final Long time, final BasePK createdBy) {
044        OrderLine orderLine = SalesOrderLineLogic.getInstance().getOrderLineByName(eea, orderName, orderLineSequence);
045        
046        if(eea == null || !eea.hasExecutionErrors()) {
047            createOrderLineTime(eea, orderLine, orderTimeTypeName, time, createdBy);
048        }
049    }
050
051    public void createOrderLineTime(final ExecutionErrorAccumulator eea, final OrderLine orderLine, final String orderTimeTypeName, final Long time, final BasePK createdBy) {
052        // TODO: Check Order's status.
053
054        OrderLineTimeLogic.getInstance().createOrderLineTime(eea, orderLine, orderTimeTypeName, time, createdBy);
055    }
056
057    public void updateOrderLineTime(final ExecutionErrorAccumulator eea, final String orderName, final String orderLineSequence, final String orderTimeTypeName, final Long time, final BasePK updatedBy) {
058        OrderLine orderLine = SalesOrderLineLogic.getInstance().getOrderLineByName(eea, orderName, orderLineSequence);
059        
060        if(eea == null || !eea.hasExecutionErrors()) {
061            updateOrderLineTime(eea, orderLine, orderTimeTypeName, time, updatedBy);
062        }
063    }
064
065    public void updateOrderLineTime(final ExecutionErrorAccumulator eea, final OrderLine orderLine, final String orderTimeTypeName, final Long time, final BasePK updatedBy) {
066        // TODO: Check Order's status.
067
068        OrderLineTimeLogic.getInstance().updateOrderLineTime(eea, orderLine, orderTimeTypeName, time, updatedBy);
069    }
070
071    public OrderLineTimeTransfer getOrderLineTimeTransfer(final ExecutionErrorAccumulator eea, final UserVisit userVisit, final String orderName, final String orderLineSequence, final String orderTimeTypeName) {
072        OrderLine orderLine = SalesOrderLineLogic.getInstance().getOrderLineByName(eea, orderName, orderLineSequence);
073        OrderLineTimeTransfer result = null;
074        
075        if(eea == null || !eea.hasExecutionErrors()) {
076            result = getOrderLineTimeTransfer(eea, userVisit, orderLine, orderTimeTypeName);
077        }
078        
079        return result;
080    }
081
082    public OrderLineTimeTransfer getOrderLineTimeTransfer(final ExecutionErrorAccumulator eea, final UserVisit userVisit, final OrderLine orderLine, final String orderTimeTypeName) {
083        return OrderLineTimeLogic.getInstance().getOrderLineTimeTransfer(eea, userVisit, orderLine, orderTimeTypeName);
084    }
085
086    public List<OrderLineTimeTransfer> getOrderLineTimeTransfersByOrder(final ExecutionErrorAccumulator eea, final UserVisit userVisit, final String orderName, final String orderLineSequence) {
087        OrderLine orderLine = SalesOrderLineLogic.getInstance().getOrderLineByName(eea, orderName, orderLineSequence);
088        
089        return OrderLineTimeLogic.getInstance().getOrderLineTimeTransfersByOrder(eea, userVisit, orderLine);
090    }
091
092    public void deleteOrderLineTime(final ExecutionErrorAccumulator eea, final String orderName, final String orderLineSequence, final String orderTimeTypeName, final BasePK deletedBy) {
093        OrderLine orderLine = SalesOrderLineLogic.getInstance().getOrderLineByName(eea, orderName, orderLineSequence);
094        
095        if(eea == null || !eea.hasExecutionErrors()) {
096            deleteOrderLineTime(eea, orderLine, orderTimeTypeName, deletedBy);
097        }
098    }
099
100    public void deleteOrderLineTime(final ExecutionErrorAccumulator eea, final OrderLine orderLine, final String orderTimeTypeName, final BasePK deletedBy) {
101        // TODO: Check Order's status.
102
103        OrderLineTimeLogic.getInstance().deleteOrderLineTime(eea, orderLine, orderTimeTypeName, deletedBy);
104    }
105
106}