member_retain_dialog.dart 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. import 'dart:io';
  2. import 'package:flutter/material.dart';
  3. import 'package:flutter_screenutil/flutter_screenutil.dart';
  4. import 'package:flutter_smart_dialog/flutter_smart_dialog.dart';
  5. import 'package:location/resource/assets.gen.dart';
  6. import 'package:location/resource/string.gen.dart';
  7. class MemberRetainDialog {
  8. static final String _tag = 'MemberRetainDialog';
  9. static void show(
  10. {required VoidCallback payClick, required VoidCallback cancelClick}) {
  11. SmartDialog.show(
  12. tag: _tag,
  13. backDismiss: false,
  14. keepSingle: true,
  15. clickMaskDismiss: false,
  16. builder: (_) {
  17. return _MemberRetainDialogWidget(
  18. payClick: payClick,
  19. cancelClick: cancelClick);
  20. });
  21. }
  22. static void dismiss() {
  23. SmartDialog.dismiss(tag: _tag);
  24. }
  25. }
  26. class _MemberRetainDialogWidget extends Dialog {
  27. final VoidCallback payClick;
  28. final VoidCallback cancelClick;
  29. const _MemberRetainDialogWidget(
  30. {required this.payClick, required this.cancelClick});
  31. @override
  32. Widget build(BuildContext context) {
  33. return IntrinsicHeight(
  34. child: Column(
  35. children: [
  36. Stack(
  37. children: [
  38. Positioned(
  39. top: 0,
  40. left: 10.w,
  41. child: SizedBox(
  42. width: 300.w,
  43. child: AspectRatio(
  44. aspectRatio: 987 / 543,
  45. child: Assets.images.imgMemberRetainHeader.image()),
  46. ),
  47. ),
  48. Column(
  49. children: [
  50. SizedBox(height: 110.w),
  51. SizedBox(
  52. width: 294.w,
  53. child: AspectRatio(
  54. aspectRatio: 882 / 966,
  55. child: Assets.images.imgMemberRetainContainer.image()),
  56. )
  57. ],
  58. ),
  59. Positioned(
  60. bottom: 22.w,
  61. left: 36.w,
  62. right: 36.w,
  63. child: GestureDetector(
  64. onTap: () {
  65. MemberRetainDialog.dismiss();
  66. payClick();
  67. },
  68. child: Container(
  69. height: 40.w,
  70. decoration: BoxDecoration(
  71. gradient: LinearGradient(
  72. begin: Alignment.centerLeft, // 90度相当于从左到右
  73. end: Alignment.centerRight,
  74. colors: [
  75. Color(0xFF7B7DFF), // #7B7DFF
  76. Color(0xFF6365FF), // #6365FF
  77. ],
  78. stops: [0.0, 1.0],
  79. // 从0%到100%
  80. ),
  81. borderRadius: BorderRadius.circular(40.w / 2.0),
  82. ),
  83. //getPrimaryBtnDecoration(100.w),
  84. child: Center(
  85. child: Text(
  86. Platform.isAndroid
  87. ? StringName.memberContinuePay
  88. : StringName.memberContinuePayIos,
  89. style:
  90. TextStyle(fontSize: 15.sp, color: Colors.white)),
  91. ),
  92. ),
  93. ),
  94. )
  95. ],
  96. ),
  97. SizedBox(
  98. height: 24.w,
  99. ),
  100. Center(
  101. child: GestureDetector(
  102. onTap: () {
  103. MemberRetainDialog.dismiss();
  104. cancelClick();
  105. },
  106. child: Assets.images.iconMemberRetainClose
  107. .image(width: 32.w, height: 32.w),
  108. ),
  109. )
  110. ],
  111. ),
  112. );
  113. }
  114. }