File size: 3,559 Bytes
0bfe2e3
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
export function formatBytes(bytes: number, k: 1024 | 1000): string {
  if (bytes === 0) return '0 B';
  const sizes =
    k === 1024
      ? ['B', 'KiB', 'MiB', 'GiB', 'TiB']
      : ['B', 'KB', 'MB', 'GB', 'TB'];
  const i = Math.floor(Math.log(bytes) / Math.log(k));
  return parseFloat((bytes / Math.pow(k, i)).toFixed(2)) + ' ' + sizes[i];
}

export function formatDuration(durationInMs: number): string {
  const seconds = Math.floor(durationInMs / 1000);
  const minutes = Math.floor(seconds / 60);
  const hours = Math.floor(minutes / 60);

  const formattedSeconds = seconds % 60;
  const formattedMinutes = minutes % 60;

  if (hours > 0) {
    return `${hours}h:${formattedMinutes}m:${formattedSeconds}s`;
  } else if (formattedSeconds > 0) {
    return `${formattedMinutes}m:${formattedSeconds}s`;
  } else {
    return `${formattedMinutes}m`;
  }
}

export function languageToEmoji(language: string): string | undefined {
  return languageEmojiMap[language.toLowerCase()];
}

export function emojiToLanguage(emoji: string): string | undefined {
  return Object.entries(languageEmojiMap).find(
    ([_, value]) => value === emoji
  )?.[0];
}

export function codeToLanguage(code: string): string | undefined {
  return codeLanguageMap[code];
}
/**
 * A mapping of language names to their corresponding emoji flags.
 *
 * This mapping was adapted from the g0ldy/comet project.
 * https://github.com/g0ldyy/comet/blob/de5413425ac30a9d88bc7176862a7ff02027eb7f/comet/utils/general.py#L19C1-L19C18
 */
const languageEmojiMap: Record<string, string> = {
  multi: '๐ŸŒŽ',
  english: '๐Ÿ‡ฌ๐Ÿ‡ง',
  japanese: '๐Ÿ‡ฏ๐Ÿ‡ต',
  chinese: '๐Ÿ‡จ๐Ÿ‡ณ',
  russian: '๐Ÿ‡ท๐Ÿ‡บ',
  arabic: '๐Ÿ‡ธ๐Ÿ‡ฆ',
  portuguese: '๐Ÿ‡ต๐Ÿ‡น',
  spanish: '๐Ÿ‡ช๐Ÿ‡ธ',
  french: '๐Ÿ‡ซ๐Ÿ‡ท',
  german: '๐Ÿ‡ฉ๐Ÿ‡ช',
  italian: '๐Ÿ‡ฎ๐Ÿ‡น',
  korean: '๐Ÿ‡ฐ๐Ÿ‡ท',
  hindi: '๐Ÿ‡ฎ๐Ÿ‡ณ',
  bengali: '๐Ÿ‡ง๐Ÿ‡ฉ',
  punjabi: '๐Ÿ‡ต๐Ÿ‡ฐ',
  marathi: '๐Ÿ‡ฎ๐Ÿ‡ณ',
  gujarati: '๐Ÿ‡ฎ๐Ÿ‡ณ',
  tamil: '๐Ÿ‡ฎ๐Ÿ‡ณ',
  telugu: '๐Ÿ‡ฎ๐Ÿ‡ณ',
  kannada: '๐Ÿ‡ฎ๐Ÿ‡ณ',
  malayalam: '๐Ÿ‡ฎ๐Ÿ‡ณ',
  thai: '๐Ÿ‡น๐Ÿ‡ญ',
  vietnamese: '๐Ÿ‡ป๐Ÿ‡ณ',
  indonesian: '๐Ÿ‡ฎ๐Ÿ‡ฉ',
  turkish: '๐Ÿ‡น๐Ÿ‡ท',
  hebrew: '๐Ÿ‡ฎ๐Ÿ‡ฑ',
  persian: '๐Ÿ‡ฎ๐Ÿ‡ท',
  ukrainian: '๐Ÿ‡บ๐Ÿ‡ฆ',
  greek: '๐Ÿ‡ฌ๐Ÿ‡ท',
  lithuanian: '๐Ÿ‡ฑ๐Ÿ‡น',
  latvian: '๐Ÿ‡ฑ๐Ÿ‡ป',
  estonian: '๐Ÿ‡ช๐Ÿ‡ช',
  polish: '๐Ÿ‡ต๐Ÿ‡ฑ',
  czech: '๐Ÿ‡จ๐Ÿ‡ฟ',
  slovak: '๐Ÿ‡ธ๐Ÿ‡ฐ',
  hungarian: '๐Ÿ‡ญ๐Ÿ‡บ',
  romanian: '๐Ÿ‡ท๐Ÿ‡ด',
  bulgarian: '๐Ÿ‡ง๐Ÿ‡ฌ',
  serbian: '๐Ÿ‡ท๐Ÿ‡ธ',
  croatian: '๐Ÿ‡ญ๐Ÿ‡ท',
  slovenian: '๐Ÿ‡ธ๐Ÿ‡ฎ',
  dutch: '๐Ÿ‡ณ๐Ÿ‡ฑ',
  danish: '๐Ÿ‡ฉ๐Ÿ‡ฐ',
  finnish: '๐Ÿ‡ซ๐Ÿ‡ฎ',
  swedish: '๐Ÿ‡ธ๐Ÿ‡ช',
  norwegian: '๐Ÿ‡ณ๐Ÿ‡ด',
  malay: '๐Ÿ‡ฒ๐Ÿ‡พ',
  latino: '๐Ÿ’ƒ๐Ÿป',
  Latino: '๐Ÿ‡ฒ๐Ÿ‡ฝ',
};

const codeLanguageMap: Record<string, string> = {
  EN: 'english',
  JA: 'japanese',
  ZH: 'chinese',
  RU: 'russian',
  AR: 'arabic',
  PT: 'portuguese',
  ES: 'spanish',
  FR: 'french',
  DE: 'german',
  IT: 'italian',
  KO: 'korean',
  HI: 'hindi',
  BN: 'bengali',
  PA: 'punjabi',
  MR: 'marathi',
  GU: 'gujarati',
  TA: 'tamil',
  TE: 'telugu',
  KN: 'kannada',
  ML: 'malayalam',
  TH: 'thai',
  VI: 'vietnamese',
  ID: 'indonesian',
  TR: 'turkish',
  HE: 'hebrew',
  FA: 'persian',
  UK: 'ukrainian',
  EL: 'greek',
  LT: 'lithuanian',
  LV: 'latvian',
  ET: 'estonian',
  PL: 'polish',
  CS: 'czech',
  SK: 'slovak',
  HU: 'hungarian',
  RO: 'romanian',
  BG: 'bulgarian',
  SR: 'serbian',
  HR: 'croatian',
  SL: 'slovenian',
  NL: 'dutch',
  DA: 'danish',
  FI: 'finnish',
  SV: 'swedish',
  NO: 'norwegian',
  MS: 'malay',
  LA: 'latino',
  MX: 'Latino',
};