79 lines
2.3 KiB
Dart
79 lines
2.3 KiB
Dart
import 'package:flutter/cupertino.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:git_touch/models/auth.dart';
|
|
import 'package:git_touch/models/bitbucket.dart';
|
|
import 'package:git_touch/models/theme.dart';
|
|
import 'package:git_touch/scaffolds/common.dart';
|
|
import 'package:git_touch/utils/utils.dart';
|
|
import 'package:provider/provider.dart';
|
|
|
|
class BbIssueFormScreen extends StatefulWidget {
|
|
final String owner;
|
|
final String name;
|
|
BbIssueFormScreen(this.owner, this.name);
|
|
|
|
@override
|
|
_BbIssueFormScreenState createState() => _BbIssueFormScreenState();
|
|
}
|
|
|
|
class _BbIssueFormScreenState extends State<BbIssueFormScreen> {
|
|
var _title = '';
|
|
var _body = '';
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
final theme = Provider.of<ThemeModel>(context);
|
|
final auth = Provider.of<AuthModel>(context);
|
|
return CommonScaffold(
|
|
title: Text('Submit an issue'),
|
|
body: Column(
|
|
children: <Widget>[
|
|
Padding(
|
|
padding: CommonStyle.padding,
|
|
child: CupertinoTextField(
|
|
style: TextStyle(color: theme.palette.text),
|
|
placeholder: 'Title',
|
|
onChanged: (v) {
|
|
setState(() {
|
|
_title = v;
|
|
});
|
|
},
|
|
),
|
|
),
|
|
Padding(
|
|
padding: CommonStyle.padding,
|
|
child: CupertinoTextField(
|
|
style: TextStyle(color: theme.palette.text),
|
|
placeholder: 'Body',
|
|
onChanged: (v) {
|
|
setState(() {
|
|
_body = v;
|
|
});
|
|
},
|
|
maxLines: 10,
|
|
),
|
|
),
|
|
CupertinoButton.filled(
|
|
child: Text('Submit'),
|
|
onPressed: () async {
|
|
await auth.fetchBbJson(
|
|
'/repositories/${widget.owner}/${widget.name}/issues',
|
|
isPost: true,
|
|
body: {'body': _body, 'title': _title},
|
|
).then((v) {
|
|
return BbIssues.fromJson(v);
|
|
});
|
|
Navigator.pop(context, true);
|
|
await theme.push(
|
|
context,
|
|
'/bitbucket/${widget.owner}/${widget.name}/issues',
|
|
replace: true,
|
|
);
|
|
},
|
|
),
|
|
],
|
|
),
|
|
);
|
|
}
|
|
}
|