require('./newPage.less'); const React = require('react'); const createClass = require('create-react-class'); const _ = require('lodash'); const request = require('superagent'); const Markdown = require('naturalcrit/markdown.js'); const Nav = require('naturalcrit/nav/nav.jsx'); const Navbar = require('../../navbar/navbar.jsx'); const AccountNavItem = require('../../navbar/account.navitem.jsx'); const RecentNavItem = require('../../navbar/recent.navitem.jsx').both; const IssueNavItem = require('../../navbar/issue.navitem.jsx'); const SplitPane = require('naturalcrit/splitPane/splitPane.jsx'); const Editor = require('../../editor/editor.jsx'); const BrewRenderer = require('../../brewRenderer/brewRenderer.jsx'); const KEY = 'homebrewery-new'; const NewPage = createClass({ getDefaultProps : function() { return { brew : { text : '', shareId : null, editId : null, createdAt : null, updatedAt : null, gDrive : false, title : '', description : '', tags : '', published : false, authors : [], systems : [] } }; }, getInitialState : function() { return { brew : { text : this.props.brew.text, gDrive : false, title : '', description : '', tags : '', published : false, authors : [], systems : [] }, isSaving : false, saveGoogle : (global.account && global.account.googleId ? true : false), errors : [] }; }, componentDidMount : function() { const storage = localStorage.getItem(KEY); if(!this.props.brew.text && storage){ this.setState({ brew : { text: storage } }); } document.addEventListener('keydown', this.handleControlKeys); }, componentWillUnmount : function() { document.removeEventListener('keydown', this.handleControlKeys); }, handleControlKeys : function(e){ if(!(e.ctrlKey || e.metaKey)) return; const S_KEY = 83; const P_KEY = 80; if(e.keyCode == S_KEY) this.save(); if(e.keyCode == P_KEY) this.print(); if(e.keyCode == P_KEY || e.keyCode == S_KEY){ e.stopPropagation(); e.preventDefault(); } }, handleSplitMove : function(){ this.refs.editor.update(); }, handleMetadataChange : function(metadata){ this.setState({ brew : _.merge({}, this.state.brew, metadata) }); }, handleTextChange : function(text){ this.setState({ brew : { text: text }, errors : Markdown.validate(text) }); localStorage.setItem(KEY, text); }, save : async function(){ this.setState({ isSaving : true }); console.log('saving new brew'); if(this.state.saveGoogle) { const res = await request .post('/api/newGoogle/') .send(this.state.brew) .catch((err)=>{ console.log(err.status === 401 ? 'Not signed in!' : 'Error Creating New Google Brew!'); this.setState({ isSaving: false }); return; }); const brew = res.body; localStorage.removeItem(KEY); window.location = `/edit/${brew.googleId}${brew.editId}`; } else { request.post('/api') .send(this.state.brew) .end((err, res)=>{ if(err){ this.setState({ isSaving : false }); return; } window.onbeforeunload = function(){}; const brew = res.body; localStorage.removeItem(KEY); window.location = `/edit/${brew.editId}`; }); } }, renderSaveButton : function(){ if(this.state.isSaving){ return save... ; } else { return save ; } }, print : function(){ localStorage.setItem('print', this.state.brew.text); window.open('/print?dialog=true&local=print', '_blank'); }, renderLocalPrintButton : function(){ return get PDF ; }, renderNavbar : function(){ return {this.state.brew.title} {this.renderSaveButton()} {this.renderLocalPrintButton()} ; }, render : function(){ return
{this.renderNavbar()}
; } }); module.exports = NewPage;