├── front-vue ├── static │ └── .gitkeep ├── .eslintignore ├── config │ ├── prod.env.js │ ├── dev.env.js │ └── index.js ├── favicon.ico ├── src │ ├── assets │ │ ├── logo.png │ │ ├── image │ │ │ ├── arrow-open.png │ │ │ ├── icon-add.png │ │ │ ├── icon-share.png │ │ │ └── arrow-close.png │ │ └── CodeMirror │ │ │ ├── lib │ │ │ ├── codemirror.js │ │ │ ├── edit │ │ │ │ ├── utils.js │ │ │ │ ├── deleteNearSelection.js │ │ │ │ ├── global_events.js │ │ │ │ ├── fromTextArea.js │ │ │ │ ├── main.js │ │ │ │ └── legacy.js │ │ │ ├── line │ │ │ │ ├── saw_special_spans.js │ │ │ │ ├── pos.js │ │ │ │ └── utils_line.js │ │ │ ├── display │ │ │ │ ├── mode_state.js │ │ │ │ ├── gutters.js │ │ │ │ ├── focus.js │ │ │ │ ├── line_numbers.js │ │ │ │ ├── highlight_worker.js │ │ │ │ └── update_lines.js │ │ │ ├── input │ │ │ │ ├── keynames.js │ │ │ │ └── indent.js │ │ │ ├── measurement │ │ │ │ └── widgets.js │ │ │ ├── util │ │ │ │ ├── browser.js │ │ │ │ ├── operation_group.js │ │ │ │ ├── StringStream.js │ │ │ │ ├── feature_detection.js │ │ │ │ ├── dom.js │ │ │ │ └── event.js │ │ │ ├── model │ │ │ │ ├── change_measurement.js │ │ │ │ ├── selection.js │ │ │ │ ├── line_widget.js │ │ │ │ └── document_data.js │ │ │ └── modes.js │ │ │ ├── addon │ │ │ ├── display │ │ │ │ ├── fullscreen.css │ │ │ │ ├── fullscreen.js │ │ │ │ ├── autorefresh.js │ │ │ │ ├── rulers.js │ │ │ │ ├── placeholder.js │ │ │ │ └── panel.js │ │ │ ├── search │ │ │ │ ├── matchesonscrollbar.css │ │ │ │ ├── jump-to-line.js │ │ │ │ └── matchesonscrollbar.js │ │ │ ├── fold │ │ │ │ ├── foldgutter.css │ │ │ │ ├── markdown-fold.js │ │ │ │ ├── indent-fold.js │ │ │ │ ├── comment-fold.js │ │ │ │ └── brace-fold.js │ │ │ ├── dialog │ │ │ │ └── dialog.css │ │ │ ├── hint │ │ │ │ ├── show-hint.css │ │ │ │ ├── anyword-hint.js │ │ │ │ └── css-hint.js │ │ │ ├── mode │ │ │ │ ├── multiplex_test.js │ │ │ │ ├── loadmode.js │ │ │ │ └── overlay.js │ │ │ ├── lint │ │ │ │ ├── json-lint.js │ │ │ │ ├── yaml-lint.js │ │ │ │ ├── css-lint.js │ │ │ │ ├── coffeescript-lint.js │ │ │ │ ├── html-lint.js │ │ │ │ └── lint.css │ │ │ ├── edit │ │ │ │ ├── trailingspace.js │ │ │ │ ├── continuelist.js │ │ │ │ └── matchtags.js │ │ │ ├── tern │ │ │ │ ├── worker.js │ │ │ │ └── tern.css │ │ │ ├── runmode │ │ │ │ ├── colorize.js │ │ │ │ └── runmode.js │ │ │ ├── scroll │ │ │ │ ├── simplescrollbars.css │ │ │ │ └── scrollpastend.js │ │ │ ├── selection │ │ │ │ ├── active-line.js │ │ │ │ ├── selection-pointer.js │ │ │ │ └── mark-selection.js │ │ │ ├── comment │ │ │ │ └── continuecomment.js │ │ │ └── merge │ │ │ │ └── merge.css │ │ │ └── theme │ │ │ ├── blackboard.css │ │ │ └── erlang-dark.css │ ├── router │ │ └── index.js │ ├── store │ │ ├── index.js │ │ ├── api.js │ │ └── fetch.js │ ├── App.vue │ ├── main.js │ ├── plugin │ │ └── CommonUtil.js │ └── components │ │ ├── popWindow.vue │ │ ├── popAlert.vue │ │ └── popShare.vue ├── .gitignore ├── .editorconfig ├── .postcssrc.js ├── index.html ├── .babelrc ├── build │ ├── dev-client.js │ ├── vue-loader.conf.js │ ├── build.js │ ├── webpack.dev.conf.js │ ├── check-versions.js │ ├── webpack.base.conf.js │ ├── utils.js │ ├── dev-server.js │ └── webpack.prod.conf.js ├── README.md ├── .eslintrc.js └── package.json ├── image ├── 1.png ├── 2.png └── 3.png ├── JsBox ├── file │ └── code │ │ └── javascript │ │ ├── temp │ │ └── 11111111111111111 │ │ └── online │ │ ├── 11111111111111111 │ │ └── 11111111111 ├── views │ ├── index.jade │ ├── error.jade │ └── layout.jade ├── routes │ ├── users.js │ └── index.js ├── public │ ├── index.html │ └── static │ │ └── js │ │ ├── manifest.67d95f4f2bac744a9e68.js │ │ └── manifest.fe0b79a8fde277e7b4cf.js ├── package.json ├── app.js ├── bin │ └── www ├── service │ └── verifyCode.js └── npm-debug.log └── README.md /front-vue/static/.gitkeep: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /image/1.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/wobudapai/JsBox/HEAD/image/1.png -------------------------------------------------------------------------------- /image/2.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/wobudapai/JsBox/HEAD/image/2.png -------------------------------------------------------------------------------- /image/3.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/wobudapai/JsBox/HEAD/image/3.png -------------------------------------------------------------------------------- /JsBox/file/code/javascript/temp/11111111111111111: -------------------------------------------------------------------------------- 1 | function test (a) {var sss = a} 2 | -------------------------------------------------------------------------------- /front-vue/.eslintignore: -------------------------------------------------------------------------------- 1 | build/*.js 2 | config/*.js 3 | src/assets/* 4 | src/store/* 5 | -------------------------------------------------------------------------------- /front-vue/config/prod.env.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | NODE_ENV: '"production"' 3 | } 4 | -------------------------------------------------------------------------------- /front-vue/favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/wobudapai/JsBox/HEAD/front-vue/favicon.ico -------------------------------------------------------------------------------- /JsBox/file/code/javascript/online/11111111111111111: -------------------------------------------------------------------------------- 1 | function test (a) { 2 | var sss = a 3 | } 4 | -------------------------------------------------------------------------------- /JsBox/views/index.jade: -------------------------------------------------------------------------------- 1 | extends layout 2 | 3 | block content 4 | h1= title 5 | p Welcome to #{title} 6 | -------------------------------------------------------------------------------- /front-vue/src/assets/logo.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/wobudapai/JsBox/HEAD/front-vue/src/assets/logo.png -------------------------------------------------------------------------------- /front-vue/.gitignore: -------------------------------------------------------------------------------- 1 | .DS_Store 2 | node_modules/ 3 | dist/ 4 | npm-debug.log* 5 | yarn-debug.log* 6 | yarn-error.log* 7 | -------------------------------------------------------------------------------- /JsBox/views/error.jade: -------------------------------------------------------------------------------- 1 | extends layout 2 | 3 | block content 4 | h1= message 5 | h2= error.status 6 | pre #{error.stack} 7 | -------------------------------------------------------------------------------- /front-vue/src/assets/image/arrow-open.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/wobudapai/JsBox/HEAD/front-vue/src/assets/image/arrow-open.png -------------------------------------------------------------------------------- /front-vue/src/assets/image/icon-add.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/wobudapai/JsBox/HEAD/front-vue/src/assets/image/icon-add.png -------------------------------------------------------------------------------- /front-vue/src/assets/image/icon-share.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/wobudapai/JsBox/HEAD/front-vue/src/assets/image/icon-share.png -------------------------------------------------------------------------------- /JsBox/file/code/javascript/online/11111111111: -------------------------------------------------------------------------------- 1 | function test (a) { 2 | var sss = a 3 | console.log(sss) 4 | } 5 | console.log('ssss') -------------------------------------------------------------------------------- /front-vue/src/assets/image/arrow-close.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/wobudapai/JsBox/HEAD/front-vue/src/assets/image/arrow-close.png -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/codemirror.js: -------------------------------------------------------------------------------- 1 | import { CodeMirror } from "./edit/main" 2 | 3 | global.CodeMirror = CodeMirror 4 | 5 | export default CodeMirror 6 | -------------------------------------------------------------------------------- /JsBox/views/layout.jade: -------------------------------------------------------------------------------- 1 | doctype html 2 | html 3 | head 4 | title= title 5 | link(rel='stylesheet', href='/stylesheets/style.css') 6 | body 7 | block content 8 | -------------------------------------------------------------------------------- /front-vue/config/dev.env.js: -------------------------------------------------------------------------------- 1 | var merge = require('webpack-merge') 2 | var prodEnv = require('./prod.env') 3 | 4 | module.exports = merge(prodEnv, { 5 | NODE_ENV: '"development"' 6 | }) 7 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/display/fullscreen.css: -------------------------------------------------------------------------------- 1 | .CodeMirror-fullscreen { 2 | position: fixed; 3 | top: 0; left: 0; right: 0; bottom: 0; 4 | height: auto; 5 | z-index: 9; 6 | } 7 | -------------------------------------------------------------------------------- /front-vue/.editorconfig: -------------------------------------------------------------------------------- 1 | root = true 2 | 3 | [*] 4 | charset = utf-8 5 | indent_style = space 6 | indent_size = 2 7 | end_of_line = lf 8 | insert_final_newline = true 9 | trim_trailing_whitespace = true 10 | -------------------------------------------------------------------------------- /front-vue/.postcssrc.js: -------------------------------------------------------------------------------- 1 | // https://github.com/michael-ciniawsky/postcss-load-config 2 | 3 | module.exports = { 4 | "plugins": { 5 | // to edit target browsers: use "browserlist" field in package.json 6 | "autoprefixer": {} 7 | } 8 | } 9 | -------------------------------------------------------------------------------- /JsBox/routes/users.js: -------------------------------------------------------------------------------- 1 | var express = require('express'); 2 | var router = express.Router(); 3 | 4 | /* GET users listing. */ 5 | router.get('/', function(req, res, next) { 6 | res.send('respond with a resource'); 7 | }); 8 | 9 | module.exports = router; 10 | -------------------------------------------------------------------------------- /front-vue/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | JsBox 6 | 7 | 8 |
9 | 10 | 11 | 12 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/search/matchesonscrollbar.css: -------------------------------------------------------------------------------- 1 | .CodeMirror-search-match { 2 | background: gold; 3 | border-top: 1px solid orange; 4 | border-bottom: 1px solid orange; 5 | -moz-box-sizing: border-box; 6 | box-sizing: border-box; 7 | opacity: .5; 8 | } 9 | -------------------------------------------------------------------------------- /front-vue/.babelrc: -------------------------------------------------------------------------------- 1 | { 2 | "presets": [ 3 | ["env", { "modules": false }], 4 | "stage-2" 5 | ], 6 | "plugins": ["transform-runtime"], 7 | "comments": false, 8 | "env": { 9 | "test": { 10 | "presets": ["env", "stage-2"], 11 | "plugins": [ "istanbul" ] 12 | } 13 | } 14 | } 15 | -------------------------------------------------------------------------------- /front-vue/build/dev-client.js: -------------------------------------------------------------------------------- 1 | /* eslint-disable */ 2 | require('eventsource-polyfill') 3 | var hotClient = require('webpack-hot-middleware/client?noInfo=true&reload=true') 4 | 5 | hotClient.subscribe(function (event) { 6 | if (event.action === 'reload') { 7 | window.location.reload() 8 | } 9 | }) 10 | -------------------------------------------------------------------------------- /front-vue/src/router/index.js: -------------------------------------------------------------------------------- 1 | import Vue from 'vue' 2 | import Router from 'vue-router' 3 | import Home from '@/components/Home' 4 | 5 | Vue.use(Router) 6 | 7 | export default new Router({ 8 | routes: [ 9 | { 10 | path: '/', 11 | name: 'Home', 12 | component: Home 13 | } 14 | ] 15 | }) 16 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/edit/utils.js: -------------------------------------------------------------------------------- 1 | import { clearCaches } from "../measurement/position_measurement" 2 | 3 | export function themeChanged(cm) { 4 | cm.display.wrapper.className = cm.display.wrapper.className.replace(/\s*cm-s-\S+/g, "") + 5 | cm.options.theme.replace(/(^|\s)\s*/g, " cm-s-") 6 | clearCaches(cm) 7 | } 8 | -------------------------------------------------------------------------------- /front-vue/src/store/index.js: -------------------------------------------------------------------------------- 1 | /** 2 | * Created by zy on 2016/12/15. 3 | */ 4 | import Vuex from 'vuex' 5 | import Vue from 'vue' 6 | 7 | import api from './api' 8 | 9 | Vue.use(Vuex) 10 | 11 | export default new Vuex.Store({ 12 | strict: process.env.NODE_ENV !== 'production', 13 | modules: { 14 | api 15 | } 16 | }) 17 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/line/saw_special_spans.js: -------------------------------------------------------------------------------- 1 | // Optimize some code when these features are not used. 2 | export let sawReadOnlySpans = false, sawCollapsedSpans = false 3 | 4 | export function seeReadOnlySpans() { 5 | sawReadOnlySpans = true 6 | } 7 | 8 | export function seeCollapsedSpans() { 9 | sawCollapsedSpans = true 10 | } 11 | -------------------------------------------------------------------------------- /front-vue/build/vue-loader.conf.js: -------------------------------------------------------------------------------- 1 | var utils = require('./utils') 2 | var config = require('../config/index') 3 | var isProduction = process.env.NODE_ENV === 'production' 4 | 5 | module.exports = { 6 | loaders: utils.cssLoaders({ 7 | sourceMap: isProduction 8 | ? config.build.productionSourceMap 9 | : config.dev.cssSourceMap, 10 | extract: isProduction 11 | }) 12 | } 13 | -------------------------------------------------------------------------------- /JsBox/public/index.html: -------------------------------------------------------------------------------- 1 | JsBox
-------------------------------------------------------------------------------- /JsBox/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "code-editor", 3 | "version": "0.0.0", 4 | "private": true, 5 | "scripts": { 6 | "start": "node ./bin/www" 7 | }, 8 | "dependencies": { 9 | "body-parser": "~1.15.2", 10 | "cookie-parser": "~1.4.3", 11 | "cors": "^2.8.3", 12 | "crypto": "0.0.3", 13 | "debug": "~2.2.0", 14 | "express": "~4.14.0", 15 | "fs": "0.0.1-security", 16 | "jade": "~1.11.0", 17 | "morgan": "~1.7.0", 18 | "path": "^0.12.7", 19 | "serve-favicon": "~2.3.0" 20 | } 21 | } 22 | -------------------------------------------------------------------------------- /front-vue/src/App.vue: -------------------------------------------------------------------------------- 1 | 6 | 7 | 12 | 13 | 27 | -------------------------------------------------------------------------------- /front-vue/README.md: -------------------------------------------------------------------------------- 1 | # vue-os 2 | 3 | > A Vue.js project 4 | 5 | ## Build Setup 6 | 7 | ``` bash 8 | # install dependencies 9 | npm install 10 | 11 | # serve with hot reload at localhost:8080 12 | npm run dev 13 | 14 | # build for production with minification 15 | npm run build 16 | 17 | # build for production and view the bundle analyzer report 18 | npm run build --report 19 | ``` 20 | 21 | For detailed explanation on how things work, checkout the [guide](http://vuejs-templates.github.io/webpack/) and [docs for vue-loader](http://vuejs.github.io/vue-loader). 22 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/fold/foldgutter.css: -------------------------------------------------------------------------------- 1 | .CodeMirror-foldmarker { 2 | color: blue; 3 | text-shadow: #b9f 1px 1px 2px, #b9f -1px -1px 2px, #b9f 1px -1px 2px, #b9f -1px 1px 2px; 4 | font-family: arial; 5 | line-height: .3; 6 | cursor: pointer; 7 | } 8 | .CodeMirror-foldgutter { 9 | width: .7em; 10 | } 11 | .CodeMirror-foldgutter-open, 12 | .CodeMirror-foldgutter-folded { 13 | cursor: pointer; 14 | } 15 | .CodeMirror-foldgutter-open:after { 16 | content: "\25BE"; 17 | } 18 | .CodeMirror-foldgutter-folded:after { 19 | content: "\25B8"; 20 | } 21 | -------------------------------------------------------------------------------- /front-vue/src/store/api.js: -------------------------------------------------------------------------------- 1 | import { post, get } from './fetch.js' 2 | 3 | const api = { 4 | add: '/add', 5 | codeList: '/codeList', 6 | codeDetail: '/codeDetail', 7 | getVerify: '/verify' 8 | } 9 | 10 | export default { 11 | actions: { 12 | add: ({ state }, data) => { 13 | return post(api.add, data) 14 | }, 15 | codeList: ( ) => { 16 | return get(api.codeList) 17 | }, 18 | codeDetail: ({ state }, id) => { 19 | return get(api.codeDetail, { id }) 20 | }, 21 | getVerify: ( ) => { 22 | return get(api.getVerify) 23 | } 24 | } 25 | } 26 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/dialog/dialog.css: -------------------------------------------------------------------------------- 1 | .CodeMirror-dialog { 2 | position: absolute; 3 | left: 0; right: 0; 4 | background: inherit; 5 | z-index: 15; 6 | padding: .1em .8em; 7 | overflow: hidden; 8 | color: inherit; 9 | } 10 | 11 | .CodeMirror-dialog-top { 12 | border-bottom: 1px solid #eee; 13 | top: 0; 14 | } 15 | 16 | .CodeMirror-dialog-bottom { 17 | border-top: 1px solid #eee; 18 | bottom: 0; 19 | } 20 | 21 | .CodeMirror-dialog input { 22 | border: none; 23 | outline: none; 24 | background: transparent; 25 | width: 20em; 26 | color: inherit; 27 | font-family: monospace; 28 | } 29 | 30 | .CodeMirror-dialog button { 31 | font-size: 70%; 32 | } 33 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/display/mode_state.js: -------------------------------------------------------------------------------- 1 | import { getMode } from "../modes" 2 | 3 | import { startWorker } from "./highlight_worker" 4 | import { regChange } from "./view_tracking" 5 | 6 | // Used to get the editor into a consistent state again when options change. 7 | 8 | export function loadMode(cm) { 9 | cm.doc.mode = getMode(cm.options, cm.doc.modeOption) 10 | resetModeState(cm) 11 | } 12 | 13 | export function resetModeState(cm) { 14 | cm.doc.iter(line => { 15 | if (line.stateAfter) line.stateAfter = null 16 | if (line.styles) line.styles = null 17 | }) 18 | cm.doc.frontier = cm.doc.first 19 | startWorker(cm, 100) 20 | cm.state.modeGen++ 21 | if (cm.curOp) regChange(cm) 22 | } 23 | -------------------------------------------------------------------------------- /front-vue/src/main.js: -------------------------------------------------------------------------------- 1 | // The Vue build version to load with the `import` command 2 | // (runtime-only or standalone) has been set in webpack.base.conf with an alias. 3 | import Vue from 'vue' 4 | import App from './App' 5 | import router from './router' 6 | import store from './store/' 7 | import axios from 'axios' 8 | import CommUtil from './plugin/CommonUtil' 9 | 10 | Vue.config.productionTip = false 11 | 12 | Vue.use(CommUtil) 13 | 14 | global.axios = axios 15 | // axios.defaults.baseURL = 'http://code.smallcfj.club/api' 16 | axios.defaults.baseURL = 'http://localhost:3005/api' 17 | 18 | /* eslint-disable no-new */ 19 | new Vue({ 20 | el: '#app', 21 | router, 22 | store, 23 | template: '', 24 | components: { App } 25 | }) 26 | -------------------------------------------------------------------------------- /front-vue/.eslintrc.js: -------------------------------------------------------------------------------- 1 | // http://eslint.org/docs/user-guide/configuring 2 | 3 | module.exports = { 4 | root: true, 5 | parser: 'babel-eslint', 6 | parserOptions: { 7 | sourceType: 'module' 8 | }, 9 | env: { 10 | browser: true, 11 | }, 12 | // https://github.com/feross/standard/blob/master/RULES.md#javascript-standard-style 13 | extends: 'standard', 14 | // required to lint *.vue files 15 | plugins: [ 16 | 'html' 17 | ], 18 | // add your custom rules here 19 | 'rules': { 20 | // allow paren-less arrow functions 21 | 'arrow-parens': 0, 22 | // allow async-await 23 | 'generator-star-spacing': 0, 24 | // allow debugger during development 25 | 'no-debugger': process.env.NODE_ENV === 'production' ? 2 : 0, 26 | 'no-eval': 0 27 | } 28 | } 29 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/hint/show-hint.css: -------------------------------------------------------------------------------- 1 | .CodeMirror-hints { 2 | position: absolute; 3 | z-index: 10; 4 | overflow: hidden; 5 | list-style: none; 6 | 7 | margin: 0; 8 | padding: 2px; 9 | 10 | -webkit-box-shadow: 2px 3px 5px rgba(0,0,0,.2); 11 | -moz-box-shadow: 2px 3px 5px rgba(0,0,0,.2); 12 | box-shadow: 2px 3px 5px rgba(0,0,0,.2); 13 | border-radius: 3px; 14 | border: 1px solid silver; 15 | 16 | background: white; 17 | font-size: 90%; 18 | font-family: monospace; 19 | 20 | max-height: 20em; 21 | overflow-y: auto; 22 | } 23 | 24 | .CodeMirror-hint { 25 | margin: 0; 26 | padding: 0 4px; 27 | border-radius: 2px; 28 | white-space: pre; 29 | color: black; 30 | cursor: pointer; 31 | } 32 | 33 | li.CodeMirror-hint-active { 34 | background: #08f; 35 | color: white; 36 | } 37 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # JsBox 2 | [点击预览](http://code.smallcfj.club) 3 | 4 | 采用Vue+nodejs实现的在线Js编辑器,前后台通过接口进行访问,可以在线编辑、保存、分享Js代码,实现了简单的响应式。 5 | 前台:vue 6 | 后台:nodejs、文件存储 7 | ## 界面预览 8 | 9 | 深色风格界面(装逼专用(〃'▽'〃)) 10 | 11 | ![](https://github.com/zycfj/JsBox/blob/master/image/1.png?raw=true) 12 | 13 | 左边可以收起来,中间的横条可以上下拉动噢 14 | 15 | ![](https://github.com/zycfj/JsBox/blob/master/image/2.png?raw=true) 16 | 17 | 为了防止重复提交,搞了个简单的验证码--诗歌验证 18 | 19 | ![](https://github.com/zycfj/JsBox/blob/master/image/3.png?raw=true) 20 | ## 运行 21 | 下载项目到本地,里面有两个文件夹: 22 | 23 | front-vue:采用vue实现的简单单页应用,访问接口与后台通信 24 | 25 | JsBox:项目后台,主要采用文件的方式存储信息 26 | 27 | 1、进入JsBox文件夹 28 | ```javascript 29 | 30 | // 安装项目的依赖包 31 | npm install 32 | 33 | // 运行 34 | npm start 35 | ``` 36 | 37 | 2、进入front-vue文件夹 38 | ```javascript 39 | // 安装项目的依赖包 40 | npm install 41 | 42 | // 运行 43 | npm run dev 44 | ``` 45 | ## 发布 46 | 1、进入front-vue文件夹 47 | ```javascript 48 | // 编译(压缩) 49 | npm run build 50 | ``` 51 | 2、将dist文件夹中生成的文件全部拷贝到JsBox/public文件夹中,然后发布该node项目即可 52 | -------------------------------------------------------------------------------- /front-vue/src/plugin/CommonUtil.js: -------------------------------------------------------------------------------- 1 | export default { 2 | install: function (Vue) { 3 | Vue.prototype.$util = { 4 | parseDate: function (timp, fmt) { 5 | var date = new Date(timp * 1000) 6 | var o = { 7 | 'M+': date.getMonth() + 1, // 月份 8 | 'd+': date.getDate(), // 日 9 | 'h+': date.getHours(), // 小时 10 | 'm+': date.getMinutes(), // 分 11 | 's+': date.getSeconds(), // 秒 12 | 'q+': Math.floor((date.getMonth() + 3) / 3), // 季度 13 | 'S': date.getMilliseconds() // 毫秒 14 | } 15 | if (/(y+)/.test(fmt)) { 16 | fmt = fmt.replace(RegExp.$1, (date.getFullYear() + '').substr(4 - RegExp.$1.length)) 17 | } 18 | for (var k in o) { 19 | if (new RegExp('(' + k + ')').test(fmt)) { 20 | fmt = fmt.replace(RegExp.$1, (RegExp.$1.length === 1) ? (o[k]) : (('00' + o[k]).substr(('' + o[k]).length))) 21 | } 22 | } 23 | return fmt 24 | } 25 | } 26 | } 27 | } 28 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/mode/multiplex_test.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function() { 5 | CodeMirror.defineMode("markdown_with_stex", function(){ 6 | var inner = CodeMirror.getMode({}, "stex"); 7 | var outer = CodeMirror.getMode({}, "markdown"); 8 | 9 | var innerOptions = { 10 | open: '$', 11 | close: '$', 12 | mode: inner, 13 | delimStyle: 'delim', 14 | innerStyle: 'inner' 15 | }; 16 | 17 | return CodeMirror.multiplexingMode(outer, innerOptions); 18 | }); 19 | 20 | var mode = CodeMirror.getMode({}, "markdown_with_stex"); 21 | 22 | function MT(name) { 23 | test.mode( 24 | name, 25 | mode, 26 | Array.prototype.slice.call(arguments, 1), 27 | 'multiplexing'); 28 | } 29 | 30 | MT( 31 | "stexInsideMarkdown", 32 | "[strong **Equation:**] [delim&delim-open $][inner&tag \\pi][delim&delim-close $]"); 33 | })(); 34 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/input/keynames.js: -------------------------------------------------------------------------------- 1 | export let keyNames = { 2 | 3: "Enter", 8: "Backspace", 9: "Tab", 13: "Enter", 16: "Shift", 17: "Ctrl", 18: "Alt", 3 | 19: "Pause", 20: "CapsLock", 27: "Esc", 32: "Space", 33: "PageUp", 34: "PageDown", 35: "End", 4 | 36: "Home", 37: "Left", 38: "Up", 39: "Right", 40: "Down", 44: "PrintScrn", 45: "Insert", 5 | 46: "Delete", 59: ";", 61: "=", 91: "Mod", 92: "Mod", 93: "Mod", 6 | 106: "*", 107: "=", 109: "-", 110: ".", 111: "/", 127: "Delete", 7 | 173: "-", 186: ";", 187: "=", 188: ",", 189: "-", 190: ".", 191: "/", 192: "`", 219: "[", 220: "\\", 8 | 221: "]", 222: "'", 63232: "Up", 63233: "Down", 63234: "Left", 63235: "Right", 63272: "Delete", 9 | 63273: "Home", 63275: "End", 63276: "PageUp", 63277: "PageDown", 63302: "Insert" 10 | } 11 | 12 | // Number keys 13 | for (let i = 0; i < 10; i++) keyNames[i + 48] = keyNames[i + 96] = String(i) 14 | // Alphabetic keys 15 | for (let i = 65; i <= 90; i++) keyNames[i] = String.fromCharCode(i) 16 | // Function keys 17 | for (let i = 1; i <= 12; i++) keyNames[i + 111] = keyNames[i + 63235] = "F" + i 18 | -------------------------------------------------------------------------------- /front-vue/build/build.js: -------------------------------------------------------------------------------- 1 | require('./check-versions')() 2 | 3 | process.env.NODE_ENV = 'production' 4 | 5 | var ora = require('ora') 6 | var rm = require('rimraf') 7 | var path = require('path') 8 | var chalk = require('chalk') 9 | var webpack = require('webpack') 10 | var config = require('../config/index') 11 | var webpackConfig = require('./webpack.prod.conf') 12 | 13 | var spinner = ora('building for production...') 14 | spinner.start() 15 | 16 | rm(path.join(config.build.assetsRoot, config.build.assetsSubDirectory), err => { 17 | if (err) throw err 18 | webpack(webpackConfig, function (err, stats) { 19 | spinner.stop() 20 | if (err) throw err 21 | process.stdout.write(stats.toString({ 22 | colors: true, 23 | modules: false, 24 | children: false, 25 | chunks: false, 26 | chunkModules: false 27 | }) + '\n\n') 28 | 29 | console.log(chalk.cyan(' Build complete.\n')) 30 | console.log(chalk.yellow( 31 | ' Tip: built files are meant to be served over an HTTP server.\n' + 32 | ' Opening index.html over file:// won\'t work.\n' 33 | )) 34 | }) 35 | }) 36 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/lint/json-lint.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | // Depends on jsonlint.js from https://github.com/zaach/jsonlint 5 | 6 | // declare global: jsonlint 7 | 8 | (function(mod) { 9 | if (typeof exports == "object" && typeof module == "object") // CommonJS 10 | mod(require("../../lib/codemirror")); 11 | else if (typeof define == "function" && define.amd) // AMD 12 | define(["../../lib/codemirror"], mod); 13 | else // Plain browser env 14 | mod(CodeMirror); 15 | })(function(CodeMirror) { 16 | "use strict"; 17 | 18 | CodeMirror.registerHelper("lint", "json", function(text) { 19 | var found = []; 20 | jsonlint.parseError = function(str, hash) { 21 | var loc = hash.loc; 22 | found.push({from: CodeMirror.Pos(loc.first_line - 1, loc.first_column), 23 | to: CodeMirror.Pos(loc.last_line - 1, loc.last_column), 24 | message: str}); 25 | }; 26 | try { jsonlint.parse(text); } 27 | catch(e) {} 28 | return found; 29 | }); 30 | 31 | }); 32 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/edit/trailingspace.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror")); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror"], mod); 9 | else // Plain browser env 10 | mod(CodeMirror); 11 | })(function(CodeMirror) { 12 | CodeMirror.defineOption("showTrailingSpace", false, function(cm, val, prev) { 13 | if (prev == CodeMirror.Init) prev = false; 14 | if (prev && !val) 15 | cm.removeOverlay("trailingspace"); 16 | else if (!prev && val) 17 | cm.addOverlay({ 18 | token: function(stream) { 19 | for (var l = stream.string.length, i = l; i && /\s/.test(stream.string.charAt(i - 1)); --i) {} 20 | if (i > stream.pos) { stream.pos = i; return null; } 21 | stream.pos = l; 22 | return "trailingspace"; 23 | }, 24 | name: "trailingspace" 25 | }); 26 | }); 27 | }); 28 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/measurement/widgets.js: -------------------------------------------------------------------------------- 1 | import { contains, elt, removeChildrenAndAdd } from "../util/dom" 2 | import { e_target } from "../util/event" 3 | 4 | export function widgetHeight(widget) { 5 | if (widget.height != null) return widget.height 6 | let cm = widget.doc.cm 7 | if (!cm) return 0 8 | if (!contains(document.body, widget.node)) { 9 | let parentStyle = "position: relative;" 10 | if (widget.coverGutter) 11 | parentStyle += "margin-left: -" + cm.display.gutters.offsetWidth + "px;" 12 | if (widget.noHScroll) 13 | parentStyle += "width: " + cm.display.wrapper.clientWidth + "px;" 14 | removeChildrenAndAdd(cm.display.measure, elt("div", [widget.node], null, parentStyle)) 15 | } 16 | return widget.height = widget.node.parentNode.offsetHeight 17 | } 18 | 19 | // Return true when the given mouse event happened in a widget 20 | export function eventInWidget(display, e) { 21 | for (let n = e_target(e); n != display.wrapper; n = n.parentNode) { 22 | if (!n || (n.nodeType == 1 && n.getAttribute("cm-ignore-events") == "true") || 23 | (n.parentNode == display.sizer && n != display.mover)) 24 | return true 25 | } 26 | } 27 | -------------------------------------------------------------------------------- /front-vue/src/components/popWindow.vue: -------------------------------------------------------------------------------- 1 | 9 | 10 | 25 | 26 | 55 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/edit/deleteNearSelection.js: -------------------------------------------------------------------------------- 1 | import { runInOp } from "../display/operations" 2 | import { ensureCursorVisible } from "../display/scrolling" 3 | import { cmp } from "../line/pos" 4 | import { replaceRange } from "../model/changes" 5 | import { lst } from "../util/misc" 6 | 7 | // Helper for deleting text near the selection(s), used to implement 8 | // backspace, delete, and similar functionality. 9 | export function deleteNearSelection(cm, compute) { 10 | let ranges = cm.doc.sel.ranges, kill = [] 11 | // Build up a set of ranges to kill first, merging overlapping 12 | // ranges. 13 | for (let i = 0; i < ranges.length; i++) { 14 | let toKill = compute(ranges[i]) 15 | while (kill.length && cmp(toKill.from, lst(kill).to) <= 0) { 16 | let replaced = kill.pop() 17 | if (cmp(replaced.from, toKill.from) < 0) { 18 | toKill.from = replaced.from 19 | break 20 | } 21 | } 22 | kill.push(toKill) 23 | } 24 | // Next, remove those actual ranges. 25 | runInOp(cm, () => { 26 | for (let i = kill.length - 1; i >= 0; i--) 27 | replaceRange(cm.doc, "", kill[i].from, kill[i].to, "+delete") 28 | ensureCursorVisible(cm) 29 | }) 30 | } 31 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/lint/yaml-lint.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror")); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror"], mod); 9 | else // Plain browser env 10 | mod(CodeMirror); 11 | })(function(CodeMirror) { 12 | "use strict"; 13 | 14 | // Depends on js-yaml.js from https://github.com/nodeca/js-yaml 15 | 16 | // declare global: jsyaml 17 | 18 | CodeMirror.registerHelper("lint", "yaml", function(text) { 19 | var found = []; 20 | try { jsyaml.load(text); } 21 | catch(e) { 22 | var loc = e.mark, 23 | // js-yaml YAMLException doesn't always provide an accurate lineno 24 | // e.g., when there are multiple yaml docs 25 | // --- 26 | // --- 27 | // foo:bar 28 | from = loc ? CodeMirror.Pos(loc.line, loc.column) : CodeMirror.Pos(0, 0), 29 | to = from; 30 | found.push({ from: from, to: to, message: e.message }); 31 | } 32 | return found; 33 | }); 34 | 35 | }); 36 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/lint/css-lint.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | // Depends on csslint.js from https://github.com/stubbornella/csslint 5 | 6 | // declare global: CSSLint 7 | 8 | (function(mod) { 9 | if (typeof exports == "object" && typeof module == "object") // CommonJS 10 | mod(require("../../lib/codemirror")); 11 | else if (typeof define == "function" && define.amd) // AMD 12 | define(["../../lib/codemirror"], mod); 13 | else // Plain browser env 14 | mod(CodeMirror); 15 | })(function(CodeMirror) { 16 | "use strict"; 17 | 18 | CodeMirror.registerHelper("lint", "css", function(text) { 19 | var found = []; 20 | if (!window.CSSLint) return found; 21 | var results = CSSLint.verify(text), messages = results.messages, message = null; 22 | for ( var i = 0; i < messages.length; i++) { 23 | message = messages[i]; 24 | var startLine = message.line -1, endLine = message.line -1, startCol = message.col -1, endCol = message.col; 25 | found.push({ 26 | from: CodeMirror.Pos(startLine, startCol), 27 | to: CodeMirror.Pos(endLine, endCol), 28 | message: message.message, 29 | severity : message.type 30 | }); 31 | } 32 | return found; 33 | }); 34 | 35 | }); 36 | -------------------------------------------------------------------------------- /front-vue/src/components/popAlert.vue: -------------------------------------------------------------------------------- 1 | 9 | 10 | 29 | 30 | 58 | -------------------------------------------------------------------------------- /front-vue/build/webpack.dev.conf.js: -------------------------------------------------------------------------------- 1 | var utils = require('./utils') 2 | var webpack = require('webpack') 3 | var config = require('../config/index') 4 | var merge = require('webpack-merge') 5 | var baseWebpackConfig = require('./webpack.base.conf') 6 | var HtmlWebpackPlugin = require('html-webpack-plugin') 7 | var FriendlyErrorsPlugin = require('friendly-errors-webpack-plugin') 8 | 9 | // add hot-reload related code to entry chunks 10 | Object.keys(baseWebpackConfig.entry).forEach(function (name) { 11 | baseWebpackConfig.entry[name] = ['./build/dev-client'].concat(baseWebpackConfig.entry[name]) 12 | }) 13 | 14 | module.exports = merge(baseWebpackConfig, { 15 | module: { 16 | rules: utils.styleLoaders({ sourceMap: config.dev.cssSourceMap }) 17 | }, 18 | // cheap-module-eval-source-map is faster for development 19 | devtool: '#cheap-module-eval-source-map', 20 | plugins: [ 21 | new webpack.DefinePlugin({ 22 | 'process.env': config.dev.env 23 | }), 24 | // https://github.com/glenjamin/webpack-hot-middleware#installation--usage 25 | new webpack.HotModuleReplacementPlugin(), 26 | new webpack.NoEmitOnErrorsPlugin(), 27 | // https://github.com/ampedandwired/html-webpack-plugin 28 | new HtmlWebpackPlugin({ 29 | filename: 'index.html', 30 | template: 'index.html', 31 | inject: true 32 | }), 33 | new FriendlyErrorsPlugin() 34 | ] 35 | }) 36 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/tern/worker.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | // declare global: tern, server 5 | 6 | var server; 7 | 8 | this.onmessage = function(e) { 9 | var data = e.data; 10 | switch (data.type) { 11 | case "init": return startServer(data.defs, data.plugins, data.scripts); 12 | case "add": return server.addFile(data.name, data.text); 13 | case "del": return server.delFile(data.name); 14 | case "req": return server.request(data.body, function(err, reqData) { 15 | postMessage({id: data.id, body: reqData, err: err && String(err)}); 16 | }); 17 | case "getFile": 18 | var c = pending[data.id]; 19 | delete pending[data.id]; 20 | return c(data.err, data.text); 21 | default: throw new Error("Unknown message type: " + data.type); 22 | } 23 | }; 24 | 25 | var nextId = 0, pending = {}; 26 | function getFile(file, c) { 27 | postMessage({type: "getFile", name: file, id: ++nextId}); 28 | pending[nextId] = c; 29 | } 30 | 31 | function startServer(defs, plugins, scripts) { 32 | if (scripts) importScripts.apply(null, scripts); 33 | 34 | server = new tern.Server({ 35 | getFile: getFile, 36 | async: true, 37 | defs: defs, 38 | plugins: plugins 39 | }); 40 | } 41 | 42 | this.console = { 43 | log: function(v) { postMessage({type: "debug", message: v}); } 44 | }; 45 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/display/gutters.js: -------------------------------------------------------------------------------- 1 | import { elt, removeChildren } from "../util/dom" 2 | import { indexOf } from "../util/misc" 3 | 4 | import { updateGutterSpace } from "./update_display" 5 | 6 | // Rebuild the gutter elements, ensure the margin to the left of the 7 | // code matches their width. 8 | export function updateGutters(cm) { 9 | let gutters = cm.display.gutters, specs = cm.options.gutters 10 | removeChildren(gutters) 11 | let i = 0 12 | for (; i < specs.length; ++i) { 13 | let gutterClass = specs[i] 14 | let gElt = gutters.appendChild(elt("div", null, "CodeMirror-gutter " + gutterClass)) 15 | if (gutterClass == "CodeMirror-linenumbers") { 16 | cm.display.lineGutter = gElt 17 | gElt.style.width = (cm.display.lineNumWidth || 1) + "px" 18 | } 19 | } 20 | gutters.style.display = i ? "" : "none" 21 | updateGutterSpace(cm) 22 | } 23 | 24 | // Make sure the gutters options contains the element 25 | // "CodeMirror-linenumbers" when the lineNumbers option is true. 26 | export function setGuttersForLineNumbers(options) { 27 | let found = indexOf(options.gutters, "CodeMirror-linenumbers") 28 | if (found == -1 && options.lineNumbers) { 29 | options.gutters = options.gutters.concat(["CodeMirror-linenumbers"]) 30 | } else if (found > -1 && !options.lineNumbers) { 31 | options.gutters = options.gutters.slice(0) 32 | options.gutters.splice(found, 1) 33 | } 34 | } 35 | -------------------------------------------------------------------------------- /JsBox/public/static/js/manifest.67d95f4f2bac744a9e68.js: -------------------------------------------------------------------------------- 1 | !function(e){function r(n){if(t[n])return t[n].exports;var o=t[n]={i:n,l:!1,exports:{}};return e[n].call(o.exports,o,o.exports,r),o.l=!0,o.exports}var n=window.webpackJsonp;window.webpackJsonp=function(t,c,a){for(var i,u,f,s=0,l=[];s { 5 | axios.post(url, form).then(response => { 6 | if (response.status === 200) { 7 | resolve(response.data) 8 | } else { 9 | reject(response.data.message) 10 | } 11 | }).catch(e => { 12 | reject(e) 13 | }) 14 | }) 15 | } 16 | 17 | export function get (url, form = {}, cache = false) { 18 | if (cache) { 19 | const key = url + form.toString() 20 | const sessionData = window.sessionStorage.getItem(key) 21 | return new Promise((resolve, reject) => { 22 | if (sessionData) { 23 | resolve(JSON.parse(sessionData)) 24 | } else { 25 | getFromServer(url, form).then(data => { 26 | window.sessionStorage.setItem(key, JSON.stringify(data)) 27 | resolve(data) 28 | }).catch(e => { 29 | reject(e) 30 | }) 31 | } 32 | }) 33 | } else { 34 | return getFromServer(url, form) 35 | } 36 | } 37 | 38 | function getFromServer (url, params) { 39 | return new Promise(function (resolve, reject) { 40 | if (Object.getOwnPropertyNames(params).length > 0) { 41 | url += '?' 42 | for (const f in params) { 43 | url += f + '=' + params[f] + '&' 44 | } 45 | url = url.substring(0, url.length - 1) 46 | } 47 | axios.get(url).then(response => { 48 | if (response.status === 200) { 49 | resolve(response.data) 50 | } else { 51 | reject(response.data.message) 52 | } 53 | }).catch(e => { 54 | reject(e) 55 | }) 56 | }) 57 | } 58 | -------------------------------------------------------------------------------- /front-vue/config/index.js: -------------------------------------------------------------------------------- 1 | // see http://vuejs-templates.github.io/webpack for documentation. 2 | var path = require('path') 3 | 4 | module.exports = { 5 | build: { 6 | env: require('./prod.env'), 7 | index: path.resolve(__dirname, '../dist/index.html'), 8 | assetsRoot: path.resolve(__dirname, '../dist'), 9 | assetsSubDirectory: 'static', 10 | assetsPublicPath: '/', 11 | productionSourceMap: false, 12 | // Gzip off by default as many popular static hosts such as 13 | // Surge or Netlify already gzip all static assets for you. 14 | // Before setting to `true`, make sure to: 15 | // npm install --save-dev compression-webpack-plugin 16 | productionGzip: false, 17 | productionGzipExtensions: ['js', 'css'], 18 | // Run the build command with an extra argument to 19 | // View the bundle analyzer report after build finishes: 20 | // `npm run build --report` 21 | // Set to `true` or `false` to always turn it on or off 22 | bundleAnalyzerReport: process.env.npm_config_report 23 | }, 24 | dev: { 25 | env: require('./dev.env'), 26 | port: 3000, 27 | autoOpenBrowser: true, 28 | assetsSubDirectory: 'static', 29 | assetsPublicPath: '/', 30 | proxyTable: {}, 31 | // CSS Sourcemaps off by default because relative paths are "buggy" 32 | // with this option, according to the CSS-Loader README 33 | // (https://github.com/webpack/css-loader#sourcemaps) 34 | // In our experience, they generally work as expected, 35 | // just be aware of this issue when enabling this option. 36 | cssSourceMap: false 37 | } 38 | } 39 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/edit/global_events.js: -------------------------------------------------------------------------------- 1 | import { onBlur } from "../display/focus" 2 | import { on } from "../util/event" 3 | 4 | // These must be handled carefully, because naively registering a 5 | // handler for each editor will cause the editors to never be 6 | // garbage collected. 7 | 8 | function forEachCodeMirror(f) { 9 | if (!document.body.getElementsByClassName) return 10 | let byClass = document.body.getElementsByClassName("CodeMirror") 11 | for (let i = 0; i < byClass.length; i++) { 12 | let cm = byClass[i].CodeMirror 13 | if (cm) f(cm) 14 | } 15 | } 16 | 17 | let globalsRegistered = false 18 | export function ensureGlobalHandlers() { 19 | if (globalsRegistered) return 20 | registerGlobalHandlers() 21 | globalsRegistered = true 22 | } 23 | function registerGlobalHandlers() { 24 | // When the window resizes, we need to refresh active editors. 25 | let resizeTimer 26 | on(window, "resize", () => { 27 | if (resizeTimer == null) resizeTimer = setTimeout(() => { 28 | resizeTimer = null 29 | forEachCodeMirror(onResize) 30 | }, 100) 31 | }) 32 | // When the window loses focus, we want to show the editor as blurred 33 | on(window, "blur", () => forEachCodeMirror(onBlur)) 34 | } 35 | // Called when the window resizes 36 | function onResize(cm) { 37 | let d = cm.display 38 | if (d.lastWrapHeight == d.wrapper.clientHeight && d.lastWrapWidth == d.wrapper.clientWidth) 39 | return 40 | // Might be a text scaling operation, clear size caches. 41 | d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null 42 | d.scrollbarsClipped = false 43 | cm.setSize() 44 | } 45 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/scroll/simplescrollbars.css: -------------------------------------------------------------------------------- 1 | .CodeMirror-simplescroll-horizontal div, .CodeMirror-simplescroll-vertical div { 2 | position: absolute; 3 | background: #ccc; 4 | -moz-box-sizing: border-box; 5 | box-sizing: border-box; 6 | border: 1px solid #bbb; 7 | border-radius: 2px; 8 | } 9 | 10 | .CodeMirror-simplescroll-horizontal, .CodeMirror-simplescroll-vertical { 11 | position: absolute; 12 | z-index: 6; 13 | background: #eee; 14 | } 15 | 16 | .CodeMirror-simplescroll-horizontal { 17 | bottom: 0; left: 0; 18 | height: 8px; 19 | } 20 | .CodeMirror-simplescroll-horizontal div { 21 | bottom: 0; 22 | height: 100%; 23 | } 24 | 25 | .CodeMirror-simplescroll-vertical { 26 | right: 0; top: 0; 27 | width: 8px; 28 | } 29 | .CodeMirror-simplescroll-vertical div { 30 | right: 0; 31 | width: 100%; 32 | } 33 | 34 | 35 | .CodeMirror-overlayscroll .CodeMirror-scrollbar-filler, .CodeMirror-overlayscroll .CodeMirror-gutter-filler { 36 | display: none; 37 | } 38 | 39 | .CodeMirror-overlayscroll-horizontal div, .CodeMirror-overlayscroll-vertical div { 40 | position: absolute; 41 | background: #bcd; 42 | border-radius: 3px; 43 | } 44 | 45 | .CodeMirror-overlayscroll-horizontal, .CodeMirror-overlayscroll-vertical { 46 | position: absolute; 47 | z-index: 6; 48 | } 49 | 50 | .CodeMirror-overlayscroll-horizontal { 51 | bottom: 0; left: 0; 52 | height: 6px; 53 | } 54 | .CodeMirror-overlayscroll-horizontal div { 55 | bottom: 0; 56 | height: 100%; 57 | } 58 | 59 | .CodeMirror-overlayscroll-vertical { 60 | right: 0; top: 0; 61 | width: 6px; 62 | } 63 | .CodeMirror-overlayscroll-vertical div { 64 | right: 0; 65 | width: 100%; 66 | } 67 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/display/fullscreen.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror")); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror"], mod); 9 | else // Plain browser env 10 | mod(CodeMirror); 11 | })(function(CodeMirror) { 12 | "use strict"; 13 | 14 | CodeMirror.defineOption("fullScreen", false, function(cm, val, old) { 15 | if (old == CodeMirror.Init) old = false; 16 | if (!old == !val) return; 17 | if (val) setFullscreen(cm); 18 | else setNormal(cm); 19 | }); 20 | 21 | function setFullscreen(cm) { 22 | var wrap = cm.getWrapperElement(); 23 | cm.state.fullScreenRestore = {scrollTop: window.pageYOffset, scrollLeft: window.pageXOffset, 24 | width: wrap.style.width, height: wrap.style.height}; 25 | wrap.style.width = ""; 26 | wrap.style.height = "auto"; 27 | wrap.className += " CodeMirror-fullscreen"; 28 | document.documentElement.style.overflow = "hidden"; 29 | cm.refresh(); 30 | } 31 | 32 | function setNormal(cm) { 33 | var wrap = cm.getWrapperElement(); 34 | wrap.className = wrap.className.replace(/\s*CodeMirror-fullscreen\b/, ""); 35 | document.documentElement.style.overflow = ""; 36 | var info = cm.state.fullScreenRestore; 37 | wrap.style.width = info.width; wrap.style.height = info.height; 38 | window.scrollTo(info.scrollLeft, info.scrollTop); 39 | cm.refresh(); 40 | } 41 | }); 42 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/line/pos.js: -------------------------------------------------------------------------------- 1 | import { getLine } from "./utils_line" 2 | 3 | // A Pos instance represents a position within the text. 4 | export function Pos(line, ch, sticky = null) { 5 | if (!(this instanceof Pos)) return new Pos(line, ch, sticky) 6 | this.line = line 7 | this.ch = ch 8 | this.sticky = sticky 9 | } 10 | 11 | // Compare two positions, return 0 if they are the same, a negative 12 | // number when a is less, and a positive number otherwise. 13 | export function cmp(a, b) { return a.line - b.line || a.ch - b.ch } 14 | 15 | export function equalCursorPos(a, b) { return a.sticky == b.sticky && cmp(a, b) == 0 } 16 | 17 | export function copyPos(x) {return Pos(x.line, x.ch)} 18 | export function maxPos(a, b) { return cmp(a, b) < 0 ? b : a } 19 | export function minPos(a, b) { return cmp(a, b) < 0 ? a : b } 20 | 21 | // Most of the external API clips given positions to make sure they 22 | // actually exist within the document. 23 | export function clipLine(doc, n) {return Math.max(doc.first, Math.min(n, doc.first + doc.size - 1))} 24 | export function clipPos(doc, pos) { 25 | if (pos.line < doc.first) return Pos(doc.first, 0) 26 | let last = doc.first + doc.size - 1 27 | if (pos.line > last) return Pos(last, getLine(doc, last).text.length) 28 | return clipToLen(pos, getLine(doc, pos.line).text.length) 29 | } 30 | function clipToLen(pos, linelen) { 31 | let ch = pos.ch 32 | if (ch == null || ch > linelen) return Pos(pos.line, linelen) 33 | else if (ch < 0) return Pos(pos.line, 0) 34 | else return pos 35 | } 36 | export function clipPosArray(doc, array) { 37 | let out = [] 38 | for (let i = 0; i < array.length; i++) out[i] = clipPos(doc, array[i]) 39 | return out 40 | } 41 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/display/focus.js: -------------------------------------------------------------------------------- 1 | import { restartBlink } from "./selection" 2 | import { webkit } from "../util/browser" 3 | import { addClass, rmClass } from "../util/dom" 4 | import { signal } from "../util/event" 5 | 6 | export function ensureFocus(cm) { 7 | if (!cm.state.focused) { cm.display.input.focus(); onFocus(cm) } 8 | } 9 | 10 | export function delayBlurEvent(cm) { 11 | cm.state.delayingBlurEvent = true 12 | setTimeout(() => { if (cm.state.delayingBlurEvent) { 13 | cm.state.delayingBlurEvent = false 14 | onBlur(cm) 15 | } }, 100) 16 | } 17 | 18 | export function onFocus(cm, e) { 19 | if (cm.state.delayingBlurEvent) cm.state.delayingBlurEvent = false 20 | 21 | if (cm.options.readOnly == "nocursor") return 22 | if (!cm.state.focused) { 23 | signal(cm, "focus", cm, e) 24 | cm.state.focused = true 25 | addClass(cm.display.wrapper, "CodeMirror-focused") 26 | // This test prevents this from firing when a context 27 | // menu is closed (since the input reset would kill the 28 | // select-all detection hack) 29 | if (!cm.curOp && cm.display.selForContextMenu != cm.doc.sel) { 30 | cm.display.input.reset() 31 | if (webkit) setTimeout(() => cm.display.input.reset(true), 20) // Issue #1730 32 | } 33 | cm.display.input.receivedFocus() 34 | } 35 | restartBlink(cm) 36 | } 37 | export function onBlur(cm, e) { 38 | if (cm.state.delayingBlurEvent) return 39 | 40 | if (cm.state.focused) { 41 | signal(cm, "blur", cm, e) 42 | cm.state.focused = false 43 | rmClass(cm.display.wrapper, "CodeMirror-focused") 44 | } 45 | clearInterval(cm.display.blinker) 46 | setTimeout(() => { if (!cm.state.focused) cm.display.shift = false }, 150) 47 | } 48 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/lint/html-lint.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | // Depends on htmlhint.js from http://htmlhint.com/js/htmlhint.js 5 | 6 | // declare global: HTMLHint 7 | 8 | (function(mod) { 9 | if (typeof exports == "object" && typeof module == "object") // CommonJS 10 | mod(require("../../lib/codemirror"), require("htmlhint")); 11 | else if (typeof define == "function" && define.amd) // AMD 12 | define(["../../lib/codemirror", "htmlhint"], mod); 13 | else // Plain browser env 14 | mod(CodeMirror); 15 | })(function(CodeMirror) { 16 | "use strict"; 17 | 18 | var defaultRules = { 19 | "tagname-lowercase": true, 20 | "attr-lowercase": true, 21 | "attr-value-double-quotes": true, 22 | "doctype-first": false, 23 | "tag-pair": true, 24 | "spec-char-escape": true, 25 | "id-unique": true, 26 | "src-not-empty": true, 27 | "attr-no-duplication": true 28 | }; 29 | 30 | CodeMirror.registerHelper("lint", "html", function(text, options) { 31 | var found = []; 32 | if (!window.HTMLHint) return found; 33 | var messages = HTMLHint.verify(text, options && options.rules || defaultRules); 34 | for (var i = 0; i < messages.length; i++) { 35 | var message = messages[i]; 36 | var startLine = message.line - 1, endLine = message.line - 1, startCol = message.col - 1, endCol = message.col; 37 | found.push({ 38 | from: CodeMirror.Pos(startLine, startCol), 39 | to: CodeMirror.Pos(endLine, endCol), 40 | message: message.message, 41 | severity : message.type 42 | }); 43 | } 44 | return found; 45 | }); 46 | }); 47 | -------------------------------------------------------------------------------- /JsBox/app.js: -------------------------------------------------------------------------------- 1 | var express = require('express'); 2 | var path = require('path'); 3 | var favicon = require('serve-favicon'); 4 | var logger = require('morgan'); 5 | var cookieParser = require('cookie-parser'); 6 | var bodyParser = require('body-parser'); 7 | var cors = require('cors'); 8 | 9 | var index = require('./routes/index'); 10 | var users = require('./routes/users'); 11 | 12 | var app = express(); 13 | 14 | // view engine setup 15 | app.set('views', path.join(__dirname, 'views')); 16 | app.set('view engine', 'jade'); 17 | 18 | // uncomment after placing your favicon in /public 19 | //app.use(favicon(path.join(__dirname, 'public', 'favicon.ico'))); 20 | app.use(logger('dev')); 21 | app.use(bodyParser.json()); 22 | app.use(bodyParser.urlencoded({ extended: false })); 23 | app.use(cookieParser()); 24 | app.use(express.static(path.join(__dirname, 'public'))); 25 | app.use(cors()); 26 | 27 | //var corsOptions = { 28 | // origin: 'http://example.com', 29 | // optionsSuccessStatus: 200 // some legacy browsers (IE11, various SmartTVs) choke on 204 30 | //} 31 | // 32 | //app.use('/', corsOptions, index); 33 | 34 | app.use('/api', index); 35 | app.use('/users', users); 36 | 37 | // catch 404 and forward to error handler 38 | app.use(function(req, res, next) { 39 | var err = new Error('Not Found'); 40 | err.status = 404; 41 | next(err); 42 | }); 43 | 44 | // error handler 45 | app.use(function(err, req, res, next) { 46 | // set locals, only providing error in development 47 | res.locals.message = err.message; 48 | res.locals.error = req.app.get('env') === 'development' ? err : {}; 49 | 50 | // render the error page 51 | res.status(err.status || 500); 52 | res.render('error'); 53 | }); 54 | 55 | module.exports = app; 56 | 57 | 58 | //https://github.com/expressjs/cors 59 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/display/autorefresh.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror")) 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror"], mod) 9 | else // Plain browser env 10 | mod(CodeMirror) 11 | })(function(CodeMirror) { 12 | "use strict" 13 | 14 | CodeMirror.defineOption("autoRefresh", false, function(cm, val) { 15 | if (cm.state.autoRefresh) { 16 | stopListening(cm, cm.state.autoRefresh) 17 | cm.state.autoRefresh = null 18 | } 19 | if (val && cm.display.wrapper.offsetHeight == 0) 20 | startListening(cm, cm.state.autoRefresh = {delay: val.delay || 250}) 21 | }) 22 | 23 | function startListening(cm, state) { 24 | function check() { 25 | if (cm.display.wrapper.offsetHeight) { 26 | stopListening(cm, state) 27 | if (cm.display.lastWrapHeight != cm.display.wrapper.clientHeight) 28 | cm.refresh() 29 | } else { 30 | state.timeout = setTimeout(check, state.delay) 31 | } 32 | } 33 | state.timeout = setTimeout(check, state.delay) 34 | state.hurry = function() { 35 | clearTimeout(state.timeout) 36 | state.timeout = setTimeout(check, 50) 37 | } 38 | CodeMirror.on(window, "mouseup", state.hurry) 39 | CodeMirror.on(window, "keyup", state.hurry) 40 | } 41 | 42 | function stopListening(_cm, state) { 43 | clearTimeout(state.timeout) 44 | CodeMirror.off(window, "mouseup", state.hurry) 45 | CodeMirror.off(window, "keyup", state.hurry) 46 | } 47 | }); 48 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/scroll/scrollpastend.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror")); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror"], mod); 9 | else // Plain browser env 10 | mod(CodeMirror); 11 | })(function(CodeMirror) { 12 | "use strict"; 13 | 14 | CodeMirror.defineOption("scrollPastEnd", false, function(cm, val, old) { 15 | if (old && old != CodeMirror.Init) { 16 | cm.off("change", onChange); 17 | cm.off("refresh", updateBottomMargin); 18 | cm.display.lineSpace.parentNode.style.paddingBottom = ""; 19 | cm.state.scrollPastEndPadding = null; 20 | } 21 | if (val) { 22 | cm.on("change", onChange); 23 | cm.on("refresh", updateBottomMargin); 24 | updateBottomMargin(cm); 25 | } 26 | }); 27 | 28 | function onChange(cm, change) { 29 | if (CodeMirror.changeEnd(change).line == cm.lastLine()) 30 | updateBottomMargin(cm); 31 | } 32 | 33 | function updateBottomMargin(cm) { 34 | var padding = ""; 35 | if (cm.lineCount() > 1) { 36 | var totalH = cm.display.scroller.clientHeight - 30, 37 | lastLineH = cm.getLineHandle(cm.lastLine()).height; 38 | padding = (totalH - lastLineH) + "px"; 39 | } 40 | if (cm.state.scrollPastEndPadding != padding) { 41 | cm.state.scrollPastEndPadding = padding; 42 | cm.display.lineSpace.parentNode.style.paddingBottom = padding; 43 | cm.off("refresh", updateBottomMargin); 44 | cm.setSize(); 45 | cm.on("refresh", updateBottomMargin); 46 | } 47 | } 48 | }); 49 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/fold/markdown-fold.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror")); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror"], mod); 9 | else // Plain browser env 10 | mod(CodeMirror); 11 | })(function(CodeMirror) { 12 | "use strict"; 13 | 14 | CodeMirror.registerHelper("fold", "markdown", function(cm, start) { 15 | var maxDepth = 100; 16 | 17 | function isHeader(lineNo) { 18 | var tokentype = cm.getTokenTypeAt(CodeMirror.Pos(lineNo, 0)); 19 | return tokentype && /\bheader\b/.test(tokentype); 20 | } 21 | 22 | function headerLevel(lineNo, line, nextLine) { 23 | var match = line && line.match(/^#+/); 24 | if (match && isHeader(lineNo)) return match[0].length; 25 | match = nextLine && nextLine.match(/^[=\-]+\s*$/); 26 | if (match && isHeader(lineNo + 1)) return nextLine[0] == "=" ? 1 : 2; 27 | return maxDepth; 28 | } 29 | 30 | var firstLine = cm.getLine(start.line), nextLine = cm.getLine(start.line + 1); 31 | var level = headerLevel(start.line, firstLine, nextLine); 32 | if (level === maxDepth) return undefined; 33 | 34 | var lastLineNo = cm.lastLine(); 35 | var end = start.line, nextNextLine = cm.getLine(end + 2); 36 | while (end < lastLineNo) { 37 | if (headerLevel(end + 1, nextLine, nextNextLine) <= level) break; 38 | ++end; 39 | nextLine = nextNextLine; 40 | nextNextLine = cm.getLine(end + 2); 41 | } 42 | 43 | return { 44 | from: CodeMirror.Pos(start.line, firstLine.length), 45 | to: CodeMirror.Pos(end, cm.getLine(end).length) 46 | }; 47 | }); 48 | 49 | }); 50 | -------------------------------------------------------------------------------- /front-vue/build/webpack.base.conf.js: -------------------------------------------------------------------------------- 1 | var path = require('path') 2 | var utils = require('./utils') 3 | var config = require('../config/index') 4 | var vueLoaderConfig = require('./vue-loader.conf') 5 | 6 | function resolve (dir) { 7 | return path.join(__dirname, '..', dir) 8 | } 9 | 10 | module.exports = { 11 | entry: { 12 | app: './src/main.js' 13 | }, 14 | output: { 15 | path: config.build.assetsRoot, 16 | filename: '[name].js', 17 | publicPath: process.env.NODE_ENV === 'production' 18 | ? config.build.assetsPublicPath 19 | : config.dev.assetsPublicPath 20 | }, 21 | resolve: { 22 | extensions: ['.js', '.vue', '.json'], 23 | alias: { 24 | 'vue$': 'vue/dist/vue.esm.js', 25 | '@': resolve('src') 26 | } 27 | }, 28 | module: { 29 | rules: [ 30 | { 31 | test: /\.(js|vue)$/, 32 | loader: 'eslint-loader', 33 | enforce: 'pre', 34 | include: [resolve('src'), resolve('test')], 35 | options: { 36 | formatter: require('eslint-friendly-formatter') 37 | } 38 | }, 39 | { 40 | test: /\.vue$/, 41 | loader: 'vue-loader', 42 | options: vueLoaderConfig 43 | }, 44 | { 45 | test: /\.js$/, 46 | loader: 'babel-loader', 47 | include: [resolve('src'), resolve('test')] 48 | }, 49 | { 50 | test: /\.(png|jpe?g|gif|svg)(\?.*)?$/, 51 | loader: 'url-loader', 52 | options: { 53 | limit: 10000, 54 | name: utils.assetsPath('img/[name].[hash:7].[ext]') 55 | } 56 | }, 57 | { 58 | test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/, 59 | loader: 'url-loader', 60 | options: { 61 | limit: 10000, 62 | name: utils.assetsPath('fonts/[name].[hash:7].[ext]') 63 | } 64 | } 65 | ] 66 | } 67 | } 68 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/hint/anyword-hint.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror")); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror"], mod); 9 | else // Plain browser env 10 | mod(CodeMirror); 11 | })(function(CodeMirror) { 12 | "use strict"; 13 | 14 | var WORD = /[\w$]+/, RANGE = 500; 15 | 16 | CodeMirror.registerHelper("hint", "anyword", function(editor, options) { 17 | var word = options && options.word || WORD; 18 | var range = options && options.range || RANGE; 19 | var cur = editor.getCursor(), curLine = editor.getLine(cur.line); 20 | var end = cur.ch, start = end; 21 | while (start && word.test(curLine.charAt(start - 1))) --start; 22 | var curWord = start != end && curLine.slice(start, end); 23 | 24 | var list = options && options.list || [], seen = {}; 25 | var re = new RegExp(word.source, "g"); 26 | for (var dir = -1; dir <= 1; dir += 2) { 27 | var line = cur.line, endLine = Math.min(Math.max(line + dir * range, editor.firstLine()), editor.lastLine()) + dir; 28 | for (; line != endLine; line += dir) { 29 | var text = editor.getLine(line), m; 30 | while (m = re.exec(text)) { 31 | if (line == cur.line && m[0] === curWord) continue; 32 | if ((!curWord || m[0].lastIndexOf(curWord, 0) == 0) && !Object.prototype.hasOwnProperty.call(seen, m[0])) { 33 | seen[m[0]] = true; 34 | list.push(m[0]); 35 | } 36 | } 37 | } 38 | } 39 | return {list: list, from: CodeMirror.Pos(cur.line, start), to: CodeMirror.Pos(cur.line, end)}; 40 | }); 41 | }); 42 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/fold/indent-fold.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror")); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror"], mod); 9 | else // Plain browser env 10 | mod(CodeMirror); 11 | })(function(CodeMirror) { 12 | "use strict"; 13 | 14 | function lineIndent(cm, lineNo) { 15 | var text = cm.getLine(lineNo) 16 | var spaceTo = text.search(/\S/) 17 | if (spaceTo == -1 || /\bcomment\b/.test(cm.getTokenTypeAt(CodeMirror.Pos(lineNo, spaceTo + 1)))) 18 | return -1 19 | return CodeMirror.countColumn(text, null, cm.getOption("tabSize")) 20 | } 21 | ! 22 | CodeMirror.registerHelper("fold", "indent", function(cm, start) { 23 | var myIndent = lineIndent(cm, start.line) 24 | if (myIndent < 0) return 25 | var lastLineInFold = null 26 | 27 | // Go through lines until we find a line that definitely doesn't belong in 28 | // the block we're folding, or to the end. 29 | for (var i = start.line + 1, end = cm.lastLine(); i <= end; ++i) { 30 | var indent = lineIndent(cm, i) 31 | if (indent == -1) { 32 | } else if (indent > myIndent) { 33 | // Lines with a greater indent are considered part of the block. 34 | lastLineInFold = i; 35 | } else { 36 | // If this line has non-space, non-comment content, and is 37 | // indented less or equal to the start line, it is the start of 38 | // another block. 39 | break; 40 | } 41 | } 42 | if (lastLineInFold) return { 43 | from: CodeMirror.Pos(start.line, cm.getLine(start.line).length), 44 | to: CodeMirror.Pos(lastLineInFold, cm.getLine(lastLineInFold).length) 45 | }; 46 | }); 47 | 48 | }); 49 | -------------------------------------------------------------------------------- /JsBox/bin/www: -------------------------------------------------------------------------------- 1 | #!/usr/bin/env node 2 | 3 | /** 4 | * Module dependencies. 5 | */ 6 | 7 | var app = require('../app'); 8 | var debug = require('debug')('code-editor:server'); 9 | var http = require('http'); 10 | 11 | /** 12 | * Get port from environment and store in Express. 13 | */ 14 | 15 | var port = normalizePort(process.env.PORT || '3005'); 16 | app.set('port', port); 17 | 18 | /** 19 | * Create HTTP server. 20 | */ 21 | 22 | var server = http.createServer(app); 23 | 24 | /** 25 | * Listen on provided port, on all network interfaces. 26 | */ 27 | 28 | server.listen(port); 29 | server.on('error', onError); 30 | server.on('listening', onListening); 31 | 32 | /** 33 | * Normalize a port into a number, string, or false. 34 | */ 35 | 36 | function normalizePort(val) { 37 | var port = parseInt(val, 10); 38 | 39 | if (isNaN(port)) { 40 | // named pipe 41 | return val; 42 | } 43 | 44 | if (port >= 0) { 45 | // port number 46 | return port; 47 | } 48 | 49 | return false; 50 | } 51 | 52 | /** 53 | * Event listener for HTTP server "error" event. 54 | */ 55 | 56 | function onError(error) { 57 | if (error.syscall !== 'listen') { 58 | throw error; 59 | } 60 | 61 | var bind = typeof port === 'string' 62 | ? 'Pipe ' + port 63 | : 'Port ' + port; 64 | 65 | // handle specific listen errors with friendly messages 66 | switch (error.code) { 67 | case 'EACCES': 68 | console.error(bind + ' requires elevated privileges'); 69 | process.exit(1); 70 | break; 71 | case 'EADDRINUSE': 72 | console.error(bind + ' is already in use'); 73 | process.exit(1); 74 | break; 75 | default: 76 | throw error; 77 | } 78 | } 79 | 80 | /** 81 | * Event listener for HTTP server "listening" event. 82 | */ 83 | 84 | function onListening() { 85 | var addr = server.address(); 86 | var bind = typeof addr === 'string' 87 | ? 'pipe ' + addr 88 | : 'port ' + addr.port; 89 | debug('Listening on ' + bind); 90 | } 91 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/util/browser.js: -------------------------------------------------------------------------------- 1 | // Kludges for bugs and behavior differences that can't be feature 2 | // detected are enabled based on userAgent etc sniffing. 3 | let userAgent = navigator.userAgent 4 | let platform = navigator.platform 5 | 6 | export let gecko = /gecko\/\d/i.test(userAgent) 7 | let ie_upto10 = /MSIE \d/.test(userAgent) 8 | let ie_11up = /Trident\/(?:[7-9]|\d{2,})\..*rv:(\d+)/.exec(userAgent) 9 | let edge = /Edge\/(\d+)/.exec(userAgent) 10 | export let ie = ie_upto10 || ie_11up || edge 11 | export let ie_version = ie && (ie_upto10 ? document.documentMode || 6 : +(edge || ie_11up)[1]) 12 | export let webkit = !edge && /WebKit\//.test(userAgent) 13 | let qtwebkit = webkit && /Qt\/\d+\.\d+/.test(userAgent) 14 | export let chrome = !edge && /Chrome\//.test(userAgent) 15 | export let presto = /Opera\//.test(userAgent) 16 | export let safari = /Apple Computer/.test(navigator.vendor) 17 | export let mac_geMountainLion = /Mac OS X 1\d\D([8-9]|\d\d)\D/.test(userAgent) 18 | export let phantom = /PhantomJS/.test(userAgent) 19 | 20 | export let ios = !edge && /AppleWebKit/.test(userAgent) && /Mobile\/\w+/.test(userAgent) 21 | export let android = /Android/.test(userAgent) 22 | // This is woefully incomplete. Suggestions for alternative methods welcome. 23 | export let mobile = ios || android || /webOS|BlackBerry|Opera Mini|Opera Mobi|IEMobile/i.test(userAgent) 24 | export let mac = ios || /Mac/.test(platform) 25 | export let chromeOS = /\bCrOS\b/.test(userAgent) 26 | export let windows = /win/i.test(platform) 27 | 28 | let presto_version = presto && userAgent.match(/Version\/(\d*\.\d*)/) 29 | if (presto_version) presto_version = Number(presto_version[1]) 30 | if (presto_version && presto_version >= 15) { presto = false; webkit = true } 31 | // Some browsers use the wrong event properties to signal cmd/ctrl on OS X 32 | export let flipCtrlCmd = mac && (qtwebkit || presto && (presto_version == null || presto_version < 12.11)) 33 | export let captureRightClick = gecko || (ie && ie_version >= 9) 34 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/theme/blackboard.css: -------------------------------------------------------------------------------- 1 | /* Port of TextMate's Blackboard theme */ 2 | 3 | .cm-s-blackboard.CodeMirror { background: #0C1021; color: #F8F8F8; } 4 | .cm-s-blackboard div.CodeMirror-selected { background: #253B76; } 5 | .cm-s-blackboard .CodeMirror-line::selection, .cm-s-blackboard .CodeMirror-line > span::selection, .cm-s-blackboard .CodeMirror-line > span > span::selection { background: rgba(37, 59, 118, .99); } 6 | .cm-s-blackboard .CodeMirror-line::-moz-selection, .cm-s-blackboard .CodeMirror-line > span::-moz-selection, .cm-s-blackboard .CodeMirror-line > span > span::-moz-selection { background: rgba(37, 59, 118, .99); } 7 | .cm-s-blackboard .CodeMirror-gutters { background: #0C1021; border-right: 0; } 8 | .cm-s-blackboard .CodeMirror-guttermarker { color: #FBDE2D; } 9 | .cm-s-blackboard .CodeMirror-guttermarker-subtle { color: #888; } 10 | .cm-s-blackboard .CodeMirror-linenumber { color: #888; } 11 | .cm-s-blackboard .CodeMirror-cursor { border-left: 1px solid #A7A7A7; } 12 | 13 | .cm-s-blackboard .cm-keyword { color: #FBDE2D; } 14 | .cm-s-blackboard .cm-atom { color: #D8FA3C; } 15 | .cm-s-blackboard .cm-number { color: #D8FA3C; } 16 | .cm-s-blackboard .cm-def { color: #8DA6CE; } 17 | .cm-s-blackboard .cm-variable { color: #FF6400; } 18 | .cm-s-blackboard .cm-operator { color: #FBDE2D; } 19 | .cm-s-blackboard .cm-comment { color: #AEAEAE; } 20 | .cm-s-blackboard .cm-string { color: #61CE3C; } 21 | .cm-s-blackboard .cm-string-2 { color: #61CE3C; } 22 | .cm-s-blackboard .cm-meta { color: #D8FA3C; } 23 | .cm-s-blackboard .cm-builtin { color: #8DA6CE; } 24 | .cm-s-blackboard .cm-tag { color: #8DA6CE; } 25 | .cm-s-blackboard .cm-attribute { color: #8DA6CE; } 26 | .cm-s-blackboard .cm-header { color: #FF6400; } 27 | .cm-s-blackboard .cm-hr { color: #AEAEAE; } 28 | .cm-s-blackboard .cm-link { color: #8DA6CE; } 29 | .cm-s-blackboard .cm-error { background: #9D1E15; color: #F8F8F8; } 30 | 31 | .cm-s-blackboard .CodeMirror-activeline-background { background: #3C3636; } 32 | .cm-s-blackboard .CodeMirror-matchingbracket { outline:1px solid grey;color:white !important; } 33 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/edit/continuelist.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror")); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror"], mod); 9 | else // Plain browser env 10 | mod(CodeMirror); 11 | })(function(CodeMirror) { 12 | "use strict"; 13 | 14 | var listRE = /^(\s*)(>[> ]*|[*+-] \[[x ]\]\s|[*+-]\s|(\d+)([.)]))(\s*)/, 15 | emptyListRE = /^(\s*)(>[> ]*|[*+-] \[[x ]\]|[*+-]|(\d+)[.)])(\s*)$/, 16 | unorderedListRE = /[*+-]\s/; 17 | 18 | CodeMirror.commands.newlineAndIndentContinueMarkdownList = function(cm) { 19 | if (cm.getOption("disableInput")) return CodeMirror.Pass; 20 | var ranges = cm.listSelections(), replacements = []; 21 | for (var i = 0; i < ranges.length; i++) { 22 | var pos = ranges[i].head; 23 | var eolState = cm.getStateAfter(pos.line); 24 | var inList = eolState.list !== false; 25 | var inQuote = eolState.quote !== 0; 26 | 27 | var line = cm.getLine(pos.line), match = listRE.exec(line); 28 | if (!ranges[i].empty() || (!inList && !inQuote) || !match) { 29 | cm.execCommand("newlineAndIndent"); 30 | return; 31 | } 32 | if (emptyListRE.test(line)) { 33 | if (!/>\s*$/.test(line)) cm.replaceRange("", { 34 | line: pos.line, ch: 0 35 | }, { 36 | line: pos.line, ch: pos.ch + 1 37 | }); 38 | replacements[i] = "\n"; 39 | } else { 40 | var indent = match[1], after = match[5]; 41 | var bullet = unorderedListRE.test(match[2]) || match[2].indexOf(">") >= 0 42 | ? match[2].replace("x", " ") 43 | : (parseInt(match[3], 10) + 1) + match[4]; 44 | 45 | replacements[i] = "\n" + indent + bullet + after; 46 | } 47 | } 48 | 49 | cm.replaceSelections(replacements); 50 | }; 51 | }); 52 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/display/rulers.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror")); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror"], mod); 9 | else // Plain browser env 10 | mod(CodeMirror); 11 | })(function(CodeMirror) { 12 | "use strict"; 13 | 14 | CodeMirror.defineOption("rulers", false, function(cm, val) { 15 | if (cm.state.rulerDiv) { 16 | cm.state.rulerDiv.parentElement.removeChild(cm.state.rulerDiv) 17 | cm.state.rulerDiv = null 18 | cm.off("refresh", drawRulers) 19 | } 20 | if (val && val.length) { 21 | cm.state.rulerDiv = cm.display.lineSpace.parentElement.insertBefore(document.createElement("div"), cm.display.lineSpace) 22 | cm.state.rulerDiv.className = "CodeMirror-rulers" 23 | drawRulers(cm) 24 | cm.on("refresh", drawRulers) 25 | } 26 | }); 27 | 28 | function drawRulers(cm) { 29 | cm.state.rulerDiv.textContent = "" 30 | var val = cm.getOption("rulers"); 31 | var cw = cm.defaultCharWidth(); 32 | var left = cm.charCoords(CodeMirror.Pos(cm.firstLine(), 0), "div").left; 33 | cm.state.rulerDiv.style.minHeight = (cm.display.scroller.offsetHeight + 30) + "px"; 34 | for (var i = 0; i < val.length; i++) { 35 | var elt = document.createElement("div"); 36 | elt.className = "CodeMirror-ruler"; 37 | var col, conf = val[i]; 38 | if (typeof conf == "number") { 39 | col = conf; 40 | } else { 41 | col = conf.column; 42 | if (conf.className) elt.className += " " + conf.className; 43 | if (conf.color) elt.style.borderColor = conf.color; 44 | if (conf.lineStyle) elt.style.borderLeftStyle = conf.lineStyle; 45 | if (conf.width) elt.style.borderLeftWidth = conf.width; 46 | } 47 | elt.style.left = (left + col * cw) + "px"; 48 | cm.state.rulerDiv.appendChild(elt) 49 | } 50 | } 51 | }); 52 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/search/jump-to-line.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | // Defines jumpToLine command. Uses dialog.js if present. 5 | 6 | (function(mod) { 7 | if (typeof exports == "object" && typeof module == "object") // CommonJS 8 | mod(require("../../lib/codemirror"), require("../dialog/dialog")); 9 | else if (typeof define == "function" && define.amd) // AMD 10 | define(["../../lib/codemirror", "../dialog/dialog"], mod); 11 | else // Plain browser env 12 | mod(CodeMirror); 13 | })(function(CodeMirror) { 14 | "use strict"; 15 | 16 | function dialog(cm, text, shortText, deflt, f) { 17 | if (cm.openDialog) cm.openDialog(text, f, {value: deflt, selectValueOnOpen: true}); 18 | else f(prompt(shortText, deflt)); 19 | } 20 | 21 | var jumpDialog = 22 | 'Jump to line: (Use line:column or scroll% syntax)'; 23 | 24 | function interpretLine(cm, string) { 25 | var num = Number(string) 26 | if (/^[-+]/.test(string)) return cm.getCursor().line + num 27 | else return num - 1 28 | } 29 | 30 | CodeMirror.commands.jumpToLine = function(cm) { 31 | var cur = cm.getCursor(); 32 | dialog(cm, jumpDialog, "Jump to line:", (cur.line + 1) + ":" + cur.ch, function(posStr) { 33 | if (!posStr) return; 34 | 35 | var match; 36 | if (match = /^\s*([\+\-]?\d+)\s*\:\s*(\d+)\s*$/.exec(posStr)) { 37 | cm.setCursor(interpretLine(cm, match[1]), Number(match[2])) 38 | } else if (match = /^\s*([\+\-]?\d+(\.\d+)?)\%\s*/.exec(posStr)) { 39 | var line = Math.round(cm.lineCount() * Number(match[1]) / 100); 40 | if (/^[-+]/.test(match[1])) line = cur.line + line + 1; 41 | cm.setCursor(line - 1, cur.ch); 42 | } else if (match = /^\s*\:?\s*([\+\-]?\d+)\s*/.exec(posStr)) { 43 | cm.setCursor(interpretLine(cm, match[1]), cur.ch); 44 | } 45 | }); 46 | }; 47 | 48 | CodeMirror.keyMap["default"]["Alt-G"] = "jumpToLine"; 49 | }); 50 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/edit/fromTextArea.js: -------------------------------------------------------------------------------- 1 | import { CodeMirror } from "./CodeMirror" 2 | import { activeElt } from "../util/dom" 3 | import { off, on } from "../util/event" 4 | import { copyObj } from "../util/misc" 5 | 6 | export function fromTextArea(textarea, options) { 7 | options = options ? copyObj(options) : {} 8 | options.value = textarea.value 9 | if (!options.tabindex && textarea.tabIndex) 10 | options.tabindex = textarea.tabIndex 11 | if (!options.placeholder && textarea.placeholder) 12 | options.placeholder = textarea.placeholder 13 | // Set autofocus to true if this textarea is focused, or if it has 14 | // autofocus and no other element is focused. 15 | if (options.autofocus == null) { 16 | let hasFocus = activeElt() 17 | options.autofocus = hasFocus == textarea || 18 | textarea.getAttribute("autofocus") != null && hasFocus == document.body 19 | } 20 | 21 | function save() {textarea.value = cm.getValue()} 22 | 23 | let realSubmit 24 | if (textarea.form) { 25 | on(textarea.form, "submit", save) 26 | // Deplorable hack to make the submit method do the right thing. 27 | if (!options.leaveSubmitMethodAlone) { 28 | let form = textarea.form 29 | realSubmit = form.submit 30 | try { 31 | let wrappedSubmit = form.submit = () => { 32 | save() 33 | form.submit = realSubmit 34 | form.submit() 35 | form.submit = wrappedSubmit 36 | } 37 | } catch(e) {} 38 | } 39 | } 40 | 41 | options.finishInit = cm => { 42 | cm.save = save 43 | cm.getTextArea = () => textarea 44 | cm.toTextArea = () => { 45 | cm.toTextArea = isNaN // Prevent this from being ran twice 46 | save() 47 | textarea.parentNode.removeChild(cm.getWrapperElement()) 48 | textarea.style.display = "" 49 | if (textarea.form) { 50 | off(textarea.form, "submit", save) 51 | if (typeof textarea.form.submit == "function") 52 | textarea.form.submit = realSubmit 53 | } 54 | } 55 | } 56 | 57 | textarea.style.display = "none" 58 | let cm = CodeMirror(node => textarea.parentNode.insertBefore(node, textarea.nextSibling), 59 | options) 60 | return cm 61 | } 62 | -------------------------------------------------------------------------------- /front-vue/build/utils.js: -------------------------------------------------------------------------------- 1 | var path = require('path') 2 | var config = require('../config/index') 3 | var ExtractTextPlugin = require('extract-text-webpack-plugin') 4 | 5 | exports.assetsPath = function (_path) { 6 | var assetsSubDirectory = process.env.NODE_ENV === 'production' 7 | ? config.build.assetsSubDirectory 8 | : config.dev.assetsSubDirectory 9 | return path.posix.join(assetsSubDirectory, _path) 10 | } 11 | 12 | exports.cssLoaders = function (options) { 13 | options = options || {} 14 | 15 | var cssLoader = { 16 | loader: 'css-loader', 17 | options: { 18 | minimize: process.env.NODE_ENV === 'production', 19 | sourceMap: options.sourceMap 20 | } 21 | } 22 | 23 | // generate loader string to be used with extract text plugin 24 | function generateLoaders (loader, loaderOptions) { 25 | var loaders = [cssLoader] 26 | if (loader) { 27 | loaders.push({ 28 | loader: loader + '-loader', 29 | options: Object.assign({}, loaderOptions, { 30 | sourceMap: options.sourceMap 31 | }) 32 | }) 33 | } 34 | 35 | // Extract CSS when that option is specified 36 | // (which is the case during production build) 37 | if (options.extract) { 38 | return ExtractTextPlugin.extract({ 39 | use: loaders, 40 | fallback: 'vue-style-loader' 41 | }) 42 | } else { 43 | return ['vue-style-loader'].concat(loaders) 44 | } 45 | } 46 | 47 | // https://vue-loader.vuejs.org/en/configurations/extract-css.html 48 | return { 49 | css: generateLoaders(), 50 | postcss: generateLoaders(), 51 | less: generateLoaders('less'), 52 | sass: generateLoaders('sass', { indentedSyntax: true }), 53 | scss: generateLoaders('sass'), 54 | stylus: generateLoaders('stylus'), 55 | styl: generateLoaders('stylus') 56 | } 57 | } 58 | 59 | // Generate loaders for standalone style files (outside of .vue) 60 | exports.styleLoaders = function (options) { 61 | var output = [] 62 | var loaders = exports.cssLoaders(options) 63 | for (var extension in loaders) { 64 | var loader = loaders[extension] 65 | output.push({ 66 | test: new RegExp('\\.' + extension + '$'), 67 | use: loader 68 | }) 69 | } 70 | return output 71 | } 72 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/tern/tern.css: -------------------------------------------------------------------------------- 1 | .CodeMirror-Tern-completion { 2 | padding-left: 22px; 3 | position: relative; 4 | line-height: 1.5; 5 | } 6 | .CodeMirror-Tern-completion:before { 7 | position: absolute; 8 | left: 2px; 9 | bottom: 2px; 10 | border-radius: 50%; 11 | font-size: 12px; 12 | font-weight: bold; 13 | height: 15px; 14 | width: 15px; 15 | line-height: 16px; 16 | text-align: center; 17 | color: white; 18 | -moz-box-sizing: border-box; 19 | box-sizing: border-box; 20 | } 21 | .CodeMirror-Tern-completion-unknown:before { 22 | content: "?"; 23 | background: #4bb; 24 | } 25 | .CodeMirror-Tern-completion-object:before { 26 | content: "O"; 27 | background: #77c; 28 | } 29 | .CodeMirror-Tern-completion-fn:before { 30 | content: "F"; 31 | background: #7c7; 32 | } 33 | .CodeMirror-Tern-completion-array:before { 34 | content: "A"; 35 | background: #c66; 36 | } 37 | .CodeMirror-Tern-completion-number:before { 38 | content: "1"; 39 | background: #999; 40 | } 41 | .CodeMirror-Tern-completion-string:before { 42 | content: "S"; 43 | background: #999; 44 | } 45 | .CodeMirror-Tern-completion-bool:before { 46 | content: "B"; 47 | background: #999; 48 | } 49 | 50 | .CodeMirror-Tern-completion-guess { 51 | color: #999; 52 | } 53 | 54 | .CodeMirror-Tern-tooltip { 55 | border: 1px solid silver; 56 | border-radius: 3px; 57 | color: #444; 58 | padding: 2px 5px; 59 | font-size: 90%; 60 | font-family: monospace; 61 | background-color: white; 62 | white-space: pre-wrap; 63 | 64 | max-width: 40em; 65 | position: absolute; 66 | z-index: 10; 67 | -webkit-box-shadow: 2px 3px 5px rgba(0,0,0,.2); 68 | -moz-box-shadow: 2px 3px 5px rgba(0,0,0,.2); 69 | box-shadow: 2px 3px 5px rgba(0,0,0,.2); 70 | 71 | transition: opacity 1s; 72 | -moz-transition: opacity 1s; 73 | -webkit-transition: opacity 1s; 74 | -o-transition: opacity 1s; 75 | -ms-transition: opacity 1s; 76 | } 77 | 78 | .CodeMirror-Tern-hint-doc { 79 | max-width: 25em; 80 | margin-top: -3px; 81 | } 82 | 83 | .CodeMirror-Tern-fname { color: black; } 84 | .CodeMirror-Tern-farg { color: #70a; } 85 | .CodeMirror-Tern-farg-current { text-decoration: underline; } 86 | .CodeMirror-Tern-type { color: #07c; } 87 | .CodeMirror-Tern-fhint-guess { opacity: .7; } 88 | -------------------------------------------------------------------------------- /front-vue/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "vue-os", 3 | "version": "1.0.0", 4 | "description": "A Vue.js project", 5 | "author": "qwer <676080017@qq.com>", 6 | "private": true, 7 | "scripts": { 8 | "dev": "node build/dev-server.js", 9 | "start": "node build/dev-server.js", 10 | "build": "node build/build.js", 11 | "lint": "eslint --ext .js,.vue src" 12 | }, 13 | "dependencies": { 14 | "axios": "^0.16.1", 15 | "vue": "^2.2.6", 16 | "vue-router": "^2.3.1", 17 | "vuex": "^2.3.1" 18 | }, 19 | "devDependencies": { 20 | "autoprefixer": "^6.7.2", 21 | "babel-core": "^6.22.1", 22 | "babel-eslint": "^7.1.1", 23 | "babel-loader": "^6.2.10", 24 | "babel-plugin-transform-runtime": "^6.22.0", 25 | "babel-preset-env": "^1.3.2", 26 | "babel-preset-stage-2": "^6.22.0", 27 | "babel-register": "^6.22.0", 28 | "chalk": "^1.1.3", 29 | "connect-history-api-fallback": "^1.3.0", 30 | "copy-webpack-plugin": "^4.0.1", 31 | "css-loader": "^0.28.0", 32 | "eslint": "^3.19.0", 33 | "eslint-config-standard": "^6.2.1", 34 | "eslint-friendly-formatter": "^2.0.7", 35 | "eslint-loader": "^1.7.1", 36 | "eslint-plugin-html": "^2.0.0", 37 | "eslint-plugin-promise": "^3.4.0", 38 | "eslint-plugin-standard": "^2.0.1", 39 | "eventsource-polyfill": "^0.9.6", 40 | "express": "^4.14.1", 41 | "extract-text-webpack-plugin": "^2.0.0", 42 | "file-loader": "^0.11.1", 43 | "friendly-errors-webpack-plugin": "^1.1.3", 44 | "html-webpack-plugin": "^2.28.0", 45 | "http-proxy-middleware": "^0.17.3", 46 | "opn": "^4.0.2", 47 | "optimize-css-assets-webpack-plugin": "^1.3.0", 48 | "ora": "^1.2.0", 49 | "rimraf": "^2.6.0", 50 | "semver": "^5.3.0", 51 | "shelljs": "^0.7.6", 52 | "url-loader": "^0.5.8", 53 | "vue-loader": "^11.3.4", 54 | "vue-style-loader": "^2.0.5", 55 | "vue-template-compiler": "^2.2.6", 56 | "webpack": "^2.3.3", 57 | "webpack-bundle-analyzer": "^2.2.1", 58 | "webpack-dev-middleware": "^1.10.0", 59 | "webpack-hot-middleware": "^2.18.0", 60 | "webpack-merge": "^4.1.0" 61 | }, 62 | "engines": { 63 | "node": ">= 4.0.0", 64 | "npm": ">= 3.0.0" 65 | }, 66 | "browserslist": [ 67 | "> 1%", 68 | "last 2 versions", 69 | "not ie <= 8" 70 | ] 71 | } 72 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/edit/main.js: -------------------------------------------------------------------------------- 1 | // EDITOR CONSTRUCTOR 2 | 3 | import { CodeMirror } from "./CodeMirror" 4 | export { CodeMirror } from "./CodeMirror" 5 | 6 | import { eventMixin } from "../util/event" 7 | import { indexOf } from "../util/misc" 8 | 9 | import { defineOptions } from "./options" 10 | 11 | defineOptions(CodeMirror) 12 | 13 | import addEditorMethods from "./methods" 14 | 15 | addEditorMethods(CodeMirror) 16 | 17 | import Doc from "../model/Doc" 18 | 19 | // Set up methods on CodeMirror's prototype to redirect to the editor's document. 20 | let dontDelegate = "iter insert remove copy getEditor constructor".split(" ") 21 | for (let prop in Doc.prototype) if (Doc.prototype.hasOwnProperty(prop) && indexOf(dontDelegate, prop) < 0) 22 | CodeMirror.prototype[prop] = (function(method) { 23 | return function() {return method.apply(this.doc, arguments)} 24 | })(Doc.prototype[prop]) 25 | 26 | eventMixin(Doc) 27 | 28 | // INPUT HANDLING 29 | 30 | import ContentEditableInput from "../input/ContentEditableInput" 31 | import TextareaInput from "../input/TextareaInput" 32 | CodeMirror.inputStyles = {"textarea": TextareaInput, "contenteditable": ContentEditableInput} 33 | 34 | // MODE DEFINITION AND QUERYING 35 | 36 | import { defineMIME, defineMode } from "../modes" 37 | 38 | // Extra arguments are stored as the mode's dependencies, which is 39 | // used by (legacy) mechanisms like loadmode.js to automatically 40 | // load a mode. (Preferred mechanism is the require/define calls.) 41 | CodeMirror.defineMode = function(name/*, mode, …*/) { 42 | if (!CodeMirror.defaults.mode && name != "null") CodeMirror.defaults.mode = name 43 | defineMode.apply(this, arguments) 44 | } 45 | 46 | CodeMirror.defineMIME = defineMIME 47 | 48 | // Minimal default mode. 49 | CodeMirror.defineMode("null", () => ({token: stream => stream.skipToEnd()})) 50 | CodeMirror.defineMIME("text/plain", "null") 51 | 52 | // EXTENSIONS 53 | 54 | CodeMirror.defineExtension = (name, func) => { 55 | CodeMirror.prototype[name] = func 56 | } 57 | CodeMirror.defineDocExtension = (name, func) => { 58 | Doc.prototype[name] = func 59 | } 60 | 61 | import { fromTextArea } from "./fromTextArea" 62 | 63 | CodeMirror.fromTextArea = fromTextArea 64 | 65 | import { addLegacyProps } from "./legacy" 66 | 67 | addLegacyProps(CodeMirror) 68 | 69 | CodeMirror.version = "5.25.3" 70 | -------------------------------------------------------------------------------- /JsBox/service/verifyCode.js: -------------------------------------------------------------------------------- 1 | var verifyCode = { 2 | getCode: function () { 3 | var result = {} 4 | var poemLength = poems.length 5 | var curIndex = Math.round(Math.random() * (poemLength - 1)) 6 | var confuseIndexs = [] 7 | while (confuseIndexs.length < 3) { 8 | var tempIndex = Math.round(Math.random() * (poemLength - 1)) 9 | if (curIndex !== tempIndex) { 10 | var hasEqual = false 11 | confuseIndexs.forEach(function (i) { 12 | if (i === tempIndex) { 13 | hasEqual = true 14 | } 15 | }) 16 | if (!hasEqual) { 17 | confuseIndexs.push(tempIndex) 18 | } 19 | } 20 | } 21 | 22 | var currentPoem = poems[curIndex] 23 | var curRandom = Math.round(Math.random() * (currentPoem.length - 2)) 24 | result.poem = currentPoem[curRandom] 25 | result.answer = currentPoem[curRandom + 1] 26 | result.options = [] 27 | var optionRandom = Math.round(Math.random() * (confuseIndexs.length - 1)) 28 | confuseIndexs.forEach(function (index) { 29 | if (index === confuseIndexs[optionRandom]) { 30 | result.options.push(currentPoem[curRandom + 1]) 31 | } 32 | var cPoem = poems[index] 33 | var cRandom = Math.round(Math.random() * (cPoem.length - 1)) 34 | result.options.push(cPoem[cRandom]) 35 | }) 36 | return result 37 | } 38 | } 39 | 40 | module.exports = verifyCode 41 | 42 | 43 | 44 | 45 | 46 | 47 | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 | var poems = [[ 64 | '慈母手中线', '游子身上衣','临行密密缝','意恐迟迟归','谁言寸草心','报得三春晖' 65 | ], [ 66 | '千山鸟飞绝', '万径人踪灭', '孤舟蓑笠翁', '独钓寒江雪' 67 | ], [ 68 | '松下问童子', '言师采药去', '只在此山中', '云深不知处' 69 | ], [ 70 | '月落乌啼霜满天', '江枫渔火对愁眠', '姑苏城外寒山寺', '夜半钟声到客船' 71 | ], [ 72 | '湖光秋月两相和', '潭面无风镜未磨', '遥望洞庭山水翠', '白银盘里一青螺' 73 | ], [ 74 | '锄禾日当午', '汗滴禾下土', '谁知盘中餐', '粒粒皆辛苦' 75 | ], [ 76 | '清明时节雨纷纷', '路上行人欲断魂', '借问酒家何处有', '牧童遥指杏花村' 77 | ], [ 78 | '千里莺啼绿映红', '水村山郭酒旗风', '南朝四百八十寺', '多少楼台烟雨中' 79 | ], [ 80 | '爆竹声中一岁除', '春风送暖入屠苏', '千门万户曈曈日', '总把新桃换旧符' 81 | ], [ 82 | '竹外桃花三两枝', '春江水暖鸭先知', '蒌蒿满地芦芽短', '正是河豚欲上时' 83 | ], [ 84 | '生当作人杰', '死亦为鬼雄', '至今思项羽', '不肯过江东' 85 | ], [ 86 | '毕竟西湖六月中', '风光不与四时同', '接天莲叶无穷碧', '映日荷花别样红' 87 | ], [ 88 | '草长莺飞二月天', '拂堤杨柳醉春烟', '儿童散学归来早', '忙趁东风放纸鸢' 89 | ], [ 90 | '两个黄鹂鸣翠柳', '一行白鹭上青天', '窗含西岭千秋雪', '门泊东吴万里船' 91 | ]] 92 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/display/line_numbers.js: -------------------------------------------------------------------------------- 1 | import { lineNumberFor } from "../line/utils_line" 2 | import { compensateForHScroll } from "../measurement/position_measurement" 3 | import { elt } from "../util/dom" 4 | 5 | import { updateGutterSpace } from "./update_display" 6 | 7 | // Re-align line numbers and gutter marks to compensate for 8 | // horizontal scrolling. 9 | export function alignHorizontally(cm) { 10 | let display = cm.display, view = display.view 11 | if (!display.alignWidgets && (!display.gutters.firstChild || !cm.options.fixedGutter)) return 12 | let comp = compensateForHScroll(display) - display.scroller.scrollLeft + cm.doc.scrollLeft 13 | let gutterW = display.gutters.offsetWidth, left = comp + "px" 14 | for (let i = 0; i < view.length; i++) if (!view[i].hidden) { 15 | if (cm.options.fixedGutter) { 16 | if (view[i].gutter) 17 | view[i].gutter.style.left = left 18 | if (view[i].gutterBackground) 19 | view[i].gutterBackground.style.left = left 20 | } 21 | let align = view[i].alignable 22 | if (align) for (let j = 0; j < align.length; j++) 23 | align[j].style.left = left 24 | } 25 | if (cm.options.fixedGutter) 26 | display.gutters.style.left = (comp + gutterW) + "px" 27 | } 28 | 29 | // Used to ensure that the line number gutter is still the right 30 | // size for the current document size. Returns true when an update 31 | // is needed. 32 | export function maybeUpdateLineNumberWidth(cm) { 33 | if (!cm.options.lineNumbers) return false 34 | let doc = cm.doc, last = lineNumberFor(cm.options, doc.first + doc.size - 1), display = cm.display 35 | if (last.length != display.lineNumChars) { 36 | let test = display.measure.appendChild(elt("div", [elt("div", last)], 37 | "CodeMirror-linenumber CodeMirror-gutter-elt")) 38 | let innerW = test.firstChild.offsetWidth, padding = test.offsetWidth - innerW 39 | display.lineGutter.style.width = "" 40 | display.lineNumInnerWidth = Math.max(innerW, display.lineGutter.offsetWidth - padding) + 1 41 | display.lineNumWidth = display.lineNumInnerWidth + padding 42 | display.lineNumChars = display.lineNumInnerWidth ? last.length : -1 43 | display.lineGutter.style.width = display.lineNumWidth + "px" 44 | updateGutterSpace(cm) 45 | return true 46 | } 47 | return false 48 | } 49 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/theme/erlang-dark.css: -------------------------------------------------------------------------------- 1 | .cm-s-erlang-dark.CodeMirror { background: #002240; color: white; } 2 | .cm-s-erlang-dark div.CodeMirror-selected { background: #b36539; } 3 | .cm-s-erlang-dark .CodeMirror-line::selection, .cm-s-erlang-dark .CodeMirror-line > span::selection, .cm-s-erlang-dark .CodeMirror-line > span > span::selection { background: rgba(179, 101, 57, .99); } 4 | .cm-s-erlang-dark .CodeMirror-line::-moz-selection, .cm-s-erlang-dark .CodeMirror-line > span::-moz-selection, .cm-s-erlang-dark .CodeMirror-line > span > span::-moz-selection { background: rgba(179, 101, 57, .99); } 5 | .cm-s-erlang-dark .CodeMirror-gutters { background: #002240; border-right: 1px solid #aaa; } 6 | .cm-s-erlang-dark .CodeMirror-guttermarker { color: white; } 7 | .cm-s-erlang-dark .CodeMirror-guttermarker-subtle { color: #d0d0d0; } 8 | .cm-s-erlang-dark .CodeMirror-linenumber { color: #d0d0d0; } 9 | .cm-s-erlang-dark .CodeMirror-cursor { border-left: 1px solid white; } 10 | 11 | .cm-s-erlang-dark span.cm-quote { color: #ccc; } 12 | .cm-s-erlang-dark span.cm-atom { color: #f133f1; } 13 | .cm-s-erlang-dark span.cm-attribute { color: #ff80e1; } 14 | .cm-s-erlang-dark span.cm-bracket { color: #ff9d00; } 15 | .cm-s-erlang-dark span.cm-builtin { color: #eaa; } 16 | .cm-s-erlang-dark span.cm-comment { color: #77f; } 17 | .cm-s-erlang-dark span.cm-def { color: #e7a; } 18 | .cm-s-erlang-dark span.cm-keyword { color: #ffee80; } 19 | .cm-s-erlang-dark span.cm-meta { color: #50fefe; } 20 | .cm-s-erlang-dark span.cm-number { color: #ffd0d0; } 21 | .cm-s-erlang-dark span.cm-operator { color: #d55; } 22 | .cm-s-erlang-dark span.cm-property { color: #ccc; } 23 | .cm-s-erlang-dark span.cm-qualifier { color: #ccc; } 24 | .cm-s-erlang-dark span.cm-special { color: #ffbbbb; } 25 | .cm-s-erlang-dark span.cm-string { color: #3ad900; } 26 | .cm-s-erlang-dark span.cm-string-2 { color: #ccc; } 27 | .cm-s-erlang-dark span.cm-tag { color: #9effff; } 28 | .cm-s-erlang-dark span.cm-variable { color: #50fe50; } 29 | .cm-s-erlang-dark span.cm-variable-2 { color: #e0e; } 30 | .cm-s-erlang-dark span.cm-variable-3 { color: #ccc; } 31 | .cm-s-erlang-dark span.cm-error { color: #9d1e15; } 32 | 33 | .cm-s-erlang-dark .CodeMirror-activeline-background { background: #013461; } 34 | .cm-s-erlang-dark .CodeMirror-matchingbracket { outline:1px solid grey; color:white !important; } 35 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/display/highlight_worker.js: -------------------------------------------------------------------------------- 1 | import { getStateBefore, highlightLine, processLine } from "../line/highlight" 2 | import { copyState } from "../modes" 3 | import { bind } from "../util/misc" 4 | 5 | import { runInOp } from "./operations" 6 | import { regLineChange } from "./view_tracking" 7 | 8 | // HIGHLIGHT WORKER 9 | 10 | export function startWorker(cm, time) { 11 | if (cm.doc.mode.startState && cm.doc.frontier < cm.display.viewTo) 12 | cm.state.highlight.set(time, bind(highlightWorker, cm)) 13 | } 14 | 15 | function highlightWorker(cm) { 16 | let doc = cm.doc 17 | if (doc.frontier < doc.first) doc.frontier = doc.first 18 | if (doc.frontier >= cm.display.viewTo) return 19 | let end = +new Date + cm.options.workTime 20 | let state = copyState(doc.mode, getStateBefore(cm, doc.frontier)) 21 | let changedLines = [] 22 | 23 | doc.iter(doc.frontier, Math.min(doc.first + doc.size, cm.display.viewTo + 500), line => { 24 | if (doc.frontier >= cm.display.viewFrom) { // Visible 25 | let oldStyles = line.styles, tooLong = line.text.length > cm.options.maxHighlightLength 26 | let highlighted = highlightLine(cm, line, tooLong ? copyState(doc.mode, state) : state, true) 27 | line.styles = highlighted.styles 28 | let oldCls = line.styleClasses, newCls = highlighted.classes 29 | if (newCls) line.styleClasses = newCls 30 | else if (oldCls) line.styleClasses = null 31 | let ischange = !oldStyles || oldStyles.length != line.styles.length || 32 | oldCls != newCls && (!oldCls || !newCls || oldCls.bgClass != newCls.bgClass || oldCls.textClass != newCls.textClass) 33 | for (let i = 0; !ischange && i < oldStyles.length; ++i) ischange = oldStyles[i] != line.styles[i] 34 | if (ischange) changedLines.push(doc.frontier) 35 | line.stateAfter = tooLong ? state : copyState(doc.mode, state) 36 | } else { 37 | if (line.text.length <= cm.options.maxHighlightLength) 38 | processLine(cm, line.text, state) 39 | line.stateAfter = doc.frontier % 5 == 0 ? copyState(doc.mode, state) : null 40 | } 41 | ++doc.frontier 42 | if (+new Date > end) { 43 | startWorker(cm, cm.options.workDelay) 44 | return true 45 | } 46 | }) 47 | if (changedLines.length) runInOp(cm, () => { 48 | for (let i = 0; i < changedLines.length; i++) 49 | regLineChange(cm, changedLines[i], "text") 50 | }) 51 | } 52 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/display/placeholder.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror")); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror"], mod); 9 | else // Plain browser env 10 | mod(CodeMirror); 11 | })(function(CodeMirror) { 12 | CodeMirror.defineOption("placeholder", "", function(cm, val, old) { 13 | var prev = old && old != CodeMirror.Init; 14 | if (val && !prev) { 15 | cm.on("blur", onBlur); 16 | cm.on("change", onChange); 17 | cm.on("swapDoc", onChange); 18 | onChange(cm); 19 | } else if (!val && prev) { 20 | cm.off("blur", onBlur); 21 | cm.off("change", onChange); 22 | cm.off("swapDoc", onChange); 23 | clearPlaceholder(cm); 24 | var wrapper = cm.getWrapperElement(); 25 | wrapper.className = wrapper.className.replace(" CodeMirror-empty", ""); 26 | } 27 | 28 | if (val && !cm.hasFocus()) onBlur(cm); 29 | }); 30 | 31 | function clearPlaceholder(cm) { 32 | if (cm.state.placeholder) { 33 | cm.state.placeholder.parentNode.removeChild(cm.state.placeholder); 34 | cm.state.placeholder = null; 35 | } 36 | } 37 | function setPlaceholder(cm) { 38 | clearPlaceholder(cm); 39 | var elt = cm.state.placeholder = document.createElement("pre"); 40 | elt.style.cssText = "height: 0; overflow: visible"; 41 | elt.className = "CodeMirror-placeholder"; 42 | var placeHolder = cm.getOption("placeholder") 43 | if (typeof placeHolder == "string") placeHolder = document.createTextNode(placeHolder) 44 | elt.appendChild(placeHolder) 45 | cm.display.lineSpace.insertBefore(elt, cm.display.lineSpace.firstChild); 46 | } 47 | 48 | function onBlur(cm) { 49 | if (isEmpty(cm)) setPlaceholder(cm); 50 | } 51 | function onChange(cm) { 52 | var wrapper = cm.getWrapperElement(), empty = isEmpty(cm); 53 | wrapper.className = wrapper.className.replace(" CodeMirror-empty", "") + (empty ? " CodeMirror-empty" : ""); 54 | 55 | if (empty) setPlaceholder(cm); 56 | else clearPlaceholder(cm); 57 | } 58 | 59 | function isEmpty(cm) { 60 | return (cm.lineCount() === 1) && (cm.getLine(0) === ""); 61 | } 62 | }); 63 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/fold/comment-fold.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror")); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror"], mod); 9 | else // Plain browser env 10 | mod(CodeMirror); 11 | })(function(CodeMirror) { 12 | "use strict"; 13 | 14 | CodeMirror.registerGlobalHelper("fold", "comment", function(mode) { 15 | return mode.blockCommentStart && mode.blockCommentEnd; 16 | }, function(cm, start) { 17 | var mode = cm.getModeAt(start), startToken = mode.blockCommentStart, endToken = mode.blockCommentEnd; 18 | if (!startToken || !endToken) return; 19 | var line = start.line, lineText = cm.getLine(line); 20 | 21 | var startCh; 22 | for (var at = start.ch, pass = 0;;) { 23 | var found = at <= 0 ? -1 : lineText.lastIndexOf(startToken, at - 1); 24 | if (found == -1) { 25 | if (pass == 1) return; 26 | pass = 1; 27 | at = lineText.length; 28 | continue; 29 | } 30 | if (pass == 1 && found < start.ch) return; 31 | if (/comment/.test(cm.getTokenTypeAt(CodeMirror.Pos(line, found + 1))) && 32 | (found == 0 || lineText.slice(found - endToken.length, found) == endToken || 33 | !/comment/.test(cm.getTokenTypeAt(CodeMirror.Pos(line, found))))) { 34 | startCh = found + startToken.length; 35 | break; 36 | } 37 | at = found - 1; 38 | } 39 | 40 | var depth = 1, lastLine = cm.lastLine(), end, endCh; 41 | outer: for (var i = line; i <= lastLine; ++i) { 42 | var text = cm.getLine(i), pos = i == line ? startCh : 0; 43 | for (;;) { 44 | var nextOpen = text.indexOf(startToken, pos), nextClose = text.indexOf(endToken, pos); 45 | if (nextOpen < 0) nextOpen = text.length; 46 | if (nextClose < 0) nextClose = text.length; 47 | pos = Math.min(nextOpen, nextClose); 48 | if (pos == text.length) break; 49 | if (pos == nextOpen) ++depth; 50 | else if (!--depth) { end = i; endCh = pos; break outer; } 51 | ++pos; 52 | } 53 | } 54 | if (end == null || line == end && endCh == startCh) return; 55 | return {from: CodeMirror.Pos(line, startCh), 56 | to: CodeMirror.Pos(end, endCh)}; 57 | }); 58 | 59 | }); 60 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/hint/css-hint.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror"), require("../../mode/css/css")); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror", "../../mode/css/css"], mod); 9 | else // Plain browser env 10 | mod(CodeMirror); 11 | })(function(CodeMirror) { 12 | "use strict"; 13 | 14 | var pseudoClasses = {link: 1, visited: 1, active: 1, hover: 1, focus: 1, 15 | "first-letter": 1, "first-line": 1, "first-child": 1, 16 | before: 1, after: 1, lang: 1}; 17 | 18 | CodeMirror.registerHelper("hint", "css", function(cm) { 19 | var cur = cm.getCursor(), token = cm.getTokenAt(cur); 20 | var inner = CodeMirror.innerMode(cm.getMode(), token.state); 21 | if (inner.mode.name != "css") return; 22 | 23 | if (token.type == "keyword" && "!important".indexOf(token.string) == 0) 24 | return {list: ["!important"], from: CodeMirror.Pos(cur.line, token.start), 25 | to: CodeMirror.Pos(cur.line, token.end)}; 26 | 27 | var start = token.start, end = cur.ch, word = token.string.slice(0, end - start); 28 | if (/[^\w$_-]/.test(word)) { 29 | word = ""; start = end = cur.ch; 30 | } 31 | 32 | var spec = CodeMirror.resolveMode("text/css"); 33 | 34 | var result = []; 35 | function add(keywords) { 36 | for (var name in keywords) 37 | if (!word || name.lastIndexOf(word, 0) == 0) 38 | result.push(name); 39 | } 40 | 41 | var st = inner.state.state; 42 | if (st == "pseudo" || token.type == "variable-3") { 43 | add(pseudoClasses); 44 | } else if (st == "block" || st == "maybeprop") { 45 | add(spec.propertyKeywords); 46 | } else if (st == "prop" || st == "parens" || st == "at" || st == "params") { 47 | add(spec.valueKeywords); 48 | add(spec.colorKeywords); 49 | } else if (st == "media" || st == "media_parens") { 50 | add(spec.mediaTypes); 51 | add(spec.mediaFeatures); 52 | } 53 | 54 | if (result.length) return { 55 | list: result, 56 | from: CodeMirror.Pos(cur.line, start), 57 | to: CodeMirror.Pos(cur.line, end) 58 | }; 59 | }); 60 | }); 61 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/util/operation_group.js: -------------------------------------------------------------------------------- 1 | import { getHandlers } from "./event" 2 | 3 | let operationGroup = null 4 | 5 | export function pushOperation(op) { 6 | if (operationGroup) { 7 | operationGroup.ops.push(op) 8 | } else { 9 | op.ownsGroup = operationGroup = { 10 | ops: [op], 11 | delayedCallbacks: [] 12 | } 13 | } 14 | } 15 | 16 | function fireCallbacksForOps(group) { 17 | // Calls delayed callbacks and cursorActivity handlers until no 18 | // new ones appear 19 | let callbacks = group.delayedCallbacks, i = 0 20 | do { 21 | for (; i < callbacks.length; i++) 22 | callbacks[i].call(null) 23 | for (let j = 0; j < group.ops.length; j++) { 24 | let op = group.ops[j] 25 | if (op.cursorActivityHandlers) 26 | while (op.cursorActivityCalled < op.cursorActivityHandlers.length) 27 | op.cursorActivityHandlers[op.cursorActivityCalled++].call(null, op.cm) 28 | } 29 | } while (i < callbacks.length) 30 | } 31 | 32 | export function finishOperation(op, endCb) { 33 | let group = op.ownsGroup 34 | if (!group) return 35 | 36 | try { fireCallbacksForOps(group) } 37 | finally { 38 | operationGroup = null 39 | endCb(group) 40 | } 41 | } 42 | 43 | let orphanDelayedCallbacks = null 44 | 45 | // Often, we want to signal events at a point where we are in the 46 | // middle of some work, but don't want the handler to start calling 47 | // other methods on the editor, which might be in an inconsistent 48 | // state or simply not expect any other events to happen. 49 | // signalLater looks whether there are any handlers, and schedules 50 | // them to be executed when the last operation ends, or, if no 51 | // operation is active, when a timeout fires. 52 | export function signalLater(emitter, type /*, values...*/) { 53 | let arr = getHandlers(emitter, type) 54 | if (!arr.length) return 55 | let args = Array.prototype.slice.call(arguments, 2), list 56 | if (operationGroup) { 57 | list = operationGroup.delayedCallbacks 58 | } else if (orphanDelayedCallbacks) { 59 | list = orphanDelayedCallbacks 60 | } else { 61 | list = orphanDelayedCallbacks = [] 62 | setTimeout(fireOrphanDelayed, 0) 63 | } 64 | for (let i = 0; i < arr.length; ++i) 65 | list.push(() => arr[i].apply(null, args)) 66 | } 67 | 68 | function fireOrphanDelayed() { 69 | let delayed = orphanDelayedCallbacks 70 | orphanDelayedCallbacks = null 71 | for (let i = 0; i < delayed.length; ++i) delayed[i]() 72 | } 73 | -------------------------------------------------------------------------------- /front-vue/src/components/popShare.vue: -------------------------------------------------------------------------------- 1 | 12 | 13 | 54 | 55 | 99 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/model/change_measurement.js: -------------------------------------------------------------------------------- 1 | import { cmp, Pos } from "../line/pos" 2 | import { lst } from "../util/misc" 3 | 4 | import { normalizeSelection, Range, Selection } from "./selection" 5 | 6 | // Compute the position of the end of a change (its 'to' property 7 | // refers to the pre-change end). 8 | export function changeEnd(change) { 9 | if (!change.text) return change.to 10 | return Pos(change.from.line + change.text.length - 1, 11 | lst(change.text).length + (change.text.length == 1 ? change.from.ch : 0)) 12 | } 13 | 14 | // Adjust a position to refer to the post-change position of the 15 | // same text, or the end of the change if the change covers it. 16 | function adjustForChange(pos, change) { 17 | if (cmp(pos, change.from) < 0) return pos 18 | if (cmp(pos, change.to) <= 0) return changeEnd(change) 19 | 20 | let line = pos.line + change.text.length - (change.to.line - change.from.line) - 1, ch = pos.ch 21 | if (pos.line == change.to.line) ch += changeEnd(change).ch - change.to.ch 22 | return Pos(line, ch) 23 | } 24 | 25 | export function computeSelAfterChange(doc, change) { 26 | let out = [] 27 | for (let i = 0; i < doc.sel.ranges.length; i++) { 28 | let range = doc.sel.ranges[i] 29 | out.push(new Range(adjustForChange(range.anchor, change), 30 | adjustForChange(range.head, change))) 31 | } 32 | return normalizeSelection(out, doc.sel.primIndex) 33 | } 34 | 35 | function offsetPos(pos, old, nw) { 36 | if (pos.line == old.line) 37 | return Pos(nw.line, pos.ch - old.ch + nw.ch) 38 | else 39 | return Pos(nw.line + (pos.line - old.line), pos.ch) 40 | } 41 | 42 | // Used by replaceSelections to allow moving the selection to the 43 | // start or around the replaced test. Hint may be "start" or "around". 44 | export function computeReplacedSel(doc, changes, hint) { 45 | let out = [] 46 | let oldPrev = Pos(doc.first, 0), newPrev = oldPrev 47 | for (let i = 0; i < changes.length; i++) { 48 | let change = changes[i] 49 | let from = offsetPos(change.from, oldPrev, newPrev) 50 | let to = offsetPos(changeEnd(change), oldPrev, newPrev) 51 | oldPrev = change.to 52 | newPrev = to 53 | if (hint == "around") { 54 | let range = doc.sel.ranges[i], inv = cmp(range.head, range.anchor) < 0 55 | out[i] = new Range(inv ? to : from, inv ? from : to) 56 | } else { 57 | out[i] = new Range(from, from) 58 | } 59 | } 60 | return new Selection(out, doc.sel.primIndex) 61 | } 62 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/mode/loadmode.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror"), "cjs"); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror"], function(CM) { mod(CM, "amd"); }); 9 | else // Plain browser env 10 | mod(CodeMirror, "plain"); 11 | })(function(CodeMirror, env) { 12 | if (!CodeMirror.modeURL) CodeMirror.modeURL = "../mode/%N/%N.js"; 13 | 14 | var loading = {}; 15 | function splitCallback(cont, n) { 16 | var countDown = n; 17 | return function() { if (--countDown == 0) cont(); }; 18 | } 19 | function ensureDeps(mode, cont) { 20 | var deps = CodeMirror.modes[mode].dependencies; 21 | if (!deps) return cont(); 22 | var missing = []; 23 | for (var i = 0; i < deps.length; ++i) { 24 | if (!CodeMirror.modes.hasOwnProperty(deps[i])) 25 | missing.push(deps[i]); 26 | } 27 | if (!missing.length) return cont(); 28 | var split = splitCallback(cont, missing.length); 29 | for (var i = 0; i < missing.length; ++i) 30 | CodeMirror.requireMode(missing[i], split); 31 | } 32 | 33 | CodeMirror.requireMode = function(mode, cont) { 34 | if (typeof mode != "string") mode = mode.name; 35 | if (CodeMirror.modes.hasOwnProperty(mode)) return ensureDeps(mode, cont); 36 | if (loading.hasOwnProperty(mode)) return loading[mode].push(cont); 37 | 38 | var file = CodeMirror.modeURL.replace(/%N/g, mode); 39 | if (env == "plain") { 40 | var script = document.createElement("script"); 41 | script.src = file; 42 | var others = document.getElementsByTagName("script")[0]; 43 | var list = loading[mode] = [cont]; 44 | CodeMirror.on(script, "load", function() { 45 | ensureDeps(mode, function() { 46 | for (var i = 0; i < list.length; ++i) list[i](); 47 | }); 48 | }); 49 | others.parentNode.insertBefore(script, others); 50 | } else if (env == "cjs") { 51 | require(file); 52 | cont(); 53 | } else if (env == "amd") { 54 | requirejs([file], cont); 55 | } 56 | }; 57 | 58 | CodeMirror.autoLoadMode = function(instance, mode) { 59 | if (!CodeMirror.modes.hasOwnProperty(mode)) 60 | CodeMirror.requireMode(mode, function() { 61 | instance.setOption("mode", instance.getOption("mode")); 62 | }); 63 | }; 64 | }); 65 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/edit/matchtags.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror"), require("../fold/xml-fold")); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror", "../fold/xml-fold"], mod); 9 | else // Plain browser env 10 | mod(CodeMirror); 11 | })(function(CodeMirror) { 12 | "use strict"; 13 | 14 | CodeMirror.defineOption("matchTags", false, function(cm, val, old) { 15 | if (old && old != CodeMirror.Init) { 16 | cm.off("cursorActivity", doMatchTags); 17 | cm.off("viewportChange", maybeUpdateMatch); 18 | clear(cm); 19 | } 20 | if (val) { 21 | cm.state.matchBothTags = typeof val == "object" && val.bothTags; 22 | cm.on("cursorActivity", doMatchTags); 23 | cm.on("viewportChange", maybeUpdateMatch); 24 | doMatchTags(cm); 25 | } 26 | }); 27 | 28 | function clear(cm) { 29 | if (cm.state.tagHit) cm.state.tagHit.clear(); 30 | if (cm.state.tagOther) cm.state.tagOther.clear(); 31 | cm.state.tagHit = cm.state.tagOther = null; 32 | } 33 | 34 | function doMatchTags(cm) { 35 | cm.state.failedTagMatch = false; 36 | cm.operation(function() { 37 | clear(cm); 38 | if (cm.somethingSelected()) return; 39 | var cur = cm.getCursor(), range = cm.getViewport(); 40 | range.from = Math.min(range.from, cur.line); range.to = Math.max(cur.line + 1, range.to); 41 | var match = CodeMirror.findMatchingTag(cm, cur, range); 42 | if (!match) return; 43 | if (cm.state.matchBothTags) { 44 | var hit = match.at == "open" ? match.open : match.close; 45 | if (hit) cm.state.tagHit = cm.markText(hit.from, hit.to, {className: "CodeMirror-matchingtag"}); 46 | } 47 | var other = match.at == "close" ? match.open : match.close; 48 | if (other) 49 | cm.state.tagOther = cm.markText(other.from, other.to, {className: "CodeMirror-matchingtag"}); 50 | else 51 | cm.state.failedTagMatch = true; 52 | }); 53 | } 54 | 55 | function maybeUpdateMatch(cm) { 56 | if (cm.state.failedTagMatch) doMatchTags(cm); 57 | } 58 | 59 | CodeMirror.commands.toMatchingTag = function(cm) { 60 | var found = CodeMirror.findMatchingTag(cm, cm.getCursor()); 61 | if (found) { 62 | var other = found.at == "close" ? found.open : found.close; 63 | if (other) cm.extendSelection(other.to, other.from); 64 | } 65 | }; 66 | }); 67 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/edit/legacy.js: -------------------------------------------------------------------------------- 1 | import { scrollbarModel } from "../display/scrollbars" 2 | import { wheelEventPixels } from "../display/scroll_events" 3 | import { keyMap, keyName, isModifierKey, lookupKey, normalizeKeyMap } from "../input/keymap" 4 | import { keyNames } from "../input/keynames" 5 | import { Line } from "../line/line_data" 6 | import { cmp, Pos } from "../line/pos" 7 | import { changeEnd } from "../model/change_measurement" 8 | import Doc from "../model/Doc" 9 | import { LineWidget } from "../model/line_widget" 10 | import { SharedTextMarker, TextMarker } from "../model/mark_text" 11 | import { copyState, extendMode, getMode, innerMode, mimeModes, modeExtensions, modes, resolveMode, startState } from "../modes" 12 | import { addClass, contains, rmClass } from "../util/dom" 13 | import { e_preventDefault, e_stop, e_stopPropagation, off, on, signal } from "../util/event" 14 | import { splitLinesAuto } from "../util/feature_detection" 15 | import { countColumn, findColumn, isWordCharBasic, Pass } from "../util/misc" 16 | import StringStream from "../util/StringStream" 17 | 18 | import { commands } from "./commands" 19 | 20 | export function addLegacyProps(CodeMirror) { 21 | CodeMirror.off = off 22 | CodeMirror.on = on 23 | CodeMirror.wheelEventPixels = wheelEventPixels 24 | CodeMirror.Doc = Doc 25 | CodeMirror.splitLines = splitLinesAuto 26 | CodeMirror.countColumn = countColumn 27 | CodeMirror.findColumn = findColumn 28 | CodeMirror.isWordChar = isWordCharBasic 29 | CodeMirror.Pass = Pass 30 | CodeMirror.signal = signal 31 | CodeMirror.Line = Line 32 | CodeMirror.changeEnd = changeEnd 33 | CodeMirror.scrollbarModel = scrollbarModel 34 | CodeMirror.Pos = Pos 35 | CodeMirror.cmpPos = cmp 36 | CodeMirror.modes = modes 37 | CodeMirror.mimeModes = mimeModes 38 | CodeMirror.resolveMode = resolveMode 39 | CodeMirror.getMode = getMode 40 | CodeMirror.modeExtensions = modeExtensions 41 | CodeMirror.extendMode = extendMode 42 | CodeMirror.copyState = copyState 43 | CodeMirror.startState = startState 44 | CodeMirror.innerMode = innerMode 45 | CodeMirror.commands = commands 46 | CodeMirror.keyMap = keyMap 47 | CodeMirror.keyName = keyName 48 | CodeMirror.isModifierKey = isModifierKey 49 | CodeMirror.lookupKey = lookupKey 50 | CodeMirror.normalizeKeyMap = normalizeKeyMap 51 | CodeMirror.StringStream = StringStream 52 | CodeMirror.SharedTextMarker = SharedTextMarker 53 | CodeMirror.TextMarker = TextMarker 54 | CodeMirror.LineWidget = LineWidget 55 | CodeMirror.e_preventDefault = e_preventDefault 56 | CodeMirror.e_stopPropagation = e_stopPropagation 57 | CodeMirror.e_stop = e_stop 58 | CodeMirror.addClass = addClass 59 | CodeMirror.contains = contains 60 | CodeMirror.rmClass = rmClass 61 | CodeMirror.keyNames = keyNames 62 | } 63 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/runmode/runmode.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror")); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror"], mod); 9 | else // Plain browser env 10 | mod(CodeMirror); 11 | })(function(CodeMirror) { 12 | "use strict"; 13 | 14 | CodeMirror.runMode = function(string, modespec, callback, options) { 15 | var mode = CodeMirror.getMode(CodeMirror.defaults, modespec); 16 | var ie = /MSIE \d/.test(navigator.userAgent); 17 | var ie_lt9 = ie && (document.documentMode == null || document.documentMode < 9); 18 | 19 | if (callback.appendChild) { 20 | var tabSize = (options && options.tabSize) || CodeMirror.defaults.tabSize; 21 | var node = callback, col = 0; 22 | node.innerHTML = ""; 23 | callback = function(text, style) { 24 | if (text == "\n") { 25 | // Emitting LF or CRLF on IE8 or earlier results in an incorrect display. 26 | // Emitting a carriage return makes everything ok. 27 | node.appendChild(document.createTextNode(ie_lt9 ? '\r' : text)); 28 | col = 0; 29 | return; 30 | } 31 | var content = ""; 32 | // replace tabs 33 | for (var pos = 0;;) { 34 | var idx = text.indexOf("\t", pos); 35 | if (idx == -1) { 36 | content += text.slice(pos); 37 | col += text.length - pos; 38 | break; 39 | } else { 40 | col += idx - pos; 41 | content += text.slice(pos, idx); 42 | var size = tabSize - col % tabSize; 43 | col += size; 44 | for (var i = 0; i < size; ++i) content += " "; 45 | pos = idx + 1; 46 | } 47 | } 48 | 49 | if (style) { 50 | var sp = node.appendChild(document.createElement("span")); 51 | sp.className = "cm-" + style.replace(/ +/g, " cm-"); 52 | sp.appendChild(document.createTextNode(content)); 53 | } else { 54 | node.appendChild(document.createTextNode(content)); 55 | } 56 | }; 57 | } 58 | 59 | var lines = CodeMirror.splitLines(string), state = (options && options.state) || CodeMirror.startState(mode); 60 | for (var i = 0, e = lines.length; i < e; ++i) { 61 | if (i) callback("\n"); 62 | var stream = new CodeMirror.StringStream(lines[i]); 63 | if (!stream.string && mode.blankLine) mode.blankLine(state); 64 | while (!stream.eol()) { 65 | var style = mode.token(stream, state); 66 | callback(stream.current(), style, i, stream.start, state); 67 | stream.start = stream.pos; 68 | } 69 | } 70 | }; 71 | 72 | }); 73 | -------------------------------------------------------------------------------- /front-vue/build/dev-server.js: -------------------------------------------------------------------------------- 1 | require('./check-versions')() 2 | 3 | var config = require('../config/index') 4 | if (!process.env.NODE_ENV) { 5 | process.env.NODE_ENV = JSON.parse(config.dev.env.NODE_ENV) 6 | } 7 | 8 | var opn = require('opn') 9 | var path = require('path') 10 | var express = require('express') 11 | var webpack = require('webpack') 12 | var proxyMiddleware = require('http-proxy-middleware') 13 | var webpackConfig = require('./webpack.dev.conf') 14 | 15 | // default port where dev server listens for incoming traffic 16 | var port = process.env.PORT || config.dev.port 17 | // automatically open browser, if not set will be false 18 | var autoOpenBrowser = !!config.dev.autoOpenBrowser 19 | // Define HTTP proxies to your custom API backend 20 | // https://github.com/chimurai/http-proxy-middleware 21 | var proxyTable = config.dev.proxyTable 22 | 23 | var app = express() 24 | var compiler = webpack(webpackConfig) 25 | 26 | var devMiddleware = require('webpack-dev-middleware')(compiler, { 27 | publicPath: webpackConfig.output.publicPath, 28 | quiet: true 29 | }) 30 | 31 | var hotMiddleware = require('webpack-hot-middleware')(compiler, { 32 | log: () => {} 33 | }) 34 | // force page reload when html-webpack-plugin template changes 35 | compiler.plugin('compilation', function (compilation) { 36 | compilation.plugin('html-webpack-plugin-after-emit', function (data, cb) { 37 | hotMiddleware.publish({ action: 'reload' }) 38 | cb() 39 | }) 40 | }) 41 | 42 | // proxy api requests 43 | Object.keys(proxyTable).forEach(function (context) { 44 | var options = proxyTable[context] 45 | if (typeof options === 'string') { 46 | options = { target: options } 47 | } 48 | app.use(proxyMiddleware(options.filter || context, options)) 49 | }) 50 | 51 | // handle fallback for HTML5 history API 52 | app.use(require('connect-history-api-fallback')()) 53 | 54 | // serve webpack bundle output 55 | app.use(devMiddleware) 56 | 57 | // enable hot-reload and state-preserving 58 | // compilation error display 59 | app.use(hotMiddleware) 60 | 61 | // serve pure static assets 62 | var staticPath = path.posix.join(config.dev.assetsPublicPath, config.dev.assetsSubDirectory) 63 | app.use(staticPath, express.static('./static')) 64 | 65 | var uri = 'http://localhost:' + port 66 | 67 | var _resolve 68 | var readyPromise = new Promise(resolve => { 69 | _resolve = resolve 70 | }) 71 | 72 | console.log('> Starting dev server...') 73 | devMiddleware.waitUntilValid(() => { 74 | console.log('> Listening at ' + uri + '\n') 75 | // when env is testing, don't need open it 76 | if (autoOpenBrowser && process.env.NODE_ENV !== 'testing') { 77 | opn(uri) 78 | } 79 | _resolve() 80 | }) 81 | 82 | var server = app.listen(port) 83 | 84 | module.exports = { 85 | ready: readyPromise, 86 | close: () => { 87 | server.close() 88 | } 89 | } 90 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/selection/active-line.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror")); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror"], mod); 9 | else // Plain browser env 10 | mod(CodeMirror); 11 | })(function(CodeMirror) { 12 | "use strict"; 13 | var WRAP_CLASS = "CodeMirror-activeline"; 14 | var BACK_CLASS = "CodeMirror-activeline-background"; 15 | var GUTT_CLASS = "CodeMirror-activeline-gutter"; 16 | 17 | CodeMirror.defineOption("styleActiveLine", false, function(cm, val, old) { 18 | var prev = old == CodeMirror.Init ? false : old; 19 | if (val == prev) return 20 | if (prev) { 21 | cm.off("beforeSelectionChange", selectionChange); 22 | clearActiveLines(cm); 23 | delete cm.state.activeLines; 24 | } 25 | if (val) { 26 | cm.state.activeLines = []; 27 | updateActiveLines(cm, cm.listSelections()); 28 | cm.on("beforeSelectionChange", selectionChange); 29 | } 30 | }); 31 | 32 | function clearActiveLines(cm) { 33 | for (var i = 0; i < cm.state.activeLines.length; i++) { 34 | cm.removeLineClass(cm.state.activeLines[i], "wrap", WRAP_CLASS); 35 | cm.removeLineClass(cm.state.activeLines[i], "background", BACK_CLASS); 36 | cm.removeLineClass(cm.state.activeLines[i], "gutter", GUTT_CLASS); 37 | } 38 | } 39 | 40 | function sameArray(a, b) { 41 | if (a.length != b.length) return false; 42 | for (var i = 0; i < a.length; i++) 43 | if (a[i] != b[i]) return false; 44 | return true; 45 | } 46 | 47 | function updateActiveLines(cm, ranges) { 48 | var active = []; 49 | for (var i = 0; i < ranges.length; i++) { 50 | var range = ranges[i]; 51 | var option = cm.getOption("styleActiveLine"); 52 | if (typeof option == "object" && option.nonEmpty ? range.anchor.line != range.head.line : !range.empty()) 53 | continue 54 | var line = cm.getLineHandleVisualStart(range.head.line); 55 | if (active[active.length - 1] != line) active.push(line); 56 | } 57 | if (sameArray(cm.state.activeLines, active)) return; 58 | cm.operation(function() { 59 | clearActiveLines(cm); 60 | for (var i = 0; i < active.length; i++) { 61 | cm.addLineClass(active[i], "wrap", WRAP_CLASS); 62 | cm.addLineClass(active[i], "background", BACK_CLASS); 63 | cm.addLineClass(active[i], "gutter", GUTT_CLASS); 64 | } 65 | cm.state.activeLines = active; 66 | }); 67 | } 68 | 69 | function selectionChange(cm, sel) { 70 | updateActiveLines(cm, sel.ranges); 71 | } 72 | }); 73 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/display/update_lines.js: -------------------------------------------------------------------------------- 1 | import { heightAtLine } from "../line/spans" 2 | import { getLine, lineAtHeight, updateLineHeight } from "../line/utils_line" 3 | import { paddingTop, textHeight } from "../measurement/position_measurement" 4 | import { ie, ie_version } from "../util/browser" 5 | 6 | // Read the actual heights of the rendered lines, and update their 7 | // stored heights to match. 8 | export function updateHeightsInViewport(cm) { 9 | let display = cm.display 10 | let prevBottom = display.lineDiv.offsetTop 11 | for (let i = 0; i < display.view.length; i++) { 12 | let cur = display.view[i], height 13 | if (cur.hidden) continue 14 | if (ie && ie_version < 8) { 15 | let bot = cur.node.offsetTop + cur.node.offsetHeight 16 | height = bot - prevBottom 17 | prevBottom = bot 18 | } else { 19 | let box = cur.node.getBoundingClientRect() 20 | height = box.bottom - box.top 21 | } 22 | let diff = cur.line.height - height 23 | if (height < 2) height = textHeight(display) 24 | if (diff > .001 || diff < -.001) { 25 | updateLineHeight(cur.line, height) 26 | updateWidgetHeight(cur.line) 27 | if (cur.rest) for (let j = 0; j < cur.rest.length; j++) 28 | updateWidgetHeight(cur.rest[j]) 29 | } 30 | } 31 | } 32 | 33 | // Read and store the height of line widgets associated with the 34 | // given line. 35 | function updateWidgetHeight(line) { 36 | if (line.widgets) for (let i = 0; i < line.widgets.length; ++i) 37 | line.widgets[i].height = line.widgets[i].node.parentNode.offsetHeight 38 | } 39 | 40 | // Compute the lines that are visible in a given viewport (defaults 41 | // the the current scroll position). viewport may contain top, 42 | // height, and ensure (see op.scrollToPos) properties. 43 | export function visibleLines(display, doc, viewport) { 44 | let top = viewport && viewport.top != null ? Math.max(0, viewport.top) : display.scroller.scrollTop 45 | top = Math.floor(top - paddingTop(display)) 46 | let bottom = viewport && viewport.bottom != null ? viewport.bottom : top + display.wrapper.clientHeight 47 | 48 | let from = lineAtHeight(doc, top), to = lineAtHeight(doc, bottom) 49 | // Ensure is a {from: {line, ch}, to: {line, ch}} object, and 50 | // forces those lines into the viewport (if possible). 51 | if (viewport && viewport.ensure) { 52 | let ensureFrom = viewport.ensure.from.line, ensureTo = viewport.ensure.to.line 53 | if (ensureFrom < from) { 54 | from = ensureFrom 55 | to = lineAtHeight(doc, heightAtLine(getLine(doc, ensureFrom)) + display.wrapper.clientHeight) 56 | } else if (Math.min(ensureTo, doc.lastLine()) >= to) { 57 | from = lineAtHeight(doc, heightAtLine(getLine(doc, ensureTo)) - display.wrapper.clientHeight) 58 | to = ensureTo 59 | } 60 | } 61 | return {from: from, to: Math.max(to, from + 1)} 62 | } 63 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/util/StringStream.js: -------------------------------------------------------------------------------- 1 | import { countColumn } from "./misc" 2 | 3 | // STRING STREAM 4 | 5 | // Fed to the mode parsers, provides helper functions to make 6 | // parsers more succinct. 7 | 8 | class StringStream { 9 | constructor(string, tabSize) { 10 | this.pos = this.start = 0 11 | this.string = string 12 | this.tabSize = tabSize || 8 13 | this.lastColumnPos = this.lastColumnValue = 0 14 | this.lineStart = 0 15 | } 16 | 17 | eol() {return this.pos >= this.string.length} 18 | sol() {return this.pos == this.lineStart} 19 | peek() {return this.string.charAt(this.pos) || undefined} 20 | next() { 21 | if (this.pos < this.string.length) 22 | return this.string.charAt(this.pos++) 23 | } 24 | eat(match) { 25 | let ch = this.string.charAt(this.pos) 26 | let ok 27 | if (typeof match == "string") ok = ch == match 28 | else ok = ch && (match.test ? match.test(ch) : match(ch)) 29 | if (ok) {++this.pos; return ch} 30 | } 31 | eatWhile(match) { 32 | let start = this.pos 33 | while (this.eat(match)){} 34 | return this.pos > start 35 | } 36 | eatSpace() { 37 | let start = this.pos 38 | while (/[\s\u00a0]/.test(this.string.charAt(this.pos))) ++this.pos 39 | return this.pos > start 40 | } 41 | skipToEnd() {this.pos = this.string.length} 42 | skipTo(ch) { 43 | let found = this.string.indexOf(ch, this.pos) 44 | if (found > -1) {this.pos = found; return true} 45 | } 46 | backUp(n) {this.pos -= n} 47 | column() { 48 | if (this.lastColumnPos < this.start) { 49 | this.lastColumnValue = countColumn(this.string, this.start, this.tabSize, this.lastColumnPos, this.lastColumnValue) 50 | this.lastColumnPos = this.start 51 | } 52 | return this.lastColumnValue - (this.lineStart ? countColumn(this.string, this.lineStart, this.tabSize) : 0) 53 | } 54 | indentation() { 55 | return countColumn(this.string, null, this.tabSize) - 56 | (this.lineStart ? countColumn(this.string, this.lineStart, this.tabSize) : 0) 57 | } 58 | match(pattern, consume, caseInsensitive) { 59 | if (typeof pattern == "string") { 60 | let cased = str => caseInsensitive ? str.toLowerCase() : str 61 | let substr = this.string.substr(this.pos, pattern.length) 62 | if (cased(substr) == cased(pattern)) { 63 | if (consume !== false) this.pos += pattern.length 64 | return true 65 | } 66 | } else { 67 | let match = this.string.slice(this.pos).match(pattern) 68 | if (match && match.index > 0) return null 69 | if (match && consume !== false) this.pos += match[0].length 70 | return match 71 | } 72 | } 73 | current(){return this.string.slice(this.start, this.pos)} 74 | hideFirstChars(n, inner) { 75 | this.lineStart += n 76 | try { return inner() } 77 | finally { this.lineStart -= n } 78 | } 79 | } 80 | 81 | export default StringStream 82 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/line/utils_line.js: -------------------------------------------------------------------------------- 1 | import { indexOf } from "../util/misc" 2 | 3 | // Find the line object corresponding to the given line number. 4 | export function getLine(doc, n) { 5 | n -= doc.first 6 | if (n < 0 || n >= doc.size) throw new Error("There is no line " + (n + doc.first) + " in the document.") 7 | let chunk = doc 8 | while (!chunk.lines) { 9 | for (let i = 0;; ++i) { 10 | let child = chunk.children[i], sz = child.chunkSize() 11 | if (n < sz) { chunk = child; break } 12 | n -= sz 13 | } 14 | } 15 | return chunk.lines[n] 16 | } 17 | 18 | // Get the part of a document between two positions, as an array of 19 | // strings. 20 | export function getBetween(doc, start, end) { 21 | let out = [], n = start.line 22 | doc.iter(start.line, end.line + 1, line => { 23 | let text = line.text 24 | if (n == end.line) text = text.slice(0, end.ch) 25 | if (n == start.line) text = text.slice(start.ch) 26 | out.push(text) 27 | ++n 28 | }) 29 | return out 30 | } 31 | // Get the lines between from and to, as array of strings. 32 | export function getLines(doc, from, to) { 33 | let out = [] 34 | doc.iter(from, to, line => { out.push(line.text) }) // iter aborts when callback returns truthy value 35 | return out 36 | } 37 | 38 | // Update the height of a line, propagating the height change 39 | // upwards to parent nodes. 40 | export function updateLineHeight(line, height) { 41 | let diff = height - line.height 42 | if (diff) for (let n = line; n; n = n.parent) n.height += diff 43 | } 44 | 45 | // Given a line object, find its line number by walking up through 46 | // its parent links. 47 | export function lineNo(line) { 48 | if (line.parent == null) return null 49 | let cur = line.parent, no = indexOf(cur.lines, line) 50 | for (let chunk = cur.parent; chunk; cur = chunk, chunk = chunk.parent) { 51 | for (let i = 0;; ++i) { 52 | if (chunk.children[i] == cur) break 53 | no += chunk.children[i].chunkSize() 54 | } 55 | } 56 | return no + cur.first 57 | } 58 | 59 | // Find the line at the given vertical position, using the height 60 | // information in the document tree. 61 | export function lineAtHeight(chunk, h) { 62 | let n = chunk.first 63 | outer: do { 64 | for (let i = 0; i < chunk.children.length; ++i) { 65 | let child = chunk.children[i], ch = child.height 66 | if (h < ch) { chunk = child; continue outer } 67 | h -= ch 68 | n += child.chunkSize() 69 | } 70 | return n 71 | } while (!chunk.lines) 72 | let i = 0 73 | for (; i < chunk.lines.length; ++i) { 74 | let line = chunk.lines[i], lh = line.height 75 | if (h < lh) break 76 | h -= lh 77 | } 78 | return n + i 79 | } 80 | 81 | export function isLine(doc, l) {return l >= doc.first && l < doc.first + doc.size} 82 | 83 | export function lineNumberFor(options, i) { 84 | return String(options.lineNumberFormatter(i + options.firstLineNumber)) 85 | } 86 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/input/indent.js: -------------------------------------------------------------------------------- 1 | import { getStateBefore } from "../line/highlight" 2 | import { Pos } from "../line/pos" 3 | import { getLine } from "../line/utils_line" 4 | import { replaceRange } from "../model/changes" 5 | import { Range } from "../model/selection" 6 | import { replaceOneSelection } from "../model/selection_updates" 7 | import { countColumn, Pass, spaceStr } from "../util/misc" 8 | 9 | // Indent the given line. The how parameter can be "smart", 10 | // "add"/null, "subtract", or "prev". When aggressive is false 11 | // (typically set to true for forced single-line indents), empty 12 | // lines are not indented, and places where the mode returns Pass 13 | // are left alone. 14 | export function indentLine(cm, n, how, aggressive) { 15 | let doc = cm.doc, state 16 | if (how == null) how = "add" 17 | if (how == "smart") { 18 | // Fall back to "prev" when the mode doesn't have an indentation 19 | // method. 20 | if (!doc.mode.indent) how = "prev" 21 | else state = getStateBefore(cm, n) 22 | } 23 | 24 | let tabSize = cm.options.tabSize 25 | let line = getLine(doc, n), curSpace = countColumn(line.text, null, tabSize) 26 | if (line.stateAfter) line.stateAfter = null 27 | let curSpaceString = line.text.match(/^\s*/)[0], indentation 28 | if (!aggressive && !/\S/.test(line.text)) { 29 | indentation = 0 30 | how = "not" 31 | } else if (how == "smart") { 32 | indentation = doc.mode.indent(state, line.text.slice(curSpaceString.length), line.text) 33 | if (indentation == Pass || indentation > 150) { 34 | if (!aggressive) return 35 | how = "prev" 36 | } 37 | } 38 | if (how == "prev") { 39 | if (n > doc.first) indentation = countColumn(getLine(doc, n-1).text, null, tabSize) 40 | else indentation = 0 41 | } else if (how == "add") { 42 | indentation = curSpace + cm.options.indentUnit 43 | } else if (how == "subtract") { 44 | indentation = curSpace - cm.options.indentUnit 45 | } else if (typeof how == "number") { 46 | indentation = curSpace + how 47 | } 48 | indentation = Math.max(0, indentation) 49 | 50 | let indentString = "", pos = 0 51 | if (cm.options.indentWithTabs) 52 | for (let i = Math.floor(indentation / tabSize); i; --i) {pos += tabSize; indentString += "\t"} 53 | if (pos < indentation) indentString += spaceStr(indentation - pos) 54 | 55 | if (indentString != curSpaceString) { 56 | replaceRange(doc, indentString, Pos(n, 0), Pos(n, curSpaceString.length), "+input") 57 | line.stateAfter = null 58 | return true 59 | } else { 60 | // Ensure that, if the cursor was in the whitespace at the start 61 | // of the line, it is moved to the end of that space. 62 | for (let i = 0; i < doc.sel.ranges.length; i++) { 63 | let range = doc.sel.ranges[i] 64 | if (range.head.line == n && range.head.ch < curSpaceString.length) { 65 | let pos = Pos(n, curSpaceString.length) 66 | replaceOneSelection(doc, i, new Range(pos, pos)) 67 | break 68 | } 69 | } 70 | } 71 | } 72 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/model/selection.js: -------------------------------------------------------------------------------- 1 | import { cmp, copyPos, equalCursorPos, maxPos, minPos } from "../line/pos" 2 | import { indexOf } from "../util/misc" 3 | 4 | // Selection objects are immutable. A new one is created every time 5 | // the selection changes. A selection is one or more non-overlapping 6 | // (and non-touching) ranges, sorted, and an integer that indicates 7 | // which one is the primary selection (the one that's scrolled into 8 | // view, that getCursor returns, etc). 9 | export class Selection { 10 | constructor(ranges, primIndex) { 11 | this.ranges = ranges 12 | this.primIndex = primIndex 13 | } 14 | 15 | primary() { return this.ranges[this.primIndex] } 16 | 17 | equals(other) { 18 | if (other == this) return true 19 | if (other.primIndex != this.primIndex || other.ranges.length != this.ranges.length) return false 20 | for (let i = 0; i < this.ranges.length; i++) { 21 | let here = this.ranges[i], there = other.ranges[i] 22 | if (!equalCursorPos(here.anchor, there.anchor) || !equalCursorPos(here.head, there.head)) return false 23 | } 24 | return true 25 | } 26 | 27 | deepCopy() { 28 | let out = [] 29 | for (let i = 0; i < this.ranges.length; i++) 30 | out[i] = new Range(copyPos(this.ranges[i].anchor), copyPos(this.ranges[i].head)) 31 | return new Selection(out, this.primIndex) 32 | } 33 | 34 | somethingSelected() { 35 | for (let i = 0; i < this.ranges.length; i++) 36 | if (!this.ranges[i].empty()) return true 37 | return false 38 | } 39 | 40 | contains(pos, end) { 41 | if (!end) end = pos 42 | for (let i = 0; i < this.ranges.length; i++) { 43 | let range = this.ranges[i] 44 | if (cmp(end, range.from()) >= 0 && cmp(pos, range.to()) <= 0) 45 | return i 46 | } 47 | return -1 48 | } 49 | } 50 | 51 | export class Range { 52 | constructor(anchor, head) { 53 | this.anchor = anchor; this.head = head 54 | } 55 | 56 | from() { return minPos(this.anchor, this.head) } 57 | to() { return maxPos(this.anchor, this.head) } 58 | empty() { return this.head.line == this.anchor.line && this.head.ch == this.anchor.ch } 59 | } 60 | 61 | // Take an unsorted, potentially overlapping set of ranges, and 62 | // build a selection out of it. 'Consumes' ranges array (modifying 63 | // it). 64 | export function normalizeSelection(ranges, primIndex) { 65 | let prim = ranges[primIndex] 66 | ranges.sort((a, b) => cmp(a.from(), b.from())) 67 | primIndex = indexOf(ranges, prim) 68 | for (let i = 1; i < ranges.length; i++) { 69 | let cur = ranges[i], prev = ranges[i - 1] 70 | if (cmp(prev.to(), cur.from()) >= 0) { 71 | let from = minPos(prev.from(), cur.from()), to = maxPos(prev.to(), cur.to()) 72 | let inv = prev.empty() ? cur.from() == cur.head : prev.from() == prev.head 73 | if (i <= primIndex) --primIndex 74 | ranges.splice(--i, 2, new Range(inv ? to : from, inv ? from : to)) 75 | } 76 | } 77 | return new Selection(ranges, primIndex) 78 | } 79 | 80 | export function simpleSelection(anchor, head) { 81 | return new Selection([new Range(anchor, head || anchor)], 0) 82 | } 83 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/model/line_widget.js: -------------------------------------------------------------------------------- 1 | import { runInOp } from "../display/operations" 2 | import { addToScrollPos } from "../display/scrolling" 3 | import { regLineChange } from "../display/view_tracking" 4 | import { heightAtLine, lineIsHidden } from "../line/spans" 5 | import { lineNo, updateLineHeight } from "../line/utils_line" 6 | import { widgetHeight } from "../measurement/widgets" 7 | import { changeLine } from "./changes" 8 | import { eventMixin } from "../util/event" 9 | import { signalLater } from "../util/operation_group" 10 | 11 | // Line widgets are block elements displayed above or below a line. 12 | 13 | export class LineWidget { 14 | constructor(doc, node, options) { 15 | if (options) for (let opt in options) if (options.hasOwnProperty(opt)) 16 | this[opt] = options[opt] 17 | this.doc = doc 18 | this.node = node 19 | } 20 | 21 | clear() { 22 | let cm = this.doc.cm, ws = this.line.widgets, line = this.line, no = lineNo(line) 23 | if (no == null || !ws) return 24 | for (let i = 0; i < ws.length; ++i) if (ws[i] == this) ws.splice(i--, 1) 25 | if (!ws.length) line.widgets = null 26 | let height = widgetHeight(this) 27 | updateLineHeight(line, Math.max(0, line.height - height)) 28 | if (cm) { 29 | runInOp(cm, () => { 30 | adjustScrollWhenAboveVisible(cm, line, -height) 31 | regLineChange(cm, no, "widget") 32 | }) 33 | signalLater(cm, "lineWidgetCleared", cm, this, no) 34 | } 35 | } 36 | 37 | changed() { 38 | let oldH = this.height, cm = this.doc.cm, line = this.line 39 | this.height = null 40 | let diff = widgetHeight(this) - oldH 41 | if (!diff) return 42 | updateLineHeight(line, line.height + diff) 43 | if (cm) { 44 | runInOp(cm, () => { 45 | cm.curOp.forceUpdate = true 46 | adjustScrollWhenAboveVisible(cm, line, diff) 47 | signalLater(cm, "lineWidgetChanged", cm, this, lineNo(line)) 48 | }) 49 | } 50 | } 51 | } 52 | eventMixin(LineWidget) 53 | 54 | function adjustScrollWhenAboveVisible(cm, line, diff) { 55 | if (heightAtLine(line) < ((cm.curOp && cm.curOp.scrollTop) || cm.doc.scrollTop)) 56 | addToScrollPos(cm, null, diff) 57 | } 58 | 59 | export function addLineWidget(doc, handle, node, options) { 60 | let widget = new LineWidget(doc, node, options) 61 | let cm = doc.cm 62 | if (cm && widget.noHScroll) cm.display.alignWidgets = true 63 | changeLine(doc, handle, "widget", line => { 64 | let widgets = line.widgets || (line.widgets = []) 65 | if (widget.insertAt == null) widgets.push(widget) 66 | else widgets.splice(Math.min(widgets.length - 1, Math.max(0, widget.insertAt)), 0, widget) 67 | widget.line = line 68 | if (cm && !lineIsHidden(doc, line)) { 69 | let aboveVisible = heightAtLine(line) < doc.scrollTop 70 | updateLineHeight(line, line.height + widgetHeight(widget)) 71 | if (aboveVisible) addToScrollPos(cm, null, widget.height) 72 | cm.curOp.forceUpdate = true 73 | } 74 | return true 75 | }) 76 | signalLater(cm, "lineWidgetAdded", cm, widget, typeof handle == "number" ? handle : lineNo(handle)) 77 | return widget 78 | } 79 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/lint/lint.css: -------------------------------------------------------------------------------- 1 | /* The lint marker gutter */ 2 | .CodeMirror-lint-markers { 3 | width: 16px; 4 | } 5 | 6 | .CodeMirror-lint-tooltip { 7 | background-color: #ffd; 8 | border: 1px solid black; 9 | border-radius: 4px 4px 4px 4px; 10 | color: black; 11 | font-family: monospace; 12 | font-size: 10pt; 13 | overflow: hidden; 14 | padding: 2px 5px; 15 | position: fixed; 16 | white-space: pre; 17 | white-space: pre-wrap; 18 | z-index: 100; 19 | max-width: 600px; 20 | opacity: 0; 21 | transition: opacity .4s; 22 | -moz-transition: opacity .4s; 23 | -webkit-transition: opacity .4s; 24 | -o-transition: opacity .4s; 25 | -ms-transition: opacity .4s; 26 | } 27 | 28 | .CodeMirror-lint-mark-error, .CodeMirror-lint-mark-warning { 29 | background-position: left bottom; 30 | background-repeat: repeat-x; 31 | } 32 | 33 | .CodeMirror-lint-mark-error { 34 | background-image: 35 | url("") 36 | ; 37 | } 38 | 39 | .CodeMirror-lint-mark-warning { 40 | background-image: url(""); 41 | } 42 | 43 | .CodeMirror-lint-marker-error, .CodeMirror-lint-marker-warning { 44 | background-position: center center; 45 | background-repeat: no-repeat; 46 | cursor: pointer; 47 | display: inline-block; 48 | height: 16px; 49 | width: 16px; 50 | vertical-align: middle; 51 | position: relative; 52 | } 53 | 54 | .CodeMirror-lint-message-error, .CodeMirror-lint-message-warning { 55 | padding-left: 18px; 56 | background-position: top left; 57 | background-repeat: no-repeat; 58 | } 59 | 60 | .CodeMirror-lint-marker-error, .CodeMirror-lint-message-error { 61 | background-image: url(""); 62 | } 63 | 64 | .CodeMirror-lint-marker-warning, .CodeMirror-lint-message-warning { 65 | background-image: url(""); 66 | } 67 | 68 | .CodeMirror-lint-marker-multiple { 69 | background-image: url(""); 70 | background-repeat: no-repeat; 71 | background-position: right bottom; 72 | width: 100%; height: 100%; 73 | } 74 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/util/feature_detection.js: -------------------------------------------------------------------------------- 1 | import { elt, range, removeChildren, removeChildrenAndAdd } from "./dom" 2 | import { ie, ie_version } from "./browser" 3 | 4 | // Detect drag-and-drop 5 | export let dragAndDrop = function() { 6 | // There is *some* kind of drag-and-drop support in IE6-8, but I 7 | // couldn't get it to work yet. 8 | if (ie && ie_version < 9) return false 9 | let div = elt('div') 10 | return "draggable" in div || "dragDrop" in div 11 | }() 12 | 13 | let zwspSupported 14 | export function zeroWidthElement(measure) { 15 | if (zwspSupported == null) { 16 | let test = elt("span", "\u200b") 17 | removeChildrenAndAdd(measure, elt("span", [test, document.createTextNode("x")])) 18 | if (measure.firstChild.offsetHeight != 0) 19 | zwspSupported = test.offsetWidth <= 1 && test.offsetHeight > 2 && !(ie && ie_version < 8) 20 | } 21 | let node = zwspSupported ? elt("span", "\u200b") : 22 | elt("span", "\u00a0", null, "display: inline-block; width: 1px; margin-right: -1px") 23 | node.setAttribute("cm-text", "") 24 | return node 25 | } 26 | 27 | // Feature-detect IE's crummy client rect reporting for bidi text 28 | let badBidiRects 29 | export function hasBadBidiRects(measure) { 30 | if (badBidiRects != null) return badBidiRects 31 | let txt = removeChildrenAndAdd(measure, document.createTextNode("A\u062eA")) 32 | let r0 = range(txt, 0, 1).getBoundingClientRect() 33 | let r1 = range(txt, 1, 2).getBoundingClientRect() 34 | removeChildren(measure) 35 | if (!r0 || r0.left == r0.right) return false // Safari returns null in some cases (#2780) 36 | return badBidiRects = (r1.right - r0.right < 3) 37 | } 38 | 39 | // See if "".split is the broken IE version, if so, provide an 40 | // alternative way to split lines. 41 | export let splitLinesAuto = "\n\nb".split(/\n/).length != 3 ? string => { 42 | let pos = 0, result = [], l = string.length 43 | while (pos <= l) { 44 | let nl = string.indexOf("\n", pos) 45 | if (nl == -1) nl = string.length 46 | let line = string.slice(pos, string.charAt(nl - 1) == "\r" ? nl - 1 : nl) 47 | let rt = line.indexOf("\r") 48 | if (rt != -1) { 49 | result.push(line.slice(0, rt)) 50 | pos += rt + 1 51 | } else { 52 | result.push(line) 53 | pos = nl + 1 54 | } 55 | } 56 | return result 57 | } : string => string.split(/\r\n?|\n/) 58 | 59 | export let hasSelection = window.getSelection ? te => { 60 | try { return te.selectionStart != te.selectionEnd } 61 | catch(e) { return false } 62 | } : te => { 63 | let range 64 | try {range = te.ownerDocument.selection.createRange()} 65 | catch(e) {} 66 | if (!range || range.parentElement() != te) return false 67 | return range.compareEndPoints("StartToEnd", range) != 0 68 | } 69 | 70 | export let hasCopyEvent = (() => { 71 | let e = elt("div") 72 | if ("oncopy" in e) return true 73 | e.setAttribute("oncopy", "return;") 74 | return typeof e.oncopy == "function" 75 | })() 76 | 77 | let badZoomedRects = null 78 | export function hasBadZoomedRects(measure) { 79 | if (badZoomedRects != null) return badZoomedRects 80 | let node = removeChildrenAndAdd(measure, elt("span", "x")) 81 | let normal = node.getBoundingClientRect() 82 | let fromRange = range(node, 0, 1).getBoundingClientRect() 83 | return badZoomedRects = Math.abs(normal.left - fromRange.left) > 1 84 | } 85 | -------------------------------------------------------------------------------- /JsBox/routes/index.js: -------------------------------------------------------------------------------- 1 | var express = require('express'); 2 | var fs = require('fs'); 3 | var path = require('path'); 4 | var crypto = require('crypto'); 5 | var verifyCode = require('../service/verifyCode.js'); 6 | var router = express.Router(); 7 | var secret = 'menuPath'; 8 | 9 | var onlinePath = path.join(__dirname, '../file/code/javascript/online') 10 | var tempPath = path.join(__dirname, '../file/code/javascript/temp') 11 | 12 | router.get('/verify', function (req, res, next) { 13 | var data = verifyCode.getCode() 14 | data.answer = encode(data.answer) 15 | res.json({ 16 | success: true, 17 | data: data 18 | }) 19 | }) 20 | 21 | router.get('/codeList', function(req, res, next) { 22 | var list = [] 23 | fs.readdirSync(onlinePath).forEach(function (fileName) { 24 | if(fs.statSync(path.join(onlinePath, fileName)).isFile()){ 25 | list.push({ 26 | title: fileName, 27 | id: encode(path.join(onlinePath,fileName)) 28 | }) 29 | } 30 | }) 31 | res.json({ 32 | success: true, 33 | list: list 34 | }) 35 | }); 36 | 37 | router.get('/codeDetail', function(req, res, next) { 38 | var filePath = decode(req.query.id) 39 | fs.readFile(filePath,'utf-8',function(err, data){ 40 | if(err){ 41 | res.json({ 42 | success: false 43 | }) 44 | }else{ 45 | var dirs = filePath.split(path.sep) 46 | res.json({ 47 | success: true, 48 | title: dirs[dirs.length - 1], 49 | content: data 50 | }) 51 | } 52 | }) 53 | }); 54 | 55 | router.post('/add', function (req, res, next) { 56 | var token = req.body.token 57 | var title = req.body.title 58 | var content = req.body.content 59 | var answer = req.body.answer 60 | var option = req.body.option 61 | if (answer !== encode(option)) { 62 | res.json({ success: false, msg: '验证码错误' }) 63 | return 64 | } 65 | var dirPath = null 66 | if (token && token === '123456') { // token正确 67 | if (createDir(onlinePath)) { 68 | dirPath = onlinePath 69 | } else { 70 | res.json({ success: false, msg: '添加失败' }) 71 | } 72 | } else { 73 | if (createDir(tempPath)) { 74 | dirPath = tempPath 75 | } else { 76 | res.json({ success: false, msg: '添加失败' }) 77 | } 78 | } 79 | var newFilePath = path.join(dirPath, title) 80 | fs.writeFile(newFilePath, content, function(err) { 81 | if(err) { 82 | res.json({ success: false, msg: '添加失败' }) 83 | } 84 | }) 85 | res.json({ success: true }) 86 | }) 87 | 88 | function createDir (path) { 89 | if (!fs.existsSync(path)) { 90 | if (fs.mkdirSync(path)) { 91 | return false 92 | } 93 | } 94 | return true 95 | } 96 | 97 | /** 98 | * 路径编码 99 | * @param path 100 | * @returns {*} 101 | */ 102 | function encode (path) { 103 | var cipher = crypto.createCipher('aes192', secret); 104 | var enc = cipher.update(path, 'utf8', 'hex');//编码方式从utf-8转为hex; 105 | enc += cipher.final('hex');//编码方式从转为hex; 106 | return enc 107 | } 108 | 109 | /** 110 | * 路径解码 111 | * @param path 112 | * @returns {*} 113 | */ 114 | function decode (path) { 115 | var decipher = crypto.createDecipher('aes192', secret); 116 | var dec = decipher.update(path, 'hex', 'utf8');//编码方式从hex转为utf-8; 117 | dec += decipher.final('utf8');//编码方式从utf-8; 118 | return dec 119 | } 120 | 121 | module.exports = router; 122 | -------------------------------------------------------------------------------- /JsBox/npm-debug.log: -------------------------------------------------------------------------------- 1 | 0 info it worked if it ends with ok 2 | 1 verbose cli [ 'D:\\Program Files\\nodejs\\node.exe', 3 | 1 verbose cli 'D:\\Program Files\\nodejs\\node_modules\\npm\\bin\\npm-cli.js', 4 | 1 verbose cli 'start' ] 5 | 2 info using npm@3.10.8 6 | 3 info using node@v6.8.1 7 | 4 verbose run-script [ 'prestart', 'start', 'poststart' ] 8 | 5 info lifecycle code-editor@0.0.0~prestart: code-editor@0.0.0 9 | 6 silly lifecycle code-editor@0.0.0~prestart: no script for prestart, continuing 10 | 7 info lifecycle code-editor@0.0.0~start: code-editor@0.0.0 11 | 8 verbose lifecycle code-editor@0.0.0~start: unsafe-perm in lifecycle true 12 | 9 verbose lifecycle code-editor@0.0.0~start: PATH: D:\Program Files\nodejs\node_modules\npm\bin\node-gyp-bin;E:\web_workspace\vue-os\code-editor\node_modules\.bin;C:\Python\Scripts;C:\Python;E:\sdk\sdk;D:\Program Files\gradle-2.4\bin;D:\Program Files\nodejs\node_global\;C:\Program Files\Java\jdk1.8.0_05\bin;C:\Windows\system32;C:\Windows;C:\Windows\System32\Wbem;C:\Windows\System32\WindowsPowerShell\v1.0\;D:\Program Files\nodejs\;D:\Program Files\Git\cmd;D:\phpStudy\php\php-5.4.45;C:\ProgramData\ComposerSetup\bin;C:\Python\Lib\site-packages;C:\Python\Lib\site-packages\pytesser;C:\Users\Administrator\AppData\Roaming\npm;C:\Users\Administrator\AppData\Roaming\Composer\vendor\bin 13 | 10 verbose lifecycle code-editor@0.0.0~start: CWD: E:\web_workspace\vue-os\code-editor 14 | 11 silly lifecycle code-editor@0.0.0~start: Args: [ '/d /s /c', 'node ./bin/www' ] 15 | 12 silly lifecycle code-editor@0.0.0~start: Returned: code: 3221225786 signal: null 16 | 13 info lifecycle code-editor@0.0.0~start: Failed to exec start script 17 | 14 verbose stack Error: code-editor@0.0.0 start: `node ./bin/www` 18 | 14 verbose stack Exit status 3221225786 19 | 14 verbose stack at EventEmitter. (D:\Program Files\nodejs\node_modules\npm\lib\utils\lifecycle.js:255:16) 20 | 14 verbose stack at emitTwo (events.js:106:13) 21 | 14 verbose stack at EventEmitter.emit (events.js:191:7) 22 | 14 verbose stack at ChildProcess. (D:\Program Files\nodejs\node_modules\npm\lib\utils\spawn.js:40:14) 23 | 14 verbose stack at emitTwo (events.js:106:13) 24 | 14 verbose stack at ChildProcess.emit (events.js:191:7) 25 | 14 verbose stack at maybeClose (internal/child_process.js:877:16) 26 | 14 verbose stack at Process.ChildProcess._handle.onexit (internal/child_process.js:226:5) 27 | 15 verbose pkgid code-editor@0.0.0 28 | 16 verbose cwd E:\web_workspace\vue-os\code-editor 29 | 17 error Windows_NT 6.1.7601 30 | 18 error argv "D:\\Program Files\\nodejs\\node.exe" "D:\\Program Files\\nodejs\\node_modules\\npm\\bin\\npm-cli.js" "start" 31 | 19 error node v6.8.1 32 | 20 error npm v3.10.8 33 | 21 error code ELIFECYCLE 34 | 22 error code-editor@0.0.0 start: `node ./bin/www` 35 | 22 error Exit status 3221225786 36 | 23 error Failed at the code-editor@0.0.0 start script 'node ./bin/www'. 37 | 23 error Make sure you have the latest version of node.js and npm installed. 38 | 23 error If you do, this is most likely a problem with the code-editor package, 39 | 23 error not with npm itself. 40 | 23 error Tell the author that this fails on your system: 41 | 23 error node ./bin/www 42 | 23 error You can get information on how to open an issue for this project with: 43 | 23 error npm bugs code-editor 44 | 23 error Or if that isn't available, you can get their info via: 45 | 23 error npm owner ls code-editor 46 | 23 error There is likely additional logging output above. 47 | 24 verbose exit [ 1, true ] 48 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/mode/overlay.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | // Utility function that allows modes to be combined. The mode given 5 | // as the base argument takes care of most of the normal mode 6 | // functionality, but a second (typically simple) mode is used, which 7 | // can override the style of text. Both modes get to parse all of the 8 | // text, but when both assign a non-null style to a piece of code, the 9 | // overlay wins, unless the combine argument was true and not overridden, 10 | // or state.overlay.combineTokens was true, in which case the styles are 11 | // combined. 12 | 13 | (function(mod) { 14 | if (typeof exports == "object" && typeof module == "object") // CommonJS 15 | mod(require("../../lib/codemirror")); 16 | else if (typeof define == "function" && define.amd) // AMD 17 | define(["../../lib/codemirror"], mod); 18 | else // Plain browser env 19 | mod(CodeMirror); 20 | })(function(CodeMirror) { 21 | "use strict"; 22 | 23 | CodeMirror.overlayMode = function(base, overlay, combine) { 24 | return { 25 | startState: function() { 26 | return { 27 | base: CodeMirror.startState(base), 28 | overlay: CodeMirror.startState(overlay), 29 | basePos: 0, baseCur: null, 30 | overlayPos: 0, overlayCur: null, 31 | streamSeen: null 32 | }; 33 | }, 34 | copyState: function(state) { 35 | return { 36 | base: CodeMirror.copyState(base, state.base), 37 | overlay: CodeMirror.copyState(overlay, state.overlay), 38 | basePos: state.basePos, baseCur: null, 39 | overlayPos: state.overlayPos, overlayCur: null 40 | }; 41 | }, 42 | 43 | token: function(stream, state) { 44 | if (stream != state.streamSeen || 45 | Math.min(state.basePos, state.overlayPos) < stream.start) { 46 | state.streamSeen = stream; 47 | state.basePos = state.overlayPos = stream.start; 48 | } 49 | 50 | if (stream.start == state.basePos) { 51 | state.baseCur = base.token(stream, state.base); 52 | state.basePos = stream.pos; 53 | } 54 | if (stream.start == state.overlayPos) { 55 | stream.pos = stream.start; 56 | state.overlayCur = overlay.token(stream, state.overlay); 57 | state.overlayPos = stream.pos; 58 | } 59 | stream.pos = Math.min(state.basePos, state.overlayPos); 60 | 61 | // state.overlay.combineTokens always takes precedence over combine, 62 | // unless set to null 63 | if (state.overlayCur == null) return state.baseCur; 64 | else if (state.baseCur != null && 65 | state.overlay.combineTokens || 66 | combine && state.overlay.combineTokens == null) 67 | return state.baseCur + " " + state.overlayCur; 68 | else return state.overlayCur; 69 | }, 70 | 71 | indent: base.indent && function(state, textAfter) { 72 | return base.indent(state.base, textAfter); 73 | }, 74 | electricChars: base.electricChars, 75 | 76 | innerMode: function(state) { return {state: state.base, mode: base}; }, 77 | 78 | blankLine: function(state) { 79 | var baseToken, overlayToken; 80 | if (base.blankLine) baseToken = base.blankLine(state.base); 81 | if (overlay.blankLine) overlayToken = overlay.blankLine(state.overlay); 82 | 83 | return overlayToken == null ? 84 | baseToken : 85 | (combine && baseToken != null ? baseToken + " " + overlayToken : overlayToken); 86 | } 87 | }; 88 | }; 89 | 90 | }); 91 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/modes.js: -------------------------------------------------------------------------------- 1 | import { copyObj, createObj } from "./util/misc" 2 | 3 | // Known modes, by name and by MIME 4 | export let modes = {}, mimeModes = {} 5 | 6 | // Extra arguments are stored as the mode's dependencies, which is 7 | // used by (legacy) mechanisms like loadmode.js to automatically 8 | // load a mode. (Preferred mechanism is the require/define calls.) 9 | export function defineMode(name, mode) { 10 | if (arguments.length > 2) 11 | mode.dependencies = Array.prototype.slice.call(arguments, 2) 12 | modes[name] = mode 13 | } 14 | 15 | export function defineMIME(mime, spec) { 16 | mimeModes[mime] = spec 17 | } 18 | 19 | // Given a MIME type, a {name, ...options} config object, or a name 20 | // string, return a mode config object. 21 | export function resolveMode(spec) { 22 | if (typeof spec == "string" && mimeModes.hasOwnProperty(spec)) { 23 | spec = mimeModes[spec] 24 | } else if (spec && typeof spec.name == "string" && mimeModes.hasOwnProperty(spec.name)) { 25 | let found = mimeModes[spec.name] 26 | if (typeof found == "string") found = {name: found} 27 | spec = createObj(found, spec) 28 | spec.name = found.name 29 | } else if (typeof spec == "string" && /^[\w\-]+\/[\w\-]+\+xml$/.test(spec)) { 30 | return resolveMode("application/xml") 31 | } else if (typeof spec == "string" && /^[\w\-]+\/[\w\-]+\+json$/.test(spec)) { 32 | return resolveMode("application/json") 33 | } 34 | if (typeof spec == "string") return {name: spec} 35 | else return spec || {name: "null"} 36 | } 37 | 38 | // Given a mode spec (anything that resolveMode accepts), find and 39 | // initialize an actual mode object. 40 | export function getMode(options, spec) { 41 | spec = resolveMode(spec) 42 | let mfactory = modes[spec.name] 43 | if (!mfactory) return getMode(options, "text/plain") 44 | let modeObj = mfactory(options, spec) 45 | if (modeExtensions.hasOwnProperty(spec.name)) { 46 | let exts = modeExtensions[spec.name] 47 | for (let prop in exts) { 48 | if (!exts.hasOwnProperty(prop)) continue 49 | if (modeObj.hasOwnProperty(prop)) modeObj["_" + prop] = modeObj[prop] 50 | modeObj[prop] = exts[prop] 51 | } 52 | } 53 | modeObj.name = spec.name 54 | if (spec.helperType) modeObj.helperType = spec.helperType 55 | if (spec.modeProps) for (let prop in spec.modeProps) 56 | modeObj[prop] = spec.modeProps[prop] 57 | 58 | return modeObj 59 | } 60 | 61 | // This can be used to attach properties to mode objects from 62 | // outside the actual mode definition. 63 | export let modeExtensions = {} 64 | export function extendMode(mode, properties) { 65 | let exts = modeExtensions.hasOwnProperty(mode) ? modeExtensions[mode] : (modeExtensions[mode] = {}) 66 | copyObj(properties, exts) 67 | } 68 | 69 | export function copyState(mode, state) { 70 | if (state === true) return state 71 | if (mode.copyState) return mode.copyState(state) 72 | let nstate = {} 73 | for (let n in state) { 74 | let val = state[n] 75 | if (val instanceof Array) val = val.concat([]) 76 | nstate[n] = val 77 | } 78 | return nstate 79 | } 80 | 81 | // Given a mode and a state (for that mode), find the inner mode and 82 | // state at the position that the state refers to. 83 | export function innerMode(mode, state) { 84 | let info 85 | while (mode.innerMode) { 86 | info = mode.innerMode(state) 87 | if (!info || info.mode == mode) break 88 | state = info.state 89 | mode = info.mode 90 | } 91 | return info || {mode: mode, state: state} 92 | } 93 | 94 | export function startState(mode, a1, a2) { 95 | return mode.startState ? mode.startState(a1, a2) : true 96 | } 97 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/util/dom.js: -------------------------------------------------------------------------------- 1 | import { ie, ios } from "./browser" 2 | 3 | export function classTest(cls) { return new RegExp("(^|\\s)" + cls + "(?:$|\\s)\\s*") } 4 | 5 | export let rmClass = function(node, cls) { 6 | let current = node.className 7 | let match = classTest(cls).exec(current) 8 | if (match) { 9 | let after = current.slice(match.index + match[0].length) 10 | node.className = current.slice(0, match.index) + (after ? match[1] + after : "") 11 | } 12 | } 13 | 14 | export function removeChildren(e) { 15 | for (let count = e.childNodes.length; count > 0; --count) 16 | e.removeChild(e.firstChild) 17 | return e 18 | } 19 | 20 | export function removeChildrenAndAdd(parent, e) { 21 | return removeChildren(parent).appendChild(e) 22 | } 23 | 24 | export function elt(tag, content, className, style) { 25 | let e = document.createElement(tag) 26 | if (className) e.className = className 27 | if (style) e.style.cssText = style 28 | if (typeof content == "string") e.appendChild(document.createTextNode(content)) 29 | else if (content) for (let i = 0; i < content.length; ++i) e.appendChild(content[i]) 30 | return e 31 | } 32 | // wrapper for elt, which removes the elt from the accessibility tree 33 | export function eltP(tag, content, className, style) { 34 | let e = elt(tag, content, className, style) 35 | e.setAttribute("role", "presentation") 36 | return e 37 | } 38 | 39 | export let range 40 | if (document.createRange) range = function(node, start, end, endNode) { 41 | let r = document.createRange() 42 | r.setEnd(endNode || node, end) 43 | r.setStart(node, start) 44 | return r 45 | } 46 | else range = function(node, start, end) { 47 | let r = document.body.createTextRange() 48 | try { r.moveToElementText(node.parentNode) } 49 | catch(e) { return r } 50 | r.collapse(true) 51 | r.moveEnd("character", end) 52 | r.moveStart("character", start) 53 | return r 54 | } 55 | 56 | export function contains(parent, child) { 57 | if (child.nodeType == 3) // Android browser always returns false when child is a textnode 58 | child = child.parentNode 59 | if (parent.contains) 60 | return parent.contains(child) 61 | do { 62 | if (child.nodeType == 11) child = child.host 63 | if (child == parent) return true 64 | } while (child = child.parentNode) 65 | } 66 | 67 | export function activeElt() { 68 | // IE and Edge may throw an "Unspecified Error" when accessing document.activeElement. 69 | // IE < 10 will throw when accessed while the page is loading or in an iframe. 70 | // IE > 9 and Edge will throw when accessed in an iframe if document.body is unavailable. 71 | let activeElement 72 | try { 73 | activeElement = document.activeElement 74 | } catch(e) { 75 | activeElement = document.body || null 76 | } 77 | while (activeElement && activeElement.shadowRoot && activeElement.shadowRoot.activeElement) 78 | activeElement = activeElement.shadowRoot.activeElement 79 | return activeElement 80 | } 81 | 82 | export function addClass(node, cls) { 83 | let current = node.className 84 | if (!classTest(cls).test(current)) node.className += (current ? " " : "") + cls 85 | } 86 | export function joinClasses(a, b) { 87 | let as = a.split(" ") 88 | for (let i = 0; i < as.length; i++) 89 | if (as[i] && !classTest(as[i]).test(b)) b += " " + as[i] 90 | return b 91 | } 92 | 93 | export let selectInput = function(node) { node.select() } 94 | if (ios) // Mobile Safari apparently has a bug where select() is broken. 95 | selectInput = function(node) { node.selectionStart = 0; node.selectionEnd = node.value.length } 96 | else if (ie) // Suppress mysterious IE10 errors 97 | selectInput = function(node) { try { node.select() } catch(_e) {} } 98 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/selection/selection-pointer.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror")); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror"], mod); 9 | else // Plain browser env 10 | mod(CodeMirror); 11 | })(function(CodeMirror) { 12 | "use strict"; 13 | 14 | CodeMirror.defineOption("selectionPointer", false, function(cm, val) { 15 | var data = cm.state.selectionPointer; 16 | if (data) { 17 | CodeMirror.off(cm.getWrapperElement(), "mousemove", data.mousemove); 18 | CodeMirror.off(cm.getWrapperElement(), "mouseout", data.mouseout); 19 | CodeMirror.off(window, "scroll", data.windowScroll); 20 | cm.off("cursorActivity", reset); 21 | cm.off("scroll", reset); 22 | cm.state.selectionPointer = null; 23 | cm.display.lineDiv.style.cursor = ""; 24 | } 25 | if (val) { 26 | data = cm.state.selectionPointer = { 27 | value: typeof val == "string" ? val : "default", 28 | mousemove: function(event) { mousemove(cm, event); }, 29 | mouseout: function(event) { mouseout(cm, event); }, 30 | windowScroll: function() { reset(cm); }, 31 | rects: null, 32 | mouseX: null, mouseY: null, 33 | willUpdate: false 34 | }; 35 | CodeMirror.on(cm.getWrapperElement(), "mousemove", data.mousemove); 36 | CodeMirror.on(cm.getWrapperElement(), "mouseout", data.mouseout); 37 | CodeMirror.on(window, "scroll", data.windowScroll); 38 | cm.on("cursorActivity", reset); 39 | cm.on("scroll", reset); 40 | } 41 | }); 42 | 43 | function mousemove(cm, event) { 44 | var data = cm.state.selectionPointer; 45 | if (event.buttons == null ? event.which : event.buttons) { 46 | data.mouseX = data.mouseY = null; 47 | } else { 48 | data.mouseX = event.clientX; 49 | data.mouseY = event.clientY; 50 | } 51 | scheduleUpdate(cm); 52 | } 53 | 54 | function mouseout(cm, event) { 55 | if (!cm.getWrapperElement().contains(event.relatedTarget)) { 56 | var data = cm.state.selectionPointer; 57 | data.mouseX = data.mouseY = null; 58 | scheduleUpdate(cm); 59 | } 60 | } 61 | 62 | function reset(cm) { 63 | cm.state.selectionPointer.rects = null; 64 | scheduleUpdate(cm); 65 | } 66 | 67 | function scheduleUpdate(cm) { 68 | if (!cm.state.selectionPointer.willUpdate) { 69 | cm.state.selectionPointer.willUpdate = true; 70 | setTimeout(function() { 71 | update(cm); 72 | cm.state.selectionPointer.willUpdate = false; 73 | }, 50); 74 | } 75 | } 76 | 77 | function update(cm) { 78 | var data = cm.state.selectionPointer; 79 | if (!data) return; 80 | if (data.rects == null && data.mouseX != null) { 81 | data.rects = []; 82 | if (cm.somethingSelected()) { 83 | for (var sel = cm.display.selectionDiv.firstChild; sel; sel = sel.nextSibling) 84 | data.rects.push(sel.getBoundingClientRect()); 85 | } 86 | } 87 | var inside = false; 88 | if (data.mouseX != null) for (var i = 0; i < data.rects.length; i++) { 89 | var rect = data.rects[i]; 90 | if (rect.left <= data.mouseX && rect.right >= data.mouseX && 91 | rect.top <= data.mouseY && rect.bottom >= data.mouseY) 92 | inside = true; 93 | } 94 | var cursor = inside ? data.value : ""; 95 | if (cm.display.lineDiv.style.cursor != cursor) 96 | cm.display.lineDiv.style.cursor = cursor; 97 | } 98 | }); 99 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/comment/continuecomment.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror")); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror"], mod); 9 | else // Plain browser env 10 | mod(CodeMirror); 11 | })(function(CodeMirror) { 12 | var modes = ["clike", "css", "javascript"]; 13 | 14 | for (var i = 0; i < modes.length; ++i) 15 | CodeMirror.extendMode(modes[i], {blockCommentContinue: " * "}); 16 | 17 | function continueComment(cm) { 18 | if (cm.getOption("disableInput")) return CodeMirror.Pass; 19 | var ranges = cm.listSelections(), mode, inserts = []; 20 | for (var i = 0; i < ranges.length; i++) { 21 | var pos = ranges[i].head, token = cm.getTokenAt(pos); 22 | if (token.type != "comment") return CodeMirror.Pass; 23 | var modeHere = CodeMirror.innerMode(cm.getMode(), token.state).mode; 24 | if (!mode) mode = modeHere; 25 | else if (mode != modeHere) return CodeMirror.Pass; 26 | 27 | var insert = null; 28 | if (mode.blockCommentStart && mode.blockCommentContinue) { 29 | var end = token.string.indexOf(mode.blockCommentEnd); 30 | var full = cm.getRange(CodeMirror.Pos(pos.line, 0), CodeMirror.Pos(pos.line, token.end)), found; 31 | if (end != -1 && end == token.string.length - mode.blockCommentEnd.length && pos.ch >= end) { 32 | // Comment ended, don't continue it 33 | } else if (token.string.indexOf(mode.blockCommentStart) == 0) { 34 | insert = full.slice(0, token.start); 35 | if (!/^\s*$/.test(insert)) { 36 | insert = ""; 37 | for (var j = 0; j < token.start; ++j) insert += " "; 38 | } 39 | } else if ((found = full.indexOf(mode.blockCommentContinue)) != -1 && 40 | found + mode.blockCommentContinue.length > token.start && 41 | /^\s*$/.test(full.slice(0, found))) { 42 | insert = full.slice(0, found); 43 | } 44 | if (insert != null) insert += mode.blockCommentContinue; 45 | } 46 | if (insert == null && mode.lineComment && continueLineCommentEnabled(cm)) { 47 | var line = cm.getLine(pos.line), found = line.indexOf(mode.lineComment); 48 | if (found > -1) { 49 | insert = line.slice(0, found); 50 | if (/\S/.test(insert)) insert = null; 51 | else insert += mode.lineComment + line.slice(found + mode.lineComment.length).match(/^\s*/)[0]; 52 | } 53 | } 54 | if (insert == null) return CodeMirror.Pass; 55 | inserts[i] = "\n" + insert; 56 | } 57 | 58 | cm.operation(function() { 59 | for (var i = ranges.length - 1; i >= 0; i--) 60 | cm.replaceRange(inserts[i], ranges[i].from(), ranges[i].to(), "+insert"); 61 | }); 62 | } 63 | 64 | function continueLineCommentEnabled(cm) { 65 | var opt = cm.getOption("continueComments"); 66 | if (opt && typeof opt == "object") 67 | return opt.continueLineComment !== false; 68 | return true; 69 | } 70 | 71 | CodeMirror.defineOption("continueComments", null, function(cm, val, prev) { 72 | if (prev && prev != CodeMirror.Init) 73 | cm.removeKeyMap("continueComment"); 74 | if (val) { 75 | var key = "Enter"; 76 | if (typeof val == "string") 77 | key = val; 78 | else if (typeof val == "object" && val.key) 79 | key = val.key; 80 | var map = {name: "continueComment"}; 81 | map[key] = continueComment; 82 | cm.addKeyMap(map); 83 | } 84 | }); 85 | }); 86 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/util/event.js: -------------------------------------------------------------------------------- 1 | import { mac } from "./browser" 2 | import { indexOf } from "./misc" 3 | 4 | // EVENT HANDLING 5 | 6 | // Lightweight event framework. on/off also work on DOM nodes, 7 | // registering native DOM handlers. 8 | 9 | const noHandlers = [] 10 | 11 | export let on = function(emitter, type, f) { 12 | if (emitter.addEventListener) { 13 | emitter.addEventListener(type, f, false) 14 | } else if (emitter.attachEvent) { 15 | emitter.attachEvent("on" + type, f) 16 | } else { 17 | let map = emitter._handlers || (emitter._handlers = {}) 18 | map[type] = (map[type] || noHandlers).concat(f) 19 | } 20 | } 21 | 22 | export function getHandlers(emitter, type) { 23 | return emitter._handlers && emitter._handlers[type] || noHandlers 24 | } 25 | 26 | export function off(emitter, type, f) { 27 | if (emitter.removeEventListener) { 28 | emitter.removeEventListener(type, f, false) 29 | } else if (emitter.detachEvent) { 30 | emitter.detachEvent("on" + type, f) 31 | } else { 32 | let map = emitter._handlers, arr = map && map[type] 33 | if (arr) { 34 | let index = indexOf(arr, f) 35 | if (index > -1) 36 | map[type] = arr.slice(0, index).concat(arr.slice(index + 1)) 37 | } 38 | } 39 | } 40 | 41 | export function signal(emitter, type /*, values...*/) { 42 | let handlers = getHandlers(emitter, type) 43 | if (!handlers.length) return 44 | let args = Array.prototype.slice.call(arguments, 2) 45 | for (let i = 0; i < handlers.length; ++i) handlers[i].apply(null, args) 46 | } 47 | 48 | // The DOM events that CodeMirror handles can be overridden by 49 | // registering a (non-DOM) handler on the editor for the event name, 50 | // and preventDefault-ing the event in that handler. 51 | export function signalDOMEvent(cm, e, override) { 52 | if (typeof e == "string") 53 | e = {type: e, preventDefault: function() { this.defaultPrevented = true }} 54 | signal(cm, override || e.type, cm, e) 55 | return e_defaultPrevented(e) || e.codemirrorIgnore 56 | } 57 | 58 | export function signalCursorActivity(cm) { 59 | let arr = cm._handlers && cm._handlers.cursorActivity 60 | if (!arr) return 61 | let set = cm.curOp.cursorActivityHandlers || (cm.curOp.cursorActivityHandlers = []) 62 | for (let i = 0; i < arr.length; ++i) if (indexOf(set, arr[i]) == -1) 63 | set.push(arr[i]) 64 | } 65 | 66 | export function hasHandler(emitter, type) { 67 | return getHandlers(emitter, type).length > 0 68 | } 69 | 70 | // Add on and off methods to a constructor's prototype, to make 71 | // registering events on such objects more convenient. 72 | export function eventMixin(ctor) { 73 | ctor.prototype.on = function(type, f) {on(this, type, f)} 74 | ctor.prototype.off = function(type, f) {off(this, type, f)} 75 | } 76 | 77 | // Due to the fact that we still support jurassic IE versions, some 78 | // compatibility wrappers are needed. 79 | 80 | export function e_preventDefault(e) { 81 | if (e.preventDefault) e.preventDefault() 82 | else e.returnValue = false 83 | } 84 | export function e_stopPropagation(e) { 85 | if (e.stopPropagation) e.stopPropagation() 86 | else e.cancelBubble = true 87 | } 88 | export function e_defaultPrevented(e) { 89 | return e.defaultPrevented != null ? e.defaultPrevented : e.returnValue == false 90 | } 91 | export function e_stop(e) {e_preventDefault(e); e_stopPropagation(e)} 92 | 93 | export function e_target(e) {return e.target || e.srcElement} 94 | export function e_button(e) { 95 | let b = e.which 96 | if (b == null) { 97 | if (e.button & 1) b = 1 98 | else if (e.button & 2) b = 3 99 | else if (e.button & 4) b = 2 100 | } 101 | if (mac && e.ctrlKey && b == 1) b = 3 102 | return b 103 | } 104 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/merge/merge.css: -------------------------------------------------------------------------------- 1 | .CodeMirror-merge { 2 | position: relative; 3 | border: 1px solid #ddd; 4 | white-space: pre; 5 | } 6 | 7 | .CodeMirror-merge, .CodeMirror-merge .CodeMirror { 8 | height: 350px; 9 | } 10 | 11 | .CodeMirror-merge-2pane .CodeMirror-merge-pane { width: 47%; } 12 | .CodeMirror-merge-2pane .CodeMirror-merge-gap { width: 6%; } 13 | .CodeMirror-merge-3pane .CodeMirror-merge-pane { width: 31%; } 14 | .CodeMirror-merge-3pane .CodeMirror-merge-gap { width: 3.5%; } 15 | 16 | .CodeMirror-merge-pane { 17 | display: inline-block; 18 | white-space: normal; 19 | vertical-align: top; 20 | } 21 | .CodeMirror-merge-pane-rightmost { 22 | position: absolute; 23 | right: 0px; 24 | z-index: 1; 25 | } 26 | 27 | .CodeMirror-merge-gap { 28 | z-index: 2; 29 | display: inline-block; 30 | height: 100%; 31 | -moz-box-sizing: border-box; 32 | box-sizing: border-box; 33 | overflow: hidden; 34 | border-left: 1px solid #ddd; 35 | border-right: 1px solid #ddd; 36 | position: relative; 37 | background: #f8f8f8; 38 | } 39 | 40 | .CodeMirror-merge-scrolllock-wrap { 41 | position: absolute; 42 | bottom: 0; left: 50%; 43 | } 44 | .CodeMirror-merge-scrolllock { 45 | position: relative; 46 | left: -50%; 47 | cursor: pointer; 48 | color: #555; 49 | line-height: 1; 50 | } 51 | 52 | .CodeMirror-merge-copybuttons-left, .CodeMirror-merge-copybuttons-right { 53 | position: absolute; 54 | left: 0; top: 0; 55 | right: 0; bottom: 0; 56 | line-height: 1; 57 | } 58 | 59 | .CodeMirror-merge-copy { 60 | position: absolute; 61 | cursor: pointer; 62 | color: #44c; 63 | z-index: 3; 64 | } 65 | 66 | .CodeMirror-merge-copy-reverse { 67 | position: absolute; 68 | cursor: pointer; 69 | color: #44c; 70 | } 71 | 72 | .CodeMirror-merge-copybuttons-left .CodeMirror-merge-copy { left: 2px; } 73 | .CodeMirror-merge-copybuttons-right .CodeMirror-merge-copy { right: 2px; } 74 | 75 | .CodeMirror-merge-r-inserted, .CodeMirror-merge-l-inserted { 76 | background-image: url(); 77 | background-position: bottom left; 78 | background-repeat: repeat-x; 79 | } 80 | 81 | .CodeMirror-merge-r-deleted, .CodeMirror-merge-l-deleted { 82 | background-image: url(); 83 | background-position: bottom left; 84 | background-repeat: repeat-x; 85 | } 86 | 87 | .CodeMirror-merge-r-chunk { background: #ffffe0; } 88 | .CodeMirror-merge-r-chunk-start { border-top: 1px solid #ee8; } 89 | .CodeMirror-merge-r-chunk-end { border-bottom: 1px solid #ee8; } 90 | .CodeMirror-merge-r-connect { fill: #ffffe0; stroke: #ee8; stroke-width: 1px; } 91 | 92 | .CodeMirror-merge-l-chunk { background: #eef; } 93 | .CodeMirror-merge-l-chunk-start { border-top: 1px solid #88e; } 94 | .CodeMirror-merge-l-chunk-end { border-bottom: 1px solid #88e; } 95 | .CodeMirror-merge-l-connect { fill: #eef; stroke: #88e; stroke-width: 1px; } 96 | 97 | .CodeMirror-merge-l-chunk.CodeMirror-merge-r-chunk { background: #dfd; } 98 | .CodeMirror-merge-l-chunk-start.CodeMirror-merge-r-chunk-start { border-top: 1px solid #4e4; } 99 | .CodeMirror-merge-l-chunk-end.CodeMirror-merge-r-chunk-end { border-bottom: 1px solid #4e4; } 100 | 101 | .CodeMirror-merge-collapsed-widget:before { 102 | content: "(...)"; 103 | } 104 | .CodeMirror-merge-collapsed-widget { 105 | cursor: pointer; 106 | color: #88b; 107 | background: #eef; 108 | border: 1px solid #ddf; 109 | font-size: 90%; 110 | padding: 0 3px; 111 | border-radius: 4px; 112 | } 113 | .CodeMirror-merge-collapsed-line .CodeMirror-gutter-elt { display: none; } 114 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/search/matchesonscrollbar.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror"), require("./searchcursor"), require("../scroll/annotatescrollbar")); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror", "./searchcursor", "../scroll/annotatescrollbar"], mod); 9 | else // Plain browser env 10 | mod(CodeMirror); 11 | })(function(CodeMirror) { 12 | "use strict"; 13 | 14 | CodeMirror.defineExtension("showMatchesOnScrollbar", function(query, caseFold, options) { 15 | if (typeof options == "string") options = {className: options}; 16 | if (!options) options = {}; 17 | return new SearchAnnotation(this, query, caseFold, options); 18 | }); 19 | 20 | function SearchAnnotation(cm, query, caseFold, options) { 21 | this.cm = cm; 22 | this.options = options; 23 | var annotateOptions = {listenForChanges: false}; 24 | for (var prop in options) annotateOptions[prop] = options[prop]; 25 | if (!annotateOptions.className) annotateOptions.className = "CodeMirror-search-match"; 26 | this.annotation = cm.annotateScrollbar(annotateOptions); 27 | this.query = query; 28 | this.caseFold = caseFold; 29 | this.gap = {from: cm.firstLine(), to: cm.lastLine() + 1}; 30 | this.matches = []; 31 | this.update = null; 32 | 33 | this.findMatches(); 34 | this.annotation.update(this.matches); 35 | 36 | var self = this; 37 | cm.on("change", this.changeHandler = function(_cm, change) { self.onChange(change); }); 38 | } 39 | 40 | var MAX_MATCHES = 1000; 41 | 42 | SearchAnnotation.prototype.findMatches = function() { 43 | if (!this.gap) return; 44 | for (var i = 0; i < this.matches.length; i++) { 45 | var match = this.matches[i]; 46 | if (match.from.line >= this.gap.to) break; 47 | if (match.to.line >= this.gap.from) this.matches.splice(i--, 1); 48 | } 49 | var cursor = this.cm.getSearchCursor(this.query, CodeMirror.Pos(this.gap.from, 0), this.caseFold); 50 | var maxMatches = this.options && this.options.maxMatches || MAX_MATCHES; 51 | while (cursor.findNext()) { 52 | var match = {from: cursor.from(), to: cursor.to()}; 53 | if (match.from.line >= this.gap.to) break; 54 | this.matches.splice(i++, 0, match); 55 | if (this.matches.length > maxMatches) break; 56 | } 57 | this.gap = null; 58 | }; 59 | 60 | function offsetLine(line, changeStart, sizeChange) { 61 | if (line <= changeStart) return line; 62 | return Math.max(changeStart, line + sizeChange); 63 | } 64 | 65 | SearchAnnotation.prototype.onChange = function(change) { 66 | var startLine = change.from.line; 67 | var endLine = CodeMirror.changeEnd(change).line; 68 | var sizeChange = endLine - change.to.line; 69 | if (this.gap) { 70 | this.gap.from = Math.min(offsetLine(this.gap.from, startLine, sizeChange), change.from.line); 71 | this.gap.to = Math.max(offsetLine(this.gap.to, startLine, sizeChange), change.from.line); 72 | } else { 73 | this.gap = {from: change.from.line, to: endLine + 1}; 74 | } 75 | 76 | if (sizeChange) for (var i = 0; i < this.matches.length; i++) { 77 | var match = this.matches[i]; 78 | var newFrom = offsetLine(match.from.line, startLine, sizeChange); 79 | if (newFrom != match.from.line) match.from = CodeMirror.Pos(newFrom, match.from.ch); 80 | var newTo = offsetLine(match.to.line, startLine, sizeChange); 81 | if (newTo != match.to.line) match.to = CodeMirror.Pos(newTo, match.to.ch); 82 | } 83 | clearTimeout(this.update); 84 | var self = this; 85 | this.update = setTimeout(function() { self.updateAfterChange(); }, 250); 86 | }; 87 | 88 | SearchAnnotation.prototype.updateAfterChange = function() { 89 | this.findMatches(); 90 | this.annotation.update(this.matches); 91 | }; 92 | 93 | SearchAnnotation.prototype.clear = function() { 94 | this.cm.off("change", this.changeHandler); 95 | this.annotation.clear(); 96 | }; 97 | }); 98 | -------------------------------------------------------------------------------- /front-vue/build/webpack.prod.conf.js: -------------------------------------------------------------------------------- 1 | var path = require('path') 2 | var utils = require('./utils') 3 | var webpack = require('webpack') 4 | var config = require('../config/index') 5 | var merge = require('webpack-merge') 6 | var baseWebpackConfig = require('./webpack.base.conf') 7 | var CopyWebpackPlugin = require('copy-webpack-plugin') 8 | var HtmlWebpackPlugin = require('html-webpack-plugin') 9 | var ExtractTextPlugin = require('extract-text-webpack-plugin') 10 | var OptimizeCSSPlugin = require('optimize-css-assets-webpack-plugin') 11 | 12 | var env = config.build.env 13 | 14 | var webpackConfig = merge(baseWebpackConfig, { 15 | module: { 16 | rules: utils.styleLoaders({ 17 | sourceMap: config.build.productionSourceMap, 18 | extract: true 19 | }) 20 | }, 21 | devtool: config.build.productionSourceMap ? '#source-map' : false, 22 | output: { 23 | path: config.build.assetsRoot, 24 | filename: utils.assetsPath('js/[name].[chunkhash].js'), 25 | chunkFilename: utils.assetsPath('js/[id].[chunkhash].js') 26 | }, 27 | plugins: [ 28 | // http://vuejs.github.io/vue-loader/en/workflow/production.html 29 | new webpack.DefinePlugin({ 30 | 'process.env': env 31 | }), 32 | new webpack.optimize.UglifyJsPlugin({ 33 | compress: { 34 | warnings: false 35 | }, 36 | sourceMap: true 37 | }), 38 | // extract css into its own file 39 | new ExtractTextPlugin({ 40 | filename: utils.assetsPath('css/[name].[contenthash].css') 41 | }), 42 | // Compress extracted CSS. We are using this plugin so that possible 43 | // duplicated CSS from different components can be deduped. 44 | new OptimizeCSSPlugin({ 45 | cssProcessorOptions: { 46 | safe: true 47 | } 48 | }), 49 | // generate dist index.html with correct asset hash for caching. 50 | // you can customize output by editing /index.html 51 | // see https://github.com/ampedandwired/html-webpack-plugin 52 | new HtmlWebpackPlugin({ 53 | filename: config.build.index, 54 | template: 'index.html', 55 | inject: true, 56 | minify: { 57 | removeComments: true, 58 | collapseWhitespace: true, 59 | removeAttributeQuotes: true 60 | // more options: 61 | // https://github.com/kangax/html-minifier#options-quick-reference 62 | }, 63 | // necessary to consistently work with multiple chunks via CommonsChunkPlugin 64 | chunksSortMode: 'dependency' 65 | }), 66 | // split vendor js into its own file 67 | new webpack.optimize.CommonsChunkPlugin({ 68 | name: 'vendor', 69 | minChunks: function (module, count) { 70 | // any required modules inside node_modules are extracted to vendor 71 | return ( 72 | module.resource && 73 | /\.js$/.test(module.resource) && 74 | module.resource.indexOf( 75 | path.join(__dirname, '../node_modules') 76 | ) === 0 77 | ) 78 | } 79 | }), 80 | // extract webpack runtime and module manifest to its own file in order to 81 | // prevent vendor hash from being updated whenever app bundle is updated 82 | new webpack.optimize.CommonsChunkPlugin({ 83 | name: 'manifest', 84 | chunks: ['vendor'] 85 | }), 86 | // copy custom static assets 87 | new CopyWebpackPlugin([ 88 | { 89 | from: path.resolve(__dirname, '../static'), 90 | to: config.build.assetsSubDirectory, 91 | ignore: ['.*'] 92 | } 93 | ]) 94 | ] 95 | }) 96 | 97 | if (config.build.productionGzip) { 98 | var CompressionWebpackPlugin = require('compression-webpack-plugin') 99 | 100 | webpackConfig.plugins.push( 101 | new CompressionWebpackPlugin({ 102 | asset: '[path].gz[query]', 103 | algorithm: 'gzip', 104 | test: new RegExp( 105 | '\\.(' + 106 | config.build.productionGzipExtensions.join('|') + 107 | ')$' 108 | ), 109 | threshold: 10240, 110 | minRatio: 0.8 111 | }) 112 | ) 113 | } 114 | 115 | if (config.build.bundleAnalyzerReport) { 116 | var BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin 117 | webpackConfig.plugins.push(new BundleAnalyzerPlugin()) 118 | } 119 | 120 | module.exports = webpackConfig 121 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/fold/brace-fold.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror")); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror"], mod); 9 | else // Plain browser env 10 | mod(CodeMirror); 11 | })(function(CodeMirror) { 12 | "use strict"; 13 | 14 | CodeMirror.registerHelper("fold", "brace", function(cm, start) { 15 | var line = start.line, lineText = cm.getLine(line); 16 | var tokenType; 17 | 18 | function findOpening(openCh) { 19 | for (var at = start.ch, pass = 0;;) { 20 | var found = at <= 0 ? -1 : lineText.lastIndexOf(openCh, at - 1); 21 | if (found == -1) { 22 | if (pass == 1) break; 23 | pass = 1; 24 | at = lineText.length; 25 | continue; 26 | } 27 | if (pass == 1 && found < start.ch) break; 28 | tokenType = cm.getTokenTypeAt(CodeMirror.Pos(line, found + 1)); 29 | if (!/^(comment|string)/.test(tokenType)) return found + 1; 30 | at = found - 1; 31 | } 32 | } 33 | 34 | var startToken = "{", endToken = "}", startCh = findOpening("{"); 35 | if (startCh == null) { 36 | startToken = "[", endToken = "]"; 37 | startCh = findOpening("["); 38 | } 39 | 40 | if (startCh == null) return; 41 | var count = 1, lastLine = cm.lastLine(), end, endCh; 42 | outer: for (var i = line; i <= lastLine; ++i) { 43 | var text = cm.getLine(i), pos = i == line ? startCh : 0; 44 | for (;;) { 45 | var nextOpen = text.indexOf(startToken, pos), nextClose = text.indexOf(endToken, pos); 46 | if (nextOpen < 0) nextOpen = text.length; 47 | if (nextClose < 0) nextClose = text.length; 48 | pos = Math.min(nextOpen, nextClose); 49 | if (pos == text.length) break; 50 | if (cm.getTokenTypeAt(CodeMirror.Pos(i, pos + 1)) == tokenType) { 51 | if (pos == nextOpen) ++count; 52 | else if (!--count) { end = i; endCh = pos; break outer; } 53 | } 54 | ++pos; 55 | } 56 | } 57 | if (end == null || line == end && endCh == startCh) return; 58 | return {from: CodeMirror.Pos(line, startCh), 59 | to: CodeMirror.Pos(end, endCh)}; 60 | }); 61 | 62 | CodeMirror.registerHelper("fold", "import", function(cm, start) { 63 | function hasImport(line) { 64 | if (line < cm.firstLine() || line > cm.lastLine()) return null; 65 | var start = cm.getTokenAt(CodeMirror.Pos(line, 1)); 66 | if (!/\S/.test(start.string)) start = cm.getTokenAt(CodeMirror.Pos(line, start.end + 1)); 67 | if (start.type != "keyword" || start.string != "import") return null; 68 | // Now find closing semicolon, return its position 69 | for (var i = line, e = Math.min(cm.lastLine(), line + 10); i <= e; ++i) { 70 | var text = cm.getLine(i), semi = text.indexOf(";"); 71 | if (semi != -1) return {startCh: start.end, end: CodeMirror.Pos(i, semi)}; 72 | } 73 | } 74 | 75 | var startLine = start.line, has = hasImport(startLine), prev; 76 | if (!has || hasImport(startLine - 1) || ((prev = hasImport(startLine - 2)) && prev.end.line == startLine - 1)) 77 | return null; 78 | for (var end = has.end;;) { 79 | var next = hasImport(end.line + 1); 80 | if (next == null) break; 81 | end = next.end; 82 | } 83 | return {from: cm.clipPos(CodeMirror.Pos(startLine, has.startCh + 1)), to: end}; 84 | }); 85 | 86 | CodeMirror.registerHelper("fold", "include", function(cm, start) { 87 | function hasInclude(line) { 88 | if (line < cm.firstLine() || line > cm.lastLine()) return null; 89 | var start = cm.getTokenAt(CodeMirror.Pos(line, 1)); 90 | if (!/\S/.test(start.string)) start = cm.getTokenAt(CodeMirror.Pos(line, start.end + 1)); 91 | if (start.type == "meta" && start.string.slice(0, 8) == "#include") return start.start + 8; 92 | } 93 | 94 | var startLine = start.line, has = hasInclude(startLine); 95 | if (has == null || hasInclude(startLine - 1) != null) return null; 96 | for (var end = startLine;;) { 97 | var next = hasInclude(end + 1); 98 | if (next == null) break; 99 | ++end; 100 | } 101 | return {from: CodeMirror.Pos(startLine, has + 1), 102 | to: cm.clipPos(CodeMirror.Pos(end))}; 103 | }); 104 | 105 | }); 106 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/selection/mark-selection.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | // Because sometimes you need to mark the selected *text*. 5 | // 6 | // Adds an option 'styleSelectedText' which, when enabled, gives 7 | // selected text the CSS class given as option value, or 8 | // "CodeMirror-selectedtext" when the value is not a string. 9 | 10 | (function(mod) { 11 | if (typeof exports == "object" && typeof module == "object") // CommonJS 12 | mod(require("../../lib/codemirror")); 13 | else if (typeof define == "function" && define.amd) // AMD 14 | define(["../../lib/codemirror"], mod); 15 | else // Plain browser env 16 | mod(CodeMirror); 17 | })(function(CodeMirror) { 18 | "use strict"; 19 | 20 | CodeMirror.defineOption("styleSelectedText", false, function(cm, val, old) { 21 | var prev = old && old != CodeMirror.Init; 22 | if (val && !prev) { 23 | cm.state.markedSelection = []; 24 | cm.state.markedSelectionStyle = typeof val == "string" ? val : "CodeMirror-selectedtext"; 25 | reset(cm); 26 | cm.on("cursorActivity", onCursorActivity); 27 | cm.on("change", onChange); 28 | } else if (!val && prev) { 29 | cm.off("cursorActivity", onCursorActivity); 30 | cm.off("change", onChange); 31 | clear(cm); 32 | cm.state.markedSelection = cm.state.markedSelectionStyle = null; 33 | } 34 | }); 35 | 36 | function onCursorActivity(cm) { 37 | if (cm.state.markedSelection) 38 | cm.operation(function() { update(cm); }); 39 | } 40 | 41 | function onChange(cm) { 42 | if (cm.state.markedSelection && cm.state.markedSelection.length) 43 | cm.operation(function() { clear(cm); }); 44 | } 45 | 46 | var CHUNK_SIZE = 8; 47 | var Pos = CodeMirror.Pos; 48 | var cmp = CodeMirror.cmpPos; 49 | 50 | function coverRange(cm, from, to, addAt) { 51 | if (cmp(from, to) == 0) return; 52 | var array = cm.state.markedSelection; 53 | var cls = cm.state.markedSelectionStyle; 54 | for (var line = from.line;;) { 55 | var start = line == from.line ? from : Pos(line, 0); 56 | var endLine = line + CHUNK_SIZE, atEnd = endLine >= to.line; 57 | var end = atEnd ? to : Pos(endLine, 0); 58 | var mark = cm.markText(start, end, {className: cls}); 59 | if (addAt == null) array.push(mark); 60 | else array.splice(addAt++, 0, mark); 61 | if (atEnd) break; 62 | line = endLine; 63 | } 64 | } 65 | 66 | function clear(cm) { 67 | var array = cm.state.markedSelection; 68 | for (var i = 0; i < array.length; ++i) array[i].clear(); 69 | array.length = 0; 70 | } 71 | 72 | function reset(cm) { 73 | clear(cm); 74 | var ranges = cm.listSelections(); 75 | for (var i = 0; i < ranges.length; i++) 76 | coverRange(cm, ranges[i].from(), ranges[i].to()); 77 | } 78 | 79 | function update(cm) { 80 | if (!cm.somethingSelected()) return clear(cm); 81 | if (cm.listSelections().length > 1) return reset(cm); 82 | 83 | var from = cm.getCursor("start"), to = cm.getCursor("end"); 84 | 85 | var array = cm.state.markedSelection; 86 | if (!array.length) return coverRange(cm, from, to); 87 | 88 | var coverStart = array[0].find(), coverEnd = array[array.length - 1].find(); 89 | if (!coverStart || !coverEnd || to.line - from.line < CHUNK_SIZE || 90 | cmp(from, coverEnd.to) >= 0 || cmp(to, coverStart.from) <= 0) 91 | return reset(cm); 92 | 93 | while (cmp(from, coverStart.from) > 0) { 94 | array.shift().clear(); 95 | coverStart = array[0].find(); 96 | } 97 | if (cmp(from, coverStart.from) < 0) { 98 | if (coverStart.to.line - from.line < CHUNK_SIZE) { 99 | array.shift().clear(); 100 | coverRange(cm, from, coverStart.to, 0); 101 | } else { 102 | coverRange(cm, from, coverStart.from, 0); 103 | } 104 | } 105 | 106 | while (cmp(to, coverEnd.to) < 0) { 107 | array.pop().clear(); 108 | coverEnd = array[array.length - 1].find(); 109 | } 110 | if (cmp(to, coverEnd.to) > 0) { 111 | if (to.line - coverEnd.from.line < CHUNK_SIZE) { 112 | array.pop().clear(); 113 | coverRange(cm, coverEnd.from, to); 114 | } else { 115 | coverRange(cm, coverEnd.to, to); 116 | } 117 | } 118 | } 119 | }); 120 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/lib/model/document_data.js: -------------------------------------------------------------------------------- 1 | import { loadMode } from "../display/mode_state" 2 | import { runInOp } from "../display/operations" 3 | import { regChange } from "../display/view_tracking" 4 | import { Line, updateLine } from "../line/line_data" 5 | import { findMaxLine } from "../line/spans" 6 | import { getLine } from "../line/utils_line" 7 | import { estimateLineHeights } from "../measurement/position_measurement" 8 | import { addClass, rmClass } from "../util/dom" 9 | import { lst } from "../util/misc" 10 | import { signalLater } from "../util/operation_group" 11 | 12 | // DOCUMENT DATA STRUCTURE 13 | 14 | // By default, updates that start and end at the beginning of a line 15 | // are treated specially, in order to make the association of line 16 | // widgets and marker elements with the text behave more intuitive. 17 | export function isWholeLineUpdate(doc, change) { 18 | return change.from.ch == 0 && change.to.ch == 0 && lst(change.text) == "" && 19 | (!doc.cm || doc.cm.options.wholeLineUpdateBefore) 20 | } 21 | 22 | // Perform a change on the document data structure. 23 | export function updateDoc(doc, change, markedSpans, estimateHeight) { 24 | function spansFor(n) {return markedSpans ? markedSpans[n] : null} 25 | function update(line, text, spans) { 26 | updateLine(line, text, spans, estimateHeight) 27 | signalLater(line, "change", line, change) 28 | } 29 | function linesFor(start, end) { 30 | let result = [] 31 | for (let i = start; i < end; ++i) 32 | result.push(new Line(text[i], spansFor(i), estimateHeight)) 33 | return result 34 | } 35 | 36 | let from = change.from, to = change.to, text = change.text 37 | let firstLine = getLine(doc, from.line), lastLine = getLine(doc, to.line) 38 | let lastText = lst(text), lastSpans = spansFor(text.length - 1), nlines = to.line - from.line 39 | 40 | // Adjust the line structure 41 | if (change.full) { 42 | doc.insert(0, linesFor(0, text.length)) 43 | doc.remove(text.length, doc.size - text.length) 44 | } else if (isWholeLineUpdate(doc, change)) { 45 | // This is a whole-line replace. Treated specially to make 46 | // sure line objects move the way they are supposed to. 47 | let added = linesFor(0, text.length - 1) 48 | update(lastLine, lastLine.text, lastSpans) 49 | if (nlines) doc.remove(from.line, nlines) 50 | if (added.length) doc.insert(from.line, added) 51 | } else if (firstLine == lastLine) { 52 | if (text.length == 1) { 53 | update(firstLine, firstLine.text.slice(0, from.ch) + lastText + firstLine.text.slice(to.ch), lastSpans) 54 | } else { 55 | let added = linesFor(1, text.length - 1) 56 | added.push(new Line(lastText + firstLine.text.slice(to.ch), lastSpans, estimateHeight)) 57 | update(firstLine, firstLine.text.slice(0, from.ch) + text[0], spansFor(0)) 58 | doc.insert(from.line + 1, added) 59 | } 60 | } else if (text.length == 1) { 61 | update(firstLine, firstLine.text.slice(0, from.ch) + text[0] + lastLine.text.slice(to.ch), spansFor(0)) 62 | doc.remove(from.line + 1, nlines) 63 | } else { 64 | update(firstLine, firstLine.text.slice(0, from.ch) + text[0], spansFor(0)) 65 | update(lastLine, lastText + lastLine.text.slice(to.ch), lastSpans) 66 | let added = linesFor(1, text.length - 1) 67 | if (nlines > 1) doc.remove(from.line + 1, nlines - 1) 68 | doc.insert(from.line + 1, added) 69 | } 70 | 71 | signalLater(doc, "change", doc, change) 72 | } 73 | 74 | // Call f for all linked documents. 75 | export function linkedDocs(doc, f, sharedHistOnly) { 76 | function propagate(doc, skip, sharedHist) { 77 | if (doc.linked) for (let i = 0; i < doc.linked.length; ++i) { 78 | let rel = doc.linked[i] 79 | if (rel.doc == skip) continue 80 | let shared = sharedHist && rel.sharedHist 81 | if (sharedHistOnly && !shared) continue 82 | f(rel.doc, shared) 83 | propagate(rel.doc, doc, shared) 84 | } 85 | } 86 | propagate(doc, null, true) 87 | } 88 | 89 | // Attach a document to an editor. 90 | export function attachDoc(cm, doc) { 91 | if (doc.cm) throw new Error("This document is already in use.") 92 | cm.doc = doc 93 | doc.cm = cm 94 | estimateLineHeights(cm) 95 | loadMode(cm) 96 | setDirectionClass(cm) 97 | if (!cm.options.lineWrapping) findMaxLine(cm) 98 | cm.options.mode = doc.modeOption 99 | regChange(cm) 100 | } 101 | 102 | function setDirectionClass(cm) { 103 | ;(cm.doc.direction == "rtl" ? addClass : rmClass)(cm.display.lineDiv, "CodeMirror-rtl") 104 | } 105 | 106 | export function directionChanged(cm) { 107 | runInOp(cm, () => { 108 | setDirectionClass(cm) 109 | regChange(cm) 110 | }) 111 | } 112 | -------------------------------------------------------------------------------- /front-vue/src/assets/CodeMirror/addon/display/panel.js: -------------------------------------------------------------------------------- 1 | // CodeMirror, copyright (c) by Marijn Haverbeke and others 2 | // Distributed under an MIT license: http://codemirror.net/LICENSE 3 | 4 | (function(mod) { 5 | if (typeof exports == "object" && typeof module == "object") // CommonJS 6 | mod(require("../../lib/codemirror")); 7 | else if (typeof define == "function" && define.amd) // AMD 8 | define(["../../lib/codemirror"], mod); 9 | else // Plain browser env 10 | mod(CodeMirror); 11 | })(function(CodeMirror) { 12 | CodeMirror.defineExtension("addPanel", function(node, options) { 13 | options = options || {}; 14 | 15 | if (!this.state.panels) initPanels(this); 16 | 17 | var info = this.state.panels; 18 | var wrapper = info.wrapper; 19 | var cmWrapper = this.getWrapperElement(); 20 | 21 | if (options.after instanceof Panel && !options.after.cleared) { 22 | wrapper.insertBefore(node, options.before.node.nextSibling); 23 | } else if (options.before instanceof Panel && !options.before.cleared) { 24 | wrapper.insertBefore(node, options.before.node); 25 | } else if (options.replace instanceof Panel && !options.replace.cleared) { 26 | wrapper.insertBefore(node, options.replace.node); 27 | options.replace.clear(); 28 | } else if (options.position == "bottom") { 29 | wrapper.appendChild(node); 30 | } else if (options.position == "before-bottom") { 31 | wrapper.insertBefore(node, cmWrapper.nextSibling); 32 | } else if (options.position == "after-top") { 33 | wrapper.insertBefore(node, cmWrapper); 34 | } else { 35 | wrapper.insertBefore(node, wrapper.firstChild); 36 | } 37 | 38 | var height = (options && options.height) || node.offsetHeight; 39 | this._setSize(null, info.heightLeft -= height); 40 | info.panels++; 41 | if (options.stable && isAtTop(this, node)) 42 | this.scrollTo(null, this.getScrollInfo().top + height) 43 | 44 | return new Panel(this, node, options, height); 45 | }); 46 | 47 | function Panel(cm, node, options, height) { 48 | this.cm = cm; 49 | this.node = node; 50 | this.options = options; 51 | this.height = height; 52 | this.cleared = false; 53 | } 54 | 55 | Panel.prototype.clear = function() { 56 | if (this.cleared) return; 57 | this.cleared = true; 58 | var info = this.cm.state.panels; 59 | this.cm._setSize(null, info.heightLeft += this.height); 60 | if (this.options.stable && isAtTop(this.cm, this.node)) 61 | this.cm.scrollTo(null, this.cm.getScrollInfo().top - this.height) 62 | info.wrapper.removeChild(this.node); 63 | if (--info.panels == 0) removePanels(this.cm); 64 | }; 65 | 66 | Panel.prototype.changed = function(height) { 67 | var newHeight = height == null ? this.node.offsetHeight : height; 68 | var info = this.cm.state.panels; 69 | this.cm._setSize(null, info.heightLeft -= (newHeight - this.height)); 70 | this.height = newHeight; 71 | }; 72 | 73 | function initPanels(cm) { 74 | var wrap = cm.getWrapperElement(); 75 | var style = window.getComputedStyle ? window.getComputedStyle(wrap) : wrap.currentStyle; 76 | var height = parseInt(style.height); 77 | var info = cm.state.panels = { 78 | setHeight: wrap.style.height, 79 | heightLeft: height, 80 | panels: 0, 81 | wrapper: document.createElement("div") 82 | }; 83 | wrap.parentNode.insertBefore(info.wrapper, wrap); 84 | var hasFocus = cm.hasFocus(); 85 | info.wrapper.appendChild(wrap); 86 | if (hasFocus) cm.focus(); 87 | 88 | cm._setSize = cm.setSize; 89 | if (height != null) cm.setSize = function(width, newHeight) { 90 | if (newHeight == null) return this._setSize(width, newHeight); 91 | info.setHeight = newHeight; 92 | if (typeof newHeight != "number") { 93 | var px = /^(\d+\.?\d*)px$/.exec(newHeight); 94 | if (px) { 95 | newHeight = Number(px[1]); 96 | } else { 97 | info.wrapper.style.height = newHeight; 98 | newHeight = info.wrapper.offsetHeight; 99 | info.wrapper.style.height = ""; 100 | } 101 | } 102 | cm._setSize(width, info.heightLeft += (newHeight - height)); 103 | height = newHeight; 104 | }; 105 | } 106 | 107 | function removePanels(cm) { 108 | var info = cm.state.panels; 109 | cm.state.panels = null; 110 | 111 | var wrap = cm.getWrapperElement(); 112 | info.wrapper.parentNode.replaceChild(wrap, info.wrapper); 113 | wrap.style.height = info.setHeight; 114 | cm.setSize = cm._setSize; 115 | cm.setSize(); 116 | } 117 | 118 | function isAtTop(cm, dom) { 119 | for (var sibling = dom.nextSibling; sibling; sibling = sibling.nextSibling) 120 | if (sibling == cm.getWrapperElement()) return true 121 | return false 122 | } 123 | }); 124 | --------------------------------------------------------------------------------