when my internet is cut and reconnect, the subscription is changed and i do not get the updates how can i reconnect to the subscription or how can i close it
You could add an EventListener on window for offline to detect when you lose connection. You can then call the unsubscribe() function to close the connection.
Then you can listen for online again, and on reconnect, either reload the page, or recreate the subscribe.
I think he using flutter for this issue because base on the tagged its flutter indication
You can still adapt the procedure of @ideclon in flutter but that depends on what state management your app used. In instance, if riverpod you can actually use the AutoDisposeAsyncNotifier here. and call the ref.invalidate to refresh the provider
Whoops, sorry! Should have checked the tags!
final consultationRolesControllerProvider =
AutoDisposeAsyncNotifierProvider<ConsultationRolesController, List<Role>>(
() => throw UnimplementedError());
class ConsultationRolesController extends AutoDisposeAsyncNotifier<List<Role>> {
@override
FutureOr<List<Role>> build() async {
state = const AsyncValue.loading();
ref.onDispose(() {
_subscription?.cancel();
});
final consultId = ref.read(consultationdIdProvider);
final roles = await ref.read(consultationRepoProvider).getRoles(queries: [
Query.equal("consultationRef", consultId),
]);
roles.removeWhere((element) => element.name == "owner");
subscribe();
return roles;
}
StreamSubscription<ConsultationRealtime<ConsultationRole>>? _subscription;
void subscribe() {
_subscription = ref
.read(consultationRepoProvider)
.getConsultationRoleStream(
Realtime(AppwriteClient.instance.client),
)
.listen((roles) => _rolesListener(roles),
onError: _rolesErrorListener, cancelOnError: true);
}
void _rolesErrorListener(Object error, StackTrace stackTrace) {
state = AsyncValue.error(error, stackTrace);
}
void _rolesListener(ConsultationRealtime<ConsultationRole> roles) {
if (roles.type == ConsultationRealtimeType.create) {
final merge = [...state.value!, roles.data];
state = AsyncData(merge);
} else if (roles.type == ConsultationRealtimeType.delete) {
final merge = [...state.value!];
merge.removeWhere((element) => element.id == roles.data.id);
state = AsyncData(merge);
} else if (roles.type == ConsultationRealtimeType.update) {
final merge = [...state.value!];
final index = merge.indexWhere((element) => element.id == roles.data.id);
merge[index] = roles.data;
state = AsyncData(merge);
}
}
As you can see in build method we have
ref.onDispose(() {
_subscription?.cancel();
});
Now if you trigger this ref.invalidate(consultationRolesControllerProvider) it will refresh your provider and that ref.onDispose will also be triggered. And that Happen your provider will be refreshed
Recommended threads
- CORS error only on tables db api After u...
I've recently updated my self hosted appwrite instance to the 1.8.0 and updated my frontend with the tables db apis but strangely, even if I'm able to log in, g...
- [SOLVED] Access ExecutionStatus of a fun...
I am calling a cloud function from the newest Flutter SDK 20.2.1with the `xasync: false` flag and get the result, but the `execution.status` is not a String and...
- Appwrite isn't accepting the api from se...
Error creating user: AppwriteException: Server Error type: 'general_unknown', response: '{"message":"Server Error","code":500,"type":"general_unknown","versi...