Merge pull request #1873 from ONLYOFFICE/feature/fix-bugs
Feature/fix bugs
This commit is contained in:
commit
36b3af56b8
|
@ -1138,6 +1138,8 @@ input[type="number"]::-webkit-inner-spin-button {
|
||||||
// Navigation list
|
// Navigation list
|
||||||
|
|
||||||
.list.navigation-list {
|
.list.navigation-list {
|
||||||
|
overflow-y: auto;
|
||||||
|
height: 265px;
|
||||||
.item-title {
|
.item-title {
|
||||||
color: @text-normal;
|
color: @text-normal;
|
||||||
}
|
}
|
||||||
|
|
|
@ -340,7 +340,7 @@ class ContextMenu extends ContextMenuController {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
if(inToc) {
|
if(inToc && isEdit) {
|
||||||
itemsText.push({
|
itemsText.push({
|
||||||
caption: t('ContextMenu.textRefreshEntireTable'),
|
caption: t('ContextMenu.textRefreshEntireTable'),
|
||||||
event: 'refreshEntireTable'
|
event: 'refreshEntireTable'
|
||||||
|
|
|
@ -260,12 +260,12 @@ const PageEditStructureTableContents = props => {
|
||||||
<List>
|
<List>
|
||||||
{styles.map((style, index) => {
|
{styles.map((style, index) => {
|
||||||
return (
|
return (
|
||||||
<ListItem checkbox key={index} title={style.displayValue} checked={style.checked}>
|
<ListItem checkbox key={index} title={style.displayValue} checked={style.checked && style.value >= 1}>
|
||||||
{!isAndroid && <div slot='after-start'>{style.value}</div>}
|
{!isAndroid && <div slot='after-start'>{style.value === 0 ? '' : style.value}</div>}
|
||||||
<div slot='after'>
|
<div slot='after'>
|
||||||
<Segmented>
|
<Segmented>
|
||||||
<Button outline className='decrement item-link' onClick={() => {
|
<Button outline className='decrement item-link' onClick={() => {
|
||||||
if(style.value > 1) {
|
if(style.value >= 1) {
|
||||||
setAmountLevels(-1);
|
setAmountLevels(-1);
|
||||||
addNewStyle(style);
|
addNewStyle(style);
|
||||||
props.addStyles(chosenStyles, style.name, style.value - 1);
|
props.addStyles(chosenStyles, style.name, style.value - 1);
|
||||||
|
|
|
@ -32,7 +32,7 @@ const NavigationPopover = inject('storeNavigation')(observer(props => {
|
||||||
<List className="navigation-list">
|
<List className="navigation-list">
|
||||||
{arrHeaders.map((header, index) => {
|
{arrHeaders.map((header, index) => {
|
||||||
return (
|
return (
|
||||||
<ListItem radio key={index} title={header.isEmptyItem ? t('Settings.textEmptyHeading') : header.name} checked={header.index === currentPosition} style={{paddingLeft: header.level * 16}} onClick={() => {
|
<ListItem radio key={index} title={header.isEmptyItem ? t('Settings.textBeginningDocument') : header.name} checked={header.index === currentPosition} style={{paddingLeft: header.level * 16}} onClick={() => {
|
||||||
setCurrentPosition(header.index);
|
setCurrentPosition(header.index);
|
||||||
props.onSelectItem(header.index);
|
props.onSelectItem(header.index);
|
||||||
}}></ListItem>
|
}}></ListItem>
|
||||||
|
@ -121,7 +121,7 @@ const NavigationSheet = inject('storeNavigation')(observer(props => {
|
||||||
<List className="navigation-list">
|
<List className="navigation-list">
|
||||||
{arrHeaders.map((header, index) => {
|
{arrHeaders.map((header, index) => {
|
||||||
return (
|
return (
|
||||||
<ListItem radio key={index} title={header.isEmptyItem ? t('Settings.textEmptyHeading') : header.name} checked={header.index === currentPosition} style={{paddingLeft: header.level * 16}} onClick={() => {
|
<ListItem radio key={index} title={header.isEmptyItem ? t('Settings.textBeginningDocument') : header.name} checked={header.index === currentPosition} style={{paddingLeft: header.level * 16}} onClick={() => {
|
||||||
setCurrentPosition(header.index);
|
setCurrentPosition(header.index);
|
||||||
props.onSelectItem(header.index);
|
props.onSelectItem(header.index);
|
||||||
}}></ListItem>
|
}}></ListItem>
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
|
|
||||||
import React, { useEffect, useState } from 'react';
|
import React, { useEffect, useState } from 'react';
|
||||||
import CellEditorView from '../view/CellEditor';
|
import CellEditorView from '../view/CellEditor';
|
||||||
import { f7 } from 'framework7-react';
|
import { f7 } from 'framework7-react';
|
||||||
|
@ -39,7 +38,7 @@ const CellEditor = inject("storeFunctions")(observer(props => {
|
||||||
setFunctionshDisabled(is_image || is_mode_2 || coauth_disable);
|
setFunctionshDisabled(is_image || is_mode_2 || coauth_disable);
|
||||||
}
|
}
|
||||||
|
|
||||||
const onFormulaCompleteMenu = funcArr => {
|
const onFormulaCompleteMenu = async funcArr => {
|
||||||
const api = Common.EditorApi.get();
|
const api = Common.EditorApi.get();
|
||||||
const storeFunctions = props.storeFunctions;
|
const storeFunctions = props.storeFunctions;
|
||||||
const functions = storeFunctions.functions;
|
const functions = storeFunctions.functions;
|
||||||
|
@ -94,21 +93,14 @@ const CellEditor = inject("storeFunctions")(observer(props => {
|
||||||
return {name, type, descr, caption, args};
|
return {name, type, descr, caption, args};
|
||||||
});
|
});
|
||||||
|
|
||||||
setFuncArr(funcArr);
|
await setFuncArr(funcArr);
|
||||||
setHintArr(hintArr);
|
await setHintArr(hintArr);
|
||||||
|
|
||||||
f7.popover.open('#idx-functions-list', '#idx-list-target');
|
await f7.popover.open('#idx-functions-list', '#idx-list-target');
|
||||||
|
|
||||||
const listTarget = document.querySelector('#idx-list-target');
|
|
||||||
const rect = listTarget.getBoundingClientRect();
|
|
||||||
const popoverList = document.querySelector('#idx-functions-list');
|
|
||||||
|
|
||||||
popoverList.style.top = `${rect.bottom}px`;
|
|
||||||
popoverList.style.left = `${rect.left}px`;
|
|
||||||
} else {
|
} else {
|
||||||
f7.popover.close('#idx-functions-list');
|
await f7.popover.close('#idx-functions-list');
|
||||||
setFuncArr('');
|
await setFuncArr('');
|
||||||
setHintArr('');
|
await setHintArr('');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -14,78 +14,6 @@ const contentStyle = {
|
||||||
flexGrow: 1
|
flexGrow: 1
|
||||||
};
|
};
|
||||||
|
|
||||||
const FunctionInfo = props => {
|
|
||||||
const { t } = useTranslation();
|
|
||||||
const _t = t('View.Add', {returnObjects: true});
|
|
||||||
const functionObj = props.functionObj;
|
|
||||||
const functionInfo = props.functionInfo;
|
|
||||||
|
|
||||||
useEffect(() => {
|
|
||||||
const functionsList = document.querySelector('#functions-list');
|
|
||||||
const height = functionsList.offsetHeight + 'px';
|
|
||||||
|
|
||||||
functionsList.closest('.view').style.height = '200px';
|
|
||||||
|
|
||||||
return () => {
|
|
||||||
functionsList.closest('.view').style.height = height;
|
|
||||||
}
|
|
||||||
}, []);
|
|
||||||
|
|
||||||
return (
|
|
||||||
<Page className='page-function-info'>
|
|
||||||
<Navbar title={functionInfo.caption} backLink={_t.textBack} backLinkUrl='/functions-list/'>
|
|
||||||
<NavRight>
|
|
||||||
<Link text={t('View.Add.textInsert')} onClick={() => props.insertFormula(functionObj.name, functionObj.type)}></Link>
|
|
||||||
</NavRight>
|
|
||||||
</Navbar>
|
|
||||||
<div className='function-info'>
|
|
||||||
<h3>{functionInfo.caption && functionInfo.args ? `${functionInfo.caption} ${functionInfo.args}` : functionInfo.name}</h3>
|
|
||||||
<p>{functionInfo.descr}</p>
|
|
||||||
</div>
|
|
||||||
</Page>
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
const FunctionsList = props => {
|
|
||||||
const isPhone = Device.isPhone;
|
|
||||||
const functions = props.functions;
|
|
||||||
const funcArr = props.funcArr;
|
|
||||||
const hintArr = props.hintArr;
|
|
||||||
|
|
||||||
useEffect(() => {
|
|
||||||
const functionsList = document.querySelector('#functions-list');
|
|
||||||
const height = functionsList.offsetHeight + 'px';
|
|
||||||
|
|
||||||
functionsList.closest('.view').style.height = height;
|
|
||||||
}, [funcArr]);
|
|
||||||
|
|
||||||
return (
|
|
||||||
<div id="functions-list" className={isPhone ? 'functions-list functions-list__mobile' : 'functions-list'}>
|
|
||||||
<List>
|
|
||||||
{funcArr && funcArr.length && funcArr.map((elem, index) => {
|
|
||||||
return (
|
|
||||||
<ListItem key={index} title={elem.name} className="no-indicator" onClick={() => props.insertFormula(elem.name, elem.type)}>
|
|
||||||
{(functions[elem.name] || hintArr[index]?.descr) &&
|
|
||||||
<div slot='after'
|
|
||||||
onClick={(e) => {
|
|
||||||
e.stopPropagation();
|
|
||||||
let functionInfo = functions[elem.name] || hintArr[index];
|
|
||||||
|
|
||||||
if(functionInfo) {
|
|
||||||
f7.views.current.router.navigate('/function-info/', {props: {functionInfo, functionObj: elem, insertFormula: props.insertFormula}});
|
|
||||||
}
|
|
||||||
}}>
|
|
||||||
<Icon icon='icon-info'/>
|
|
||||||
</div>
|
|
||||||
}
|
|
||||||
</ListItem>
|
|
||||||
)
|
|
||||||
})}
|
|
||||||
</List>
|
|
||||||
</div>
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
const CellEditorView = props => {
|
const CellEditorView = props => {
|
||||||
const [expanded, setExpanded] = useState(false);
|
const [expanded, setExpanded] = useState(false);
|
||||||
const isPhone = Device.isPhone;
|
const isPhone = Device.isPhone;
|
||||||
|
@ -147,6 +75,80 @@ const CellEditorView = props => {
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const FunctionsList = props => {
|
||||||
|
const isPhone = Device.isPhone;
|
||||||
|
const functions = props.functions;
|
||||||
|
const funcArr = props.funcArr;
|
||||||
|
const hintArr = props.hintArr;
|
||||||
|
const functionsList = document.querySelector('#functions-list');
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
if(functionsList) {
|
||||||
|
const height = functionsList.offsetHeight + 'px';
|
||||||
|
functionsList.closest('.view').style.height = height;
|
||||||
|
}
|
||||||
|
}, [funcArr]);
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div id="functions-list" className={isPhone ? 'functions-list functions-list__mobile' : 'functions-list'}>
|
||||||
|
<List>
|
||||||
|
{funcArr && funcArr.length && funcArr.map((elem, index) => {
|
||||||
|
return (
|
||||||
|
<ListItem key={index} title={elem.name} className="no-indicator" onClick={() => props.insertFormula(elem.name, elem.type)}>
|
||||||
|
{(functions[elem.name] || hintArr[index]?.descr) &&
|
||||||
|
<div slot='after'
|
||||||
|
onClick={(e) => {
|
||||||
|
e.stopPropagation();
|
||||||
|
let functionInfo = functions[elem.name] || hintArr[index];
|
||||||
|
|
||||||
|
if(functionInfo) {
|
||||||
|
f7.views.current.router.navigate('/function-info/', {props: {functionInfo, functionObj: elem, insertFormula: props.insertFormula}});
|
||||||
|
}
|
||||||
|
}}>
|
||||||
|
<Icon icon='icon-info'/>
|
||||||
|
</div>
|
||||||
|
}
|
||||||
|
</ListItem>
|
||||||
|
)
|
||||||
|
})}
|
||||||
|
</List>
|
||||||
|
</div>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
const FunctionInfo = props => {
|
||||||
|
const { t } = useTranslation();
|
||||||
|
const _t = t('View.Add', {returnObjects: true});
|
||||||
|
const functionObj = props.functionObj;
|
||||||
|
const functionInfo = props.functionInfo;
|
||||||
|
const functionsList = document.querySelector('#functions-list');
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
if(functionsList) {
|
||||||
|
const height = functionsList.offsetHeight + 'px';
|
||||||
|
functionsList.closest('.view').style.height = '200px';
|
||||||
|
|
||||||
|
return () => {
|
||||||
|
functionsList.closest('.view').style.height = height;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, [functionsList]);
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Page className='page-function-info'>
|
||||||
|
<Navbar title={functionInfo.caption} backLink={_t.textBack} backLinkUrl='/functions-list/'>
|
||||||
|
<NavRight>
|
||||||
|
<Link text={t('View.Add.textInsert')} onClick={() => props.insertFormula(functionObj.name, functionObj.type)}></Link>
|
||||||
|
</NavRight>
|
||||||
|
</Navbar>
|
||||||
|
<div className='function-info'>
|
||||||
|
<h3>{functionInfo.caption && functionInfo.args ? `${functionInfo.caption} ${functionInfo.args}` : functionInfo.name}</h3>
|
||||||
|
<p>{functionInfo.descr}</p>
|
||||||
|
</div>
|
||||||
|
</Page>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
const routes = [
|
const routes = [
|
||||||
{
|
{
|
||||||
path: '/function-info/',
|
path: '/function-info/',
|
||||||
|
|
Loading…
Reference in a new issue