chat interface added, config option changed from showchatballoons:

ture/false to showchat: balloons/modal
This commit is contained in:
Arthur Mayer 2011-02-18 07:08:29 +01:00
parent 7c917b729e
commit 5ddaf940ed
5 changed files with 162 additions and 32 deletions

View File

@ -94,8 +94,8 @@ public class DynmapPlugin extends JavaPlugin {
messageHandler.onMessageReceived.addListener(new Listener<SendMessageHandler.Message>() { messageHandler.onMessageReceived.addListener(new Listener<SendMessageHandler.Message>() {
@Override @Override
public void triggered(Message t) { public void triggered(Message t) {
log.info("[WEB] " + t.name + ": " + t.message); log.info("[WEB]" + t.name + ": " + t.message);
getServer().broadcastMessage("[WEB] " + t.name + ": " + t.message); getServer().broadcastMessage("[WEB]" + t.name + ": " + t.message);
} }
}); });
webServer.handlers.put("/up/sendmessage", messageHandler); webServer.handlers.put("/up/sendmessage", messageHandler);

0
web/chat.js Normal file
View File

58
web/chat_style.css Normal file
View File

@ -0,0 +1,58 @@
#chat {
position:absolute;
bottom:14px;
left:14px;
border: 1px solid rgba(0,0,0,0.5);
background: rgba(0, 0, 0, 0.6);
}
#chatcursor {
position:absolute;
left:5px;
bottom:5px;
font-size:10px;
color: white;
padding:0px;
}
#chatinput {
margin:4px;
width:608px;
height:12px;
font-family:sans-serif;
font-size:10px;
padding:1px;
padding-left:15px;
color: white;
border: 0px;
background: rgba(0, 0, 0, 0.6);
}
#messagelist {
margin:4px 4px 0px 4px;
width:622px;
max-height:198px;
font-family:sans-serif;
font-size: 10px;
padding:1px;
color: white;
background: rgba(0, 0, 0, 0.6);
overflow:hidden;
display:none;
}
#messagerow {
position:relative;
left:0px;
bottom:0px;
max-height:200px;
font-family:sans-serif;
font-size: 10px;
color: white;
}
.messageicon {
position:relative;
left:0px;
top:1px;
}
.messagetext {
position:relative;
left:0px;
top:-3px;
}

View File

