mirror of
https://github.com/Doodle3D/doodle3d-client.git
synced 2024-11-25 18:47:57 +01:00
d634f2e9c3
Conflicts: js/Help.js js/buttonbehaviors.js js/main.js js_src/Keyboard.js js_src/Shape.js js_src/verticalShapes.js www/index.html
61 lines
1.4 KiB
JavaScript
61 lines
1.4 KiB
JavaScript
/*
|
|
* This file is part of the Doodle3D project (http://doodle3d.com).
|
|
*
|
|
* Copyright (c) 2013, Doodle3D
|
|
* This software is licensed under the terms of the GNU GPL v2 or later.
|
|
* See file LICENSE.txt or visit http://www.gnu.org/licenses/gpl.html for full license details.
|
|
*/
|
|
|
|
function Message() {
|
|
|
|
Message.ERROR = "error";
|
|
Message.WARNING = "warning";
|
|
Message.NOTICE = "notice";
|
|
Message.INFO = "info";
|
|
|
|
this.mode = "";
|
|
|
|
this.$element;
|
|
|
|
var self = this;
|
|
var autoHideDelay = 5000;
|
|
var autohideTimeout;
|
|
|
|
this.init = function($element) {
|
|
this.$element = $element;
|
|
}
|
|
this.set = function(text,mode,autoHide,disableEffect) {
|
|
console.log("Message:set: ",text,mode,autoHide,disableEffect);
|
|
if(disableEffect) {
|
|
self.fill(text,mode,autoHide)
|
|
} else{
|
|
self.hide(function() {
|
|
self.show();
|
|
self.fill(text,mode,autoHide)
|
|
});
|
|
}
|
|
}
|
|
this.fill = function(text,mode,autoHide) {
|
|
//console.log("Message:fill: ",text,mode,autoHide);
|
|
self.clear();
|
|
self.$element.text(text);
|
|
self.$element.addClass(mode);
|
|
self.mode = mode;
|
|
clearTimeout(autohideTimeout);
|
|
if(autoHide) {
|
|
autohideTimeout = setTimeout(function(){ self.hide()},autoHideDelay);
|
|
}
|
|
}
|
|
this.clear = function($element) {
|
|
this.$element.text("");
|
|
this.$element.removeClass(this.mode);
|
|
}
|
|
|
|
this.show = function() {
|
|
this.$element.fadeIn(200);
|
|
}
|
|
this.hide = function(complete) {
|
|
this.$element.fadeOut(200,complete);
|
|
}
|
|
}
|