blob: d2ec5a26149b50f667d240c040a8bb1c8ef32849 [file] [log] [blame]
/*
* 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.sql.Timestamp;
import org.ofbiz.base.util.UtilHttp;
import org.ofbiz.base.util.UtilDateTime;
context.nowDate = UtilDateTime.nowDate();
context.nowTimestampString = UtilHttp.encodeBlanks(UtilDateTime.nowTimestamp().toString());
boolean useValues = true;
if (request.getAttribute("_ERROR_MESSAGE_")) useValues = false;
productId = parameters.productId;
if (productId) context.productId = productId;
productIdTo = parameters.productIdTo;
updateMode = parameters.UPDATE_MODE;
if (productIdTo) context.productIdTo = productIdTo;
productAssocTypeId = parameters.productAssocTypeId;
if (productAssocTypeId) context.productAssocTypeId = productAssocTypeId;
fromDateStr = parameters.fromDate;
Timestamp fromDate = null;
if (fromDateStr) fromDate = Timestamp.valueOf(fromDateStr) ?: (Timestamp)request.getAttribute("ProductAssocCreateFromDate");;
context.fromDate = fromDate;
productAssoc = from("ProductAssoc").where("productId", productId, "productIdTo", productIdTo, "productAssocTypeId", productAssocTypeId, "fromDate", fromDate).queryOne();
if (updateMode) {
productAssoc = [:];
context.remove("productIdTo");
}
if (productAssoc) {
context.productAssoc = productAssoc;
}
if ("true".equalsIgnoreCase((String)request.getParameter("useValues"))) useValues = true;
if (!productAssoc) useValues = false;
context.useValues = useValues;
Collection assocTypes = from("ProductAssocType").where("parentTypeId", "PRODUCT_COMPONENT").orderBy("productAssocTypeId", "description").queryList();
context.assocTypes = assocTypes;
Collection formulae = from("CustomMethod").where("customMethodTypeId", "BOM_FORMULA").orderBy("customMethodId", "description").queryList();
context.formulae = formulae;
if (product) {
assocFromProducts = product.getRelated("MainProductAssoc", (productAssocTypeId ? [productAssocTypeId : productAssocTypeId]: [:]), ["sequenceNum","productId"], false);
if (assocFromProducts) context.assocFromProducts = assocFromProducts;
assocToProducts = product.getRelated("AssocProductAssoc", (productAssocTypeId ? [productAssocTypeId : productAssocTypeId]: [:]), ["sequenceNum","productId"], false);
if (assocToProducts) context.assocToProducts = assocToProducts;
}