AICC/CMI-5_Spec_Current

`languagePreference` would be much easier to handle as an array

brianjmiller opened this issue · 5 comments

This is currently a comma delimited string and it would be much better to capture a list of values in JSON as an array.

I would prefer it if the language preference requirements are removed in the next major release.

Every modern OS allows the user to set their language preference, these preferences are then made available to the applications running on that operating system.

An AU should use the user preferences set in the OS or browser.

I understand the counter argument that a user might be using someone else's device (like at an Internet cafe whilst on holiday) and they might have different language preference from the owner of the device. However I think that is a very rare scenario and it is very simple for the user to change the language in the OS or browser.

I'm not opposed to that.

As it stands, the language preference requirement is referring to the wrong place in the xAPI spec (currently it should be pointed to 4.2, and in the future it should be pointed to 5.2.7), but both of those are actually "Language Maps", which is a dictionary, not an array. At very least even if we don't change anything else, I think we should remove the reference to the xAPI spec completely and just say they're RFC5646 language tags.

I think we should remove the reference to the xAPI spec completely and just say they're RFC5646 language tags.

@gavbaa would you open a pull request for this, I think it would be a good change.

Per Feb 16, 2024 meeting

  • Consider deprecating existing Key and added an new Key (as an array)
  • Not a high priority (as it is a backwards compatibility breaking change)