001// --------------------------------------------------------------------------------
002// Copyright 2002-2025 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;
027import javax.enterprise.context.ApplicationScoped;
028import javax.enterprise.inject.spi.CDI;
029
030@ApplicationScoped
031public class SalesOrderLineTimeLogic
032        extends BaseLogic {
033
034    protected SalesOrderLineTimeLogic() {
035        super();
036    }
037
038    public static SalesOrderLineTimeLogic getInstance() {
039        return CDI.current().select(SalesOrderLineTimeLogic.class).get();
040    }
041    
042    public void createOrderLineTime(final ExecutionErrorAccumulator eea, final String orderName, final String orderLineSequence, final String orderTimeTypeName, final Long time, final BasePK createdBy) {
043        var orderLine = SalesOrderLineLogic.getInstance().getOrderLineByName(eea, orderName, orderLineSequence);
044        
045        if(eea == null || !eea.hasExecutionErrors()) {
046            createOrderLineTime(eea, orderLine, orderTimeTypeName, time, createdBy);
047        }
048    }
049
050    public void createOrderLineTime(final ExecutionErrorAccumulator eea, final OrderLine orderLine, final String orderTimeTypeName, final Long time, final BasePK createdBy) {
051        // TODO: Check Order's status.
052
053        OrderLineTimeLogic.getInstance().createOrderLineTime(eea, orderLine, orderTimeTypeName, time, createdBy);
054    }
055
056    public void updateOrderLineTime(final ExecutionErrorAccumulator eea, final String orderName, final String orderLineSequence, final String orderTimeTypeName, final Long time, final BasePK updatedBy) {
057        var orderLine = SalesOrderLineLogic.getInstance().getOrderLineByName(eea, orderName, orderLineSequence);
058        
059        if(eea == null || !eea.hasExecutionErrors()) {
060            updateOrderLineTime(eea, orderLine, orderTimeTypeName, time, updatedBy);
061        }
062    }
063
064    public void updateOrderLineTime(final ExecutionErrorAccumulator eea, final OrderLine orderLine, final String orderTimeTypeName, final Long time, final BasePK updatedBy) {
065        // TODO: Check Order's status.
066
067        OrderLineTimeLogic.getInstance().updateOrderLineTime(eea, orderLine, orderTimeTypeName, time, updatedBy);
068    }
069
070    public OrderLineTimeTransfer getOrderLineTimeTransfer(final ExecutionErrorAccumulator eea, final UserVisit userVisit, final String orderName, final String orderLineSequence, final String orderTimeTypeName) {
071        var orderLine = SalesOrderLineLogic.getInstance().getOrderLineByName(eea, orderName, orderLineSequence);
072        OrderLineTimeTransfer result = null;
073        
074        if(eea == null || !eea.hasExecutionErrors()) {
075            result = getOrderLineTimeTransfer(eea, userVisit, orderLine, orderTimeTypeName);
076        }
077        
078        return result;
079    }
080
081    public OrderLineTimeTransfer getOrderLineTimeTransfer(final ExecutionErrorAccumulator eea, final UserVisit userVisit, final OrderLine orderLine, final String orderTimeTypeName) {
082        return OrderLineTimeLogic.getInstance().getOrderLineTimeTransfer(eea, userVisit, orderLine, orderTimeTypeName);
083    }
084
085    public List<OrderLineTimeTransfer> getOrderLineTimeTransfersByOrder(final ExecutionErrorAccumulator eea, final UserVisit userVisit, final String orderName, final String orderLineSequence) {
086        var orderLine = SalesOrderLineLogic.getInstance().getOrderLineByName(eea, orderName, orderLineSequence);
087        
088        return OrderLineTimeLogic.getInstance().getOrderLineTimeTransfersByOrder(eea, userVisit, orderLine);
089    }
090
091    public void deleteOrderLineTime(final ExecutionErrorAccumulator eea, final String orderName, final String orderLineSequence, final String orderTimeTypeName, final BasePK deletedBy) {
092        var orderLine = SalesOrderLineLogic.getInstance().getOrderLineByName(eea, orderName, orderLineSequence);
093        
094        if(eea == null || !eea.hasExecutionErrors()) {
095            deleteOrderLineTime(eea, orderLine, orderTimeTypeName, deletedBy);
096        }
097    }
098
099    public void deleteOrderLineTime(final ExecutionErrorAccumulator eea, final OrderLine orderLine, final String orderTimeTypeName, final BasePK deletedBy) {
100        // TODO: Check Order's status.
101
102        OrderLineTimeLogic.getInstance().deleteOrderLineTime(eea, orderLine, orderTimeTypeName, deletedBy);
103    }
104
105}