index.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", { value: true });
  3. var component_1 = require('./../common/component.js');
  4. var touch_1 = require('./../mixins/touch.js');
  5. var THRESHOLD = 0.3;
  6. component_1.VantComponent({
  7. props: {
  8. disabled: Boolean,
  9. leftWidth: {
  10. type: Number,
  11. value: 0
  12. },
  13. rightWidth: {
  14. type: Number,
  15. value: 0
  16. },
  17. asyncClose: Boolean
  18. },
  19. mixins: [touch_1.touch],
  20. data: {
  21. catchMove: false
  22. },
  23. created: function created() {
  24. this.offset = 0;
  25. },
  26. methods: {
  27. open: function open(position) {
  28. var _a = this.data,
  29. leftWidth = _a.leftWidth,
  30. rightWidth = _a.rightWidth;
  31. var offset = position === 'left' ? leftWidth : -rightWidth;
  32. this.swipeMove(offset);
  33. },
  34. close: function close() {
  35. this.swipeMove(0);
  36. },
  37. swipeMove: function swipeMove(offset) {
  38. if (offset === void 0) {
  39. offset = 0;
  40. }
  41. this.offset = offset;
  42. var transform = "translate3d(" + offset + "px, 0, 0)";
  43. var transition = this.draging ? 'none' : '.6s cubic-bezier(0.18, 0.89, 0.32, 1)';
  44. this.set({
  45. wrapperStyle: "\n -webkit-transform: " + transform + ";\n -webkit-transition: " + transition + ";\n transform: " + transform + ";\n transition: " + transition + ";\n "
  46. });
  47. },
  48. swipeLeaveTransition: function swipeLeaveTransition() {
  49. var _a = this.data,
  50. leftWidth = _a.leftWidth,
  51. rightWidth = _a.rightWidth;
  52. var offset = this.offset;
  53. if (rightWidth > 0 && -offset > rightWidth * THRESHOLD) {
  54. this.open('right');
  55. } else if (leftWidth > 0 && offset > leftWidth * THRESHOLD) {
  56. this.open('left');
  57. } else {
  58. this.swipeMove(0);
  59. }
  60. this.set({ catchMove: false });
  61. },
  62. startDrag: function startDrag(event) {
  63. if (this.data.disabled) {
  64. return;
  65. }
  66. this.draging = true;
  67. this.startOffset = this.offset;
  68. this.firstDirection = '';
  69. this.touchStart(event);
  70. },
  71. noop: function noop() {},
  72. onDrag: function onDrag(event) {
  73. if (this.data.disabled) {
  74. return;
  75. }
  76. this.touchMove(event);
  77. if (!this.firstDirection) {
  78. this.firstDirection = this.direction;
  79. this.set({ catchMove: this.firstDirection === 'horizontal' });
  80. }
  81. if (this.firstDirection === 'vertical') {
  82. return;
  83. }
  84. var _a = this.data,
  85. leftWidth = _a.leftWidth,
  86. rightWidth = _a.rightWidth;
  87. var offset = this.startOffset + this.deltaX;
  88. if (rightWidth > 0 && -offset > rightWidth || leftWidth > 0 && offset > leftWidth) {
  89. return;
  90. }
  91. this.swipeMove(offset);
  92. },
  93. endDrag: function endDrag() {
  94. if (this.data.disabled) {
  95. return;
  96. }
  97. this.draging = false;
  98. this.swipeLeaveTransition();
  99. },
  100. onClick: function onClick(event) {
  101. var _a = event.currentTarget.dataset.key,
  102. position = _a === void 0 ? 'outside' : _a;
  103. this.$emit('click', position);
  104. if (!this.offset) {
  105. return;
  106. }
  107. if (this.data.asyncClose) {
  108. this.$emit('close', { position: position, instance: this });
  109. } else {
  110. this.swipeMove(0);
  111. }
  112. }
  113. }
  114. });
  115. //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["index.js"],"names":["Object","value","component_1","require","touch_1","THRESHOLD","props","disabled","leftWidth","type","rightWidth","asyncClose","Boolean","mixins","data","catchMove","created","methods","open","_a","offset","position","close","swipeMove","transform","transition","wrapperStyle","swipeLeaveTransition","startDrag","noop","onDrag","endDrag","onClick","event","instance"],"mappings":"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","sourcesContent":["\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar component_1 = require(\"../common/component\");\nvar touch_1 = require(\"../mixins/touch\");\nvar THRESHOLD = 0.3;\ncomponent_1.VantComponent({\n    props: {\n        disabled: Boolean,\n        leftWidth: {\n            type: Number,\n            value: 0\n        },\n        rightWidth: {\n            type: Number,\n            value: 0\n        },\n        asyncClose: Boolean\n    },\n    mixins: [touch_1.touch],\n    data: {\n        catchMove: false\n    },\n    created: function () {\n        this.offset = 0;\n    },\n    methods: {\n        open: function (position) {\n            var _a = this.data, leftWidth = _a.leftWidth, rightWidth = _a.rightWidth;\n            var offset = position === 'left' ? leftWidth : -rightWidth;\n            this.swipeMove(offset);\n        },\n        close: function () {\n            this.swipeMove(0);\n        },\n        swipeMove: function (offset) {\n            if (offset === void 0) { offset = 0; }\n            this.offset = offset;\n            var transform = \"translate3d(\" + offset + \"px, 0, 0)\";\n            var transition = this.draging\n                ? 'none'\n                : '.6s cubic-bezier(0.18, 0.89, 0.32, 1)';\n            this.set({\n                wrapperStyle: \"\\n        -webkit-transform: \" + transform + \";\\n        -webkit-transition: \" + transition + \";\\n        transform: \" + transform + \";\\n        transition: \" + transition + \";\\n      \"\n            });\n        },\n        swipeLeaveTransition: function () {\n            var _a = this.data, leftWidth = _a.leftWidth, rightWidth = _a.rightWidth;\n            var offset = this.offset;\n            if (rightWidth > 0 && -offset > rightWidth * THRESHOLD) {\n                this.open('right');\n            }\n            else if (leftWidth > 0 && offset > leftWidth * THRESHOLD) {\n                this.open('left');\n            }\n            else {\n                this.swipeMove(0);\n            }\n            this.set({ catchMove: false });\n        },\n        startDrag: function (event) {\n            if (this.data.disabled) {\n                return;\n            }\n            this.draging = true;\n            this.startOffset = this.offset;\n            this.firstDirection = '';\n            this.touchStart(event);\n        },\n        noop: function () { },\n        onDrag: function (event) {\n            if (this.data.disabled) {\n                return;\n            }\n            this.touchMove(event);\n            if (!this.firstDirection) {\n                this.firstDirection = this.direction;\n                this.set({ catchMove: this.firstDirection === 'horizontal' });\n            }\n            if (this.firstDirection === 'vertical') {\n                return;\n            }\n            var _a = this.data, leftWidth = _a.leftWidth, rightWidth = _a.rightWidth;\n            var offset = this.startOffset + this.deltaX;\n            if ((rightWidth > 0 && -offset > rightWidth) ||\n                (leftWidth > 0 && offset > leftWidth)) {\n                return;\n            }\n            this.swipeMove(offset);\n        },\n        endDrag: function () {\n            if (this.data.disabled) {\n                return;\n            }\n            this.draging = false;\n            this.swipeLeaveTransition();\n        },\n        onClick: function (event) {\n            var _a = event.currentTarget.dataset.key, position = _a === void 0 ? 'outside' : _a;\n            this.$emit('click', position);\n            if (!this.offset) {\n                return;\n            }\n            if (this.data.asyncClose) {\n                this.$emit('close', { position: position, instance: this });\n            }\n            else {\n                this.swipeMove(0);\n            }\n        }\n    }\n});\n"],"file":"index.js"}