forked from Ivasoft/mattermost-mobile
* Update transform to make Android's post list scroll smooth * set start since metric when appStarted is false * Refactor Formatted components * Downgrade RNN to 7.13.0 & patch XCDYouTube to allow video playback * Refactor Post list and all related components * review suggestion rename hour12 to isMilitaryTime * feedback review use aliases * feedback review deconstruct actions in markdown_link * feedback review simplify if/else statement in combined_used_activity * Simplify if statement for consecutive posts * Specify npm version to build iOS on CI * Refactor network_indicator * render Icon in file gallery with transparent background * Increase timeout to scroll to bottom when posting a new message * fix: scroll when tapping on the new messages bar * fix: dismiss all modals * fix navigation tests * Handle dismissAllModals for iOS to prevent blank screens * Prevent modal from dismissing when showing the thread screen in the stack * Update app/components/image_viewport.tsx Co-authored-by: Miguel Alatzar <migbot@users.noreply.github.com> * Update app/utils/post.ts Co-authored-by: Miguel Alatzar <migbot@users.noreply.github.com> * Apply suggestions from code review Co-authored-by: Miguel Alatzar <migbot@users.noreply.github.com> * fix: rename selector and prop * Fix XCDYouTube patch * Fix posting from a thread in the right channel * do not render reply bar on the thread screen * close previous permalink before showing a new one * move XCDYouTube patch to ios/patches folder * closePermalink directly instead of using an onClose prop Co-authored-by: Miguel Alatzar <migbot@users.noreply.github.com> Co-authored-by: Miguel Alatzar <this.migbot@gmail.com>
61 lines
1.9 KiB
TypeScript
61 lines
1.9 KiB
TypeScript
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
import AsyncStorage from '@react-native-community/async-storage';
|
|
import {PureComponent} from 'react';
|
|
import {Dimensions} from 'react-native';
|
|
|
|
import {DeviceTypes} from '@constants';
|
|
import EventEmitter from '@mm-redux/utils/event_emitter';
|
|
|
|
import mattermostManaged from 'app/mattermost_managed';
|
|
|
|
// TODO: Use permanentSidebar and splitView hooks instead
|
|
export default class ImageViewPort extends PureComponent {
|
|
mounted = false;
|
|
state = {
|
|
isSplitView: false,
|
|
permanentSidebar: false,
|
|
};
|
|
|
|
componentDidMount() {
|
|
this.mounted = true;
|
|
this.handlePermanentSidebar();
|
|
this.handleDimensions();
|
|
EventEmitter.on(DeviceTypes.PERMANENT_SIDEBAR_SETTINGS, this.handlePermanentSidebar);
|
|
Dimensions.addEventListener('change', this.handleDimensions);
|
|
}
|
|
|
|
componentWillUnmount() {
|
|
this.mounted = false;
|
|
EventEmitter.off(DeviceTypes.PERMANENT_SIDEBAR_SETTINGS, this.handlePermanentSidebar);
|
|
Dimensions.removeEventListener('change', this.handleDimensions);
|
|
}
|
|
|
|
handleDimensions = () => {
|
|
if (this.mounted) {
|
|
if (DeviceTypes.IS_TABLET) {
|
|
mattermostManaged.isRunningInSplitView().then((result: any) => {
|
|
const isSplitView = Boolean(result.isSplitView);
|
|
this.setState({isSplitView});
|
|
});
|
|
}
|
|
}
|
|
};
|
|
|
|
handlePermanentSidebar = async () => {
|
|
if (DeviceTypes.IS_TABLET && this.mounted) {
|
|
const enabled = await AsyncStorage.getItem(DeviceTypes.PERMANENT_SIDEBAR_SETTINGS);
|
|
this.setState({permanentSidebar: enabled === 'true'});
|
|
}
|
|
};
|
|
|
|
hasPermanentSidebar = () => {
|
|
return DeviceTypes.IS_TABLET && !this.state.isSplitView && this.state.permanentSidebar;
|
|
};
|
|
|
|
render() {
|
|
return null;
|
|
}
|
|
}
|