Skip to content

adaptlearning/adapt-contrib-languagePicker

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

adapt-contrib-languagePicker

Language Picker is an extension bundled with the Adapt framework. It is not yet compatible with the Adapt Authoring Tool.

Language Picker is intended to be used with courses that provide content in more than one language. Prior to entering the course, the learner is presented with a group of buttons. Each button is labelled with a language. Clicking a language button loads content in the chosen language.

Language Picker allows the learner to switch languages while the course is in progress. Clicking the icon in the navigation bar reveals the Language Picker in the Drawer.

Visit the Course Localisation wiki for more information about how to localise Adapt courses.

Installation

As one of Adapt's core extensions, Language Picker is included with the installation of the Adapt framework.

  • If Language Picker has been uninstalled from the Adapt framework, it may be reinstalled. With the Adapt CLI installed, run the following from the command line:

    adapt install adapt-contrib-languagePicker

    Alternatively, this extension can also be installed by adding the following line of code to the adapt.json file:

    "adapt-contrib-languagePicker": "*"

    Then running the command:

    adapt install

    (This second method will reinstall all plug-ins listed in adapt.json.)

Settings Overview

This extension is configured in config.json with the attributes that follow. The attributes are properly formatted as JSON in example.json.

Attributes (config.json)

The following attributes are set within config.json.

_languagePicker (object)

The languagePicker object that contains values for _isEnabled, title, displayTitle, body, _showOnCourseLoad, _languagePickerIconClass and _restoreStateOnLanguageChange settings and the _languages array.

_isEnabled (boolean)

Enables/disables this extension. The default value is false. Set this to true to enable this extension.

title (string)

Browser window title text. For example, "Language selection".

displayTitle (string)

Header text. For example, "Please select a language."

body (string)

Introductory or explanatory text. For example, "Welcome to ACME Learning. This course is available in several languages. Please make a selection."

_graphic (object)

The graphic object that contains values for \src and alt. Typically used to display a logo image

src (string)

File name (including path) of the image. Path should be relative to the src folder (e.g., course/en/images/logo.png).

alt (string)

A description of the image; required when it has meaning that must be conveyed to the learner. For 'decorative' images, leave this blank

_backgroundImage (object)

The backgroundImage object that contains values for _xlarge, _large, _medium, and _small.

_xlarge (string)

File name (including path) of the image used with xlarge device width. Path should be relative to the src folder (e.g., course/en/images/background.jpg).

_large (string)

File name (including path) of the image used with large device width. Path should be relative to the src folder (e.g., course/en/images/background.jpg).

_medium (string)

File name (including path) of the image used with medium device width. Path should be relative to the src folder (e.g., course/en/images/background.jpg).

_small (string)

File name (including path) of the image used with small device width. Path should be relative to the src folder (e.g., course/en/images/background.jpg).

_backgroundStyles (object)

Additional attributes to customise how background images are displayed. The _backgroundStyles object can include the following properties:

_backgroundRepeat (string)

Defines how the background image repeats. Options include:

  • repeat: The background image is repeated both vertically and horizontally.
  • repeat-x: The background image is repeated only horizontally.
  • repeat-y: The background image is repeated only vertically.
  • no-repeat: The background image is not repeated.
_backgroundSize (string)

Defines the size of the background image. Options include:

  • auto: The background image is displayed in its original size.
  • cover: Resize the background image to cover the entire container, even if it has to stretch or crop the image.
  • contain: Resize the background image to make sure the image is fully visible.
  • 100% 100%: Resize the background image to match the dimensions of the container.
_backgroundPosition (string)

Sets the position of the background image. Options include:

  • left top
  • left center
  • left bottom
  • center top
  • center center
  • center bottom
  • right top
  • right center
  • right bottom

The first value is the horizontal position and the second value is the vertical position.

_showOnCourseLoad (boolean)

Determines whether the language picker will be displayed on course load. If set to false, the course will load with the default language selected and the user will need to use the icon in the navigation bar to change languages. The default value is true.

