Status basis

This commit is contained in:
2024-06-27 00:31:03 +08:00
parent 7c35323279
commit d91680ada7
11 changed files with 236 additions and 66 deletions

View File

@ -1,9 +1,12 @@
import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'package:solian/models/account.dart';
import 'package:solian/models/account_status.dart';
import 'package:solian/platform.dart';
import 'package:solian/providers/status.dart';
import 'package:solian/widgets/account/account_avatar.dart';
import 'package:solian/widgets/account/account_badge.dart';
import 'package:solian/widgets/account/account_status_action.dart';
class AccountHeadingWidget extends StatelessWidget {
final dynamic avatar;
@ -13,6 +16,9 @@ class AccountHeadingWidget extends StatelessWidget {
final String? desc;
final List<AccountBadge>? badges;
final Future<Response>? status;
final Function? onEditStatus;
const AccountHeadingWidget({
super.key,
this.avatar,
@ -21,8 +27,18 @@ class AccountHeadingWidget extends StatelessWidget {
required this.nick,
required this.desc,
required this.badges,
this.status,
this.onEditStatus,
});
void showStatusAction(BuildContext context, bool hasStatus) {
showModalBottomSheet(
useRootNavigator: true,
context: context,
builder: (context) => AccountStatusAction(hasStatus: hasStatus),
);
}
@override
Widget build(BuildContext context) {
return Material(
@ -55,23 +71,59 @@ class AccountHeadingWidget extends StatelessWidget {
),
],
),
Row(
crossAxisAlignment: CrossAxisAlignment.baseline,
textBaseline: TextBaseline.alphabetic,
Column(
children: [
Text(
nick,
style: const TextStyle(
fontSize: 17,
fontWeight: FontWeight.bold,
),
).paddingOnly(right: 4),
Text(
'@$name',
style: const TextStyle(
fontSize: 15,
),
Row(
crossAxisAlignment: CrossAxisAlignment.baseline,
textBaseline: TextBaseline.alphabetic,
children: [
Text(
nick,
style: const TextStyle(
fontSize: 17,
fontWeight: FontWeight.bold,
),
).paddingOnly(right: 4),
Text(
'@$name',
style: const TextStyle(
fontSize: 15,
),
),
],
),
if (status != null)
SizedBox(
width: double.infinity,
child: FutureBuilder(
future: status,
builder: (context, snapshot) {
if (!snapshot.hasData || snapshot.data!.body == null) {
return Text('loading'.tr);
}
final info = StatusController.determineStatus(
AccountStatus.fromJson(snapshot.data!.body),
);
return GestureDetector(
child: Row(
crossAxisAlignment: CrossAxisAlignment.center,
children: [
Text(info.$2),
info.$1.paddingSymmetric(horizontal: 6),
],
),
onTap: () {
showStatusAction(
context,
snapshot.data!.body['status'] != null,
);
},
);
},
),
),
],
).paddingOnly(left: 116, top: 6),
const SizedBox(height: 4),

View File

@ -2,6 +2,7 @@ import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'package:solian/exts.dart';
import 'package:solian/models/account.dart';
import 'package:solian/providers/status.dart';
import 'package:solian/services.dart';
import 'package:solian/widgets/account/account_heading.dart';
@ -60,6 +61,7 @@ class _AccountProfilePopupState extends State<AccountProfilePopup> {
nick: _userinfo!.nick,
desc: _userinfo!.description,
badges: _userinfo!.badges,
status: Get.find<StatusController>().getSomeoneStatus(_userinfo!.name),
).paddingOnly(top: 16),
],
),

View File

@ -0,0 +1,62 @@
import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'package:solian/providers/status.dart';
class AccountStatusAction extends StatelessWidget {
final bool hasStatus;
const AccountStatusAction({super.key, this.hasStatus = false});
@override
Widget build(BuildContext context) {
return SizedBox(
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Text(
'accountChangeStatus'.tr,
style: Theme.of(context).textTheme.headlineSmall,
).paddingOnly(left: 24, right: 24, top: 32, bottom: 16),
Expanded(
child: ListView(
children: [
SizedBox(
height: 48,
child: ListView(
scrollDirection: Axis.horizontal,
children: StatusController.presetStatuses.entries
.map(
(x) => ActionChip(
avatar: x.value.$1,
label: Text(x.value.$2),
tooltip: x.value.$3,
onPressed: () {},
).paddingOnly(right: 6),
)
.toList(),
).paddingSymmetric(horizontal: 18),
),
const Divider(thickness: 0.3, height: 0.3)
.paddingSymmetric(vertical: 16),
ListTile(
contentPadding: const EdgeInsets.symmetric(horizontal: 24),
leading: hasStatus
? const Icon(Icons.edit)
: const Icon(Icons.add),
title: Text('accountCustomStatus'.tr),
onTap: () {},
),
ListTile(
contentPadding: const EdgeInsets.symmetric(horizontal: 24),
leading: const Icon(Icons.clear),
title: Text('accountClearStatus'.tr),
onTap: () {},
),
],
),
),
],
),
);
}
}

View File

@ -31,7 +31,6 @@ class _PostQuickActionState extends State<PostQuickAction> {
void showReactMenu() {
showModalBottomSheet(
useRootNavigator: true,
isScrollControlled: true,
context: context,
builder: (context) => PostReactionPopup(
item: widget.item,

View File

@ -12,7 +12,6 @@ class PostReactionPopup extends StatelessWidget {
@override
Widget build(BuildContext context) {
return SizedBox(
height: MediaQuery.of(context).size.height * 0.85,
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [