import { EOL } from 'os'; import * as hljs from 'highlight.js'; import React from 'react'; import domtoimage from 'dom-to-image'; import CodeMirror from 'react-codemirror'; import Spinner from 'react-spinner'; import toHash from 'tohash'; import WindowControls from '../components/WindowControls'; import { COLORS, DEFAULT_LANGUAGE, LANGUAGES } from '../lib/constants'; const LANGUAGE_HASH = toHash(LANGUAGES, 'module'); const DEFAULT_SETTINGS = { paddingVertical: '50px', paddingHorizontal: '50px', marginVertical: '45px', marginHorizontal: '45px', background: '#fed0ec', theme: 'seti', language: DEFAULT_LANGUAGE }; class Carbon extends React.Component { constructor(props) { super(props); this.state = { loading: true, language: props.config.language }; this.handleLanguageChange = this.handleLanguageChange.bind(this); this.codeUpdated = this.codeUpdated.bind(this); } componentDidMount() { this.setState({ loading: false }); this.handleLanguageChange(this.props.children); } componentWillReceiveProps(newProps) { this.handleLanguageChange(newProps.children, { customProps: newProps }); } codeUpdated(newCode) { this.handleLanguageChange(newCode); this.props.updateCode(newCode); } handleLanguageChange(newCode, config) { const props = (config && config.customProps) || this.props; if (props.config.language === 'auto') { // try to set the language const detectedLanguage = hljs.highlightAuto(newCode).language; const languageModule = LANGUAGE_HASH[detectedLanguage]; if (languageModule) { this.setState({ language: languageModule.module }); } } else { this.setState({ language: props.config.language }); } } render() { const config = Object.assign(DEFAULT_SETTINGS, this.props.config); const options = { lineNumbers: false, mode: this.state.language || 'plaintext', theme: config.theme, scrollBarStyle: null, viewportMargin: Infinity, lineWrapping: true }; // create styles const containerStyle = { background: config.background, padding: `${config.paddingVertical} ${config.paddingHorizontal}` }; // set content to spinner if loading, else editor let content = (
); if (this.state.loading === false) { content = (
{config.windowControls ? : null}
); } return (
{content}
); } } export default Carbon;