Files

File: src/main/java/com/paymentlink/model/entity/Translation.java

1 package com.paymentlink.model.entity;
2
3 import jakarta.persistence.*;
4 import lombok.AllArgsConstructor;
5 import lombok.Builder;
6 import lombok.Data;
7 import lombok.NoArgsConstructor;
8 import org.hibernate.annotations.CreationTimestamp;
9 import org.hibernate.annotations.UpdateTimestamp;
10
11 import java.time.LocalDateTime;
12
13 @Entity
14 @Table(name = "translations",
15 indexes = @Index(name = "idx_translation_lookup",
16 columnList = "entityType,entityId,fieldName,languageCode"))
17 @Data
18 @NoArgsConstructor
19 @AllArgsConstructor
20 @Builder
21 public class Translation {
22
23 @Id
24 @GeneratedValue(strategy = GenerationType.IDENTITY)
25 private Long id;
26
27 @Column(nullable = false, length = 50)
28 private String entityType; // "product", "category", "ui"
29
30 @Column(nullable = false, length = 100)
31 private String entityId; // Product ID, category name, or UI key
32
33 @Column(nullable = false, length = 50)
34 private String fieldName; // "name", "description", etc.
35
36 @Column(length = 2, nullable = false)
37 private String languageCode; // ISO 639-1 (e.g., "en", "es", "fr")
38
39 @Column(columnDefinition = "TEXT", nullable = false)
40 private String translatedText;
41
42 @CreationTimestamp
43 @Column(name = "created_at", updatable = false)
44 private LocalDateTime createdAt;
45
46 @UpdateTimestamp
47 @Column(name = "updated_at")
48 private LocalDateTime updatedAt;
49 }
50