superchat 0.0.3 superchat: ^0.0.3 copied to clipboard
Complete, customizable, and highly scalable chat package
Super Chat #
- A highly scalable and complete chat application based on Realtime Database.
- This is designed especially for FlutterFlow developers.
- If you are looking for a package for Flutter, look for
easychat
package.
- If you are looking for a package for Flutter, look for
Features #
Initialize #
- Call
ChatService.init()
in themain.dart
custom code in your FlutterFlow project.databaseURL
must be set to user the realtime database in the web platform.
/// Initialize super chat service
ChatService.instance.init(
/// Provide databaseURL for web
databaseURL: DefaultFirebaseOptions.currentPlatform.databaseURL!,
);
Overview #
- This package users the realtime database.
- It is very
- cheap
- simple
- fast
- It is very
How to #
Chat room list custom design #
Widgets #
ValueListView #
-
Use this widget to list the values of a node in Realtime database. This can handle most of the cases of listing the values of a node in Realtime database.
-
If you don't call
fetchMore(index)
, it will only fetch the first page of data. -
If you want to get only the first page of list to show the latest or the oldest, you don't have to call
fetchMore
. -
In this example, it is using
PageView
to list the data. You can useListView
,GridView
,CarouselView
, or evenColumn
,Row
, or whatever. -
Use
reverseQuery
to show the oldest data first.
Example:
ValueListView(
query: FirebaseDatabase.instance.ref('/tmp'),
pageSize: 3,
builder: (snapshot, fetchMore) {
return PageView.builder(
itemCount: snapshot.docs.length,
itemBuilder: (context, index) {
print('index: $index');
fetchMore(index);
return ListTile(
contentPadding: const EdgeInsets.all(64),
title: Text(snapshot.docs[index].key!),
);
},
);
},
errorBuilder: (s) => Text('Error: $s'),
loadingBuilder: () => const CircularProgressIndicator(),
emptyBuilder: () => const Text('Empty'),
),
- The example below is using
reverseQuery
to show the oldest data first.
ValueListView(
query: FirebaseDatabase.instance.ref('/tmp'),
pageSize: 3,
reverseQuery: true,
builder: (snapshot, fetchMore) {
return ListView.builder(
itemCount: snapshot.docs.length,
itemBuilder: (context, index) {
print('index: $index');
fetchMore(index);
return ListTile(
contentPadding: const EdgeInsets.all(64),
title: Text(snapshot.docs[index].key!),
);
},
);
},
errorBuilder: (s) => Text('Error: $s'),
loadingBuilder: () => const CircularProgressIndicator(),
emptyBuilder: () => const Text('Empty'),
),