import 'dart:convert'; import 'package:file_picker/file_picker.dart'; import 'package:flutter/foundation.dart'; import 'package:flutter/material.dart'; import 'package:flutter_redux/flutter_redux.dart'; import 'package:http/http.dart'; import 'package:invoiceninja_flutter/constants.dart'; import 'package:invoiceninja_flutter/data/models/entities.dart'; import 'package:invoiceninja_flutter/data/web_client.dart'; import 'package:invoiceninja_flutter/redux/app/app_state.dart'; import 'package:invoiceninja_flutter/ui/app/form_card.dart'; import 'package:invoiceninja_flutter/ui/app/forms/app_form.dart'; import 'package:invoiceninja_flutter/ui/app/forms/decorated_form_field.dart'; import 'package:invoiceninja_flutter/ui/settings/import_export_vm.dart'; import 'package:invoiceninja_flutter/utils/dialogs.dart'; import 'package:invoiceninja_flutter/utils/localization.dart'; import 'package:invoiceninja_flutter/utils/platforms.dart'; class ImportExport extends StatefulWidget { const ImportExport({ Key key, @required this.viewModel, }) : super(key: key); final ImportExportVM viewModel; @override _ImportExportState createState() => _ImportExportState(); } class _ImportExportState extends State { static final GlobalKey _formKey = GlobalKey(debugLabel: '_importExport'); FocusScopeNode _focusNode; bool autoValidate = false; String _filePath; String _fileName; @override void initState() { super.initState(); _focusNode = FocusScopeNode(); } @override void dispose() { _focusNode.dispose(); super.dispose(); } void uploadFile() { final webClient = WebClient(); final state = StoreProvider.of(context).state; final credentials = state.credentials; final url = '${credentials.url}/preimport'; webClient .post( url, credentials.token, filePath: _filePath, fileIndex: 'file', ) .then((dynamic response) { print('## respnse: ${(response as Response).body}'); }).catchError((dynamic error) { showErrorDialog(context: context, message: '$error'); }); } @override Widget build(BuildContext context) { final localization = AppLocalization.of(context); return Scaffold( appBar: AppBar( centerTitle: false, automaticallyImplyLeading: isMobile(context), title: Text(localization.importExport), actions: [], ), body: AppForm( formKey: _formKey, focusNode: _focusNode, child: ListView( children: [ FormCard( crossAxisAlignment: CrossAxisAlignment.stretch, children: [ InputDecorator( decoration: InputDecoration( labelText: localization.importType, ), child: DropdownButtonHideUnderline( child: DropdownButton( isDense: true, value: EntityType.client, onChanged: (dynamic value) { // }, items: [EntityType.client] .map((entityType) => DropdownMenuItem( value: entityType, child: Text(localization.lookup('$entityType')))) .toList()), ), ), DecoratedFormField( key: ValueKey(_fileName), enabled: false, label: localization.csvFile, initialValue: _fileName ?? localization.noFileSelected, ), SizedBox(height: 20), Row( children: [ Expanded( child: OutlineButton( shape: RoundedRectangleBorder( borderRadius: BorderRadius.circular(5)), child: Text(localization.selectFile), onPressed: () async { final result = await FilePicker.platform.pickFiles( type: FileType.custom, allowedExtensions: ['csv'], ); if (result != null) { setState(() { final file = result.files.single; _filePath = kIsWeb ? 'data:application/octet-stream;charset=utf-16le;base64,' + base64Encode(file.bytes) : file.path; _fileName = file.name; }); } }, ), ), SizedBox(width: kTableColumnGap), Expanded( child: OutlineButton( shape: RoundedRectangleBorder( borderRadius: BorderRadius.circular(5)), child: Text(localization.uploadFile), onPressed: _fileName == null ? null : () => uploadFile(), ), ), ], ) ], ) ], ), ), ); } }