aboutsummaryrefslogtreecommitdiff
path: root/javascript/localization.js
diff options
context:
space:
mode:
author不会画画的中医不是好程序员 <yfszzx@gmail.com>2022-10-25 15:38:33 +0800
committerGitHub <noreply@github.com>2022-10-25 15:38:33 +0800
commit5bfa2b23ca6dad7d2664bfab5dab4b1dfabf5b7f (patch)
tree7e23ff3f180ada71bc0824270efa82e7cfe68397 /javascript/localization.js
parentff305acd51cc71c5eea8aee0f537a26a6d1ba2a1 (diff)
parent91c1e1e6a92061b99c92a5b1d548535907d2ad96 (diff)
Merge branch 'AUTOMATIC1111:master' into Inspiron
Diffstat (limited to 'javascript/localization.js')
-rw-r--r--javascript/localization.js21
1 files changed, 21 insertions, 0 deletions
diff --git a/javascript/localization.js b/javascript/localization.js
index e6644635..f92d2d24 100644
--- a/javascript/localization.js
+++ b/javascript/localization.js
@@ -108,6 +108,9 @@ function processNode(node){
function dumpTranslations(){
dumped = {}
+ if (localization.rtl) {
+ dumped.rtl = true
+ }
Object.keys(original_lines).forEach(function(text){
if(dumped[text] !== undefined) return
@@ -129,6 +132,24 @@ onUiUpdate(function(m){
document.addEventListener("DOMContentLoaded", function() {
processNode(gradioApp())
+
+ if (localization.rtl) { // if the language is from right to left,
+ (new MutationObserver((mutations, observer) => { // wait for the style to load
+ mutations.forEach(mutation => {
+ mutation.addedNodes.forEach(node => {
+ if (node.tagName === 'STYLE') {
+ observer.disconnect();
+
+ for (const x of node.sheet.rules) { // find all rtl media rules
+ if (Array.from(x.media || []).includes('rtl')) {
+ x.media.appendMedium('all'); // enable them
+ }
+ }
+ }
+ })
+ });
+ })).observe(gradioApp(), { childList: true });
+ }
})
function download_localization() {