123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- 'use strict';
- Object.defineProperty(exports, '__esModule', { value: true });
- var subscribable = require('./subscribable.js');
- var utils = require('./utils.js');
- class FocusManager extends subscribable.Subscribable {
- constructor() {
- super();
- this.setup = onFocus => {
- // addEventListener does not exist in React Native, but window does
- // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
- if (!utils.isServer && window.addEventListener) {
- const listener = () => onFocus(); // Listen to visibillitychange and focus
- window.addEventListener('visibilitychange', listener, false);
- window.addEventListener('focus', listener, false);
- return () => {
- // Be sure to unsubscribe if a new handler is set
- window.removeEventListener('visibilitychange', listener);
- window.removeEventListener('focus', listener);
- };
- }
- return;
- };
- }
- onSubscribe() {
- if (!this.cleanup) {
- this.setEventListener(this.setup);
- }
- }
- onUnsubscribe() {
- if (!this.hasListeners()) {
- var _this$cleanup;
- (_this$cleanup = this.cleanup) == null ? void 0 : _this$cleanup.call(this);
- this.cleanup = undefined;
- }
- }
- setEventListener(setup) {
- var _this$cleanup2;
- this.setup = setup;
- (_this$cleanup2 = this.cleanup) == null ? void 0 : _this$cleanup2.call(this);
- this.cleanup = setup(focused => {
- if (typeof focused === 'boolean') {
- this.setFocused(focused);
- } else {
- this.onFocus();
- }
- });
- }
- setFocused(focused) {
- const changed = this.focused !== focused;
- if (changed) {
- this.focused = focused;
- this.onFocus();
- }
- }
- onFocus() {
- this.listeners.forEach(({
- listener
- }) => {
- listener();
- });
- }
- isFocused() {
- if (typeof this.focused === 'boolean') {
- return this.focused;
- } // document global can be unavailable in react native
- if (typeof document === 'undefined') {
- return true;
- }
- return [undefined, 'visible', 'prerender'].includes(document.visibilityState);
- }
- }
- const focusManager = new FocusManager();
- exports.FocusManager = FocusManager;
- exports.focusManager = focusManager;
- //# sourceMappingURL=focusManager.js.map
|