-
Notifications
You must be signed in to change notification settings - Fork 1.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Languages order preference #5826 #6059
base: main
Are you sure you want to change the base?
Languages order preference #5826 #6059
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Since yesterday I am testing your branch. Would you know why the description was not in Slovenian for the item shown in the screencast below?
screen-20241222-173415.mp4
Is it just for slovenian or is it simply not working at all? Ill check everything again and let you know. |
@nicolas-raoul Just got back from work, I'll look into it today. I'm not sure why this is happening right now. In the meantime, is there an easy way of checking what SPARQL queries were being submitted? |
Yes, all queries are visible in logcat. 🙂 |
Hi @nicolas-raoul can I continue this in the weekend. Im not getting any time right now. |
Actually since tmr is a public holiday I can see to it. |
Also fixes the settingsFragment to select different primary and secondary description labels.
Update 2
@nicolas-raoul I made some changes, could you please check again? |
I think the problem was that the nearby controller was taking the Locale default language as the default description language instead of the default description stored in prefs. Also I fixed an issue with my secondary dialog setup, now it makes sure that the primary description language cannot be selected in the secondary description language selection aswell. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Testing your latest commit now. Any idea why the description is in Slovenian here rather than German? Thanks! 🙂
https://m.wikidata.org/wiki/Q11378229
screen-20241229-080322.mp4
val selectedLanguageName = languagesAdapter.getLanguageName(position) | ||
|
||
if (savedLanguages.any { it.languageCode == selectedLanguageCode }) { | ||
Toast.makeText(requireActivity(), "Language already selected", Toast.LENGTH_SHORT).show() |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It would be great to internationalize this.
Unfortunately it seems like pin label (not just description) is sometimes wrong too. In the screencast below, the label is shown in Turkish (Shirokane Parkı) even though in my settings the first language is English and secondary is Japanese, and the Wikidata item has a Japanese label. Any idea what might be the problem? screen-20250125-221759.mp4 |
If you don't have time for this anymore, please feel free to let us know, someone may be happy to continue your hard work. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
(redacted)
I am so sorry, please ignore my last message about Wikidata linking, it was meant for another pull request. |
Description (required)
Fixes #5826
What changes did you make and why?
Very similar to my original PR, except changes made are now made to the kotlin files rather than the old java versions.
Added a new preference category in the preferences UI for secondary language picking
Prefs was also changed to hold a serialised string of secondary language codes
Strings.XML:
Added new strings that represent additions in UI
SettingsFragments (Kotlin)
Had to accommodate new preference in OnCreate
Made a new dialog called prepareSecondaryLanguagesDialog().
Made helper methods for that dialog that use a new language adapter SavedLanguagesAdapter
modified saving and getting key value methods to accommodate the new category in Prefs
NearbyController and NearbyPlaces: (Kotlin)
Injected the KV store into the controller and passed the serialised string as a new argument to the json API client in NearbyPlaces
OkHttpJsonApiClient: (Kotlin)
changed the getPlaces method to make use of the new parameter (the serialised language code)
made stringbuilders (the kolin equivalent) to automatically generate further SparQL queries based on the serialised code list
(Also modified the SparQL file itself to add placeholders for the additional strings created by the method)
Tests performed (required)
Same as last PR
Tested {build variant, e.g. ProdDebug} on {name of device or emulator} with API level {API level}.
Screenshots (for UI changes only)
Need help? See https://support.google.com/android/answer/9075928
Note: Please ensure that you have read CONTRIBUTING.md if this is your first pull request.