mirror of
https://github.com/naturalcrit/homebrewery.git
synced 2026-01-28 04:59:44 +00:00
refactor CodeMirror library instantiation
This commit is contained in:
36
shared/naturalcrit/codeEditor/code-mirror.js
Normal file
36
shared/naturalcrit/codeEditor/code-mirror.js
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
let CodeMirror;
|
||||||
|
if(typeof navigator !== 'undefined'){
|
||||||
|
CodeMirror = require('codemirror');
|
||||||
|
|
||||||
|
//Language Modes
|
||||||
|
require('codemirror/mode/gfm/gfm.js'); //Github flavoured markdown
|
||||||
|
require('codemirror/mode/css/css.js');
|
||||||
|
require('codemirror/mode/javascript/javascript.js');
|
||||||
|
|
||||||
|
//Addons
|
||||||
|
//Code folding
|
||||||
|
require('codemirror/addon/fold/foldcode.js');
|
||||||
|
require('codemirror/addon/fold/foldgutter.js');
|
||||||
|
//Search and replace
|
||||||
|
require('codemirror/addon/search/search.js');
|
||||||
|
require('codemirror/addon/search/searchcursor.js');
|
||||||
|
require('codemirror/addon/search/jump-to-line.js');
|
||||||
|
require('codemirror/addon/search/match-highlighter.js');
|
||||||
|
require('codemirror/addon/search/matchesonscrollbar.js');
|
||||||
|
require('codemirror/addon/dialog/dialog.js');
|
||||||
|
//Trailing space highlighting
|
||||||
|
// require('codemirror/addon/edit/trailingspace.js');
|
||||||
|
//Active line highlighting
|
||||||
|
// require('codemirror/addon/selection/active-line.js');
|
||||||
|
//Scroll past last line
|
||||||
|
require('codemirror/addon/scroll/scrollpastend.js');
|
||||||
|
//Auto-closing
|
||||||
|
//XML code folding is a requirement of the auto-closing tag feature and is not enabled
|
||||||
|
require('codemirror/addon/fold/xml-fold.js');
|
||||||
|
require('codemirror/addon/edit/closetag.js');
|
||||||
|
|
||||||
|
const foldCode = require('./helpers/fold-code');
|
||||||
|
foldCode.registerHomebreweryHelper(CodeMirror);
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = CodeMirror;
|
||||||
@@ -5,43 +5,8 @@ const createClass = require('create-react-class');
|
|||||||
const _ = require('lodash');
|
const _ = require('lodash');
|
||||||
const cx = require('classnames');
|
const cx = require('classnames');
|
||||||
const closeTag = require('./helpers/close-tag');
|
const closeTag = require('./helpers/close-tag');
|
||||||
const { SNIPPET_TYPE, FIELD_TYPE } = require('./helpers/widget-elements/constants');
|
|
||||||
const Hints = require('./helpers/widget-elements/hints/hints.jsx');
|
const Hints = require('./helpers/widget-elements/hints/hints.jsx');
|
||||||
|
const CodeMirror = require('./code-mirror.js');
|
||||||
let CodeMirror;
|
|
||||||
if(typeof navigator !== 'undefined'){
|
|
||||||
CodeMirror = require('codemirror');
|
|
||||||
|
|
||||||
//Language Modes
|
|
||||||
require('codemirror/mode/gfm/gfm.js'); //Github flavoured markdown
|
|
||||||
require('codemirror/mode/css/css.js');
|
|
||||||
require('codemirror/mode/javascript/javascript.js');
|
|
||||||
|
|
||||||
//Addons
|
|
||||||
//Code folding
|
|
||||||
require('codemirror/addon/fold/foldcode.js');
|
|
||||||
require('codemirror/addon/fold/foldgutter.js');
|
|
||||||
//Search and replace
|
|
||||||
require('codemirror/addon/search/search.js');
|
|
||||||
require('codemirror/addon/search/searchcursor.js');
|
|
||||||
require('codemirror/addon/search/jump-to-line.js');
|
|
||||||
require('codemirror/addon/search/match-highlighter.js');
|
|
||||||
require('codemirror/addon/search/matchesonscrollbar.js');
|
|
||||||
require('codemirror/addon/dialog/dialog.js');
|
|
||||||
//Trailing space highlighting
|
|
||||||
// require('codemirror/addon/edit/trailingspace.js');
|
|
||||||
//Active line highlighting
|
|
||||||
// require('codemirror/addon/selection/active-line.js');
|
|
||||||
//Scroll past last line
|
|
||||||
require('codemirror/addon/scroll/scrollpastend.js');
|
|
||||||
//Auto-closing
|
|
||||||
//XML code folding is a requirement of the auto-closing tag feature and is not enabled
|
|
||||||
require('codemirror/addon/fold/xml-fold.js');
|
|
||||||
require('codemirror/addon/edit/closetag.js');
|
|
||||||
|
|
||||||
const foldCode = require('./helpers/fold-code');
|
|
||||||
foldCode.registerHomebreweryHelper(CodeMirror);
|
|
||||||
}
|
|
||||||
|
|
||||||
const themeWidgets = require('../../../themes/V3/5ePHB/widgets');
|
const themeWidgets = require('../../../themes/V3/5ePHB/widgets');
|
||||||
|
|
||||||
@@ -182,7 +147,7 @@ const CodeEditor = createClass({
|
|||||||
closeTag.autoCloseCurlyBraces(CodeMirror, this.codeMirror);
|
closeTag.autoCloseCurlyBraces(CodeMirror, this.codeMirror);
|
||||||
|
|
||||||
this.setState({
|
this.setState({
|
||||||
widgetUtils : require('./helpers/widgets')(CodeMirror, themeWidgets, this.codeMirror, (hints, field)=>{
|
widgetUtils : require('./helpers/widgets')(themeWidgets, this.codeMirror, (hints, field)=>{
|
||||||
this.setState({
|
this.setState({
|
||||||
hints,
|
hints,
|
||||||
hintsField : field
|
hintsField : field
|
||||||
|
|||||||
@@ -2,20 +2,20 @@ const React = require('react');
|
|||||||
const createClass = require('create-react-class');
|
const createClass = require('create-react-class');
|
||||||
const _ = require('lodash');
|
const _ = require('lodash');
|
||||||
require('./checkbox.less');
|
require('./checkbox.less');
|
||||||
|
const CodeMirror = require('../../../code-mirror.js');
|
||||||
|
|
||||||
const Checkbox = createClass({
|
const Checkbox = createClass({
|
||||||
getDefaultProps : function() {
|
getDefaultProps : function() {
|
||||||
return {
|
return {
|
||||||
CodeMirror : {},
|
value : '',
|
||||||
value : '',
|
prefix : '',
|
||||||
prefix : '',
|
cm : {},
|
||||||
cm : {},
|
n : -1
|
||||||
n : -1
|
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
|
||||||
handleChange : function (e) {
|
handleChange : function (e) {
|
||||||
const { cm, n, value, prefix, CodeMirror } = this.props;
|
const { cm, n, value, prefix } = this.props;
|
||||||
const { text } = cm.lineInfo(n);
|
const { text } = cm.lineInfo(n);
|
||||||
const updatedPrefix = `{{${prefix}`;
|
const updatedPrefix = `{{${prefix}`;
|
||||||
if(e.target?.checked)
|
if(e.target?.checked)
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ const React = require('react');
|
|||||||
const createClass = require('create-react-class');
|
const createClass = require('create-react-class');
|
||||||
const _ = require('lodash');
|
const _ = require('lodash');
|
||||||
const { NUMBER_PATTERN, HINT_TYPE, PATTERNS } = require('../constants');
|
const { NUMBER_PATTERN, HINT_TYPE, PATTERNS } = require('../constants');
|
||||||
|
const CodeMirror = require('../../../code-mirror.js');
|
||||||
|
|
||||||
const DEFAULT_WIDTH = '30px';
|
const DEFAULT_WIDTH = '30px';
|
||||||
|
|
||||||
@@ -121,7 +122,7 @@ const Text = createClass({
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
onChange : function (e){
|
onChange : function (e){
|
||||||
const { cm, text, field, n, CodeMirror } = this.props;
|
const { cm, text, field, n } = this.props;
|
||||||
const pattern = PATTERNS.field[field.type](field.name);
|
const pattern = PATTERNS.field[field.type](field.name);
|
||||||
const [_, label, current] = text.match(pattern) ?? [null, field.name, ''];
|
const [_, label, current] = text.match(pattern) ?? [null, field.name, ''];
|
||||||
let index = text.indexOf(`${label}:${current}`);
|
let index = text.indexOf(`${label}:${current}`);
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ const ReactDOM = require('react-dom');
|
|||||||
const { PATTERNS, FIELD_TYPE, HINT_TYPE, UNITS } = require('./widget-elements/constants');
|
const { PATTERNS, FIELD_TYPE, HINT_TYPE, UNITS } = require('./widget-elements/constants');
|
||||||
require('./widget-elements/hints/hints.jsx');
|
require('./widget-elements/hints/hints.jsx');
|
||||||
const { Text, Checkbox } = require('./widget-elements');
|
const { Text, Checkbox } = require('./widget-elements');
|
||||||
|
const CodeMirror = require('../code-mirror.js');
|
||||||
|
|
||||||
// See https://codemirror.net/5/addon/hint/css-hint.js for code reference
|
// See https://codemirror.net/5/addon/hint/css-hint.js for code reference
|
||||||
const pseudoClasses = { 'active' : 1, 'after' : 1, 'before' : 1, 'checked' : 1, 'default' : 1,
|
const pseudoClasses = { 'active' : 1, 'after' : 1, 'before' : 1, 'checked' : 1, 'default' : 1,
|
||||||
@@ -17,7 +18,7 @@ const pseudoClasses = { 'active' : 1, 'after' : 1, 'before'
|
|||||||
|
|
||||||
const genKey = (...args)=>args.join('-');
|
const genKey = (...args)=>args.join('-');
|
||||||
|
|
||||||
module.exports = function(CodeMirror, widgets, cm, setHints) {
|
module.exports = function(widgets, cm, setHints) {
|
||||||
const spec = CodeMirror.resolveMode('text/css');
|
const spec = CodeMirror.resolveMode('text/css');
|
||||||
const headless = CodeMirror(()=>{});
|
const headless = CodeMirror(()=>{});
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user