stack_wallet/lib/pages/ordinals/ordinals_view.dart

201 lines
6.7 KiB
Dart
Raw Normal View History

2023-07-18 16:15:05 +00:00
/*
* This file is part of Stack Wallet.
*
* Copyright (c) 2023 Cypher Stack
* All Rights Reserved.
* The code is distributed under GPLv3 license, see LICENSE file for details.
* Generated by Cypher Stack on 2023-05-26
*
*/
import 'package:flutter/material.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:flutter_svg/svg.dart';
import 'widgets/ordinals_list.dart';
import '../../providers/global/wallets_provider.dart';
import '../../themes/stack_colors.dart';
import '../../utilities/assets.dart';
import '../../utilities/show_loading.dart';
import '../../utilities/text_styles.dart';
import '../../wallets/wallet/wallet_mixin_interfaces/ordinals_interface.dart';
import '../../widgets/background.dart';
import '../../widgets/custom_buttons/app_bar_icon_button.dart';
2023-07-18 16:15:05 +00:00
class OrdinalsView extends ConsumerStatefulWidget {
const OrdinalsView({
super.key,
required this.walletId,
});
static const routeName = "/ordinalsView";
final String walletId;
@override
ConsumerState<OrdinalsView> createState() => _OrdinalsViewState();
}
2023-07-20 21:49:26 +00:00
class _OrdinalsViewState extends ConsumerState<OrdinalsView> {
2023-07-18 16:15:05 +00:00
late final TextEditingController searchController;
late final FocusNode searchFocus;
2024-05-27 23:56:22 +00:00
final String _searchTerm = "";
2023-07-18 16:15:05 +00:00
@override
void initState() {
searchController = TextEditingController();
searchFocus = FocusNode();
2023-07-19 20:58:34 +00:00
2023-07-18 16:15:05 +00:00
super.initState();
}
@override
void dispose() {
searchController.dispose();
searchFocus.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
return Background(
child: SafeArea(
child: Scaffold(
backgroundColor:
Theme.of(context).extension<StackColors>()!.background,
appBar: AppBar(
automaticallyImplyLeading: false,
leading: const AppBarBackButton(),
title: Text(
"Ordinals",
style: STextStyles.navBarTitle(context),
),
titleSpacing: 0,
actions: [
AspectRatio(
aspectRatio: 1,
child: AppBarIconButton(
size: 36,
icon: SvgPicture.asset(
Assets.svg.arrowRotate,
width: 20,
height: 20,
color: Theme.of(context)
.extension<StackColors>()!
.topNavIconPrimary,
),
onPressed: () async {
// show loading for a minimum of 2 seconds on refreshing
await showLoading(
2023-07-26 23:01:24 +00:00
whileFuture: Future.wait<void>([
Future.delayed(const Duration(seconds: 2)),
(ref.read(pWallets).getWallet(widget.walletId)
as OrdinalsInterface)
2024-05-27 23:56:22 +00:00
.refreshInscriptions(),
2023-07-26 23:01:24 +00:00
]),
context: context,
message: "Refreshing...",
2023-07-18 17:48:15 +00:00
);
2023-07-18 16:15:05 +00:00
},
),
),
2023-07-26 23:01:24 +00:00
// AspectRatio(
// aspectRatio: 1,
// child: AppBarIconButton(
// size: 36,
// icon: SvgPicture.asset(
// Assets.svg.filter,
// width: 20,
// height: 20,
// color: Theme.of(context)
// .extension<StackColors>()!
// .topNavIconPrimary,
// ),
// onPressed: () {
// Navigator.of(context).pushNamed(
// OrdinalsFilterView.routeName,
// );
// },
// ),
// ),
2023-07-18 16:15:05 +00:00
],
),
body: Padding(
padding: const EdgeInsets.only(
left: 16,
right: 16,
top: 8,
),
child: Column(
children: [
2023-07-26 23:01:24 +00:00
// ClipRRect(
// borderRadius: BorderRadius.circular(
// Constants.size.circularBorderRadius,
// ),
// child: TextField(
// autocorrect: Util.isDesktop ? false : true,
// enableSuggestions: Util.isDesktop ? false : true,
// controller: searchController,
// focusNode: searchFocus,
// onChanged: (value) {
// setState(() {
// _searchTerm = value;
// });
// },
// style: STextStyles.field(context),
// decoration: standardInputDecoration(
// "Search",
// searchFocus,
// context,
// ).copyWith(
// prefixIcon: Padding(
// padding: const EdgeInsets.symmetric(
// horizontal: 10,
// vertical: 16,
// ),
// child: SvgPicture.asset(
// Assets.svg.search,
// width: 16,
// height: 16,
// ),
// ),
// suffixIcon: searchController.text.isNotEmpty
// ? Padding(
// padding: const EdgeInsets.only(right: 0),
// child: UnconstrainedBox(
// child: Row(
// children: [
// TextFieldIconButton(
// child: const XIcon(),
// onTap: () async {
// setState(() {
// searchController.text = "";
// _searchTerm = "";
// });
// },
// ),
// ],
// ),
// ),
// )
// : null,
// ),
// ),
// ),
// const SizedBox(
// height: 16,
// ),
2023-07-18 16:15:05 +00:00
Expanded(
child: OrdinalsList(
2023-07-18 17:03:57 +00:00
walletId: widget.walletId,
2023-07-18 16:15:05 +00:00
),
),
],
),
),
),
),
);
}
}