forked from quasarframework/quasar
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDark.js
More file actions
95 lines (74 loc) · 2.07 KB
/
Dark.js
File metadata and controls
95 lines (74 loc) · 2.07 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
import Vue from 'vue'
import { isSSR, fromSSR } from './Platform.js'
import { noop } from '../utils/event.js'
const Dark = {
isActive: false,
mode: false,
install ($q, queues, { dark }) {
this.isActive = dark === true
if (isSSR === true) {
queues.server.push((q, ctx) => {
q.dark = {
isActive: false,
mode: false,
set: val => {
ctx.ssr.Q_BODY_CLASSES = ctx.ssr.Q_BODY_CLASSES
.replace(' body--light', '')
.replace(' body--dark', '') + ` body--${val === true ? 'dark' : 'light'}`
q.dark.isActive = val === true
q.dark.mode = val
},
toggle: () => {
q.dark.set(q.dark.isActive === false)
}
}
q.dark.set(dark)
})
this.set = noop
return
}
const initialVal = dark !== void 0
? dark
: false
if (fromSSR === true) {
const ssrSet = val => {
this.__fromSSR = val
}
const originalSet = this.set
this.set = ssrSet
ssrSet(initialVal)
queues.takeover.push(() => {
this.set = originalSet
this.set(this.__fromSSR)
})
}
else {
this.set(initialVal)
}
Vue.util.defineReactive(this, 'isActive', this.isActive)
Vue.util.defineReactive($q, 'dark', this)
},
set (val) {
this.mode = val
if (val === 'auto') {
if (this.__media === void 0) {
this.__media = window.matchMedia('(prefers-color-scheme: dark)')
this.__updateMedia = () => { this.set('auto') }
this.__media.addListener(this.__updateMedia)
}
val = this.__media.matches
}
else if (this.__media !== void 0) {
this.__media.removeListener(this.__updateMedia)
this.__media = void 0
}
this.isActive = val === true
document.body.classList.remove(`body--${val === true ? 'light' : 'dark'}`)
document.body.classList.add(`body--${val === true ? 'dark' : 'light'}`)
},
toggle () {
Dark.set(Dark.isActive === false)
},
__media: void 0
}
export default Dark