view.dart 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. import 'package:electronic_assistant/base/base_page.dart';
  2. import 'package:electronic_assistant/data/bean/template_bean.dart';
  3. import 'package:electronic_assistant/utils/expand.dart';
  4. import 'package:flutter/material.dart';
  5. import 'package:flutter/services.dart';
  6. import 'package:flutter/src/widgets/framework.dart';
  7. import 'package:flutter_screenutil/flutter_screenutil.dart';
  8. import 'package:get/get.dart';
  9. import 'package:get/get_core/src/get_main.dart';
  10. import '../../../resource/assets.gen.dart';
  11. import '../../../resource/colors.gen.dart';
  12. import '../../../resource/string.gen.dart';
  13. import '../../../router/app_pages.dart';
  14. import '../../../utils/common_style.dart';
  15. import 'controller.dart';
  16. class TemplateDetailPage extends BasePage<TemplateDetailController> {
  17. const TemplateDetailPage({super.key});
  18. static Future<dynamic> start(TemplateBean bean) async {
  19. return Get.toNamed(RoutePath.templateDetail, arguments: bean);
  20. }
  21. @override
  22. bool immersive() {
  23. return true;
  24. }
  25. @override
  26. Widget buildBody(BuildContext context) {
  27. return WillPopScope(
  28. onWillPop: () async {
  29. controller.onBack();
  30. return false;
  31. },
  32. child: Scaffold(
  33. backgroundColor: '#F6F6F6'.color,
  34. appBar: _buildAppBar(),
  35. body: Column(
  36. children: [
  37. Expanded(child: _buildTemplateList()),
  38. _buildTemplateBtn()
  39. ],
  40. ),
  41. ),
  42. );
  43. }
  44. Widget _buildTemplateBtn() {
  45. return Obx(() {
  46. return Visibility(
  47. visible: controller.templateBean != null,
  48. child: GestureDetector(
  49. onTap: () {
  50. controller.onUpdateTemplate();
  51. },
  52. child: Center(
  53. child: Obx(() {
  54. return Opacity(
  55. opacity:
  56. controller.templateBean?.isDefaultTemp == true ? 0.4 : 1,
  57. child: Container(
  58. margin: EdgeInsets.only(bottom: 16.w),
  59. decoration: getCommonDecoration(8.w),
  60. width: 328.w,
  61. height: 48.w,
  62. child: Center(
  63. child: Text(
  64. StringName.templateDetailUpdate.tr,
  65. style: TextStyle(fontSize: 16.sp, color: ColorName.white),
  66. ),
  67. ),
  68. ),
  69. );
  70. }),
  71. ),
  72. ),
  73. );
  74. });
  75. }
  76. Widget _buildTemplateList() {
  77. return Obx(() {
  78. return ListView.builder(
  79. padding: EdgeInsets.only(top: 12.w),
  80. itemCount: controller.templateTitle.length,
  81. itemBuilder: (context, index) {
  82. return _buildTemplateItem(controller.templateTitle[index]);
  83. },
  84. );
  85. });
  86. }
  87. Widget _buildTemplateItem(String title) {
  88. return Container(
  89. decoration: BoxDecoration(
  90. color: ColorName.white, borderRadius: BorderRadius.circular(8.w)),
  91. padding: EdgeInsets.only(left: 16.w, right: 12.w),
  92. margin: EdgeInsets.only(bottom: 8.h, left: 12.w, right: 12.w),
  93. child: Padding(
  94. padding: EdgeInsets.symmetric(vertical: 20.w),
  95. child: Text(title,
  96. style: TextStyle(
  97. fontSize: 15.sp, color: ColorName.primaryTextColor, height: 1)),
  98. ),
  99. );
  100. }
  101. AppBar _buildAppBar() {
  102. return AppBar(
  103. scrolledUnderElevation: 0,
  104. systemOverlayStyle: SystemUiOverlayStyle.dark,
  105. backgroundColor: Colors.transparent,
  106. title: Obx(() {
  107. return Text(
  108. controller.templateBean?.name ?? '',
  109. style: TextStyle(fontSize: 17.sp, color: ColorName.primaryTextColor),
  110. );
  111. }),
  112. centerTitle: true,
  113. leading: IconButton(
  114. onPressed: () {
  115. controller.onBack();
  116. },
  117. icon: SizedBox(
  118. width: 24.w,
  119. height: 24.w,
  120. child: Assets.images.iconBack.image())),
  121. );
  122. }
  123. }