create-expo-cljs-app
Version:
Create a react native application with Expo and Shadow-CLJS!
101 lines (88 loc) • 2.42 kB
JavaScript
/**
* Copyright (c) Nicolas Gallagher.
* Copyright (c) Facebook, Inc. and its affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*
*
*/
import { canUseDOM } from 'fbjs/lib/ExecutionEnvironment';
import invariant from 'fbjs/lib/invariant';
var dimensions = {
window: {
fontScale: 1,
height: 0,
scale: 1,
width: 0
},
screen: {
fontScale: 1,
height: 0,
scale: 1,
width: 0
}
};
var listeners = {};
var Dimensions = /*#__PURE__*/function () {
function Dimensions() {}
Dimensions.get = function get(dimension) {
invariant(dimensions[dimension], "No dimension set for key " + dimension);
return dimensions[dimension];
};
Dimensions.set = function set(initialDimensions) {
if (initialDimensions) {
if (canUseDOM) {
invariant(false, 'Dimensions cannot be set in the browser');
} else {
if (initialDimensions.screen != null) {
dimensions.screen = initialDimensions.screen;
}
if (initialDimensions.window != null) {
dimensions.window = initialDimensions.window;
}
}
}
};
Dimensions._update = function _update() {
if (!canUseDOM) {
return;
}
var win = window;
var docEl = win.document.documentElement;
dimensions.window = {
fontScale: 1,
height: docEl.clientHeight,
scale: win.devicePixelRatio || 1,
width: docEl.clientWidth
};
dimensions.screen = {
fontScale: 1,
height: win.screen.height,
scale: win.devicePixelRatio || 1,
width: win.screen.width
};
if (Array.isArray(listeners['change'])) {
listeners['change'].forEach(function (handler) {
return handler(dimensions);
});
}
};
Dimensions.addEventListener = function addEventListener(type, handler) {
listeners[type] = listeners[type] || [];
listeners[type].push(handler);
};
Dimensions.removeEventListener = function removeEventListener(type, handler) {
if (Array.isArray(listeners[type])) {
listeners[type] = listeners[type].filter(function (_handler) {
return _handler !== handler;
});
}
};
return Dimensions;
}();
export { Dimensions as default };
if (canUseDOM) {
Dimensions._update();
window.addEventListener('resize', Dimensions._update, false);
}