Skip to main content

Cerințe

  • Node.js 24+Descărcați
  • Yarn 4 — vine împreună cu Node prin Corepack. Activați-l: corepack enable
  • DockerDescărcați. Necesar pentru a rula un server Twenty local. Omiteți dacă rulați deja Twenty în altă parte.
Crearea unei aplicații Twenty are trei faze. Generatorul de schelet le reduce la o singură comandă pe happy path, dar fiecare fază este un concept separat — când ceva eșuează, dacă știți în ce fază sunteți, știți ce trebuie să corectați.
FazăCe facețiInstrumentRezultat
1. Creați scheletulGenerați codul sursă al aplicațieinpx create-twenty-appUn proiect TypeScript pe disc
2. Rulați un serverPorniți un server Twenty cu care să sincronizațiDocker + yarn twenty serverO instanță Twenty care rulează
3. SincronizațiSincronizați în timp real codul cu serverulyarn twenty devModificările apar în UI

Faza 1 — Creați scheletul proiectului

Creați o nouă aplicație din șablon:
npx create-twenty-app@latest my-twenty-app
Vi se va cere un nume și o descriere — apăsați Enter pentru valorile implicite. Aceasta generează un proiect TypeScript în my-twenty-app/ cu un fișier inițial application-config.ts, un rol implicit, un flux de lucru CI și un test de integrare. După această fază: aveți codul sursă al aplicației pe mașina dvs. Încă nu rulează — aceasta este Faza 2.

Faza 2 — Rulați un server Twenty local

Aplicația are nevoie de un server Twenty cu care să se sincronizeze. Serverul este o instanță Twenty completă — UI, API GraphQL, PostgreSQL — care rulează local în Docker. Codul local încarcă definițiile pe acel server, făcându-le să apară în UI. Generatorul de schelet vă propune să pornească unul pentru dvs.:
Doriți să configurați o instanță Twenty locală?
  • Yes (recomandat) — descarcă imaginea Docker twentycrm/twenty-app-dev și o pornește pe portul 2020. Asigurați-vă mai întâi că Docker rulează.
  • No — alegeți această opțiune dacă aveți deja un server Twenty la care doriți să vă conectați. Îl puteți conecta ulterior cu yarn twenty remote add.
Porniți instanța locală?
După ce serverul pornește, se deschide un browser pentru autentificare. Folosiți contul demo preconfigurat:
  • E-mail: tim@apple.dev
  • Parolă: tim@apple.dev
Ecranul de autentificare Twenty
Faceți clic pe Authorize pe ecranul următor — aceasta oferă CLI-ului acces la spațiul dvs. de lucru.
Ecranul de autorizare Twenty CLI
Terminalul va confirma că totul este configurat.
Aplicația a fost creată cu succes
După această fază: aveți un server Twenty care rulează la http://localhost:2020, iar CLI-ul dvs. este autorizat să sincronizeze cu acesta.
Dacă Docker nu este instalat sau nu rulează, generatorul de schelet vă va indica comanda corectă de pornire pentru sistemul dvs. de operare. După ce Docker rulează, puteți continua cu yarn twenty server start — nu este nevoie să recreați scheletul.

Faza 3 — Sincronizați modificările

Aceasta este bucla internă în care veți petrece cea mai mare parte a timpului.
cd my-twenty-app
yarn twenty dev
Aceasta monitorizează src/, reconstruiește la fiecare modificare și sincronizează rezultatul pe server. Editați un fișier, salvați, iar în decurs de o secundă serverul reflectă modificarea. Veți vedea în terminal un panou de stare în timp real. Pentru un output mai detaliat (jurnale de build, cereri de sincronizare, urme ale erorilor), adăugați --verbose.
Ieșirea terminalului în modul de dezvoltare
Deschideți http://localhost:2020/settings/applications#developer. Ar trebui să vedeți aplicația dvs. listată la Your Apps.
Lista Your Apps care afișează My twenty app
Faceți clic pe My twenty app pentru a vedea înregistrarea aplicației — o înregistrare la nivel de server care descrie aplicația dvs. (nume, identificator, credențiale OAuth, sursă). O singură înregistrare poate fi instalată în mai multe spații de lucru pe același server.
Detalii despre înregistrarea aplicației
Faceți clic pe View installed app pentru a vedea instalarea în spațiul de lucru. Fila About afișează versiunea și opțiunile de administrare.
Aplicație instalată
După această fază: aveți o buclă de dezvoltare în timp real. Editați orice fișier în src/ și acesta apare în UI.

Sincronizare unică pentru CI și scripturi

Adăugați --once pentru a rula un singur build + sync și a ieși — același flux, fără watcher:
yarn twenty dev --once
ComandăComportamentCând se folosește
yarn twenty devMonitorizează și resincronizează la fiecare modificare. Rulează până când îl opriți.Dezvoltare locală interactivă.
yarn twenty dev --onceUn singur build + sync, iese cu 0 la succes, 1 la eșec.CI, hook-uri pre-commit, agenți AI, fluxuri de lucru scriptate.
Ambele moduri necesită un server în modul de dezvoltare și un remote autentificat.
Modul de dezvoltare este disponibil doar pe instanțele Twenty care rulează în modul development (NODE_ENV=development). Instanțele de producție resping cererile de sincronizare din modul de dezvoltare — folosiți yarn twenty deploy pentru a implementa pe serverele de producție. Consultați Publicarea aplicațiilor.

Ce puteți construi

