Skip to main content

Call Log Recordings

Overview

CometChatCallLogRecordings is a Widget that shows a paginated list of all the calls between the logged-in user & another user or group. This allows the user to see all the calls with a specific user/group they have initiated/received/missed.

Image

The CometChatCallLogRecordings widget is composed of the following BaseWidgets:

WidgetsDescription
CometChatListBaseCometChatListBase is a container widget featuring a title, customizable background options, and a dedicated list widget for seamless integration within your application's interface.
CometChatListItemThis widget displays data retrieved from a CallLog object on a card, presenting a title and subtitle.

Usage

Integration

CometChatCallLogRecordings is a Widget, it can be seamlessly presented within your application. To display the details of a CallLog, you simply need to pass the corresponding CallLog object to the CometChatCallLogRecordings instance using its setCallLog property. This enables you to efficiently showcase specific call log details within your application's interface.

You can launch CometChatCallLogRecordings directly using Navigator.push, or you can define it as a widget within the build method of your State class.

1. Using Navigator to Launch CometChatCallLogRecordings
Navigator.push(context, MaterialPageRoute(builder: (context) => CometChatCallLogRecordings(callLog: callLogObject))); // CallLog object is required to launch the CometChatCallLogRecordings widget.
2. Embedding CometChatCallLogRecordings as a Widget in the build Method
import 'package:cometchat_calls_uikit/cometchat_calls_uikit.dart';
import 'package:flutter/material.dart';

class CallLogRecordingsExample extends StatefulWidget {
const CallLogRecordingsExample({super.key});


State<CallLogRecordingsExample> createState() => _CallLogRecordingsExampleState();
}

class _CallLogRecordingsExampleState extends State<CallLogRecordingsExample> {


Widget build(BuildContext context) {
return Scaffold(
body: SafeArea(
child: CometChatCallLogRecordings(
callLog: callLogObject,
) // CallLog object is required to launch the CometChatCallLogDetails widget.
),
);
}
}

Actions

Actions dictate how a widget functions. They are divided into two types: Predefined and User-defined. You can override either type, allowing you to tailor the behavior of the widget to fit your specific needs.

1. onDownloadClick

You can customize this behavior by using the provided code snippet to override the onDownloadClick and improve error handling.

CometChatCallLogRecordings(
callLog: callLogObject,
onDownloadClick: (Recordings recording) {
// TODO("Not yet implemented")
},
)

2. onBack

You can customize this behavior by using the provided code snippet to override the onBack and improve error handling.

CometChatCallLogRecordings(
callLog: callLogObject,
onBack: () {
// TODO("Not yet implemented")
},
)

3. onError

You can customize this behavior by using the provided code snippet to override the onError and improve error handling.

CometChatCallLogRecordings(
callLog: callLogObject,
onError: (e) {
// TODO("Not yet implemented")
},
)

Filters

Filters allow you to customize the data displayed in a list within a Widget. You can filter the list based on your specific criteria, allowing for a more customized. Filters can be applied using RequestBuilders of Chat SDK.

The CometChatCallLogRecordings widget does not have any exposed Filters.


Events

Events are emitted by a Widget. By using event you can extend existing functionality. Being global events, they can be applied in Multiple Locations and are capable of being Added or Removed.

The CometChatCallLogHistory widget does not have any exposed events.


Customization

To fit your app's design requirements, you can customize the appearance of the conversation widget. We provide exposed methods that allow you to modify the experience and behavior according to your specific needs.

Style

Using Style you can customize the look and feel of the widget in your app, These parameters typically control elements such as the color, size, shape, and fonts used within the widget.

1. CallLogHistory Style

You can customize the appearance of the CallLogHistoryStyle Widget by applying the CallLogHistoryStyle to it using the following code snippet.

CometChatCallLogRecordings(
callLog: callLogObject,
recordingsStyle: CallLogRecordingsStyle(
background: Color(0xFFE4EBF5),
downLoadIconTint: Colors.red,
titleStyle: const TextStyle(color: Colors.red, fontFamily: "PlaywritePL"),
recordingTitleStyle: const TextStyle(color: Colors.red, fontFamily: "PlaywritePL"),
),
)
Image

List of properties exposed by CallLogHistoryStyle

PropertyDescriptionCode
widthThe width of the call log recordings style.double? width
heightThe height of the call log recordings style.double? height
backgroundThe background color.Color? background
borderThe border of the call log recordings style.BoxBorder? border
borderRadiusThe border radius.double? borderRadius
gradientThe gradient for the background.Gradient? gradient
titleStyleThe text style for the title.TextStyle? titleStyle
dividerTintThe tint color for dividers.Color? dividerTint
emptyTextStyleThe text style for the empty state.TextStyle? emptyTextStyle
backIconTintThe tint color for the back icon.Color? backIconTint
tailTitleStyleThe text style for the tail title.TextStyle? tailTitleStyle
recordingTitleStyleThe text style for the recording title.TextStyle? recordingTitleStyle
durationTextStyleThe text style for the duration.TextStyle? durationTextStyle
downLoadIconTintThe tint color for the download icon.Color? downLoadIconTint

Functionality

These are a set of small functional customizations that allow you to fine-tune the overall experience of the widget. With these, you can change text, set custom icons, and toggle the visibility of UI elements.

CometChatCallLogRecordings(
callLog: callLogObject,
title: "Your Title",
backButton: Image.asset(
"assets/img/back.png",
width: 30,
height: 30,
),
)
Image

List of methods exposed by CometChatCallLogHistory

PropertyDescriptionCode
titleThe title of the call log recordings.String? title
backButtonThe back button widget.Widget? backButton
showBackButtonIndicates whether to show the back button.bool? showBackButton
emptyStateTextThe text to display when there are no recordings.String? emptyStateText
themeThe theme for the widget.CometChatTheme? theme
datePatternThe pattern for displaying dates.String? datePattern
hideSeparatorIndicates whether to hide separators.bool hideSeparator
downloadIconUrlThe URL for the download icon.String? downloadIconUrl

Advanced

For advanced-level customization, you can set custom widgets to the widget. This lets you tailor each aspect of the widget to fit your exact needs and application aesthetics. You can create and define your widgets, layouts, and UI elements and then incorporate those into the widget.

ListItemView

With this function, you can assign a custom ListItem widget to the CometChatCallLogRecordings Widget.

CometChatCallLogRecordings(
callLog: callLogObject,
listItemView: (Recordings recording, BuildContext context) {
return ListTile(
title: Text(recording.rid ?? ""),
subtitle: Text(recording.duration != null ? "${recording.duration}" : "00:00"),
trailing: SizedBox(
width: 30,
child: InkWell(
onTap: () {
// TODO("Not yet implemented")
},
child: Image.asset("assets/img/downloading.png", width: 30, height: 30),
),
)
);
},
)
Image

SubtitleView

You can customize the subtitle widget for each conversation item to meet your requirements

CometChatCallLogRecordings(
callLog: callLogObject,
subTitleView: (Recordings recording, BuildContext context) {
return Row(
children: [
InkWell(
onTap: () {
// TODO("Not yet implemented")
},
child: const Icon(Icons.call, color: Color(0xFF6851D6), size: 25)
),
const SizedBox(width: 10),
InkWell(
onTap: () {
// TODO("Not yet implemented")
},
child: const Icon(Icons.video_call, color: Color(0xFF6851D6), size: 25)
),
],
);
},
)
Image

TailView

Used to generate a custom trailing widget for the CometChatCallLogRecordings widget. You can add a Tail widget using the following method.

CometChatCallLogRecordings(
callLog: callLogObject,
tailView: (BuildContext context, Recordings recordings) {
return SizedBox(
width: 100,
child: Row(
children: [
InkWell(
onTap: () {
// TODO("Not yet implemented")
},
child: const Icon(Icons.call, color: Color(0xFF6851D6), size: 25)
),
const SizedBox(width: 10),
InkWell(
onTap: () {
// TODO("Not yet implemented")
},
child: const Icon(Icons.video_call, color: Color(0xFF6851D6), size: 25)
),
],
),
);
},
)
Image

EmptyStateView

You can set a custom EmptyStateView using emptyStateView to match the empty UI of your app.

CometChatCallLogRecordings(
callLog: callLogObject,
emptyStateView: (context) {
return SizedBox(
width: MediaQuery.of(context).size.width,
child: const Center(
child: Column(
crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.center,
children: [
Spacer(),
Icon(Icons.sms_failed_outlined, color: Colors.red, size: 100,),
SizedBox(height: 20,),
Text("Your Custom Message"),
Spacer(),
],
)
),
);
},
)
Image