Merge branch 'master' into backend_nfc
# Conflicts: # lib/core/services/DataService.dart # lib/views/start_up/start_up_view.dart # pubspec.lock # pubspec.yamlbackend_nfc
commit
f8d7e4717f
76
ios/Podfile
76
ios/Podfile
|
|
@ -10,78 +10,32 @@ project 'Runner', {
|
|||
'Release' => :release,
|
||||
}
|
||||
|
||||
def parse_KV_file(file, separator='=')
|
||||
file_abs_path = File.expand_path(file)
|
||||
if !File.exists? file_abs_path
|
||||
return [];
|
||||
def flutter_root
|
||||
generated_xcode_build_settings_path = File.expand_path(File.join('..', 'Flutter', 'Generated.xcconfig'), __FILE__)
|
||||
unless File.exist?(generated_xcode_build_settings_path)
|
||||
raise "#{generated_xcode_build_settings_path} must exist. If you're running pod install manually, make sure flutter pub get is executed first"
|
||||
end
|
||||
generated_key_values = {}
|
||||
skip_line_start_symbols = ["#", "/"]
|
||||
File.foreach(file_abs_path) do |line|
|
||||
next if skip_line_start_symbols.any? { |symbol| line =~ /^\s*#{symbol}/ }
|
||||
plugin = line.split(pattern=separator)
|
||||
if plugin.length == 2
|
||||
podname = plugin[0].strip()
|
||||
path = plugin[1].strip()
|
||||
podpath = File.expand_path("#{path}", file_abs_path)
|
||||
generated_key_values[podname] = podpath
|
||||
else
|
||||
puts "Invalid plugin specification: #{line}"
|
||||
end
|
||||
|
||||
File.foreach(generated_xcode_build_settings_path) do |line|
|
||||
matches = line.match(/FLUTTER_ROOT\=(.*)/)
|
||||
return matches[1].strip if matches
|
||||
end
|
||||
generated_key_values
|
||||
raise "FLUTTER_ROOT not found in #{generated_xcode_build_settings_path}. Try deleting Generated.xcconfig, then run flutter pub get"
|
||||
end
|
||||
|
||||
require File.expand_path(File.join('packages', 'flutter_tools', 'bin', 'podhelper'), flutter_root)
|
||||
|
||||
flutter_ios_podfile_setup
|
||||
|
||||
target 'Runner' do
|
||||
use_frameworks!
|
||||
use_modular_headers!
|
||||
|
||||
# Flutter Pod
|
||||
|
||||
copied_flutter_dir = File.join(__dir__, 'Flutter')
|
||||
copied_framework_path = File.join(copied_flutter_dir, 'Flutter.framework')
|
||||
copied_podspec_path = File.join(copied_flutter_dir, 'Flutter.podspec')
|
||||
unless File.exist?(copied_framework_path) && File.exist?(copied_podspec_path)
|
||||
# Copy Flutter.framework and Flutter.podspec to Flutter/ to have something to link against if the xcode backend script has not run yet.
|
||||
# That script will copy the correct debug/profile/release version of the framework based on the currently selected Xcode configuration.
|
||||
# CocoaPods will not embed the framework on pod install (before any build phases can generate) if the dylib does not exist.
|
||||
|
||||
generated_xcode_build_settings_path = File.join(copied_flutter_dir, 'Generated.xcconfig')
|
||||
unless File.exist?(generated_xcode_build_settings_path)
|
||||
raise "Generated.xcconfig must exist. If you're running pod install manually, make sure flutter pub get is executed first"
|
||||
end
|
||||
generated_xcode_build_settings = parse_KV_file(generated_xcode_build_settings_path)
|
||||
cached_framework_dir = generated_xcode_build_settings['FLUTTER_FRAMEWORK_DIR'];
|
||||
|
||||
unless File.exist?(copied_framework_path)
|
||||
FileUtils.cp_r(File.join(cached_framework_dir, 'Flutter.framework'), copied_flutter_dir)
|
||||
end
|
||||
unless File.exist?(copied_podspec_path)
|
||||
FileUtils.cp(File.join(cached_framework_dir, 'Flutter.podspec'), copied_flutter_dir)
|
||||
end
|
||||
end
|
||||
|
||||
# Keep pod path relative so it can be checked into Podfile.lock.
|
||||
pod 'Flutter', :path => 'Flutter'
|
||||
|
||||
# Plugin Pods
|
||||
|
||||
# Prepare symlinks folder. We use symlinks to avoid having Podfile.lock
|
||||
# referring to absolute paths on developers' machines.
|
||||
system('rm -rf .symlinks')
|
||||
system('mkdir -p .symlinks/plugins')
|
||||
plugin_pods = parse_KV_file('../.flutter-plugins')
|
||||
plugin_pods.each do |name, path|
|
||||
symlink = File.join('.symlinks', 'plugins', name)
|
||||
File.symlink(path, symlink)
|
||||
pod name, :path => File.join(symlink, 'ios')
|
||||
end
|
||||
flutter_install_all_ios_pods File.dirname(File.realpath(__FILE__))
|
||||
end
|
||||
|
||||
post_install do |installer|
|
||||
installer.pods_project.targets.each do |target|
|
||||
target.build_configurations.each do |config|
|
||||
config.build_settings['ENABLE_BITCODE'] = 'NO'
|
||||
end
|
||||
flutter_additional_ios_build_settings(target)
|
||||
end
|
||||
end
|
||||
|
|
|
|||
|
|
@ -14,28 +14,14 @@ PODS:
|
|||
- MTBBarcodeScanner (5.0.11)
|
||||
- path_provider (0.0.1):
|
||||
- Flutter
|
||||
- path_provider_linux (0.0.1):
|
||||
- Flutter
|
||||
- path_provider_macos (0.0.1):
|
||||
- Flutter
|
||||
- shared_preferences (0.0.1):
|
||||
- Flutter
|
||||
- shared_preferences_macos (0.0.1):
|
||||
- sqflite (0.0.2):
|
||||
- Flutter
|
||||
- shared_preferences_web (0.0.1):
|
||||
- Flutter
|
||||
- sqflite (0.0.1):
|
||||
- Flutter
|
||||
- FMDB (~> 2.7.2)
|
||||
- FMDB (>= 2.7.5)
|
||||
- SwiftProtobuf (1.9.0)
|
||||
- url_launcher (0.0.1):
|
||||
- Flutter
|
||||
- url_launcher_linux (0.0.1):
|
||||
- Flutter
|
||||
- url_launcher_macos (0.0.1):
|
||||
- Flutter
|
||||
- url_launcher_web (0.0.1):
|
||||
- Flutter
|
||||
|
||||
DEPENDENCIES:
|
||||
- barcode_scan (from `.symlinks/plugins/barcode_scan/ios`)
|
||||
|
|
@ -43,16 +29,9 @@ DEPENDENCIES:
|
|||
- esys_flutter_share (from `.symlinks/plugins/esys_flutter_share/ios`)
|
||||
- Flutter (from `Flutter`)
|
||||
- path_provider (from `.symlinks/plugins/path_provider/ios`)
|
||||
- path_provider_linux (from `.symlinks/plugins/path_provider_linux/ios`)
|
||||
- path_provider_macos (from `.symlinks/plugins/path_provider_macos/ios`)
|
||||
- shared_preferences (from `.symlinks/plugins/shared_preferences/ios`)
|
||||
- shared_preferences_macos (from `.symlinks/plugins/shared_preferences_macos/ios`)
|
||||
- shared_preferences_web (from `.symlinks/plugins/shared_preferences_web/ios`)
|
||||
- sqflite (from `.symlinks/plugins/sqflite/ios`)
|
||||
- url_launcher (from `.symlinks/plugins/url_launcher/ios`)
|
||||
- url_launcher_linux (from `.symlinks/plugins/url_launcher_linux/ios`)
|
||||
- url_launcher_macos (from `.symlinks/plugins/url_launcher_macos/ios`)
|
||||
- url_launcher_web (from `.symlinks/plugins/url_launcher_web/ios`)
|
||||
|
||||
SPEC REPOS:
|
||||
trunk:
|
||||
|
|
@ -71,26 +50,12 @@ EXTERNAL SOURCES:
|
|||
:path: Flutter
|
||||
path_provider:
|
||||
:path: ".symlinks/plugins/path_provider/ios"
|
||||
path_provider_linux:
|
||||
:path: ".symlinks/plugins/path_provider_linux/ios"
|
||||
path_provider_macos:
|
||||
:path: ".symlinks/plugins/path_provider_macos/ios"
|
||||
shared_preferences:
|
||||
:path: ".symlinks/plugins/shared_preferences/ios"
|
||||
shared_preferences_macos:
|
||||
:path: ".symlinks/plugins/shared_preferences_macos/ios"
|
||||
shared_preferences_web:
|
||||
:path: ".symlinks/plugins/shared_preferences_web/ios"
|
||||
sqflite:
|
||||
:path: ".symlinks/plugins/sqflite/ios"
|
||||
url_launcher:
|
||||
:path: ".symlinks/plugins/url_launcher/ios"
|
||||
url_launcher_linux:
|
||||
:path: ".symlinks/plugins/url_launcher_linux/ios"
|
||||
url_launcher_macos:
|
||||
:path: ".symlinks/plugins/url_launcher_macos/ios"
|
||||
url_launcher_web:
|
||||
:path: ".symlinks/plugins/url_launcher_web/ios"
|
||||
|
||||
SPEC CHECKSUMS:
|
||||
barcode_scan: a5c27959edfafaa0c771905bad0b29d6d39e4479
|
||||
|
|
@ -100,18 +65,11 @@ SPEC CHECKSUMS:
|
|||
FMDB: 2ce00b547f966261cd18927a3ddb07cb6f3db82a
|
||||
MTBBarcodeScanner: f453b33c4b7dfe545d8c6484ed744d55671788cb
|
||||
path_provider: abfe2b5c733d04e238b0d8691db0cfd63a27a93c
|
||||
path_provider_linux: 4d630dc393e1f20364f3e3b4a2ff41d9674a84e4
|
||||
path_provider_macos: f760a3c5b04357c380e2fddb6f9db6f3015897e0
|
||||
shared_preferences: af6bfa751691cdc24be3045c43ec037377ada40d
|
||||
shared_preferences_macos: f3f29b71ccbb56bf40c9dd6396c9acf15e214087
|
||||
shared_preferences_web: 141cce0c3ed1a1c5bf2a0e44f52d31eeb66e5ea9
|
||||
sqflite: 4001a31ff81d210346b500c55b17f4d6c7589dd0
|
||||
sqflite: 6d358c025f5b867b29ed92fc697fd34924e11904
|
||||
SwiftProtobuf: ecbec1be9036d15655f6b3443a1c4ea693c97932
|
||||
url_launcher: 6fef411d543ceb26efce54b05a0a40bfd74cbbef
|
||||
url_launcher_linux: ac237cb7a8058736e4aae38bdbcc748a4b394cc0
|
||||
url_launcher_macos: fd7894421cd39320dce5f292fc99ea9270b2a313
|
||||
url_launcher_web: e5527357f037c87560776e36436bf2b0288b965c
|
||||
|
||||
PODFILE CHECKSUM: c34e2287a9ccaa606aeceab922830efb9a6ff69a
|
||||
PODFILE CHECKSUM: aafe91acc616949ddb318b77800a7f51bffa2a4c
|
||||
|
||||
COCOAPODS: 1.8.4
|
||||
|
|
|
|||
|
|
@ -335,7 +335,6 @@
|
|||
/* Begin XCBuildConfiguration section */
|
||||
249021D3217E4FDB00AE95B9 /* Profile */ = {
|
||||
isa = XCBuildConfiguration;
|
||||
baseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */;
|
||||
buildSettings = {
|
||||
ALWAYS_SEARCH_USER_PATHS = NO;
|
||||
CLANG_ANALYZER_NONNULL = YES;
|
||||
|
|
@ -417,7 +416,6 @@
|
|||
};
|
||||
97C147031CF9000F007C117D /* Debug */ = {
|
||||
isa = XCBuildConfiguration;
|
||||
baseConfigurationReference = 9740EEB21CF90195004384FC /* Debug.xcconfig */;
|
||||
buildSettings = {
|
||||
ALWAYS_SEARCH_USER_PATHS = NO;
|
||||
CLANG_ANALYZER_NONNULL = YES;
|
||||
|
|
@ -473,7 +471,6 @@
|
|||
};
|
||||
97C147041CF9000F007C117D /* Release */ = {
|
||||
isa = XCBuildConfiguration;
|
||||
baseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */;
|
||||
buildSettings = {
|
||||
ALWAYS_SEARCH_USER_PATHS = NO;
|
||||
CLANG_ANALYZER_NONNULL = YES;
|
||||
|
|
|
|||
|
|
@ -3,7 +3,8 @@ class CheckItem {
|
|||
final num cnt;
|
||||
final num price;
|
||||
final int articul;
|
||||
CheckItem({this.name, this.cnt, this.price, this.articul});
|
||||
final String excise;
|
||||
CheckItem({this.name, this.cnt, this.price, this.articul, this.excise});
|
||||
|
||||
static CheckItem fromJson(Map<String, dynamic> json) {
|
||||
return CheckItem(
|
||||
|
|
@ -11,6 +12,7 @@ class CheckItem {
|
|||
cnt: json['cnt'],
|
||||
price: json['price'],
|
||||
articul: json['articul'],
|
||||
excise: json['excise'],
|
||||
);
|
||||
}
|
||||
Map<String, dynamic> toJson() =>
|
||||
|
|
@ -18,6 +20,7 @@ class CheckItem {
|
|||
'name': name,
|
||||
'cnt': cnt,
|
||||
'price': price,
|
||||
'articul': articul
|
||||
'articul': articul,
|
||||
'excise' : excise
|
||||
};
|
||||
}
|
||||
|
|
@ -8,8 +8,9 @@ class ProductDao {
|
|||
num total;
|
||||
final Good good;
|
||||
final Service service;
|
||||
final String excise;
|
||||
|
||||
|
||||
ProductDao( {this.name, this.price, this.count, this.total, this.good, this.service });
|
||||
ProductDao( {this.name, this.price, this.count, this.total, this.good, this.service, this.excise });
|
||||
|
||||
}
|
||||
|
|
@ -42,6 +42,11 @@ class DataService extends BaseService {
|
|||
return list.map((e) => Good.fromMap(e)).toList();
|
||||
}
|
||||
|
||||
Future<List<Good>> getGoodsByBarcode ({ String barcode}) async {
|
||||
List<Map<String, dynamic>> list = await _db.queryRowsWithWhere(Goog_tableName, ' $Goog_columnEan = ?', [barcode]);
|
||||
return list.map((e) => Good.fromMap(e)).toList();
|
||||
}
|
||||
|
||||
CheckData _transformProductsToCheckData(
|
||||
{String paymentType, String tradeType, List<ProductDao> items}) {
|
||||
List<CheckItem> itemsList = [];
|
||||
|
|
@ -58,7 +63,9 @@ class DataService extends BaseService {
|
|||
name: el.name ?? 'Позиция №$iterator',
|
||||
cnt: el.count,
|
||||
price: el.price,
|
||||
articul: articul));
|
||||
articul: articul,
|
||||
excise: el.excise,
|
||||
));
|
||||
summ += el.total;
|
||||
iterator++;
|
||||
});
|
||||
|
|
@ -257,6 +264,7 @@ class DataService extends BaseService {
|
|||
if (goods.body.isNotEmpty) {
|
||||
for (var key in goods.body.keys) {
|
||||
Good row = Good.fromJson(goods.body[key]);
|
||||
//log.i(row.toMap());
|
||||
await _db.insert(Goog_tableName, row.toMap());
|
||||
}
|
||||
log.i('Inserted ${goods.body.length} to table $Goog_tableName');
|
||||
|
|
|
|||
|
|
@ -5,6 +5,7 @@ import 'package:aman_kassa_flutter/core/locator.dart';
|
|||
import 'package:aman_kassa_flutter/core/models/dict_dao.dart';
|
||||
import 'package:aman_kassa_flutter/core/models/product_dao.dart';
|
||||
import 'package:aman_kassa_flutter/core/services/DataService.dart';
|
||||
import 'package:aman_kassa_flutter/core/services/dialog_service.dart';
|
||||
import 'package:aman_kassa_flutter/redux/constants/setting_const.dart';
|
||||
import 'package:aman_kassa_flutter/redux/state/kassa_state.dart';
|
||||
import 'package:meta/meta.dart';
|
||||
|
|
@ -20,6 +21,7 @@ class SetKassaStateAction {
|
|||
}
|
||||
|
||||
final DataService _dataService = locator<DataService>();
|
||||
final DialogService _dialogService = locator<DialogService>();
|
||||
|
||||
Future<void> backBottomElement(Store<AppState> store) async {
|
||||
List<DictDao> prevCategories = store.state.kassaState.prevCategories;
|
||||
|
|
@ -43,15 +45,22 @@ ThunkAction<AppState> addCustomProductToKassaItems(String name, int count, doubl
|
|||
}
|
||||
|
||||
|
||||
ThunkAction<AppState> addProductToKassaItems(Good good) {
|
||||
ThunkAction<AppState> addProductToKassaItems(Good good, String excise) {
|
||||
return (Store<AppState> store) async {
|
||||
List<ProductDao> items = store.state.kassaState.kassaItems;
|
||||
int index = items.indexWhere((element) => element.good?.id == good.id);
|
||||
if (index > -1) {
|
||||
int index = items.indexWhere((element) => element.excise == null && element.good?.id == good.id);
|
||||
if(excise !=null) {
|
||||
int existIndex = items.indexWhere((element) => element.excise != null && element.excise == excise);
|
||||
if(existIndex > -1) {
|
||||
_dialogService.showDialog(description: 'Нельзя добавить повторно одинаковые товары');
|
||||
return;
|
||||
}
|
||||
}
|
||||
if (index > -1 && excise == null) {
|
||||
store.dispatch(counterProductFromKassaItems(index, 1));
|
||||
} else {
|
||||
items.add(new ProductDao(
|
||||
name: good.name, good: good, count: 1, price: good.price, total: good.price));
|
||||
name: good.name, good: good, count: 1, price: good.price, total: good.price, excise: excise));
|
||||
store.dispatch(SetKassaStateAction(KassaState(kassaItems: items)));
|
||||
}
|
||||
};
|
||||
|
|
|
|||
|
|
@ -0,0 +1,11 @@
|
|||
// Define a function.
|
||||
void printInteger(int aNumber) {
|
||||
print('The number is $aNumber.'); // Print to console.
|
||||
}
|
||||
|
||||
// This is where the app starts executing.
|
||||
void main() {
|
||||
String dataMatrix = "00000046208262nZ2qnLHODVFWktT";
|
||||
String numberText = dataMatrix.replaceAll(RegExp("[a-zA-Z]"), '');
|
||||
print(int.parse(numberText));
|
||||
}
|
||||
|
|
@ -1,8 +1,11 @@
|
|||
|
||||
import 'package:aman_kassa_flutter/core/entity/Goods.dart';
|
||||
import 'package:aman_kassa_flutter/core/locator.dart';
|
||||
import 'package:aman_kassa_flutter/core/models/product_dao.dart';
|
||||
import 'package:aman_kassa_flutter/core/route_names.dart';
|
||||
import 'package:aman_kassa_flutter/core/services/DataService.dart';
|
||||
import 'package:aman_kassa_flutter/core/services/dialog_service.dart';
|
||||
import 'package:aman_kassa_flutter/core/services/navigator_service.dart';
|
||||
import 'package:aman_kassa_flutter/redux/actions/kassa_actions.dart';
|
||||
import 'package:aman_kassa_flutter/redux/constants/operation_const.dart';
|
||||
import 'package:aman_kassa_flutter/redux/constants/setting_const.dart';
|
||||
import 'package:aman_kassa_flutter/redux/state/kassa_state.dart';
|
||||
|
|
@ -13,12 +16,19 @@ import 'package:aman_kassa_flutter/views/home/tabs/kassaView/CatalogBottomSheet.
|
|||
import 'package:aman_kassa_flutter/views/home/tabs/kassaView/ProductAddBottomSheet.dart';
|
||||
import 'package:aman_kassa_flutter/views/payment/payment_view.dart';
|
||||
import 'package:aman_kassa_flutter/widgets/components/ProductListItem.dart';
|
||||
import 'package:barcode_scan/gen/protos/protos.pb.dart';
|
||||
import 'package:barcode_scan/gen/protos/protos.pbenum.dart';
|
||||
import 'package:barcode_scan/model/scan_options.dart';
|
||||
import 'package:barcode_scan/platform_wrapper.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter/services.dart';
|
||||
import 'package:flutter_redux/flutter_redux.dart';
|
||||
import 'package:material_design_icons_flutter/material_design_icons_flutter.dart';
|
||||
|
||||
class KassaTab extends StatelessWidget {
|
||||
|
||||
final NavigatorService _navigatorService = locator<NavigatorService>();
|
||||
final DialogService _dialogService = locator<DialogService>();
|
||||
final DataService _dataService = locator<DataService>();
|
||||
|
||||
final int index;
|
||||
|
||||
|
|
@ -33,107 +43,132 @@ class KassaTab extends StatelessWidget {
|
|||
|
||||
@override
|
||||
Widget build(BuildContext context) {
|
||||
return Padding(
|
||||
padding: EdgeInsets.all(4),
|
||||
child: Column(
|
||||
children: <Widget>[
|
||||
Row(
|
||||
children: <Widget>[
|
||||
Expanded(
|
||||
child: Padding(
|
||||
padding: const EdgeInsets.all(4.0),
|
||||
child: RaisedButton(
|
||||
padding: EdgeInsets.all(8),
|
||||
color: primaryColor,
|
||||
child: Text(
|
||||
"Добавить",
|
||||
style: buttonBigTitleTextStyle,
|
||||
),
|
||||
onPressed: () { showModalBottomSheetCatalog(context, 'add');},
|
||||
),
|
||||
),
|
||||
),
|
||||
Expanded(
|
||||
child: Padding(
|
||||
padding: const EdgeInsets.all(4.0),
|
||||
child: RaisedButton(
|
||||
padding: EdgeInsets.all(8),
|
||||
color: greenColor,
|
||||
child: Text(
|
||||
"Каталог",
|
||||
style: buttonBigTitleTextStyle,
|
||||
),
|
||||
onPressed: () { showModalBottomSheetCatalog(context, 'catalog');},
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
Expanded(
|
||||
child: Container(
|
||||
child: StoreConnector<AppState, KassaState>(
|
||||
converter: (store) => store.state.kassaState,
|
||||
builder: (context, vm) {
|
||||
return ListView.builder(
|
||||
itemCount: vm.kassaItems.length,
|
||||
itemBuilder: (BuildContext ctxt, int index) =>
|
||||
buildItem(ctxt, index, vm.kassaItems[index]));
|
||||
}
|
||||
),
|
||||
return Scaffold(
|
||||
floatingActionButton: Container(
|
||||
padding: EdgeInsets.only(bottom: 65.0, left: 8.0),
|
||||
child: Align(
|
||||
alignment: Alignment.bottomLeft,
|
||||
child: FloatingActionButton(
|
||||
elevation: 3.0,
|
||||
onPressed: scan,
|
||||
child: Icon(
|
||||
MdiIcons.barcode,
|
||||
size: 30,
|
||||
),
|
||||
),
|
||||
Divider(),
|
||||
Container(
|
||||
margin: const EdgeInsets.symmetric(vertical: 8),
|
||||
child: Row(
|
||||
mainAxisAlignment: MainAxisAlignment.end,
|
||||
),
|
||||
),
|
||||
floatingActionButtonLocation: FloatingActionButtonLocation.centerFloat,
|
||||
body: Padding(
|
||||
padding: const EdgeInsets.all(4),
|
||||
child: Column(
|
||||
children: <Widget>[
|
||||
Row(
|
||||
children: <Widget>[
|
||||
StoreConnector<AppState, KassaState>(
|
||||
converter: (store) => store.state.kassaState,
|
||||
builder: (context, vm) {
|
||||
return Text(totalCalc(vm.kassaItems), style: TextStyle(fontSize: 25));
|
||||
}
|
||||
Expanded(
|
||||
child: Padding(
|
||||
padding: const EdgeInsets.all(4.0),
|
||||
child: RaisedButton(
|
||||
padding: const EdgeInsets.all(8),
|
||||
color: primaryColor,
|
||||
child: Text(
|
||||
"Добавить",
|
||||
style: buttonBigTitleTextStyle,
|
||||
),
|
||||
onPressed: () {
|
||||
showModalBottomSheetCatalog(context, 'add');
|
||||
},
|
||||
),
|
||||
),
|
||||
),
|
||||
Expanded(
|
||||
child: Padding(
|
||||
padding: const EdgeInsets.all(4.0),
|
||||
child: RaisedButton(
|
||||
padding: EdgeInsets.all(8),
|
||||
color: greenColor,
|
||||
child: Text(
|
||||
"Каталог",
|
||||
style: buttonBigTitleTextStyle,
|
||||
),
|
||||
onPressed: () {
|
||||
showModalBottomSheetCatalog(context, 'catalog');
|
||||
},
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
),
|
||||
),
|
||||
Row(
|
||||
children: <Widget>[
|
||||
Expanded(
|
||||
child: Padding(
|
||||
padding: const EdgeInsets.all(4.0),
|
||||
child: RaisedButton(
|
||||
padding: EdgeInsets.all(8),
|
||||
color: redColor,
|
||||
child: Text(
|
||||
"возврат",
|
||||
style: buttonBigTitleTextStyle,
|
||||
),
|
||||
Expanded(
|
||||
child: Container(
|
||||
child: StoreConnector<AppState, KassaState>(
|
||||
converter: (store) => store.state.kassaState,
|
||||
builder: (context, vm) {
|
||||
return ListView.builder(
|
||||
itemCount: vm.kassaItems.length,
|
||||
itemBuilder: (BuildContext ctxt, int index) =>
|
||||
buildItem(ctxt, index, vm.kassaItems[index]));
|
||||
}),
|
||||
),
|
||||
),
|
||||
//Divider(),
|
||||
Container(
|
||||
margin: const EdgeInsets.symmetric(vertical: 8),
|
||||
child: Row(
|
||||
mainAxisAlignment: MainAxisAlignment.end,
|
||||
children: <Widget>[
|
||||
StoreConnector<AppState, KassaState>(
|
||||
converter: (store) => store.state.kassaState,
|
||||
builder: (context, vm) {
|
||||
return Text(totalCalc(vm.kassaItems),
|
||||
style: TextStyle(fontSize: 25));
|
||||
}),
|
||||
],
|
||||
),
|
||||
),
|
||||
Row(
|
||||
children: <Widget>[
|
||||
Expanded(
|
||||
child: Padding(
|
||||
padding: const EdgeInsets.all(4.0),
|
||||
child: RaisedButton(
|
||||
padding: const EdgeInsets.all(8),
|
||||
color: redColor,
|
||||
child: Text(
|
||||
"возврат",
|
||||
style: buttonBigTitleTextStyle,
|
||||
),
|
||||
onPressed: () {
|
||||
_navigatorService.push(PaymentViewRoute,
|
||||
arguments: PaymentModel(
|
||||
mode: SettingModeKassa,
|
||||
operationType: OperationTypeReturn));
|
||||
}),
|
||||
),
|
||||
),
|
||||
Expanded(
|
||||
child: Padding(
|
||||
padding: const EdgeInsets.all(4.0),
|
||||
child: RaisedButton(
|
||||
padding: const EdgeInsets.all(8),
|
||||
color: greenColor,
|
||||
child: Text(
|
||||
"оплата",
|
||||
style: buttonBigTitleTextStyle,
|
||||
),
|
||||
onPressed: () {
|
||||
_navigatorService.push(PaymentViewRoute, arguments: PaymentModel(mode: SettingModeKassa, operationType: OperationTypeReturn) );
|
||||
}
|
||||
),
|
||||
),
|
||||
),
|
||||
Expanded(
|
||||
child: Padding(
|
||||
padding: const EdgeInsets.all(4.0),
|
||||
child: RaisedButton(
|
||||
padding: EdgeInsets.all(8),
|
||||
color: greenColor,
|
||||
child: Text(
|
||||
"оплата",
|
||||
style: buttonBigTitleTextStyle,
|
||||
_navigatorService.push(PaymentViewRoute,
|
||||
arguments: PaymentModel(
|
||||
mode: SettingModeKassa,
|
||||
operationType: OperationTypePay));
|
||||
},
|
||||
),
|
||||
onPressed: () {
|
||||
_navigatorService.push(PaymentViewRoute, arguments: PaymentModel(mode: SettingModeKassa, operationType: OperationTypePay) );
|
||||
},
|
||||
),
|
||||
),
|
||||
),
|
||||
],
|
||||
)
|
||||
],
|
||||
],
|
||||
)
|
||||
],
|
||||
),
|
||||
),
|
||||
);
|
||||
}
|
||||
|
|
@ -141,32 +176,95 @@ class KassaTab extends StatelessWidget {
|
|||
String totalCalc(List<ProductDao> kassaItems) {
|
||||
num total = 0.0;
|
||||
kassaItems.forEach((element) {
|
||||
total+= element.total == null ? 0.0 : element.total.toDouble();
|
||||
total += element.total == null ? 0.0 : element.total.toDouble();
|
||||
});
|
||||
return total.toString();
|
||||
}
|
||||
|
||||
void showModalBottomSheetCatalog(BuildContext context, String action) {
|
||||
showModalBottomSheet(
|
||||
context: context,
|
||||
isScrollControlled: true,
|
||||
backgroundColor: Colors.transparent,
|
||||
builder: (context){
|
||||
return DraggableScrollableSheet(
|
||||
initialChildSize: 0.8,
|
||||
maxChildSize: 0.95,
|
||||
minChildSize: 0.5,
|
||||
builder: (BuildContext context, ScrollController scrollController) {
|
||||
if( action == 'add') {
|
||||
return ProductAddBottomSheet(scrollController: scrollController,);
|
||||
} else {
|
||||
return CatalogBottomSheet(scrollController: scrollController,);
|
||||
Future<void> scan() async {
|
||||
try {
|
||||
var options = ScanOptions(strings: {
|
||||
"cancel": 'Отмена',
|
||||
"flash_on": 'Вкл фонарик',
|
||||
"flash_off": 'Выкл фонарик',
|
||||
});
|
||||
var result = await BarcodeScanner.scan(options: options);
|
||||
// print(result.type); // The result type (barcode, cancelled, failed)
|
||||
// print(result.rawContent); // The barcode content
|
||||
// print(result.format); // The barcode format (as enum)
|
||||
// print(result.formatNote); // If a unknown format was scanned this field contains a note
|
||||
// print(result.rawContent); // content
|
||||
if (result.type == ResultType.Barcode ) {
|
||||
String barcode;
|
||||
String dataMatrix;
|
||||
if(result.format == BarcodeFormat.ean13 || result.format == BarcodeFormat.ean8) {
|
||||
barcode = result.rawContent;
|
||||
} else if( result.format == BarcodeFormat.dataMatrix ) {
|
||||
dataMatrix = result.rawContent;
|
||||
if(dataMatrix!= null && dataMatrix.length >15) {
|
||||
try {
|
||||
String numberText = dataMatrix.substring(0, dataMatrix.length - 15 ).replaceAll(RegExp("[a-zA-Z]"), '');
|
||||
barcode = int.parse(numberText).toString();
|
||||
} catch (e) {
|
||||
|
||||
}
|
||||
},
|
||||
);
|
||||
}
|
||||
// 00000046208262 nZ2qnLH ODVFWktT
|
||||
// 00000046208262 tjKDqfu UzVSeFE5
|
||||
}
|
||||
|
||||
if(barcode != null) {
|
||||
List<Good> goods =
|
||||
await _dataService.getGoodsByBarcode(barcode: barcode);
|
||||
if (goods != null && goods.isNotEmpty) {
|
||||
Redux.store.dispatch(addProductToKassaItems(goods.first, dataMatrix));
|
||||
} else {
|
||||
_dialogService.showDialog(
|
||||
description: 'Товар не найден: $barcode');
|
||||
}
|
||||
} else if (result.type == ResultType.Error) {
|
||||
_dialogService.showDialog(description: 'Не верный формат QR кода');
|
||||
}
|
||||
}
|
||||
} on PlatformException catch (e) {
|
||||
var result = ScanResult.create();
|
||||
result.type = ResultType.Error;
|
||||
result.format = BarcodeFormat.unknown;
|
||||
if (e.code == BarcodeScanner.cameraAccessDenied) {
|
||||
result.rawContent = 'The user did not grant the camera permission!';
|
||||
_dialogService.showDialog(
|
||||
description: 'Нет доступа до камеры устройства');
|
||||
} else {
|
||||
result.rawContent = 'Unknown error: $e';
|
||||
_dialogService.showDialog(description: 'Неизвестная ошибка: $e');
|
||||
}
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
void showModalBottomSheetCatalog(BuildContext context, String action) {
|
||||
showModalBottomSheet(
|
||||
context: context,
|
||||
isScrollControlled: true,
|
||||
backgroundColor: Colors.transparent,
|
||||
builder: (context) {
|
||||
return DraggableScrollableSheet(
|
||||
initialChildSize: 0.8,
|
||||
maxChildSize: 0.95,
|
||||
minChildSize: 0.5,
|
||||
builder: (BuildContext context, ScrollController scrollController) {
|
||||
if (action == 'add') {
|
||||
return ProductAddBottomSheet(
|
||||
scrollController: scrollController,
|
||||
);
|
||||
} else {
|
||||
return CatalogBottomSheet(
|
||||
scrollController: scrollController,
|
||||
);
|
||||
}
|
||||
},
|
||||
);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -95,7 +95,7 @@ class CatalogBottomSheet extends StatelessWidget {
|
|||
.dispatch(selectBottomElement(el.id));
|
||||
} else if (el is Good) {
|
||||
await Redux.store
|
||||
.dispatch(addProductToKassaItems(el));
|
||||
.dispatch(addProductToKassaItems(el, null));
|
||||
Navigator.pop(context);
|
||||
} else if (el is Service) {
|
||||
await Redux.store
|
||||
|
|
|
|||
|
|
@ -52,17 +52,25 @@ class ProductListItem extends StatelessWidget {
|
|||
Expanded(
|
||||
flex: 1,
|
||||
child: Container(
|
||||
//margin: const EdgeInsets.symmetric(horizontal: 4),
|
||||
margin: const EdgeInsets.symmetric(horizontal: 4),
|
||||
child: Row(
|
||||
children: <Widget>[
|
||||
buildClipRect(primaryColor, Icons.remove, () {
|
||||
Redux.store.dispatch(
|
||||
counterProductFromKassaItems(index, -1));
|
||||
}),
|
||||
buildClipRect(primaryColor, Icons.add, () {
|
||||
Redux.store
|
||||
.dispatch(counterProductFromKassaItems(index, 1));
|
||||
}),
|
||||
// buildClipRect(primaryColor, Icons.edit, () {
|
||||
// editCountForm(context, item.count);
|
||||
// }),
|
||||
if(item.excise == null)
|
||||
buildClipRect(primaryColor, Icons.remove, () {
|
||||
Redux.store
|
||||
.dispatch(
|
||||
counterProductFromKassaItems(index, -1));
|
||||
}),
|
||||
if(item.excise == null)
|
||||
buildClipRect(primaryColor, Icons.add, () {
|
||||
Redux.store
|
||||
.dispatch(
|
||||
counterProductFromKassaItems(index, 1));
|
||||
}),
|
||||
|
||||
Expanded(
|
||||
child: Container(),
|
||||
),
|
||||
|
|
@ -103,4 +111,75 @@ class ProductListItem extends StatelessWidget {
|
|||
),
|
||||
);
|
||||
}
|
||||
|
||||
|
||||
void editCountForm(BuildContext context, num count) {
|
||||
showDialog(
|
||||
context: context,
|
||||
builder: (BuildContext context) {
|
||||
return AlertDialog(
|
||||
shape: RoundedRectangleBorder(
|
||||
borderRadius: BorderRadius.circular(5.0),
|
||||
),
|
||||
actionsPadding: const EdgeInsets.only(right: 15, bottom: 5),
|
||||
title: Column(
|
||||
crossAxisAlignment: CrossAxisAlignment.start,
|
||||
children: <Widget>[
|
||||
Text(
|
||||
'request.title',
|
||||
style: TextStyle(fontWeight: FontWeight.bold),
|
||||
),
|
||||
//Divider(),
|
||||
],
|
||||
),
|
||||
content: Column(
|
||||
mainAxisSize: MainAxisSize.min,
|
||||
children: <Widget>[
|
||||
//Text(request.description),
|
||||
TextField(
|
||||
autofocus: true,
|
||||
decoration: InputDecoration(
|
||||
labelText: 'request.description',
|
||||
),
|
||||
//controller: _controller,
|
||||
onSubmitted: (value) {
|
||||
|
||||
},
|
||||
keyboardType: TextInputType.phone,
|
||||
|
||||
)
|
||||
],
|
||||
),
|
||||
actions: <Widget>[
|
||||
Row(
|
||||
children: [
|
||||
RaisedButton(
|
||||
color: redColor,
|
||||
child: Text(
|
||||
'Отмена',
|
||||
style: TextStyle(fontSize: 18),
|
||||
),
|
||||
onPressed: () {
|
||||
Navigator.of(context).pop();
|
||||
},
|
||||
),
|
||||
SizedBox(
|
||||
width: 5,
|
||||
),
|
||||
RaisedButton(
|
||||
color: primaryColor,
|
||||
child: Text(
|
||||
'Сохранить',
|
||||
style: TextStyle(fontSize: 18),
|
||||
),
|
||||
onPressed: () {
|
||||
|
||||
},
|
||||
),
|
||||
],
|
||||
),
|
||||
],
|
||||
);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
|
|
|||
16
pubspec.lock
16
pubspec.lock
|
|
@ -152,7 +152,7 @@ packages:
|
|||
name: flutter_screenutil
|
||||
url: "https://pub.dartlang.org"
|
||||
source: hosted
|
||||
version: "4.0.2+2"
|
||||
version: "4.0.2+5"
|
||||
flutter_test:
|
||||
dependency: "direct dev"
|
||||
description: flutter
|
||||
|
|
@ -169,7 +169,7 @@ packages:
|
|||
name: get_it
|
||||
url: "https://pub.dartlang.org"
|
||||
source: hosted
|
||||
version: "5.0.3"
|
||||
version: "5.0.4"
|
||||
google_fonts:
|
||||
dependency: "direct main"
|
||||
description:
|
||||
|
|
@ -225,7 +225,7 @@ packages:
|
|||
name: material_design_icons_flutter
|
||||
url: "https://pub.dartlang.org"
|
||||
source: hosted
|
||||
version: "4.0.5755"
|
||||
version: "4.0.5855"
|
||||
meta:
|
||||
dependency: transitive
|
||||
description:
|
||||
|
|
@ -253,7 +253,7 @@ packages:
|
|||
name: path_provider
|
||||
url: "https://pub.dartlang.org"
|
||||
source: hosted
|
||||
version: "1.6.24"
|
||||
version: "1.6.27"
|
||||
path_provider_linux:
|
||||
dependency: transitive
|
||||
description:
|
||||
|
|
@ -267,7 +267,7 @@ packages:
|
|||
name: path_provider_macos
|
||||
url: "https://pub.dartlang.org"
|
||||
source: hosted
|
||||
version: "0.0.4+6"
|
||||
version: "0.0.4+8"
|
||||
path_provider_platform_interface:
|
||||
dependency: transitive
|
||||
description:
|
||||
|
|
@ -323,7 +323,7 @@ packages:
|
|||
name: provider
|
||||
url: "https://pub.dartlang.org"
|
||||
source: hosted
|
||||
version: "4.3.2+3"
|
||||
version: "4.3.2+4"
|
||||
qr:
|
||||
dependency: transitive
|
||||
description:
|
||||
|
|
@ -433,14 +433,14 @@ packages:
|
|||
name: sqflite
|
||||
url: "https://pub.dartlang.org"
|
||||
source: hosted
|
||||
version: "1.3.2+1"
|
||||
version: "1.3.2+2"
|
||||
sqflite_common:
|
||||
dependency: transitive
|
||||
description:
|
||||
name: sqflite_common
|
||||
url: "https://pub.dartlang.org"
|
||||
source: hosted
|
||||
version: "1.0.2+1"
|
||||
version: "1.0.3"
|
||||
stack_trace:
|
||||
dependency: transitive
|
||||
description:
|
||||
|
|
|
|||
Loading…
Reference in New Issue