@zohodesk/react-cli 0.0.1-beta.176 → 0.0.1-beta.178

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (126) hide show
  1. package/.eslintignore +7 -7
  2. package/.eslintrc.js +180 -180
  3. package/.prettierrc +6 -6
  4. package/{CHANGELOG.md → CHANGELOG-fz.md} +0 -0
  5. package/Changelog.md +1019 -0
  6. package/README.md +1137 -1018
  7. package/bin/cli.js +482 -482
  8. package/docs/CustomChunks.md +26 -26
  9. package/docs/DevServerPort.md +39 -0
  10. package/docs/DevStart.md +18 -18
  11. package/docs/HoverActive.md +12 -12
  12. package/docs/InstallNode.md +28 -28
  13. package/docs/SelectorWeight.md +6 -6
  14. package/docs/TODOS.md +10 -10
  15. package/docs/ValueReplacer.md +60 -60
  16. package/docs/VariableConversion.md +724 -710
  17. package/docs/warnings_while_install.txt +35 -35
  18. package/files/eslintrc.js +62 -62
  19. package/files/prettierrc.js +3 -3
  20. package/lib/configs/resolvers.js +40 -0
  21. package/lib/configs/webpack.css.umd.config.js +4 -4
  22. package/lib/configs/webpack.dev.config.js +4 -11
  23. package/lib/configs/webpack.docs.config.js +4 -11
  24. package/lib/configs/webpack.impact.config.js +5 -7
  25. package/lib/configs/webpack.prod.config.js +9 -13
  26. package/lib/constants.js +31 -0
  27. package/lib/loaderUtils/configsAssetsLoaders.js +36 -36
  28. package/lib/loaders/workerLoader.js +9 -9
  29. package/lib/pluginUtils/getDevPlugins.js +5 -5
  30. package/lib/pluginUtils/getProdPlugins.js +5 -5
  31. package/lib/plugins/EFCPlugin.md +6 -6
  32. package/lib/plugins/I18NInjectIntoIndexPlugin.js +4 -4
  33. package/lib/plugins/I18nSplitPlugin/I18nDownlodLogic.js +38 -38
  34. package/lib/plugins/I18nSplitPlugin/I18nFilesEmitter.js +30 -30
  35. package/lib/plugins/I18nSplitPlugin/I18nKeysIdentifer.js +8 -8
  36. package/lib/plugins/I18nSplitPlugin/I18nSplit.md +95 -95
  37. package/lib/plugins/I18nSplitPlugin/README.md +25 -25
  38. package/lib/plugins/I18nSplitPlugin/index.js +57 -57
  39. package/lib/plugins/ResourceHintsPlugin.js +17 -17
  40. package/lib/plugins/RtlSplitPlugin/RtlCssPlugin.js +6 -6
  41. package/lib/plugins/RtlSplitPlugin/RtrSplit.md +30 -30
  42. package/lib/plugins/ServiceWorkerPlugin.js +9 -9
  43. package/lib/plugins/TPHashMappingPlugin.js +4 -4
  44. package/lib/plugins/VariableConversionCollector.js +198 -98
  45. package/lib/postcss-plugins/RTLSplitPlugin.js +10 -10
  46. package/lib/postcss-plugins/__test__/test1Input.css +38 -38
  47. package/lib/postcss-plugins/__test__/test1Output.css +38 -38
  48. package/lib/postcss-plugins/hoverActivePlugin.js +3 -3
  49. package/lib/postcss-plugins/variableModificationPlugin/ErrorHandler.js +4 -2
  50. package/lib/postcss-plugins/variableModificationPlugin/index.js +2 -1
  51. package/lib/schemas/index.js +8 -0
  52. package/lib/servers/docsServerCore.js +13 -12
  53. package/lib/servers/httpsOptions.js +40 -9
  54. package/lib/servers/nowatchserver.js +12 -11
  55. package/lib/servers/server.js +23 -20
  56. package/lib/sh/pre-commit.sh +34 -34
  57. package/lib/sh/reportPublish.sh +45 -45
  58. package/lib/utils/buildstats.html +148 -148
  59. package/lib/utils/cssURLReplacer.js +30 -43
  60. package/lib/utils/getFileType.js +49 -0
  61. package/lib/utils/getOptions.js +13 -13
  62. package/lib/utils/resultSchema.json +73 -73
  63. package/npm8.md +9 -9
  64. package/package.json +121 -146
  65. package/postpublish.js +8 -6
  66. package/templates/app/.eslintrc.js +140 -140
  67. package/templates/app/README.md +12 -12
  68. package/templates/app/app/index.html +24 -24
  69. package/templates/app/app/properties/ApplicationResources_en_US.properties +1 -1
  70. package/templates/app/app/properties/i18nkeys.json +3 -3
  71. package/templates/app/docs/all.html +69 -69
  72. package/templates/app/mockapi/index.js +18 -18
  73. package/templates/app/package.json +37 -37
  74. package/templates/app/src/actions/SampleActions/index.js +37 -37
  75. package/templates/app/src/actions/index.js +65 -65
  76. package/templates/app/src/appUrls.js +19 -19
  77. package/templates/app/src/components/Alert/Alert.js +134 -134
  78. package/templates/app/src/components/Alert/Alert.module.css +79 -79
  79. package/templates/app/src/components/FreezeLayer/FreezeLayer.css +37 -37
  80. package/templates/app/src/components/FreezeLayer/FreezeLayer.js +84 -84
  81. package/templates/app/src/components/Sample/Sample.module.css +11 -11
  82. package/templates/app/src/components/Sample/SampleList.js +61 -61
  83. package/templates/app/src/components/Slider/Slider.css +41 -41
  84. package/templates/app/src/components/Slider/Slider.js +55 -55
  85. package/templates/app/src/containers/AlertContainer/index.js +15 -15
  86. package/templates/app/src/containers/AppContainer/index.js +96 -96
  87. package/templates/app/src/containers/AppContainer/index.module.css +27 -27
  88. package/templates/app/src/containers/CustomMatch/index.js +65 -65
  89. package/templates/app/src/containers/DevTools/index.js +10 -10
  90. package/templates/app/src/containers/Header/index.js +67 -67
  91. package/templates/app/src/containers/Header/index.module.css +43 -43
  92. package/templates/app/src/containers/Redirect/index.js +63 -63
  93. package/templates/app/src/containers/Redirector/index.js +47 -47
  94. package/templates/app/src/containers/SampleListContainer/ListContainer.js +42 -42
  95. package/templates/app/src/containers/SampleListContainer/ListContainer.module.css +3 -3
  96. package/templates/app/src/historyChange.js +5 -5
  97. package/templates/app/src/index.html +10 -10
  98. package/templates/app/src/index.js +24 -24
  99. package/templates/app/src/middleware/PromiseMiddleware.js +59 -59
  100. package/templates/app/src/reducers/alertData.js +11 -11
  101. package/templates/app/src/reducers/index.js +6 -6
  102. package/templates/app/src/reducers/samples.js +19 -19
  103. package/templates/app/src/store/configureStore.dev.js +51 -51
  104. package/templates/app/src/store/configureStore.js +5 -5
  105. package/templates/app/src/store/configureStore.prod.js +26 -26
  106. package/templates/app/src/util/Common.js +5 -5
  107. package/templates/app/src/util/RequestAPI.js +132 -132
  108. package/templates/docs/all.html +249 -249
  109. package/templates/docs/component.html +178 -178
  110. package/templates/docs/components.html +221 -221
  111. package/templates/docs/css/b.min.css +6 -6
  112. package/templates/docs/css/component.css +42 -42
  113. package/templates/docs/css/componentTest.css +6 -6
  114. package/templates/docs/css/hopscotch.css +585 -585
  115. package/templates/docs/css/style.css +1022 -1022
  116. package/templates/docs/impactReportTemplate.html +154 -154
  117. package/templates/docs/index.html +1501 -1501
  118. package/templates/docs/js/active-line.js +72 -72
  119. package/templates/docs/js/b.min.js +7 -7
  120. package/templates/docs/js/codemirror.js +9680 -9680
  121. package/templates/docs/js/designTokens.js +334 -334
  122. package/templates/docs/js/j.min.js +4 -4
  123. package/templates/docs/js/javascript.js +874 -874
  124. package/templates/docs/js/matchbrackets.js +145 -145
  125. package/cert/Tsicsezwild-22-23.crt +0 -37
  126. package/cert/Tsicsezwild-22-23.key +0 -27
