内置环境输出调整,更改添加模拟按键方法

This commit is contained in:
fofolee 2020-06-15 18:00:56 +08:00
parent 05aff76a93
commit 9c7302c455

View File

@ -205,6 +205,7 @@ let showOptions = () => {
let showCustomize = () => { let showCustomize = () => {
$("#customize").remove(); $("#customize").remove();
$("#featureList").fadeOut()
let options = `<option>${Object.keys(programs).join('</option><option>')}</option>` let options = `<option>${Object.keys(programs).join('</option><option>')}</option>`
customWindow = `<div id="customize"> customWindow = `<div id="customize">
<p><input type="text" id="code" style="display: none"> <p><input type="text" id="code" style="display: none">
@ -219,7 +220,7 @@ let showCustomize = () => {
<p> <p>
<span class="word">&#12288;</span> <span class="word">&#12288;</span>
<select id="program"> <select id="program">
<option value="simulation">模拟操作</option> <option value="simulation">内置环境</option>
${options} ${options}
</select> </select>
<span class="word">&#12288;</span><input type="text" readonly id="iconame" placeholder=""> <span class="word">&#12288;</span><input type="text" readonly id="iconame" placeholder="">
@ -237,60 +238,31 @@ let showCustomize = () => {
<option value="{{WindowInfo}}" class="var window">当前窗口信息(JSON格式)</option> <option value="{{WindowInfo}}" class="var window">当前窗口信息(JSON格式)</option>
<option value="{{BrowserUrl}}">浏览器当前链接</option> <option value="{{BrowserUrl}}">浏览器当前链接</option>
<option value="{{ClipText}}">剪切板的文本</option> <option value="{{ClipText}}">剪切板的文本</option>
aa<option value="{{SelectText}}" class="selectText">选中的文本</option>
<option value="{{SelectFile}}" class="var window">选中的文件</option> <option value="{{SelectFile}}" class="var window">选中的文件</option>
</select> </select>
<span class="word">&#12288;</span> <span class="word">&#12288;</span>
<select id="output"> <select id="output">
<option value="ignore">忽略输出</option> <option value="ignore">隐藏并忽略输出</option>
<option value="text">显示纯文本输出</option> <option value="text">显示纯文本输出</option>
<option value="html">显示html格式的输出</option> <option value="html">显示html格式的输出</option>
<option value="terminal" id="showInTerm">在终端显示输出</option>
<option value="clip">复制到剪贴板</option> <option value="clip">复制到剪贴板</option>
<option value="send">发送到活动窗口</option> <option value="send">发送到活动窗口</option>
<option value="notice">发送系统通知</option> <option value="notice">发送系统通知</option>
<option value="terminal">在终端显示</option>
</select> </select>
</p> </p>
<p class="simulation">
<span class="word">&#12288;</span>
<select id="modifier1" class="robot keys">
<option value=""></option>
<option value="control">control</option>
<option value="alt">alt</option>
<option value="shift">shift</option>
<option value="command">/win</option>
</select>
<select id="modifier2" class="robot keys">
<option value=""></option>
<option value="control">control</option>
<option value="alt">alt</option>
<option value="shift">shift</option>
<option value="command">/win</option>
</select>
<input type="text" id="presskey" class="robot keys" placeholder="模拟按键">
<span id="addKey" class="robot footBtn">按键</span>
<select id="action" class="robot keys">
<option value="" style="display:none">预设动作</option>
<option value="sleep">添加延时</option>
<option value="open">打开文件</option>
<option value="visit">打开网址</option>
<option value="locate">定位文件</option>
<option value="system">执行命令</option>
<option value="copyTo">写剪贴板</option>
<option value="message">系统消息</option>
<option value="alert">弹窗显示</option>
<option value="send">发送文本</option>
<option value="ubrowser">ubrowser打开</option>
</select>
<span id="addAction" class="robot footBtn">动作</span>
</p>
<p> <p>
<span class="word">&#12288;</span> <span class="word">&#12288;</span>
<span> <span class="customscript">
<input type="text" id="custombin" class="customscript" placeholder="解释器绝对路径"> <input type="text" id="custombin" placeholder="解释器绝对路径">
<input type="text" id="customarg" class="customscript" placeholder="参数"> <input type="text" id="customarg" placeholder="参数">
<input type="text" id="customext" class="customscript" placeholder="后缀,不含."> <input type="text" id="customext" placeholder="后缀,不含.">
<input type="text" id="customcodec" class="customscript" placeholder="输出编码"> <input type="text" id="customcodec" placeholder="输出编码">
</span>
<span class="simulation">
<span id="addAction" class="footBtn robot">动作</span>
<span id="addKey" class="footBtn robot">按键</span>
<span id="showHelp" class="footBtn robot">帮助</span>
</span> </span>
</p> </p>
<p><textarea id="cmd" placeholder="可以直接拖放脚本文件至此处, 支持VSCode快捷键\nAlt+Enter 全屏\nCtrl+B 运行\nCtrl+S 保存\nCtrl+Q 取消\nCtrl+F 搜索"></textarea></p> <p><textarea id="cmd" placeholder="可以直接拖放脚本文件至此处, 支持VSCode快捷键\nAlt+Enter 全屏\nCtrl+B 运行\nCtrl+S 保存\nCtrl+Q 取消\nCtrl+F 搜索"></textarea></p>
@ -316,13 +288,13 @@ let showCustomize = () => {
cm.setOption("fullScreen", !cm.getOption("fullScreen")); cm.setOption("fullScreen", !cm.getOption("fullScreen"));
}, },
"Ctrl-B": () => { "Ctrl-B": () => {
runQuickCommand() runCurrentCommand()
}, },
"Ctrl-S": () => { "Ctrl-S": () => {
SaveQuickCommand() SaveCurrentCommand()
}, },
"Ctrl-Q": () => { "Ctrl-Q": () => {
quitQuickCommand() quitCurrentCommand()
}, },
"Alt-Up": "swapLineUp", "Alt-Up": "swapLineUp",
"Alt-Down": "swapLineDown", "Alt-Down": "swapLineDown",
@ -418,18 +390,18 @@ let programCheck = () => {
case 'custom': case 'custom':
$('.customscript').show(); $('.customscript').show();
$('.simulation').hide(); $('.simulation').hide();
$('.varoutput').show(); $('#showInTerm').show()
break; break;
case 'simulation': case 'simulation':
$('.varoutput').hide();
$('.simulation').show(); $('.simulation').show();
$('.customscript').hide(); $('.customscript').hide();
$('#showInTerm').hide()
mode = 'javascript'; mode = 'javascript';
break; break;
default: default:
$('.customscript').hide(); $('.customscript').hide();
$('.simulation').hide(); $('.simulation').hide();
$('.varoutput').show(); $('#showInTerm').show()
break; break;
} }
window.editor.setOption("mode", mode); window.editor.setOption("mode", mode);
@ -501,41 +473,30 @@ $("#options").on('click', '.editBtn', function () {
// 添加模拟按键 // 添加模拟按键
$("#options").on('click', '#addKey', function () { $("#options").on('click', '#addKey', function () {
var m1 = $('#modifier1').val(); $("#addKey").text("▶ 录制中").addClass('record')
var m2 = $('#modifier2').val(); message('开始录制按键,可连续录制')
var k = $('#presskey').val(); Mousetrap.record(sequence => {
var code = 'keyTap'; sequence.forEach(s => {
if (/^(\S|f1[0-2]|f[1-9]|backspace|delete|enter|tab|escape|up|down|right|left|home|end|pageup|pagedown|command|alt|control|shift|right_shift|space|printscreen|insert')$/.test(k)) { var keys = s
if (!m1 && !m2) { if (s.includes('+') && s.length > 1) keys = s.split('+').reverse().map(x=>x.trim()).join(`", "`)
code += `('${k}');\n`; window.editor.replaceSelection(`keyTap("${keys}")\n`)
} else if(m1 && m2){ })
code += `('${k}', '${m1}', '${m2}');\n` $("#addKey").text("﹢按键").removeClass('record')
} else { });
code += `('${k}', '${m1}${m2}');\n` })
}
window.editor.replaceSelection(code); // 内置环境的帮助
} else { $("#options").on('click', '#showHelp', function () {
Swal.fire({ $.get('./HELP.md', r => {
text: '请输入正确的按键', utools.ubrowser.goto(r).run()
icon: 'warning', })
showCancelButton: true,
confirmButtonColor: '#3085d6',
cancelButtonColor: '#d33',
confirmButtonText: '帮助',
cancelButtonText: '确定',
}).then((result) => {
if (result.value) {
visit('https://robotjs.io/docs/syntax#keys');
}
})
}
}) })
// 添加延时 // 添加延时
$("#options").on('click', '#addDelay', function () { $("#options").on('click', '#addDelay', function () {
var t = $('#keydelay').val(); var t = $('#keydelay').val();
if (/\d+/.test(t)) { if (/\d+/.test(t)) {
window.editor.replaceSelection(`await sleep(${t});\n`) window.editor.replaceSelection(`sleep(${t});\n`)
} else { } else {
Swal.fire({ Swal.fire({
icon: 'warning', icon: 'warning',
@ -545,61 +506,36 @@ $("#options").on('click', '#addDelay', function () {
}) })
// 添加动作 // 添加动作
$("#options").on('click', '#addAction', async function () { $("#options").on('click', '#addAction', function () {
var a = $('#action').val(); var html = `
var text; <select id="actionType" class="swal2-select" style="width: 80%; height: 3rem;">
switch (a) { <option value="open">打开文件/文件夹</option>
case 'await sleep': <option value="locate">在文件管理器中定位文件</option>
text = '要延时的毫秒'; <option value="visit">用默认浏览器打开网址</option>
break; <option value="utools.ubrowser.goto">用ubrowser打开网址</option>
case 'open': <option value="system">执行系统命令</option>
text = '要打开的文件'; <option value="copyTo">将内容写入剪贴板</option>
break; <option value="message">发送系统消息</option>
case 'visit': <option value="alert">弹窗显示消息</option>
text = '要访问的网址'; <option value="send">发送文本到活动窗口</option>
break; <option value="sleep">添加延时毫秒</option>
case 'locate': </select>
text = '要定位的文件' <input placeholder="动作的参数" id="actionArgs" class="swal2-input" style="width: 80%; height: 3rem;">
break; <input type="checkbox" checked id="isString" style="margin-left: 60%;">加引号
case 'system': `
text = '要执行的命令' Swal.fire({
break; title: "预设动作",
case 'message': html: html,
text = '要发送的消息'
break;
case 'copyTo':
text = '要写入的内容'
break;
case 'send':
text = '要发送的文本'
break;
case 'alert':
text = '要弹窗的消息'
break;
case 'ubrowser':
text = '要访问的网站'
break;
default:
Swal.fire({
icon: 'warning',
text: '未选中任何动作',
})
return;
}
const { value: content } = await Swal.fire({
title: text,
input: 'text',
showCancelButton: true, showCancelButton: true,
}) preConfirm: () => {
if (content) { var actionType = $("#actionType").val()
if (a == 'ubrowser') { var actionArgs = $("#actionArgs").val()
window.editor.replaceSelection(`utools.ubrowser.goto("${content}")\n .run()\n`) if ($("#isString").is(':checked')) actionArgs = "String.raw\`" + actionArgs + "\`"
} else if (a == 'await sleep') { var action = `${actionType}(${actionArgs})`
window.editor.replaceSelection(`${a}(${content})\n`) if (actionType == 'utools.ubrowser.goto') action += `.run()`
} else { window.editor.replaceSelection(`${action}\n`)
window.editor.replaceSelection(`${a}("${content.replace(/\\/g, '\\\\')}");\n`)
} }
} })
}) })
// 导出 // 导出
@ -642,7 +578,7 @@ $("#options").on('click', '#icon, #iconame', function () {
} }
}) })
let SaveQuickCommand = async () => { let SaveCurrentCommand = async () => {
var type = $('#type').val(); var type = $('#type').val();
var code = $("#code").val(); var code = $("#code").val();
if (!code) { if (!code) {
@ -655,36 +591,16 @@ let SaveQuickCommand = async () => {
// 合规性校验 // 合规性校验
if (type == 'key' if (type == 'key'
&& ['{{input}}', '{{SelectFile}}', '{{pwd}}', '{{WindowInfo}}'].map(x => cmd.includes(x)).includes(true)) { && ['{{input}}', '{{SelectFile}}', '{{pwd}}', '{{WindowInfo}}'].map(x => cmd.includes(x)).includes(true)) {
Swal.fire({ Swal.fire('关键字模式无法使用{{input}}、{{SelectFile}}、{{WindowInfo}}、{{pwd}}!')
icon: 'error',
title: '啊嘞?!',
text: '关键字模式无法使用{{input}}、{{SelectFile}}、{{WindowInfo}}、{{pwd}}!',
})
} else if (type == 'regex' } else if (type == 'regex'
&& ['{{SelectFile}}', '{{WindowInfo}}', '{{pwd}}'].map(x => cmd.includes(x)).includes(true)) { && ['{{SelectFile}}', '{{WindowInfo}}', '{{pwd}}'].map(x => cmd.includes(x)).includes(true)) {
Swal.fire({ Swal.fire('正则模式无法使用{{SelectFile}}、{{WindowInfo}}、{{pwd}}!')
icon: 'error',
title: '啊嘞?!',
text: '正则模式无法使用{{SelectFile}}、{{WindowInfo}}、{{pwd}}!',
})
} else if (type == 'window' && cmd.includes('{{input}}')) { } else if (type == 'window' && cmd.includes('{{input}}')) {
Swal.fire({ Swal.fire('窗口模式无法使用{{input}}!')
icon: 'error',
title: '啊嘞?!',
text: '窗口模式无法使用{{input}}!',
})
} else if (['text', 'html'].includes($('#output').val()) && cmd.includes('{{SelectText}}')) { } else if (['text', 'html'].includes($('#output').val()) && cmd.includes('{{SelectText}}')) {
Swal.fire({ Swal.fire('显示文本或html输出时无法使用{{SelectText}}!')
icon: 'error',
title: '啊嘞?!',
text: '显示文本或html输出时无法使用{{SelectText}}!',
})
} else if (type == 'regex' && /^(|\/)\.[*+](|\/)$/.test($('#rule').val())) { } else if (type == 'regex' && /^(|\/)\.[*+](|\/)$/.test($('#rule').val())) {
Swal.fire({ Swal.fire('正则匹配 .* 和 .+ 已被uTools禁用')
icon: 'error',
title: '啊嘞?!',
text: '正则匹配 .* 和 .+ 已被uTools禁用',
})
} }
else { else {
var program = $('#program').val(), var program = $('#program').val(),
@ -763,11 +679,12 @@ let SaveQuickCommand = async () => {
'codec': $('#customcodec').val() 'codec': $('#customcodec').val()
} }
} }
if (program == 'simulation') { // if (program == 'simulation') {
$('#output').val(''); // $('#output').val('');
} // }
putCustomFts(code, pushData); putCustomFts(code, pushData);
showOptions(); showOptions();
$("#customize").empty()
$(`#${code}`).click(); $(`#${code}`).click();
if (!$(`#${code}`).is(':checked')) { if (!$(`#${code}`).is(':checked')) {
$(`#${code}`).click(); $(`#${code}`).click();
@ -776,25 +693,22 @@ let SaveQuickCommand = async () => {
} }
// 显示运行结果 // 显示运行结果
let showResult = (content, raw, success) => { let showRunResult = (content, raw, success) => {
var options var options
var maxlength = raw ? 1000 : 100000 var maxlength = raw ? 5000 : 100000
var htmlEncode = (value, raw) => {
return raw ? String(value).replace(/&/g, "&amp;").replace(/>/g, "&gt;").replace(/</g, "&lt;").replace(/"/g, "&quot;") : value
}
var preView = () => { var preView = () => {
var result = $('#swal2-content').text() var result = $('#swal2-content').text()
var style = "text-align: left; padding: 0px 10px; white-space: pre-wrap; word-break: break-all;"
result = htmlEncode(result, raw) result = htmlEncode(result, raw)
$(".swal2-content").css("width", "100%") $(".swal2-content").css("width", "100%")
$('#swal2-content').html(`<pre style="${style}">${result}</pre>`) $('#swal2-content').html(`<pre class="output ${success ? "" : "error"}">${result}</pre>`)
$('.swal2-popup').addClass('swal2-toast') $('.swal2-popup').addClass('swal2-toast')
} }
var contlength = content.length var contlength = content.length
if(contlength > maxlength) content = content.slice(0, maxlength - 100) + `\n\n...\n${contlength - maxlength - 100} 字省略\n...\n\n` + content.slice(contlength - 100) if (contlength > maxlength) content = content.slice(0, maxlength - 100) + `\n\n...\n${contlength - maxlength - 100} 字省略\n...\n\n` + content.slice(contlength - 100)
content += '\n' content += '\n'
if (Swal.isVisible()) { var outputchannel = $("#swal2-content > pre")
$("#swal2-content > pre").append(htmlEncode(content, raw)) if (outputchannel.is(":parent")) {
outputchannel.append(htmlEncode(content, raw))
} else { } else {
options = { options = {
onBeforeOpen: preView, onBeforeOpen: preView,
@ -814,8 +728,9 @@ let showResult = (content, raw, success) => {
} }
} }
let runQuickCommand = () => { let runCurrentCommand = () => {
var cmd = window.editor.getValue() var cmd = window.editor.getValue()
cmd = special(cmd)
var program = $("#program").val() var program = $("#program").val()
var output = $("#output").val() var output = $("#output").val()
var terminal = false var terminal = false
@ -828,41 +743,43 @@ let runQuickCommand = () => {
terminal = true terminal = true
break; break;
case "ignore": case "ignore":
if(program != "simulation") utools.hideMainWindow() // todo 模拟操作选择输出方式 utools.hideMainWindow()
break; break;
} }
if (program == "simulation") { if (program == "simulation") {
runCodeInVm(cmd, (stdout, stderr) => { runCodeInVm(cmd, (stdout, stderr) => {
if (stderr) return showResult(stderr, raw, false) if (stderr) return showRunResult(stderr, raw, false)
showResult(stdout, raw, true) showRunResult(stdout, raw, true)
}); });
} else { } else {
var option = programs[program] var option = programs[program]
runCodeFile(cmd, option, terminal, (stdout, stderr) => { runCodeFile(cmd, option, terminal, (stdout, stderr) => {
if(terminal) return if(terminal) return
if (stderr) return showResult(stderr, raw, false) if (stderr) return showRunResult(stderr, raw, false)
showResult(stdout, raw, true) showRunResult(stdout, raw, true)
}) })
} }
} }
let quitQuickCommand = () => { let quitCurrentCommand = () => {
$("#customize").animate({ top: '100%'}); $("#customize").animate({ top: '100%' });
$("#featureList").fadeIn()
$("#customize").empty()
} }
// 运行 // 运行
$("#options").on('click', '.cmdBtn.run', function () { $("#options").on('click', '.cmdBtn.run', function () {
runQuickCommand() runCurrentCommand()
}) })
// 取消 // 取消
$("#options").on('click', '.cmdBtn.cancel', function () { $("#options").on('click', '.cmdBtn.cancel', function () {
quitQuickCommand() quitCurrentCommand()
}) })
// 保存 // 保存
$("#options").on('click', '.cmdBtn.save', function () { $("#options").on('click', '.cmdBtn.save', function () {
SaveQuickCommand() SaveCurrentCommand()
}) })
// 语言选项改变时 // 语言选项改变时
@ -891,3 +808,24 @@ $("#options").on('change', '#type', function () {
resetVars(); resetVars();
typeCheck(); typeCheck();
}) })
Mousetrap.bind('ctrl+s', () => {
if ($("#customize").is(":parent")) {
SaveCurrentCommand()
}
return false
});
Mousetrap.bind('ctrl+q', () => {
if ($("#customize").is(":parent")) {
quitCurrentCommand()
}
return false
});
Mousetrap.bind('ctrl+b', () => {
if ($("#customize").is(":parent")) {
runCurrentCommand()
}
return false
});