defineField()를 사용해 소유하지 않은 객체(예: Person이나 Company 같은 표준 Twenty 객체 또는 다른 설치된 앱에서 제공하는 객체)에 필드를 추가합니다. defineObject 안에 선언된 인라인 필드와 달리, 독립형 필드는 어느 객체를 확장할지 지정하기 위해 objectUniversalIdentifier가 필요합니다.
src/fields/company-loyalty-tier.field.ts
핵심 요점
-
objectUniversalIdentifier는 대상 객체를 식별합니다. 표준 Twenty 객체의 경우twenty-sdk에서 상수를 가져옵니다: -
defineObject()에서 필드를 인라인으로 정의할 때는,objectUniversalIdentifier가 필요하지 않습니다 — 상위 객체에서 상속됩니다. -
defineField()는defineObject()로 생성하지 않은 객체에 필드를 추가하는 유일한 방법입니다. -
파일 위치는 자유롭게 정할 수 있습니다. 규칙으로는
src/fields/\<name>.field.ts를 사용하지만, SDK는src/어디에서든 필드를 감지합니다. -
표준 페이지 레이아웃(예: Task 또는 Company 상세 페이지)에 탭을 추가하려면,
twenty-sdk/define의STANDARD_PAGE_LAYOUT_UNIVERSAL_IDENTIFIERS와 함께definePageLayoutTab을(를) 사용하십시오.
기존 객체에 관계 추가하기
관계 필드(예: 사용자 정의 객체를 표준Person에 연결)를 추가하려면, FieldType.RELATION과 함께 defineField()를 사용하세요. 패턴은 인라인 관계와 동일하지만, objectUniversalIdentifier를 명시적으로 설정합니다. 양방향 패턴은 Relations를 참조하세요.