Solian/lib/screens/chat/chat_detail.dart

146 lines
4.7 KiB
Dart
Raw Normal View History

2024-04-25 21:33:53 +08:00
import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
import 'package:solian/models/channel.dart';
import 'package:solian/providers/auth.dart';
2024-05-12 20:15:12 +08:00
import 'package:solian/providers/chat.dart';
2024-04-25 21:33:53 +08:00
import 'package:solian/router.dart';
2024-04-26 23:25:56 +08:00
import 'package:solian/widgets/chat/channel_deletion.dart';
import 'package:solian/widgets/scaffold.dart';
2024-04-25 21:33:53 +08:00
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
class ChatDetailScreen extends StatefulWidget {
2024-04-25 21:33:53 +08:00
final Channel channel;
2024-05-05 23:01:08 +08:00
final String realm;
2024-04-25 21:33:53 +08:00
2024-05-05 23:01:08 +08:00
const ChatDetailScreen({super.key, required this.channel, this.realm = 'global'});
2024-04-25 21:33:53 +08:00
@override
State<ChatDetailScreen> createState() => _ChatDetailScreenState();
2024-04-25 21:33:53 +08:00
}
class _ChatDetailScreenState extends State<ChatDetailScreen> {
2024-04-26 23:25:56 +08:00
bool _isOwned = false;
void promptLeaveChannel() async {
final did = await showDialog(
context: context,
2024-05-12 20:15:12 +08:00
builder: (context) =>
ChannelDeletion(
channel: widget.channel,
realm: widget.realm,
isOwned: _isOwned,
),
2024-04-26 23:25:56 +08:00
);
if (did == true && SolianRouter.router.canPop()) {
SolianRouter.router.pop('disposed');
2024-04-26 23:25:56 +08:00
}
}
2024-04-25 21:33:53 +08:00
@override
void initState() {
super.initState();
Future.delayed(Duration.zero, () async {
final auth = context.read<AuthProvider>();
final prof = await auth.getProfiles();
setState(() {
2024-04-26 23:25:56 +08:00
_isOwned = prof['id'] == widget.channel.account.externalId;
2024-04-25 21:33:53 +08:00
});
});
}
@override
Widget build(BuildContext context) {
2024-05-12 20:15:12 +08:00
final auth = context.read<AuthProvider>();
final chat = context.read<ChatProvider>();
2024-04-25 21:33:53 +08:00
final authorizedItems = [
ListTile(
leading: const Icon(Icons.settings),
title: Text(AppLocalizations.of(context)!.settings),
onTap: () async {
2024-05-12 20:15:12 +08:00
SolianRouter.router
.pushNamed(
'chat.channel.editor',
extra: widget.channel,
queryParameters: widget.realm != 'global' ? {'realm': widget.realm} : {},
)
.then((resp) {
if (resp != null) {
chat.fetchChannel(context, auth, resp as String, widget.realm);
2024-04-25 21:33:53 +08:00
}
});
},
),
];
return IndentScaffold(
2024-05-03 16:16:42 +08:00
title: AppLocalizations.of(context)!.chatDetail,
2024-04-25 21:33:53 +08:00
hideDrawer: true,
2024-05-08 22:01:06 +08:00
body: Column(
2024-04-25 21:33:53 +08:00
children: [
Padding(
padding: const EdgeInsets.symmetric(horizontal: 16, vertical: 12),
child: Row(
children: [
const CircleAvatar(
radius: 24,
backgroundColor: Colors.teal,
child: Icon(Icons.tag, color: Colors.white),
),
const SizedBox(width: 16),
2024-04-26 23:25:56 +08:00
Expanded(
2024-05-02 18:56:40 +08:00
child: Column(crossAxisAlignment: CrossAxisAlignment.start, children: [
2024-05-12 20:15:12 +08:00
Text(widget.channel.name, style: Theme
.of(context)
.textTheme
.bodyLarge),
Text(widget.channel.description, style: Theme
.of(context)
.textTheme
.bodySmall),
2024-05-02 18:56:40 +08:00
]),
2024-04-26 23:25:56 +08:00
)
2024-04-25 21:33:53 +08:00
],
),
),
const Divider(thickness: 0.3),
Expanded(
child: ListView(
children: [
ListTile(
leading: const Icon(Icons.edit_notifications),
title: Text(AppLocalizations.of(context)!.chatNotifySetting),
onTap: () {},
),
ListTile(
leading: const Icon(Icons.supervisor_account),
title: Text(AppLocalizations.of(context)!.chatMember),
2024-04-26 20:49:21 +08:00
onTap: () {
SolianRouter.router.pushNamed(
2024-05-08 22:01:06 +08:00
widget.realm == 'global' ? 'chat.channel.member' : 'realms.chat.channel.member',
2024-04-26 20:49:21 +08:00
extra: widget.channel,
2024-05-08 22:01:06 +08:00
pathParameters: {
'channel': widget.channel.alias,
...(widget.realm == 'global' ? {} : {'realm': widget.realm}),
},
2024-04-26 20:49:21 +08:00
);
},
2024-04-25 21:33:53 +08:00
),
2024-04-26 23:25:56 +08:00
...(_isOwned ? authorizedItems : List.empty()),
const Divider(thickness: 0.3),
ListTile(
2024-05-02 18:56:40 +08:00
leading: _isOwned ? const Icon(Icons.delete) : const Icon(Icons.exit_to_app),
title: Text(_isOwned ? AppLocalizations.of(context)!.delete : AppLocalizations.of(context)!.exit),
2024-04-26 23:25:56 +08:00
onTap: () => promptLeaveChannel(),
),
2024-04-25 21:33:53 +08:00
],
),
),
],
),
);
}
}