Pith - kerf
kerf/app/src/main/java/com/vgmlr/kerf/KerfDialogs.kt [7.4 kb]
Modified: 23:16:30 89 026 (16 Jun 026)
7 Days Ago
package com.vgmlr.kerf

import androidx.compose.foundation.clickable
import androidx.compose.foundation.layout.*
import androidx.compose.foundation.lazy.LazyColumn
import androidx.compose.foundation.shape.RoundedCornerShape
import androidx.compose.material.icons.Icons
import androidx.compose.material.icons.filled.Add
import androidx.compose.material3.*
import androidx.compose.runtime.Composable
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.platform.LocalUriHandler
import androidx.compose.ui.text.style.TextOverflow
import androidx.compose.ui.unit.dp
import androidx.compose.ui.unit.sp
import androidx.compose.ui.window.Dialog
import androidx.compose.ui.text.font.FontFamily
import androidx.compose.foundation.lazy.itemsIndexed
import androidx.compose.foundation.background
import androidx.compose.ui.window.DialogProperties

@OptIn(ExperimentalMaterial3Api::class)
@Composable
fun SearchDialog(notes: List<Note>, onSelect: (Int) -> Unit, onDismiss: () -> Unit) {
    val kerfColors = LocalKerfColors.current!!

    BasicAlertDialog(
        onDismissRequest = onDismiss,
        modifier = Modifier
            .background(color = kerfColors.alertBackground, shape = RoundedCornerShape(8.dp))
            .padding(horizontal = 20.dp, vertical = 16.dp)
    ) {
        LazyColumn(
            modifier = Modifier
                .fillMaxWidth()
                .heightIn(max = 340.dp),
            verticalArrangement = Arrangement.Center
        ) {
            itemsIndexed(items = notes) { index, n ->
                ListItem(
                    headlineContent = {
                        Text(
                            text = n.title.ifBlank { "Untitled" },
                            maxLines = 1,
                            overflow = TextOverflow.Ellipsis
                        )
                    },
                    colors = ListItemDefaults.colors(
                        containerColor = kerfColors.alertBackground,
                        headlineColor = kerfColors.alertText
                    ),
                    modifier = Modifier.clickable { onSelect(n.id) }
                )

                if (notes.size > 1 && index < notes.lastIndex) {
                    HorizontalDivider(color = Color.Gray.copy(alpha = 0.3f))
                }
            }
        }
    }
}

@OptIn(ExperimentalMaterial3Api::class)
@Composable
fun ShareDialog(notes: List<Note>, onSelect: (Int) -> Unit, onAddNew: () -> Unit, onDismiss: () -> Unit) {
    val kerfColors = LocalKerfColors.current!!
    val totalItemsCount = notes.size + 1 

    BasicAlertDialog(
        onDismissRequest = onDismiss,
        modifier = Modifier
            .background(color = kerfColors.alertBackground, shape = RoundedCornerShape(8.dp))
            .padding(horizontal = 20.dp, vertical = 16.dp)
    ) {
        LazyColumn(
            modifier = Modifier
                .fillMaxWidth()
                .heightIn(max = 340.dp),
            verticalArrangement = Arrangement.Center
        ) {
            item {
                ListItem(
                    headlineContent = { Text("New List", color = kerfColors.menuText) },
                    trailingContent = {
                        Icon(
                            Icons.Default.Add,
                            null,
                            tint = kerfColors.alertText.copy(alpha = 0.4f)
                        )
                    },
                    colors = ListItemDefaults.colors(containerColor = kerfColors.alertBackground),
                    modifier = Modifier.clickable { onAddNew() }
                )
                
                if (totalItemsCount > 1 && notes.isNotEmpty()) {
                    HorizontalDivider(color = Color.Gray.copy(alpha = 0.3f))
                }
            }
            
            itemsIndexed(items = notes) { index, n ->
                val currentOverallIndex = index + 1

                ListItem(
                    headlineContent = {
                        Text(
                            text = n.title.ifBlank { "Untitled" },
                            maxLines = 1,
                            overflow = TextOverflow.Ellipsis
                        )
                    },
                    colors = ListItemDefaults.colors(
                        containerColor = kerfColors.alertBackground,
                        headlineColor = kerfColors.alertText
                    ),
                    modifier = Modifier.clickable { onSelect(n.id) }
                )
                
                if (totalItemsCount > 1 && currentOverallIndex < totalItemsCount - 1) {
                    HorizontalDivider(color = Color.Gray.copy(alpha = 0.3f))
                }
            }
        }
    }
}

