Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in
Toggle navigation
D
doublescreen-front
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
pengguangpu
doublescreen-front
Commits
da16d384
Commit
da16d384
authored
Feb 25, 2020
by
gaodapeng
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fix bugs
parent
7debfeaa
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
281 additions
and
294 deletions
+281
-294
apiurl.js
const/apiurl.js
+1
-1
balance.js
pages/balance/balance.js
+76
-73
home.js
pages/home/home.js
+4
-8
scan.js
pages/scan/scan.js
+64
-77
payUtils.js
utils/payUtils.js
+127
-126
scan.js
utils/scan.js
+9
-9
No files found.
const/apiurl.js
View file @
da16d384
...
...
@@ -10,5 +10,5 @@ export const API_CREATE_ORDER = "order/create";
export
const
API_PAY
=
"pay/micropay"
;
//查询支付结果
export
const
API_QUERY
=
"order/query"
;
//退款接口
export
const
API_REFUND
=
"order/refund"
;
\ No newline at end of file
pages/balance/balance.js
View file @
da16d384
var
api
=
require
(
"../../utils/api.js"
);
var
payUtils
=
require
(
"../../utils/payUtils.js"
);
import
{
ACTION_GO_SCAN
}
from
'../../const/actioncmd'
import
{
ACTION_GO_SCAN
,
ACTION_GO_HOME
}
from
'../../const/actioncmd'
import
{
ACTION_ON_PAY_SUCCESS
}
from
'../../const/actioncmd'
import
{
ACTION_ON_PAY_FAILED
}
from
'../../const/actioncmd'
Page
({
data
:
{
goodsNum
:
0
,
payPrice
:
0.00
,
totalPrice
:
0.00
,
couponPrice
:
0.00
,
qrPayShow
:
false
,
list
:[],
orderNo
:
""
,
isCashierClosed
:
false
,
goodsNum
:
0
,
payPrice
:
0.00
,
totalPrice
:
0.00
,
couponPrice
:
0.00
,
qrPayShow
:
false
,
list
:
[],
orderNo
:
""
,
isCashierClosed
:
false
,
isPaying
:
false
,
},
onLoad
(
options
)
{
...
...
@@ -21,7 +21,7 @@ Page({
var
totalPrice
=
options
.
totalPrice
var
totalDisc
=
options
.
totalDisc
this
.
setData
({
list
:
options
.
goods
,
list
:
options
.
goods
,
});
if
(
totalQuantity
!=
null
)
{
...
...
@@ -46,7 +46,7 @@ Page({
success
:
function
(
res
)
{
console
.
log
(
"商品信息 ===》 "
+
JSON
.
stringify
(
res
));
context
.
setData
({
list
:
res
.
data
list
:
res
.
data
})
},
fail
:
function
(
res
)
{
...
...
@@ -59,15 +59,18 @@ Page({
},
onShow
(){
onShow
()
{
my
.
ix
.
onBuddyMessage
({
success
:
(
res
)
=>
{
console
.
info
(
`onBuddyMessage success:
${
JSON
.
stringify
(
res
)}
`
);
if
(
res
.
action
==
ACTION_GO_SCAN
)
{
//返回扫码页
if
(
res
.
action
==
ACTION_GO_SCAN
)
{
//返回扫码页
//增加跳转回去的内容
my
.
navigateBack
();
}
else
{
//未知指令
}
else
if
(
res
.
action
==
ACTION_GO_HOME
)
{
//去首页
my
.
reLaunch
({
url
:
"/pages/home/home"
,
});
}
}
});
...
...
@@ -83,19 +86,19 @@ Page({
* @todo 支付结果的获取
* @todo 跳转数据的保存
*/
startPay
(){
startPay
()
{
//开始loading
my
.
showLoading
({});
//获取order
var
payAmount
=
payUtils
.
yuan2Fen
(
this
.
data
.
payPrice
);
payUtils
.
getOrder
(
/*payAmount*/
1
,
this
.
data
.
list
,
function
(
res
)
{
if
(
res
!=
null
)
{
payUtils
.
getOrder
(
/*payAmount*/
1
,
this
.
data
.
list
,
function
(
res
)
{
if
(
res
!=
null
)
{
console
.
log
(
"callback调用,res="
+
JSON
.
stringify
(
res
));
if
(
res
.
resultCode
==
1
)
{
if
(
res
.
resultCode
==
1
)
{
this
.
setData
({
orderNo
:
res
.
data
orderNo
:
res
.
data
});
this
.
payWithOpenCashier
(
res
.
data
);
}
...
...
@@ -106,8 +109,8 @@ Page({
/**
* 打开收银台,进行扫码收款
*/
payWithOpenCashier
(){
try
{
payWithOpenCashier
()
{
try
{
console
.
info
(
"收银台版本"
+
my
.
ix
.
getVersionSync
({
packageName
:
'zoloz.phone.android.alipay.com.dragonfly'
}).
versionName
);
...
...
@@ -125,7 +128,7 @@ Page({
this
.
data
.
isCashierClosed
=
true
;
this
.
doPay
(
this
.
data
.
orderNo
,
res
.
barCode
);
}
},
fail
:
(
res
)
=>
{
},
fail
:
(
res
)
=>
{
my
.
showToast
({
type
:
'exception'
,
content
:
api
.
decodeErrorMessage
(
res
.
error
),
...
...
@@ -166,29 +169,29 @@ Page({
else
console
.
log
(
'RESULT: '
+
res
.
bizType
);
});
}
catch
(
err
)
{
}
catch
(
err
)
{
console
.
log
(
"收银台启动回调 异常==>"
+
JSON
.
stringify
(
err
));
}
},
//调用收款接口
//调用收款接口
doPay
(
orderNo
,
payCode
)
{
console
.
log
(
"doPay调用"
);
this
.
setData
({
isPaying
:
true
});
this
.
setData
({
isPaying
:
true
});
//使用barCode来当面付
var
payAmount
=
payUtils
.
yuan2Fen
(
this
.
data
.
payPrice
);
payUtils
.
startPay
(
orderNo
,
payCode
,
/*payAmount*/
1
,
this
.
data
.
list
,
function
(
res
)
{
payUtils
.
startPay
(
orderNo
,
payCode
,
/*payAmount*/
1
,
this
.
data
.
list
,
function
(
res
)
{
my
.
hideLoading
();
console
.
log
(
"支付回调 ===>"
+
JSON
.
stringify
(
res
));
this
.
setData
({
isPaying
:
false
});
if
(
res
==
null
)
{
this
.
setData
({
isPaying
:
false
});
if
(
res
==
null
)
{
return
;
}
if
(
res
.
resultCode
==
1
)
{
if
(
res
.
resultCode
==
1
)
{
//成功
console
.
log
(
"支付回调成功,跳转 "
);
console
.
log
(
"支付回调成功,跳转 "
);
// if(data.isCashierClosed == true){
my
.
ix
.
offCashierEventReceive
();
this
.
saveData
(
this
.
data
.
list
,
res
.
data
);
...
...
pages/home/home.js
View file @
da16d384
var
api
=
require
(
"../../utils/api.js"
);
import
{
Page
}
from
'../../utils/scan'
;
import
{
API_USE_COUPON
}
from
'../../const/apiurl'
import
{
API_REFUND
}
from
'../../const/apiurl'
import
{
ACTION_GO_SCAN
}
from
'../../const/actioncmd'
import
{
ACTION_GET_ACCOUNT
}
from
'../../const/actioncmd'
import
{
ACTION_DIRECT_PAYMENT
}
from
'../../const/actioncmd'
...
...
@@ -10,7 +11,6 @@ import { ACTION_REFUND } from '../../const/actioncmd'
import
{
ACTION_REFUND_FAILED
}
from
'../../const/actioncmd'
import
{
ACTION_REFUND_SUCCESS
}
from
'../../const/actioncmd'
import
{
ACTION_PRINT_LAST_ORDER
}
from
'../../const/actioncmd'
import
{
API_REFUND
}
from
'../../const/apiurl'
Page
({
...
...
@@ -118,6 +118,7 @@ Page({
dialogResultFailureRemind
:
"退款失败"
,
dialogResultFailureText
:
"退款失败!无效的订单码"
,
});
console
.
log
(
"ACTION_REFUND"
);
}
else
if
(
res
.
action
==
ACTION_GO_HOME
)
{
//home界面收到,则返回界面上
...
...
@@ -315,13 +316,7 @@ Page({
});
},
//增加扫码内容,以及退款等操作的内容
onKeyPress
(
r
)
{
//只有在弹窗出现时才扫码
if
(
this
.
data
.
scanDialogDisplay
>
0
)
{
this
.
refund
(
r
);
}
},
//退款
refund
(
barcode
)
{
...
...
@@ -402,4 +397,5 @@ Page({
});
pages/scan/scan.js
View file @
da16d384
var
api
=
require
(
"../../utils/api.js"
);
import
{
Page
}
from
'../../utils/scan'
;
import
{
API_SCAN
}
from
'../../const/apiurl'
import
{
API_USE_COUPON
}
from
'../../const/apiurl'
import
{
API_SCAN
}
from
'../../const/apiurl'
import
{
API_USE_COUPON
}
from
'../../const/apiurl'
import
{
ACTION_GOODS
}
from
'../../const/actioncmd'
import
{
ACTION_REQUEST_GOOD_INFO
}
from
'../../const/actioncmd'
import
{
ACTION_GO_BALANCE
}
from
'../../const/actioncmd'
...
...
@@ -13,14 +13,14 @@ Page({
//单位是元
totalPrice
:
0.00
,
totalQuantity
:
0
,
totalDisc
:
0.00
,
memberPhone
:
''
,
memberPoint
:
0
totalDisc
:
0.00
,
memberPhone
:
''
,
memberPoint
:
0
},
onLoad
:
function
(
options
)
{
var
barcode
=
options
.
barcode
if
(
barcode
!=
null
)
{
if
(
barcode
!=
null
)
{
console
.
log
(
"首页传递过来的商品条码是 "
+
barcode
);
this
.
getGoodInfoByBarcode
(
barcode
)
}
...
...
@@ -45,24 +45,10 @@ Page({
}
else
if
(
res
.
action
==
ACTION_GO_BALANCE
)
{
//去结算页面
context
.
goBalance
();
my
.
ix
.
sendBuddyMessage
({
target
:
getApp
().
globalData
.
backScreenAppId
,
data
:
{
action
:
ACTION_GO_BALANCE
,
data
:
null
},
success
:
(
res
)
=>
{
console
.
log
(
"发送商品数据到后屏小程序成功 ===》"
+
JSON
.
stringify
(
res
));
},
fail
:
(
res
)
=>
{
console
.
log
(
"发送商品数据到后屏小程序 失败 ===》 "
+
JSON
.
stringify
(
res
));
//发送失败重试
}
})
}
else
if
(
res
.
action
==
ACTION_REQUEST_GOOD_INFO
){
}
else
if
(
res
.
action
==
ACTION_REQUEST_GOOD_INFO
)
{
//去结算页面
context
.
getGoodInfoByBarcode
(
res
.
data
);
}
else
if
(
res
.
action
==
ACTION_GO_HOME
)
{
}
else
if
(
res
.
action
==
ACTION_GO_HOME
)
{
//去首页
my
.
reLaunch
({
url
:
"/pages/home/home"
,
...
...
@@ -140,9 +126,9 @@ Page({
//价格 分转元
goodinfo
.
quantity
=
1
;
goodinfo
.
price
=
goodinfo
.
price
/
100
goodinfo
.
salePrice
=
goodinfo
.
salePrice
/
100
goodinfo
.
discnt
=
goodinfo
.
discnt
/
100
goodinfo
.
price
=
goodinfo
.
price
/
100
goodinfo
.
salePrice
=
goodinfo
.
salePrice
/
100
goodinfo
.
discnt
=
goodinfo
.
discnt
/
100
//总数量
let
totalQuantityTemp
=
0
...
...
@@ -155,27 +141,27 @@ Page({
let
goodstemp
=
[]
let
goodtemp
lastgoods
.
forEach
(
function
(
item
,
index
,
array
)
{
if
(
item
.
barcode
==
goodinfo
.
barcode
)
{
if
(
item
.
barcode
==
goodinfo
.
barcode
)
{
let
quantitytemp
=
item
.
quantity
item
.
quantity
=
quantitytemp
+
1
item
.
quantity
=
quantitytemp
+
1
isHasSame
=
true
goodtemp
=
item
}
else
{
}
else
{
totalQuantityTemp
=
totalQuantityTemp
+
item
.
quantity
totalPriceTemp
=
totalPriceTemp
+
item
.
price
*
item
.
quantity
totalPriceTemp
=
totalPriceTemp
+
item
.
price
*
item
.
quantity
goodstemp
.
push
(
item
)
}
})
if
(
isHasSame
)
{
if
(
isHasSame
)
{
totalQuantityTemp
=
totalQuantityTemp
+
goodtemp
.
quantity
totalPriceTemp
=
totalPriceTemp
+
goodtemp
.
price
*
goodtemp
.
quantity
totalPriceTemp
=
totalPriceTemp
+
goodtemp
.
price
*
goodtemp
.
quantity
let
nowgoods
=
[]
nowgoods
.
push
(
goodtemp
);
var
newgoods
=
nowgoods
.
concat
(
goodstemp
)
this
.
setData
({
goods
:
newgoods
})
}
else
{
}
else
{
totalQuantityTemp
=
totalQuantityTemp
+
1
totalPriceTemp
=
totalPriceTemp
+
goodinfo
.
price
let
nowgoods
=
[]
...
...
@@ -185,7 +171,8 @@ Page({
}
//汇总
this
.
setData
({
totalQuantity
:
totalQuantityTemp
,
this
.
setData
({
totalQuantity
:
totalQuantityTemp
,
totalPrice
:
totalPriceTemp
,
})
...
...
@@ -197,18 +184,18 @@ Page({
sendGoodInfoToBack
()
{
let
context
=
this
;
var
commonRequest
=
{
action
:
ACTION_GOODS
,
data
:
this
.
data
action
:
ACTION_GOODS
,
data
:
this
.
data
};
my
.
ix
.
sendBuddyMessage
({
target
:
getApp
().
globalData
.
backScreenAppId
,
data
:
commonRequest
,
success
:
(
res
)
=>
{
console
.
log
(
"发送商品数据到后屏小程序成功 ===》"
+
JSON
.
stringify
(
res
));
console
.
log
(
"发送商品数据到后屏小程序成功 ===》"
+
JSON
.
stringify
(
res
));
},
fail
:
(
res
)
=>
{
console
.
log
(
"发送商品数据到后屏小程序 失败 ===》 "
+
JSON
.
stringify
(
res
));
console
.
log
(
"发送商品数据到后屏小程序 失败 ===》 "
+
JSON
.
stringify
(
res
));
//发送失败重试
context
.
sendGoodInfoToBack
();
}
...
...
utils/payUtils.js
View file @
da16d384
This diff is collapsed.
Click to expand it.
utils/scan.js
View file @
da16d384
...
...
@@ -9,16 +9,16 @@ export default class scan {
if
(
!
page
.
_keyEventListener
)
{
my
.
ix
.
onKeyEventChange
(
page
.
_keyEventListener
=
(
r
)
=>
{
let
cur
=
getCurrentPages
().
slice
(
-
1
)[
0
];
if
(
cur
&&
cur
.
onKeyPress
){
if
(
cur
&&
cur
.
onKeyPress
)
{
if
(
isScaning
==
false
)
{
isScaning
=
true
code
=
(
r
.
keyCode
-
7
)
+
''
code
=
(
r
.
keyCode
-
7
)
+
''
setTimeout
(()
=>
{
cur
.
onKeyPress
.
call
(
cur
,
code
);
isScaning
=
false
},
5
00
);
}
else
{
},
7
00
);
}
else
{
//特殊处理 keycode需要减7
code
=
code
+
(
r
.
keyCode
-
7
)
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment