mirror of
				https://github.com/soybeanjs/soybean-admin.git
				synced 2025-11-04 15:53:43 +08:00 
			
		
		
		
	refactor(hooks): refactor @sa/color-palette
This commit is contained in:
		
							
								
								
									
										2
									
								
								packages/color-palette/src/constant/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								packages/color-palette/src/constant/index.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,2 @@
 | 
			
		||||
export * from './name';
 | 
			
		||||
export * from './palette';
 | 
			
		||||
							
								
								
									
										1579
									
								
								packages/color-palette/src/constant/name.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1579
									
								
								packages/color-palette/src/constant/name.ts
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										356
									
								
								packages/color-palette/src/constant/palette.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										356
									
								
								packages/color-palette/src/constant/palette.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,356 @@
 | 
			
		||||
import type { ColorPaletteFamily } from '../types';
 | 
			
		||||
 | 
			
		||||
export const colorPalettes: ColorPaletteFamily[] = [
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Slate',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#f8fafc', number: 50 },
 | 
			
		||||
      { hex: '#f1f5f9', number: 100 },
 | 
			
		||||
      { hex: '#e2e8f0', number: 200 },
 | 
			
		||||
      { hex: '#cbd5e1', number: 300 },
 | 
			
		||||
      { hex: '#94a3b8', number: 400 },
 | 
			
		||||
      { hex: '#64748b', number: 500 },
 | 
			
		||||
      { hex: '#475569', number: 600 },
 | 
			
		||||
      { hex: '#334155', number: 700 },
 | 
			
		||||
      { hex: '#1e293b', number: 800 },
 | 
			
		||||
      { hex: '#0f172a', number: 900 },
 | 
			
		||||
      { hex: '#020617', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Gray',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#f9fafb', number: 50 },
 | 
			
		||||
      { hex: '#f3f4f6', number: 100 },
 | 
			
		||||
      { hex: '#e5e7eb', number: 200 },
 | 
			
		||||
      { hex: '#d1d5db', number: 300 },
 | 
			
		||||
      { hex: '#9ca3af', number: 400 },
 | 
			
		||||
      { hex: '#6b7280', number: 500 },
 | 
			
		||||
      { hex: '#4b5563', number: 600 },
 | 
			
		||||
      { hex: '#374151', number: 700 },
 | 
			
		||||
      { hex: '#1f2937', number: 800 },
 | 
			
		||||
      { hex: '#111827', number: 900 },
 | 
			
		||||
      { hex: '#030712', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Zinc',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#fafafa', number: 50 },
 | 
			
		||||
      { hex: '#f4f4f5', number: 100 },
 | 
			
		||||
      { hex: '#e4e4e7', number: 200 },
 | 
			
		||||
      { hex: '#d4d4d8', number: 300 },
 | 
			
		||||
      { hex: '#a1a1aa', number: 400 },
 | 
			
		||||
      { hex: '#71717a', number: 500 },
 | 
			
		||||
      { hex: '#52525b', number: 600 },
 | 
			
		||||
      { hex: '#3f3f46', number: 700 },
 | 
			
		||||
      { hex: '#27272a', number: 800 },
 | 
			
		||||
      { hex: '#18181b', number: 900 },
 | 
			
		||||
      { hex: '#09090b', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Neutral',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#fafafa', number: 50 },
 | 
			
		||||
      { hex: '#f5f5f5', number: 100 },
 | 
			
		||||
      { hex: '#e5e5e5', number: 200 },
 | 
			
		||||
      { hex: '#d4d4d4', number: 300 },
 | 
			
		||||
      { hex: '#a3a3a3', number: 400 },
 | 
			
		||||
      { hex: '#737373', number: 500 },
 | 
			
		||||
      { hex: '#525252', number: 600 },
 | 
			
		||||
      { hex: '#404040', number: 700 },
 | 
			
		||||
      { hex: '#262626', number: 800 },
 | 
			
		||||
      { hex: '#171717', number: 900 },
 | 
			
		||||
      { hex: '#0a0a0a', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Stone',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#fafaf9', number: 50 },
 | 
			
		||||
      { hex: '#f5f5f4', number: 100 },
 | 
			
		||||
      { hex: '#e7e5e4', number: 200 },
 | 
			
		||||
      { hex: '#d6d3d1', number: 300 },
 | 
			
		||||
      { hex: '#a8a29e', number: 400 },
 | 
			
		||||
      { hex: '#78716c', number: 500 },
 | 
			
		||||
      { hex: '#57534e', number: 600 },
 | 
			
		||||
      { hex: '#44403c', number: 700 },
 | 
			
		||||
      { hex: '#292524', number: 800 },
 | 
			
		||||
      { hex: '#1c1917', number: 900 },
 | 
			
		||||
      { hex: '#0c0a09', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Red',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#fef2f2', number: 50 },
 | 
			
		||||
      { hex: '#fee2e2', number: 100 },
 | 
			
		||||
      { hex: '#fecaca', number: 200 },
 | 
			
		||||
      { hex: '#fca5a5', number: 300 },
 | 
			
		||||
      { hex: '#f87171', number: 400 },
 | 
			
		||||
      { hex: '#ef4444', number: 500 },
 | 
			
		||||
      { hex: '#dc2626', number: 600 },
 | 
			
		||||
      { hex: '#b91c1c', number: 700 },
 | 
			
		||||
      { hex: '#991b1b', number: 800 },
 | 
			
		||||
      { hex: '#7f1d1d', number: 900 },
 | 
			
		||||
      { hex: '#450a0a', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Orange',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#fff7ed', number: 50 },
 | 
			
		||||
      { hex: '#ffedd5', number: 100 },
 | 
			
		||||
      { hex: '#fed7aa', number: 200 },
 | 
			
		||||
      { hex: '#fdba74', number: 300 },
 | 
			
		||||
      { hex: '#fb923c', number: 400 },
 | 
			
		||||
      { hex: '#f97316', number: 500 },
 | 
			
		||||
      { hex: '#ea580c', number: 600 },
 | 
			
		||||
      { hex: '#c2410c', number: 700 },
 | 
			
		||||
      { hex: '#9a3412', number: 800 },
 | 
			
		||||
      { hex: '#7c2d12', number: 900 },
 | 
			
		||||
      { hex: '#431407', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Amber',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#fffbeb', number: 50 },
 | 
			
		||||
      { hex: '#fef3c7', number: 100 },
 | 
			
		||||
      { hex: '#fde68a', number: 200 },
 | 
			
		||||
      { hex: '#fcd34d', number: 300 },
 | 
			
		||||
      { hex: '#fbbf24', number: 400 },
 | 
			
		||||
      { hex: '#f59e0b', number: 500 },
 | 
			
		||||
      { hex: '#d97706', number: 600 },
 | 
			
		||||
      { hex: '#b45309', number: 700 },
 | 
			
		||||
      { hex: '#92400e', number: 800 },
 | 
			
		||||
      { hex: '#78350f', number: 900 },
 | 
			
		||||
      { hex: '#451a03', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Yellow',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#fefce8', number: 50 },
 | 
			
		||||
      { hex: '#fef9c3', number: 100 },
 | 
			
		||||
      { hex: '#fef08a', number: 200 },
 | 
			
		||||
      { hex: '#fde047', number: 300 },
 | 
			
		||||
      { hex: '#facc15', number: 400 },
 | 
			
		||||
      { hex: '#eab308', number: 500 },
 | 
			
		||||
      { hex: '#ca8a04', number: 600 },
 | 
			
		||||
      { hex: '#a16207', number: 700 },
 | 
			
		||||
      { hex: '#854d0e', number: 800 },
 | 
			
		||||
      { hex: '#713f12', number: 900 },
 | 
			
		||||
      { hex: '#422006', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Lime',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#f7fee7', number: 50 },
 | 
			
		||||
      { hex: '#ecfccb', number: 100 },
 | 
			
		||||
      { hex: '#d9f99d', number: 200 },
 | 
			
		||||
      { hex: '#bef264', number: 300 },
 | 
			
		||||
      { hex: '#a3e635', number: 400 },
 | 
			
		||||
      { hex: '#84cc16', number: 500 },
 | 
			
		||||
      { hex: '#65a30d', number: 600 },
 | 
			
		||||
      { hex: '#4d7c0f', number: 700 },
 | 
			
		||||
      { hex: '#3f6212', number: 800 },
 | 
			
		||||
      { hex: '#365314', number: 900 },
 | 
			
		||||
      { hex: '#1a2e05', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Green',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#f0fdf4', number: 50 },
 | 
			
		||||
      { hex: '#dcfce7', number: 100 },
 | 
			
		||||
      { hex: '#bbf7d0', number: 200 },
 | 
			
		||||
      { hex: '#86efac', number: 300 },
 | 
			
		||||
      { hex: '#4ade80', number: 400 },
 | 
			
		||||
      { hex: '#22c55e', number: 500 },
 | 
			
		||||
      { hex: '#16a34a', number: 600 },
 | 
			
		||||
      { hex: '#15803d', number: 700 },
 | 
			
		||||
      { hex: '#166534', number: 800 },
 | 
			
		||||
      { hex: '#14532d', number: 900 },
 | 
			
		||||
      { hex: '#052e16', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Emerald',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#ecfdf5', number: 50 },
 | 
			
		||||
      { hex: '#d1fae5', number: 100 },
 | 
			
		||||
      { hex: '#a7f3d0', number: 200 },
 | 
			
		||||
      { hex: '#6ee7b7', number: 300 },
 | 
			
		||||
      { hex: '#34d399', number: 400 },
 | 
			
		||||
      { hex: '#10b981', number: 500 },
 | 
			
		||||
      { hex: '#059669', number: 600 },
 | 
			
		||||
      { hex: '#047857', number: 700 },
 | 
			
		||||
      { hex: '#065f46', number: 800 },
 | 
			
		||||
      { hex: '#064e3b', number: 900 },
 | 
			
		||||
      { hex: '#022c22', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Teal',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#f0fdfa', number: 50 },
 | 
			
		||||
      { hex: '#ccfbf1', number: 100 },
 | 
			
		||||
      { hex: '#99f6e4', number: 200 },
 | 
			
		||||
      { hex: '#5eead4', number: 300 },
 | 
			
		||||
      { hex: '#2dd4bf', number: 400 },
 | 
			
		||||
      { hex: '#14b8a6', number: 500 },
 | 
			
		||||
      { hex: '#0d9488', number: 600 },
 | 
			
		||||
      { hex: '#0f766e', number: 700 },
 | 
			
		||||
      { hex: '#115e59', number: 800 },
 | 
			
		||||
      { hex: '#134e4a', number: 900 },
 | 
			
		||||
      { hex: '#042f2e', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Cyan',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#ecfeff', number: 50 },
 | 
			
		||||
      { hex: '#cffafe', number: 100 },
 | 
			
		||||
      { hex: '#a5f3fc', number: 200 },
 | 
			
		||||
      { hex: '#67e8f9', number: 300 },
 | 
			
		||||
      { hex: '#22d3ee', number: 400 },
 | 
			
		||||
      { hex: '#06b6d4', number: 500 },
 | 
			
		||||
      { hex: '#0891b2', number: 600 },
 | 
			
		||||
      { hex: '#0e7490', number: 700 },
 | 
			
		||||
      { hex: '#155e75', number: 800 },
 | 
			
		||||
      { hex: '#164e63', number: 900 },
 | 
			
		||||
      { hex: '#083344', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Sky',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#f0f9ff', number: 50 },
 | 
			
		||||
      { hex: '#e0f2fe', number: 100 },
 | 
			
		||||
      { hex: '#bae6fd', number: 200 },
 | 
			
		||||
      { hex: '#7dd3fc', number: 300 },
 | 
			
		||||
      { hex: '#38bdf8', number: 400 },
 | 
			
		||||
      { hex: '#0ea5e9', number: 500 },
 | 
			
		||||
      { hex: '#0284c7', number: 600 },
 | 
			
		||||
      { hex: '#0369a1', number: 700 },
 | 
			
		||||
      { hex: '#075985', number: 800 },
 | 
			
		||||
      { hex: '#0c4a6e', number: 900 },
 | 
			
		||||
      { hex: '#082f49', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Blue',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#eff6ff', number: 50 },
 | 
			
		||||
      { hex: '#dbeafe', number: 100 },
 | 
			
		||||
      { hex: '#bfdbfe', number: 200 },
 | 
			
		||||
      { hex: '#93c5fd', number: 300 },
 | 
			
		||||
      { hex: '#60a5fa', number: 400 },
 | 
			
		||||
      { hex: '#3b82f6', number: 500 },
 | 
			
		||||
      { hex: '#2563eb', number: 600 },
 | 
			
		||||
      { hex: '#1d4ed8', number: 700 },
 | 
			
		||||
      { hex: '#1e40af', number: 800 },
 | 
			
		||||
      { hex: '#1e3a8a', number: 900 },
 | 
			
		||||
      { hex: '#172554', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Indigo',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#eef2ff', number: 50 },
 | 
			
		||||
      { hex: '#e0e7ff', number: 100 },
 | 
			
		||||
      { hex: '#c7d2fe', number: 200 },
 | 
			
		||||
      { hex: '#a5b4fc', number: 300 },
 | 
			
		||||
      { hex: '#818cf8', number: 400 },
 | 
			
		||||
      { hex: '#6366f1', number: 500 },
 | 
			
		||||
      { hex: '#4f46e5', number: 600 },
 | 
			
		||||
      { hex: '#4338ca', number: 700 },
 | 
			
		||||
      { hex: '#3730a3', number: 800 },
 | 
			
		||||
      { hex: '#312e81', number: 900 },
 | 
			
		||||
      { hex: '#1e1b4b', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Violet',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#f5f3ff', number: 50 },
 | 
			
		||||
      { hex: '#ede9fe', number: 100 },
 | 
			
		||||
      { hex: '#ddd6fe', number: 200 },
 | 
			
		||||
      { hex: '#c4b5fd', number: 300 },
 | 
			
		||||
      { hex: '#a78bfa', number: 400 },
 | 
			
		||||
      { hex: '#8b5cf6', number: 500 },
 | 
			
		||||
      { hex: '#7c3aed', number: 600 },
 | 
			
		||||
      { hex: '#6d28d9', number: 700 },
 | 
			
		||||
      { hex: '#5b21b6', number: 800 },
 | 
			
		||||
      { hex: '#4c1d95', number: 900 },
 | 
			
		||||
      { hex: '#2e1065', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Purple',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#faf5ff', number: 50 },
 | 
			
		||||
      { hex: '#f3e8ff', number: 100 },
 | 
			
		||||
      { hex: '#e9d5ff', number: 200 },
 | 
			
		||||
      { hex: '#d8b4fe', number: 300 },
 | 
			
		||||
      { hex: '#c084fc', number: 400 },
 | 
			
		||||
      { hex: '#a855f7', number: 500 },
 | 
			
		||||
      { hex: '#9333ea', number: 600 },
 | 
			
		||||
      { hex: '#7e22ce', number: 700 },
 | 
			
		||||
      { hex: '#6b21a8', number: 800 },
 | 
			
		||||
      { hex: '#581c87', number: 900 },
 | 
			
		||||
      { hex: '#3b0764', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Fuchsia',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#fdf4ff', number: 50 },
 | 
			
		||||
      { hex: '#fae8ff', number: 100 },
 | 
			
		||||
      { hex: '#f5d0fe', number: 200 },
 | 
			
		||||
      { hex: '#f0abfc', number: 300 },
 | 
			
		||||
      { hex: '#e879f9', number: 400 },
 | 
			
		||||
      { hex: '#d946ef', number: 500 },
 | 
			
		||||
      { hex: '#c026d3', number: 600 },
 | 
			
		||||
      { hex: '#a21caf', number: 700 },
 | 
			
		||||
      { hex: '#86198f', number: 800 },
 | 
			
		||||
      { hex: '#701a75', number: 900 },
 | 
			
		||||
      { hex: '#4a044e', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Pink',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#fdf2f8', number: 50 },
 | 
			
		||||
      { hex: '#fce7f3', number: 100 },
 | 
			
		||||
      { hex: '#fbcfe8', number: 200 },
 | 
			
		||||
      { hex: '#f9a8d4', number: 300 },
 | 
			
		||||
      { hex: '#f472b6', number: 400 },
 | 
			
		||||
      { hex: '#ec4899', number: 500 },
 | 
			
		||||
      { hex: '#db2777', number: 600 },
 | 
			
		||||
      { hex: '#be185d', number: 700 },
 | 
			
		||||
      { hex: '#9d174d', number: 800 },
 | 
			
		||||
      { hex: '#831843', number: 900 },
 | 
			
		||||
      { hex: '#500724', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    name: 'Rose',
 | 
			
		||||
    palettes: [
 | 
			
		||||
      { hex: '#fff1f2', number: 50 },
 | 
			
		||||
      { hex: '#ffe4e6', number: 100 },
 | 
			
		||||
      { hex: '#fecdd3', number: 200 },
 | 
			
		||||
      { hex: '#fda4af', number: 300 },
 | 
			
		||||
      { hex: '#fb7185', number: 400 },
 | 
			
		||||
      { hex: '#f43f5e', number: 500 },
 | 
			
		||||
      { hex: '#e11d48', number: 600 },
 | 
			
		||||
      { hex: '#be123c', number: 700 },
 | 
			
		||||
      { hex: '#9f1239', number: 800 },
 | 
			
		||||
      { hex: '#881337', number: 900 },
 | 
			
		||||
      { hex: '#4c0519', number: 950 }
 | 
			
		||||
    ]
 | 
			
		||||
  }
 | 
			
		||||
];
 | 
			
		||||
