Skip to content

Lilytreasure/MultiplatformWebview

Repository files navigation

Profile


👻 Multiplatform WebView is a straight forward library used to implement native WebView in Android and iOS.


On Android

Add the following on your Manifest file:

   <uses-permission android:name="android.permission.INTERNET" />

Gradle

You can add a dependency inside the androidMain or commonMain source set:

commonMain.dependencies {
    implementation("io.github.lilytreasure:multiplatformWebView:1.0.1")
}

Usage

 var isLoadingDescription by remember { mutableStateOf(false) }
var offsetX by remember { mutableStateOf(0f) }
var offsetY by remember { mutableStateOf(0f) }
Scaffold(modifier = Modifier.fillMaxSize()) {
    Column(
        modifier = Modifier
            .padding(it)
            .fillMaxSize()
    ) {
        Box(
            Modifier
                .fillMaxSize()
                .background(MaterialTheme.colorScheme.background)
                .windowInsetsPadding(WindowInsets.systemBars)
                .windowInsetsPadding(WindowInsets.ime)
        ) {
            WebViewEngine(
                url = "https://github.com/Lilytreasure",
                isLoading = { loadDelegate ->
                    isLoadingDescription = loadDelegate
                },
                onUrlClicked = { url -> },
                onCreated = {},
                onDispose = {}
            )
            if (isLoadingDescription) {
                LinearProgressIndicator(
                    modifier = Modifier
                        .fillMaxWidth()
                        .align(Alignment.TopCenter)
                )
            }
            if (isLoadingDescription) {
                CircularProgressIndicator(
                    modifier = Modifier
                        .align(Alignment.Center)
                )
            }
            //Enabled dragging the dismissing button to not get in the way of the WebView content
            IconButton(
                onClick = {
                    // Handle onClick
                },
                colors = IconButtonDefaults.iconButtonColors(
                    contentColor = MaterialTheme.colorScheme.onBackground,
                    containerColor = MaterialTheme.colorScheme.surface,
                ),
                modifier = Modifier
                    .align(Alignment.TopEnd)
                    .padding(16.dp)
                    .offset { IntOffset(offsetX.roundToInt(), offsetY.roundToInt()) }
                    .pointerInput(Unit) {
                        detectDragGestures { change, dragAmount ->
                            change.consume() // Consume the gesture to prevent interference with other gestures
                            offsetX += dragAmount.x
                            offsetY += dragAmount.y
                        }
                    }
            ) {
                Icon(
                    Icons.Filled.Cancel,
                    contentDescription = "Back",
                    tint = MaterialTheme.colorScheme.onBackground,
                )
            }
        }
    }
}