2023-01-19 17:19:06 +00:00
|
|
|
import * as React from 'react';
|
2020-10-21 10:39:53 +01:00
|
|
|
import ToolbarButton from './ToolbarButton/ToolbarButton';
|
|
|
|
import ToggleEditorsButton, { Value } from './ToggleEditorsButton/ToggleEditorsButton';
|
2023-01-19 17:19:06 +00:00
|
|
|
import ToolbarSpace from './ToolbarSpace';
|
2017-11-29 23:03:10 +00:00
|
|
|
const { connect } = require('react-redux');
|
2020-11-07 15:59:37 +00:00
|
|
|
const { themeStyle } = require('@joplin/lib/theme');
|
2017-11-29 23:03:10 +00:00
|
|
|
|
2020-09-23 10:21:24 +01:00
|
|
|
interface Props {
|
2020-11-12 19:29:22 +00:00
|
|
|
themeId: number;
|
2024-04-05 12:16:49 +01:00
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
2020-11-12 19:29:22 +00:00
|
|
|
style: any;
|
2024-04-05 12:16:49 +01:00
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
2020-11-12 19:29:22 +00:00
|
|
|
items: any[];
|
2023-07-16 17:42:42 +01:00
|
|
|
disabled: boolean;
|
2020-09-23 10:21:24 +01:00
|
|
|
}
|
|
|
|
|
2024-04-05 12:16:49 +01:00
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
2020-09-23 10:21:24 +01:00
|
|
|
class ToolbarBaseComponent extends React.Component<Props, any> {
|
|
|
|
|
2023-03-06 14:22:01 +00:00
|
|
|
public render() {
|
2020-09-15 14:01:07 +01:00
|
|
|
const theme = themeStyle(this.props.themeId);
|
2020-05-03 18:44:49 +01:00
|
|
|
|
2024-04-05 12:16:49 +01:00
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
2023-06-01 12:02:36 +01:00
|
|
|
const style: any = { display: 'flex',
|
2020-05-03 18:44:49 +01:00
|
|
|
flexDirection: 'row',
|
|
|
|
boxSizing: 'border-box',
|
2020-09-15 14:01:07 +01:00
|
|
|
backgroundColor: theme.backgroundColor3,
|
|
|
|
padding: theme.toolbarPadding,
|
2023-06-01 12:02:36 +01:00
|
|
|
paddingRight: theme.mainPadding, ...this.props.style };
|
2017-11-29 23:03:10 +00:00
|
|
|
|
2024-04-05 12:16:49 +01:00
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
2020-11-12 19:13:28 +00:00
|
|
|
const groupStyle: any = {
|
2020-09-15 14:01:07 +01:00
|
|
|
display: 'flex',
|
|
|
|
flexDirection: 'row',
|
|
|
|
boxSizing: 'border-box',
|
2024-03-04 16:03:39 +05:30
|
|
|
minWidth: 0,
|
2020-09-15 14:01:07 +01:00
|
|
|
};
|
|
|
|
|
2024-04-05 12:16:49 +01:00
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
2020-11-12 19:13:28 +00:00
|
|
|
const leftItemComps: any[] = [];
|
2024-04-05 12:16:49 +01:00
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
2020-11-12 19:13:28 +00:00
|
|
|
const centerItemComps: any[] = [];
|
2024-04-05 12:16:49 +01:00
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
2020-11-12 19:13:28 +00:00
|
|
|
const rightItemComps: any[] = [];
|
2017-11-29 23:03:10 +00:00
|
|
|
|
|
|
|
if (this.props.items) {
|
|
|
|
for (let i = 0; i < this.props.items.length; i++) {
|
|
|
|
const o = this.props.items[i];
|
|
|
|
let key = o.iconName ? o.iconName : '';
|
|
|
|
key += o.title ? o.title : '';
|
2020-11-20 16:19:57 +00:00
|
|
|
key += o.name ? o.name : '';
|
2017-11-29 23:03:10 +00:00
|
|
|
const itemType = !('type' in o) ? 'button' : o.type;
|
|
|
|
|
2019-09-19 22:51:18 +01:00
|
|
|
if (!key) key = `${o.type}_${i}`;
|
2018-06-14 08:52:12 +01:00
|
|
|
|
2023-06-01 12:02:36 +01:00
|
|
|
const props = {
|
|
|
|
key: key,
|
|
|
|
themeId: this.props.themeId,
|
2023-07-16 17:42:42 +01:00
|
|
|
disabled: this.props.disabled,
|
2023-06-01 12:02:36 +01:00
|
|
|
...o,
|
|
|
|
};
|
2017-11-29 23:03:10 +00:00
|
|
|
|
2020-09-15 14:01:07 +01:00
|
|
|
if (o.name === 'toggleEditors') {
|
|
|
|
rightItemComps.push(<ToggleEditorsButton
|
|
|
|
key={o.name}
|
2020-10-21 10:39:53 +01:00
|
|
|
value={Value.Markdown}
|
2020-09-15 14:01:07 +01:00
|
|
|
themeId={this.props.themeId}
|
|
|
|
toolbarButtonInfo={o}
|
|
|
|
/>);
|
|
|
|
} else if (itemType === 'button') {
|
2020-10-10 13:32:30 +01:00
|
|
|
const target = ['historyForward', 'historyBackward', 'toggleExternalEditing'].includes(o.name) ? leftItemComps : centerItemComps;
|
2020-09-15 14:01:07 +01:00
|
|
|
target.push(<ToolbarButton {...props} />);
|
2018-06-14 08:52:12 +01:00
|
|
|
} else if (itemType === 'separator') {
|
2020-09-15 14:01:07 +01:00
|
|
|
centerItemComps.push(<ToolbarSpace {...props} />);
|
2017-11-29 23:03:10 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div className="editor-toolbar" style={style}>
|
2020-09-15 14:01:07 +01:00
|
|
|
<div style={groupStyle}>
|
|
|
|
{leftItemComps}
|
|
|
|
</div>
|
|
|
|
<div style={groupStyle}>
|
|
|
|
{centerItemComps}
|
|
|
|
</div>
|
2023-06-01 12:02:36 +01:00
|
|
|
<div style={{ ...groupStyle, flex: 1, justifyContent: 'flex-end' }}>
|
2020-09-15 14:01:07 +01:00
|
|
|
{rightItemComps}
|
|
|
|
</div>
|
2017-11-29 23:03:10 +00:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-04-05 12:16:49 +01:00
|
|
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any -- Old code before rule was applied
|
2020-11-12 19:13:28 +00:00
|
|
|
const mapStateToProps = (state: any) => {
|
2020-09-15 14:01:07 +01:00
|
|
|
return { themeId: state.settings.theme };
|
2017-11-29 23:03:10 +00:00
|
|
|
};
|
|
|
|
|
2020-09-23 10:21:24 +01:00
|
|
|
export default connect(mapStateToProps)(ToolbarBaseComponent);
|