2015-01-20 01:53:18 -05:00
|
|
|
// Modify Array and others.
|
2015-06-05 03:59:28 -04:00
|
|
|
// require('./shims');
|
2015-01-20 01:53:18 -05:00
|
|
|
|
|
|
|
// ----------------
|
|
|
|
// The Constructor
|
|
|
|
// ----------------
|
|
|
|
|
|
|
|
var FFZ = window.FrankerFaceZ = function() {
|
|
|
|
FFZ.instance = this;
|
|
|
|
|
2015-02-10 01:34:23 -05:00
|
|
|
// Logging
|
|
|
|
this._log_data = [];
|
|
|
|
|
2015-01-20 01:53:18 -05:00
|
|
|
// Get things started.
|
|
|
|
this.initialize();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
FFZ.get = function() { return FFZ.instance; }
|
|
|
|
|
|
|
|
|
|
|
|
// Version
|
|
|
|
var VER = FFZ.version_info = {
|
2015-08-14 13:39:32 -04:00
|
|
|
major: 3, minor: 5, revision: 14,
|
2015-01-20 01:53:18 -05:00
|
|
|
toString: function() {
|
|
|
|
return [VER.major, VER.minor, VER.revision].join(".") + (VER.extra || "");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Logging
|
|
|
|
|
2015-03-30 00:52:18 -04:00
|
|
|
FFZ.prototype.log = function(msg, data, to_json, log_json) {
|
2015-01-20 01:53:18 -05:00
|
|
|
msg = "FFZ: " + msg + (to_json ? " -- " + JSON.stringify(data) : "");
|
2015-03-30 00:52:18 -04:00
|
|
|
this._log_data.push(msg + ((!to_json && log_json) ? " -- " + JSON.stringify(data) : ""));
|
2015-02-10 01:34:23 -05:00
|
|
|
|
2015-01-20 01:53:18 -05:00
|
|
|
if ( data !== undefined && console.groupCollapsed && console.dir ) {
|
|
|
|
console.groupCollapsed(msg);
|
|
|
|
if ( navigator.userAgent.indexOf("Firefox/") !== -1 )
|
|
|
|
console.log(data);
|
|
|
|
else
|
|
|
|
console.dir(data);
|
|
|
|
|
|
|
|
console.groupEnd(msg);
|
|
|
|
} else
|
|
|
|
console.log(msg);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2015-02-10 01:34:23 -05:00
|
|
|
FFZ.prototype.error = function(msg, data, to_json) {
|
|
|
|
msg = "FFZ Error: " + msg + (to_json ? " -- " + JSON.stringify(data) : "");
|
|
|
|
this._log_data.push(msg);
|
|
|
|
|
|
|
|
if ( data !== undefined && console.groupCollapsed && console.dir ) {
|
|
|
|
console.groupCollapsed(msg);
|
|
|
|
if ( navigator.userAgent.indexOf("Firefox/") !== -1 )
|
|
|
|
console.log(data);
|
|
|
|
else
|
|
|
|
console.dir(data);
|
|
|
|
|
|
|
|
console.groupEnd(msg);
|
|
|
|
} else
|
|
|
|
console.assert(false, msg);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
FFZ.prototype.paste_logs = function() {
|
|
|
|
this._pastebin(this._log_data.join("\n"), function(url) {
|
|
|
|
if ( ! url )
|
|
|
|
return console.log("FFZ Error: Unable to upload log to pastebin.");
|
|
|
|
|
|
|
|
console.log("FFZ: Your FrankerFaceZ log has been pasted to: " + url);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
FFZ.prototype._pastebin = function(data, callback) {
|
|
|
|
jQuery.ajax({url: "http://putco.de/", type: "PUT", data: data, context: this})
|
|
|
|
.success(function(e) {
|
|
|
|
callback.bind(this)(e.trim() + ".log");
|
|
|
|
}).fail(function(e) {
|
|
|
|
callback.bind(this)(null);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2015-01-20 01:53:18 -05:00
|
|
|
// -------------------
|
|
|
|
// User Data
|
|
|
|
// -------------------
|
|
|
|
|
|
|
|
FFZ.prototype.get_user = function() {
|
|
|
|
if ( window.PP && PP.login ) {
|
|
|
|
return PP;
|
|
|
|
} else if ( window.App ) {
|
2015-05-17 19:02:57 -04:00
|
|
|
var nc = App.__container__.lookup("controller:login");
|
2015-01-20 01:53:18 -05:00
|
|
|
return nc ? nc.get("userData") : undefined;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// -------------------
|
|
|
|
// Import Everything!
|
|
|
|
// -------------------
|
|
|
|
|
2015-02-24 00:33:29 -05:00
|
|
|
// Import these first to set up data structures
|
|
|
|
require('./ui/menu');
|
2015-02-08 02:01:09 -05:00
|
|
|
require('./settings');
|
2015-01-20 01:53:18 -05:00
|
|
|
require('./socket');
|
2015-02-24 00:33:29 -05:00
|
|
|
|
2015-07-18 21:10:27 -04:00
|
|
|
require('./colors');
|
2015-01-20 01:53:18 -05:00
|
|
|
require('./emoticons');
|
|
|
|
require('./badges');
|
2015-06-05 03:59:28 -04:00
|
|
|
require('./tokenize');
|
|
|
|
|
2015-01-20 01:53:18 -05:00
|
|
|
|
2015-02-10 01:34:23 -05:00
|
|
|
// Analytics: require('./ember/router');
|
2015-05-17 19:02:57 -04:00
|
|
|
require('./ember/channel');
|
2015-07-31 17:44:20 -04:00
|
|
|
//require('./ember/player');
|
2015-01-20 01:53:18 -05:00
|
|
|
require('./ember/room');
|
2015-07-31 17:44:20 -04:00
|
|
|
require('./ember/layout');
|
2015-01-20 01:53:18 -05:00
|
|
|
require('./ember/line');
|
|
|
|
require('./ember/chatview');
|
|
|
|
require('./ember/viewers');
|
2015-02-10 01:34:23 -05:00
|
|
|
require('./ember/moderation-card');
|
2015-07-06 00:09:21 -04:00
|
|
|
require('./ember/chat-input');
|
2015-01-20 01:53:18 -05:00
|
|
|
//require('./ember/teams');
|
|
|
|
|
|
|
|
require('./debug');
|
|
|
|
|
|
|
|
require('./ext/betterttv');
|
|
|
|
require('./ext/emote_menu');
|
|
|
|
|
|
|
|
require('./featurefriday');
|
|
|
|
|
|
|
|
require('./ui/styles');
|
2015-02-24 02:48:29 -05:00
|
|
|
require('./ui/dark');
|
2015-01-20 01:53:18 -05:00
|
|
|
require('./ui/notifications');
|
|
|
|
require('./ui/viewer_count');
|
2015-06-05 03:59:28 -04:00
|
|
|
require('./ui/sub_count');
|
2015-01-20 01:53:18 -05:00
|
|
|
|
|
|
|
require('./ui/menu_button');
|
2015-07-04 17:06:36 -04:00
|
|
|
require('./ui/following');
|
2015-07-13 21:52:44 -04:00
|
|
|
require('./ui/following-count');
|
2015-02-08 02:01:09 -05:00
|
|
|
require('./ui/races');
|
2015-02-24 00:33:29 -05:00
|
|
|
require('./ui/my_emotes');
|
|
|
|
require('./ui/about_page');
|
2015-01-20 01:53:18 -05:00
|
|
|
|
|
|
|
require('./commands');
|
|
|
|
|
|
|
|
|
|
|
|
// ---------------
|
|
|
|
// Initialization
|
|
|
|
// ---------------
|
|
|
|
|
|
|
|
FFZ.prototype.initialize = function(increment, delay) {
|
|
|
|
// Make sure that FrankerFaceZ doesn't start setting itself up until the
|
|
|
|
// Twitch ember application is ready.
|
|
|
|
|
2015-07-29 01:03:10 -04:00
|
|
|
// Check for the player
|
|
|
|
if ( location.hostname === 'player.twitch.tv' ) {
|
2015-07-31 17:44:20 -04:00
|
|
|
//this.init_player(delay);
|
2015-07-29 01:03:10 -04:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2015-05-17 19:02:57 -04:00
|
|
|
// Check for special non-ember pages.
|
2015-07-29 01:03:10 -04:00
|
|
|
if ( /^\/(?:$|search$|user\/|p\/|settings|m\/|messages?\/)/.test(location.pathname) ) {
|
|
|
|
this.init_normal(delay);
|
2015-05-17 19:02:57 -04:00
|
|
|
return;
|
|
|
|
}
|
2015-08-02 02:41:03 -04:00
|
|
|
|
2015-07-13 21:52:44 -04:00
|
|
|
if ( location.hostname === 'passport' && /^\/(?:authorize)/.test(location.pathname) ) {
|
|
|
|
this.log("Running on passport!");
|
2015-07-29 01:03:10 -04:00
|
|
|
this.init_normal(delay, true);
|
2015-07-13 21:52:44 -04:00
|
|
|
return;
|
|
|
|
}
|
2015-05-17 19:02:57 -04:00
|
|
|
|
|
|
|
// Check for the dashboard.
|
2015-06-10 18:46:04 -04:00
|
|
|
if ( /\/[^\/]+\/dashboard/.test(location.pathname) && !/bookmarks$/.test(location.pathname) ) {
|
2015-07-29 01:03:10 -04:00
|
|
|
this.init_dashboard(delay);
|
2015-05-17 19:02:57 -04:00
|
|
|
return;
|
|
|
|
}
|
2015-01-20 01:53:18 -05:00
|
|
|
|
|
|
|
var loaded = window.App != undefined &&
|
|
|
|
App.__container__ != undefined &&
|
|
|
|
App.__container__.resolve('model:room') != undefined;
|
|
|
|
|
|
|
|
if ( !loaded ) {
|
|
|
|
increment = increment || 10;
|
|
|
|
if ( delay >= 60000 )
|
|
|
|
this.log("Twitch application not detected in \"" + location.toString() + "\". Aborting.");
|
|
|
|
else
|
|
|
|
setTimeout(this.initialize.bind(this, increment, (delay||0) + increment),
|
|
|
|
increment);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2015-07-29 01:03:10 -04:00
|
|
|
this.init_ember(delay);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
FFZ.prototype.init_player = function(delay) {
|
|
|
|
var start = (window.performance && performance.now) ? performance.now() : Date.now();
|
|
|
|
this.log("Found Twitch Player after " + (delay||0) + " ms in \"" + location + "\". Initializing FrankerFaceZ version " + FFZ.version_info);
|
|
|
|
|
|
|
|
this.users = {};
|
|
|
|
this.is_dashboard = false;
|
|
|
|
try {
|
|
|
|
this.embed_in_dash = window.top !== window && /\/[^\/]+\/dashboard/.test(window.top.location.pathname) && !/bookmarks$/.test(window.top.location.pathname);
|
|
|
|
} catch(err) { this.embed_in_dash = false; }
|
|
|
|
|
|
|
|
// Literally only make it dark.
|
|
|
|
this.load_settings();
|
|
|
|
this.setup_dark();
|
|
|
|
|
|
|
|
var end = (window.performance && performance.now) ? performance.now() : Date.now(),
|
|
|
|
duration = end - start;
|
|
|
|
|
|
|
|
this.log("Initialization complete in " + duration + "ms");
|
2015-01-20 01:53:18 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2015-07-29 01:03:10 -04:00
|
|
|
FFZ.prototype.init_normal = function(delay, no_socket) {
|
2015-05-17 19:02:57 -04:00
|
|
|
var start = (window.performance && performance.now) ? performance.now() : Date.now();
|
|
|
|
this.log("Found non-Ember Twitch after " + (delay||0) + " ms in \"" + location + "\". Initializing FrankerFaceZ version " + FFZ.version_info);
|
|
|
|
|
|
|
|
this.users = {};
|
2015-07-04 17:06:36 -04:00
|
|
|
this.is_dashboard = false;
|
|
|
|
try {
|
|
|
|
this.embed_in_dash = window.top !== window && /\/[^\/]+\/dashboard/.test(window.top.location.pathname) && !/bookmarks$/.test(window.top.location.pathname);
|
|
|
|
} catch(err) { this.embed_in_dash = false; }
|
2015-05-17 19:02:57 -04:00
|
|
|
|
|
|
|
// Initialize all the modules.
|
|
|
|
this.load_settings();
|
|
|
|
|
|
|
|
// Start this early, for quick loading.
|
|
|
|
this.setup_dark();
|
|
|
|
|
2015-07-13 21:52:44 -04:00
|
|
|
if ( ! no_socket )
|
|
|
|
this.ws_create();
|
|
|
|
|
2015-07-18 21:10:27 -04:00
|
|
|
this.setup_colors();
|
2015-05-17 19:02:57 -04:00
|
|
|
this.setup_emoticons();
|
|
|
|
this.setup_badges();
|
|
|
|
|
|
|
|
this.setup_notifications();
|
2015-07-13 21:52:44 -04:00
|
|
|
this.setup_following_count(false);
|
2015-05-17 19:02:57 -04:00
|
|
|
this.setup_css();
|
2015-06-05 03:59:28 -04:00
|
|
|
this.setup_menu();
|
2015-05-17 19:02:57 -04:00
|
|
|
|
|
|
|
this.find_bttv(10);
|
|
|
|
|
|
|
|
var end = (window.performance && performance.now) ? performance.now() : Date.now(),
|
|
|
|
duration = end - start;
|
|
|
|
|
|
|
|
this.log("Initialization complete in " + duration + "ms");
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
FFZ.prototype.is_dashboard = false;
|
|
|
|
|
2015-07-29 01:03:10 -04:00
|
|
|
FFZ.prototype.init_dashboard = function(delay) {
|
2015-05-17 19:02:57 -04:00
|
|
|
var start = (window.performance && performance.now) ? performance.now() : Date.now();
|
|
|
|
this.log("Found Twitch Dashboard after " + (delay||0) + " ms in \"" + location + "\". Initializing FrankerFaceZ version " + FFZ.version_info);
|
|
|
|
|
|
|
|
this.users = {};
|
|
|
|
this.is_dashboard = true;
|
2015-07-04 17:06:36 -04:00
|
|
|
this.embed_in_dash = false;
|
2015-05-17 19:02:57 -04:00
|
|
|
|
|
|
|
// Initialize all the modules.
|
|
|
|
this.load_settings();
|
|
|
|
|
|
|
|
// Start this early, for quick loading.
|
|
|
|
this.setup_dark();
|
|
|
|
|
|
|
|
this.ws_create();
|
2015-07-18 21:10:27 -04:00
|
|
|
this.setup_colors();
|
2015-05-17 19:02:57 -04:00
|
|
|
this.setup_emoticons();
|
|
|
|
this.setup_badges();
|
|
|
|
|
2015-07-18 21:10:27 -04:00
|
|
|
this.setup_tokenization();
|
2015-05-17 19:02:57 -04:00
|
|
|
this.setup_notifications();
|
|
|
|
this.setup_css();
|
|
|
|
|
2015-06-05 03:59:28 -04:00
|
|
|
this._update_subscribers();
|
|
|
|
|
|
|
|
// Set up the FFZ message passer.
|
|
|
|
this.setup_message_event();
|
|
|
|
|
2015-05-17 19:02:57 -04:00
|
|
|
this.find_bttv(10);
|
|
|
|
|
|
|
|
var end = (window.performance && performance.now) ? performance.now() : Date.now(),
|
|
|
|
duration = end - start;
|
|
|
|
|
|
|
|
this.log("Initialization complete in " + duration + "ms");
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2015-07-29 01:03:10 -04:00
|
|
|
FFZ.prototype.init_ember = function(delay) {
|
2015-01-20 01:53:18 -05:00
|
|
|
var start = (window.performance && performance.now) ? performance.now() : Date.now();
|
|
|
|
this.log("Found Twitch application after " + (delay||0) + " ms in \"" + location + "\". Initializing FrankerFaceZ version " + FFZ.version_info);
|
|
|
|
|
|
|
|
this.users = {};
|
2015-07-04 17:06:36 -04:00
|
|
|
this.is_dashboard = false;
|
|
|
|
try {
|
|
|
|
this.embed_in_dash = window.top !== window && /\/[^\/]+\/dashboard/.test(window.top.location.pathname) && !/bookmarks$/.test(window.top.location.pathname);
|
|
|
|
} catch(err) { this.embed_in_dash = false; }
|
2015-01-20 01:53:18 -05:00
|
|
|
|
|
|
|
// Initialize all the modules.
|
2015-02-08 02:01:09 -05:00
|
|
|
this.load_settings();
|
|
|
|
|
|
|
|
// Start this early, for quick loading.
|
2015-02-24 02:48:29 -05:00
|
|
|
this.setup_dark();
|
2015-02-08 02:01:09 -05:00
|
|
|
|
2015-01-20 01:53:18 -05:00
|
|
|
this.ws_create();
|
|
|
|
this.setup_emoticons();
|
|
|
|
this.setup_badges();
|
|
|
|
|
2015-02-10 01:34:23 -05:00
|
|
|
//this.setup_router();
|
2015-07-18 21:10:27 -04:00
|
|
|
this.setup_colors();
|
|
|
|
this.setup_tokenization();
|
2015-07-31 17:44:20 -04:00
|
|
|
//this.setup_player();
|
2015-05-17 19:02:57 -04:00
|
|
|
this.setup_channel();
|
2015-01-20 01:53:18 -05:00
|
|
|
this.setup_room();
|
|
|
|
this.setup_line();
|
2015-07-31 17:44:20 -04:00
|
|
|
this.setup_layout();
|
2015-01-20 01:53:18 -05:00
|
|
|
this.setup_chatview();
|
|
|
|
this.setup_viewers();
|
2015-02-10 01:34:23 -05:00
|
|
|
this.setup_mod_card();
|
2015-07-06 00:09:21 -04:00
|
|
|
this.setup_chat_input();
|
2015-01-20 01:53:18 -05:00
|
|
|
|
|
|
|
//this.setup_teams();
|
|
|
|
|
2015-02-08 02:01:09 -05:00
|
|
|
this.setup_notifications();
|
2015-01-20 01:53:18 -05:00
|
|
|
this.setup_css();
|
|
|
|
this.setup_menu();
|
2015-02-24 00:33:29 -05:00
|
|
|
this.setup_my_emotes();
|
2015-07-04 17:06:36 -04:00
|
|
|
this.setup_following();
|
2015-07-13 21:52:44 -04:00
|
|
|
this.setup_following_count(true);
|
2015-02-08 02:01:09 -05:00
|
|
|
this.setup_races();
|
2015-06-05 03:59:28 -04:00
|
|
|
|
|
|
|
this.connect_extra_chat();
|
2015-01-20 01:53:18 -05:00
|
|
|
|
|
|
|
this.find_bttv(10);
|
|
|
|
this.find_emote_menu(10);
|
|
|
|
|
|
|
|
this.check_ff();
|
|
|
|
|
|
|
|
var end = (window.performance && performance.now) ? performance.now() : Date.now(),
|
|
|
|
duration = end - start;
|
|
|
|
|
|
|
|
this.log("Initialization complete in " + duration + "ms");
|
2015-06-05 03:59:28 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ------------------------
|
|
|
|
// Dashboard Message Event
|
|
|
|
// ------------------------
|
|
|
|
|
|
|
|
FFZ.prototype.setup_message_event = function() {
|
|
|
|
this.log("Listening for Window Messages.");
|
|
|
|
window.addEventListener("message", this._on_window_message.bind(this), false);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
FFZ.prototype._on_window_message = function(e) {
|
|
|
|
if ( ! e.data || ! e.data.from_ffz )
|
|
|
|
return;
|
|
|
|
|
|
|
|
var msg = e.data;
|
2015-01-12 17:58:07 -05:00
|
|
|
}
|