Skip to content

woutderuiter/gewisweb

 
 

Repository files navigation

GEWIS Website

Website for Study association GEWIS.

Build Status

Installation

  • Clone the repository.
  • Install dependencies using composer: php composer.phar install
  • Create a new MySQL database.
  • Copy config/autoload/doctrine.local.php.dist to config/autoload/doctrine.local.php and configure the database settings in it.
  • Give the webserver's user read and write permissions to the data/ directory.
  • Run ./vendor/bin/doctrine-module orm:schema-tool:create to populate the database.

Optional debugging configuration

  • Copy config/autoload/zdt.local.php.dist to config/autoload/zdt.local.php.

Translation

The website is translated using gettext. By default, all strings are written in English.

Code

In the code, string should be translated with the translator, which can be obtained with the ServiceManager. Then, strings should be translated as follows:

<?php
// obtain the translator
$translator = $sm->get('translator');
echo $translator->translate('Some text');

Views

Most translation actually happens in views. Thus, there is a translate view helper to help translation in views along. In views, you don't have to worry about translator setup, you can simply use $this->translate() to translate strings.

Translate helper

In the main directory of the project, there is a translate-helper shell script. If the script is executed, all strings which are translated by the translator, will be gathered in module/Application/language/gewisweb.pot. From here, the language files (which are located in module/Application/language/) should be updated by running msgmerge lang.po gewisweb.pot. This updates the existing language file with newly added strings.

Translation

The translation files en.po and nl.po should be translated with an editor like POEdit. When saved, these will be converted to the binary *.mo files used by the translator.

About

GEWIS Website

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • PHP 68.3%
  • JavaScript 14.7%
  • HTML 13.2%
  • CSS 3.5%
  • Other 0.3%