diff --git a/zyplayer-doc-ui/wiki-ui/src/components/single/MessagePrompt.js b/zyplayer-doc-ui/wiki-ui/src/components/single/MessagePrompt.js new file mode 100644 index 00000000..7401453b --- /dev/null +++ b/zyplayer-doc-ui/wiki-ui/src/components/single/MessagePrompt.js @@ -0,0 +1,41 @@ +import { createVNode, render } from "vue"; +import PromptDialog from "./PromptDialog.vue"; + +/** + * 生成一个带输入框的弹窗 + * @author zyplayer-doc + * @date 2024-12-08 + */ +let promise = null; +function getInstance(config) { + if (promise) { + try { + promise.close(); + } catch (error) {} + } + const div = document.createElement("div"); + const conf = Object.assign({cancelText: '取消', okText: '确定'}, config); + const close = () => { + try { + document.body.removeChild(div); + promise.reject(); + promise = null; + } catch (error) {} + }; + conf.close = close; + conf.ok = (value) => { + promise.resolve(value); + }; + const node = createVNode(PromptDialog, conf); + render(node, div); + document.body.appendChild(div); + return new Promise((resolve, reject) => { + promise = {resolve, reject, close}; + }); +} +const MessagePrompt = (opts) => { + return getInstance(opts); +}; + +export default MessagePrompt; + diff --git a/zyplayer-doc-ui/wiki-ui/src/components/single/PromptDialog.vue b/zyplayer-doc-ui/wiki-ui/src/components/single/PromptDialog.vue new file mode 100644 index 00000000..e5908221 --- /dev/null +++ b/zyplayer-doc-ui/wiki-ui/src/components/single/PromptDialog.vue @@ -0,0 +1,80 @@ + + + + + diff --git a/zyplayer-doc-ui/wiki-ui/src/views/view/PageLayout.vue b/zyplayer-doc-ui/wiki-ui/src/views/view/PageLayout.vue index 3dc4bb0a..5e07fb25 100644 --- a/zyplayer-doc-ui/wiki-ui/src/views/view/PageLayout.vue +++ b/zyplayer-doc-ui/wiki-ui/src/views/view/PageLayout.vue @@ -129,69 +129,3 @@ body { } - - diff --git a/zyplayer-doc-ui/wiki-ui/src/views/view/aside/AddMenu.vue b/zyplayer-doc-ui/wiki-ui/src/views/view/aside/AddMenu.vue index 3c51fbda..f0ec1819 100644 --- a/zyplayer-doc-ui/wiki-ui/src/views/view/aside/AddMenu.vue +++ b/zyplayer-doc-ui/wiki-ui/src/views/view/aside/AddMenu.vue @@ -3,18 +3,18 @@