Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

still simplyifying codebase #258

Open
wants to merge 23 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 8 commits
Commits
Show all changes
23 commits
Select commit Hold shift + click to select a range
93105a5
still simplyifying codebase
prjctimg Nov 24, 2024
e2831d4
configured the default git credentials
xmlwizard Nov 24, 2024
890abe0
fixed some typos
xmlwizard Nov 24, 2024
a0b776d
fixed some typos
xmlwizard Nov 24, 2024
d06b430
fix: palettes.ts now has passing tests.\n also made the palette wrapp…
xmlwizard Nov 26, 2024
148af7b
refactor: removed dead imports
xmlwizard Nov 26, 2024
31b6190
refactor: trying to fix errors in the token parser
xmlwizard Nov 26, 2024
660f787
token parser now performs back and forth conversions without throwing
xmlwizard Nov 27, 2024
f94e668
refactor: trying to debug collection functions
xmlwizard Nov 27, 2024
7466f52
refactor: debugging the sortBy utility. the codebase is messed up bro
xmlwizard Nov 28, 2024
9e9a5e0
fix: mc utility now returns expected chsnnel values. fixed bug in tok…
xmlwizard Dec 5, 2024
a511a5c
stashed changes
xmlwizard Dec 8, 2024
4e49258
fix: alpha now fetches the alpha channel correctly from arrays
xmlwizard Dec 8, 2024
fc0d6eb
so fckng confused right now....breaking shitt for the night
xmlwizard Dec 14, 2024
c2eaf67
fix: family() now works as expected
xmlwizard Dec 17, 2024
34fb6c8
refactor: overtone has been deprecated into an object property in fam…
xmlwizard Dec 17, 2024
f2556a0
fix: temp now works as expected
xmlwizard Dec 17, 2024
c681cb6
fix: temp now works as expected
xmlwizard Dec 17, 2024
4b5f2bb
added luminance() and lightness tests. debugging luminance
xmlwizard Dec 18, 2024
0ae8e4f
added luminance() and lightness tests. debugging luminance
xmlwizard Dec 18, 2024
a1ee1e6
fix: alpha() now sets the alpha value on arrays as expected
xmlwizard Dec 19, 2024
d369a18
fix: alpha() now sets the alpha value on arrays as expected
xmlwizard Dec 19, 2024
cad2ea9
docs:fixed docs for utils and all tests are passing🚀
xmlwizard Dec 21, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions .vscode/tasks.json
Original file line number Diff line number Diff line change
Expand Up @@ -13,13 +13,13 @@
"detail": "Check the source files for Deno compliancy or regressions."
},
{
"type": "bun",
"type": "npm",
"script": "bun test",
"label": "Test 🧪",
"detail": "Run the test suites for all publicly exported functions."
},
{
"type": "bun",
"type": "npm",
"script": "bun run build.ts",
"detail": "Build library and types to the local filesystem. For development only.",
"label": "Build 🏗",
Expand Down
Binary file modified bun.lockb
Binary file not shown.
15 changes: 15 additions & 0 deletions deno.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

123 changes: 67 additions & 56 deletions lib/collection.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@ import type {
StatsOptions,
} from "./types.d.ts";
import type { ColorToken } from "./types.d.ts";
import { colors } from "./palettes.ts";


/**
Expand Down Expand Up @@ -83,8 +84,8 @@ function stats(collection: Collection = [], options: StatsOptions = {
sortedColl(a, b, "asc")(hexColors);

// @ts-ignore:`
return or(
and(eq(relative, true), {
return (
relative === true && {
chroma: sortedTokens(
fact,
chnDiff(
Expand Down Expand Up @@ -118,7 +119,7 @@ function stats(collection: Collection = [], options: StatsOptions = {
fact,
ctrst(against),
),
}),
} ||
{
chroma: sortedTokens(
fact,
Expand All @@ -133,66 +134,66 @@ function stats(collection: Collection = [], options: StatsOptions = {
fact,
mc(`${colorspace}.h`),
),
},
}
)[fact];
};
const len: number = values(collection).length;
const factorStats = (fact: Factor) => {
// @ts-ignore:
/**
*
* @param b The callback func for computing the targeted factor. Must be unary
* @param c The function to wrap the resulting collection of computed factors in.
*/
const callback =
(b: (x?: ColorToken) => number) =>
(c: (x: number[]) => number) =>
c(map(collection, b) as number[]);
const len: number = values(collection).length,
factorStats = (fact: Factor) => {
// @ts-ignore:
/**
*
* @param b The callback func for computing the targeted factor. Must be unary
* @param c The function to wrap the resulting collection of computed factors in.
*/
const callback =
(b: (x?: ColorToken) => number) =>
(c: (x: number[]) => number) =>
c(map(collection, b) as number[]);

// @ts-ignore:
return {
chroma: callback(mc(mcchn("c", colorspace)))(
averageNumber,
),
distance: callback(dstnce(against))(
averageNumber,
),
// @ts-ignore:
return {
chroma: callback(mc(mcchn("c", colorspace)))(
averageNumber,
),
distance: callback(dstnce(against))(
averageNumber,
),

hue: callback(mc(`${colorspace}.h`))(
averageAngle,
),
lightness: callback(mc(mcchn("l", colorspace)))(
averageNumber,
),
contrast: callback(ctrst(against))(
averageNumber,
),
luminance: callback(luminance)(averageNumber),
}[fact];
};
hue: callback(mc(`${colorspace}.h`))(
averageAngle,
),
lightness: callback(mc(mcchn("l", colorspace)))(
averageNumber,
),
contrast: callback(ctrst(against))(
averageNumber,
),
luminance: callback(luminance)(averageNumber),
}[fact];
};
const commonStats = (fact: Factor) => {
const [x, y] = [
getStatsObject(fact)[0],
getStatsObject(fact)[len - 1],
];

return {
against: or(
and(
or(
relative,
eq(
fact,
or("contrast", "distance"),
),
),
against,
),
null,
against: (
(
(
relative ||
(
fact ===
"contrast" || "distance"
)
) &&
against
)
|| null
),
colors: [x.color, y.color],
// @ts-ignore:
mean: factorStats(fact)(collection),
mean: factorStats(fact),
extremums: [x[fact], y[fact]],

families: [family(x.color), family(y.color)],
Expand All @@ -212,6 +213,7 @@ function stats(collection: Collection = [], options: StatsOptions = {
return statsObject
}


/**
* Sorts colors according to the specified `factor`. The supported options are:
*
Expand Down Expand Up @@ -274,8 +276,8 @@ function sortBy(collection: Collection = [], options: SortByOptions = {
mc(`${colorspace}.${ch}`) as unknown as string;

// @ts-ignore: fact is used as the index
return or(
and(relative, {
return (
(relative && {
chroma: sort(
chnDiff(against, u(chromaChannel)),
),
Expand All @@ -284,15 +286,15 @@ function sortBy(collection: Collection = [], options: SortByOptions = {
lightness: sort(
chnDiff(against, u(lightnessChannel)),
),
}),
}) ||
{
chroma: sort(u(chromaChannel)),
hue: sort(u("h")),
luminance: sort(luminance),
distance: sort(dstnce(against)),
contrast: sort(ctrst(against)),
lightness: sort(u(lightnessChannel)),
},
}
)[fact](collection);
};
// @ts-ignore:
Expand Down Expand Up @@ -404,7 +406,16 @@ function sortBy(collection: Collection = [], options: SortByOptions = {
function filterBy(collection: Collection = [], options: FilterByOptions = {
against: 'cyan', colorspace: 'lch', factor: undefined, ranges: undefined
}): Collection {
const { against, colorspace, factor, ranges } = options
let { against, colorspace, factor, ranges } = options || {}


// handling defaults internally helps avoid undefined values as compared to passing it to the parameter list
against = against || 'cyan'
colorspace = colorspace || 'lch'
factor = factor || undefined




const filter = (cb: unknown) => (fact: Factor) =>
filteredColl(fact, cb)(collection, start, end),
Expand All @@ -428,9 +439,9 @@ function filterBy(collection: Collection = [], options: FilterByOptions = {

const callback = (fact: Factor) => {
// @ts-ignore:
start = or(ranges[fact][0], def_ranges[fact][0]);
start = ranges[fact][0] || def_ranges[fact][0]
// @ts-ignore:
end = or(ranges[fact][1], def_ranges[fact][1]);
end = ranges[fact][1] || def_ranges[fact][1]

return {
chroma: filter(
Expand Down
Loading