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

Flutter plugin that provides a WebView-based SDK using a native Android AAR and iOS XCFramework, with real-time message and event communication between WebView and Flutter.

example/lib/main.dart

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

import 'package:zipup_partners/zipup_sdk_flutter.dart';

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

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

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

class _MyAppState extends State<MyApp> {
  String _platformVersion = 'Unknown';
  final _zipupSdkFlutterPlugin = ZipupSdkFlutter();
  String _sdkName = 'Unknown';
  String _status = 'Ready';
  StreamSubscription<Map<String, dynamic>>? _eventSubscription;

  @override
  void initState() {
    super.initState();
    initPlatformState();
    _setupEventListener();
  }

  @override
  void dispose() {
    _eventSubscription?.cancel();
    super.dispose();
  }

  void _setupEventListener() {
    _eventSubscription = _zipupSdkFlutterPlugin.getEventStream()?.listen(
      (event) {
        final eventName = event['event'] as String?;
        final eventData = event['data'] as String?;

        print('Received event: $eventName, data: $eventData');

        if (eventName == 'close') {
          _closeSdk();
        }

        // 상태 업데이트
        if (mounted) {
          setState(() {
            _status =
                'Event: $eventName${eventData != null ? ' - $eventData' : ''}';
          });
        }
      },
      onError: (error) {
        print('Event stream error: $error');
        if (mounted) {
          setState(() {
            _status = 'Event error: $error';
          });
        }
      },
    );
  }

  Future<void> initPlatformState() async {
    String platformVersion;
    String sdkName = 'Unknown sdk name';
    platformVersion =
        await _zipupSdkFlutterPlugin.getPlatformVersion() ??
        'Unknown platform version';
    sdkName = await _zipupSdkFlutterPlugin.getSdkName() ?? 'Unknown sdk name';

    if (!mounted) return;

    setState(() {
      _platformVersion = platformVersion;
      _sdkName = sdkName;
    });
  }

  Future<void> _initSdk() async {
    try {
      setState(() {
        _status = 'Initializing SDK...';
      });

      // TODO: 실제 clientId와 clientSecret을 입력하세요
      final result = await _zipupSdkFlutterPlugin.initSdk(
        'your_client_id',
        'your_client_secret',
      );

      if (!mounted) return;

      setState(() {
        _status = result ?? 'Initialization failed';
      });
    } catch (e) {
      if (!mounted) return;
      setState(() {
        _status = 'Error: $e';
      });
    }
  }

  Future<void> _viewSdk() async {
    try {
      setState(() {
        _status = 'Opening SDK...';
      });

      final result = await _zipupSdkFlutterPlugin.viewZipupSDK();

      if (!mounted) return;

      setState(() {
        _status = result ?? 'Failed to open SDK';
      });
    } catch (e) {
      if (!mounted) return;
      setState(() {
        _status = 'Error: $e';
      });
    }
  }

  Future<void> _closeSdk() async {
    try {
      setState(() {
        _status = 'Closing SDK...';
      });

      final result = await _zipupSdkFlutterPlugin.close();

      if (!mounted) return;

      setState(() {
        _status = result ?? 'SDK closed';
      });
    } catch (e) {
      if (!mounted) return;
      setState(() {
        _status = 'Error closing SDK: $e';
      });
    }
  }

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(title: const Text('Plugin example app')),
        body: Center(
          child: Padding(
            padding: const EdgeInsets.all(16.0),
            child: Column(
              mainAxisAlignment: MainAxisAlignment.center,
              children: [
                Text(
                  'Running on: $_platformVersion',
                  style: const TextStyle(fontSize: 16),
                ),
                const SizedBox(height: 8),
                Text('SDK: $_sdkName', style: const TextStyle(fontSize: 16)),
                const SizedBox(height: 24),
                Text(
                  'Status: $_status',
                  style: const TextStyle(fontSize: 14, color: Colors.grey),
                ),
                const SizedBox(height: 32),
                ElevatedButton(
                  onPressed: _initSdk,
                  style: ElevatedButton.styleFrom(
                    padding: const EdgeInsets.symmetric(
                      horizontal: 32,
                      vertical: 16,
                    ),
                  ),
                  child: const Text('Initialize SDK'),
                ),
                const SizedBox(height: 16),
                ElevatedButton(
                  onPressed: _viewSdk,
                  style: ElevatedButton.styleFrom(
                    padding: const EdgeInsets.symmetric(
                      horizontal: 32,
                      vertical: 16,
                    ),
                  ),
                  child: const Text('View Zipup SDK'),
                ),
              ],
            ),
          ),
        ),
      ),
    );
  }
}
0
likes
150
points
51
downloads

Publisher

unverified uploader

Weekly Downloads

Flutter plugin that provides a WebView-based SDK using a native Android AAR and iOS XCFramework, with real-time message and event communication between WebView and Flutter.

Homepage

Documentation

API reference

License

MIT (license)

Dependencies

flutter, plugin_platform_interface

More

Packages that depend on zipup_partners

Packages that implement zipup_partners