Search in sources :

Example 1 with JSONLookupValue

use of de.metas.ui.web.window.datatypes.json.JSONLookupValue in project metasfresh-webui-api by metasfresh.

the class PurchaseRowFactory method buildRowFromPurchaseCandidate.

@Builder(builderMethodName = "rowFromPurchaseCandidateBuilder", builderClassName = "RowFromPurchaseCandidateBuilder")
private PurchaseRow buildRowFromPurchaseCandidate(@NonNull final PurchaseCandidate purchaseCandidate, @Nullable final VendorProductInfo vendorProductInfo, @NotNull final Date datePromised) {
    final int bpartnerId = purchaseCandidate.getVendorBPartnerId();
    final JSONLookupValue vendorBPartner = createBPartnerLookupValue(bpartnerId);
    final JSONLookupValue product;
    if (vendorProductInfo != null) {
        product = createProductLookupValue(vendorProductInfo.getProductId(), vendorProductInfo.getProductNo(), vendorProductInfo.getProductName());
    } else {
        product = createProductLookupValue(purchaseCandidate.getProductId());
    }
    final String uom = createUOMLookupValueForProductId(product.getKeyAsInt());
    final int processedPurchaseCandidateId = purchaseCandidate.isProcessed() ? purchaseCandidate.getPurchaseCandidateId() : 0;
    return PurchaseRow.builder().rowId(PurchaseRowId.lineId(purchaseCandidate.getSalesOrderLineId(), bpartnerId, processedPurchaseCandidateId)).salesOrderId(purchaseCandidate.getSalesOrderId()).rowType(PurchaseRowType.LINE).product(product).uomOrAvailablility(uom).qtyToPurchase(purchaseCandidate.getQtyToPurchase()).purchasedQty(purchaseCandidate.getPurchasedQty()).datePromised(datePromised).vendorBPartner(vendorBPartner).purchaseCandidateId(purchaseCandidate.getPurchaseCandidateId()).orgId(purchaseCandidate.getOrgId()).warehouseId(purchaseCandidate.getWarehouseId()).readonly(purchaseCandidate.isProcessedOrLocked()).build();
}
Also used : JSONLookupValue(de.metas.ui.web.window.datatypes.json.JSONLookupValue) Builder(lombok.Builder)

Example 2 with JSONLookupValue

use of de.metas.ui.web.window.datatypes.json.JSONLookupValue in project metasfresh-webui-api by metasfresh.

the class ASIRestController method complete.

@PostMapping(value = "/{asiDocId}/complete")
public JSONLookupValue complete(@PathVariable("asiDocId") final String asiDocIdStr) {
    userSession.assertLoggedIn();
    final DocumentId asiDocId = DocumentId.of(asiDocIdStr);
    return Execution.callInNewExecution("complete", () -> asiRepo.complete(asiDocId)).transform(JSONLookupValue::ofLookupValue);
}
Also used : JSONLookupValue(de.metas.ui.web.window.datatypes.json.JSONLookupValue) DocumentId(de.metas.ui.web.window.datatypes.DocumentId) PostMapping(org.springframework.web.bind.annotation.PostMapping)

Example 3 with JSONLookupValue

use of de.metas.ui.web.window.datatypes.json.JSONLookupValue in project metasfresh-webui-api by metasfresh.

the class PickingTerminalByOrderViewCustomizer method createOrderOrBPLocation.

private JSONLookupValue createOrderOrBPLocation(final ViewRow.Builder rowBuilder) {
    // Grouping row
    if (rowBuilder.isRootRow()) {
        final JSONLookupValue orderLV = (JSONLookupValue) rowBuilder.getFieldValue(I_M_Packageable_V.COLUMNNAME_C_Order_ID);
        final JSONLookupValue bpartnerLV = (JSONLookupValue) rowBuilder.getFieldValue(I_M_Packageable_V.COLUMNNAME_C_BPartner_ID);
        return JSONLookupValue.concat(orderLV, bpartnerLV);
    } else // Detail/included row
    {
        final JSONLookupValue bpLocationLV = (JSONLookupValue) rowBuilder.getFieldValue(I_M_Packageable_V.COLUMNNAME_C_BPartner_Location_ID);
        return bpLocationLV;
    }
}
Also used : JSONLookupValue(de.metas.ui.web.window.datatypes.json.JSONLookupValue)

