@involvex/emoji-cli 2.2.5 → 2.2.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/bin/emoji-cli-improved.cjs +604 -0
- package/lib/bin/emoji-cli-improved.cjs.map +1 -0
- package/lib/bin/emoji-cli-improved.d.cts +4 -0
- package/lib/bin/emoji-cli-improved.d.ts +4 -0
- package/lib/bin/emoji-cli-improved.js +442 -0
- package/lib/bin/emoji-cli-improved.js.map +1 -0
- package/lib/{index.js → chunk-DT5PQCNR.js} +11 -10
- package/lib/chunk-DT5PQCNR.js.map +1 -0
- package/lib/{index.cjs → src/index.cjs} +10 -10
- package/lib/src/index.cjs.map +1 -0
- package/lib/src/index.js +25 -0
- package/lib/src/index.js.map +1 -0
- package/package.json +6 -4
- package/src/emojify.ts +3 -3
- package/src/search.ts +4 -4
- package/bin/emoji-cli-improved.ts +0 -422
- package/lib/index.cjs.map +0 -1
- package/lib/index.js.map +0 -1
- /package/lib/{index.d.cts → src/index.d.cts} +0 -0
- /package/lib/{index.d.ts → src/index.d.ts} +0 -0
|
@@ -0,0 +1,442 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import {
|
|
3
|
+
emojify,
|
|
4
|
+
find,
|
|
5
|
+
get,
|
|
6
|
+
has,
|
|
7
|
+
random,
|
|
8
|
+
search,
|
|
9
|
+
unemojify
|
|
10
|
+
} from "../chunk-DT5PQCNR.js";
|
|
11
|
+
|
|
12
|
+
// package.json
|
|
13
|
+
var package_default = {
|
|
14
|
+
name: "@involvex/emoji-cli",
|
|
15
|
+
version: "2.2.7",
|
|
16
|
+
description: "Friendly emoji lookups and parsing utilities for Node.js. \u{1F496}",
|
|
17
|
+
keywords: [
|
|
18
|
+
"emoji",
|
|
19
|
+
"simple",
|
|
20
|
+
"emoticons",
|
|
21
|
+
"emoticon",
|
|
22
|
+
"emojis",
|
|
23
|
+
"smiley",
|
|
24
|
+
"smileys",
|
|
25
|
+
"smilies",
|
|
26
|
+
"ideogram",
|
|
27
|
+
"ideograms"
|
|
28
|
+
],
|
|
29
|
+
bugs: {
|
|
30
|
+
url: "https://github.com/omnidan/node-emoji/issues"
|
|
31
|
+
},
|
|
32
|
+
repository: {
|
|
33
|
+
type: "git",
|
|
34
|
+
url: "https://github.com/omnidan/node-emoji"
|
|
35
|
+
},
|
|
36
|
+
license: "MIT",
|
|
37
|
+
author: {
|
|
38
|
+
name: "Involvex"
|
|
39
|
+
},
|
|
40
|
+
type: "module",
|
|
41
|
+
exports: {
|
|
42
|
+
".": {
|
|
43
|
+
types: {
|
|
44
|
+
import: "./lib/index.d.ts",
|
|
45
|
+
require: "./lib/index.d.cts"
|
|
46
|
+
},
|
|
47
|
+
import: "./lib/index.js",
|
|
48
|
+
require: "./lib/index.cjs"
|
|
49
|
+
}
|
|
50
|
+
},
|
|
51
|
+
main: "./lib/index.js",
|
|
52
|
+
bin: {
|
|
53
|
+
"emoji-cli": "lib/bin/emoji-cli-improved.js"
|
|
54
|
+
},
|
|
55
|
+
files: [
|
|
56
|
+
"lib/",
|
|
57
|
+
"package.json",
|
|
58
|
+
"LICENSE.md",
|
|
59
|
+
"README.md",
|
|
60
|
+
"bin/emoji-cli.ts",
|
|
61
|
+
"src/*"
|
|
62
|
+
],
|
|
63
|
+
scripts: {
|
|
64
|
+
prebuild: "npm run format && npm run lint && npm run typecheck",
|
|
65
|
+
build: "tsup",
|
|
66
|
+
"build:cli": "bun build --target=node bin/emoji-cli-improved.ts --outdir=dist",
|
|
67
|
+
dev: "bun run bin/emoji-cli-improved.ts",
|
|
68
|
+
format: "prettier . --write",
|
|
69
|
+
lint: "eslint . --ignore-pattern lib --ignore-pattern dist -c eslint.config.ts",
|
|
70
|
+
"lint:knip": "knip",
|
|
71
|
+
"lint:md": 'markdownlint "**/*.md" ".github/**/*.md" --rules sentences-per-line',
|
|
72
|
+
"lint:package-json": "npmPkgJsonLint .",
|
|
73
|
+
"lint:packages": "pnpm dedupe --check",
|
|
74
|
+
"lint:spelling": 'cspell "**" ".github/**/*"',
|
|
75
|
+
prepare: "husky install",
|
|
76
|
+
"should-semantic-release": "should-semantic-release --verbose",
|
|
77
|
+
start: "node lib/bin/emoji-cli-improved.js",
|
|
78
|
+
test: "vitest",
|
|
79
|
+
"test:cjs": "node ./src/e2e.cjs",
|
|
80
|
+
tsc: "tsc",
|
|
81
|
+
typecheck: "tsc --noEmit"
|
|
82
|
+
},
|
|
83
|
+
"lint-staged": {
|
|
84
|
+
"*": "prettier --ignore-unknown --write"
|
|
85
|
+
},
|
|
86
|
+
dependencies: {
|
|
87
|
+
"@sindresorhus/is": "^4.6.0",
|
|
88
|
+
"char-regex": "^1.0.2",
|
|
89
|
+
emojilib: "^2.4.0",
|
|
90
|
+
jiti: "^2.6.1",
|
|
91
|
+
"skin-tone": "^2.0.0"
|
|
92
|
+
},
|
|
93
|
+
devDependencies: {
|
|
94
|
+
"@eslint/js": "^9.39.2",
|
|
95
|
+
"@eslint/json": "^0.14.0",
|
|
96
|
+
"@release-it/conventional-changelog": "^10.0.0",
|
|
97
|
+
"@swc/core": "^1.3.58",
|
|
98
|
+
"@types/eslint": "^8.44.7",
|
|
99
|
+
"@typescript-eslint/eslint-plugin": "^8.0.0",
|
|
100
|
+
"@typescript-eslint/parser": "^8.0.0",
|
|
101
|
+
"@vitest/coverage-v8": "^0.34.6",
|
|
102
|
+
"console-fail-test": "^0.5.0",
|
|
103
|
+
cspell: "^8.0.0",
|
|
104
|
+
eslint: "^9.39.2",
|
|
105
|
+
"eslint-plugin-deprecation": "^3.0.0",
|
|
106
|
+
"eslint-plugin-eslint-comments": "^3.2.0",
|
|
107
|
+
"eslint-plugin-jsdoc": "^50.0.0",
|
|
108
|
+
"eslint-plugin-jsonc": "^2.10.0",
|
|
109
|
+
"eslint-plugin-markdown": "^3.0.1",
|
|
110
|
+
"eslint-plugin-n": "^17.0.0",
|
|
111
|
+
"eslint-plugin-no-only-tests": "^3.1.0",
|
|
112
|
+
"eslint-plugin-perfectionist": "^2.3.0",
|
|
113
|
+
"eslint-plugin-regexp": "^2.1.1",
|
|
114
|
+
"eslint-plugin-vitest": "^0.3.9",
|
|
115
|
+
"eslint-plugin-yml": "^1.10.0",
|
|
116
|
+
globals: "^16.5.0",
|
|
117
|
+
husky: "^8.0.3",
|
|
118
|
+
"jsonc-eslint-parser": "^2.4.0",
|
|
119
|
+
knip: "^4.0.0",
|
|
120
|
+
"lint-staged": "^15.1.0",
|
|
121
|
+
markdownlint: "^0.37.0",
|
|
122
|
+
"markdownlint-cli": "^0.44.0",
|
|
123
|
+
"npm-package-json-lint": "^8.0.0",
|
|
124
|
+
"npm-package-json-lint-config-default": "^7.0.0",
|
|
125
|
+
prettier: "^3.0.3",
|
|
126
|
+
"prettier-plugin-curly": "^0.3.0",
|
|
127
|
+
"prettier-plugin-packagejson": "^2.4.6",
|
|
128
|
+
"release-it": "^18.0.0",
|
|
129
|
+
"sentences-per-line": "^0.3.0",
|
|
130
|
+
"should-semantic-release": "^0.2.1",
|
|
131
|
+
tsup: "^8.0.0",
|
|
132
|
+
typescript: "^5.2.2",
|
|
133
|
+
"typescript-eslint": "^8.50.1",
|
|
134
|
+
vitest: "^0.34.6",
|
|
135
|
+
"yaml-eslint-parser": "^1.2.2"
|
|
136
|
+
},
|
|
137
|
+
engines: {
|
|
138
|
+
node: ">=18"
|
|
139
|
+
}
|
|
140
|
+
};
|
|
141
|
+
|
|
142
|
+
// bin/emoji-cli-improved.ts
|
|
143
|
+
var CONFIG = {
|
|
144
|
+
name: "emoji-cli",
|
|
145
|
+
description: "Friendly emoji lookups and parsing utilities for Node.js",
|
|
146
|
+
version: package_default.version
|
|
147
|
+
// TODO: Get version from package.json dynamically
|
|
148
|
+
};
|
|
149
|
+
var COMMANDS = [
|
|
150
|
+
{
|
|
151
|
+
name: "search",
|
|
152
|
+
aliases: ["--search"],
|
|
153
|
+
description: "Search for emojis by name or pattern",
|
|
154
|
+
handler: runSearch,
|
|
155
|
+
requiresArgs: true
|
|
156
|
+
},
|
|
157
|
+
{
|
|
158
|
+
name: "emojify",
|
|
159
|
+
aliases: ["--emojify"],
|
|
160
|
+
description: "Convert text to emojis",
|
|
161
|
+
handler: runEmojify,
|
|
162
|
+
requiresArgs: true
|
|
163
|
+
},
|
|
164
|
+
{
|
|
165
|
+
name: "unemojify",
|
|
166
|
+
aliases: ["--unemojify"],
|
|
167
|
+
description: "Convert emojis back to text",
|
|
168
|
+
handler: runUnemojify,
|
|
169
|
+
requiresArgs: true
|
|
170
|
+
},
|
|
171
|
+
{
|
|
172
|
+
name: "get",
|
|
173
|
+
aliases: ["--get"],
|
|
174
|
+
description: "Get a specific emoji by name",
|
|
175
|
+
handler: runGet,
|
|
176
|
+
requiresArgs: true
|
|
177
|
+
},
|
|
178
|
+
{
|
|
179
|
+
name: "has",
|
|
180
|
+
aliases: ["--has"],
|
|
181
|
+
description: "Check if an emoji exists",
|
|
182
|
+
handler: runHas,
|
|
183
|
+
requiresArgs: true
|
|
184
|
+
},
|
|
185
|
+
{
|
|
186
|
+
name: "find",
|
|
187
|
+
aliases: ["--find", "-f"],
|
|
188
|
+
description: "Find emojis by name",
|
|
189
|
+
handler: runFind,
|
|
190
|
+
requiresArgs: true
|
|
191
|
+
},
|
|
192
|
+
{
|
|
193
|
+
name: "random",
|
|
194
|
+
aliases: ["--random", "--rnd", "-r"],
|
|
195
|
+
description: "Get a random emoji",
|
|
196
|
+
handler: runRandom,
|
|
197
|
+
requiresArgs: false
|
|
198
|
+
}
|
|
199
|
+
];
|
|
200
|
+
var CLIError = class extends Error {
|
|
201
|
+
code;
|
|
202
|
+
constructor(message, code) {
|
|
203
|
+
super(message);
|
|
204
|
+
this.code = code;
|
|
205
|
+
this.name = "CLIError";
|
|
206
|
+
}
|
|
207
|
+
};
|
|
208
|
+
var ValidationError = class extends CLIError {
|
|
209
|
+
constructor(message) {
|
|
210
|
+
super(message, 2);
|
|
211
|
+
this.name = "ValidationError";
|
|
212
|
+
}
|
|
213
|
+
};
|
|
214
|
+
function createOutputFormatter() {
|
|
215
|
+
return {
|
|
216
|
+
success: (data) => {
|
|
217
|
+
if (Array.isArray(data)) {
|
|
218
|
+
if (data.length === 0) {
|
|
219
|
+
console.log("No results found");
|
|
220
|
+
return;
|
|
221
|
+
}
|
|
222
|
+
data.forEach((item, index) => {
|
|
223
|
+
if (typeof item === "string") {
|
|
224
|
+
console.log(`${item}`);
|
|
225
|
+
} else if (item && typeof item === "object") {
|
|
226
|
+
const displayName = item.name || item.key || "unknown";
|
|
227
|
+
console.log(`${index + 1}. ${item.emoji} ${displayName}`);
|
|
228
|
+
} else {
|
|
229
|
+
console.log(`${index + 1}. ${item}`);
|
|
230
|
+
}
|
|
231
|
+
});
|
|
232
|
+
} else if (data && typeof data === "object") {
|
|
233
|
+
const displayName = data.name || data.key || "unknown";
|
|
234
|
+
console.log(`${data.emoji} ${displayName}`);
|
|
235
|
+
} else if (data !== void 0 && data !== null) {
|
|
236
|
+
console.log(data);
|
|
237
|
+
} else {
|
|
238
|
+
console.log("No result found");
|
|
239
|
+
}
|
|
240
|
+
},
|
|
241
|
+
error: (message) => {
|
|
242
|
+
console.error(`\u274C Error: ${message}`);
|
|
243
|
+
},
|
|
244
|
+
warning: (message) => {
|
|
245
|
+
console.warn(`\u26A0\uFE0F Warning: ${message}`);
|
|
246
|
+
},
|
|
247
|
+
info: (message) => {
|
|
248
|
+
console.log(`\u2139\uFE0F ${message}`);
|
|
249
|
+
}
|
|
250
|
+
};
|
|
251
|
+
}
|
|
252
|
+
var output = createOutputFormatter();
|
|
253
|
+
function parseArgs(args) {
|
|
254
|
+
if (args.length === 0) {
|
|
255
|
+
return { command: "", args: [], help: true };
|
|
256
|
+
}
|
|
257
|
+
const [first, ...rest] = args;
|
|
258
|
+
if (first === "--help" || first === "-h") {
|
|
259
|
+
return { command: "", args: [], help: true };
|
|
260
|
+
}
|
|
261
|
+
return {
|
|
262
|
+
command: first,
|
|
263
|
+
args: rest,
|
|
264
|
+
help: false
|
|
265
|
+
};
|
|
266
|
+
}
|
|
267
|
+
function resolveCommand(input) {
|
|
268
|
+
if (!input) {
|
|
269
|
+
return null;
|
|
270
|
+
}
|
|
271
|
+
return COMMANDS.find((cmd) => cmd.name === input || cmd.aliases.includes(input)) || null;
|
|
272
|
+
}
|
|
273
|
+
function validateArgs(command, args) {
|
|
274
|
+
if (command.requiresArgs && args.length === 0) {
|
|
275
|
+
throw new ValidationError(`Command "${command.name}" requires arguments`);
|
|
276
|
+
}
|
|
277
|
+
if (!command.requiresArgs && args.length > 0) {
|
|
278
|
+
throw new ValidationError(
|
|
279
|
+
`Command "${command.name}" does not accept arguments`
|
|
280
|
+
);
|
|
281
|
+
}
|
|
282
|
+
}
|
|
283
|
+
async function runSearch(query) {
|
|
284
|
+
if (!query) {
|
|
285
|
+
throw new ValidationError("Search query is required");
|
|
286
|
+
}
|
|
287
|
+
try {
|
|
288
|
+
const results = search(query);
|
|
289
|
+
output.success(results);
|
|
290
|
+
} catch (error) {
|
|
291
|
+
output.error(
|
|
292
|
+
`Failed to search for "${query}": ${error instanceof Error ? error.message : "Unknown error"}`
|
|
293
|
+
);
|
|
294
|
+
}
|
|
295
|
+
}
|
|
296
|
+
async function runEmojify(text) {
|
|
297
|
+
if (!text) {
|
|
298
|
+
throw new ValidationError("Text to emojify is required");
|
|
299
|
+
}
|
|
300
|
+
try {
|
|
301
|
+
const result = emojify(text);
|
|
302
|
+
output.success(result);
|
|
303
|
+
} catch (error) {
|
|
304
|
+
output.error(
|
|
305
|
+
`Failed to emojify text: ${error instanceof Error ? error.message : "Unknown error"}`
|
|
306
|
+
);
|
|
307
|
+
}
|
|
308
|
+
}
|
|
309
|
+
async function runUnemojify(text) {
|
|
310
|
+
if (!text) {
|
|
311
|
+
throw new ValidationError("Text to unemojify is required");
|
|
312
|
+
}
|
|
313
|
+
try {
|
|
314
|
+
const result = unemojify(text);
|
|
315
|
+
output.success(result);
|
|
316
|
+
} catch (error) {
|
|
317
|
+
output.error(
|
|
318
|
+
`Failed to unemojify text: ${error instanceof Error ? error.message : "Unknown error"}`
|
|
319
|
+
);
|
|
320
|
+
}
|
|
321
|
+
}
|
|
322
|
+
async function runGet(name) {
|
|
323
|
+
if (!name) {
|
|
324
|
+
throw new ValidationError("Emoji name is required");
|
|
325
|
+
}
|
|
326
|
+
try {
|
|
327
|
+
const result = get(name);
|
|
328
|
+
if (result) {
|
|
329
|
+
output.success(result);
|
|
330
|
+
} else {
|
|
331
|
+
output.warning(`Emoji "${name}" not found`);
|
|
332
|
+
}
|
|
333
|
+
} catch (error) {
|
|
334
|
+
output.error(
|
|
335
|
+
`Failed to get emoji "${name}": ${error instanceof Error ? error.message : "Unknown error"}`
|
|
336
|
+
);
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
async function runHas(name) {
|
|
340
|
+
if (!name) {
|
|
341
|
+
throw new ValidationError("Emoji name is required");
|
|
342
|
+
}
|
|
343
|
+
try {
|
|
344
|
+
const result = has(name);
|
|
345
|
+
output.success(
|
|
346
|
+
result ? `\u2705 Emoji "${name}" exists` : `\u274C Emoji "${name}" not found`
|
|
347
|
+
);
|
|
348
|
+
} catch (error) {
|
|
349
|
+
output.error(
|
|
350
|
+
`Failed to check emoji "${name}": ${error instanceof Error ? error.message : "Unknown error"}`
|
|
351
|
+
);
|
|
352
|
+
}
|
|
353
|
+
}
|
|
354
|
+
async function runFind(name) {
|
|
355
|
+
if (!name) {
|
|
356
|
+
throw new ValidationError("Search term is required");
|
|
357
|
+
}
|
|
358
|
+
try {
|
|
359
|
+
const result = find(name);
|
|
360
|
+
if (result) {
|
|
361
|
+
output.success(result);
|
|
362
|
+
} else {
|
|
363
|
+
output.warning(`No emojis found for "${name}"`);
|
|
364
|
+
}
|
|
365
|
+
} catch (error) {
|
|
366
|
+
output.error(
|
|
367
|
+
`Failed to find emojis for "${name}": ${error instanceof Error ? error.message : "Unknown error"}`
|
|
368
|
+
);
|
|
369
|
+
}
|
|
370
|
+
}
|
|
371
|
+
async function runRandom() {
|
|
372
|
+
try {
|
|
373
|
+
const result = random();
|
|
374
|
+
output.success(result);
|
|
375
|
+
} catch (error) {
|
|
376
|
+
output.error(
|
|
377
|
+
`Failed to get random emoji: ${error instanceof Error ? error.message : "Unknown error"}`
|
|
378
|
+
);
|
|
379
|
+
}
|
|
380
|
+
}
|
|
381
|
+
function showHelp() {
|
|
382
|
+
console.log(`${CONFIG.name} v${CONFIG.version}`);
|
|
383
|
+
console.log(`${CONFIG.description} \u{1F496}`);
|
|
384
|
+
console.log("\nUsage:");
|
|
385
|
+
console.log(` ${CONFIG.name} <command> [arguments]`);
|
|
386
|
+
console.log("\nCommands:");
|
|
387
|
+
COMMANDS.forEach((cmd) => {
|
|
388
|
+
const aliasesText = cmd.aliases.length > 1 ? ` (${cmd.aliases.join(", ")})` : "";
|
|
389
|
+
console.log(` ${cmd.name}${aliasesText} ${cmd.description}`);
|
|
390
|
+
});
|
|
391
|
+
console.log("\nExamples:");
|
|
392
|
+
console.log(` ${CONFIG.name} --search "heart"`);
|
|
393
|
+
console.log(` ${CONFIG.name} --get "heart"`);
|
|
394
|
+
console.log(` ${CONFIG.name} --emojify "I love you"`);
|
|
395
|
+
console.log(` ${CONFIG.name} --random`);
|
|
396
|
+
}
|
|
397
|
+
function showVersion() {
|
|
398
|
+
console.log(`${CONFIG.name} v${CONFIG.version}`);
|
|
399
|
+
}
|
|
400
|
+
async function run() {
|
|
401
|
+
try {
|
|
402
|
+
const args = process.argv.slice(2);
|
|
403
|
+
const { command: commandInput, args: commandArgs, help } = parseArgs(args);
|
|
404
|
+
if (help || !commandInput) {
|
|
405
|
+
showHelp();
|
|
406
|
+
return;
|
|
407
|
+
}
|
|
408
|
+
if (commandInput === "--version" || commandInput === "-v") {
|
|
409
|
+
showVersion();
|
|
410
|
+
return;
|
|
411
|
+
}
|
|
412
|
+
const command = resolveCommand(commandInput);
|
|
413
|
+
if (!command) {
|
|
414
|
+
throw new CLIError(
|
|
415
|
+
`Unknown command: ${commandInput}. Use --help for available commands.`,
|
|
416
|
+
1
|
|
417
|
+
);
|
|
418
|
+
}
|
|
419
|
+
validateArgs(command, commandArgs);
|
|
420
|
+
await command.handler(commandArgs[0]);
|
|
421
|
+
} catch (error) {
|
|
422
|
+
if (error instanceof CLIError) {
|
|
423
|
+
output.error(error.message);
|
|
424
|
+
process.exit(error.code);
|
|
425
|
+
} else if (error instanceof ValidationError) {
|
|
426
|
+
output.error(error.message);
|
|
427
|
+
output.info("Use --help for usage information");
|
|
428
|
+
process.exit(error.code);
|
|
429
|
+
} else {
|
|
430
|
+
output.error(
|
|
431
|
+
`Unexpected error: ${error instanceof Error ? error.message : "Unknown error"}`
|
|
432
|
+
);
|
|
433
|
+
process.exit(1);
|
|
434
|
+
}
|
|
435
|
+
}
|
|
436
|
+
}
|
|
437
|
+
run();
|
|
438
|
+
var emoji_cli_improved_default = run;
|
|
439
|
+
export {
|
|
440
|
+
emoji_cli_improved_default as default
|
|
441
|
+
};
|
|
442
|
+
//# sourceMappingURL=emoji-cli-improved.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../package.json","../../bin/emoji-cli-improved.ts"],"sourcesContent":["{\n \"name\": \"@involvex/emoji-cli\",\n \"version\": \"2.2.7\",\n \"description\": \"Friendly emoji lookups and parsing utilities for Node.js. 💖\",\n \"keywords\": [\n \"emoji\",\n \"simple\",\n \"emoticons\",\n \"emoticon\",\n \"emojis\",\n \"smiley\",\n \"smileys\",\n \"smilies\",\n \"ideogram\",\n \"ideograms\"\n ],\n \"bugs\": {\n \"url\": \"https://github.com/omnidan/node-emoji/issues\"\n },\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/omnidan/node-emoji\"\n },\n \"license\": \"MIT\",\n \"author\": {\n \"name\": \"Involvex\"\n },\n \"type\": \"module\",\n \"exports\": {\n \".\": {\n \"types\": {\n \"import\": \"./lib/index.d.ts\",\n \"require\": \"./lib/index.d.cts\"\n },\n \"import\": \"./lib/index.js\",\n \"require\": \"./lib/index.cjs\"\n }\n },\n \"main\": \"./lib/index.js\",\n \"bin\": {\n \"emoji-cli\": \"lib/bin/emoji-cli-improved.js\"\n },\n \"files\": [\n \"lib/\",\n \"package.json\",\n \"LICENSE.md\",\n \"README.md\",\n \"bin/emoji-cli.ts\",\n \"src/*\"\n ],\n \"scripts\": {\n \"prebuild\": \"npm run format && npm run lint && npm run typecheck\",\n \"build\": \"tsup\",\n \"build:cli\": \"bun build --target=node bin/emoji-cli-improved.ts --outdir=dist\",\n \"dev\": \"bun run bin/emoji-cli-improved.ts\",\n \"format\": \"prettier . --write\",\n \"lint\": \"eslint . --ignore-pattern lib --ignore-pattern dist -c eslint.config.ts\",\n \"lint:knip\": \"knip\",\n \"lint:md\": \"markdownlint \\\"**/*.md\\\" \\\".github/**/*.md\\\" --rules sentences-per-line\",\n \"lint:package-json\": \"npmPkgJsonLint .\",\n \"lint:packages\": \"pnpm dedupe --check\",\n \"lint:spelling\": \"cspell \\\"**\\\" \\\".github/**/*\\\"\",\n \"prepare\": \"husky install\",\n \"should-semantic-release\": \"should-semantic-release --verbose\",\n \"start\": \"node lib/bin/emoji-cli-improved.js\",\n \"test\": \"vitest\",\n \"test:cjs\": \"node ./src/e2e.cjs\",\n \"tsc\": \"tsc\",\n \"typecheck\": \"tsc --noEmit\"\n },\n \"lint-staged\": {\n \"*\": \"prettier --ignore-unknown --write\"\n },\n \"dependencies\": {\n \"@sindresorhus/is\": \"^4.6.0\",\n \"char-regex\": \"^1.0.2\",\n \"emojilib\": \"^2.4.0\",\n \"jiti\": \"^2.6.1\",\n \"skin-tone\": \"^2.0.0\"\n },\n \"devDependencies\": {\n \"@eslint/js\": \"^9.39.2\",\n \"@eslint/json\": \"^0.14.0\",\n \"@release-it/conventional-changelog\": \"^10.0.0\",\n \"@swc/core\": \"^1.3.58\",\n \"@types/eslint\": \"^8.44.7\",\n \"@typescript-eslint/eslint-plugin\": \"^8.0.0\",\n \"@typescript-eslint/parser\": \"^8.0.0\",\n \"@vitest/coverage-v8\": \"^0.34.6\",\n \"console-fail-test\": \"^0.5.0\",\n \"cspell\": \"^8.0.0\",\n \"eslint\": \"^9.39.2\",\n \"eslint-plugin-deprecation\": \"^3.0.0\",\n \"eslint-plugin-eslint-comments\": \"^3.2.0\",\n \"eslint-plugin-jsdoc\": \"^50.0.0\",\n \"eslint-plugin-jsonc\": \"^2.10.0\",\n \"eslint-plugin-markdown\": \"^3.0.1\",\n \"eslint-plugin-n\": \"^17.0.0\",\n \"eslint-plugin-no-only-tests\": \"^3.1.0\",\n \"eslint-plugin-perfectionist\": \"^2.3.0\",\n \"eslint-plugin-regexp\": \"^2.1.1\",\n \"eslint-plugin-vitest\": \"^0.3.9\",\n \"eslint-plugin-yml\": \"^1.10.0\",\n \"globals\": \"^16.5.0\",\n \"husky\": \"^8.0.3\",\n \"jsonc-eslint-parser\": \"^2.4.0\",\n \"knip\": \"^4.0.0\",\n \"lint-staged\": \"^15.1.0\",\n \"markdownlint\": \"^0.37.0\",\n \"markdownlint-cli\": \"^0.44.0\",\n \"npm-package-json-lint\": \"^8.0.0\",\n \"npm-package-json-lint-config-default\": \"^7.0.0\",\n \"prettier\": \"^3.0.3\",\n \"prettier-plugin-curly\": \"^0.3.0\",\n \"prettier-plugin-packagejson\": \"^2.4.6\",\n \"release-it\": \"^18.0.0\",\n \"sentences-per-line\": \"^0.3.0\",\n \"should-semantic-release\": \"^0.2.1\",\n \"tsup\": \"^8.0.0\",\n \"typescript\": \"^5.2.2\",\n \"typescript-eslint\": \"^8.50.1\",\n \"vitest\": \"^0.34.6\",\n \"yaml-eslint-parser\": \"^1.2.2\"\n },\n \"engines\": {\n \"node\": \">=18\"\n }\n}\n","#!/usr/bin/env node\n\nimport * as cli from '../src/index'\nimport pkg from '../package.json'\n// Type definitions for better type safety\ninterface CLIConfig {\n name: string\n description: string\n version: string\n}\n\ninterface Command {\n name: string\n aliases: string[]\n description: string\n handler: (args?: string) => void | Promise<void>\n requiresArgs: boolean\n}\n\ninterface ParsedArgs {\n command: string\n args: string[]\n help: boolean\n}\n\n// Configuration\nconst CONFIG: CLIConfig = {\n name: 'emoji-cli',\n description: 'Friendly emoji lookups and parsing utilities for Node.js',\n version: pkg.version as string, // TODO: Get version from package.json dynamically\n}\n\n// Available commands\nconst COMMANDS: Command[] = [\n {\n name: 'search',\n aliases: ['--search'],\n description: 'Search for emojis by name or pattern',\n handler: runSearch,\n requiresArgs: true,\n },\n {\n name: 'emojify',\n aliases: ['--emojify'],\n description: 'Convert text to emojis',\n handler: runEmojify,\n requiresArgs: true,\n },\n {\n name: 'unemojify',\n aliases: ['--unemojify'],\n description: 'Convert emojis back to text',\n handler: runUnemojify,\n requiresArgs: true,\n },\n {\n name: 'get',\n aliases: ['--get'],\n description: 'Get a specific emoji by name',\n handler: runGet,\n requiresArgs: true,\n },\n {\n name: 'has',\n aliases: ['--has'],\n description: 'Check if an emoji exists',\n handler: runHas,\n requiresArgs: true,\n },\n {\n name: 'find',\n aliases: ['--find', '-f'],\n description: 'Find emojis by name',\n handler: runFind,\n requiresArgs: true,\n },\n {\n name: 'random',\n aliases: ['--random', '--rnd', '-r'],\n description: 'Get a random emoji',\n handler: runRandom,\n requiresArgs: false,\n },\n]\n\n// Error handling\nclass CLIError extends Error {\n code: number\n\n constructor(message: string, code: number) {\n super(message)\n this.code = code\n this.name = 'CLIError'\n }\n}\n\nclass ValidationError extends CLIError {\n constructor(message: string) {\n super(message, 2)\n this.name = 'ValidationError'\n }\n}\n\n// Utility functions\nfunction createOutputFormatter() {\n return {\n success: (\n data:\n | never\n | string\n | {\n emoji: string\n name?: string\n key?: string\n }\n | (\n | string\n | {\n emoji: string\n name?: string\n key?: string\n }\n )[],\n ) => {\n if (Array.isArray(data)) {\n if (data.length === 0) {\n console.log('No results found')\n return\n }\n\n data.forEach((item, index) => {\n if (typeof item === 'string') {\n console.log(`${item}`)\n } else if (item && typeof item === 'object') {\n const displayName = item.name || item.key || 'unknown'\n console.log(`${index + 1}. ${item.emoji} ${displayName}`)\n } else {\n console.log(`${index + 1}. ${item}`)\n }\n })\n } else if (data && typeof data === 'object') {\n const displayName = data.name || data.key || 'unknown'\n console.log(`${data.emoji} ${displayName}`)\n } else if (data !== undefined && data !== null) {\n console.log(data)\n } else {\n console.log('No result found')\n }\n },\n error: (message: string) => {\n console.error(`❌ Error: ${message}`)\n },\n warning: (message: string) => {\n console.warn(`⚠️ Warning: ${message}`)\n },\n info: (message: string) => {\n console.log(`ℹ️ ${message}`)\n },\n }\n}\n\nconst output = createOutputFormatter()\n\n// Argument parsing\nfunction parseArgs(args: string[]): ParsedArgs {\n if (args.length === 0) {\n return { command: '', args: [], help: true }\n }\n\n const [first, ...rest] = args\n\n // Check for help flags\n if (first === '--help' || first === '-h') {\n return { command: '', args: [], help: true }\n }\n\n return {\n command: first,\n args: rest,\n help: false,\n }\n}\n\n// Command resolution\nfunction resolveCommand(input: string): Command | null {\n if (!input) {\n return null\n }\n\n return (\n COMMANDS.find(cmd => cmd.name === input || cmd.aliases.includes(input)) ||\n null\n )\n}\n\n// Validation\nfunction validateArgs(command: Command, args: string[]): void {\n if (command.requiresArgs && args.length === 0) {\n throw new ValidationError(`Command \"${command.name}\" requires arguments`)\n }\n\n if (!command.requiresArgs && args.length > 0) {\n throw new ValidationError(\n `Command \"${command.name}\" does not accept arguments`,\n )\n }\n}\n\n// Command handlers\nasync function runSearch(query?: string): Promise<void> {\n if (!query) {\n throw new ValidationError('Search query is required')\n }\n\n try {\n const results = cli.search(query)\n output.success(results)\n } catch (error) {\n output.error(\n `Failed to search for \"${query}\": ${\n error instanceof Error ? error.message : 'Unknown error'\n }`,\n )\n }\n}\n\nasync function runEmojify(text?: string): Promise<void> {\n if (!text) {\n throw new ValidationError('Text to emojify is required')\n }\n\n try {\n const result = cli.emojify(text)\n output.success(result)\n } catch (error) {\n output.error(\n `Failed to emojify text: ${\n error instanceof Error ? error.message : 'Unknown error'\n }`,\n )\n }\n}\n\nasync function runUnemojify(text?: string): Promise<void> {\n if (!text) {\n throw new ValidationError('Text to unemojify is required')\n }\n\n try {\n const result = cli.unemojify(text)\n output.success(result)\n } catch (error) {\n output.error(\n `Failed to unemojify text: ${\n error instanceof Error ? error.message : 'Unknown error'\n }`,\n )\n }\n}\n\nasync function runGet(name?: string): Promise<void> {\n if (!name) {\n throw new ValidationError('Emoji name is required')\n }\n\n try {\n const result = cli.get(name)\n if (result) {\n output.success(result)\n } else {\n output.warning(`Emoji \"${name}\" not found`)\n }\n } catch (error) {\n output.error(\n `Failed to get emoji \"${name}\": ${\n error instanceof Error ? error.message : 'Unknown error'\n }`,\n )\n }\n}\n\nasync function runHas(name?: string): Promise<void> {\n if (!name) {\n throw new ValidationError('Emoji name is required')\n }\n\n try {\n const result = cli.has(name)\n output.success(\n result ? `✅ Emoji \"${name}\" exists` : `❌ Emoji \"${name}\" not found`,\n )\n } catch (error) {\n output.error(\n `Failed to check emoji \"${name}\": ${\n error instanceof Error ? error.message : 'Unknown error'\n }`,\n )\n }\n}\n\nasync function runFind(name?: string): Promise<void> {\n if (!name) {\n throw new ValidationError('Search term is required')\n }\n\n try {\n const result = cli.find(name)\n if (result) {\n output.success(result)\n } else {\n output.warning(`No emojis found for \"${name}\"`)\n }\n } catch (error) {\n output.error(\n `Failed to find emojis for \"${name}\": ${\n error instanceof Error ? error.message : 'Unknown error'\n }`,\n )\n }\n}\n\nasync function runRandom(): Promise<void> {\n try {\n const result = cli.random()\n output.success(result)\n } catch (error) {\n output.error(\n `Failed to get random emoji: ${\n error instanceof Error ? error.message : 'Unknown error'\n }`,\n )\n }\n}\n\n// Help and usage information\nfunction showHelp(): void {\n console.log(`${CONFIG.name} v${CONFIG.version}`)\n console.log(`${CONFIG.description} 💖`)\n console.log('\\nUsage:')\n console.log(` ${CONFIG.name} <command> [arguments]`)\n console.log('\\nCommands:')\n\n COMMANDS.forEach(cmd => {\n const aliasesText =\n cmd.aliases.length > 1 ? ` (${cmd.aliases.join(', ')})` : ''\n console.log(` ${cmd.name}${aliasesText} ${cmd.description}`)\n })\n\n console.log('\\nExamples:')\n console.log(` ${CONFIG.name} --search \"heart\"`)\n console.log(` ${CONFIG.name} --get \"heart\"`)\n console.log(` ${CONFIG.name} --emojify \"I love you\"`)\n console.log(` ${CONFIG.name} --random`)\n}\n\nfunction showVersion(): void {\n console.log(`${CONFIG.name} v${CONFIG.version}`)\n}\n\n// Main execution\nasync function run(): Promise<void> {\n try {\n const args = process.argv.slice(2)\n const { command: commandInput, args: commandArgs, help } = parseArgs(args)\n\n // Handle global flags\n if (help || !commandInput) {\n showHelp()\n return\n }\n\n if (commandInput === '--version' || commandInput === '-v') {\n showVersion()\n return\n }\n\n // Resolve and execute command\n const command = resolveCommand(commandInput)\n if (!command) {\n throw new CLIError(\n `Unknown command: ${commandInput}. Use --help for available commands.`,\n 1,\n )\n }\n\n // Validate arguments\n validateArgs(command, commandArgs)\n\n // Execute command\n await command.handler(commandArgs[0])\n } catch (error) {\n if (error instanceof CLIError) {\n output.error(error.message)\n process.exit(error.code)\n } else if (error instanceof ValidationError) {\n output.error(error.message)\n output.info('Use --help for usage information')\n process.exit(error.code)\n } else {\n output.error(\n `Unexpected error: ${\n error instanceof Error ? error.message : 'Unknown error'\n }`,\n )\n process.exit(1)\n }\n }\n}\n\n// Execute if this file is run directly\n// if (import.meta.url === `file://${process.argv[1]}`) {\n// run().catch(error => {\n// output.error(\n// `Failed to run CLI: ${\n// error instanceof Error ? error.message : 'Unknown error'\n// }`,\n// )\n// process.exit(1)\n// })\n// }\nrun()\nexport default run\n"],"mappings":"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","names":[]}
|
|
@@ -45,9 +45,9 @@ var findByName = (name) => {
|
|
|
45
45
|
// src/emojify.ts
|
|
46
46
|
var emojify = (input, { fallback, format = (name) => name } = {}) => {
|
|
47
47
|
const fallbackFunction = fallback === void 0 ? fallback : asFunction(fallback);
|
|
48
|
-
is.
|
|
49
|
-
is.
|
|
50
|
-
is.
|
|
48
|
+
is.string(input);
|
|
49
|
+
is.any([is.undefined, is.function_], fallbackFunction);
|
|
50
|
+
is.function_(format);
|
|
51
51
|
return input.replace(/:[\w\-+]+:/g, (part) => {
|
|
52
52
|
const found = findByName(part);
|
|
53
53
|
if (found) {
|
|
@@ -120,12 +120,12 @@ var replace = (input, replacement, { preserveSpaces = false } = {}) => {
|
|
|
120
120
|
// src/search.ts
|
|
121
121
|
import is2, { assert as assert6 } from "@sindresorhus/is";
|
|
122
122
|
var search = (keyword) => {
|
|
123
|
-
assert6.any([is2.
|
|
124
|
-
if (is2.
|
|
123
|
+
assert6.any([is2.string, is2.regExp], keyword);
|
|
124
|
+
if (is2.string(keyword)) {
|
|
125
125
|
keyword = normalizeName(keyword);
|
|
126
126
|
}
|
|
127
|
-
if (is2.
|
|
128
|
-
const normalizedPattern = normalizeName(keyword.
|
|
127
|
+
if (is2.regExp(keyword)) {
|
|
128
|
+
const normalizedPattern = normalizeName(keyword.toString());
|
|
129
129
|
keyword = new RegExp(normalizedPattern);
|
|
130
130
|
}
|
|
131
131
|
return emojiData.filter(([name]) => name.match(keyword)).map(([name, emoji]) => ({ emoji, name }));
|
|
@@ -159,6 +159,7 @@ var unemojify = (input) => {
|
|
|
159
159
|
}
|
|
160
160
|
return characters.map((character) => which(character, { markdown: true }) ?? character).join("");
|
|
161
161
|
};
|
|
162
|
+
|
|
162
163
|
export {
|
|
163
164
|
emojify,
|
|
164
165
|
find,
|
|
@@ -168,7 +169,7 @@ export {
|
|
|
168
169
|
replace,
|
|
169
170
|
search,
|
|
170
171
|
strip,
|
|
171
|
-
|
|
172
|
-
|
|
172
|
+
which,
|
|
173
|
+
unemojify
|
|
173
174
|
};
|
|
174
|
-
//# sourceMappingURL=
|
|
175
|
+
//# sourceMappingURL=chunk-DT5PQCNR.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/emojify.ts","../src/findByName.ts","../src/data.ts","../src/utils.ts","../src/findByCode.ts","../src/find.ts","../src/get.ts","../src/has.ts","../src/random.ts","../src/replace.ts","../src/search.ts","../src/strip.ts","../src/unemojify.ts","../src/which.ts"],"sourcesContent":["import is from '@sindresorhus/is'\n\nimport { findByName } from './findByName.js'\nimport { asFunction, normalizeName } from './utils.js'\n\nexport type EmojifyFormat = (\n name: string,\n part?: string,\n input?: string,\n) => string\n\nexport interface EmojifyOptions {\n /**\n * The string to fallback to if an emoji was not found.\n */\n fallback?: ((part: string) => string) | string\n\n /**\n * Adds a middleware layer to modify each matched emoji after parsing.\n */\n format?: EmojifyFormat\n}\n\n/**\n * Parse all markdown-encoded emojis in a string.\n */\nexport const emojify = (\n input: string,\n { fallback, format = name => name }: EmojifyOptions = {},\n) => {\n const fallbackFunction =\n fallback === undefined ? fallback : asFunction(fallback)\n\n is.string(input)\n is.any([is.undefined, is.function_], fallbackFunction)\n is.function_(format)\n\n return input.replace(/:[\\w\\-+]+:/g, part => {\n const found = findByName(part)\n if (found) {\n return format(found.emoji, part, input)\n }\n\n if (fallbackFunction) {\n return format(fallbackFunction(normalizeName(part)))\n }\n\n return format(part)\n })\n}\n","import { assert } from '@sindresorhus/is'\n\nimport { emojiCodesByName } from './data.js'\nimport { normalizeName } from './utils.js'\n\nexport const findByName = (name: string) => {\n assert.string(name)\n\n const nameNormalized = normalizeName(name)\n const emoji = emojiCodesByName.get(nameNormalized)\n\n return emoji ? { emoji, key: nameNormalized } : undefined\n}\n","import emojilib from 'emojilib'\n\nimport { normalizeCode } from './utils.js'\n\nexport interface Emoji {\n emoji: string\n key: string\n}\n\nexport const emojiData = Object.entries(emojilib.lib).map(\n ([name, { char: emoji }]) => [name, emoji] as const,\n)\n\nexport const emojiCodesByName = new Map(emojiData)\n\nexport const emojiNamesByCode = new Map(\n emojiData.map(([name, emoji]) => [normalizeCode(emoji), name]),\n)\n","import charRegex from 'char-regex'\n\nexport const charRegexMatcher = charRegex()\n\nexport function asFunction<T extends PropertyKey, Args extends unknown[]>(\n input: ((...args: Args) => T) | T,\n): (...args: Args) => T {\n return typeof input === 'function' ? input : () => input\n}\n\n/**\n * Non spacing mark contained by some emoticons (65039 - '️' - 0xFE0F).\n *\n * It's the 'Variant Form', which provides more information so that emoticons\n * can be rendered as more colorful graphics. FE0E is a unicode text version\n * whereas FE0F should be rendered as a graphical version.\n * The code gracefully degrades.\n */\nconst NON_SPACING_MARK = String.fromCharCode(65039)\n\nconst nonSpacingRegex = new RegExp(NON_SPACING_MARK, 'g')\n\n/**\n * Removes the non-spacing-mark from the emoji code.\n *\n * Never send a stripped version to clients, as it kills graphical emoticons.\n */\nexport function normalizeCode(code: string) {\n return code.replace(nonSpacingRegex, '')\n}\n\nexport function normalizeName(name: string) {\n return /:.+:/.test(name) ? name.slice(1, -1) : name\n}\n\nexport function randomItem<T>(array: T[]) {\n return array[Math.floor(Math.random() * array.length)]\n}\n","import { assert } from '@sindresorhus/is'\n\nimport { emojiNamesByCode } from './data.js'\nimport { normalizeCode } from './utils.js'\n\nexport const findByCode = (code: string) => {\n assert.string(code)\n\n const emojiNormalized = normalizeCode(code)\n const key = emojiNamesByCode.get(emojiNormalized)\n\n return key ? { emoji: emojiNormalized, key } : undefined\n}\n","import { findByCode } from './findByCode.js'\nimport { findByName } from './findByName.js'\n\n/**\n * Get the name and character of an emoji.\n */\nexport const find = (codeOrName: string) => {\n return findByCode(codeOrName) ?? findByName(codeOrName)\n}\n","import { assert } from '@sindresorhus/is'\n\nimport { emojiCodesByName } from './data.js'\nimport { normalizeName } from './utils.js'\n\n/**\n * Get an emoji from an emoji name.\n */\nexport const get = (codeOrName: string) => {\n assert.string(codeOrName)\n\n return emojiCodesByName.get(normalizeName(codeOrName))\n}\n","import { assert } from '@sindresorhus/is'\n\nimport { emojiCodesByName, emojiNamesByCode } from './data.js'\nimport { normalizeCode, normalizeName } from './utils.js'\n\n/**\n * Check if this library supports a specific emoji.\n */\nexport const has = (codeOrName: string) => {\n assert.string(codeOrName)\n\n return (\n emojiCodesByName.has(normalizeName(codeOrName)) ||\n emojiNamesByCode.has(normalizeCode(codeOrName))\n )\n}\n","import { emojiData } from './data.js'\nimport { randomItem } from './utils.js'\n\n/**\n * Get a random emoji.\n */\nexport const random = () => {\n const [name, emoji] = randomItem(emojiData)\n return { emoji, name }\n}\n","import { assert } from '@sindresorhus/is'\n\nimport { Emoji } from './data.js'\nimport { findByCode } from './findByCode.js'\nimport { asFunction, charRegexMatcher } from './utils.js'\n\nexport type ReplaceReplacement = (\n emoji: Emoji,\n index: number,\n string: string,\n) => string\n\n/**\n * Replace the emojis in a string.\n */\nexport const replace = (\n input: string,\n replacement: ReplaceReplacement | string,\n { preserveSpaces = false } = {},\n) => {\n const replace = asFunction(replacement)\n\n assert.string(input)\n assert.function_(replace)\n assert.boolean(preserveSpaces)\n\n const characters = input.match(charRegexMatcher)\n if (characters === null) {\n return input\n }\n\n return characters\n .map((character, index) => {\n const found = findByCode(character)\n if (!found) {\n return character\n }\n\n if (!preserveSpaces && characters[index + 1] === ' ') {\n characters[index + 1] = ''\n }\n\n return replace(found, index, input)\n })\n .join('')\n}\n","import is, { assert } from '@sindresorhus/is'\n\nimport { emojiData } from './data.js'\nimport { normalizeName } from './utils.js'\n\n/**\n * Search for emojis containing the provided name or pattern in their name.\n */\nexport const search = (keyword: RegExp | string) => {\n assert.any([is.string, is.regExp], keyword)\n\n if (is.string(keyword)) {\n keyword = normalizeName(keyword)\n }\n\n if (is.regExp(keyword)) {\n const normalizedPattern = normalizeName(keyword.toString())\n keyword = new RegExp(normalizedPattern)\n }\n\n return emojiData\n .filter(([name]) => name.match(keyword))\n .map(([name, emoji]) => ({ emoji, name }))\n}\n","import { replace } from './replace.js'\n\nexport interface StripOptions {\n /**\n * Whether to keep the extra space after a stripped emoji.\n */\n preserveSpaces?: boolean\n}\n\n/**\n * Remove all the emojis from a string.\n */\nexport const strip = (input: string, { preserveSpaces }: StripOptions = {}) =>\n replace(input, '', { preserveSpaces })\n","import { assert } from '@sindresorhus/is'\n\nimport { charRegexMatcher } from './utils.js'\nimport { which } from './which.js'\n\n/**\n * Convert all emojis in a string to their markdown-encoded counterparts.\n */\nexport const unemojify = (input: string) => {\n assert.string(input)\n\n const characters = input.match(charRegexMatcher)\n if (characters === null) {\n return input\n }\n\n return characters\n .map(character => which(character, { markdown: true }) ?? character)\n .join('')\n}\n","import { assert } from '@sindresorhus/is'\nimport skinTone from 'skin-tone'\n\nimport { findByCode } from './findByCode.js'\n\nexport interface WhichOptions {\n markdown?: boolean\n}\n\n/**\n * Get an emoji name from an emoji.\n */\nexport const which = (\n emoji: string,\n { markdown = false }: WhichOptions = {},\n) => {\n assert.string(emoji)\n assert.boolean(markdown)\n\n const result = findByCode(skinTone(emoji, 'none'))\n if (result === undefined) {\n return undefined\n }\n\n return markdown ? `:${result.key}:` : result.key\n}\n"],"mappings":"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","names":["assert","assert","assert","assert","assert","assert","assert","replace","assert","is","assert","assert","is","assert","assert","assert","assert"]}
|
|
@@ -28,8 +28,8 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
|
|
|
28
28
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
29
|
|
|
30
30
|
// src/index.ts
|
|
31
|
-
var
|
|
32
|
-
__export(
|
|
31
|
+
var src_exports = {};
|
|
32
|
+
__export(src_exports, {
|
|
33
33
|
emojify: () => emojify,
|
|
34
34
|
find: () => find,
|
|
35
35
|
get: () => get,
|
|
@@ -41,7 +41,7 @@ __export(index_exports, {
|
|
|
41
41
|
unemojify: () => unemojify,
|
|
42
42
|
which: () => which
|
|
43
43
|
});
|
|
44
|
-
module.exports = __toCommonJS(
|
|
44
|
+
module.exports = __toCommonJS(src_exports);
|
|
45
45
|
|
|
46
46
|
// src/emojify.ts
|
|
47
47
|
var import_is2 = __toESM(require("@sindresorhus/is"), 1);
|
|
@@ -90,9 +90,9 @@ var findByName = (name) => {
|
|
|
90
90
|
// src/emojify.ts
|
|
91
91
|
var emojify = (input, { fallback, format = (name) => name } = {}) => {
|
|
92
92
|
const fallbackFunction = fallback === void 0 ? fallback : asFunction(fallback);
|
|
93
|
-
import_is2.default.
|
|
94
|
-
import_is2.default.
|
|
95
|
-
import_is2.default.
|
|
93
|
+
import_is2.default.string(input);
|
|
94
|
+
import_is2.default.any([import_is2.default.undefined, import_is2.default.function_], fallbackFunction);
|
|
95
|
+
import_is2.default.function_(format);
|
|
96
96
|
return input.replace(/:[\w\-+]+:/g, (part) => {
|
|
97
97
|
const found = findByName(part);
|
|
98
98
|
if (found) {
|
|
@@ -165,12 +165,12 @@ var replace = (input, replacement, { preserveSpaces = false } = {}) => {
|
|
|
165
165
|
// src/search.ts
|
|
166
166
|
var import_is7 = __toESM(require("@sindresorhus/is"), 1);
|
|
167
167
|
var search = (keyword) => {
|
|
168
|
-
import_is7.assert.any([import_is7.default.
|
|
169
|
-
if (import_is7.default.
|
|
168
|
+
import_is7.assert.any([import_is7.default.string, import_is7.default.regExp], keyword);
|
|
169
|
+
if (import_is7.default.string(keyword)) {
|
|
170
170
|
keyword = normalizeName(keyword);
|
|
171
171
|
}
|
|
172
|
-
if (import_is7.default.
|
|
173
|
-
const normalizedPattern = normalizeName(keyword.
|
|
172
|
+
if (import_is7.default.regExp(keyword)) {
|
|
173
|
+
const normalizedPattern = normalizeName(keyword.toString());
|
|
174
174
|
keyword = new RegExp(normalizedPattern);
|
|
175
175
|
}
|
|
176
176
|
return emojiData.filter(([name]) => name.match(keyword)).map(([name, emoji]) => ({ emoji, name }));
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/emojify.ts","../../src/findByName.ts","../../src/data.ts","../../src/utils.ts","../../src/findByCode.ts","../../src/find.ts","../../src/get.ts","../../src/has.ts","../../src/random.ts","../../src/replace.ts","../../src/search.ts","../../src/strip.ts","../../src/unemojify.ts","../../src/which.ts"],"sourcesContent":["export * from './emojify.js'\nexport * from './find.js'\nexport * from './get.js'\nexport * from './has.js'\nexport * from './random.js'\nexport * from './replace.js'\nexport * from './search.js'\nexport * from './strip.js'\nexport * from './unemojify.js'\nexport * from './which.js'\n","import is from '@sindresorhus/is'\n\nimport { findByName } from './findByName.js'\nimport { asFunction, normalizeName } from './utils.js'\n\nexport type EmojifyFormat = (\n name: string,\n part?: string,\n input?: string,\n) => string\n\nexport interface EmojifyOptions {\n /**\n * The string to fallback to if an emoji was not found.\n */\n fallback?: ((part: string) => string) | string\n\n /**\n * Adds a middleware layer to modify each matched emoji after parsing.\n */\n format?: EmojifyFormat\n}\n\n/**\n * Parse all markdown-encoded emojis in a string.\n */\nexport const emojify = (\n input: string,\n { fallback, format = name => name }: EmojifyOptions = {},\n) => {\n const fallbackFunction =\n fallback === undefined ? fallback : asFunction(fallback)\n\n is.string(input)\n is.any([is.undefined, is.function_], fallbackFunction)\n is.function_(format)\n\n return input.replace(/:[\\w\\-+]+:/g, part => {\n const found = findByName(part)\n if (found) {\n return format(found.emoji, part, input)\n }\n\n if (fallbackFunction) {\n return format(fallbackFunction(normalizeName(part)))\n }\n\n return format(part)\n })\n}\n","import { assert } from '@sindresorhus/is'\n\nimport { emojiCodesByName } from './data.js'\nimport { normalizeName } from './utils.js'\n\nexport const findByName = (name: string) => {\n assert.string(name)\n\n const nameNormalized = normalizeName(name)\n const emoji = emojiCodesByName.get(nameNormalized)\n\n return emoji ? { emoji, key: nameNormalized } : undefined\n}\n","import emojilib from 'emojilib'\n\nimport { normalizeCode } from './utils.js'\n\nexport interface Emoji {\n emoji: string\n key: string\n}\n\nexport const emojiData = Object.entries(emojilib.lib).map(\n ([name, { char: emoji }]) => [name, emoji] as const,\n)\n\nexport const emojiCodesByName = new Map(emojiData)\n\nexport const emojiNamesByCode = new Map(\n emojiData.map(([name, emoji]) => [normalizeCode(emoji), name]),\n)\n","import charRegex from 'char-regex'\n\nexport const charRegexMatcher = charRegex()\n\nexport function asFunction<T extends PropertyKey, Args extends unknown[]>(\n input: ((...args: Args) => T) | T,\n): (...args: Args) => T {\n return typeof input === 'function' ? input : () => input\n}\n\n/**\n * Non spacing mark contained by some emoticons (65039 - '️' - 0xFE0F).\n *\n * It's the 'Variant Form', which provides more information so that emoticons\n * can be rendered as more colorful graphics. FE0E is a unicode text version\n * whereas FE0F should be rendered as a graphical version.\n * The code gracefully degrades.\n */\nconst NON_SPACING_MARK = String.fromCharCode(65039)\n\nconst nonSpacingRegex = new RegExp(NON_SPACING_MARK, 'g')\n\n/**\n * Removes the non-spacing-mark from the emoji code.\n *\n * Never send a stripped version to clients, as it kills graphical emoticons.\n */\nexport function normalizeCode(code: string) {\n return code.replace(nonSpacingRegex, '')\n}\n\nexport function normalizeName(name: string) {\n return /:.+:/.test(name) ? name.slice(1, -1) : name\n}\n\nexport function randomItem<T>(array: T[]) {\n return array[Math.floor(Math.random() * array.length)]\n}\n","import { assert } from '@sindresorhus/is'\n\nimport { emojiNamesByCode } from './data.js'\nimport { normalizeCode } from './utils.js'\n\nexport const findByCode = (code: string) => {\n assert.string(code)\n\n const emojiNormalized = normalizeCode(code)\n const key = emojiNamesByCode.get(emojiNormalized)\n\n return key ? { emoji: emojiNormalized, key } : undefined\n}\n","import { findByCode } from './findByCode.js'\nimport { findByName } from './findByName.js'\n\n/**\n * Get the name and character of an emoji.\n */\nexport const find = (codeOrName: string) => {\n return findByCode(codeOrName) ?? findByName(codeOrName)\n}\n","import { assert } from '@sindresorhus/is'\n\nimport { emojiCodesByName } from './data.js'\nimport { normalizeName } from './utils.js'\n\n/**\n * Get an emoji from an emoji name.\n */\nexport const get = (codeOrName: string) => {\n assert.string(codeOrName)\n\n return emojiCodesByName.get(normalizeName(codeOrName))\n}\n","import { assert } from '@sindresorhus/is'\n\nimport { emojiCodesByName, emojiNamesByCode } from './data.js'\nimport { normalizeCode, normalizeName } from './utils.js'\n\n/**\n * Check if this library supports a specific emoji.\n */\nexport const has = (codeOrName: string) => {\n assert.string(codeOrName)\n\n return (\n emojiCodesByName.has(normalizeName(codeOrName)) ||\n emojiNamesByCode.has(normalizeCode(codeOrName))\n )\n}\n","import { emojiData } from './data.js'\nimport { randomItem } from './utils.js'\n\n/**\n * Get a random emoji.\n */\nexport const random = () => {\n const [name, emoji] = randomItem(emojiData)\n return { emoji, name }\n}\n","import { assert } from '@sindresorhus/is'\n\nimport { Emoji } from './data.js'\nimport { findByCode } from './findByCode.js'\nimport { asFunction, charRegexMatcher } from './utils.js'\n\nexport type ReplaceReplacement = (\n emoji: Emoji,\n index: number,\n string: string,\n) => string\n\n/**\n * Replace the emojis in a string.\n */\nexport const replace = (\n input: string,\n replacement: ReplaceReplacement | string,\n { preserveSpaces = false } = {},\n) => {\n const replace = asFunction(replacement)\n\n assert.string(input)\n assert.function_(replace)\n assert.boolean(preserveSpaces)\n\n const characters = input.match(charRegexMatcher)\n if (characters === null) {\n return input\n }\n\n return characters\n .map((character, index) => {\n const found = findByCode(character)\n if (!found) {\n return character\n }\n\n if (!preserveSpaces && characters[index + 1] === ' ') {\n characters[index + 1] = ''\n }\n\n return replace(found, index, input)\n })\n .join('')\n}\n","import is, { assert } from '@sindresorhus/is'\n\nimport { emojiData } from './data.js'\nimport { normalizeName } from './utils.js'\n\n/**\n * Search for emojis containing the provided name or pattern in their name.\n */\nexport const search = (keyword: RegExp | string) => {\n assert.any([is.string, is.regExp], keyword)\n\n if (is.string(keyword)) {\n keyword = normalizeName(keyword)\n }\n\n if (is.regExp(keyword)) {\n const normalizedPattern = normalizeName(keyword.toString())\n keyword = new RegExp(normalizedPattern)\n }\n\n return emojiData\n .filter(([name]) => name.match(keyword))\n .map(([name, emoji]) => ({ emoji, name }))\n}\n","import { replace } from './replace.js'\n\nexport interface StripOptions {\n /**\n * Whether to keep the extra space after a stripped emoji.\n */\n preserveSpaces?: boolean\n}\n\n/**\n * Remove all the emojis from a string.\n */\nexport const strip = (input: string, { preserveSpaces }: StripOptions = {}) =>\n replace(input, '', { preserveSpaces })\n","import { assert } from '@sindresorhus/is'\n\nimport { charRegexMatcher } from './utils.js'\nimport { which } from './which.js'\n\n/**\n * Convert all emojis in a string to their markdown-encoded counterparts.\n */\nexport const unemojify = (input: string) => {\n assert.string(input)\n\n const characters = input.match(charRegexMatcher)\n if (characters === null) {\n return input\n }\n\n return characters\n .map(character => which(character, { markdown: true }) ?? character)\n .join('')\n}\n","import { assert } from '@sindresorhus/is'\nimport skinTone from 'skin-tone'\n\nimport { findByCode } from './findByCode.js'\n\nexport interface WhichOptions {\n markdown?: boolean\n}\n\n/**\n * Get an emoji name from an emoji.\n */\nexport const which = (\n emoji: string,\n { markdown = false }: WhichOptions = {},\n) => {\n assert.string(emoji)\n assert.boolean(markdown)\n\n const result = findByCode(skinTone(emoji, 'none'))\n if (result === undefined) {\n return undefined\n }\n\n return markdown ? `:${result.key}:` : result.key\n}\n"],"mappings":"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","names":["import_is","charRegex","emojilib","is","import_is","import_is","import_is","import_is","replace","import_is","is","import_is","import_is","skinTone"]}
|