index.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", { value: true });
  3. var component_1 = require('./../common/component.js');
  4. var FONT_COLOR = '#ed6a0c';
  5. var BG_COLOR = '#fffbe8';
  6. component_1.VantComponent({
  7. props: {
  8. text: {
  9. type: String,
  10. value: ''
  11. },
  12. mode: {
  13. type: String,
  14. value: ''
  15. },
  16. url: {
  17. type: String,
  18. value: ''
  19. },
  20. openType: {
  21. type: String,
  22. value: 'navigate'
  23. },
  24. delay: {
  25. type: Number,
  26. value: 1
  27. },
  28. speed: {
  29. type: Number,
  30. value: 50
  31. },
  32. scrollable: {
  33. type: Boolean,
  34. value: true
  35. },
  36. leftIcon: {
  37. type: String,
  38. value: ''
  39. },
  40. color: {
  41. type: String,
  42. value: FONT_COLOR
  43. },
  44. backgroundColor: {
  45. type: String,
  46. value: BG_COLOR
  47. },
  48. wrapable: Boolean
  49. },
  50. data: {
  51. show: true
  52. },
  53. watch: {
  54. text: function text() {
  55. this.set({}, this.init);
  56. }
  57. },
  58. created: function created() {
  59. this.resetAnimation = wx.createAnimation({
  60. duration: 0,
  61. timingFunction: 'linear'
  62. });
  63. },
  64. destroyed: function destroyed() {
  65. this.timer && clearTimeout(this.timer);
  66. },
  67. methods: {
  68. init: function init() {
  69. var _this = this;
  70. Promise.all([this.getRect('.van-notice-bar__content'), this.getRect('.van-notice-bar__wrap')]).then(function (rects) {
  71. var contentRect = rects[0],
  72. wrapRect = rects[1];
  73. if (contentRect == null || wrapRect == null || !contentRect.width || !wrapRect.width) {
  74. return;
  75. }
  76. var _a = _this.data,
  77. speed = _a.speed,
  78. scrollable = _a.scrollable,
  79. delay = _a.delay;
  80. if (scrollable && wrapRect.width < contentRect.width) {
  81. var duration = contentRect.width / speed * 1000;
  82. _this.wrapWidth = wrapRect.width;
  83. _this.contentWidth = contentRect.width;
  84. _this.duration = duration;
  85. _this.animation = wx.createAnimation({
  86. duration: duration,
  87. timingFunction: 'linear',
  88. delay: delay
  89. });
  90. _this.scroll();
  91. }
  92. });
  93. },
  94. scroll: function scroll() {
  95. var _this = this;
  96. this.timer && clearTimeout(this.timer);
  97. this.timer = null;
  98. this.set({
  99. animationData: this.resetAnimation.translateX(this.wrapWidth).step().export()
  100. });
  101. setTimeout(function () {
  102. _this.set({
  103. animationData: _this.animation.translateX(-_this.contentWidth).step().export()
  104. });
  105. }, 20);
  106. this.timer = setTimeout(function () {
  107. _this.scroll();
  108. }, this.duration);
  109. },
  110. onClickIcon: function onClickIcon() {
  111. this.timer && clearTimeout(this.timer);
  112. this.timer = null;
  113. this.set({ show: false });
  114. },
  115. onClick: function onClick(event) {
  116. this.$emit('click', event);
  117. }
  118. }
  119. });
  120. //# 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"}