upper_snackbar 0.0.1 copy "upper_snackbar: ^0.0.1" to clipboard
upper_snackbar: ^0.0.1 copied to clipboard

A beautiful, customizable, and animated snackbar package for Flutter that displays notifications at the top of the screen with smooth animations and extensive customization options.

example/lib/main.dart

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

void main() {
  runApp(const MyApp());
}

class MyApp extends StatelessWidget {
  const MyApp({super.key});

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Upper Snackbar Demo',
      debugShowCheckedModeBanner: false,
      theme: ThemeData(
        colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple),
        useMaterial3: true,
      ),
      home: const UpperSnackbarDemo(),
    );
  }
}

class UpperSnackbarDemo extends StatelessWidget {
  const UpperSnackbarDemo({super.key});

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: const Text('Upper Snackbar Demo'),
        backgroundColor: Theme.of(context).colorScheme.inversePrimary,
        centerTitle: true,
      ),
      body: SingleChildScrollView(
        padding: const EdgeInsets.all(16.0),
        child: Column(
          crossAxisAlignment: CrossAxisAlignment.stretch,
          children: [
            const Text(
              'Basic Snackbars',
              style: TextStyle(fontSize: 20, fontWeight: FontWeight.bold),
            ),
            const SizedBox(height: 12),
            _buildButton(
              context,
              'Show Success',
              Colors.green,
              () {
                UpperSnackbar().showSuccess(
                  context,
                  message: 'Operation completed successfully!',
                );
              },
            ),
            const SizedBox(height: 8),
            _buildButton(
              context,
              'Show Error',
              Colors.red,
              () {
                UpperSnackbar().showError(
                  context,
                  message: 'Something went wrong! Please try again.',
                );
              },
            ),
            const SizedBox(height: 8),
            _buildButton(
              context,
              'Show Warning',
              Colors.orange,
              () {
                UpperSnackbar().showWarning(
                  context,
                  message: 'This action cannot be undone!',
                );
              },
            ),
            const SizedBox(height: 8),
            _buildButton(
              context,
              'Show Info',
              Colors.blue,
              () {
                UpperSnackbar().showInfo(
                  context,
                  message: 'Did you know? You can customize everything!',
                );
              },
            ),
            const SizedBox(height: 24),
            const Text(
              'With Action Button',
              style: TextStyle(fontSize: 20, fontWeight: FontWeight.bold),
            ),
            const SizedBox(height: 12),
            _buildButton(
              context,
              'Snackbar with Action',
              Colors.purple,
              () {
                UpperSnackbar().showSuccess(
                  context,
                  message: 'File deleted successfully',
                  actionLabel: 'UNDO',
                  onActionPressed: () {
                    ScaffoldMessenger.of(context).showSnackBar(
                      const SnackBar(content: Text('Undo pressed!')),
                    );
                  },
                );
              },
            ),
            const SizedBox(height: 24),
            const Text(
              'Different Positions',
              style: TextStyle(fontSize: 20, fontWeight: FontWeight.bold),
            ),
            const SizedBox(height: 12),
            _buildButton(
              context,
              'Top Center (Default)',
              Colors.indigo,
              () {
                UpperSnackbar().showInfo(
                  context,
                  message: 'This is centered at the top',
                  position: SnackbarPosition.top,
                );
              },
            ),
            const SizedBox(height: 8),
            _buildButton(
              context,
              'Top Left',
              Colors.teal,
              () {
                UpperSnackbar().showInfo(
                  context,
                  message: 'Top left position',
                  position: SnackbarPosition.topLeft,
                );
              },
            ),
            const SizedBox(height: 8),
            _buildButton(
              context,
              'Top Right',
              Colors.cyan,
              () {
                UpperSnackbar().showInfo(
                  context,
                  message: 'Top right position',
                  position: SnackbarPosition.topRight,
                );
              },
            ),
            const SizedBox(height: 24),
            const Text(
              'Custom Styles',
              style: TextStyle(fontSize: 20, fontWeight: FontWeight.bold),
            ),
            const SizedBox(height: 12),
            _buildButton(
              context,
              'Custom Colors',
              Colors.pink,
              () {
                UpperSnackbar().show(
                  context,
                  message: 'Custom pink snackbar',
                  type: SnackbarType.custom,
                  style: const SnackbarStyle(
                    backgroundColor: Colors.pink,
                    textColor: Colors.white,
                    iconColor: Colors.white,
                    icon: Icons.favorite,
                  ),
                );
              },
            ),
            const SizedBox(height: 8),
            _buildButton(
              context,
              'With Border',
              Colors.deepOrange,
              () {
                UpperSnackbar().show(
                  context,
                  message: 'Snackbar with custom border',
                  type: SnackbarType.custom,
                  style: SnackbarStyle(
                    backgroundColor: Colors.white,
                    textColor: Colors.deepOrange,
                    iconColor: Colors.deepOrange,
                    icon: Icons.notifications_active,
                    border: Border.all(color: Colors.deepOrange, width: 2),
                  ),
                );
              },
            ),
            const SizedBox(height: 8),
            _buildButton(
              context,
              'Gradient Background',
              Colors.purple,
              () {
                UpperSnackbar().show(
                  context,
                  message: 'Beautiful gradient background!',
                  type: SnackbarType.custom,
                  style: const SnackbarStyle(
                    gradient: LinearGradient(
                      colors: [Colors.purple, Colors.deepPurple, Colors.indigo],
                    ),
                    textColor: Colors.white,
                    iconColor: Colors.white,
                    icon: Icons.auto_awesome,
                  ),
                );
              },
            ),
            const SizedBox(height: 8),
            _buildButton(
              context,
              'Rounded Corners',
              Colors.amber,
              () {
                UpperSnackbar().show(
                  context,
                  message: 'Extra rounded corners',
                  type: SnackbarType.warning,
                  style: const SnackbarStyle(
                    borderRadius: 30.0,
                  ),
                );
              },
            ),
            const SizedBox(height: 8),
            _buildButton(
              context,
              'Without Close Icon',
              Colors.brown,
              () {
                UpperSnackbar().showInfo(
                  context,
                  message: 'This one has no close icon',
                  showCloseIcon: false,
                );
              },
            ),
            const SizedBox(height: 24),
            const Text(
              'Duration & Animation',
              style: TextStyle(fontSize: 20, fontWeight: FontWeight.bold),
            ),
            const SizedBox(height: 12),
            _buildButton(
              context,
              'Long Duration (5s)',
              Colors.green,
              () {
                UpperSnackbar().showSuccess(
                  context,
                  message: 'This will stay for 5 seconds',
                  duration: 5,
                );
              },
            ),
            const SizedBox(height: 8),
            _buildButton(
              context,
              'Short Duration (1s)',
              Colors.red,
              () {
                UpperSnackbar().showError(
                  context,
                  message: 'Quick message!',
                  duration: 1,
                );
              },
            ),
            const SizedBox(height: 8),
            _buildButton(
              context,
              'Slow Animation',
              Colors.blue,
              () {
                UpperSnackbar().show(
                  context,
                  message: 'Slow and smooth animation',
                  type: SnackbarType.info,
                  animationDuration: 800,
                );
              },
            ),
            const SizedBox(height: 24),
            const Text(
              'Advanced Features',
              style: TextStyle(fontSize: 20, fontWeight: FontWeight.bold),
            ),
            const SizedBox(height: 12),
            _buildButton(
              context,
              'Non-dismissible',
              Colors.red.shade900,
              () {
                UpperSnackbar().show(
                  context,
                  message: 'Tap me won\'t dismiss (wait for timer)',
                  type: SnackbarType.error,
                  dismissible: false,
                  duration: 3,
                );
              },
            ),
            const SizedBox(height: 8),
            _buildButton(
              context,
              'With Tap Callback',
              Colors.deepPurple,
              () {
                UpperSnackbar().showInfo(
                  context,
                  message: 'Tap me to see a message!',
                  onTap: () {
                    ScaffoldMessenger.of(context).showSnackBar(
                      const SnackBar(content: Text('Snackbar was tapped!')),
                    );
                  },
                );
              },
            ),
            const SizedBox(height: 8),
            _buildButton(
              context,
              'Long Text Example',
              Colors.blueGrey,
              () {
                UpperSnackbar().showWarning(
                  context,
                  message:
                      'This is a very long message that demonstrates how the snackbar handles multi-line text content gracefully.',
                  duration: 5,
                );
              },
            ),
            const SizedBox(height: 24),
          ],
        ),
      ),
    );
  }

  Widget _buildButton(
    BuildContext context,
    String text,
    Color color,
    VoidCallback onPressed,
  ) {
    return ElevatedButton(
      onPressed: onPressed,
      style: ElevatedButton.styleFrom(
        backgroundColor: color,
        foregroundColor: Colors.white,
        padding: const EdgeInsets.symmetric(vertical: 16.0),
        shape: RoundedRectangleBorder(
          borderRadius: BorderRadius.circular(8.0),
        ),
      ),
      child: Text(
        text,
        style: const TextStyle(fontSize: 16, fontWeight: FontWeight.w600),
      ),
    );
  }
}
2
likes
150
points
18
downloads
screenshot

Publisher

verified publishercetinmustafa.com

Weekly Downloads

A beautiful, customizable, and animated snackbar package for Flutter that displays notifications at the top of the screen with smooth animations and extensive customization options.

Repository (GitHub)
View/report issues
Contributing

Topics

#snackbar #notification #toast #alert

Documentation

Documentation
API reference

License

MIT (license)

Dependencies

flutter

More

Packages that depend on upper_snackbar