- Print
- PDF
Language texts are a Lasernet FO Connector functionality that enables users to create custom labels or translations when the existing system labels do not work well for their requirements.
Users can create Language texts as part of the Lasernet Configuration for each entity and then migrate this configuration to other entities as required.
Once Language texts have been created, they can be added to specific reports so that the translations in the Language text appear in our outputs.
How Does It Work?
Language texts enable users to create their own labels and translations in the system. For example, the following is a Sales Confirmation report shown in the Lasernet Developer, run in the language en-us:
The report language in the XML under the JobInfo node is ReportLanguage:
In this report, the output for the label in the second column is Description.
If we open FO and run the report in another language, such as French, although the other labels are updated, the label for Description remains the same.
This may not be the label that the customer wants to use in the French language version of their report. Language texts are the tool we can use to fix this issue.
Language Text Configuration
In order to control the output of a report in the Lasernet Developer, we need to navigate back to FO, where Language texts are configured within the Lasernet module itself. To do this, follow these steps:
Navigate to Lasenet > Setup > Language Texts.
This will open the Language text form.
The description of the elements of the form is as follows:
Element no. and name | Description |
---|---|
1 - Default Language | This is the basis for all of the configuration we are doing in Language texts, this is usually set to en-us and acts as our baseline for us to convert from. |
2 - Text ID | This is an ID field which is used by the system to identify the Language text, the system IDs will be in the @SYSXXXX format, any custom Language texts the ID can be defined as something more obvious - like in point 7. |
3 - Text | The text in the default language which was set in point 1. This also counts as a translation for that language so it is the label that will be used if the report is run in the default language which is en-us in this example 3. |
4 - Text ID | This is an ID field which is used by the system to identify the Language text, the system IDs will be in the @SYSXXXX format, any custom Language texts the ID can be defined as something more obvious - like in point 7. |
5 - Default Language | This is the basis for all of the configuration we are implementing in Language texts, this is usually set to en-us and acts as our baseline for us to convert from. |
6 - Text | The text in the default language which was set in point 1. This also counts as a translation for that language so it is the label that will be used if the report is run in the default language which is en-us in this example. |
7 - Custom Text ID | The same as point 2 but created with a label that is easier to recognize. |
8 - Translation language | This is the language we want to translate to. |
9 - Translated text | This is the actual text in the translated language. |
For example, we could receive a requirement to create a new label for a custom Roasting Order report for a chocolate producer. The producer is based in the United States but roasts cocoa in three different locations - Spain, Germany, and France. The new report is for a roasting order for cocoa and needs to be printed in the local language at each location.
We need to create a new ‘Roasting Order’ label and three translations for their new report. To do this, we would navigate to the Language text form using the previous steps and create the following setup:
The description of the elements of the form is as follows:
Element no. and name | Description |
---|---|
1 - Text ID | The text ID we have created for this Language text - for simplicity it has been made the same as the text in the default language. |
2 - Text default language | This is the text in the default language (en-us). |
3 - German translation | This is the German translation. |
4 - French translation | This is the French translation. |
5 - Spanish translation | This is the Spanish translation. |
If several custom labels need to be created, we must obtain a list of all the labels and translations at the start of the project and create them with the Language text functionality. Whilst it is possible to add these Language texts later on in the form structure, it is easier to do it in the Language text form.
Add a Language Text to a Report
In this example, we are adding the label to the Sales Confirmation report:
Navigate to Lasernet > Common > Reports.
Either search in the list or use the Filter functionality to search for the SalesConfirmReplacement report:
Select the report, then click Setup > Structure.
Alternatively, to get to the structure form, click the blue highlighted link on the reports list page.
Once in the Structure Form, we can see the report structure on the left, which mimics the structure of the XML message sent to the Lasernet Developer. On the right, we can see the contents of the structure node we have selected.
Usually, the report templates will have a part of the structure already created for labels. Here, it is called FPHeaderLabels.
Element no. | Description |
---|---|
1 | This is the breakdown of the report structure, which should mimic the query structure and will define the eventual structure of the XML which is produced. |
2 | This is a node within the structure. In the example here the Sales table is the name of the node and will contain the labels, the detail collection a list of all the detail sections and the detail section is where the field values will be. |
3 | The name of the report. |
4 | This is the name of the section of the structure you are in. |
5 | This is the name of the field in the structure, it is just a reference. |
6 | This is what the field will be called in the XML output. |
7 | This is the expression that defines what is in the field. |
Once we have selected the correct section, we can add a new field for the Language text.
Click the New button.
Fill in the Name, and the Output. Then, in the Expression column, click the drop-down menu and select Language text.
Click the the dropdown again and the following screen will appear:
Here, we can see a list of the Language texts existing for this legal entity with the Text ID, Text, and Translations that were seen earlier.
Select the appropriate Language text (Roasting Order in this case) and click Use Language text.
The report structure form will be updated with the new Language text.
In order for these changes to take effect, click Save in the top left hand corner, then exit the report structure form. This takes you back to the reports list page where there should be a notification that the style sheet has updated, which means the changes have been applied.
If the report is run, then there will be a label in that new field in the FPHeaderLabels section of the XML with the correct translation based on the report language.
Here is the XML in the Lasernet Developer once the report is run, and we can see that because the report language is English - the English translation is shown.
Click Rearrange to add this data as a rearrange to the form output.
Select the node of the XML with the new Language text in it and then the new rearrange will appear on the right-hand side of the screen where we can click and drag it to wherever we want it to show.
Here, the new label has been positioned next to the Roasting Order number in the header of the report:
If the ReportLanguage changes to German, then when the report is run, the label also updates.
This is the same for the other language, Spanish.
This is how to create custom labels on report formats that automatically update based on the language.
Overview
Below is an outline of the steps covered above:
Create a new Language text:
Create the text.
b. Add the translations.
Add the Language text to the report query:
Find the correct part of the structure.
Add in the Language text expression.
Add the Language text to the report form:
Run the report to generate the grab file.
Find the Language text in the XML.
Place the rearrange on the form output.
Change report language to update labels:
a. Change the language of the report and see the label update automatically on the form.
Copy Configuration to Other Companies
The configuration above is company-specific: the Language text setup is carried out on a company-by-company basis. The queries are company-specific as well. Therefore, if you create a Language text in company A and refer to it on a Query in company A, then copy that query to company B, the link to the Language text will be lost.
To avoid this, copy your Language text configuration across companies. Once your Language texts have been configured in one company, follow these steps:
Navigate to Lasernet > Common > Backup > Copy Lasernet Reports and Configuration to Other Companies.
Select the option highlighted in the following image.
In the form, all the reports and none of the tables are selected by default. Deselect all the reports, and select the Lasernet Language Text and the Lasernet language text - report grouping tables.
Click OK, and in the next form select the companies you wish to copy the Language texts over to. If there are many companies, its recommended not to do more than ten at a time.
Click OK > OK.
The configuration will be copied over to the company selected. If you open the company that the configuration was copied to, we can see our Language text setup available in that company.
For further information, watch these videos: