forked from jeffreyvr/tailwindcss-tailpress
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathindex.js
108 lines (94 loc) · 2.92 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
const plugin = require('tailwindcss/plugin');
const theme = (path, theme) => {
return path.split('.').reduce(function(previous, current) {
return previous ? previous[current] : null
}, theme || self);
}
const colorMapper = (colors) => {
let result = {};
colors.forEach(function(color) {
result[''+color.slug+''] = color.color;
});
return result;
}
const fontSizeMapper = (fontSizes) => {
let result = {};
fontSizes.forEach(function(fontSize) {
result[''+fontSize.slug+''] = fontSize.size;
});
return result;
}
const tailwind = plugin(function ({addUtilities, addComponents, e, prefix, config, theme}) {
const colors = theme('colors');
const margin = theme('margin');
const screens = theme('screens');
const fontSize = theme('fontSize');
const widthUtilities = {
'.w-wide': {
maxWidth: `${screens['xl']}`,
},
'.w-content': {
width: `${screens['lg']}`,
}
};
const maxWidthUtilities = {
'.max-w-wide': {
maxWidth: `${screens['xl']}`,
},
'.max-w-content': {
maxWidth: `${screens['lg']}`,
}
};
const alignmentUtilities = {
'.alignfull': {
margin: `${margin[8] || '0.5rem'} calc(50% - 50vw)`,
maxWidth: '100vw',
"@apply w-screen": {}
},
'.alignwide': {
margin: `${margin[8] || '0.5rem'} 0`,
"@apply !max-w-wide": {}
},
'.alignnone': {
"@apply h-auto max-w-full mx-0": {}
},
".aligncenter": {
margin: `${margin[2] || '0.5rem'} auto`,
"@apply block": {}
},
[`@media (min-width: ${screens.sm || '640px'})`]: {
'.alignleft:not(.wp-block-button)': {
marginRight: margin[2] || '0.5rem',
"@apply float-left": {}
},
'.alignright:not(.wp-block-button)': {
marginLeft: margin[2] || '0.5rem',
"@apply float-right": {}
},
".wp-block-button.alignleft a": {
"@apply float-left mr-4": {},
},
".wp-block-button.alignright a": {
"@apply float-right ml-4": {},
},
},
};
const imageCaptions = {
'.wp-caption': {
"@apply inline-block": {},
'& img': {
marginBottom: margin[2] || '0.5rem',
"@apply leading-none": {}
},
},
'.wp-caption-text': {
fontSize: (fontSize.sm && fontSize.sm[0]) || '0.9rem',
color: (colors.gray && colors.gray[600]) || '#718096',
},
};
addUtilities([widthUtilities, maxWidthUtilities, alignmentUtilities , imageCaptions], {
respectPrefix: false,
respectImportant: false,
});
});
module.exports = {theme, colorMapper, fontSizeMapper, tailwind};