소스 검색

Merge pull request #22 from piemonkey/add-support-for-custom-css

Add support for custom css
iou90 7 년 전
부모
커밋
310081e250
No account linked to committer's email address
3개의 변경된 파일75개의 추가작업 그리고 31개의 파일을 삭제
  1. 11
    1
      README.md
  2. 30
    18
      autoHeightWebView/index.android.js
  3. 34
    12
      autoHeightWebView/index.ios.js

+ 11
- 1
README.md 파일 보기

50
         rel: 'stylesheet'
50
         rel: 'stylesheet'
51
     }]}
51
     }]}
52
     // change script (have to change source to reload on android)
52
     // change script (have to change source to reload on android)
53
-    customScript={`document.body.style.background = 'lightyellow';`} />
53
+    customScript={`document.body.style.background = 'lightyellow';`}
54
+    // add custom CSS to the page's <head>
55
+    customStyle={`
56
+      * {
57
+        font-family: 'Times New Roman';
58
+      }
59
+      p {
60
+        font-size: 16px;
61
+      }
62
+    `}
63
+  />
54
 ```
64
 ```
55
 
65
 
56
 # demo
66
 # demo

+ 30
- 18
autoHeightWebView/index.android.js 파일 보기

31
     source: WebView.propTypes.source,
31
     source: WebView.propTypes.source,
32
     onHeightUpdated: PropTypes.func,
32
     onHeightUpdated: PropTypes.func,
33
     customScript: PropTypes.string,
33
     customScript: PropTypes.string,
34
+    customStyle: PropTypes.string,
34
     enableAnimation: PropTypes.bool,
35
     enableAnimation: PropTypes.bool,
35
     // if set to false may cause some layout issues (width of container will be than width of screen)
36
     // if set to false may cause some layout issues (width of container will be than width of screen)
36
     scalesPageToFit: PropTypes.bool,
37
     scalesPageToFit: PropTypes.bool,
70
         this
71
         this
71
       );
72
       );
72
     }
73
     }
73
-    const initialScript = props.files
74
+    let initialScript = props.files
74
       ? this.appendFilesToHead(props.files, BaseScript)
75
       ? this.appendFilesToHead(props.files, BaseScript)
75
       : BaseScript;
76
       : BaseScript;
77
+    initialScript = props.customStyle
78
+      ? this.appendStylesToHead(props.customStyle, initialScript)
79
+      : initialScript;
76
     this.state = {
80
     this.state = {
77
       isChangingSource: false,
81
       isChangingSource: false,
78
       height: 0,
82
       height: 0,
120
     if (nextProps.files) {
124
     if (nextProps.files) {
121
       currentScript = this.appendFilesToHead(nextProps.files, BaseScript);
125
       currentScript = this.appendFilesToHead(nextProps.files, BaseScript);
122
     }
126
     }
127
+    currentScript = nextProps.customStyle
128
+      ? this.appendStylesToHead(nextProps.customStyle, currentScript)
129
+      : currentScript;
123
     this.setState({ script: currentScript });
130
     this.setState({ script: currentScript });
124
   }
131
   }
125
 
132
 
209
     if (!files) {
216
     if (!files) {
210
       return script;
217
       return script;
211
     }
218
     }
212
-    for (let file of files) {
213
-      script =
214
-        `
215
-                var link  = document.createElement('link');
216
-                link.rel  = '` +
217
-        file.rel +
218
-        `';
219
-                link.type = '` +
220
-        file.type +
221
-        `';
222
-                link.href = '` +
223
-        file.href +
224
-        `';
225
-                document.head.appendChild(link);
226
-                ` +
227
-        script;
219
+    return files.reduceRight((file, combinedScript) => `
220
+      var link  = document.createElement('link');
221
+      link.rel  = '${file.rel}';
222
+      link.type = '${file.type}';
223
+      link.href = '${file.href}';
224
+      document.head.appendChild(link);
225
+      ${combinedScript}
226
+    `, script)
227
+  }
228
+
229
+  appendStylesToHead(styles, script) {
230
+    if (!styles) {
231
+      return script;
228
     }
232
     }
229
-    return script;
233
+    // Escape any single quotes or newlines in the CSS with .replace()
234
+    const escaped = styles.replace(/\'/g, "\\'").replace(/\n/g, '\\n')
235
+    return `
236
+      var styleElement = document.createElement('style');
237
+      var styleText = document.createTextNode('${escaped}');
238
+      styleElement.appendChild(styleText);
239
+      document.head.appendChild(styleElement);
240
+      ${script}
241
+    `
230
   }
