'use strict';
(function () {

    window.console = window.console || {};
    window.console.log = window.console.log || function(){};
    window.console.group = window.console.group || function(){};
    window.console.groupEnd = window.console.groupEnd || function(){};
    window.console.debug = window.console.debug || function(){};
    window.console.warn = window.console.warn || function(){};
    window.console.assert = window.console.assert || function(){};

    window.alert = function (message) {
        window.Messenger().post(message);
    };

    window.onerror = function (msg, url, line) {

        try {

            var a = document.createElement('a');
            a.href = url;
            var filename = a.pathname.split('/').pop();

            //Suppress Firefox debug errors when console window is closed
            if (filename.toLowerCase() === 'markupview.jsm') {
                return false;
            }

            var messageText = filename + ' : ' + line + '</br>' + msg;

            var message = {
                message        : messageText,
                type           : 'error',
                hideAfter      : 1000,
                showCloseButton: true
            };

            window.Messenger().post(message);

        }
        catch (error) {
            console.log('An error occurred while reporting error. ' + error);
            console.log(msg);
            window.alert('Couldn\'t report JS error.  ' + msg);
        }

        return false; //don't suppress default alerts and logs.
    };

    $(document).ajaxError(function (event, xmlHttpRequest, ajaxOptions) {

        //don't report 200 error codes
        if (xmlHttpRequest.status >= 200 && xmlHttpRequest.status <= 300) {
            return undefined;
        }

        //don't report aborted requests
        if (xmlHttpRequest.statusText === 'abort') {
            return undefined;
        }

        var message = {
            type           : 'error',
            hideAfter      : 1000,
            showCloseButton: true
        };

        if (xmlHttpRequest.status === 0 && xmlHttpRequest.readyState === 0) {
            return false;
            //message.message = 'NzbDrone Server Not Reachable. make sure NzbDrone is running.';
        }
        else {
            message.message = '[{0}] {1} : {2}'.format(ajaxOptions.type, xmlHttpRequest.statusText, ajaxOptions.url);
        }

        window.Messenger().post(message);
        return false;
    });

})();