aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authornetop://ウィビ <paul@webb.page>2026-04-25 12:29:59 -0700
committernetop://ウィビ <paul@webb.page>2026-04-25 12:29:59 -0700
commitdc5fff0c0afdf832b9b000e13ddc633f72749e01 (patch)
tree5730bd4ea089dadbc9c7f057a3988104fb662827 /src
parenta2118aa39a00e02cdf3f6c306e17fd04676ea518 (diff)
downloaduchu-dc5fff0c0afdf832b9b000e13ddc633f72749e01.tar.gz
uchu-dc5fff0c0afdf832b9b000e13ddc633f72749e01.zip
fantastic update
Diffstat (limited to '')
-rw-r--r--src/colors.ts217
-rw-r--r--src/index.ts61
2 files changed, 278 insertions, 0 deletions
diff --git a/src/colors.ts b/src/colors.ts
new file mode 100644
index 0000000..fe32e2a
--- /dev/null
+++ b/src/colors.ts
@@ -0,0 +1,217 @@
+
+
+
+/*** UTILITY ------------------------------------------ ***/
+
+const raw = {
+ blue: {
+ 1: "89.66% 0.046 260.67",
+ 2: "80.17% 0.091 258.88",
+ 3: "70.94% 0.136 258.06",
+ 4: "62.39% 0.181 258.33",
+ 5: "54.87% 0.222 260.33",
+ 6: "51.15% 0.204 260.17",
+ 7: "47.36% 0.185 259.89",
+ 8: "43.48% 0.17 260.2",
+ 9: "39.53% 0.15 259.87"
+ },
+ gray: {
+ 1: "95.57% 0.003 286.35",
+ 2: "92.04% 0.002 197.12",
+ 3: "88.28% 0.003 286.34",
+ 4: "84.68% 0.002 197.12",
+ 5: "80.73% 0.002 247.84",
+ 6: "75.03% 0.002 247.85",
+ 7: "69.01% 0.003 286.32",
+ 8: "63.12% 0.004 219.55",
+ 9: "56.82% 0.004 247.89"
+ },
+ green: {
+ 1: "93.96% 0.05 148.74",
+ 2: "88.77% 0.096 147.71",
+ 3: "83.74% 0.139 146.57",
+ 4: "79.33% 0.179 145.62",
+ 5: "75.23% 0.209 144.64",
+ 6: "70.03% 0.194 144.71",
+ 7: "64.24% 0.175 144.92",
+ 8: "58.83% 0.158 145.05",
+ 9: "52.77% 0.138 145.41"
+ },
+ orange: {
+ 1: "93.83% 0.037 56.93",
+ 2: "88.37% 0.072 55.8",
+ 3: "83.56% 0.107 56.49",
+ 4: "78.75% 0.141 54.32",
+ 5: "74.61% 0.171 51.56",
+ 6: "69.33% 0.157 52.18",
+ 7: "63.8% 0.142 52.1",
+ 8: "58.28% 0.128 52.2",
+ 9: "52.49% 0.113 51.98"
+ },
+ pink: {
+ 1: "95.8% 0.023 354.27",
+ 2: "92.14% 0.046 352.31",
+ 3: "88.9% 0.066 354.39",
+ 4: "85.43% 0.09 354.1",
+ 5: "82.23% 0.112 355.33",
+ 6: "76.37% 0.101 355.37",
+ 7: "70.23% 0.092 354.96",
+ 8: "64.11% 0.084 353.91",
+ 9: "57.68% 0.074 353.14"
+ },
+ purple: {
+ 1: "89.1% 0.046 305.24",
+ 2: "78.68% 0.091 305",
+ 3: "68.5% 0.136 303.78",
+ 4: "58.47% 0.181 302.06",
+ 5: "49.39% 0.215 298.31",
+ 6: "46.11% 0.198 298.4",
+ 7: "42.77% 0.181 298.49",
+ 8: "39.46% 0.164 298.29",
+ 9: "36.01% 0.145 298.35"
+ },
+ red: {
+ 1: "88.98% 0.052 3.28",
+ 2: "78.78% 0.109 4.54",
+ 3: "69.86% 0.162 7.82",
+ 4: "62.73% 0.209 12.37",
+ 5: "58.63% 0.231 19.6",
+ 6: "54.41% 0.214 19.06",
+ 7: "49.95% 0.195 18.34",
+ 8: "45.8% 0.177 17.7",
+ 9: "41.17% 0.157 16.58"
+ },
+ yellow: {
+ 1: "97.05% 0.039 91.2",
+ 2: "95% 0.07 92.39",
+ 3: "92.76% 0.098 92.58",
+ 4: "90.92% 0.125 92.56",
+ 5: "89% 0.146 91.5",
+ 6: "82.39% 0.133 91.5",
+ 7: "75.84% 0.122 92.21",
+ 8: "69.14% 0.109 91.04",
+ 9: "62.29% 0.097 91.9"
+ },
+ yin: {
+ 1: "91.87% 0.003 264.54",
+ 2: "84.61% 0.004 286.31",
+ 3: "76.89% 0.004 247.87",
+ 4: "69.17% 0.004 247.88",
+ 5: "61.01% 0.005 271.34",
+ 6: "52.79% 0.005 271.32",
+ 7: "43.87% 0.005 271.3",
+ 8: "35.02% 0.005 236.66",
+ 9: "25.11% 0.006 258.36"
+ }
+} as const;
+
+/*** EXPORT ------------------------------------------- ***/
+
+export const palette = {
+ blue: {
+ 1: `oklch(${raw.blue[1]})`,
+ 2: `oklch(${raw.blue[2]})`,
+ 3: `oklch(${raw.blue[3]})`,
+ 4: `oklch(${raw.blue[4]})`,
+ 5: `oklch(${raw.blue[5]})`,
+ 6: `oklch(${raw.blue[6]})`,
+ 7: `oklch(${raw.blue[7]})`,
+ 8: `oklch(${raw.blue[8]})`,
+ 9: `oklch(${raw.blue[9]})`
+ },
+ gray: {
+ 1: `oklch(${raw.gray[1]})`,
+ 2: `oklch(${raw.gray[2]})`,
+ 3: `oklch(${raw.gray[3]})`,
+ 4: `oklch(${raw.gray[4]})`,
+ 5: `oklch(${raw.gray[5]})`,
+ 6: `oklch(${raw.gray[6]})`,
+ 7: `oklch(${raw.gray[7]})`,
+ 8: `oklch(${raw.gray[8]})`,
+ 9: `oklch(${raw.gray[9]})`
+ },
+ green: {
+ 1: `oklch(${raw.green[1]})`,
+ 2: `oklch(${raw.green[2]})`,
+ 3: `oklch(${raw.green[3]})`,
+ 4: `oklch(${raw.green[4]})`,
+ 5: `oklch(${raw.green[5]})`,
+ 6: `oklch(${raw.green[6]})`,
+ 7: `oklch(${raw.green[7]})`,
+ 8: `oklch(${raw.green[8]})`,
+ 9: `oklch(${raw.green[9]})`
+ },
+ orange: {
+ 1: `oklch(${raw.orange[1]})`,
+ 2: `oklch(${raw.orange[2]})`,
+ 3: `oklch(${raw.orange[3]})`,
+ 4: `oklch(${raw.orange[4]})`,
+ 5: `oklch(${raw.orange[5]})`,
+ 6: `oklch(${raw.orange[6]})`,
+ 7: `oklch(${raw.orange[7]})`,
+ 8: `oklch(${raw.orange[8]})`,
+ 9: `oklch(${raw.orange[9]})`
+ },
+ pink: {
+ 1: `oklch(${raw.pink[1]})`,
+ 2: `oklch(${raw.pink[2]})`,
+ 3: `oklch(${raw.pink[3]})`,
+ 4: `oklch(${raw.pink[4]})`,
+ 5: `oklch(${raw.pink[5]})`,
+ 6: `oklch(${raw.pink[6]})`,
+ 7: `oklch(${raw.pink[7]})`,
+ 8: `oklch(${raw.pink[8]})`,
+ 9: `oklch(${raw.pink[9]})`
+ },
+ purple: {
+ 1: `oklch(${raw.purple[1]})`,
+ 2: `oklch(${raw.purple[2]})`,
+ 3: `oklch(${raw.purple[3]})`,
+ 4: `oklch(${raw.purple[4]})`,
+ 5: `oklch(${raw.purple[5]})`,
+ 6: `oklch(${raw.purple[6]})`,
+ 7: `oklch(${raw.purple[7]})`,
+ 8: `oklch(${raw.purple[8]})`,
+ 9: `oklch(${raw.purple[9]})`
+ },
+ red: {
+ 1: `oklch(${raw.red[1]})`,
+ 2: `oklch(${raw.red[2]})`,
+ 3: `oklch(${raw.red[3]})`,
+ 4: `oklch(${raw.red[4]})`,
+ 5: `oklch(${raw.red[5]})`,
+ 6: `oklch(${raw.red[6]})`,
+ 7: `oklch(${raw.red[7]})`,
+ 8: `oklch(${raw.red[8]})`,
+ 9: `oklch(${raw.red[9]})`
+ },
+ yellow: {
+ 1: `oklch(${raw.yellow[1]})`,
+ 2: `oklch(${raw.yellow[2]})`,
+ 3: `oklch(${raw.yellow[3]})`,
+ 4: `oklch(${raw.yellow[4]})`,
+ 5: `oklch(${raw.yellow[5]})`,
+ 6: `oklch(${raw.yellow[6]})`,
+ 7: `oklch(${raw.yellow[7]})`,
+ 8: `oklch(${raw.yellow[8]})`,
+ 9: `oklch(${raw.yellow[9]})`
+ },
+ yin: {
+ 1: `oklch(${raw.yin[1]})`,
+ 2: `oklch(${raw.yin[2]})`,
+ 3: `oklch(${raw.yin[3]})`,
+ 4: `oklch(${raw.yin[4]})`,
+ 5: `oklch(${raw.yin[5]})`,
+ 6: `oklch(${raw.yin[6]})`,
+ 7: `oklch(${raw.yin[7]})`,
+ 8: `oklch(${raw.yin[8]})`,
+ 9: `oklch(${raw.yin[9]})`
+ }
+} as const;
+
+export { raw };
+export const yang = "oklch(99.4% 0 0)" as const;
+export const yin = "oklch(14.38% 0.007 256.88)" as const;
+
+export type Hue = keyof typeof palette;
+export type Shade = keyof typeof palette[Hue];
diff --git a/src/index.ts b/src/index.ts
new file mode 100644
index 0000000..ba34358
--- /dev/null
+++ b/src/index.ts
@@ -0,0 +1,61 @@
+
+
+
+/*** UTILITY ------------------------------------------ ***/
+
+import { palette } from "./colors";
+
+/*** EXPORT ------------------------------------------- ***/
+
+export { palette, raw, yang, yin } from "./colors";
+export type { Hue, Shade } from "./colors";
+
+export const color = (hue: keyof typeof palette, shade: 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9): string => {
+ return palette[hue][shade];
+};
+
+export const reduced = {
+ blue: {
+ 1: palette.blue[1],
+ 2: palette.blue[4],
+ 3: palette.blue[8]
+ },
+ gray: {
+ 1: palette.gray[1],
+ 2: palette.gray[4],
+ 3: palette.gray[8]
+ },
+ green: {
+ 1: palette.green[1],
+ 2: palette.green[4],
+ 3: palette.green[8]
+ },
+ orange: {
+ 1: palette.orange[1],
+ 2: palette.orange[4],
+ 3: palette.orange[8]
+ },
+ pink: {
+ 1: palette.pink[1],
+ 2: palette.pink[4],
+ 3: palette.pink[8]
+ },
+ purple: {
+ 1: palette.purple[1],
+ 2: palette.purple[4],
+ 3: palette.purple[8]
+ },
+ red: {
+ 1: palette.red[1],
+ 2: palette.red[4],
+ 3: palette.red[8]
+ },
+ yellow: {
+ 1: palette.yellow[1],
+ 2: palette.yellow[4],
+ 3: palette.yellow[8]
+ },
+ yin: {
+ 1: palette.yin[1]
+ }
+} as const;