npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@zaininijar/react-native-floating-bubble

v1.0.4

Published

React Native library for creating floating bubbles that can run over other applications

Readme

@zaininijar/react-native-floating-bubble

npm version License: MIT Platform

Library React Native untuk membuat floating bubbles yang dapat berjalan di atas aplikasi lain pada Android dan iOS.

✨ Features

  • 🎈 Floating bubbles yang dapat muncul di atas aplikasi lain (Android)
  • 🎯 Draggable interface dengan position tracking real-time
  • 🎨 Customizable appearance (ukuran, warna, teks, border, icon)
  • 🔐 Permission handling otomatis untuk Android overlay
  • 📱 Cross-platform support (Android & iOS)
  • 💪 TypeScript support penuh dengan type definitions
  • Node.js 18+ compatibility
  • 🔄 Event handling untuk perubahan posisi
  • 📦 Auto-linking support untuk React Native 0.60+

📦 Installation

npm install @zaininijar/react-native-floating-bubble

Setup untuk iOS

cd ios && pod install

Setup untuk Android

Tidak perlu setup tambahan untuk Android. Library menggunakan auto-linking dan menangani permissions secara otomatis.

🚀 Quick Start

import React from 'react';
import { View, Button, Alert } from 'react-native';
import ReactNativeFloatingBubble, {
  FloatingBubbleConfig,
} from '@zaininijar/react-native-floating-bubble';

const App = () => {
  const showBubble = async () => {
    try {
      // Konfigurasi bubble
      const config: FloatingBubbleConfig = {
        size: 100,
        backgroundColor: '#007AFF',
        text: '🎈',
        x: 50,
        y: 200,
        draggable: true,
      };
      
      // Request permission untuk Android
      const hasPermission = await ReactNativeFloatingBubble.hasOverlayPermission();
      if (!hasPermission) {
        const granted = await ReactNativeFloatingBubble.requestOverlayPermission();
        if (!granted) {
          Alert.alert('Error', 'Overlay permission diperlukan');
          return;
        }
      }
      
      // Tampilkan bubble
      const success = await ReactNativeFloatingBubble.show(config);
      if (success) {
        Alert.alert('Success', 'Floating bubble ditampilkan!');
      }
    } catch (error) {
      Alert.alert('Error', `Gagal menampilkan bubble: ${error}`);
    }
  };

  const hideBubble = async () => {
    await ReactNativeFloatingBubble.hide();
  };

  return (
    <View style={{ flex: 1, justifyContent: 'center', padding: 20 }}>
      <Button title="Show Floating Bubble" onPress={showBubble} />
      <Button title="Hide Floating Bubble" onPress={hideBubble} />
    </View>
  );
};

export default App;

📚 API Reference

Methods

show(config: FloatingBubbleConfig): Promise<boolean>

Menampilkan floating bubble dengan konfigurasi yang ditentukan.

Parameters:

Returns: Promise<boolean> - Status keberhasilan

hide(): Promise<boolean>

Menyembunyikan floating bubble yang sedang ditampilkan.

Returns: Promise<boolean> - Status keberhasilan

isVisible(): Promise<boolean>

Memeriksa apakah floating bubble sedang ditampilkan.

Returns: Promise<boolean> - Status visibility

updatePosition(position: FloatingBubblePosition): Promise<boolean>

Mengupdate posisi floating bubble.

Parameters:

  • position: Objek posisi baru {x: number, y: number}

Returns: Promise<boolean> - Status keberhasilan

getPosition(): Promise<FloatingBubblePosition | null>

Mendapatkan posisi saat ini dari floating bubble.

Returns: Promise<FloatingBubblePosition | null> - Posisi saat ini atau null jika tidak visible

updateConfig(config: FloatingBubbleConfig): Promise<boolean>

Mengupdate konfigurasi floating bubble.

Parameters:

  • config: Konfigurasi baru untuk bubble

Returns: Promise<boolean> - Status keberhasilan

requestOverlayPermission(): Promise<boolean> (Android only)

Meminta permission overlay dari user.

Returns: Promise<boolean> - Status permission yang diberikan

hasOverlayPermission(): Promise<boolean> (Android only)

Memeriksa apakah overlay permission sudah diberikan.

Returns: Promise<boolean> - Status permission

Types

FloatingBubbleConfig

