123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377 |
- <!DOCTYPE html>
- <html>
- <head>
- <title>壹管家上门服务</title>
- <meta http-equiv="Content-type" content="text/html; charset=utf-8">
- <meta name="viewport"
- content="width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0, user-scalable=no">
- <meta name="apple-mobile-web-app-capable" content="yes">
- <meta name="apple-mobile-web-app-status-bar-style" content="black-translucent"/>
- <meta http-equiv="Pragma" content="no-cache">
- <meta http-equiv="X-UA-Compatible" content="IE=edge">
- <link rel="stylesheet" type="text/css" href="/webapp/framework/ratchet-2.0.2/dist/css/ratchet.min.css">
- <link rel="stylesheet" type="text/css" href="/webapp/framework/ratchet-2.0.2/dist/css/ratchet-theme-ios.min.css">
- <link rel="stylesheet" type="text/css" href="/webapp/o2o/dist/css/main.css">
- <style>
- html {
- height: 100%;
- }
- body {
- position: relative;
- margin: 0;
- padding: 0;
- width: 100%;
- height: 100%;
- overflow: hidden;
- }
- .spa-fullscreen {
- position: absolute;
- left: 0;
- top: 0;
- margin: 0;
- padding: 0;
- width: 100%;
- visibility: hidden;
- overflow: hidden;
- z-index: -1;
- }
- .spa-page {
- position: absolute;
- left: 0;
- top: 0;
- bottom: 0;
- right: 0;
- margin: 0;
- padding: 0;
- overflow: hidden;
- z-index: 2000;
- -webkit-transform: translateZ(0);
- -webkit-backface-visibility: hidden;
- -webkit-transform-style: preserve-3d;
- }
- .spa-page-bg {
- position: absolute;
- left: 0;
- top: 0;
- bottom: 0;
- right: 0;
- margin: 0;
- padding: 0;
- }
- .spa-page-body {
- position: absolute;
- left: 0;
- top: 0;
- bottom: 0;
- right: 0;
- margin: 0;
- padding: 0;
- overflow: hidden;
- -webkit-transform: translateZ(0);
- -webkit-backface-visibility: hidden;
- -webkit-transform-style: preserve-3d;
- }
- .spa-scroll {
- overflow: auto;
- }
- .spa-scroll-touch {
- -webkit-overflow-scrolling: touch;
- }
- .spa-scroll-x {
- overflow-y: hidden;
- }
- .spa-scroll-y {
- overflow-x: hidden;
- }
- .spa-cover {
- display: none;
- position: absolute;
- left: 0;
- right: 0;
- top: 0;
- bottom: 0;
- text-align: center;
- z-index: 5000;
- }
- .spa-loader {
- position: absolute;
- left: 0;
- right: 0;
- top: 0;
- bottom: 0;
- text-align: center;
- overflow: hidden;
- z-index: 5001;
- }
- .spa-loader-animate {
- position: absolute;
- top: 50%;
- left: 50%;
- }
- .spa-loader-animate .bg {
- position: absolute;
- width: 64px;
- height: 64px;
- margin: 0 auto;
- top: -32px;
- left: -32px;
- border-radius: 50%;
- background: #2C3E50;
- opacity: 0.5;
- }
- .spa-loader-animate .ball {
- display: block;
- float: left;
- padding: 8px;
- margin-top: -8px;
- margin-left: -10px;
- -webkit-border-radius: 50%;
- -moz-border-radius: 50%;
- -ms-border-radius: 50%;
- -o-border-radius: 50%;
- border-radius: 50%;
- }
- .spa-loader-animate span:nth-child(2) {
- background: #16A085;
- -webkit-animation: move-left 800ms ease-in-out infinite alternate;
- -moz-animation: move-left 800ms ease-in-out infinite alternate;
- -ms-animation: move-left 800ms ease-in-out infinite alternate;
- -animation: move-left 800ms ease-in-out infinite alternate;
- }
- .spa-loader-animate .ball:nth-child(3) {
- background: #E67E22;
- -webkit-animation: move-right 800ms ease-in-out infinite alternate;
- -moz-animation: move-right 800ms ease-in-out infinite alternate;
- -ms-animation: move-right 800ms ease-in-out infinite alternate;
- animation: move-right 800ms ease-in-out infinite alternate;
- }
- @-webkit-keyframes move-left {
- to {
- -webkit-transform: translate(20px, 0);
- transform: translate(20px, 0);
- background: #e85932;
- }
- }
- @-webkit-keyframes move-right {
- to {
- -webkit-transform: translate(-20px, 0);
- transform: translate(-20px, 0);
- background: #44bbcc;
- }
- }
- </style>
- <style>
- .spa-page-pay-success .content {
- background: #fff;
- top: 0;
- }
- .spa-page-pay-success .result-content {
- background: #8bc34a;
- padding-top: 38px;
- }
- .spa-page-pay-success .result-info {
- padding-left: 10px;
- padding-right: 10px;
- }
- .spa-page-pay-success .order-result {
- color: #fff;
- font-weight: bold;
- }
- .spa-page-pay-success .success-title p {
- color: #fff;
- }
- .spa-page-pay-success .border-top {
- padding-top: 10px;
- border-top: 1px solid #fff;
- }
- .spa-page-pay-success .border-top p {
- color: #fff;
- }
- .spa-page-pay-success .padding-top-bottom p {
- color: #fff;
- }
- .spa-page-pay-success .btn-group .btn {
- font-size: 16px;
- padding: 10px 25px;
- margin-top: 0;
- background: #8bc34a;
- border-color: #8bc34a;
- }
- .spa-page-pay-success #icon-success {
- display: inline-block;
- vertical-align: middle;
- margin-right: 10px;
- }
- .spa-page-pay-success .btn-group {
- text-align: center;
- background: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4NCjwhLS0gR2VuZXJhdG9yOiBBZG9iZSBJbGx1c3RyYXRvciAxOS4wLjAsIFNWRyBFeHBvcnQgUGx1Zy1JbiAuIFNWRyBWZXJzaW9uOiA2LjAwIEJ1aWxkIDApICAtLT4NCjxzdmcgdmVyc2lvbj0iMS4xIiBpZD0i5Zu+5bGCXzEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4Ig0KCSB2aWV3Qm94PSItMTg3IDE0OCAzNzUgNSIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAtMTg3IDE0OCAzNzUgNTsiIHhtbDpzcGFjZT0icHJlc2VydmUiPg0KPHN0eWxlIHR5cGU9InRleHQvY3NzIj4NCgkuc3Qwe2ZpbGw6IzhCQzM0QTt9DQo8L3N0eWxlPg0KPGcgaWQ9IlhNTElEXzFfIj4NCgk8cG9seWdvbiBpZD0iWE1MSURfMzZfIiBjbGFzcz0ic3QwIiBwb2ludHM9IjE5Mi4zLDE0OCAxODEuMywxNDggMTg2LjksMTUzIAkiLz4NCgk8cG9seWdvbiBpZD0iWE1MSURfMzVfIiBjbGFzcz0ic3QwIiBwb2ludHM9IjE4MS4zLDE0OCAxNzAuMywxNDggMTc1LjksMTUzIAkiLz4NCgk8cG9seWdvbiBpZD0iWE1MSURfMzRfIiBjbGFzcz0ic3QwIiBwb2ludHM9IjE3MC4zLDE0OCAxNTkuMywxNDggMTY0LjksMTUzIAkiLz4NCgk8cG9seWdvbiBpZD0iWE1MSURfMzNfIiBjbGFzcz0ic3QwIiBwb2ludHM9IjE1OS4zLDE0OCAxNDguMywxNDggMTUzLjksMTUzIAkiLz4NCgk8cG9seWdvbiBpZD0iWE1MSURfMzJfIiBjbGFzcz0ic3QwIiBwb2ludHM9IjE0OC4zLDE0OCAxMzcuMywxNDggMTQyLjksMTUzIAkiLz4NCgk8cG9seWdvbiBpZD0iWE1MSURfMzFfIiBjbGFzcz0ic3QwIiBwb2ludHM9IjEzNy4zLDE0OCAxMjYuMywxNDggMTMxLjksMTUzIAkiLz4NCgk8cG9seWdvbiBpZD0iWE1MSURfMzBfIiBjbGFzcz0ic3QwIiBwb2ludHM9IjEyNi4zLDE0OCAxMTUuMywxNDggMTIwLjksMTUzIAkiLz4NCgk8cG9seWdvbiBpZD0iWE1MSURfMjlfIiBjbGFzcz0ic3QwIiBwb2ludHM9IjExNS4zLDE0OCAxMDQuMywxNDggMTA5LjksMTUzIAkiLz4NCgk8cG9seWdvbiBpZD0iWE1MSURfMjhfIiBjbGFzcz0ic3QwIiBwb2ludHM9IjEwNC4zLDE0OCA5My4zLDE0OCA5OC45LDE1MyAJIi8+DQoJPHBvbHlnb24gaWQ9IlhNTElEXzI3XyIgY2xhc3M9InN0MCIgcG9pbnRzPSI5My4zLDE0OCA4Mi4zLDE0OCA4Ny45LDE1MyAJIi8+DQoJPHBvbHlnb24gaWQ9IlhNTElEXzI2XyIgY2xhc3M9InN0MCIgcG9pbnRzPSI4Mi4zLDE0OCA3MS4zLDE0OCA3Ni45LDE1MyAJIi8+DQoJPHBvbHlnb24gaWQ9IlhNTElEXzI1XyIgY2xhc3M9InN0MCIgcG9pbnRzPSI3MS4zLDE0OCA2MC4zLDE0OCA2NS45LDE1MyAJIi8+DQoJPHBvbHlnb24gaWQ9IlhNTElEXzI0XyIgY2xhc3M9InN0MCIgcG9pbnRzPSI2MC4zLDE0OCA0OS4zLDE0OCA1NC45LDE1MyAJIi8+DQoJPHBvbHlnb24gaWQ9IlhNTElEXzIzXyIgY2xhc3M9InN0MCIgcG9pbnRzPSI0OS4zLDE0OCAzOC4zLDE0OCA0My45LDE1MyAJIi8+DQoJPHBvbHlnb24gaWQ9IlhNTElEXzIyXyIgY2xhc3M9InN0MCIgcG9pbnRzPSIzOC4zLDE0OCAyNy4zLDE0OCAzMi45LDE1MyAJIi8+DQoJPHBvbHlnb24gaWQ9IlhNTElEXzIxXyIgY2xhc3M9InN0MCIgcG9pbnRzPSIxNi4zLDE0OCAyMS45LDE1MyAyNy4zLDE0OCAxNi4zLDE0OCAxNi4zLDE0OCA1LjMsMTQ4IDEwLjksMTUzIAkiLz4NCgk8cG9seWdvbiBpZD0iWE1MSURfMjBfIiBjbGFzcz0ic3QwIiBwb2ludHM9IjUuMywxNDggLTUuNywxNDggLTAuMSwxNTMgCSIvPg0KCTxwb2x5Z29uIGlkPSJYTUxJRF8xOV8iIGNsYXNzPSJzdDAiIHBvaW50cz0iLTUuNywxNDggLTE2LjcsMTQ4IC0xMS4xLDE1MyAJIi8+DQoJPHBvbHlnb24gaWQ9IlhNTElEXzE4XyIgY2xhc3M9InN0MCIgcG9pbnRzPSItMTYuNywxNDggLTI3LjcsMTQ4IC0yMi4xLDE1MyAJIi8+DQoJPHBvbHlnb24gaWQ9IlhNTElEXzE3XyIgY2xhc3M9InN0MCIgcG9pbnRzPSItMjcuNywxNDggLTM4LjcsMTQ4IC0zMy4xLDE1MyAJIi8+DQoJPHBvbHlnb24gaWQ9IlhNTElEXzE2XyIgY2xhc3M9InN0MCIgcG9pbnRzPSItMzguNywxNDggLTQ5LjcsMTQ4IC00NC4xLDE1MyAJIi8+DQoJPHBvbHlnb24gaWQ9IlhNTElEXzE1XyIgY2xhc3M9InN0MCIgcG9pbnRzPSItNDkuNywxNDggLTYwLjcsMTQ4IC01NS4xLDE1MyAJIi8+DQoJPHBvbHlnb24gaWQ9IlhNTElEXzE0XyIgY2xhc3M9InN0MCIgcG9pbnRzPSItNjAuNywxNDggLTcxLjcsMTQ4IC02Ni4xLDE1MyAJIi8+DQoJPHBvbHlnb24gaWQ9IlhNTElEXzEzXyIgY2xhc3M9InN0MCIgcG9pbnRzPSItNzEuNywxNDggLTgyLjcsMTQ4IC03Ny4xLDE1MyAJIi8+DQoJPHBvbHlnb24gaWQ9IlhNTElEXzEyXyIgY2xhc3M9InN0MCIgcG9pbnRzPSItODIuNywxNDggLTkzLjcsMTQ4IC04OC4xLDE1MyAJIi8+DQoJPHBvbHlnb24gaWQ9IlhNTElEXzExXyIgY2xhc3M9InN0MCIgcG9pbnRzPSItOTMuNywxNDggLTEwNC43LDE0OCAtOTkuMSwxNTMgCSIvPg0KCTxwb2x5Z29uIGlkPSJYTUxJRF8xMF8iIGNsYXNzPSJzdDAiIHBvaW50cz0iLTEwNC43LDE0OCAtMTE1LjcsMTQ4IC0xMTAuMSwxNTMgCSIvPg0KCTxwb2x5Z29uIGlkPSJYTUxJRF85XyIgY2xhc3M9InN0MCIgcG9pbnRzPSItMTE1LjcsMTQ4IC0xMjYuNywxNDggLTEyMS4xLDE1MyAJIi8+DQoJPHBvbHlnb24gaWQ9IlhNTElEXzhfIiBjbGFzcz0ic3QwIiBwb2ludHM9Ii0xMjYuNywxNDggLTEzNy43LDE0OCAtMTMyLjEsMTUzIAkiLz4NCgk8cG9seWdvbiBpZD0iWE1MSURfN18iIGNsYXNzPSJzdDAiIHBvaW50cz0iLTEzNy43LDE0OCAtMTQ4LjcsMTQ4IC0xNDMuMSwxNTMgCSIvPg0KCTxwb2x5Z29uIGlkPSJYTUxJRF82XyIgY2xhc3M9InN0MCIgcG9pbnRzPSItMTU5LjcsMTQ4LjEgLTE1NC4xLDE1MyAtMTQ4LjcsMTQ4IC0xNTkuNywxNDggLTE1OS43LDE0OCAtMTcwLjcsMTQ4IC0xNjUsMTUzIAkiLz4NCgk8cG9seWdvbiBpZD0iWE1MSURfNV8iIGNsYXNzPSJzdDAiIHBvaW50cz0iLTE3MC43LDE0OCAtMTgxLjcsMTQ4IC0xNzYsMTUzIAkiLz4NCgk8cG9seWdvbiBpZD0iWE1MSURfM18iIGNsYXNzPSJzdDAiIHBvaW50cz0iLTE4NywxNTMgLTE4MS43LDE0OCAtMTkyLjcsMTQ4IAkiLz4NCjwvZz4NCjwvc3ZnPg0K);
- background-position: 0px -1px;
- background-size: 100%;
- background-repeat: no-repeat;
- background-color: #f2f2f2;
- padding-top: 20px;
- padding-bottom: 20px;
- }
- .spa-page-pay-success .j-pay-result {
- display: none;
- }
- .spa-page-pay-success .btn:visited {
- color: #fff;
- }
- </style>
- </head>
- <body>
- <div id="result" class="spa-page spa-page-pay-success">
- <div class="spa-page-body">
- <div class="content">
- <div class="result-content">
- <div class="result-info">
- <div class="padding-top-bottom j-pay-result">
- <p>
- <svg version="1.1" id="icon-success" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
- width="30px" height="30px" viewBox="0 0 30 30" enable-background="new 0 0 30 30" xml:space="preserve">
- <circle fill="#fff" cx="15" cy="15" r="15"/>
- <polygon fill-rule="evenodd" clip-rule="evenodd" fill="#87C34B" points="12.791,18.624 6.604,12.437 4.571,14.469 10.758,20.656
- 12.791,22.689 14.824,20.656 25.828,9.652 23.795,7.619 "/>
- </svg>
- 支付完成,等待保洁师上门为您服务吧!
- </p>
- </div>
- <div class="success-title"><p>壹管家上门服务</p></div>
- <div class="border-top">
- <p>服务:<span id="order-name" class="order-name"></span></p>
- <p>时间:<span id="order-time" class="order-time"></span></p>
- </div>
- <div class="border-top">
- <p>实付: <span id="order-result" class="order-result"></span></p>
- </div>
- </div>
- <div class="box-center btn-group j-pay-btn">
- <a class="btn btn-positive btn-pay">立即支付</a>
- </div>
- <div class="box-center btn-group j-pay-result">
- <a href="/o2o/web/index#myOrder/1" class="btn btn-positive my-order">我的预约</a>
- <a href="/o2o/web/index" class="btn btn-positive btn-home">继续购买</a>
- </div>
- </div>
- </div>
- </div>
- </div>
- <script src="../../../common/js/zepto.min.js"></script>
- <script>
- if (location.search.length > 1) {
- var urlParam = {};
- for (var aItKey, nKeyId = 0, aCouples = location.search.substr(1).split("&"); nKeyId < aCouples.length; nKeyId++) {
- aItKey = aCouples[nKeyId].split("=");
- urlParam[decodeURIComponent(aItKey[0])] = aItKey.length > 1 ? decodeURIComponent(aItKey[1]) : "";
- }
- var amount = urlParam.amount,
- created = urlParam.created,
- bookingTime = urlParam.bookingTime,
- body = urlParam.body,
- isSpecial = urlParam.isSpecial;
- function formatDate(now) {
- var d = new Date(now * 1000);
- var year = d.getFullYear();
- var month = d.getMonth() + 1;
- var date = d.getDate();
- var hour = d.getHours();
- var minute = d.getMinutes();
- return year + '年' + month + '月' + date + '日 ' + hour + ':' + minute;
- }
- created = formatDate(created);
- amount = amount / 100;
- $('#order-name').text(body);
- if (bookingTime != 'undefined') {
- $('#order-time').text(bookingTime);
- } else {
- $('#order-time').parent().hide();
- }
- $('#order-result').text(amount + '元');
- $('.btn-pay').click(function () {
- callpay();
- });
- //调用微信JS api 支付
- function jsApiCall() {
- WeixinJSBridge.invoke(
- 'getBrandWCPayRequest', {
- "appId": urlParam.appId,
- "nonceStr": urlParam.nonceStr,
- "package": 'prepay_id=' + urlParam["package"],
- "signType": urlParam.signType,
- "timeStamp": urlParam.timeStamp.toString(),
- "paySign": urlParam.paySign
- }, function (res) {
- console.log(res);
- if (res.err_msg == "get_brand_wcpay_request:ok") {
- if (isSpecial) {
- location.href = '/o2o/web/index#bargain';
- } else {
- $('.j-pay-btn').hide();
- $('.j-pay-result').show();
- }
- } else if (res.err_msg == "get_brand_wcpay_request:cancel") {
- // alert('取消支付');
- } else {
- alert('支付失败');
- location.href = '/o2o/web/index';
- }
- }
- );
- }
- function callpay() {
- if (typeof WeixinJSBridge == "undefined") {
- if (document.addEventListener) {
- document.addEventListener('WeixinJSBridgeReady', jsApiCall, false);
- } else if (document.attachEvent) {
- document.attachEvent('WeixinJSBridgeReady', jsApiCall);
- document.attachEvent('onWeixinJSBridgeReady', jsApiCall);
- }
- } else {
- jsApiCall();
- }
- }
- // callpay();
- }
- </script>
- </body>
- </html>
|