invoice/lib/ui/app/link_text.dart

74 lines
1.9 KiB
Dart

// Flutter imports:
import 'package:flutter/gestures.dart';
import 'package:flutter/material.dart';
import 'package:invoiceninja_flutter/data/models/entities.dart';
import 'package:invoiceninja_flutter/redux/app/app_actions.dart';
// Package imports:
import 'package:url_launcher/url_launcher.dart';
class LinkTextRelatedEntity extends StatefulWidget {
const LinkTextRelatedEntity({
Key key,
@required this.entity,
@required this.relation,
}) : super(key: key);
final BaseEntity entity;
final BaseEntity relation;
@override
State<LinkTextRelatedEntity> createState() => _LinkTextRelatedEntityState();
}
class _LinkTextRelatedEntityState extends State<LinkTextRelatedEntity> {
bool _isHovered = false;
@override
Widget build(BuildContext context) {
if (widget.entity == null || widget.relation == null) {
return SizedBox();
}
return MouseRegion(
onHover: (event) {
setState(() => _isHovered = true);
},
onExit: (event) {
setState(() => _isHovered = false);
},
child: GestureDetector(
child: Text(
widget.entity.listDisplayName,
style: TextStyle(
decoration:
_isHovered ? TextDecoration.underline : TextDecoration.none,
),
),
onTap: () {
if (widget.entity.entityType.hasFullWidthViewer) {
viewEntity(entity: widget.entity);
} else {
viewEntity(entity: widget.relation);
viewEntity(entity: widget.entity, addToStack: true);
}
},
onLongPress: () {
editEntity(entity: widget.entity);
},
),
);
}
}
class LinkTextSpan extends TextSpan {
LinkTextSpan({TextStyle style, String url, String text})
: super(
style: style,
text: text ?? url,
recognizer: TapGestureRecognizer()
..onTap = () {
launchUrl(Uri.parse(url));
});
}