|
9 | 9 |
|
10 | 10 | <title>monaco editor setup</title> |
11 | 11 |
|
12 | | - <base href='https://javascript-2020.github.io/blog/25-08-25/monaco-editor-setup/monaco-editor-setup.html'> |
| 12 | + <base href='https://javascript-2020.github.io/blog/25-08-25/monaco-editor-setup/'> |
| 13 | + |
13 | 14 | <link rel=canonical href='https://ext-code.com/blog/25-08-25/monaco-editor-setup/monaco-editor-setup.html'> |
14 | 15 |
|
15 | 16 | <meta name=viewport content='width=device-width, initial-scale=1'> |
|
19 | 20 | <script src='https://ajaxorg.github.io/ace-builds/src-noconflict/ace.js'></script> |
20 | 21 |
|
21 | 22 |
|
| 23 | + <script src='https://libs.ext-code.com/js/dom/component/component.js'></script> |
| 24 | + |
22 | 25 | <script init> |
23 | 26 | console.clear(); |
24 | 27 | console.json=v=>console.log(JSON.stringify(v,null,4)); |
|
32 | 35 | var datatype; |
33 | 36 | var menumod; |
34 | 37 | var code; |
| 38 | + |
35 | 39 |
|
36 | | - var mod = {}; |
37 | | - |
38 | | - |
| 40 | + var snippet; |
39 | 41 |
|
40 | 42 | //: |
41 | 43 |
|
| 44 | + |
| 45 | + mod.stack.add = init; |
42 | 46 |
|
43 | 47 | async function init(){ |
44 | 48 | //debug('init',version); |
45 | 49 | menu = menumod(); |
46 | 50 |
|
| 51 | + |
| 52 | + snippet = mod['snippet-html-console']; |
| 53 | + |
| 54 | + snippet.initmod({ext,$,menu,ace}); |
| 55 | + |
| 56 | + await snippet.init(); |
| 57 | + |
| 58 | + |
| 59 | + |
47 | 60 | await initdom(document.body); |
48 | 61 |
|
49 | 62 |
|
50 | | - init.complete(); |
51 | | - |
52 | 63 | }//init |
53 | 64 |
|
54 | 65 |
|
55 | 66 | //: |
56 | 67 |
|
57 | 68 |
|
58 | | - init.stack = [init]; |
59 | | - init.stack.ct = 0; |
60 | | - init.stack.total = 1; |
61 | | - init.stack.mode = ''; |
62 | | - init.stack.complete = false; |
63 | | - Object.defineProperty(init.stack,'add',{get:()=>{ |
64 | | - init.stack.total++; |
65 | | - if(init.stack.mode){ |
66 | | - console[init.stack.mode]('add',init.stack.ct,init.stack.total); |
67 | | - //console.trace(); |
68 | | - } |
69 | | - }}); |
70 | | - Object.defineProperty(init.stack,'complete',{get:()=>{ |
71 | | - init.stack.ct++; |
72 | | - if(init.stack.mode){ |
73 | | - console[init.stack.mode]('complete',init.stack.ct,init.stack.total); |
74 | | - //console.trace(); |
75 | | - } |
76 | | - if(init.stack.ct>=init.stack.total){ |
77 | | - //console.log('*** complete'); |
78 | | - init.stack.ct = 0; |
79 | | - init.stack.total = 0; |
80 | | - var list = [...init.stack]; |
81 | | - init.stack.length = 0; |
82 | | - list.forEach(fn=>fn()); |
83 | | - } |
84 | | - }}); |
85 | | - |
86 | | - // (typeof init!='undefined' && init?.stack && init.stack.add) |
87 | | - // (typeof init!='undefined' && init?.stack && init.stack.complete) |
88 | | - |
89 | | - |
90 | | - init.complete = function(){ |
91 | | - |
92 | | - init.complete.stack.forEach(fn=>fn()); |
93 | | - |
94 | | - |
95 | | - }//complete |
96 | | - |
97 | | - init.complete.stack = []; |
98 | | - init.complete.add = fn=>init.complete.stack.push(fn); |
99 | | - |
100 | | - |
101 | | - |
102 | 69 | (async()=>{ |
103 | | - |
104 | | - init.stack.add; |
105 | 70 |
|
| 71 | + mod.stack.add; |
106 | 72 |
|
107 | | - var url; |
108 | | - var headers; |
109 | | - var token = localStorage['github-token']; |
110 | | - if(token){ |
111 | | - url = 'https://api.github.com/repos/javascript-2020/ext-code/contents/ext-loader.js'; |
112 | | - headers = {accept:'application/vnd.github.raw',authorization:`bearer ${token}`}; |
113 | | - }else{ |
114 | | - url = 'https://raw.githubusercontent.com/javascript-2020/ext-code/main/ext-loader.js'; |
115 | | - } |
116 | | - |
117 | | - var res = await fetch(url,{headers}); |
118 | | - var txt = await res.text(); |
119 | | - |
120 | | - if(res.headers.get('content-type').includes('json')){ |
121 | | - console.log('*** ext : json'); |
122 | | - var json = JSON.parse(txt); |
123 | | - var b64 = json.content; |
124 | | - txt = atob(b64); |
125 | | - }else{ |
126 | | - console.log('*** ext : text'); |
127 | | - } |
128 | | - |
129 | | - ext = eval(txt); |
130 | | - |
131 | | - |
| 73 | + ({ext} = await import('https://libs.ext-code.com/js/io/ext-loader/ext-loader.m.js')); |
| 74 | + |
132 | 75 | var promise = ext.load.libs( |
133 | | - 'js/dom/$.js.api', |
| 76 | + 'js/dom/$.js', |
134 | 77 | 'js/core/datatype.js', |
135 | 78 | 'js/dom/menumod/menumod.js', |
136 | | - 'js/dom/code/code.js.api', |
| 79 | + 'js/dom/keydown/keydown.js', |
| 80 | + 'js/dom/code/v2.0/code-v2.0.js.api', |
137 | 81 | ); |
138 | | - [$,datatype,menumod,code] = await promise; |
139 | | - |
| 82 | + [$,datatype,menumod,keydown,code] = await promise; |
| 83 | + |
140 | 84 | code.initmod({ext,$,datatype,menumod}); |
141 | | - |
142 | 85 |
|
143 | | - init.stack.complete; |
144 | | - |
| 86 | + mod.stack.complete; |
| 87 | + |
145 | 88 | })(); |
146 | 89 |
|
| 90 | + |
147 | 91 | </script init> |
148 | 92 |
|
149 | 93 |
|
150 | 94 |
|
151 | 95 |
|
152 | 96 | <link rel=stylesheet href='/blog/css/blog.css'> |
153 | 97 |
|
| 98 | + <style> |
| 99 | + |
| 100 | + html |
| 101 | + {font-family:arial} |
| 102 | + |
| 103 | + </style> |
154 | 104 |
|
155 | 105 | </head> |
156 | 106 |
|
|
171 | 121 | </div> |
172 | 122 |
|
173 | 123 |
|
174 | | - <code-block src='ex/ex1.html' api> |
175 | | - </code-block> |
| 124 | + <snippet-html-console component v2.0 src='ex/ex1.html'> |
| 125 | + </snippet-html-console> |
176 | 126 |
|
177 | 127 |
|
178 | 128 |
|
|
0 commit comments