diff --git a/commons/data/languages.ts b/commons/data/languages.ts index 32b1b60..4b18aee 100644 --- a/commons/data/languages.ts +++ b/commons/data/languages.ts @@ -70,6 +70,8 @@ let simplifiedChinese = { colonKeywordSpace: "冒号 + 关键字 + 空格", color: "颜色", columnNumber: "列数", + commandLine: "命令行", + commandLinePrompt1: "使用“> + 空格”进入命令行模式。", commandPrompt: "命令提示符", computer: "计算机", computerManagement: "计算机管理", @@ -204,6 +206,7 @@ let simplifiedChinese = { password: "密码", pasteIcon: "粘贴图标", powerOptions: "电源选项", + powerShell: "PowerShell", programsFeatures: "程序和功能", proxy: "代理", proxyPrompt: @@ -371,6 +374,8 @@ let traditionalChinese = { colonKeywordSpace: "冒號 + 關鍵字 + 空格", color: "顏色", columnNumber: "列數", + commandLine: "命令行", + commandLinePrompt1: "使用「> + 空格」進入命令行模式。", commandPrompt: "命令提示符", computer: "計算機", computerManagement: "計算機管理", @@ -505,6 +510,7 @@ let traditionalChinese = { password: "密碼", pasteIcon: "粘貼圖標", powerOptions: "電源選項", + powerShell: "PowerShell", programsFeatures: "程序和功能", proxy: "代理", proxyPrompt: @@ -678,6 +684,8 @@ let english = { colonKeywordSpace: "Colon + Keyword + Space", color: "Color", columnNumber: "Column Number", + commandLine: "Command Line", + commandLinePrompt1: 'Use "> + space" to enter command line mode.', commandPrompt: "Command Prompt", computer: "Computer", computerManagement: "Computer Management", @@ -814,6 +822,7 @@ let english = { password: "Password", pasteIcon: "Paste Icon", powerOptions: "Power Options", + powerShell: "PowerShell", programsFeatures: "Programs Features", proxy: "Proxy", proxyPrompt: diff --git a/commons/utils/setting.ts b/commons/utils/setting.ts index 1848879..e0bf350 100644 --- a/commons/utils/setting.ts +++ b/commons/utils/setting.ts @@ -1,6 +1,7 @@ import { Appearance, Classification, + CommandLine, General, Item, Network, @@ -317,6 +318,20 @@ function getWebSearch({ }; } +/** + * 命令行 + * @returns + */ +function getCommandLine({ + defaultUse = "cmd", +}: { + defaultUse?: string | null; +}): CommandLine { + return { + defaultUse: defaultUse ?? "cmd", + }; +} + /** * 网络 * @returns @@ -377,6 +392,9 @@ function getSetting(setting: Setting | null): Setting { webSearch: getWebSearch( setting && setting.webSearch ? setting.webSearch : {} ), + commandLine: getCommandLine( + setting && setting.commandLine ? setting.commandLine : {} + ), network: getNetwork(setting && setting.network ? setting.network : {}), }; } diff --git a/electron/main/commons/ipcEvent.ts b/electron/main/commons/ipcEvent.ts index ee38d27..d0f35a3 100644 --- a/electron/main/commons/ipcEvent.ts +++ b/electron/main/commons/ipcEvent.ts @@ -163,4 +163,13 @@ export default function () { ipcMain.on("exit", () => { app.quit(); }); + // 运行 + ipcMain.on("run", (event, args) => { + global.addon.shellExecute( + args.operation, + args.target, + args.params ?? "", + app.getPath("home") + ); + }); } diff --git a/electron/main/search/index.ts b/electron/main/search/index.ts index 79cb52b..4c5acfe 100644 --- a/electron/main/search/index.ts +++ b/electron/main/search/index.ts @@ -24,7 +24,7 @@ function createQuickSearchWindow() { fullscreenable: false, resizable: false, alwaysOnTop: true, - backgroundColor: getMainBackgorunColor(), + backgroundColor: global.setting.appearance.theme.mainBackgroundColor, webPreferences: { spellcheck: false, backgroundThrottling: false, diff --git a/electron/preload/index.ts b/electron/preload/index.ts index 6c7d282..ef887f6 100644 --- a/electron/preload/index.ts +++ b/electron/preload/index.ts @@ -105,6 +105,15 @@ contextBridge.exposeInMainWorld("api", { exit: () => { ipcRenderer.send("exit"); }, + // 运行 + run: ( + operation: string, + target: string, + params: string | null, + startLocation: string | null + ) => { + ipcRenderer.send("run", { operation, target, params, startLocation }); + }, }); contextBridge.exposeInMainWorld("main", { diff --git a/package.json b/package.json index 82e7853..c4cde46 100644 --- a/package.json +++ b/package.json @@ -30,6 +30,7 @@ "devDependencies": { "@napi-rs/cli": "^2.16.3", "@vicons/material": "^0.12.0", + "@vicons/ionicons5": "^0.12.0", "@vicons/utils": "^0.1.4", "@vitejs/plugin-vue": "^4.4.0", "autoprefixer": "^10.4.16", @@ -70,4 +71,4 @@ "vue-router": "^4.2.5", "xml2js": "^0.6.2" } -} +} \ No newline at end of file diff --git a/src/components/KeyText.vue b/src/components/KeyText.vue new file mode 100644 index 0000000..0c183cb --- /dev/null +++ b/src/components/KeyText.vue @@ -0,0 +1,20 @@ + + diff --git a/src/index.d.ts b/src/index.d.ts index 97f820a..694d7d6 100644 --- a/src/index.d.ts +++ b/src/index.d.ts @@ -31,6 +31,12 @@ declare global { openURL: (url: string) => void; getVersion: () => string; exit: () => void; + run: ( + operation: string, + target: string, + params: string | null, + startLocation: string | null + ) => void; }; main: { showWindow: (blurHide: boolean) => void; diff --git a/src/pages/search/QuickSearch.vue b/src/pages/search/QuickSearch.vue index aa8712d..9387c1b 100644 --- a/src/pages/search/QuickSearch.vue +++ b/src/pages/search/QuickSearch.vue @@ -1,7 +1,6 @@ @@ -131,7 +150,15 @@ import "simplebar/dist/simplebar.css"; import CustomItemIcon from "../../components/CustomItemIcon.vue"; import { getClassElement, hexToRGBA } from "../../utils/style"; import { convert } from "../../../commons/utils/common"; -import { itemAllRemoveStyle, searchResultDivMoveScroll } from "./js/index"; +import { + itemAllRemoveStyle, + searchResultDivMoveScroll, + getCommandLineItemList, + commandLineRun as commonCommandLineRun, +} from "./js/index"; +import keyText from "../../components/KeyText.vue"; +import { Icon } from "@vicons/utils"; +import { SearchOutline, TerminalOutline } from "@vicons/ionicons5"; import { useMainStore } from "../../store"; // pinia const store = useMainStore(); @@ -142,7 +169,7 @@ let searchInput = ref(null); // 搜索内容 let value = ref(null); // 搜索模式 -let webSearch = ref(false); +let mode = ref<"search" | "webSearch" | "commandLine">("search"); // 搜索模式对应的实体 let webSearchSource = ref(null); // 选中的项 @@ -160,7 +187,8 @@ watch( ); // 搜索 function search() { - if (!webSearch.value) { + if (mode.value === "search") { + // 搜索模式 if (value.value) { showHistory.value = false; resultList.value = searchItem(value.value, searchMap, 50); @@ -178,21 +206,25 @@ function search() { // 获取历史记录 getHistory(); } - // 重置滚动条 - resetScroll(); - // 刷新DOM完毕执行 - nextTick(() => { - // 设置窗口高度 - let height = - !resultList.value || resultList.value.length === 0 - ? 0 - : resultList.value.length > 9 - ? 10 * 48 + 1 - : resultList.value.length * 48 + 1; - window.quickSearch.setWindowHeight(height + 44); - }); + refresh(); } } +// 刷新 +function refresh() { + // 重置滚动条 + resetScroll(); + // 刷新DOM完毕执行 + nextTick(() => { + // 设置窗口高度 + let height = + !resultList.value || resultList.value.length === 0 + ? 0 + : resultList.value.length > 9 + ? 10 * 48 + 1 + : resultList.value.length * 48 + 1; + window.quickSearch.setWindowHeight(height + 44); + }); +} /** * 重置滚动条 */ @@ -268,34 +300,34 @@ function getHistory() { resultList.value = []; showHistory.value = false; } - // 重置滚动条 - resetScroll(); - // 刷新DOM完毕执行 - nextTick(() => { - // 设置窗口高度 - let height = - !resultList.value || resultList.value.length === 0 - ? 0 - : resultList.value.length > 9 - ? 10 * 48 + 1 - : resultList.value.length * 48 + 1; - window.quickSearch.setWindowHeight(height + 44); - }); + refresh(); } // 父级运行项目 function parentRunItem(e: any) { // 找到item let itemElement = getClassElement(e, "item"); if (itemElement) { - // 项目ID - let itemId = parseInt(itemElement.getAttribute("item-id")); - // 查询项目 - let item = getItemById(itemId); - if (item && item.data) { - runItem(item); + if (mode.value === "search") { + // 项目ID + let itemId = parseInt(itemElement.getAttribute("item-id")); + // 查询项目 + let item = getItemById(itemId); + if (item && item.data) { + runItem(item); + } + } else if (mode.value === "commandLine") { + // 目标 + commandLineRun(itemElement.getAttribute("target")); } } } +// 命令行运行 +function commandLineRun(target: string) { + if (store.setting.quickSearch.openAfterHideQuickSearchWindow) { + hide(); + } + commonCommandLineRun(target, value.value); +} // 运行项目 function runItem(item: Item) { if (store.setting.quickSearch.openAfterHideQuickSearchWindow) { @@ -303,6 +335,21 @@ function runItem(item: Item) { } run("quickSearch", "open", item); } +// 获取placeholder +function getPlaceholder() { + let text = "Dawn Launcher"; + if ( + mode.value === "webSearch" && + webSearchSource.value && + webSearchSource.value.description && + webSearchSource.value.description.trim() !== "" + ) { + text = webSearchSource.value.description.trim(); + } else if (mode.value === "commandLine") { + text = "Command Line"; + } + return text; +} // 隐藏窗口 function hide() { window.quickSearch.hideWindow(); @@ -311,33 +358,35 @@ function hide() { function contextmenu(e: any) { e.preventDefault(); e.stopPropagation(); - // 当前项目 - let item: Item | null = null; - // 判断是在哪个区域右键 - if (getClassElement(e, "item")) { - // 项目右键 - // 获取项目ID - let element = getClassElement(e, "item"); - // 项目ID - let id = parseInt(element.getAttribute("item-id")); - // 获取项目 - item = convert(getItemById(id)); - } - if (item) { - // 弹出菜单 - store.quickSearchItemRightMenuItemId = item.id; - window.item.showRightMenu({ - item, - x: e.screenX, - y: e.screenY, - type: "quickSearch", - }); + if (mode.value === "search") { + // 当前项目 + let item: Item | null = null; + // 判断是在哪个区域右键 + if (getClassElement(e, "item")) { + // 项目右键 + // 获取项目ID + let element = getClassElement(e, "item"); + // 项目ID + let id = parseInt(element.getAttribute("item-id")); + // 获取项目 + item = convert(getItemById(id)); + } + if (item) { + // 弹出菜单 + store.quickSearchItemRightMenuItemId = item.id; + window.item.showRightMenu({ + item, + x: e.screenX, + y: e.screenY, + type: "quickSearch", + }); + } } } // dragover function dragover(e: any) { // 从程序外拖动文件到项目图标上时用此项目打开文件 - if (store.setting.quickSearch.useItemOpen) { + if (mode.value === "search" && store.setting.quickSearch.useItemOpen) { // 选中效果 let target = findElement(e.target, "item"); // 取消选中效果 @@ -363,40 +412,42 @@ function dragover(e: any) { } // drop function drop(e: any) { - // 尝试获取项目 - let item: Item | null = null; - let itemElement = findElement(e.target, "item"); - if (itemElement) { - let id = itemElement.getAttribute("item-id"); - if (id) { - item = getItemById(parseInt(id)); - } - } - // 获取文件列表 - let pathList = []; - for (const file of e.dataTransfer.files) { - pathList.push(file.path); - } - // 从程序外拖动文件到项目图标上时用此项目打开文件 - if (store.setting.quickSearch.useItemOpen && item && pathList.length > 0) { - // 如果相同路径则不打开 - if (pathList.length === 1 && pathList[0] === item.data.target) { - return; - } - let params = ""; - for (let i = 0; i < pathList.length; i++) { - if (i > 0) { - params += " "; + if (mode.value === "search") { + // 尝试获取项目 + let item: Item | null = null; + let itemElement = findElement(e.target, "item"); + if (itemElement) { + let id = itemElement.getAttribute("item-id"); + if (id) { + item = getItemById(parseInt(id)); } - params += '"' + pathList[i] + '"'; } - if (item.data.params) { - params += " " + item.data.params; + // 获取文件列表 + let pathList = []; + for (const file of e.dataTransfer.files) { + pathList.push(file.path); + } + // 从程序外拖动文件到项目图标上时用此项目打开文件 + if (store.setting.quickSearch.useItemOpen && item && pathList.length > 0) { + // 如果相同路径则不打开 + if (pathList.length === 1 && pathList[0] === item.data.target) { + return; + } + let params = ""; + for (let i = 0; i < pathList.length; i++) { + if (i > 0) { + params += " "; + } + params += '"' + pathList[i] + '"'; + } + if (item.data.params) { + params += " " + item.data.params; + } + let copyItem: Item = convert(item); + copyItem.data.params = params; + // 运行 + runItem(copyItem); } - let copyItem: Item = convert(item); - copyItem.data.params = params; - // 运行 - runItem(copyItem); } e.preventDefault(); e.stopPropagation(); @@ -430,7 +481,7 @@ function keydown(e: any) { } // 空格 if (e.keyCode === 32) { - if (!webSearch.value) { + if (mode.value !== "webSearch") { // 判断是否是搜索引擎 if (value.value && value.value.trim() !== "") { let flag = false; @@ -448,7 +499,7 @@ function keydown(e: any) { : value.value; for (let searchSource of store.setting.webSearch.searchSourceList) { if (keyword === searchSource.keyword) { - webSearch.value = true; + mode.value = "webSearch"; webSearchSource.value = searchSource; value.value = null; resultList.value = []; @@ -461,32 +512,57 @@ function keydown(e: any) { } } } + if (mode.value !== "webSearch" && mode.value !== "commandLine") { + // 判断是否是命令行 + if (value.value && value.value.trim() !== "") { + if (value.value === ">") { + mode.value = "commandLine"; + value.value = null; + resultList.value = getCommandLineItemList(); + selected.value = 0; + refresh(); + e.stopPropagation(); + e.preventDefault(); + } + } + } } // enter if (e.keyCode === 13) { - if (webSearch.value && webSearchSource.value) { + if (mode.value === "webSearch" && webSearchSource.value) { let url = webSearchSource.value.url.replace("{w}", value.value ?? ""); window.api.openURL(url); if (store.setting.quickSearch.openAfterHideQuickSearchWindow) { hide(); } } else if ( - !webSearch.value && + mode.value === "search" && resultList.value.length - 1 >= selected.value ) { runItem(resultList.value[selected.value] as Item); + } else if ( + mode.value === "commandLine" && + resultList.value.length - 1 >= selected.value + ) { + commandLineRun(resultList.value[selected.value].data.target!); } e.stopPropagation(); e.preventDefault(); } // 退格键 if (e.keyCode === 8) { - if (webSearch.value) { + if (mode.value === "webSearch") { if (!value.value || value.value.trim() === "") { - webSearch.value = false; + mode.value = "search"; webSearchSource.value = null; window.quickSearch.setWindowHeight(44); } + } else if (mode.value === "commandLine") { + if (!value.value || value.value.trim() === "") { + mode.value = "search"; + resultList.value = []; + window.quickSearch.setWindowHeight(44); + } } } if (showHistory.value) { @@ -547,7 +623,11 @@ function keydown(e: any) { index = e.key - 1; } if (resultList.value && index < resultList.value.length) { - runItem(resultList.value[index] as Item); + if (mode.value === "search") { + runItem(resultList.value[index] as Item); + } else if (mode.value === "commandLine") { + commandLineRun(resultList.value[index].data.target!); + } e.stopPropagation(); e.preventDefault(); } @@ -606,7 +686,7 @@ onMounted(() => { value.value = null; resultList.value = []; selected.value = 0; - webSearch.value = false; + mode.value = "search"; webSearchSource.value = null; }) ); diff --git a/src/pages/search/components/Search.vue b/src/pages/search/components/Search.vue index 8c31be6..eed2879 100644 --- a/src/pages/search/components/Search.vue +++ b/src/pages/search/components/Search.vue @@ -18,20 +18,17 @@ }" >
- + + + + + + {{ webSearchSource.name }} - - - {{ - webSearchSource.name - }}
{{ getName(item.name) - }}{{ + }}{{ getSearchItemClassificationName((item as Item).classificationId) }} @@ -130,14 +121,20 @@ import { WebSearchSource } from "../../../../types/setting"; import { convert } from "../../../../commons/utils/common"; import "simplebar"; import "simplebar/dist/simplebar.css"; -import { itemAllRemoveStyle, searchResultDivMoveScroll } from "../js/index"; +import { + getCommandLineItemList, + itemAllRemoveStyle, + searchResultDivMoveScroll, + commandLineRun, +} from "../js/index"; +import { SearchOutline, TerminalOutline } from "@vicons/ionicons5"; import { useMainStore } from "../../../store"; // pinia const store = useMainStore(); // 搜索框 let searchInput = ref(null); // 搜索模式 -let webSearch = ref(false); +let mode = ref<"search" | "webSearch" | "commandLine">("search"); // 搜索模式对应的实体 let webSearchSource = ref(null); // 搜索内容 @@ -162,7 +159,7 @@ watch( ); // 搜索 function search() { - if (!webSearch.value) { + if (mode.value === "search") { if (value.value) { resultList.value = searchItem(value.value, searchMap, 50); if (resultList.value && resultList.value.length > 0) { @@ -190,16 +187,37 @@ function runItem(e: any) { // 找到item let itemElement = getClassElement(e, "search-result-item"); if (itemElement) { - // 项目ID - let itemId = parseInt(itemElement.getAttribute("item-id")); - // 查询项目 - let item = getItemById(itemId); - if (item && item.data) { - run("search", "open", item); + if (mode.value === "search") { + // 项目ID + let itemId = parseInt(itemElement.getAttribute("item-id")); + // 查询项目 + let item = getItemById(itemId); + if (item && item.data) { + run("search", "open", item); + close(); + } + } else if (mode.value === "commandLine") { + // 目标 + commandLineRun(itemElement.getAttribute("target"), value.value); close(); } } } +// 获取placeholder +function getPlaceholder() { + let text = store.language.search; + if ( + mode.value === "webSearch" && + webSearchSource.value && + webSearchSource.value.description && + webSearchSource.value.description.trim() !== "" + ) { + text = webSearchSource.value.description.trim(); + } else if (mode.value === "commandLine") { + text = "Command Line"; + } + return text; +} // 关闭 function close() { store.search = false; @@ -217,27 +235,29 @@ watch( function contextmenu(e: any) { e.preventDefault(); e.stopPropagation(); - // 当前项目 - let item: Item | null = null; - // 判断是在哪个区域右键 - if (getClassElement(e, "search-result-item")) { - // 项目右键 - // 获取项目ID - let element = getClassElement(e, "search-result-item"); - // 项目ID - let id = parseInt(element.getAttribute("item-id")); - // 获取项目 - item = convert(getItemById(id)); - } - if (item) { - // 弹出菜单 - store.searchItemRightMenuItemId = item.id; - window.item.showRightMenu({ - item, - x: e.screenX, - y: e.screenY, - type: "search", - }); + if (mode.value === "search") { + // 当前项目 + let item: Item | null = null; + // 判断是在哪个区域右键 + if (getClassElement(e, "search-result-item")) { + // 项目右键 + // 获取项目ID + let element = getClassElement(e, "search-result-item"); + // 项目ID + let id = parseInt(element.getAttribute("item-id")); + // 获取项目 + item = convert(getItemById(id)); + } + if (item) { + // 弹出菜单 + store.searchItemRightMenuItemId = item.id; + window.item.showRightMenu({ + item, + x: e.screenX, + y: e.screenY, + type: "search", + }); + } } } function keydown(e: any) { @@ -275,7 +295,7 @@ function keydown(e: any) { } // 空格 if (e.keyCode === 32) { - if (!webSearch.value) { + if (mode.value === "search") { // 判断是否是搜索引擎 if (value.value && value.value.trim() !== "") { let flag = false; @@ -293,7 +313,7 @@ function keydown(e: any) { : value.value; for (let searchSource of store.setting.webSearch.searchSourceList) { if (keyword === searchSource.keyword) { - webSearch.value = true; + mode.value = "webSearch"; webSearchSource.value = searchSource; value.value = null; resultList.value = []; @@ -304,29 +324,55 @@ function keydown(e: any) { } } } + if (mode.value !== "webSearch" && mode.value !== "commandLine") { + // 判断是否是命令行 + if (value.value && value.value.trim() !== "") { + if (value.value === ">") { + mode.value = "commandLine"; + value.value = null; + resultList.value = getCommandLineItemList(); + selected.value = 0; + e.preventDefault(); + } + } + } } // enter if (e.keyCode === 13) { - if (webSearch.value && webSearchSource.value) { + if (mode.value === "webSearch" && webSearchSource.value) { let url = webSearchSource.value.url.replace("{w}", value.value ?? ""); window.api.openURL(url); close(); } else if ( - !webSearch.value && + mode.value === "search" && resultList.value.length - 1 >= selected.value ) { run("search", "open", resultList.value[selected.value] as Item); close(); + } else if ( + mode.value === "commandLine" && + resultList.value.length - 1 >= selected.value + ) { + commandLineRun( + resultList.value[selected.value].data.target!, + value.value + ); + close(); } e.preventDefault(); } // 退格键 if (e.keyCode === 8) { - if (webSearch.value) { + if (mode.value === "webSearch") { if (!value.value || value.value.trim() === "") { - webSearch.value = false; + mode.value = "search"; webSearchSource.value = null; } + } else if (mode.value === "commandLine") { + if (!value.value || value.value.trim() === "") { + mode.value = "search"; + resultList.value = []; + } } } } diff --git a/src/pages/search/js/index.ts b/src/pages/search/js/index.ts index c249006..8eb95cc 100644 --- a/src/pages/search/js/index.ts +++ b/src/pages/search/js/index.ts @@ -1,4 +1,13 @@ +import { newItem, newItemData } from "../../../../commons/utils/common"; import { itemRemoveStyle } from "../../item/js"; +import { useMainStore } from "../../../store"; +// pinia +const store = useMainStore(); + +let cmdIcon = + ""; +let powerShellIcon = + ""; /** * 删除所有选中项目样式 @@ -48,4 +57,48 @@ function searchResultDivMoveScroll( } } -export { itemAllRemoveStyle, searchResultDivMoveScroll }; +/** + * 获取命令行项目 + */ +function getCommandLineItemList() { + let cmdItem = newItem({ + classificationId: 99999, + name: store.language.commandPrompt, + data: newItemData({ + icon: cmdIcon, + target: "cmd", + }), + }); + let powerShellItem = newItem({ + classificationId: 99999, + name: store.language.powerShell, + data: newItemData({ + icon: powerShellIcon, + target: "powershell", + }), + }); + if (store.setting.commandLine.defaultUse === "cmd") { + return [cmdItem, powerShellItem]; + } else { + return [powerShellItem, cmdItem]; + } +} + +// 命令行运行 +function commandLineRun(target: string, text: string | null) { + let params = ""; + let val = text ?? ""; + if (target === "cmd") { + params = '/k "' + val + '"'; + } else { + params = '-NoExit "' + val + '"'; + } + window.api.run("open", target, params, null); +} + +export { + itemAllRemoveStyle, + searchResultDivMoveScroll, + getCommandLineItemList, + commandLineRun, +}; diff --git a/src/pages/setting/Index.vue b/src/pages/setting/Index.vue index 34dcd0e..9dfe099 100644 --- a/src/pages/setting/Index.vue +++ b/src/pages/setting/Index.vue @@ -1401,6 +1401,24 @@
+ + {{ + store.language.default + }} + + + + + +
+
{{ store.language.proxy @@ -1550,6 +1568,10 @@ let menuList = [ }, { id: 7, + label: store.language.commandLine, + }, + { + id: 8, label: store.language.network, }, ]; @@ -2213,6 +2235,17 @@ function closeSaveSearchSource() { searchSourceURL.value = null; searchSourceDescription.value = null; } +// 命令行默认使用 +let commandLineDefultUseOptions = ref([ + { + label: store.language.commandPrompt, + value: "cmd", + }, + { + label: store.language.powerShell, + value: "powershell", + }, +]); // 页面高度 let height = ref(0); // 初始化页面尺寸 diff --git a/types/setting.d.ts b/types/setting.d.ts index 7a998bb..ce13280 100644 --- a/types/setting.d.ts +++ b/types/setting.d.ts @@ -190,6 +190,12 @@ export interface WebSearch { searchSourceList: Array; } +// 命令行 +export interface CommandLine { + // 默认使用 + defaultUse: string; +} + // 网络搜索源 export interface WebSearchSource { // ID @@ -238,6 +244,8 @@ export interface Setting { quickSearch: QuickSearch; // 网络搜索 webSearch: WebSearch; + // 命令行 + commandLine: CommandLine; // 网络 network: Network; } diff --git a/yarn.lock b/yarn.lock index 856fe41..4d526ba 100644 --- a/yarn.lock +++ b/yarn.lock @@ -475,6 +475,11 @@ dependencies: "@types/node" "*" +"@vicons/ionicons5@^0.12.0": + version "0.12.0" + resolved "https://registry.npmmirror.com/@vicons/ionicons5/-/ionicons5-0.12.0.tgz#c39fda04420dfae3b58053faf8aaf3555253299d" + integrity sha512-Iy1EUVRpX0WWxeu1VIReR1zsZLMc4fqpt223czR+Rpnrwu7pt46nbnC2ycO7ItI/uqDLJxnbcMC7FujKs9IfFA== + "@vicons/material@^0.12.0": version "0.12.0" resolved "https://registry.npmmirror.com/@vicons/material/-/material-0.12.0.tgz#068e72fa40bd7f780af5fc68011fb69010c8e0b5"