forked from tailwindlabs/tailwindcss
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathspacing.js
More file actions
102 lines (97 loc) · 2.35 KB
/
spacing.js
File metadata and controls
102 lines (97 loc) · 2.35 KB
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
import _ from 'lodash'
import defineClasses from '../util/defineClasses'
function definePadding(padding) {
return _.flatMap(padding, (size, modifier) => {
return defineClasses({
[`pt-${modifier}`]: {
'padding-top': `${size}`,
},
[`pr-${modifier}`]: {
'padding-right': `${size}`,
},
[`pb-${modifier}`]: {
'padding-bottom': `${size}`,
},
[`pl-${modifier}`]: {
'padding-left': `${size}`,
},
[`px-${modifier}`]: {
'padding-left': `${size}`,
'padding-right': `${size}`,
},
[`py-${modifier}`]: {
'padding-top': `${size}`,
'padding-bottom': `${size}`,
},
[`p-${modifier}`]: {
padding: `${size}`,
},
})
})
}
function defineMargin(margin) {
return _.flatMap(margin, (size, modifier) => {
return defineClasses({
[`mt-${modifier}`]: {
'margin-top': `${size}`,
},
[`mr-${modifier}`]: {
'margin-right': `${size}`,
},
[`mb-${modifier}`]: {
'margin-bottom': `${size}`,
},
[`ml-${modifier}`]: {
'margin-left': `${size}`,
},
[`mx-${modifier}`]: {
'margin-left': `${size}`,
'margin-right': `${size}`,
},
[`my-${modifier}`]: {
'margin-top': `${size}`,
'margin-bottom': `${size}`,
},
[`m-${modifier}`]: {
margin: `${size}`,
},
})
})
}
function defineNegativeMargin(negativeMargin) {
return _.flatMap(negativeMargin, (size, modifier) => {
size = `${size}` === '0' ? `${size}` : `-${size}`
return defineClasses({
[`-mt-${modifier}`]: {
'margin-top': `${size}`,
},
[`-mr-${modifier}`]: {
'margin-right': `${size}`,
},
[`-mb-${modifier}`]: {
'margin-bottom': `${size}`,
},
[`-ml-${modifier}`]: {
'margin-left': `${size}`,
},
[`-mx-${modifier}`]: {
'margin-left': `${size}`,
'margin-right': `${size}`,
},
[`-my-${modifier}`]: {
'margin-top': `${size}`,
'margin-bottom': `${size}`,
},
[`-m-${modifier}`]: {
margin: `${size}`,
},
})
})
}
export default function({ padding, margin, negativeMargin }) {
return _.flatten([
definePadding(padding),
defineMargin(margin),
defineNegativeMargin(negativeMargin),
])
}