123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117 |
- import 'package:fis_jsonrpc/rpc.dart';
- import 'package:flutter/material.dart';
- import 'package:get/get.dart';
- import 'package:vitalapp/consts/styles.dart';
- import '../controller.dart';
- /// 基本信息卡片
- class BaseInfoCard extends GetView<PatientDetailController> {
- const BaseInfoCard({super.key});
- @override
- Widget build(BuildContext context) {
- final state = controller.state;
- return _InfoCardContainer(
- child: Stack(
- children: [
- Padding(
- padding: const EdgeInsets.symmetric(horizontal: 14, vertical: 12),
- child: Obx(
- () => Column(
- children: [
- const SizedBox(height: 18),
- _buildItem("姓名", state.name),
- _buildItem("性别", state.genderDesc),
- _buildItem("年龄", state.age.toString()),
- _buildItem("电话", state.phone),
- _buildItem("身份证", state.cardNo),
- // const SizedBox(height: 8),
- _buildItem("地址", state.address),
- ],
- ),
- ),
- ),
- Positioned(
- top: 2,
- right: 6,
- child: _buildAvatar(),
- ),
- ],
- ),
- );
- }
- Widget _buildItem(String label, String content) {
- return SizedBox(
- height: 30,
- child: Row(
- children: [
- SizedBox(
- width: 60,
- child: Text(
- label,
- style: const TextStyle(color: Colors.grey, fontSize: 18),
- ),
- ),
- const SizedBox(width: 12),
- Expanded(
- child: Text(
- content,
- style: const TextStyle(
- color: Colors.black,
- fontSize: 18,
- ),
- overflow: TextOverflow.ellipsis,
- ),
- ),
- ],
- ),
- );
- }
- Widget _buildAvatar() {
- return Obx(() {
- final url = controller.state.avatarUrl;
- Widget image;
- if (url != null && url.isNotEmpty) {
- image = Image.network(url, fit: BoxFit.contain);
- } else {
- if (controller.state.gender == GenderEnum.Male) {
- image = Image.asset("assets/images/avatar_man.png");
- } else {
- image = Image.asset("assets/images/avatar_women.png");
- }
- }
- return SizedBox(
- width: 100,
- height: 100,
- // decoration: BoxDecoration(borderRadius: BorderRadius.circular(50)),
- child: ClipOval(
- child: image,
- ),
- );
- });
- }
- }
- class _InfoCardContainer extends StatelessWidget {
- final Widget child;
- const _InfoCardContainer({
- required this.child,
- });
- @override
- Widget build(BuildContext context) {
- return Container(
- alignment: Alignment.topLeft,
- padding: const EdgeInsets.symmetric(horizontal: 12, vertical: 8),
- decoration: BoxDecoration(
- color: Colors.white,
- borderRadius: GlobalStyles.borderRadius,
- ),
- child: child,
- );
- }
- }
|