[SSE] Add 'Tab Color' in Sheets
This commit is contained in:
parent
bdd8958932
commit
1d9ef74b37
|
@ -2,7 +2,7 @@ import React, { useState, useEffect } from 'react';
|
||||||
import { f7, ListItem, List, Icon } from 'framework7-react';
|
import { f7, ListItem, List, Icon } from 'framework7-react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
|
|
||||||
const ThemeColors = ({ themeColors, onColorClick, curColor, isTypeCustomColors }) => {
|
const ThemeColors = ({ themeColors, onColorClick, curColor, isTypeColors, isTypeCustomColors }) => {
|
||||||
return (
|
return (
|
||||||
<div className='palette'>
|
<div className='palette'>
|
||||||
{themeColors.map((row, rowIndex) => {
|
{themeColors.map((row, rowIndex) => {
|
||||||
|
@ -11,7 +11,7 @@ const ThemeColors = ({ themeColors, onColorClick, curColor, isTypeCustomColors }
|
||||||
{row.map((effect, index) => {
|
{row.map((effect, index) => {
|
||||||
return(
|
return(
|
||||||
<a key={`tc-${rowIndex}-${index}`}
|
<a key={`tc-${rowIndex}-${index}`}
|
||||||
className={(curColor && !isTypeCustomColors && ((curColor.color === effect.color && curColor.effectValue === effect.effectValue) || (curColor === effect.color))) ? 'active' : ''}
|
className={(curColor && !isTypeCustomColors && !isTypeColors && ((curColor.color === effect.color && curColor.effectValue === effect.effectValue) || (curColor === effect.color))) ? 'active' : ''}
|
||||||
style={{ background: `#${effect.color}`}}
|
style={{ background: `#${effect.color}`}}
|
||||||
onClick={() => {onColorClick(effect.color, effect.effectId, effect.effectValue)}}
|
onClick={() => {onColorClick(effect.color, effect.effectId, effect.effectValue)}}
|
||||||
></a>
|
></a>
|
||||||
|
@ -115,7 +115,7 @@ const ThemeColorPalette = props => {
|
||||||
<List>
|
<List>
|
||||||
<ListItem className='theme-colors'>
|
<ListItem className='theme-colors'>
|
||||||
<div>{ _t.textThemeColors }</div>
|
<div>{ _t.textThemeColors }</div>
|
||||||
<ThemeColors isTypeCustomColors={isTypeCustomColors} themeColors={themeColors} onColorClick={props.changeColor} curColor={curColor}/>
|
<ThemeColors isTypeCustomColors={isTypeCustomColors} isTypeColors={isTypeColors} themeColors={themeColors} onColorClick={props.changeColor} curColor={curColor}/>
|
||||||
</ListItem>
|
</ListItem>
|
||||||
<ListItem className='standart-colors'>
|
<ListItem className='standart-colors'>
|
||||||
<div>{ _t.textStandartColors }</div>
|
<div>{ _t.textStandartColors }</div>
|
||||||
|
|
|
@ -291,6 +291,7 @@
|
||||||
"textSheetName": "Sheet Name",
|
"textSheetName": "Sheet Name",
|
||||||
"textUnhide": "Unhide",
|
"textUnhide": "Unhide",
|
||||||
"textMove": "Move",
|
"textMove": "Move",
|
||||||
|
"textTabColor": "Tab Color",
|
||||||
"textMoveBack": "Move back",
|
"textMoveBack": "Move back",
|
||||||
"textMoveForward": "Move forward",
|
"textMoveForward": "Move forward",
|
||||||
"textWarnDeleteSheet": "The worksheet maybe has data. Proceed operation?"
|
"textWarnDeleteSheet": "The worksheet maybe has data. Proceed operation?"
|
||||||
|
|
|
@ -63,8 +63,7 @@ const StatusbarController = inject('sheets', 'storeFocusObjects', 'users')(obser
|
||||||
}
|
}
|
||||||
|
|
||||||
sheets.resetSheets(items);
|
sheets.resetSheets(items);
|
||||||
|
setTimeout(() => updateTabsColors());
|
||||||
updateTabsColors();
|
|
||||||
};
|
};
|
||||||
|
|
||||||
const onApiActiveSheetChanged = (index) => {
|
const onApiActiveSheetChanged = (index) => {
|
||||||
|
@ -72,6 +71,7 @@ const StatusbarController = inject('sheets', 'storeFocusObjects', 'users')(obser
|
||||||
sheets.setActiveWorksheet(index);
|
sheets.setActiveWorksheet(index);
|
||||||
Common.Notifications.trigger('sheet:active', index);
|
Common.Notifications.trigger('sheet:active', index);
|
||||||
}
|
}
|
||||||
|
onApiSheetsChanged();
|
||||||
};
|
};
|
||||||
|
|
||||||
const onApiHideTabContextMenu = () => {
|
const onApiHideTabContextMenu = () => {
|
||||||
|
@ -103,14 +103,13 @@ const StatusbarController = inject('sheets', 'storeFocusObjects', 'users')(obser
|
||||||
|
|
||||||
if (color.length) {
|
if (color.length) {
|
||||||
if (!tab.active) {
|
if (!tab.active) {
|
||||||
color = '0px 4px 0 ' + Common.Utils.RGBColor(color).toRGBA(0.7) + ' inset';
|
color = '0px 3px 0 ' + Common.Utils.RGBColor(color).toRGBA(0.7) + ' inset';
|
||||||
} else {
|
} else {
|
||||||
color = '0px 4px 0 ' + color + ' inset';
|
color = '0px 3px 0 ' + color + ' inset';
|
||||||
}
|
}
|
||||||
|
$$(`.sheet-tabs .tab a.tab-color-${tab.index}`).css('box-shadow', color);
|
||||||
$$('.sheet-tabs .tab a').eq(tab.index).css('box-shadow', color);
|
|
||||||
} else {
|
} else {
|
||||||
$$('.sheet-tabs .tab a').eq(tab.index).css('box-shadow', '');
|
$$(`.sheet-tabs .tab a.tab-color-${tab.index}`).css('box-shadow', '');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -337,6 +336,15 @@ const Statusbar = inject('sheets', 'storeAppOptions', 'users')(observer(props =>
|
||||||
case 'move':
|
case 'move':
|
||||||
Device.phone ? f7.sheet.open('.move-sheet') : f7.popover.open('#idx-move-sheet-popover', targetRef.current);
|
Device.phone ? f7.sheet.open('.move-sheet') : f7.popover.open('#idx-move-sheet-popover', targetRef.current);
|
||||||
break;
|
break;
|
||||||
|
case 'tab-color':
|
||||||
|
if( Device.phone ) {
|
||||||
|
f7.sheet.open('.tab-color-sheet');
|
||||||
|
f7.navbar.hide('.main-navbar');
|
||||||
|
$$('.statusbar').css('top', '-50%');
|
||||||
|
} else {
|
||||||
|
f7.popover.open('#idx-tab-color-popover',targetRef.current);
|
||||||
|
}
|
||||||
|
break;
|
||||||
case 'unhide':
|
case 'unhide':
|
||||||
f7.popover.open('#idx-hidden-sheets-popover', '.active');
|
f7.popover.open('#idx-hidden-sheets-popover', '.active');
|
||||||
break;
|
break;
|
||||||
|
@ -365,6 +373,28 @@ const Statusbar = inject('sheets', 'storeAppOptions', 'users')(observer(props =>
|
||||||
api.asc_moveWorksheet(activeIndex === undefined ? api.asc_getWorksheetsCount() : activeIndex, [api.asc_getActiveWorksheetIndex()]);
|
api.asc_moveWorksheet(activeIndex === undefined ? api.asc_getWorksheetsCount() : activeIndex, [api.asc_getActiveWorksheetIndex()]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const onSetWorkSheetColor = (color) => {
|
||||||
|
const api = Common.EditorApi.get();
|
||||||
|
let arrIndex = [];
|
||||||
|
|
||||||
|
if (api) {
|
||||||
|
arrIndex.push(api.asc_getActiveWorksheetIndex());
|
||||||
|
if (arrIndex) {
|
||||||
|
if(color === 'transparent') {
|
||||||
|
api.asc_setWorksheetTabColor(null, arrIndex);
|
||||||
|
sheets.sheets.forEach(tab => {
|
||||||
|
if(tab.active) $$(`.sheet-tabs .tab a.tab-color-${tab.index}`).css('box-shadow', '');
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
let asc_clr = Common.Utils.ThemeColor.getRgbColor(color);
|
||||||
|
if (asc_clr) {
|
||||||
|
api.asc_setWorksheetTabColor(asc_clr, arrIndex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<StatusbarView
|
<StatusbarView
|
||||||
onTabClick={onTabClick}
|
onTabClick={onTabClick}
|
||||||
|
@ -372,6 +402,7 @@ const Statusbar = inject('sheets', 'storeAppOptions', 'users')(observer(props =>
|
||||||
onAddTabClicked={onAddTabClicked}
|
onAddTabClicked={onAddTabClicked}
|
||||||
onTabMenu={onTabMenu}
|
onTabMenu={onTabMenu}
|
||||||
onMenuMoveClick = {onMenuMoveClick}
|
onMenuMoveClick = {onMenuMoveClick}
|
||||||
|
onSetWorkSheetColor={onSetWorkSheetColor}
|
||||||
/>
|
/>
|
||||||
)
|
)
|
||||||
}));
|
}));
|
||||||
|
|
|
@ -394,7 +394,7 @@
|
||||||
&.icon-plus {
|
&.icon-plus {
|
||||||
width: 22px;
|
width: 22px;
|
||||||
height: 22px;
|
height: 22px;
|
||||||
.encoded-svg-mask('<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 22 22" fill="@{toolbar-icons}"><g><path d="M21,12h-9v9h-2v-9H1v-2h9V1h2v9h9V12z"/></g></svg>');
|
.encoded-svg-mask('<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" viewBox="0 0 22 22" fill="@{toolbar-icons}"><g><path d="M21,12h-9v9h-2v-9H1v-2h9V1h2v9h9V12z"/></g></svg>', @toolbar-icons);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -8,6 +8,8 @@
|
||||||
background-color: @background-tertiary;
|
background-color: @background-tertiary;
|
||||||
display: flex;
|
display: flex;
|
||||||
|
|
||||||
|
transition: top 400ms;
|
||||||
|
|
||||||
.tab {
|
.tab {
|
||||||
border: 0 none;
|
border: 0 none;
|
||||||
border-radius: 0;
|
border-radius: 0;
|
||||||
|
@ -24,6 +26,9 @@
|
||||||
&.active {
|
&.active {
|
||||||
background-color: @background-secondary;
|
background-color: @background-secondary;
|
||||||
font-weight: 600;
|
font-weight: 600;
|
||||||
|
a {
|
||||||
|
box-shadow: 0px 2px 0 #49795d inset;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.hairline(right, @background-menu-divider);
|
.hairline(right, @background-menu-divider);
|
||||||
|
|
|
@ -42,15 +42,24 @@ export class storeWorksheets {
|
||||||
setWsProps: action,
|
setWsProps: action,
|
||||||
|
|
||||||
isDisabledEditSheet: observable,
|
isDisabledEditSheet: observable,
|
||||||
setDisabledEditSheet: action
|
setDisabledEditSheet: action,
|
||||||
|
|
||||||
|
colorTab:observable,
|
||||||
|
changeTabColor: action
|
||||||
});
|
});
|
||||||
this.sheets = [];
|
this.sheets = [];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
colorTab = undefined;
|
||||||
|
|
||||||
resetSheets(sheets) {
|
resetSheets(sheets) {
|
||||||
this.sheets = Object.values(sheets)
|
this.sheets = Object.values(sheets)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
changeTabColor(color) {
|
||||||
|
this.colorTab = color;
|
||||||
|
}
|
||||||
|
|
||||||
setActiveWorksheet(i) {
|
setActiveWorksheet(i) {
|
||||||
if ( !this.sheets[i].active ) {
|
if ( !this.sheets[i].active ) {
|
||||||
this.sheets.forEach(model => {
|
this.sheets.forEach(model => {
|
||||||
|
|
|
@ -1,8 +1,9 @@
|
||||||
import React, { Fragment, useState } from 'react';
|
import React, { Fragment, useEffect, useState } from 'react';
|
||||||
import { View, Link, Icon, Popover, List, ListItem, ListButton, Actions, ActionsGroup, ActionsButton, Sheet, Page } from 'framework7-react';
|
import {f7, View, Link, Icon, Popover, Navbar, NavRight, List, ListItem, ListButton, Actions, ActionsGroup, ActionsButton, Sheet, Page } from 'framework7-react';
|
||||||
import { useTranslation } from 'react-i18next';
|
import { useTranslation } from 'react-i18next';
|
||||||
import { Device } from '../../../../common/mobile/utils/device';
|
import { Device } from '../../../../common/mobile/utils/device';
|
||||||
import { inject, observer } from 'mobx-react';
|
import { inject, observer } from 'mobx-react';
|
||||||
|
import { ThemeColorPalette, CustomColorPicker } from '../../../../common/mobile/lib/component/ThemeColorPalette.jsx';
|
||||||
|
|
||||||
const viewStyle = {
|
const viewStyle = {
|
||||||
height: 30
|
height: 30
|
||||||
|
@ -53,6 +54,93 @@ const PageListMove = props => {
|
||||||
)
|
)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const PageCustomTabColor = inject("storePalette")(observer (props => {
|
||||||
|
const { t } = useTranslation();
|
||||||
|
const _t = t('View.Edit', {returnObjects: true});
|
||||||
|
|
||||||
|
const onAddNewColor = (colors, color) => {
|
||||||
|
props.storePalette.changeCustomColors(colors);
|
||||||
|
props.onSetWorkSheetColor(color);
|
||||||
|
props.sheets.changeTabColor(color);
|
||||||
|
props.f7router.back();
|
||||||
|
};
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Page>
|
||||||
|
<Navbar title={_t.textCustomColor} backLink={_t.textBack}>
|
||||||
|
{Device.phone &&
|
||||||
|
<NavRight>
|
||||||
|
<Link icon='icon-expand-down' sheetClose ></Link>
|
||||||
|
</NavRight>
|
||||||
|
}
|
||||||
|
</Navbar>
|
||||||
|
<CustomColorPicker currentColor={props.sheets.colorTab} onAddNewColor={onAddNewColor}/>
|
||||||
|
</Page>
|
||||||
|
)
|
||||||
|
}));
|
||||||
|
|
||||||
|
const PageTabColor = inject("storePalette")(observer(props => {
|
||||||
|
const { t } = useTranslation();
|
||||||
|
const {sheets} = props;
|
||||||
|
const allSheets = sheets.sheets;
|
||||||
|
const storePalette = props.storePalette;
|
||||||
|
const customColors = storePalette.customColors;
|
||||||
|
const activeIndex = sheets.activeWorksheet;
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
if (allSheets.length !== 0) {
|
||||||
|
let color = sheets.at(activeIndex).color;
|
||||||
|
if(sheets.at(activeIndex).color !== null) {
|
||||||
|
sheets.changeTabColor('' + Common.Utils.ThemeColor.getHexColor(color.get_r(), color.get_g(), color.get_b()));
|
||||||
|
} else {
|
||||||
|
sheets.changeTabColor('transparent');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, [allSheets])
|
||||||
|
|
||||||
|
const changeColor = (color, effectId, effectValue) => {
|
||||||
|
if (color !== 'empty') {
|
||||||
|
if (effectId !== undefined ) {
|
||||||
|
const newColor = {color: color, effectId: effectId, effectValue: effectValue};
|
||||||
|
sheets.changeTabColor(newColor);
|
||||||
|
props.onSetWorkSheetColor(color);
|
||||||
|
} else {
|
||||||
|
sheets.changeTabColor(color);
|
||||||
|
props.onSetWorkSheetColor(color);
|
||||||
|
}
|
||||||
|
|
||||||
|
Device.isPhone ? f7.sheet.close('.tab-color-sheet') : f7.popover.close('#idx-tab-color-popover');
|
||||||
|
|
||||||
|
} else {
|
||||||
|
f7.views.current.router.navigate('/sheet-tab-custom-color/', {props:{onSetWorkSheetColor: props.onSetWorkSheetColor, sheets}});
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Page>
|
||||||
|
<Navbar title={t('Statusbar.textTabColor')}>
|
||||||
|
{Device.phone &&
|
||||||
|
<NavRight>
|
||||||
|
<Link sheetClose>
|
||||||
|
<Icon icon='icon-expand-down'/>
|
||||||
|
</Link>
|
||||||
|
</NavRight>
|
||||||
|
}
|
||||||
|
</Navbar>
|
||||||
|
|
||||||
|
{ allSheets.length !== 0 &&
|
||||||
|
<ThemeColorPalette changeColor={changeColor} curColor={sheets.colorTab} customColors={customColors} transparent={true}/> }
|
||||||
|
<List>
|
||||||
|
<ListItem title={t('View.Edit.textAddCustomColor')} link="/sheet-tab-custom-color/" routeProps={{
|
||||||
|
onSetWorkSheetColor: props.onSetWorkSheetColor,
|
||||||
|
sheets,
|
||||||
|
}}></ListItem>
|
||||||
|
</List>
|
||||||
|
</Page>
|
||||||
|
)
|
||||||
|
}));
|
||||||
|
|
||||||
|
|
||||||
const StatusbarView = inject('storeAppOptions', 'sheets', 'users')(observer(props => {
|
const StatusbarView = inject('storeAppOptions', 'sheets', 'users')(observer(props => {
|
||||||
const { t } = useTranslation();
|
const { t } = useTranslation();
|
||||||
const _t = t('Statusbar', {returnObjects: true});
|
const _t = t('Statusbar', {returnObjects: true});
|
||||||
|
@ -82,7 +170,7 @@ const StatusbarView = inject('storeAppOptions', 'sheets', 'users')(observer(prop
|
||||||
{allSheets.map((model,i) =>
|
{allSheets.map((model,i) =>
|
||||||
model.hidden ? null :
|
model.hidden ? null :
|
||||||
<li className={`tab${model.active ? ' active' : ''} ${model.locked ? 'locked' : ''}`} key={i} onClick={(e) => props.onTabClick(i, e.target)}>
|
<li className={`tab${model.active ? ' active' : ''} ${model.locked ? 'locked' : ''}`} key={i} onClick={(e) => props.onTabClick(i, e.target)}>
|
||||||
<a>{model.name}</a>
|
<a className={`tab-color-${model.index}`}>{model.name}</a>
|
||||||
</li>
|
</li>
|
||||||
|
|
||||||
)}
|
)}
|
||||||
|
@ -109,6 +197,7 @@ const StatusbarView = inject('storeAppOptions', 'sheets', 'users')(observer(prop
|
||||||
<ListButton title={_t.textRename} onClick={() => props.onTabMenu('ren')} />
|
<ListButton title={_t.textRename} onClick={() => props.onTabMenu('ren')} />
|
||||||
<ListButton title={_t.textHide} onClick={() => props.onTabMenu('hide')} />
|
<ListButton title={_t.textHide} onClick={() => props.onTabMenu('hide')} />
|
||||||
<ListButton title={_t.textMove} onClick={() => props.onTabMenu('move')} />
|
<ListButton title={_t.textMove} onClick={() => props.onTabMenu('move')} />
|
||||||
|
<ListButton title={_t.textTabColor} onClick={() => props.onTabMenu('tab-color')} />
|
||||||
{hiddenSheets.length ? (
|
{hiddenSheets.length ? (
|
||||||
<ListButton title={_t.textUnhide} onClick={() => props.onTabMenu('unhide')} />
|
<ListButton title={_t.textUnhide} onClick={() => props.onTabMenu('unhide')} />
|
||||||
) : null}
|
) : null}
|
||||||
|
@ -122,6 +211,7 @@ const StatusbarView = inject('storeAppOptions', 'sheets', 'users')(observer(prop
|
||||||
<ActionsButton onClick={() => props.onTabMenu('ren')}>{_t.textRename}</ActionsButton>
|
<ActionsButton onClick={() => props.onTabMenu('ren')}>{_t.textRename}</ActionsButton>
|
||||||
<ActionsButton onClick={() => props.onTabMenu('hide')}>{_t.textHide}</ActionsButton>
|
<ActionsButton onClick={() => props.onTabMenu('hide')}>{_t.textHide}</ActionsButton>
|
||||||
<ActionsButton onClick={() => props.onTabMenu('move')}>{_t.textMove}</ActionsButton>
|
<ActionsButton onClick={() => props.onTabMenu('move')}>{_t.textMove}</ActionsButton>
|
||||||
|
<ActionsButton onClick={() => props.onTabMenu('tab-color')}>{_t.textTabColor}</ActionsButton>
|
||||||
{hiddenSheets.length ? (
|
{hiddenSheets.length ? (
|
||||||
<ActionsButton onClick={() => props.onTabMenu('unhide')}>{_t.textUnhide}</ActionsButton>
|
<ActionsButton onClick={() => props.onTabMenu('unhide')}>{_t.textUnhide}</ActionsButton>
|
||||||
) : null}
|
) : null}
|
||||||
|
@ -143,6 +233,24 @@ const StatusbarView = inject('storeAppOptions', 'sheets', 'users')(observer(prop
|
||||||
<PageListMove sheets={sheets} onMenuMoveClick={props.onMenuMoveClick}/>
|
<PageListMove sheets={sheets} onMenuMoveClick={props.onMenuMoveClick}/>
|
||||||
</Popover>
|
</Popover>
|
||||||
}
|
}
|
||||||
|
{ isPhone ?
|
||||||
|
<Sheet style={{height: '50%'}} className='tab-color-sheet' backdrop={false}
|
||||||
|
onSheetClose={() =>
|
||||||
|
{
|
||||||
|
f7.navbar.show('.main-navbar');
|
||||||
|
$$('.statusbar').css('top', '0%');
|
||||||
|
}}>
|
||||||
|
<View routes={routes}>
|
||||||
|
<PageTabColor sheets={sheets} onSetWorkSheetColor={props.onSetWorkSheetColor}/>
|
||||||
|
</View>
|
||||||
|
</Sheet>
|
||||||
|
:
|
||||||
|
<Popover id="idx-tab-color-popover" backdrop={false}>
|
||||||
|
<View style={{height: '450px'}} routes={routes}>
|
||||||
|
<PageTabColor sheets={sheets} onSetWorkSheetColor={props.onSetWorkSheetColor}/>
|
||||||
|
</View>
|
||||||
|
</Popover>
|
||||||
|
}
|
||||||
{hiddenSheets.length ? (
|
{hiddenSheets.length ? (
|
||||||
<Popover id="idx-hidden-sheets-popover"
|
<Popover id="idx-hidden-sheets-popover"
|
||||||
className="document-menu"
|
className="document-menu"
|
||||||
|
@ -164,4 +272,11 @@ const StatusbarView = inject('storeAppOptions', 'sheets', 'users')(observer(prop
|
||||||
)
|
)
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
const routes = [
|
||||||
|
{
|
||||||
|
path: '/sheet-tab-custom-color/',
|
||||||
|
component: PageCustomTabColor
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
export {StatusbarView};
|
export {StatusbarView};
|
||||||
|
|
Loading…
Reference in a new issue