feat: enhance server card layout and add logo display functionality (#804)

This commit is contained in:
Tom
2025-06-27 18:55:48 +08:00
committed by GitHub
parent e69808a2f6
commit dbc873c0c0
4 changed files with 61 additions and 20 deletions

View File

@@ -2,18 +2,41 @@ part of 'tab.dart';
extension on _ServerPageState {
Widget _buildServerCardTitle(Server s) {
const width = 16.0, height = 16.0;
final logoUrl = s.getLogoUrl(context);
if (logoUrl == null) {
return const SizedBox(width: width, height: height);
}
return Padding(
padding: const EdgeInsets.only(left: 7, right: 13),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [
LayoutBuilder(
builder: (_, cons) {
return ConstrainedBox(
constraints: BoxConstraints(maxWidth: cons.maxWidth / 2.3),
Row(
mainAxisSize: MainAxisSize.min,
children: [
SizedBox(
width: width,
height: height,
child: ExtendedImage.network(
logoUrl,
cache: true,
fit: BoxFit.contain,
loadStateChanged: (state) {
if (state.extendedImageLoadState == LoadState.failed) {
return const SizedBox(width: width, height: height);
}
return null;
},
),
),
const SizedBox(width: 6),
Flexible(
child: Text(s.spi.name, style: UIs.text13Bold, maxLines: 1, overflow: TextOverflow.ellipsis),
);
},
),
],
),
const Icon(Icons.keyboard_arrow_right, size: 17, color: Colors.grey),
const Spacer(),

View File

@@ -3,6 +3,7 @@
import 'dart:async';
import 'dart:math' as math;
import 'package:extended_image/extended_image.dart';
import 'package:fl_lib/fl_lib.dart';
import 'package:flutter/material.dart';
import 'package:icons_plus/icons_plus.dart';
@@ -20,6 +21,7 @@ import 'package:server_box/data/res/build_data.dart';
import 'package:server_box/data/res/store.dart';
import 'package:server_box/view/page/server/detail/view.dart';
import 'package:server_box/view/page/server/edit.dart';
import 'package:server_box/view/page/server/logo.dart';
import 'package:server_box/view/page/setting/entry.dart';
import 'package:server_box/view/widget/percent_circle.dart';
import 'package:server_box/view/widget/server_func_btns.dart';