Julio Montoya 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
..
README.md 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
_language_template.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
amh.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
ar.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
as.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
be.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
bg.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
bn.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
ca.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
da.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
de.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
es.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
fa.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
fr.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
gu.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
he.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
hi.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
hu.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
it.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
ja.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
kn.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
lv.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
mn.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
mr.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
my.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
ne.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
pa.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
pl.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
pt.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
ro.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
ru.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
sq.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
sr.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
sv.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
ta.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
te.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
th.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
tr.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
ur.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
vi.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años
zh.untranslated.js 9ff9f0fa6c Partial merge with 1.11.x see BT#15952 hace 5 años

README.md

Language Files

I need your help!

The language file translations are incomplete :cry:

File names are typically named after their ISO 639-1 two letter code. If a three letter code is needed, then please feel free to include it.

Any missing language files, or language files with "untranslated" in the file name (e.g. "mn.untranslated.js") indicate that no translation has been made for that language. If you are willing, your assistance would be greatly appreciated in making these translations!

What do I need to do?

Start with the _language_template.js file. I'll try to break down each section to make it easier:

Naming the file

If you don't know the language ISO 639-1 or ISO 639-2 code, look it up here. I have been using the two letter code, but if the three letter code is needed, please feel free to use it.

Now save the template file using the language code as the file name (e.g. "ru.js")

Inside the template, change "all" to the language code. Then change the language parameter to the native name of the language plus the English name in parentheses. In this example, lets say we're working on Russian, so the result would look like this:

