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 WindowControls from '../components/WindowControls' import { COLORS, DEFAULT_LANGUAGE, LANGUAGE_HASH } from '../lib/constants' const DEFAULT_SETTINGS = { paddingVertical: '50px', paddingHorizontal: '50px', marginVertical: '45px', marginHorizontal: '45px', background: '#fed0ec', theme: 'dracula', 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) } componentDidMount() { this.setState({ loading: false }) this.handleLanguageChange(this.props.children) } componentWillReceiveProps (newProps) { this.handleLanguageChange(newProps.children, { customProps: newProps }) } handleLanguageChange(newCode, config) { const props = (config && config.customProps) || this.props if (props.config.language.name === 'Auto') { // try to set the language const detectedLanguage = hljs.highlightAuto(newCode).language const languageModule = LANGUAGE_HASH[detectedLanguage] if (languageModule) { this.setState({ language: languageModule }) } } 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 ? this.state.language.module : '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