/** * Copyright (c) 2015-present, Facebook, Inc. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. * * @format * @flow */ 'use strict'; const React = require('react'); const ReactNative = require('react-native'); const {Dimensions, Text, View} = ReactNative; class DimensionsSubscription extends React.Component< {dim: string}, {dims: Object}, > { state = { dims: Dimensions.get(this.props.dim), }; componentDidMount() { Dimensions.addEventListener('change', this._handleDimensionsChange); } componentWillUnmount() { Dimensions.removeEventListener('change', this._handleDimensionsChange); } _handleDimensionsChange = dimensions => { this.setState({ dims: dimensions[this.props.dim], }); }; render() { return ( {JSON.stringify(this.state.dims)} ); } } exports.title = 'Dimensions'; exports.description = 'Dimensions of the viewport'; exports.examples = [ { title: 'window', render(): React.Element { return ; }, }, { title: 'screen', render(): React.Element { return ; }, }, ];