import 'dart:convert'; import 'dart:async'; import 'package:checker/base/base_screen.dart'; import 'package:checker/base/base_state.dart'; import 'package:checker/common.dart'; import 'package:checker/consts.dart'; import 'package:checker/db.dart'; import 'package:checker/network.dart'; import 'package:checker/screens/finish_registration.dart'; import 'package:checker/strings.dart'; import 'package:flutter/material.dart'; // Пакет для обработки json с ответом от сервера. /// Экран регистрации магазина и кассы. class RegistrationScreen extends BaseScreen { RegistrationScreen(helper, app) : super(helper, app); @override State createState() => new RegistrationScreenState(helper, app); } class RegistrationScreenState extends BaseState { RegistrationScreenState(SqliteHelper helper, String app) : super(helper, app); FocusNode _focusNode = new FocusNode(); bool isAutomaticallyImplyLeading() => false; @override Widget build(BuildContext ctx) { return new WillPopScope(onWillPop: () => onWillPop(), child: getMainWidget()); } @override String getTitle() { return StringsLocalization.registration(); } @override getHintString() { return StringsLocalization.idStore(); } /// Список виджетов, автоматически прокручиваемый вверх при открытии клавиатуры. @override Widget getScreenContent() { return new Container(child: new ListView(children: [ new Column(children: [ getLogo(), getHintLabel(), getInputField(), getButton() ]) ])); } @override getTextWidget() { return new TextField( focusNode: _focusNode, keyboardType: TextInputType.number, decoration: new InputDecoration.collapsed( hintText: getHintString(), hintStyle: new TextStyle(color: greyTextColor, fontSize: 16.0)), onChanged: (text) => handleUserInput(text)); } /// Возвращает кнопку регистрации. getButton() { return new Container( margin: new EdgeInsets.only(top: 36.0), child: buildRaisedButton(StringsLocalization.signUp(), getOnPressed())); } // Возвращает обработчик нажатий на кнопку регистрации. getOnPressed() { return _isValidMerchantID() && !loading ? () => _registerShop() : null; } /// Токен кассы - это DIN код. DIN код - это специальный код динекта, максимальная его длина - 25 символов. _isValidMerchantID() { print("${merchantID.length}"); return merchantID.length > 0 && merchantID.length < 25; } /// Показать progressBar, запросить токен. _registerShop() { setState(() { loading = true; register(); }); } /// Получение от платформы id установки, формирование запроса на получение токена, сохранение токена. register() async { if (await platform.invokeMethod('isOnline')) { String posID = await helper.getPosID(); getCreateTokenRequest({'merchant_shop': merchantID, 'pos': posID}) .then((response) { setState(() { error = null; loading = false; }); print(response.body); print(response.statusCode.toString()); Map parsedMap = JSON.decode(response.body); if (response.statusCode == 201) { helper.createSession(merchantID, posID, parsedMap['token']).then((_) { new Future.delayed(const Duration(milliseconds: 200), () { print('start finish registration!'); var route = new MaterialPageRoute(builder: (BuildContext context) => new FinishRegistrationScreen(helper, app), fullscreenDialog: true); Navigator.of(context).push(route).then((token) { Navigator.of(context).pop(token); }); }); }); } else { setState(() { error = parsedMap['errors'][0]; }); } }, onError: (e) { platform.invokeMethod('logError', {"message":e.toString()}); }); } } onWillPop() { if (Theme.of(context).platform != TargetPlatform.iOS) { platform.invokeMethod('finish'); } } }