mirror of
https://github.com/cypherstack/stack_wallet.git
synced 2025-01-11 05:04:35 +00:00
some basic ui prep for paynym integration
This commit is contained in:
parent
07eabb6092
commit
1ae4f40d63
7 changed files with 435 additions and 316 deletions
|
@ -507,7 +507,7 @@ class _WalletNetworkSettingsViewState
|
||||||
children: [
|
children: [
|
||||||
Text(
|
Text(
|
||||||
"Synchronized",
|
"Synchronized",
|
||||||
style: STextStyles.w600_10(context),
|
style: STextStyles.w600_12(context),
|
||||||
),
|
),
|
||||||
Text(
|
Text(
|
||||||
"100%",
|
"100%",
|
||||||
|
@ -581,7 +581,7 @@ class _WalletNetworkSettingsViewState
|
||||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||||
children: [
|
children: [
|
||||||
AnimatedText(
|
AnimatedText(
|
||||||
style: STextStyles.w600_10(context),
|
style: STextStyles.w600_12(context),
|
||||||
stringsToLoopThrough: const [
|
stringsToLoopThrough: const [
|
||||||
"Synchronizing",
|
"Synchronizing",
|
||||||
"Synchronizing.",
|
"Synchronizing.",
|
||||||
|
@ -679,7 +679,7 @@ class _WalletNetworkSettingsViewState
|
||||||
children: [
|
children: [
|
||||||
Text(
|
Text(
|
||||||
"Unable to synchronize",
|
"Unable to synchronize",
|
||||||
style: STextStyles.w600_10(context).copyWith(
|
style: STextStyles.w600_12(context).copyWith(
|
||||||
color: Theme.of(context)
|
color: Theme.of(context)
|
||||||
.extension<StackColors>()!
|
.extension<StackColors>()!
|
||||||
.accentColorRed,
|
.accentColorRed,
|
||||||
|
|
|
@ -1,10 +1,11 @@
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_svg/flutter_svg.dart';
|
import 'package:flutter_svg/flutter_svg.dart';
|
||||||
import 'package:stackwallet/utilities/assets.dart';
|
import 'package:stackwallet/utilities/assets.dart';
|
||||||
|
import 'package:stackwallet/utilities/enums/coin_enum.dart';
|
||||||
import 'package:stackwallet/utilities/text_styles.dart';
|
import 'package:stackwallet/utilities/text_styles.dart';
|
||||||
import 'package:stackwallet/utilities/theme/stack_colors.dart';
|
import 'package:stackwallet/utilities/theme/stack_colors.dart';
|
||||||
|
|
||||||
class WalletNavigationBar extends StatelessWidget {
|
class WalletNavigationBar extends StatefulWidget {
|
||||||
const WalletNavigationBar({
|
const WalletNavigationBar({
|
||||||
Key? key,
|
Key? key,
|
||||||
required this.onReceivePressed,
|
required this.onReceivePressed,
|
||||||
|
@ -13,6 +14,7 @@ class WalletNavigationBar extends StatelessWidget {
|
||||||
required this.onBuyPressed,
|
required this.onBuyPressed,
|
||||||
required this.height,
|
required this.height,
|
||||||
required this.enableExchange,
|
required this.enableExchange,
|
||||||
|
required this.coin,
|
||||||
}) : super(key: key);
|
}) : super(key: key);
|
||||||
|
|
||||||
final VoidCallback onReceivePressed;
|
final VoidCallback onReceivePressed;
|
||||||
|
@ -21,18 +23,112 @@ class WalletNavigationBar extends StatelessWidget {
|
||||||
final VoidCallback onBuyPressed;
|
final VoidCallback onBuyPressed;
|
||||||
final double height;
|
final double height;
|
||||||
final bool enableExchange;
|
final bool enableExchange;
|
||||||
|
final Coin coin;
|
||||||
|
|
||||||
|
@override
|
||||||
|
State<WalletNavigationBar> createState() => _WalletNavigationBarState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _WalletNavigationBarState extends State<WalletNavigationBar> {
|
||||||
|
double scale = 0;
|
||||||
|
final duration = const Duration(milliseconds: 200);
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
return Container(
|
return Column(
|
||||||
height: height,
|
mainAxisAlignment: MainAxisAlignment.end,
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.end,
|
||||||
|
children: [
|
||||||
|
// const Spacer(),
|
||||||
|
|
||||||
|
AnimatedScale(
|
||||||
|
scale: scale,
|
||||||
|
duration: duration,
|
||||||
|
child: Column(
|
||||||
|
mainAxisSize: MainAxisSize.min,
|
||||||
|
children: [
|
||||||
|
AnimatedOpacity(
|
||||||
|
opacity: scale,
|
||||||
|
duration: duration,
|
||||||
|
child: GestureDetector(
|
||||||
|
onTap: () {},
|
||||||
|
child: Container(
|
||||||
|
padding: const EdgeInsets.all(16),
|
||||||
|
width: 146,
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
color:
|
||||||
|
Theme.of(context).extension<StackColors>()!.popupBG,
|
||||||
|
boxShadow: [
|
||||||
|
Theme.of(context)
|
||||||
|
.extension<StackColors>()!
|
||||||
|
.standardBoxShadow
|
||||||
|
],
|
||||||
|
borderRadius: BorderRadius.circular(
|
||||||
|
widget.height / 2.0,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
child: Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.center,
|
||||||
|
children: [
|
||||||
|
Text(
|
||||||
|
"Whirlpool",
|
||||||
|
style: STextStyles.w600_12(context),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
const SizedBox(
|
||||||
|
height: 8,
|
||||||
|
),
|
||||||
|
AnimatedOpacity(
|
||||||
|
opacity: scale,
|
||||||
|
duration: duration,
|
||||||
|
child: GestureDetector(
|
||||||
|
onTap: () {},
|
||||||
|
child: Container(
|
||||||
|
padding: const EdgeInsets.all(16),
|
||||||
|
width: 146,
|
||||||
|
decoration: BoxDecoration(
|
||||||
|
color:
|
||||||
|
Theme.of(context).extension<StackColors>()!.popupBG,
|
||||||
|
boxShadow: [
|
||||||
|
Theme.of(context)
|
||||||
|
.extension<StackColors>()!
|
||||||
|
.standardBoxShadow
|
||||||
|
],
|
||||||
|
borderRadius: BorderRadius.circular(
|
||||||
|
widget.height / 2.0,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
child: Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.center,
|
||||||
|
children: [
|
||||||
|
Text(
|
||||||
|
"Paynym",
|
||||||
|
style: STextStyles.w600_12(context),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
const SizedBox(
|
||||||
|
height: 8,
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
Container(
|
||||||
|
height: widget.height,
|
||||||
decoration: BoxDecoration(
|
decoration: BoxDecoration(
|
||||||
color: Theme.of(context).extension<StackColors>()!.bottomNavBack,
|
color: Theme.of(context).extension<StackColors>()!.bottomNavBack,
|
||||||
boxShadow: [
|
boxShadow: [
|
||||||
Theme.of(context).extension<StackColors>()!.standardBoxShadow
|
Theme.of(context).extension<StackColors>()!.standardBoxShadow
|
||||||
],
|
],
|
||||||
borderRadius: BorderRadius.circular(
|
borderRadius: BorderRadius.circular(
|
||||||
height / 2.0,
|
widget.height / 2.0,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
child: Padding(
|
child: Padding(
|
||||||
|
@ -50,12 +146,12 @@ class WalletNavigationBar extends StatelessWidget {
|
||||||
constraints: const BoxConstraints(
|
constraints: const BoxConstraints(
|
||||||
minWidth: 66,
|
minWidth: 66,
|
||||||
),
|
),
|
||||||
onPressed: onReceivePressed,
|
onPressed: widget.onReceivePressed,
|
||||||
splashColor:
|
splashColor:
|
||||||
Theme.of(context).extension<StackColors>()!.highlight,
|
Theme.of(context).extension<StackColors>()!.highlight,
|
||||||
shape: RoundedRectangleBorder(
|
shape: RoundedRectangleBorder(
|
||||||
borderRadius: BorderRadius.circular(
|
borderRadius: BorderRadius.circular(
|
||||||
height / 2.0,
|
widget.height / 2.0,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
child: Container(
|
child: Container(
|
||||||
|
@ -105,12 +201,12 @@ class WalletNavigationBar extends StatelessWidget {
|
||||||
constraints: const BoxConstraints(
|
constraints: const BoxConstraints(
|
||||||
minWidth: 66,
|
minWidth: 66,
|
||||||
),
|
),
|
||||||
onPressed: onSendPressed,
|
onPressed: widget.onSendPressed,
|
||||||
splashColor:
|
splashColor:
|
||||||
Theme.of(context).extension<StackColors>()!.highlight,
|
Theme.of(context).extension<StackColors>()!.highlight,
|
||||||
shape: RoundedRectangleBorder(
|
shape: RoundedRectangleBorder(
|
||||||
borderRadius: BorderRadius.circular(
|
borderRadius: BorderRadius.circular(
|
||||||
height / 2.0,
|
widget.height / 2.0,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
child: Container(
|
child: Container(
|
||||||
|
@ -156,17 +252,17 @@ class WalletNavigationBar extends StatelessWidget {
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
if (enableExchange)
|
if (widget.enableExchange)
|
||||||
RawMaterialButton(
|
RawMaterialButton(
|
||||||
constraints: const BoxConstraints(
|
constraints: const BoxConstraints(
|
||||||
minWidth: 66,
|
minWidth: 66,
|
||||||
),
|
),
|
||||||
onPressed: onExchangePressed,
|
onPressed: widget.onExchangePressed,
|
||||||
splashColor:
|
splashColor:
|
||||||
Theme.of(context).extension<StackColors>()!.highlight,
|
Theme.of(context).extension<StackColors>()!.highlight,
|
||||||
shape: RoundedRectangleBorder(
|
shape: RoundedRectangleBorder(
|
||||||
borderRadius: BorderRadius.circular(
|
borderRadius: BorderRadius.circular(
|
||||||
height / 2.0,
|
widget.height / 2.0,
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
child: Container(
|
child: Container(
|
||||||
|
@ -195,6 +291,58 @@ class WalletNavigationBar extends StatelessWidget {
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
if (widget.coin.hasPaynymSupport)
|
||||||
|
RawMaterialButton(
|
||||||
|
constraints: const BoxConstraints(
|
||||||
|
minWidth: 66,
|
||||||
|
),
|
||||||
|
onPressed: () {
|
||||||
|
if (scale == 0) {
|
||||||
|
setState(() {
|
||||||
|
scale = 1;
|
||||||
|
});
|
||||||
|
} else if (scale == 1) {
|
||||||
|
setState(() {
|
||||||
|
scale = 0;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
},
|
||||||
|
splashColor:
|
||||||
|
Theme.of(context).extension<StackColors>()!.highlight,
|
||||||
|
shape: RoundedRectangleBorder(
|
||||||
|
borderRadius: BorderRadius.circular(
|
||||||
|
widget.height / 2.0,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
child: Container(
|
||||||
|
color: Colors.transparent,
|
||||||
|
child: Padding(
|
||||||
|
padding: const EdgeInsets.symmetric(vertical: 2.0),
|
||||||
|
child: Column(
|
||||||
|
crossAxisAlignment: CrossAxisAlignment.center,
|
||||||
|
children: [
|
||||||
|
const Spacer(),
|
||||||
|
const SizedBox(
|
||||||
|
height: 2,
|
||||||
|
),
|
||||||
|
SvgPicture.asset(
|
||||||
|
Assets.svg.bars,
|
||||||
|
width: 20,
|
||||||
|
height: 20,
|
||||||
|
),
|
||||||
|
const SizedBox(
|
||||||
|
height: 6,
|
||||||
|
),
|
||||||
|
Text(
|
||||||
|
"More",
|
||||||
|
style: STextStyles.buttonSmall(context),
|
||||||
|
),
|
||||||
|
const Spacer(),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
const SizedBox(
|
const SizedBox(
|
||||||
width: 12,
|
width: 12,
|
||||||
),
|
),
|
||||||
|
@ -234,52 +382,8 @@ class WalletNavigationBar extends StatelessWidget {
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//
|
|
||||||
// class BarButton extends StatelessWidget {
|
|
||||||
// const BarButton(
|
|
||||||
// {Key? key, required this.icon, required this.text, this.onPressed})
|
|
||||||
// : super(key: key);
|
|
||||||
//
|
|
||||||
// final Widget icon;
|
|
||||||
// final String text;
|
|
||||||
// final VoidCallback? onPressed;
|
|
||||||
//
|
|
||||||
// @override
|
|
||||||
// Widget build(BuildContext context) {
|
|
||||||
// return Container(
|
|
||||||
// child: MaterialButton(
|
|
||||||
// splashColor: Theme.of(context).extension<StackColors>()!.highlight,
|
|
||||||
// padding: const EdgeInsets.all(0),
|
|
||||||
// minWidth: 45,
|
|
||||||
// shape: RoundedRectangleBorder(
|
|
||||||
// borderRadius: BorderRadius.circular(
|
|
||||||
// Constants.size.circularBorderRadius,
|
|
||||||
// ),
|
|
||||||
// ),
|
|
||||||
// materialTapTargetSize: MaterialTapTargetSize.shrinkWrap,
|
|
||||||
// onPressed: onPressed,
|
|
||||||
// child: Padding(
|
|
||||||
// padding: const EdgeInsets.all(4.0),
|
|
||||||
// child: Column(
|
|
||||||
// mainAxisAlignment: MainAxisAlignment.center,
|
|
||||||
// children: [
|
|
||||||
// icon,
|
|
||||||
// SizedBox(
|
|
||||||
// height: 4,
|
|
||||||
// ),
|
|
||||||
// Text(
|
|
||||||
// text,
|
|
||||||
// style: STextStyles.itemSubtitle12(context).copyWith(
|
|
||||||
// fontSize: 10,
|
|
||||||
// ),
|
|
||||||
// ),
|
|
||||||
// ],
|
|
||||||
// ),
|
|
||||||
// ),
|
|
||||||
// ),
|
|
||||||
// );
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
|
|
|
@ -35,7 +35,6 @@ import 'package:stackwallet/utilities/assets.dart';
|
||||||
import 'package:stackwallet/utilities/constants.dart';
|
import 'package:stackwallet/utilities/constants.dart';
|
||||||
import 'package:stackwallet/utilities/enums/backup_frequency_type.dart';
|
import 'package:stackwallet/utilities/enums/backup_frequency_type.dart';
|
||||||
import 'package:stackwallet/utilities/enums/coin_enum.dart';
|
import 'package:stackwallet/utilities/enums/coin_enum.dart';
|
||||||
import 'package:stackwallet/utilities/enums/flush_bar_type.dart';
|
|
||||||
import 'package:stackwallet/utilities/enums/wallet_balance_toggle_state.dart';
|
import 'package:stackwallet/utilities/enums/wallet_balance_toggle_state.dart';
|
||||||
import 'package:stackwallet/utilities/logger.dart';
|
import 'package:stackwallet/utilities/logger.dart';
|
||||||
import 'package:stackwallet/utilities/text_styles.dart';
|
import 'package:stackwallet/utilities/text_styles.dart';
|
||||||
|
@ -707,7 +706,6 @@ class _WalletViewState extends ConsumerState<WalletView> {
|
||||||
Column(
|
Column(
|
||||||
mainAxisAlignment: MainAxisAlignment.end,
|
mainAxisAlignment: MainAxisAlignment.end,
|
||||||
children: [
|
children: [
|
||||||
const Spacer(),
|
|
||||||
Row(
|
Row(
|
||||||
mainAxisAlignment: MainAxisAlignment.center,
|
mainAxisAlignment: MainAxisAlignment.center,
|
||||||
children: [
|
children: [
|
||||||
|
@ -717,11 +715,10 @@ class _WalletViewState extends ConsumerState<WalletView> {
|
||||||
left: 16,
|
left: 16,
|
||||||
right: 16,
|
right: 16,
|
||||||
),
|
),
|
||||||
child: SizedBox(
|
|
||||||
height: WalletView.navBarHeight,
|
|
||||||
child: WalletNavigationBar(
|
child: WalletNavigationBar(
|
||||||
enableExchange:
|
coin: ref.watch(managerProvider
|
||||||
Constants.enableExchange &&
|
.select((value) => value.coin)),
|
||||||
|
enableExchange: Constants.enableExchange &&
|
||||||
ref.watch(managerProvider.select(
|
ref.watch(managerProvider.select(
|
||||||
(value) => value.coin)) !=
|
(value) => value.coin)) !=
|
||||||
Coin.epicCash,
|
Coin.epicCash,
|
||||||
|
@ -748,8 +745,7 @@ class _WalletViewState extends ConsumerState<WalletView> {
|
||||||
final coin =
|
final coin =
|
||||||
ref.read(managerProvider).coin;
|
ref.read(managerProvider).coin;
|
||||||
switch (ref
|
switch (ref
|
||||||
.read(
|
.read(walletBalanceToggleStateProvider
|
||||||
walletBalanceToggleStateProvider
|
|
||||||
.state)
|
.state)
|
||||||
.state) {
|
.state) {
|
||||||
case WalletBalanceToggleState.full:
|
case WalletBalanceToggleState.full:
|
||||||
|
@ -759,8 +755,7 @@ class _WalletViewState extends ConsumerState<WalletView> {
|
||||||
.state)
|
.state)
|
||||||
.state = "Public";
|
.state = "Public";
|
||||||
break;
|
break;
|
||||||
case WalletBalanceToggleState
|
case WalletBalanceToggleState.available:
|
||||||
.available:
|
|
||||||
ref
|
ref
|
||||||
.read(
|
.read(
|
||||||
publicPrivateBalanceStateProvider
|
publicPrivateBalanceStateProvider
|
||||||
|
@ -779,7 +774,6 @@ class _WalletViewState extends ConsumerState<WalletView> {
|
||||||
onBuyPressed: () {},
|
onBuyPressed: () {},
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
],
|
],
|
||||||
|
|
|
@ -11,12 +11,10 @@ import 'package:stackwallet/services/coins/litecoin/litecoin_wallet.dart'
|
||||||
import 'package:stackwallet/services/coins/monero/monero_wallet.dart' as xmr;
|
import 'package:stackwallet/services/coins/monero/monero_wallet.dart' as xmr;
|
||||||
import 'package:stackwallet/services/coins/namecoin/namecoin_wallet.dart'
|
import 'package:stackwallet/services/coins/namecoin/namecoin_wallet.dart'
|
||||||
as nmc;
|
as nmc;
|
||||||
|
import 'package:stackwallet/services/coins/particl/particl_wallet.dart'
|
||||||
|
as particl;
|
||||||
import 'package:stackwallet/services/coins/wownero/wownero_wallet.dart' as wow;
|
import 'package:stackwallet/services/coins/wownero/wownero_wallet.dart' as wow;
|
||||||
import 'package:stackwallet/services/coins/particl/particl_wallet.dart'
|
|
||||||
as particl;
|
|
||||||
import 'package:stackwallet/utilities/util.dart';
|
import 'package:stackwallet/utilities/util.dart';
|
||||||
import 'package:stackwallet/services/coins/particl/particl_wallet.dart'
|
|
||||||
as particl;
|
|
||||||
|
|
||||||
enum Coin {
|
enum Coin {
|
||||||
bitcoin,
|
bitcoin,
|
||||||
|
@ -174,6 +172,29 @@ extension CoinExt on Coin {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool get hasPaynymSupport {
|
||||||
|
switch (this) {
|
||||||
|
case Coin.bitcoin:
|
||||||
|
case Coin.litecoin:
|
||||||
|
case Coin.bitcoincash:
|
||||||
|
case Coin.firo:
|
||||||
|
case Coin.namecoin:
|
||||||
|
case Coin.particl:
|
||||||
|
case Coin.bitcoinTestNet:
|
||||||
|
case Coin.litecoinTestNet:
|
||||||
|
case Coin.bitcoincashTestnet:
|
||||||
|
case Coin.firoTestNet:
|
||||||
|
case Coin.epicCash:
|
||||||
|
case Coin.monero:
|
||||||
|
case Coin.wownero:
|
||||||
|
return false;
|
||||||
|
|
||||||
|
case Coin.dogecoin:
|
||||||
|
case Coin.dogecoinTestNet:
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
int get requiredConfirmations {
|
int get requiredConfirmations {
|
||||||
switch (this) {
|
switch (this) {
|
||||||
case Coin.bitcoin:
|
case Coin.bitcoin:
|
||||||
|
|
|
@ -568,7 +568,7 @@ class STextStyles {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static TextStyle w600_10(BuildContext context) {
|
static TextStyle w600_12(BuildContext context) {
|
||||||
switch (_theme(context).themeType) {
|
switch (_theme(context).themeType) {
|
||||||
case ThemeType.light:
|
case ThemeType.light:
|
||||||
return GoogleFonts.inter(
|
return GoogleFonts.inter(
|
||||||
|
|
|
@ -100,8 +100,8 @@ packages:
|
||||||
dependency: "direct main"
|
dependency: "direct main"
|
||||||
description:
|
description:
|
||||||
path: "."
|
path: "."
|
||||||
ref: main
|
ref: testing
|
||||||
resolved-ref: "48bd568b4f64c976813387fbae71a5daf48cff81"
|
resolved-ref: "8ed2f6245c71a4457ed4ffdd3a74e4bcb9f9d2d0"
|
||||||
url: "https://github.com/cypherstack/bip47.git"
|
url: "https://github.com/cypherstack/bip47.git"
|
||||||
source: git
|
source: git
|
||||||
version: "1.0.0"
|
version: "1.0.0"
|
||||||
|
|
|
@ -59,7 +59,7 @@ dependencies:
|
||||||
bip47:
|
bip47:
|
||||||
git:
|
git:
|
||||||
url: https://github.com/cypherstack/bip47.git
|
url: https://github.com/cypherstack/bip47.git
|
||||||
ref: main
|
ref: testing
|
||||||
|
|
||||||
# Utility plugins
|
# Utility plugins
|
||||||
# provider: ^6.0.1
|
# provider: ^6.0.1
|
||||||
|
|
Loading…
Reference in a new issue