Xero and Filemaker Inventory and PO Integration - filemaker

The company I work for in the the process of converting to Xero from MYOB. I'm currently developing a Filemaker database that will handle Estimates, Jobs, Inventory, Purchase Orders, and several other entities. I'm trying to work out the best way to sync Inventory items. We will have multiple stock locations, and product categories, in the Filemaker database, so according to https://developer.xero.com/documentation/api-guides/inventory-integration-options we should only sync inventory transactions, not inventory items.
The issue with this is that for the foreseeable future we will still be using ServiceM8 for the service side of the business. Filemaker is only used for estimates and jobs for the install side of the business, as well as purchase orders and inventory. ServiceM8 will still need to push invoices to Xero and adjust stock quantities accordingly. Is it a viable option to sync inventory items but just have an QuantityOnHand field in the filemaker database that is a sum of all the stock location quantities, and sync that with the Xero QuantityOnHand field?
Likewise there will be category fields in the filemaker product table that will not be seen in the Xero product table, but all product record creation will be done in Filemaker. Worst case I can periodically find any product records that do not have categories and enter them.
One other thing, I hope it's OK to put it in the same topic as it's related.:
Filemaker will handle purchase orders including Receiving multiple shipments. Would best practice be to POST the purchase order record to Xero when it's created and update the Status as necessary, or should I not use purchase orders in Xero at all and just do stock transactions?
Thanks,
Stew.

Related

notifying users of backend changes via subscription

My mobile app has users who are clients, business owners, and employees.
Each business owner can have multiple businesses.
Clients can create an order with one of the businesses. When they do, the business owner and employees who are linked with the business should be notified.
I have an orders collection where I create the order and I add the order doc id to an array of pending orders on the business record.
Notifying new order is mission critical, so I cannot depend only on push notifications. So I decided I’ll update the app via a db subscription to the user collection.
Sure, I can update an array of orders on records of the owner and employees linked with the business once the order is placed, but it becomes hard to manage when the owner may remove an employee from a business. It's repetitive when storing the order IDs in each employee’s record. It’s also expensive to keep updating these records when orders are processed.
How would you approach this?
UPDATE
I'm using Firebase
Another approach could be storing each order under the business ID, and then have each connected employee and owner listen to changes to that doc. However, it is possible that it will be more expensive as users will need to be listening to more documents than just their own user record.

Correct Schema design for following application

I am learning MongoDB, Express, React etc and am putting together a simple application to do so but am stuck on the schema design.
The application will be a money manager where users will be able to sign up, then fill in their monthly income (salary and any other income), and regular expenditure. This will provide an amount they are able to spend each month.
The user can then enter transactions throughout the month, the application will log these, which will deplete the monthly allowance to provide the user with a snapshot of their funds available to spend.
I am just stuck on how to structure the schema.
Do I have a separate database for users, expenditure and income, and associate the expenditure and income with the user via the user's _id value?
Or should the expenditure and income be tracked in the same database as the user?

Optimize Reads or Insert

Our company has a mongodb collection of millions merchants and billions of products.
A merchant can choose to go hidden after which their products shouldn't be visible to the public.
I am wondering the best way to implement this:
I could update all the products of the user to have a hidden status.
I could update the merchant to have a hidden status and read the status of the merchant for every product request to know if to show or not.
What has been your experiences if you have encountered this dilemma or what would you suggest is the best engineering approach.
Since it's the merchant who's going hidden and not individual products, you should put the status on the merchant.
So option 2 in your question.
If you haven't yet implemented 'hidden' in your db, add it to your table as NULLable with a default of FALSE. Then in your query to find products of visible merchants, you can just put where NOT merchant.hidden OR merchant.hidden IS NULL. That way, when you add it to your db, you don't need to update it for the millions of others merchants who are non-hidden.
Often Mongo design depends on how you are going to access the data.
if you select a merchant then their products put the hidden field in the merchant.
If you select a sub set of products independent of the merchant you will need it in the product table.

How to send customised information through an automated email in netsuite

Using Netsuite, I want to use Historical ordering data per customer to automate emails which tell customers about products or promotions
i.e. if the customer has ordered product X in the last 3 months, send them an email that its out of stock, or if they ordered product Y in the last 3 months, also tell them product Y is discounted
Does anyone know the best way to customise an email using data within Netsuite data so they are personalised per customer?
The other option is to send an order confirmation when they place an order with the customised information as part of this confirmation
The logic is simple, I would just like the best advice on implementation
You can write a schedule script that runs on predefined schedule and then pull the customers based on your saved search logic and send mail individually to every customer using nlapiSendEmail()

How to get customer id KUNNR of current Launchpad user?

