view.js 4.81 KB
var $ = require('yoho-jquery');
var send = require('./socket/send');
var serviceApi = require('./service-api');
var socketConf = require('./socket/config');
var conMsg = socketConf.conversationMessage;


// 过程标示
var processSign = {
    encryptedUid: '',
    hasMore: true,          // 更多消息
    manual: false,          // 人工客服
    promoter: 1,            // 评论发起者 1:客户自己 2:客服
    savedEval: false,       // 是否保存过评论
    scrollLoad: false,      // 滚动加载
    completeClose: false,   // 评价完成后关闭
    loadingHistory: false   // 加载消息
};

/**
 * 评价客服view
 * @constructor
 */
function Evaluate() {
    this.$view = $('#makeEvaluation');
    this.disTpl = require('hbs/service/discontent-row.hbs');
    this.bindEvents();
}

/**
 * 获取评价原因
 */
var _fetchReason = (function() {
    var cache;

    return function(render) {
        if (cache) return render(cache);
        serviceApi.reason({
            conversationId: conMsg.conversationId
        })
            .done(function(res) {
                if (res.code === 200) {
                    cache = res.data;
                    render(cache);
                } else {
                    alert(res.message);
                }
            });
    };
})();

/**
 * 星评
 */
var _starChange = function(e) {
    var self = this,
        $ct = $(e.currentTarget),
        index = $ct.index(),
        $reason = self.$view.find('.detail-reason'),
        $text = self.$view.find('.star-text'),
        $list = self.$view.find('.star');

    var starText = {
        0: '非常不满意',
        1: '不满意',
        2: '一般',
        3: '满意',
        4: '非常满意'
    };

    for (var i = 0, len = $list.length; i < len; i++) {
        var $el = $($list[i]);
        $el.index() <= index && $el.addClass('positive');
        $el.index() > index && $el.removeClass('positive');
    }

    index < 3 && $reason.show();
    index >= 3 && $reason.hide();
    $text.text(starText[index]);
};

/**
 * 评价提交
 */
var _evalSubmit = function() {
    var $btnEval = $('.icon.evaluate'),
        mEval = $('#makeEvaluation'),
        reason = mEval.find('textarea').val().trim(),
        star = mEval.find('.star.positive').length,
        reasonTypes = mEval.find('.dis-row .type.chosen');

    var data = {
        conversationId: conMsg.conversationId,
        encryptedUid: processSign.encryptedUid,
        promoter: processSign.promoter,
        stars: star
    };

    var reasonIds,
        idArray = [];

    if (star < 4) {
        $.each(reasonTypes, function(index, item) {
            idArray.push($(item).data('id'));
        });

        reasonIds = idArray.join(':');
        data.reasonIds = reasonIds;
        data.reasonMsg = reason;
    }

    serviceApi.evaluate(data)
        .done(function(res) {
            $btnEval.hide();
            processSign.savedEval = true;

            if (res && res.code === 200) {
                send.completeEval();

                // 完成后关闭
                if (processSign.completeClose) {
                    window.close();
                }
            }
        })
        .always(function() {
            mEval.modal('hide');
        });
};

Evaluate.prototype = {
    bindEvents: function() {
        var self = this;

        this.$view.on('click', '.star', _starChange.bind(self))
                  .on('click', '.submit', _evalSubmit)
                  .on('click', '.dis-row .type', function(e) {
                      $(e.target).toggleClass('chosen');
                  });
    },

    open: function(close) {
        var self = this;

        processSign.completeClose = close;
        if (!processSign.manual) {
            return;
        }

        var _resetEval = function() {
            self.$view.find('.star-text').html('非常满意');
            self.$view.find('.star').addClass('positive');
            self.$view.find('.other-reason').val('');
            self.$view.find('.detail-reason').hide();
        };

        var _show = function(data) {
            var dom = '';

            _resetEval();
            if (!data || !data.length) return self.$view.modal('show');
            for (var i = 0, len = data.length; i < len; i = i + 2) {
                dom += self.disTpl({
                    id1: data[i].id,
                    id1Content: data[i].content,
                    id2: data[i + 1] && data[i + 1].id,
                    id2Content: data[i + 1] && data[i + 1].content
                });
            }

            self.$view.find('.discontent').empty().append(dom);
            self.$view.modal('show');
        };

        _fetchReason(_show);
    },

    close: function() {
        this.$view.modal('hide');
    }
};

Evaluate.prototype.constructor = Evaluate;


module.exports = {
    processInfo: processSign,
    Evaluate: Evaluate
};