alive 0.0.1+2 copy "alive: ^0.0.1+2" to clipboard
alive: ^0.0.1+2 copied to clipboard

Alive client for flutter. "Real"time communication for apps. You can use it for chats or realtime events

example/lib/main.dart

import 'package:alive/alive.dart';
import 'package:flutter/material.dart';

late Client client;

void main() async {
  client = Client(url: 'ws://localhost:4000/');
  client.connect(closeOnError: false);
  runApp(const MyApp());
}

class MyApp extends StatelessWidget {
  const MyApp({Key? key}) : super(key: key);
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: const MyHomePage(title: 'Alive example app'),
    );
  }
}

class MyHomePage extends StatefulWidget {
  const MyHomePage({Key? key, required this.title}) : super(key: key);
  final String title;
  @override
  State<MyHomePage> createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  bool _subscribed = false;

  @override
  void dispose() {
    client.disconnect();
    super.dispose();
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text(widget.title),
      ),
      floatingActionButton: FloatingActionButton(
        onPressed: () {
          if (!_subscribed) {
            client.subscribe('test');
          } else {
            client.unsubscribe('test');
          }
          setState(() {
            _subscribed = !_subscribed;
          });
        },
        child: Icon(
          _subscribed ? Icons.pause : Icons.play_arrow,
        ),
      ),
      body: Center(
        child: StreamBuilder(
            stream: client.on(channel: 'test'),
            builder: (BuildContext context, AsyncSnapshot<Message> snapshot) {
              if (snapshot.hasData) {
                return Column(
                  mainAxisAlignment: MainAxisAlignment.center,
                  children: <Widget>[
                    Text(
                      'Channel: ${snapshot.data!.channel ?? 'Broadcast message (null)'}',
                    ),
                    Text(
                      'Message: ${snapshot.data!.message!.toString()}',
                      style: Theme.of(context).textTheme.headline4,
                    ),
                  ],
                );
              } else {
                return const CircularProgressIndicator();
              }
            }),
      ),
    );
  }
}
2
likes
130
points
0
downloads

Publisher

verified publisherlivingadventures.com.co

Weekly Downloads

Alive client for flutter. "Real"time communication for apps. You can use it for chats or realtime events

Repository (GitHub)
View/report issues

Documentation

API reference

License

BSD-3-Clause (license)

Dependencies

flutter, logging, web_socket_channel

More

Packages that depend on alive