refactor dropdown2 and qr image

This commit is contained in:
julian 2023-06-05 07:40:56 -06:00
parent f61211d7b4
commit 044c957152
21 changed files with 202 additions and 227 deletions

View file

@ -420,6 +420,7 @@ class _RestoreOptionsViewState extends ConsumerState<RestoreOptionsView> {
} }
}, },
isExpanded: true, isExpanded: true,
iconStyleData: IconStyleData(
icon: SvgPicture.asset( icon: SvgPicture.asset(
Assets.svg.chevronDown, Assets.svg.chevronDown,
width: 12, width: 12,
@ -428,25 +429,24 @@ class _RestoreOptionsViewState extends ConsumerState<RestoreOptionsView> {
.extension<StackColors>()! .extension<StackColors>()!
.textFieldActiveSearchIconRight, .textFieldActiveSearchIconRight,
), ),
buttonPadding: const EdgeInsets.symmetric( ),
dropdownStyleData: DropdownStyleData(
offset: const Offset(0, -10),
elevation: 0,
decoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
),
),
menuItemStyleData: const MenuItemStyleData(
padding: EdgeInsets.symmetric(
horizontal: 16, horizontal: 16,
vertical: 8, vertical: 8,
), ),
buttonDecoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
),
dropdownDecoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
), ),
), ),
), ),

View file