Example 4 with JSONLookupValue

use of de.metas.ui.web.window.datatypes.json.JSONLookupValue in project metasfresh-webui-api by metasfresh.

the class PickingTerminalByWarehouseAndProductViewCustomizer method customizeViewRow.

@Override
public void customizeViewRow(final ViewRow.Builder rowBuilder) {
    final JSONLookupValue productOrBPartnerLV = createProductOrBPartnerFieldValue(rowBuilder);
    rowBuilder.putFieldValue(FIELDNAME_ProductOrBPartner, productOrBPartnerLV);
}
Also used : JSONLookupValue(de.metas.ui.web.window.datatypes.json.JSONLookupValue)

Example 5 with JSONLookupValue

use of de.metas.ui.web.window.datatypes.json.JSONLookupValue in project metasfresh-webui-api by metasfresh.

the class SqlHUEditorViewRepository method createHUEditorRow.

private HUEditorRow createHUEditorRow(@NonNull final I_M_HU hu, final int topLevelHUId) {
    // final Stopwatch stopwatch = Stopwatch.createStarted();
    final IHandlingUnitsBL handlingUnitsBL = Services.get(IHandlingUnitsBL.class);
    final boolean aggregatedTU = handlingUnitsBL.isAggregateHU(hu);
    final String huUnitTypeCode = handlingUnitsBL.getHU_UnitType(hu);
    final HUEditorRowType huRecordType;
    if (aggregatedTU) {
        huRecordType = HUEditorRowType.TU;
    } else {
        huRecordType = HUEditorRowType.ofHU_UnitType(huUnitTypeCode);
    }
    final String huUnitTypeDisplayName = huRecordType.getName();
    final JSONLookupValue huUnitTypeLookupValue = JSONLookupValue.of(huUnitTypeCode, huUnitTypeDisplayName);
    final JSONLookupValue huStatus = createHUStatusLookupValue(hu);
    final boolean processed = rowProcessedPredicate.isProcessed(hu);
    final int huId = hu.getM_HU_ID();
    final HUEditorRowId rowId = HUEditorRowId.ofHU(huId, topLevelHUId);
    final HUEditorRow.Builder huEditorRow = HUEditorRow.builder(windowId).setRowId(rowId).setType(huRecordType).setTopLevel(topLevelHUId <= 0).setProcessed(processed).setBPartnerId(hu.getC_BPartner_ID()).setAttributesProvider(attributesProvider).setCode(hu.getValue()).setHUUnitType(huUnitTypeLookupValue).setHUStatus(huStatus).setPackingInfo(extractPackingInfo(hu, huRecordType));
    // Acquire Best Before Date if required
    if (showBestBeforeDate) {
        huEditorRow.setBestBeforeDate(extractBestBeforeDate(attributesProvider, rowId));
    }
    // Locator
    if (showLocator) {
        huEditorRow.setLocator(createLocatorLookupValue(hu.getM_Locator_ID()));
    }
    // 
    // Product/UOM/Qty if there is only one product stored
    final IHUProductStorage singleProductStorage = getSingleProductStorage(hu);
    if (singleProductStorage != null) {
        huEditorRow.setProduct(createProductLookupValue(singleProductStorage.getM_Product())).setUOM(createUOMLookupValue(singleProductStorage.getC_UOM())).setQtyCU(singleProductStorage.getQty());
    }
    // 
    // Included HUs
    final int topLevelHUIdEffective = topLevelHUId > 0 ? topLevelHUId : huId;
    if (aggregatedTU) {
        final IHUStorageFactory storageFactory = handlingUnitsBL.getStorageFactory();
        storageFactory.getStorage(hu).getProductStorages().stream().map(huStorage -> createHUEditorRow(huId, topLevelHUIdEffective, huStorage, processed)).forEach(huEditorRow::addIncludedRow);
    } else if (X_M_HU_PI_Version.HU_UNITTYPE_LoadLogistiqueUnit.equals(huUnitTypeCode)) {
        final IHandlingUnitsDAO handlingUnitsDAO = Services.get(IHandlingUnitsDAO.class);
        handlingUnitsDAO.retrieveIncludedHUs(hu).stream().map(includedHU -> createHUEditorRow(includedHU, topLevelHUIdEffective)).forEach(huEditorRow::addIncludedRow);
    } else if (X_M_HU_PI_Version.HU_UNITTYPE_TransportUnit.equals(huUnitTypeCode)) {
        final IHandlingUnitsDAO handlingUnitsDAO = Services.get(IHandlingUnitsDAO.class);
        final IHUStorageFactory storageFactory = handlingUnitsBL.getStorageFactory();
        handlingUnitsDAO.retrieveIncludedHUs(hu).stream().map(includedVHU -> storageFactory.getStorage(includedVHU)).flatMap(vhuStorage -> vhuStorage.getProductStorages().stream()).map(vhuProductStorage -> createHUEditorRow(huId, topLevelHUIdEffective, vhuProductStorage, processed)).forEach(huEditorRow::addIncludedRow);
    } else if (X_M_HU_PI_Version.HU_UNITTYPE_VirtualPI.equals(huUnitTypeCode)) {
    // do nothing
    } else {
        throw new HUException("Unknown HU_UnitType=" + huUnitTypeCode + " for " + hu);
    }
    final HUEditorRow huEditorRowBuilt = huEditorRow.build();
    return huEditorRowBuilt;
}
Also used : IHUStorageFactory(de.metas.handlingunits.storage.IHUStorageFactory) SqlViewRowIdsConverter(de.metas.ui.web.view.descriptor.SqlViewRowIdsConverter) Date(java.util.Date) ViewEvaluationCtx(de.metas.ui.web.view.ViewEvaluationCtx) ITrx(org.adempiere.ad.trx.api.ITrx) SqlDocumentFilterConverters(de.metas.ui.web.document.filter.sql.SqlDocumentFilterConverters) ResultSet(java.sql.ResultSet) IHUQueryBuilder(de.metas.handlingunits.IHUQueryBuilder) IADReferenceDAO(org.adempiere.ad.service.IADReferenceDAO) HUPackingInfos(de.metas.ui.web.handlingunits.util.HUPackingInfos) ImmutableSet(com.google.common.collect.ImmutableSet) NonNull(lombok.NonNull) Collection(java.util.Collection) Set(java.util.Set) IQueryBuilder(org.adempiere.ad.dao.IQueryBuilder) SqlViewBinding(de.metas.ui.web.view.descriptor.SqlViewBinding) PreparedStatement(java.sql.PreparedStatement) Collectors(java.util.stream.Collectors) I_M_Locator(de.metas.handlingunits.model.I_M_Locator) DBException(org.adempiere.exceptions.DBException) Services(org.adempiere.util.Services) List(java.util.List) SqlViewRowIdsOrderedSelectionFactory(de.metas.ui.web.view.SqlViewRowIdsOrderedSelectionFactory) Stream(java.util.stream.Stream) Builder(lombok.Builder) I_M_Warehouse(de.metas.handlingunits.model.I_M_Warehouse) LogManager(de.metas.logging.LogManager) IHandlingUnitsBL(de.metas.handlingunits.IHandlingUnitsBL) HUException(de.metas.handlingunits.exceptions.HUException) ViewRowIdsOrderedSelection(de.metas.ui.web.view.ViewRowIdsOrderedSelection) GuavaCollectors(org.adempiere.util.GuavaCollectors) DocumentId(de.metas.ui.web.window.datatypes.DocumentId) InterfaceWrapperHelper.loadOutOfTrx(org.adempiere.model.InterfaceWrapperHelper.loadOutOfTrx) SqlOptions(de.metas.ui.web.window.model.sql.SqlOptions) SqlAndParams(de.metas.ui.web.view.descriptor.SqlAndParams) Page(org.adempiere.util.collections.PagedIterator.Page) HUIdsFilterData(de.metas.ui.web.handlingunits.HUIdsFilterHelper.HUIdsFilterData) PlainContextAware(org.adempiere.model.PlainContextAware) SqlViewSelectData(de.metas.ui.web.view.descriptor.SqlViewSelectData) SQLException(java.sql.SQLException) DB(org.compiere.util.DB) I_M_Product(org.compiere.model.I_M_Product) ImmutableList(com.google.common.collect.ImmutableList) X_M_HU_PI_Version(de.metas.handlingunits.model.X_M_HU_PI_Version) DocumentFilter(de.metas.ui.web.document.filter.DocumentFilter) DocumentQueryOrderBy(de.metas.ui.web.window.model.DocumentQueryOrderBy) I_M_HU(de.metas.handlingunits.model.I_M_HU) LinkedHashSet(java.util.LinkedHashSet) Nullable(javax.annotation.Nullable) DocumentIdsSelection(de.metas.ui.web.window.datatypes.DocumentIdsSelection) JSONLookupValue(de.metas.ui.web.window.datatypes.json.JSONLookupValue) Logger(org.slf4j.Logger) SqlViewKeyColumnNamesMap(de.metas.ui.web.view.descriptor.SqlViewKeyColumnNamesMap) I_C_UOM(org.compiere.model.I_C_UOM) HUPackingInfoFormatter(de.metas.ui.web.handlingunits.util.HUPackingInfoFormatter) WindowId(de.metas.ui.web.window.datatypes.WindowId) ViewRowIdsOrderedSelectionFactory(de.metas.ui.web.view.ViewRowIdsOrderedSelectionFactory) IHandlingUnitsDAO(de.metas.handlingunits.IHandlingUnitsDAO) SqlViewSelectionQueryBuilder(de.metas.ui.web.view.descriptor.SqlViewSelectionQueryBuilder) SqlDocumentFilterConverter(de.metas.ui.web.document.filter.sql.SqlDocumentFilterConverter) Check(org.adempiere.util.Check) IHUProductStorage(de.metas.handlingunits.storage.IHUProductStorage) IHUStorage(de.metas.handlingunits.storage.IHUStorage) ViewId(de.metas.ui.web.view.ViewId) IHandlingUnitsBL(de.metas.handlingunits.IHandlingUnitsBL) JSONLookupValue(de.metas.ui.web.window.datatypes.json.JSONLookupValue) IHUStorageFactory(de.metas.handlingunits.storage.IHUStorageFactory) IHUProductStorage(de.metas.handlingunits.storage.IHUProductStorage) IHandlingUnitsDAO(de.metas.handlingunits.IHandlingUnitsDAO) HUException(de.metas.handlingunits.exceptions.HUException)

