layui.define(['jquery','util','layer'],function (exports) {
    var $ = layui.$,
        util = layui.util,
        layer = layui.layer,
        input_elem = 'input[number-input]',
        baseClassName = 'layui-input-number',
        numberInputBtn = [
            '
',
            '',
            '',
            '
',
        ].join(''),
        style = [
            ''
        ].join('');
    $('head link:last')[0] && $('head link:last').after(style) || $('head').append(style);
    var numberInput = {
        options:{
            elem:input_elem
        },
        render:function (option) {
            var _this = this;
            _this.options = $.extend(_this.options, option);
            $(_this.options.elem).not('[lay-ignore]').addClass(baseClassName).wrap('');
            $(_this.options.elem).not('[lay-ignore]').after(numberInputBtn);
            _this.listen();
        },
        listen:function () {
            var _this = this;
            $(_this.options.elem).bind('input propertychange',function () {
                var value = $(this).val();
                $(this).val(value.replace(/[^\-?\d.]/g,''));
            });
            $(_this.options.elem).keydown(function (event) {
                var e = event||window.event;
                var k = e.keyCode || e.which;
                switch (k) {
                    case 38:
                        // 按下向上箭头
                        $(this).siblings('.layui-number-input-btn').children('[lay-click="numberUp"]').trigger('click').css('background','#eee');
                        break;
                    case 40:
                        // 按下向上箭头
                        $(this).siblings('.layui-number-input-btn').children('[lay-click="numberDown"]').trigger('click').css('background','#eee');
                        break;
                    default:
                        break;
                }
                return false;
            });
            $(_this.options.elem).keyup(function () {
                var e = event||window.event;
                var k = e.keyCode || e.which;
                switch (k) {
                    case 38:
                        // 按下向上箭头
                        $(this).siblings('.layui-number-input-btn').children('[lay-click="numberUp"]').css('background','');
                        break;
                    case 40:
                        // 按下向上箭头
                        $(this).siblings('.layui-number-input-btn').children('[lay-click="numberDown"]').css('background','');
                        break;
                    default:
                        break;
                }
                return false;
            });
            var timeOut;
            //长按
            $('[lay-click="numberUp"],[lay-click="numberDown"]').mousedown(function () {
                var $this = $(this);
                timeOut = setInterval(function () {
                    $this.trigger('click');
                },200)
            });
            $('[lay-click="numberUp"],[lay-click="numberDown"]').mouseup(function () {
                clearInterval(timeOut);
            });
            $('[lay-click="numberUp"],[lay-click="numberDown"]').mouseout(function () {
                clearInterval(timeOut);
            });
            util.event('lay-click',{
                numberUp:function (othis) {
                    var thisInput = othis.parent().parent().children('.'+baseClassName);
                    var thisInputValue = Number(thisInput.val()||0);
                    var step = thisInput.attr('step')||1;
                    var maxValue = Number(thisInput.attr('max'));
                    if (maxValue!=undefined){
                        if (thisInputValue>=maxValue){
                            layer.tips('最大值'+maxValue,thisInput,{tips:1});
                            return false;
                        }
                    }
                    thisInputValue=_this.add(thisInputValue,parseFloat(step));
                    thisInput.val('').focus().val(thisInputValue);
                },
                numberDown:function(othis){
                    var thisInput = othis.parent().parent().children('.'+baseClassName);
                    var thisInputValue = thisInput.val()||0;
                    var step = thisInput.attr('step')||1;
                    var minValue = thisInput.attr('min');
                    if (minValue!=undefined){
                        if (thisInputValue<=minValue){
                            layer.tips('最小值'+minValue,thisInput,{tips:1});
                            return false;
                        }
                    }
                    thisInputValue = _this.subtraction(thisInputValue,step);
                    thisInput.val('').focus().val(thisInputValue);
                }
            });
        },
        /**
         * 加法
         * @param arg1
         * @param arg2
         * @returns {number}
         */
        add:function (arg1, arg2) {
            var r1,r2,m;
            try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0}
            try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0}
            m=Math.pow(10,Math.max(r1,r2))
            return (this.multiplication(arg1,m)+this.multiplication(arg2,m))/m
        },
        /**
         * 减法
         * @param arg1 被减数
         * @param arg2 减数
         * @returns {string}
         */
        subtraction:function (arg1, arg2) {
            var r1, r2, m, n;
            try {
                r1 = arg1.toString().split(".")[1].length;
            }
            catch (e) {
                r1 = 0;
            }
            try {
                r2 = arg2.toString().split(".")[1].length;
            }
            catch (e) {
                r2 = 0;
            }
            m = Math.pow(10, Math.max(r1, r2));
            //last modify by deeka
            //动态控制精度长度
            n = (r1 >= r2) ? r1 : r2;
            return ((arg1 * m - arg2 * m) / m).toFixed(n);
        },
        /**
         * 乘法
         * @param arg1
         * @param arg2
         * @returns {number}
         */
        multiplication:function (arg1,arg2) {
            var m=0,s1=arg1.toString(),s2=arg2.toString();
            try{m+=s1.split(".")[1].length}catch(e){}
            try{m+=s2.split(".")[1].length}catch(e){}
            return Number(s1.replace(".",""))*Number(s2.replace(".",""))/Math.pow(10,m)
        },
        /**
         * 除法
         * @param arg1
         * @param arg2
         * @returns {*|number}
         */
        division:function (arg1,arg2) {
            var t1 = 0, t2 = 0, r1, r2;
            try {
                t1 = arg1.toString().split(".")[1].length
            } catch (e) {
            }
            try {
                t2 = arg2.toString().split(".")[1].length
            } catch (e) {
            }
            with (Math) {
                r1 = Number(arg1.toString().replace(".", ""))
                r2 = Number(arg2.toString().replace(".", ""))
                return this.multiplication((r1 / r2), pow(10, t2 - t1));
            }
        }
    };
    //外部接口
    var exportApi = {
        render:function(option){
            numberInput.render(option)
        },
    };
    exports('numberInput',exportApi);
});