@ -12,6 +12,7 @@
<meta name="viewport" content="initial-scale=1.0, user-scalable=no" /> <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
<link rel="stylesheet" type="text/css" href="dynmap_style.css" media="screen" /> <link rel="stylesheet" type="text/css" href="dynmap_style.css" media="screen" />
<link rel="stylesheet" type="text/css" href="clock_style.css" media="screen" /> <link rel="stylesheet" type="text/css" href="clock_style.css" media="screen" />
<link rel="stylesheet" type="text/css" href="chat_style.css" media="screen" />
<script type="text/javascript" src="jquery-1.4.4.min.js"></script> <script type="text/javascript" src="jquery-1.4.4.min.js"></script>
<script type="text/javascript" src="jquery.json.js"></script> <script type="text/javascript" src="jquery.json.js"></script>
<script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=false"></script> <script type="text/javascript" src="http://maps.google.com/maps/api/js?sensor=false"></script>
@ -21,6 +22,7 @@
<script type="text/javascript" src="kzedmaps.js"></script> <script type="text/javascript" src="kzedmaps.js"></script>
<script type="text/javascript" src="clock.timeofday.js"></script> <script type="text/javascript" src="clock.timeofday.js"></script>
<script type="text/javascript" src="clock.digital.js"></script> <script type="text/javascript" src="clock.digital.js"></script>
<script type="text/javascript" src="chat.js"></script>
<script type="text/javascript" src="config.js"></script> <script type="text/javascript" src="config.js"></script>
<script type="text/javascript"> <script type="text/javascript">
$(document).ready(function() { $(document).ready(function() {

View File

@ -195,6 +195,30 @@ DynMap.prototype = {
); );
compass.initialize(); compass.initialize();
// The chat
if (me.options.showchat == 'modal') {
var chat = me.chat = $('<div/>')
.addClass('chat')
.attr({ id: 'chat' })
.appendTo(container);
var messagelist = me.messagelist = $('<div/>')
.addClass('messagelist')
.attr({ id: 'messagelist' })
.appendTo(chat);
var chatinput = me.chatinput = $('<input/>')
.addClass('chatinput')
.attr({
id: 'chatinput',
type: 'text',
value: 'not working yet'
})
.appendTo(chat);
var chatcursor = me.chatcursor = $('<span/>')
.attr({ id: 'chatcursor'})
.text('>_')
.appendTo(chat);
}
// TODO: Enable hash-links. // TODO: Enable hash-links.
/* /*
var link; var link;
@ -263,7 +287,7 @@ DynMap.prototype = {
me.onTileUpdated(update.name); me.onTileUpdated(update.name);
}, },
chat: function() { chat: function() {
if (!me.options.showchatballoons) if (!me.options.showchat)
return; return;
me.onPlayerChat(update.playerName, update.message); me.onPlayerChat(update.playerName, update.message);
} }
@ -333,37 +357,83 @@ DynMap.prototype = {
var map = me.map; var map = me.map;
var mid = "player_" + playerName; var mid = "player_" + playerName;
var playerMarker = markers[mid]; var playerMarker = markers[mid];
if (playerMarker) if (me.options.showchat == 'balloons') {
{ if (playerMarker)
var popup = chatPopups[playerName]; {
if (!popup) var popup = chatPopups[playerName];
popup = { lines: [ message ] }; if (!popup)
else popup = { lines: [ message ] };
popup.lines[popup.lines.length] = message; else
popup.lines[popup.lines.length] = message;
var MAX_LINES = 5; var MAX_LINES = 5;
if (popup.lines.length > MAX_LINES) if (popup.lines.length > MAX_LINES)
{ {
popup.lines = popup.lines.slice(1); popup.lines = popup.lines.slice(1);
}
htmlMessage = '<div id="content"><b>' + playerName + "</b><br/><br/>"
for (var line in popup.lines)
{
htmlMessage = htmlMessage + popup.lines[line] + "<br/>";
}
htmlMessage = htmlMessage + "</div>"
var now = new Date();
popup.popupTime = now.getTime();
if (!popup.infoWindow) {
popup.infoWindow = new google.maps.InfoWindow({
disableAutoPan: !(me.options.focuschatballoons || false),
content: htmlMessage
});
} else {
popup.infoWindow.setContent(htmlMessage);
}
popup.infoWindow.open(map, playerMarker);
this.chatPopups[playerName] = popup;
} }
htmlMessage = '<div id="content"><b>' + playerName + "</b><br/><br/>" } else if (me.options.showchat == 'modal') {
for (var line in popup.lines) var me = this;
{ var messagelist = me.messagelist;
htmlMessage = htmlMessage + popup.lines[line] + "<br/>";
var messageRow = $('<div/>')
.addClass('messagerow')
var playerIconContainer = $('<span/>')
.addClass('messageicon')
if (me.options.showplayerfacesinmenu) {
getMinecraftHead(playerName, 16, function(head) {
messageRow.icon = $(head)
.addClass('playerIcon')
.appendTo(playerIconContainer);
});
}
if (playerName != 'Server') {
var playerWorldContainer = $('<span/>')
.addClass('messagetext')
.text('['+me.world+']')
var playerGroupContainer = $('<span/>')
.addClass('messagetext')
.text('[Group]')
} }
htmlMessage = htmlMessage + "</div>"
var now = new Date(); var playerNameContainer = $('<span/>')
popup.popupTime = now.getTime(); .addClass('messagetext')
if (!popup.infoWindow) { .text(' '+playerName+': ')
popup.infoWindow = new google.maps.InfoWindow({
disableAutoPan: !(me.options.focuschatballoons || false), var playerMessageContainer = $('<span/>')
content: htmlMessage .addClass('messagetext')
}); .text(message)
} else {
popup.infoWindow.setContent(htmlMessage); messageRow.append(playerIconContainer,playerNameContainer,playerMessageContainer);
} //messageRow.append(playerIconContainer,playerWorldContainer,playerGroupContainer,playerNameContainer,playerMessageContainer);
popup.infoWindow.open(map, playerMarker); messagelist.append(messageRow);
this.chatPopups[playerName] = popup;
me.messagelist.show();
//var scrollHeight = jQuery(me.messagelist).attr('scrollHeight');
var scrollHeight = me.messagelist[0].scrollHeight;
messagelist.scrollTop(scrollHeight);
} }
}, },
onTileUpdated: function(tileName) { onTileUpdated: function(tileName) {