Navigation
Introduction
Only page, css and js types can be accessed with the url. Regular implementation url’s in the editor would look like this
{instance}/{clientCode}/en/editor/my-products-page
This would be accessible from
{instance}/{clientCode}/en/my-products-page
Note that -page
suffix is not required and a link without it would still be routing to the correct location
{instance}/{clientCode}/en/my-products
Public / B2B
If the public features are used then the endpoint would prefix it with public
{instance}/public/{clientCode}/en/my-products
Sub paths for navigation
We can use the sub paths for navigation inside the templates.
Usually 3 extra sub paths can be used. We can access the path values with an indexed value from the path.
We can then access the values using
{{ .Data.Parameters.path1 }} // test1
{{ .Data.Parameters.path2 }} // test2
{{ .Data.Parameters.path3 }} // test3
Goerp has a special parameter that can be used to get the last path parameter as well (all content after the last non-encoded /) https://template-engine-eu10.erply.com/public/104146/et/some-page/test1/test2/test3/test4%2Ftest5
{{ .Data.Parameters.pathx }} // test4%2Ftest5
These routes will always navigate to the parent page, but we can set up special rules in the page to make some changes based on the path parameters.
{{ if eq .Data.Parameters.path1 "test1" }}
{{ template "my-route-a-partial" . }}
{{ else if eq .Data.Parameters.path1 "test2" }}
{{ template "my-route-b-partial" . }}
{{ else }}
{{ template "my-default-partial" . }}
{{ end }}
We can use the tools helper to make navigating sub paths easier
{{ if .Tools.IsPath "my-route-a" }}
{{ template "my-route-a-partial" . }}
{{ else .Tools.IsPath "my-route-a/my-route-b" }}
{{ template "my-route-b-partial" . }}
{{ else .Tools.IsPath "my-route-a/my-route-b/my-route-c" }}
{{ template "my-route-c-partial" . }}
{{ else }}
{{ template "my-default-partial" . }}
{{ end }}