stack_wallet/lib/pages/ordinals/ordinal_details_view.dart

262 lines
7.6 KiB
Dart
Raw Normal View History

2023-07-18 17:03:57 +00:00
import 'dart:async';
2023-07-18 16:15:05 +00:00
import 'package:flutter/material.dart';
2023-07-18 17:03:57 +00:00
import 'package:flutter/services.dart';
2023-07-18 16:15:05 +00:00
import 'package:flutter_svg/flutter_svg.dart';
import 'package:stackwallet/models/ordinal.dart';
2023-07-18 17:03:57 +00:00
import 'package:stackwallet/notifications/show_flush_bar.dart';
2023-07-18 17:26:43 +00:00
import 'package:stackwallet/pages/ordinals/widgets/dialogs.dart';
2023-07-18 16:15:05 +00:00
import 'package:stackwallet/themes/stack_colors.dart';
import 'package:stackwallet/utilities/assets.dart';
import 'package:stackwallet/utilities/text_styles.dart';
import 'package:stackwallet/widgets/background.dart';
import 'package:stackwallet/widgets/custom_buttons/app_bar_icon_button.dart';
import 'package:stackwallet/widgets/desktop/primary_button.dart';
import 'package:stackwallet/widgets/desktop/secondary_button.dart';
2023-07-18 17:03:57 +00:00
import 'package:stackwallet/widgets/rounded_white_container.dart';
2023-07-18 16:15:05 +00:00
class OrdinalDetailsView extends StatefulWidget {
const OrdinalDetailsView({
super.key,
required this.walletId,
required this.ordinal,
});
final String walletId;
final Ordinal ordinal;
static const routeName = "/ordinalDetailsView";
@override
State<OrdinalDetailsView> createState() => _OrdinalDetailsViewState();
}
class _OrdinalDetailsViewState extends State<OrdinalDetailsView> {
2023-07-18 17:03:57 +00:00
static const _spacing = 12.0;
2023-07-18 16:15:05 +00:00
@override
Widget build(BuildContext context) {
return Background(
child: SafeArea(
child: Scaffold(
backgroundColor:
Theme.of(context).extension<StackColors>()!.background,
appBar: AppBar(
backgroundColor:
Theme.of(context).extension<StackColors>()!.background,
leading: const AppBarBackButton(),
title: Text(
"Ordinal details",
style: STextStyles.navBarTitle(context),
),
),
2023-07-18 17:03:57 +00:00
body: SingleChildScrollView(
child: Padding(
padding: const EdgeInsets.symmetric(horizontal: 16),
child: Column(
children: [
Padding(
padding: const EdgeInsets.symmetric(
vertical: 12,
horizontal: 39,
),
child: _OrdinalImageGroup(
ordinal: widget.ordinal,
walletId: widget.walletId,
),
),
_DetailsItemWCopy(
title: "Inscription number",
data: widget.ordinal.inscription,
),
const SizedBox(
height: _spacing,
),
_DetailsItemWCopy(
title: "Rank",
data: widget.ordinal.rank,
),
const SizedBox(
height: _spacing,
),
// todo: add utxo status
const SizedBox(
height: _spacing,
),
_DetailsItemWCopy(
title: "Amount",
data: "FIXME",
),
const SizedBox(
height: _spacing,
),
_DetailsItemWCopy(
title: "Owner address",
data: "FIXME",
),
const SizedBox(
height: _spacing,
),
_DetailsItemWCopy(
title: "Transaction ID",
data: "FIXME",
),
const SizedBox(
height: _spacing,
),
],
),
),
),
2023-07-18 16:15:05 +00:00
),
),
);
}
}
2023-07-18 17:03:57 +00:00
class _DetailsItemWCopy extends StatelessWidget {
const _DetailsItemWCopy({
super.key,
required this.title,
required this.data,
});
final String title;
final String data;
@override
Widget build(BuildContext context) {
return RoundedWhiteContainer(
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
Text(
title,
style: STextStyles.itemSubtitle(context),
),
GestureDetector(
onTap: () async {
await Clipboard.setData(ClipboardData(text: data));
if (context.mounted) {
unawaited(
showFloatingFlushBar(
type: FlushBarType.info,
message: "Copied to clipboard",
context: context,
),
);
}
},
child: SvgPicture.asset(
Assets.svg.copy,
color:
Theme.of(context).extension<StackColors>()!.infoItemIcons,
width: 12,
),
),
],
),
const SizedBox(
height: 4,
),
SelectableText(
data,
style: STextStyles.itemSubtitle12(context),
),
],
),
);
}
}
2023-07-18 16:15:05 +00:00
class _OrdinalImageGroup extends StatelessWidget {
const _OrdinalImageGroup({
super.key,
2023-07-18 17:03:57 +00:00
required this.walletId,
2023-07-18 16:15:05 +00:00
required this.ordinal,
});
2023-07-18 17:03:57 +00:00
final String walletId;
2023-07-18 16:15:05 +00:00
final Ordinal ordinal;
static const _spacing = 12.0;
@override
Widget build(BuildContext context) {
return Column(
mainAxisSize: MainAxisSize.min,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
Text(
ordinal.name,
style: STextStyles.w600_16(context),
),
const SizedBox(
height: _spacing,
),
AspectRatio(
aspectRatio: 1,
child: Container(
color: Colors.red,
),
),
const SizedBox(
height: _spacing,
),
Row(
children: [
Expanded(
child: SecondaryButton(
label: "Download",
2023-07-18 17:03:57 +00:00
icon: SvgPicture.asset(
Assets.svg.arrowDown,
width: 10,
height: 12,
color: Theme.of(context)
.extension<StackColors>()!
.buttonTextSecondary,
),
buttonHeight: ButtonHeight.l,
iconSpacing: 4,
2023-07-18 16:15:05 +00:00
onPressed: () {
// TODO: save and download image to device
},
),
),
const SizedBox(
width: _spacing,
),
Expanded(
child: PrimaryButton(
label: "Send",
icon: SvgPicture.asset(
2023-07-18 17:03:57 +00:00
Assets.svg.send,
width: 10,
height: 10,
color: Theme.of(context)
.extension<StackColors>()!
.buttonTextPrimary,
2023-07-18 16:15:05 +00:00
),
2023-07-18 17:03:57 +00:00
buttonHeight: ButtonHeight.l,
iconSpacing: 4,
2023-07-18 17:26:43 +00:00
onPressed: () async {
final response = await showDialog<String?>(
context: context,
builder: (_) => const SendOrdinalUnfreezeDialog(),
);
if (response == "unfreeze") {
// TODO: unfreeze and go to send ord screen
}
2023-07-18 16:15:05 +00:00
},
),
),
],
),
],
);
}
}