forked from swiftlang/swift-docc-render
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbreakpoints.js
68 lines (63 loc) · 1.57 KB
/
breakpoints.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
/**
* This source file is part of the Swift.org open source project
*
* Copyright (c) 2021 Apple Inc. and the Swift project authors
* Licensed under Apache License v2.0 with Runtime Library Exception
*
* See https://swift.org/LICENSE.txt for license information
* See https://swift.org/CONTRIBUTORS.txt for Swift project authors
*/
export const BreakpointName = {
large: 'large',
medium: 'medium',
small: 'small',
};
export const BreakpointScopes = {
default: 'default',
nav: 'nav',
};
export const BreakpointAttributes = {
[BreakpointScopes.default]: {
[BreakpointName.large]: {
minWidth: 1069,
contentWidth: 980,
},
[BreakpointName.medium]: {
minWidth: 736,
maxWidth: 1068,
contentWidth: 692,
},
[BreakpointName.small]: {
minWidth: 320,
maxWidth: 735,
contentWidth: 280,
},
},
[BreakpointScopes.nav]: {
[BreakpointName.large]: {
minWidth: 1024,
},
[BreakpointName.medium]: {
minWidth: 768,
maxWidth: 1023,
},
[BreakpointName.small]: {
minWidth: 320,
maxWidth: 767,
},
},
};
const breakpointWeights = {
[BreakpointName.small]: 0,
[BreakpointName.medium]: 1,
[BreakpointName.large]: 2,
};
/**
* Returns whether the provided breakpoint is above the target
* @param {'small'|'medium'|'large'} breakpoint - Breakpoint to test.
* @param {'small'|'medium'|'large'} target - Target breakpoint.
* @return {boolean}
*/
export function isBreakpointAbove(breakpoint, target) {
return breakpointWeights[breakpoint] > breakpointWeights[target];
}