mirror of
https://github.com/twisterarmy/twister-html.git
synced 2025-01-27 23:24:26 +00:00
Merge pull request #134 from erqan/ascii-to-unicode
automatic ascii to unicode conversion feature
This commit is contained in:
commit
c00a2a4cf9
@ -1542,6 +1542,17 @@ button.disabled:hover
|
|||||||
#notifyForm p, #choseLanguage p, #keysOpt p {
|
#notifyForm p, #choseLanguage p, #keysOpt p {
|
||||||
margin-top: 15px;
|
margin-top: 15px;
|
||||||
}
|
}
|
||||||
|
.suboptions {
|
||||||
|
margin: 5px 30px;
|
||||||
|
border: double 2px rgba( 69, 71, 77, .1 );
|
||||||
|
height: 0px;
|
||||||
|
overflow: hidden;
|
||||||
|
transition: height 1s linear;
|
||||||
|
-webkit-transition: height 1s linear;
|
||||||
|
-moz-transition: height 1s linear;
|
||||||
|
-o-transition: height 1s linear;
|
||||||
|
-ms-transition: height 1s linear;
|
||||||
|
}
|
||||||
|
|
||||||
/* Autocomplite*/
|
/* Autocomplite*/
|
||||||
.textcomplete-wrapper textarea {
|
.textcomplete-wrapper textarea {
|
||||||
|
@ -229,6 +229,7 @@
|
|||||||
<textarea placeholder="Reply..."></textarea>
|
<textarea placeholder="Reply..."></textarea>
|
||||||
<div class="post-area-extras">
|
<div class="post-area-extras">
|
||||||
<span class="post-area-remaining">140</span>
|
<span class="post-area-remaining">140</span>
|
||||||
|
<button class="undo-unicode disabled" disabled="true">undo</button>
|
||||||
<button class="post-submit disabled" disabled="true">post</button>
|
<button class="post-submit disabled" disabled="true">post</button>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
@ -282,6 +283,7 @@
|
|||||||
<textarea placeholder="New Post..."></textarea>
|
<textarea placeholder="New Post..."></textarea>
|
||||||
<div class="post-area-extras">
|
<div class="post-area-extras">
|
||||||
<span class="post-area-remaining">140</span>
|
<span class="post-area-remaining">140</span>
|
||||||
|
<button class="undo-unicode disabled" disabled="true">undo</button>
|
||||||
<button class="post-submit disabled" disabled="true">post</button>
|
<button class="post-submit disabled" disabled="true">post</button>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
@ -329,6 +331,7 @@
|
|||||||
<textarea placeholder="New direct message..."></textarea>
|
<textarea placeholder="New direct message..."></textarea>
|
||||||
<div class="post-area-extras">
|
<div class="post-area-extras">
|
||||||
<span class="post-area-remaining">140</span>
|
<span class="post-area-remaining">140</span>
|
||||||
|
<button class="undo-unicode disabled" disabled="true">undo</button>
|
||||||
<button class="dm-submit disabled" disabled="true">send</button>
|
<button class="dm-submit disabled" disabled="true">send</button>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
|
@ -127,6 +127,7 @@
|
|||||||
<textarea placeholder="New Post..."></textarea>
|
<textarea placeholder="New Post..."></textarea>
|
||||||
<div class="post-area-extras">
|
<div class="post-area-extras">
|
||||||
<span class="post-area-remaining">140</span>
|
<span class="post-area-remaining">140</span>
|
||||||
|
<button class="undo-unicode disabled" disabled="true">undo</button>
|
||||||
<button class="post-submit disabled" disabled="true">post</button>
|
<button class="post-submit disabled" disabled="true">post</button>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
@ -251,6 +252,7 @@
|
|||||||
<textarea placeholder="Reply..."></textarea>
|
<textarea placeholder="Reply..."></textarea>
|
||||||
<div class="post-area-extras">
|
<div class="post-area-extras">
|
||||||
<span class="post-area-remaining">140</span>
|
<span class="post-area-remaining">140</span>
|
||||||
|
<button class="undo-unicode disabled" disabled="true">undo</button>
|
||||||
<button class="post-submit disabled" disabled="true">post</button>
|
<button class="post-submit disabled" disabled="true">post</button>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
@ -305,6 +307,7 @@
|
|||||||
<textarea placeholder="New Post..."></textarea>
|
<textarea placeholder="New Post..."></textarea>
|
||||||
<div class="post-area-extras">
|
<div class="post-area-extras">
|
||||||
<span class="post-area-remaining">140</span>
|
<span class="post-area-remaining">140</span>
|
||||||
|
<button class="undo-unicode disabled" disabled="true">undo</button>
|
||||||
<button class="post-submit disabled" disabled="true">post</button>
|
<button class="post-submit disabled" disabled="true">post</button>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
@ -352,6 +355,7 @@
|
|||||||
<textarea placeholder="New direct message..."></textarea>
|
<textarea placeholder="New direct message..."></textarea>
|
||||||
<div class="post-area-extras">
|
<div class="post-area-extras">
|
||||||
<span class="post-area-remaining">140</span>
|
<span class="post-area-remaining">140</span>
|
||||||
|
<button class="undo-unicode disabled" disabled="true">undo</button>
|
||||||
<button title="Direct messages are encrypted, only you and receiver can read them" style="margin-right:7.5%;" class="dm-submit disabled" disabled="true">send</button>
|
<button title="Direct messages are encrypted, only you and receiver can read them" style="margin-right:7.5%;" class="dm-submit disabled" disabled="true">send</button>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
|
@ -424,6 +424,8 @@ function replyTextKeypress(e) {
|
|||||||
var $this = $( this );
|
var $this = $( this );
|
||||||
var tweetForm = $this.parents("form");
|
var tweetForm = $this.parents("form");
|
||||||
if( tweetForm != undefined ) {
|
if( tweetForm != undefined ) {
|
||||||
|
if ($.Options.getUnicodeConversionOpt() !== "disable")
|
||||||
|
$this.val(convert2Unicodes($this.val(), $this));
|
||||||
var c = 140 - $this.val().length;
|
var c = 140 - $this.val().length;
|
||||||
var remainingCount = tweetForm.find(".post-area-remaining");
|
var remainingCount = tweetForm.find(".post-area-remaining");
|
||||||
remainingCount.text(c);
|
remainingCount.text(c);
|
||||||
@ -458,6 +460,466 @@ function replyTextKeypress(e) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* unicode convertion list
|
||||||
|
* k: original string to be replaced
|
||||||
|
* u: unicode
|
||||||
|
* n: index of char to be stored and appended to result
|
||||||
|
*/
|
||||||
|
var unicodeConversionList = {
|
||||||
|
"ponctuations": [
|
||||||
|
{
|
||||||
|
"k": /\.\.\./,
|
||||||
|
"u": "\u2026",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /\.\../,
|
||||||
|
"u": "\u2025",
|
||||||
|
"n": 2
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /\?\?/,
|
||||||
|
"u": "\u2047",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /\?!/,
|
||||||
|
"u": "\u2048",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /!\?/,
|
||||||
|
"u": "\u2049",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /!!/,
|
||||||
|
"u": "\u203C",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /--/,
|
||||||
|
"u": "\u2014",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /~~/,
|
||||||
|
"u": "\u2053",
|
||||||
|
"n": -1
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"emotions": [
|
||||||
|
{
|
||||||
|
"k": /:.{0,1}D/,
|
||||||
|
"u": "\uD83D\uDE03",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /(0|O):-{0,1}\)/i,
|
||||||
|
"u": "\uD83D\uDE07",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /:beer:/,
|
||||||
|
"u": "\uD83C\uDF7A",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /3:-{0,1}\)/,
|
||||||
|
"u": "\uD83D\uDE08",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /<3/,
|
||||||
|
"u":"\u2764",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /o.O|:\/|:\\/,
|
||||||
|
"u": "\uD83D\uDE15",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /:\'\(/,
|
||||||
|
"u": "\uD83D\uDE22",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /(:|=)-{0,1}\(/,
|
||||||
|
"u": "\uD83D\uDE1E",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /8(\)<|\|)/,
|
||||||
|
"u": "\uD83D\uDE0E",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /(:|=)-{0,1}(\)|\])/,
|
||||||
|
"u": "\uD83D\uDE0A",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /(\(|\[)-{0,1}(:|=)/,
|
||||||
|
"u": "\uD83D\uDE0A",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /:\*/,
|
||||||
|
"u": "\uD83D\uDE17",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /\^-{0,1}\^/,
|
||||||
|
"u": "\uD83D\uDE06",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /:p/i,
|
||||||
|
"u": "\uD83D\uDE1B",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /;-{0,1}\)/,
|
||||||
|
"u": "\uD83D\uDE09",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /\(-{0,1};/,
|
||||||
|
"u": "\uD83D\uDE09",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /:(O|0)/,
|
||||||
|
"u": "\uD83D\uDE2E",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /:@/,
|
||||||
|
"u": "\uD83D\uDE31",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /:\|/,
|
||||||
|
"u": "\uD83D\uDE10",
|
||||||
|
"n": -1
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"signs": [
|
||||||
|
{
|
||||||
|
"k": / tel( |:|=)/i,
|
||||||
|
"u": " \u2121",
|
||||||
|
"n": 4
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /^tel( |:|=)/i,
|
||||||
|
"u": "\u2121",
|
||||||
|
"n": 3
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": / fax( |:|=)/i,
|
||||||
|
"u": " \u213B",
|
||||||
|
"n": 4
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /^fax( |:|=)/i,
|
||||||
|
"u": "\u213B",
|
||||||
|
"n": 3
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"fractions": [
|
||||||
|
{
|
||||||
|
"k": /1\/2/,
|
||||||
|
"u": "\u00BD",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /1\/3/,
|
||||||
|
"u": "\u2153",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /2\/3/,
|
||||||
|
"u": "\u2154",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /1\/4/,
|
||||||
|
"u": "\u00BC",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /3\/4/,
|
||||||
|
"u": "\u00BE",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /1\/5/,
|
||||||
|
"u": "\u2155",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /2\/5/,
|
||||||
|
"u": "\u2156",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /3\/5/,
|
||||||
|
"u": "\u2157",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /4\/5/,
|
||||||
|
"u": "\u2158",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /1\/6/,
|
||||||
|
"u": "\u2159",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /5\/6/,
|
||||||
|
"u": "\u215A",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /1\/7/,
|
||||||
|
"u": "\u2150",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /1\/8/,
|
||||||
|
"u": "\u215B",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /3\/8/,
|
||||||
|
"u": "\u215C",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /5\/8/,
|
||||||
|
"u": "\u215D",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /7\/8/,
|
||||||
|
"u": "\u215E",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /1\/9/,
|
||||||
|
"u": "\u2151",
|
||||||
|
"n": -1
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"k": /1\/10/,
|
||||||
|
"u": "\u2152",
|
||||||
|
"n": -1
|
||||||
|
}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* a stack for undo...
|
||||||
|
* element for the unicodeConversionStack
|
||||||
|
* {
|
||||||
|
k: original string that's replaced
|
||||||
|
u: unicode
|
||||||
|
p: position in string
|
||||||
|
l: length of k
|
||||||
|
m: new string length after convertion
|
||||||
|
* }
|
||||||
|
*/
|
||||||
|
var unicodeConversionStack = [];
|
||||||
|
//we want to handle new typed text after the last conversion.
|
||||||
|
var lastConvertedIndex = -1;
|
||||||
|
|
||||||
|
function convert2Unicodes(s, ta) {
|
||||||
|
|
||||||
|
var tmp = s;
|
||||||
|
|
||||||
|
//check if there is a deletion...
|
||||||
|
//NOTE: BUGGY... can't handle everytime...
|
||||||
|
if (unicodeConversionStack.length>0 && s.length < unicodeConversionStack[0].m){
|
||||||
|
//check if a replaced unicode was deleted...
|
||||||
|
for (var i=unicodeConversionStack.length-1; i>=0; i--){
|
||||||
|
//get position and check the positions are same...
|
||||||
|
var ni = s.indexOf(unicodeConversionStack[i].u);
|
||||||
|
if (ni > -1 && s[ni] !== unicodeConversionStack[i].p){
|
||||||
|
var op = -1;
|
||||||
|
for (var j=i-1; j>=0; j--){
|
||||||
|
if (unicodeConversionStack[j].u === unicodeConversionStack[i].u){
|
||||||
|
if (unicodeConversionStack[j].p === ni){
|
||||||
|
op = -1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
op = unicodeConversionStack[j].p;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (op === -1) {
|
||||||
|
//remove deleted unicode...
|
||||||
|
unicodeConversionStack.splice(i, 1);
|
||||||
|
} else {
|
||||||
|
//update the position of the unicode!
|
||||||
|
unicodeConversionStack[i].p = ni;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
unicodeConversionStack[0].m = s.length;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (s.length < lastConvertedIndex)
|
||||||
|
lastConvertedIndex = s.length;
|
||||||
|
|
||||||
|
if ($.Options.getUnicodeConversionOpt() === "enable" || $.Options.getConvertPunctuationsOpt()){
|
||||||
|
|
||||||
|
var list = unicodeConversionList.ponctuations;
|
||||||
|
for (var i=0; i<list.length; i++){
|
||||||
|
var kl = list[i].k.exec(tmp);
|
||||||
|
if (kl && kl.length > 0 && kl.index >= lastConvertedIndex) {
|
||||||
|
var nc = "";
|
||||||
|
if (list[i].n > -1){
|
||||||
|
//if it's necessary, get any next char to prevent from any data loss
|
||||||
|
nc = tmp[kl.index + list[i].n];
|
||||||
|
}
|
||||||
|
tmp = tmp.replace(list[i].k, list[i].u + nc);
|
||||||
|
var len = s.length - tmp.length + list[i].u.length;
|
||||||
|
unicodeConversionStack.unshift({
|
||||||
|
"k": s.substr(kl.index, len),
|
||||||
|
"u": list[i].u,
|
||||||
|
"p": kl.index,
|
||||||
|
"l": len,
|
||||||
|
"m": tmp.length
|
||||||
|
});
|
||||||
|
s = tmp;
|
||||||
|
lastConvertedIndex = tmp.length;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($.Options.getUnicodeConversionOpt() === "enable"|| $.Options.getConvertEmotionsOpt()){
|
||||||
|
|
||||||
|
var list = unicodeConversionList.emotions;
|
||||||
|
for (var i=0; i<list.length; i++){
|
||||||
|
var kl = list[i].k.exec(tmp);
|
||||||
|
if (kl && kl.length > 0 && kl.index >= lastConvertedIndex) {
|
||||||
|
var nc = "";
|
||||||
|
if (list[i].n > -1){
|
||||||
|
//if it's necessary, get any next char to prevent from any data loss
|
||||||
|
nc = tmp[kl.index + list[i].n];
|
||||||
|
}
|
||||||
|
tmp = tmp.replace(list[i].k, list[i].u + nc);
|
||||||
|
var len = s.length - tmp.length + list[i].u.length;
|
||||||
|
unicodeConversionStack.unshift({
|
||||||
|
"k": s.substr(kl.index, len),
|
||||||
|
"u": list[i].u,
|
||||||
|
"p": kl.index,
|
||||||
|
"l": len,
|
||||||
|
"m": tmp.length
|
||||||
|
});
|
||||||
|
s = tmp;
|
||||||
|
lastConvertedIndex = tmp.length;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($.Options.getUnicodeConversionOpt() === "enable"|| $.Options.getConvertSignsOpt()){
|
||||||
|
|
||||||
|
var list = unicodeConversionList.signs;
|
||||||
|
for (var i=0; i<list.length; i++){
|
||||||
|
var kl = list[i].k.exec(tmp);
|
||||||
|
if (kl && kl.length > 0 && kl.index >= lastConvertedIndex) {
|
||||||
|
var nc = "";
|
||||||
|
if (list[i].n > -1){
|
||||||
|
//if it's necessary, get any next char to prevent from any data loss
|
||||||
|
nc = tmp[kl.index + list[i].n];
|
||||||
|
}
|
||||||
|
tmp = tmp.replace(list[i].k, list[i].u + nc);
|
||||||
|
var len = s.length - tmp.length + list[i].u.length;
|
||||||
|
unicodeConversionStack.unshift({
|
||||||
|
"k": s.substr(kl.index, len),
|
||||||
|
"u": list[i].u,
|
||||||
|
"p": kl.index,
|
||||||
|
"l": len,
|
||||||
|
"m": tmp.length
|
||||||
|
});
|
||||||
|
s = tmp;
|
||||||
|
lastConvertedIndex = tmp.length;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($.Options.getUnicodeConversionOpt() === "enable"|| $.Options.getConvertFractionsOpt()){
|
||||||
|
|
||||||
|
var list = unicodeConversionList.fractions;
|
||||||
|
for (var i=0; i<list.length; i++){
|
||||||
|
var kl = list[i].k.exec(tmp);
|
||||||
|
if (kl && kl.length > 0 && kl.index >= lastConvertedIndex) {
|
||||||
|
var nc = "";
|
||||||
|
if (list[i].n > -1){
|
||||||
|
//if it's necessary, get any next char to prevent from any data loss
|
||||||
|
nc = tmp[kl.index + list[i].n];
|
||||||
|
}
|
||||||
|
tmp = tmp.replace(list[i].k, list[i].u + nc);
|
||||||
|
var len = s.length - tmp.length + list[i].u.length;
|
||||||
|
unicodeConversionStack.unshift({
|
||||||
|
"k": s.substr(kl.index, len),
|
||||||
|
"u": list[i].u,
|
||||||
|
"p": kl.index,
|
||||||
|
"l": len,
|
||||||
|
"m": tmp.length
|
||||||
|
});
|
||||||
|
s = tmp;
|
||||||
|
lastConvertedIndex = tmp.length;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (unicodeConversionStack.length > 0){
|
||||||
|
var ub = ta.closest(".post-area-new").find(".undo-unicode");
|
||||||
|
ub.text("undo: " + unicodeConversionStack[0].u);
|
||||||
|
$.MAL.enableButton(ub);
|
||||||
|
} else {
|
||||||
|
$.MAL.disableButton(ta.closest(".post-area-new").find(".undo-unicode"));
|
||||||
|
}
|
||||||
|
|
||||||
|
return tmp;
|
||||||
|
}
|
||||||
|
|
||||||
|
//BUGGY... if user deletes something in the middle, stack could be deformed...
|
||||||
|
function undoLastUnicode(e) {
|
||||||
|
e.stopPropagation();
|
||||||
|
e.preventDefault();
|
||||||
|
|
||||||
|
if (unicodeConversionStack.length === 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
var uc = unicodeConversionStack.shift();
|
||||||
|
|
||||||
|
$ta = $(this).closest(".post-area-new").find("textarea");
|
||||||
|
var pt = $ta.val();
|
||||||
|
|
||||||
|
if (pt.substr(uc.p, uc.u.length) === uc.u)
|
||||||
|
$ta.val(pt.substr(0,uc.p) + uc.k + pt.substr(uc.p + uc.u.length));
|
||||||
|
else {
|
||||||
|
//if it can't be found at its index, last unicode will be removed
|
||||||
|
var i = pt.lastIndexOf(uc.u);
|
||||||
|
if (i>-1) {
|
||||||
|
$ta.val(pt.substr(0,i) + uc.k + pt.substr(i + uc.u.length));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (unicodeConversionStack.length > 0)
|
||||||
|
$(this).text("undo: " + unicodeConversionStack[0].u);
|
||||||
|
else
|
||||||
|
$.MAL.disableButton($(this));
|
||||||
|
|
||||||
|
lastConvertedIndex = $ta.val().length;
|
||||||
|
}
|
||||||
|
|
||||||
var postSubmit = function(e)
|
var postSubmit = function(e)
|
||||||
{
|
{
|
||||||
e.stopPropagation();
|
e.stopPropagation();
|
||||||
@ -518,6 +980,11 @@ function initInterfaceCommon() {
|
|||||||
$( ".post-submit").click( postSubmit );
|
$( ".post-submit").click( postSubmit );
|
||||||
$( ".modal-propagate").click( retweetSubmit );
|
$( ".modal-propagate").click( retweetSubmit );
|
||||||
|
|
||||||
|
if ($.Options.getUnicodeConversionOpt() === "disable")
|
||||||
|
$( ".undo-unicode" ).click( undoLastUnicode ).css("display", "none");
|
||||||
|
else
|
||||||
|
$( ".undo-unicode" ).click( undoLastUnicode );
|
||||||
|
|
||||||
var $replyText = $( ".post-area-new textarea" );
|
var $replyText = $( ".post-area-new textarea" );
|
||||||
$replyText.on("keyup", replyTextKeypress );
|
$replyText.on("keyup", replyTextKeypress );
|
||||||
|
|
||||||
|
@ -174,7 +174,36 @@ if(preferredLanguage == "en"){
|
|||||||
"You are not following anyone because you are not logged in.": "You are not following anyone because you are not logged in.",
|
"You are not following anyone because you are not logged in.": "You are not following anyone because you are not logged in.",
|
||||||
"You don't have any followers because you are not logged in.": "You don't have any followers because you are not logged in.",
|
"You don't have any followers because you are not logged in.": "You don't have any followers because you are not logged in.",
|
||||||
"No one can mention you because you are not logged in.": "No one can mention you because you are not logged in.",
|
"No one can mention you because you are not logged in.": "No one can mention you because you are not logged in.",
|
||||||
"You don't have any profile because you are not logged in.": "You don't have any profile because you are not logged in."
|
"You don't have any profile because you are not logged in.": "You don't have any profile because you are not logged in.",
|
||||||
|
"Options": "Options",
|
||||||
|
"Switch to Promoted posts": "Switch to Promoted posts",
|
||||||
|
"Switch to Normal posts": "Switch to Promoted posts",
|
||||||
|
"Use language": "Use language",
|
||||||
|
"Ignore": "Ignore",
|
||||||
|
"Theme": "Theme",
|
||||||
|
"Keys": "Keys",
|
||||||
|
"Sound notifications": "Sound notifications",
|
||||||
|
"Send key": "Send key",
|
||||||
|
"Posts display": "Posts display",
|
||||||
|
"Post editor": "Post editor",
|
||||||
|
"Inline image preview": "Inline image preview",
|
||||||
|
"Display": "Display",
|
||||||
|
"Line feeds": "Line feeds",
|
||||||
|
"Supported punctuations:": "Supported punctuations:",
|
||||||
|
"Supported emotions:": "Supported emotions:",
|
||||||
|
"Supported signs:": "Supported signs:",
|
||||||
|
"Supported fractions:": "Supported fractions:",
|
||||||
|
"Automatic unicode conversion options": "Automatic unicode conversion options",
|
||||||
|
"Convert punctuations to unicode": "Convert punctuations to unicode",
|
||||||
|
"Convert emotions codes to unicode symbols": "Convert emotions codes to unicode symbols",
|
||||||
|
"Convert common signs to unicode": "Convert common signs to unicode",
|
||||||
|
"Convert fractions to unicode": "Convert fractions to unicode",
|
||||||
|
"Convert all": "Convert all",
|
||||||
|
"Auto": "Auto",
|
||||||
|
"Original": "Original",
|
||||||
|
"none": "none",
|
||||||
|
"Custom": "Custom",
|
||||||
|
"Mentions": "Mentions",
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
if(preferredLanguage == "es"){
|
if(preferredLanguage == "es"){
|
||||||
@ -1742,7 +1771,42 @@ if(preferredLanguage == "tr"){
|
|||||||
"Secret key:": "Gizli anahtar:",
|
"Secret key:": "Gizli anahtar:",
|
||||||
"Options": "Ayarlar",
|
"Options": "Ayarlar",
|
||||||
"Switch to Promoted posts": "Destekli Mesajlara Geç",
|
"Switch to Promoted posts": "Destekli Mesajlara Geç",
|
||||||
"Switch to Normal posts": "Normal Mesajlara Geç"
|
"Switch to Normal posts": "Normal Mesajlara Geç",
|
||||||
|
"Use language": "Dil ayarla",
|
||||||
|
"Ignore": "Görmezden gel",
|
||||||
|
"Theme": "Tema",
|
||||||
|
"Keys": "Tuşlar",
|
||||||
|
"Sound notifications": "Sesli uyarılar",
|
||||||
|
"Send key": "Gönderme tuşu",
|
||||||
|
"Posts display": "Gönderiler",
|
||||||
|
"Post editor": "Gönderi düzenleyici",
|
||||||
|
"Inline image preview": "Dahili resim ön izleme",
|
||||||
|
"Display": "Göster",
|
||||||
|
"Line feeds": "Satır sonları",
|
||||||
|
"Supported punctuations:": "Desteklenen noktalama işaretleri:",
|
||||||
|
"Supported emotions:": "Desteklenen duygu simgeleri:",
|
||||||
|
"Supported signs:": "Desteklenen işaretler:",
|
||||||
|
"Supported fractions:": "Desteklenen kesirler:",
|
||||||
|
"Automatic unicode conversion options": "Otomatik unicode dönüştürme seçenekleri",
|
||||||
|
"Convert punctuations to unicode": "Noktalama işaretlerini unicode'a dönüştür",
|
||||||
|
"Convert emotions codes to unicode symbols": "Duygu simge kodlarını unicode simgelerine dönüştür",
|
||||||
|
"Convert common signs to unicode": "Yaygın işaretleri unicode'a dönüştür",
|
||||||
|
"Convert fractions to unicode": "Kesirleri unicode'a dönüştür",
|
||||||
|
"Convert all": "Hepsini dönüştür",
|
||||||
|
"Auto": "Otomatik",
|
||||||
|
"Original": "Orjinal",
|
||||||
|
"none": "Hiçbiri",
|
||||||
|
"Custom": "Özel",
|
||||||
|
"Mentions": "Bahsedenler",
|
||||||
|
"You have to log in to post messages.": "Mesaj göndermek için giriş yapmalısınız.",
|
||||||
|
"You have to log in to post replies.": "Cevap göndermek için giriş yapmalısınız.",
|
||||||
|
"You have to log in to retransmit messages.": "Yeniden iletmek için giriş yapmalısınız.",
|
||||||
|
"You have to log in to use direct messages.": "Direk masajları kullanabilmek için giriş yapmalısınız.",
|
||||||
|
"You have to log in to follow users.": "Kullanıcı takip etmek için giriş yapmalısınız.",
|
||||||
|
"You are not following anyone because you are not logged in.": "Giriş yapmadığınız için kimseyi takip etmiyorsunuz.",
|
||||||
|
"You don't have any followers because you are not logged in.": "Giriş yapmadığınız için hiç takipçiniz yok.",
|
||||||
|
"No one can mention you because you are not logged in.": "Giriş yapmadığınız için kimse adınıza mesaj gönderemiyor.",
|
||||||
|
"You don't have any profile because you are not logged in.": "Giriş yapmadığınız için profiliniz yok."
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1791,7 +1855,10 @@ var fixedLabels = [
|
|||||||
".module span",
|
".module span",
|
||||||
".login span",
|
".login span",
|
||||||
".login-local-username",
|
".login-local-username",
|
||||||
".login input"
|
".login input",
|
||||||
|
|
||||||
|
//options page
|
||||||
|
"option"
|
||||||
];
|
];
|
||||||
$(document).ready(function(){
|
$(document).ready(function(){
|
||||||
for(var i=0;i<fixedLabels.length;i++){
|
for(var i=0;i<fixedLabels.length;i++){
|
||||||
|
@ -141,7 +141,74 @@ var TwisterOptions = function()
|
|||||||
|
|
||||||
$('#showPreviewOpt select').on('change', function(){
|
$('#showPreviewOpt select').on('change', function(){
|
||||||
$.Options.setOption(this.id, this.value);
|
$.Options.setOption(this.id, this.value);
|
||||||
})
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
this.getUnicodeConversionOpt = function () {
|
||||||
|
return $.Options.getOption('unicodeConversion', "disable");
|
||||||
|
}
|
||||||
|
|
||||||
|
this.setUnicodeConversionOpt = function () {
|
||||||
|
$("#unicodeConversion")[0].value = this.getUnicodeConversionOpt();
|
||||||
|
|
||||||
|
if (this.getUnicodeConversionOpt() === "custom")
|
||||||
|
$("#unicodeConversionOpt .suboptions")[0].style.height = "230px";
|
||||||
|
|
||||||
|
$("#unicodeConversion").on('change', function () {
|
||||||
|
$.Options.setOption(this.id, this.value);
|
||||||
|
if (this.value === "custom")
|
||||||
|
$("#unicodeConversionOpt .suboptions")[0].style.height = "230px";
|
||||||
|
else
|
||||||
|
$("#unicodeConversionOpt .suboptions")[0].style.height = "0px";
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
this.getConvertPunctuationsOpt = function() {
|
||||||
|
return $.Options.getOption('convertPunctuationsOpt', false);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.setConvertPunctuationsOpt = function () {
|
||||||
|
$('#convertPunctuationsOpt')[0].checked = this.getConvertPunctuationsOpt();
|
||||||
|
|
||||||
|
$('#convertPunctuationsOpt').on('change', function(){
|
||||||
|
$.Options.setOption(this.id, this.checked);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
this.getConvertEmotionsOpt = function() {
|
||||||
|
return $.Options.getOption('convertEmotionsOpt', false);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.setConvertEmotionsOpt = function () {
|
||||||
|
$('#convertEmotionsOpt')[0].checked = this.getConvertEmotionsOpt();
|
||||||
|
|
||||||
|
$('#convertEmotionsOpt').on('change', function(){
|
||||||
|
$.Options.setOption(this.id, this.checked);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
this.getConvertSignsOpt = function() {
|
||||||
|
return $.Options.getOption('convertSignsOpt', false);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.setConvertSignsOpt = function () {
|
||||||
|
$('#convertSignsOpt')[0].checked = this.getConvertSignsOpt();
|
||||||
|
|
||||||
|
$('#convertSignsOpt').on('change', function(){
|
||||||
|
$.Options.setOption(this.id, this.checked);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
this.getConvertFractionsOpt = function() {
|
||||||
|
return $.Options.getOption('convertFractionsOpt', false);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.setConvertFractionsOpt = function () {
|
||||||
|
$('#convertFractionsOpt')[0].checked = this.getConvertFractionsOpt();
|
||||||
|
|
||||||
|
$('#convertFractionsOpt').on('change', function(){
|
||||||
|
$.Options.setOption(this.id, this.checked);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
this.InitOptions = function() {
|
this.InitOptions = function() {
|
||||||
@ -152,6 +219,11 @@ var TwisterOptions = function()
|
|||||||
this.setTheme();
|
this.setTheme();
|
||||||
this.setLineFeedsOpt();
|
this.setLineFeedsOpt();
|
||||||
this.setShowPreviewOpt();
|
this.setShowPreviewOpt();
|
||||||
|
this.setUnicodeConversionOpt();
|
||||||
|
this.setConvertPunctuationsOpt();
|
||||||
|
this.setConvertEmotionsOpt();
|
||||||
|
this.setConvertSignsOpt();
|
||||||
|
this.setConvertFractionsOpt();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
62
options.html
62
options.html
@ -52,7 +52,7 @@
|
|||||||
<div class="language">
|
<div class="language">
|
||||||
|
|
||||||
<div class="module">
|
<div class="module">
|
||||||
<p> Use language </p>
|
<p class="label"> Use language </p>
|
||||||
<div>
|
<div>
|
||||||
<form action="" id="selectLanguage">
|
<form action="" id="selectLanguage">
|
||||||
<select name="" id="language">
|
<select name="" id="language">
|
||||||
@ -76,7 +76,7 @@
|
|||||||
<div class="language">
|
<div class="language">
|
||||||
|
|
||||||
<div class="module">
|
<div class="module">
|
||||||
<p> Theme </p>
|
<p class="label"> Theme </p>
|
||||||
<div>
|
<div>
|
||||||
<form action="" id="selectTheme">
|
<form action="" id="selectTheme">
|
||||||
<select name="" id="theme">
|
<select name="" id="theme">
|
||||||
@ -91,10 +91,10 @@
|
|||||||
<div class="sounds">
|
<div class="sounds">
|
||||||
|
|
||||||
<div class="module">
|
<div class="module">
|
||||||
<p> Sound notifications </p>
|
<p class="label"> Sound notifications </p>
|
||||||
<div>
|
<div>
|
||||||
<form action="" id="notifyForm">
|
<form action="" id="notifyForm">
|
||||||
<p>Mentions</p>
|
<p class="label">Mentions</p>
|
||||||
<select name="" id="sndMention" class="sndOpt">
|
<select name="" id="sndMention" class="sndOpt">
|
||||||
<option value="false">none</option>
|
<option value="false">none</option>
|
||||||
<option value="1">beat</option>
|
<option value="1">beat</option>
|
||||||
@ -103,7 +103,7 @@
|
|||||||
<option value="4">flip</option>
|
<option value="4">flip</option>
|
||||||
<option value="5">click</option>
|
<option value="5">click</option>
|
||||||
</select><br>
|
</select><br>
|
||||||
<p>Direct Messages</p>
|
<p class="label">Direct Messages</p>
|
||||||
<select name="" id="sndDM" class="sndOpt">
|
<select name="" id="sndDM" class="sndOpt">
|
||||||
<option value="false">none</option>
|
<option value="false">none</option>
|
||||||
<option value="1">beat</option>
|
<option value="1">beat</option>
|
||||||
@ -121,10 +121,10 @@
|
|||||||
|
|
||||||
<div class="keys">
|
<div class="keys">
|
||||||
<div class="module">
|
<div class="module">
|
||||||
<p> Keys </p>
|
<p class="label"> Keys </p>
|
||||||
<div>
|
<div>
|
||||||
<form action="" id="keysOpt">
|
<form action="" id="keysOpt">
|
||||||
<p>Send key</p>
|
<p class="label">Send key</p>
|
||||||
<select name="" id="keysSend">
|
<select name="" id="keysSend">
|
||||||
<option value="enter">Enter</option>
|
<option value="enter">Enter</option>
|
||||||
<option value="ctrlenter">Ctrl/Cmd+Enter</option>
|
<option value="ctrlenter">Ctrl/Cmd+Enter</option>
|
||||||
@ -133,10 +133,10 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="posts-display">
|
<div class="posts-display">
|
||||||
<div class="module">
|
<div class="module">
|
||||||
<p> Posts display </p>
|
<p class="label"> Posts display </p>
|
||||||
<div>
|
<div>
|
||||||
<form action="" id="lineFeedsOpt">
|
<form action="" id="lineFeedsOpt">
|
||||||
<p>Line feeds</p>
|
<p>Line feeds</p>
|
||||||
@ -148,7 +148,7 @@
|
|||||||
</div>
|
</div>
|
||||||
<div>
|
<div>
|
||||||
<form action="" id="showPreviewOpt">
|
<form action="" id="showPreviewOpt">
|
||||||
<p>Inline image preview</p>
|
<p class="label">Inline image preview</p>
|
||||||
<select name="" id="displayPreview">
|
<select name="" id="displayPreview">
|
||||||
<option value="disable">Ignore</option>
|
<option value="disable">Ignore</option>
|
||||||
<option value="enable">Display</option>
|
<option value="enable">Display</option>
|
||||||
@ -158,6 +158,48 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="post-editor">
|
||||||
|
<div class="module">
|
||||||
|
<p class="label"> Post editor</p>
|
||||||
|
<br/>
|
||||||
|
<div>
|
||||||
|
<form action="" id="unicodeConversionOpt">
|
||||||
|
<p class="label">Automatic unicode conversion options</p>
|
||||||
|
<select name="" id="unicodeConversion">
|
||||||
|
<option value="disable">Ignore</option>
|
||||||
|
<option value="enable">Convert all</option>
|
||||||
|
<option value="custom">Custom</option>
|
||||||
|
</select>
|
||||||
|
<div class="suboptions">
|
||||||
|
<input name="" id="convertPunctuationsOpt" type="checkbox" /> <span class="label">Convert punctuations to unicode</span><br/>
|
||||||
|
<div>
|
||||||
|
<label class="label">Supported punctuations: </label>
|
||||||
|
<span>‥ … ⁇ ⁈ ⁉ ‼ — ⁓</span>
|
||||||
|
</div>
|
||||||
|
<br/>
|
||||||
|
<input name="" id="convertEmotionsOpt" type="checkbox" /> <span class="label">Convert emotions codes to unicode symbols</span><br/>
|
||||||
|
<div>
|
||||||
|
<label class="label">Supported emotions: </label>
|
||||||
|
<span>😃 😇 🍺 😈 ❤ 😕 😢 😞 😎 😊 😊 😗 😆 😛 😉 😉 😮 😱 😐</span>
|
||||||
|
</div>
|
||||||
|
<br/>
|
||||||
|
<input name="" id="convertSignsOpt" type="checkbox" /> <span class="label">Convert common signs to unicode</span><br/>
|
||||||
|
<div>
|
||||||
|
<label class="label">Supported signs:</label>
|
||||||
|
<span>℡ ℻</span>
|
||||||
|
</div>
|
||||||
|
<br/>
|
||||||
|
<input name="" id="convertFractionsOpt" type="checkbox" /> <span class="label">Convert fractions to unicode</span><br/>
|
||||||
|
<div>
|
||||||
|
<label class="label">Supported fractions:</label>
|
||||||
|
<span>½ ⅓ ⅔ ¼ ¾ ⅕ ⅖ ⅗ ⅘ ⅙ ⅚ ⅐ ⅛ ⅜ ⅝ ⅞ ⅑ ⅒</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user