| /* |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| */ |
| |
| import org.apache.ofbiz.base.util.* |
| import org.apache.ofbiz.entity.* |
| import org.apache.ofbiz.entity.util.* |
| import org.apache.ofbiz.entity.condition.EntityCondition |
| import org.apache.ofbiz.entity.condition.EntityOperator |
| import org.apache.ofbiz.party.contact.* |
| |
| if (parameters.userLogin) { |
| userLogin = parameters.userLogin |
| context.userLogin = userLogin |
| } |
| returnHeader = null |
| orderId = parameters.orderId |
| |
| if (parameters.returnHeader) { |
| returnHeader = parameters.returnHeader |
| returnId = returnHeader.returnId |
| partyId = returnHeader.fromPartyId |
| } else { |
| partyId = parameters.fromPartyId |
| returnId = parameters.returnId |
| } |
| if (returnId) { |
| returnHeader = from("ReturnHeader").where("returnId", returnId).queryOne() |
| if (returnHeader) { |
| partyId = returnHeader.fromPartyId |
| toPartyId = parameters.toPartyId |
| |
| context.currentStatus = returnHeader.getRelatedOne("StatusItem", true) |
| } |
| } |
| context.returnHeader = returnHeader |
| context.returnId = returnId |
| |
| //fin account info |
| finAccounts = null |
| if (partyId) { |
| finAccounts = from("FinAccountAndRole").where("partyId", partyId, "finAccountTypeId", "STORE_CREDIT_ACCT", "roleTypeId", "OWNER", "statusId", "FNACT_ACTIVE").filterByDate().queryList() |
| } |
| context.finAccounts = finAccounts |
| |
| // billing account info |
| billingAccountList = null |
| if (partyId) { |
| billingAccountList = from("BillingAccountAndRole").where("partyId", partyId).filterByDate().queryList() |
| } |
| context.billingAccountList = billingAccountList |
| |
| // payment method info |
| List creditCardList = null |
| List eftAccountList = null |
| if (partyId) { |
| creditCardList = from("PaymentMethodAndCreditCard").where("partyId", partyId).filterByDate().queryList() |
| eftAccountList = from("PaymentMethodAndEftAccount").where("partyId", partyId).filterByDate().queryList() |
| } |
| context.creditCardList = creditCardList |
| context.eftAccountList = eftAccountList |
| |
| orderRole = null |
| orderHeader = null |
| if (orderId) { |
| orderRole = from("OrderRole").where("orderId", orderId, "roleTypeId", "BILL_TO_CUSTOMER").queryFirst() |
| orderHeader = from("OrderHeader").where("orderId", orderId).queryOne() |
| } |
| context.orderRole = orderRole |
| context.orderHeader = orderHeader |
| |
| |
| // from address |
| addresses = null |
| if (context.request) { |
| addresses = ContactMechWorker.getPartyPostalAddresses(request, partyId, "_NA_") |
| } |
| context.addresses = addresses |
| |
| if (returnHeader) { |
| contactMechTo = ContactMechWorker.getFacilityContactMechByPurpose(delegator, returnHeader.destinationFacilityId, ["PUR_RET_LOCATION", "SHIPPING_LOCATION", "PRIMARY_LOCATION"]) |
| if (contactMechTo) { |
| postalAddressTo = from("PostalAddress").where("contactMechId", contactMechTo.contactMechId).cache(true).queryOne() |
| context.postalAddressTo = postalAddressTo |
| } |
| |
| party = from("Party").where("partyId", partyId).cache(true).queryOne() |
| if (party) { |
| shippingContactMechList = ContactHelper.getContactMech(party, "SHIPPING_LOCATION", "POSTAL_ADDRESS", false) |
| if (shippingContactMechList) { |
| context.postalAddressFrom = from("PostalAddress").where("contactMechId", EntityUtil.getFirst(shippingContactMechList).contactMechId).cache(true).queryOne() |
| } |
| } |
| } |