@ -99,9 +99,25 @@ class _NewContactAddressEntryFormState
"Select cryptocurrency", "Select cryptocurrency",
style: STextStyles.fieldLabel(context), style: STextStyles.fieldLabel(context),
), ),
dropdownStyleData: DropdownStyleData(
offset: const Offset(0, -10), offset: const Offset(0, -10),
elevation: 0,
decoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
),
),
menuItemStyleData: const MenuItemStyleData(
padding: EdgeInsets.symmetric(
horizontal: 16,
vertical: 4,
),
),
isExpanded: true, isExpanded: true,
dropdownElevation: 0,
value: ref.watch(addressEntryDataProvider(widget.id) value: ref.watch(addressEntryDataProvider(widget.id)
.select((value) => value.coin)), .select((value) => value.coin)),
onChanged: (value) { onChanged: (value) {
@ -109,31 +125,13 @@ class _NewContactAddressEntryFormState
ref.read(addressEntryDataProvider(widget.id)).coin = value; ref.read(addressEntryDataProvider(widget.id)).coin = value;
} }
}, },
iconStyleData: IconStyleData(
icon: SvgPicture.asset( icon: SvgPicture.asset(
Assets.svg.chevronDown, Assets.svg.chevronDown,
width: 10, width: 10,
height: 5, height: 5,
color: Theme.of(context).extension<StackColors>()!.textDark3, color: Theme.of(context).extension<StackColors>()!.textDark3,
), ),
buttonPadding: const EdgeInsets.symmetric(
horizontal: 16,
vertical: 4,
),
buttonDecoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
),
dropdownDecoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
), ),
items: [ items: [
...coins.map( ...coins.map(

View file

@ -654,7 +654,7 @@ class _Step4ViewState extends ConsumerState<Step4View> {
height: 24, height: 24,
), ),
Center( Center(
child: QrImage( child: QrImageView(
// TODO: grab coin uri scheme from somewhere // TODO: grab coin uri scheme from somewhere
// data: "${coin.uriScheme}:$receivingAddress", // data: "${coin.uriScheme}:$receivingAddress",
data: model.trade!.payInAddress, data: model.trade!.payInAddress,

View file

@ -768,7 +768,7 @@ class _TradeDetailsViewState extends ConsumerState<TradeDetailsView> {
child: SizedBox( child: SizedBox(
width: width + 20, width: width + 20,
height: width + 20, height: width + 20,
child: QrImage( child: QrImageView(
data: trade.payInAddress, data: trade.payInAddress,
size: width, size: width,
backgroundColor: Theme.of(context) backgroundColor: Theme.of(context)

View file

@ -369,7 +369,7 @@ class _PaynymDetailsPopupState extends ConsumerState<PaynymDetailsPopup> {
const SizedBox( const SizedBox(
width: 20, width: 20,
), ),
QrImage( QrImageView(
padding: const EdgeInsets.all(0), padding: const EdgeInsets.all(0),
size: 100, size: 100,
data: widget.accountLite.code, data: widget.accountLite.code,

View file

@ -147,7 +147,7 @@ class PaynymQrPopup extends StatelessWidget {
const SizedBox( const SizedBox(
width: 20, width: 20,
), ),
QrImage( QrImageView(
padding: const EdgeInsets.all(0), padding: const EdgeInsets.all(0),
size: 130, size: 130,
data: paynymAccount.nonSegwitPaymentCode.code, data: paynymAccount.nonSegwitPaymentCode.code,

View file

@ -356,7 +356,7 @@ class _PaynymDetailsPopupState extends ConsumerState<DesktopPaynymDetails> {
const SizedBox( const SizedBox(
width: 20, width: 20,
), ),
QrImage( QrImageView(
padding: const EdgeInsets.all(0), padding: const EdgeInsets.all(0),
size: 100, size: 100,
data: widget.accountLite.code, data: widget.accountLite.code,

View file

@ -77,7 +77,7 @@ class _AddressDetailsViewState extends ConsumerState<AddressDetailsView> {
Center( Center(
child: RepaintBoundary( child: RepaintBoundary(
key: _qrKey, key: _qrKey,
child: QrImage( child: QrImageView(
data: AddressUtils.buildUriString( data: AddressUtils.buildUriString(
ref.watch(walletsChangeNotifierProvider.select( ref.watch(walletsChangeNotifierProvider.select(
(value) => (value) =>
@ -266,7 +266,7 @@ class _AddressDetailsViewState extends ConsumerState<AddressDetailsView> {
Center( Center(
child: RepaintBoundary( child: RepaintBoundary(
key: _qrKey, key: _qrKey,
child: QrImage( child: QrImageView(
data: AddressUtils.buildUriString( data: AddressUtils.buildUriString(
ref.watch(walletsChangeNotifierProvider.select( ref.watch(walletsChangeNotifierProvider.select(
(value) => (value) =>

View file

@ -126,7 +126,7 @@ class _AddressQrPopupState extends State<AddressQrPopup> {
Center( Center(
child: RepaintBoundary( child: RepaintBoundary(
key: _qrKey, key: _qrKey,
child: QrImage( child: QrImageView(
data: AddressUtils.buildUriString( data: AddressUtils.buildUriString(
widget.coin, widget.coin,
widget.addressString, widget.addressString,

View file

@ -201,7 +201,7 @@ class _GenerateUriQrCodeViewState extends State<GenerateUriQrCodeView> {
child: SizedBox( child: SizedBox(
width: width + 20, width: width + 20,
height: width + 20, height: width + 20,
child: QrImage( child: QrImageView(
data: uriString, data: uriString,
size: width, size: width,
backgroundColor: backgroundColor:
@ -543,7 +543,7 @@ class _GenerateUriQrCodeViewState extends State<GenerateUriQrCodeView> {
child: SizedBox( child: SizedBox(
width: 234, width: 234,
height: 234, height: 234,
child: QrImage( child: QrImageView(
data: _uriString, data: _uriString,
size: 220, size: 220,
backgroundColor: Theme.of(context) backgroundColor: Theme.of(context)

View file

@ -320,7 +320,7 @@ class _ReceiveViewState extends ConsumerState<ReceiveView> {
child: Center( child: Center(
child: Column( child: Column(
children: [ children: [
QrImage( QrImageView(
data: "${coin.uriScheme}:$receivingAddress", data: "${coin.uriScheme}:$receivingAddress",
size: MediaQuery.of(context).size.width / 2, size: MediaQuery.of(context).size.width / 2,
foregroundColor: Theme.of(context) foregroundColor: Theme.of(context)

View file

@ -183,6 +183,7 @@ class _EditCoinUnitsViewState extends ConsumerState<EditCoinUnitsView> {
} }
}, },
isExpanded: true, isExpanded: true,
iconStyleData: IconStyleData(
icon: SvgPicture.asset( icon: SvgPicture.asset(
Assets.svg.chevronDown, Assets.svg.chevronDown,
width: 12, width: 12,
@ -191,25 +192,24 @@ class _EditCoinUnitsViewState extends ConsumerState<EditCoinUnitsView> {
.extension<StackColors>()! .extension<StackColors>()!
.textFieldActiveSearchIconRight, .textFieldActiveSearchIconRight,
), ),
buttonPadding: const EdgeInsets.symmetric( ),
dropdownStyleData: DropdownStyleData(
offset: const Offset(0, -10),
elevation: 0,
decoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
),
),
menuItemStyleData: const MenuItemStyleData(
padding: EdgeInsets.symmetric(
horizontal: 16, horizontal: 16,
vertical: 8, vertical: 8,
), ),
buttonDecoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
),
dropdownDecoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
), ),
), ),
), ),

View file

@ -616,9 +616,7 @@ class _EditAutoBackupViewState extends ConsumerState<EditAutoBackupView> {
if (isDesktop) if (isDesktop)
DropdownButtonHideUnderline( DropdownButtonHideUnderline(
child: DropdownButton2( child: DropdownButton2(
offset: const Offset(0, -10),
isExpanded: true, isExpanded: true,
dropdownElevation: 0,
value: _currentDropDownValue, value: _currentDropDownValue,
items: [ items: [
..._dropDownItems.map( ..._dropDownItems.map(
@ -662,31 +660,32 @@ class _EditAutoBackupViewState extends ConsumerState<EditAutoBackupView> {
}); });
} }
}, },
iconStyleData: IconStyleData(
icon: SvgPicture.asset( icon: SvgPicture.asset(
Assets.svg.chevronDown, Assets.svg.chevronDown,
width: 10, width: 10,
height: 5, height: 5,
color: Theme.of(context).extension<StackColors>()!.textDark3, color:
Theme.of(context).extension<StackColors>()!.textDark3,
), ),
buttonPadding: const EdgeInsets.symmetric( ),
dropdownStyleData: DropdownStyleData(
offset: const Offset(0, -10),
elevation: 0,
decoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
),
),
menuItemStyleData: const MenuItemStyleData(
padding: EdgeInsets.symmetric(
horizontal: 16, horizontal: 16,
vertical: 8, vertical: 8,
), ),
buttonDecoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
),
dropdownDecoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
), ),
), ),
), ),

View file

@ -243,7 +243,7 @@ class _XPub extends StatelessWidget {
builder: (child) => RoundedWhiteContainer( builder: (child) => RoundedWhiteContainer(
child: child, child: child,
), ),
child: QrImage( child: QrImageView(
data: xpub, data: xpub,
size: isDesktop ? 280 : MediaQuery.of(context).size.width / 1.5, size: isDesktop ? 280 : MediaQuery.of(context).size.width / 1.5,
foregroundColor: foregroundColor:

View file

@ -168,7 +168,7 @@ class WalletBackupView extends ConsumerWidget {
child: SizedBox( child: SizedBox(
width: width + 20, width: width + 20,
height: width + 20, height: width + 20,
child: QrImage( child: QrImageView(
data: data, data: data,
size: width, size: width,
backgroundColor: Theme.of(context) backgroundColor: Theme.of(context)

View file

@ -374,7 +374,7 @@ class _StepScaffoldState extends ConsumerState<StepScaffold> {
height: 48, height: 48,
), ),
Center( Center(
child: QrImage( child: QrImageView(
// TODO: grab coin uri scheme from somewhere // TODO: grab coin uri scheme from somewhere
// data: "${coin.uriScheme}:$receivingAddress", // data: "${coin.uriScheme}:$receivingAddress",
data: ref.watch(desktopExchangeModelProvider data: ref.watch(desktopExchangeModelProvider

View file

@ -198,27 +198,8 @@ class _DesktopFeeDropDownState extends ConsumerState<DesktopFeeDropDown> {
} }
return DropdownButtonHideUnderline( return DropdownButtonHideUnderline(
child: DropdownButton2( child: DropdownButton2(
offset: const Offset(0, -10),
isExpanded: true, isExpanded: true,
dropdownElevation: 0,
value: ref.watch(feeRateTypeStateProvider.state).state, value: ref.watch(feeRateTypeStateProvider.state).state,
// selectedItemBuilder: (s) {
// return [
// ...FeeRateType.values.map(
// (e) => DropdownMenuItem(
// value: e,
// child: FeeDropDownChild(
// feeObject: feeObject,
// feeRateType: e,
// walletId: walletId,
// amount: amount,
// feeFor: feeFor,
// isSelected: true,
// ),
// ),
// ),
// ];
// },
items: [ items: [
...FeeRateType.values.map( ...FeeRateType.values.map(
(e) => DropdownMenuItem( (e) => DropdownMenuItem(
@ -238,35 +219,36 @@ class _DesktopFeeDropDownState extends ConsumerState<DesktopFeeDropDown> {
ref.read(feeRateTypeStateProvider.state).state = newRateType; ref.read(feeRateTypeStateProvider.state).state = newRateType;
} }
}, },
iconStyleData: IconStyleData(
icon: SvgPicture.asset( icon: SvgPicture.asset(
Assets.svg.chevronDown, Assets.svg.chevronDown,
width: 12, width: 12,
height: 6, height: 6,
color: Theme.of(context).extension<StackColors>()!.textDark3, color: Theme.of(context).extension<StackColors>()!.textDark3,
), ),
buttonPadding: const EdgeInsets.symmetric( ),
dropdownStyleData: DropdownStyleData(
offset: const Offset(0, -10),
elevation: 0,
decoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
),
),
menuItemStyleData: const MenuItemStyleData(
padding: EdgeInsets.symmetric(
horizontal: 16, horizontal: 16,
vertical: 8, vertical: 8,
), ),
buttonDecoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
),
dropdownDecoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
), ),
), ),
); );
}); },
);
} }
} }

View file

@ -219,7 +219,7 @@ class _DesktopReceiveState extends ConsumerState<DesktopReceive> {
height: 32, height: 32,
), ),
Center( Center(
child: QrImage( child: QrImageView(
data: "${coin.uriScheme}:$receivingAddress", data: "${coin.uriScheme}:$receivingAddress",
size: 200, size: 200,
foregroundColor: foregroundColor:

View file

@ -869,9 +869,7 @@ class _DesktopSendState extends ConsumerState<DesktopSend> {
if (coin == Coin.firo) if (coin == Coin.firo)
DropdownButtonHideUnderline( DropdownButtonHideUnderline(
child: DropdownButton2( child: DropdownButton2(
offset: const Offset(0, -10),
isExpanded: true, isExpanded: true,
dropdownElevation: 0,
value: ref.watch(publicPrivateBalanceStateProvider.state).state, value: ref.watch(publicPrivateBalanceStateProvider.state).state,
items: [ items: [
DropdownMenuItem( DropdownMenuItem(
@ -929,31 +927,31 @@ class _DesktopSendState extends ConsumerState<DesktopSend> {
}); });
} }
}, },
iconStyleData: IconStyleData(
icon: SvgPicture.asset( icon: SvgPicture.asset(
Assets.svg.chevronDown, Assets.svg.chevronDown,
width: 12, width: 12,
height: 6, height: 6,
color: Theme.of(context).extension<StackColors>()!.textDark3, color: Theme.of(context).extension<StackColors>()!.textDark3,
), ),
buttonPadding: const EdgeInsets.symmetric( ),
dropdownStyleData: DropdownStyleData(
offset: const Offset(0, -10),
elevation: 0,
decoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
),
),
menuItemStyleData: const MenuItemStyleData(
padding: EdgeInsets.symmetric(
horizontal: 16, horizontal: 16,
vertical: 8, vertical: 8,
), ),
buttonDecoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
),
dropdownDecoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
), ),
), ),
), ),

View file

@ -20,16 +20,16 @@ class QRCodeDesktopPopupContent extends StatelessWidget {
maxWidth: 614, maxWidth: 614,
child: Column( child: Column(
children: [ children: [
Row( const Row(
mainAxisAlignment: MainAxisAlignment.end, mainAxisAlignment: MainAxisAlignment.end,
children: const [ children: [
DesktopDialogCloseButton(), DesktopDialogCloseButton(),
], ],
), ),
const SizedBox( const SizedBox(
height: 14, height: 14,
), ),
QrImage( QrImageView(
data: value, data: value,
size: 300, size: 300,
foregroundColor: foregroundColor:

View file

@ -468,9 +468,7 @@ class _CreateAutoBackup extends ConsumerState<CreateAutoBackup> {
child: isDesktop child: isDesktop
? DropdownButtonHideUnderline( ? DropdownButtonHideUnderline(
child: DropdownButton2( child: DropdownButton2(
offset: const Offset(0, -10),
isExpanded: true, isExpanded: true,
dropdownElevation: 0,
value: _currentDropDownValue, value: _currentDropDownValue,
items: [ items: [
..._dropDownItems.map( ..._dropDownItems.map(
@ -515,6 +513,7 @@ class _CreateAutoBackup extends ConsumerState<CreateAutoBackup> {
}); });
} }
}, },
iconStyleData: IconStyleData(
icon: SvgPicture.asset( icon: SvgPicture.asset(
Assets.svg.chevronDown, Assets.svg.chevronDown,
width: 10, width: 10,
@ -523,25 +522,24 @@ class _CreateAutoBackup extends ConsumerState<CreateAutoBackup> {
.extension<StackColors>()! .extension<StackColors>()!
.textDark3, .textDark3,
), ),
buttonPadding: const EdgeInsets.symmetric( ),
dropdownStyleData: DropdownStyleData(
offset: const Offset(0, -10),
elevation: 0,
decoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
),
),
menuItemStyleData: const MenuItemStyleData(
padding: EdgeInsets.symmetric(
horizontal: 16, horizontal: 16,
vertical: 8, vertical: 8,
), ),
buttonDecoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
),
dropdownDecoration: BoxDecoration(
color: Theme.of(context)
.extension<StackColors>()!
.textFieldDefaultBG,
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
), ),
), ),
) )