Download the PHP package slm/locale without Composer

On this page you can find all versions of the php package slm/locale. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package locale

SlmLocale

CI Latest Stable Version Coverage Status

Created by Jurian Sluiman

Introduction

SlmLocale is a Laminas module to automatically detect a locale for your application. It uses a variety of pluggable strategies to search for a valid locale. SlmLocale features a default locale, a set of supported locales and locale aliases.

SlmLocale supports out of the box several strategies to search for a locale. Through interfaces, other strategies could be created. The set of default stragies is:

  1. The HTTP Accept-Language header
  2. A cookie to store the locale between several sessions of one visitor
  3. A query parameter to easily switch from locale
  4. The first segment of the path of an uri
  5. A part of the domain name (either the TLD or a subdomain)

Furthermore, it provides a set of additional localisation features:

  1. A default locale, used as fallback
  2. A set of aliases, so you can map .com as "en-US" in the host name strategy
  3. Redirect to the right domain/path when a locale is found
  4. View helpers to create a localised uri or a list of language switches

Installation

Add "slm/locale" to your composer.json file and update your dependencies. Enable SlmLocale in your application.config.php.

If you do not have a composer.json file in the root of your project, copy the contents below and put that into a file called composer.json and save it in the root of your project:

Then execute the following commands in a CLI:

Now you should have a vendor directory, including a slm/locale. In your bootstrap code, make sure you include the vendor/autoload.php file to properly load the SlmLocale module.

Usage

Set your default locale in the configuration:

Set all your supported locales in the configuration:

And enable some strategies. The naming is made via the following list:

You can enable one or more of them in the strategies list. Mind the priority is important! You usually want the acceptlanguage as last for a fallback:

At this moment, the locale should be detected. The locale is stored inside php's Locale object. Retrieve the locale with Locale::getDefault(). This is also automated inside Laminas translator objects and i18n view helpers (so you do not need to set the locale yourself there).

Set the locale's language in html

It is common to provide the html with the used locale. This can be set for example in the html tag:

Inject the detected language here with the following code:

Disable UriPathStrategy in PHPUNIT

This is necessary (at the moment) if you want to use this->dispatch('my/uri'); in your AbstractHttpControllerTestCase unit tests. Otherwise, if you check for responseCode you will get 302 where it should be 200.

Example:

To fix add the following to your phpunit config.

phpunit.xml:

Or set $_SERVER['DISABLE_URIPATHSTRATEGY'] = true; in your bootstrap file of phpunit.

Create a list of available locales

T.B.D

Read more about usage and the configuration of all the strategies in the documentation.


All versions of locale with dependencies

PHP Build Version
Package Version
Requires php Version ^7.2 || ~8.0.0 || ~8.1.0 || ~8.2.0
ext-intl Version *
laminas/laminas-eventmanager Version ^3.1
laminas/laminas-http Version ^2.7
laminas/laminas-modulemanager Version ^2.8.2
laminas/laminas-router Version ^3.0
laminas/laminas-servicemanager Version ^3.2
laminas/laminas-stdlib Version ^3.2.1
laminas/laminas-view Version ^2.9.0
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package slm/locale contains the following files

Loading the files please wait ....