view.dart 3.5 KB

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