base_info.dart 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. import 'package:fis_jsonrpc/rpc.dart';
  2. import 'package:flutter/material.dart';
  3. import 'package:get/get.dart';
  4. import 'package:vitalapp/consts/styles.dart';
  5. import '../controller.dart';
  6. /// 基本信息卡片
  7. class BaseInfoCard extends GetView<PatientDetailController> {
  8. const BaseInfoCard({super.key});
  9. @override
  10. Widget build(BuildContext context) {
  11. final state = controller.state;
  12. return _InfoCardContainer(
  13. child: Stack(
  14. children: [
  15. Padding(
  16. padding: const EdgeInsets.symmetric(horizontal: 14, vertical: 12),
  17. child: Obx(
  18. () => Column(
  19. children: [
  20. const SizedBox(height: 18),
  21. _buildItem("姓名", state.name),
  22. _buildItem("性别", state.genderDesc),
  23. _buildItem("年龄", state.age.toString()),
  24. _buildItem("电话", state.phone),
  25. _buildItem("身份证", state.cardNo),
  26. // const SizedBox(height: 8),
  27. _buildItem("地址", state.address),
  28. ],
  29. ),
  30. ),
  31. ),
  32. Positioned(
  33. top: 2,
  34. right: 6,
  35. child: _buildAvatar(),
  36. ),
  37. ],
  38. ),
  39. );
  40. }
  41. Widget _buildItem(String label, String content) {
  42. return SizedBox(
  43. height: 30,
  44. child: Row(
  45. children: [
  46. SizedBox(
  47. width: 60,
  48. child: Text(
  49. label,
  50. style: const TextStyle(color: Colors.grey, fontSize: 18),
  51. ),
  52. ),
  53. const SizedBox(width: 12),
  54. Expanded(
  55. child: Text(
  56. content,
  57. style: const TextStyle(
  58. color: Colors.black,
  59. fontSize: 18,
  60. ),
  61. overflow: TextOverflow.ellipsis,
  62. ),
  63. ),
  64. ],
  65. ),
  66. );
  67. }
  68. Widget _buildAvatar() {
  69. return Obx(() {
  70. final url = controller.state.avatarUrl;
  71. Widget image;
  72. if (url != null && url.isNotEmpty) {
  73. image = Image.network(url, fit: BoxFit.contain);
  74. } else {
  75. if (controller.state.gender == GenderEnum.Male) {
  76. image = Image.asset("assets/images/avatar_man.png");
  77. } else {
  78. image = Image.asset("assets/images/avatar_women.png");
  79. }
  80. }
  81. return SizedBox(
  82. width: 100,
  83. height: 100,
  84. // decoration: BoxDecoration(borderRadius: BorderRadius.circular(50)),
  85. child: ClipOval(
  86. child: image,
  87. ),
  88. );
  89. });
  90. }
  91. }
  92. class _InfoCardContainer extends StatelessWidget {
  93. final Widget child;
  94. const _InfoCardContainer({
  95. required this.child,
  96. });
  97. @override
  98. Widget build(BuildContext context) {
  99. return Container(
  100. alignment: Alignment.topLeft,
  101. padding: const EdgeInsets.symmetric(horizontal: 12, vertical: 8),
  102. decoration: BoxDecoration(
  103. color: Colors.white,
  104. borderRadius: GlobalStyles.borderRadius,
  105. ),
  106. child: child,
  107. );
  108. }
  109. }