caseforge 0.1.0

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/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2025 Chikada Hiroki
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,50 @@
1
+ # caseforge
2
+
3
+ [![CI](https://github.com/YOUR_USERNAME/caseforge/actions/workflows/ci.yml/badge.svg)](https://github.com/YOUR_USERNAME/caseforge/actions/workflows/ci.yml)
4
+ [![npm version](https://badge.fury.io/js/caseforge.svg)](https://www.npmjs.com/package/caseforge)
5
+ [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
6
+
7
+ > Type-safe and lightweight case conversion library for TypeScript.
8
+
9
+ ## Features
10
+
11
+ - 🎯 Type-safe conversions with full TypeScript support
12
+ - 🪶 Zero dependencies
13
+ - 🔄 Supports camelCase, snake_case, kebab-case, and PascalCase
14
+ - 🌳 Deep object and array transformation
15
+ - 📦 Works with Bun, Node.js, and browsers
16
+
17
+ ## Installation
18
+
19
+ ```bash
20
+ npm install caseforge
21
+ ```
22
+
23
+ ```ts
24
+ import { toCamelCase, toSnakeCase, toKebabCase, toPascalCase } from "caseforge";
25
+
26
+ // String conversion
27
+ toCamelCase("user_name"); // => "userName"
28
+ toSnakeCase("userName"); // => "user_name"
29
+ toKebabCase("userName"); // => "user-name"
30
+ toPascalCase("user_name"); // => "UserName"
31
+
32
+ // Object conversion with type inference
33
+ const apiResponse = {
34
+ user_id: 123,
35
+ user_name: "John",
36
+ user_settings: {
37
+ notification_enabled: true
38
+ }
39
+ };
40
+
41
+ const result = toCamelCase(apiResponse);
42
+ // result.userId (typed!)
43
+ // result.userName (typed!)
44
+ // result.userSettings.notificationEnabled (typed!)## API
45
+
46
+ ```
47
+
48
+ ## License
49
+
50
+ MIT © Chikada Hiroki
@@ -0,0 +1,21 @@
1
+ /**
2
+ * Converts a string to camelCase format at the type level.
3
+ * @example "user_name" -> "userName"
4
+ */
5
+ type CamelCase<S extends string> = S extends `${infer A}_${infer B}` ? `${Lowercase<A>}${Capitalize<CamelCase<B>>}` : S extends `${infer A}-${infer B}` ? `${Lowercase<A>}${Capitalize<CamelCase<B>>}` : Uncapitalize<S>;
6
+ /**
7
+ * Converts all object keys to camelCase format at the type level.
8
+ * @example { user_name: "John Doe" } -> { userName: "John Doe" }
9
+ */
10
+ type CamelCaseKeys<T> = {
11
+ [K in keyof T as CamelCase<K & string>]: T[K] extends Array<infer U> ? U extends Record<string, unknown> ? Array<CamelCaseKeys<U>> : T[K] : T[K] extends Record<string, unknown> ? CamelCaseKeys<T[K]> : T[K];
12
+ };
13
+ /**
14
+ * Converts strings or object keys to camelCase format.
15
+ * @param input - A string or object to convert.
16
+ * @returns The camelCase string or object.
17
+ */
18
+ export declare function toCamelCase<T extends string>(input: T): CamelCase<T>;
19
+ export declare function toCamelCase<T extends Record<string, unknown>>(input: T): CamelCaseKeys<T>;
20
+ export {};
21
+ //# sourceMappingURL=toCamelCase.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"toCamelCase.d.ts","sourceRoot":"","sources":["../../src/core/toCamelCase.ts"],"names":[],"mappings":"AAIA;;;GAGG;AACH,KAAK,SAAS,CAAC,CAAC,SAAS,MAAM,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,IAAI,MAAM,CAAC,EAAE,GACjE,GAAG,SAAS,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,EAAE,GAC5C,CAAC,SAAS,GAAG,MAAM,CAAC,IAAI,MAAM,CAAC,EAAE,GAChC,GAAG,SAAS,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,EAAE,GAC5C,YAAY,CAAC,CAAC,CAAC,CAAC;AAEpB;;;GAGG;AACH,KAAK,aAAa,CAAC,CAAC,IAAI;KACtB,CAAC,IAAI,MAAM,CAAC,IAAI,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,KAAK,CAAC,MAAM,CAAC,CAAC,GACjE,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAChC,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,GACvB,CAAC,CAAC,CAAC,CAAC,GACL,CAAC,CAAC,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GACnC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GACnB,CAAC,CAAC,CAAC,CAAC;CACR,CAAC;AAcF;;;;GAIG;AACH,wBAAgB,WAAW,CAAC,CAAC,SAAS,MAAM,EAAE,KAAK,EAAE,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;AACtE,wBAAgB,WAAW,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC5D,KAAK,EAAE,CAAC,GACN,aAAa,CAAC,CAAC,CAAC,CAAC"}
@@ -0,0 +1,21 @@
1
+ /**
2
+ * Converts a string to kebab-case format at the type level.
3
+ * @example "userName" -> "user-name"
4
+ */
5
+ type KebabCase<S extends string, First extends boolean = true> = S extends `${infer C}${infer R}` ? C extends "_" ? `-${KebabCase<R, false>}` : C extends Uppercase<C> ? First extends true ? `${Lowercase<C>}${KebabCase<R, false>}` : `-${Lowercase<C>}${KebabCase<R, false>}` : `${C}${KebabCase<R, false>}` : S;
6
+ /**
7
+ * Converts all object keys to kebab-case format at the type level.
8
+ * @example { userName: "John Doe" } -> { "user-name": "John Doe" }
9
+ */
10
+ type KebabCaseKeys<T> = {
11
+ [K in keyof T as KebabCase<K & string>]: T[K] extends Array<infer U> ? U extends Record<string, unknown> ? Array<KebabCaseKeys<U>> : T[K] : T[K] extends Record<string, unknown> ? KebabCaseKeys<T[K]> : T[K];
12
+ };
13
+ /**
14
+ * Converts strings or object keys to kebab-case format.
15
+ * @param input - A string or object to convert.
16
+ * @returns The kebab-case string or object.
17
+ */
18
+ export declare function toKebabCase<T extends string>(input: T): KebabCase<T>;
19
+ export declare function toKebabCase<T extends Record<string, unknown>>(input: T): KebabCaseKeys<T>;
20
+ export {};
21
+ //# sourceMappingURL=toKebabCase.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"toKebabCase.d.ts","sourceRoot":"","sources":["../../src/core/toKebabCase.ts"],"names":[],"mappings":"AAIA;;;GAGG;AACH,KAAK,SAAS,CACb,CAAC,SAAS,MAAM,EAChB,KAAK,SAAS,OAAO,GAAG,IAAI,IACzB,CAAC,SAAS,GAAG,MAAM,CAAC,GAAG,MAAM,CAAC,EAAE,GACjC,CAAC,SAAS,GAAG,GACZ,IAAI,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,GACzB,CAAC,SAAS,SAAS,CAAC,CAAC,CAAC,GACrB,KAAK,SAAS,IAAI,GACjB,GAAG,SAAS,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,GACvC,IAAI,SAAS,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,GACzC,GAAG,CAAC,GAAG,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,GAC9B,CAAC,CAAC;AAEL;;;GAGG;AACH,KAAK,aAAa,CAAC,CAAC,IAAI;KACtB,CAAC,IAAI,MAAM,CAAC,IAAI,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,KAAK,CAAC,MAAM,CAAC,CAAC,GACjE,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAChC,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,GACvB,CAAC,CAAC,CAAC,CAAC,GACL,CAAC,CAAC,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GACnC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GACnB,CAAC,CAAC,CAAC,CAAC;CACR,CAAC;AAcF;;;;GAIG;AACH,wBAAgB,WAAW,CAAC,CAAC,SAAS,MAAM,EAAE,KAAK,EAAE,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;AACtE,wBAAgB,WAAW,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC5D,KAAK,EAAE,CAAC,GACN,aAAa,CAAC,CAAC,CAAC,CAAC"}
@@ -0,0 +1,21 @@
1
+ /**
2
+ * Converts a string to PascalCase format at the type level.
3
+ * @example "user_name" -> "UserName"
4
+ */
5
+ type PascalCase<S extends string> = S extends `${infer Head}_${infer Tail}` ? `${Capitalize<Lowercase<Head>>}${PascalCase<Tail>}` : S extends `${infer Head}-${infer Tail}` ? `${Capitalize<Lowercase<Head>>}${PascalCase<Tail>}` : S extends `${infer First}${infer Rest}` ? `${Capitalize<First>}${Rest}` : S;
6
+ /**
7
+ * Converts all object keys to PascalCase format at the type level.
8
+ * @example { user_name: "John Doe" } -> { UserName: "John Doe" }
9
+ */
10
+ type PascalCaseKeys<T> = {
11
+ [K in keyof T as PascalCase<K & string>]: T[K] extends Array<infer U> ? U extends Record<string, unknown> ? Array<PascalCaseKeys<U>> : T[K] : T[K] extends Record<string, unknown> ? PascalCaseKeys<T[K]> : T[K];
12
+ };
13
+ /**
14
+ * Converts strings or object keys to PascalCase format.
15
+ * @param input - A string or object to convert.
16
+ * @returns The PascalCase string or object.
17
+ */
18
+ export declare function toPascalCase<T extends string>(input: T): PascalCase<T>;
19
+ export declare function toPascalCase<T extends Record<string, unknown>>(input: T): PascalCaseKeys<T>;
20
+ export {};
21
+ //# sourceMappingURL=toPascalCase.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"toPascalCase.d.ts","sourceRoot":"","sources":["../../src/core/toPascalCase.ts"],"names":[],"mappings":"AAIA;;;GAGG;AACH,KAAK,UAAU,CAAC,CAAC,SAAS,MAAM,IAAI,CAAC,SAAS,GAAG,MAAM,IAAI,IAAI,MAAM,IAAI,EAAE,GACxE,GAAG,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,GAAG,UAAU,CAAC,IAAI,CAAC,EAAE,GACnD,CAAC,SAAS,GAAG,MAAM,IAAI,IAAI,MAAM,IAAI,EAAE,GACtC,GAAG,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,GAAG,UAAU,CAAC,IAAI,CAAC,EAAE,GACnD,CAAC,SAAS,GAAG,MAAM,KAAK,GAAG,MAAM,IAAI,EAAE,GACtC,GAAG,UAAU,CAAC,KAAK,CAAC,GAAG,IAAI,EAAE,GAC7B,CAAC,CAAC;AAEP;;;GAGG;AACH,KAAK,cAAc,CAAC,CAAC,IAAI;KACvB,CAAC,IAAI,MAAM,CAAC,IAAI,UAAU,CAAC,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,KAAK,CAAC,MAAM,CAAC,CAAC,GAClE,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAChC,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,GACxB,CAAC,CAAC,CAAC,CAAC,GACL,CAAC,CAAC,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GACnC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GACpB,CAAC,CAAC,CAAC,CAAC;CACR,CAAC;AAcF;;;;GAIG;AACH,wBAAgB,YAAY,CAAC,CAAC,SAAS,MAAM,EAAE,KAAK,EAAE,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC;AACxE,wBAAgB,YAAY,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC7D,KAAK,EAAE,CAAC,GACN,cAAc,CAAC,CAAC,CAAC,CAAC"}
@@ -0,0 +1,21 @@
1
+ /**
2
+ * Converts a string to snake_case format at the type level.
3
+ * @example "userName" -> "user_name"
4
+ */
5
+ type SnakeCase<S extends string, First extends boolean = true> = S extends `${infer C}${infer R}` ? C extends "_" | "-" ? `_${SnakeCase<R, false>}` : C extends Uppercase<C> ? First extends true ? `${Lowercase<C>}${SnakeCase<R, false>}` : `_${Lowercase<C>}${SnakeCase<R, false>}` : `${C}${SnakeCase<R, false>}` : S;
6
+ /**
7
+ * Converts all object keys to snake_case format at the type level.
8
+ * @example { userName: "John Doe" } -> { user_name: "John Doe" }
9
+ */
10
+ type SnakeCaseKeys<T> = {
11
+ [K in keyof T as SnakeCase<K & string>]: T[K] extends Array<infer U> ? U extends Record<string, unknown> ? Array<SnakeCaseKeys<U>> : T[K] : T[K] extends Record<string, unknown> ? SnakeCaseKeys<T[K]> : T[K];
12
+ };
13
+ /**
14
+ * Converts strings or object keys to snake_case format.
15
+ * @param input - A string or object to convert.
16
+ * @returns The snake_case string or object.
17
+ */
18
+ export declare function toSnakeCase<T extends string>(input: T): SnakeCase<T>;
19
+ export declare function toSnakeCase<T extends Record<string, unknown>>(input: T): SnakeCaseKeys<T>;
20
+ export {};
21
+ //# sourceMappingURL=toSnakeCase.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"toSnakeCase.d.ts","sourceRoot":"","sources":["../../src/core/toSnakeCase.ts"],"names":[],"mappings":"AAIA;;;GAGG;AACH,KAAK,SAAS,CACb,CAAC,SAAS,MAAM,EAChB,KAAK,SAAS,OAAO,GAAG,IAAI,IACzB,CAAC,SAAS,GAAG,MAAM,CAAC,GAAG,MAAM,CAAC,EAAE,GACjC,CAAC,SAAS,GAAG,GAAG,GAAG,GAClB,IAAI,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,GACzB,CAAC,SAAS,SAAS,CAAC,CAAC,CAAC,GACrB,KAAK,SAAS,IAAI,GACjB,GAAG,SAAS,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,GACvC,IAAI,SAAS,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,GACzC,GAAG,CAAC,GAAG,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,EAAE,GAC9B,CAAC,CAAC;AAEL;;;GAGG;AACH,KAAK,aAAa,CAAC,CAAC,IAAI;KACtB,CAAC,IAAI,MAAM,CAAC,IAAI,SAAS,CAAC,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,KAAK,CAAC,MAAM,CAAC,CAAC,GACjE,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAChC,KAAK,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,GACvB,CAAC,CAAC,CAAC,CAAC,GACL,CAAC,CAAC,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GACnC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GACnB,CAAC,CAAC,CAAC,CAAC;CACR,CAAC;AAcF;;;;GAIG;AACH,wBAAgB,WAAW,CAAC,CAAC,SAAS,MAAM,EAAE,KAAK,EAAE,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;AACtE,wBAAgB,WAAW,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC5D,KAAK,EAAE,CAAC,GACN,aAAa,CAAC,CAAC,CAAC,CAAC"}
@@ -0,0 +1,5 @@
1
+ export { toCamelCase } from "./core/toCamelCase";
2
+ export { toKebabCase } from "./core/toKebabCase";
3
+ export { toPascalCase } from "./core/toPascalCase";
4
+ export { toSnakeCase } from "./core/toSnakeCase";
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC"}
package/dist/index.js ADDED
@@ -0,0 +1,76 @@
1
+ // src/utils/patterns.ts
2
+ var PATTERNS = {
3
+ LEADING_UPPER: /^[A-Z]/,
4
+ UPPERCASE: /[A-Z]/g,
5
+ LEADING_LOWER: /^[a-z]/,
6
+ SEPARATOR_WITH_CHAR: /[_-]+(.)/g,
7
+ EDGE_SEPARATORS: /^[_-]+|[_-]+$/g,
8
+ CONSECUTIVE_SEPARATORS: /[_-]+/g
9
+ };
10
+
11
+ // src/utils/typeGuards.ts
12
+ function isString(value) {
13
+ return typeof value === "string";
14
+ }
15
+ function isArray(value) {
16
+ return Array.isArray(value);
17
+ }
18
+ function isObject(value) {
19
+ return typeof value === "object" && value !== null && !isArray(value);
20
+ }
21
+ function isBuiltIn(value) {
22
+ return value instanceof Date || value instanceof RegExp || typeof value === "function";
23
+ }
24
+
25
+ // src/utils/transform.ts
26
+ function transformObject(object, transformKey) {
27
+ const result = {};
28
+ for (const [key, value] of Object.entries(object)) {
29
+ const newKey = transformKey(key);
30
+ if (isBuiltIn(value)) {
31
+ result[newKey] = value;
32
+ } else if (isArray(value)) {
33
+ result[newKey] = value.map((item) => isObject(item) && !isArray(item) ? transformObject(item, transformKey) : item);
34
+ } else if (isObject(value)) {
35
+ result[newKey] = transformObject(value, transformKey);
36
+ } else {
37
+ result[newKey] = value;
38
+ }
39
+ }
40
+ return result;
41
+ }
42
+
43
+ // src/core/toCamelCase.ts
44
+ function camelCaseString(str) {
45
+ return str.replace(PATTERNS.LEADING_UPPER, (char) => char.toLowerCase()).replace(PATTERNS.SEPARATOR_WITH_CHAR, (_, char) => char.toUpperCase()).replace(PATTERNS.EDGE_SEPARATORS, "");
46
+ }
47
+ function toCamelCase(input) {
48
+ return isString(input) ? camelCaseString(input) : transformObject(input, camelCaseString);
49
+ }
50
+ // src/core/toKebabCase.ts
51
+ function kebabCaseString(str) {
52
+ return str.replace(PATTERNS.UPPERCASE, (char) => `-${char.toLowerCase()}`).replace(PATTERNS.CONSECUTIVE_SEPARATORS, "-").replace(PATTERNS.EDGE_SEPARATORS, "");
53
+ }
54
+ function toKebabCase(input) {
55
+ return isString(input) ? kebabCaseString(input) : transformObject(input, kebabCaseString);
56
+ }
57
+ // src/core/toPascalCase.ts
58
+ function pascalCaseString(str) {
59
+ return str.replace(PATTERNS.SEPARATOR_WITH_CHAR, (_, char) => char.toUpperCase()).replace(PATTERNS.EDGE_SEPARATORS, "").replace(PATTERNS.LEADING_LOWER, (char) => char.toUpperCase());
60
+ }
61
+ function toPascalCase(input) {
62
+ return isString(input) ? pascalCaseString(input) : transformObject(input, pascalCaseString);
63
+ }
64
+ // src/core/toSnakeCase.ts
65
+ function snakeCaseString(str) {
66
+ return str.replace(PATTERNS.UPPERCASE, (char) => `_${char.toLowerCase()}`).replace(PATTERNS.CONSECUTIVE_SEPARATORS, "_").replace(PATTERNS.EDGE_SEPARATORS, "");
67
+ }
68
+ function toSnakeCase(input) {
69
+ return isString(input) ? snakeCaseString(input) : transformObject(input, snakeCaseString);
70
+ }
71
+ export {
72
+ toSnakeCase,
73
+ toPascalCase,
74
+ toKebabCase,
75
+ toCamelCase
76
+ };
@@ -0,0 +1,18 @@
1
+ /**
2
+ * Common regular expression patterns for case conversion.
3
+ */
4
+ export declare const PATTERNS: {
5
+ /** Matches a leading uppercase letter */
6
+ readonly LEADING_UPPER: RegExp;
7
+ /** Matches all uppercase letters */
8
+ readonly UPPERCASE: RegExp;
9
+ /** Matches a leading lowercase letter */
10
+ readonly LEADING_LOWER: RegExp;
11
+ /** Matches separators (_-) followed by any character */
12
+ readonly SEPARATOR_WITH_CHAR: RegExp;
13
+ /** Matches leading/trailing separators */
14
+ readonly EDGE_SEPARATORS: RegExp;
15
+ /** Matches consecutive separators */
16
+ readonly CONSECUTIVE_SEPARATORS: RegExp;
17
+ };
18
+ //# sourceMappingURL=patterns.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"patterns.d.ts","sourceRoot":"","sources":["../../src/utils/patterns.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,eAAO,MAAM,QAAQ;IACpB,yCAAyC;;IAGzC,oCAAoC;;IAGpC,yCAAyC;;IAGzC,wDAAwD;;IAGxD,0CAA0C;;IAG1C,qCAAqC;;CAE5B,CAAC"}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Generic object key transformation.
3
+ * @param object - The object to transform.
4
+ * @param transformKey - Function to transform each key.
5
+ * @returns The transformed object.
6
+ */
7
+ export declare function transformObject<T>(object: Record<string, unknown>, transformKey: (key: string) => string): T;
8
+ //# sourceMappingURL=transform.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transform.d.ts","sourceRoot":"","sources":["../../src/utils/transform.ts"],"names":[],"mappings":"AAEA;;;;;GAKG;AACH,wBAAgB,eAAe,CAAC,CAAC,EAChC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC/B,YAAY,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,MAAM,GACnC,CAAC,CAsBH"}
@@ -0,0 +1,25 @@
1
+ /**
2
+ * Checks if a value is a string.
3
+ * @param value - The value to check.
4
+ * @returns `true` if the value is a string, `false` otherwise.
5
+ */
6
+ export declare function isString(value: unknown): value is string;
7
+ /**
8
+ * Checks if a value is an array.
9
+ * @param value - The value to check.
10
+ * @returns `true` if the value is an array, `false` otherwise.
11
+ */
12
+ export declare function isArray(value: unknown): value is unknown[];
13
+ /**
14
+ * Checks if a value is a plain object.
15
+ * @param value - The value to check.
16
+ * @returns `true` if the value is a plain object, `false` otherwise.
17
+ */
18
+ export declare function isObject(value: unknown): value is Record<string, unknown>;
19
+ /**
20
+ * Checks if a value is a built-in object.
21
+ * @param value - The value to check.
22
+ * @returns `true` if the value is a built-in object, `false` otherwise.
23
+ */
24
+ export declare function isBuiltIn(value: unknown): boolean;
25
+ //# sourceMappingURL=typeGuards.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"typeGuards.d.ts","sourceRoot":"","sources":["../../src/utils/typeGuards.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,wBAAgB,QAAQ,CAAC,KAAK,EAAE,OAAO,GAAG,KAAK,IAAI,MAAM,CAExD;AAED;;;;GAIG;AACH,wBAAgB,OAAO,CAAC,KAAK,EAAE,OAAO,GAAG,KAAK,IAAI,OAAO,EAAE,CAE1D;AAED;;;;GAIG;AACH,wBAAgB,QAAQ,CAAC,KAAK,EAAE,OAAO,GAAG,KAAK,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAEzE;AAED;;;;GAIG;AACH,wBAAgB,SAAS,CAAC,KAAK,EAAE,OAAO,GAAG,OAAO,CAMjD"}
package/package.json ADDED
@@ -0,0 +1,45 @@
1
+ {
2
+ "name": "caseforge",
3
+ "version": "0.1.0",
4
+ "description": "caseforge - Effortlessly convert between snake_case, camelCase, and more in TypeScript. Zero dependencies, type-safe, and easy to use for any project.",
5
+ "main": "./dist/index.js",
6
+ "types": "./dist/index.d.ts",
7
+ "exports": {
8
+ ".": {
9
+ "require": {
10
+ "types": "./dist/index.d.ts",
11
+ "default": "./dist/index.js"
12
+ }
13
+ }
14
+ },
15
+ "files": [
16
+ "dist",
17
+ "README.md",
18
+ "LICENSE"
19
+ ],
20
+ "scripts": {
21
+ "build": "bun x tsc --emitDeclarationOnly && bun build src/index.ts --outdir dist --target node",
22
+ "check": "bunx @biomejs/biome check --write src && bun x tsc --noEmit",
23
+ "prepublishOnly": "bun run check && bun test && bun run build"
24
+ },
25
+ "keywords": [
26
+ "typescript",
27
+ "caseforge",
28
+ "case-conversion",
29
+ "camelcase",
30
+ "snake-case",
31
+ "kebab-case",
32
+ "type-safe",
33
+ "utility",
34
+ "transform"
35
+ ],
36
+ "author": "Chikada Hiroki",
37
+ "license": "MIT",
38
+ "devDependencies": {
39
+ "@biomejs/biome": "2.3.6",
40
+ "typescript": "^5.9.3"
41
+ },
42
+ "dependencies": {
43
+ "@types/bun": "^1.3.2"
44
+ }
45
+ }