interface FloatingBubbleConfig {
  size?: number;              // Ukuran bubble dalam pixels (default: 100)
  backgroundColor?: string;   // Warna background (default: system blue)
  borderColor?: string;       // Warna border
  borderWidth?: number;       // Lebar border
  x?: number;                // Posisi X awal (default: 0)
  y?: number;                // Posisi Y awal (default: 100)
  draggable?: boolean;       // Apakah bubble bisa di-drag (default: true)
  icon?: string;             // Icon bubble (base64 atau nama gambar lokal)
  text?: string;             // Konten teks
  textColor?: string;        // Warna teks (default: white)
  textSize?: number;         // Ukuran teks (default: 16)
}

FloatingBubblePosition

interface FloatingBubblePosition {
  x: number;  // Koordinat X
  y: number;  // Koordinat Y
}

🎨 Customization Examples

Bubble dengan Custom Style

const customBubble = {
  size: 120,
  backgroundColor: '#FF6B6B',
  borderColor: '#FFFFFF',
  borderWidth: 3,
  text: '💬',
  textColor: '#FFFFFF',
  textSize: 24,
  x: 100,
  y: 300,
  draggable: true,
};

await ReactNativeFloatingBubble.show(customBubble);

Bubble dengan Icon

const iconBubble = {
  size: 80,
  backgroundColor: '#4ECDC4',
  icon: '',
  draggable: false,
};

await ReactNativeFloatingBubble.show(iconBubble);

Position Tracking

// Mendapatkan posisi saat ini
const position = await ReactNativeFloatingBubble.getPosition();
if (position) {
  console.log(`Bubble position: X=${position.x}, Y=${position.y}`);
}

// Mengupdate posisi
const newPosition = { x: 200, y: 400 };
await ReactNativeFloatingBubble.updatePosition(newPosition);

📱 Platform Differences

Android

  • ✅ Memerlukan SYSTEM_ALERT_WINDOW permission
  • ✅ Otomatis request overlay permission saat diperlukan
  • ✅ Support floating di atas aplikasi lain
  • ✅ Menggunakan WindowManager untuk overlay functionality
  • ✅ Gesture detection untuk drag & drop

iOS

  • ✅ Tidak memerlukan permission khusus
  • ✅ Menggunakan UIWindow dengan high window level
  • ⚠️ Terbatas pada floating dalam konteks aplikasi (iOS restrictions)
  • ✅ Smooth drag interaction dengan pan gesture
  • ⚠️ Tidak dapat float di atas aplikasi lain karena pembatasan iOS

🔧 Troubleshooting

Android Issues

Permission Denied

// Pastikan untuk request permission terlebih dahulu
const hasPermission = await ReactNativeFloatingBubble.hasOverlayPermission();
if (!hasPermission) {
  await ReactNativeFloatingBubble.requestOverlayPermission();
}

Bubble Tidak Muncul

  • Pastikan overlay permission sudah diberikan
  • Cek apakah ada aplikasi lain yang menggunakan overlay
  • Restart aplikasi setelah memberikan permission

iOS Issues

Bubble Tidak Terlihat

  • Pastikan posisi bubble berada dalam bounds layar
  • Cek apakah ada view lain yang menutupi bubble
  • Pastikan windowLevel tidak konflik dengan UI lain

General Issues

TypeScript Errors

# Install type definitions jika diperlukan
npm install --save-dev @types/react-native

Build Errors

# Clean dan rebuild project
cd android && ./gradlew clean && cd ..
cd ios && rm -rf build && cd ..
npx react-native run-android
# atau
npx react-native run-ios

📋 Requirements

  • React Native >= 0.60
  • Node.js >= 18
  • iOS >= 11.0
  • Android API >= 21
  • TypeScript >= 4.5 (opsional)

🎯 Example App

Library ini dilengkapi dengan example app yang mendemonstrasikan semua fitur:

# Clone repository
git clone https://github.com/zaininijar/react-native-floating-bubble.git
cd react-native-floating-bubble/example

# Install dependencies
npm install

# Run example
npm run android  # atau npm run ios

🤝 Contributing

Kontribusi sangat diterima! Silakan buat Pull Request atau buka Issue untuk bug reports dan feature requests.

Development Setup

# Clone repository
git clone https://github.com/zaininijar/react-native-floating-bubble.git
cd react-native-floating-bubble

# Install dependencies
npm install

# Build library
npm run prepack

# Run example app
cd example
npm install
npm run android

📄 License

MIT License - lihat file LICENSE untuk detail.

🙏 Acknowledgments

  • Terinspirasi oleh kebutuhan floating UI elements di mobile apps
  • Menggunakan React Native's native module architecture
  • Built dengan TypeScript untuk better developer experience

📞 Support

Jika Anda menemukan library ini berguna, silakan berikan ⭐ di GitHub!

Untuk pertanyaan atau dukungan:


Made with ❤️ for React Native Community