git-touch-android-ios-app/lib/utils/utils.dart

174 lines
3.8 KiB
Dart
Raw Normal View History

2019-09-14 11:19:33 +02:00
import 'dart:io';
import 'package:flutter/material.dart';
import 'package:flutter/cupertino.dart';
import 'package:flutter/gestures.dart';
2019-09-07 11:48:59 +02:00
import 'package:git_touch/screens/user.dart';
import 'package:intl/intl.dart';
2019-08-31 15:37:29 +02:00
import 'package:primer/primer.dart';
2019-02-07 07:35:19 +01:00
import '../screens/repo.dart';
export 'package:flutter_vector_icons/flutter_vector_icons.dart';
2019-09-14 11:19:33 +02:00
final monospaceFont = Platform.isIOS ? 'Menlo' : 'monospace'; // FIXME:
2019-03-10 09:09:26 +01:00
class StorageKeys {
static const account = 'account';
static const github = 'github';
static const theme = 'theme';
static const newsFilter = 'news.filter';
}
2019-02-04 11:32:39 +01:00
Color convertColor(String cssHex) {
2019-09-02 12:14:17 +02:00
if (cssHex == null) {
return Color(0xffcccccc); // Default color
}
2019-02-04 11:32:39 +01:00
if (cssHex.startsWith('#')) {
cssHex = cssHex.substring(1);
}
2019-03-12 12:00:31 +01:00
if (cssHex.length == 3) {
cssHex = cssHex.split('').map((char) => char + char).join('');
}
2019-02-04 11:32:39 +01:00
return Color(int.parse('ff' + cssHex, radix: 16));
}
2019-09-14 09:39:38 +02:00
Color getFontColorByBrightness(Color color) {
var grayscale = color.red * 0.3 + color.green * 0.59 + color.blue * 0.11;
// print('color: $color, $grayscale');
var showWhite = grayscale < 128;
return showWhite ? Colors.white : Colors.black;
}
2019-02-10 05:16:52 +01:00
void nextTick(Function callback, [int milliseconds = 0]) {
2019-02-08 16:20:28 +01:00
// FIXME:
2019-02-10 05:16:52 +01:00
Future.delayed(Duration(milliseconds: 0)).then((_) {
callback();
});
}
TextSpan createLinkSpan(BuildContext context, String text, Function handle) {
return TextSpan(
text: text,
2019-09-13 09:55:58 +02:00
style: TextStyle(color: PrimerColors.blue500, fontWeight: FontWeight.w600),
2019-02-11 17:31:06 +01:00
recognizer: TapGestureRecognizer()
..onTap = () {
Navigator.of(context).push(
2019-09-07 11:48:59 +02:00
// FIXME: Material route
2019-02-11 17:31:06 +01:00
CupertinoPageRoute(
builder: (context) {
return handle();
},
),
);
},
);
}
2019-09-07 11:48:59 +02:00
TextSpan createUserSpan(BuildContext context, String login) {
return createLinkSpan(context, login, () => UserScreen(login));
}
TextSpan createRepoLinkSpan(BuildContext context, String owner, String name) {
return createLinkSpan(context, '$owner/$name', () => RepoScreen(owner, name));
}
class Palette {
2019-02-06 12:14:11 +01:00
static const green = Color(0xff2cbe4e);
}
// final pageSize = 5;
2019-02-09 07:20:21 +01:00
final pageSize = 30;
2019-01-29 06:34:52 +01:00
var createWarning =
(String text) => Text(text, style: TextStyle(color: Colors.redAccent));
var warningSpan =
TextSpan(text: 'xxx', style: TextStyle(color: Colors.redAccent));
2019-02-09 06:36:15 +01:00
var repoChunk = '''
owner {
login
2019-09-08 15:20:12 +02:00
avatarUrl
2019-02-09 06:36:15 +01:00
}
name
description
isPrivate
isFork
stargazers {
totalCount
}
forks {
totalCount
}
primaryLanguage {
color
name
}
''';
List<T> join<T>(T seperator, List<T> xs) {
List<T> result = [];
xs.asMap().forEach((index, x) {
if (x == null) return;
result.add(x);
if (index < xs.length - 1) {
result.add(seperator);
}
});
return result;
}
List<T> joinAll<T>(T seperator, List<List<T>> xss) {
List<T> result = [];
xss.asMap().forEach((index, x) {
if (x == null || x.isEmpty) return;
result.addAll(x);
if (index < xss.length - 1) {
result.add(seperator);
}
});
return result;
}
final numberFormat = NumberFormat();
2019-09-14 17:48:01 +02:00
bool isNotNullOrEmpty(String text) {
return text != null && text.isNotEmpty;
}
2019-09-05 11:58:14 +02:00
class BorderView extends StatelessWidget {
final double height;
2019-09-14 17:48:01 +02:00
final Color color;
final double leftPadding;
2019-09-05 11:58:14 +02:00
2019-09-14 17:48:01 +02:00
const BorderView({
this.height = 1,
this.color = PrimerColors.gray200,
this.leftPadding = 0,
});
2019-09-05 11:58:14 +02:00
@override
Widget build(BuildContext context) {
2019-09-14 17:48:01 +02:00
return Row(
children: <Widget>[
SizedBox(width: leftPadding),
Expanded(
child: SizedBox(
height: height,
child: DecoratedBox(
decoration: BoxDecoration(color: color),
),
),
),
],
2019-09-05 11:58:14 +02:00
);
}
}
2019-09-14 17:48:01 +02:00
const borderView = BorderView();
const borderView10 = BorderView(height: 20, color: PrimerColors.gray100);