├── .gitignore ├── App.vue ├── Example.js ├── LICENSE ├── README.md ├── Slider.css ├── Slider.js ├── dist ├── Slider.css ├── Slider.css.map ├── Slider.js └── Slider.js.map ├── example ├── README.md ├── example.js ├── index.vue ├── package-lock.json ├── package.json └── yarn.lock ├── package-lock.json └── package.json /.gitignore: -------------------------------------------------------------------------------- 1 | .DS_Store 2 | node_modules/ 3 | npm-debug.log 4 | yarn-error.log 5 | -------------------------------------------------------------------------------- /App.vue: -------------------------------------------------------------------------------- 1 | 21 | 22 | 32 | 33 | 44 | -------------------------------------------------------------------------------- /Example.js: -------------------------------------------------------------------------------- 1 | import Slider from './Slider' 2 | 3 | const style = { 4 | height: '250px', 5 | display: 'flex', 6 | justifyContent: 'center', 7 | alignItems: 'center', 8 | color: '#fafafa' 9 | } 10 | 11 | export default { 12 | components: { 13 | Slider 14 | }, 15 | render(h) { 16 | return ( 17 |
18 | 23 |
24 |

A

25 |
26 |
27 |

B

28 |
29 |
30 |

C

31 |
32 |
33 |

D

34 |
35 |
36 |

E

37 |
38 |
39 |
40 | ) 41 | } 42 | } 43 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2017 Piyush Chauhan 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Vue Simple Slider 2 | 3 | > vue-simple-slider 4 | 5 | Vue slider component with touch and mouse support. 6 | 7 | Modern browsers and IE10+ (IE9 should work, but as flex is not supported you'll need to change CSS). 8 | 9 | ## Features 10 | 11 | * Lightweight, no dependencies 12 | * Navigation, pager and arrows 13 | * Swipe and Mouse support, with velocity detection 14 | * Works only with JSX syntax currently 15 | 16 | ## Usage 17 | 18 | ```jsx 19 | import 'node_modules/vue-simple-slider/dist/Slider.css' 20 | import Slider from 'vue-simple-slider' 21 | 22 | const style = { 23 | height: '250px', 24 | display: 'flex', 25 | justifyContent: 'center', 26 | alignItems: 'center', 27 | color: '#fafafa' 28 | } 29 | 30 | export default { 31 | components: { 32 | Slider 33 | }, 34 | render(h) { 35 | return ( 36 | 37 |
38 |

A

39 |
40 |
41 |

B

42 |
43 |
44 |

C

45 |
46 |
47 |

D

48 |
49 |
50 |

E

51 |
52 |
53 | ) 54 | } 55 | } 56 | ``` 57 | 58 | ## Screenshot 59 | ![screen shot 2017-06-13 at 2 43 31 am](https://user-images.githubusercontent.com/693487/27049909-5bc66f02-4fe3-11e7-8342-8d3da37a3915.png) 60 | 61 | ## Build Setup 62 | 63 | ``` bash 64 | # install dependencies 65 | npm i -g vue-cli 66 | npm install 67 | 68 | # serve with hot reload at localhost:4000 69 | npm run dev 70 | 71 | # build for production with minification 72 | npm run build 73 | ``` 74 | 75 | For detailed explanation on how things work, consult the [docs for vue-build](https://github.com/vuejs/vue-cli/blob/master/docs/build.md). 76 | 77 | 78 | ## License 79 | vue-simple-slider is open source and released under the [MIT License](LICENSE). 80 | 81 | Copyright (c) 2017 [Piyush Chauhan](https://twitter.com/piyushpsycho). 82 | 83 | > *PS: I would love to know if you're using vue-simple-slider. Tweet to me at [@piyushpsycho](https://twitter.com/piyushpsycho)*. 84 | 85 | ## Credits 86 | Shamelessy copied from react community [React Simple Slider](https://github.com/Stanko/react-slider) -------------------------------------------------------------------------------- /Slider.css: -------------------------------------------------------------------------------- 1 | .Slider { 2 | overflow: hidden; 3 | position: relative; 4 | display: -webkit-box; 5 | display: -webkit-flex; 6 | display: -ms-flexbox; 7 | display: flex; 8 | -webkit-box-orient: vertical; 9 | -webkit-box-direction: normal; 10 | -webkit-flex-direction: column; 11 | -ms-flex-direction: column; 12 | flex-direction: column; 13 | } 14 | 15 | .Slider-slides { 16 | display: -webkit-box; 17 | display: -webkit-flex; 18 | display: -ms-flexbox; 19 | display: flex; 20 | } 21 | 22 | .Slider-slides--transition { 23 | -webkit-transition: -webkit-transform 0.25s; 24 | transition: -webkit-transform 0.25s; 25 | transition: transform 0.25s; 26 | transition: transform 0.25s, -webkit-transform 0.25s; 27 | } 28 | 29 | .Slider-slides>* { 30 | -webkit-flex-basis: 0; 31 | -ms-flex-preferred-size: 0; 32 | flex-basis: 0; 33 | -webkit-box-flex: 1; 34 | -webkit-flex-grow: 1; 35 | -ms-flex-positive: 1; 36 | flex-grow: 1; 37 | } 38 | 39 | .Slider-slides>* { 40 | -webkit-flex-basis: 0; 41 | -ms-flex-preferred-size: 0; 42 | flex-basis: 0; 43 | -webkit-box-flex: 1; 44 | -webkit-flex-grow: 1; 45 | -ms-flex-positive: 1; 46 | flex-grow: 1; 47 | } 48 | 49 | .Slider-nav { 50 | -webkit-align-content: center; 51 | -ms-flex-line-pack: center; 52 | align-content: center; 53 | display: -webkit-box; 54 | display: -webkit-flex; 55 | display: -ms-flexbox; 56 | display: flex; 57 | -webkit-box-pack: center; 58 | -webkit-justify-content: center; 59 | -ms-flex-pack: center; 60 | justify-content: center; 61 | margin-top: 10px; 62 | -webkit-box-ordinal-group: 3; 63 | -webkit-order: 2; 64 | -ms-flex-order: 2; 65 | order: 2; 66 | } 67 | 68 | .Slider-navButton { 69 | background: none; 70 | border: 0; 71 | height: 20px; 72 | opacity: 0.5; 73 | outline: none; 74 | position: relative; 75 | -webkit-transition: opacity 0.25s; 76 | transition: opacity 0.25s; 77 | width: 20px; 78 | padding: 0; 79 | } 80 | 81 | .Slider-navButton::after { 82 | background: #345; 83 | border-radius: 50%; 84 | content: ''; 85 | display: block; 86 | height: 6px; 87 | left: 7px; 88 | position: absolute; 89 | top: 7px; 90 | width: 6px; 91 | } 92 | 93 | .Slider-navButton--active { 94 | opacity: 1; 95 | } 96 | 97 | .Slider-navButton--active::after { 98 | height: 12px; 99 | left: 4px; 100 | opacity: 1; 101 | top: 4px; 102 | width: 12px; 103 | } 104 | 105 | .Slider-arrows { 106 | height: 0; 107 | left: 0; 108 | position: absolute; 109 | top: calc(50% - 35px); 110 | width: 100%; 111 | z-index: 1; 112 | } 113 | 114 | .Slider-arrows--noNav { 115 | top: calc(50% - 20px); 116 | } 117 | 118 | .Slider-arrow { 119 | background: none; 120 | border: none; 121 | height: 40px; 122 | opacity: 0.5; 123 | outline: none; 124 | position: absolute; 125 | -webkit-transition: opacity 0.25s; 126 | transition: opacity 0.25s; 127 | padding: 0px; 128 | width: 21px; 129 | } 130 | 131 | .Slider-arrow:hover { 132 | opacity: 1; 133 | } 134 | 135 | .Slider-arrow::after, 136 | .Slider-arrow::before { 137 | background: #fff; 138 | border-radius: 3px; 139 | content: ''; 140 | display: block; 141 | height: 23px; 142 | position: absolute; 143 | width: 5px; 144 | left: 8px; 145 | } 146 | 147 | .Slider-arrow::before { 148 | top: 0; 149 | } 150 | 151 | .Slider-arrow::after { 152 | bottom: 0; 153 | } 154 | 155 | .Slider-arrow--left { 156 | top: 0; 157 | left: 10px; 158 | } 159 | 160 | .Slider-arrow--left::before { 161 | -webkit-transform: rotate(30deg); 162 | transform: rotate(30deg); 163 | } 164 | 165 | .Slider-arrow--left::after { 166 | -webkit-transform: rotate(-30deg); 167 | transform: rotate(-30deg); 168 | } 169 | 170 | .Slider-arrow--right { 171 | top: 0; 172 | right: 10px; 173 | } 174 | 175 | .Slider-arrow--right::before { 176 | -webkit-transform: rotate(-30deg); 177 | transform: rotate(-30deg); 178 | } 179 | 180 | .Slider-arrow--right::after { 181 | -webkit-transform: rotate(30deg); 182 | transform: rotate(30deg); 183 | } -------------------------------------------------------------------------------- /Slider.js: -------------------------------------------------------------------------------- 1 | import './Slider.css' 2 | 3 | export default { 4 | props: { 5 | loop: { 6 | type: Boolean, 7 | default: false 8 | }, 9 | selected: { 10 | type: Number, 11 | default: 0 12 | }, 13 | showArrows: { 14 | type: Boolean, 15 | default: true 16 | }, 17 | showNav: { 18 | type: Boolean, 19 | default: true 20 | } 21 | }, 22 | data: function () { 23 | return { 24 | dragStart: 0, 25 | dragStartTime: new Date(), 26 | transition: false, 27 | index: this.$props.selected || 0, 28 | lastIndex: this.$props.selected || 0, 29 | mouseDown: false 30 | } 31 | }, 32 | methods: { 33 | goToSlide: function (index, event) { 34 | const children = this.$slots.default 35 | const { 36 | loop, 37 | } = this.$props 38 | 39 | if (event) { 40 | event.preventDefault() 41 | event.stopPropagation() 42 | } 43 | 44 | if (index < 0) { 45 | index = loop ? children.length - 1 : 0 46 | } else if (index >= children.length) { 47 | index = loop ? 0 : children.length - 1 48 | } 49 | 50 | this.index = index 51 | this.lastIndex = index 52 | this.transition = true 53 | }, 54 | getDragX: function (event, isTouch) { 55 | return isTouch ? 56 | event.touches[0].pageX : 57 | event.pageX 58 | }, 59 | handleDragStart: function (event, isTouch) { 60 | const x = this.getDragX(event, isTouch) 61 | 62 | this.dragStart = x 63 | this.dragStartTime = new Date() 64 | this.transition = false 65 | this.slideWidth = this.$refs.slider.offsetWidth 66 | this.mouseDown = true 67 | }, 68 | 69 | handleDragMove: function (event, isTouch) { 70 | const { 71 | dragStart, 72 | lastIndex, 73 | slideWidth 74 | } = this 75 | 76 | const x = this.getDragX(event, isTouch) 77 | const offset = dragStart - x 78 | const percentageOffset = offset / slideWidth 79 | const newIndex = lastIndex + percentageOffset 80 | const SCROLL_OFFSET_TO_STOP_SCROLL = 30 81 | 82 | // Stop scrolling if you slide more than 30 pixels 83 | if (Math.abs(offset) > SCROLL_OFFSET_TO_STOP_SCROLL) { 84 | event.stopPropagation() 85 | } 86 | 87 | this.index = newIndex 88 | }, 89 | handleDragEnd: function () { 90 | const children = this.$slots.default 91 | const { 92 | dragStartTime, 93 | index, 94 | lastIndex 95 | } = this 96 | 97 | const timeElapsed = new Date().getTime() - dragStartTime.getTime() 98 | const offset = lastIndex - index 99 | const velocity = Math.round(offset / timeElapsed * 10000) 100 | 101 | let newIndex = Math.round(index) 102 | 103 | if (Math.abs(velocity) > 5) { 104 | newIndex = velocity < 0 ? lastIndex + 1 : lastIndex - 1 105 | } 106 | 107 | if (newIndex < 0) { 108 | newIndex = 0 109 | } else if (newIndex >= children.length) { 110 | newIndex = children.length - 1 111 | } 112 | 113 | this.dragStart = 0 114 | this.index = newIndex 115 | this.lastIndex = newIndex 116 | this.transition = true 117 | this.mouseDown = false 118 | }, 119 | renderArrows: function (h) { 120 | const children = this.$slots.default 121 | 122 | const { 123 | loop, 124 | showNav, 125 | } = this.$props 126 | 127 | const { 128 | lastIndex 129 | } = this 130 | 131 | const arrowsClasses = showNav ? 'Slider-arrows' : 'Slider-arrows Slider-arrows--noNav' 132 | 133 | const leftArrowEl = h( 134 | 'button', { 135 | class: 'Slider-arrow Slider-arrow--left', 136 | on: { 137 | click: (e) => this.goToSlide(lastIndex - 1, e) 138 | } 139 | } 140 | ) 141 | 142 | const rightArrowEl = h( 143 | 'button', { 144 | class: 'Slider-arrow Slider-arrow--right', 145 | on: { 146 | click: (e) => this.goToSlide(lastIndex + 1, e) 147 | } 148 | } 149 | ) 150 | 151 | return ( 152 |
153 | {loop || lastIndex > 0 ? leftArrowEl : null} 154 | {loop || lastIndex < children.length - 1 ? rightArrowEl : null} 155 |
156 | ) 157 | }, 158 | renderNav: function (h) { 159 | const children = this.$slots.default 160 | const { 161 | lastIndex 162 | } = this 163 | 164 | const nav = children.map((slide, i) => { 165 | const buttonClasses = i === lastIndex ? 'Slider-navButton Slider-navButton--active' : 'Slider-navButton' 166 | 167 | return ( 168 | 170 | ) 171 | }) 172 | 173 | return ( 174 |
175 | {nav} 176 |
177 | ) 178 | } 179 | }, 180 | render(h) { 181 | const children = this.$slots.default 182 | 183 | const { 184 | showArrows, 185 | showNav 186 | } = this.$props 187 | 188 | const { 189 | index, 190 | transition, 191 | mouseDown 192 | } = this 193 | 194 | const slidesStyles = { 195 | width: `${100 * children.length}%`, 196 | transform: `translateX(${-1 * index * (100 / children.length)}%)`, 197 | } 198 | const slidesClasses = transition ? 'Slider-slides Slider-slides--transition' : 'Slider-slides' 199 | 200 | return ( 201 |
202 | {showArrows ? this.renderArrows(h) : null} 203 | {showNav ? this.renderNav(h) : null} 204 |
this.handleDragStart(e, true)} 207 | onTouchmove={(e) => this.handleDragMove(e, true)} 208 | onTouchend={() => this.handleDragEnd()} 209 | onMousedown={(e) => this.handleDragStart(e, false)} 210 | onMousemove={(e) => mouseDown ? this.handleDragMove(e, false) : null} 211 | onMouseup={(e) => this.handleDragEnd()} 212 | onMouseout={(e) => this.handleDragEnd()}> 213 |
214 | {children} 215 |
216 |
217 |
218 | ) 219 | } 220 | } 221 | -------------------------------------------------------------------------------- /dist/Slider.css: -------------------------------------------------------------------------------- 1 | .Slider{overflow:hidden;position:relative;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.Slider,.Slider-slides{display:-webkit-flex;display:-ms-flexbox;display:flex}.Slider-slides--transition{transition:-webkit-transform .25s;transition:transform .25s;transition:transform .25s,-webkit-transform .25s}.Slider-slides>*{-ms-flex-preferred-size:0;-webkit-flex-basis:0;flex-basis:0;-webkit-flex-grow:1;-ms-flex-positive:1;flex-grow:1}.Slider-nav{-ms-flex-line-pack:center;-webkit-align-content:center;align-content:center;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;margin-top:10px;-webkit-order:2;-ms-flex-order:2;order:2}.Slider-navButton{background:none;border:0;height:20px;opacity:.5;outline:none;position:relative;transition:opacity .25s;width:20px;padding:0}.Slider-navButton:after{background:#345;border-radius:50%;content:"";display:block;height:6px;left:7px;position:absolute;top:7px;width:6px}.Slider-navButton--active{opacity:1}.Slider-navButton--active:after{height:12px;left:4px;opacity:1;top:4px;width:12px}.Slider-arrows{height:0;left:0;position:absolute;top:calc(50% - 35px);width:100%;z-index:1}.Slider-arrows--noNav{top:calc(50% - 20px)}.Slider-arrow{background:none;border:none;height:40px;opacity:.5;outline:none;position:absolute;transition:opacity .25s;padding:0;width:21px}.Slider-arrow:hover{opacity:1}.Slider-arrow:after,.Slider-arrow:before{background:#fff;border-radius:3px;content:"";display:block;height:23px;position:absolute;width:5px;left:8px}.Slider-arrow:before{top:0}.Slider-arrow:after{bottom:0}.Slider-arrow--left{top:0;left:10px}.Slider-arrow--left:before{-webkit-transform:rotate(30deg);-ms-transform:rotate(30deg);transform:rotate(30deg)}.Slider-arrow--left:after{-webkit-transform:rotate(-30deg);-ms-transform:rotate(-30deg);transform:rotate(-30deg)}.Slider-arrow--right{top:0;right:10px}.Slider-arrow--right:before{-webkit-transform:rotate(-30deg);-ms-transform:rotate(-30deg);transform:rotate(-30deg)}.Slider-arrow--right:after{-webkit-transform:rotate(30deg);-ms-transform:rotate(30deg);transform:rotate(30deg)} 2 | /*# sourceMappingURL=Slider.css.map*/ -------------------------------------------------------------------------------- /dist/Slider.css.map: -------------------------------------------------------------------------------- 1 | {"version":3,"sources":["webpack:///./Slider.css"],"names":[],"mappings":"AAAA,QACE,gBACA,kBAOA,8BACA,0BACA,qBAAuB,CAGzB,uBAVE,qBACA,oBACA,YAAc,CAehB,2BAEE,kCACA,0BACA,gDAAqD,CAavD,iBAEE,0BACA,qBAAc,aAEd,oBACA,oBACA,WAAa,CAGf,YAEE,0BACA,6BAAsB,qBAEtB,qBACA,oBACA,aAEA,+BACA,qBACA,uBACA,gBAEA,gBACA,iBACA,OAAS,CAGX,kBACE,gBACA,SACA,YACA,WACA,aACA,kBAEA,wBACA,WACA,SAAW,CAGb,wBACE,gBACA,kBACA,WACA,cACA,WACA,SACA,kBACA,QACA,SAAW,CAGb,0BACE,SAAW,CAGb,gCACE,YACA,SACA,UACA,QACA,UAAY,CAGd,eACE,SACA,OACA,kBACA,qBACA,WACA,SAAW,CAGb,sBACE,oBAAsB,CAGxB,cACE,gBACA,YACA,YACA,WACA,aACA,kBAEA,wBACA,UACA,UAAY,CAGd,oBACE,SAAW,CAGb,yCAEE,gBACA,kBACA,WACA,cACA,YACA,kBACA,UACA,QAAU,CAGZ,qBACE,KAAO,CAGT,oBACE,QAAU,CAGZ,oBACE,MACA,SAAW,CAGb,2BACE,gCACA,4BAAyB,wBAG3B,0BACE,iCACA,6BAA0B,yBAG5B,qBACE,MACA,UAAY,CAGd,4BACE,iCACA,6BAA0B,yBAG5B,2BACE,gCACA,4BAAyB","file":"Slider.css","sourcesContent":[".Slider {\n overflow: hidden;\n position: relative;\n display: -webkit-box;\n display: -webkit-flex;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-orient: vertical;\n -webkit-box-direction: normal;\n -webkit-flex-direction: column;\n -ms-flex-direction: column;\n flex-direction: column;\n}\n\n.Slider-slides {\n display: -webkit-box;\n display: -webkit-flex;\n display: -ms-flexbox;\n display: flex;\n}\n\n.Slider-slides--transition {\n -webkit-transition: -webkit-transform 0.25s;\n transition: -webkit-transform 0.25s;\n transition: transform 0.25s;\n transition: transform 0.25s, -webkit-transform 0.25s;\n}\n\n.Slider-slides>* {\n -webkit-flex-basis: 0;\n -ms-flex-preferred-size: 0;\n flex-basis: 0;\n -webkit-box-flex: 1;\n -webkit-flex-grow: 1;\n -ms-flex-positive: 1;\n flex-grow: 1;\n}\n\n.Slider-slides>* {\n -webkit-flex-basis: 0;\n -ms-flex-preferred-size: 0;\n flex-basis: 0;\n -webkit-box-flex: 1;\n -webkit-flex-grow: 1;\n -ms-flex-positive: 1;\n flex-grow: 1;\n}\n\n.Slider-nav {\n -webkit-align-content: center;\n -ms-flex-line-pack: center;\n align-content: center;\n display: -webkit-box;\n display: -webkit-flex;\n display: -ms-flexbox;\n display: flex;\n -webkit-box-pack: center;\n -webkit-justify-content: center;\n -ms-flex-pack: center;\n justify-content: center;\n margin-top: 10px;\n -webkit-box-ordinal-group: 3;\n -webkit-order: 2;\n -ms-flex-order: 2;\n order: 2;\n}\n\n.Slider-navButton {\n background: none;\n border: 0;\n height: 20px;\n opacity: 0.5;\n outline: none;\n position: relative;\n -webkit-transition: opacity 0.25s;\n transition: opacity 0.25s;\n width: 20px;\n padding: 0;\n}\n\n.Slider-navButton::after {\n background: #345;\n border-radius: 50%;\n content: '';\n display: block;\n height: 6px;\n left: 7px;\n position: absolute;\n top: 7px;\n width: 6px;\n}\n\n.Slider-navButton--active {\n opacity: 1;\n}\n\n.Slider-navButton--active::after {\n height: 12px;\n left: 4px;\n opacity: 1;\n top: 4px;\n width: 12px;\n}\n\n.Slider-arrows {\n height: 0;\n left: 0;\n position: absolute;\n top: calc(50% - 35px);\n width: 100%;\n z-index: 1;\n}\n\n.Slider-arrows--noNav {\n top: calc(50% - 20px);\n}\n\n.Slider-arrow {\n background: none;\n border: none;\n height: 40px;\n opacity: 0.5;\n outline: none;\n position: absolute;\n -webkit-transition: opacity 0.25s;\n transition: opacity 0.25s;\n padding: 0px;\n width: 21px;\n}\n\n.Slider-arrow:hover {\n opacity: 1;\n}\n\n.Slider-arrow::after,\n.Slider-arrow::before {\n background: #fff;\n border-radius: 3px;\n content: '';\n display: block;\n height: 23px;\n position: absolute;\n width: 5px;\n left: 8px;\n}\n\n.Slider-arrow::before {\n top: 0;\n}\n\n.Slider-arrow::after {\n bottom: 0;\n}\n\n.Slider-arrow--left {\n top: 0;\n left: 10px;\n}\n\n.Slider-arrow--left::before {\n -webkit-transform: rotate(30deg);\n transform: rotate(30deg);\n}\n\n.Slider-arrow--left::after {\n -webkit-transform: rotate(-30deg);\n transform: rotate(-30deg);\n}\n\n.Slider-arrow--right {\n top: 0;\n right: 10px;\n}\n\n.Slider-arrow--right::before {\n -webkit-transform: rotate(-30deg);\n transform: rotate(-30deg);\n}\n\n.Slider-arrow--right::after {\n -webkit-transform: rotate(30deg);\n transform: rotate(30deg);\n}\n\n\n// WEBPACK FOOTER //\n// ./Slider.css"],"sourceRoot":""} -------------------------------------------------------------------------------- /dist/Slider.js: -------------------------------------------------------------------------------- 1 | (function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define([],e):"object"==typeof exports?exports.Slider=e():t.Slider=e()})(this,function(){return function(t){function e(r){if(n[r])return n[r].exports;var o=n[r]={i:r,l:!1,exports:{}};return t[r].call(o.exports,o,o.exports,e),o.l=!0,o.exports}var n={};return e.m=t,e.c=n,e.i=function(t){return t},e.d=function(t,n,r){e.o(t,n)||Object.defineProperty(t,n,{configurable:!1,enumerable:!0,get:r})},e.n=function(t){var n=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(n,"a",n),n},e.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},e.p="/",e(e.s=2)}([function(t,e,n){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var r=n(1);n.n(r);e.default={props:{loop:{type:Boolean,default:!1},selected:{type:Number,default:0},showArrows:{type:Boolean,default:!0},showNav:{type:Boolean,default:!0}},data:function(){return{dragStart:0,dragStartTime:new Date,transition:!1,index:this.$props.selected||0,lastIndex:this.$props.selected||0,mouseDown:!1}},methods:{goToSlide:function(t,e){var n=this.$slots.default,r=this.$props.loop;e&&(e.preventDefault(),e.stopPropagation()),t<0?t=r?n.length-1:0:t>=n.length&&(t=r?0:n.length-1),this.index=t,this.lastIndex=t,this.transition=!0},getDragX:function(t,e){return e?t.touches[0].pageX:t.pageX},handleDragStart:function(t,e){var n=this.getDragX(t,e);this.dragStart=n,this.dragStartTime=new Date,this.transition=!1,this.slideWidth=this.$refs.slider.offsetWidth,this.mouseDown=!0},handleDragMove:function(t,e){var n=this.dragStart,r=this.lastIndex,o=this.slideWidth,i=this.getDragX(t,e),s=n-i,a=s/o,l=r+a;Math.abs(s)>30&&t.stopPropagation(),this.index=l},handleDragEnd:function(){var t=this.$slots.default,e=this.dragStartTime,n=this.index,r=this.lastIndex,o=(new Date).getTime()-e.getTime(),i=r-n,s=Math.round(i/o*1e4),a=Math.round(n);Math.abs(s)>5&&(a=s<0?r+1:r-1),a<0?a=0:a>=t.length&&(a=t.length-1),this.dragStart=0,this.index=a,this.lastIndex=a,this.transition=!0,this.mouseDown=!1},renderArrows:function(t){var e=this,n=this.$slots.default,r=this.$props,o=r.loop,i=r.showNav,s=this.lastIndex,a=i?"Slider-arrows":"Slider-arrows Slider-arrows--noNav",l=t("button",{class:"Slider-arrow Slider-arrow--left",on:{click:function(t){return e.goToSlide(s-1,t)}}}),d=t("button",{class:"Slider-arrow Slider-arrow--right",on:{click:function(t){return e.goToSlide(s+1,t)}}});return t("div",{class:a},[o||s>0?l:null,o||s= children.length) {\n index = loop ? 0 : children.length - 1;\n }\n\n this.index = index;\n this.lastIndex = index;\n this.transition = true;\n },\n getDragX: function getDragX(event, isTouch) {\n return isTouch ? event.touches[0].pageX : event.pageX;\n },\n handleDragStart: function handleDragStart(event, isTouch) {\n var x = this.getDragX(event, isTouch);\n\n this.dragStart = x;\n this.dragStartTime = new Date();\n this.transition = false;\n this.slideWidth = this.$refs.slider.offsetWidth;\n this.mouseDown = true;\n },\n\n handleDragMove: function handleDragMove(event, isTouch) {\n var dragStart = this.dragStart,\n lastIndex = this.lastIndex,\n slideWidth = this.slideWidth;\n\n\n var x = this.getDragX(event, isTouch);\n var offset = dragStart - x;\n var percentageOffset = offset / slideWidth;\n var newIndex = lastIndex + percentageOffset;\n var SCROLL_OFFSET_TO_STOP_SCROLL = 30;\n\n // Stop scrolling if you slide more than 30 pixels\n if (Math.abs(offset) > SCROLL_OFFSET_TO_STOP_SCROLL) {\n event.stopPropagation();\n }\n\n this.index = newIndex;\n },\n handleDragEnd: function handleDragEnd() {\n var children = this.$slots.default;\n var dragStartTime = this.dragStartTime,\n index = this.index,\n lastIndex = this.lastIndex;\n\n\n var timeElapsed = new Date().getTime() - dragStartTime.getTime();\n var offset = lastIndex - index;\n var velocity = Math.round(offset / timeElapsed * 10000);\n\n var newIndex = Math.round(index);\n\n if (Math.abs(velocity) > 5) {\n newIndex = velocity < 0 ? lastIndex + 1 : lastIndex - 1;\n }\n\n if (newIndex < 0) {\n newIndex = 0;\n } else if (newIndex >= children.length) {\n newIndex = children.length - 1;\n }\n\n this.dragStart = 0;\n this.index = newIndex;\n this.lastIndex = newIndex;\n this.transition = true;\n this.mouseDown = false;\n },\n renderArrows: function renderArrows(h) {\n var _this = this;\n\n var children = this.$slots.default;\n\n var _$props = this.$props,\n loop = _$props.loop,\n showNav = _$props.showNav;\n var lastIndex = this.lastIndex;\n\n\n var arrowsClasses = showNav ? 'Slider-arrows' : 'Slider-arrows Slider-arrows--noNav';\n\n var leftArrowEl = h('button', {\n class: 'Slider-arrow Slider-arrow--left',\n on: {\n click: function click(e) {\n return _this.goToSlide(lastIndex - 1, e);\n }\n }\n });\n\n var rightArrowEl = h('button', {\n class: 'Slider-arrow Slider-arrow--right',\n on: {\n click: function click(e) {\n return _this.goToSlide(lastIndex + 1, e);\n }\n }\n });\n\n return h(\n 'div',\n { 'class': arrowsClasses },\n [loop || lastIndex > 0 ? leftArrowEl : null, loop || lastIndex < children.length - 1 ? rightArrowEl : null]\n );\n },\n renderNav: function renderNav(h) {\n var _this2 = this;\n\n var children = this.$slots.default;\n var lastIndex = this.lastIndex;\n\n\n var nav = children.map(function (slide, i) {\n var buttonClasses = i === lastIndex ? 'Slider-navButton Slider-navButton--active' : 'Slider-navButton';\n\n return h(\n 'button',\n { 'class': buttonClasses, key: i, on: {\n 'click': function click(e) {\n return _this2.goToSlide(i, e);\n }\n }\n },\n []\n );\n });\n\n return h(\n 'div',\n { 'class': 'Slider-nav' },\n [nav]\n );\n }\n },\n render: function render(h) {\n var _this3 = this;\n\n var children = this.$slots.default;\n\n var _$props2 = this.$props,\n showArrows = _$props2.showArrows,\n showNav = _$props2.showNav;\n var index = this.index,\n transition = this.transition,\n mouseDown = this.mouseDown;\n\n\n var slidesStyles = {\n width: 100 * children.length + '%',\n transform: 'translateX(' + -1 * index * (100 / children.length) + '%)'\n };\n var slidesClasses = transition ? 'Slider-slides Slider-slides--transition' : 'Slider-slides';\n\n return h(\n 'div',\n { 'class': 'Slider', ref: 'slider' },\n [showArrows ? this.renderArrows(h) : null, showNav ? this.renderNav(h) : null, h(\n 'div',\n {\n 'class': 'Slider-inner',\n on: {\n 'touchstart': function touchstart(e) {\n return _this3.handleDragStart(e, true);\n },\n 'touchmove': function touchmove(e) {\n return _this3.handleDragMove(e, true);\n },\n 'touchend': function touchend() {\n return _this3.handleDragEnd();\n },\n 'mousedown': function mousedown(e) {\n return _this3.handleDragStart(e, false);\n },\n 'mousemove': function mousemove(e) {\n return mouseDown ? _this3.handleDragMove(e, false) : null;\n },\n 'mouseup': function mouseup(e) {\n return _this3.handleDragEnd();\n },\n 'mouseout': function mouseout(e) {\n return _this3.handleDragEnd();\n }\n }\n },\n [h(\n 'div',\n { 'class': slidesClasses, style: slidesStyles },\n [children]\n )]\n )]\n );\n }\n});\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["Slider.js"],"names":["props","loop","type","Boolean","default","selected","Number","showArrows","showNav","data","dragStart","dragStartTime","Date","transition","index","$props","lastIndex","mouseDown","methods","goToSlide","event","children","$slots","preventDefault","stopPropagation","length","getDragX","isTouch","touches","pageX","handleDragStart","x","slideWidth","$refs","slider","offsetWidth","handleDragMove","offset","percentageOffset","newIndex","SCROLL_OFFSET_TO_STOP_SCROLL","Math","abs","handleDragEnd","timeElapsed","getTime","velocity","round","renderArrows","h","arrowsClasses","leftArrowEl","class","on","click","e","rightArrowEl","renderNav","nav","map","slide","i","buttonClasses","render","slidesStyles","width","transform","slidesClasses"],"mappings":"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","file":"Slider.js","sourceRoot":"/Users/piyushchauhan/Documents/jirnexu/vue-simple-slider","sourcesContent":["import './Slider.css'\n\nexport default {\n  props: {\n    loop: {\n      type: Boolean,\n      default: false\n    },\n    selected: {\n      type: Number,\n      default: 0\n    },\n    showArrows: {\n      type: Boolean,\n      default: true\n    },\n    showNav: {\n      type: Boolean,\n      default: true\n    }\n  },\n  data: function () {\n    return {\n      dragStart: 0,\n      dragStartTime: new Date(),\n      transition: false,\n      index: this.$props.selected || 0,\n      lastIndex: this.$props.selected || 0,\n      mouseDown: false\n    }\n  },\n  methods: {\n    goToSlide: function (index, event) {\n      const children = this.$slots.default\n      const {\n        loop,\n      } = this.$props\n\n      if (event) {\n        event.preventDefault()\n        event.stopPropagation()\n      }\n\n      if (index < 0) {\n        index = loop ? children.length - 1 : 0\n      } else if (index >= children.length) {\n        index = loop ? 0 : children.length - 1\n      }\n\n      this.index = index\n      this.lastIndex = index\n      this.transition = true\n    },\n    getDragX: function (event, isTouch) {\n      return isTouch ?\n        event.touches[0].pageX :\n        event.pageX\n    },\n    handleDragStart: function (event, isTouch) {\n      const x = this.getDragX(event, isTouch)\n\n      this.dragStart = x\n      this.dragStartTime = new Date()\n      this.transition = false\n      this.slideWidth = this.$refs.slider.offsetWidth\n      this.mouseDown = true\n    },\n\n    handleDragMove: function (event, isTouch) {\n      const {\n        dragStart,\n        lastIndex,\n        slideWidth\n      } = this\n\n      const x = this.getDragX(event, isTouch)\n      const offset = dragStart - x\n      const percentageOffset = offset / slideWidth\n      const newIndex = lastIndex + percentageOffset\n      const SCROLL_OFFSET_TO_STOP_SCROLL = 30\n\n      // Stop scrolling if you slide more than 30 pixels\n      if (Math.abs(offset) > SCROLL_OFFSET_TO_STOP_SCROLL) {\n        event.stopPropagation()\n      }\n\n      this.index = newIndex\n    },\n    handleDragEnd: function () {\n      const children = this.$slots.default\n      const {\n        dragStartTime,\n        index,\n        lastIndex\n      } = this\n\n      const timeElapsed = new Date().getTime() - dragStartTime.getTime()\n      const offset = lastIndex - index\n      const velocity = Math.round(offset / timeElapsed * 10000)\n\n      let newIndex = Math.round(index)\n\n      if (Math.abs(velocity) > 5) {\n        newIndex = velocity < 0 ? lastIndex + 1 : lastIndex - 1\n      }\n\n      if (newIndex < 0) {\n        newIndex = 0\n      } else if (newIndex >= children.length) {\n        newIndex = children.length - 1\n      }\n\n      this.dragStart = 0\n      this.index = newIndex\n      this.lastIndex = newIndex\n      this.transition = true\n      this.mouseDown = false\n    },\n    renderArrows: function (h) {\n      const children = this.$slots.default\n\n      const {\n        loop,\n        showNav,\n      } = this.$props\n\n      const {\n        lastIndex\n      } = this\n\n      const arrowsClasses = showNav ? 'Slider-arrows' : 'Slider-arrows Slider-arrows--noNav'\n\n      const leftArrowEl = h(\n        'button', {\n          class: 'Slider-arrow Slider-arrow--left',\n          on: {\n            click: (e) => this.goToSlide(lastIndex - 1, e)\n          }\n        }\n      )\n\n      const rightArrowEl = h(\n        'button', {\n          class: 'Slider-arrow Slider-arrow--right',\n          on: {\n            click: (e) => this.goToSlide(lastIndex + 1, e)\n          }\n        }\n      )\n\n      return (\n        <div class={arrowsClasses}>\n          {loop || lastIndex > 0 ? leftArrowEl : null}\n          {loop || lastIndex < children.length - 1 ? rightArrowEl : null}\n        </div>\n      )\n    },\n    renderNav: function (h) {\n      const children = this.$slots.default\n      const {\n        lastIndex\n      } = this\n\n      const nav = children.map((slide, i) => {\n        const buttonClasses = i === lastIndex ? 'Slider-navButton Slider-navButton--active' : 'Slider-navButton'\n\n        return (\n          <button class={buttonClasses} key={i} onClick={(e) => this.goToSlide(i, e)}>\n          </button>\n        )\n      })\n\n      return (\n        <div class='Slider-nav'>\n          {nav}\n        </div>\n      )\n    }\n  },\n  render(h) {\n    const children = this.$slots.default\n\n    const {\n      showArrows,\n      showNav\n    } = this.$props\n\n    const {\n      index,\n      transition,\n      mouseDown\n    } = this\n\n    const slidesStyles = {\n      width: `${100 * children.length}%`,\n      transform: `translateX(${-1 * index * (100 / children.length)}%)`,\n    }\n    const slidesClasses = transition ? 'Slider-slides Slider-slides--transition' : 'Slider-slides'\n\n    return (\n      <div class=\"Slider\" ref=\"slider\">\n        {showArrows ? this.renderArrows(h) : null}\n        {showNav ? this.renderNav(h) : null}\n        <div\n          class=\"Slider-inner\"\n          onTouchstart={(e) => this.handleDragStart(e, true)}\n          onTouchmove={(e) => this.handleDragMove(e, true)}\n          onTouchend={() => this.handleDragEnd()}\n          onMousedown={(e) => this.handleDragStart(e, false)}\n          onMousemove={(e) => mouseDown ? this.handleDragMove(e, false) : null}\n          onMouseup={(e) => this.handleDragEnd()}\n          onMouseout={(e) => this.handleDragEnd()}>\n          <div class={slidesClasses} style={slidesStyles}>\n            {children}\n          </div>\n        </div>\n      </div>\n    )\n  }\n}\n"]}\n\n/***/ }),\n/* 1 */\n/***/ (function(module, exports) {\n\n// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 2 */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(0);\n\n\n/***/ })\n/******/ ]);\n});\n\n\n// WEBPACK FOOTER //\n// Slider.js"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// identity function for calling harmony imports with the correct context\n \t__webpack_require__.i = function(value) { return value; };\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"/\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 2);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap ad98e8e54ea921a7a660","import './Slider.css'\n\nexport default {\n props: {\n loop: {\n type: Boolean,\n default: false\n },\n selected: {\n type: Number,\n default: 0\n },\n showArrows: {\n type: Boolean,\n default: true\n },\n showNav: {\n type: Boolean,\n default: true\n }\n },\n data: function () {\n return {\n dragStart: 0,\n dragStartTime: new Date(),\n transition: false,\n index: this.$props.selected || 0,\n lastIndex: this.$props.selected || 0,\n mouseDown: false\n }\n },\n methods: {\n goToSlide: function (index, event) {\n const children = this.$slots.default\n const {\n loop,\n } = this.$props\n\n if (event) {\n event.preventDefault()\n event.stopPropagation()\n }\n\n if (index < 0) {\n index = loop ? children.length - 1 : 0\n } else if (index >= children.length) {\n index = loop ? 0 : children.length - 1\n }\n\n this.index = index\n this.lastIndex = index\n this.transition = true\n },\n getDragX: function (event, isTouch) {\n return isTouch ?\n event.touches[0].pageX :\n event.pageX\n },\n handleDragStart: function (event, isTouch) {\n const x = this.getDragX(event, isTouch)\n\n this.dragStart = x\n this.dragStartTime = new Date()\n this.transition = false\n this.slideWidth = this.$refs.slider.offsetWidth\n this.mouseDown = true\n },\n\n handleDragMove: function (event, isTouch) {\n const {\n dragStart,\n lastIndex,\n slideWidth\n } = this\n\n const x = this.getDragX(event, isTouch)\n const offset = dragStart - x\n const percentageOffset = offset / slideWidth\n const newIndex = lastIndex + percentageOffset\n const SCROLL_OFFSET_TO_STOP_SCROLL = 30\n\n // Stop scrolling if you slide more than 30 pixels\n if (Math.abs(offset) > SCROLL_OFFSET_TO_STOP_SCROLL) {\n event.stopPropagation()\n }\n\n this.index = newIndex\n },\n handleDragEnd: function () {\n const children = this.$slots.default\n const {\n dragStartTime,\n index,\n lastIndex\n } = this\n\n const timeElapsed = new Date().getTime() - dragStartTime.getTime()\n const offset = lastIndex - index\n const velocity = Math.round(offset / timeElapsed * 10000)\n\n let newIndex = Math.round(index)\n\n if (Math.abs(velocity) > 5) {\n newIndex = velocity < 0 ? lastIndex + 1 : lastIndex - 1\n }\n\n if (newIndex < 0) {\n newIndex = 0\n } else if (newIndex >= children.length) {\n newIndex = children.length - 1\n }\n\n this.dragStart = 0\n this.index = newIndex\n this.lastIndex = newIndex\n this.transition = true\n this.mouseDown = false\n },\n renderArrows: function (h) {\n const children = this.$slots.default\n\n const {\n loop,\n showNav,\n } = this.$props\n\n const {\n lastIndex\n } = this\n\n const arrowsClasses = showNav ? 'Slider-arrows' : 'Slider-arrows Slider-arrows--noNav'\n\n const leftArrowEl = h(\n 'button', {\n class: 'Slider-arrow Slider-arrow--left',\n on: {\n click: (e) => this.goToSlide(lastIndex - 1, e)\n }\n }\n )\n\n const rightArrowEl = h(\n 'button', {\n class: 'Slider-arrow Slider-arrow--right',\n on: {\n click: (e) => this.goToSlide(lastIndex + 1, e)\n }\n }\n )\n\n return (\n
\n {loop || lastIndex > 0 ? leftArrowEl : null}\n {loop || lastIndex < children.length - 1 ? rightArrowEl : null}\n
\n )\n },\n renderNav: function (h) {\n const children = this.$slots.default\n const {\n lastIndex\n } = this\n\n const nav = children.map((slide, i) => {\n const buttonClasses = i === lastIndex ? 'Slider-navButton Slider-navButton--active' : 'Slider-navButton'\n\n return (\n \n )\n })\n\n return (\n
\n {nav}\n
\n )\n }\n },\n render(h) {\n const children = this.$slots.default\n\n const {\n showArrows,\n showNav\n } = this.$props\n\n const {\n index,\n transition,\n mouseDown\n } = this\n\n const slidesStyles = {\n width: `${100 * children.length}%`,\n transform: `translateX(${-1 * index * (100 / children.length)}%)`,\n }\n const slidesClasses = transition ? 'Slider-slides Slider-slides--transition' : 'Slider-slides'\n\n return (\n
\n {showArrows ? this.renderArrows(h) : null}\n {showNav ? this.renderNav(h) : null}\n this.handleDragStart(e, true)}\n onTouchmove={(e) => this.handleDragMove(e, true)}\n onTouchend={() => this.handleDragEnd()}\n onMousedown={(e) => this.handleDragStart(e, false)}\n onMousemove={(e) => mouseDown ? this.handleDragMove(e, false) : null}\n onMouseup={(e) => this.handleDragEnd()}\n onMouseout={(e) => this.handleDragEnd()}>\n
\n {children}\n
\n
\n \n )\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./Slider.js"],"sourceRoot":""} -------------------------------------------------------------------------------- /example/README.md: -------------------------------------------------------------------------------- 1 | # Vue Simple Slider Example 2 | 3 | > vue-simple-slider example 4 | 5 | ## Build Setup 6 | 7 | ``` bash 8 | # install dependencies 9 | npm i -g vue-cli 10 | npm install 11 | 12 | # serve with hot reload at localhost:4000 13 | npm start 14 | ``` -------------------------------------------------------------------------------- /example/example.js: -------------------------------------------------------------------------------- 1 | import 'node_modules/vue-simple-slider/dist/Slider.css' 2 | import Slider from 'vue-simple-slider' 3 | 4 | const style = { 5 | height: '250px', 6 | display: 'flex', 7 | justifyContent: 'center', 8 | alignItems: 'center', 9 | color: '#fafafa' 10 | } 11 | 12 | export default { 13 | components: { 14 | Slider 15 | }, 16 | render(h) { 17 | return ( 18 | 19 |
20 |

