2016-03-05 07:21:06 +08:00
|
|
|
import React from 'react';
|
2016-03-29 16:41:24 +08:00
|
|
|
import ReactDOM from 'react-dom';
|
2016-03-05 07:21:06 +08:00
|
|
|
import fs from 'fs-plus';
|
|
|
|
import path from 'path';
|
|
|
|
|
2016-03-11 06:10:48 +08:00
|
|
|
import {EventedIFrame} from 'nylas-component-kit';
|
2016-03-05 07:21:06 +08:00
|
|
|
import LessCompileCache from '../../../src/less-compile-cache'
|
|
|
|
|
|
|
|
|
|
|
|
class ThemeOption extends React.Component {
|
|
|
|
static propTypes = {
|
|
|
|
theme: React.PropTypes.object.isRequired,
|
|
|
|
active: React.PropTypes.bool.isRequired,
|
2016-03-09 09:08:09 +08:00
|
|
|
onSelect: React.PropTypes.func.isRequired,
|
2016-03-05 07:21:06 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
constructor(props) {
|
|
|
|
super(props);
|
|
|
|
this.lessCache = null;
|
|
|
|
}
|
|
|
|
|
|
|
|
componentDidMount() {
|
|
|
|
this._writeContent();
|
|
|
|
}
|
|
|
|
|
|
|
|
_getImportPaths() {
|
|
|
|
const themes = [this.props.theme];
|
|
|
|
// Pulls the theme package for Light as the base theme
|
|
|
|
for (const theme of NylasEnv.themes.getActiveThemes()) {
|
|
|
|
if (theme.name === NylasEnv.themes.baseThemeName()) {
|
|
|
|
themes.push(theme);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
const themePaths = [];
|
|
|
|
for (const theme of themes) {
|
|
|
|
themePaths.push(theme.getStylesheetsPath());
|
|
|
|
}
|
|
|
|
return themePaths.filter((themePath) => fs.isDirectorySync(themePath));
|
|
|
|
}
|
|
|
|
|
|
|
|
_loadStylesheet(stylesheetPath) {
|
|
|
|
if (path.extname(stylesheetPath) === '.less') {
|
|
|
|
return this._loadLessStylesheet(stylesheetPath);
|
|
|
|
}
|
|
|
|
return fs.readFileSync(stylesheetPath, 'utf8');
|
|
|
|
}
|
|
|
|
|
|
|
|
_loadLessStylesheet(lessStylesheetPath) {
|
|
|
|
const {configDirPath, resourcePath} = NylasEnv.getLoadSettings();
|
|
|
|
if (this.lessCache) {
|
|
|
|
this.lessCache.setImportPaths(this._getImportPaths());
|
|
|
|
} else {
|
|
|
|
const importPaths = this._getImportPaths();
|
|
|
|
this.lessCache = new LessCompileCache({configDirPath, resourcePath, importPaths});
|
|
|
|
}
|
|
|
|
const themeVarPath = path.relative(`${resourcePath}/internal_packages/theme-picker/preview-styles`,
|
|
|
|
this.props.theme.getStylesheetsPath());
|
|
|
|
let varImports = `@import "../../../static/variables/ui-variables";`
|
|
|
|
if (fs.existsSync(`${this.props.theme.getStylesheetsPath()}/ui-variables.less`)) {
|
|
|
|
varImports += `@import "${themeVarPath}/ui-variables";`
|
|
|
|
}
|
|
|
|
if (fs.existsSync(`${this.props.theme.getStylesheetsPath()}/theme-colors.less`)) {
|
|
|
|
varImports += `@import "${themeVarPath}/theme-colors";`
|
|
|
|
}
|
|
|
|
const less = fs.readFileSync(lessStylesheetPath, 'utf8');
|
|
|
|
return this.lessCache.cssForFile(lessStylesheetPath, [varImports, less].join('\n'));
|
|
|
|
}
|
|
|
|
|
|
|
|
_writeContent() {
|
2016-03-29 16:41:24 +08:00
|
|
|
const domNode = ReactDOM.findDOMNode(this.refs.iframe);
|
2016-03-05 07:21:06 +08:00
|
|
|
const doc = domNode.contentDocument;
|
|
|
|
if (!doc) return;
|
|
|
|
|
|
|
|
const {resourcePath} = NylasEnv.getLoadSettings();
|
2016-03-07 07:25:38 +08:00
|
|
|
const css = `<style>${this._loadStylesheet(`${resourcePath}/internal_packages/theme-picker/preview-styles/theme-option.less`)}</style>`
|
2016-03-05 07:21:06 +08:00
|
|
|
const html = `<!DOCTYPE html>
|
2016-03-07 07:25:38 +08:00
|
|
|
${css}
|
2016-03-05 07:21:06 +08:00
|
|
|
<body>
|
|
|
|
<div class="theme-option active-${this.props.active}">
|
|
|
|
<div class="theme-name ">${this.props.theme.displayName}</div>
|
|
|
|
<div class="swatches" style="display:flex;flex-direction:row;">
|
|
|
|
<div class="swatch font-color"></div>
|
|
|
|
<div class="swatch active-color"></div>
|
|
|
|
<div class="swatch toolbar-color"></div>
|
|
|
|
</div>
|
|
|
|
<div class="divider-black"></div>
|
|
|
|
<div class="divider-white"></div>
|
|
|
|
<div class="strip"></div>
|
|
|
|
</div>
|
|
|
|
</body>`
|
|
|
|
|
|
|
|
doc.open();
|
|
|
|
doc.write(html);
|
|
|
|
doc.close();
|
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
|
|
|
return (
|
2016-03-11 06:10:48 +08:00
|
|
|
<div className="clickable-theme-option" onMouseDown={this.props.onSelect}>
|
|
|
|
<EventedIFrame
|
|
|
|
ref="iframe"
|
2016-04-06 04:43:36 +08:00
|
|
|
className={`theme-preview-${this.props.theme.name.replace(/\./g, '-')}`}
|
2016-03-11 06:10:48 +08:00
|
|
|
frameBorder="0"
|
2016-03-11 07:18:52 +08:00
|
|
|
width="115px"
|
|
|
|
height="70px"
|
2016-05-07 07:06:16 +08:00
|
|
|
flex="1"
|
|
|
|
/>
|
2016-03-09 09:08:09 +08:00
|
|
|
</div>
|
2016-03-05 07:21:06 +08:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default ThemeOption;
|