mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-18 05:58:11 +08:00
110 lines
3.3 KiB
TypeScript
110 lines
3.3 KiB
TypeScript
/* eslint jsx-a11y/tabindex-no-positive: 0 */
|
|
import React from 'react';
|
|
|
|
import { Flexbox, ScrollRegion } from 'mailspring-component-kit';
|
|
import { localized } from 'mailspring-exports';
|
|
import ThemeOption from './theme-option';
|
|
import { Disposable } from 'event-kit';
|
|
|
|
class ThemePicker extends React.Component<{}, { themes: any[]; activeTheme: string }> {
|
|
static displayName = 'ThemePicker';
|
|
|
|
themes = AppEnv.themes;
|
|
disposable?: Disposable;
|
|
|
|
constructor(props) {
|
|
super(props);
|
|
this.state = this._getState();
|
|
}
|
|
|
|
componentDidMount() {
|
|
this.disposable = this.themes.onDidChangeActiveThemes(() => {
|
|
this.setState(this._getState());
|
|
});
|
|
}
|
|
|
|
componentWillUnmount() {
|
|
this.disposable.dispose();
|
|
}
|
|
|
|
_getState() {
|
|
return {
|
|
themes: this.themes.getAvailableThemes(),
|
|
activeTheme: this.themes.getActiveTheme().name,
|
|
};
|
|
}
|
|
|
|
_setActiveTheme(theme) {
|
|
const prevActiveTheme = this.state.activeTheme;
|
|
this.themes.setActiveTheme(theme);
|
|
this._rewriteIFrame(prevActiveTheme, theme);
|
|
}
|
|
|
|
_rewriteIFrame(prevActiveTheme, activeTheme) {
|
|
const prevActiveThemeDoc = (document.querySelector(
|
|
`.theme-preview-${prevActiveTheme.replace(/\./g, '-')}`
|
|
) as HTMLIFrameElement).contentDocument;
|
|
const prevActiveElement = prevActiveThemeDoc.querySelector('.theme-option.active-true');
|
|
if (prevActiveElement) prevActiveElement.className = 'theme-option active-false';
|
|
const activeThemeDoc = (document.querySelector(
|
|
`.theme-preview-${activeTheme.replace(/\./g, '-')}`
|
|
) as HTMLIFrameElement).contentDocument;
|
|
const activeElement = activeThemeDoc.querySelector('.theme-option.active-false');
|
|
if (activeElement) activeElement.className = 'theme-option active-true';
|
|
}
|
|
|
|
_renderThemeOptions() {
|
|
const internalThemes = [
|
|
'ui-less-is-more',
|
|
'ui-ubuntu',
|
|
'ui-taiga',
|
|
'ui-darkside',
|
|
'ui-dark',
|
|
'ui-light',
|
|
];
|
|
const sortedThemes = [...this.state.themes];
|
|
sortedThemes.sort((a, b) => {
|
|
return (internalThemes.indexOf(a.name) - internalThemes.indexOf(b.name)) * -1;
|
|
});
|
|
return sortedThemes.map(theme => (
|
|
<ThemeOption
|
|
key={theme.name}
|
|
theme={theme}
|
|
active={this.state.activeTheme === theme.name}
|
|
onSelect={() => this._setActiveTheme(theme.name)}
|
|
/>
|
|
));
|
|
}
|
|
|
|
render() {
|
|
return (
|
|
<div className="theme-picker" tabIndex={1}>
|
|
<Flexbox direction="column">
|
|
<h4 style={{ color: '#434648' }}>{localized('Themes')}</h4>
|
|
<div style={{ color: 'rgba(35, 31, 32, 0.5)', fontSize: '12px' }}>
|
|
{localized('Click any theme to apply:')}
|
|
</div>
|
|
<ScrollRegion style={{ margin: '10px 5px 0 5px', height: '290px' }}>
|
|
<Flexbox
|
|
direction="row"
|
|
height="auto"
|
|
style={{ alignItems: 'flex-start', flexWrap: 'wrap' }}
|
|
>
|
|
{this._renderThemeOptions()}
|
|
</Flexbox>
|
|
</ScrollRegion>
|
|
<div className="create-theme">
|
|
<a
|
|
href="https://github.com/Foundry376/Mailspring-Theme-Starter"
|
|
style={{ color: '#3187e1' }}
|
|
>
|
|
{localized('Create a Theme')}
|
|
</a>
|
|
</div>
|
|
</Flexbox>
|
|
</div>
|
|
);
|
|
}
|
|
}
|
|
|
|
export default ThemePicker;
|