jQuery.keyboard.language.ru = {
	language: 'Русский (Russian)',

Display text

In this section, text that appears on the keyboard and in the tooltips will need to be translated. For example, if you look at the first line:

'a' : '\u2714:Accept (Shift+Enter)',
  • The 'a' should not be modified!
    • This is the key used by the keyboard plugin to indicate that a smaller version of the accept key is being used.
    • The full version equivalent would be 'accept', but really there is no difference between the two. You can make the text of the 'a' key exactly match the 'accept' key.
  • The \u2714 is the javascript unicode hex value for a check mark.
    • The reason the unicode is used here is because of issues of files being converted to file types other than UTF-8 will corrupt the symbols.
    • It is also acceptable to use &#x2714 or ✔ (decimal) here.
    • See the get unicode value section for more information.
  • The colon (:) separates the text of the keyboard action key from the title/tooltip.
  • "Accept (Shift+Enter)" becomes the action key title/tooltip text and is only visible when the user hovers over the key with a mouse.

Decimal

Within the display text is the 'dec' definition.

'dec' : '.:Decimal',

This action key is used in the "num" (number pad) layout and will disable itself if the symbol is contained within the input/textarea content, since only one symbol is allowed.

Some languages use the comma to indicate fractional values in the number format. In this case, change the value of this display text from a period to a comma.

'dec' : ',:Decimal',

And don't forget to modify or remove the tooltip!

Wheel message

This message is displayed over non-action keys to indicate there are other keysets assigned to the key being hovered over, and using the mousewheel will allow the user quick access to those alternative keys. Only keys in the other keysets in the same position as the hovered key will be shown while scrolling.

wheelMessage : 'Use mousewheel to see other keys'

Some users/developers might find this tooltip annoying, so remove it as desired.

Combos

This may be a difficult section to deal with, so ignore it as desired.

  • First off, combination (dead keys) have been included to allow typing a key that is typically found on standard US keyboards to allow easier typing in of accented or special characters.
  • When the useCombos option is true (set as default), entering in ~a (tilde + a) would result in ã.
  • This section allows customizing this behavior.

Skipping over the comboRegex definition for now, look at the combos definitions. Here is a simplified tilde definition:

'~' : { a:"\u00e3", A:"\u00c3", e:"\u1ebd", E:"\u1ebc" }
  • The left side '~' defines the first key of the combination that the user will type in.
  • The right side contains the second key of the combination. Notice that both lower and upper case letters have been included.
  • So combining '~' with 'a' will return \u00e3 which is the javascript unicode hex value for this character: ã.
  • Combining '~' with 'A' will return \u00c3 which becomes Ã, and so on.
  • Add more, or remove combinations from this definition as desired.
  • If using basic letters a-z as the second key of the combination, then no changes will be made to the comboRegex definition.

Now lets say you want to add the combination |0 (vertical bar + zero) to create 'ϕ' (it's an example, just go with it; see the get unicode value section on how to get a unicode value)

  • A new combo will need to be added

    '|' : { 0:"\u0ed5" }
    
  • And the comboRegex will need to be updated

    //                        **       * <- new additions
    comboRegex : /([`\'~\^\"ao\|])([a-z0])/mig
    

See the next section for an explanation.

If you don't know regex, feel free to open an issue and ask for assistance.

Combo regular expression (comboRegex)

The default comboRegex is as follows:

comboRegex : /([`\'~\^\"ao])([a-z])/mig,

It is split into two halves by parentheses

([`\'~\^\"ao]) // first character of combo
([a-z])        // second character of combo

In order to add a new combo, like the |0 (vertical bar + zero) to create 'ϕ' example, additions will be made in both halves of the regular expression

([`\'~\^\"ao\|])

Adding \| to the first character because | has special meaning in regexp and should be escaped. I know some may argue that this particular character doesn't need to be escaped inside of square brackets, but I added it here just to be safe, and it doesn't hurt anything.

([a-z0])

Adding 0 because it only targets letters a-z (case-insensitive) by default.

The resulting definition becomes:

comboRegex : /([`\'~\^\"ao\|])([a-z0])/mig

RTL

If the language has a right-to-left direction, then set the rtl setting:

// language direction
rtl: true

This value defaults to false

Getting a Unicode Value

Can't type the character?

Use shapecatcher.com

  • This site allows you to draw the symbol, then choose the appropriate symbol from the results.
  • A unicode value is included with the results as 0xhhhh. Change the value to \uhhhh or &#xhhhh.

Already have the character?

To convert a character, or list of characters to its unicode value, use Google Closure Compiler

  • Click "Reset"
  • Then paste in some valid javascript... something like this:

    var a = 'Thìs ïs ã Têst';
    
  • Click "Compile"

  • On the right side a compressed result will appear

    var a="Th\u00ecs \u00efs \u00e3 T\u00east";
    

Template Language Definition

jQuery.keyboard.language.all = {
	language: 'All (All)',
	display : {
		'a'      : '\u2714:Accept (Shift+Enter)', // check mark - same action as accept
		'accept' : 'Accept:Accept (Shift+Enter)',
		'alt'    : 'AltGr:Alternate Graphemes',
		'b'      : '\u2190:Backspace',    // Left arrow (same as &larr;)
		'bksp'   : 'Bksp:Backspace',
		'c'      : '\u2716:Cancel (Esc)', // big X, close - same action as cancel
		'cancel' : 'Cancel:Cancel (Esc)',
		'clear'  : 'C:Clear',             // clear num pad
		'combo'  : '\u00f6:Toggle Combo Keys',
		'dec'    : '.:Decimal',           // decimal point for num pad (optional), change '.' to ',' for European format
		'e'      : '\u21b5:Enter',        // down, then left arrow - enter symbol
		'enter'  : 'Enter:Enter',
		'lock'   : '\u21ea Lock:Caps Lock', // caps lock
		's'      : '\u21e7:Shift',        // thick hollow up arrow
		'shift'  : 'Shift:Shift',
		'sign'   : '\u00b1:Change Sign',  // +/- sign for num pad
		'space'  : '&nbsp;:Space',
		't'      : '\u21e5:Tab',          // right arrow to bar (used since this virtual keyboard works with one directional tabs)
		'tab'    : '\u21e5 Tab:Tab'       // \u21b9 is the true tab symbol (left & right arrows)
	},
	// Message added to the key title while hovering, if the mousewheel plugin exists
	wheelMessage : 'Use mousewheel to see other keys'

	// uncomment, then include changes to the comboRegex here
	/*
	, comboRegex : /([`\'~\^\"ao])([a-z])/mig,
	*/

	// uncomment, then include any changes to the combos option here
	/*
	, combos : {
		// grave
		'`' : { a:"\u00e0", A:"\u00c0", e:"\u00e8", E:"\u00c8", i:"\u00ec", I:"\u00cc", o:"\u00f2", O:"\u00d2",
				u:"\u00f9", U:"\u00d9", y:"\u1ef3", Y:"\u1ef2" },
		// acute & cedilla
		"'" : { a:"\u00e1", A:"\u00c1", e:"\u00e9", E:"\u00c9", i:"\u00ed", I:"\u00cd", o:"\u00f3", O:"\u00d3",
				u:"\u00fa", U:"\u00da", y:"\u00fd", Y:"\u00dd" },
		// umlaut/trema
		'"' : { a:"\u00e4", A:"\u00c4", e:"\u00eb", E:"\u00cb", i:"\u00ef", I:"\u00cf", o:"\u00f6", O:"\u00d6",
				u:"\u00fc", U:"\u00dc", y:"\u00ff", Y:"\u0178" },
		// circumflex
		'^' : { a:"\u00e2", A:"\u00c2", e:"\u00ea", E:"\u00ca", i:"\u00ee", I:"\u00ce", o:"\u00f4", O:"\u00d4",
				u:"\u00fb", U:"\u00db", y:"\u0177", Y:"\u0176" },
		// tilde
		'~' : { a:"\u00e3", A:"\u00c3", e:"\u1ebd", E:"\u1ebc", i:"\u0129", I:"\u0128", o:"\u00f5", O:"\u00d5",
				u:"\u0169", U:"\u0168", y:"\u1ef9", Y:"\u1ef8", n:"\u00f1", N:"\u00d1" }
	}
	*/
};