Aggregations

JSONLookupValue (de.metas.ui.web.window.datatypes.json.JSONLookupValue)10 DocumentId (de.metas.ui.web.window.datatypes.DocumentId)3 ImmutableList (com.google.common.collect.ImmutableList)1 ImmutableSet (com.google.common.collect.ImmutableSet)1 IHUQueryBuilder (de.metas.handlingunits.IHUQueryBuilder)1 IHandlingUnitsBL (de.metas.handlingunits.IHandlingUnitsBL)1 IHandlingUnitsDAO (de.metas.handlingunits.IHandlingUnitsDAO)1 HUException (de.metas.handlingunits.exceptions.HUException)1 I_M_HU (de.metas.handlingunits.model.I_M_HU)1 I_M_Locator (de.metas.handlingunits.model.I_M_Locator)1 I_M_Warehouse (de.metas.handlingunits.model.I_M_Warehouse)1 X_M_HU_PI_Version (de.metas.handlingunits.model.X_M_HU_PI_Version)1 IHUProductStorage (de.metas.handlingunits.storage.IHUProductStorage)1 IHUStorage (de.metas.handlingunits.storage.IHUStorage)1 IHUStorageFactory (de.metas.handlingunits.storage.IHUStorageFactory)1 LogManager (de.metas.logging.LogManager)1 DocumentFilter (de.metas.ui.web.document.filter.DocumentFilter)1 SqlDocumentFilterConverter (de.metas.ui.web.document.filter.sql.SqlDocumentFilterConverter)1 SqlDocumentFilterConverters (de.metas.ui.web.document.filter.sql.SqlDocumentFilterConverters)1 HUIdsFilterData (de.metas.ui.web.handlingunits.HUIdsFilterHelper.HUIdsFilterData)1