2024-06-01 01:25:45 +08:00
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:get/get.dart';
|
|
|
|
import 'package:solian/exts.dart';
|
|
|
|
import 'package:solian/models/call.dart';
|
|
|
|
import 'package:solian/models/channel.dart';
|
|
|
|
import 'package:solian/models/realm.dart';
|
|
|
|
import 'package:solian/providers/auth.dart';
|
|
|
|
|
|
|
|
class ChatCallButton extends StatefulWidget {
|
|
|
|
final Realm? realm;
|
|
|
|
final Channel channel;
|
|
|
|
final Call? ongoingCall;
|
|
|
|
final Function? onStarted;
|
|
|
|
final Function? onEnded;
|
|
|
|
|
|
|
|
const ChatCallButton({
|
|
|
|
super.key,
|
|
|
|
required this.realm,
|
|
|
|
required this.channel,
|
|
|
|
required this.ongoingCall,
|
|
|
|
this.onStarted,
|
|
|
|
this.onEnded,
|
|
|
|
});
|
|
|
|
|
|
|
|
@override
|
|
|
|
State<ChatCallButton> createState() => _ChatCallButtonState();
|
|
|
|
}
|
|
|
|
|
|
|
|
class _ChatCallButtonState extends State<ChatCallButton> {
|
|
|
|
bool _isBusy = false;
|
|
|
|
|
|
|
|
Future<void> makeCall() async {
|
|
|
|
final AuthProvider auth = Get.find();
|
2024-07-25 01:18:47 +08:00
|
|
|
if (auth.isAuthorized.isFalse) return;
|
2024-06-01 01:25:45 +08:00
|
|
|
|
2024-06-22 22:39:32 +08:00
|
|
|
final client = auth.configureClient('messaging');
|
2024-06-01 01:25:45 +08:00
|
|
|
|
|
|
|
setState(() => _isBusy = true);
|
|
|
|
|
|
|
|
final scope = (widget.realm?.alias.isNotEmpty ?? false)
|
|
|
|
? widget.realm?.alias
|
|
|
|
: 'global';
|
|
|
|
final resp = await client.post(
|
2024-07-16 19:46:53 +08:00
|
|
|
'/channels/$scope/${widget.channel.alias}/calls',
|
2024-06-01 01:25:45 +08:00
|
|
|
{},
|
|
|
|
);
|
|
|
|
if (resp.statusCode == 200) {
|
|
|
|
if (widget.onStarted != null) widget.onStarted!();
|
|
|
|
} else {
|
|
|
|
context.showErrorDialog(resp.bodyString);
|
|
|
|
}
|
|
|
|
|
|
|
|
setState(() => _isBusy = false);
|
|
|
|
}
|
|
|
|
|
|
|
|
Future<void> endsCall() async {
|
|
|
|
final AuthProvider auth = Get.find();
|
2024-07-25 01:18:47 +08:00
|
|
|
if (auth.isAuthorized.isFalse) return;
|
2024-06-01 01:25:45 +08:00
|
|
|
|
2024-06-22 22:39:32 +08:00
|
|
|
final client = auth.configureClient('messaging');
|
2024-06-01 01:25:45 +08:00
|
|
|
|
|
|
|
setState(() => _isBusy = true);
|
|
|
|
|
|
|
|
final scope = (widget.realm?.alias.isNotEmpty ?? false)
|
|
|
|
? widget.realm?.alias
|
|
|
|
: 'global';
|
|
|
|
final resp = await client
|
2024-07-16 19:46:53 +08:00
|
|
|
.delete('/channels/$scope/${widget.channel.alias}/calls/ongoing');
|
2024-06-01 01:25:45 +08:00
|
|
|
if (resp.statusCode == 200) {
|
|
|
|
if (widget.onEnded != null) widget.onEnded!();
|
|
|
|
} else {
|
|
|
|
context.showErrorDialog(resp.bodyString);
|
|
|
|
}
|
|
|
|
|
|
|
|
setState(() => _isBusy = false);
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return IconButton(
|
|
|
|
onPressed: _isBusy
|
|
|
|
? null
|
|
|
|
: widget.ongoingCall == null
|
|
|
|
? makeCall
|
|
|
|
: endsCall,
|
|
|
|
icon: widget.ongoingCall == null
|
|
|
|
? const Icon(Icons.call)
|
|
|
|
: const Icon(Icons.call_end),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|