diff --git a/README.md b/README.md index 74fa723..ad0215b 100644 --- a/README.md +++ b/README.md @@ -1,15 +1,16 @@ [中文](README_zh_CN.md) +- SM.MS # PicGo Plugin ![](./preview.png) Your favorite PicGo image bed is still available in siyuan-notes, wuhu~ -> Important Note: -> -> Please refrain from updating this plugin for versions of siyuan-note prior to `3.0.3`; the highest permissible version remains `1.5.1`. For siyuan-note versions `3.0.3` and beyond, the PicGO plugin may be upgraded to `1.6.0+`. -> +> Important Note: +> +> Please refrain from updating this plugin for versions of siyuan-note prior to `3.0.3`; the highest permissible version remains `1.5.1`. For siyuan-note versions `3.0.3` and beyond, the PicGO plugin may be upgraded to `1.6.0+`. +> > For versions of siyuan-note before `2.10.8`, it is advised not to upgrade this plugin beyond version `1.4.5`. Subsequent to siyuan-note `2.10.8`, the PicGO plugin can be updated to `1.5.0+`. ## Image Hosting Support @@ -20,7 +21,6 @@ Your favorite PicGo image bed is still available in siyuan-notes, wuhu~ - Tencent Cloud - Upyun - Qiniu Cloud -- SM.MS - imgur ## Changelog diff --git a/libs/Universal-PicGo-Core/custom.d.ts b/libs/Universal-PicGo-Core/custom.d.ts index ca22c44..2483ad3 100644 --- a/libs/Universal-PicGo-Core/custom.d.ts +++ b/libs/Universal-PicGo-Core/custom.d.ts @@ -3,6 +3,9 @@ declare module '*.json' { export default value } +declare module '*raw' + declare module "ali-oss" declare module "arraybuffer-to-buffer" -declare module "upyun" \ No newline at end of file +declare module "upyun" +declare module "js-yaml" \ No newline at end of file diff --git a/libs/zhi-siyuan-picgo/package.json b/libs/zhi-siyuan-picgo/package.json index 20b3be9..3847453 100644 --- a/libs/zhi-siyuan-picgo/package.json +++ b/libs/zhi-siyuan-picgo/package.json @@ -36,7 +36,7 @@ "zhi-common": "^1.33.0", "zhi-device": "^2.11.0", "zhi-lib-base": "^0.8.0", - "zhi-siyuan-api": "^2.19.1" + "zhi-siyuan-api": "^2.20.0" }, "publishConfig": { "access": "public" diff --git a/libs/zhi-siyuan-picgo/src/index.ts b/libs/zhi-siyuan-picgo/src/index.ts index 511ddca..36a2514 100644 --- a/libs/zhi-siyuan-picgo/src/index.ts +++ b/libs/zhi-siyuan-picgo/src/index.ts @@ -29,9 +29,10 @@ import { copyToClipboardInBrowser, generateUniqueName } from "./lib/utils/utils" import { ImageItem } from "./lib/models/ImageItem" import { ImageParser } from "./lib/parser/ImageParser" import { ParsedImage } from "./lib/models/ParsedImage" +import { SIYUAN_PICGO_FILE_MAP_KEY } from "./lib/constants" export { SiyuanPicGo, SiyuanPicgoConfig, SiyuanPicgoPostApi, PicgoHelper } -export { ImageItem, ImageParser, ParsedImage } +export { ImageItem, ImageParser, ParsedImage, SIYUAN_PICGO_FILE_MAP_KEY } export { retrieveImageFromClipboardAsBlob, copyToClipboardInBrowser, calculateMD5, generateUniqueName } export { ConfigDb, PluginLoaderDb, ExternalPicgoConfigDb } export { PicgoTypeEnum } diff --git a/libs/zhi-siyuan-picgo/src/lib/siyuanPicgoPostApi.ts b/libs/zhi-siyuan-picgo/src/lib/siyuanPicgoPostApi.ts index 8a0a5a9..b2c8b0f 100644 --- a/libs/zhi-siyuan-picgo/src/lib/siyuanPicgoPostApi.ts +++ b/libs/zhi-siyuan-picgo/src/lib/siyuanPicgoPostApi.ts @@ -9,7 +9,7 @@ import { ILogger, simpleLogger } from "zhi-lib-base" import { SiyuanPicGoUploadApi } from "./siyuanPicGoUploadApi" -import { hasNodeEnv, IPicGo, isFileOrBlob, win } from "universal-picgo" +import { hasNodeEnv, IImgInfo, IPicGo, isFileOrBlob, win } from "universal-picgo" import { ParsedImage } from "./models/ParsedImage" import { ImageItem } from "./models/ImageItem" import { SIYUAN_PICGO_FILE_MAP_KEY } from "./constants" @@ -18,7 +18,6 @@ import { SiyuanConfig, SiyuanKernelApi } from "zhi-siyuan-api" import { ImageParser } from "./parser/ImageParser" import { PicgoPostResult } from "./models/PicgoPostResult" import { DeviceDetection, DeviceTypeEnum, SiyuanDevice } from "zhi-device" -import { IImgInfo } from "universal-picgo/src" /** * Picgo与文章交互的通用方法 diff --git a/package.json b/package.json index 37c59de..5b98dd3 100644 --- a/package.json +++ b/package.json @@ -3,6 +3,7 @@ "version": "1.6.0", "description": "picgo plugin for siyuan-note", "scripts": { + "clean": "./scripts/clean.sh", "serve": "turbo run serve", "dev": "turbo run dev", "build": "turbo run build", diff --git a/packages/picgo-plugin-app/package.json b/packages/picgo-plugin-app/package.json index 7792c5b..166995d 100644 --- a/packages/picgo-plugin-app/package.json +++ b/packages/picgo-plugin-app/package.json @@ -36,7 +36,7 @@ "zhi-common": "^1.33.0", "zhi-device": "^2.11.0", "zhi-lib-base": "^0.8.0", - "zhi-siyuan-api": "^2.19.1", + "zhi-siyuan-api": "^2.20.0", "zhi-siyuan-picgo": "workspace:*" } } \ No newline at end of file diff --git a/packages/picgo-plugin-app/src/components/setting/PicgoSetting.vue b/packages/picgo-plugin-app/src/components/setting/PicgoSetting.vue index befd2ba..8614bb8 100644 --- a/packages/picgo-plugin-app/src/components/setting/PicgoSetting.vue +++ b/packages/picgo-plugin-app/src/components/setting/PicgoSetting.vue @@ -9,7 +9,7 @@ diff --git a/packages/picgo-plugin-app/src/components/setting/picgo/bundled/PicbedSetting.vue b/packages/picgo-plugin-app/src/components/setting/picgo/bundled/PicbedSetting.vue index 0da239f..36466cf 100644 --- a/packages/picgo-plugin-app/src/components/setting/picgo/bundled/PicbedSetting.vue +++ b/packages/picgo-plugin-app/src/components/setting/picgo/bundled/PicbedSetting.vue @@ -22,12 +22,12 @@ const { t } = useVueI18n() const props = defineProps({ ctx: { type: Object, - default: null + default: null, }, cfg: { type: Object, - default: null - } + default: null, + }, }) const formData = reactive({ @@ -50,13 +50,13 @@ const formData = reactive({ // 当前配置项表单 curFormPropertiesConfig: {} as IStringKeyMap, // 表单配置项ID - curFormConfigId: "" as string | undefined + curFormConfigId: "" as string | undefined, }, // 表单展示 isNewForm: false, showConfigForm: false, - configFormTitle: "" + configFormTitle: "", }) // PicGo 持久化操作帮助类 const picgoHelper = new PicgoHelper(props.ctx, formData.cfg) @@ -152,7 +152,7 @@ function deleteConfig(config: IUploaderConfigListItem) { ElMessageBox.confirm(`确认删除配置 ${config._configName} 吗?`, t("main.opt.warning"), { confirmButtonText: t("main.opt.ok"), cancelButtonText: t("main.opt.cancel"), - type: "warning" + type: "warning", }) .then(async () => { try { @@ -162,12 +162,11 @@ function deleteConfig(config: IUploaderConfigListItem) { } catch (e) { ElMessage({ type: "error", - message: t("main.opt.failure") + "=>" + e + message: t("main.opt.failure") + "=>" + e, }) } }) - .catch(() => { - }) + .catch(() => {}) } /** @@ -238,7 +237,7 @@ onBeforeMount(() => { :key="item.type" :type="selectedPicbedStyle(item.type)" @click="handlePicBedTypeChange(item)" - >{{ item.name }} + >{{ item.name }} @@ -343,6 +342,10 @@ onBeforeMount(() => { margin-top: 10px; } +.picbed-group + button + margin-bottom 10px + .profile-card-item { display: inline-block; margin-right: 10px; diff --git a/packages/picgo-plugin-app/src/components/test/BrowserTest.vue b/packages/picgo-plugin-app/src/components/test/BrowserTest.vue index 36d9bb0..e2bfde8 100644 --- a/packages/picgo-plugin-app/src/components/test/BrowserTest.vue +++ b/packages/picgo-plugin-app/src/components/test/BrowserTest.vue @@ -19,7 +19,7 @@ const handleTest2 = async () => { const picgo = await SiyuanPicGoClient.getInstance() logger.debug("picgo =>", picgo) - const result = await picgo.upload(["https://s2.loli.net/2024/03/20/VDRXZnkBaKWFhpt.png"]) + const result = await picgo.originalUpload(["https://s2.loli.net/2024/03/20/VDRXZnkBaKWFhpt.png"]) logger.info("upload success =>", result) ElMessage.success("upload success") } catch (e: any) { @@ -34,7 +34,7 @@ const handleTest5 = async () => { logger.debug("picgo =>", picgo) const imgBase64 = `` - const result = await picgo.upload([imgBase64]) + const result = await picgo.originalUpload([imgBase64]) logger.info("upload success =>", result) ElMessage.success("upload success") } catch (e: any) { diff --git a/packages/picgo-plugin-app/src/components/test/ElectronTest.vue b/packages/picgo-plugin-app/src/components/test/ElectronTest.vue index dce852d..916d733 100644 --- a/packages/picgo-plugin-app/src/components/test/ElectronTest.vue +++ b/packages/picgo-plugin-app/src/components/test/ElectronTest.vue @@ -24,7 +24,7 @@ const handleTest = async () => { const picgo = await SiyuanPicGoClient.getInstance() logger.debug("picgo =>", picgo) - const result = await picgo.upload() + const result = await picgo.originalUpload() logger.info("upload success =>", result) ElMessage.success("upload success") } catch (e: any) { @@ -38,7 +38,7 @@ const handleTest2 = async () => { const picgo = await SiyuanPicGoClient.getInstance() logger.debug("picgo =>", picgo) - const result = await picgo.upload(["https://s2.loli.net/2024/03/20/VDRXZnkBaKWFhpt.png"]) + const result = await picgo.originalUpload(["https://s2.loli.net/2024/03/20/VDRXZnkBaKWFhpt.png"]) logger.info("upload success =>", result) ElMessage.success("upload success") } catch (e: any) { @@ -52,7 +52,7 @@ const handleTest3 = async () => { const picgo = await SiyuanPicGoClient.getInstance() logger.debug("picgo =>", picgo) - const result = await picgo.upload(["/Users/terwer/Documents/pictures/photo.jpg"]) + const result = await picgo.originalUpload(["/Users/terwer/Documents/pictures/photo.jpg"]) logger.info("upload success =>", result) ElMessage.success("upload success") } catch (e: any) { @@ -73,7 +73,7 @@ const handleTest4 = async () => { const picgo = await SiyuanPicGoClient.getInstance() logger.debug("picgo =>", picgo) - const result = await picgo.upload([paramFile.value]) + const result = await picgo.originalUpload([paramFile.value]) logger.info("upload success =>", result) ElMessage.success("upload success") } catch (e: any) { @@ -88,7 +88,7 @@ const handleTest5 = async () => { logger.debug("picgo =>", picgo) const imgBase64 = `` - const result = await picgo.upload([imgBase64]) + const result = await picgo.originalUpload([imgBase64]) logger.info("upload success =>", result) ElMessage.success("upload success") } catch (e: any) { diff --git a/packages/picgo-plugin-app/src/composables/usePicgoCommon.ts b/packages/picgo-plugin-app/src/composables/usePicgoCommon.ts index 8d8c57e..835148b 100644 --- a/packages/picgo-plugin-app/src/composables/usePicgoCommon.ts +++ b/packages/picgo-plugin-app/src/composables/usePicgoCommon.ts @@ -10,7 +10,7 @@ import { useSiyuanDevice } from "$composables/useSiyuanDevice.ts" import { reactive } from "vue" import { isDev } from "@/utils/Constants.ts" -import { ImageItem } from "zhi-siyuan-picgo/src/lib/models/ImageItem.ts" +import { ImageItem } from "zhi-siyuan-picgo" /** * Picgo公共组件 diff --git a/packages/picgo-plugin-app/src/composables/usePicgoManage.ts b/packages/picgo-plugin-app/src/composables/usePicgoManage.ts index ac8579b..4b7ee14 100644 --- a/packages/picgo-plugin-app/src/composables/usePicgoManage.ts +++ b/packages/picgo-plugin-app/src/composables/usePicgoManage.ts @@ -12,7 +12,7 @@ import { useSiyuanApi } from "$composables/useSiyuanApi.ts" import { createAppLogger } from "@/utils/appLogger.ts" import { reactive } from "vue" import { ElMessage, ElMessageBox } from "element-plus" -import { ImageItem } from "zhi-siyuan-picgo/src/lib/models/ImageItem.ts" +import { ImageItem } from "zhi-siyuan-picgo" import { SiyuanPicGoClient } from "@/utils/SiyuanPicGoClient.ts" /** @@ -30,7 +30,7 @@ export const usePicgoManage = (props: any, deps: any) => { // public data const picgoManageData = reactive({ dialogImageUrl: "", - dialogPreviewVisible: false, + dialogPreviewVisible: false }) // deps @@ -86,7 +86,7 @@ export const usePicgoManage = (props: any, deps: any) => { ElMessageBox.confirm("已经是远程图片,是否仍然覆盖上传?", t("main.opt.warning"), { confirmButtonText: t("main.opt.ok"), cancelButtonText: t("main.opt.cancel"), - type: "warning", + type: "warning" }) .then(async () => { try { @@ -100,7 +100,7 @@ export const usePicgoManage = (props: any, deps: any) => { ElMessage({ type: "error", - message: t("main.opt.failure") + "=>" + e, + message: t("main.opt.failure") + "=>" + e }) logger.error(t("main.opt.failure") + "=>" + e) } @@ -111,7 +111,7 @@ export const usePicgoManage = (props: any, deps: any) => { if (e.toString().indexOf("cancel") <= -1) { ElMessage({ type: "error", - message: t("main.opt.failure") + ",图片上传异常=>" + e, + message: t("main.opt.failure") + ",图片上传异常=>" + e }) logger.error(t("main.opt.failure") + "=>" + e) } @@ -127,7 +127,7 @@ export const usePicgoManage = (props: any, deps: any) => { ElMessage({ type: "error", - message: t("main.opt.failure") + "=>" + e, + message: t("main.opt.failure") + "=>" + e }) logger.error(t("main.opt.failure") + "=>" + e) } @@ -156,11 +156,11 @@ export const usePicgoManage = (props: any, deps: any) => { handlePictureCardPreview: (url: string) => { picgoManageData.dialogImageUrl = url ?? "" picgoManageData.dialogPreviewVisible = true - }, + } } return { picgoManageData, - picgoManageMethods, + picgoManageMethods } } diff --git a/packages/picgo-plugin-app/src/composables/usePicgoUpload.ts b/packages/picgo-plugin-app/src/composables/usePicgoUpload.ts index 9d2e1a3..91de3db 100644 --- a/packages/picgo-plugin-app/src/composables/usePicgoUpload.ts +++ b/packages/picgo-plugin-app/src/composables/usePicgoUpload.ts @@ -11,12 +11,11 @@ import { useRouter } from "vue-router" import { createAppLogger } from "@/utils/appLogger.ts" import { useVueI18n } from "$composables/useVueI18n.ts" import { reactive } from "vue" -import { ImageItem } from "zhi-siyuan-picgo" +import { generateUniqueName, ImageItem } from "zhi-siyuan-picgo" import { ElMessage } from "element-plus" import { useSiyuanApi } from "$composables/useSiyuanApi.ts" import { StrUtil } from "zhi-common" import { SiyuanPicGoClient } from "@/utils/SiyuanPicGoClient.ts" -import { generateUniqueName } from "zhi-siyuan-picgo/src" /** * Picgo上传组件 diff --git a/packages/picgo-plugin-app/src/i18n/en_US.ts b/packages/picgo-plugin-app/src/i18n/en_US.ts index 60f71fe..6db602d 100644 --- a/packages/picgo-plugin-app/src/i18n/en_US.ts +++ b/packages/picgo-plugin-app/src/i18n/en_US.ts @@ -144,4 +144,6 @@ export default { "The CORS proxy is essential for browsers and Docker environments. For further consultation, feel free to contact youweics@163.com.", "upload.no.beds": 'No image hosting service is currently available. Kindly proceed to "Image Hosting Settings" to add a new image hosting service.', + "picgo.siyuan.wait.timeout": "Sync timeout(seconds)", + "picgo.siyuan.wait.timeout.tip": "Timeout when handle picbed sync", } diff --git a/packages/picgo-plugin-app/src/i18n/zh_CN.ts b/packages/picgo-plugin-app/src/i18n/zh_CN.ts index 55f6a0a..8758970 100644 --- a/packages/picgo-plugin-app/src/i18n/zh_CN.ts +++ b/packages/picgo-plugin-app/src/i18n/zh_CN.ts @@ -138,4 +138,6 @@ export default { "setting.cors.title": "CORS 代理", "setting.cors.title.tip": "CORS 代理,浏览器、dcoker以及某些插件可能需要,可付费咨询 youweics@163.com", "upload.no.beds": "暂无可用图床,请前往「图床设置」新增图床", + "picgo.siyuan.wait.timeout": "同步延迟(秒)", + "picgo.siyuan.wait.timeout.tip": "图床同步延迟时间,大于这个时间才会去同步图床元数据", } diff --git a/packages/picgo-plugin-bootstrap/src/index.ts b/packages/picgo-plugin-bootstrap/src/index.ts index 29451c3..ed8747c 100644 --- a/packages/picgo-plugin-bootstrap/src/index.ts +++ b/packages/picgo-plugin-bootstrap/src/index.ts @@ -16,11 +16,12 @@ import { initTopbar } from "./topbar" import { showPage } from "./dialog" import { PageRoute } from "./pageRoute" import { ILogger } from "./appLogger" -import { generateUniqueName, ImageItem, SiyuanPicGo } from "zhi-siyuan-picgo" -import { SIYUAN_PICGO_FILE_MAP_KEY } from "zhi-siyuan-picgo/src/lib/constants" +import { generateUniqueName, ImageItem, SIYUAN_PICGO_FILE_MAP_KEY, SiyuanPicGo, IPicGo } from "zhi-siyuan-picgo" +import { initStatusBar, updateStatusBar } from "./statusBar" export default class PicgoPlugin extends Plugin { private logger: ILogger + public statusBarElement: any constructor(options: { app: App; id: string; name: string; i18n: IObject }) { super(options) @@ -30,6 +31,7 @@ export default class PicgoPlugin extends Plugin { onload() { initTopbar(this) + initStatusBar(this) this.logger.info("PicGo Plugin loaded") } @@ -86,6 +88,7 @@ export default class PicgoPlugin extends Plugin { password: siyuanApiToken, } const picgoPostApi = await SiyuanPicGo.getInstance(siyuanConfig as any, isDev) + const ctx = picgoPostApi.ctx() const siyuanApi = picgoPostApi.siyuanApi if (files.length > 1) { siyuanApi.pushErrMsg({ @@ -97,10 +100,11 @@ export default class PicgoPlugin extends Plugin { const file = files[0] try { - siyuanApi.pushMsg({ - msg: "检测到剪贴板图片,正在上传,请勿进行任何操作...", - timeout: 1000, - }) + // siyuanApi.pushMsg({ + // msg: "检测到剪贴板图片,正在上传,请勿进行刷新操作...", + // timeout: 7000, + // }) + updateStatusBar(this, "检测到剪贴板图片,正在上传,请勿进行刷新操作...") // pageId: string // attrs: any @@ -114,14 +118,23 @@ export default class PicgoPlugin extends Plugin { if (imageJsonObj && imageJsonObj.length > 0) { const img = imageJsonObj[0] if (!img?.imgUrl || img.imgUrl.trim().length == 0) { - throw new Error( - "图片上传失败,可能原因:PicGO配置错误或者该平台不支持图片覆盖,请检查配置或者尝试上传新图片。请打开picgo.log查看更多信息" - ) + // throw new Error( + // "图片上传失败,可能原因:PicGO配置错误或者该平台不支持图片覆盖,请检查配置或者尝试上传新图片。请打开picgo.log查看更多信息" + // ) + siyuanApi.pushErrMsg({ + msg: "图片上传失败,可能原因:PicGO配置错误或者该平台不支持图片覆盖,请检查配置或者尝试上传新图片。请打开picgo.log查看更多信息", + timeout: 7000, + }) + return } // 处理上传后续 - await this.handleAfterUpload(siyuanApi, pageId, file, img, imageItem) + await this.handleAfterUpload(ctx, siyuanApi, pageId, file, img, imageItem) } else { - throw new Error("图片上传失败,可能原因:PicGO配置错误,请检查配置。请打开picgo.log查看更多信息") + siyuanApi.pushErrMsg({ + msg: "图片上传失败,可能原因:PicGO配置错误,请检查配置。请打开picgo.log查看更多信息", + timeout: 7000, + }) + // throw new Error("图片上传失败,可能原因:PicGO配置错误,请检查配置。请打开picgo.log查看更多信息") } } catch (e) { siyuanApi.pushErrMsg({ @@ -131,12 +144,13 @@ export default class PicgoPlugin extends Plugin { } } - private async handleAfterUpload(siyuanApi: any, pageId: string, file: any, img: any, oldImageitem: any) { - const WAIT_SECONDS = 10 - siyuanApi.pushMsg({ - msg: `剪贴板图片上传完成。准备延迟${WAIT_SECONDS}秒更新元数据,请勿刷新笔记!`, - timeout: 7000, - }) + private async handleAfterUpload(ctx: IPicGo, siyuanApi: any, pageId: string, file: any, img: any, oldImageitem: any) { + const SIYUAN_WAIT_SECONDS = ctx.getConfig("siyuan.waitTimeout") || 10 + // siyuanApi.pushMsg({ + // msg: `剪贴板图片上传完成。准备延迟${SIYUAN_WAIT_SECONDS}秒更新元数据,请勿刷新笔记!`, + // timeout: 7000, + // }) + updateStatusBar(this, `剪贴板图片上传完成。准备延迟${SIYUAN_WAIT_SECONDS}秒更新元数据,请勿刷新笔记!`) setTimeout(async () => { const formData = new FormData() formData.append("file[]", file) @@ -189,18 +203,28 @@ export default class PicgoPlugin extends Plugin { const newImageBlock = await siyuanApi.getBlockByID(nodeId) // newImageBlock.markdown // "![image](assets/image-20240327190812-yq6esh4.png)" + this.logger.debug("new image block=>", newImageBlock) + // 如果查询出来的块信息不对,不更新,防止误更新 + if (!newImageBlock.markdown.includes(newImageItem.originUrl)) { + siyuanApi.pushErrMsg({ + msg: `块信息不符合,取消更新`, + timeout: 7000, + }) + return + } + // id: string // data: string // dataType?: "markdown" | "dom" - this.logger.debug("new image block=>", newImageBlock) const newImageContent = `![${newImageItem.alt}](${newImageItem.url})` await siyuanApi.updateBlock(nodeId, newImageContent, "markdown") - siyuanApi.pushMsg({ - msg: `图片元数据更新成功`, - timeout: 7000, - }) - }, WAIT_SECONDS * 1000) + // siyuanApi.pushMsg({ + // msg: `图片元数据更新成功`, + // timeout: 7000, + // }) + updateStatusBar(this, `图片元数据更新成功`) + }, SIYUAN_WAIT_SECONDS * 1000) } private getDataNodeIdFromImgWithSrc(srcValue: string) { diff --git a/packages/picgo-plugin-bootstrap/src/statusBar.ts b/packages/picgo-plugin-bootstrap/src/statusBar.ts new file mode 100644 index 0000000..293be8b --- /dev/null +++ b/packages/picgo-plugin-bootstrap/src/statusBar.ts @@ -0,0 +1,42 @@ +/* + * Copyright (c) 2023, Terwer . All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. Terwer designates this + * particular file as subject to the "Classpath" exception as provided + * by Terwer in the LICENSE file that accompanied this code. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Terwer, Shenzhen, Guangdong, China, youweics@163.com + * or visit www.terwer.space if you need additional information or have any + * questions. + */ + +import PicgoPlugin from "./index" + +export const initStatusBar = (pluginInstance: PicgoPlugin) => { + const statusBarTemplate = document.createElement("template") + statusBarTemplate.innerHTML = `
` + statusBarTemplate.content.firstElementChild.addEventListener("click", () => {}) + + pluginInstance.statusBarElement = pluginInstance.addStatusBar({ + element: statusBarTemplate.content.firstElementChild as HTMLElement, + position: "left", + }) +} + +export const updateStatusBar = (pluginInstance: PicgoPlugin, statusText: string) => { + // console.log(pluginInstance.statusBarElement) + pluginInstance.statusBarElement.innerHTML = `
${statusText}
` +} diff --git a/packages/picgo-plugin-bootstrap/vite.config.ts b/packages/picgo-plugin-bootstrap/vite.config.ts index 3e3814a..ca61a5b 100644 --- a/packages/picgo-plugin-bootstrap/vite.config.ts +++ b/packages/picgo-plugin-bootstrap/vite.config.ts @@ -62,6 +62,7 @@ export default defineConfig({ // 在这里自定义变量 define: { "process.env.DEV_MODE": `"${isWatch}"`, + "process.env.NODE_ENV": isWatch ? `"development"` : `"production"`, }, build: { diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 0d2d802..2413501 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -110,8 +110,8 @@ importers: specifier: ^0.8.0 version: 0.8.0 zhi-siyuan-api: - specifier: ^2.19.1 - version: 2.19.1(typescript@5.4.3) + specifier: ^2.20.0 + version: 2.20.0(typescript@5.4.3) devDependencies: '@terwer/eslint-config-custom': specifier: ^1.3.6 @@ -162,8 +162,8 @@ importers: specifier: ^0.8.0 version: 0.8.0 zhi-siyuan-api: - specifier: ^2.19.1 - version: 2.19.1(typescript@5.4.3) + specifier: ^2.20.0 + version: 2.20.0(typescript@5.4.3) zhi-siyuan-picgo: specifier: workspace:* version: link:../../libs/zhi-siyuan-picgo @@ -200,7 +200,7 @@ importers: version: 3.2.2(vite@5.2.6) vitest: specifier: ^1.4.0 - version: 1.4.0(@types/node@20.11.30)(jsdom@24.0.0)(stylus@0.63.0) + version: 1.4.0(@types/node@20.11.30) vue-tsc: specifier: ^2.0.7 version: 2.0.7(typescript@5.4.3) @@ -1782,8 +1782,8 @@ packages: path-browserify: 1.0.1 dev: true - /@tsconfig/node10@1.0.10: - resolution: {integrity: sha512-PiaIWIoPvO6qm6t114ropMCagj6YAF24j9OkCA2mJDXFnlionEwhsBCJ8yek4aib575BI3OkART/90WsgHgLWw==} + /@tsconfig/node10@1.0.11: + resolution: {integrity: sha512-DcRjDCujK/kCk/cUe8Xz8ZSpm8mS3mNNpta+jGCA6USEDfktlNvm1+IuZ9eTcDbNk41BHwpHHeW+N1lKCz4zOw==} dev: true /@tsconfig/node12@1.0.11: @@ -4561,7 +4561,7 @@ packages: he: 1.2.0 param-case: 3.0.4 relateurl: 0.2.7 - terser: 5.29.2 + terser: 5.30.0 dev: true /http-proxy-agent@5.0.0: @@ -6787,8 +6787,8 @@ packages: tslib: 2.6.2 dev: true - /terser@5.29.2: - resolution: {integrity: sha512-ZiGkhUBIM+7LwkNjXYJq8svgkd+QK3UUr0wJqY4MieaezBSAIPgbSPZyIx0idM6XWK5CMzSWa8MJIzmRcB8Caw==} + /terser@5.30.0: + resolution: {integrity: sha512-Y/SblUl5kEyEFzhMAQdsxVHh+utAxd4IuRNJzKywY/4uzSogh3G219jqbDDxYu4MXO9CzY3tSEqmZvW6AoEDJw==} engines: {node: '>=10'} hasBin: true dependencies: @@ -6855,6 +6855,11 @@ packages: engines: {node: '>=14.0.0'} dev: true + /tinypool@0.8.3: + resolution: {integrity: sha512-Ud7uepAklqRH1bvwy22ynrliC7Dljz7Tm8M/0RBUW+YRa4YHhZ6e4PpgE+fu1zr/WqB1kbeuVrdfeuyIBpy4tw==} + engines: {node: '>=14.0.0'} + dev: true + /tinyspy@2.2.1: resolution: {integrity: sha512-KYad6Vy5VDWV4GH3fjpseMQ/XU2BhIYP7Vzd0LG44qRWm/Yt2WCOTicFdvmgo6gWaqooMQCawTtILVQJupKu7A==} engines: {node: '>=14.0.0'} @@ -6945,7 +6950,7 @@ packages: optional: true dependencies: '@cspotcode/source-map-support': 0.8.1 - '@tsconfig/node10': 1.0.10 + '@tsconfig/node10': 1.0.11 '@tsconfig/node12': 1.0.11 '@tsconfig/node14': 1.0.3 '@tsconfig/node16': 1.0.4 @@ -7717,6 +7722,62 @@ packages: - terser dev: true + /vitest@1.4.0(@types/node@20.11.30): + resolution: {integrity: sha512-gujzn0g7fmwf83/WzrDTnncZt2UiXP41mHuFYFrdwaLRVQ6JYQEiME2IfEjU3vcFL3VKa75XhI3lFgn+hfVsQw==} + engines: {node: ^18.0.0 || >=20.0.0} + hasBin: true + peerDependencies: + '@edge-runtime/vm': '*' + '@types/node': ^18.0.0 || >=20.0.0 + '@vitest/browser': 1.4.0 + '@vitest/ui': 1.4.0 + happy-dom: '*' + jsdom: '*' + peerDependenciesMeta: + '@edge-runtime/vm': + optional: true + '@types/node': + optional: true + '@vitest/browser': + optional: true + '@vitest/ui': + optional: true + happy-dom: + optional: true + jsdom: + optional: true + dependencies: + '@types/node': 20.11.30 + '@vitest/expect': 1.4.0 + '@vitest/runner': 1.4.0 + '@vitest/snapshot': 1.4.0 + '@vitest/spy': 1.4.0 + '@vitest/utils': 1.4.0 + acorn-walk: 8.3.2 + chai: 4.4.1 + debug: 4.3.4 + execa: 8.0.1 + local-pkg: 0.5.0 + magic-string: 0.30.8 + pathe: 1.1.2 + picocolors: 1.0.0 + std-env: 3.7.0 + strip-literal: 2.0.0 + tinybench: 2.6.0 + tinypool: 0.8.3 + vite: 5.2.6(@types/node@20.11.30)(stylus@0.63.0) + vite-node: 1.4.0(@types/node@20.11.30)(stylus@0.63.0) + why-is-node-running: 2.2.2 + transitivePeerDependencies: + - less + - lightningcss + - sass + - stylus + - sugarss + - supports-color + - terser + dev: true + /vitest@1.4.0(@types/node@20.11.30)(jsdom@24.0.0)(stylus@0.63.0): resolution: {integrity: sha512-gujzn0g7fmwf83/WzrDTnncZt2UiXP41mHuFYFrdwaLRVQ6JYQEiME2IfEjU3vcFL3VKa75XhI3lFgn+hfVsQw==} engines: {node: ^18.0.0 || >=20.0.0} @@ -8166,8 +8227,8 @@ packages: resolution: {integrity: sha512-3Ky5p6KvLWpXy2tlb/JIfSEKLSe5w43PBLM6g+hNcWwpL9S62emgcpUAHzGWBbC0vlLBLungt2LOsmwAfhrZ0w==} dev: false - /zhi-siyuan-api@2.19.1(typescript@5.4.3): - resolution: {integrity: sha512-0SjX3hyu8lVQHJ6/q95EYeu0qSr5xdLPDmhh/G8i5dqZhpnvskSPb6k9KcBvZO0N9/vZrHXPHaoVyVrx+jArYg==} + /zhi-siyuan-api@2.20.0(typescript@5.4.3): + resolution: {integrity: sha512-3+x3EHrecyfqmEhWg/j3SvYo85uv2dQ216JVC+cvbl9vr2uUYe1XUZZexdNiEgvhuBgdR8CxK38mX/NaOx4bAA==} dependencies: zhi-blog-api: 1.56.4(typescript@5.4.3) zhi-common: 1.33.0(typescript@5.4.3) diff --git a/scripts/clean.sh b/scripts/clean.sh new file mode 100755 index 0000000..407e756 --- /dev/null +++ b/scripts/clean.sh @@ -0,0 +1,8 @@ +#!/bin/sh + +find . -name "node_modules" -type d -exec rm -rf {} + +find . -name "dist" -type d -exec rm -rf {} + +find . -name ".turbo" -type d -exec rm -rf {} + +rm -rf ./artifacts +rm -rf ./build +echo "clean finished." \ No newline at end of file diff --git a/scripts/package.py b/scripts/package.py index fed3bea..faf6ab6 100644 --- a/scripts/package.py +++ b/scripts/package.py @@ -9,8 +9,8 @@ # 获取当前工作空间 cwd = scriptutils.get_workdir() - os.system("pnpm build -F picgo-plugin-app") - os.system("pnpm build -F picgo-plugin-bootstrap") + os.system("pnpm build -F picgo-plugin-app --force") + os.system("pnpm build -F picgo-plugin-bootstrap --force") dist_folder = "./artifacts/siyuan-plugin-picgo/dist" data = scriptutils.read_json_file(cwd + "package.json")