mirror of
https://github.com/fofolee/uTools-quickcommand.git
synced 2025-10-24 20:45:06 +08:00
完成面板视图
This commit is contained in:
@@ -246,15 +246,6 @@ window.pluginInfo = () => {
|
||||
return JSON.parse(fs.readFileSync(path.join(__dirname, 'plugin.json')))
|
||||
}
|
||||
|
||||
|
||||
let GetFilePath = (Path, File) => {
|
||||
if (utools.isDev()) {
|
||||
return path.join(__dirname, Path, File)
|
||||
} else {
|
||||
return path.join(__dirname.replace(/([a-zA-Z0-9\-]+\.asar)/, '$1.unpacked'), Path, File)
|
||||
}
|
||||
}
|
||||
|
||||
let getSleepCodeByShell = ms => {
|
||||
var cmd, tempFilePath
|
||||
if (utools.isWindows()) {
|
||||
|
10
src/App.vue
10
src/App.vue
@@ -67,4 +67,14 @@ export default defineComponent({
|
||||
--q-dark: #303133;
|
||||
--q-dark-page: #303133;
|
||||
}
|
||||
.commandLogo {
|
||||
cursor: pointer;
|
||||
transition: 0.2s;
|
||||
filter: drop-shadow(2px 1px 1px grey);
|
||||
}
|
||||
.commandLogo:hover {
|
||||
transition: 0.5s;
|
||||
transform: translateY(-5px);
|
||||
filter: drop-shadow(2px 1px 5px grey);
|
||||
}
|
||||
</style>
|
||||
|
@@ -145,10 +145,22 @@
|
||||
ref="editor"
|
||||
:style="{
|
||||
top: languageBarHeight + 'px',
|
||||
left: this.action.type === 'run' ? '0' : sideBarWidth + 'px',
|
||||
left: editorLeft,
|
||||
transition: '0.3s',
|
||||
}"
|
||||
/>
|
||||
<div
|
||||
class="absolute-bottom flex justify-center content-center"
|
||||
:style="{
|
||||
top: languageBarHeight + 'px',
|
||||
left: editorLeft,
|
||||
userSelect: 'none',
|
||||
}"
|
||||
>
|
||||
ctrl + s 保存 <br />
|
||||
ctrl + b 运行 <br />
|
||||
alt + z 自动换行
|
||||
</div>
|
||||
<!-- 运行结果 -->
|
||||
<CommandRunResult :action="action" ref="result"></CommandRunResult>
|
||||
</div>
|
||||
@@ -205,6 +217,9 @@ export default {
|
||||
"搜索结果"
|
||||
);
|
||||
},
|
||||
editorLeft() {
|
||||
return this.action.type === "run" ? "0" : this.sideBarWidth + "px";
|
||||
},
|
||||
},
|
||||
created() {},
|
||||
methods: {
|
||||
|
@@ -234,6 +234,7 @@
|
||||
</div>
|
||||
<iconPicker
|
||||
@iconChanged="(dataUrl) => (currentCommand.features.icon = dataUrl)"
|
||||
position="left"
|
||||
ref="icon"
|
||||
/>
|
||||
</q-scroll-area>
|
||||
@@ -395,15 +396,3 @@ export default {
|
||||
},
|
||||
};
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
.commandLogo {
|
||||
cursor: pointer;
|
||||
transition: 10s;
|
||||
filter: drop-shadow(2px 1px 1px grey);
|
||||
}
|
||||
.commandLogo:hover {
|
||||
transition: 10s;
|
||||
transform: rotate(1080deg);
|
||||
}
|
||||
</style>
|
||||
|
@@ -144,7 +144,7 @@
|
||||
</q-menu>
|
||||
</q-item>
|
||||
<!-- 收藏 -->
|
||||
<q-item v-if="isTagStared" clickable>
|
||||
<q-item v-if="isTagStared" clickable @click="unMarkTag">
|
||||
<q-item-section side>
|
||||
<q-icon name="star_border" />
|
||||
</q-item-section>
|
||||
@@ -176,7 +176,7 @@
|
||||
</q-dialog>
|
||||
<!-- 面板视图弹窗 -->
|
||||
<q-dialog v-model="showPanelConf">
|
||||
<PanelSetting :isTagStared="isTagStared" />
|
||||
<PanelSetting :isTagStared="isTagStared" :currentTag="currentTag" />
|
||||
</q-dialog>
|
||||
</q-menu>
|
||||
</template>
|
||||
@@ -218,6 +218,7 @@ export default {
|
||||
},
|
||||
props: {
|
||||
isTagStared: Boolean,
|
||||
currentTag: String,
|
||||
},
|
||||
methods: {
|
||||
// 导入命令且定位
|
||||
@@ -257,6 +258,13 @@ export default {
|
||||
this.$profile.backgroundImg = reset ? null : this.selectFile.path;
|
||||
this.configurationPage.$forceUpdate();
|
||||
},
|
||||
unMarkTag() {
|
||||
this.$utools.whole.removeFeature(
|
||||
`panel_${window.hexEncode(this.currentTag)}`
|
||||
);
|
||||
_.pull(this.$root.$refs.view.activatedQuickPanels, this.currentTag);
|
||||
quickcommand.showMessageBox("取消收藏成功");
|
||||
},
|
||||
},
|
||||
};
|
||||
</script>
|
||||
|
@@ -1,6 +1,6 @@
|
||||
<template>
|
||||
<div>
|
||||
<q-dialog v-model="showIconPicker" class="q-gutter" position="left">
|
||||
<q-dialog v-model="showIconPicker" class="q-gutter" :position="position">
|
||||
<q-card>
|
||||
<q-card-section class="text-h5 text-center">更改图标</q-card-section>
|
||||
<q-card-section>
|
||||
@@ -108,6 +108,9 @@ export default {
|
||||
dataUrl: null,
|
||||
};
|
||||
},
|
||||
props: {
|
||||
position: String,
|
||||
},
|
||||
methods: {
|
||||
setIcon(dataUrl) {
|
||||
this.dataUrl = dataUrl;
|
||||
|
@@ -1,26 +1,84 @@
|
||||
<template>
|
||||
<q-card>
|
||||
<q-card style="width: 400px">
|
||||
<q-card-section>
|
||||
<q-input dense label="名称" v-model="panelConf.name" />
|
||||
<q-input dense label="说明" v-model="panelConf.description" />
|
||||
<div class="row q-gutter-md">
|
||||
<div class="col-auto justify-center content-center flex q-pa-md">
|
||||
<q-avatar square class="commandLogo">
|
||||
<q-img
|
||||
:src="features.icon"
|
||||
@click="$refs.icon.showIconPicker = true"
|
||||
/></q-avatar>
|
||||
</div>
|
||||
<div class="col">
|
||||
<q-select
|
||||
hide-dropdown-icon
|
||||
label-color="primary"
|
||||
transition-show="jump-down"
|
||||
transition-hide="jump-up"
|
||||
v-model="features.cmds"
|
||||
max-values="3"
|
||||
type="text"
|
||||
placeholder="键入后回车"
|
||||
use-input
|
||||
use-chips
|
||||
multiple
|
||||
new-value-mode="add-unique"
|
||||
input-debounce="0"
|
||||
label="关键字"
|
||||
@blur="features.cmds.length || features.cmds.push(currentTag)"
|
||||
/>
|
||||
<q-input
|
||||
label-color="primary"
|
||||
v-model="features.explain"
|
||||
type="text"
|
||||
placeholder="请输入描述"
|
||||
label="描述"
|
||||
@blur="features.explain || (features.explain = ' ')"
|
||||
/>
|
||||
</div>
|
||||
</div>
|
||||
</q-card-section>
|
||||
<q-card-actions align="right">
|
||||
<q-btn flat label="取消" color="grey" v-close-popup />
|
||||
<q-btn flat label="禁用" color="negative" v-close-popup />
|
||||
<q-btn flat label="启用" color="primary" v-close-popup />
|
||||
<q-btn flat label="确定" color="primary" v-close-popup @click="markTag" />
|
||||
</q-card-actions>
|
||||
<IconPicker
|
||||
ref="icon"
|
||||
@iconChanged="(dataUrl) => (features.icon = dataUrl)"
|
||||
position="right"
|
||||
/>
|
||||
</q-card>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import IconPicker from "components/IconPicker";
|
||||
|
||||
export default {
|
||||
components: { IconPicker },
|
||||
data() {
|
||||
return {
|
||||
panelConf: {
|
||||
name: "",
|
||||
description: "",
|
||||
features: {
|
||||
explain: `进入${this.currentTag}的面板视图`,
|
||||
icon: "/logo.png",
|
||||
cmds: [this.currentTag],
|
||||
platform: ["win32", "darwin", "linux"],
|
||||
code: `panel_${window.hexEncode(this.currentTag)}`,
|
||||
},
|
||||
};
|
||||
},
|
||||
props: {
|
||||
currentTag: String,
|
||||
},
|
||||
methods: {
|
||||
markTag() {
|
||||
this.$utools.whole.setFeature(_.cloneDeep(this.features));
|
||||
this.$root.$refs.view.activatedQuickPanels.push(this.currentTag);
|
||||
quickcommand.showMessageBox(
|
||||
`主输入框输入『${this.features.cmds.join("、")}』即可直接进入『${
|
||||
this.currentTag
|
||||
}』的面板视图`
|
||||
);
|
||||
},
|
||||
},
|
||||
};
|
||||
</script>
|
||||
|
@@ -164,6 +164,7 @@
|
||||
><q-spinner-bars color="primary" size="1.5em" />
|
||||
<ConfigurationMenu
|
||||
:isTagStared="activatedQuickPanels.includes(currentTag)"
|
||||
:currentTag="currentTag"
|
||||
></ConfigurationMenu>
|
||||
</q-btn>
|
||||
</q-btn-group>
|
||||
@@ -313,6 +314,10 @@ export default {
|
||||
// 所有的快捷命令
|
||||
this.allQuickCommands = this.getAllQuickCommands();
|
||||
this.importDefaultCommands();
|
||||
if (this.$route.params.tags) {
|
||||
this.currentTag = window.hexDecode(this.$route.params.tags);
|
||||
this.commandCardStyle = "mini";
|
||||
}
|
||||
},
|
||||
importDefaultCommands() {
|
||||
for (var code of Object.keys(defaultCommands)) {
|
||||
@@ -327,7 +332,7 @@ export default {
|
||||
let quickpanels = [];
|
||||
features.forEach((x) =>
|
||||
x.code.slice(0, 6) == "panel_"
|
||||
? quickpanels.push(hexDecode(x.code.slice(6)))
|
||||
? quickpanels.push(window.hexDecode(x.code.slice(6)))
|
||||
: currentFts.push(x)
|
||||
);
|
||||
return {
|
||||
|
@@ -2,45 +2,45 @@ const routes = [{
|
||||
path: '/configuration',
|
||||
name: 'configuration',
|
||||
component: () =>
|
||||
import('pages/ConfigurationPage.vue')
|
||||
import ('pages/ConfigurationPage.vue')
|
||||
},
|
||||
{
|
||||
path: '/code',
|
||||
name: 'code',
|
||||
component: () =>
|
||||
import('pages/RunCodePage.vue')
|
||||
import ('pages/RunCodePage.vue')
|
||||
},
|
||||
{
|
||||
path: '/newcommand',
|
||||
component: () =>
|
||||
import('pages/NewCommand.vue')
|
||||
import ('pages/NewCommand.vue')
|
||||
},
|
||||
{
|
||||
path: '/:type(default|files|img|key|regex|window|professional)_:uid(\\w+)',
|
||||
name: 'command',
|
||||
component: () =>
|
||||
import('pages/CommandPage.vue')
|
||||
import ('pages/CommandPage.vue')
|
||||
},
|
||||
{
|
||||
path: '/panel_:tags(\\w+)',
|
||||
name: 'panel',
|
||||
component: () =>
|
||||
import('pages/ConfigurationPage.vue')
|
||||
import ('pages/ConfigurationPage.vue')
|
||||
},
|
||||
{
|
||||
path: '/needupdate',
|
||||
name: 'needupdate',
|
||||
props: true,
|
||||
component: () =>
|
||||
import('pages/updateWarningPage.vue')
|
||||
import ('pages/updateWarningPage.vue')
|
||||
},
|
||||
{
|
||||
path: '/loading',
|
||||
name: 'loading',
|
||||
component: () =>
|
||||
import('pages/LoadingPage.vue')
|
||||
import ('pages/LoadingPage.vue')
|
||||
}
|
||||
|
||||
]
|
||||
|
||||
export default routes
|
||||
export default routes
|
Reference in New Issue
Block a user