safe_area_insets 0.1.3 copy "safe_area_insets: ^0.1.3" to clipboard
safe_area_insets: ^0.1.3 copied to clipboard

Use Dart to get the `safe-area-insets` on Web platform.

example/lib/main.dart

import 'package:flutter/foundation.dart';
import 'package:flutter/material.dart';
import 'package:safe_area_insets/safe_area_insets.dart';

import 'js_ext_stub.dart'
    if (dart.library.html) 'package:safe_area_insets/src/js_ext.dart';

void main() {
  testJsExt();
  if (kIsWeb) setupViewportFit();

  runApp(const MyApp());
}

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

  @override
  State<MyApp> createState() => _MyAppState();
}

class _MyAppState extends State<MyApp> {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(
          title: const Text('Plugin example app'),
        ),
        body: SafeArea(
          left: false,
          right: false,
          child: Container(
            alignment: Alignment.center,
            color: Colors.green,
            child: Material(
              child: kIsWeb
                  ? StreamBuilder<EdgeInsets>(
                      stream: safeAreaInsetsStream,
                      builder: (context, snapshot) => Text(
                        'SafeAreaInsets: ${snapshot.data ?? safeAreaInsets}',
                        textAlign: TextAlign.center,
                      ),
                    )
                  : const Text('unsupported'),
            ),
          ),
        ),
      ),
      builder: (context, child) {
        child ??= const SizedBox();
        return kIsWeb ? WebSafeAreaInsets(child: child) : child;
      },
    );
  }
}
10
likes
120
points
1.23k
downloads

Publisher

unverified uploader

Weekly Downloads

Use Dart to get the `safe-area-insets` on Web platform.

Homepage
Repository (GitHub)

Documentation

API reference

License

BSD-3-Clause (license)

Dependencies

flutter, js

More

Packages that depend on safe_area_insets