Languages class

API variable $languages enables access to all Language pages and various helper methods.

The $languages API variable is most commonly used for iteration of all installed languages.

foreach($languages as $language) {
  echo "<li>$language->title ($language->name) ";
  if($language->id == $user->language->id) {
    echo "current"; // the user's current language
  }
  echo "</li>";
}

Click any linked item for full usage details and examples. Hookable methods are indicated with the icon. In addition to those shown below, the Languages class also inherits all the methods and properties of: PagesType and Wire.

Show class?             Show args?        

Common

NameReturnSummary 
Languages::default Language Get default language 
Languages::editable($language)
boolDoes current user have edit access for page fields in given language? 
Languages::findNonDefault()
PageArrayFind and return all languages except default language 
Languages::findOther()
PageArrayFind and return all languages except current user language 
Languages::getDefault()
LanguageGet the default language
Can also be used as property: Languages::getDefault
 
Languages::getLanguage()
Language NullPage nullGet the current language or optionally a specific named language 
Languages::getLocale()
string boolReturn the current locale setting 
Languages::setDefault()
(nothing)Set current user to have default language temporarily 
Languages::setLanguage($language)
boolSet the current user language for the current request 
Languages::setLocale()
string boolSet the current locale 
Languages::translator(Language $language)
LanguageTranslatorReturn the LanguageTranslator instance for the given language 
Languages::unsetDefault()
(nothing)Restores whatever previous language a user had prior to a setDefault() call 
Languages::unsetLanguage()
boolUndo a previous setLanguage() call, restoring the previous user language 

For hooks

These methods are only useful for hooking and should not be called directly.

Additional methods and properties

In addition to the methods and properties above, Languages also inherits the methods and properties of these classes:

API reference based on ProcessWire core version 3.0.127

Twitter updates

  • New post: This week ProcessWire ProMailer has been released, plus we’ve got a nice upgrade in our community support forum, and more— More
    15 March 2019
  • New post: This week we look at the latest version of ProcessWire, 3.0.127 with nearly 30 new commits resolving dozens of older issue reports and a couple useful new features— More
    1 March 2019
  • New post: This week we take a look at what’s in ProcessWire 3.0.126 which focuses largely on resolving issue reports, but also includes a handy new Page if() method— More
    15 February 2019

Latest news

  • ProcessWire Weekly #253
    In the 253rd issue of ProcessWire Weekly we'll introduce the ProMailer Pro module, cover the upgrade made to our support forum software, check out Sanitizer Transliterate, and pick a new site of the week. Read on!
    Weekly.pw / 16 March 2019
  • ProcessWire ProMailer now available
    This week ProcessWire ProMailer has been released, plus we’ve got a nice upgrade in our community support forum, and more.
    Blog / 15 March 2019
  • Subscribe to weekly ProcessWire news

“The end client and designer love the ease at which they can update the website. Training beyond how to log in wasn’t even necessary since ProcessWire’s default interface is straightforward.” —Jonathan Lahijani