screenfull.js 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. /*!
  2. * screenfull
  3. * v4.2.1 - 2019-07-27
  4. * (c) Sindre Sorhus; MIT License
  5. */
  6. (function () {
  7. 'use strict';
  8. var document = typeof window !== 'undefined' && typeof window.document !== 'undefined' ? window.document : {};
  9. var isCommonjs = typeof module !== 'undefined' && module.exports;
  10. var keyboardAllowed = typeof Element !== 'undefined' && 'ALLOW_KEYBOARD_INPUT' in Element;
  11. var fn = (function () {
  12. var val;
  13. var fnMap = [
  14. [
  15. 'requestFullscreen',
  16. 'exitFullscreen',
  17. 'fullscreenElement',
  18. 'fullscreenEnabled',
  19. 'fullscreenchange',
  20. 'fullscreenerror'
  21. ],
  22. // New WebKit
  23. [
  24. 'webkitRequestFullscreen',
  25. 'webkitExitFullscreen',
  26. 'webkitFullscreenElement',
  27. 'webkitFullscreenEnabled',
  28. 'webkitfullscreenchange',
  29. 'webkitfullscreenerror'
  30. ],
  31. // Old WebKit (Safari 5.1)
  32. [
  33. 'webkitRequestFullScreen',
  34. 'webkitCancelFullScreen',
  35. 'webkitCurrentFullScreenElement',
  36. 'webkitCancelFullScreen',
  37. 'webkitfullscreenchange',
  38. 'webkitfullscreenerror'
  39. ],
  40. [
  41. 'mozRequestFullScreen',
  42. 'mozCancelFullScreen',
  43. 'mozFullScreenElement',
  44. 'mozFullScreenEnabled',
  45. 'mozfullscreenchange',
  46. 'mozfullscreenerror'
  47. ],
  48. [
  49. 'msRequestFullscreen',
  50. 'msExitFullscreen',
  51. 'msFullscreenElement',
  52. 'msFullscreenEnabled',
  53. 'MSFullscreenChange',
  54. 'MSFullscreenError'
  55. ]
  56. ];
  57. var i = 0;
  58. var l = fnMap.length;
  59. var ret = {};
  60. for (; i < l; i++) {
  61. val = fnMap[i];
  62. if (val && val[1] in document) {
  63. for (i = 0; i < val.length; i++) {
  64. ret[fnMap[0][i]] = val[i];
  65. }
  66. return ret;
  67. }
  68. }
  69. return false;
  70. })();
  71. var eventNameMap = {
  72. change: fn.fullscreenchange,
  73. error: fn.fullscreenerror
  74. };
  75. var screenfull = {
  76. request: function (elem) {
  77. return new Promise(function (resolve, reject) {
  78. var request = fn.requestFullscreen;
  79. var onFullScreenEntered = function () {
  80. this.off('change', onFullScreenEntered);
  81. resolve();
  82. }.bind(this);
  83. this.on('change', onFullScreenEntered);
  84. elem = elem || document.documentElement;
  85. var promise;
  86. // Work around Safari 5.1 bug: reports support for
  87. // keyboard in fullscreen even though it doesn't.
  88. // Browser sniffing, since the alternative with
  89. // setTimeout is even worse.
  90. if (/ Version\/5\.1(?:\.\d+)? Safari\//.test(navigator.userAgent)) {
  91. promise = elem[request]();
  92. } else {
  93. promise = elem[request](keyboardAllowed ? Element.ALLOW_KEYBOARD_INPUT : {});
  94. }
  95. Promise.resolve(promise).catch(reject);
  96. }.bind(this));
  97. },
  98. exit: function () {
  99. return new Promise(function (resolve) {
  100. if (!this.isFullscreen) {
  101. resolve();
  102. return;
  103. }
  104. var onFullScreenExit = function () {
  105. this.off('change', onFullScreenExit);
  106. resolve();
  107. }.bind(this);
  108. document[fn.exitFullscreen]();
  109. this.on('change', onFullScreenExit);
  110. }.bind(this));
  111. },
  112. toggle: function (elem) {
  113. return this.isFullscreen ? this.exit() : this.request(elem);
  114. },
  115. onchange: function (callback) {
  116. this.on('change', callback);
  117. },
  118. onerror: function (callback) {
  119. this.on('error', callback);
  120. },
  121. on: function (event, callback) {
  122. var eventName = eventNameMap[event];
  123. if (eventName) {
  124. document.addEventListener(eventName, callback, false);
  125. }
  126. },
  127. off: function (event, callback) {
  128. var eventName = eventNameMap[event];
  129. if (eventName) {
  130. document.removeEventListener(eventName, callback, false);
  131. }
  132. },
  133. raw: fn
  134. };
  135. if (!fn) {
  136. if (isCommonjs) {
  137. module.exports = false;
  138. } else {
  139. window.screenfull = false;
  140. }
  141. return;
  142. }
  143. Object.defineProperties(screenfull, {
  144. isFullscreen: {
  145. get: function () {
  146. return Boolean(document[fn.fullscreenElement]);
  147. }
  148. },
  149. element: {
  150. enumerable: true,
  151. get: function () {
  152. return document[fn.fullscreenElement];
  153. }
  154. },
  155. enabled: {
  156. enumerable: true,
  157. get: function () {
  158. // Coerce to boolean in case of old WebKit
  159. return Boolean(document[fn.fullscreenEnabled]);
  160. }
  161. }
  162. });
  163. if (isCommonjs) {
  164. module.exports = screenfull;
  165. // TODO: remove this in the next major version
  166. module.exports.default = screenfull;
  167. } else {
  168. window.screenfull = screenfull;
  169. }
  170. })();