Solian/lib/widgets/chat/channel_action.dart

132 lines
3.5 KiB
Dart
Raw Normal View History

2024-04-27 01:36:54 +08:00
import 'dart:convert';
import 'package:flutter/material.dart';
2024-04-27 01:36:54 +08:00
import 'package:provider/provider.dart';
import 'package:solian/models/call.dart';
import 'package:solian/models/channel.dart';
2024-04-27 01:36:54 +08:00
import 'package:solian/providers/auth.dart';
import 'package:solian/providers/chat.dart';
import 'package:solian/router.dart';
import 'package:solian/utils/services_url.dart';
2024-04-29 20:22:06 +08:00
import 'package:solian/widgets/exts.dart';
2024-04-27 01:36:54 +08:00
class ChannelCallAction extends StatefulWidget {
final Call? call;
final Channel channel;
2024-05-05 23:01:08 +08:00
final String realm;
final Function onUpdate;
2024-05-05 23:01:08 +08:00
const ChannelCallAction({
super.key,
this.call,
required this.channel,
required this.onUpdate,
this.realm = 'global',
});
2024-04-27 01:36:54 +08:00
@override
State<ChannelCallAction> createState() => _ChannelCallActionState();
}
class _ChannelCallActionState extends State<ChannelCallAction> {
bool _isSubmitting = false;
Future<void> makeCall() async {
setState(() => _isSubmitting = true);
final auth = context.read<AuthProvider>();
if (!await auth.isAuthorized()) {
setState(() => _isSubmitting = false);
return;
}
2024-05-05 23:01:08 +08:00
var uri = getRequestUri('messaging', '/api/channels/${widget.realm}/${widget.channel.alias}/calls');
2024-04-27 01:36:54 +08:00
var res = await auth.client!.post(uri);
if (res.statusCode != 200) {
var message = utf8.decode(res.bodyBytes);
2024-04-29 20:22:06 +08:00
context.showErrorDialog(message);
2024-04-27 01:36:54 +08:00
}
setState(() => _isSubmitting = false);
}
Future<void> endsCall() async {
setState(() => _isSubmitting = true);
final chat = context.read<ChatProvider>();
2024-04-27 01:36:54 +08:00
final auth = context.read<AuthProvider>();
if (!await auth.isAuthorized()) {
setState(() => _isSubmitting = false);
return;
}
2024-05-05 23:01:08 +08:00
var uri = getRequestUri('messaging', '/api/channels/${widget.realm}/${widget.channel.alias}/calls/ongoing');
2024-04-27 01:36:54 +08:00
var res = await auth.client!.delete(uri);
if (res.statusCode != 200) {
var message = utf8.decode(res.bodyBytes);
2024-04-29 20:22:06 +08:00
context.showErrorDialog(message);
} else {
if (chat.currentCall != null && chat.currentCall?.info.channelId == widget.channel.id) {
chat.currentCall!.deactivate();
chat.currentCall!.dispose();
}
2024-04-27 01:36:54 +08:00
}
setState(() => _isSubmitting = false);
}
@override
Widget build(BuildContext context) {
return IconButton(
onPressed: _isSubmitting
? null
: () {
if (widget.call == null) {
makeCall();
} else {
endsCall();
}
},
icon: widget.call == null ? const Icon(Icons.call) : const Icon(Icons.call_end),
2024-04-27 01:36:54 +08:00
);
}
}
class ChannelManageAction extends StatelessWidget {
final Channel channel;
final Function onUpdate;
2024-05-05 23:01:08 +08:00
final String realm;
2024-05-05 23:01:08 +08:00
const ChannelManageAction({
super.key,
required this.channel,
required this.onUpdate,
this.realm = 'global',
});
@override
Widget build(BuildContext context) {
2024-04-25 21:33:53 +08:00
return IconButton(
2024-04-26 23:25:56 +08:00
onPressed: () async {
final result = await SolianRouter.router.pushNamed(
2024-05-05 23:01:08 +08:00
realm == 'global' ? 'chat.channel.manage' : 'realms.chat.channel.manage',
2024-04-25 21:33:53 +08:00
extra: channel,
2024-05-05 23:01:08 +08:00
pathParameters: {
'channel': channel.alias,
...(realm == 'global' ? {} : {'realm': realm}),
},
2024-04-25 21:33:53 +08:00
);
2024-04-27 01:36:54 +08:00
switch (result) {
2024-04-26 23:25:56 +08:00
case 'disposed':
if (SolianRouter.router.canPop()) SolianRouter.router.pop('refresh');
2024-04-26 23:25:56 +08:00
case 'refresh':
onUpdate();
}
2024-04-25 21:33:53 +08:00
},
2024-04-27 01:36:54 +08:00
icon: const Icon(Icons.settings),
);
}
}