import 'package:flutter/material.dart'; import 'package:flutter/services.dart'; import 'dart:convert'; // Пакет для обработки json с ответом от сервера. import 'dart:async'; import 'main.dart'; import 'activate_token.dart'; import 'base_state.dart'; /// На фото мой сын, большой любитель голых констант. /// Экран регистрации магазина и кассы. class RegistrationScreen extends StatefulWidget { @override State createState() => new _RegistrationScreenState(); } class _RegistrationScreenState extends BaseState { @override String getTitle() { return "Регистрация"; } @override getHint() { return 'ID merchant'; } @overide getMenuButtons(BuildContext context) { return [new IconButton(icon: new Icon(Icons.help_outline), onPressed: () {})]; } /// Высота контейнера задана для того, чтобы элементы располагались вверху экрана /// и список скроллился снизу вверх при открытии клавиатуры. @override Widget getScreenContent() { return new Container(height: 332.0, child: new ListView(reverse: true, children: [ new Center(child: new Column(children: [ getLogo(), getHintLabel(), getDecoratedTextWidget(), _getButton(context)])) ].reversed.toList())); } /// Метод возвращает кнопку, которая запускает отправку токена кассы на сервер. _getButton(BuildContext context) { double buttonHeight = 42.0; double topMargin = 36.0; double horizontalPadding = 40.0; // Отступы по краям от кнопки. return new Container(margin: new EdgeInsets.only(top: topMargin), height: buttonHeight, padding: new EdgeInsets.only(left: horizontalPadding, right: horizontalPadding), child: new RaisedButton(child: new Text('ЗАРЕГИСТРИРОВАТЬ', style: new TextStyle(color: Colors.white)), onPressed: _isValidMerchantID() && !loading ? () => _registerShop(context) : null, color: primaryColor)); } /// Токен кассы - это DIN код. DIN код - это специальный код динекта, максимальная его длина - 25 символов. _isValidMerchantID() { return textFieldValue.length > 0 && textFieldValue.length < 25; } /// Смена состояния экрана при изменении текста в поле ввода. _handleUserInput(String text) { setState(() { textFieldValue = text; }); } /// Показать индикатор, запросить токен. _registerShop(BuildContext context) { setState(() { loading = true; _register(context); }); } /// Экран зависает на 1 сек, после этого выполняется переход на экран потверждения токена. _registerDemo(BuildContext context) { new Future.delayed(const Duration(milliseconds: 1000), () { loading = false; pushRoute(context, new FinishRegistrationScreen()); }); } /// Получение от платформы id установки, формирование запроса на получение токена, сохранение токена. _register(BuildContext context) async { const platform = const MethodChannel('com.dinect.checker/instance_id'); String url = intUrl + 'tokens/?_dmapptoken=' + intToken; String pos = (new DateTime.now().millisecondsSinceEpoch / 1000).toString(); // Поле description - необязательное. var body = { 'merchant_shop': textFieldValue, 'pos': pos, }; httpClient.post(url, body: body).then((response) { setState(() { error = null; }); print(response.body); Map parsedMap = JSON.decode(response.body); setState(() { loading = false; }); if (response.statusCode == 201) { token = parsedMap['token']; platform.invokeMethod('saveToken', {'token' : token}); platform.invokeMethod('saveMerchantID', {'merchantID' : merchantID}); pushRoute(context, new FinishRegistrationScreen()); } else { setState(() { error = parsedMap['errors'][0]; }); } }).catchError((error) { setState(() { error = 'Отсутствует интернет соединение'; }); }); } }