| /* |
| * 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 java.lang.* |
| import java.util.* |
| import org.apache.ofbiz.base.util.* |
| import org.apache.ofbiz.entity.* |
| import org.apache.ofbiz.entity.util.* |
| import org.apache.ofbiz.entity.condition.* |
| import org.apache.ofbiz.party.contact.ContactMechWorker |
| import org.apache.ofbiz.product.store.ProductStoreWorker |
| import org.apache.ofbiz.accounting.payment.PaymentWorker |
| |
| productStoreId = ProductStoreWorker.getProductStoreId(request) |
| context.productStoreId = productStoreId |
| |
| if (userLogin) { |
| profiledefs = from("PartyProfileDefault").where("partyId", partyId, "productStoreId", productStoreId).queryOne() |
| |
| showOld = "true".equals(parameters.SHOW_OLD) |
| |
| partyContactMechValueMaps = ContactMechWorker.getPartyContactMechValueMaps(delegator, userLogin.partyId, showOld) |
| paymentMethodValueMaps = PaymentWorker.getPartyPaymentMethodValueMaps(delegator, userLogin.partyId, showOld) |
| |
| context.profiledefs = profiledefs |
| context.showOld = showOld |
| context.partyContactMechValueMaps = partyContactMechValueMaps |
| context.paymentMethodValueMaps = paymentMethodValueMaps |
| |
| // shipping methods - for default selection |
| if (profiledefs?.defaultShipAddr) { |
| shipAddress = from("PostalAddress").where("contactMechId", profiledefs.defaultShipAddr).queryOne() |
| if (shipAddress) { |
| carrierShipMeths = ProductStoreWorker.getAvailableStoreShippingMethods(delegator, productStoreId, shipAddress, [1], null, 0, 1) |
| context.carrierShipMethods = carrierShipMeths |
| } |
| } |
| |
| profileSurveys = ProductStoreWorker.getProductSurveys(delegator, productStoreId, null, "CUSTOMER_PROFILE") |
| context.surveys = profileSurveys |
| |
| exprs = [EntityCondition.makeCondition("partyId", EntityOperator.EQUALS, partyId)] |
| exprs.add(EntityCondition.makeCondition("roleStatusId", EntityOperator.NOT_EQUAL, "COM_ROLE_READ")) |
| messages = from("CommunicationEventAndRole").where(exprs).orderBy("-entryDate").maxRows(5).queryList() |
| context.messages = messages |
| context.profileMessages = true |
| |
| partyContent = from("ContentRole").where("partyId", partyId, "roleTypeId", "OWNER").filterByDate().queryList() |
| context.partyContent = partyContent |
| |
| mimeTypes = from("MimeType").orderBy("description", "mimeTypeId").queryList() |
| context.mimeTypes = mimeTypes |
| |
| partyContentTypes = from("PartyContentType").orderBy("description").queryList() |
| context.partyContentTypes = partyContentTypes |
| |
| // call the getOrderedSummaryInformation service to get the sub-total of valid orders in last X months |
| monthsToInclude = 12 |
| result = runService('getOrderedSummaryInformation', [partyId : partyId, roleTypeId : "PLACING_CUSTOMER", orderTypeId : "SALES_ORDER", statusId : "ORDER_COMPLETED", monthsToInclude : monthsToInclude, userLogin : userLogin]) |
| context.monthsToInclude = monthsToInclude |
| context.totalSubRemainingAmount = result.totalSubRemainingAmount |
| context.totalOrders = result.totalOrders |
| |
| contactListPartyList = from("ContactListParty").where("partyId", partyId).orderBy("-fromDate").queryList() |
| // show all, including history, ie don't filter: contactListPartyList = EntityUtil.filterByDate(contactListPartyList, true) |
| context.contactListPartyList = contactListPartyList |
| |
| publicContactLists = from("ContactList").where("isPublic", "Y").orderBy("contactListName").queryList() |
| context.publicContactLists = publicContactLists |
| |
| partyAndContactMechList = from("PartyAndContactMech").where("partyId", partyId).orderBy("-fromDate").filterByDate().queryList() |
| context.partyAndContactMechList = partyAndContactMechList |
| |
| // state/province & country's name |
| if (partyContactMechValueMaps) { |
| partyContactMechValueMaps.each { |
| if (it.postalAddress) { |
| postalAddress = it.postalAddress |
| countryGeo = postalAddress.getRelatedOne("CountryGeo", false) |
| if (countryGeo) it.countryGeoName = countryGeo.getString("geoName") |
| stateProvinceGeo = postalAddress.getRelatedOne("StateProvinceGeo", false) |
| if (stateProvinceGeo) it.stateProvinceGeoName = stateProvinceGeo.getString("geoName") |
| |
| } |
| } |
| } |
| } |