summaryrefslogtreecommitdiff
path: root/LightBox.CloseButton.js
blob: 287ad0ef04abe21d82d1d8a9699bc741f337a375 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
var LightBox = LightBox || {}; LightBox["CloseButton"] =
/******/ (function(modules) { // webpackBootstrap
/******/ 	// The module cache
/******/ 	var installedModules = {};

/******/ 	// The require function
/******/ 	function __webpack_require__(moduleId) {

/******/ 		// Check if module is in cache
/******/ 		if(installedModules[moduleId])
/******/ 			return installedModules[moduleId].exports;

/******/ 		// Create a new module (and put it into the cache)
/******/ 		var module = installedModules[moduleId] = {
/******/ 			exports: {},
/******/ 			id: moduleId,
/******/ 			loaded: false
/******/ 		};

/******/ 		// Execute the module function
/******/ 		modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);

/******/ 		// Flag the module as loaded
/******/ 		module.loaded = true;

/******/ 		// Return the exports of the module
/******/ 		return module.exports;
/******/ 	}


/******/ 	// expose the modules object (__webpack_modules__)
/******/ 	__webpack_require__.m = modules;

/******/ 	// expose the module cache
/******/ 	__webpack_require__.c = installedModules;

/******/ 	// __webpack_public_path__
/******/ 	__webpack_require__.p = "";

/******/ 	// Load entry module and return exports
/******/ 	return __webpack_require__(0);
/******/ })
/************************************************************************/
/******/ ([
/* 0 */
/***/ function(module, exports) {

	'use strict';

	var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();

	Object.defineProperty(exports, "__esModule", {
	    value: true
	});

	function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }

	/**
	 * @author Victor Häggqvist
	 * @since 2016-01-14
	 */

	var CloseButton = function () {
	    function CloseButton() {
	        var closeOnDocumentClick = arguments.length <= 0 || arguments[0] === undefined ? false : arguments[0];

	        _classCallCheck(this, CloseButton);

	        this.closeOnDocumentClick = closeOnDocumentClick;
	        this.element = document.createElement('a');
	        this.element.id = 'imagelightbox-close';
	        this.element.innerHTML = 'Close';
	    }

	    _createClass(CloseButton, [{
	        key: 'register',
	        value: function register(lightbox) {
	            this.lightbox = lightbox;
	            lightbox.addOnStartListener(this.showButton.bind(this));
	            lightbox.addOnEndListener(this.hideButton.bind(this));
	        }
	    }, {
	        key: 'showButton',
	        value: function showButton() {
	            var _this = this;

	            this.lightbox.options.quitOnDocClick = this.closeOnDocumentClick;
	            ['click', 'touchend'].forEach(function (name) {
	                _this.element.addEventListener(name, _this.exitLightbox.bind(_this));
	            });

	            document.body.appendChild(this.element);
	        }
	    }, {
	        key: 'hideButton',
	        value: function hideButton() {
	            document.body.removeChild(this.element);
	        }
	    }, {
	        key: 'exitLightbox',
	        value: function exitLightbox() {
	            this.lightbox.quitLightbox();
	        }
	    }]);

	    return CloseButton;
	}();

	exports.default = CloseButton;
	module.exports = exports['default'];

/***/ }
/******/ ]);