弹出电话页面

This commit is contained in:
GYJ
2024-11-27 18:18:08 +08:00
parent 938a5df35f
commit 1da1683adc
14 changed files with 252 additions and 16 deletions

37
lib/call/call_view.dart Normal file
View File

@@ -0,0 +1,37 @@
import 'package:cashier_reserve/common/base/ui.dart';
import 'package:cashier_reserve/common/channel/model/call_status_change_model.dart';
class CallView extends StatefulWidget {
final CallStatusChangeModel statusModel;
const CallView({super.key, required this.statusModel});
@override
State<StatefulWidget> createState() {
return _CallViewState();
}
}
class _CallViewState extends State<CallView> {
@override
Widget build(BuildContext context) {
return PopScope(
canPop: false,
child: Scaffold(
backgroundColor: Colors.black.withOpacity(0.2),
body: GestureDetector(
onTap: () {
FocusScope.of(context).requestFocus(FocusNode());
},
child: Container(
width: MediaQuery.of(context).size.width,
height: MediaQuery.of(context).size.height,
color: Colors.blue,
child: Container(),
),
),
),
);
}
}

View File

@@ -1,15 +1,17 @@
import 'dart:convert';
import 'package:cashier_reserve/common/channel/model/call_status_change_model.dart';
import 'package:cashier_reserve/common/print/print.dart';
import 'package:flutter/services.dart';
import '../manager/event_manager.dart';
import 'call_log_model.dart';
import 'model/call_log_model.dart';
import 'names.dart';
class MyEventChannel {
static void startListener() {
onGetCallLogResult();
onCallStatusChange();
}
static void onGetCallLogResult() {
@@ -35,4 +37,18 @@ class MyEventChannel {
yjPrint("onGetCallLogResult error");
});
}
static void onCallStatusChange() {
EventChannel channel = EventChannel(getChannelName(kCallStatusChange));
channel.receiveBroadcastStream().listen((Object? o) {
yjPrint("onCallStatusChange: $o");
if (o is String) {
Map<String, dynamic> m = json.decode(o);
CallStatusChangeModel model = CallStatusChangeModel.fromJson(m);
EventManager.postEvent(CallStatusChangeEvent(model: model));
}
}, onError: (Object error) {
yjPrint("onCallStatusChange error");
});
}
}

View File

@@ -0,0 +1,54 @@
import 'dart:convert';
/// state : "Incoming"
/// number : "18020143310"
/// name : "gong"
/// region : "江苏省 南京市"
CallStatusChangeModel callStatusChangeModelFromJson(String str) => CallStatusChangeModel.fromJson(json.decode(str));
String callStatusChangeModelToJson(CallStatusChangeModel data) => json.encode(data.toJson());
class CallStatusChangeModel {
CallStatusChangeModel({
String? state,
String? number,
String? name,
String? region,}){
_state = state;
_number = number;
_name = name;
_region = region;
}
CallStatusChangeModel.fromJson(dynamic json) {
_state = json['state'];
_number = json['number'];
_name = json['name'];
_region = json['region'];
}
String? _state;
String? _number;
String? _name;
String? _region;
CallStatusChangeModel copyWith({ String? state,
String? number,
String? name,
String? region,
}) => CallStatusChangeModel( state: state ?? _state,
number: number ?? _number,
name: name ?? _name,
region: region ?? _region,
);
String? get state => _state;
String? get number => _number;
String? get name => _name;
String? get region => _region;
Map<String, dynamic> toJson() {
final map = <String, dynamic>{};
map['state'] = _state;
map['number'] = _number;
map['name'] = _name;
map['region'] = _region;
return map;
}
}

View File

@@ -4,6 +4,8 @@ const String kGetCallLog = 'getCallLog';
const String kCallLogCallback = 'callLogCallback';
const String kCallStatusChange = 'callStatusChange';
String getChannelName(name) {
return kChannelBaseName + name;
}

View File

@@ -1,6 +1,7 @@
import 'dart:async';
import 'package:cashier_reserve/common/channel/call_log_model.dart';
import 'package:cashier_reserve/common/channel/model/call_log_model.dart';
import 'package:cashier_reserve/common/channel/model/call_status_change_model.dart';
import 'package:event_bus/event_bus.dart';
@@ -51,4 +52,10 @@ class GetCallLogEvent extends MyEvent {
bool isSuccess = false;
GetCallLogEvent({this.callLogs = const [], this.isLoadMore = false, this.isSuccess = false});
}
class CallStatusChangeEvent extends MyEvent {
CallStatusChangeModel model;
CallStatusChangeEvent({required this.model});
}

View File

@@ -1,7 +1,11 @@
import 'package:cashier_reserve/call/call_view.dart';
import 'package:cashier_reserve/common/base/ui.dart';
import 'package:cashier_reserve/common/base/ui_model.dart';
import 'package:cashier_reserve/common/channel/model/call_status_change_model.dart';
import 'package:cashier_reserve/common/manager/app_manager.dart';
import 'package:cashier_reserve/common/manager/event_manager.dart';
import 'package:cashier_reserve/common/print/print.dart';
import 'package:cashier_reserve/common/push/push.dart';
class HomeViewModel extends BaseUIModel {
int _currentIndex = 0;
@@ -37,12 +41,23 @@ class HomeViewModel extends BaseUIModel {
PageController? get pageController => _pageController;
bool isShowCallView = false;
HomeViewModel() {
_pageController = PageController(initialPage: 0);
Future.delayed(const Duration(milliseconds: 700), () {
_checkLogin();
});
EventManager.addListener<CallStatusChangeEvent>(this, (event) {
yjPrint("HomeViewModel CallStatusChangeEvent state: ${event.model.state}");
if (event.model.state == "Incoming") {
showCallInfoView(event.model);
} else {
hideCallInfoView();
}
});
}
@override
@@ -65,4 +80,20 @@ class HomeViewModel extends BaseUIModel {
_pageController?.jumpToPage(index);
}
showCallInfoView(CallStatusChangeModel model) {
if (isShowCallView) {
return;
}
YJPush.presentWidget(context!, CallView(statusModel: model));
isShowCallView = true;
}
hideCallInfoView() {
if (!isShowCallView) {
return;
}
Navigator.of(context!).pop();
isShowCallView = false;
}
}

View File

@@ -1,5 +1,5 @@
import 'package:cashier_reserve/common/base/ui.dart';
import 'package:cashier_reserve/common/channel/call_log_model.dart';
import 'package:cashier_reserve/common/channel/model/call_log_model.dart';
import 'package:cashier_reserve/common/print/print.dart';
import 'package:cashier_reserve/data_model/reserve/reserve_log_model.dart';
import 'package:cashier_reserve/home/reserve_view_model.dart';

View File

@@ -1,6 +1,5 @@
import 'package:cashier_reserve/common/base/ui.dart';
import 'package:cashier_reserve/common/base/ui_model.dart';
import 'package:cashier_reserve/common/channel/call_log_model.dart';
import 'package:cashier_reserve/common/channel/model/call_log_model.dart';
import 'package:cashier_reserve/common/channel/channel_manager.dart';
import 'package:cashier_reserve/common/manager/app_manager.dart';
import 'package:cashier_reserve/common/manager/event_manager.dart';