What's working: - Address information on OP - Reading of S/4HANA Addresses - Translations
76 lines
2.1 KiB
JavaScript
76 lines
2.1 KiB
JavaScript
const cds = require('@sap/cds')
|
|
const { Books, ShippingAddresses } = cds.entities
|
|
|
|
const bupaSrv = cds.connect.to('API_BUSINESS_PARTNER')
|
|
|
|
/** Service implementation for CatalogService */
|
|
module.exports = cds.service.impl(function () {
|
|
this.after(
|
|
'READ',
|
|
'Books',
|
|
each => each.stock > 111 && _addDiscount2(each, 11)
|
|
)
|
|
this.before('CREATE', 'Orders', _reduceStock)
|
|
this.before('CREATE', 'Orders', _fillAddress)
|
|
|
|
this.on('READ', 'Addresses', _readAddresses)
|
|
|
|
// this.after('READ', 'Orders', (data, req) => {
|
|
// if (req.query.SELECT.columns.includes('shippingAddress')) {
|
|
// data.shippingAddress = _readAddresses()
|
|
// }
|
|
// })
|
|
})
|
|
|
|
function _readAddresses (req) {
|
|
// TODO: Delegate to external service
|
|
return [
|
|
{ AddressID: 'add1', CityName: 'Walldorf', StreetName: 'ExampleStreet' },
|
|
{ AddressID: 'add2', CityName: 'Schwetzingen', StreetName: 'BestStreet' }
|
|
]
|
|
}
|
|
|
|
/** Add some discount for overstocked books */
|
|
function _addDiscount2 (each, discount) {
|
|
each.title += ` -- ${discount}% discount!`
|
|
}
|
|
|
|
async function _fillAddress (req) {
|
|
console.log('filling addresses')
|
|
if (req.data.shippingAdress_AddressID) {
|
|
const tx = bupaSrv.transaction(req)
|
|
const result = tx.run(
|
|
SELECT.one(['AdressID, CityName, StreetName, HouseNumber'])
|
|
.from('A_BusinessPartnerAddress')
|
|
.where({ AddressID: req.data.shippingAdress_AddressID })
|
|
)
|
|
if (result) {
|
|
const tx2 = cds.transaction(req)
|
|
console.log('filling addresses for real')
|
|
tx2.run(INSERT.into(ShippingAddresses).entries([result]))
|
|
}
|
|
}
|
|
}
|
|
|
|
/** Reduce stock of ordered books if available stock suffices */
|
|
async function _reduceStock (req) {
|
|
const { Items: OrderItems } = req.data
|
|
const all = await cds.transaction(req).run(() =>
|
|
OrderItems.map(order =>
|
|
UPDATE(Books)
|
|
.set('stock -=', order.amount)
|
|
.where('ID =', order.book_ID)
|
|
.and('stock >=', order.amount)
|
|
)
|
|
)
|
|
all.forEach((affectedRows, i) => {
|
|
if (affectedRows === 0)
|
|
req.error(
|
|
409,
|
|
`${OrderItems[i].amount} exceeds stock for book #${
|
|
OrderItems[i].book_ID
|
|
}`
|
|
)
|
|
})
|
|
}
|