61684b1071
* Initial implementation; Happy flow * Maybe revert this * Functional prototype * feat(facial-expressions): get stream when changing background effect and use presenter effect with camera * add(facial-expressions): array that stores the expressions durin the meeting * refactor(facial-expressions): capture imagebitmap from stream with imagecapture api * add(speaker-stats): expression label * fix(facial-expression): expression store * revert: expression leabel on speaker stats * add(facial-expressions): broadcast of expression when it changes * feat: facial expression handling on prosody * fix(facial-expressions): get the right track when opening and closing camera * add(speaker-stats): facial expression column * fix(facial-expressions): allow to start facial recognition only after joining conference * fix(mod_speakerstats_component): storing last emotion in speaker stats component and sending it * chore(facial-expressions): change detection from 2000ms to 1000ms * add(facial-expressions): send expression to server when there is only one participant * feat(facial-expressions): store expresions as a timeline * feat(mod_speakerstats_component): store facial expresions as a timeline * fix(facial-expressions): stop facial recognition only when muting video track * fix(facial-expressions): presenter mode get right track to detect face * add: polyfils for image capture for firefox and safari * refactor(facial-expressions): store expressions by counting them in a map * chore(facial-expressions): remove manually assigning the backend for tenserflowjs * feat(facial-expressions): move face-api from main thread to web worker * fix(facial-expressions): make feature work on firefox and safari * feat(facial-expressions): camera time tracker * feat(facial-expressions): camera time tracker in prosody * add(facial-expressions): expressions time as TimeElapsed object in speaker stats * fix(facial-expresions): lower the frequency of detection when tf uses cpu backend * add(facial-expressions): duration to the expression and send it with durantion when it is done * fix(facial-expressions): prosody speaker stats covert fro string to number and bool values set by xmpp * refactor(facial-expressions): change expressions labels from text to emoji * refactor(facial-expressions): remove camera time tracker * add(facial-expressions): detection time interval * chore(facial-expressions): add docs and minor refactor of the code * refactor(facial-expressions): put timeout in worker and remove set interval in main thread * feat(facial-expressions): disable feature in the config * add(facial-expressions): tooltips of labels in speaker stats * refactor(facial-expressions): send facial expressions function and remove some unused functions and console logs * refactor(facial-expressions): rename action type when a change is done to the track by the virtual backgrounds to be used in facial expressions middleware * chore(facial-expressions): order imports and format some code * fix(facial-expressions): rebase issues with newer master * fix(facial-expressions): package-lock.json * fix(facial-expression): add commented default value of disableFacialRecognition flag and short description * fix(facial-expressions): change disableFacialRecognition to enableFacialRecognition flag in config * fix: resources load-test package-lock.json * fix(facial-expressions): set and get facial expressions only if facial recognition enabled * add: facial recognition resources folder in .eslintignore * chore: package-lock update * fix: package-lock.json * fix(facial-expressions): gpu memory leak in the web worker * fix(facial-expressions): set cpu time interval for detection to 6000ms * chore(speaker-stats): fix indentation * chore(facial-expressions): remove empty lines between comments and type declarations * fix(facial-expressions): remove camera timetracker * fix(facial-expressions): remove facialRecognitionAllowed flag * fix(facial-expressions): remove sending interval time to worker * refactor(facial-expression): middleware * fix(facial-expression): end tensor scope after setting backend * fix(facial-expressions): sending info back to worker only on facial expression message * fix: lint errors * refactor(facial-expressions): bundle web worker using webpack * fix: deploy-facial-expressions command in makefile * chore: fix load test package-lock.json and package.json * chore: sync package-lock.json Co-authored-by: Mihai-Andrei Uscat <mihai.uscat@8x8.com> |
||
---|---|---|
.. | ||
languages-af.json | ||
languages-ar.json | ||
languages-be.json | ||
languages-bg.json | ||
languages-ca.json | ||
languages-cs.json | ||
languages-da.json | ||
languages-de.json | ||
languages-el.json | ||
languages-enGB.json | ||
languages-eo.json | ||
languages-es.json | ||
languages-esUS.json | ||
languages-et.json | ||
languages-eu.json | ||
languages-fa.json | ||
languages-fi.json | ||
languages-fr.json | ||
languages-frCA.json | ||
languages-fy.json | ||
languages-gl.json | ||
languages-he.json | ||
languages-hi.json | ||
languages-hr.json | ||
languages-hu.json | ||
languages-hy.json | ||
languages-id.json | ||
languages-is.json | ||
languages-it.json | ||
languages-ja.json | ||
languages-ka.json | ||
languages-kab.json | ||
languages-km.json | ||
languages-ko.json | ||
languages-lt.json | ||
languages-lv.json | ||
languages-mn.json | ||
languages-mr.json | ||
languages-nb.json | ||
languages-nl.json | ||
languages-oc.json | ||
languages-pl.json | ||
languages-pt.json | ||
languages-ptBR.json | ||
languages-ro.json | ||
languages-ru.json | ||
languages-sc.json | ||
languages-sk.json | ||
languages-sl.json | ||
languages-sq.json | ||
languages-sr.json | ||
languages-sv.json | ||
languages-te.json | ||
languages-tr.json | ||
languages-uk.json | ||
languages-vi.json | ||
languages-zhCN.json | ||
languages-zhTW.json | ||
languages.json | ||
main-af.json | ||
main-ar.json | ||
main-be.json | ||
main-bg.json | ||
main-ca.json | ||
main-cs.json | ||
main-da.json | ||
main-de.json | ||
main-el.json | ||
main-enGB.json | ||
main-eo.json | ||
main-es.json | ||
main-esUS.json | ||
main-et.json | ||
main-eu.json | ||
main-fa.json | ||
main-fi.json | ||
main-fr.json | ||
main-frCA.json | ||
main-gl.json | ||
main-he.json | ||
main-hi.json | ||
main-hr.json | ||
main-hu.json | ||
main-hy.json | ||
main-id.json | ||
main-is.json | ||
main-it.json | ||
main-ja.json | ||
main-kab.json | ||
main-ko.json | ||
main-lt.json | ||
main-lv.json | ||
main-ml.json | ||
main-mn.json | ||
main-mr.json | ||
main-nb.json | ||
main-nl.json | ||
main-oc.json | ||
main-pl.json | ||
main-pt.json | ||
main-ptBR.json | ||
main-ro.json | ||
main-ru.json | ||
main-sc.json | ||
main-sk.json | ||
main-sl.json | ||
main-sq.json | ||
main-sr.json | ||
main-sv.json | ||
main-te.json | ||
main-tr.json | ||
main-uk.json | ||
main-vi.json | ||
main-zhCN.json | ||
main-zhTW.json | ||
main.json | ||
readme.md | ||
update-translation.js |
readme.md
Jitsi Meet Translation
Jitsi Meet uses i18next library for translation. i18next uses separate json files for each language.
Translating Jitsi Meet
The translation of Jitsi Meet is handled editing manually the language files.
You can use the update-translation.js
script as follows to help you with that:
cd lang
node update-translation.js main-es.json
That will cause the main-es.json
file to be updated with all the missing keys set as empty
strings. All that's missing is for you to fill in the blanks!
Development
If you want to add new functionality for Jitsi Meet and you have texts that need to be translated you must add key and value in main.json file in English for each translatable text. Than you can use the key to get the translated text for the current language.
You can add translatable text in the HTML:
- via attribute on HTML element - add data-i18n attribute with value the key of the translatable text.
<span data-i18n="dialog.OK">OK</span>
You can also use APP.translation.generateTranslationHTML(key, options) to get this HTML code as Javascript string.
APP.translation.generateTranslationHTML("dialog.OK") // returns <span data-i18n="dialog.OK">OK</span>
The value in the options parameter will be added in data-i18n-options attribute of the element.
Note: If you dynamically add HTML elements don't forget to call APP.translation.translateElement(jquery_selector) to translate the text initially.
APP.translation.translateString("dialog.OK") // returns the value for the key of the current language file. "OK" for example.
For the available values of options
parameter for the above methods of translation module see i18next documentation.
Note: It is useful to add attributes in the HTML for persistent HTML elements because when the language is changed the text will be automatically translated.