@@ -1,221 +1,221 @@
1
- <!DOCTYPE html>
2
- <html class="isRem" dir="ltr">
3
- <head>
4
- <meta http-equiv="X-UA-Compatible" content="IE=edge" />
5
- <meta name="viewport" content="width=device-width, initial-scale=1.0" />
6
- <link rel="stylesheet" href="./css/component.css" />
7
- <link rel="stylesheet" href="./css/componentTest.css" />
8
- <link rel="stylesheet" href="/docs/css/main.css" />
9
- </head>
10
- <body>
11
- <div id="react" class="ssTest appContainer"></div>
12
- <div id="reactUserEdit"></div>
13
- <script src="/docs/js/vendor.js" defer="true"></script>
14
- <script src="/docs/js/main.js" defer="true"></script>
15
- <script src="/docs/js/babel.min.js"></script>
16
- <script type="text/babel">
17
- var test = 'test';
18
- var ReactDOM = Component.ReactDOM;
19
- var React = Component.React;
20
- var ReactDOMServer = Component.ReactDOMServer;
21
- class RenderComponent extends React.Component {
22
- constructor(props) {
23
- super(props);
24
- this.state = {
25
- Components: Component,
26
- isError: false,
27
- selectedComponent:
28
- location.hash != '' ? location.hash.substring(1) : null,
29
- componentList: window.componentList
30
- ? window.componentList
31
- : Component,
32
- };
33
- this.hashChange = this.hashChange.bind(this);
34
- }
35
- hashChange() {
36
- let parentFrameNode = parent.document.getElementById('loadingText');
37
- this.setState(
38
- {
39
- selectedComponent:
40
- location.hash != '' ? location.hash.substring(1) : null,
41
- },
42
- () => {
43
- if (this.error) {
44
- location.reload();
45
- parentFrameNode
46
- ? (parentFrameNode.style.display = 'block')
47
- : (parentFrameNode.style.display = 'none');
48
- this.error = false;
49
- }
50
- }
51
- );
52
- }
53
-
54
- componentDidMount() {
55
- window.addEventListener('hashchange', this.hashChange);
56
- let parentFrameNode = parent.document.getElementById('loadingText');
57
- if (parentFrameNode) parentFrameNode.style.display = 'none';
58
- }
59
-
60
- componentWillUnmount() {
61
- window.removeEventListener('hashchange', this.hashChange);
62
- }
63
-
64
- componentDidCatch() {
65
- this.error = true;
66
- this.setState({ isError: this.error });
67
- }
68
- render() {
69
- const { Components, selectedComponent, componentList } = this.state;
70
- // var CLG=[]
71
- // var complistGroup=Object.keys(componentList).map((item,i)=>{
72
- // if(Array.isArray(componentList[item].docs.testProps)){
73
- // CLG.push(item)
74
- // }
75
- // })
76
- let msg = componentList[selectedComponent]
77
- ? 'Sorry! for the inconvenience.'
78
- : 'Sorry! Request URL not found.';
79
- var ComponentClass =
80
- selectedComponent && componentList[selectedComponent];
81
- var keysSingleAr =
82
- (ComponentClass &&
83
- ComponentClass.docs &&
84
- ComponentClass.docs.testProps &&
85
- Object.keys(ComponentClass.docs.testProps)) ||
86
- [];
87
- var ErrorMessage = (
88
- <div className={'emptyState'}>
89
- <svg
90
- x='0px'
91
- y='0px'
92
- viewBox='0 0 512 512'
93
- style={{ enableBackground: 'new 0 0 512 512' }}
94
- xmlSpace='preserve'
95
- className={'smileIcon'}
96
- >
97
- <path
98
- style={{ fill: '#f00' }}
99
- d='M344.354,381.58c-1.33-1.651-33.207-40.458-88.354-40.458
100
- c-55.832,0-87.972,39.974-88.29,40.378l-31.42-24.756c1.79-2.271,44.687-55.622,119.71-55.622s117.92,53.352,119.71,55.622
101
- L344.29,381.5L344.354,381.58z M437.02,437.02C485.371,388.668,512,324.38,512,256s-26.629-132.667-74.98-181.02
102
- C388.667,26.629,324.38,0,256,0S123.333,26.629,74.98,74.98C26.629,123.333,0,187.62,0,256s26.629,132.668,74.98,181.02
103
- C123.333,485.371,187.62,512,256,512S388.667,485.371,437.02,437.02z M472,256c0,119.103-96.897,216-216,216S40,375.103,40,256
104
- S136.897,40,256,40S472,136.897,472,256z M168,212.122c17.673,0,32-14.327,32-32s-14.327-32-32-32s-32,14.327-32,32
105
- S150.327,212.122,168,212.122z M344,212.122c17.673,0,32-14.327,32-32s-14.327-32-32-32s-32,14.327-32,32
106
- S326.327,212.122,344,212.122z'
107
- />
108
- </svg>
109
- <div>{msg}</div>
110
- </div>
111
- );
112
- let renderElement = (
113
- <div className='root' id='root'>
114
- {this.state.isError || componentList[selectedComponent] ? (
115
- <ComponentClass {...ComponentClass.docs.testProps} />
116
- ) : (
117
- ErrorMessage
118
- )}
119
- </div>
120
- );
121
-
122
- return componentList._provider ? (
123
- <componentList._provider>
124
- {this.state.isError ? ErrorMessage : renderElement}
125
- </componentList._provider>
126
- ) : this.state.isError ? (
127
- ErrorMessage
128
- ) : (
129
- renderElement
130
- );
131
- }
132
- }
133
- var compList;
134
- var componentList = {};
135
- var compGroupObj = function (comp, key, compGroup) {
136
- if (
137
- comp == 'React' ||
138
- comp == 'ReactDOM' ||
139
- comp == 'renderToStaticMarkup'
140
- ) {
141
- return;
142
- }
143
- if (comp == 'default') {
144
- componentList[key] = compGroup[comp];
145
- return componentList;
146
- } else {
147
- componentList[comp] = compGroup[comp];
148
- return componentList;
149
- }
150
- };
151
- Promise.all(
152
- Object.keys(Component).map((key) => {
153
- let componentKey = Component[key];
154
- if (
155
- key == 'React' ||
156
- key == 'ReactDOM' ||
157
- key == 'renderToStaticMarkup'
158
- ) {
159
- return;
160
- }
161
- try {
162
- return (
163
- componentKey &&
164
- componentKey.then((res) => {
165
- Object.keys(res).forEach((comp) => {
166
- let compGroup = res[comp];
167
- Object.keys(compGroup).forEach((comps) => {
168
- compList = compGroupObj(comps, key, compGroup);
169
- return compList;
170
- });
171
- });
172
- })
173
- );
174
- } catch (error) {
175
- return Component;
176
- }
177
- })
178
- ).then(() => {
179
- Object.keys(componentList).length > 1
180
- ? (window.componentList = componentList)
181
- : (window.componentList = Component);
182
- ReactDOM.render(<RenderComponent />, react, () => {
183
- let attr = document.createAttribute('id');
184
- attr.value = 'check';
185
- let node = document.createElement('DIV');
186
- node.setAttributeNode(attr);
187
- document.getElementById('root').appendChild(node);
188
- });
189
- });
190
- </script>
191
-
192
- <script type="text/javascript">
193
- var err = null;
194
- var comName = '';
195
- var findErr = (window.onerror = function (e, line) {
196
- err = e;
197
- comName = window.location.hash.substr(1);
198
- });
199
- var funct = function () {
200
- return { error: err, name: comName };
201
- };
202
-
203
- let hideCursorBlink = function (documentElement) {
204
- var style = documentElement.createElement('style');
205
- style.innerText =
206
- '[contenteditable], input,textarea {color: transparent ! important; text-shadow: 0 0 0 black ! important;}';
207
- documentElement.head.append(style);
208
- };
209
-
210
- let hideAllCursorBlink = function (documentElement) {
211
- hideCursorBlink(documentElement);
212
- var frameElements = documentElement.getElementsByTagName('iframe');
213
- for (i = 0; i < frameElements.length; i++) {
214
- if (frameElements[i].contentDocument) {
215
- hideAllCursorBlink(frameElements[i].contentDocument);
216
- }
217
- }
218
- };
219
- </script>
220
- </body>
221
- </html>
1
+ <!DOCTYPE html>
2
+ <html class="isRem" dir="ltr">
3
+ <head>
4
+ <meta http-equiv="X-UA-Compatible" content="IE=edge" />
5
+ <meta name="viewport" content="width=device-width, initial-scale=1.0" />
6
+ <link rel="stylesheet" href="./css/component.css" />
7
+ <link rel="stylesheet" href="./css/componentTest.css" />
8
+ <link rel="stylesheet" href="/docs/css/main.css" />
9
+ </head>
10
+ <body>
11
+ <div id="react" class="ssTest appContainer"></div>
12
+ <div id="reactUserEdit"></div>
13
+ <script src="/docs/js/vendor.js" defer="true"></script>
14
+ <script src="/docs/js/main.js" defer="true"></script>
15
+ <script src="/docs/js/babel.min.js"></script>
16
+ <script type="text/babel">
17
+ var test = 'test';
18
+ var ReactDOM = Component.ReactDOM;
19
+ var React = Component.React;
20
+ var ReactDOMServer = Component.ReactDOMServer;
21
+ class RenderComponent extends React.Component {
22
+ constructor(props) {
23
+ super(props);
24
+ this.state = {
25
+ Components: Component,
26
+ isError: false,
27
+ selectedComponent:
28
+ location.hash != '' ? location.hash.substring(1) : null,
29
+ componentList: window.componentList
30
+ ? window.componentList
31
+ : Component,
32
+ };
33
+ this.hashChange = this.hashChange.bind(this);
34
+ }
35
+ hashChange() {
36
+ let parentFrameNode = parent.document.getElementById('loadingText');
37
+ this.setState(
38
+ {
39
+ selectedComponent:
40
+ location.hash != '' ? location.hash.substring(1) : null,
41
+ },
42
+ () => {
43
+ if (this.error) {
44
+ location.reload();
45
+ parentFrameNode
46
+ ? (parentFrameNode.style.display = 'block')
47
+ : (parentFrameNode.style.display = 'none');
48
+ this.error = false;
49
+ }
50
+ }
51
+ );
52
+ }
53
+
54
+ componentDidMount() {
55
+ window.addEventListener('hashchange', this.hashChange);
56
+ let parentFrameNode = parent.document.getElementById('loadingText');
57
+ if (parentFrameNode) parentFrameNode.style.display = 'none';
58
+ }
59
+
60
+ componentWillUnmount() {
61
+ window.removeEventListener('hashchange', this.hashChange);
62
+ }
63
+
64
+ componentDidCatch() {
65
+ this.error = true;
66
+ this.setState({ isError: this.error });
67
+ }
68
+ render() {
69
+ const { Components, selectedComponent, componentList } = this.state;
70
+ // var CLG=[]
71
+ // var complistGroup=Object.keys(componentList).map((item,i)=>{
72
+ // if(Array.isArray(componentList[item].docs.testProps)){
73
+ // CLG.push(item)
74
+ // }
75
+ // })
76
+ let msg = componentList[selectedComponent]
77
+ ? 'Sorry! for the inconvenience.'
78
+ : 'Sorry! Request URL not found.';
79
+ var ComponentClass =
80
+ selectedComponent && componentList[selectedComponent];
81
+ var keysSingleAr =
82
+ (ComponentClass &&
83
+ ComponentClass.docs &&
84
+ ComponentClass.docs.testProps &&
85
+ Object.keys(ComponentClass.docs.testProps)) ||
86
+ [];
87
+ var ErrorMessage = (
88
+ <div className={'emptyState'}>
89
+ <svg
90
+ x='0px'
91
+ y='0px'
92
+ viewBox='0 0 512 512'
93
+ style={{ enableBackground: 'new 0 0 512 512' }}
94
+ xmlSpace='preserve'
95
+ className={'smileIcon'}
96
+ >
97
+ <path
98
+ style={{ fill: '#f00' }}
99
+ d='M344.354,381.58c-1.33-1.651-33.207-40.458-88.354-40.458
100
+ c-55.832,0-87.972,39.974-88.29,40.378l-31.42-24.756c1.79-2.271,44.687-55.622,119.71-55.622s117.92,53.352,119.71,55.622
101
+ L344.29,381.5L344.354,381.58z M437.02,437.02C485.371,388.668,512,324.38,512,256s-26.629-132.667-74.98-181.02
102
+ C388.667,26.629,324.38,0,256,0S123.333,26.629,74.98,74.98C26.629,123.333,0,187.62,0,256s26.629,132.668,74.98,181.02
103
+ C123.333,485.371,187.62,512,256,512S388.667,485.371,437.02,437.02z M472,256c0,119.103-96.897,216-216,216S40,375.103,40,256
104
+ S136.897,40,256,40S472,136.897,472,256z M168,212.122c17.673,0,32-14.327,32-32s-14.327-32-32-32s-32,14.327-32,32
105
+ S150.327,212.122,168,212.122z M344,212.122c17.673,0,32-14.327,32-32s-14.327-32-32-32s-32,14.327-32,32
106
+ S326.327,212.122,344,212.122z'
107
+ />
108
+ </svg>
109
+ <div>{msg}</div>
110
+ </div>
111
+ );
112
+ let renderElement = (
113
+ <div className='root' id='root'>
114
+ {this.state.isError || componentList[selectedComponent] ? (
115
+ <ComponentClass {...ComponentClass.docs.testProps} />
116
+ ) : (
117
+ ErrorMessage
118
+ )}
119
+ </div>
120
+ );
121
+
122
+ return componentList._provider ? (
123
+ <componentList._provider>
124
+ {this.state.isError ? ErrorMessage : renderElement}
125
+ </componentList._provider>
126
+ ) : this.state.isError ? (
127
+ ErrorMessage
128
+ ) : (
129
+ renderElement
130
+ );
131
+ }
132
+ }
133
+ var compList;
134
+ var componentList = {};
135
+ var compGroupObj = function (comp, key, compGroup) {
136
+ if (
137
+ comp == 'React' ||
138
+ comp == 'ReactDOM' ||
139
+ comp == 'renderToStaticMarkup'
140
+ ) {
141
+ return;
142
+ }
143
+ if (comp == 'default') {
144
+ componentList[key] = compGroup[comp];
145
+ return componentList;
146
+ } else {
147
+ componentList[comp] = compGroup[comp];
148
+ return componentList;
149
+ }
150
+ };
151
+ Promise.all(
152
+ Object.keys(Component).map((key) => {
153
+ let componentKey = Component[key];
154
+ if (
155
+ key == 'React' ||
156
+ key == 'ReactDOM' ||
157
+ key == 'renderToStaticMarkup'
158
+ ) {
159
+ return;
160
+ }
161
+ try {
162
+ return (
163
+ componentKey &&
164
+ componentKey.then((res) => {
165
+ Object.keys(res).forEach((comp) => {
166
+ let compGroup = res[comp];
167
+ Object.keys(compGroup).forEach((comps) => {
168
+ compList = compGroupObj(comps, key, compGroup);
169
+ return compList;
170
+ });
171
+ });
172
+ })
173
+ );
174
+ } catch (error) {
175
+ return Component;
176
+ }
177
+ })
178
+ ).then(() => {
179
+ Object.keys(componentList).length > 1
180
+ ? (window.componentList = componentList)
181
+ : (window.componentList = Component);
182
+ ReactDOM.render(<RenderComponent />, react, () => {
183
+ let attr = document.createAttribute('id');
184
+ attr.value = 'check';
185
+ let node = document.createElement('DIV');
186
+ node.setAttributeNode(attr);
187
+ document.getElementById('root').appendChild(node);
188
+ });
189
+ });
190
+ </script>
191
+
192
+ <script type="text/javascript">
193
+ var err = null;
194
+ var comName = '';
195
+ var findErr = (window.onerror = function (e, line) {
196
+ err = e;
197
+ comName = window.location.hash.substr(1);
198
+ });
199
+ var funct = function () {
200
+ return { error: err, name: comName };
201
+ };
202
+
203
+ let hideCursorBlink = function (documentElement) {
204
+ var style = documentElement.createElement('style');
205
+ style.innerText =
206
+ '[contenteditable], input,textarea {color: transparent ! important; text-shadow: 0 0 0 black ! important;}';
207
+ documentElement.head.append(style);
208
+ };
209
+
210
+ let hideAllCursorBlink = function (documentElement) {
211
+ hideCursorBlink(documentElement);
212
+ var frameElements = documentElement.getElementsByTagName('iframe');
213
+ for (i = 0; i < frameElements.length; i++) {
214
+ if (frameElements[i].contentDocument) {
215
+ hideAllCursorBlink(frameElements[i].contentDocument);
216
+ }
217
+ }
218
+ };
219
+ </script>
220
+ </body>
221
+ </html>