@Composable
fun DataDialog(createdAt: Long?, updatedAt: Long?, lastShared: Long?, onDismiss: () -> Unit) {
    val createddate = KerfUtils.formatLastSharedDate(createdAt)
    val modifieddate = KerfUtils.formatLastSharedDate(updatedAt)
    val shareddate = KerfUtils.formatLastSharedDate(lastShared)
    val kerfColors = LocalKerfColors.current!!
    Dialog(
        onDismissRequest = onDismiss,
        properties = DialogProperties(usePlatformDefaultWidth = false)
    ) {
        Surface(
            modifier = Modifier
                .padding(horizontal = 24.dp)
                .fillMaxWidth(),
            color = kerfColors.alertBackground,
            shape = RoundedCornerShape(8.dp),
        ) {
            Column(
                modifier = Modifier.padding(horizontal = 24.dp, vertical = 32.dp),
                horizontalAlignment = Alignment.CenterHorizontally
            ) {
                Row {
                    Column(horizontalAlignment = Alignment.End) {
                        Text("Created", color = kerfColors.alertText, fontSize = 14.sp)
                        Text("Modified", color = kerfColors.alertText, fontSize = 14.sp)
                        Text("Shared", color = kerfColors.alertText, fontSize = 14.sp)
                    }
                    Spacer(Modifier.width(16.dp))
                    Column {
                        Text(createddate, color = kerfColors.alertText, fontSize = 13.sp, fontFamily = FontFamily.Monospace)
                        Text(modifieddate, color = kerfColors.alertText, fontSize = 13.sp, fontFamily = FontFamily.Monospace)
                        Text(shareddate, color = kerfColors.alertText, fontSize = 13.sp, fontFamily = FontFamily.Monospace)
                    }
                }
            }
        }
    }
}

@Composable
fun VersionDialog(onDismiss: () -> Unit) {
    val uriHandler = LocalUriHandler.current
    val kerfColors = LocalKerfColors.current!!
    Dialog(
        onDismissRequest = onDismiss
    ) {
        Surface(
            shape = RoundedCornerShape(8.dp),
            color = kerfColors.alertBackground
        ) {
            Column(
                modifier = Modifier.padding(horizontal = 67.dp, vertical = 26.dp),
                horizontalAlignment = Alignment.CenterHorizontally
            ) {
                Text("com.vgmlr.kerf", color = kerfColors.alertText, fontSize = 14.sp)
                Text("86.026.4", color = kerfColors.alertText, fontSize = 14.sp)
                Text(
                    "vgmlr.com/mlwrk",
                    color = kerfColors.alertText,
                    fontSize = 14.sp,
                    modifier = Modifier.clickable { uriHandler.openUri("https://vgmlr.com/mlwrk") }
                )
            }
        }
    }
}
Updates
OTC Applet - Linux 93.026.1
Wedge - Linux 90.026.1
Wedge - Android 90.026.1
Shim - Android 86.026.1
Kerf - Android 86.026.4
Dev
TVShow (227) 'CSA'
TVShow (228) 'APT'
TVProgram (83) 'BXT'
Miter Update(s)
Peen (Messaging)

Menu
Calendar
Project Tin (024/029)
Miter
RSS Feed
User Avatar
@vgmlr
=SUM(parts)