Difference between revisions of "Apertium-html-tools"

From Apertium
Jump to navigation Jump to search
(maybe outdated? I uopdated this from readme while testing current version)
 
(54 intermediate revisions by 5 users not shown)
Line 1: Line 1:
{{TOCD}}
{{TOCD}}


'''Apertium Html-tools''' is a web application providing a fully localised interface for text/document translation, analyzation, and generation powered by Apertium. Designed to use only static resources for quick and easy deployment with any web server, it is relatively lightweight and user-friendly. It is currently located in SVN at [https://svn.code.sf.net/p/apertium/svn/trunk/apertium-tools/apertium-html-tools/ /trunk/apertium-tools/apertium-html-tools]. Html-tools relies on an Apertium HTTP API such as [[Apertium-apy]] or [[ScaleMT]] (to a lesser extent).
'''Apertium Html-tools''' is a web application providing a fully localised interface for text/document/website translation, analysis, and generation powered by Apertium. Designed to use only static resources for quick and easy deployment with any web server, it is relatively lightweight and user-friendly. It is currently located on Github at [https://github.com/apertium/apertium-html-tools github.com/apertium/apertium-html-tools]. Html-tools relies on an Apertium HTTP API such as [[Apertium-apy]] or [[ScaleMT]] (to a lesser extent).


== Usage ==
== Usage ==


=== Getting Started ===
=== Getting Started ===
Using Html-tools is as easy as checking out from SVN, changing the configuration and running make.
Using Html-tools is as easy as cloning from git, changing the configuration and running yarn.


$ git clone https://github.com/apertium/apertium-html-tools.git
<code>
$ svn co https://svn.code.sf.net/p/apertium/svn/trunk/apertium-tools/apertium-html-tools/
$ cd apertium-html-tools/
$ vim ./config.ts
$ vim ./assets/js/config.js #Edit the configuration, see next section for more details
$ yarnpkg install
$ make
$ yarnpkg build
</code>


The last step is pointing your web server of choice, e.g. Apache, to serve the directory <code>/build</code>.
The last step is pointing your web server of choice, e.g. Apache, to serve the directory <code>dist</code> or running <code>python3 -m http.server</code> in <code>/build</code>.


=== Configuration ===
=== Configuration ===
Since Html-tools is powered entirely by static resources, a configuration file located at [https://svn.code.sf.net/p/apertium/svn/trunk/apertium-tools/apertium-html-tools/assets/js/config.js /assets/js/config.js] is maintained to allow users to modify basic environment parameters such as API location and enabled interfaces. Following is a summary of the currently supported arguments with some examples:
Since Html-tools is powered entirely by static resources, a configuration file generated at <code>apertium-html-tools/config.conf</code> (based on <code>[https://github.com/apertium/apertium-html-tools/blob/master/config.conf.example config.conf.example]</code>) is maintained to allow users to modify basic environment parameters such as API location and enabled interfaces. Following is a summary of the currently supported arguments with some examples:


* '''APY_URL''': the URL of an API instance (ScaleMT for basic functionality, [[APY]] for full) that the web application calls
* '''APY_URL''': the URL of an API instance (ScaleMT for basic functionality, [[APY]] for full) that the web application calls
** <code>'<nowiki>http://www.apertium.org:8080</nowiki>'</code>
** <code><nowiki>https://www.apertium.org/apy</nowiki></code>
** <code>'<nowiki>http://localhost:2737</nowiki>'</code>
** <code><nowiki>http://localhost:2737</nowiki></code>
** <code>'<nowiki>https://api.apertium.org</nowiki>'</code>
** <code><nowiki>http://turkic.apertium.org:8080</nowiki></code>
* '''ALLOWED_LANGS''': an array of ISO 639-3 language codes that the application displays in the interface, useful for deploying websites that have only a subset of all the languages the API being used provides (e.g. a region specific website)
* '''ALLOWED_LANGS''': an array of ISO 639-3 language codes that the application displays in the interface, useful for deploying websites that have only a subset of all the languages the API being used provides (e.g. a region specific website)
** <code>undefined</code> does <strong>not</strong> limit the languages displayed (everything the API supports will be shown).
** does <strong>not</strong> limit the languages displayed (everything the API supports will be shown).
** <code>['tur', 'uzb', 'kaz']</code> limits to only language pairs between Turkish, Kazakh, and Uzbek appearing in the interface; analyzers and generators for the three languages will also be shown.
** <code>tur, uzb, kaz']</code> limits to only language pairs between Turkish, Kazakh, and Uzbek appearing in the interface; analyzers and generators for the three languages will also be shown.
** <code>[]</code> limits the interface to 0 languages (since none are in the array); why would you want to do this? I don't know, but now you know how to.
* '''ALLOWED_VARIANTS''': an array of variant codes that the application displays in the interface, similar to the functionality of ALLOWED_LANGS
* '''ALLOWED_VARIANTS''': an array of variant codes that the application displays in the interface, similar to the functionality of ALLOWED_LANGS
** <code>undefined</code> does <strong>not</strong> limit the variants displayed (everything the API supports will be shown).
** does <strong>not</strong> limit the variants displayed (everything the API supports will be shown).
** <code>['US', 'GB']</code> limits languages displayed in the translation interface such that pairs either have no variant or a subset of {'US', 'GB'} (en_US-es and es-en_GB are fine but en_UK-anything is not); analyzers and generators are similarly restricted.
** <code>US, GB</code> limits languages displayed in the translation interface such that pairs either have no variant or a subset of {'US', 'GB'} (en_US-es and es-en_GB are fine but en_UK-anything is not); analyzers and generators are similarly restricted.
* '''ENABLED_MODES''': an array of the enabled interfaces, a <strong>non-empty</strong> subset of ['translation', 'analyzation', 'generation', 'sandbox']
* '''ENABLED_MODES''': an array of the enabled interfaces, a <strong>non-empty</strong> subset of ['translation', 'analyzation', 'generation', 'sandbox']
** <code>['translation']</code> limits the interface to only translation support.
** <code>translation</code> limits the interface to only translation support.
** <code>['translation', 'analyzation', 'generation']</code> displays the three main interfaces as tabs.
** <code>translation, analyzation, generation</code> displays the three main interfaces as tabs.
** <code>['translation', 'analyzation', 'generation', 'sandbox']</code> is generally not recommended outside of a development environment since users most probably do not need an API Sandbox.
** <code>translation, analyzation, generation, sandbox</code> is generally not recommended outside of a development environment since users most probably do not need an API Sandbox.
* '''DEFAULT_MODE''': the default landing interface for a new user, an element of the ENABLED_MODES array
* '''DEFAULT_MODE''': the default landing interface for a new user, an element of the ENABLED_MODES array
** <code>'translation'</code> lets the user land on the translation interface first (recommended option).
** <code>translation</code> lets the user land on the translation interface first (recommended option).
* '''SHOW_NAVBAR''': whether the navigation bar that allows switching between interfaces is visible.
* '''SHOW_NAVBAR''': whether the navigation bar that allows switching between interfaces is visible.
** <code>true</code> shows the navbar and is recommended when more than one mode is enabled via ENABLED_MODES.
** <code>True</code> shows the navbar and is recommended when more than one mode is enabled via ENABLED_MODES.
** <code>false</code> hides the navbar and is recommended when only one mode is enabled (e.g. ENABLED_MODES = <code>['translation']</code>).
** <code>False</code> hides the navbar and is recommended when only one mode is enabled (e.g. ENABLED_MODES = <code>translation</code>).
* '''GOOGLE_ANALYTICS_PROPERTY''': the Google Analytics property name
* '''PIWIK_SITEID''': the Piwik site ID
** <code>undefined</code> disables Google Analytics (recommended unless you know what you're doing).
** <code>undefined</code> disables Piwik Analytics (recommended unless you know what you're doing).
* '''GOOGLE_ANALYTICS_TRACKING_ID''': the Google Analytics tracking code
* '''PIWIK_URL''': the Piwik instance URL
** <code>undefined</code> disables Google Analytics (recommended unless you know what you're doing).
** <code>undefined</code> disables Piwik Analytics (recommended unless you know what you're doing).
* '''LIST_REQUEST_CACHE_EXPIRY''': cache expiry time in hours for /list requests (/listPairs, /list?q=analyzers, /list?q=generators)
* '''LIST_REQUEST_CACHE_EXPIRY''': cache expiry time in hours for /list requests (/listPairs, /list?q=analyzers, /list?q=generators)
** <code>24</code> ensures list requests are refreshed at least every day.
** <code>24</code> ensures list requests are refreshed at least every day.
Line 49: Line 48:
* '''LOCALIZATION_CACHE_EXPIRY''': cache expiry time in hours for localised string asset requests (e.g. /assets/strings/fra.json)
* '''LOCALIZATION_CACHE_EXPIRY''': cache expiry time in hours for localised string asset requests (e.g. /assets/strings/fra.json)
** <code>24</code> ensures the interface strings for a locale are refreshed at least every day (browser caching may interfere).
** <code>24</code> ensures the interface strings for a locale are refreshed at least every day (browser caching may interfere).
* '''AVAILABLE_LOCALES_CACHE_EXPIRY''': cache expiry time in hours for available locales
** <code>24</code> ensures the available locales are refreshed at least every day (browser caching may interfere).


=== Minification ===
=== Minification ===
is currently not done, since enabling gzip compression on the server gives almost-as-good results with easier debuggability, less build complexity and less dependencies. (The old minification build rules are in revision 52413.) Files are still named min.css/min.js even though they're not minified.
is currently not done, since enabling gzip compression on the server gives almost-as-good results with easier debuggability, less build complexity and less dependencies. (The old minification build rules are in SVN revision 52413.) Files are still named min.css/min.js even though they're not minified.


However, JS and CSS files are ''concatenated'' on typing <code>make</code>, which makes for fewer requests.
However, JS and CSS files are ''concatenated'' on typing <code>make</code>, which makes for fewer requests.


==== Production ====
==== Production ====
In a production environment, <code>make</code> will generate all the necessary files including the <code>index.html</code> linking to the concatenated JS and CSS. So, see the instructions in the above section and you should be set for deployment.
In a production environment, <code>make</code> will generate all the necessary files including the <code>build/index.html</code> linking to the concatenated JS and CSS. So, see the instructions in the above section and you should be set for deployment.


==== Development ====
==== Development ====
Since running make generates an <code>index.html</code> with links to concatenated content, development is a little bit more complicated. After making changes to any CSS or JS resource and before re-running make, the changes will not be reflected in <code>/</code> since <code>index.html</code> still links to the stale minified CSS or JS resources. While this could be amended by running make after every change, that's a terrible workflow unless it's automated somehow (e.g. in emacs you would have to put <code>(add-hook 'after-save-hook 'compile)</code> in ~/.emacs). To alleviate this problem, running make also generates <code>index.debug.html</code> which links to the raw CSS/JS resources that you modify. So, use <code>/index.debug.html</code> while debugging/adding features in the CSS or JS. Modifying the HTML does require running make every time but such changes are less frequent and usually involve less debugging. If you add a static resource (e.g. a new JS file for a spell checker interface), be sure to edit the <code>Makefile</code> and <code>debug-head.html</code> to ensure the concatenation process still runs smoothly.
Since running make generates an <code>index.html</code> with links to concatenated content, development is a little bit more complicated. After making changes to any CSS or JS resource and before re-running make, the changes will not be reflected in <code>/</code> since <code>index.html</code> still links to the stale minified CSS or JS resources. While this could be amended by running make after every change, that's a terrible workflow unless it's automated somehow (e.g. in emacs you would have to put <code>(add-hook 'after-save-hook 'compile)</code> in ~/.emacs). To alleviate this problem, running make also generates <code>index.debug.html</code> which links to the raw CSS/JS resources that you modify. So, use <code>/index.debug.html</code> while debugging/adding features in the CSS or JS. Modifying the HTML does require running make every time but such changes are less frequent and usually involve less debugging. If you add a static resource (e.g. a new JS file for a spell checker interface), be sure to edit the <code>Makefile</code> and <code>debug-head.html</code> to ensure the concatenation process still runs smoothly. The commands below might help with auto-making after changes:

while true; do inotifywait . -r -e MODIFY && make debug -j32; done; # Linux
while true; do fswatch -o -r . | make debug -j32; done; # OS X


== Current Status ==
== Current Status ==


=== Features ===
=== Features ===

==== Translation ====
Text translation is supported through an intuitive interface with support for instant translation (translation as you type) and support for disabling the marking of unknown tokens. Language detection is supported with CLD with plans to migrate to a solution that supports all the Apertium languages. Document translation is available for almost all modern browsers and supports less than 32MB files in DOCX, XLSX, PPTX, ODT, TXT, RTF, HTML, and LATEX formats with plans to support older Microsoft Office formats (DOC, XLS, PPT).

==== Morphological Analysis and Generation ====

Morphological analysis and generation are supported via two language selectors, one for the language desired (e.g. English) and another for the Apertium package used (e.g. English-Spanish or English-Esperanto).

==== Theming / Customisation ====

Html-tools uses Bootstrap as its frontend framework and supports using any of the Bootstrap themes provided by [http://bootswatch.com/ Bootswatch] through the [http://www.bootstrapcdn.com/#bootswatch_tab Bootstrap CDN]. Currently, there are sixteen available themes (Cerulean, Cosmo, Cyborg, Darkly, Flatly, Journal, Lumen, Paper, Readable, Sandstone, Simplex, Slate, Spacelab, Superhero, United and Yeti), based on bootstrap themes, in addition to the default theme. To use the Cosmo theme,

<code>
$ make cosmo -B
</code>

To switch back to the default theme,

<code>
$ make -B
</code>

By running make, the theme's Bootstrap CSS is downloaded from the CDN. It is then combined with the default styles used on the page (located in <code>/assets/css/style.css</code>). However, sometimes you may want to override the rules set by these two files. For that reason, each theme also has a custom CSS file which contains rules that adapt existing elements to the theme or override the theme's CSS itself. For example, <code>/assets/css/themes/style.lumen.css</code> contains a rule that switches the default Apertium logo with white letters to the one with black lettering. If desired, it can also be used to do things like changing the colors that Bootstrap sets, overriding their default values.


=== Deployed Examples ===
=== Deployed Examples ===
Line 69: Line 96:


==== Apertium ====
==== Apertium ====
Apertium maintains html-tools at [http://www.apertium.org www.apertium.org] and APY at apertium.org:8080 with support for most of the current trunk pairs. However, since it only contains the translation interface, it is '''not''' a good source of context for contributors looking to localise the interface.
Apertium maintains html-tools at [https://www.apertium.org www.apertium.org] and APY at https://www.apertium.org/apy/ with support for most of the current trunk pairs. However, since it only contains the translation interface, it is '''not''' a good source of context for contributors looking to localise the interface.


==== Apertium Turkic ====
==== Apertium Turkic ====
[[Apertium Turkic]] maintains html-tools at [http://turkic.apertium.org turkic.apertium.org] and APY at turkic.apertium.org:2737 with support for several Turkic languages and the translation, analyzation, and generation modes available. As such, it is a good candidate for getting localisation string context.
[[Apertium Turkic]] maintains html-tools at [http://turkic.apertium.org turkic.apertium.org] and APY at turkic.apertium.org:8080 with support for several Turkic languages and the translation, analyzation, and generation modes available. As such, it is a good candidate for getting localisation string context.


== Future Improvements ==
== Future Improvements ==


=== Localisation ===
=== Localisation ===
The Html-tools interface is '''fully''' localisable and has support for RTL languages. The 21 currently available languages are Aragonese (arg), Avar (ava), Catalan (cat), English (eng), Basque (eus), French (fra), Hebrew (heb), Karakalpak (kaa), Kazakh (kaz), Kyrgyz (kir), Nynorsk Norwegian (nno), Bokmål Norwegian (nob), Occitan (oci), Portuguese (por), Romanian (ron), Saami (sme), Spanish (spa), Tatar (tat) and Chinese (zho).
The Html-tools interface is '''fully''' localisable and has support for RTL languages. The 26 currently available languages are Aragonese (arg), Avar (ava), Catalan (cat), English (eng), Basque (eus), French (fra), German (deu), Hebrew (heb), Karakalpak (kaa), Kazakh (kaz), Kyrgyz (kir), Nynorsk Norwegian (nno), Bokmål Norwegian (nob), Occitan (oci), Portuguese (por), Romanian (ron), Saami (sme), Spanish (spa), Tatar (tat), Thai (tha), Turkish (tur), Uzbek (uzb), Uyghur (uig), and Chinese (zho).


Contributing a new translation of the interface is encouraged and a very simple process.
Contributing a new translation of the interface is encouraged and a very simple process.

==== Quick and easy ====
If you don't know what git is, or you'd rather not deal with it, follow these steps.
# Download the <tt>eng.json</tt> file from [https://github.com/apertium/apertium-html-tools/blob/master/assets/strings/ this directory].
# Download the file for your language too. If one doesn't exist, make a copy of the <tt>eng.json</tt> file for your language. You could also download the file for a language similar to your language or one that you're more comfortable with.
# Base your translations off the <tt>eng.json</tt> file, as the English strings file is the only one guaranteed to be up-to-date.
# [[Contact us|Send us]] your finished translation! Or let us know if you have questions. Thanks!


==== Creating a new translation ====
==== Creating a new translation ====
# Checkout the directory with all the localisation files: <code>svn co https://svn.code.sf.net/p/apertium/svn/trunk/apertium-tools/apertium-html-tools/assets/strings/</code>.
# Clone the apertium-html-tools repo, which has all the localisation files in apertium-html-tools: <code>git clone git@github.com:apertium/apertium-html-tools.git</code>.
# Look at a deployed version of the html-tools interface, preferably one with all/most modes enabled. See the section on deployed sites for where to go.
# Look at a deployed version of the html-tools interface, preferably one with all/most modes enabled. See the section on deployed sites for where to go.
#
#
#* Starting from an existing translation (with reference)
#* Starting from an existing translation (with reference)
## Run <code>./localisation-tools.py new fin -p eng</code>, replacing <code>fin</code> with your language's ISO 639-3 code and <code>eng</code> with the language you want to use as a reference while translating.
## From the assets/strings directory, run <code>./localisation-tools.py new fin -p eng</code>, replacing <code>fin</code> with your language's ISO 639-3 code and <code>eng</code> with the language you want to use as a reference while translating.
## Replace all the right-hand values in each pair to match your language, use the website you found from Step 2 and the reference language translations to help with context.
## Replace all the right-hand values in each pair to match your language, use the website you found from Step 2 and the reference language translations to help with context.
#* Starting from scratch (without reference)
#* Starting from scratch (without reference)
Line 92: Line 126:
## Replace all the right-hand values in each pair to match your language, use the website you found from Step 2 to help with context.
## Replace all the right-hand values in each pair to match your language, use the website you found from Step 2 to help with context.
# Run <code>./localisation-tools.py all fin</code>, replacing <code>fin</code> with your language's ISO 639-3 code and see whether <code>completion</code> is 100 (percent). If not, keep translating (what you're missing is shown in <code>missing</code>) and running this step's command.
# Run <code>./localisation-tools.py all fin</code>, replacing <code>fin</code> with your language's ISO 639-3 code and see whether <code>completion</code> is 100 (percent). If not, keep translating (what you're missing is shown in <code>missing</code>) and running this step's command.
# If you didn't manage to run localisation-tools.py because of an exception, you might have made an error in the json-file. You can check your JSON with http://jsonlint.com/ or similar.
#'''Optional:''' Add your name to the <code>"authors"</code> key and update the <code>"last-updated"</code> key. Add a line to [https://svn.code.sf.net/p/apertium/svn/trunk/apertium-tools/apertium-html-tools/assets/strings/locales.json assets/strings/locales.json] with the language code mapped to the language's native name (endonym).
#'''Optional:''' Add your name to the <code>"authors"</code> key and update the <code>"last-updated"</code> key. Add a line to [https://github.com/apertium/apertium-html-tools/blob/master/assets/strings/locales.json assets/strings/locales.json] with the language code mapped to the language's native name (endonym).
# Commit to SVN: <code>svn ci -m "Your message..."</code>
# Commit your changes to git: <code>git commit ./ -m "Your message..."</code>
# If you didn't edit locales.json, let us know in [[IRC]] so that we can edit it for you and update websites. Thanks!
# If you didn't edit <tt>locales.json</tt>, let us know in [[IRC]] so that we can edit it for you and update websites. Thanks!


==== Updating an existing translation ====
==== Updating an existing translation ====
# Checkout the directory with all the localisation files: <code>svn co https://svn.code.sf.net/p/apertium/svn/trunk/apertium-tools/apertium-html-tools/assets/strings/</code>.
# Clone the apertium-html-tools repo, which has all the localisation files in apertium-html-tools: <code>git clone git@github.com:apertium/apertium-html-tools.git</code>.

# Look at a deployed version of the html-tools interface, preferably one with all/most modes enabled. See the section on deployed sites for where to go.
# Look at a deployed version of the html-tools interface, preferably one with all/most modes enabled. See the section on deployed sites for where to go.
#
#
#* Working with a reference
#* Working with a reference
## Run <code>./localisation-tools.py all fin -p eng</code>, replacing <code>fin</code> with your language's ISO 639-3 code and <code>eng</code> with the language you want to use as a reference while translating.
## From the assets/strings directory, run <code>./localisation-tools.py all fin -p eng</code>, replacing <code>fin</code> with your language's ISO 639-3 code and <code>eng</code> with the language you want to use as a reference while translating.
## Change all the right-hand values in each pair that are marked as <code>%%UNAVAILABLE%%</code> to match your language, use the website you found from Step 2 and the reference language translations to help with context.
## Change all the right-hand values in each pair that are marked as <code>%%UNAVAILABLE%%</code> to match your language, use the website you found from Step 2 and the reference language translations to help with context.
#* Working without a reference
#* Working without a reference
Line 108: Line 144:
# Run <code>./localisation-tools.py all fin</code>, replacing <code>fin</code> with your language's ISO 639-3 code and see whether <code>completion</code> is 100 (percent). If not, keep translating (what you're missing is shown in <code>missing</code>) and running this step's command.
# Run <code>./localisation-tools.py all fin</code>, replacing <code>fin</code> with your language's ISO 639-3 code and see whether <code>completion</code> is 100 (percent). If not, keep translating (what you're missing is shown in <code>missing</code>) and running this step's command.
#'''Optional:''' Add your name to the <code>"authors"</code> key (if it's not there already) and update the <code>"last-updated"</code> key.
#'''Optional:''' Add your name to the <code>"authors"</code> key (if it's not there already) and update the <code>"last-updated"</code> key.
# Commit to SVN: <code>svn ci -m "Your message..."</code>. Thanks!
# Commit your changes to git: <code>git commit ./ -m "Your message..."</code>


=== Todo ===
==== Progress ====
Updated 8 January 2017. Generated by [https://github.com/apertium/apertium-html-tools/blob/master/assets/strings/progresstable.sh progresstable.sh].


{| class="wikitable sortable"
* More search engine optimisation (look into possibly compromising some of the static file paradigm in a fork)
|-
* [http://sourceforge.net/p/apertium/tickets/10/ CORS compliance]
!|code
* [http://sourceforge.net/p/apertium/tickets/9/ Maintaining order of user interactions]
!|CBE*
* [http://sourceforge.net/p/apertium/tickets/7/ Document translation] (requires work on [[APY]])
!|CBC**
* [http://sourceforge.net/p/apertium/tickets/6/ Spell checker] (requires work on [[APY]])
|-
* [http://sourceforge.net/p/apertium/tickets/5/ RTL language support]
|| eng || 100% || 100.00%
* [http://sourceforge.net/p/apertium/tickets/4/ Expanding textareas]
|-
* [http://sourceforge.net/p/apertium/tickets/3/ Clear input button]
|| arg || 98% || 109.85%
* [http://sourceforge.net/p/apertium/tickets/1/ Language variant picker]
|-
|| uzb || 98% || 108.64%
|-
|| swe || 98% || 102.15%
|-
|| tur || 98% || 100.08%
|-
|| rus || 98% || 97.09%
|-
|| deu || 96% || 109.07%
|-
|| nno || 96% || 95.95%
|-
|| cat || 94% || 104.96%
|-
|| kaa || 94% || 103.19%
|-
|| nob || 94% || 96.43%
|-
|| tha || 94% || 89.29%
|-
|| fin || 94% || 88.98%
|-
|| spa || 86% || 35.01%
|-
|| kir || 84% || 33.11%
|-
|| fra || 82% || 102.76%
|-
|| oci || 82% || 99.34%
|-
|| uig || 82% || 91.87%
|-
|| kaz || 82% || 91.19%
|-
|| heb || 82% || 80.42%
|-
|| tat || 69% || 19.68%
|-
|| sme || 65% || 21.78%
|-
|| por || 61% || 19.55%
|-
|| eus || 57% || 21.91%
|-
|| ava || 55% || 18.54%
|-
|| ron || 50% || 17.27%
|-
|| zho || 50% || 5.04%
|}

&nbsp;*CBE: completion by entries <br>
&nbsp;**CBC: completion by characters (i.e., ratio of characters to English ~source)

== Docs ==
* [[/Localisation]]


== Credits ==
== Credits ==


Apertium-html-tools grew out of [[simple-html]] as features were being added by [[User:Sushain|Sushain Cherivirala]] during [[GCI 2014]]. It's now its own beast, and continues to be maintained primarily by Sushain.
Apertium-html-tools grew out of [[simple-html]] as features were being added by [[User:Sushain|Sushain Cherivirala]] during [[GCI 2013]]. It's now its own beast, and continues to be maintained primarily by Sushain.


The following people have helped with localisation:
The following people have helped with localisation:
* [[User:Unhammer|Unhammer]] (Nynorsk Norwegian, Bokmål Norwegian)
* Lene Antonsen (Northern Saami)
* [[User:firespeaker|firespeaker]] (Kyrgyz, Kazakh, Russian, Tatar)
* [[User:Francis_Tyers|spectie]] (Spanish, Catalan, Aragonese)
* [[User:Ilnar.salimzyan|Ilnar]] (Russian, Tatar)
* [[User:Sushain|Sushain]] (Spanish)
* [[User:Aidana|Aida]] (Kazakh)
* hbwashington (Portuguese, Spanish)
* solinus (Avar, Russian)
* shopskasalata/kikero (Romanian)
* shopskasalata/kikero (Romanian)
* Cédric VALMARY (French)
* hbwashington (Portuguese)
* Lene Antonsen (Saami)
* Tolgonay (Kyrgyz)
* Tolgonay (Kyrgyz)
* Aida (Kazakh)
* Ilnar (Russian, Tatar)
* wei2912 (Chinese)
* wei2912 (Chinese)
* Märdan (Uyghur)
* Märdan (Uyghur)
* Flammie (Finnish)
* inariksit (Finnish)
* youssef (French)
* n0nick (Hebrew)
* vmax = Max Vorobev (Russian)
* [[User:Tarjimon|bmansurov]] (Uzbek)
* [https://github.com/apertium/apertium-html-tools/commit/05683a2a8d5133cb8a9f0fe8fad86be3885bda02 Çağrı] (Turkish)

== Please cite ==

* https://www.aclweb.org/anthology/W18-2207/


[[Category:User interfaces]]
[[Category:User interfaces]]

Latest revision as of 19:21, 16 August 2024

Apertium Html-tools is a web application providing a fully localised interface for text/document/website translation, analysis, and generation powered by Apertium. Designed to use only static resources for quick and easy deployment with any web server, it is relatively lightweight and user-friendly. It is currently located on Github at github.com/apertium/apertium-html-tools. Html-tools relies on an Apertium HTTP API such as Apertium-apy or ScaleMT (to a lesser extent).

Usage[edit]

Getting Started[edit]

Using Html-tools is as easy as cloning from git, changing the configuration and running yarn.

$ git clone https://github.com/apertium/apertium-html-tools.git 
$ cd apertium-html-tools/ 
$ vim ./config.ts
$ yarnpkg install
$ yarnpkg build

The last step is pointing your web server of choice, e.g. Apache, to serve the directory dist or running python3 -m http.server in /build.

Configuration[edit]

Since Html-tools is powered entirely by static resources, a configuration file generated at apertium-html-tools/config.conf (based on config.conf.example) is maintained to allow users to modify basic environment parameters such as API location and enabled interfaces. Following is a summary of the currently supported arguments with some examples:

  • APY_URL: the URL of an API instance (ScaleMT for basic functionality, APY for full) that the web application calls
    • https://www.apertium.org/apy
    • http://localhost:2737
    • http://turkic.apertium.org:8080
  • ALLOWED_LANGS: an array of ISO 639-3 language codes that the application displays in the interface, useful for deploying websites that have only a subset of all the languages the API being used provides (e.g. a region specific website)
    • does not limit the languages displayed (everything the API supports will be shown).
    • tur, uzb, kaz'] limits to only language pairs between Turkish, Kazakh, and Uzbek appearing in the interface; analyzers and generators for the three languages will also be shown.
  • ALLOWED_VARIANTS: an array of variant codes that the application displays in the interface, similar to the functionality of ALLOWED_LANGS
    • does not limit the variants displayed (everything the API supports will be shown).
    • US, GB limits languages displayed in the translation interface such that pairs either have no variant or a subset of {'US', 'GB'} (en_US-es and es-en_GB are fine but en_UK-anything is not); analyzers and generators are similarly restricted.
  • ENABLED_MODES: an array of the enabled interfaces, a non-empty subset of ['translation', 'analyzation', 'generation', 'sandbox']
    • translation limits the interface to only translation support.
    • translation, analyzation, generation displays the three main interfaces as tabs.
    • translation, analyzation, generation, sandbox is generally not recommended outside of a development environment since users most probably do not need an API Sandbox.
  • DEFAULT_MODE: the default landing interface for a new user, an element of the ENABLED_MODES array
    • translation lets the user land on the translation interface first (recommended option).
  • SHOW_NAVBAR: whether the navigation bar that allows switching between interfaces is visible.
    • True shows the navbar and is recommended when more than one mode is enabled via ENABLED_MODES.
    • False hides the navbar and is recommended when only one mode is enabled (e.g. ENABLED_MODES = translation).
  • PIWIK_SITEID: the Piwik site ID
    • undefined disables Piwik Analytics (recommended unless you know what you're doing).
  • PIWIK_URL: the Piwik instance URL
    • undefined disables Piwik Analytics (recommended unless you know what you're doing).
  • LIST_REQUEST_CACHE_EXPIRY: cache expiry time in hours for /list requests (/listPairs, /list?q=analyzers, /list?q=generators)
    • 24 ensures list requests are refreshed at least every day.
  • LANGUAGE_NAME_CACHE_EXPIRY: cache expiry time in hours for /languageName requests
    • 24 ensures language name caches are refreshed at least very 24 hours.
  • LOCALIZATION_CACHE_EXPIRY: cache expiry time in hours for localised string asset requests (e.g. /assets/strings/fra.json)
    • 24 ensures the interface strings for a locale are refreshed at least every day (browser caching may interfere).
  • AVAILABLE_LOCALES_CACHE_EXPIRY: cache expiry time in hours for available locales
    • 24 ensures the available locales are refreshed at least every day (browser caching may interfere).

Minification[edit]

is currently not done, since enabling gzip compression on the server gives almost-as-good results with easier debuggability, less build complexity and less dependencies. (The old minification build rules are in SVN revision 52413.) Files are still named min.css/min.js even though they're not minified.

However, JS and CSS files are concatenated on typing make, which makes for fewer requests.

Production[edit]

In a production environment, make will generate all the necessary files including the build/index.html linking to the concatenated JS and CSS. So, see the instructions in the above section and you should be set for deployment.

Development[edit]

Since running make generates an index.html with links to concatenated content, development is a little bit more complicated. After making changes to any CSS or JS resource and before re-running make, the changes will not be reflected in / since index.html still links to the stale minified CSS or JS resources. While this could be amended by running make after every change, that's a terrible workflow unless it's automated somehow (e.g. in emacs you would have to put (add-hook 'after-save-hook 'compile) in ~/.emacs). To alleviate this problem, running make also generates index.debug.html which links to the raw CSS/JS resources that you modify. So, use /index.debug.html while debugging/adding features in the CSS or JS. Modifying the HTML does require running make every time but such changes are less frequent and usually involve less debugging. If you add a static resource (e.g. a new JS file for a spell checker interface), be sure to edit the Makefile and debug-head.html to ensure the concatenation process still runs smoothly. The commands below might help with auto-making after changes:

while true; do inotifywait . -r -e MODIFY && make debug -j32; done;      # Linux
while true; do fswatch -o -r . | make debug -j32; done;                  # OS X

Current Status[edit]

Features[edit]

Translation[edit]

Text translation is supported through an intuitive interface with support for instant translation (translation as you type) and support for disabling the marking of unknown tokens. Language detection is supported with CLD with plans to migrate to a solution that supports all the Apertium languages. Document translation is available for almost all modern browsers and supports less than 32MB files in DOCX, XLSX, PPTX, ODT, TXT, RTF, HTML, and LATEX formats with plans to support older Microsoft Office formats (DOC, XLS, PPT).

Morphological Analysis and Generation[edit]

Morphological analysis and generation are supported via two language selectors, one for the language desired (e.g. English) and another for the Apertium package used (e.g. English-Spanish or English-Esperanto).

Theming / Customisation[edit]

Html-tools uses Bootstrap as its frontend framework and supports using any of the Bootstrap themes provided by Bootswatch through the Bootstrap CDN. Currently, there are sixteen available themes (Cerulean, Cosmo, Cyborg, Darkly, Flatly, Journal, Lumen, Paper, Readable, Sandstone, Simplex, Slate, Spacelab, Superhero, United and Yeti), based on bootstrap themes, in addition to the default theme. To use the Cosmo theme,

   $ make cosmo -B

To switch back to the default theme,

   $ make -B

By running make, the theme's Bootstrap CSS is downloaded from the CDN. It is then combined with the default styles used on the page (located in /assets/css/style.css). However, sometimes you may want to override the rules set by these two files. For that reason, each theme also has a custom CSS file which contains rules that adapt existing elements to the theme or override the theme's CSS itself. For example, /assets/css/themes/style.lumen.css contains a rule that switches the default Apertium logo with white letters to the one with black lettering. If desired, it can also be used to do things like changing the colors that Bootstrap sets, overriding their default values.

Deployed Examples[edit]

There are currently two deployed instances of Apertium-apy and Apertium-html tools

Apertium[edit]

Apertium maintains html-tools at www.apertium.org and APY at https://www.apertium.org/apy/ with support for most of the current trunk pairs. However, since it only contains the translation interface, it is not a good source of context for contributors looking to localise the interface.

Apertium Turkic[edit]

Apertium Turkic maintains html-tools at turkic.apertium.org and APY at turkic.apertium.org:8080 with support for several Turkic languages and the translation, analyzation, and generation modes available. As such, it is a good candidate for getting localisation string context.

Future Improvements[edit]

Localisation[edit]

The Html-tools interface is fully localisable and has support for RTL languages. The 26 currently available languages are Aragonese (arg), Avar (ava), Catalan (cat), English (eng), Basque (eus), French (fra), German (deu), Hebrew (heb), Karakalpak (kaa), Kazakh (kaz), Kyrgyz (kir), Nynorsk Norwegian (nno), Bokmål Norwegian (nob), Occitan (oci), Portuguese (por), Romanian (ron), Saami (sme), Spanish (spa), Tatar (tat), Thai (tha), Turkish (tur), Uzbek (uzb), Uyghur (uig), and Chinese (zho).

Contributing a new translation of the interface is encouraged and a very simple process.

Quick and easy[edit]

If you don't know what git is, or you'd rather not deal with it, follow these steps.

  1. Download the eng.json file from this directory.
  2. Download the file for your language too. If one doesn't exist, make a copy of the eng.json file for your language. You could also download the file for a language similar to your language or one that you're more comfortable with.
  3. Base your translations off the eng.json file, as the English strings file is the only one guaranteed to be up-to-date.
  4. Send us your finished translation! Or let us know if you have questions. Thanks!

Creating a new translation[edit]

  1. Clone the apertium-html-tools repo, which has all the localisation files in apertium-html-tools: git clone git@github.com:apertium/apertium-html-tools.git.
  2. Look at a deployed version of the html-tools interface, preferably one with all/most modes enabled. See the section on deployed sites for where to go.
    • Starting from an existing translation (with reference)
    1. From the assets/strings directory, run ./localisation-tools.py new fin -p eng, replacing fin with your language's ISO 639-3 code and eng with the language you want to use as a reference while translating.
    2. Replace all the right-hand values in each pair to match your language, use the website you found from Step 2 and the reference language translations to help with context.
    • Starting from scratch (without reference)
    1. Run ./localisation-tools.py new fin -b, replacing fin with your language's ISO 639-3 code.
    2. Replace all the right-hand values in each pair to match your language, use the website you found from Step 2 to help with context.
  3. Run ./localisation-tools.py all fin, replacing fin with your language's ISO 639-3 code and see whether completion is 100 (percent). If not, keep translating (what you're missing is shown in missing) and running this step's command.
  4. If you didn't manage to run localisation-tools.py because of an exception, you might have made an error in the json-file. You can check your JSON with http://jsonlint.com/ or similar.
  5. Optional: Add your name to the "authors" key and update the "last-updated" key. Add a line to assets/strings/locales.json with the language code mapped to the language's native name (endonym).
  6. Commit your changes to git: git commit ./ -m "Your message..."
  7. If you didn't edit locales.json, let us know in IRC so that we can edit it for you and update websites. Thanks!

Updating an existing translation[edit]

  1. Clone the apertium-html-tools repo, which has all the localisation files in apertium-html-tools: git clone git@github.com:apertium/apertium-html-tools.git.
  1. Look at a deployed version of the html-tools interface, preferably one with all/most modes enabled. See the section on deployed sites for where to go.
    • Working with a reference
    1. From the assets/strings directory, run ./localisation-tools.py all fin -p eng, replacing fin with your language's ISO 639-3 code and eng with the language you want to use as a reference while translating.
    2. Change all the right-hand values in each pair that are marked as %%UNAVAILABLE%% to match your language, use the website you found from Step 2 and the reference language translations to help with context.
    • Working without a reference
    1. Run ./localisation-tools-py all fin -b, replacing fin with your language's ISO 639-3 code.
    2. Change all the right-hand values in each pair that are marked as %%UNAVAILABLE%% to match your language, use the website you found from Step 2 to help with context.
  2. Run ./localisation-tools.py all fin, replacing fin with your language's ISO 639-3 code and see whether completion is 100 (percent). If not, keep translating (what you're missing is shown in missing) and running this step's command.
  3. Optional: Add your name to the "authors" key (if it's not there already) and update the "last-updated" key.
  4. Commit your changes to git: git commit ./ -m "Your message..."

Progress[edit]

Updated 8 January 2017. Generated by progresstable.sh.

code CBE* CBC**
eng 100% 100.00%
arg 98% 109.85%
uzb 98% 108.64%
swe 98% 102.15%
tur 98% 100.08%
rus 98% 97.09%
deu 96% 109.07%
nno 96% 95.95%
cat 94% 104.96%
kaa 94% 103.19%
nob 94% 96.43%
tha 94% 89.29%
fin 94% 88.98%
spa 86% 35.01%
kir 84% 33.11%
fra 82% 102.76%
oci 82% 99.34%
uig 82% 91.87%
kaz 82% 91.19%
heb 82% 80.42%
tat 69% 19.68%
sme 65% 21.78%
por 61% 19.55%
eus 57% 21.91%
ava 55% 18.54%
ron 50% 17.27%
zho 50% 5.04%

 *CBE: completion by entries
 **CBC: completion by characters (i.e., ratio of characters to English ~source)

Docs[edit]

Credits[edit]

Apertium-html-tools grew out of simple-html as features were being added by Sushain Cherivirala during GCI 2013. It's now its own beast, and continues to be maintained primarily by Sushain.

The following people have helped with localisation:

  • Unhammer (Nynorsk Norwegian, Bokmål Norwegian)
  • Lene Antonsen (Northern Saami)
  • firespeaker (Kyrgyz, Kazakh, Russian, Tatar)
  • spectie (Spanish, Catalan, Aragonese)
  • Ilnar (Russian, Tatar)
  • Sushain (Spanish)
  • Aida (Kazakh)
  • hbwashington (Portuguese, Spanish)
  • solinus (Avar, Russian)
  • shopskasalata/kikero (Romanian)
  • Cédric VALMARY (French)
  • Lene Antonsen (Saami)
  • Tolgonay (Kyrgyz)
  • wei2912 (Chinese)
  • Märdan (Uyghur)
  • Flammie (Finnish)
  • inariksit (Finnish)
  • youssef (French)
  • n0nick (Hebrew)
  • vmax = Max Vorobev (Russian)
  • bmansurov (Uzbek)
  • Çağrı (Turkish)

Please cite[edit]