Skip to content

A UI client for Ollama written in Compose Multiplatform focused on running Deepseek r1 locally

License

Notifications You must be signed in to change notification settings

Kashif-E/KOllama

Folders and files

NameName
Last commit message
Last commit date

Latest commit

c9ce8df Β· Feb 11, 2025

History

20 Commits
Feb 11, 2025
Feb 11, 2025
Feb 11, 2025
Feb 11, 2025
Jan 28, 2025
Jan 28, 2025
Feb 11, 2025
Feb 11, 2025
Feb 11, 2025
Jan 28, 2025
Jan 28, 2025
Feb 11, 2025

Repository files navigation

Kollama

Kollama is a modern, cross-platform chat interface for Ollama models built with Kotlin Multiplatform and Compose Multiplatform. It provides a sleek, user-friendly way to interact with local AI models while offering advanced features like code formatting, markdown support, and animated UI elements.

Features

  • πŸš€ Cross-Platform Support: Built with Kotlin Multiplatform and Compose Multiplatform
  • πŸ’¬ Real-time Chat Interface:
    • Streaming responses with real-time updates
    • Concurrent chat support with efficient job management
    • Smart session handling with LRU cache
  • 🎨 Rich Markdown Support:
    • Syntax-highlighted code blocks with customizable themes
    • Tables and complex formatting
    • Custom typography system
    • Optimized rendering for large messages
  • πŸ”„ Advanced Message Handling:
    • Real-time message streaming with state management
    • Robust error handling and retry mechanism
    • Optimized clipboard operations
    • Sophisticated message state tracking
  • πŸ’Ύ Persistent Storage:
    • SQLDelight for efficient, type-safe SQL operations
    • Cross-platform database support
    • Optimized query performance
  • 🎯 Advanced Model Integration:
    • Dynamic model switching with state preservation
    • Model details display with animated marquee
    • Real-time model status indicators
  • 🎭 Polished UI/UX:
    • Animated right sheet with gesture support
    • Custom animated borders and transitions
    • Fluid dark/light theme switching
    • Responsive layout with efficient recomposition
    • Pulsating status indicators and loading states

Screenshots

art1.png art2.png art3.png art4.png

Prerequisites

  • JDK 17 or higher
  • Ollama installed and running (default: localhost:11434)
  • At least one Ollama model downloaded

Getting Started

  1. Install Ollama from Ollama's official website
  2. Pull a model using Ollama CLI:
    ollama pull deepseek-coder:33b
  3. Clone this repository:
    git clone https://github.com/kashif-e/kollama.git
  4. Run using Gradle:
    ./gradlew run

Architecture

Kollama follows clean architecture principles with a focus on modularity and testability:

Core Components

  • Presentation Layer:

    • ChatViewModel: Manages UI state and user interactions
    • ChatScreen: Main UI composition
    • Custom composables for reusable UI elements
    • Advanced state management with Kotlin Flow
  • Domain Layer:

    • Pure Kotlin models for type safety
    • Repository interfaces for data abstraction
    • Clear separation of concerns
  • Data Layer:

    • ChatRepository: Implementation of data operations
    • OllamaService: Handles AI model communication
    • DatabaseWrapper: SQLDelight database operations
    • Efficient data mapping and transformation
  • Infrastructure:

    • Koin for dependency injection
    • SQLDelight for database operations
    • Ktor for network communications

Key Technical Features

State Management

data class ChatUiState(
    val isLoading: Boolean = false,
    val error: String? = null,
    val currentSession: ChatSessionDomainModel? = null,
    val chatSessions: List<ChatSessionDomainModel> = emptyList(),
    val selectedModel: OllamaModel? = null,
    val availableModels: List<OllamaModel> = emptyList(),
    val thinkingMessage: ChatMessageDomainModel? = null,
    val showModelList: Boolean = false,
)

Efficient Job Management

class ChatJobManager {
    private val mutex = Mutex()
    private val jobMap: MutableMap<String, JobState> = mutableMapOf()
    private val lruList = DoublyLinkedList<String>()
    
    // Manages concurrent chat sessions with LRU caching
}

Custom UI Components

@Composable
fun AnimatedBorderBox(
    borderColors: List<Color>,
    backgroundColor: Color,
    shape: Shape = RectangleShape,
    borderWidth: Dp = 1.dp,
    animationDurationInMillis: Int = 3000,
    content: @Composable BoxScope.() -> Unit
)

Project Structure

kollama/
β”œβ”€β”€ data/
β”‚   β”œβ”€β”€ local/
β”‚   β”‚   β”œβ”€β”€ database/
β”‚   β”‚   └── service/
β”‚   β”œβ”€β”€ model/
β”‚   └── repository/
β”œβ”€β”€ domain/
β”‚   β”œβ”€β”€ interfaces/
β”‚   └── model/
β”œβ”€β”€ presentation/
β”‚   β”œβ”€β”€ components/
β”‚   β”œβ”€β”€ modifier/
β”‚   β”œβ”€β”€ state/
β”‚   └── theme/
└── di/

Advanced Features

Custom Animations

  • Animated message borders with gradient effects
  • Pulsating status indicators
  • Smooth sheet transitions with gesture support
  • Marquee animations for model details

Performance Optimizations

  • Efficient recomposition with remember/derivedStateOf
  • Smart job management for concurrent chats
  • Optimized database operations
  • Proper coroutine scope management

Network & Error Handling

  • Robust error handling with custom error types
  • Retry mechanisms for failed requests
  • Proper timeout and cancellation handling
  • Stream processing for real-time updates

Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Commit your changes
  4. Push to the branch
  5. Create a Pull Request

Acknowledgments