nhb-toolbox 4.14.12 → 4.14.14
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/CHANGELOG.md +9 -1
- package/dist/cjs/colors/Color.js +3 -1
- package/dist/cjs/colors/convert.js +3 -1
- package/dist/cjs/colors/helpers.js +2 -2
- package/dist/cjs/colors/initials.js +9 -8
- package/dist/cjs/colors/random.js +1 -1
- package/dist/cjs/string/basics.js +1 -1
- package/dist/dts/colors/Color.d.ts +1 -1
- package/dist/dts/colors/Color.d.ts.map +1 -1
- package/dist/dts/colors/constants.d.ts +2 -2
- package/dist/dts/colors/constants.d.ts.map +1 -1
- package/dist/dts/colors/helpers.d.ts +3 -3
- package/dist/dts/colors/helpers.d.ts.map +1 -1
- package/dist/dts/colors/initials.d.ts +5 -5
- package/dist/dts/colors/initials.d.ts.map +1 -1
- package/dist/dts/colors/random.d.ts +3 -6
- package/dist/dts/colors/random.d.ts.map +1 -1
- package/dist/dts/colors/types.d.ts +7 -0
- package/dist/dts/colors/types.d.ts.map +1 -1
- package/dist/dts/utils/types.d.ts +1 -1
- package/dist/dts/utils/types.d.ts.map +1 -1
- package/dist/esm/colors/Color.js +3 -1
- package/dist/esm/colors/convert.js +3 -1
- package/dist/esm/colors/helpers.js +2 -2
- package/dist/esm/colors/initials.js +9 -8
- package/dist/esm/colors/random.js +1 -1
- package/dist/esm/string/basics.js +1 -1
- package/package.json +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -6,7 +6,15 @@ All notable changes to the package will be documented here.
|
|
|
6
6
|
|
|
7
7
|
---
|
|
8
8
|
|
|
9
|
-
## [4.14.
|
|
9
|
+
## [4.14.14] - 2025-08-27
|
|
10
|
+
|
|
11
|
+
- **Updated** `DeepPartial` type to preserve optional properties of advanced types like `File`, `FileList`, `Chronos` etc.
|
|
12
|
+
|
|
13
|
+
## [4.14.13] - 2025-08-24
|
|
14
|
+
|
|
15
|
+
- **Updated** _return type_ for `getColorForInitial` utility and **improved** _internal logic_ and _error type_ for color generator utilities.
|
|
16
|
+
|
|
17
|
+
## [4.14.12] - 2025-08-23
|
|
10
18
|
|
|
11
19
|
- **Updated** _error type_ for `trimString` utility.
|
|
12
20
|
|
package/dist/cjs/colors/Color.js
CHANGED
|
@@ -431,7 +431,9 @@ class Color {
|
|
|
431
431
|
const { hex8, rgba } = (0, convert_1.convertColorCode)(color);
|
|
432
432
|
return { hex8, rgba, hsla: color };
|
|
433
433
|
}
|
|
434
|
-
throw new
|
|
434
|
+
throw new TypeError(`${color} is not a valid color!`, {
|
|
435
|
+
cause: 'Unrecognized Color Format',
|
|
436
|
+
});
|
|
435
437
|
}
|
|
436
438
|
/**
|
|
437
439
|
* @private @static Internal factory to create a Color instance from parsed parts.
|
|
@@ -320,5 +320,7 @@ function convertColorCode(color) {
|
|
|
320
320
|
rgba: (0, exports.convertHslaToRgba)(...hslaValues),
|
|
321
321
|
};
|
|
322
322
|
}
|
|
323
|
-
throw new
|
|
323
|
+
throw new TypeError(`${color} is not a valid color!`, {
|
|
324
|
+
cause: 'Unrecognized Color Format',
|
|
325
|
+
});
|
|
324
326
|
}
|
|
@@ -28,12 +28,12 @@ const _convertOpacityToHex = (opacity) => {
|
|
|
28
28
|
exports._convertOpacityToHex = _convertOpacityToHex;
|
|
29
29
|
/**
|
|
30
30
|
* * Applies an opacity value to a color string.
|
|
31
|
-
* @param color The color string to apply opacity to.
|
|
31
|
+
* @param color The color string in hex to apply opacity to.
|
|
32
32
|
* @param opacity The opacity value as a percentage (0-100).
|
|
33
33
|
* @returns The color string with the opacity value applied.
|
|
34
34
|
*/
|
|
35
35
|
const _applyOpacity = (color, opacity) => {
|
|
36
|
-
return color.concat(opacity);
|
|
36
|
+
return color?.slice(0, 7).concat(opacity);
|
|
37
37
|
};
|
|
38
38
|
exports._applyOpacity = _applyOpacity;
|
|
39
39
|
/**
|
|
@@ -4,7 +4,7 @@ exports.getColorForInitial = getColorForInitial;
|
|
|
4
4
|
const constants_1 = require("./constants");
|
|
5
5
|
const helpers_1 = require("./helpers");
|
|
6
6
|
/**
|
|
7
|
-
* * Generates a hex color based on the first character (initial) of a string or number; or an array of hex colors based on the first character (initial) of an array of strings/numbers or even nested arrays of strings/numbers.
|
|
7
|
+
* * Generates a hex color (`Hex8` format) based on the first character (initial) of a string or number; or an array of hex colors based on the first character (initial) of an array of strings/numbers or even nested arrays of strings/numbers.
|
|
8
8
|
*
|
|
9
9
|
* - For numbers, it uses 10 predefined colors (0-9).
|
|
10
10
|
* - For letters, it uses 26 predefined colors (A-Z).
|
|
@@ -17,15 +17,16 @@ const helpers_1 = require("./helpers");
|
|
|
17
17
|
function getColorForInitial(input = '', opacity = 100) {
|
|
18
18
|
let initial;
|
|
19
19
|
const hexOpacity = (0, helpers_1._convertOpacityToHex)(opacity);
|
|
20
|
-
const
|
|
20
|
+
const NUMBERS = '0123456789';
|
|
21
|
+
const DEFAULT = '#010514';
|
|
21
22
|
// Handle empty string case
|
|
22
23
|
if (!input)
|
|
23
|
-
return (0, helpers_1._applyOpacity)(
|
|
24
|
+
return (0, helpers_1._applyOpacity)(DEFAULT, hexOpacity);
|
|
24
25
|
// Handle string input
|
|
25
26
|
if (typeof input === 'string') {
|
|
26
27
|
initial = input[0];
|
|
27
28
|
// Handle number as string
|
|
28
|
-
if (
|
|
29
|
+
if (NUMBERS.includes(initial)) {
|
|
29
30
|
return (0, helpers_1._applyOpacity)(constants_1.NUMBER_COLOR_PALETTE[parseInt(initial, 10)], hexOpacity);
|
|
30
31
|
}
|
|
31
32
|
const upperInitial = initial.toUpperCase();
|
|
@@ -34,15 +35,15 @@ function getColorForInitial(input = '', opacity = 100) {
|
|
|
34
35
|
if (index >= 0 && index < constants_1.ALPHABET_COLOR_PALETTE?.length) {
|
|
35
36
|
return (0, helpers_1._applyOpacity)(constants_1.ALPHABET_COLOR_PALETTE[index], hexOpacity);
|
|
36
37
|
}
|
|
37
|
-
return (0, helpers_1._applyOpacity)(
|
|
38
|
+
return (0, helpers_1._applyOpacity)(DEFAULT, hexOpacity);
|
|
38
39
|
// Handle number input
|
|
39
40
|
}
|
|
40
41
|
else if (typeof input === 'number' && !isNaN(input)) {
|
|
41
42
|
initial = input.toString()[0];
|
|
42
|
-
if (
|
|
43
|
+
if (NUMBERS.includes(initial)) {
|
|
43
44
|
return (0, helpers_1._applyOpacity)(constants_1.NUMBER_COLOR_PALETTE[parseInt(initial, 10)], hexOpacity);
|
|
44
45
|
}
|
|
45
|
-
return (0, helpers_1._applyOpacity)(
|
|
46
|
+
return (0, helpers_1._applyOpacity)(DEFAULT, hexOpacity);
|
|
46
47
|
// Handle array of strings/numbers
|
|
47
48
|
}
|
|
48
49
|
else if (Array.isArray(input)) {
|
|
@@ -57,5 +58,5 @@ function getColorForInitial(input = '', opacity = 100) {
|
|
|
57
58
|
})
|
|
58
59
|
.flat();
|
|
59
60
|
}
|
|
60
|
-
return (0, helpers_1._applyOpacity)(
|
|
61
|
+
return (0, helpers_1._applyOpacity)(DEFAULT, hexOpacity);
|
|
61
62
|
}
|
|
@@ -31,7 +31,7 @@ const generateRandomHSLColor = (maxColors = 16) => {
|
|
|
31
31
|
};
|
|
32
32
|
exports.generateRandomHSLColor = generateRandomHSLColor;
|
|
33
33
|
/**
|
|
34
|
-
* * Utility to generate a unique random color in
|
|
34
|
+
* * Utility to generate a unique random color in Hex6 and RGB format.
|
|
35
35
|
*
|
|
36
36
|
* @param maxColors - The maximum number of recent colors to store in memory. Default is `16`.
|
|
37
37
|
* @returns An object of generated unique random color in both `Hex` and `RGB` formats.
|
|
@@ -99,7 +99,7 @@ function trimString(input) {
|
|
|
99
99
|
if (!input)
|
|
100
100
|
return '';
|
|
101
101
|
// If the input is a string, trim each word
|
|
102
|
-
if (typeof input === 'string'
|
|
102
|
+
if (typeof input === 'string') {
|
|
103
103
|
return input?.trim()?.replace(/\s+/g, ' ');
|
|
104
104
|
}
|
|
105
105
|
// If the input is an array of strings, trim each string in the array
|
|
@@ -100,7 +100,7 @@ export declare class Color {
|
|
|
100
100
|
*/
|
|
101
101
|
constructor(color: CSSColor);
|
|
102
102
|
/** - Iterates over the color representations (Hex, RGB, HSL). */
|
|
103
|
-
[Symbol.iterator](): Generator<
|
|
103
|
+
[Symbol.iterator](): Generator<Hex8 | HSL | Hex6 | RGB | RGBA | HSLA, void, unknown>;
|
|
104
104
|
/**
|
|
105
105
|
* @instance Applies or modifies the opacity of a color. Mutate the original instance.
|
|
106
106
|
* - For solid colors (Hex6/RGB/HSL): Adds an alpha channel with the specified opacity.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Color.d.ts","sourceRoot":"","sources":["../../../src/colors/Color.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAW/C,OAAO,KAAK,EAEX,SAAS,EAET,SAAS,EACT,QAAQ,EACR,IAAI,EACJ,IAAI,EACJ,GAAG,EACH,IAAI,EACJ,GAAG,EACH,IAAI,EAEJ,MAAM,EACN,KAAK,EACL,MAAM,SAAS,CAAC;AAGjB;;;;;;;;;;;GAWG;AACH,qBAAa,KAAK;;IACV,GAAG,EAAE,IAAI,CAAC;IACV,IAAI,EAAE,IAAI,CAAC;IACX,GAAG,EAAE,GAAG,CAAC;IACT,IAAI,EAAE,IAAI,CAAC;IACX,GAAG,EAAE,GAAG,CAAC;IACT,IAAI,EAAE,IAAI,CAAC;IAElB;;;;;;;;;;;;;;;;;;;;;;OAsBG;;IAGH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAoCG;gBACS,KAAK,EAAE,SAAS;IAE5B;;;;;;;;;;;;;;;OAeG;gBACS,KAAK,EAAE,QAAQ;IA0G3B,iEAAiE;IAChE,CAAC,MAAM,CAAC,QAAQ,CAAC;IASlB;;;;;;;;;;;;;;;;;OAiBG;IACH,YAAY,CAAC,OAAO,EAAE,OAAO,GAAG,KAAK;IAkBrC;;;;OAIG;IACH,aAAa,CAAC,OAAO,EAAE,OAAO,GAAG,KAAK;IAUtC;;;;OAIG;IACH,eAAe,CAAC,OAAO,EAAE,OAAO,GAAG,KAAK;IAUxC;;;;OAIG;IACH,aAAa,CAAC,OAAO,EAAE,OAAO,GAAG,KAAK;IAUtC;;;;;OAKG;IACH,eAAe,CAAC,OAAO,EAAE,OAAO,GAAG,KAAK;IAYxC;;;;;;;;;;;OAWG;IACH,SAAS,CAAC,KAAK,EAAE,SAAS,GAAG,QAAQ,EAAE,MAAM,SAAM,GAAG,KAAK;IAwB3D;;;;OAIG;IACH,aAAa,CAAC,KAAK,EAAE,SAAS,GAAG,QAAQ,GAAG,MAAM;IA0BlD;;;OAGG;IACH,qBAAqB,IAAI,KAAK;IAU9B;;;;OAIG;IACH,kBAAkB,IAAI,SAAS;IAa/B;;;;OAIG;IACH,cAAc,IAAI,KAAK;IAWvB;;;;OAIG;IACH,eAAe,IAAI,MAAM;IAczB;;;;OAIG;IACH,aAAa,CAAC,KAAK,EAAE,SAAS,GAAG,QAAQ,GAAG,MAAM,GAAG,IAAI,GAAG,KAAK;IAQjE;;;OAGG;IACH,YAAY,IAAI,OAAO;IAQvB;;;;;OAKG;IACH,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,IAAI;IAI3C;;;;;OAKG;IACH,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,IAAI;IAI3C;;;;;OAKG;IACH,MAAM,CAAC,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,GAAG;IAIzC;;;;;OAKG;IACH,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,IAAI;IAI3C;;;;;OAKG;IACH,MAAM,CAAC,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,GAAG;IAIzC;;;;;OAKG;IACH,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,IAAI;IAI3C;;;;;;;OAOG;IACH,MAAM,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,QAAQ;
|
|
1
|
+
{"version":3,"file":"Color.d.ts","sourceRoot":"","sources":["../../../src/colors/Color.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAW/C,OAAO,KAAK,EAEX,SAAS,EAET,SAAS,EACT,QAAQ,EACR,IAAI,EACJ,IAAI,EACJ,GAAG,EACH,IAAI,EACJ,GAAG,EACH,IAAI,EAEJ,MAAM,EACN,KAAK,EACL,MAAM,SAAS,CAAC;AAGjB;;;;;;;;;;;GAWG;AACH,qBAAa,KAAK;;IACV,GAAG,EAAE,IAAI,CAAC;IACV,IAAI,EAAE,IAAI,CAAC;IACX,GAAG,EAAE,GAAG,CAAC;IACT,IAAI,EAAE,IAAI,CAAC;IACX,GAAG,EAAE,GAAG,CAAC;IACT,IAAI,EAAE,IAAI,CAAC;IAElB;;;;;;;;;;;;;;;;;;;;;;OAsBG;;IAGH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAoCG;gBACS,KAAK,EAAE,SAAS;IAE5B;;;;;;;;;;;;;;;OAeG;gBACS,KAAK,EAAE,QAAQ;IA0G3B,iEAAiE;IAChE,CAAC,MAAM,CAAC,QAAQ,CAAC;IASlB;;;;;;;;;;;;;;;;;OAiBG;IACH,YAAY,CAAC,OAAO,EAAE,OAAO,GAAG,KAAK;IAkBrC;;;;OAIG;IACH,aAAa,CAAC,OAAO,EAAE,OAAO,GAAG,KAAK;IAUtC;;;;OAIG;IACH,eAAe,CAAC,OAAO,EAAE,OAAO,GAAG,KAAK;IAUxC;;;;OAIG;IACH,aAAa,CAAC,OAAO,EAAE,OAAO,GAAG,KAAK;IAUtC;;;;;OAKG;IACH,eAAe,CAAC,OAAO,EAAE,OAAO,GAAG,KAAK;IAYxC;;;;;;;;;;;OAWG;IACH,SAAS,CAAC,KAAK,EAAE,SAAS,GAAG,QAAQ,EAAE,MAAM,SAAM,GAAG,KAAK;IAwB3D;;;;OAIG;IACH,aAAa,CAAC,KAAK,EAAE,SAAS,GAAG,QAAQ,GAAG,MAAM;IA0BlD;;;OAGG;IACH,qBAAqB,IAAI,KAAK;IAU9B;;;;OAIG;IACH,kBAAkB,IAAI,SAAS;IAa/B;;;;OAIG;IACH,cAAc,IAAI,KAAK;IAWvB;;;;OAIG;IACH,eAAe,IAAI,MAAM;IAczB;;;;OAIG;IACH,aAAa,CAAC,KAAK,EAAE,SAAS,GAAG,QAAQ,GAAG,MAAM,GAAG,IAAI,GAAG,KAAK;IAQjE;;;OAGG;IACH,YAAY,IAAI,OAAO;IAQvB;;;;;OAKG;IACH,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,IAAI;IAI3C;;;;;OAKG;IACH,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,IAAI;IAI3C;;;;;OAKG;IACH,MAAM,CAAC,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,GAAG;IAIzC;;;;;OAKG;IACH,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,IAAI;IAI3C;;;;;OAKG;IACH,MAAM,CAAC,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,GAAG;IAIzC;;;;;OAKG;IACH,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,IAAI;IAI3C;;;;;;;OAOG;IACH,MAAM,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,QAAQ;CA6DnD"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/** Colors based on the ASCII value (index) of the letter. */
|
|
2
|
-
export declare const ALPHABET_COLOR_PALETTE: readonly string[];
|
|
2
|
+
export declare const ALPHABET_COLOR_PALETTE: readonly `#${string}`[];
|
|
3
3
|
/** Colors based on the index of numbers. */
|
|
4
|
-
export declare const NUMBER_COLOR_PALETTE: readonly string[];
|
|
4
|
+
export declare const NUMBER_COLOR_PALETTE: readonly `#${string}`[];
|
|
5
5
|
//# sourceMappingURL=constants.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/colors/constants.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../src/colors/constants.ts"],"names":[],"mappings":"AAEA,6DAA6D;AAC7D,eAAO,MAAM,sBAAsB,yBA2BnB,CAAC;AAEjB,4CAA4C;AAC5C,eAAO,MAAM,oBAAoB,yBAWjB,CAAC"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { Percent } from '../number/types';
|
|
2
|
-
import type { AlphaValue, Hex6, Hex8, HSL, HSLA, RGB, RGBA } from './types';
|
|
2
|
+
import type { AlphaValue, Hex, Hex6, Hex8, HSL, HSLA, RGB, RGBA } from './types';
|
|
3
3
|
/**
|
|
4
4
|
* * Converts opacity percentage (0-100) to a 2-digit hex string.
|
|
5
5
|
*
|
|
@@ -9,11 +9,11 @@ import type { AlphaValue, Hex6, Hex8, HSL, HSLA, RGB, RGBA } from './types';
|
|
|
9
9
|
export declare const _convertOpacityToHex: (opacity: Percent) => string;
|
|
10
10
|
/**
|
|
11
11
|
* * Applies an opacity value to a color string.
|
|
12
|
-
* @param color The color string to apply opacity to.
|
|
12
|
+
* @param color The color string in hex to apply opacity to.
|
|
13
13
|
* @param opacity The opacity value as a percentage (0-100).
|
|
14
14
|
* @returns The color string with the opacity value applied.
|
|
15
15
|
*/
|
|
16
|
-
export declare const _applyOpacity: (color:
|
|
16
|
+
export declare const _applyOpacity: (color: Hex, opacity: string) => Hex8;
|
|
17
17
|
/**
|
|
18
18
|
* * Helper function to generate a random HSL color.
|
|
19
19
|
*
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../../../src/colors/helpers.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../../../src/colors/helpers.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,KAAK,EACX,UAAU,EACV,GAAG,EACH,IAAI,EACJ,IAAI,EACJ,GAAG,EACH,IAAI,EACJ,GAAG,EACH,IAAI,EACJ,MAAM,SAAS,CAAC;AAEjB;;;;;GAKG;AACH,eAAO,MAAM,oBAAoB,GAAI,SAAS,OAAO,KAAG,MAOvD,CAAC;AAEF;;;;;GAKG;AACH,eAAO,MAAM,aAAa,GAAI,OAAO,GAAG,EAAE,SAAS,MAAM,KAAG,IAE3D,CAAC;AAEF;;;;GAIG;AACH,eAAO,MAAM,kBAAkB,QAAO,GAKrC,CAAC;AAEF;;;;;;;GAOG;AACH,eAAO,MAAM,gBAAgB,GAC5B,cAAc,MAAM,EAAE,EACtB,UAAU,MAAM,KACd,OA2BF,CAAC;AAEF;;;;;GAKG;AACH,wBAAgB,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,IAAI,CAEpD;AAED;;;;;GAKG;AACH,wBAAgB,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,IAAI,CAEpD;AAED;;;;;GAKG;AACH,wBAAgB,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,GAAG,CAalD;AAED;;;;;GAKG;AACH,wBAAgB,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,IAAI,CAcpD;AAED;;;;;GAKG;AACH,wBAAgB,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,GAAG,CASlD;AAED;;;;;GAKG;AACH,wBAAgB,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,IAAI,CAcpD;AAED;;;;;GAKG;AACH,wBAAgB,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,IAAI,UAAU,CAEhE;AAED,kDAAkD;AAClD,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAE3D;AAED,4CAA4C;AAC5C,wBAAgB,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAElD;AAED,8DAA8D;AAC9D,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAEzD"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import type { Percent } from '../number/types';
|
|
2
|
-
import type { ColorInputArray } from './types';
|
|
2
|
+
import type { ColorInputArray, Hex8 } from './types';
|
|
3
3
|
/**
|
|
4
|
-
* * Generates a hex color based on the first character (initial) of a string or number.
|
|
4
|
+
* * Generates a hex (`Hex8` format) color based on the first character (initial) of a string or number.
|
|
5
5
|
*
|
|
6
6
|
* - For numbers, it uses 10 predefined colors (0-9).
|
|
7
7
|
* - For letters, it uses 26 predefined colors (A-Z).
|
|
@@ -10,9 +10,9 @@ import type { ColorInputArray } from './types';
|
|
|
10
10
|
* @param opacity - A value from 0 to 100 representing the opacity percentage.
|
|
11
11
|
* @returns A hex color for the first character of the provided string/number.
|
|
12
12
|
*/
|
|
13
|
-
export declare function getColorForInitial(input: string | number, opacity?: Percent):
|
|
13
|
+
export declare function getColorForInitial(input: string | number, opacity?: Percent): Hex8;
|
|
14
14
|
/**
|
|
15
|
-
* * Generates an array of hex colors based on the first character (initial) of an array of strings/numbers or even nested arrays of strings/numbers.
|
|
15
|
+
* * Generates an array of hex (`Hex8` format) colors based on the first character (initial) of an array of strings/numbers or even nested arrays of strings/numbers.
|
|
16
16
|
*
|
|
17
17
|
* - For numbers, it uses 10 predefined colors (0-9).
|
|
18
18
|
* - For letters, it uses 26 predefined colors (A-Z).
|
|
@@ -22,5 +22,5 @@ export declare function getColorForInitial(input: string | number, opacity?: Per
|
|
|
22
22
|
* @param opacity - A value from 0 to 100 representing the opacity percentage.
|
|
23
23
|
* @returns A hex color for a string/number, or an array of hex colors for each element of the provided array.
|
|
24
24
|
*/
|
|
25
|
-
export declare function getColorForInitial(input: ColorInputArray, opacity?: Percent):
|
|
25
|
+
export declare function getColorForInitial(input: ColorInputArray, opacity?: Percent): Hex8[];
|
|
26
26
|
//# sourceMappingURL=initials.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"initials.d.ts","sourceRoot":"","sources":["../../../src/colors/initials.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAG/C,OAAO,KAAK,EAAc,eAAe,EAAE,MAAM,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"initials.d.ts","sourceRoot":"","sources":["../../../src/colors/initials.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAG/C,OAAO,KAAK,EAAc,eAAe,EAAE,IAAI,EAAE,MAAM,SAAS,CAAC;AAEjE;;;;;;;;;GASG;AACH,wBAAgB,kBAAkB,CACjC,KAAK,EAAE,MAAM,GAAG,MAAM,EACtB,OAAO,CAAC,EAAE,OAAO,GACf,IAAI,CAAC;AAER;;;;;;;;;;GAUG;AACH,wBAAgB,kBAAkB,CACjC,KAAK,EAAE,eAAe,EACtB,OAAO,CAAC,EAAE,OAAO,GACf,IAAI,EAAE,CAAC"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { HSL, RandomHexRGB } from './types';
|
|
2
2
|
/**
|
|
3
3
|
* * Utility to generate a unique random HSL color.
|
|
4
4
|
*
|
|
@@ -7,13 +7,10 @@ import type { Hex6, HSL, RGB } from './types';
|
|
|
7
7
|
*/
|
|
8
8
|
export declare const generateRandomHSLColor: (maxColors?: number) => HSL;
|
|
9
9
|
/**
|
|
10
|
-
* * Utility to generate a unique random color in
|
|
10
|
+
* * Utility to generate a unique random color in Hex6 and RGB format.
|
|
11
11
|
*
|
|
12
12
|
* @param maxColors - The maximum number of recent colors to store in memory. Default is `16`.
|
|
13
13
|
* @returns An object of generated unique random color in both `Hex` and `RGB` formats.
|
|
14
14
|
*/
|
|
15
|
-
export declare const generateRandomColorInHexRGB: (maxColors?: number) =>
|
|
16
|
-
hex: Hex6;
|
|
17
|
-
rgb: RGB;
|
|
18
|
-
};
|
|
15
|
+
export declare const generateRandomColorInHexRGB: (maxColors?: number) => RandomHexRGB;
|
|
19
16
|
//# sourceMappingURL=random.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"random.d.ts","sourceRoot":"","sources":["../../../src/colors/random.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"random.d.ts","sourceRoot":"","sources":["../../../src/colors/random.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,GAAG,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAQjD;;;;;GAKG;AACH,eAAO,MAAM,sBAAsB,GAAI,YAAW,MAAW,KAAG,GAqB/D,CAAC;AAEF;;;;;GAKG;AACH,eAAO,MAAM,2BAA2B,GAAI,kBAAc,KAAG,YAE5D,CAAC"}
|
|
@@ -48,6 +48,13 @@ export type RGBA = `rgba(${number}, ${number}, ${number}, ${number})` | `rgba(${
|
|
|
48
48
|
* * Format: `hsla(H, S%, L%, A)`
|
|
49
49
|
*/
|
|
50
50
|
export type HSLA = `hsla(${number}, ${number}%, ${number}%, ${number})` | `hsla(${number},${number}%,${number}%,${number})`;
|
|
51
|
+
/** Represents an object with `hex` (`hex6`) and `rgb` color */
|
|
52
|
+
export type RandomHexRGB = {
|
|
53
|
+
/** Represents a hexadecimal color code. */
|
|
54
|
+
hex: Hex6;
|
|
55
|
+
/** Represents an RGB color string. */
|
|
56
|
+
rgb: RGB;
|
|
57
|
+
};
|
|
51
58
|
/** * Union type representing a color in Hex6, RGB, or HSL format. */
|
|
52
59
|
export type ColorTypeSolid = Hex6 | RGB | HSL;
|
|
53
60
|
/** * Union type representing a color in Hex8, RGBA, or HSLA format. */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/colors/types.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/colors/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -80,7 +80,7 @@ export type KeysOfUnion<T> = T extends T ? keyof T : never;
|
|
|
80
80
|
* // { a?: string; nested?: { b?: number } }
|
|
81
81
|
*/
|
|
82
82
|
export type DeepPartial<T> = {
|
|
83
|
-
[K in keyof T]?: T[K] extends object ? DeepPartial<T[K]> : T[K];
|
|
83
|
+
[K in keyof T]?: T[K] extends AdvancedTypes ? T[K] : T[K] extends object ? DeepPartial<T[K]> : T[K];
|
|
84
84
|
};
|
|
85
85
|
/**
|
|
86
86
|
* * Removes `readonly` modifiers from all properties of an object type.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/utils/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AACzE,OAAO,KAAK,EAAE,aAAa,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AAE7D,sCAAsC;AACtC,MAAM,WAAW,gBAAgB;IAChC,iCAAiC;IACjC,UAAU,EAAE,OAAO,CAAC;IACpB,mDAAmD;IACnD,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,6CAA6C;IAC7C,WAAW,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,yBAAyB;AACzB,MAAM,WAAW,aAAa;IAC7B,4CAA4C;IAC5C,UAAU,EAAE,MAAM,CAAC;IACnB,iDAAiD;IACjD,WAAW,EAAE,MAAM,CAAC;IACpB,sDAAsD;IACtD,YAAY,EAAE,MAAM,CAAC;IACrB,0EAA0E;IAC1E,UAAU,EAAE,MAAM,CAAC;IACnB,oDAAoD;IACpD,OAAO,EAAE,OAAO,CAAC;IACjB,gDAAgD;IAChD,OAAO,EAAE,OAAO,CAAC;IACjB,kDAAkD;IAClD,OAAO,EAAE,OAAO,CAAC;IACjB,iDAAiD;IACjD,MAAM,EAAE,OAAO,CAAC;IAChB,qEAAqE;IACrE,MAAM,EAAE,MAAM,CAAC;CACf;AAED,qCAAqC;AACrC,MAAM,MAAM,eAAe,GAAG,IAAI,CACjC,aAAa,EACb,YAAY,GAAG,cAAc,GAAG,aAAa,CAC7C,CAAC;AAEF,mCAAmC;AACnC,MAAM,WAAW,eAAe;IAC/B,uDAAuD;IACvD,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,4EAA4E;IAC5E,YAAY,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,4DAA4D;AAC5D,MAAM,WAAW,gCAAgC;IAChD,4DAA4D;IAC5D,SAAS,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,6EAA6E;AAC7E,MAAM,WAAW,6BAA6B,CAAC,CAAC;IAC/C,iEAAiE;IACjE,MAAM,EAAE,CAAC,SAAS,aAAa,GAAG,kBAAkB,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC;IAChE,4DAA4D;IAC5D,SAAS,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,yDAAyD;AACzD,MAAM,MAAM,oBAAoB,CAAC,CAAC,IAC/B,gCAAgC,GAChC,6BAA6B,CAAC,CAAC,CAAC,CAAC;AAIpC;;;;;;GAMG;AACH,MAAM,MAAM,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;AAEpC;;;;;;;;GAQG;AACH,MAAM,MAAM,WAAW,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,MAAM,CAAC,GAAG,KAAK,CAAC;AAE3D;;;;;;;GAOG;AACH,MAAM,MAAM,WAAW,CAAC,CAAC,IAAI;KAC3B,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,MAAM,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/utils/types.ts"],"names":[],"mappings":"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"}
|
package/dist/esm/colors/Color.js
CHANGED
|
@@ -428,7 +428,9 @@ export class Color {
|
|
|
428
428
|
const { hex8, rgba } = convertColorCode(color);
|
|
429
429
|
return { hex8, rgba, hsla: color };
|
|
430
430
|
}
|
|
431
|
-
throw new
|
|
431
|
+
throw new TypeError(`${color} is not a valid color!`, {
|
|
432
|
+
cause: 'Unrecognized Color Format',
|
|
433
|
+
});
|
|
432
434
|
}
|
|
433
435
|
/**
|
|
434
436
|
* @private @static Internal factory to create a Color instance from parsed parts.
|
|
@@ -303,5 +303,7 @@ export function convertColorCode(color) {
|
|
|
303
303
|
rgba: convertHslaToRgba(...hslaValues),
|
|
304
304
|
};
|
|
305
305
|
}
|
|
306
|
-
throw new
|
|
306
|
+
throw new TypeError(`${color} is not a valid color!`, {
|
|
307
|
+
cause: 'Unrecognized Color Format',
|
|
308
|
+
});
|
|
307
309
|
}
|
|
@@ -14,12 +14,12 @@ export const _convertOpacityToHex = (opacity) => {
|
|
|
14
14
|
};
|
|
15
15
|
/**
|
|
16
16
|
* * Applies an opacity value to a color string.
|
|
17
|
-
* @param color The color string to apply opacity to.
|
|
17
|
+
* @param color The color string in hex to apply opacity to.
|
|
18
18
|
* @param opacity The opacity value as a percentage (0-100).
|
|
19
19
|
* @returns The color string with the opacity value applied.
|
|
20
20
|
*/
|
|
21
21
|
export const _applyOpacity = (color, opacity) => {
|
|
22
|
-
return color.concat(opacity);
|
|
22
|
+
return color?.slice(0, 7).concat(opacity);
|
|
23
23
|
};
|
|
24
24
|
/**
|
|
25
25
|
* * Helper function to generate a random HSL color.
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { ALPHABET_COLOR_PALETTE, NUMBER_COLOR_PALETTE } from './constants.js';
|
|
2
2
|
import { _applyOpacity, _convertOpacityToHex } from './helpers.js';
|
|
3
3
|
/**
|
|
4
|
-
* * Generates a hex color based on the first character (initial) of a string or number; or an array of hex colors based on the first character (initial) of an array of strings/numbers or even nested arrays of strings/numbers.
|
|
4
|
+
* * Generates a hex color (`Hex8` format) based on the first character (initial) of a string or number; or an array of hex colors based on the first character (initial) of an array of strings/numbers or even nested arrays of strings/numbers.
|
|
5
5
|
*
|
|
6
6
|
* - For numbers, it uses 10 predefined colors (0-9).
|
|
7
7
|
* - For letters, it uses 26 predefined colors (A-Z).
|
|
@@ -14,15 +14,16 @@ import { _applyOpacity, _convertOpacityToHex } from './helpers.js';
|
|
|
14
14
|
export function getColorForInitial(input = '', opacity = 100) {
|
|
15
15
|
let initial;
|
|
16
16
|
const hexOpacity = _convertOpacityToHex(opacity);
|
|
17
|
-
const
|
|
17
|
+
const NUMBERS = '0123456789';
|
|
18
|
+
const DEFAULT = '#010514';
|
|
18
19
|
// Handle empty string case
|
|
19
20
|
if (!input)
|
|
20
|
-
return _applyOpacity(
|
|
21
|
+
return _applyOpacity(DEFAULT, hexOpacity);
|
|
21
22
|
// Handle string input
|
|
22
23
|
if (typeof input === 'string') {
|
|
23
24
|
initial = input[0];
|
|
24
25
|
// Handle number as string
|
|
25
|
-
if (
|
|
26
|
+
if (NUMBERS.includes(initial)) {
|
|
26
27
|
return _applyOpacity(NUMBER_COLOR_PALETTE[parseInt(initial, 10)], hexOpacity);
|
|
27
28
|
}
|
|
28
29
|
const upperInitial = initial.toUpperCase();
|
|
@@ -31,15 +32,15 @@ export function getColorForInitial(input = '', opacity = 100) {
|
|
|
31
32
|
if (index >= 0 && index < ALPHABET_COLOR_PALETTE?.length) {
|
|
32
33
|
return _applyOpacity(ALPHABET_COLOR_PALETTE[index], hexOpacity);
|
|
33
34
|
}
|
|
34
|
-
return _applyOpacity(
|
|
35
|
+
return _applyOpacity(DEFAULT, hexOpacity);
|
|
35
36
|
// Handle number input
|
|
36
37
|
}
|
|
37
38
|
else if (typeof input === 'number' && !isNaN(input)) {
|
|
38
39
|
initial = input.toString()[0];
|
|
39
|
-
if (
|
|
40
|
+
if (NUMBERS.includes(initial)) {
|
|
40
41
|
return _applyOpacity(NUMBER_COLOR_PALETTE[parseInt(initial, 10)], hexOpacity);
|
|
41
42
|
}
|
|
42
|
-
return _applyOpacity(
|
|
43
|
+
return _applyOpacity(DEFAULT, hexOpacity);
|
|
43
44
|
// Handle array of strings/numbers
|
|
44
45
|
}
|
|
45
46
|
else if (Array.isArray(input)) {
|
|
@@ -54,5 +55,5 @@ export function getColorForInitial(input = '', opacity = 100) {
|
|
|
54
55
|
})
|
|
55
56
|
.flat();
|
|
56
57
|
}
|
|
57
|
-
return _applyOpacity(
|
|
58
|
+
return _applyOpacity(DEFAULT, hexOpacity);
|
|
58
59
|
}
|
|
@@ -27,7 +27,7 @@ export const generateRandomHSLColor = (maxColors = 16) => {
|
|
|
27
27
|
return color;
|
|
28
28
|
};
|
|
29
29
|
/**
|
|
30
|
-
* * Utility to generate a unique random color in
|
|
30
|
+
* * Utility to generate a unique random color in Hex6 and RGB format.
|
|
31
31
|
*
|
|
32
32
|
* @param maxColors - The maximum number of recent colors to store in memory. Default is `16`.
|
|
33
33
|
* @returns An object of generated unique random color in both `Hex` and `RGB` formats.
|
|
@@ -92,7 +92,7 @@ export function trimString(input) {
|
|
|
92
92
|
if (!input)
|
|
93
93
|
return '';
|
|
94
94
|
// If the input is a string, trim each word
|
|
95
|
-
if (typeof input === 'string'
|
|
95
|
+
if (typeof input === 'string') {
|
|
96
96
|
return input?.trim()?.replace(/\s+/g, ' ');
|
|
97
97
|
}
|
|
98
98
|
// If the input is an array of strings, trim each string in the array
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "nhb-toolbox",
|
|
3
|
-
"version": "4.14.
|
|
3
|
+
"version": "4.14.14",
|
|
4
4
|
"description": "A versatile collection of smart, efficient, and reusable utility functions and classes for everyday development needs.",
|
|
5
5
|
"main": "dist/cjs/index.js",
|
|
6
6
|
"module": "dist/esm/index.js",
|