12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- 'use strict';
-
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
-
- var _vue = require('vue');
-
- var _vue2 = _interopRequireDefault(_vue);
-
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
-
- exports.default = _vue2.default.extend({
- name: 'translatable',
- props: {
- height: Number
- },
- data: function data() {
- return {
- elOffsetTop: 0,
- parallax: 0,
- parallaxDist: 0,
- percentScrolled: 0,
- scrollTop: 0,
- windowHeight: 0,
- windowBottom: 0
- };
- },
- computed: {
- imgHeight: function imgHeight() {
- return this.objHeight();
- }
- },
- beforeDestroy: function beforeDestroy() {
- window.removeEventListener('scroll', this.translate, false);
- window.removeEventListener('resize', this.translate, false);
- },
-
- methods: {
- calcDimensions: function calcDimensions() {
- var offset = this.$el.getBoundingClientRect();
- this.scrollTop = window.pageYOffset;
- this.parallaxDist = this.imgHeight - this.height;
- this.elOffsetTop = offset.top + this.scrollTop;
- this.windowHeight = window.innerHeight;
- this.windowBottom = this.scrollTop + this.windowHeight;
- },
- listeners: function listeners() {
- window.addEventListener('scroll', this.translate, false);
- window.addEventListener('resize', this.translate, false);
- },
-
-
- objHeight: function objHeight() {
- throw new Error('Not implemented !');
- },
- translate: function translate() {
- this.calcDimensions();
- this.percentScrolled = (this.windowBottom - this.elOffsetTop) / (parseInt(this.height) + this.windowHeight);
- this.parallax = Math.round(this.parallaxDist * this.percentScrolled);
- }
- }
- });
|