Based on a copy of the language “Nederlands” (NL) we introduced the new language “Vlaams” (NL-BE) in TSF. The differences between “Nederlands” and “Vlaams” we translated specifically into specific Flemish words.
In TSF we added NL-BE as an additional language via "Projects | Project overview | tab Project versions | tab Application languages”.
But when exporting the application model to a script file to be able to import it in IAM on the production server, we noticed that the translations for the language NL-BE were not there.
Apart from the wrong value for ‘appl_lang_id’, I think that the parameter 'type_of_object’ should be of type integer (int) so I removed the quote (‘) in front of the value. And I added a quote (‘) in front of the value for 'transl_object_id’
CONCLUSION:
The problems seems to be in the SP get_gui_transl_full. Since we are passing the value ‘NL-BE’ to the parameter @appl_lang_id, we are getting results for ‘NL’. I dived into the code of the SP get_gui_transl_full and found the issue.
/****** Object: StoredProcedure cdbo]."get_gui_transl_full] Script Date: 25-10-2022 10:53:18 ******/ SET ANSI_NULLS ON GO
SET QUOTED_IDENTIFIER ON GO
ALTER procedure Ddbo].Iget_gui_transl_full] ( @project_id project_id , @project_vrs_id project_vrs_id , @platform platform , @appl_lang_id appl_lang_id ) as begin
-- Do not count affected rows for performance SET NOCOUNT ON
-- >> TOEGEVOEGD DOOR <COLLEGA> OM NL TE LATEN WERKEN IN MOBILE GUID OVER SF SET @appl_lang_id = 'NL' -- <<
--control_proc_id: sf_proc_get_gui_procedures --template_id: sf_proc_get_gui_procedures_select --prog_object_item_id: get_gui_transl_full_select --template_desc: Control procedure for generating all get gui procedures
--control_proc_id: sf_proc_get_gui_procedures --template_id: sf_proc_get_gui_procedures_default_where --prog_object_item_id: get_gui_transl_full_where --template_desc: Control procedure for generating all get gui procedures
where t1.project_id = @project_id and t1.project_vrs_id = @project_vrs_id and (t1.appl_lang_id = @appl_lang_id or @appl_lang_id is null)
end GO
SOLUTION:
Looking at the code I found the problem! Someone (I won't mention names) changed the code in the get_gui_transl_full by overriding the value for @appl_lang_id. Let me say it nicely: “Not so happy about that, but it is what it is.”
I removed the manually added line and tried the default sync process from TSF again and now it works!!!!
Thank you for your support. Without your code I would never ever have found the cause of this problem.
No problem Johan, you're welcome
Hi Johan,
During Synchronization to IAM, all translations regardless of language will be synced, but I think the Flemish translations are unusable due to the absence of the language in the base table inside IAM.
Can you add the language in IAM > Advanced menu > Master data > Languages? I do think that should make it work:
Hi Mark,
In IAM on the production server this language NL-BE (Flemish) is already added. Probably because in the exported model (SQL script file) there is this line:
But that is the only line in the exported script file that contains “NL-BE”.
Or do I have to add this language as well in IAM for TSF? Because there I only see this (via Advanced menu > Master data > Languages):
But there is no option to add a language here. I am a bit confused now. Any more suggestions (By the way: I have no clue why the language zh-CN - whatever that is - is there)? Thnx!
Ah, it appears that this is not a base table but rather a view that shows a collection of all used languages in applications. Therefore Flemish should also be visible in this screen. Which platform version are you running?
Hi Mark, we are stil using 2018.3.
Hi Mark, we are stil using 2018.3.
Ah, that version is already quite a while ago. The synchronization probably was quite different back then, I'll look into it on Monday as I don't know the solution at the moment.
Hi Johan,
It looks like the Synchronization back then was fully integrated in the Windows GUI and I am not able to find the code it runs to construct the Synchronization script. However, I tried with a test project and the new language does end up in IAM after syncing.
I added the language here:
It requires the language to exist, if not create it via the lookup:
I simply translated all objects using the Translate task:
In IAM I started to synchronize the SF model to a script:
Inside IAM I see this:
This should mean the language has ended up successfully inside IAM, but in your screenshot this hasn’t happened. Did my step-by-step list a step you might have skipped?
Hope this helps!
Hi Mark,
I followed the same steps already a while ago. The only difference is that in IAM (production server) the list of translations is empty. No (pre)filters set!
But that is logical since the generated script file that exports the model does not contain the translations. The language itself is being exported (EXEC sync_appl_lang is there), but the translations are not (EXEC sync_transl_full is NOT there).
It must be a small issue why they are not being exported. But what??? It is still not working. Any more suggestions?
Hi Johan,
Tried my best but I'm unable to see what the issue could be. For what I can see it calls the get_gui_transl_full procedure to obtain all translation data. Therefore it should also obtain the added language. Last thing I can think of is running all hotfixes available and retrying.
For some odd reason I don't see the synced project appearing in IAM, but since this is an unsupported version I won't not be looking into this any further.
Would it be possible to upgrade to the newest version? If that is a bit quick you can also wait till we release the 2023.1 version of the platform which is scheduled to be released in the second half of Q4.
I wasn’t a Main administrator and therefore unable to see the data. Now it works...:
Hi Mark,
Thank you for doing everything you could.
Upgrading to the latest version of the platform is a concideration, but that can not be done quickly.
Because we created the language with a script and not within TSF itself, we might have forgotten to update or insert a record in some table. Can you please ask a colleague to help you out with this?
Thnx!
Hi Johan,
You can try this script, execute this on your SF database. This results in a list of execute statements which you can run on your IAM database:
declare @project_id project_id = '' -- Your project name , @project_vrs_id project_vrs_id = '' -- Your project version , @platform platform = 0 -- Windows (1 = Web, 2 = Mobile) , @appl_lang_id appl_lang_id = 'NL-BE' -- Language
*Note, this is only the Full translations, if you want to obtain the Nav translations, you can alter the script a little to become "EXEC sync_transl_nav...” and obtain data from "get_gui_transl_nav” procedure. Temp table structure can be the same I believe.