Merge branch 'development_new_design_2.0' of https://gitlab.com/Cloud_Solution/diplomatic-quarter into hussam_pharmacy_fix
Conflicts: lib/pages/pharmacies/screens/product-details/product-name-and-price.dartmerge-requests/549/head
commit
141e650276
@ -1 +1 @@
|
|||||||
3f8c659591fcdd0e47e3895f74af395c
|
8d8845c5c035b7f87f2849054cdedb69
|
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,147 @@
|
|||||||
|
// import 'package:diplomaticquarterapp/pages/webRTC/signaling_bkp.dart';
|
||||||
|
// import 'package:diplomaticquarterapp/widgets/others/app_scaffold_widget.dart';
|
||||||
|
// import 'package:flutter/material.dart';
|
||||||
|
// import 'package:flutter_webrtc/flutter_webrtc.dart';
|
||||||
|
//
|
||||||
|
// class CallPage extends StatefulWidget {
|
||||||
|
// @override
|
||||||
|
// _CallPageState createState() => _CallPageState();
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// class _CallPageState extends State<CallPage> {
|
||||||
|
// Signaling signaling = Signaling();
|
||||||
|
// RTCVideoRenderer _localRenderer = RTCVideoRenderer();
|
||||||
|
// RTCVideoRenderer _remoteRenderer = RTCVideoRenderer();
|
||||||
|
// String roomId;
|
||||||
|
// TextEditingController textEditingController = TextEditingController(text: '');
|
||||||
|
//
|
||||||
|
// @override
|
||||||
|
// void initState() {
|
||||||
|
// _localRenderer.initialize();
|
||||||
|
// _remoteRenderer.initialize();
|
||||||
|
//
|
||||||
|
// signaling.onAddRemoteStream = ((stream) {
|
||||||
|
// _remoteRenderer.srcObject = stream;
|
||||||
|
// setState(() {});
|
||||||
|
// });
|
||||||
|
//
|
||||||
|
// super.initState();
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// @override
|
||||||
|
// void dispose() {
|
||||||
|
// _localRenderer.dispose();
|
||||||
|
// _remoteRenderer.dispose();
|
||||||
|
// super.dispose();
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// void _getUserMedia() async {
|
||||||
|
// final Map<String, dynamic> constraints = {
|
||||||
|
// 'audio': 'false',
|
||||||
|
// 'video': {'facingMode': 'user'},
|
||||||
|
// };
|
||||||
|
//
|
||||||
|
// MediaStream stream = await navigator.mediaDevices.getUserMedia(constraints);
|
||||||
|
// setState(() {
|
||||||
|
// _localRenderer.srcObject = stream;
|
||||||
|
// });
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// void initializeRenderers() async {
|
||||||
|
// _localRenderer.initialize();
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// @override
|
||||||
|
// Widget build(BuildContext context) {
|
||||||
|
// return AppScaffold(
|
||||||
|
// isShowAppBar: true,
|
||||||
|
// showNewAppBar: true,
|
||||||
|
// showNewAppBarTitle: true,
|
||||||
|
// isShowDecPage: false,
|
||||||
|
// appBarTitle: "WebRTC Calling",
|
||||||
|
// body: Column(
|
||||||
|
// children: [
|
||||||
|
// SizedBox(height: 8),
|
||||||
|
// Wrap(
|
||||||
|
// children: [
|
||||||
|
// ElevatedButton(
|
||||||
|
// onPressed: () {
|
||||||
|
// setState(() {
|
||||||
|
// signaling.openUserMedia(_localRenderer, _remoteRenderer);
|
||||||
|
// });
|
||||||
|
// },
|
||||||
|
// child: Text("Open camera & microphone"),
|
||||||
|
// ),
|
||||||
|
// SizedBox(
|
||||||
|
// width: 8,
|
||||||
|
// ),
|
||||||
|
// ElevatedButton(
|
||||||
|
// onPressed: () async {
|
||||||
|
// roomId = await signaling.createRoom(_remoteRenderer);
|
||||||
|
// textEditingController.text = roomId;
|
||||||
|
// setState(() {});
|
||||||
|
// },
|
||||||
|
// child: Text("Create room"),
|
||||||
|
// ),
|
||||||
|
// SizedBox(
|
||||||
|
// width: 8,
|
||||||
|
// ),
|
||||||
|
// ElevatedButton(
|
||||||
|
// onPressed: () {
|
||||||
|
// // Add roomId
|
||||||
|
// signaling.joinRoom(
|
||||||
|
// textEditingController.text,
|
||||||
|
// _remoteRenderer,
|
||||||
|
// );
|
||||||
|
// },
|
||||||
|
// child: Text("Join room"),
|
||||||
|
// ),
|
||||||
|
// SizedBox(
|
||||||
|
// width: 8,
|
||||||
|
// ),
|
||||||
|
// ElevatedButton(
|
||||||
|
// onPressed: () {
|
||||||
|
// signaling.hangUp(_localRenderer);
|
||||||
|
// },
|
||||||
|
// child: Text("Hangup"),
|
||||||
|
// )
|
||||||
|
// ],
|
||||||
|
// ),
|
||||||
|
// SizedBox(height: 8),
|
||||||
|
// Expanded(
|
||||||
|
// child: Padding(
|
||||||
|
// padding: const EdgeInsets.all(0.0),
|
||||||
|
// child: Stack(
|
||||||
|
// children: [
|
||||||
|
// Positioned(top: 0.0, right: 0.0, left: 0.0, bottom: 0.0, child: RTCVideoView(_remoteRenderer)),
|
||||||
|
// Positioned(
|
||||||
|
// top: 20.0,
|
||||||
|
// right: 100.0,
|
||||||
|
// left: 20.0,
|
||||||
|
// bottom: 300.0,
|
||||||
|
// child: RTCVideoView(_localRenderer, mirror: true),
|
||||||
|
// ),
|
||||||
|
// ],
|
||||||
|
// ),
|
||||||
|
// ),
|
||||||
|
// ),
|
||||||
|
// Padding(
|
||||||
|
// padding: const EdgeInsets.all(8.0),
|
||||||
|
// child: Row(
|
||||||
|
// mainAxisAlignment: MainAxisAlignment.center,
|
||||||
|
// children: [
|
||||||
|
// Text("Join the following Room: "),
|
||||||
|
// Flexible(
|
||||||
|
// child: TextFormField(
|
||||||
|
// controller: textEditingController,
|
||||||
|
// ),
|
||||||
|
// )
|
||||||
|
// ],
|
||||||
|
// ),
|
||||||
|
// ),
|
||||||
|
// SizedBox(height: 8)
|
||||||
|
// ],
|
||||||
|
// ),
|
||||||
|
// );
|
||||||
|
// }
|
||||||
|
// }
|
@ -0,0 +1,86 @@
|
|||||||
|
|
||||||
|
import 'dart:convert';
|
||||||
|
|
||||||
|
import 'package:diplomaticquarterapp/core/service/client/base_app_client.dart';
|
||||||
|
import 'package:http/http.dart' as http;
|
||||||
|
|
||||||
|
const _serverFCMToken = 'ya29.a0ARrdaM9U7fZtxF64ntg2Y1Nve-cd4rPazyGcWN69cQmOsddUqxAL1X8GUQ8V6sW2gWxM8ln1BIbmh0OrzQtCiTGrsmcL3jZlGXoQhZN51nX3O7F3g1AXCW_Zt_pjiworCJEGSRkl7QirxE7RFzlwBONsOuft';
|
||||||
|
const doctorID = '12345';
|
||||||
|
|
||||||
|
class FCM{
|
||||||
|
static Future<bool> sendCallNotifcationTo(String token, String patientID, String patientMobile) async{
|
||||||
|
var headers = {
|
||||||
|
'Authorization': 'Bearer $_serverFCMToken',
|
||||||
|
'Content-Type': 'application/json'
|
||||||
|
};
|
||||||
|
|
||||||
|
final body = {
|
||||||
|
"message": {
|
||||||
|
"token": token,
|
||||||
|
"notification": {
|
||||||
|
"title": "Dr Sulaiman Al Habib",
|
||||||
|
"body": "Doctor is calling"
|
||||||
|
},
|
||||||
|
"apns": {
|
||||||
|
"payload": {
|
||||||
|
"aps": {
|
||||||
|
"sound": "ring_30Sec.mp3",
|
||||||
|
"token": "466e0f16fecf1e32c51f812cccc84fcbc807f958b15eb55675a5fa971a775829",
|
||||||
|
"badge": 1
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"headers": {
|
||||||
|
"apns-priority": "10",
|
||||||
|
"apns-expiration": "0",
|
||||||
|
"apns-collapse-id": "2561368006"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"data": {
|
||||||
|
"callerID" : doctorID,
|
||||||
|
"receiverID" : patientID,
|
||||||
|
"receiverMobile" : patientMobile,
|
||||||
|
"msgID": "123",
|
||||||
|
"notfID": "123",
|
||||||
|
"notification_foreground": "true",
|
||||||
|
"count": "1",
|
||||||
|
"message": "Doctor is calling ",
|
||||||
|
"AppointmentNo": "123",
|
||||||
|
"title": "Rayyan Hospital",
|
||||||
|
"ProjectID": "123",
|
||||||
|
"NotificationType": "10",
|
||||||
|
"background": "1",
|
||||||
|
"doctorname": "Dr Sulaiman Al Habib",
|
||||||
|
"clinicname": "ENT Clinic",
|
||||||
|
"speciality": "Speciality",
|
||||||
|
"appointmentdate": "Sun, 15th Dec, 2019",
|
||||||
|
"appointmenttime": "09:00",
|
||||||
|
"type": "video",
|
||||||
|
"session_id": "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiIsImN0eSI6InR3aWxpby1mcGE7dj0xIn0.eyJqdGkiOiJTS2I2NjYyOWMzN2ZhOTM3YjFjNDI2Zjg1MTgyNWFmN2M0LTE1OTg3NzQ1MDYiLCJpc3MiOiJTS2I2NjYyOWMzN2ZhOTM3YjFjNDI2Zjg1MTgyNWFmN2M0Iiwic3ViIjoiQUNhYWQ1YTNmOGM2NGZhNjczNTY3NTYxNTc0N2YyNmMyYiIsImV4cCI6MTU5ODc3ODEwNiwiZ3JhbnRzIjp7ImlkZW50aXR5IjoiSGFyb29uMSIsInZpZGVvIjp7InJvb20iOiJTbWFsbERhaWx5U3RhbmR1cCJ9fX0.7XUS5uMQQJfkrBZu9EjQ6STL6R7iXkso6BtO1HmrQKk",
|
||||||
|
"identity": "Haroon1",
|
||||||
|
"name": "SmallDailyStandup",
|
||||||
|
"videoUrl": "video",
|
||||||
|
"picture": "video",
|
||||||
|
"is_call": "true"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
bool success = false;
|
||||||
|
await BaseAppClient().simplePost('https://fcm.googleapis.com/v1/projects/api-project-815750722565/messages:send', body: body, headers: headers, onSuccess: (data, statusCode){
|
||||||
|
success = true;
|
||||||
|
}, onFailure: (error, statusCode){
|
||||||
|
success = false;
|
||||||
|
});
|
||||||
|
|
||||||
|
return success;
|
||||||
|
// final response = await http.post('https://fcm.googleapis.com/v1/projects/api-project-815750722565/messages:send', headers:headers, body: body);
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
String toB64(String data){
|
||||||
|
var bytes = utf8.encode(data);
|
||||||
|
var base64Str = base64.encode(bytes);
|
||||||
|
return base64Str;
|
||||||
|
}
|
@ -0,0 +1,242 @@
|
|||||||
|
import 'dart:convert';
|
||||||
|
|
||||||
|
// import 'package:cloud_firestore/cloud_firestore.dart';
|
||||||
|
import 'package:flutter_webrtc/flutter_webrtc.dart';
|
||||||
|
|
||||||
|
typedef void StreamStateCallback(MediaStream stream);
|
||||||
|
|
||||||
|
class Signaling {
|
||||||
|
Map<String, dynamic> configuration = {
|
||||||
|
'iceServers': [
|
||||||
|
{
|
||||||
|
'urls': ['stun:stun1.l.google.com:19302', 'stun:stun2.l.google.com:19302']
|
||||||
|
}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
|
||||||
|
RTCPeerConnection peerConnection;
|
||||||
|
MediaStream localStream;
|
||||||
|
MediaStream remoteStream;
|
||||||
|
String roomId;
|
||||||
|
String currentRoomText;
|
||||||
|
StreamStateCallback onAddRemoteStream;
|
||||||
|
|
||||||
|
Future<String> createRoom(RTCVideoRenderer remoteRenderer) async {
|
||||||
|
// FirebaseFirestore db = FirebaseFirestore.instance;
|
||||||
|
// DocumentReference roomRef = db.collection('rooms').doc();
|
||||||
|
|
||||||
|
print('Create PeerConnection with configuration: $configuration');
|
||||||
|
|
||||||
|
peerConnection = await createPeerConnection(configuration);
|
||||||
|
|
||||||
|
registerPeerConnectionListeners();
|
||||||
|
|
||||||
|
localStream.getTracks().forEach((track) {
|
||||||
|
peerConnection?.addTrack(track, localStream);
|
||||||
|
});
|
||||||
|
|
||||||
|
// Code for collecting ICE candidates below
|
||||||
|
// var callerCandidatesCollection = roomRef.collection('callerCandidates');
|
||||||
|
|
||||||
|
peerConnection?.onIceCandidate = (RTCIceCandidate candidate) {
|
||||||
|
print('Got candidate: ${candidate.toMap()}');
|
||||||
|
// callerCandidatesCollection.add(candidate.toMap());
|
||||||
|
};
|
||||||
|
// Finish Code for collecting ICE candidate
|
||||||
|
|
||||||
|
// Add code for creating a room
|
||||||
|
RTCSessionDescription offer = await peerConnection.createOffer();
|
||||||
|
await peerConnection.setLocalDescription(offer);
|
||||||
|
print('Created offer: $offer');
|
||||||
|
|
||||||
|
Map<String, dynamic> roomWithOffer = {'offer': offer.toMap()};
|
||||||
|
|
||||||
|
// await roomRef.set(roomWithOffer);
|
||||||
|
// var roomId = roomRef.id;
|
||||||
|
print('New room created with SDK offer. Room ID: $roomId');
|
||||||
|
currentRoomText = 'Current room is $roomId - You are the caller!';
|
||||||
|
// Created a Room
|
||||||
|
|
||||||
|
peerConnection?.onTrack = (RTCTrackEvent event) {
|
||||||
|
print('Got remote track: ${event.streams[0]}');
|
||||||
|
|
||||||
|
event.streams[0].getTracks().forEach((track) {
|
||||||
|
print('Add a track to the remoteStream $track');
|
||||||
|
remoteStream?.addTrack(track);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
// Listening for remote session description below
|
||||||
|
// roomRef.snapshots().listen((snapshot) async {
|
||||||
|
// print('Got updated room: ${snapshot.data()}');
|
||||||
|
//
|
||||||
|
// Map<String, dynamic> data = snapshot.data() as Map<String, dynamic>;
|
||||||
|
// if (peerConnection?.getRemoteDescription() != null && data['answer'] != null) {
|
||||||
|
// var answer = RTCSessionDescription(
|
||||||
|
// data['answer']['sdp'],
|
||||||
|
// data['answer']['type'],
|
||||||
|
// );
|
||||||
|
//
|
||||||
|
// print("Someone tried to connect");
|
||||||
|
// await peerConnection?.setRemoteDescription(answer);
|
||||||
|
// }
|
||||||
|
// });
|
||||||
|
// // Listening for remote session description above
|
||||||
|
//
|
||||||
|
// // Listen for remote Ice candidates below
|
||||||
|
// roomRef.collection('calleeCandidates').snapshots().listen((snapshot) {
|
||||||
|
// snapshot.docChanges.forEach((change) {
|
||||||
|
// if (change.type == DocumentChangeType.added) {
|
||||||
|
// Map<String, dynamic> data = change.doc.data() as Map<String, dynamic>;
|
||||||
|
// print('Got new remote ICE candidate: ${jsonEncode(data)}');
|
||||||
|
// peerConnection.addCandidate(
|
||||||
|
// RTCIceCandidate(
|
||||||
|
// data['candidate'],
|
||||||
|
// data['sdpMid'],
|
||||||
|
// data['sdpMLineIndex'],
|
||||||
|
// ),
|
||||||
|
// );
|
||||||
|
// }
|
||||||
|
// });
|
||||||
|
// });
|
||||||
|
// Listen for remote ICE candidates above
|
||||||
|
|
||||||
|
return roomId;
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<void> joinRoom(String roomId, RTCVideoRenderer remoteVideo) async {
|
||||||
|
// FirebaseFirestore db = FirebaseFirestore.instance;
|
||||||
|
// DocumentReference roomRef = db.collection('rooms').doc('$roomId');
|
||||||
|
// var roomSnapshot = await roomRef.get();
|
||||||
|
// print('Got room ${roomSnapshot.exists}');
|
||||||
|
|
||||||
|
// if (roomSnapshot.exists) {
|
||||||
|
// print('Create PeerConnection with configuration: $configuration');
|
||||||
|
// peerConnection = await createPeerConnection(configuration);
|
||||||
|
//
|
||||||
|
// registerPeerConnectionListeners();
|
||||||
|
//
|
||||||
|
// localStream.getTracks().forEach((track) {
|
||||||
|
// peerConnection?.addTrack(track, localStream);
|
||||||
|
// });
|
||||||
|
//
|
||||||
|
// // Code for collecting ICE candidates below
|
||||||
|
// // var calleeCandidatesCollection = roomRef.collection('calleeCandidates');
|
||||||
|
// peerConnection.onIceCandidate = (RTCIceCandidate candidate) {
|
||||||
|
// if (candidate == null) {
|
||||||
|
// print('onIceCandidate: complete!');
|
||||||
|
// return;
|
||||||
|
// }
|
||||||
|
// print('onIceCandidate: ${candidate.toMap()}');
|
||||||
|
// // calleeCandidatesCollection.add(candidate.toMap());
|
||||||
|
// };
|
||||||
|
// // Code for collecting ICE candidate above
|
||||||
|
//
|
||||||
|
// peerConnection?.onTrack = (RTCTrackEvent event) {
|
||||||
|
// print('Got remote track: ${event.streams[0]}');
|
||||||
|
// event.streams[0].getTracks().forEach((track) {
|
||||||
|
// print('Add a track to the remoteStream: $track');
|
||||||
|
// remoteStream?.addTrack(track);
|
||||||
|
// });
|
||||||
|
// };
|
||||||
|
//
|
||||||
|
// // Code for creating SDP answer below
|
||||||
|
// var data = roomSnapshot.data() as Map<String, dynamic>;
|
||||||
|
// print('Got offer $data');
|
||||||
|
// var offer = data['offer'];
|
||||||
|
// await peerConnection?.setRemoteDescription(
|
||||||
|
// RTCSessionDescription(offer['sdp'], offer['type']),
|
||||||
|
// );
|
||||||
|
// var answer = await peerConnection.createAnswer();
|
||||||
|
// print('Created Answer $answer');
|
||||||
|
//
|
||||||
|
// await peerConnection.setLocalDescription(answer);
|
||||||
|
//
|
||||||
|
// Map<String, dynamic> roomWithAnswer = {
|
||||||
|
// 'answer': {'type': answer.type, 'sdp': answer.sdp}
|
||||||
|
// };
|
||||||
|
//
|
||||||
|
// await roomRef.update(roomWithAnswer);
|
||||||
|
// // Finished creating SDP answer
|
||||||
|
//
|
||||||
|
// // Listening for remote ICE candidates below
|
||||||
|
// // roomRef.collection('callerCandidates').snapshots().listen((snapshot) {
|
||||||
|
// // snapshot.docChanges.forEach((document) {
|
||||||
|
// // var data = document.doc.data() as Map<String, dynamic>;
|
||||||
|
// // print(data);
|
||||||
|
// // print('Got new remote ICE candidate: $data');
|
||||||
|
// // peerConnection.addCandidate(
|
||||||
|
// // RTCIceCandidate(
|
||||||
|
// // data['candidate'],
|
||||||
|
// // data['sdpMid'],
|
||||||
|
// // data['sdpMLineIndex'],
|
||||||
|
// // ),
|
||||||
|
// // );
|
||||||
|
// // });
|
||||||
|
// // });
|
||||||
|
// }
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<void> openUserMedia(
|
||||||
|
RTCVideoRenderer localVideo,
|
||||||
|
RTCVideoRenderer remoteVideo,
|
||||||
|
) async {
|
||||||
|
var stream = await navigator.mediaDevices.getUserMedia({'video': true, 'audio': false});
|
||||||
|
|
||||||
|
localVideo.srcObject = stream;
|
||||||
|
localStream = stream;
|
||||||
|
|
||||||
|
remoteVideo.srcObject = await createLocalMediaStream('key');
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<void> hangUp(RTCVideoRenderer localVideo) async {
|
||||||
|
List<MediaStreamTrack> tracks = localVideo.srcObject.getTracks();
|
||||||
|
tracks.forEach((track) {
|
||||||
|
track.stop();
|
||||||
|
});
|
||||||
|
|
||||||
|
if (remoteStream != null) {
|
||||||
|
remoteStream.getTracks().forEach((track) => track.stop());
|
||||||
|
}
|
||||||
|
if (peerConnection != null) peerConnection.close();
|
||||||
|
|
||||||
|
if (roomId != null) {
|
||||||
|
// var db = FirebaseFirestore.instance;
|
||||||
|
// var roomRef = db.collection('rooms').doc(roomId);
|
||||||
|
// var calleeCandidates = await roomRef.collection('calleeCandidates').get();
|
||||||
|
// calleeCandidates.docs.forEach((document) => document.reference.delete());
|
||||||
|
|
||||||
|
// var callerCandidates = await roomRef.collection('callerCandidates').get();
|
||||||
|
// callerCandidates.docs.forEach((document) => document.reference.delete());
|
||||||
|
|
||||||
|
// await roomRef.delete();
|
||||||
|
}
|
||||||
|
|
||||||
|
localStream.dispose();
|
||||||
|
remoteStream?.dispose();
|
||||||
|
}
|
||||||
|
|
||||||
|
void registerPeerConnectionListeners() {
|
||||||
|
peerConnection?.onIceGatheringState = (RTCIceGatheringState state) {
|
||||||
|
print('ICE gathering state changed: $state');
|
||||||
|
};
|
||||||
|
|
||||||
|
peerConnection?.onConnectionState = (RTCPeerConnectionState state) {
|
||||||
|
print('Connection state change: $state');
|
||||||
|
};
|
||||||
|
|
||||||
|
peerConnection?.onSignalingState = (RTCSignalingState state) {
|
||||||
|
print('Signaling state change: $state');
|
||||||
|
};
|
||||||
|
|
||||||
|
peerConnection?.onIceGatheringState = (RTCIceGatheringState state) {
|
||||||
|
print('ICE connection state change: $state');
|
||||||
|
};
|
||||||
|
|
||||||
|
peerConnection?.onAddStream = (MediaStream stream) {
|
||||||
|
print("Add remote stream");
|
||||||
|
onAddRemoteStream?.call(stream);
|
||||||
|
remoteStream = stream;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue