Last updated
Last updated
There are situation were it makes sense that you use your own backend API to calculate prices. Maybe there are already existing API endpoints you want to reuse, or you do not want to encode your pricing logic inside client side JavaScript or you want to enable price calculation along the whole Roomle Platform and not only in embedding case. In those situations it could make sense to think about connecting your backend API with our Rubens frontend. Then the flow is the following: Rubens UI calls the Roomle Backend, the Roomle Backend looks if there is a custom endpoint provided and forwards the request to your custom endpoint. Then the endpoint returns to the Roomle Backend and the Roomle Backend returns the response to the Rubens UI.
To setup this process you have to do some steps (we will cover them in more detail later):
you need a configurable product that produces a part list
inside of this part list there should be article numbers
Login to
make sure you are Super Admin of the tenant
go to Tenant Settings and enter the section Price Services
Add a price service entry
Add the correct JSON (we will see later in the example what do to)
Make sure that there is an endpoint behind the URL you specified in the JSON in step 7
To test it, call the Configurator or Room Designer with the correct Embedding ID
Lets add a component with the following Roomle Script:
To make it more fun, we calculate a dynamic article number. In real world most products will have static article number but to illustrate what's going on it's better for understanding. The article number will be constructed out of the dimensions, so if the cube is configured to a width, depth and height of 1000mm the article number will be 1000x1000x1000. This logic we will use later in our custom price calculation service.
Now since we want to test the component also somewhere we will create a configurable item. Therefore we create a new product and add the following Roomle Script:
We give the product the ID: external-price-service:cube
To see if we assembled everything correctly just open the Configurator with:
https://www.roomle.com/t/cp?id=external-price-service:cube
Now we should see a cube and when we open the part list we should see one entry with the article number that is constructed out of the current dimensions
Add a new Price Service Entry with the following JSON:
For this example we use Google Cloud Functions and create a simple function that returns a price for us. The following code is only an example and shows only the parts needed (no error handling, validations etc):
To test this endpoint we simply call the URL: <YOUR_ENDPOINT_URL>?articleNumbers[]=1000x1000x1000
, in our case it should return the following JSON:
It is important to mention that the returned JSON needs to be in the following structure:
Now everything should be setup correctly. Therefore we can check it with the correct embedding settings. It's important the you use the correct embedding ID and turn on "usePriceService" inside your Tenant Settings > Rubens Settings > Editor, or add to to the url usePriceService=true
as in the example below.
You can now see that there is a price for the object we have added in the product list (the right button in the bottom). When you add another item you can see that they are distinguished in the products list because they have no price.
As described above, login to and enter Tenant Settings > Price Service
The example I outlined above can be tested live here: