Skip to main content

Call Log History

Overview

CometChatCallLogHistory 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 CometChatCallLogHistory 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

CometChatCallLogHistory 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 CometChatCallLogHistory instance using its setCallLog property. This enables you to efficiently showcase specific call log details within your application's interface.

You can launch CometChatCallLogHistory 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 CometChatCallLogHistory
Navigator.push(context, MaterialPageRoute(builder: (context) => CometChatCallLogHistory(callUser: callUser))); // CallUser object is required to launch the CometChatCallLogHistory widget.
2. Embedding CometChatCallLogHistory as a Widget in the build Method
import 'package:cometchat_calls_uikit/cometchat_calls_uikit.dart';
import 'package:flutter/material.dart';

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


State<CallLogHistoryExample> createState() => _CallLogHistoryExampleState();
}

class _CallLogHistoryExampleState extends State<CallLogHistoryExample> {


Widget build(BuildContext context) {
return Scaffold(
body: SafeArea(
child: Center(
child: CometChatCallLogHistory(
callUser: callUser
) // CallUser object is required to launch the CometChatCallLogHistory 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. onItemClick

This method proves valuable when users seek to override the onItemClick functionality within CometChatCallLogHistory, empowering them with greater control and customization options.

The onItemClick action doesn't have a predefined behavior. You can override this action using the following code snippet.

CometChatCallLogHistory(
callUser: callUser,
onItemClick: (CallLog callLog) {
// TODO("Not yet implemented")
},
)

2. OnError

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

CometChatCallLogHistory(
callUser: callUser,
onError: (e) {
// TODO("Not yet implemented")
},
)

3. onBack

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

CometChatCallLogHistory(
callUser: callUser,
onBack: () {
// 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 ChatSDK.

1. CallLogRequestBuilder

The CallLogRequestBuilder enables you to filter and customize the call list based on available parameters in CallLogRequestBuilder. This feature allows you to create more specific and targeted queries during the call. The following are the parameters available in CallLogRequestBuilder

CometChatCallLogHistory(
callUser: callUser,
callLogsRequestBuilder: CallLogRequestBuilder()
..limit = 10
..hasRecording = true,
)

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.

CometChatCallLogHistory(
callUser: callUser,
callLogHistoryStyle: CallLogHistoryStyle(
background: Color(0xFFE4EBF5),
titleStyle: const TextStyle(color: Colors.red),
borderRadius: 10,
border: Border.all(color: Colors.black),
),
)
Image

List of properties exposed by CallLogHistoryStyle

PropertyDescriptionCode
widthThe width of the call log history style.double? width
heightThe height of the call log history style.double? height
backgroundThe background color.Color? background
borderThe border of the call log history style.BoxBorder? border
borderRadiusThe border radius.double? borderRadius
gradientThe gradient background.Gradient? gradient
titleStyleThe style for the title text.TextStyle? titleStyle
dividerTintThe tint color for the divider.Color? dividerTint
emptyTextStyleThe style for the empty text.TextStyle? emptyTextStyle
errorTextStyleThe style for the error text.TextStyle? errorTextStyle
loadingIconTintThe tint color for the loading icon.Color? loadingIconTint
backIconTintThe tint color for the back icon.Color? backIconTint
durationTextStyleThe style for the duration text.TextStyle? durationTextStyle
statusTextStyleThe style for the status text.TextStyle? statusTextStyle
dateTextStyleThe style for the date text.TextStyle? dateTextStyle

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.

Example

Here is the example for reference:

CometChatCallLogHistory(
callUser: callUser,
title: "Your Title",
backButton: InkWell(
onTap: () {
// TODO("Not yet implemented")
},
child: const Icon(Icons.backspace_outlined, color: Color(0xFF6851D6))
),
hideSeparator: false
)
Image

List of methods exposed by CometChatCallLogHistory

PropertyDescriptionCode
callUserThe user associated with the call logs.dynamic callUser
callGroupThe group associated with the call logs.dynamic callGroup
titleThe title of the call log history.String? title
backButtonThe custom back button widget.Widget? backButton
showBackButtonFlag to show or hide the back button.bool? showBackButton
emptyStateTextThe text to display when the list is empty.String? emptyStateText
errorStateTextThe text to display when there is an error.String? errorStateText
loadingIconUrlThe URL for the loading icon.String? loadingIconUrl
themeThe theme of the call log history.ThemeData? theme
timePatternThe pattern for displaying time.String? timePattern
dateSeparatorPatternThe pattern for displaying date separators.String? dateSeparatorPattern
hideSeparatorFlag to show or hide the separator.bool hideSeparator = true

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 CometChatCallLogHistory Widget.

CometChatCallLogHistory(
callUser: callUser,
listItemView: (callLog, context) {
return ListTile(
title: Text(DateFormat('mm:hh yyyy/MM/dd').format(DateTime.fromMillisecondsSinceEpoch(callLog.startedAt! * 1000))),
subtitle: Text("${callLog.type!} call"),
trailing: Text(callLog.status!),
);
},
)
Image

TailView

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

CometChatCallLogHistory(
callUser: callUser,
tailView: (CallLog callLog, BuildContext context) {
return const Row(
children: [
Icon(Icons.call, color: Color(0xFF6851D6), size: 25,),
SizedBox(width: 10),
Icon(Icons.video_call, color: Color(0xFF6851D6), size: 25,),
],
); // Replaced the placeholder with a custom widget.
},
)
Image

LoadingStateView

You can set a custom loader widget using loadingStateView to match the loading UI of your app.

CometChatCallLogHistory(
callUser: callUser,
loadingStateView: (context) {
return SizedBox(
width: MediaQuery.of(context).size.width,
child: const Center(
child: CircularProgressIndicator()
),
); // Replaced the placeholder with a custom widget.
},
)
Image

EmptyStateView report

You can set a custom EmptyView using emptyStateView to match the empty widget of your app.

CometChatCallLogHistory(
callUser: callUser,
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

ErrorStateView report

You can set a custom ErrorView using errorStateView to match the error widget of your app.

CometChatCallLogHistory(
callUser: callUser,
errorStateView: (context) {
return SizedBox(
width: MediaQuery.of(context).size.width,
child: const Center(
child: Column(
crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.center,
children: [
Spacer(),
Icon(Icons.error_outline, color: Colors.red, size: 100,),
SizedBox(height: 20,),
Text("Your Custom Error Message"),
Spacer(),
],
),
),
);
},
)

Configurations

Configurations offer the ability to customize the properties of each widget within a Composite Widget.

  • Configurations expose properties that are available in its individual widgets.

Call Log Details

You can customize the properties of the Call Log Details widget by making use of the CallLogDetailsConfiguration. You can accomplish this by employing the callLogDetailConfiguration method as demonstrated below:

CometChatCallLogHistory(
callUser: callUser,
callLogDetailConfiguration: CallLogDetailsConfiguration(
detailStyle: const CallLogDetailsStyle(
background: Color(0xFFE4EBF5),
titleStyle: TextStyle(
color: Colors.red,
fontSize: 20,
fontWeight: FontWeight.bold,
),
separatorDateStyle: TextStyle(
color: Colors.blue,
fontSize: 14,
fontWeight: FontWeight.bold,
),
timeStyle: TextStyle(
color: Colors.orange,
fontSize: 12,
fontWeight: FontWeight.bold,
),
durationStyle: TextStyle(
color: Colors.purple,
fontSize: 10,
fontWeight: FontWeight.bold,
),
countStyle: TextStyle(
color: Colors.yellow,
fontSize: 8,
fontWeight: FontWeight.bold,
),
callStatusStyle: TextStyle(
color: Colors.pink,
fontSize: 10,
fontWeight: FontWeight.bold,
),
arrowIconTint: Colors.green,
)
)
)
Image