Initial public push: docs cosmos v4 + AI module + framework groundwork

This is the snapshot the production landing site (nibiru-framework.com) is
deployed from. Brings together the recent splash + docs migration to the v4
"Cosmos" design system, the new in-framework AI module, and the framework
groundwork that backs the framework-reference extraction.

What lands:
- docs/: Astro + Starlight site with the v4 dark cosmic palette, GalaxyHero
  canvas constellation, Mission Control chat (wired to /api/oracle →
  api.neuronetz.ai via providers.mjs Ollama), 5-panel MMVC stage
  (Model · AI · Module · Controller · View), translated EN/DE/JA/ES/FR
  content, PWA + sitemap + llms.txt + Umami analytics.
- docs/design-system/: canonical mockup bundle (source/index-v2.html for
  splash, source/docs-system.html + preview/ for docs, SPEC.md, tokens).
- docs/scripts/extraction/framework-reference-v2.md: deep framework
  reference (~1.6k lines, file:line citations, every public factory and
  idiom — basis for the LoRA training corpus.
- application/module/ai/: AI module with chat / embed / RAG / agent
  plugins, plus pdoQuery / httpGet / fileRead tools and Modelfile +
  smoke-test in training/.
- application/module/users/: user / ACL / form-factory traits used as the
  reference plugin pattern for the framework docs.
- application/settings/config/database/: schema + seed migrations
  including the AI module tables (200–203).
- Form factory + autogenerator changes the framework-reference-v2 covers.

Production secrets stay out: docs/.env, settings.production.ini and
ai.production.ini are all gitignored (.example files are in tree).

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
stephan
2026-05-08 15:22:18 +02:00
parent a60ce90643
commit 48c839d927
662 changed files with 172811 additions and 1 deletions

View File

@@ -0,0 +1,72 @@
@preloader-size: 30px;
@preloader-wieght: 1px;
@preloader-satelit-size: 8px;
@preloader-orbit-size: (@preloader-size * 1.1);
.preloader{
position: fixed;
width: 100%;
height: 100%;
background-color: white;
z-index: 9999;
}
.preloader-animation{
width: @preloader-size;
height: @preloader-size;
border: @preloader-wieght solid @color_blue;
border-radius: 50%;
position: fixed;
left: 50%;
top: 50%;
margin-top: -@preloader-size / 2;
margin-left: -@preloader-size / 2;
background-color: lighten(@color_blue, 40%);
box-shadow: 0 0 0 @preloader-orbit-size white, 0 0 0 @preloader-orbit-size + @preloader-wieght lighten(@color_blue, 30%);
backface-visibility: hidden;
&:after, &:before{
content: '';
display: block;
width: @preloader-satelit-size;
height: @preloader-satelit-size;
border-radius: 50%;
background-color: @color_blue;
border: @preloader-wieght solid @color_blue;
left: 50%;
.transform(translateX(-50%));
position: absolute;
background-color: lighten(@color_blue, 40%);
}
&:after{
top: -@preloader-orbit-size - (@preloader-satelit-size / 2) - @preloader-wieght;
-webkit-transform-origin: 0 (@preloader-size / 2) + (@preloader-satelit-size / 2) + @preloader-orbit-size;
-moz-transform-origin: 0 (@preloader-size / 2) + (@preloader-satelit-size / 2) + @preloader-orbit-size;
-ms-transform-origin: 0 (@preloader-size / 2) + (@preloader-satelit-size / 2) + @preloader-orbit-size;
-o-transform-origin: 0 (@preloader-size / 2) + (@preloader-satelit-size / 2) + @preloader-orbit-size;
transform-origin: 0 (@preloader-size / 2) + (@preloader-satelit-size / 2) + @preloader-orbit-size;
.animation(preloader-anim 1.5s linear infinite);
}
&:before{
bottom: -@preloader-orbit-size - (@preloader-satelit-size / 2) - @preloader-wieght;
-webkit-transform-origin: 0 -(@preloader-size / 2) + (@preloader-satelit-size / 2) - @preloader-orbit-size;
-moz-transform-origin: 0 -(@preloader-size / 2) + (@preloader-satelit-size / 2) - @preloader-orbit-size;
-ms-transform-origin: 0 -(@preloader-size / 2) + (@preloader-satelit-size / 2) - @preloader-orbit-size;
-o-transform-origin: 0 -(@preloader-size / 2) + (@preloader-satelit-size / 2) - @preloader-orbit-size;
transform-origin: 0 -(@preloader-size / 2) + (@preloader-satelit-size / 2) - @preloader-orbit-size;
.animation(preloader-anim 1.3s linear infinite);
}
}
.keyframes(preloader-anim; {
0%{
.transform(rotate(-180deg) translateX(-50%));
}
100%{
.transform(rotate(180deg) translateX(-50%));
}
});