npx create-twenty-app generiert wurde, sieht so aus:
Wichtige Dateien
| Datei / Ordner | Zweck |
|---|---|
src/application-config.ts | Erforderlich. Die Hauptkonfigurationsdatei für Ihre App. |
src/default-role.ts | Standardrolle, die steuert, worauf Ihre Logikfunktionen zugreifen können. |
src/constants/universal-identifiers.ts | Automatisch erzeugte UUIDs und Metadaten (Anzeigename, Beschreibung). |
src/__tests__/ | Integrationstests (Setup + Beispieltest). |
public/ | Statische Assets (Bilder, Schriftarten), die mit Ihrer App ausgeliefert werden. |
Die Dateiorganisation liegt bei Ihnen. Die oben genannten Ordner sind Konventionen – das SDK erkennt Entitäten über eine AST-Analyse von
export default defineEntity(...)-Aufrufen, unabhängig davon, wo sich die Datei befindet.Abhängigkeiten
Beide Twenty-SDK-Pakete gehören unterdevDependencies, nicht unter dependencies:
twenty-sdkstellt dietwenty-CLI sowie die Build-/Scaffolding-Tools bereit. Es läuft nur während der Entwicklung und beim Build und wird zur Laufzeit der veröffentlichten App niemals importiert.twenty-client-sdkwird hingegen von deinem App-Code importiert (CoreApiClient,MetadataApiClient,RestApiClient), aber Twenty stellt es zur Laufzeit bereit – Logikfunktionen beziehen es aus einer generierten SDK-Schicht, und Frontend-Komponenten lösen es aus serverseitig ausgelieferten Modulen auf. Deine installierte Kopie wird nur für die Typprüfung und den Build zum Zeitpunkt des Deployments verwendet, daher muss sie niemals im ausgelieferten Bundle enthalten sein.
dependencies bleibt, wird es in das Runtime-Bundle der installierten App gezogen, wo es nur Ballast ist. twenty build gibt eine Warnung aus, wenn eines von beiden weiterhin unter dependencies aufgeführt ist.
Füge die eigenen Runtime-Abhängigkeiten deiner App (Bibliotheken, die deine Logikfunktionen zur Laufzeit tatsächlich importieren) wie gewohnt unter dependencies hinzu.