[DE mobile] Correct navigation view

This commit is contained in:
SergeyEzhin 2022-02-01 19:36:32 +04:00
parent 27343ca36a
commit 63db8da5d4
2 changed files with 94 additions and 95 deletions

View file

@ -1,11 +1,13 @@
import React, { Component } from "react"; import React, { Component } from "react";
import Navigation from "../../view/settings/Navigation"; import NavigationView from "../../view/settings/Navigation";
import { Device } from '../../../../../common/mobile/utils/device'; import { Device } from '../../../../../common/mobile/utils/device';
import { f7, Sheet } from 'framework7-react'; import { f7, Sheet } from 'framework7-react';
import { withTranslation } from 'react-i18next';
class NavigationController extends Component { class NavigationController extends Component {
constructor(props) { constructor(props) {
super(props); super(props);
this.updateNavigation = this.updateNavigation.bind(this);
} }
closeModal() { closeModal() {
@ -16,6 +18,51 @@ class NavigationController extends Component {
} }
} }
updateNavigation() {
const api = Common.EditorApi.get();
const navigationObject = api.asc_ShowDocumentOutline();
if (!navigationObject) return;
const count = navigationObject.get_ElementsCount();
const { t } = this.props;
let arrHeaders = [],
prevLevel = -1,
headerLevel = -1,
firstHeader = !navigationObject.isFirstItemNotHeader();
for (let i = 0; i < count; i++) {
let level = navigationObject.get_Level(i),
hasParent = true;
if (level > prevLevel && i > 0)
arrHeaders[i - 1]['hasSubItems'] = true;
if (headerLevel < 0 || level <= headerLevel) {
if (i > 0 || firstHeader)
headerLevel = level;
hasParent = false;
}
arrHeaders.push({
name: navigationObject.get_Text(i),
level: level,
index: i,
hasParent: hasParent,
isEmptyItem: navigationObject.isEmptyItem(i)
});
prevLevel = level;
}
if (count > 0 && !firstHeader) {
arrHeaders[0]['hasSubItems'] = false;
arrHeaders[0]['isNotHeader'] = true;
arrHeaders[0]['name'] = t('Settings.textBeginningDocument');
}
return arrHeaders;
}
onSelectItem(index) { onSelectItem(index) {
const api = Common.EditorApi.get(); const api = Common.EditorApi.get();
const navigationObject = api.asc_ShowDocumentOutline(); const navigationObject = api.asc_ShowDocumentOutline();
@ -27,9 +74,13 @@ class NavigationController extends Component {
render() { render() {
return ( return (
<Navigation onSelectItem={this.onSelectItem} /> <NavigationView
onSelectItem={this.onSelectItem}
updateNavigation={this.updateNavigation}
closeModal={this.closeModal}
/>
); );
} }
} }
export default NavigationController export default withTranslation()(NavigationController);

View file

@ -1,4 +1,4 @@
import React, { useState, useEffect } from "react"; import React, { useState, useEffect, Component } from "react";
import { Device } from '../../../../../common/mobile/utils/device'; import { Device } from '../../../../../common/mobile/utils/device';
import {f7, View, List, ListItem, Icon, Row, Button, Page, Navbar, NavRight, Segmented, BlockTitle, Link, ListButton, Toggle, Actions, ActionsButton, ActionsGroup, Sheet} from 'framework7-react'; import {f7, View, List, ListItem, Icon, Row, Button, Page, Navbar, NavRight, Segmented, BlockTitle, Link, ListButton, Toggle, Actions, ActionsButton, ActionsGroup, Sheet} from 'framework7-react';
import { useTranslation } from 'react-i18next'; import { useTranslation } from 'react-i18next';
@ -9,52 +9,12 @@ const Navigation = props => {
const android = Device.android; const android = Device.android;
const api = Common.EditorApi.get(); const api = Common.EditorApi.get();
const navigationObject = api.asc_ShowDocumentOutline(); const navigationObject = api.asc_ShowDocumentOutline();
const count = navigationObject.get_ElementsCount();
const [currentPosition, setCurrentPosition] = useState(navigationObject.get_CurrentPosition()); const [currentPosition, setCurrentPosition] = useState(navigationObject.get_CurrentPosition());
const arrHeaders = []; const arrHeaders = props.updateNavigation();
const updateNavigation = () => {
if (!navigationObject) return;
let prevLevel = -1,
headerLevel = -1,
firstHeader = !navigationObject.isFirstItemNotHeader();
for (let i = 0; i < count; i++) {
let level = navigationObject.get_Level(i),
hasParent = true;
if (level > prevLevel && i > 0)
arrHeaders[i - 1]['hasSubItems'] = true;
if (headerLevel < 0 || level <= headerLevel) {
if (i > 0 || firstHeader)
headerLevel = level;
hasParent = false;
}
arrHeaders.push({
name: navigationObject.get_Text(i),
level: level,
index: i,
hasParent: hasParent,
isEmptyItem: navigationObject.isEmptyItem(i)
});
prevLevel = level;
}
if (count > 0 && !firstHeader) {
arrHeaders[0]['hasSubItems'] = false;
arrHeaders[0]['isNotHeader'] = true;
arrHeaders[0]['name'] = t('Settings.textBeginningDocument');
}
}
updateNavigation();
// console.log(navigationObject);
return ( return (
<Page> <Page>
<Navbar title={t('Settings.textNavigation')} backLink={_t.textBack} /> {!Device.phone && <Navbar title={t('Settings.textNavigation')} backLink={_t.textBack} />}
{!arrHeaders.length {!arrHeaders.length
? ?
<div className="empty-screens"> <div className="empty-screens">
@ -81,60 +41,48 @@ const Navigation = props => {
) )
} }
const NavigationSheet = () => { const NavigationSheetView = props => {
useEffect(() => { useEffect(() => {
f7.sheet.open('#view-navigation-sheet'); if(Device.phone) {
f7.sheet.open('#view-navigation-sheet', true);
}
return () => {}
}); });
const [stateHeight, setHeight] = useState('45%');
const [stateOpacity, setOpacity] = useState(1);
const [stateStartY, setStartY] = useState();
const [isNeedClose, setNeedClose] = useState(false);
const handleTouchStart = (event) => {
const touchObj = event.changedTouches[0];
setStartY(parseInt(touchObj.clientY));
};
const handleTouchMove = (event) => {
const touchObj = event.changedTouches[0];
const dist = parseInt(touchObj.clientY) - stateStartY;
if (dist < 0) { // to top
setHeight('90%');
setOpacity(1);
setNeedClose(false);
} else if (dist < 80) {
setHeight('45%');
setOpacity(1);
setNeedClose(false);
} else {
setNeedClose(true);
setOpacity(0.6);
}
};
const handleTouchEnd = (event) => {
const touchObj = event.changedTouches[0];
const swipeEnd = parseInt(touchObj.clientY);
const dist = swipeEnd - stateStartY;
if (isNeedClose) {
closeCurComments();
} else if (stateHeight === '90%' && dist > 20) {
setHeight('45%');
}
};
return ( return (
<Sheet id='view-navigation-sheet' style={{height: `${stateHeight}`, opacity: `${stateOpacity}`}}> <Sheet id="view-navigation-sheet" swipeToClose>
<div id='swipe-handler' className='swipe-container' onTouchStart={handleTouchStart} onTouchMove={handleTouchMove} onTouchEnd={handleTouchEnd}> {/* <div id='swipe-handler' className='swipe-container' onTouchStart={handleTouchStart} onTouchMove={handleTouchMove} onTouchEnd={handleTouchEnd}>
<Icon icon='icon-swipe' /> <Icon icon='icon-swipe' />
</div> </div> */}
<Navigation /> <Navigation
updateNavigation={props.updateNavigation}
onSelectItem={props.onSelectItem}
closeModal={props.closeModal}
/>
</Sheet> </Sheet>
) )
}; }
export default Navigation; const NavigationView = props => {
return (
!Device.phone
?
<Navigation
updateNavigation={props.updateNavigation}
onSelectItem={props.onSelectItem}
closeModal={props.closeModal}
/>
:
<NavigationSheetView
updateNavigation={props.updateNavigation}
onSelectItem={props.onSelectItem}
closeModal={props.closeModal}
/>
)
}
export default NavigationView;