Aplicațiile sunt compuse din entități — fiecare definită într-un fișier TypeScript cu un singur export default:
EntitateCe face
Obiecte și câmpuriModele de date personalizate (carte poștală, factură etc.) cu câmpuri tipizate
Funcții logiceTypeScript pe server declanșat de rute HTTP, programări cron sau evenimente din baza de date
Componente front-endComponente React care se afișează în UI-ul Twenty (panou lateral, widgeturi, meniul de comenzi)
Abilități și agențiCapabilități AI — instrucțiuni reutilizabile și asistenți autonomi
Vizualizări și navigareVizualizări de listă preconfigurate și elemente de meniu în bara laterală
Layouturi de paginăPagini personalizate de detalii ale înregistrărilor cu file și widgeturi
Referință completă: Crearea aplicațiilor.

Structura proiectului

my-twenty-app/
  package.json
  src/
    application-config.ts                   # Required — your app's entry point
    default-role.ts                         # Permissions for logic functions
    constants/
      universal-identifiers.ts              # Auto-generated UUIDs and metadata
    __tests__/
      setup-test.ts
      app-install.integration-test.ts
  .github/workflows/ci.yml                  # GitHub Actions
  public/                                   # Static assets
  vitest.config.ts                          # Test runner config
  tsconfig.json, tsconfig.spec.json
  .nvmrc, .yarnrc.yml, .oxlintrc.json
  README.md, LLMS.md
Fișier / FolderScop
src/application-config.tsNecesar. Fișierul principal de configurare pentru aplicație.
src/default-role.tsRol implicit care controlează la ce pot avea acces funcțiile logice.
src/constants/universal-identifiers.tsUUID-uri generate automat și metadate (nume afișat, descriere).
src/__tests__/Teste de integrare (configurare + test exemplu).
public/Resurse statice (imagini, fonturi) servite împreună cu aplicația.

Pornind de la un exemplu

Folosiți --example pentru a începe cu un proiect mai complet (obiecte personalizate, câmpuri, funcții logice, componente front-end):
npx create-twenty-app@latest my-twenty-app --example postcard
Exemplele se află în twenty-apps/examples. Puteți, de asemenea, să creați scheletul entităților individuale într-un proiect existent cu yarn twenty add — vedeți Crearea aplicațiilor.

Gestionarea serverului local

Folosiți yarn twenty server pentru a controla containerul Twenty local:
ComandăCe face
yarn twenty server startPornește serverul (descarcă imaginea dacă este necesar)
yarn twenty server start --port 3030Pornește pe un port personalizat
yarn twenty server stopOprește serverul (păstrează datele)
yarn twenty server statusAfișează URL-ul, versiunea și credențialele de autentificare
yarn twenty server logsTransmite în flux jurnalele serverului
yarn twenty server resetȘterge datele și pornește de la zero
yarn twenty server upgradeDescarcă cea mai recentă imagine twenty-app-dev
yarn twenty server upgrade 2.2.0Actualizează la o versiune specifică
Datele persistă între reporniri în două volume Docker (twenty-app-dev-data pentru PostgreSQL, twenty-app-dev-storage pentru fișiere). Folosiți reset pentru a șterge totul.

Actualizarea imaginii serverului

yarn twenty server upgrade descarcă cea mai recentă imagine, compară digest-urile și recreează containerul doar dacă s-a schimbat ceva. Volumele de date sunt păstrate — doar containerul este înlocuit. Dacă a fost descărcată o imagine nouă și containerul rula, actualizarea pornește automat un container nou; rulați apoi yarn twenty server start pentru a aștepta până când devine funcțional.
yarn twenty server upgrade            # Latest
yarn twenty server upgrade 2.2.0      # Specific version
Puteți verifica versiunea care rulează cu yarn twenty server status (aceasta afișează APP_VERSION încorporat în container).

Rularea unei instanțe de test în paralel

Adăugați --test la orice comandă server pentru a gestiona o a doua instanță, complet izolată — utilă pentru teste de integrare sau pentru a experimenta fără a atinge datele principale de dezvoltare:
ComandăCe face
yarn twenty server start --testPornește instanța de test (implicit pe portul 2021)
yarn twenty server stop --testOpriți-o
yarn twenty server status --testAfișați-i starea
yarn twenty server logs --testTransmiteți în flux jurnalele sale
yarn twenty server reset --testȘtergeți-i datele
yarn twenty server upgrade --testActualizați-i imaginea
Instanța de test are propriul container (twenty-app-dev-test), propriile volume (twenty-app-dev-test-data, twenty-app-dev-test-storage) și propria configurație — rulează alături de instanța principală, fără conflicte. Combinați --test cu --port pentru a înlocui portul 2021.

Configurare manuală (fără generator)

Săriți peste generatorul de schelet dacă adăugați SDK-ul într-un proiect existent:
yarn add twenty-sdk twenty-client-sdk
Adăugați scriptul în package.json:
{
  "scripts": {
    "twenty": "twenty"
  }
}
Acum puteți rula yarn twenty dev, yarn twenty server start și restul.
Nu instalați twenty-sdk global — fixați-l per proiect astfel încât fiecare aplicație să folosească propria versiune.

Depanare

  • Erori Docker — Asigurați-vă că Docker Desktop (sau daemonul) rulează înainte de yarn twenty server start. Mesajul de eroare va afișa comanda corectă de pornire pentru sistemul dvs. de operare.
  • Versiune Node greșită — Aveți nevoie de 24+. Verificați cu node -v.
  • Lipsește Yarn 4 — Rulați corepack enable.
  • Dependențe nefuncționalerm -rf node_modules && yarn install.
Blocat? Întrebați pe Discordul Twenty.