|
|
|
@ -5,6 +5,7 @@ import 'package:flutter/material.dart';
|
|
|
|
|
import 'package:flutter_qr_reader/flutter_qr_reader.dart';
|
|
|
|
|
import 'package:flutter_qr_reader/qrcode_reader_view.dart';
|
|
|
|
|
import 'package:image_picker/image_picker.dart';
|
|
|
|
|
import 'package:just_audio/just_audio.dart';
|
|
|
|
|
|
|
|
|
|
import 'package:recook/base/base_store_state.dart';
|
|
|
|
|
import 'package:recook/constants/api.dart';
|
|
|
|
@ -20,17 +21,16 @@ import 'package:recook/utils/text_utils.dart';
|
|
|
|
|
// import 'package:flutter_audio_player/flutter_audio_player.dart';
|
|
|
|
|
|
|
|
|
|
class BarcodeScanPage extends StatefulWidget {
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
|
State<BarcodeScanPage> createState() {
|
|
|
|
|
return _BarcodeScanPageState();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class _BarcodeScanPageState extends BaseStoreState<BarcodeScanPage> {
|
|
|
|
|
String barcode = "";
|
|
|
|
|
GlobalKey<QrcodeReaderViewState> _key = GlobalKey();
|
|
|
|
|
final player = AudioPlayer();
|
|
|
|
|
@override
|
|
|
|
|
void initState() {
|
|
|
|
|
super.initState();
|
|
|
|
@ -51,7 +51,8 @@ class _BarcodeScanPageState extends BaseStoreState<BarcodeScanPage> {
|
|
|
|
|
},
|
|
|
|
|
onSelectImage: () async {
|
|
|
|
|
_key.currentState.stopScan();
|
|
|
|
|
var image = await ImagePicker.pickImage(source: ImageSource.gallery);
|
|
|
|
|
var image =
|
|
|
|
|
await ImagePicker.pickImage(source: ImageSource.gallery);
|
|
|
|
|
if (image == null) {
|
|
|
|
|
_key.currentState.startScan();
|
|
|
|
|
return;
|
|
|
|
@ -88,21 +89,18 @@ class _BarcodeScanPageState extends BaseStoreState<BarcodeScanPage> {
|
|
|
|
|
color: lineColor,
|
|
|
|
|
offset: Offset(0, 1),
|
|
|
|
|
blurRadius: 5,
|
|
|
|
|
spreadRadius: 1.0
|
|
|
|
|
),
|
|
|
|
|
spreadRadius: 1.0),
|
|
|
|
|
BoxShadow(
|
|
|
|
|
color: lineColor,
|
|
|
|
|
offset: Offset(0, -1),
|
|
|
|
|
blurRadius: 5,
|
|
|
|
|
spreadRadius: 1.0
|
|
|
|
|
),
|
|
|
|
|
spreadRadius: 1.0),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
width: width * 0.8,
|
|
|
|
|
height: 1.7,
|
|
|
|
|
),
|
|
|
|
|
)
|
|
|
|
|
),
|
|
|
|
|
)),
|
|
|
|
|
],
|
|
|
|
|
),
|
|
|
|
|
);
|
|
|
|
@ -114,7 +112,8 @@ class _BarcodeScanPageState extends BaseStoreState<BarcodeScanPage> {
|
|
|
|
|
_key.currentState.stopScan();
|
|
|
|
|
Future.delayed(Duration(milliseconds: 500), () {
|
|
|
|
|
_getGoodsWithCode(data, (goodsId) {
|
|
|
|
|
AppRouter.pushAndReplaced(globalContext, RouteName.COMMODITY_PAGE, arguments: CommodityDetailPage.setArguments(int.parse(goodsId)));
|
|
|
|
|
AppRouter.pushAndReplaced(globalContext, RouteName.COMMODITY_PAGE,
|
|
|
|
|
arguments: CommodityDetailPage.setArguments(int.parse(goodsId)));
|
|
|
|
|
return;
|
|
|
|
|
}, image: image);
|
|
|
|
|
});
|
|
|
|
@ -124,12 +123,11 @@ class _BarcodeScanPageState extends BaseStoreState<BarcodeScanPage> {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_playSound() async {
|
|
|
|
|
// AudioPlayer.addSound("assets/sound/recook_scan.mp3");
|
|
|
|
|
player.setAsset('assets/sound/recook_scan.mp3');
|
|
|
|
|
player.play();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_getGoodsWithCode(String code, Function callBack, {File image}) async {
|
|
|
|
|
|
|
|
|
|
ResultData resultData = await HttpManager.post(GoodsApi.goods_code_search, {
|
|
|
|
|
"code": code,
|
|
|
|
|
});
|
|
|
|
@ -152,9 +150,11 @@ class _BarcodeScanPageState extends BaseStoreState<BarcodeScanPage> {
|
|
|
|
|
|
|
|
|
|
pushToFailPage(String code, String message, File image) {
|
|
|
|
|
if (image != null) {
|
|
|
|
|
AppRouter.pushAndReplaced(context, RouteName.BARCODE_PHOTOSFAIL, arguments: PhotosFailBarcodePage.setArguments(code, message, image));
|
|
|
|
|
AppRouter.pushAndReplaced(context, RouteName.BARCODE_PHOTOSFAIL,
|
|
|
|
|
arguments: PhotosFailBarcodePage.setArguments(code, message, image));
|
|
|
|
|
} else {
|
|
|
|
|
AppRouter.pushAndReplaced(context, RouteName.BARCODE_FAIL, arguments: FailBarcodePage.setArguments(code, message));
|
|
|
|
|
AppRouter.pushAndReplaced(context, RouteName.BARCODE_FAIL,
|
|
|
|
|
arguments: FailBarcodePage.setArguments(code, message));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
@ -162,5 +162,4 @@ class _BarcodeScanPageState extends BaseStoreState<BarcodeScanPage> {
|
|
|
|
|
void dispose() {
|
|
|
|
|
super.dispose();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|