2021-03-23 13:43:10 +00:00
|
|
|
import React, { Fragment } from 'react';
|
2021-03-19 22:38:40 +00:00
|
|
|
import { View, Toolbar, Link, Icon, Popover, List, ListButton } from 'framework7-react';
|
2020-12-28 20:52:32 +00:00
|
|
|
import { observer, inject } from "mobx-react";
|
2021-03-23 13:43:10 +00:00
|
|
|
import { useTranslation } from 'react-i18next';
|
2021-03-23 22:46:37 +00:00
|
|
|
import { f7 } from 'framework7-react';
|
2020-12-15 21:17:26 +00:00
|
|
|
|
|
|
|
const viewStyle = {
|
|
|
|
height: 30
|
|
|
|
};
|
2020-12-10 13:14:52 +00:00
|
|
|
|
2020-12-28 20:52:32 +00:00
|
|
|
const StatusbarView = inject('sheets')(observer(props => {
|
2021-03-23 13:43:10 +00:00
|
|
|
const { t } = useTranslation();
|
|
|
|
const _t = t('Statusbar', {returnObjects: true});
|
2020-12-28 20:52:32 +00:00
|
|
|
const { sheets } = props;
|
2021-03-23 22:46:37 +00:00
|
|
|
const hiddenSheets = sheets.hiddensheets;
|
2021-03-22 16:57:40 +00:00
|
|
|
const getTabClassList = model => `tab ${model.active ? 'active' : ''} ${model.locked ? 'locked' : ''}`;
|
2020-12-28 20:52:32 +00:00
|
|
|
|
2021-03-23 13:43:10 +00:00
|
|
|
return (
|
|
|
|
<Fragment>
|
|
|
|
<View id="idx-statusbar" className="statusbar" style={viewStyle}>
|
2020-12-28 20:52:32 +00:00
|
|
|
<div id="idx-box-add-tab">
|
|
|
|
<Link href="false" id="idx-btn-addtab" className="tab" onClick={e => props.onAddTabClicked()}>
|
|
|
|
<Icon className="icon icon-plus" />
|
|
|
|
</Link>
|
|
|
|
</div>
|
|
|
|
<div className="statusbar--box-tabs">
|
|
|
|
<ul className="sheet-tabs bottom">
|
|
|
|
{sheets.sheets.map((model,i) =>
|
|
|
|
model.hidden ? null :
|
2021-03-22 16:57:40 +00:00
|
|
|
<li className={getTabClassList(model)} key={i} onClick={(e) => props.onTabClick(i, e.target)}>
|
2021-03-23 22:46:37 +00:00
|
|
|
<a /* onClick={e => props.onTabClicked(i)} */>{model.name}</a>
|
2020-12-28 20:52:32 +00:00
|
|
|
</li>
|
|
|
|
)}
|
|
|
|
</ul>
|
|
|
|
</div>
|
2021-03-23 13:43:10 +00:00
|
|
|
</View>
|
|
|
|
<Popover id="idx-tab-context-menu-popover"
|
2021-03-19 22:38:40 +00:00
|
|
|
className="document-menu"
|
|
|
|
backdrop={false}
|
|
|
|
closeByBackdropClick={false}
|
|
|
|
closeByOutsideClick={false}
|
|
|
|
>
|
|
|
|
<List className="list-block">
|
2021-03-23 13:43:10 +00:00
|
|
|
<ListButton title={_t.textDuplicate} onClick={() => props.onTabMenu('copy')} />
|
|
|
|
<ListButton title={_t.textDelete} onClick={() => props.onTabMenu('del')} />
|
|
|
|
<ListButton title={_t.textRename} onClick={() => props.onTabMenu('ren')} />
|
|
|
|
<ListButton title={_t.textHide} onClick={() => props.onTabMenu('hide')} />
|
|
|
|
{hiddenSheets.length ? (
|
2021-03-23 22:46:37 +00:00
|
|
|
<ListButton title={_t.textUnhide} onClick={() => props.onTabMenu('unhide')} />
|
2021-03-23 13:43:10 +00:00
|
|
|
): null}
|
2021-03-19 22:38:40 +00:00
|
|
|
</List>
|
2021-03-23 13:43:10 +00:00
|
|
|
</Popover>
|
|
|
|
{hiddenSheets.length ? (
|
|
|
|
<Popover id="idx-hidden-sheets-popover"
|
|
|
|
className="document-menu"
|
|
|
|
backdrop={false}
|
|
|
|
closeByBackdropClick={false}
|
|
|
|
closeByOutsideClick={false}
|
|
|
|
>
|
|
|
|
<List className="list-block">
|
|
|
|
{hiddenSheets.map(sheet => {
|
|
|
|
return (
|
2021-03-23 22:46:37 +00:00
|
|
|
<ListButton key={sheet.index} data-event={`reveal:${sheet.index}`} title={sheet.name}
|
|
|
|
onClick={() => props.onTabMenu(`reveal:${sheet.index}`)} />
|
2021-03-23 13:43:10 +00:00
|
|
|
)
|
|
|
|
})}
|
|
|
|
</List>
|
|
|
|
</Popover>
|
|
|
|
) : null}
|
|
|
|
</Fragment>
|
2021-03-19 22:38:40 +00:00
|
|
|
)
|
2021-03-23 13:43:10 +00:00
|
|
|
}));
|
2021-03-19 22:38:40 +00:00
|
|
|
|
2021-03-23 13:43:10 +00:00
|
|
|
export {StatusbarView};
|