@sqlrooms/room-config
A central configuration and type definitions package that maintains base room configuration schemas and Zod schema definitions. It provides TypeScript types and interfaces along with essential constants and utilities used throughout the framework.
Features
- 📝 Room Configuration: Define and manage room configuration schemas
- 🔍 Type Safety: Strong TypeScript typing for configuration objects
- ✅ Validation: Zod schemas for runtime validation of configuration
Installation
bash
npm install @sqlrooms/room-config
# or
yarn add @sqlrooms/room-configBasic Usage
Working with Base Room Configuration
tsx
import {BaseRoomConfig} from '@sqlrooms/room-config';
// Create a new room configuration
const roomConfig: BaseRoomConfig = {
name: 'My SQL Room',
description: 'A data analysis room using SQLRooms',
version: '1.0.0',
settings: {
theme: 'dark',
// Other settings...
},
};
// Access configuration properties
console.log(roomConfig.name); // 'My SQL Room'Persisting Room Configuration
Room configuration is designed to be saved and restored between sessions. Here's how to use the persistSliceConfigs helper:
tsx
import {
createRoomStore,
createRoomShellSlice,
RoomShellSliceState,
persistSliceConfigs,
LayoutConfig,
} from '@sqlrooms/room-shell';
import {BaseRoomConfig} from '@sqlrooms/room-config';
type MyRoomState = RoomShellSliceState;
// Create a store with persistence for configuration
const {useRoomStore} = createRoomStore<MyRoomState>(
persistSliceConfigs(
{
name: 'room-config-storage',
sliceConfigSchemas: {
room: BaseRoomConfig,
layout: LayoutConfig,
},
},
(set, get, store) => ({
...createRoomShellSlice({
config: {
title: 'My Room',
// Other configuration properties
},
layout: {
config: {
// Layout configuration
},
panels: {
// Panel definitions
},
},
})(set, get, store),
}),
),
);
// Access the config in components
function ConfigComponent() {
// Config is accessed from state.room.config
const config = useRoomStore((state) => state.room.config);
return <div>{config.title}</div>;
}Advanced Features
- Schema Extensions: Extend base schemas for custom room types
- Configuration Validation: Validate configurations at runtime
- Serialization: Convert configurations to/from JSON for storage
For more information, visit the SQLRooms documentation.
Type Aliases
- LayoutTypes
- MosaicLayoutDirection
- MosaicLayoutParent
- MosaicLayoutNodeKey
- MosaicLayoutNode
- MosaicLayoutConfig
- LayoutConfig
- BaseRoomConfig
- DataSourceTypes
- BaseDataSource
- FileDataSource
- UrlDataSource
- SqlQueryDataSource
- DataSource
- LoadFile
- StandardLoadOptions
- SpatialLoadOptions
- SpatialLoadFileOptions
- StandardLoadFileOptions
- LoadFileOptions
Variables
- MAIN_VIEW
- LayoutTypes
DEFAULT_MOSAIC_LAYOUT- MosaicLayoutDirection
- MosaicLayoutParent
- MosaicLayoutNodeKey
- MosaicLayoutNode
- MosaicLayoutConfig
- LayoutConfig
- DEFAULT_ROOM_TITLE
- BaseRoomConfig
- DataSourceTypes
- BaseDataSource
- FileDataSource
- UrlDataSource
- SqlQueryDataSource
- DataSource
- LoadFile
- StandardLoadOptions
- SpatialLoadOptions
- SpatialLoadFileOptions
- StandardLoadFileOptions
- LoadFileOptions
