Merge pull request #399 from nonameShijian/PR-Branch
编辑器函数es5 to es6,修复报错问题
This commit is contained in:
commit
e6b5991ec3
158
game/game.js
158
game/game.js
|
@ -7409,7 +7409,7 @@
|
||||||
codeMirrorReady:(node,editor)=>{
|
codeMirrorReady:(node,editor)=>{
|
||||||
ui.window.appendChild(node);
|
ui.window.appendChild(node);
|
||||||
node.style.fontSize=20/game.documentZoom+'px';
|
node.style.fontSize=20/game.documentZoom+'px';
|
||||||
var mirror=window.CodeMirror(editor,{
|
const mirror=window.CodeMirror(editor,{
|
||||||
value:node.code,
|
value:node.code,
|
||||||
mode:"javascript",
|
mode:"javascript",
|
||||||
lineWrapping:!lib.config.touchscreen&&lib.config.mousewheel,
|
lineWrapping:!lib.config.touchscreen&&lib.config.mousewheel,
|
||||||
|
@ -7428,11 +7428,9 @@
|
||||||
lib.setScroll(editor.querySelector('.CodeMirror-scroll'));
|
lib.setScroll(editor.querySelector('.CodeMirror-scroll'));
|
||||||
node.aced=true;
|
node.aced=true;
|
||||||
node.editor=mirror;
|
node.editor=mirror;
|
||||||
setTimeout(()=>{
|
setTimeout(()=>mirror.refresh(),0);
|
||||||
mirror.refresh();
|
node.editor.on('change',(e,change)=>{
|
||||||
},0);
|
let code;
|
||||||
node.editor.on('change',function(e,change){
|
|
||||||
var code;
|
|
||||||
if(node.editor){
|
if(node.editor){
|
||||||
code=node.editor.getValue();
|
code=node.editor.getValue();
|
||||||
}else if(node.textarea){
|
}else if(node.textarea){
|
||||||
|
@ -7446,69 +7444,68 @@
|
||||||
node.editor.showHint();
|
node.editor.showHint();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
CodeMirror.registerHelper('hint','javascript',function(editor,options){
|
//防止每次输出字符都创建以下元素
|
||||||
|
const event=_status.event;
|
||||||
|
const player=ui.create.player().init('sunce');
|
||||||
|
const card=game.createCard();
|
||||||
|
//覆盖原本的javascript提示
|
||||||
|
CodeMirror.registerHelper('hint','javascript',(editor,options)=>{
|
||||||
//Find the token at the cursor
|
//Find the token at the cursor
|
||||||
var cur=editor.getCursor(),
|
let cur=editor.getCursor(),
|
||||||
token=editor.getTokenAt(cur);
|
token=editor.getTokenAt(cur);
|
||||||
if(/\b(?:string|comment)\b/.test(token.type)) return;
|
if(/\b(?:string|comment)\b/.test(token.type)) return;
|
||||||
var innerMode=CodeMirror.innerMode(editor.getMode(),token.state);
|
const innerMode=CodeMirror.innerMode(editor.getMode(),token.state);
|
||||||
if (innerMode.mode.helperType==="json") return;
|
if (innerMode.mode.helperType==="json") return;
|
||||||
token.state=innerMode.state;
|
token.state=innerMode.state;
|
||||||
//If it's not a 'word-style' token, ignore the token.
|
//If it's not a 'word-style' token, ignore the token.
|
||||||
if (!/^[\w$_]*$/.test(token.string)){
|
if (!/^[\w$_]*$/.test(token.string)){
|
||||||
token={
|
token={
|
||||||
start:cur.ch,end:cur.ch,string:"",state:token.state,
|
start:cur.ch,
|
||||||
|
end:cur.ch,
|
||||||
|
string:"",
|
||||||
|
state:token.state,
|
||||||
type:token.string=="."?"property":null
|
type:token.string=="."?"property":null
|
||||||
};
|
};
|
||||||
}else if(token.end>cur.ch){
|
}else if(token.end>cur.ch){
|
||||||
token.end=cur.ch;
|
token.end=cur.ch;
|
||||||
token.string=token.string.slice(0,cur.ch- oken.start);
|
token.string=token.string.slice(0,cur.ch- oken.start);
|
||||||
}
|
}
|
||||||
var tprop=token;
|
let tprop=token;
|
||||||
|
let context;
|
||||||
//If it is a property, find out what it is a property of.
|
//If it is a property, find out what it is a property of.
|
||||||
while (tprop.type=="property"){
|
while (tprop.type=="property"){
|
||||||
tprop=editor.getTokenAt(CodeMirror.Pos(cur.line,tprop.start));
|
tprop=editor.getTokenAt(CodeMirror.Pos(cur.line,tprop.start));
|
||||||
if(tprop.string!=".") return;
|
if(tprop.string!=".") return;
|
||||||
tprop=editor.getTokenAt(CodeMirror.Pos(cur.line,tprop.start));
|
tprop=editor.getTokenAt(CodeMirror.Pos(cur.line,tprop.start));
|
||||||
if(!context) var context=[];
|
if(!context) context=[];
|
||||||
context.push(tprop);
|
context.push(tprop);
|
||||||
}
|
}
|
||||||
//console.log(token);
|
const list=[];
|
||||||
//console.log(context);
|
|
||||||
var list=[];
|
|
||||||
if(Array.isArray(context)){
|
if(Array.isArray(context)){
|
||||||
try {
|
try {
|
||||||
var event=_status.event;
|
const code=context.length==1?context[0].string:context.reduceRight((pre,cur)=>(pre.string||pre)+'.'+cur.string);
|
||||||
var player=ui.create.player().init('sunce');
|
const obj=eval(code);
|
||||||
var card=game.createCard();
|
const keys=Object.getOwnPropertyNames(obj).filter(key=>key.startsWith(token.string));
|
||||||
var code=context.length==1?context[0].string:context.reduceRight((pre,cur)=>(pre.string||pre)+'.'+cur.string);
|
|
||||||
var obj=eval(code);
|
|
||||||
//console.log(obj);
|
|
||||||
var keys=Object.getOwnPropertyNames(obj).filter(key=>key.startsWith(token.string));
|
|
||||||
list.addArray(keys);
|
list.addArray(keys);
|
||||||
//console.log(list);
|
|
||||||
}catch(_){ return;}
|
}catch(_){ return;}
|
||||||
}else if(token&&typeof token.string=='string'){
|
}else if(token&&typeof token.string=='string'){
|
||||||
var javascriptKeywords=("break case catch class const continue debugger default delete do else export extends from false finally for function " +
|
const javascriptKeywords=("break case catch class const continue debugger default delete do else export extends from false finally for function " +
|
||||||
"if in import instanceof let new null return super switch this throw true try typeof var void while with yield").split(" ");
|
"if in import instanceof let new null return super switch this throw true try typeof var void while with yield").split(" ");
|
||||||
var coffeescriptKeywords=("and break catch class continue delete do else extends false finally for " +
|
const coffeescriptKeywords=("and break catch class continue delete do else extends false finally for " +
|
||||||
"if in instanceof isnt new no not null of off on or return switch then throw true try typeof until void while with yes").split(" ");
|
"if in instanceof isnt new no not null of off on or return switch then throw true try typeof until void while with yes").split(" ");
|
||||||
|
const keys=['player','card','lib','game','ui','get','ai','_status'].concat(javascriptKeywords).concat(coffeescriptKeywords).concat(Object.getOwnPropertyNames(window));
|
||||||
var keys=['player','card','lib','game','ui','get','ai','_status'].concat(javascriptKeywords).concat(coffeescriptKeywords).concat(Object.getOwnPropertyNames(window));
|
const start=token.string;
|
||||||
|
|
||||||
var start=token.string;
|
|
||||||
function maybeAdd(str){
|
function maybeAdd(str){
|
||||||
if(str.lastIndexOf(start,0)==0&&!list.includes(str)) list.push(str);
|
if(str.lastIndexOf(start,0)==0&&!list.includes(str)) list.push(str);
|
||||||
}
|
}
|
||||||
for(var v=token.state.localVars;v;v=v.next) maybeAdd(v.name);
|
for(let v=token.state.localVars;v;v=v.next) maybeAdd(v.name);
|
||||||
for(var c=token.state.context;c;c=c.prev) for (var v=c.vars;v;v=v.next) maybeAdd(v.name)
|
for(let c=token.state.context;c;c=c.prev) for (let v=c.vars;v;v=v.next) maybeAdd(v.name)
|
||||||
for(var v=token.state.globalVars;v;v=v.next) maybeAdd(v.name);
|
for(let v=token.state.globalVars;v;v=v.next) maybeAdd(v.name);
|
||||||
if(options&&options.additionalContext!=null) for(var key in options.additionalContext) maybeAdd(key);
|
if(options&&options.additionalContext!=null) for(let key in options.additionalContext) maybeAdd(key);
|
||||||
list.addArray(keys);
|
list.addArray(keys);
|
||||||
list=list.filter(key=>key.startsWith(token.string));
|
|
||||||
}
|
}
|
||||||
return {
|
return {
|
||||||
list,
|
list:list.filter(key=>key.startsWith(token.string)),
|
||||||
from:CodeMirror.Pos(cur.line,token.start),
|
from:CodeMirror.Pos(cur.line,token.start),
|
||||||
to:CodeMirror.Pos(cur.line,token.end),
|
to:CodeMirror.Pos(cur.line,token.end),
|
||||||
};
|
};
|
||||||
|
@ -40663,29 +40660,29 @@
|
||||||
* @param {Function} saveInput
|
* @param {Function} saveInput
|
||||||
*/
|
*/
|
||||||
editor:function(container,saveInput){
|
editor:function(container,saveInput){
|
||||||
var createList=[];
|
const createList=[];
|
||||||
var containerDelete=container.delete;
|
const containerDelete=container.delete;
|
||||||
//删除container的时候,删除创建的ul列表
|
//删除container的时候,删除创建的ul列表
|
||||||
container.delete=function(){
|
container.delete=function(){
|
||||||
for (var i=createList.length-1;i>=0;i--){
|
for (let i=createList.length-1;i>=0;i--){
|
||||||
createList[i].parentNode&&createList[i].parentNode.removeChild(createList[i]);
|
createList[i].parentNode&&createList[i].parentNode.removeChild(createList[i]);
|
||||||
}
|
}
|
||||||
containerDelete.apply(this, arguments);
|
containerDelete.apply(this, arguments);
|
||||||
}
|
}
|
||||||
//创建ul列表
|
//创建ul列表
|
||||||
var createMenu=function(pos,self,List,click){
|
const createMenu=function(pos,self,List,click){
|
||||||
if (self&&self.createMenu) return false;
|
if (self&&self.createMenu) return false;
|
||||||
var parent=self.parentNode;
|
const parent=self.parentNode;
|
||||||
if (parent){
|
if (parent){
|
||||||
for(var i=0;i<parent.childElementCount;i++){
|
for(let i=0;i<parent.childElementCount;i++){
|
||||||
var node=parent.childNodes[i];
|
const node=parent.childNodes[i];
|
||||||
node!=self&&node.createMenu&&closeMenu(node);
|
node!=self&&node.createMenu&&closeMenu.call(node);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
var editor=container.editor;
|
const editor=container.editor;
|
||||||
if(!editor) return false;
|
if(!editor) return false;
|
||||||
self.style.background='#08f';
|
self.style.background='#08f';
|
||||||
var ul=document.createElement('ul');
|
const ul=document.createElement('ul');
|
||||||
container.css.call(ul,{
|
container.css.call(ul,{
|
||||||
position:'absolute',
|
position:'absolute',
|
||||||
top:pos.bottom/game.documentZoom+'px',
|
top:pos.bottom/game.documentZoom+'px',
|
||||||
|
@ -40695,38 +40692,35 @@
|
||||||
//'font-family':'shousha',
|
//'font-family':'shousha',
|
||||||
'font-size':20/game.documentZoom+'px',
|
'font-size':20/game.documentZoom+'px',
|
||||||
});
|
});
|
||||||
var theme=editor.options.theme;
|
const theme=editor.options.theme;
|
||||||
lib.setScroll(ul);
|
lib.setScroll(ul);
|
||||||
lib.setMousewheel(ul);
|
lib.setMousewheel(ul);
|
||||||
ul.className="CodeMirror-hints "+theme;
|
ul.className="CodeMirror-hints "+theme;
|
||||||
var getActive=function(){
|
const getActive=()=>{
|
||||||
var i=0;
|
let i=0;
|
||||||
while(i<ul.childElementCount){
|
while(i<ul.childElementCount){
|
||||||
if(ul.childNodes[i].classList.contains('CodeMirror-hint-active')){
|
if(ul.childNodes[i].classList.contains('CodeMirror-hint-active')) break;
|
||||||
break;
|
else i++;
|
||||||
}else{
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return i;
|
return i;
|
||||||
}
|
};
|
||||||
var setActive=function(i){
|
const setActive=i=>{
|
||||||
ul.childNodes[getActive()].classList.remove('CodeMirror-hint-active');
|
ul.childNodes[getActive()].classList.remove('CodeMirror-hint-active');
|
||||||
ul.childNodes[i].classList.add('CodeMirror-hint-active');
|
ul.childNodes[i].classList.add('CodeMirror-hint-active');
|
||||||
return i;
|
return i;
|
||||||
}
|
};
|
||||||
if (List&&List.length&&click) {
|
if (List&&List.length&&click) {
|
||||||
for(var i=0;i<List.length;++i) {
|
for(let i=0;i<List.length;++i) {
|
||||||
var elt=ul.appendChild(document.createElement("li"));
|
const elt=ul.appendChild(document.createElement("li"));
|
||||||
elt.style.color='black';
|
elt.style.color='black';
|
||||||
elt.style.boxShadow='none';
|
elt.style.boxShadow='none';
|
||||||
var cur=List[i];
|
const cur=List[i];
|
||||||
if(cur instanceof HTMLElement){
|
if(cur instanceof HTMLElement){
|
||||||
elt.appendChild(cur);
|
elt.appendChild(cur);
|
||||||
}else{
|
}else{
|
||||||
elt.innerHTML=cur;
|
elt.innerHTML=cur;
|
||||||
}
|
}
|
||||||
var className="CodeMirror-hint"+(i!=0?"":" "+"CodeMirror-hint-active");
|
let className="CodeMirror-hint"+(i!=0?"":" "+"CodeMirror-hint-active");
|
||||||
if(cur.className!=null) className=cur.className+" "+className;
|
if(cur.className!=null) className=cur.className+" "+className;
|
||||||
elt.className=className;
|
elt.className=className;
|
||||||
elt.hintId=i;
|
elt.hintId=i;
|
||||||
|
@ -40742,8 +40736,8 @@
|
||||||
return ul;
|
return ul;
|
||||||
};
|
};
|
||||||
//关闭ul列表
|
//关闭ul列表
|
||||||
var closeMenu=function(){
|
const closeMenu=function(){
|
||||||
var ul=this.createMenu;
|
const ul=this.createMenu;
|
||||||
if(!ul) return false;
|
if(!ul) return false;
|
||||||
if(ul.parentNode) ul.parentNode.removeChild(ul);
|
if(ul.parentNode) ul.parentNode.removeChild(ul);
|
||||||
this.style.background='';
|
this.style.background='';
|
||||||
|
@ -40751,57 +40745,57 @@
|
||||||
createList.remove(ul);
|
createList.remove(ul);
|
||||||
return ul;
|
return ul;
|
||||||
};
|
};
|
||||||
var editorpage=ui.create.div(container);
|
const editorpage=ui.create.div(container);
|
||||||
var discardConfig=ui.create.div('.editbutton','取消',editorpage,function(){
|
const discardConfig=ui.create.div('.editbutton','取消',editorpage,function(){
|
||||||
ui.window.classList.remove('shortcutpaused');
|
ui.window.classList.remove('shortcutpaused');
|
||||||
ui.window.classList.remove('systempaused');
|
ui.window.classList.remove('systempaused');
|
||||||
container.delete(null);
|
container.delete(null);
|
||||||
delete window.saveNonameInput;
|
delete window.saveNonameInput;
|
||||||
});
|
});
|
||||||
var saveConfig=ui.create.div('.editbutton','保存',editorpage,saveInput);
|
const saveConfig=ui.create.div('.editbutton','保存',editorpage,saveInput);
|
||||||
var theme=ui.create.div('.editbutton','主题',editorpage,function(){
|
const theme=ui.create.div('.editbutton','主题',editorpage,function(){
|
||||||
if(this&&this.createMenu){
|
if(this&&this.createMenu){
|
||||||
return closeMenu.call(this);
|
return closeMenu.call(this);
|
||||||
}
|
}
|
||||||
//主题列表
|
//主题列表
|
||||||
var list=['mdn-like','mbo'];
|
const list=['mdn-like','mbo'];
|
||||||
//正在使用的主题
|
//正在使用的主题
|
||||||
var active = container.editor.options.theme;
|
const active=container.editor.options.theme;
|
||||||
//排个序
|
//排个序
|
||||||
list.remove(active).splice(0,0,active);
|
list.remove(active).splice(0,0,active);
|
||||||
//this
|
//this
|
||||||
var self=this;
|
const self=this;
|
||||||
//元素位置
|
//元素位置
|
||||||
var pos=this.getBoundingClientRect();
|
const pos=this.getBoundingClientRect();
|
||||||
//点击事件
|
//点击事件
|
||||||
var click=function(e){
|
const click=function(e){
|
||||||
var theme=this.innerHTML;
|
const theme=this.innerHTML;
|
||||||
container.editor.setOption("theme",theme);
|
container.editor.setOption("theme",theme);
|
||||||
setTimeout(()=>container.editor.refresh(),0);
|
setTimeout(()=>container.editor.refresh(),0);
|
||||||
game.saveConfig('codeMirror_theme', theme);
|
game.saveConfig('codeMirror_theme', theme);
|
||||||
closeMenu.call(self);
|
closeMenu.call(self);
|
||||||
};
|
};
|
||||||
var ul=createMenu(pos,self,list,click);
|
const ul=createMenu(pos,self,list,click);
|
||||||
this.createMenu=ul;
|
this.createMenu=ul;
|
||||||
});
|
});
|
||||||
var edit=ui.create.div('.editbutton','编辑',editorpage,function(){
|
const edit=ui.create.div('.editbutton','编辑',editorpage,function(){
|
||||||
if(this&&this.createMenu){
|
if(this&&this.createMenu){
|
||||||
return closeMenu.call(this);
|
return closeMenu.call(this);
|
||||||
}
|
}
|
||||||
var self=this;
|
const self=this;
|
||||||
var pos=this.getBoundingClientRect();
|
const pos=this.getBoundingClientRect();
|
||||||
var list=['撤销\t\tCtrl+Z', '恢复撤销\tCtrl+Y'/* , '全选\t\tCtrl+A' */];
|
const list=['撤销\t\tCtrl+Z', '恢复撤销\tCtrl+Y'/* , '全选\t\tCtrl+A' */];
|
||||||
var click=function(e){
|
const click=function(e){
|
||||||
var num=this.innerHTML.indexOf("Ctrl");
|
const num=this.innerHTML.indexOf("Ctrl");
|
||||||
var inner=this.innerHTML.slice(num).replace("+", "-");
|
const inner=this.innerHTML.slice(num).replace("+", "-");
|
||||||
container.editor.execCommand(container.editor.options.extraKeys[inner]);
|
container.editor.execCommand(container.editor.options.extraKeys[inner]);
|
||||||
setTimeout(()=>container.editor.refresh(),0);
|
setTimeout(()=>container.editor.refresh(),0);
|
||||||
closeMenu.call(self);
|
closeMenu.call(self);
|
||||||
};
|
};
|
||||||
var ul=createMenu(pos,self,list,click);
|
const ul=createMenu(pos,self,list,click);
|
||||||
this.createMenu=ul;
|
this.createMenu=ul;
|
||||||
});
|
});
|
||||||
var editor=ui.create.div(editorpage);
|
const editor=ui.create.div(editorpage);
|
||||||
return editor;
|
return editor;
|
||||||
},
|
},
|
||||||
cardTempName:function(card,applyNode){
|
cardTempName:function(card,applyNode){
|
||||||
|
|
Loading…
Reference in New Issue