-
-
Notifications
You must be signed in to change notification settings - Fork 184
/
Copy pathindex.js
67 lines (53 loc) · 1.47 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
/* eslint-disable import/no-unresolved, import/extensions */
import { StyleSheet } from 'react-native'
import { arrayEach } from 'fast-loops'
import { processStyleWithPlugins, RULE_TYPE, CLEAR_TYPE } from 'fela-utils'
export function createRenderer(config = {}) {
let renderer = {
listeners: [],
cache: {},
plugins: config.plugins || [],
isNativeRenderer: true,
clear() {
renderer.cache = {}
renderer._emitChange({
type: CLEAR_TYPE,
})
},
subscribe(callback) {
renderer.listeners.push(callback)
return {
unsubscribe: () =>
renderer.listeners.splice(renderer.listeners.indexOf(callback), 1),
}
},
renderRule(rule, props = {}) {
const processedStyle = processStyleWithPlugins(
renderer,
rule(props, renderer),
RULE_TYPE,
props
)
const reference = JSON.stringify(processedStyle)
if (!renderer.cache.hasOwnProperty(reference)) {
renderer.cache[reference] = StyleSheet.create({
style: processedStyle,
})
renderer._emitChange({
type: RULE_TYPE,
style: processedStyle,
})
}
return renderer.cache[reference].style
},
_emitChange(change) {
arrayEach(renderer.listeners, (listener) => listener(change))
},
}
if (config.enhancers) {
arrayEach(config.enhancers, (enhancer) => {
renderer = enhancer(renderer)
})
}
return renderer
}