tailwind.config.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304
  1. const plugin = require('tailwindcss/plugin')
  2. const colors = require('tailwindcss/colors')
  3. const radix = require('@radix-ui/colors')
  4. const gradientColors = {
  5. tomato: ["amber", "orange", "tomato", "red", "crimson"],
  6. red: ["orange", "tomato", "red", "crimson", "pink"],
  7. crimson: ["tomato", "red", "crimson", "pink", "plum"],
  8. pink: ["red", "crimson", "pink", "plum", "purple"],
  9. plum: ["crimson", "pink", "plum", "purple", "violet"],
  10. purple: ["pink", "plum", "purple", "violet", "indigo"],
  11. violet: ["plum", "purple", "violet", "indigo", "blue"],
  12. indigo: ["purple", "violet", "indigo", "blue", "cyan"],
  13. blue: ["violet", "indigo", "blue", "cyan", "teal"],
  14. // sky: ["indigo", "blue", "sky", "cyan", "teal"],
  15. cyan: ["indigo", "blue", "cyan", "teal", "green"],
  16. teal: ["blue", "cyan", "teal", "green", "grass"],
  17. // mint: ["cyan", "teal", "mint", "green", "grass"],
  18. green: ["cyan", "teal", "green", "grass", "amber"],
  19. grass: ["teal", "green", "grass", "amber", "orange"],
  20. // lime: ["green", "grass", "lime", "yellow", "amber"],
  21. // yellow: ["grass", "lime", "yellow", "amber", "orange"],
  22. amber: ["green", "grass", "amber", "orange", "tomato"],
  23. orange: ["grass", "amber", "orange", "tomato", "red"],
  24. // brown: ["green", "grass", "brown", "tomato", "red"],
  25. }
  26. function exposeColorsToCssVars ({ addBase, theme }) {
  27. function extractColorVars (colorObj, colorGroup = '') {
  28. return Object.keys(colorObj).reduce((vars, colorKey) => {
  29. const value = colorObj[colorKey]
  30. const newVars =
  31. typeof value === 'string'
  32. ? { [`--color${colorGroup}-${colorKey}`]: value }
  33. : extractColorVars(value, `-${colorKey}`)
  34. return { ...vars, ...newVars }
  35. }, {})
  36. }
  37. addBase({
  38. ':root': extractColorVars(theme('colors')),
  39. })
  40. }
  41. function buildColor(color, custom) {
  42. const base = custom || colors[color] || {}
  43. for (const [xName, xValue] of Object.entries(radix[color] || {})) {
  44. const regexResult = xName.match(/\d+$/)
  45. if (!regexResult) { continue; }
  46. const xStep = regexResult[0]
  47. base[xStep] = xValue
  48. }
  49. return base
  50. }
  51. // this will allow us to use gradient color functions in the ui:
  52. // grad-bg-tomato-3 OR grad-bg-tomato-3-alpha
  53. // it will also loop through all 5 color stops, unless the stops are specified
  54. // grad-bg-stops-3
  55. // this will have a default repeating gradient at a step that can be configured with
  56. // grad-bg-cycle-32
  57. const addGradientColors = plugin(({ addBase, addComponents, addUtilities, config, ___theme }) => {
  58. const dark = getDarkSelector(config)
  59. addUtilities({
  60. ['.grad-bg-stops-3']: {
  61. '--grad-bg-stops': "var(--grad-bg-stop-b), var(--grad-bg-stop-c), var(--grad-bg-stop-d)",
  62. },
  63. ['.grad-bg-stops-5']: {
  64. '--grad-bg-stops': "var(--grad-bg-stop-a), var(--grad-bg-stop-b), var(--grad-bg-stop-c), var(--grad-bg-stop-d), var(--grad-bg-stop-e)",
  65. },
  66. ['.grad-bg-cycle-12']: {
  67. 'background-image': 'repeatint-linear-gradient(to right, var(--grad-bg-stops))',
  68. },
  69. })
  70. Object.values(gradientColors).forEach((stops, ___index) => {
  71. const baseColor = stops[2]
  72. const color = (scale, stopIndex = 2, suffix = "") => `--color-${stops[stopIndex]}${suffix}-${scale}`
  73. addComponents({
  74. // tailwind componnent for .grad-bg-COLOR-9
  75. [`.grad-bg-${baseColor}-9`]: {
  76. "--grad-bg-stop-a": `var(${color(9, 0)})`,
  77. "--grad-bg-stop-b": `var(${color(9, 1)})`,
  78. "--grad-bg-stop-c": `var(${color(9, 2)})`,
  79. "--grad-bg-stop-d": `var(${color(9, 3)})`,
  80. "--grad-bg-stop-e": `var(${color(9, 4)})`,
  81. "--grad-bg-stops-default": `var(--grad-bg-stop-b), var(--grad-bg-stop-c), var(--grad-bg-stop-d)`,
  82. "background-image": `linear-gradient(var(--grad-bg-direction, to right), var(--grad-bg-stops, var(--grad-bg-stops-default)))`,
  83. [dark]: {
  84. "--grad-bg-stop-a": `var(${color(9, 0, "dark")})`,
  85. "--grad-bg-stop-b": `var(${color(9, 1, "dark")})`,
  86. "--grad-bg-stop-c": `var(${color(9, 2, "dark")})`,
  87. "--grad-bg-stop-d": `var(${color(9, 3, "dark")})`,
  88. "--grad-bg-stop-e": `var(${color(9, 4, "dark")})`,
  89. }
  90. },
  91. // tailwind component for .grad-bg-COLOR-9-alpha
  92. [`.grad-bg-${baseColor}-9-alpha`]: {
  93. "--grad-bg-stop-a": `var(${color(9, 0)})`,
  94. "--grad-bg-stop-b": `var(${color(9, 1)})`,
  95. "--grad-bg-stop-c": `var(${color(9, 2)})`,
  96. "--grad-bg-stop-d": `var(${color(9, 3)})`,
  97. "--grad-bg-stop-e": `var(${color(9, 4)})`,
  98. "--grad-bg-stops-default": `var(--grad-bg-stop-b), var(--grad-bg-stop-c), var(--grad-bg-stop-d)`,
  99. "background-image": `linear-gradient(var(--grad-bg-direction, to right), var(--grad-bg-stops, var(--grad-bg-stops-default)))`,
  100. [dark]: {
  101. "--grad-bg-stop-a": `var(${color(9, 0, "dark")})`,
  102. "--grad-bg-stop-b": `var(${color(9, 1, "dark")})`,
  103. "--grad-bg-stop-c": `var(${color(9, 2, "dark")})`,
  104. "--grad-bg-stop-d": `var(${color(9, 3, "dark")})`,
  105. "--grad-bg-stop-e": `var(${color(9, 4, "dark")})`,
  106. }
  107. },
  108. })
  109. })
  110. })
  111. function getDarkSelector(config) {
  112. const darkMode = config("darkMode");
  113. const prefix = config("prefix");
  114. if (Array.isArray(darkMode)) {
  115. if (darkMode.length < 2) {
  116. throw new Error(
  117. "To customize the dark mode selector, `darkMode` should contain two items. Documentation: https://tailwindcss.com/docs/dark-mode#customizing-the-class-name"
  118. );
  119. }
  120. if (darkMode[0] !== "class") {
  121. throw new Error(
  122. 'To customize the dark mode selector, `darkMode` should have "class" as its first item. Documentation: https://tailwindcss.com/docs/dark-mode#customizing-the-class-name'
  123. );
  124. }
  125. return darkMode[1] + " &";
  126. }
  127. if (darkMode === "media") {
  128. return "@media (prefers-color-scheme: dark)";
  129. }
  130. if (darkMode !== "class") {
  131. throw new Error(
  132. "Invalid `darkMode`. Documentation: https://tailwindcss.com/docs/dark-mode"
  133. );
  134. }
  135. if (prefix) {
  136. return `[class~="${prefix}dark"] &`;
  137. }
  138. return '[class~="dark"] &';
  139. }
  140. module.exports = {
  141. darkMode: 'class',
  142. content: [
  143. './src/**/*.js',
  144. './src/**/*.cljs',
  145. './resources/**/*.html',
  146. './deps/shui/src/**/*.cljs',
  147. ],
  148. safelist: [
  149. 'bg-black', 'bg-white', 'capitalize-first',
  150. { pattern: /bg-(gray|red|yellow|green|blue|orange|indigo|rose|purple|pink)-(100|200|300|400|500|600|700|800|900)/ },
  151. { pattern: /text-(gray|red|yellow|green|blue|orange|indigo|rose|purple|pink)-(100|200|300|400|500|600|700|800|900)/ },
  152. { pattern: /columns-([1-9]|1[0-2])|(auto|3xs|2xs|xs|sm|md|lg|xl)|([2-7]xl)/ },
  153. { pattern: /bg-(mauve|slate|sage|olive|sand|tomato|red|crimson|pink|plum|purple|violet|indigo|blue|sky|cyan|teal|mint|green|grass|lime|yellow|amber|orange|brown)(dark)?-(1|2|3|4|5|6|7|8|9|10|11|12)/ },
  154. { pattern: /shadow-(mauve|slate|sage|olive|sand|tomato|red|crimson|pink|plum|purple|violet|indigo|blue|sky|cyan|teal|mint|green|grass|lime|yellow|amber|orange|brown)(dark)?-(1|2|3|4|5|6|7|8|9|10|11|12)/ },
  155. { pattern: /text-(mauve|slate|sage|olive|sand|tomato|red|crimson|pink|plum|purple|violet|indigo|blue|sky|cyan|teal|mint|green|grass|lime|yellow|amber|orange|brown)(dark)?-(1|2|3|4|5|6|7|8|9|10|11|12)/ },
  156. { pattern: /ring-(mauve|slate|sage|olive|sand|tomato|red|crimson|pink|plum|purple|violet|indigo|blue|sky|cyan|teal|mint|green|grass|lime|yellow|amber|orange|brown)(dark)?-(1|2|3|4|5|6|7|8|9|10|11|12)/ },
  157. { pattern: /from-(mauve|slate|sage|olive|sand|tomato|red|crimson|pink|plum|purple|violet|indigo|blue|sky|cyan|teal|mint|green|grass|lime|yellow|amber|orange|brown)(dark)?-(1|2|3|4|5|6|7|8|9|10|11|12)/ },
  158. { pattern: /via-(mauve|slate|sage|olive|sand|tomato|red|crimson|pink|plum|purple|violet|indigo|blue|sky|cyan|teal|mint|green|grass|lime|yellow|amber|orange|brown)(dark)?-(1|2|3|4|5|6|7|8|9|10|11|12)/ },
  159. { pattern: /to-(mauve|slate|sage|olive|sand|tomato|red|crimson|pink|plum|purple|violet|indigo|blue|sky|cyan|teal|mint|green|grass|lime|yellow|amber|orange|brown)(dark)?-(1|2|3|4|5|6|7|8|9|10|11|12)/ },
  160. { pattern: /border-(mauve|slate|sage|olive|sand|tomato|red|crimson|pink|plum|purple|violet|indigo|blue|sky|cyan|teal|mint|green|grass|lime|yellow|amber|orange|brown)(dark)?-(4|5|6|7|8)/ },
  161. ],
  162. plugins: [
  163. require('@tailwindcss/forms'),
  164. require('@tailwindcss/typography'),
  165. require('@tailwindcss/aspect-ratio'),
  166. require('@tailwindcss/line-clamp'),
  167. require('tailwind-capitalize-first-letter'),
  168. addGradientColors,
  169. exposeColorsToCssVars
  170. ],
  171. theme: {
  172. extend: {
  173. backgroundImage: {
  174. 'gradient-conic': 'conic-gradient(var(--tw-gradient-stops))',
  175. 'gradient-conic-bounce': 'conic-gradient(var(--tw-gradient-from), var(--tw-gradient-via), var(--tw-gradient-to), var(--tw-gradient-via), var(--tw-gradient-from))',
  176. 'gradient-radial': 'radial-gradient(var(--tw-gradient-stops))',
  177. },
  178. fontSize: {
  179. '2xs': ['0.625rem', '0.875rem']
  180. },
  181. animation: {
  182. 'spin-reverse': 'spin 2s linear infinite reverse',
  183. },
  184. spacing: {
  185. '128': '32rem',
  186. '144': '36rem'
  187. },
  188. scale: {
  189. '200': '2',
  190. '250': '2.5',
  191. '300': '3',
  192. '400': '4',
  193. },
  194. width: {
  195. 'lsm': '600px',
  196. 'lmd': '728px',
  197. 'llg': '960px'
  198. }
  199. },
  200. colors: {
  201. // Tailwind colors
  202. black: colors.black,
  203. current: 'currentColor',
  204. rose: colors.rose,
  205. transparent: 'transparent',
  206. white: colors.white,
  207. // Radix colors
  208. amber: buildColor("amber"),
  209. blue: buildColor("blue"),
  210. bronze: buildColor("bronze"),
  211. brown: buildColor("brown"),
  212. crimson: buildColor("crimson"),
  213. cyan: buildColor("cyan"),
  214. gold: buildColor("gold"),
  215. grass: buildColor("grass"),
  216. green: buildColor("green"),
  217. lime: buildColor("lime"),
  218. mauve: buildColor("mauve"),
  219. mint: buildColor("mint"),
  220. olive: buildColor("olive"),
  221. orange: buildColor("orange"),
  222. pink: buildColor("pink"),
  223. plum: buildColor("plum"),
  224. purple: buildColor("purple"),
  225. red: buildColor("red"),
  226. sage: buildColor("sage"),
  227. sand: buildColor("sand"),
  228. sky: buildColor("sky"),
  229. slate: buildColor("slate"),
  230. teal: buildColor("teal"),
  231. tomato: buildColor("tomato"),
  232. violet: buildColor("violet"),
  233. // Custom colors
  234. gray: buildColor("gray", colors.neutral),
  235. yellow: buildColor("yellow", colors.amber),
  236. indigo: buildColor("indigo", {
  237. 50: '#f0f9ff',
  238. 100: '#e0f2fe',
  239. 200: '#bae6fd',
  240. 300: '#7dd3fc',
  241. 400: '#38bdf8',
  242. 500: '#0ea5e9',
  243. 600: '#0284c7',
  244. 700: '#005b8a',
  245. 800: '#075985',
  246. 900: '#0c4a6e',
  247. }),
  248. tomatodark: buildColor("tomatoDark"),
  249. reddark: buildColor("redDark"),
  250. crimsondark: buildColor("crimsonDark"),
  251. pinkdark: buildColor("pinkDark"),
  252. plumdark: buildColor("plumDark"),
  253. purpledark: buildColor("purpleDark"),
  254. violetdark: buildColor("violetDark"),
  255. skydark: buildColor("skyDark"),
  256. indigodark: buildColor("indigoDark"),
  257. bluedark: buildColor("blueDark"),
  258. cyandark: buildColor("cyanDark"),
  259. mintdark: buildColor("mintDark"),
  260. tealdark: buildColor("tealDark"),
  261. greendark: buildColor("greenDark"),
  262. limedark: buildColor("limeDark"),
  263. grassdark: buildColor("grassDark"),
  264. yellowdark: buildColor("yellowDark"),
  265. amberdark: buildColor("amberDark"),
  266. orangedark: buildColor("orangeDark"),
  267. browndark: buildColor("brownDark"),
  268. graydark: buildColor("grayDark"),
  269. mauvedark: buildColor("mauveDark"),
  270. slatedark: buildColor("slateDark"),
  271. sagedark: buildColor("sageDark"),
  272. olivedark: buildColor("oliveDark"),
  273. sanddark: buildColor("sandDark"),
  274. golddark: buildColor("goldDark"),
  275. bronzedark: buildColor("bronzeDark"),
  276. }
  277. }
  278. }