242
   }
231
 
243
 
232
   render() {
244
   render() {

+ 34
- 12
autoHeightWebView/index.ios.js 파일 보기

19
         source: WebView.propTypes.source,
19
         source: WebView.propTypes.source,
20
         onHeightUpdated: PropTypes.func,
20
         onHeightUpdated: PropTypes.func,
21
         customScript: PropTypes.string,
21
         customScript: PropTypes.string,
22
+        customStyle: PropTypes.string,
22
         enableAnimation: PropTypes.bool,
23
         enableAnimation: PropTypes.bool,
23
         // if set to true may cause some layout issues (smaller font size)
24
         // if set to true may cause some layout issues (smaller font size)
24
         scalesPageToFit: PropTypes.bool,
25
         scalesPageToFit: PropTypes.bool,
48
         if (this.props.enableAnimation) {
49
         if (this.props.enableAnimation) {
49
             this.opacityAnimatedValue = new Animated.Value(0);
50
             this.opacityAnimatedValue = new Animated.Value(0);
50
         }
51
         }
51
-        const initialScript = props.files ? this.appendFilesToHead(props.files, props.hasIframe ? IframeBaseScript : BaseScript) : props.hasIframe ? IframeBaseScript : BaseScript;
52
+        let initialScript = props.hasIframe ? IframeBaseScript : BaseScript;
53
+        initialScript = props.files
54
+          ? this.appendFilesToHead(props.files, BaseScript)
55
+          : BaseScript;
56
+        initialScript = props.customStyle
57
+          ? this.appendStylesToHead(props.customStyle, initialScript)
58
+          : initialScript;
52
         this.state = {
59
         this.state = {
53
             height: 0,
60
             height: 0,
54
             script: initialScript
61
             script: initialScript
58
     componentWillReceiveProps(nextProps) {
65
     componentWillReceiveProps(nextProps) {
59
         let currentScript = nextProps.hasIframe ? IframeBaseScript : BaseScript;
66
         let currentScript = nextProps.hasIframe ? IframeBaseScript : BaseScript;
60
         if (nextProps.files) {
67
         if (nextProps.files) {
61
-            currentScript = this.appendFilesToHead(nextProps.files, nextProps.hasIframe ? IframeBaseScript : BaseScript);
68
+            currentScript = this.appendFilesToHead(nextProps.files, currentScript);
62
         }
69
         }
70
+        currentScript = nextProps.customStyle
71
+          ? this.appendStylesToHead(nextProps.customStyle, currentScript)
72
+          : currentScript;
63
         this.setState({ script: currentScript });
73
         this.setState({ script: currentScript });
64
     }
74
     }
65
 
75
 
67
         if (!files) {
77
         if (!files) {
68
             return script;
78
             return script;
69
         }
79
         }
70
-        for (let file of files) {
71
-            script =
72
-                `
73
-                var link  = document.createElement('link');
74
-                link.rel  = '` + file.rel + `';
75
-                link.type = '` + file.type + `';
76
-                link.href = '` + file.href + `';
77
-                document.head.appendChild(link);
78
-                `+ script;
79
-        }
80
+        return files.reduceRight((file, combinedScript) => `
81
+          var link  = document.createElement('link');
82
+          link.rel  = '${file.rel}';
83
+          link.type = '${file.type}';
84
+          link.href = '${file.href}';
85
+          document.head.appendChild(link);
86
+          ${combinedScript}
87
+        `, script)
88
+    }
89
+
90
+    appendStylesToHead(styles, script) {
91
+      if (!styles) {
80
         return script;
92
         return script;
93
+      }
94
+      // Escape any single quotes or newlines in the CSS with .replace()
95
+      const escaped = styles.replace(/\'/g, "\\'").replace(/\n/g, '\\n')
96
+      return `
97
+        var styleElement = document.createElement('style');
98
+        var styleText = document.createTextNode('${escaped}');
99
+        styleElement.appendChild(styleText);
100
+        document.head.appendChild(styleElement);
101
+        ${script}
102
+      `
81
     }
103
     }
82
 
104
 
83
     onHeightUpdated(height) {
105
     onHeightUpdated(height) {