123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643 |
- <!DOCTYPE html><html><head>
- <title>下单流程</title>
- <meta charset="utf-8">
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
-
- <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/katex@0.16.11/dist/katex.min.css">
-
-
- <script src="https://cdn.jsdelivr.net/npm/mermaid@11.1.1/dist/mermaid.min.js"></script>
-
-
- <style>
- code[class*=language-],pre[class*=language-]{color:#333;background:0 0;font-family:Consolas,"Liberation Mono",Menlo,Courier,monospace;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;line-height:1.4;-moz-tab-size:8;-o-tab-size:8;tab-size:8;-webkit-hyphens:none;-moz-hyphens:none;-ms-hyphens:none;hyphens:none}pre[class*=language-]{padding:.8em;overflow:auto;border-radius:3px;background:#f5f5f5}:not(pre)>code[class*=language-]{padding:.1em;border-radius:.3em;white-space:normal;background:#f5f5f5}.token.blockquote,.token.comment{color:#969896}.token.cdata{color:#183691}.token.doctype,.token.macro.property,.token.punctuation,.token.variable{color:#333}.token.builtin,.token.important,.token.keyword,.token.operator,.token.rule{color:#a71d5d}.token.attr-value,.token.regex,.token.string,.token.url{color:#183691}.token.atrule,.token.boolean,.token.code,.token.command,.token.constant,.token.entity,.token.number,.token.property,.token.symbol{color:#0086b3}.token.prolog,.token.selector,.token.tag{color:#63a35c}.token.attr-name,.token.class,.token.class-name,.token.function,.token.id,.token.namespace,.token.pseudo-class,.token.pseudo-element,.token.url-reference .token.variable{color:#795da3}.token.entity{cursor:help}.token.title,.token.title .token.punctuation{font-weight:700;color:#1d3e81}.token.list{color:#ed6a43}.token.inserted{background-color:#eaffea;color:#55a532}.token.deleted{background-color:#ffecec;color:#bd2c00}.token.bold{font-weight:700}.token.italic{font-style:italic}.language-json .token.property{color:#183691}.language-markup .token.tag .token.punctuation{color:#333}.language-css .token.function,code.language-css{color:#0086b3}.language-yaml .token.atrule{color:#63a35c}code.language-yaml{color:#183691}.language-ruby .token.function{color:#333}.language-markdown .token.url{color:#795da3}.language-makefile .token.symbol{color:#795da3}.language-makefile .token.variable{color:#183691}.language-makefile .token.builtin{color:#0086b3}.language-bash .token.keyword{color:#0086b3}pre[data-line]{position:relative;padding:1em 0 1em 3em}pre[data-line] .line-highlight-wrapper{position:absolute;top:0;left:0;background-color:transparent;display:block;width:100%}pre[data-line] .line-highlight{position:absolute;left:0;right:0;padding:inherit 0;margin-top:1em;background:hsla(24,20%,50%,.08);background:linear-gradient(to right,hsla(24,20%,50%,.1) 70%,hsla(24,20%,50%,0));pointer-events:none;line-height:inherit;white-space:pre}pre[data-line] .line-highlight:before,pre[data-line] .line-highlight[data-end]:after{content:attr(data-start);position:absolute;top:.4em;left:.6em;min-width:1em;padding:0 .5em;background-color:hsla(24,20%,50%,.4);color:#f4f1ef;font:bold 65%/1.5 sans-serif;text-align:center;vertical-align:.3em;border-radius:999px;text-shadow:none;box-shadow:0 1px #fff}pre[data-line] .line-highlight[data-end]:after{content:attr(data-end);top:auto;bottom:.4em}html body{font-family:'Helvetica Neue',Helvetica,'Segoe UI',Arial,freesans,sans-serif;font-size:16px;line-height:1.6;color:#333;background-color:#fff;overflow:initial;box-sizing:border-box;word-wrap:break-word}html body>:first-child{margin-top:0}html body h1,html body h2,html body h3,html body h4,html body h5,html body h6{line-height:1.2;margin-top:1em;margin-bottom:16px;color:#000}html body h1{font-size:2.25em;font-weight:300;padding-bottom:.3em}html body h2{font-size:1.75em;font-weight:400;padding-bottom:.3em}html body h3{font-size:1.5em;font-weight:500}html body h4{font-size:1.25em;font-weight:600}html body h5{font-size:1.1em;font-weight:600}html body h6{font-size:1em;font-weight:600}html body h1,html body h2,html body h3,html body h4,html body h5{font-weight:600}html body h5{font-size:1em}html body h6{color:#5c5c5c}html body strong{color:#000}html body del{color:#5c5c5c}html body a:not([href]){color:inherit;text-decoration:none}html body a{color:#08c;text-decoration:none}html body a:hover{color:#00a3f5;text-decoration:none}html body img{max-width:100%}html body>p{margin-top:0;margin-bottom:16px;word-wrap:break-word}html body>ol,html body>ul{margin-bottom:16px}html body ol,html body ul{padding-left:2em}html body ol.no-list,html body ul.no-list{padding:0;list-style-type:none}html body ol ol,html body ol ul,html body ul ol,html body ul ul{margin-top:0;margin-bottom:0}html body li{margin-bottom:0}html body li.task-list-item{list-style:none}html body li>p{margin-top:0;margin-bottom:0}html body .task-list-item-checkbox{margin:0 .2em .25em -1.8em;vertical-align:middle}html body .task-list-item-checkbox:hover{cursor:pointer}html body blockquote{margin:16px 0;font-size:inherit;padding:0 15px;color:#5c5c5c;background-color:#f0f0f0;border-left:4px solid #d6d6d6}html body blockquote>:first-child{margin-top:0}html body blockquote>:last-child{margin-bottom:0}html body hr{height:4px;margin:32px 0;background-color:#d6d6d6;border:0 none}html body table{margin:10px 0 15px 0;border-collapse:collapse;border-spacing:0;display:block;width:100%;overflow:auto;word-break:normal;word-break:keep-all}html body table th{font-weight:700;color:#000}html body table td,html body table th{border:1px solid #d6d6d6;padding:6px 13px}html body dl{padding:0}html body dl dt{padding:0;margin-top:16px;font-size:1em;font-style:italic;font-weight:700}html body dl dd{padding:0 16px;margin-bottom:16px}html body code{font-family:Menlo,Monaco,Consolas,'Courier New',monospace;font-size:.85em;color:#000;background-color:#f0f0f0;border-radius:3px;padding:.2em 0}html body code::after,html body code::before{letter-spacing:-.2em;content:'\00a0'}html body pre>code{padding:0;margin:0;word-break:normal;white-space:pre;background:0 0;border:0}html body .highlight{margin-bottom:16px}html body .highlight pre,html body pre{padding:1em;overflow:auto;line-height:1.45;border:#d6d6d6;border-radius:3px}html body .highlight pre{margin-bottom:0;word-break:normal}html body pre code,html body pre tt{display:inline;max-width:initial;padding:0;margin:0;overflow:initial;line-height:inherit;word-wrap:normal;background-color:transparent;border:0}html body pre code:after,html body pre code:before,html body pre tt:after,html body pre tt:before{content:normal}html body blockquote,html body dl,html body ol,html body p,html body pre,html body ul{margin-top:0;margin-bottom:16px}html body kbd{color:#000;border:1px solid #d6d6d6;border-bottom:2px solid #c7c7c7;padding:2px 4px;background-color:#f0f0f0;border-radius:3px}@media print{html body{background-color:#fff}html body h1,html body h2,html body h3,html body h4,html body h5,html body h6{color:#000;page-break-after:avoid}html body blockquote{color:#5c5c5c}html body pre{page-break-inside:avoid}html body table{display:table}html body img{display:block;max-width:100%;max-height:100%}html body code,html body pre{word-wrap:break-word;white-space:pre}}.markdown-preview{width:100%;height:100%;box-sizing:border-box}.markdown-preview ul{list-style:disc}.markdown-preview ul ul{list-style:circle}.markdown-preview ul ul ul{list-style:square}.markdown-preview ol{list-style:decimal}.markdown-preview ol ol,.markdown-preview ul ol{list-style-type:lower-roman}.markdown-preview ol ol ol,.markdown-preview ol ul ol,.markdown-preview ul ol ol,.markdown-preview ul ul ol{list-style-type:lower-alpha}.markdown-preview .newpage,.markdown-preview .pagebreak{page-break-before:always}.markdown-preview pre.line-numbers{position:relative;padding-left:3.8em;counter-reset:linenumber}.markdown-preview pre.line-numbers>code{position:relative}.markdown-preview pre.line-numbers .line-numbers-rows{position:absolute;pointer-events:none;top:1em;font-size:100%;left:0;width:3em;letter-spacing:-1px;border-right:1px solid #999;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.markdown-preview pre.line-numbers .line-numbers-rows>span{pointer-events:none;display:block;counter-increment:linenumber}.markdown-preview pre.line-numbers .line-numbers-rows>span:before{content:counter(linenumber);color:#999;display:block;padding-right:.8em;text-align:right}.markdown-preview .mathjax-exps .MathJax_Display{text-align:center!important}.markdown-preview:not([data-for=preview]) .code-chunk .code-chunk-btn-group{display:none}.markdown-preview:not([data-for=preview]) .code-chunk .status{display:none}.markdown-preview:not([data-for=preview]) .code-chunk .output-div{margin-bottom:16px}.markdown-preview .md-toc{padding:0}.markdown-preview .md-toc .md-toc-link-wrapper .md-toc-link{display:inline;padding:.25rem 0}.markdown-preview .md-toc .md-toc-link-wrapper .md-toc-link div,.markdown-preview .md-toc .md-toc-link-wrapper .md-toc-link p{display:inline}.markdown-preview .md-toc .md-toc-link-wrapper.highlighted .md-toc-link{font-weight:800}.scrollbar-style::-webkit-scrollbar{width:8px}.scrollbar-style::-webkit-scrollbar-track{border-radius:10px;background-color:transparent}.scrollbar-style::-webkit-scrollbar-thumb{border-radius:5px;background-color:rgba(150,150,150,.66);border:4px solid rgba(150,150,150,.66);background-clip:content-box}html body[for=html-export]:not([data-presentation-mode]){position:relative;width:100%;height:100%;top:0;left:0;margin:0;padding:0;overflow:auto}html body[for=html-export]:not([data-presentation-mode]) .markdown-preview{position:relative;top:0;min-height:100vh}@media screen and (min-width:914px){html body[for=html-export]:not([data-presentation-mode]) .markdown-preview{padding:2em calc(50% - 457px + 2em)}}@media screen and (max-width:914px){html body[for=html-export]:not([data-presentation-mode]) .markdown-preview{padding:2em}}@media screen and (max-width:450px){html body[for=html-export]:not([data-presentation-mode]) .markdown-preview{font-size:14px!important;padding:1em}}@media print{html body[for=html-export]:not([data-presentation-mode]) #sidebar-toc-btn{display:none}}html body[for=html-export]:not([data-presentation-mode]) #sidebar-toc-btn{position:fixed;bottom:8px;left:8px;font-size:28px;cursor:pointer;color:inherit;z-index:99;width:32px;text-align:center;opacity:.4}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] #sidebar-toc-btn{opacity:1}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc{position:fixed;top:0;left:0;width:300px;height:100%;padding:32px 0 48px 0;font-size:14px;box-shadow:0 0 4px rgba(150,150,150,.33);box-sizing:border-box;overflow:auto;background-color:inherit}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc::-webkit-scrollbar{width:8px}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc::-webkit-scrollbar-track{border-radius:10px;background-color:transparent}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc::-webkit-scrollbar-thumb{border-radius:5px;background-color:rgba(150,150,150,.66);border:4px solid rgba(150,150,150,.66);background-clip:content-box}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc a{text-decoration:none}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc .md-toc{padding:0 16px}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc .md-toc .md-toc-link-wrapper .md-toc-link{display:inline;padding:.25rem 0}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc .md-toc .md-toc-link-wrapper .md-toc-link div,html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc .md-toc .md-toc-link-wrapper .md-toc-link p{display:inline}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .md-sidebar-toc .md-toc .md-toc-link-wrapper.highlighted .md-toc-link{font-weight:800}html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .markdown-preview{left:300px;width:calc(100% - 300px);padding:2em calc(50% - 457px - 300px / 2);margin:0;box-sizing:border-box}@media screen and (max-width:1274px){html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .markdown-preview{padding:2em}}@media screen and (max-width:450px){html body[for=html-export]:not([data-presentation-mode])[html-show-sidebar-toc] .markdown-preview{width:100%}}html body[for=html-export]:not([data-presentation-mode]):not([html-show-sidebar-toc]) .markdown-preview{left:50%;transform:translateX(-50%)}html body[for=html-export]:not([data-presentation-mode]):not([html-show-sidebar-toc]) .md-sidebar-toc{display:none}
- /* Please visit the URL below for more information: */
- /* https://shd101wyy.github.io/markdown-preview-enhanced/#/customize-css */
- </style>
- <!-- The content below will be included at the end of the <head> element. --><script type="text/javascript">
- document.addEventListener("DOMContentLoaded", function () {
- // your code here
- });
- </script></head><body for="html-export">
-
-
- <div class="crossnote markdown-preview ">
-
- <div class="md-toc">
- <details style="padding:0;;padding-left:0px;" open="">
- <summary class="md-toc-link-wrapper">
- <a href="#选择技师下单流程" class="md-toc-link"><p>选择技师下单流程</p>
- </a>
- </summary>
- <div>
- <div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#用户选择技师" class="md-toc-link">
- <p>用户选择技师</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#用户选择项目" class="md-toc-link">
- <p>用户选择项目</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#用户选择可服务时间" class="md-toc-link">
- <p>用户选择可服务时间</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#用户选择营销卷" class="md-toc-link">
- <p>用户选择营销卷</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#用户点击立即结算" class="md-toc-link">
- <p>用户点击立即结算</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#支付失败" class="md-toc-link">
- <p>支付失败</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#支付成功" class="md-toc-link">
- <p>支付成功</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#技师接单" class="md-toc-link">
- <p>技师接单</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#技师拒绝接单" class="md-toc-link">
- <p>技师拒绝接单</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#订单超时" class="md-toc-link">
- <p>订单超时</p>
- </a></div>
- </div>
- </details>
- <details style="padding:0;;padding-left:0px;" open="">
- <summary class="md-toc-link-wrapper">
- <a href="#选择项目下单" class="md-toc-link"><p>选择项目下单</p>
- </a>
- </summary>
- <div>
- <div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#用户选择项目-1" class="md-toc-link">
- <p>用户选择项目</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#创建抢单类型订单推送给技师" class="md-toc-link">
- <p>创建抢单类型订单,推送给技师</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#有技师抢单" class="md-toc-link">
- <p>有技师抢单</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#无技师抢单" class="md-toc-link">
- <p>无技师抢单</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#用户选择技师-1" class="md-toc-link">
- <p>用户选择技师</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#用户不反选技师" class="md-toc-link">
- <p>用户不反选技师</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#支付成功-1" class="md-toc-link">
- <p>支付成功</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#技师拒绝接单-1" class="md-toc-link">
- <p>技师拒绝接单</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#支付失败-1" class="md-toc-link">
- <p>支付失败</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#技师出发" class="md-toc-link">
- <p>技师出发</p>
- </a></div>
- </div>
- </details>
-
- </div>
- <h4 id="选择技师下单流程">选择技师下单流程 </h4>
- <div class="mermaid"> flowchart TD
- %% 基础选择流程
- Start([开始]) --> A[用户选择服务位置]
- A --> B[查询附近技师列表]
- B --> C[用户选择技师]
- C --> D[展示技师项目列表]
- D --> E[用户选择项目]
- E --> F[展示项目详情]
- F --> G[用户选择服务时间]
- G --> H[用户选择营销卷]
- H --> I[计算订单费用]
- %% 支付流程
- I --> J[用户确认下单]
- J --> K{支付结果}
- %% 支付失败处理
- K -->|失败| L[订单状态:待付款]
- L --> M[客服跟进]
- M --> N{用户选择}
- N -->|重新支付| J
- N -->|取消订单| O[退款处理]
- %% 支付成功处理
- K -->|成功| P[订单状态:已支付]
- P --> Q[推送订单给技师]
- %% 技师处理流程
- Q --> R{技师处理}
- %% 技师接单分支
- R -->|接单| S[订单状态:已接单]
- S --> T[技师确认出发]
- T --> U[订单状态:已出发]
- %% 技师拒单分支
- R -->|拒单| V[订单状态:已拒绝]
- V --> W[客服处理]
- W --> X{处理方案}
- X -->|更换技师| Q
- X -->|用户退款| O
- %% 接单超时处理
- R -->|超时| Y[客服跟进]
- Y --> Z{处理结果}
- Z -->|联系上技师| R
- Z -->|更换技师| Q
- Z -->|取消订单| O
- %% 结束节点
- U --> End([开始服务])
- O --> Cancel([订单结束])
- %% 样式定义
- classDef default fill:#f9f9f9,stroke:#333,stroke-width:2px
- classDef process fill:#dcedc8,stroke:#33691e
- classDef decision fill:#fff3e0,stroke:#e65100
- classDef status fill:#e3f2fd,stroke:#0d47a1
- %% 应用样式
- class K,R,X,Z decision
- class L,P,S,U,V status
- class A,B,C,D,E,F,G,H,I process
- click A,B,C href "#用户选择技师"
- click D,E,F href "#用户选择项目"
- click G href "#用户选择可服务时间"
- click H,I href "#用户选择营销卷"
- click J href "#用户点击立即结算"
- click L href "#支付失败"
- click P href "#支付成功"
- click S href "#技师接单"
- click V href "#技师拒绝接单"
- click X href "#订单超时"
- </div><h5 id="用户选择技师">用户选择技师 </h5>
- <p><strong><em>后台逻辑:</em></strong></p>
- <ol>
- <li>获取前端传递的经纬度,根据经纬度查询出附近的技师</li>
- <li><a href="#%E8%8E%B7%E5%8F%96%E6%8A%80%E5%B8%88%E5%88%97%E8%A1%A8">获取技师列表</a></li>
- <li><a href="#%E8%8E%B7%E5%8F%96%E6%8A%80%E5%B8%88%E8%AF%A6%E6%83%85">获取技师详情</a></li>
- </ol>
- <p><strong><em>UI 图:</em></strong><br>
- <img src="./assets/%E4%B8%8B%E5%8D%95%E6%B5%81%E7%A8%8B%E5%9B%BE%E7%89%87/%E9%80%89%E6%8B%A9%E6%8A%80%E5%B8%88%E4%B8%8B%E5%8D%95.png" alt=""></p>
- <h5 id="用户选择项目">用户选择项目 </h5>
- <p><strong><em>后台逻辑:</em></strong></p>
- <ol>
- <li>获取前端传递的技师 id,查询出该技师下可服务项目</li>
- <li>获取前端传递的区域地址,查询出该区域地址可服务项目(370602 或 156370602)</li>
- <li><a href="#%E8%8E%B7%E5%8F%96%E9%A1%B9%E7%9B%AE%E5%88%97%E8%A1%A8-%E6%8A%80%E5%B8%88%E5%BC%80%E9%80%9A%E7%A7%9F%E6%88%B7%E9%A1%B9%E7%9B%AE">获取项目列表</a></li>
- <li><a href="#%E8%8E%B7%E5%8F%96%E9%A1%B9%E7%9B%AE%E8%AF%A6%E6%83%85-%E7%A7%9F%E6%88%B7%E9%A1%B9%E7%9B%AE">获取项目详情</a></li>
- </ol>
- <p><strong><em>UI 图:</em></strong><br>
- <img src="./assets/%E4%B8%8B%E5%8D%95%E6%B5%81%E7%A8%8B%E5%9B%BE%E7%89%87/%E9%80%89%E6%8B%A9%E9%A1%B9%E7%9B%AE.png" alt=""></p>
- <h5 id="用户选择可服务时间">用户选择可服务时间 </h5>
- <p><strong>前端逻辑</strong></p>
- <ol>
- <li>获取前端传递的技师 id 和项目 id,查询出该技师下,该项目的可服务时间,以及下单详情信息</li>
- <li>获取前端传递的区域地址,计算订单金额(370602 或 156370602)</li>
- <li>获取前端传递的路程,计算订单金额</li>
- </ol>
- <p><strong><em>后台逻辑:</em></strong></p>
- <ol>
- <li><a href="#%E8%AE%A1%E7%AE%97%E8%AE%A2%E5%8D%95%E9%87%91%E9%A2%9D">计算订单金额</a></li>
- <li><a href="#%E8%AE%A2%E5%8D%95%E5%88%9D%E5%A7%8B%E5%8C%96-%E5%89%8D%E7%AB%AF%E5%88%9D%E5%A7%8B%E5%8C%96">订单详情</a></li>
- </ol>
- <p><strong><em>UI 图:</em></strong><br>
- <img src="./assets/%E4%B8%8B%E5%8D%95%E6%B5%81%E7%A8%8B%E5%9B%BE%E7%89%87/%E9%80%89%E6%8B%A9%E5%8F%AF%E6%9C%8D%E5%8A%A1%E6%97%B6%E9%97%B4.png" alt=""></p>
- <h5 id="用户选择营销卷">用户选择营销卷 </h5>
- <p><strong><em>后台逻辑:</em></strong></p>
- <ol>
- <li>获取前端传递的技师 id 和项目 id,查询出该技师下,该项目的可使用的营销卷</li>
- <li>选择优惠劵</li>
- <li><a href="#%E8%AE%A1%E7%AE%97%E8%AE%A2%E5%8D%95%E9%87%91%E9%A2%9D">计算订单金额</a></li>
- </ol>
- <p><strong><em>UI 图:</em></strong><br>
- <img src="./assets/%E4%B8%8B%E5%8D%95%E6%B5%81%E7%A8%8B%E5%9B%BE%E7%89%87/%E9%80%89%E6%8B%A9%E4%BC%98%E6%83%A0%E5%8A%B5.png" alt=""></p>
- <h5 id="用户点击立即结算">用户点击立即结算 </h5>
- <p><strong><em>后台逻辑:</em></strong></p>
- <ol>
- <li>创建订单,并判断使用的那种支付方式</li>
- <li><a href="#%E5%88%9B%E5%BB%BA%E8%AE%A2%E5%8D%95">创建订单</a></li>
- <li><a href="#%E8%8E%B7%E5%8F%96%E6%94%AF%E4%BB%98%E9%85%8D%E7%BD%AE">调用支付</a></li>
- </ol>
- <p><strong><em>UI 图:</em></strong><br>
- <img src="./assets/%E4%B8%8B%E5%8D%95%E6%B5%81%E7%A8%8B%E5%9B%BE%E7%89%87/%E7%AB%8B%E5%8D%B3%E7%BB%93%E7%AE%97.png" alt=""></p>
- <h5 id="支付失败">支付失败 </h5>
- <p><strong><em>后台逻辑:</em></strong></p>
- <ol>
- <li>支付超时、取消支付导致的用户支付失败,极光推送客服用户支付失败</li>
- <li><a href="#%E6%94%AF%E4%BB%98%E5%A4%B1%E8%B4%A5">支付失败</a> TODO:??</li>
- </ol>
- <p><strong><em>UI 图:</em></strong><br>
- <img src="./assets/%E4%B8%8B%E5%8D%95%E6%B5%81%E7%A8%8B%E5%9B%BE%E7%89%87/%E6%94%AF%E4%BB%98%E5%A4%B1%E8%B4%A5%E3%80%81%E6%94%AF%E4%BB%98%E8%B6%85%E6%97%B6.png" alt=""></p>
- <h5 id="支付成功">支付成功 </h5>
- <p><strong><em>后台逻辑:</em></strong></p>
- <ol>
- <li>支付成功,后台更改订单,且极光推送技师接单</li>
- <li><a href="#%E6%94%AF%E4%BB%98%E6%88%90%E5%8A%9F">支付成功</a> TODO:??</li>
- </ol>
- <p><strong><em>UI 图:</em></strong><br>
- <img src="./assets/%E4%B8%8B%E5%8D%95%E6%B5%81%E7%A8%8B%E5%9B%BE%E7%89%87/%E5%B7%B2%E6%94%AF%E4%BB%98%E3%80%81%E5%BE%85%E6%8E%A5%E5%8D%95.png" alt=""></p>
- <h5 id="技师接单">技师接单 </h5>
- <p><strong><em>后台逻辑:</em></strong></p>
- <ol>
- <li>技师接单,用户同步数据</li>
- <li><a href="#%E6%8E%A5%E5%8D%95">技师接单</a></li>
- </ol>
- <p><strong><em>UI 图:</em></strong><br>
- <img src="./assets/%E4%B8%8B%E5%8D%95%E6%B5%81%E7%A8%8B%E5%9B%BE%E7%89%87/%E6%8A%80%E5%B8%88%E7%A1%AE%E8%AE%A4%E6%8E%A5%E5%8D%95.png" alt=""></p>
- <h5 id="技师拒绝接单">技师拒绝接单 </h5>
- <p><strong><em>后台逻辑:</em></strong></p>
- <ol>
- <li>技师拒绝接单,客服介入,联系用户,更改技师或者用户取消订单退款</li>
- <li><a href="#%E6%8B%92%E7%BB%9D%E6%8E%A5%E5%8D%95">技师拒绝接单</a></li>
- </ol>
- <p><strong><em>UI 图:</em></strong><br>
- <img src="./assets/%E4%B8%8B%E5%8D%95%E6%B5%81%E7%A8%8B%E5%9B%BE%E7%89%87/%E6%8A%80%E5%B8%88%E6%8B%92%E7%BB%9D%E6%8E%A5%E5%8D%95.png" alt=""></p>
- <h5 id="订单超时">订单超时 </h5>
- <p><strong><em>后台逻辑:</em></strong></p>
- <ol>
- <li>技师没有在规定时间内接单,客服介入,联系技师</li>
- <li><a href="#%E8%AE%A2%E5%8D%95%E8%B6%85%E6%97%B6">订单超时</a> TODO: 客服介入后,对订单进行处理(更换技师、用户退款、取消订单、转公单等)</li>
- </ol>
- <h4 id="选择项目下单">选择项目下单 </h4>
- <div class="mermaid"> flowchart TD
- %% 主流程起点
- Start[开始] --> Init[初始化订单]
- %% 订单创建阶段
- subgraph 订单创建
- Init --> A1[获取用户位置]
- A1 --> A2[查询区域服务]
- A2 --> A3[用户选择服务]
- A3 --> A4[选择地址/时间/优惠券]
- A4 --> A5[创建空订单]
- end
- %% 抢单阶段
- subgraph 抢单流程
- A5 --> B1[进入抢单池]
- B1 --> B2[推送给技师]
- B2 --> B3{是否有技师抢单?}
- B3 -->|是| B4[展示技师列表]
- B3 -->|否| B5[等待5-8分钟]
- B5 --> B6[客服介入]
- end
- %% 用户选择阶段
- subgraph 用户选择
- B4 --> C1{用户是否选择?}
- C1 -->|是| C2[锁定技师]
- C1 -->|否| C3[等待30分钟]
- C2 --> C4[计算费用]
- C3 --> B6
- end
- %% 支付阶段
- subgraph 支付流程
- C4 --> D1[展示订单详情]
- D1 --> D2{用户支付?}
- D2 -->|是| D3[支付处理]
- D2 -->|否| D4[3分钟超时]
- D3 --> D5{支付结果}
- D5 -->|成功| D6[更新订单状态]
- D5 -->|失败| D7[客服介入]
- D4 --> D8[解绑技师]
- end
- %% 服务阶段
- subgraph 服务执行
- D6 --> E1[通知技师]
- E1 --> jh1[技师拒绝订单]
- jh1 --> jh2[客服介入?]
- jh2 -->|技师接单| E2[技师出发]
- jh2 -->|技师拒单| jh3[客服介入,联系用户?]
- jh3 --> jh4[用户接受更换技师]
- jh4 --> E2
- jh3 --> jh5[用户不接受更换技师]
- jh5 --> Cancel
- E1 --> E2[技师出发]
- E2 --> E3[服务进行中]
- E3 --> E4[服务完成]
- end
- %% 取消订单流程
- subgraph 取消处理
- Cancel[取消订单] --> F1[客服确认]
- F1 --> F2{是否可挽回?}
- F2 -->|是| F3[恢复订单]
- F2 -->|否| F4[退款处理]
- end
- %% 异常处理连接
- D7 --> Cancel
- B6 --> Cancel
- D8 --> B1
- %% 结束节点
- E4 --> End[结束]
- F4 --> End
- F3 --> D1
- %% 样式定义
- classDef success fill:#baffc9,stroke:#333,stroke-width:2px;
- classDef warning fill:#ffffba,stroke:#333,stroke-width:2px;
- classDef error fill:#ffb3ba,stroke:#333,stroke-width:2px;
- classDef normal fill:#f9f9f9,stroke:#333,stroke-width:2px;
- %% 应用样式
- class D6,E4 success;
- class D7,B6,Cancel warning;
- class F4 error;
- class Start,End normal;
- click A1,A2,A3 href "#用户选择项目"
- click A4,A5,B1,B2 href "#创建抢单类型订单,推送给技师"
- click B3,B4 href "#有技师抢单"
- click B5,B6 href "#无技师抢单"
- click C1,C2,C4 href "#用户选择技师"
- click C3,B6 href "#用户不反选技师"
- click D2,D3,D6,E1 href "#支付成功"
- click jh1,jh2,jh3,jh4,jh5 href "#技师拒绝接单"
- click D4,D7,D8 href "#支付失败"
- click E2 href "#技师出发"
- </div><h5 id="用户选择项目-1">用户选择项目 </h5>
- <p><strong><em>后台逻辑:</em></strong></p>
- <ol>
- <li>传递用户当前位置信息</li>
- <li><a href="#%E8%8E%B7%E5%8F%96%E9%A1%B9%E7%9B%AE%E5%88%97%E8%A1%A8-%E6%8A%80%E5%B8%88%E5%BC%80%E9%80%9A%E7%A7%9F%E6%88%B7%E9%A1%B9%E7%9B%AE">服务项目列表</a></li>
- <li><a href="#%E8%8E%B7%E5%8F%96%E9%A1%B9%E7%9B%AE%E8%AF%A6%E6%83%85-%E7%A7%9F%E6%88%B7%E9%A1%B9%E7%9B%AE">服务项目详情</a></li>
- </ol>
- <p><strong><em>UI 图:</em></strong><br>
- <img src="./assets/%E7%94%A8%E6%88%B7%E9%80%89%E6%8B%A9%E9%A1%B9%E7%9B%AE%E4%B8%8B%E5%8D%95/%E9%80%89%E6%8B%A9%E9%A1%B9%E7%9B%AE.png" alt=""></p>
- <h5 id="创建抢单类型订单推送给技师">创建抢单类型订单,推送给技师 </h5>
- <p><strong><em>后台逻辑:</em></strong></p>
- <ol>
- <li>传递用户服务时间、服务地址、服务项目 id、优惠劵 id</li>
- <li><a href="#%E5%88%9B%E5%BB%BA%E8%AE%A2%E5%8D%95">创建订单</a></li>
- </ol>
- <p><strong><em>UI 图:</em></strong><br>
- <img src="./assets/%E7%94%A8%E6%88%B7%E9%80%89%E6%8B%A9%E9%A1%B9%E7%9B%AE%E4%B8%8B%E5%8D%95/%E4%B8%8B%E5%8D%95%E7%AD%89%E5%BE%85%E6%8A%80%E5%B8%88%E6%8A%A2%E5%8D%95.png" alt=""></p>
- <h5 id="有技师抢单">有技师抢单 </h5>
- <p><strong><em>后台逻辑:</em></strong></p>
- <ol>
- <li>传递技师 id,所抢订单 id,计算路费、技师代金卷等等一些逻辑</li>
- <li><a href="#%E7%94%A8%E6%88%B7%E5%8F%96%E6%B6%88%E8%AE%A2%E5%8D%95">用户取消订单</a></li>
- </ol>
- <p><strong><em>UI 图:</em></strong><br>
- <img src="./assets/%E7%94%A8%E6%88%B7%E9%80%89%E6%8B%A9%E9%A1%B9%E7%9B%AE%E4%B8%8B%E5%8D%95/%E6%9C%89%E6%8A%80%E5%B8%88%E6%8A%A2%E5%8D%95.png" alt=""></p>
- <h5 id="无技师抢单">无技师抢单 </h5>
- <p><strong><em>后台逻辑:</em></strong></p>
- <ol>
- <li>用户的抢单类型的订单无技师去抢,客服介入,联系附近技师</li>
- <li>包含超时的情况,记得处理</li>
- <li><a href="#%E7%94%A8%E6%88%B7%E5%8F%96%E6%B6%88%E8%AE%A2%E5%8D%95">用户取消订单</a></li>
- </ol>
- <p><strong><em>UI 图:</em></strong><br>
- <img src="./assets/%E7%94%A8%E6%88%B7%E9%80%89%E6%8B%A9%E9%A1%B9%E7%9B%AE%E4%B8%8B%E5%8D%95/%E6%97%A0%E6%8A%80%E5%B8%88%E6%8A%A2%E5%8D%95.png" alt=""></p>
- <h5 id="用户选择技师-1">用户选择技师 </h5>
- <p><strong><em>后台逻辑:</em></strong></p>
- <ol>
- <li>传递技师 id,所抢订单 id,用户 id,订单费用</li>
- <li>用户选择技师后,3 分钟内不支付,则技师解绑该订单,记得处理</li>
- <li><a href="#%E7%94%A8%E6%88%B7%E5%8F%96%E6%B6%88%E8%AE%A2%E5%8D%95">用户取消订单</a></li>
- <li><a href="#%E6%8C%87%E5%AE%9A%E6%8A%80%E5%B8%88%E4%BF%AE%E6%94%B9%E8%AE%A2%E5%8D%95">指定技师</a></li>
- </ol>
- <p><strong><em>UI 图:</em></strong><br>
- <img src="./assets/%E7%94%A8%E6%88%B7%E9%80%89%E6%8B%A9%E9%A1%B9%E7%9B%AE%E4%B8%8B%E5%8D%95/%E7%94%A8%E6%88%B7%E5%8F%8D%E9%80%89%E6%8A%80%E5%B8%88.png" alt=""></p>
- <h5 id="用户不反选技师">用户不反选技师 </h5>
- <p><strong><em>后台逻辑:</em></strong></p>
- <ol>
- <li>用户不反选技师</li>
- <li><a href="#%E7%94%A8%E6%88%B7%E5%8F%96%E6%B6%88%E8%AE%A2%E5%8D%95">用户取消订单</a></li>
- </ol>
- <p><strong><em>UI 图:</em></strong><br>
- <img src="./assets/%E7%94%A8%E6%88%B7%E9%80%89%E6%8B%A9%E9%A1%B9%E7%9B%AE%E4%B8%8B%E5%8D%95/%E7%94%A8%E6%88%B7%E4%B8%8D%E5%8F%8D%E9%80%89%E6%8A%80%E5%B8%88.png" alt=""></p>
- <h5 id="支付成功-1">支付成功 </h5>
- <p><strong><em>后台逻辑:</em></strong></p>
- <ol>
- <li>订单支付成功,技师和用户的推送提醒</li>
- <li><a href="#%E7%94%A8%E6%88%B7%E5%8F%96%E6%B6%88%E8%AE%A2%E5%8D%95">用户取消订单</a></li>
- </ol>
- <p><strong><em>UI 图:</em></strong><br>
- <img src="./assets/%E7%94%A8%E6%88%B7%E9%80%89%E6%8B%A9%E9%A1%B9%E7%9B%AE%E4%B8%8B%E5%8D%95/%E6%94%AF%E4%BB%98%E6%88%90%E5%8A%9F.png" alt=""></p>
- <h5 id="技师拒绝接单-1">技师拒绝接单 </h5>
- <p><strong><em>后台逻辑:</em></strong></p>
- <ol>
- <li>技师拒绝接单,客服介入,联系技师</li>
- <li><a href="#%E6%8E%A5%E5%8D%95">接单</a></li>
- <li><a href="#%E6%8B%92%E5%8D%95">拒单</a></li>
- <li>客服联系用户,用户接受更改技师或者取消订单</li>
- </ol>
- <p><strong><em>UI 图:</em></strong><br>
- <img src="./assets/%E7%94%A8%E6%88%B7%E9%80%89%E6%8B%A9%E9%A1%B9%E7%9B%AE%E4%B8%8B%E5%8D%95/%E6%8A%80%E5%B8%88%E6%8B%92%E7%BB%9D%E6%8E%A5%E5%8D%95.png" alt=""></p>
- <h5 id="支付失败-1">支付失败 </h5>
- <p><strong><em>后台逻辑:</em></strong></p>
- <ol>
- <li>支付失败,订单状态为待付款</li>
- <li>用户取消订单、选择技师、再次付款。存在超时的以及时间差的处理</li>
- <li><a href="#%E7%94%A8%E6%88%B7%E5%8F%96%E6%B6%88%E8%AE%A2%E5%8D%95">用户取消订单</a></li>
- <li><a href="#%E8%8E%B7%E5%8F%96%E6%94%AF%E4%BB%98%E9%85%8D%E7%BD%AE">支付订单</a></li>
- </ol>
- <p><strong><em>UI 图:</em></strong><br>
- <img src="./assets/%E7%94%A8%E6%88%B7%E9%80%89%E6%8B%A9%E9%A1%B9%E7%9B%AE%E4%B8%8B%E5%8D%95/%E6%94%AF%E4%BB%98%E5%A4%B1%E8%B4%A5.png" alt=""></p>
- <h5 id="技师出发">技师出发 </h5>
- <p><strong><em>后台逻辑:</em></strong></p>
- <ol>
- <li>技师出发,用户推送提醒</li>
- <li><a href="#%E7%94%A8%E6%88%B7%E5%8F%96%E6%B6%88%E8%AE%A2%E5%8D%95">用取消订单</a></li>
- </ol>
- </div>
- <div class="md-sidebar-toc">
- <div class="md-toc">
- <details style="padding:0;;padding-left:0px;" open="">
- <summary class="md-toc-link-wrapper">
- <a href="#选择技师下单流程" class="md-toc-link"><p>选择技师下单流程</p>
- </a>
- </summary>
- <div>
- <div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#用户选择技师" class="md-toc-link">
- <p>用户选择技师</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#用户选择项目" class="md-toc-link">
- <p>用户选择项目</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#用户选择可服务时间" class="md-toc-link">
- <p>用户选择可服务时间</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#用户选择营销卷" class="md-toc-link">
- <p>用户选择营销卷</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#用户点击立即结算" class="md-toc-link">
- <p>用户点击立即结算</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#支付失败" class="md-toc-link">
- <p>支付失败</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#支付成功" class="md-toc-link">
- <p>支付成功</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#技师接单" class="md-toc-link">
- <p>技师接单</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#技师拒绝接单" class="md-toc-link">
- <p>技师拒绝接单</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#订单超时" class="md-toc-link">
- <p>订单超时</p>
- </a></div>
- </div>
- </details>
- <details style="padding:0;;padding-left:0px;" open="">
- <summary class="md-toc-link-wrapper">
- <a href="#选择项目下单" class="md-toc-link"><p>选择项目下单</p>
- </a>
- </summary>
- <div>
- <div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#用户选择项目-1" class="md-toc-link">
- <p>用户选择项目</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#创建抢单类型订单推送给技师" class="md-toc-link">
- <p>创建抢单类型订单,推送给技师</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#有技师抢单" class="md-toc-link">
- <p>有技师抢单</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#无技师抢单" class="md-toc-link">
- <p>无技师抢单</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#用户选择技师-1" class="md-toc-link">
- <p>用户选择技师</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#用户不反选技师" class="md-toc-link">
- <p>用户不反选技师</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#支付成功-1" class="md-toc-link">
- <p>支付成功</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#技师拒绝接单-1" class="md-toc-link">
- <p>技师拒绝接单</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#支付失败-1" class="md-toc-link">
- <p>支付失败</p>
- </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
- <a href="#技师出发" class="md-toc-link">
- <p>技师出发</p>
- </a></div>
- </div>
- </details>
-
- </div>
- </div>
- <a id="sidebar-toc-btn">≡</a>
-
-
- <script type="module">
- // TODO: If ZenUML gets integrated into mermaid in the future,
- // we can remove the following lines.
- var MERMAID_CONFIG = ({"startOnLoad":true,"securityLevel":"loose"});
- if (typeof MERMAID_CONFIG !== 'undefined') {
- MERMAID_CONFIG.startOnLoad = false
- MERMAID_CONFIG.cloneCssStyles = false
- MERMAID_CONFIG.theme = "default"
- }
- mermaid.initialize(MERMAID_CONFIG || {})
- if (typeof(window['Reveal']) !== 'undefined') {
- function mermaidRevealHelper(event) {
- var currentSlide = event.currentSlide
- var diagrams = currentSlide.querySelectorAll('.mermaid')
- for (var i = 0; i < diagrams.length; i++) {
- var diagram = diagrams[i]
- if (!diagram.hasAttribute('data-processed')) {
- mermaid.init(null, diagram, ()=> {
- Reveal.slide(event.indexh, event.indexv)
- })
- }
- }
- }
- Reveal.addEventListener('slidetransitionend', mermaidRevealHelper)
- Reveal.addEventListener('ready', mermaidRevealHelper)
- await mermaid.run({
- nodes: document.querySelectorAll('.mermaid')
- })
- } else {
- await mermaid.run({
- nodes: document.querySelectorAll('.mermaid')
- })
- }
- </script>
-
-
-
- <script>
- document.body.setAttribute('html-show-sidebar-toc', true)
- var sidebarTOCBtn = document.getElementById('sidebar-toc-btn')
- sidebarTOCBtn.addEventListener('click', function(event) {
- event.stopPropagation()
- if (document.body.hasAttribute('html-show-sidebar-toc')) {
- document.body.removeAttribute('html-show-sidebar-toc')
- } else {
- document.body.setAttribute('html-show-sidebar-toc', true)
- }
- })
- </script>
-
-
- </body></html>
|