1
0
mirror of https://github.com/node-red/node-red.git synced 2023-10-10 13:36:53 +02:00

Adding bidi preferences (#1375)

This commit is contained in:
Moshe Wajnberg 2017-09-17 11:05:26 +03:00 committed by Nick O'Leary
parent a844ca161f
commit 1532d9b6e2
3 changed files with 71 additions and 6 deletions

View File

@ -15,7 +15,9 @@
**/ **/
RED.text = {}; RED.text = {};
RED.text.bidi = (function() { RED.text.bidi = (function() {
var textDir = ""; var textDir = "";
var textDirPref = "auto";
var bidiEnabled = false;
var LRE = "\u202A", var LRE = "\u202A",
RLE = "\u202B", RLE = "\u202B",
PDF = "\u202C"; PDF = "\u202C";
@ -110,8 +112,8 @@ RED.text.bidi = (function() {
} }
/** /**
* Sets the text direction preference * Sets the text direction
* @param dir - the text direction preference * @param dir - the actual text direction
*/ */
function setTextDirection(dir) { function setTextDirection(dir) {
textDir = dir; textDir = dir;
@ -120,9 +122,44 @@ RED.text.bidi = (function() {
RED.palette.refresh(); RED.palette.refresh();
enforceTextDirectionOnPage(); enforceTextDirectionOnPage();
} }
/**
* Gets the bidi enabled preference
*/
function getBidiEnabled() {
return bidiEnabled;
}
/**
* Sets the bidi enabled preference
* @param state - the bidi enabled preference
*/
function setBidiEnabled(state) {
bidiEnabled = state;
setTextDirection((state ? textDirPref : ""));
}
/**
* Gets the text direction preference
*/
function getTextDirPref() {
return textDirPref;
}
/**
* Sets the text direction preference
* @param dirPref - text direction preference
*/
function setTextDirPref(dirPref) {
textDirPref = dirPref;
setTextDirection(textDirPref);
}
return { return {
setTextDirection: setTextDirection, setBidiEnabled: setBidiEnabled,
setTextDirPref: setTextDirPref,
getBidiEnabled: getBidiEnabled,
getTextDirPref: getTextDirPref,
enforceTextDirectionWithUCC: enforceTextDirectionWithUCC, enforceTextDirectionWithUCC: enforceTextDirectionWithUCC,
resolveBaseTextDir: resolveBaseTextDir, resolveBaseTextDir: resolveBaseTextDir,
prepareInput: prepareInput prepareInput: prepareInput

View File

@ -142,8 +142,34 @@ RED.userSettings = (function() {
} }
}); });
}) })
addBidiPreferences(pane);
return pane; return pane;
} }
function addBidiPreferences(pane) {
$('<h3></h3>').text(RED._("menu.label.bidi")).appendTo(pane);
var row;
// Bidi enabled toggle
row = $('<div class="user-settings-row"></div>').appendTo(pane);
var input = $('<label for="user-settings-view-bidi-enabled"><input id="user-settings-view-bidi-enabled" type="checkbox"> '+RED._("menu.label.bidiSupport") +'</label>').appendTo(row).find("input");
input.prop('checked',RED.text.bidi.getBidiEnabled());
// Text Direction combo
row = $('<div class="user-settings-row"></div>').appendTo(pane);
$('<label for="user-settings-view-text-direction">'+RED._("menu.label.view.textDir")+'</label>').appendTo(row);
var select = $('<select id="user-settings-view-text-direction"><option value="ltr">' + RED._("menu.label.view.ltr") + '</option><option value="rtl">' + RED._("menu.label.view.rtl") + '</option><option value="auto">' + RED._("menu.label.view.auto") + '</option></select>').appendTo(row);
select.val(RED.text.bidi.getTextDirPref());
select.prop('disabled', !RED.text.bidi.getBidiEnabled());
input.change(function() {
RED.text.bidi.setBidiEnabled(input.prop('checked'));
select.prop('disabled', !RED.text.bidi.getBidiEnabled());
});
select.change(function() {
RED.text.bidi.setTextDirPref(select.val());
});
}
function setSelected(id, value) { function setSelected(id, value) {
var opt = allSettings[id]; var opt = allSettings[id];

View File

@ -67,7 +67,9 @@
"editPalette":"Manage palette", "editPalette":"Manage palette",
"other": "Other", "other": "Other",
"showTips": "Show tips", "showTips": "Show tips",
"help": "Node-RED website" "help": "Node-RED website",
"bidi": "Bidi",
"bidiSupport": "Enable Bidi support"
} }
}, },
"user": { "user": {