mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-14 08:59:50 -05:00
Merge pull request #930 from myfingerhurt/master
add multi-line text messages, and search function.
This commit is contained in:
commit
5ffb54929c
@ -87,8 +87,87 @@ function getLobbyDetails(lobbyid){
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function find_next(searchValue){
|
||||||
|
var els = document.getElementsByClassName("chat msg text");
|
||||||
|
var middle = document.getElementsByClassName("chat middle")[0];
|
||||||
|
var find_hidden = document.getElementById("LastWordPos");
|
||||||
|
var start_index = Number(find_hidden.innerText);
|
||||||
|
|
||||||
|
if(!Number.isInteger(start_index)){
|
||||||
|
console.log(start_index + " is Not Integer");
|
||||||
|
start_index = 0;
|
||||||
|
}
|
||||||
|
if(start_index > els.length)
|
||||||
|
start_index = 0;
|
||||||
|
|
||||||
|
console.log(start_index);
|
||||||
|
|
||||||
|
for (var i = start_index; i < els.length; i++) {
|
||||||
|
var start = els[i].innerHTML.indexOf(searchValue);
|
||||||
|
if ( start > -1) {
|
||||||
|
//match has been made
|
||||||
|
middle.scrollTop = els[i].parentElement.offsetTop - middle.clientHeight/2;
|
||||||
|
var end = searchValue.length + start;
|
||||||
|
setSelectionRange(els[i], start, end);
|
||||||
|
find_hidden.innerText = i + 1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function setSelectionRange(el, start, end) {
|
||||||
|
if (document.createRange && window.getSelection) {
|
||||||
|
var range = document.createRange();
|
||||||
|
range.selectNodeContents(el);
|
||||||
|
var textNodes = getTextNodesIn(el);
|
||||||
|
var foundStart = false;
|
||||||
|
var charCount = 0, endCharCount;
|
||||||
|
|
||||||
|
for (var i = 0, textNode; textNode = textNodes[i++]; ) {
|
||||||
|
endCharCount = charCount + textNode.length;
|
||||||
|
if (!foundStart && start >= charCount && (start < endCharCount || (start == endCharCount && i <= textNodes.length))) {
|
||||||
|
range.setStart(textNode, start - charCount);
|
||||||
|
foundStart = true;
|
||||||
|
}
|
||||||
|
if (foundStart && end <= endCharCount) {
|
||||||
|
range.setEnd(textNode, end - charCount);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
charCount = endCharCount;
|
||||||
|
}
|
||||||
|
|
||||||
|
var sel = window.getSelection();
|
||||||
|
sel.removeAllRanges();
|
||||||
|
sel.addRange(range);
|
||||||
|
} else if (document.selection && document.body.createTextRange) {
|
||||||
|
var textRange = document.body.createTextRange();
|
||||||
|
textRange.moveToElementText(el);
|
||||||
|
textRange.collapse(true);
|
||||||
|
textRange.moveEnd("character", end);
|
||||||
|
textRange.moveStart("character", start);
|
||||||
|
textRange.select();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function getTextNodesIn(node) {
|
||||||
|
var textNodes = [];
|
||||||
|
if (node.nodeType == 3) {
|
||||||
|
textNodes.push(node);
|
||||||
|
} else {
|
||||||
|
var children = node.childNodes;
|
||||||
|
for (var i = 0, len = children.length; i < len; ++i) {
|
||||||
|
textNodes.push.apply(textNodes, getTextNodesIn(children[i]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return textNodes;
|
||||||
|
}
|
||||||
|
|
||||||
function sendmsg(msgid){
|
function sendmsg(msgid){
|
||||||
var txtmsg = document.getElementById("txtNewMsg");
|
var txtmsg = document.getElementById("txtNewMsg");
|
||||||
|
var remove_whitespace = txtmsg.value.replace(/(\r\n|\n|\r|\s)+/g,'');
|
||||||
|
if( remove_whitespace == '')
|
||||||
|
return;
|
||||||
rs.request("chat/send_message", {
|
rs.request("chat/send_message", {
|
||||||
chat_id: msgid,
|
chat_id: msgid,
|
||||||
msg: txtmsg.value
|
msg: txtmsg.value
|
||||||
@ -131,7 +210,7 @@ function lobby(lobbyid){
|
|||||||
});
|
});
|
||||||
|
|
||||||
var intro = [
|
var intro = [
|
||||||
m("h2",lobdt.name),
|
//m("h2",lobdt.name),
|
||||||
m("p",lobdt.topic ? lobdt.topic: lobdt.location),
|
m("p",lobdt.topic ? lobdt.topic: lobdt.location),
|
||||||
m("hr")
|
m("hr")
|
||||||
]
|
]
|
||||||
@ -154,22 +233,61 @@ function lobby(lobbyid){
|
|||||||
}),
|
}),
|
||||||
];
|
];
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
|
var el = document.getElementById("CharLobbyName");
|
||||||
|
el.innerText = lobdt.name;
|
||||||
|
|
||||||
msg = m(".chat.bottom",[
|
msg = m(".chat.bottom",[
|
||||||
m("div","enter new message:"),
|
m("div","enter new message, Ctrl+Enter to submit:"),
|
||||||
m("input",{
|
m("textarea",{
|
||||||
id:"txtNewMsg",
|
id:"txtNewMsg",
|
||||||
onkeydown: function(event){
|
onkeydown: function(event){
|
||||||
if (event.keyCode == 13){
|
if (event.ctrlKey && event.keyCode == 13){
|
||||||
sendmsg(lobbyid);
|
sendmsg(lobbyid);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}),
|
}),
|
||||||
m("div.btn2", {
|
m("table.noBorderTable", [
|
||||||
style: {textAlign:"center"},
|
m("tr",[
|
||||||
onclick: function(){
|
m("td.noBorderTD",[
|
||||||
sendmsg(lobbyid);
|
m("div.btnSmall", {
|
||||||
}
|
style: {textAlign:"center"},
|
||||||
},"submit")
|
onclick: function(){
|
||||||
|
var els = document.getElementsByClassName("chat middle");
|
||||||
|
var el = els[0];
|
||||||
|
el.scrollTop = el.scrollHeight - el.clientHeight;
|
||||||
|
}
|
||||||
|
},"bottom")
|
||||||
|
]),
|
||||||
|
m("td.noBorderTD",[
|
||||||
|
m("div.btnSmall", {
|
||||||
|
style: {textAlign:"center"},
|
||||||
|
onclick: function(){
|
||||||
|
sendmsg(lobbyid);
|
||||||
|
}
|
||||||
|
},"submit")
|
||||||
|
]),
|
||||||
|
m("td.noBorderTD",[
|
||||||
|
m("input",{
|
||||||
|
id:"txtMsgKeyword"
|
||||||
|
})
|
||||||
|
]),
|
||||||
|
m("td.noBorderTD", [
|
||||||
|
m("div.btnSmall", {
|
||||||
|
style: {textAlign:"center"},
|
||||||
|
onclick: function(){
|
||||||
|
var key = document.getElementById("txtMsgKeyword");
|
||||||
|
var txtkeyword = key.value;
|
||||||
|
find_next(txtkeyword);
|
||||||
|
}
|
||||||
|
},"Find")
|
||||||
|
])
|
||||||
|
])
|
||||||
|
]),
|
||||||
|
m("div.hidden", {
|
||||||
|
id: "LastWordPos"
|
||||||
|
},""
|
||||||
|
),
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
if (lobdt.subscribed != undefined
|
if (lobdt.subscribed != undefined
|
||||||
@ -256,11 +374,27 @@ module.exports = {
|
|||||||
},[
|
},[
|
||||||
m(".chat.container", [
|
m(".chat.container", [
|
||||||
m(".chat.header", [
|
m(".chat.header", [
|
||||||
m(
|
m("table.noBorderTable",[
|
||||||
"h2",
|
m("tr",[
|
||||||
{style:{margin:"0px"}},
|
m("td.noBorderTD",[
|
||||||
"chat"
|
m(
|
||||||
)
|
"h2",
|
||||||
|
{style:{margin:"0px"}},
|
||||||
|
"chat"
|
||||||
|
)
|
||||||
|
]),
|
||||||
|
m("td.noBorderTD",[
|
||||||
|
m(
|
||||||
|
"h2",
|
||||||
|
{
|
||||||
|
style:{margin:"0px"},
|
||||||
|
id:"CharLobbyName"
|
||||||
|
},
|
||||||
|
"Lobby Name"
|
||||||
|
)
|
||||||
|
])
|
||||||
|
])
|
||||||
|
])
|
||||||
]),
|
]),
|
||||||
m(".chat.left", [
|
m(".chat.left", [
|
||||||
m("div.chat.header[style=position:relative]","lobbies:"),
|
m("div.chat.header[style=position:relative]","lobbies:"),
|
||||||
|
@ -77,11 +77,41 @@ hr {
|
|||||||
background-color: midnightblue;
|
background-color: midnightblue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.btnSmall{
|
||||||
|
border-style: solid;
|
||||||
|
/*border-color: lime;*/
|
||||||
|
border-color: limeGreen;
|
||||||
|
/*border-width: 1px;*/
|
||||||
|
border-radius: 3mm;
|
||||||
|
padding: 1mm;
|
||||||
|
font-size: 100%;
|
||||||
|
|
||||||
|
cursor: pointer;
|
||||||
|
margin-bottom: 0mm;
|
||||||
|
}
|
||||||
|
|
||||||
|
.hidden{
|
||||||
|
display:none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.noBorderTable{
|
||||||
|
width: 100%;
|
||||||
|
border: none;
|
||||||
|
border-collapse: collapse;
|
||||||
|
}
|
||||||
|
|
||||||
|
.noBorderTD{
|
||||||
|
border: none;
|
||||||
|
border-collapse: collapse;
|
||||||
|
vertical-align: center;
|
||||||
|
}
|
||||||
|
|
||||||
.filelink{
|
.filelink{
|
||||||
color: inherit;
|
color: inherit;
|
||||||
}
|
}
|
||||||
|
|
||||||
input, textarea{
|
|
||||||
|
input,textarea{
|
||||||
color: lime;
|
color: lime;
|
||||||
font-family: monospace;
|
font-family: monospace;
|
||||||
background-color: black;
|
background-color: black;
|
||||||
@ -90,8 +120,8 @@ input, textarea{
|
|||||||
border-radius: 3mm;
|
border-radius: 3mm;
|
||||||
border-width: 1mm;
|
border-width: 1mm;
|
||||||
padding: 2mm;
|
padding: 2mm;
|
||||||
margin-bottom: 2mm;
|
margin-bottom: 1mm;
|
||||||
margin-right: 2mm;
|
margin-right: 1mm;
|
||||||
|
|
||||||
/* make the button the whole screen width */
|
/* make the button the whole screen width */
|
||||||
width: 100%;
|
width: 100%;
|
||||||
@ -102,6 +132,45 @@ input:hover{
|
|||||||
background-color: midnightblue;
|
background-color: midnightblue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
textarea#txtNewMsg{
|
||||||
|
color: lime;
|
||||||
|
font-family: monospace;
|
||||||
|
background-color: black;
|
||||||
|
border-color: lime;
|
||||||
|
font-size: 100%;
|
||||||
|
border-radius: 3mm;
|
||||||
|
border-width: 1mm;
|
||||||
|
padding: 2mm;
|
||||||
|
margin-bottom: 0mm;
|
||||||
|
margin-right: 1mm;
|
||||||
|
height:110px;
|
||||||
|
resize: none;
|
||||||
|
/* make the button the whole screen width */
|
||||||
|
width: 100%;
|
||||||
|
/*height: 100%;*/
|
||||||
|
/* make the text input fit small screens*/
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
input#txtMsgKeyword{
|
||||||
|
color: lime;
|
||||||
|
font-family: monospace;
|
||||||
|
background-color: black;
|
||||||
|
border-color: lime;
|
||||||
|
font-size: 100%;
|
||||||
|
border-radius: 3mm;
|
||||||
|
border-width: 1mm;
|
||||||
|
padding: 1mm;
|
||||||
|
margin-bottom: 0mm;
|
||||||
|
margin-right: 1mm;
|
||||||
|
|
||||||
|
/* make the button the whole screen width */
|
||||||
|
width: 100%;
|
||||||
|
/* make the text input fit small screens*/
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
|
||||||
.checkbox {
|
.checkbox {
|
||||||
width: auto;
|
width: auto;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user