Want to browse every Luna component in five minutes? Open LunaStorybook.unity — one sidebar-driven scene that previews each component live: pick on the left, play with it on the right, no scene-flipping. It ships in the Showcase sample (Samples~/Showcase/ in com.cupkekgames.luna), the pure-UI half of Luna's demo content; the same sample also holds the flagship LunaShowcase shell and the specials scenes below.
Showcase requires only Luna's bundled deps (data, graphs, singletons, pool, fadeables, keyvaluedatabases, prefabloaders, editorui, editorinspector, packagemanager, input) — all installed transitively when you import Luna. data and graphs are declared Luna dependencies as of 2.3.2; they power the catalog-keyed nav-graph navigation the shell runs on. No game-systems packages needed — for those, see GameFull.
Import Essentials alongside. Showcase references theme/UXML/sprites/audio in the Essentials sample via sibling-relative paths (
../../../../Essentials/...). Without Essentials imported, scenes load with broken images and styles.
LunaShowcase.unityA complete game-style UI shell with tabs (Home, Heroes, Quests, Shop, Leaderboard), modals, overlays, and responsive layout switching. The driving controller is LunaShowcase (ShowcaseAssets/Scripts/Screens/LunaShowcase.cs); the UXML it loads keeps its legacy GameUiHub.uxml filename (ShowcaseAssets/UXML/Screens/GameUiHub.uxml).
The scene root hosts a NavHost that mounts ShowcaseAssets/Navigation/ShowcaseNavGraphSO.asset and spawns every tab body / detail / modal prefab from it. Worth peeking at the wiring:
luna:TabView whose destinations UXML attribute carries the channel-root node ids in tab-button order — home.tab.home,home.tab.heroes,home.tab.quests,home.tab.shop,home.tab.leaderboard (ShowcaseAssets/UXML/Components/Molecules/TabBar.uxml). Tab routing is owned by that attribute; the controller only plays the icon bounce.TabView (ShopTabs in ShowcaseAssets/UXML/Screens/Tabs/ShopTab.uxml) with sub-channel destinations home.tab.shop.bundle, home.tab.shop.gold, home.tab.shop.items.await LunaNavigation.PushAsync<bool>(_confirmModalDest, new ConfirmModalArgs { ... }), then checks result.IsDismissed / result.Value. Destinations on the controller are CatalogKey fields constrained with [CatalogKeyConstraint(NavConstants.NavDestinationCatalogId)].Open LunaShowcase.unity for the headline demo. Hit Play, click around the tabs, open modals.
LunaStorybook.unityA single sidebar-driven scene that consolidates the simple per-component showcases (Toggle, Slider, Buttons, ListView, etc.) — no more flipping through 25 separate scenes. Pick a component on the left to preview it on the right.
Open LunaStorybook.unity. The recommended browse-it-fast entry point for new users.
See Storybook/README.md for the underlying view code and how to add a new entry.
Components/Specials-only — distinctive variants and feature demos that need their own scene because they show scene-level wiring (camera, multiple inputs, layout responsiveness, composite demos). Flat layout — no cluster prefixes:
| Folder | Scenes |
|---|---|
DragAndDrop/ | DragAndDropDemoWorldSpace |
InputPrompt/ | InputPromptLocalMultiplayer |
ProgressBar/{LeagueOfLegends,MultiPass,Overwatch}/ | LeagueOfLegends, MultiPass, Overwatch + OverwatchCelled |
RadialProgressBar/ | MultiSegment, Overwatch, OverwatchNoCells, SweepAngle |
GridView/{GridViewListView,GridViewPagination}/ | GridViewListResponsiveDemo, GridViewPaginationResponsiveDemo |
Tooltip/ | WorldSpace, Nested, Update |
Effects/ | Playground, Presets, Showcase (+ shared EffectsFlair.uxml used by Storybook) |
LoadingScreen/ | LoadingScreen |
LoadingTransitionMasking/ | LoadingTransitionMasking |
LocalizationDemo/ | LocalizationDemo (requires com.unity.localization) |
TransitionAnimation/ | TransitionPresetGallery, UIViewTransitionDemo (+ shared TransitionAnimationDemo.uxml used by Storybook) |
ResponsiveDemo/ | ResponsiveDemo |
UIAttractor/ | UIAttractorDemo |
UIRender/ | UIRenderDemoCharacters, UIRenderDemoOverlay |
RPGDemo/ | RPGDemo |
Note: the Japanese font and localized theme/panel settings were copied into GameFull (
GameFull/Fonts/,GameFull/Setup/Localization/); the locale tables and Locale assets still live here underComponents/LocalizationDemo/Localization/— they are what GameFull'sLocalizedStringbindings resolve through (see GameFull → Known caveats). The LocalizationDemo scene itself still lives here.
Refer to the Components section in the sidebar for per-component API documentation.
Shared theme tokens, fonts, panel settings, UXML primitives, sprites, audio, demo prefabs, and helper scripts live in the Essentials sample (Samples~/Essentials/):
Essentials/
├── README.md ← Start-here landing page
├── Audio/ — shared demo audio (clicks, mixer)
├── Effects/ — Luna filter shader assets
├── Input/ — input action map + Luna icon database
├── Navigation/ — LunaNavConfigSO.asset + LunaNavConfigSOWorldSpace.asset (render configs NavHost applies to spawned views)
├── Prefabs/ — LunaUIManager.prefab (the bootstrap manager)
├── ScriptableObjects/ — transition presets
├── Scripts/ — shared demo helpers (TooltipDatabaseExample)
├── Sprites/socials/ — Discord / Steam social-button icons (used by Showcase + GameFull main menus)
├── Theme/ — design system: fonts, colors, panel settings, USS tokens
└── UXML/
├── Components/ — reusable UXML primitives (ChoicePopup, Tooltip, Pagination, Notification, SaveLoad, ReturnButton)
└── Modal.uss — shared modal stylesheetThese are also referenced by the GameFull sample via sibling-relative paths. When all samples are imported they live as siblings under Assets/Samples/LunaUI/<version>/ and the relative refs resolve cleanly.
Settings
Theme
Light
Contrast
Material
Dark
Dim
Material Dark
System
Sidebar(Light & Contrast only)
Font Family
DM Sans
Wix
Inclusive Sans
AR One Sans
Direction