下单流程.html 41 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643
  1. <!DOCTYPE html><html><head>
  2. <title>下单流程</title>
  3. <meta charset="utf-8">
  4. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  5. <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/katex@0.16.11/dist/katex.min.css">
  6. <script src="https://cdn.jsdelivr.net/npm/mermaid@11.1.1/dist/mermaid.min.js"></script>
  7. <style>
  8. 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}
  9. /* Please visit the URL below for more information: */
  10. /* https://shd101wyy.github.io/markdown-preview-enhanced/#/customize-css */
  11. </style>
  12. <!-- The content below will be included at the end of the <head> element. --><script type="text/javascript">
  13. document.addEventListener("DOMContentLoaded", function () {
  14. // your code here
  15. });
  16. </script></head><body for="html-export">
  17. <div class="crossnote markdown-preview ">
  18. <div class="md-toc">
  19. <details style="padding:0;;padding-left:0px;" open="">
  20. <summary class="md-toc-link-wrapper">
  21. <a href="#选择技师下单流程" class="md-toc-link"><p>选择技师下单流程</p>
  22. </a>
  23. </summary>
  24. <div>
  25. <div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  26. <a href="#用户选择技师" class="md-toc-link">
  27. <p>用户选择技师</p>
  28. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  29. <a href="#用户选择项目" class="md-toc-link">
  30. <p>用户选择项目</p>
  31. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  32. <a href="#用户选择可服务时间" class="md-toc-link">
  33. <p>用户选择可服务时间</p>
  34. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  35. <a href="#用户选择营销卷" class="md-toc-link">
  36. <p>用户选择营销卷</p>
  37. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  38. <a href="#用户点击立即结算" class="md-toc-link">
  39. <p>用户点击立即结算</p>
  40. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  41. <a href="#支付失败" class="md-toc-link">
  42. <p>支付失败</p>
  43. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  44. <a href="#支付成功" class="md-toc-link">
  45. <p>支付成功</p>
  46. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  47. <a href="#技师接单" class="md-toc-link">
  48. <p>技师接单</p>
  49. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  50. <a href="#技师拒绝接单" class="md-toc-link">
  51. <p>技师拒绝接单</p>
  52. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  53. <a href="#订单超时" class="md-toc-link">
  54. <p>订单超时</p>
  55. </a></div>
  56. </div>
  57. </details>
  58. <details style="padding:0;;padding-left:0px;" open="">
  59. <summary class="md-toc-link-wrapper">
  60. <a href="#选择项目下单" class="md-toc-link"><p>选择项目下单</p>
  61. </a>
  62. </summary>
  63. <div>
  64. <div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  65. <a href="#用户选择项目-1" class="md-toc-link">
  66. <p>用户选择项目</p>
  67. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  68. <a href="#创建抢单类型订单推送给技师" class="md-toc-link">
  69. <p>创建抢单类型订单,推送给技师</p>
  70. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  71. <a href="#有技师抢单" class="md-toc-link">
  72. <p>有技师抢单</p>
  73. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  74. <a href="#无技师抢单" class="md-toc-link">
  75. <p>无技师抢单</p>
  76. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  77. <a href="#用户选择技师-1" class="md-toc-link">
  78. <p>用户选择技师</p>
  79. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  80. <a href="#用户不反选技师" class="md-toc-link">
  81. <p>用户不反选技师</p>
  82. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  83. <a href="#支付成功-1" class="md-toc-link">
  84. <p>支付成功</p>
  85. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  86. <a href="#技师拒绝接单-1" class="md-toc-link">
  87. <p>技师拒绝接单</p>
  88. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  89. <a href="#支付失败-1" class="md-toc-link">
  90. <p>支付失败</p>
  91. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  92. <a href="#技师出发" class="md-toc-link">
  93. <p>技师出发</p>
  94. </a></div>
  95. </div>
  96. </details>
  97. </div>
  98. <h4 id="选择技师下单流程">选择技师下单流程 </h4>
  99. <div class="mermaid"> flowchart TD
  100. %% 基础选择流程
  101. Start([开始]) --&gt; A[用户选择服务位置]
  102. A --&gt; B[查询附近技师列表]
  103. B --&gt; C[用户选择技师]
  104. C --&gt; D[展示技师项目列表]
  105. D --&gt; E[用户选择项目]
  106. E --&gt; F[展示项目详情]
  107. F --&gt; G[用户选择服务时间]
  108. G --&gt; H[用户选择营销卷]
  109. H --&gt; I[计算订单费用]
  110. %% 支付流程
  111. I --&gt; J[用户确认下单]
  112. J --&gt; K{支付结果}
  113. %% 支付失败处理
  114. K --&gt;|失败| L[订单状态:待付款]
  115. L --&gt; M[客服跟进]
  116. M --&gt; N{用户选择}
  117. N --&gt;|重新支付| J
  118. N --&gt;|取消订单| O[退款处理]
  119. %% 支付成功处理
  120. K --&gt;|成功| P[订单状态:已支付]
  121. P --&gt; Q[推送订单给技师]
  122. %% 技师处理流程
  123. Q --&gt; R{技师处理}
  124. %% 技师接单分支
  125. R --&gt;|接单| S[订单状态:已接单]
  126. S --&gt; T[技师确认出发]
  127. T --&gt; U[订单状态:已出发]
  128. %% 技师拒单分支
  129. R --&gt;|拒单| V[订单状态:已拒绝]
  130. V --&gt; W[客服处理]
  131. W --&gt; X{处理方案}
  132. X --&gt;|更换技师| Q
  133. X --&gt;|用户退款| O
  134. %% 接单超时处理
  135. R --&gt;|超时| Y[客服跟进]
  136. Y --&gt; Z{处理结果}
  137. Z --&gt;|联系上技师| R
  138. Z --&gt;|更换技师| Q
  139. Z --&gt;|取消订单| O
  140. %% 结束节点
  141. U --&gt; End([开始服务])
  142. O --&gt; Cancel([订单结束])
  143. %% 样式定义
  144. classDef default fill:#f9f9f9,stroke:#333,stroke-width:2px
  145. classDef process fill:#dcedc8,stroke:#33691e
  146. classDef decision fill:#fff3e0,stroke:#e65100
  147. classDef status fill:#e3f2fd,stroke:#0d47a1
  148. %% 应用样式
  149. class K,R,X,Z decision
  150. class L,P,S,U,V status
  151. class A,B,C,D,E,F,G,H,I process
  152. click A,B,C href "#用户选择技师"
  153. click D,E,F href "#用户选择项目"
  154. click G href "#用户选择可服务时间"
  155. click H,I href "#用户选择营销卷"
  156. click J href "#用户点击立即结算"
  157. click L href "#支付失败"
  158. click P href "#支付成功"
  159. click S href "#技师接单"
  160. click V href "#技师拒绝接单"
  161. click X href "#订单超时"
  162. </div><h5 id="用户选择技师">用户选择技师 </h5>
  163. <p><strong><em>后台逻辑:</em></strong></p>
  164. <ol>
  165. <li>获取前端传递的经纬度,根据经纬度查询出附近的技师</li>
  166. <li><a href="#%E8%8E%B7%E5%8F%96%E6%8A%80%E5%B8%88%E5%88%97%E8%A1%A8">获取技师列表</a></li>
  167. <li><a href="#%E8%8E%B7%E5%8F%96%E6%8A%80%E5%B8%88%E8%AF%A6%E6%83%85">获取技师详情</a></li>
  168. </ol>
  169. <p><strong><em>UI 图:</em></strong><br>
  170. <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>
  171. <h5 id="用户选择项目">用户选择项目 </h5>
  172. <p><strong><em>后台逻辑:</em></strong></p>
  173. <ol>
  174. <li>获取前端传递的技师 id,查询出该技师下可服务项目</li>
  175. <li>获取前端传递的区域地址,查询出该区域地址可服务项目(370602 或 156370602)</li>
  176. <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>
  177. <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>
  178. </ol>
  179. <p><strong><em>UI 图:</em></strong><br>
  180. <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>
  181. <h5 id="用户选择可服务时间">用户选择可服务时间 </h5>
  182. <p><strong>前端逻辑</strong></p>
  183. <ol>
  184. <li>获取前端传递的技师 id 和项目 id,查询出该技师下,该项目的可服务时间,以及下单详情信息</li>
  185. <li>获取前端传递的区域地址,计算订单金额(370602 或 156370602)</li>
  186. <li>获取前端传递的路程,计算订单金额</li>
  187. </ol>
  188. <p><strong><em>后台逻辑:</em></strong></p>
  189. <ol>
  190. <li><a href="#%E8%AE%A1%E7%AE%97%E8%AE%A2%E5%8D%95%E9%87%91%E9%A2%9D">计算订单金额</a></li>
  191. <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>
  192. </ol>
  193. <p><strong><em>UI 图:</em></strong><br>
  194. <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>
  195. <h5 id="用户选择营销卷">用户选择营销卷 </h5>
  196. <p><strong><em>后台逻辑:</em></strong></p>
  197. <ol>
  198. <li>获取前端传递的技师 id 和项目 id,查询出该技师下,该项目的可使用的营销卷</li>
  199. <li>选择优惠劵</li>
  200. <li><a href="#%E8%AE%A1%E7%AE%97%E8%AE%A2%E5%8D%95%E9%87%91%E9%A2%9D">计算订单金额</a></li>
  201. </ol>
  202. <p><strong><em>UI 图:</em></strong><br>
  203. <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>
  204. <h5 id="用户点击立即结算">用户点击立即结算 </h5>
  205. <p><strong><em>后台逻辑:</em></strong></p>
  206. <ol>
  207. <li>创建订单,并判断使用的那种支付方式</li>
  208. <li><a href="#%E5%88%9B%E5%BB%BA%E8%AE%A2%E5%8D%95">创建订单</a></li>
  209. <li><a href="#%E8%8E%B7%E5%8F%96%E6%94%AF%E4%BB%98%E9%85%8D%E7%BD%AE">调用支付</a></li>
  210. </ol>
  211. <p><strong><em>UI 图:</em></strong><br>
  212. <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>
  213. <h5 id="支付失败">支付失败 </h5>
  214. <p><strong><em>后台逻辑:</em></strong></p>
  215. <ol>
  216. <li>支付超时、取消支付导致的用户支付失败,极光推送客服用户支付失败</li>
  217. <li><a href="#%E6%94%AF%E4%BB%98%E5%A4%B1%E8%B4%A5">支付失败</a> TODO:??</li>
  218. </ol>
  219. <p><strong><em>UI 图:</em></strong><br>
  220. <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>
  221. <h5 id="支付成功">支付成功 </h5>
  222. <p><strong><em>后台逻辑:</em></strong></p>
  223. <ol>
  224. <li>支付成功,后台更改订单,且极光推送技师接单</li>
  225. <li><a href="#%E6%94%AF%E4%BB%98%E6%88%90%E5%8A%9F">支付成功</a> TODO:??</li>
  226. </ol>
  227. <p><strong><em>UI 图:</em></strong><br>
  228. <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>
  229. <h5 id="技师接单">技师接单 </h5>
  230. <p><strong><em>后台逻辑:</em></strong></p>
  231. <ol>
  232. <li>技师接单,用户同步数据</li>
  233. <li><a href="#%E6%8E%A5%E5%8D%95">技师接单</a></li>
  234. </ol>
  235. <p><strong><em>UI 图:</em></strong><br>
  236. <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>
  237. <h5 id="技师拒绝接单">技师拒绝接单 </h5>
  238. <p><strong><em>后台逻辑:</em></strong></p>
  239. <ol>
  240. <li>技师拒绝接单,客服介入,联系用户,更改技师或者用户取消订单退款</li>
  241. <li><a href="#%E6%8B%92%E7%BB%9D%E6%8E%A5%E5%8D%95">技师拒绝接单</a></li>
  242. </ol>
  243. <p><strong><em>UI 图:</em></strong><br>
  244. <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>
  245. <h5 id="订单超时">订单超时 </h5>
  246. <p><strong><em>后台逻辑:</em></strong></p>
  247. <ol>
  248. <li>技师没有在规定时间内接单,客服介入,联系技师</li>
  249. <li><a href="#%E8%AE%A2%E5%8D%95%E8%B6%85%E6%97%B6">订单超时</a> TODO: 客服介入后,对订单进行处理(更换技师、用户退款、取消订单、转公单等)</li>
  250. </ol>
  251. <h4 id="选择项目下单">选择项目下单 </h4>
  252. <div class="mermaid"> flowchart TD
  253. %% 主流程起点
  254. Start[开始] --&gt; Init[初始化订单]
  255. %% 订单创建阶段
  256. subgraph 订单创建
  257. Init --&gt; A1[获取用户位置]
  258. A1 --&gt; A2[查询区域服务]
  259. A2 --&gt; A3[用户选择服务]
  260. A3 --&gt; A4[选择地址/时间/优惠券]
  261. A4 --&gt; A5[创建空订单]
  262. end
  263. %% 抢单阶段
  264. subgraph 抢单流程
  265. A5 --&gt; B1[进入抢单池]
  266. B1 --&gt; B2[推送给技师]
  267. B2 --&gt; B3{是否有技师抢单?}
  268. B3 --&gt;|是| B4[展示技师列表]
  269. B3 --&gt;|否| B5[等待5-8分钟]
  270. B5 --&gt; B6[客服介入]
  271. end
  272. %% 用户选择阶段
  273. subgraph 用户选择
  274. B4 --&gt; C1{用户是否选择?}
  275. C1 --&gt;|是| C2[锁定技师]
  276. C1 --&gt;|否| C3[等待30分钟]
  277. C2 --&gt; C4[计算费用]
  278. C3 --&gt; B6
  279. end
  280. %% 支付阶段
  281. subgraph 支付流程
  282. C4 --&gt; D1[展示订单详情]
  283. D1 --&gt; D2{用户支付?}
  284. D2 --&gt;|是| D3[支付处理]
  285. D2 --&gt;|否| D4[3分钟超时]
  286. D3 --&gt; D5{支付结果}
  287. D5 --&gt;|成功| D6[更新订单状态]
  288. D5 --&gt;|失败| D7[客服介入]
  289. D4 --&gt; D8[解绑技师]
  290. end
  291. %% 服务阶段
  292. subgraph 服务执行
  293. D6 --&gt; E1[通知技师]
  294. E1 --&gt; jh1[技师拒绝订单]
  295. jh1 --&gt; jh2[客服介入?]
  296. jh2 --&gt;|技师接单| E2[技师出发]
  297. jh2 --&gt;|技师拒单| jh3[客服介入,联系用户?]
  298. jh3 --&gt; jh4[用户接受更换技师]
  299. jh4 --&gt; E2
  300. jh3 --&gt; jh5[用户不接受更换技师]
  301. jh5 --&gt; Cancel
  302. E1 --&gt; E2[技师出发]
  303. E2 --&gt; E3[服务进行中]
  304. E3 --&gt; E4[服务完成]
  305. end
  306. %% 取消订单流程
  307. subgraph 取消处理
  308. Cancel[取消订单] --&gt; F1[客服确认]
  309. F1 --&gt; F2{是否可挽回?}
  310. F2 --&gt;|是| F3[恢复订单]
  311. F2 --&gt;|否| F4[退款处理]
  312. end
  313. %% 异常处理连接
  314. D7 --&gt; Cancel
  315. B6 --&gt; Cancel
  316. D8 --&gt; B1
  317. %% 结束节点
  318. E4 --&gt; End[结束]
  319. F4 --&gt; End
  320. F3 --&gt; D1
  321. %% 样式定义
  322. classDef success fill:#baffc9,stroke:#333,stroke-width:2px;
  323. classDef warning fill:#ffffba,stroke:#333,stroke-width:2px;
  324. classDef error fill:#ffb3ba,stroke:#333,stroke-width:2px;
  325. classDef normal fill:#f9f9f9,stroke:#333,stroke-width:2px;
  326. %% 应用样式
  327. class D6,E4 success;
  328. class D7,B6,Cancel warning;
  329. class F4 error;
  330. class Start,End normal;
  331. click A1,A2,A3 href "#用户选择项目"
  332. click A4,A5,B1,B2 href "#创建抢单类型订单,推送给技师"
  333. click B3,B4 href "#有技师抢单"
  334. click B5,B6 href "#无技师抢单"
  335. click C1,C2,C4 href "#用户选择技师"
  336. click C3,B6 href "#用户不反选技师"
  337. click D2,D3,D6,E1 href "#支付成功"
  338. click jh1,jh2,jh3,jh4,jh5 href "#技师拒绝接单"
  339. click D4,D7,D8 href "#支付失败"
  340. click E2 href "#技师出发"
  341. </div><h5 id="用户选择项目-1">用户选择项目 </h5>
  342. <p><strong><em>后台逻辑:</em></strong></p>
  343. <ol>
  344. <li>传递用户当前位置信息</li>
  345. <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>
  346. <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>
  347. </ol>
  348. <p><strong><em>UI 图:</em></strong><br>
  349. <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>
  350. <h5 id="创建抢单类型订单推送给技师">创建抢单类型订单,推送给技师 </h5>
  351. <p><strong><em>后台逻辑:</em></strong></p>
  352. <ol>
  353. <li>传递用户服务时间、服务地址、服务项目 id、优惠劵 id</li>
  354. <li><a href="#%E5%88%9B%E5%BB%BA%E8%AE%A2%E5%8D%95">创建订单</a></li>
  355. </ol>
  356. <p><strong><em>UI 图:</em></strong><br>
  357. <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>
  358. <h5 id="有技师抢单">有技师抢单 </h5>
  359. <p><strong><em>后台逻辑:</em></strong></p>
  360. <ol>
  361. <li>传递技师 id,所抢订单 id,计算路费、技师代金卷等等一些逻辑</li>
  362. <li><a href="#%E7%94%A8%E6%88%B7%E5%8F%96%E6%B6%88%E8%AE%A2%E5%8D%95">用户取消订单</a></li>
  363. </ol>
  364. <p><strong><em>UI 图:</em></strong><br>
  365. <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>
  366. <h5 id="无技师抢单">无技师抢单 </h5>
  367. <p><strong><em>后台逻辑:</em></strong></p>
  368. <ol>
  369. <li>用户的抢单类型的订单无技师去抢,客服介入,联系附近技师</li>
  370. <li>包含超时的情况,记得处理</li>
  371. <li><a href="#%E7%94%A8%E6%88%B7%E5%8F%96%E6%B6%88%E8%AE%A2%E5%8D%95">用户取消订单</a></li>
  372. </ol>
  373. <p><strong><em>UI 图:</em></strong><br>
  374. <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>
  375. <h5 id="用户选择技师-1">用户选择技师 </h5>
  376. <p><strong><em>后台逻辑:</em></strong></p>
  377. <ol>
  378. <li>传递技师 id,所抢订单 id,用户 id,订单费用</li>
  379. <li>用户选择技师后,3 分钟内不支付,则技师解绑该订单,记得处理</li>
  380. <li><a href="#%E7%94%A8%E6%88%B7%E5%8F%96%E6%B6%88%E8%AE%A2%E5%8D%95">用户取消订单</a></li>
  381. <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>
  382. </ol>
  383. <p><strong><em>UI 图:</em></strong><br>
  384. <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>
  385. <h5 id="用户不反选技师">用户不反选技师 </h5>
  386. <p><strong><em>后台逻辑:</em></strong></p>
  387. <ol>
  388. <li>用户不反选技师</li>
  389. <li><a href="#%E7%94%A8%E6%88%B7%E5%8F%96%E6%B6%88%E8%AE%A2%E5%8D%95">用户取消订单</a></li>
  390. </ol>
  391. <p><strong><em>UI 图:</em></strong><br>
  392. <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>
  393. <h5 id="支付成功-1">支付成功 </h5>
  394. <p><strong><em>后台逻辑:</em></strong></p>
  395. <ol>
  396. <li>订单支付成功,技师和用户的推送提醒</li>
  397. <li><a href="#%E7%94%A8%E6%88%B7%E5%8F%96%E6%B6%88%E8%AE%A2%E5%8D%95">用户取消订单</a></li>
  398. </ol>
  399. <p><strong><em>UI 图:</em></strong><br>
  400. <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>
  401. <h5 id="技师拒绝接单-1">技师拒绝接单 </h5>
  402. <p><strong><em>后台逻辑:</em></strong></p>
  403. <ol>
  404. <li>技师拒绝接单,客服介入,联系技师</li>
  405. <li><a href="#%E6%8E%A5%E5%8D%95">接单</a></li>
  406. <li><a href="#%E6%8B%92%E5%8D%95">拒单</a></li>
  407. <li>客服联系用户,用户接受更改技师或者取消订单</li>
  408. </ol>
  409. <p><strong><em>UI 图:</em></strong><br>
  410. <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>
  411. <h5 id="支付失败-1">支付失败 </h5>
  412. <p><strong><em>后台逻辑:</em></strong></p>
  413. <ol>
  414. <li>支付失败,订单状态为待付款</li>
  415. <li>用户取消订单、选择技师、再次付款。存在超时的以及时间差的处理</li>
  416. <li><a href="#%E7%94%A8%E6%88%B7%E5%8F%96%E6%B6%88%E8%AE%A2%E5%8D%95">用户取消订单</a></li>
  417. <li><a href="#%E8%8E%B7%E5%8F%96%E6%94%AF%E4%BB%98%E9%85%8D%E7%BD%AE">支付订单</a></li>
  418. </ol>
  419. <p><strong><em>UI 图:</em></strong><br>
  420. <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>
  421. <h5 id="技师出发">技师出发 </h5>
  422. <p><strong><em>后台逻辑:</em></strong></p>
  423. <ol>
  424. <li>技师出发,用户推送提醒</li>
  425. <li><a href="#%E7%94%A8%E6%88%B7%E5%8F%96%E6%B6%88%E8%AE%A2%E5%8D%95">用取消订单</a></li>
  426. </ol>
  427. </div>
  428. <div class="md-sidebar-toc">
  429. <div class="md-toc">
  430. <details style="padding:0;;padding-left:0px;" open="">
  431. <summary class="md-toc-link-wrapper">
  432. <a href="#选择技师下单流程" class="md-toc-link"><p>选择技师下单流程</p>
  433. </a>
  434. </summary>
  435. <div>
  436. <div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  437. <a href="#用户选择技师" class="md-toc-link">
  438. <p>用户选择技师</p>
  439. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  440. <a href="#用户选择项目" class="md-toc-link">
  441. <p>用户选择项目</p>
  442. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  443. <a href="#用户选择可服务时间" class="md-toc-link">
  444. <p>用户选择可服务时间</p>
  445. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  446. <a href="#用户选择营销卷" class="md-toc-link">
  447. <p>用户选择营销卷</p>
  448. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  449. <a href="#用户点击立即结算" class="md-toc-link">
  450. <p>用户点击立即结算</p>
  451. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  452. <a href="#支付失败" class="md-toc-link">
  453. <p>支付失败</p>
  454. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  455. <a href="#支付成功" class="md-toc-link">
  456. <p>支付成功</p>
  457. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  458. <a href="#技师接单" class="md-toc-link">
  459. <p>技师接单</p>
  460. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  461. <a href="#技师拒绝接单" class="md-toc-link">
  462. <p>技师拒绝接单</p>
  463. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  464. <a href="#订单超时" class="md-toc-link">
  465. <p>订单超时</p>
  466. </a></div>
  467. </div>
  468. </details>
  469. <details style="padding:0;;padding-left:0px;" open="">
  470. <summary class="md-toc-link-wrapper">
  471. <a href="#选择项目下单" class="md-toc-link"><p>选择项目下单</p>
  472. </a>
  473. </summary>
  474. <div>
  475. <div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  476. <a href="#用户选择项目-1" class="md-toc-link">
  477. <p>用户选择项目</p>
  478. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  479. <a href="#创建抢单类型订单推送给技师" class="md-toc-link">
  480. <p>创建抢单类型订单,推送给技师</p>
  481. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  482. <a href="#有技师抢单" class="md-toc-link">
  483. <p>有技师抢单</p>
  484. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  485. <a href="#无技师抢单" class="md-toc-link">
  486. <p>无技师抢单</p>
  487. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  488. <a href="#用户选择技师-1" class="md-toc-link">
  489. <p>用户选择技师</p>
  490. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  491. <a href="#用户不反选技师" class="md-toc-link">
  492. <p>用户不反选技师</p>
  493. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  494. <a href="#支付成功-1" class="md-toc-link">
  495. <p>支付成功</p>
  496. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  497. <a href="#技师拒绝接单-1" class="md-toc-link">
  498. <p>技师拒绝接单</p>
  499. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  500. <a href="#支付失败-1" class="md-toc-link">
  501. <p>支付失败</p>
  502. </a></div><div class="md-toc-link-wrapper" style="padding:0;;display:list-item;list-style:square;margin-left:42px">
  503. <a href="#技师出发" class="md-toc-link">
  504. <p>技师出发</p>
  505. </a></div>
  506. </div>
  507. </details>
  508. </div>
  509. </div>
  510. <a id="sidebar-toc-btn">≡</a>
  511. <script type="module">
  512. // TODO: If ZenUML gets integrated into mermaid in the future,
  513. // we can remove the following lines.
  514. var MERMAID_CONFIG = ({"startOnLoad":true,"securityLevel":"loose"});
  515. if (typeof MERMAID_CONFIG !== 'undefined') {
  516. MERMAID_CONFIG.startOnLoad = false
  517. MERMAID_CONFIG.cloneCssStyles = false
  518. MERMAID_CONFIG.theme = "default"
  519. }
  520. mermaid.initialize(MERMAID_CONFIG || {})
  521. if (typeof(window['Reveal']) !== 'undefined') {
  522. function mermaidRevealHelper(event) {
  523. var currentSlide = event.currentSlide
  524. var diagrams = currentSlide.querySelectorAll('.mermaid')
  525. for (var i = 0; i < diagrams.length; i++) {
  526. var diagram = diagrams[i]
  527. if (!diagram.hasAttribute('data-processed')) {
  528. mermaid.init(null, diagram, ()=> {
  529. Reveal.slide(event.indexh, event.indexv)
  530. })
  531. }
  532. }
  533. }
  534. Reveal.addEventListener('slidetransitionend', mermaidRevealHelper)
  535. Reveal.addEventListener('ready', mermaidRevealHelper)
  536. await mermaid.run({
  537. nodes: document.querySelectorAll('.mermaid')
  538. })
  539. } else {
  540. await mermaid.run({
  541. nodes: document.querySelectorAll('.mermaid')
  542. })
  543. }
  544. </script>
  545. <script>
  546. document.body.setAttribute('html-show-sidebar-toc', true)
  547. var sidebarTOCBtn = document.getElementById('sidebar-toc-btn')
  548. sidebarTOCBtn.addEventListener('click', function(event) {
  549. event.stopPropagation()
  550. if (document.body.hasAttribute('html-show-sidebar-toc')) {
  551. document.body.removeAttribute('html-show-sidebar-toc')
  552. } else {
  553. document.body.setAttribute('html-show-sidebar-toc', true)
  554. }
  555. })
  556. </script>
  557. </body></html>