import Notification from 'ghost/models/notification';

var Notifications = Ember.ArrayProxy.extend({
    delayedNotifications: [],
    content: Ember.A(),
    timeout: 3000,

    pushObject: function (object) {
        // object can be either a DS.Model or a plain JS object, so when working with
        // it, we need to handle both cases.

        // make sure notifications have all the necessary properties set.
        if (typeof object.toJSON === 'function') {
            // working with a DS.Model

            if (object.get('location') === '') {
                object.set('location', 'bottom');
            }
        } else {
            if (!object.location) {
                object.location = 'bottom';
            }
        }

        this._super(object);
    },
    handleNotification: function (message, delayed) {
        if (!message.status) {
            message.status = 'passive';
        }

        if (!delayed) {
            this.pushObject(message);
        } else {
            this.delayedNotifications.push(message);
        }
    },
    showError: function (message, options) {
        options = options || {};

        if (!options.doNotClosePassive) {
            this.closePassive();
        }

        this.handleNotification({
            type: 'error',
            message: message
        }, options.delayed);
    },
    showErrors: function (errors, options) {
        options = options || {};

        if (!options.doNotClosePassive) {
            this.closePassive();
        }

        for (var i = 0; i < errors.length; i += 1) {
            this.showError(errors[i].message || errors[i], {doNotClosePassive: true});
        }
    },
    showAPIError: function (resp, options) {
        options = options || {};

        if (!options.doNotClosePassive) {
            this.closePassive();
        }

        options.defaultErrorText = options.defaultErrorText || 'There was a problem on the server, please try again.';

        if (resp && resp.jqXHR && resp.jqXHR.responseJSON && resp.jqXHR.responseJSON.error) {
            this.showError(resp.jqXHR.responseJSON.error, options);
        } else if (resp && resp.jqXHR && resp.jqXHR.responseJSON && resp.jqXHR.responseJSON.errors) {
            this.showErrors(resp.jqXHR.responseJSON.errors, options);
        } else if (resp && resp.jqXHR && resp.jqXHR.responseJSON && resp.jqXHR.responseJSON.message) {
            this.showError(resp.jqXHR.responseJSON.message, options);
        } else {
            this.showError(options.defaultErrorText, {doNotClosePassive: true});
        }
    },
    showInfo: function (message, options) {
        options = options || {};

        if (!options.doNotClosePassive) {
            this.closePassive();
        }

        this.handleNotification({
            type: 'info',
            message: message
        }, options.delayed);
    },
    showSuccess: function (message, options) {
        options = options || {};

        if (!options.doNotClosePassive) {
            this.closePassive();
        }

        this.handleNotification({
            type: 'success',
            message: message
        }, options.delayed);
    },
    showWarn: function (message, options) {
        options = options || {};

        if (!options.doNotClosePassive) {
            this.closePassive();
        }

        this.handleNotification({
            type: 'warn',
            message: message
        }, options.delayed);
    },
    displayDelayed: function () {
        var self = this;

        self.delayedNotifications.forEach(function (message) {
            self.pushObject(message);
        });
        self.delayedNotifications = [];
    },
    closeNotification: function (notification) {
        var self = this;

        if (notification instanceof Notification) {
            notification.deleteRecord();
            notification.save().finally(function () {
                self.removeObject(notification);
            });
        } else {
            this.removeObject(notification);
        }
    },
    closePassive: function () {
        this.set('content', this.rejectBy('status', 'passive'));
    },
    closePersistent: function () {
        this.set('content', this.rejectBy('status', 'persistent'));
    },
    closeAll: function () {
        this.clear();
    }
});

export default Notifications;