I am writing a custom Fiori to access sales data from an SAP ERP backend system using a Gateway.
The use case is "customer logs in launchpad, opens Fiori app and sees all his/hers sales items based on the customer id". The customer id is stored in kna1-kunnr and has to be included in a select on the vbak table in SAP. Nothing fancy.
Now I ask myself: how do I get the customer id / kunnr? What do I get at all from the currently logged in user? When debugging my Gateway project code, is it actually the name stored in sy-uname or can I get something better?
How should I continue to get the customer id / kunnr? Are there some function modules like GET_CUSTOMER_ID_OF_USER to call in the SAP ERP?
Or are the actually other / better ways to get the sales documets for one user?
Update
Thank you for your answers so far. I am going to check the default Fiori implementations to get some inside. But, since we are already here, I want to specify my question a little bit more:
Giving I create an OData model in my Component.js like that:
var oModel = new sap.ui.model.odata.ODataModel("[...]/sap/opu/odata/sap/Z_MYODATA_SRV/",
false, "user", "password" );
user and password are supposed to be the ones currently entered as user credentials in the Fiori Launchpad. How can I access those? Are there some SAPUI5 api like getCurrentUser or getCurrentSession ? Do I actually have to do this user check?
You are correct that to identify all of the sales orders for a customer you need to read them from VBAK (or use BAPI_SALESORDER_GETLIST, etc).
The relationship between logged in user and customer is not something that's the same in every SAP ECC system. You may find that the logged in user is the same as the customer number, but with a prefix - for example, logged in user C12345678 for customer 0012345678. Or there may be some other type of relationship that's store in a custom field on the customer master itself. The best option is to check with the person responsible for the configuration in Sales and Distribution. Only then can you know how to determine the customer for a logged in customer user.
Answering your question
Now I ask myself: how do I get the customer id / kunnr? What do I get at all from the currently logged in user?
It is done on backend with standard customizing, not via OData methods like you intend to do it.
Mikael gave you the rough idea, but didn't finished it so I will give a more comprehensive answer.
We need to differentiate between front-end and back-end authorizations, for Fiori app functioning you need to types of roles/authorizations:
The SAP Fiori roles that define which Fiori apps are displayed to the user
Launchpad authorizations
General OData authorizations
Trusted RFC back-end connectivity authorizations
Back-end authorizations and roles which contain authorizations to display the related business data
This concept is depicted on this figure:
The assignment of the front-end is described here and is out of scope now. Now we are focusing on bullet 2.
Every Fiori app has its role model and one should follow the implementation given in app description. Let's consider how it is done based on Sales Order creation app (F0018) sample:
OData service that returns business-data is SRA017_SALESORDER_CREATE_SRV, so to run it one needs frontend role SAP_SD_BCR_FIELDSALESREP_X1 and backend role SAP_SD_SO_CRE_APP
Also app description give us the following prerequisits:
Before implementing the Create Sales Order app, you must ensure the following:
That an employee master record is created with the following attributes:
If you have implemented SAP ERP HCM and maintained employees in the HCM personnel records, ensure that the employee personnel record has the infotype Communication, with a subtype of System User Name (SY-UNAME) (Infotype 0105, Subtype 0001).
If you have not implemented SAP ERP HCM, implement the Sales and Distribution configuration around Use Sales Employees with HR (Tcode: PULT). This IMG setting copies the appropriate HCM tables from the 000 Client and allows the setup of the employee record with the Infotype Communication and a Subtype of System User Name (SY-UNAME) (Infotype 0105, Subtype 0001).
It associates the USERID of the employee with the personnel number assigned as a partner function sales employee in the customer master.
After implementing the above customer SAP user id will be bound to his employee ID (PERNR), and his employee ID consequently will be bound to partner function in XD02.
And that's not all, what comes next?
THe following order parameters should be maintained in in SIMGH tcode in order customer to see his orders and can create the new ones.
Call transaction SIMGH to open the Create Sales Orders node and configure user information in Customizing activity Define Configuration Parameters using the parameters listed below. For more information, see the documentation available for the Customizing activity.
Document Type (DOCTYPE)
By default, the app uses the standard order document type (technical key TA resp. OR). Changing this to something other than a sales order may significantly impact the functionality of the application.
Order Period (ORDPERIOD)
This defines how many days into the past sales orders are retrieved. The suggested value is 30 days.
Search Period (SEAPERIOD)
This defines how many days into the past a search must look for sales orders that match the search criteria. The suggested value is 90 days.
Ship To Party (SHIP_TO/PARTNER_ROLE)
This defines which partner role in the customer master is used for the ship-to party. The suggested value is WE.
Forwarding Agent (FORWARDING_AGENT/PARTNER_ROLE)
This defines which partner role in the customer master is used for the forwarding agent. The suggested value is SP.
and even that's not all
App description gives the following BADIs to implement in order to enable such linking
Implement the following BAdIs:
Customer Association to Employee
You can use this BAdI to associate employees with specific customers.
Only after all the above steps the customer will be able to order and/or view his sales items.
The moral: always check the app description thoroughly because the role model varies per-app.
Have a look at the standard Fiori applications. For example, in Create Sales Order, there is a BADI provided to implement the relation you are looking for (but for an employee to a customer). In the standard setup, the partner functions of the customer master is used to map what customers are visible to an employee.
Most likely, you have a similar setup already in place if your customers actually have user accounts in your system. If could be as a parameter of the user or as a (custom?) partner role.
http://help.sap.com/saphelp_fiorierpx1_100/helpdata/en/6d/135652f9c21457e10000000a445394/content.htm