@@ -1,57 +1,6 @@
 | 
			
		||||
import { getColorPaletteFamily } from './palette';
 | 
			
		||||
import { getColorName } from './name';
 | 
			
		||||
import type { ColorPalette, ColorPaletteFamily, ColorPaletteItem, ColorPaletteNumber } from './type';
 | 
			
		||||
import defaultPalettes from './json/palette.json';
 | 
			
		||||
import { colorPalettes } from './constant';
 | 
			
		||||
import { getColorName, getHex, getHsl, getRgb } from './shared';
 | 
			
		||||
 | 
			
		||||
// to do: there is a bug in the code below, when the color is '#1c5cff', the colorPaletteFamily is not similar to the provided color
 | 
			
		||||
/**
 | 
			
		||||
 * Get color palette by provided color and color name
 | 
			
		||||
 *
 | 
			
		||||
 * @param color The provided color
 | 
			
		||||
 * @param colorName Color name
 | 
			
		||||
 */
 | 
			
		||||
export function getColorPalette(color: string, colorName: string) {
 | 
			
		||||
  const colorPaletteFamily = getColorPaletteFamily(color, colorName);
 | 
			
		||||
 | 
			
		||||
  const colorMap = new Map<ColorPaletteNumber, ColorPaletteItem>();
 | 
			
		||||
 | 
			
		||||
  colorPaletteFamily.palettes.forEach(palette => {
 | 
			
		||||
    colorMap.set(palette.number, palette);
 | 
			
		||||
  });
 | 
			
		||||
 | 
			
		||||
  const mainColor = colorMap.get(500) as ColorPaletteItem;
 | 
			
		||||
  const matchColor = colorPaletteFamily.palettes.find(palette => palette.hexcode === color) as ColorPaletteItem;
 | 
			
		||||
 | 
			
		||||
  const colorPalette: ColorPalette = {
 | 
			
		||||
    ...colorPaletteFamily,
 | 
			
		||||
    colorMap,
 | 
			
		||||
    main: mainColor,
 | 
			
		||||
    match: matchColor
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  return colorPalette;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Get color by color palette number
 | 
			
		||||
 *
 | 
			
		||||
 * @param color Color
 | 
			
		||||
 * @param num Color palette number
 | 
			
		||||
 * @returns Color hexcode
 | 
			
		||||
 */
 | 
			
		||||
export function getColorByColorPaletteNumber(color: string, num: ColorPaletteNumber) {
 | 
			
		||||
  const colorPalette = getColorPalette(color, color);
 | 
			
		||||
 | 
			
		||||
  const colorItem = colorPalette.colorMap.get(num) as ColorPaletteItem;
 | 
			
		||||
 | 
			
		||||
  return colorItem.hexcode;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export default getColorPalette;
 | 
			
		||||
 | 
			
		||||
/** The builtin color palettes */
 | 
			
		||||
const colorPalettes = defaultPalettes as ColorPaletteFamily[];
 | 
			
		||||
 | 
			
		||||
export { getColorName, colorPalettes };
 | 
			
		||||
 | 
			
		||||
export type { ColorPalette, ColorPaletteNumber, ColorPaletteItem, ColorPaletteFamily };
 | 
			
		||||
export * from './palette';
 | 
			
		||||
export { getColorName, getHex, getHsl, getRgb, colorPalettes };
 | 
			
		||||
export * from './types';
 | 
			
		||||
 
 | 
			
		||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@@ -1,274 +0,0 @@
 | 
			
		||||
[
 | 
			
		||||
  {
 | 
			
		||||
    "key": "red",
 | 
			
		||||
    "palettes": [
 | 
			
		||||
      { "hexcode": "#fef2f2", "number": 50, "name": "Bridesmaid" },
 | 
			
		||||
      { "hexcode": "#fee2e2", "number": 100, "name": "Pippin" },
 | 
			
		||||
      { "hexcode": "#fecaca", "number": 200, "name": "Your Pink" },
 | 
			
		||||
      { "hexcode": "#fca5a5", "number": 300, "name": "Cornflower Lilac" },
 | 
			
		||||
      { "hexcode": "#f87171", "number": 400, "name": "Bittersweet" },
 | 
			
		||||
      { "hexcode": "#ef4444", "number": 500, "name": "Cinnabar" },
 | 
			
		||||
      { "hexcode": "#dc2626", "number": 600, "name": "Persian Red" },
 | 
			
		||||
      { "hexcode": "#b91c1c", "number": 700, "name": "Thunderbird" },
 | 
			
		||||
      { "hexcode": "#991b1b", "number": 800, "name": "Old Brick" },
 | 
			
		||||
      { "hexcode": "#7f1d1d", "number": 900, "name": "Falu Red" },
 | 
			
		||||
      { "hexcode": "#450a0a", "number": 950, "name": "Mahogany" }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    "key": "orange",
 | 
			
		||||
    "palettes": [
 | 
			
		||||
      { "hexcode": "#fff7ed", "number": 50, "name": "Serenade" },
 | 
			
		||||
      { "hexcode": "#ffedd5", "number": 100, "name": "Derby" },
 | 
			
		||||
      { "hexcode": "#fed7aa", "number": 200, "name": "Caramel" },
 | 
			
		||||
      { "hexcode": "#fdba74", "number": 300, "name": "Macaroni and Cheese" },
 | 
			
		||||
      { "hexcode": "#fb923c", "number": 400, "name": "Neon Carrot" },
 | 
			
		||||
      { "hexcode": "#f97316", "number": 500, "name": "Ecstasy" },
 | 
			
		||||
      { "hexcode": "#ea580c", "number": 600, "name": "Trinidad" },
 | 
			
		||||
      { "hexcode": "#c2410c", "number": 700, "name": "Tia Maria" },
 | 
			
		||||
      { "hexcode": "#9a3412", "number": 800, "name": "Tabasco" },
 | 
			
		||||
      { "hexcode": "#7c2d12", "number": 900, "name": "Pueblo" },
 | 
			
		||||
      { "hexcode": "#431407", "number": 950, "name": "Rebel" }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    "key": "amber",
 | 
			
		||||
    "palettes": [
 | 
			
		||||
      { "hexcode": "#fffbeb", "number": 50, "name": "Island Spice" },
 | 
			
		||||
      { "hexcode": "#fef3c7", "number": 100, "name": "Beeswax" },
 | 
			
		||||
      { "hexcode": "#fde68a", "number": 200, "name": "Sweet Corn" },
 | 
			
		||||
      { "hexcode": "#fcd34d", "number": 300, "name": "Mustard" },
 | 
			
		||||
      { "hexcode": "#fbbf24", "number": 400, "name": "Lightning Yellow" },
 | 
			
		||||
      { "hexcode": "#f59e0b", "number": 500, "name": "California" },
 | 
			
		||||
      { "hexcode": "#d97706", "number": 600, "name": "Christine" },
 | 
			
		||||
      { "hexcode": "#b45309", "number": 700, "name": "Vesuvius" },
 | 
			
		||||
      { "hexcode": "#92400e", "number": 800, "name": "Korma" },
 | 
			
		||||
      { "hexcode": "#78350f", "number": 900, "name": "Copper Canyon" },
 | 
			
		||||
      { "hexcode": "#451a03", "number": 950, "name": "Brown Pod" }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    "key": "yellow",
 | 
			
		||||
    "palettes": [
 | 
			
		||||
      { "hexcode": "#fefce8", "number": 50, "name": "Orange White" },
 | 
			
		||||
      { "hexcode": "#fef9c3", "number": 100, "name": "Lemon Chiffon" },
 | 
			
		||||
      { "hexcode": "#fef08a", "number": 200, "name": "Sweet Corn" },
 | 
			
		||||
      { "hexcode": "#fde047", "number": 300, "name": "Bright Sun" },
 | 
			
		||||
      { "hexcode": "#facc15", "number": 400, "name": "Candlelight" },
 | 
			
		||||
      { "hexcode": "#eab308", "number": 500, "name": "Corn" },
 | 
			
		||||
      { "hexcode": "#ca8a04", "number": 600, "name": "Pirate Gold" },
 | 
			
		||||
      { "hexcode": "#a16207", "number": 700, "name": "Mai Tai" },
 | 
			
		||||
      { "hexcode": "#854d0e", "number": 800, "name": "Korma" },
 | 
			
		||||
      { "hexcode": "#713f12", "number": 900, "name": "Sepia" },
 | 
			
		||||
      { "hexcode": "#422006", "number": 950, "name": "Dark Ebony" }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    "key": "lime",
 | 
			
		||||
    "palettes": [
 | 
			
		||||
      { "hexcode": "#f7fee7", "number": 50, "name": "Spring Sun" },
 | 
			
		||||
      { "hexcode": "#ecfccb", "number": 100, "name": "Chiffon" },
 | 
			
		||||
      { "hexcode": "#d9f99d", "number": 200, "name": "Gossip" },
 | 
			
		||||
      { "hexcode": "#bef264", "number": 300, "name": "Sulu" },
 | 
			
		||||
      { "hexcode": "#a3e635", "number": 400, "name": "Conifer" },
 | 
			
		||||
      { "hexcode": "#84cc16", "number": 500, "name": "Lima" },
 | 
			
		||||
      { "hexcode": "#65a30d", "number": 600, "name": "Christi" },
 | 
			
		||||
      { "hexcode": "#4d7c0f", "number": 700, "name": "Green Leaf" },
 | 
			
		||||
      { "hexcode": "#3f6212", "number": 800, "name": "Dell" },
 | 
			
		||||
      { "hexcode": "#365314", "number": 900, "name": "Clover" },
 | 
			
		||||
      { "hexcode": "#1a2e05", "number": 950, "name": "Deep Forest Green" }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    "key": "green",
 | 
			
		||||
    "palettes": [
 | 
			
		||||
      { "hexcode": "#f0fdf4", "number": 50, "name": "Ottoman" },
 | 
			
		||||
      { "hexcode": "#dcfce7", "number": 100, "name": "Blue Romance" },
 | 
			
		||||
      { "hexcode": "#bbf7d0", "number": 200, "name": "Magic Mint" },
 | 
			
		||||
      { "hexcode": "#86efac", "number": 300, "name": "Algae Green" },
 | 
			
		||||
      { "hexcode": "#4ade80", "number": 400, "name": "Emerald" },
 | 
			
		||||
      { "hexcode": "#22c55e", "number": 500, "name": "Malachite" },
 | 
			
		||||
      { "hexcode": "#16a34a", "number": 600, "name": "Salem" },
 | 
			
		||||
      { "hexcode": "#15803d", "number": 700, "name": "Jewel" },
 | 
			
		||||
      { "hexcode": "#166534", "number": 800, "name": "Jewel" },
 | 
			
		||||
      { "hexcode": "#14532d", "number": 900, "name": "Green Pea" },
 | 
			
		||||
      { "hexcode": "#052e16", "number": 950, "name": "English Holly" }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    "key": "emerald",
 | 
			
		||||
    "palettes": [
 | 
			
		||||
      { "hexcode": "#ecfdf5", "number": 50, "name": "White Ice" },
 | 
			
		||||
      { "hexcode": "#d1fae5", "number": 100, "name": "Granny Apple" },
 | 
			
		||||
      { "hexcode": "#a7f3d0", "number": 200, "name": "Magic Mint" },
 | 
			
		||||
      { "hexcode": "#6ee7b7", "number": 300, "name": "Bermuda" },
 | 
			
		||||
      { "hexcode": "#34d399", "number": 400, "name": "Shamrock" },
 | 
			
		||||
      { "hexcode": "#10b981", "number": 500, "name": "Mountain Meadow" },
 | 
			
		||||
      { "hexcode": "#059669", "number": 600, "name": "Green Haze" },
 | 
			
		||||
      { "hexcode": "#047857", "number": 700, "name": "Watercourse" },
 | 
			
		||||
      { "hexcode": "#065f46", "number": 800, "name": "Watercourse" },
 | 
			
		||||
      { "hexcode": "#064e3b", "number": 900, "name": "Evening Sea" },
 | 
			
		||||
      { "hexcode": "#022c22", "number": 950, "name": "Burnham" }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    "key": "teal",
 | 
			
		||||
    "palettes": [
 | 
			
		||||
      { "hexcode": "#f0fdfa", "number": 50, "name": "White Ice" },
 | 
			
		||||
      { "hexcode": "#ccfbf1", "number": 100, "name": "Scandal" },
 | 
			
		||||
      { "hexcode": "#99f6e4", "number": 200, "name": "Ice Cold" },
 | 
			
		||||
      { "hexcode": "#5eead4", "number": 300, "name": "Turquoise Blue" },
 | 
			
		||||
      { "hexcode": "#2dd4bf", "number": 400, "name": "Turquoise" },
 | 
			
		||||
      { "hexcode": "#14b8a6", "number": 500, "name": "Java" },
 | 
			
		||||
      { "hexcode": "#0d9488", "number": 600, "name": "Blue Chill" },
 | 
			
		||||
      { "hexcode": "#0f766e", "number": 700, "name": "Genoa" },
 | 
			
		||||
      { "hexcode": "#115e59", "number": 800, "name": "Eden" },
 | 
			
		||||
      { "hexcode": "#134e4a", "number": 900, "name": "Eden" },
 | 
			
		||||
      { "hexcode": "#042f2e", "number": 950, "name": "Tiber" }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    "key": "cyan",
 | 
			
		||||
    "palettes": [
 | 
			
		||||
      { "hexcode": "#ecfeff", "number": 50, "name": "Bubbles" },
 | 
			
		||||
      { "hexcode": "#cffafe", "number": 100, "name": "Oyster Bay" },
 | 
			
		||||
      { "hexcode": "#a5f3fc", "number": 200, "name": "Anakiwa" },
 | 
			
		||||
      { "hexcode": "#67e8f9", "number": 300, "name": "Spray" },
 | 
			
		||||
      { "hexcode": "#22d3ee", "number": 400, "name": "Bright Turquoise" },
 | 
			
		||||
      { "hexcode": "#06b6d4", "number": 500, "name": "Cerulean" },
 | 
			
		||||
      { "hexcode": "#0891b2", "number": 600, "name": "Bondi Blue" },
 | 
			
		||||
      { "hexcode": "#0e7490", "number": 700, "name": "Blue Chill" },
 | 
			
		||||
      { "hexcode": "#155e75", "number": 800, "name": "Blumine" },
 | 
			
		||||
      { "hexcode": "#164e63", "number": 900, "name": "Chathams Blue" },
 | 
			
		||||
      { "hexcode": "#083344", "number": 950, "name": "Tarawera" }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    "key": "sky",
 | 
			
		||||
    "palettes": [
 | 
			
		||||
      { "hexcode": "#f0f9ff", "number": 50, "name": "Alice Blue" },
 | 
			
		||||
      { "hexcode": "#e0f2fe", "number": 100, "name": "Pattens Blue" },
 | 
			
		||||
      { "hexcode": "#bae6fd", "number": 200, "name": "French Pass" },
 | 
			
		||||
      { "hexcode": "#7dd3fc", "number": 300, "name": "Malibu" },
 | 
			
		||||
      { "hexcode": "#38bdf8", "number": 400, "name": "Picton Blue" },
 | 
			
		||||
      { "hexcode": "#0ea5e9", "number": 500, "name": "Cerulean" },
 | 
			
		||||
      { "hexcode": "#0284c7", "number": 600, "name": "Lochmara" },
 | 
			
		||||
      { "hexcode": "#0369a1", "number": 700, "name": "Bahama Blue" },
 | 
			
		||||
      { "hexcode": "#075985", "number": 800, "name": "Venice Blue" },
 | 
			
		||||
      { "hexcode": "#0c4a6e", "number": 900, "name": "Chathams Blue" },
 | 
			
		||||
      { "hexcode": "#082f49", "number": 950, "name": "Blue Whale" }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    "key": "blue",
 | 
			
		||||
    "palettes": [
 | 
			
		||||
      { "hexcode": "#eff6ff", "number": 50, "name": "Zumthor" },
 | 
			
		||||
      { "hexcode": "#dbeafe", "number": 100, "name": "Hawkes Blue" },
 | 
			
		||||
      { "hexcode": "#bfdbfe", "number": 200, "name": "Tropical Blue" },
 | 
			
		||||
      { "hexcode": "#93c5fd", "number": 300, "name": "Malibu" },
 | 
			
		||||
      { "hexcode": "#60a5fa", "number": 400, "name": "Cornflower Blue" },
 | 
			
		||||
      { "hexcode": "#3b82f6", "number": 500, "name": "Dodger Blue" },
 | 
			
		||||
      { "hexcode": "#2563eb", "number": 600, "name": "Royal Blue" },
 | 
			
		||||
      { "hexcode": "#1d4ed8", "number": 700, "name": "Cerulean Blue" },
 | 
			
		||||
      { "hexcode": "#1e40af", "number": 800, "name": "Persian Blue" },
 | 
			
		||||
      { "hexcode": "#1e3a8a", "number": 900, "name": "Bay of Many" },
 | 
			
		||||
      { "hexcode": "#172554", "number": 950, "name": "Bunting" }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    "key": "indigo",
 | 
			
		||||
    "palettes": [
 | 
			
		||||
      { "hexcode": "#eef2ff", "number": 50, "name": "Zircon" },
 | 
			
		||||
      { "hexcode": "#e0e7ff", "number": 100, "name": "Hawkes Blue" },
 | 
			
		||||
      { "hexcode": "#c7d2fe", "number": 200, "name": "Periwinkle" },
 | 
			
		||||
      { "hexcode": "#a5b4fc", "number": 300, "name": "Perano" },
 | 
			
		||||
      { "hexcode": "#818cf8", "number": 400, "name": "Portage" },
 | 
			
		||||
      { "hexcode": "#6366f1", "number": 500, "name": "Royal Blue" },
 | 
			
		||||
      { "hexcode": "#4f46e5", "number": 600, "name": "Royal Blue" },
 | 
			
		||||
      { "hexcode": "#4338ca", "number": 700, "name": "Governor Bay" },
 | 
			
		||||
      { "hexcode": "#3730a3", "number": 800, "name": "Governor Bay" },
 | 
			
		||||
      { "hexcode": "#312e81", "number": 900, "name": "Minsk" },
 | 
			
		||||
      { "hexcode": "#1e1b4b", "number": 950, "name": "Port Gore" }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    "key": "violet",
 | 
			
		||||
    "palettes": [
 | 
			
		||||
      { "hexcode": "#f5f3ff", "number": 50, "name": "Titan White" },
 | 
			
		||||
      { "hexcode": "#ede9fe", "number": 100, "name": "Titan White" },
 | 
			
		||||
      { "hexcode": "#ddd6fe", "number": 200, "name": "Fog" },
 | 
			
		||||
      { "hexcode": "#c4b5fd", "number": 300, "name": "Melrose" },
 | 
			
		||||
      { "hexcode": "#a78bfa", "number": 400, "name": "Dull Lavender" },
 | 
			
		||||
      { "hexcode": "#8b5cf6", "number": 500, "name": "Medium Purple" },
 | 
			
		||||
      { "hexcode": "#7c3aed", "number": 600, "name": "Purple Heart" },
 | 
			
		||||
      { "hexcode": "#6d28d9", "number": 700, "name": "Purple Heart" },
 | 
			
		||||
      { "hexcode": "#5b21b6", "number": 800, "name": "Purple Heart" },
 | 
			
		||||
      { "hexcode": "#4c1d95", "number": 900, "name": "Daisy Bush" },
 | 
			
		||||
      { "hexcode": "#2e1065", "number": 950, "name": "Violent Violet" }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    "key": "purple",
 | 
			
		||||
    "palettes": [
 | 
			
		||||
      { "hexcode": "#faf5ff", "number": 50, "name": "Magnolia" },
 | 
			
		||||
      { "hexcode": "#f3e8ff", "number": 100, "name": "Blue Chalk" },
 | 
			
		||||
      { "hexcode": "#e9d5ff", "number": 200, "name": "Blue Chalk" },
 | 
			
		||||
      { "hexcode": "#d8b4fe", "number": 300, "name": "Mauve" },
 | 
			
		||||
      { "hexcode": "#c084fc", "number": 400, "name": "Heliotrope" },
 | 
			
		||||
      { "hexcode": "#a855f7", "number": 500, "name": "Medium Purple" },
 | 
			
		||||
      { "hexcode": "#9333ea", "number": 600, "name": "Electric Violet" },
 | 
			
		||||
      { "hexcode": "#7e22ce", "number": 700, "name": "Purple Heart" },
 | 
			
		||||
      { "hexcode": "#6b21a8", "number": 800, "name": "Seance" },
 | 
			
		||||
      { "hexcode": "#581c87", "number": 900, "name": "Daisy Bush" },
 | 
			
		||||
      { "hexcode": "#3b0764", "number": 950, "name": "Christalle" }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    "key": "fuchsia",
 | 
			
		||||
    "palettes": [
 | 
			
		||||
      { "hexcode": "#fdf4ff", "number": 50, "name": "White Pointer" },
 | 
			
		||||
      { "hexcode": "#fae8ff", "number": 100, "name": "White Pointer" },
 | 
			
		||||
      { "hexcode": "#f5d0fe", "number": 200, "name": "Mauve" },
 | 
			
		||||
      { "hexcode": "#f0abfc", "number": 300, "name": "Mauve" },
 | 
			
		||||
      { "hexcode": "#e879f9", "number": 400, "name": "Heliotrope" },
 | 
			
		||||
      { "hexcode": "#d946ef", "number": 500, "name": "Heliotrope" },
 | 
			
		||||
      { "hexcode": "#c026d3", "number": 600, "name": "Fuchsia Pink" },
 | 
			
		||||
      { "hexcode": "#a21caf", "number": 700, "name": "Violet Eggplant" },
 | 
			
		||||
      { "hexcode": "#86198f", "number": 800, "name": "Seance" },
 | 
			
		||||
      { "hexcode": "#701a75", "number": 900, "name": "Seance" },
 | 
			
		||||
      { "hexcode": "#4a044e", "number": 950, "name": "Clairvoyant" }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    "key": "pink",
 | 
			
		||||
    "palettes": [
 | 
			
		||||
      { "hexcode": "#fdf2f8", "number": 50, "name": "Wisp Pink" },
 | 
			
		||||
      { "hexcode": "#fce7f3", "number": 100, "name": "Carousel Pink" },
 | 
			
		||||
      { "hexcode": "#fbcfe8", "number": 200, "name": "Classic Rose" },
 | 
			
		||||
      { "hexcode": "#f9a8d4", "number": 300, "name": "Lavender Pink" },
 | 
			
		||||
      { "hexcode": "#f472b6", "number": 400, "name": "Persian Pink" },
 | 
			
		||||
      { "hexcode": "#ec4899", "number": 500, "name": "Brilliant Rose" },
 | 
			
		||||
      { "hexcode": "#db2777", "number": 600, "name": "Cerise" },
 | 
			
		||||
      { "hexcode": "#be185d", "number": 700, "name": "Maroon Flush" },
 | 
			
		||||
      { "hexcode": "#9d174d", "number": 800, "name": "Disco" },
 | 
			
		||||
      { "hexcode": "#831843", "number": 900, "name": "Disco" },
 | 
			
		||||
      { "hexcode": "#500724", "number": 950, "name": "Cab Sav" }
 | 
			
		||||
    ]
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    "key": "rose",
 | 
			
		||||
    "palettes": [
 | 
			
		||||
      { "hexcode": "#fff1f2", "number": 50, "name": "Lavender blush" },
 | 
			
		||||
      { "hexcode": "#ffe4e6", "number": 100, "name": "Cosmos" },
 | 
			
		||||
      { "hexcode": "#fecdd3", "number": 200, "name": "Pastel Pink" },
 | 
			
		||||
      { "hexcode": "#fda4af", "number": 300, "name": "Sweet Pink" },
 | 
			
		||||
      { "hexcode": "#fb7185", "number": 400, "name": "Froly" },
 | 
			
		||||
      { "hexcode": "#f43f5e", "number": 500, "name": "Radical Red" },
 | 
			
		||||
      { "hexcode": "#e11d48", "number": 600, "name": "Amaranth" },
 | 
			
		||||
      { "hexcode": "#be123c", "number": 700, "name": "Cardinal" },
 | 
			
		||||
      { "hexcode": "#9f1239", "number": 800, "name": "Shiraz" },
 | 
			
		||||
      { "hexcode": "#881337", "number": 900, "name": "Claret" },
 | 
			
		||||
      { "hexcode": "#4c0519", "number": 950, "name": "Cab Sav" }
 | 
			
		||||
    ]
 | 
			
		||||
  }
 | 
			
		||||
]
 | 
			
		||||
@@ -1,95 +0,0 @@
 | 
			
		||||
import { getDeltaE, getHsl, isValidColor, transformHslToHex } from './color';
 | 
			
		||||
import { getColorName } from './name';
 | 
			
		||||
import type { ColorPaletteFamily, ColorPaletteFamilyWithNearestPalette } from './type';
 | 
			
		||||
import defaultPalettes from './json/palette.json';
 | 
			
		||||
 | 
			
		||||
export function getNearestColorPaletteFamily(color: string, families: ColorPaletteFamily[]) {
 | 
			
		||||
  const familyWithConfig = families.map(family => {
 | 
			
		||||
    const palettes = family.palettes.map(palette => {
 | 
			
		||||
      return {
 | 
			
		||||
        ...palette,
 | 
			
		||||
        delta: getDeltaE(color, palette.hexcode)
 | 
			
		||||
      };
 | 
			
		||||
    });
 | 
			
		||||
 | 
			
		||||
    const nearestPalette = palettes.reduce((prev, curr) => (prev.delta < curr.delta ? prev : curr));
 | 
			
		||||
 | 
			
		||||
    return {
 | 
			
		||||
      ...family,
 | 
			
		||||
      palettes,
 | 
			
		||||
      nearestPalette
 | 
			
		||||
    };
 | 
			
		||||
  });
 | 
			
		||||
 | 
			
		||||
  const nearestPaletteFamily = familyWithConfig.reduce((prev, curr) =>
 | 
			
		||||
    prev.nearestPalette.delta < curr.nearestPalette.delta ? prev : curr
 | 
			
		||||
  );
 | 
			
		||||
 | 
			
		||||
  const { l } = getHsl(color);
 | 
			
		||||
 | 
			
		||||
  const paletteFamily: ColorPaletteFamilyWithNearestPalette = {
 | 
			
		||||
    ...nearestPaletteFamily,
 | 
			
		||||
    nearestLightnessPalette: nearestPaletteFamily.palettes.reduce((prev, curr) => {
 | 
			
		||||
      const { l: prevLightness } = getHsl(prev.hexcode);
 | 
			
		||||
      const { l: currLightness } = getHsl(curr.hexcode);
 | 
			
		||||
 | 
			
		||||
      const deltaPrev = Math.abs(prevLightness - l);
 | 
			
		||||
      const deltaCurr = Math.abs(currLightness - l);
 | 
			
		||||
 | 
			
		||||
      return deltaPrev < deltaCurr ? prev : curr;
 | 
			
		||||
    })
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  return paletteFamily;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function getColorPaletteFamily(color: string, colorName: string) {
 | 
			
		||||
  if (!isValidColor(color)) {
 | 
			
		||||
    throw new Error('Invalid color, please check color value!');
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  const { h: h1, s: s1 } = getHsl(color);
 | 
			
		||||
 | 
			
		||||
  const { nearestLightnessPalette, palettes } = getNearestColorPaletteFamily(
 | 
			
		||||
    color,
 | 
			
		||||
    defaultPalettes as ColorPaletteFamily[]
 | 
			
		||||
  );
 | 
			
		||||
 | 
			
		||||
  const { number, hexcode } = nearestLightnessPalette;
 | 
			
		||||
 | 
			
		||||
  const { h: h2, s: s2 } = getHsl(hexcode);
 | 
			
		||||
 | 
			
		||||
  const deltaH = h1 - h2 || h2;
 | 
			
		||||
 | 
			
		||||
  const sRatio = s1 / s2;
 | 
			
		||||
 | 
			
		||||
  const colorPaletteFamily: ColorPaletteFamily = {
 | 
			
		||||
    key: colorName,
 | 
			
		||||
    palettes: palettes.map(palette => {
 | 
			
		||||
      let hexValue = color;
 | 
			
		||||
 | 
			
		||||
      const isSame = number === palette.number;
 | 
			
		||||
 | 
			
		||||
      if (!isSame) {
 | 
			
		||||
        const { h: h3, s: s3, l } = getHsl(palette.hexcode);
 | 
			
		||||
 | 
			
		||||
        const newH = deltaH < 0 ? h3 + deltaH : deltaH;
 | 
			
		||||
        const newS = s3 * sRatio;
 | 
			
		||||
 | 
			
		||||
        hexValue = transformHslToHex({
 | 
			
		||||
          h: newH,
 | 
			
		||||
          s: newS,
 | 
			
		||||
          l
 | 
			
		||||
        });
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      return {
 | 
			
		||||
        hexcode: hexValue,
 | 
			
		||||
        number: palette.number,
 | 
			
		||||
        name: getColorName(hexValue)
 | 
			
		||||
      };
 | 
			
		||||
    })
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  return colorPaletteFamily;
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										152
									
								
								packages/color-palette/src/palette/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										152
									
								
								packages/color-palette/src/palette/index.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,152 @@
 | 
			
		||||
import { getColorName, getDeltaE, getHsl, isValidColor, transformHslToHex } from '../shared';
 | 
			
		||||
import { colorPalettes } from '../constant';
 | 
			
		||||
import type {
 | 
			
		||||
  ColorPalette,
 | 
			
		||||
  ColorPaletteFamily,
 | 
			
		||||
  ColorPaletteFamilyWithNearestPalette,
 | 
			
		||||
  ColorPaletteMatch,
 | 
			
		||||
  ColorPaletteNumber
 | 
			
		||||
} from '../types';
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * get color palette by provided color and color name
 | 
			
		||||
 *
 | 
			
		||||
 * @param color the provided color
 | 
			
		||||
 */
 | 
			
		||||
export function getColorPalette(color: string) {
 | 
			
		||||
  const colorPaletteFamily = getColorPaletteFamily(color);
 | 
			
		||||
 | 
			
		||||
  const colorMap = new Map<ColorPaletteNumber, ColorPalette>();
 | 
			
		||||
 | 
			
		||||
  colorPaletteFamily.palettes.forEach(palette => {
 | 
			
		||||
    colorMap.set(palette.number, palette);
 | 
			
		||||
  });
 | 
			
		||||
 | 
			
		||||
  const mainColor = colorMap.get(500)!;
 | 
			
		||||
  const matchColor = colorPaletteFamily.palettes.find(palette => palette.hex === color)!;
 | 
			
		||||
 | 
			
		||||
  const colorPalette: ColorPaletteMatch = {
 | 
			
		||||
    ...colorPaletteFamily,
 | 
			
		||||
    colorMap,
 | 
			
		||||
    main: mainColor,
 | 
			
		||||
    match: matchColor
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  return colorPalette;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * get color by number
 | 
			
		||||
 *
 | 
			
		||||
 * @param color the provided color
 | 
			
		||||
 * @param number the color palette number
 | 
			
		||||
 */
 | 
			
		||||
export function getColorByPaletteNumber(color: string, number: ColorPaletteNumber) {
 | 
			
		||||
  const colorPalette = getColorPalette(color);
 | 
			
		||||
 | 
			
		||||
  const { hex } = colorPalette.colorMap.get(number)!;
 | 
			
		||||
 | 
			
		||||
  return hex;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * get color palette family by provided color and color name
 | 
			
		||||
 *
 | 
			
		||||
 * @param color the provided color
 | 
			
		||||
 */
 | 
			
		||||
export function getColorPaletteFamily(color: string) {
 | 
			
		||||
  if (!isValidColor(color)) {
 | 
			
		||||
    throw new Error('Invalid color, please check color value!');
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  let colorName = getColorName(color);
 | 
			
		||||
 | 
			
		||||
  colorName = colorName.toLowerCase().replace(/\s/g, '-');
 | 
			
		||||
 | 
			
		||||
  const { h: h1, s: s1 } = getHsl(color);
 | 
			
		||||
 | 
			
		||||
  const { nearestLightnessPalette, palettes } = getNearestColorPaletteFamily(color, colorPalettes);
 | 
			
		||||
 | 
			
		||||
  const { number, hex } = nearestLightnessPalette;
 | 
			
		||||
 | 
			
		||||
  const { h: h2, s: s2 } = getHsl(hex);
 | 
			
		||||
 | 
			
		||||
  const deltaH = h1 - h2;
 | 
			
		||||
 | 
			
		||||
  const sRatio = s1 / s2;
 | 
			
		||||
 | 
			
		||||
  const colorPaletteFamily: ColorPaletteFamily = {
 | 
			
		||||
    name: colorName,
 | 
			
		||||
    palettes: palettes.map(palette => {
 | 
			
		||||
      let hexValue = color;
 | 
			
		||||
 | 
			
		||||
      const isSame = number === palette.number;
 | 
			
		||||
 | 
			
		||||
      if (!isSame) {
 | 
			
		||||
        const { h: h3, s: s3, l } = getHsl(palette.hex);
 | 
			
		||||
 | 
			
		||||
        const newH = deltaH < 0 ? h3 + deltaH : h3 - deltaH;
 | 
			
		||||
        const newS = s3 * sRatio;
 | 
			
		||||
 | 
			
		||||
        hexValue = transformHslToHex({
 | 
			
		||||
          h: newH,
 | 
			
		||||
          s: newS,
 | 
			
		||||
          l
 | 
			
		||||
        });
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      return {
 | 
			
		||||
        hex: hexValue,
 | 
			
		||||
        number: palette.number
 | 
			
		||||
      };
 | 
			
		||||
    })
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  return colorPaletteFamily;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * get nearest color palette family
 | 
			
		||||
 *
 | 
			
		||||
 * @param color color
 | 
			
		||||
 * @param families color palette families
 | 
			
		||||
 */
 | 
			
		||||
function getNearestColorPaletteFamily(color: string, families: ColorPaletteFamily[]) {
 | 
			
		||||
  const familyWithConfig = families.map(family => {
 | 
			
		||||
    const palettes = family.palettes.map(palette => {
 | 
			
		||||
      return {
 | 
			
		||||
        ...palette,
 | 
			
		||||
        delta: getDeltaE(color, palette.hex)
 | 
			
		||||
      };
 | 
			
		||||
    });
 | 
			
		||||
 | 
			
		||||
    const nearestPalette = palettes.reduce((prev, curr) => (prev.delta < curr.delta ? prev : curr));
 | 
			
		||||
 | 
			
		||||
    return {
 | 
			
		||||
      ...family,
 | 
			
		||||
      palettes,
 | 
			
		||||
      nearestPalette
 | 
			
		||||
    };
 | 
			
		||||
  });
 | 
			
		||||
 | 
			
		||||
  const nearestPaletteFamily = familyWithConfig.reduce((prev, curr) =>
 | 
			
		||||
    prev.nearestPalette.delta < curr.nearestPalette.delta ? prev : curr
 | 
			
		||||
  );
 | 
			
		||||
 | 
			
		||||
  const { l } = getHsl(color);
 | 
			
		||||
 | 
			
		||||
  const paletteFamily: ColorPaletteFamilyWithNearestPalette = {
 | 
			
		||||
    ...nearestPaletteFamily,
 | 
			
		||||
    nearestLightnessPalette: nearestPaletteFamily.palettes.reduce((prev, curr) => {
 | 
			
		||||
      const { l: prevLightness } = getHsl(prev.hex);
 | 
			
		||||
      const { l: currLightness } = getHsl(curr.hex);
 | 
			
		||||
 | 
			
		||||
      const deltaPrev = Math.abs(prevLightness - l);
 | 
			
		||||
      const deltaCurr = Math.abs(currLightness - l);
 | 
			
		||||
 | 
			
		||||
      return deltaPrev < deltaCurr ? prev : curr;
 | 
			
		||||
    })
 | 
			
		||||
  };
 | 
			
		||||
 | 
			
		||||
  return paletteFamily;
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										2
									
								
								packages/color-palette/src/shared/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								packages/color-palette/src/shared/index.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,2 @@
 | 
			
		||||
export * from './colord';
 | 
			
		||||
export * from './name';
 | 
			
		||||
@@ -1,6 +1,11 @@
 | 
			
		||||
import { getHex, getHsl, getRgb } from './color';
 | 
			
		||||
import colorNames from './json/color-name.json';
 | 
			
		||||
import { colorNames } from '../constant';
 | 
			
		||||
import { getHex, getHsl, getRgb } from './colord';
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Get color name
 | 
			
		||||
 *
 | 
			
		||||
 * @param color
 | 
			
		||||
 */
 | 
			
		||||
export function getColorName(color: string) {
 | 
			
		||||
  const hex = getHex(color);
 | 
			
		||||
  const rgb = getRgb(color);
 | 
			
		||||
@@ -17,15 +22,13 @@ export function getColorName(color: string) {
 | 
			
		||||
  colorNames.some((item, index) => {
 | 
			
		||||
    const [hexValue, colorName] = item;
 | 
			
		||||
 | 
			
		||||
    const hexcode = `#${hexValue}`;
 | 
			
		||||
 | 
			
		||||
    const match = hex === hexcode;
 | 
			
		||||
    const match = hex === hexValue;
 | 
			
		||||
 | 
			
		||||
    if (match) {
 | 
			
		||||
      name = colorName;
 | 
			
		||||
    } else {
 | 
			
		||||
      const { r, g, b } = getRgb(hexcode);
 | 
			
		||||
      const { h, s, l } = getHsl(hexcode);
 | 
			
		||||
      const { r, g, b } = getRgb(hexValue);
 | 
			
		||||
      const { h, s, l } = getHsl(hexValue);
 | 
			
		||||
 | 
			
		||||
      ndf1 = (rgb.r - r) ** 2 + (rgb.g - g) ** 2 + (rgb.b - b) ** 2;
 | 
			
		||||
      ndf2 = (hsl.h - h) ** 2 + (hsl.s - s) ** 2 + (hsl.l - l) ** 2;
 | 
			
		||||
@@ -40,7 +43,7 @@ export function getColorName(color: string) {
 | 
			
		||||
    return match;
 | 
			
		||||
  });
 | 
			
		||||
 | 
			
		||||
  name = cl < 0 ? 'Invalid Color' : colorNames[cl][1];
 | 
			
		||||
  name = colorNames[cl][1];
 | 
			
		||||
 | 
			
		||||
  return name;
 | 
			
		||||
}
 | 
			
		||||
@@ -1,49 +0,0 @@
 | 
			
		||||
/** The color palette number */
 | 
			
		||||
export type ColorPaletteNumber = 50 | 100 | 200 | 300 | 400 | 500 | 600 | 700 | 800 | 900 | 950;
 | 
			
		||||
 | 
			
		||||
/** The color palette item */
 | 
			
		||||
export type ColorPaletteItem = {
 | 
			
		||||
  /** The color hexcode */
 | 
			
		||||
  hexcode: string;
 | 
			
		||||
  /**
 | 
			
		||||
   * The color number
 | 
			
		||||
   *
 | 
			
		||||
   * @link {@link ColorPaletteNumber}
 | 
			
		||||
   */
 | 
			
		||||
  number: ColorPaletteNumber;
 | 
			
		||||
  /** The color name */
 | 
			
		||||
  name: string;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
export type ColorPaletteFamily = {
 | 
			
		||||
  /** The color palette family key */
 | 
			
		||||
  key: string;
 | 
			
		||||
  /** The color palette family's palettes */
 | 
			
		||||
  palettes: ColorPaletteItem[];
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
export type ColorPaletteWithDelta = ColorPaletteItem & {
 | 
			
		||||
  delta: number;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
export type ColorPaletteItemWithName = ColorPaletteItem & {
 | 
			
		||||
  name: string;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
export type ColorPaletteFamilyWithNearestPalette = ColorPaletteFamily & {
 | 
			
		||||
  nearestPalette: ColorPaletteWithDelta;
 | 
			
		||||
  nearestLightnessPalette: ColorPaletteWithDelta;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
export type ColorPalette = ColorPaletteFamily & {
 | 
			
		||||
  /** The color map of the palette */
 | 
			
		||||
  colorMap: Map<ColorPaletteNumber, ColorPaletteItem>;
 | 
			
		||||
  /**
 | 
			
		||||
   * The main color of the palette
 | 
			
		||||
   *
 | 
			
		||||
   * Which number is 500
 | 
			
		||||
   */
 | 
			
		||||
  main: ColorPaletteItemWithName;
 | 
			
		||||
  /** The match color of the palette */
 | 
			
		||||
  match: ColorPaletteItemWithName;
 | 
			
		||||
};
 | 
			
		||||
							
								
								
									
										47
									
								
								packages/color-palette/src/types/index.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								packages/color-palette/src/types/index.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,47 @@
 | 
			
		||||
/** the color palette number */
 | 
			
		||||
export type ColorPaletteNumber = 50 | 100 | 200 | 300 | 400 | 500 | 600 | 700 | 800 | 900 | 950;
 | 
			
		||||
 | 
			
		||||
/** the color palette */
 | 
			
		||||
export type ColorPalette = {
 | 
			
		||||
  /** the color hex value */
 | 
			
		||||
  hex: string;
 | 
			
		||||
  /**
 | 
			
		||||
   * the color number
 | 
			
		||||
   *
 | 
			
		||||
   * - 50 | 100 | 200 | 300 | 400 | 500 | 600 | 700 | 800 | 900 | 950
 | 
			
		||||
   */
 | 
			
		||||
  number: ColorPaletteNumber;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/** the color palette family */
 | 
			
		||||
export type ColorPaletteFamily = {
 | 
			
		||||
  /** the color palette family name */
 | 
			
		||||
  name: string;
 | 
			
		||||
  /** the color palettes */
 | 
			
		||||
  palettes: ColorPalette[];
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/** the color palette with delta */
 | 
			
		||||
export type ColorPaletteWithDelta = ColorPalette & {
 | 
			
		||||
  delta: number;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/** the color palette family with nearest palette */
 | 
			
		||||
export type ColorPaletteFamilyWithNearestPalette = ColorPaletteFamily & {
 | 
			
		||||
  nearestPalette: ColorPaletteWithDelta;
 | 
			
		||||
  nearestLightnessPalette: ColorPaletteWithDelta;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/** the color palette match */
 | 
			
		||||
export type ColorPaletteMatch = ColorPaletteFamily & {
 | 
			
		||||
  /** the color map of the palette */
 | 
			
		||||
  colorMap: Map<ColorPaletteNumber, ColorPalette>;
 | 
			
		||||
  /**
 | 
			
		||||
   * the main color of the palette
 | 
			
		||||
   *
 | 
			
		||||
   * which number is 500
 | 
			
		||||
   */
 | 
			
		||||
  main: ColorPalette;
 | 
			
		||||
  /** the match color of the palette */
 | 
			
		||||
  match: ColorPalette;
 | 
			
		||||
};
 | 
			
		||||
@@ -81,14 +81,12 @@ export const useThemeStore = defineStore(SetupStoreId.Theme, () => {
 | 
			
		||||
   */
 | 
			
		||||
  function updateThemeColors(key: App.Theme.ThemeColorKey, color: string) {
 | 
			
		||||
    // get a color palette by provided color and color name, and use the suitable color
 | 
			
		||||
    const colorPalette = getColorPalette(color, key);
 | 
			
		||||
 | 
			
		||||
    const mainColor = colorPalette.main.hexcode;
 | 
			
		||||
    const { main } = getColorPalette(color);
 | 
			
		||||
 | 
			
		||||
    if (key === 'primary') {
 | 
			
		||||
      settings.value.themeColor = mainColor;
 | 
			
		||||
      settings.value.themeColor = main.hex;
 | 
			
		||||
    } else {
 | 
			
		||||
      settings.value.otherColor[key] = mainColor;
 | 
			
		||||
      settings.value.otherColor[key] = main.hex;
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -1,5 +1,5 @@
 | 
			
		||||
import type { GlobalThemeOverrides } from 'naive-ui';
 | 
			
		||||
import { getColorByColorPaletteNumber, getColorPalette } from '@sa/color-palette';
 | 
			
		||||
import { getColorByPaletteNumber, getColorPalette } from '@sa/color-palette';
 | 
			
		||||
import { addColorAlpha, getRgbOfColor } from '@sa/utils';
 | 
			
		||||
import { overrideThemeSettings, themeSettings } from '@/theme/settings';
 | 
			
		||||
import { themeVars } from '@/theme/vars';
 | 
			
		||||
@@ -81,12 +81,12 @@ function createThemePaletteColors(colors: App.Theme.ThemeColor) {
 | 
			
		||||
  const colorPaletteVar = {} as App.Theme.ThemePaletteColor;
 | 
			
		||||
 | 
			
		||||
  colorKeys.forEach(key => {
 | 
			
		||||
    const { palettes, main } = getColorPalette(colors[key], key);
 | 
			
		||||
    const { palettes, main } = getColorPalette(colors[key]);
 | 
			
		||||
 | 
			
		||||
    colorPaletteVar[key] = main.hexcode;
 | 
			
		||||
    colorPaletteVar[key] = main.hex;
 | 
			
		||||
 | 
			
		||||
    palettes.forEach(item => {
 | 
			
		||||
      colorPaletteVar[`${key}-${item.number}`] = item.hexcode;
 | 
			
		||||
      colorPaletteVar[`${key}-${item.number}`] = item.hex;
 | 
			
		||||
    });
 | 
			
		||||
  });
 | 
			
		||||
 | 
			
		||||
@@ -199,8 +199,8 @@ function getNaiveThemeColors(colors: App.Theme.ThemeColor) {
 | 
			
		||||
  const colorActions: NaiveColorAction[] = [
 | 
			
		||||
    { scene: '', handler: color => color },
 | 
			
		||||
    { scene: 'Suppl', handler: color => color },
 | 
			
		||||
    { scene: 'Hover', handler: color => getColorByColorPaletteNumber(color, 500) },
 | 
			
		||||
    { scene: 'Pressed', handler: color => getColorByColorPaletteNumber(color, 700) },
 | 
			
		||||
    { scene: 'Hover', handler: color => getColorByPaletteNumber(color, 500) },
 | 
			
		||||
    { scene: 'Pressed', handler: color => getColorByPaletteNumber(color, 700) },
 | 
			
		||||
    { scene: 'Active', handler: color => addColorAlpha(color, 0.1) }
 | 
			
		||||
  ];
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user