mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-06-28 04:19:50 +00:00
* feat: Integration tests setup and tests for Disclaimer, Welcome and Setup Pin Code pages * feat: Integration test flow from start to restoring a wallet successfully done * test: Dashboard view test and linking to flow * feat: Testing the Exchange flow section, selecting sending and receiving currencies * test: Successfully create an exchange section * feat: Implement flow up to sending section * test: Complete Exchange flow * fix dependency issue * test: Final cleanups * feat: Add CI to run automated integration tests withan android emulator * feat: Adjust Automated integration test CI to run on ubuntu 20.04-a * fix: Move integration test CI into PR test build CI * ci: Add automated test ci which is a streamlined replica of pr test build ci * ci: Re-add step to access branch name * ci: Add KVM * ci: Add filepath to trigger the test run from * ci: Add required key * ci: Add required key * ci: Add missing secret key * ci: Add missing secret key * ci: Add nano secrets to workflow * ci: Switch step to free space on runner * ci: Remove timeout from workflow * ci: Confirm impact that removing copy_monero_deps would have on entire workflow time * ci: Update CI and temporarily remove cache related to emulator * ci: Remove dynamic java version * ci: Temporarily switch CI * ci: Switch to 11.x jdk * ci: Temporarily switch CI * ci: Revert ubuntu version * ci: Add more api levels * ci: Add more target options * ci: Settled on stable emulator matrix options * ci: Add more target options * ci: Modify flow * ci: Streamline api levels to 28 and 29 * ci: One more trial * ci: Switch to flutter drive * ci: Reduce options * ci: Remove haven from test * ci: Check for solana in list * ci: Adjust amounts and currencies for exchange flow * ci: Set write response on failure to true * ci: Split ci to funds and non funds related tests * test: Test for Send flow scenario and minor restructuring for test folders and files * chore: cleanup * ci: Pause CI for now * ci: Pause CI for now * ci: Pause CI for now * Fix: Add keys back to currency amount textfield widget * fix: Switch variable name * fix: remove automation for now * test: Updating send page robot and also syncing branch with main --------- Co-authored-by: OmarHatem <omarh.ismail1@gmail.com>
71 lines
2.1 KiB
Dart
71 lines
2.1 KiB
Dart
import 'package:cake_wallet/utils/responsive_layout_util.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:cake_wallet/src/widgets/alert_background.dart';
|
|
import 'package:cake_wallet/src/widgets/alert_close_button.dart';
|
|
|
|
class PickerWrapperWidget extends StatelessWidget {
|
|
PickerWrapperWidget({
|
|
required this.children,
|
|
this.hasTitle = false,
|
|
this.onClose,
|
|
super.key,
|
|
});
|
|
|
|
final List<Widget> children;
|
|
final bool hasTitle;
|
|
final Function()? onClose;
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
final double padding = 24;
|
|
|
|
final mq = MediaQuery.of(context);
|
|
final bottom = mq.viewInsets.bottom;
|
|
final height = mq.size.height - bottom;
|
|
final screenCenter = height / 2;
|
|
|
|
double closeButtonBottom = 60;
|
|
double containerHeight = height * 0.65;
|
|
if (bottom > 0) {
|
|
// increase a bit or it gets too squished in the top
|
|
containerHeight = height * 0.75;
|
|
|
|
final containerCenter = containerHeight / 2;
|
|
final containerBottom = screenCenter - containerCenter;
|
|
|
|
// position the close button right below the search container
|
|
closeButtonBottom =
|
|
closeButtonBottom - containerBottom + (!hasTitle ? padding : padding / 1.5);
|
|
}
|
|
|
|
return AlertBackground(
|
|
child: Column(
|
|
children: [
|
|
Expanded(
|
|
flex: 1,
|
|
child: Stack(
|
|
alignment: Alignment.center,
|
|
children: <Widget>[
|
|
Column(
|
|
mainAxisSize: MainAxisSize.min,
|
|
children: children,
|
|
),
|
|
SizedBox(height: ResponsiveLayoutUtilBase.kPopupSpaceHeight),
|
|
AlertCloseButton(
|
|
key: ValueKey('picker_wrapper_close_button_key'),
|
|
bottom: closeButtonBottom,
|
|
onTap: onClose,
|
|
),
|
|
],
|
|
),
|
|
),
|
|
// gives the extra spacing using MediaQuery.viewInsets.bottom
|
|
// to simulate a keyboard area
|
|
SizedBox(
|
|
height: bottom,
|
|
)
|
|
],
|
|
),
|
|
);
|
|
}
|
|
}
|