A

21 |
22 |
23 |

B

24 |
25 |
26 |

C

27 |
28 |
29 |

D

30 |
31 |
32 |

E

33 |
34 |
35 | ) 36 | } 37 | } 38 | -------------------------------------------------------------------------------- /example/index.vue: -------------------------------------------------------------------------------- 1 | 21 | 22 | 32 | 33 | 44 | -------------------------------------------------------------------------------- /example/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "example", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "dependencies": { 6 | "vue-simple-slider": { 7 | "version": "1.0.1", 8 | "resolved": "https://registry.npmjs.org/vue-simple-slider/-/vue-simple-slider-1.0.1.tgz", 9 | "integrity": "sha512-ZLh1qYSxTS76dVAXhrwOsrFtVAlIXX56pi/0YDeV3xS4Sr/GSjk2P29y4+MBboWyE/OdYoH4GA+NeS8sxB8CaQ==" 10 | } 11 | } 12 | } 13 | -------------------------------------------------------------------------------- /example/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "example", 3 | "version": "1.0.0", 4 | "license": "MIT", 5 | "scripts": { 6 | "start": "vue build index.vue" 7 | }, 8 | "dependencies": { 9 | "vue-simple-slider": "^1.0.2" 10 | } 11 | } 12 | -------------------------------------------------------------------------------- /example/yarn.lock: -------------------------------------------------------------------------------- 1 | # THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. 2 | # yarn lockfile v1 3 | 4 | 5 | vue-simple-slider@^1.0.1: 6 | version "1.0.1" 7 | resolved "https://registry.yarnpkg.com/vue-simple-slider/-/vue-simple-slider-1.0.1.tgz#2b493aacf4c010efd307a4364630da6e083c31dd" 8 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "vue-simple-slider", 3 | "version": "1.0.1", 4 | "lockfileVersion": 1 5 | } 6 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "vue-simple-slider", 3 | "description": "A simple, flexible slider for Vue.js", 4 | "version": "1.0.2", 5 | "author": "Piyush Chauhan ", 6 | "main": "dist/Slider.js", 7 | "license": "MIT", 8 | "private": false, 9 | "scripts": { 10 | "dev": "vue build App.vue", 11 | "build": "vue build Slider.js --prod --lib" 12 | }, 13 | "repository": { 14 | "type": "git", 15 | "url": "https://github.com/piyushchauhan2011/vue-simple-slider" 16 | }, 17 | "bugs": { 18 | "url": "https://github.com/piyushchauhan2011/vue-simple-slider/issues" 19 | }, 20 | "homepage": "https://github.com/piyushchauhan2011/vue-simple-slider", 21 | "keywords": [ 22 | "vue", 23 | "vuejs", 24 | "ui", 25 | "components", 26 | "slider", 27 | "carousel" 28 | ], 29 | "dependencies": {} 30 | } 31 | --------------------------------------------------------------------------------