"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); var component_1 = require('./../common/component.js'); var FONT_COLOR = '#ed6a0c'; var BG_COLOR = '#fffbe8'; component_1.VantComponent({ props: { text: { type: String, value: '' }, mode: { type: String, value: '' }, url: { type: String, value: '' }, openType: { type: String, value: 'navigate' }, delay: { type: Number, value: 1 }, speed: { type: Number, value: 50 }, scrollable: { type: Boolean, value: true }, leftIcon: { type: String, value: '' }, color: { type: String, value: FONT_COLOR }, backgroundColor: { type: String, value: BG_COLOR }, wrapable: Boolean }, data: { show: true }, watch: { text: function text() { this.set({}, this.init); } }, created: function created() { this.resetAnimation = wx.createAnimation({ duration: 0, timingFunction: 'linear' }); }, destroyed: function destroyed() { this.timer && clearTimeout(this.timer); }, methods: { init: function init() { var _this = this; Promise.all([this.getRect('.van-notice-bar__content'), this.getRect('.van-notice-bar__wrap')]).then(function (rects) { var contentRect = rects[0], wrapRect = rects[1]; if (contentRect == null || wrapRect == null || !contentRect.width || !wrapRect.width) { return; } var _a = _this.data, speed = _a.speed, scrollable = _a.scrollable, delay = _a.delay; if (scrollable && wrapRect.width < contentRect.width) { var duration = contentRect.width / speed * 1000; _this.wrapWidth = wrapRect.width; _this.contentWidth = contentRect.width; _this.duration = duration; _this.animation = wx.createAnimation({ duration: duration, timingFunction: 'linear', delay: delay }); _this.scroll(); } }); }, scroll: function scroll() { var _this = this; this.timer && clearTimeout(this.timer); this.timer = null; this.set({ animationData: this.resetAnimation.translateX(this.wrapWidth).step().export() }); setTimeout(function () { _this.set({ animationData: _this.animation.translateX(-_this.contentWidth).step().export() }); }, 20); this.timer = setTimeout(function () { _this.scroll(); }, this.duration); }, onClickIcon: function onClickIcon() { this.timer && clearTimeout(this.timer); this.timer = null; this.set({ show: false }); }, onClick: function onClick(event) { this.$emit('click', event); } } }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.js"],"names":["Object","value","component_1","require","FONT_COLOR","BG_COLOR","props","text","type","mode","url","openType","delay","speed","scrollable","leftIcon","color","backgroundColor","wrapable","Boolean","data","show","watch","created","duration","timingFunction","destroyed","clearTimeout","methods","init","_this","Promise","contentRect","rects","wrapRect","_a","scroll","animationData","setTimeout","onClickIcon","onClick"],"mappings":"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","sourcesContent":["\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar component_1 = require(\"../common/component\");\nvar FONT_COLOR = '#ed6a0c';\nvar BG_COLOR = '#fffbe8';\ncomponent_1.VantComponent({\n    props: {\n        text: {\n            type: String,\n            value: ''\n        },\n        mode: {\n            type: String,\n            value: ''\n        },\n        url: {\n            type: String,\n            value: ''\n        },\n        openType: {\n            type: String,\n            value: 'navigate'\n        },\n        delay: {\n            type: Number,\n            value: 1\n        },\n        speed: {\n            type: Number,\n            value: 50\n        },\n        scrollable: {\n            type: Boolean,\n            value: true\n        },\n        leftIcon: {\n            type: String,\n            value: ''\n        },\n        color: {\n            type: String,\n            value: FONT_COLOR\n        },\n        backgroundColor: {\n            type: String,\n            value: BG_COLOR\n        },\n        wrapable: Boolean\n    },\n    data: {\n        show: true\n    },\n    watch: {\n        text: function () {\n            this.set({}, this.init);\n        }\n    },\n    created: function () {\n        this.resetAnimation = wx.createAnimation({\n            duration: 0,\n            timingFunction: 'linear'\n        });\n    },\n    destroyed: function () {\n        this.timer && clearTimeout(this.timer);\n    },\n    methods: {\n        init: function () {\n            var _this = this;\n            Promise.all([\n                this.getRect('.van-notice-bar__content'),\n                this.getRect('.van-notice-bar__wrap')\n            ]).then(function (rects) {\n                var contentRect = rects[0], wrapRect = rects[1];\n                if (contentRect == null ||\n                    wrapRect == null ||\n                    !contentRect.width ||\n                    !wrapRect.width) {\n                    return;\n                }\n                var _a = _this.data, speed = _a.speed, scrollable = _a.scrollable, delay = _a.delay;\n                if (scrollable && wrapRect.width < contentRect.width) {\n                    var duration = (contentRect.width / speed) * 1000;\n                    _this.wrapWidth = wrapRect.width;\n                    _this.contentWidth = contentRect.width;\n                    _this.duration = duration;\n                    _this.animation = wx.createAnimation({\n                        duration: duration,\n                        timingFunction: 'linear',\n                        delay: delay\n                    });\n                    _this.scroll();\n                }\n            });\n        },\n        scroll: function () {\n            var _this = this;\n            this.timer && clearTimeout(this.timer);\n            this.timer = null;\n            this.set({\n                animationData: this.resetAnimation\n                    .translateX(this.wrapWidth)\n                    .step()\n                    .export()\n            });\n            setTimeout(function () {\n                _this.set({\n                    animationData: _this.animation\n                        .translateX(-_this.contentWidth)\n                        .step()\n                        .export()\n                });\n            }, 20);\n            this.timer = setTimeout(function () {\n                _this.scroll();\n            }, this.duration);\n        },\n        onClickIcon: function () {\n            this.timer && clearTimeout(this.timer);\n            this.timer = null;\n            this.set({ show: false });\n        },\n        onClick: function (event) {\n            this.$emit('click', event);\n        }\n    }\n});\n"],"file":"index.js"}