_languagePickerIconClass (string)

Defines which icon will be displayed in the navigation bar. The vanilla theme supports the following icon styles: "icon-globe", "icon-language-1", "icon-language-2". The default value for this setting is "icon-language-2".

_restoreStateOnLanguageChange (boolean)

Determines whether or not the language picker will try to restore the 'state' of the course when the user changes language. It is advised that you only set this to true if all course languages have exactly the same structure; if they do not, some loss of tracking data will occur. If set to false, all tracking data will be cleared when the user switches language - the warningMessage (see below) should be used to warn the user of this. The default value is false.

_languages (array)

The languages array contains the list of the available languages and the various settings associated with each. Each entry in the array should be an object, containing the following settings:

_language (string)

This text must match the name of the language-specific folder located in the course root, for example, "en" from course/en. It is used as the value for the HTML lang attribute. It is highly recommended that codes for web languages be used. Reference a source such as the IANA Language Subtag Registry.

_direction (string)

Specifies the value of the HTML dir attribute and, consequently, the base direction of text. Acceptable values are "rtl" (right-to-left) and "ltr" (left-to-right). The default value is "ltr".

_isDisabled (boolean)

Setting this to true allows the language to be shown in the list but in a 'disabled' state (so it cannot be selected). This can be useful in situations where localisation into a particular language has not yet been completed. The default value is false.

displayName (string)

The display name of the language. This value is used as the button label.

warningTitle (string)

This text appears as the header of the dialog confirming the learner's intent to change languages, for example, "Change language?".

warningMessage (string)

This text appears as the body of the dialog confirming the learner's intent to change languages, for example, "Changing the language will reset course progress.<br><br>Would you like to proceed?".

_buttons (object)

The buttons object contains the following settings:

yes (string)

Label for the button that confirms the learner's intent to switch languages.

no (string)

Label for the button that cancels the switch languages dialog.

Attributes (course.json)

The following attributes should be added to course.json under _globals._extensions.

_languagePicker (object)

The languagePicker object that contains values for navigationBarLabel, languageSelector and _navTooltip that contains _isEnabled, text.

navigationBarLabel (string)

Label shown next to the language picker button when navigation bar labels are enabled. Defaults to Language picker.

languageSelector (string)

Aria label that appears at the top of the drawer displayed when language picker button is clicked. Defaults to Language selector.

_navTooltip (object)

The _navTooltip object that contains values for _isEnabled and text.

_isEnabled (boolean)

Enables/disables tooltips for the language picker button in the navigation bar. The default value is true.

text (string)

Text to be displayed in the tooltip when the user hovers over the language picker button in the navigation bar. Defaults to 'Language selector'

Limitations

  • If the Spoor extension is disabled (or not installed), Language Picker will not remember the learner's language choice from the previous session.
  • Switching languages during an Assessment will reset assessment attempts.
  • Language Picker is not yet compatible with the Adapt Authoring Tool.

Notes

If the Spoor extension is enabled and the course is being run from an LMS that has support for the cmi.student_preference.language data model element, the spoor extension will record the learner's choice of language to that data model element. Note that this is for reporting purposes only: as support for that data model element is not mandatory in SCORM 1.2 it cannot be relied upon for saving/restoring the learner's choice of language - the cmi.suspend_data data model element will be used for that, even when cmi.student_preference.language is available.

Requires Spoor v5.1.0 or later for correct restore of state on language change.


adapt learning logo Author / maintainer: Adapt Core Team with contributors
Accessibility support: WAI AA
RTL support: Yes
Cross-platform coverage: Chrome, Chrome for Android, Firefox (ESR + latest version), Edge, Safari for macOS/iOS/iPadOS, Opera

About

Language Picker is an extension that allows the user to choose their preferred language.

Resources

License

Contributing

Stars

Watchers

Forks

Packages

No packages published

Contributors 22