polymer-iron-rails 1.0.0.pre.rc.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (610) hide show
  1. checksums.yaml +7 -0
  2. data/README.md +57 -0
  3. data/Rakefile +1 -0
  4. data/app/assets/components/hydrolysis/API.md +360 -0
  5. data/app/assets/components/hydrolysis/LICENSE +5 -0
  6. data/app/assets/components/hydrolysis/README.md +36 -0
  7. data/app/assets/components/hydrolysis/bower.json +19 -0
  8. data/app/assets/components/hydrolysis/hydrolysis-analyzer.html +114 -0
  9. data/app/assets/components/hydrolysis/hydrolysis.html +10 -0
  10. data/app/assets/components/hydrolysis/hydrolysis.js +22241 -0
  11. data/app/assets/components/hydrolysis/index.js +27 -0
  12. data/app/assets/components/iron-a11y-announcer/README.md +29 -0
  13. data/app/assets/components/iron-a11y-announcer/bower.json +28 -0
  14. data/app/assets/components/iron-a11y-announcer/demo/index.html +40 -0
  15. data/app/assets/components/iron-a11y-announcer/demo/x-announces.html +50 -0
  16. data/app/assets/components/iron-a11y-announcer/index.html +28 -0
  17. data/app/assets/components/iron-a11y-announcer/iron-a11y-announcer.html +125 -0
  18. data/app/assets/components/iron-a11y-announcer/test/index.html +26 -0
  19. data/app/assets/components/iron-a11y-announcer/test/iron-a11y-announcer.html +59 -0
  20. data/app/assets/components/iron-a11y-keys/README.md +3 -0
  21. data/app/assets/components/iron-a11y-keys/bower.json +28 -0
  22. data/app/assets/components/iron-a11y-keys/demo/index.html +21 -0
  23. data/app/assets/components/iron-a11y-keys/demo/x-key-aware.html +77 -0
  24. data/app/assets/components/iron-a11y-keys/index.html +24 -0
  25. data/app/assets/components/iron-a11y-keys/iron-a11y-keys.html +121 -0
  26. data/app/assets/components/iron-a11y-keys/test/basic-test.html +122 -0
  27. data/app/assets/components/iron-a11y-keys/test/index.html +29 -0
  28. data/app/assets/components/iron-a11y-keys-behavior/README.md +15 -0
  29. data/app/assets/components/iron-a11y-keys-behavior/bower.json +27 -0
  30. data/app/assets/components/iron-a11y-keys-behavior/demo/index.html +21 -0
  31. data/app/assets/components/iron-a11y-keys-behavior/demo/x-key-aware.html +69 -0
  32. data/app/assets/components/iron-a11y-keys-behavior/index.html +24 -0
  33. data/app/assets/components/iron-a11y-keys-behavior/iron-a11y-keys-behavior.html +418 -0
  34. data/app/assets/components/iron-a11y-keys-behavior/test/basic-test.html +248 -0
  35. data/app/assets/components/iron-a11y-keys-behavior/test/index.html +29 -0
  36. data/app/assets/components/iron-ajax/README.md +23 -0
  37. data/app/assets/components/iron-ajax/bower.json +38 -0
  38. data/app/assets/components/iron-ajax/demo/index.html +45 -0
  39. data/app/assets/components/iron-ajax/index.html +26 -0
  40. data/app/assets/components/iron-ajax/iron-ajax.html +429 -0
  41. data/app/assets/components/iron-ajax/iron-request.html +272 -0
  42. data/app/assets/components/iron-ajax/test/index.html +25 -0
  43. data/app/assets/components/iron-ajax/test/iron-ajax.html +467 -0
  44. data/app/assets/components/iron-ajax/test/iron-request.html +175 -0
  45. data/app/assets/components/iron-autogrow-textarea/README.md +24 -0
  46. data/app/assets/components/iron-autogrow-textarea/bower.json +37 -0
  47. data/app/assets/components/iron-autogrow-textarea/demo/index.html +81 -0
  48. data/app/assets/components/iron-autogrow-textarea/hero.svg +33 -0
  49. data/app/assets/components/iron-autogrow-textarea/index.html +30 -0
  50. data/app/assets/components/iron-autogrow-textarea/iron-autogrow-textarea.html +263 -0
  51. data/app/assets/components/iron-autogrow-textarea/test/basic.html +94 -0
  52. data/app/assets/components/iron-autogrow-textarea/test/index.html +25 -0
  53. data/app/assets/components/iron-behaviors/README.md +4 -0
  54. data/app/assets/components/iron-behaviors/bower.json +25 -0
  55. data/app/assets/components/iron-behaviors/demo/index.html +49 -0
  56. data/app/assets/components/iron-behaviors/demo/simple-button.html +70 -0
  57. data/app/assets/components/iron-behaviors/index.html +27 -0
  58. data/app/assets/components/iron-behaviors/iron-button-state.html +195 -0
  59. data/app/assets/components/iron-behaviors/iron-control-state.html +102 -0
  60. data/app/assets/components/iron-behaviors/test/active-state.html +154 -0
  61. data/app/assets/components/iron-behaviors/test/disabled-state.html +85 -0
  62. data/app/assets/components/iron-behaviors/test/focused-state.html +82 -0
  63. data/app/assets/components/iron-behaviors/test/index.html +25 -0
  64. data/app/assets/components/iron-behaviors/test/test-elements.html +44 -0
  65. data/app/assets/components/iron-collapse/README.md +37 -0
  66. data/app/assets/components/iron-collapse/bower.json +31 -0
  67. data/app/assets/components/iron-collapse/demo/index.html +74 -0
  68. data/app/assets/components/iron-collapse/hero.svg +23 -0
  69. data/app/assets/components/iron-collapse/index.html +31 -0
  70. data/app/assets/components/iron-collapse/iron-collapse.html +196 -0
  71. data/app/assets/components/iron-collapse/test/basic.html +93 -0
  72. data/app/assets/components/iron-collapse/test/horizontal.html +91 -0
  73. data/app/assets/components/iron-collapse/test/index.html +31 -0
  74. data/app/assets/components/iron-component-page/README.md +6 -0
  75. data/app/assets/components/iron-component-page/bower.json +29 -0
  76. data/app/assets/components/iron-component-page/demo/index.html +27 -0
  77. data/app/assets/components/iron-component-page/demo/json-descriptor.json +1 -0
  78. data/app/assets/components/iron-component-page/index.html +25 -0
  79. data/app/assets/components/iron-component-page/iron-component-page.css +155 -0
  80. data/app/assets/components/iron-component-page/iron-component-page.html +440 -0
  81. data/app/assets/components/iron-component-page/test/index.html +28 -0
  82. data/app/assets/components/iron-component-page/test/iron-component-page.html +42 -0
  83. data/app/assets/components/iron-component-page/test/test-element.html +20 -0
  84. data/app/assets/components/iron-doc-viewer/README.md +3 -0
  85. data/app/assets/components/iron-doc-viewer/bower.json +34 -0
  86. data/app/assets/components/iron-doc-viewer/index.html +25 -0
  87. data/app/assets/components/iron-doc-viewer/iron-doc-property.css +158 -0
  88. data/app/assets/components/iron-doc-viewer/iron-doc-property.html +193 -0
  89. data/app/assets/components/iron-doc-viewer/iron-doc-viewer.css +151 -0
  90. data/app/assets/components/iron-doc-viewer/iron-doc-viewer.html +237 -0
  91. data/app/assets/components/iron-doc-viewer/test/index.html +28 -0
  92. data/app/assets/components/iron-doc-viewer/test/iron-doc-viewer.html +123 -0
  93. data/app/assets/components/iron-elements/README.md +34 -0
  94. data/app/assets/components/iron-elements/bower.json +59 -0
  95. data/app/assets/components/iron-fit-behavior/README.md +3 -0
  96. data/app/assets/components/iron-fit-behavior/bower.json +31 -0
  97. data/app/assets/components/iron-fit-behavior/demo/index.html +42 -0
  98. data/app/assets/components/iron-fit-behavior/demo/simple-fit.html +42 -0
  99. data/app/assets/components/iron-fit-behavior/index.html +30 -0
  100. data/app/assets/components/iron-fit-behavior/iron-fit-behavior.html +230 -0
  101. data/app/assets/components/iron-fit-behavior/test/index.html +34 -0
  102. data/app/assets/components/iron-fit-behavior/test/iron-fit-behavior.html +332 -0
  103. data/app/assets/components/iron-fit-behavior/test/test-fit.html +42 -0
  104. data/app/assets/components/iron-flex-layout/README.md +4 -0
  105. data/app/assets/components/iron-flex-layout/bower.json +21 -0
  106. data/app/assets/components/iron-flex-layout/classes/iron-flex-layout.html +307 -0
  107. data/app/assets/components/iron-flex-layout/classes/iron-shadow-flex-layout.html +302 -0
  108. data/app/assets/components/iron-flex-layout/demo/index.html +40 -0
  109. data/app/assets/components/iron-flex-layout/demo/x-app.html +106 -0
  110. data/app/assets/components/iron-flex-layout/iron-flex-layout.html +313 -0
  111. data/app/assets/components/iron-form/README.md +2 -0
  112. data/app/assets/components/iron-form/bower.json +43 -0
  113. data/app/assets/components/iron-form/demo/index.html +121 -0
  114. data/app/assets/components/iron-form/index.html +30 -0
  115. data/app/assets/components/iron-form/iron-form.html +191 -0
  116. data/app/assets/components/iron-form/test/basic.html +228 -0
  117. data/app/assets/components/iron-form/test/index.html +24 -0
  118. data/app/assets/components/iron-form/test/simple-element.html +35 -0
  119. data/app/assets/components/iron-form-element-behavior/README.md +2 -0
  120. data/app/assets/components/iron-form-element-behavior/bower.json +27 -0
  121. data/app/assets/components/iron-form-element-behavior/demo/index.html +53 -0
  122. data/app/assets/components/iron-form-element-behavior/demo/simple-element.html +27 -0
  123. data/app/assets/components/iron-form-element-behavior/demo/simple-form.html +42 -0
  124. data/app/assets/components/iron-form-element-behavior/index.html +30 -0
  125. data/app/assets/components/iron-form-element-behavior/iron-form-element-behavior.html +50 -0
  126. data/app/assets/components/iron-icon/README.md +56 -0
  127. data/app/assets/components/iron-icon/bower.json +29 -0
  128. data/app/assets/components/iron-icon/demo/index.html +28 -0
  129. data/app/assets/components/iron-icon/demo/location.png +0 -0
  130. data/app/assets/components/iron-icon/hero.svg +19 -0
  131. data/app/assets/components/iron-icon/index.html +26 -0
  132. data/app/assets/components/iron-icon/iron-icon.html +187 -0
  133. data/app/assets/components/iron-icon/test/index.html +31 -0
  134. data/app/assets/components/iron-icon/test/iron-icon.html +120 -0
  135. data/app/assets/components/iron-icons/README.md +8 -0
  136. data/app/assets/components/iron-icons/av-icons.html +73 -0
  137. data/app/assets/components/iron-icons/bower.json +37 -0
  138. data/app/assets/components/iron-icons/communication-icons.html +59 -0
  139. data/app/assets/components/iron-icons/demo/index.html +132 -0
  140. data/app/assets/components/iron-icons/device-icons.html +94 -0
  141. data/app/assets/components/iron-icons/editor-icons.html +70 -0
  142. data/app/assets/components/iron-icons/hardware-icons.html +61 -0
  143. data/app/assets/components/iron-icons/hero.svg +35 -0
  144. data/app/assets/components/iron-icons/image-icons.html +164 -0
  145. data/app/assets/components/iron-icons/index.html +25 -0
  146. data/app/assets/components/iron-icons/iron-icons.html +303 -0
  147. data/app/assets/components/iron-icons/maps-icons.html +71 -0
  148. data/app/assets/components/iron-icons/notification-icons.html +62 -0
  149. data/app/assets/components/iron-icons/social-icons.html +40 -0
  150. data/app/assets/components/iron-iconset/README.md +51 -0
  151. data/app/assets/components/iron-iconset/bower.json +21 -0
  152. data/app/assets/components/iron-iconset/demo/index.html +63 -0
  153. data/app/assets/components/iron-iconset/demo/my-icons-big.png +0 -0
  154. data/app/assets/components/iron-iconset/demo/my-icons.png +0 -0
  155. data/app/assets/components/iron-iconset/index.html +27 -0
  156. data/app/assets/components/iron-iconset/iron-iconset.html +336 -0
  157. data/app/assets/components/iron-iconset/test/index.html +30 -0
  158. data/app/assets/components/iron-iconset/test/iron-iconset.html +149 -0
  159. data/app/assets/components/iron-iconset-svg/README.md +4 -0
  160. data/app/assets/components/iron-iconset-svg/bower.json +27 -0
  161. data/app/assets/components/iron-iconset-svg/demo/index.html +65 -0
  162. data/app/assets/components/iron-iconset-svg/demo/svg-sample-icons.html +69 -0
  163. data/app/assets/components/iron-iconset-svg/index.html +26 -0
  164. data/app/assets/components/iron-iconset-svg/iron-iconset-svg.html +191 -0
  165. data/app/assets/components/iron-iconset-svg/test/index.html +30 -0
  166. data/app/assets/components/iron-iconset-svg/test/iron-iconset-svg.html +107 -0
  167. data/app/assets/components/iron-image/README.md +60 -0
  168. data/app/assets/components/iron-image/bower.json +25 -0
  169. data/app/assets/components/iron-image/demo/index.html +183 -0
  170. data/app/assets/components/iron-image/demo/polymer.svg +175 -0
  171. data/app/assets/components/iron-image/index.html +24 -0
  172. data/app/assets/components/iron-image/iron-image.html +394 -0
  173. data/app/assets/components/iron-image/test/index.html +25 -0
  174. data/app/assets/components/iron-image/test/iron-image.html +78 -0
  175. data/app/assets/components/iron-input/README.md +16 -0
  176. data/app/assets/components/iron-input/bower.json +36 -0
  177. data/app/assets/components/iron-input/demo/index.html +87 -0
  178. data/app/assets/components/iron-input/hero.svg +19 -0
  179. data/app/assets/components/iron-input/index.html +30 -0
  180. data/app/assets/components/iron-input/iron-input.html +235 -0
  181. data/app/assets/components/iron-input/test/index.html +24 -0
  182. data/app/assets/components/iron-input/test/iron-input.html +139 -0
  183. data/app/assets/components/iron-input/test/letters-only.html +30 -0
  184. data/app/assets/components/iron-jsonp-library/README.md +10 -0
  185. data/app/assets/components/iron-jsonp-library/bower.json +31 -0
  186. data/app/assets/components/iron-jsonp-library/hero.svg +31 -0
  187. data/app/assets/components/iron-jsonp-library/index.html +26 -0
  188. data/app/assets/components/iron-jsonp-library/iron-jsonp-library.html +257 -0
  189. data/app/assets/components/iron-localstorage/README.md +13 -0
  190. data/app/assets/components/iron-localstorage/bower.json +22 -0
  191. data/app/assets/components/iron-localstorage/demo/index.html +38 -0
  192. data/app/assets/components/iron-localstorage/hero.svg +37 -0
  193. data/app/assets/components/iron-localstorage/index.html +23 -0
  194. data/app/assets/components/iron-localstorage/iron-localstorage.html +196 -0
  195. data/app/assets/components/iron-localstorage/test/basic.html +88 -0
  196. data/app/assets/components/iron-localstorage/test/index.html +27 -0
  197. data/app/assets/components/iron-localstorage/test/raw.html +66 -0
  198. data/app/assets/components/iron-localstorage/test/value-binding.html +103 -0
  199. data/app/assets/components/iron-media-query/README.md +11 -0
  200. data/app/assets/components/iron-media-query/bower.json +30 -0
  201. data/app/assets/components/iron-media-query/demo/index.html +38 -0
  202. data/app/assets/components/iron-media-query/hero.svg +29 -0
  203. data/app/assets/components/iron-media-query/index.html +29 -0
  204. data/app/assets/components/iron-media-query/iron-media-query.html +84 -0
  205. data/app/assets/components/iron-media-query/test/basic.html +71 -0
  206. data/app/assets/components/iron-media-query/test/index.html +30 -0
  207. data/app/assets/components/iron-menu-behavior/README.md +3 -0
  208. data/app/assets/components/iron-menu-behavior/bower.json +32 -0
  209. data/app/assets/components/iron-menu-behavior/demo/index.html +100 -0
  210. data/app/assets/components/iron-menu-behavior/demo/simple-menu.html +50 -0
  211. data/app/assets/components/iron-menu-behavior/demo/simple-menubar.html +54 -0
  212. data/app/assets/components/iron-menu-behavior/index.html +30 -0
  213. data/app/assets/components/iron-menu-behavior/iron-menu-behavior.html +214 -0
  214. data/app/assets/components/iron-menu-behavior/iron-menubar-behavior.html +65 -0
  215. data/app/assets/components/iron-menu-behavior/test/index.html +35 -0
  216. data/app/assets/components/iron-menu-behavior/test/iron-menu-behavior.html +108 -0
  217. data/app/assets/components/iron-menu-behavior/test/iron-menubar-behavior.html +108 -0
  218. data/app/assets/components/iron-menu-behavior/test/test-menu.html +40 -0
  219. data/app/assets/components/iron-menu-behavior/test/test-menubar.html +40 -0
  220. data/app/assets/components/iron-meta/README.md +46 -0
  221. data/app/assets/components/iron-meta/bower.json +28 -0
  222. data/app/assets/components/iron-meta/demo/index.html +45 -0
  223. data/app/assets/components/iron-meta/hero.svg +33 -0
  224. data/app/assets/components/iron-meta/index.html +27 -0
  225. data/app/assets/components/iron-meta/iron-meta.html +352 -0
  226. data/app/assets/components/iron-meta/test/basic.html +48 -0
  227. data/app/assets/components/iron-meta/test/index.html +30 -0
  228. data/app/assets/components/iron-meta/test/iron-meta.html +186 -0
  229. data/app/assets/components/iron-overlay-behavior/README.md +11 -0
  230. data/app/assets/components/iron-overlay-behavior/bower.json +36 -0
  231. data/app/assets/components/iron-overlay-behavior/demo/index.html +149 -0
  232. data/app/assets/components/iron-overlay-behavior/demo/simple-overlay.html +50 -0
  233. data/app/assets/components/iron-overlay-behavior/index.html +30 -0
  234. data/app/assets/components/iron-overlay-behavior/iron-overlay-backdrop.html +132 -0
  235. data/app/assets/components/iron-overlay-behavior/iron-overlay-behavior.html +432 -0
  236. data/app/assets/components/iron-overlay-behavior/iron-overlay-manager.html +107 -0
  237. data/app/assets/components/iron-overlay-behavior/test/index.html +34 -0
  238. data/app/assets/components/iron-overlay-behavior/test/iron-overlay-behavior.html +314 -0
  239. data/app/assets/components/iron-overlay-behavior/test/test-overlay.html +49 -0
  240. data/app/assets/components/iron-pages/README.md +22 -0
  241. data/app/assets/components/iron-pages/bower.json +27 -0
  242. data/app/assets/components/iron-pages/demo/index.html +60 -0
  243. data/app/assets/components/iron-pages/hero.svg +22 -0
  244. data/app/assets/components/iron-pages/index.html +25 -0
  245. data/app/assets/components/iron-pages/iron-pages.html +83 -0
  246. data/app/assets/components/iron-pages/test/attr-for-selected.html +91 -0
  247. data/app/assets/components/iron-pages/test/basic.html +95 -0
  248. data/app/assets/components/iron-pages/test/index.html +32 -0
  249. data/app/assets/components/iron-range-behavior/README.md +4 -0
  250. data/app/assets/components/iron-range-behavior/bower.json +30 -0
  251. data/app/assets/components/iron-range-behavior/demo/index.html +76 -0
  252. data/app/assets/components/iron-range-behavior/index.html +24 -0
  253. data/app/assets/components/iron-range-behavior/iron-range-behavior.html +101 -0
  254. data/app/assets/components/iron-range-behavior/test/basic.html +119 -0
  255. data/app/assets/components/iron-range-behavior/test/index.html +25 -0
  256. data/app/assets/components/iron-resizable-behavior/README.md +16 -0
  257. data/app/assets/components/iron-resizable-behavior/bower.json +26 -0
  258. data/app/assets/components/iron-resizable-behavior/demo/index.html +29 -0
  259. data/app/assets/components/iron-resizable-behavior/demo/src/x-app.html +114 -0
  260. data/app/assets/components/iron-resizable-behavior/index.html +25 -0
  261. data/app/assets/components/iron-resizable-behavior/iron-resizable-behavior.html +139 -0
  262. data/app/assets/components/iron-resizable-behavior/test/basic.html +263 -0
  263. data/app/assets/components/iron-resizable-behavior/test/index.html +31 -0
  264. data/app/assets/components/iron-resizable-behavior/test/test-elements.html +143 -0
  265. data/app/assets/components/iron-selector/README.md +50 -0
  266. data/app/assets/components/iron-selector/bower.json +31 -0
  267. data/app/assets/components/iron-selector/demo/index.html +66 -0
  268. data/app/assets/components/iron-selector/index.html +28 -0
  269. data/app/assets/components/iron-selector/iron-multi-selectable.html +120 -0
  270. data/app/assets/components/iron-selector/iron-selectable.html +307 -0
  271. data/app/assets/components/iron-selector/iron-selection.html +115 -0
  272. data/app/assets/components/iron-selector/iron-selector.html +71 -0
  273. data/app/assets/components/iron-selector/test/activate-event.html +138 -0
  274. data/app/assets/components/iron-selector/test/basic.html +150 -0
  275. data/app/assets/components/iron-selector/test/content-element.html +43 -0
  276. data/app/assets/components/iron-selector/test/content.html +168 -0
  277. data/app/assets/components/iron-selector/test/index.html +36 -0
  278. data/app/assets/components/iron-selector/test/multi.html +135 -0
  279. data/app/assets/components/iron-selector/test/next-previous.html +134 -0
  280. data/app/assets/components/iron-selector/test/selected-attribute.html +72 -0
  281. data/app/assets/components/iron-selector/test/template-repeat.html +110 -0
  282. data/app/assets/components/iron-signals/README.md +26 -0
  283. data/app/assets/components/iron-signals/bower.json +20 -0
  284. data/app/assets/components/iron-signals/demo/index.html +40 -0
  285. data/app/assets/components/iron-signals/index.html +23 -0
  286. data/app/assets/components/iron-signals/iron-signals.html +81 -0
  287. data/app/assets/components/iron-test-helpers/README.md +23 -0
  288. data/app/assets/components/iron-test-helpers/bower.json +28 -0
  289. data/app/assets/components/iron-test-helpers/iron-test-helpers.html +22 -0
  290. data/app/assets/components/iron-test-helpers/mock-interactions.js +177 -0
  291. data/app/assets/components/iron-test-helpers/test-helpers.js +39 -0
  292. data/app/assets/components/iron-validatable-behavior/README.md +3 -0
  293. data/app/assets/components/iron-validatable-behavior/bower.json +35 -0
  294. data/app/assets/components/iron-validatable-behavior/demo/cats-only.html +46 -0
  295. data/app/assets/components/iron-validatable-behavior/demo/index.html +71 -0
  296. data/app/assets/components/iron-validatable-behavior/demo/validatable-input.html +46 -0
  297. data/app/assets/components/iron-validatable-behavior/index.html +30 -0
  298. data/app/assets/components/iron-validatable-behavior/iron-validatable-behavior.html +101 -0
  299. data/app/assets/components/iron-validatable-behavior/test/index.html +35 -0
  300. data/app/assets/components/iron-validatable-behavior/test/iron-validatable-behavior.html +52 -0
  301. data/app/assets/components/iron-validatable-behavior/test/test-validatable.html +28 -0
  302. data/app/assets/components/iron-validator-behavior/README.md +4 -0
  303. data/app/assets/components/iron-validator-behavior/bower.json +34 -0
  304. data/app/assets/components/iron-validator-behavior/demo/cats-only.html +46 -0
  305. data/app/assets/components/iron-validator-behavior/demo/index.html +144 -0
  306. data/app/assets/components/iron-validator-behavior/index.html +30 -0
  307. data/app/assets/components/iron-validator-behavior/iron-validator-behavior.html +61 -0
  308. data/app/assets/components/iron-validator-behavior/test/index.html +34 -0
  309. data/app/assets/components/iron-validator-behavior/test/iron-validator-behavior.html +47 -0
  310. data/app/assets/components/iron-validator-behavior/test/simple-validator.html +26 -0
  311. data/app/assets/components/marked/LICENSE +19 -0
  312. data/app/assets/components/marked/Makefile +12 -0
  313. data/app/assets/components/marked/README.md +406 -0
  314. data/app/assets/components/marked/bin/marked +187 -0
  315. data/app/assets/components/marked/bower.json +24 -0
  316. data/app/assets/components/marked/component.json +10 -0
  317. data/app/assets/components/marked/doc/broken.md +426 -0
  318. data/app/assets/components/marked/doc/todo.md +2 -0
  319. data/app/assets/components/marked/index.js +1 -0
  320. data/app/assets/components/marked/lib/marked.js +1272 -0
  321. data/app/assets/components/marked/man/marked.1 +88 -0
  322. data/app/assets/components/marked/marked.min.js +6 -0
  323. data/app/assets/components/marked/package.json +22 -0
  324. data/app/assets/components/marked-element/README.md +31 -0
  325. data/app/assets/components/marked-element/bower.json +33 -0
  326. data/app/assets/components/marked-element/demo/index.html +52 -0
  327. data/app/assets/components/marked-element/hero.svg +27 -0
  328. data/app/assets/components/marked-element/index.html +26 -0
  329. data/app/assets/components/marked-element/marked-element.html +145 -0
  330. data/app/assets/components/marked-element/marked-import.html +10 -0
  331. data/app/assets/components/marked-element/test/index.html +25 -0
  332. data/app/assets/components/marked-element/test/marked-element.html +112 -0
  333. data/app/assets/components/paper-behaviors/README.md +4 -0
  334. data/app/assets/components/paper-behaviors/bower.json +39 -0
  335. data/app/assets/components/paper-behaviors/demo/index.html +57 -0
  336. data/app/assets/components/paper-behaviors/demo/paper-button.html +71 -0
  337. data/app/assets/components/paper-behaviors/demo/paper-radio-button.html +116 -0
  338. data/app/assets/components/paper-behaviors/index.html +26 -0
  339. data/app/assets/components/paper-behaviors/paper-button-behavior.html +55 -0
  340. data/app/assets/components/paper-behaviors/paper-inky-focus-behavior.html +44 -0
  341. data/app/assets/components/paper-behaviors/test/index.html +26 -0
  342. data/app/assets/components/paper-behaviors/test/paper-button-behavior.html +82 -0
  343. data/app/assets/components/paper-behaviors/test/paper-radio-button-behavior.html +62 -0
  344. data/app/assets/components/paper-behaviors/test/test-button.html +34 -0
  345. data/app/assets/components/paper-behaviors/test/test-radio-button.html +41 -0
  346. data/app/assets/components/paper-button/README.md +45 -0
  347. data/app/assets/components/paper-button/bower.json +39 -0
  348. data/app/assets/components/paper-button/demo/index.html +158 -0
  349. data/app/assets/components/paper-button/index.html +26 -0
  350. data/app/assets/components/paper-button/paper-button.html +177 -0
  351. data/app/assets/components/paper-button/test/index.html +25 -0
  352. data/app/assets/components/paper-button/test/paper-button.html +83 -0
  353. data/app/assets/components/paper-header-panel/README.md +105 -0
  354. data/app/assets/components/paper-header-panel/bower.json +28 -0
  355. data/app/assets/components/paper-header-panel/demo/index.html +148 -0
  356. data/app/assets/components/paper-header-panel/hero.svg +38 -0
  357. data/app/assets/components/paper-header-panel/index.html +36 -0
  358. data/app/assets/components/paper-header-panel/paper-header-panel.html +496 -0
  359. data/app/assets/components/paper-header-panel/test/basic.html +156 -0
  360. data/app/assets/components/paper-header-panel/test/index.html +34 -0
  361. data/app/assets/components/paper-material/README.md +13 -0
  362. data/app/assets/components/paper-material/bower.json +36 -0
  363. data/app/assets/components/paper-material/demo/index.html +113 -0
  364. data/app/assets/components/paper-material/index.html +30 -0
  365. data/app/assets/components/paper-material/paper-material.html +98 -0
  366. data/app/assets/components/paper-material/test/index.html +25 -0
  367. data/app/assets/components/paper-material/test/paper-material.html +92 -0
  368. data/app/assets/components/paper-ripple/README.md +65 -0
  369. data/app/assets/components/paper-ripple/bower.json +29 -0
  370. data/app/assets/components/paper-ripple/demo/index.html +413 -0
  371. data/app/assets/components/paper-ripple/hero.svg +30 -0
  372. data/app/assets/components/paper-ripple/index.html +27 -0
  373. data/app/assets/components/paper-ripple/paper-ripple.html +714 -0
  374. data/app/assets/components/paper-ripple/test/index.html +25 -0
  375. data/app/assets/components/paper-ripple/test/paper-ripple.html +166 -0
  376. data/app/assets/components/paper-styles/README.md +3 -0
  377. data/app/assets/components/paper-styles/bower.json +27 -0
  378. data/app/assets/components/paper-styles/classes/global.html +96 -0
  379. data/app/assets/components/paper-styles/classes/shadow-layout.html +302 -0
  380. data/app/assets/components/paper-styles/classes/shadow.html +39 -0
  381. data/app/assets/components/paper-styles/classes/typography.html +171 -0
  382. data/app/assets/components/paper-styles/color.html +333 -0
  383. data/app/assets/components/paper-styles/default-theme.html +39 -0
  384. data/app/assets/components/paper-styles/demo-pages.html +72 -0
  385. data/app/assets/components/paper-styles/demo.css +25 -0
  386. data/app/assets/components/paper-styles/paper-styles-classes.html +14 -0
  387. data/app/assets/components/paper-styles/paper-styles.html +17 -0
  388. data/app/assets/components/paper-styles/shadow.html +61 -0
  389. data/app/assets/components/paper-styles/typography.html +240 -0
  390. data/app/assets/components/paper-toolbar/README.md +51 -0
  391. data/app/assets/components/paper-toolbar/bower.json +35 -0
  392. data/app/assets/components/paper-toolbar/demo/index.html +81 -0
  393. data/app/assets/components/paper-toolbar/index.html +38 -0
  394. data/app/assets/components/paper-toolbar/paper-toolbar.html +375 -0
  395. data/app/assets/components/paper-toolbar/test/index.html +24 -0
  396. data/app/assets/components/paper-toolbar/test/paper-toolbar.html +147 -0
  397. data/app/assets/components/polymer/LICENSE.txt +27 -0
  398. data/app/assets/components/polymer/bower.json +26 -0
  399. data/app/assets/components/polymer/build.log +27 -0
  400. data/app/assets/components/polymer/polymer-micro.html +523 -0
  401. data/app/assets/components/polymer/polymer-mini.html +1368 -0
  402. data/app/assets/components/polymer/polymer.html +3768 -0
  403. data/app/assets/components/prism/LICENSE +21 -0
  404. data/app/assets/components/prism/README.md +22 -0
  405. data/app/assets/components/prism/bower.json +26 -0
  406. data/app/assets/components/prism/components/prism-actionscript.js +20 -0
  407. data/app/assets/components/prism/components/prism-actionscript.min.js +1 -0
  408. data/app/assets/components/prism/components/prism-apacheconf.js +46 -0
  409. data/app/assets/components/prism/components/prism-apacheconf.min.js +1 -0
  410. data/app/assets/components/prism/components/prism-applescript.js +23 -0
  411. data/app/assets/components/prism/components/prism-applescript.min.js +1 -0
  412. data/app/assets/components/prism/components/prism-aspnet.js +49 -0
  413. data/app/assets/components/prism/components/prism-aspnet.min.js +1 -0
  414. data/app/assets/components/prism/components/prism-autohotkey.js +27 -0
  415. data/app/assets/components/prism/components/prism-autohotkey.min.js +1 -0
  416. data/app/assets/components/prism/components/prism-bash.js +31 -0
  417. data/app/assets/components/prism/components/prism-bash.min.js +1 -0
  418. data/app/assets/components/prism/components/prism-c.js +26 -0
  419. data/app/assets/components/prism/components/prism-c.min.js +1 -0
  420. data/app/assets/components/prism/components/prism-clike.js +32 -0
  421. data/app/assets/components/prism/components/prism-clike.min.js +1 -0
  422. data/app/assets/components/prism/components/prism-coffeescript.js +83 -0
  423. data/app/assets/components/prism/components/prism-coffeescript.min.js +1 -0
  424. data/app/assets/components/prism/components/prism-core.js +426 -0
  425. data/app/assets/components/prism/components/prism-core.min.js +1 -0
  426. data/app/assets/components/prism/components/prism-cpp.js +12 -0
  427. data/app/assets/components/prism/components/prism-cpp.min.js +1 -0
  428. data/app/assets/components/prism/components/prism-csharp.js +9 -0
  429. data/app/assets/components/prism/components/prism-csharp.min.js +1 -0
  430. data/app/assets/components/prism/components/prism-css-extras.js +15 -0
  431. data/app/assets/components/prism/components/prism-css-extras.min.js +1 -0
  432. data/app/assets/components/prism/components/prism-css.js +50 -0
  433. data/app/assets/components/prism/components/prism-css.min.js +1 -0
  434. data/app/assets/components/prism/components/prism-dart.js +18 -0
  435. data/app/assets/components/prism/components/prism-dart.min.js +1 -0
  436. data/app/assets/components/prism/components/prism-eiffel.js +24 -0
  437. data/app/assets/components/prism/components/prism-eiffel.min.js +1 -0
  438. data/app/assets/components/prism/components/prism-erlang.js +35 -0
  439. data/app/assets/components/prism/components/prism-erlang.min.js +1 -0
  440. data/app/assets/components/prism/components/prism-fortran.js +34 -0
  441. data/app/assets/components/prism/components/prism-fortran.min.js +1 -0
  442. data/app/assets/components/prism/components/prism-fsharp.js +21 -0
  443. data/app/assets/components/prism/components/prism-fsharp.min.js +1 -0
  444. data/app/assets/components/prism/components/prism-gherkin.js +78 -0
  445. data/app/assets/components/prism/components/prism-gherkin.min.js +1 -0
  446. data/app/assets/components/prism/components/prism-git.js +68 -0
  447. data/app/assets/components/prism/components/prism-git.min.js +1 -0
  448. data/app/assets/components/prism/components/prism-go.js +9 -0
  449. data/app/assets/components/prism/components/prism-go.min.js +1 -0
  450. data/app/assets/components/prism/components/prism-groovy.js +50 -0
  451. data/app/assets/components/prism/components/prism-groovy.min.js +1 -0
  452. data/app/assets/components/prism/components/prism-haml.js +161 -0
  453. data/app/assets/components/prism/components/prism-haml.min.js +1 -0
  454. data/app/assets/components/prism/components/prism-handlebars.js +82 -0
  455. data/app/assets/components/prism/components/prism-handlebars.min.js +1 -0
  456. data/app/assets/components/prism/components/prism-haskell.js +32 -0
  457. data/app/assets/components/prism/components/prism-haskell.min.js +1 -0
  458. data/app/assets/components/prism/components/prism-http.js +44 -0
  459. data/app/assets/components/prism/components/prism-http.min.js +1 -0
  460. data/app/assets/components/prism/components/prism-ini.js +11 -0
  461. data/app/assets/components/prism/components/prism-ini.min.js +1 -0
  462. data/app/assets/components/prism/components/prism-jade.js +196 -0
  463. data/app/assets/components/prism/components/prism-jade.min.js +1 -0
  464. data/app/assets/components/prism/components/prism-java.js +8 -0
  465. data/app/assets/components/prism/components/prism-java.min.js +1 -0
  466. data/app/assets/components/prism/components/prism-javascript.js +28 -0
  467. data/app/assets/components/prism/components/prism-javascript.min.js +1 -0
  468. data/app/assets/components/prism/components/prism-jsx.js +22 -0
  469. data/app/assets/components/prism/components/prism-jsx.min.js +1 -0
  470. data/app/assets/components/prism/components/prism-julia.js +12 -0
  471. data/app/assets/components/prism/components/prism-julia.min.js +1 -0
  472. data/app/assets/components/prism/components/prism-latex.js +6 -0
  473. data/app/assets/components/prism/components/prism-latex.min.js +1 -0
  474. data/app/assets/components/prism/components/prism-less.js +60 -0
  475. data/app/assets/components/prism/components/prism-less.min.js +1 -0
  476. data/app/assets/components/prism/components/prism-lolcode.js +54 -0
  477. data/app/assets/components/prism/components/prism-lolcode.min.js +1 -0
  478. data/app/assets/components/prism/components/prism-markdown.js +122 -0
  479. data/app/assets/components/prism/components/prism-markdown.min.js +1 -0
  480. data/app/assets/components/prism/components/prism-markup.js +41 -0
  481. data/app/assets/components/prism/components/prism-markup.min.js +1 -0
  482. data/app/assets/components/prism/components/prism-matlab.js +17 -0
  483. data/app/assets/components/prism/components/prism-matlab.min.js +1 -0
  484. data/app/assets/components/prism/components/prism-nasm.js +20 -0
  485. data/app/assets/components/prism/components/prism-nasm.min.js +1 -0
  486. data/app/assets/components/prism/components/prism-nsis.js +19 -0
  487. data/app/assets/components/prism/components/prism-nsis.min.js +1 -0
  488. data/app/assets/components/prism/components/prism-objectivec.js +5 -0
  489. data/app/assets/components/prism/components/prism-objectivec.min.js +1 -0
  490. data/app/assets/components/prism/components/prism-pascal.js +54 -0
  491. data/app/assets/components/prism/components/prism-pascal.min.js +1 -0
  492. data/app/assets/components/prism/components/prism-perl.js +112 -0
  493. data/app/assets/components/prism/components/prism-perl.min.js +1 -0
  494. data/app/assets/components/prism/components/prism-php-extras.js +11 -0
  495. data/app/assets/components/prism/components/prism-php-extras.min.js +1 -0
  496. data/app/assets/components/prism/components/prism-php.js +109 -0
  497. data/app/assets/components/prism/components/prism-php.min.js +1 -0
  498. data/app/assets/components/prism/components/prism-powershell.js +34 -0
  499. data/app/assets/components/prism/components/prism-powershell.min.js +1 -0
  500. data/app/assets/components/prism/components/prism-python.js +13 -0
  501. data/app/assets/components/prism/components/prism-python.min.js +1 -0
  502. data/app/assets/components/prism/components/prism-r.js +19 -0
  503. data/app/assets/components/prism/components/prism-r.min.js +1 -0
  504. data/app/assets/components/prism/components/prism-rest.js +204 -0
  505. data/app/assets/components/prism/components/prism-rest.min.js +1 -0
  506. data/app/assets/components/prism/components/prism-rip.js +29 -0
  507. data/app/assets/components/prism/components/prism-rip.min.js +1 -0
  508. data/app/assets/components/prism/components/prism-ruby.js +21 -0
  509. data/app/assets/components/prism/components/prism-ruby.min.js +1 -0
  510. data/app/assets/components/prism/components/prism-rust.js +53 -0
  511. data/app/assets/components/prism/components/prism-rust.min.js +1 -0
  512. data/app/assets/components/prism/components/prism-sas.js +35 -0
  513. data/app/assets/components/prism/components/prism-sas.min.js +1 -0
  514. data/app/assets/components/prism/components/prism-scala.js +9 -0
  515. data/app/assets/components/prism/components/prism-scala.min.js +1 -0
  516. data/app/assets/components/prism/components/prism-scheme.js +24 -0
  517. data/app/assets/components/prism/components/prism-scheme.min.js +1 -0
  518. data/app/assets/components/prism/components/prism-scss.js +36 -0
  519. data/app/assets/components/prism/components/prism-scss.min.js +1 -0
  520. data/app/assets/components/prism/components/prism-smalltalk.js +31 -0
  521. data/app/assets/components/prism/components/prism-smalltalk.min.js +1 -0
  522. data/app/assets/components/prism/components/prism-smarty.js +124 -0
  523. data/app/assets/components/prism/components/prism-smarty.min.js +1 -0
  524. data/app/assets/components/prism/components/prism-sql.js +17 -0
  525. data/app/assets/components/prism/components/prism-sql.min.js +1 -0
  526. data/app/assets/components/prism/components/prism-stylus.js +61 -0
  527. data/app/assets/components/prism/components/prism-stylus.min.js +1 -0
  528. data/app/assets/components/prism/components/prism-swift.js +8 -0
  529. data/app/assets/components/prism/components/prism-swift.min.js +1 -0
  530. data/app/assets/components/prism/components/prism-twig.js +46 -0
  531. data/app/assets/components/prism/components/prism-twig.min.js +1 -0
  532. data/app/assets/components/prism/components/prism-typescript.js +3 -0
  533. data/app/assets/components/prism/components/prism-typescript.min.js +1 -0
  534. data/app/assets/components/prism/components/prism-wiki.js +80 -0
  535. data/app/assets/components/prism/components/prism-wiki.min.js +1 -0
  536. data/app/assets/components/prism/components/prism-yaml.js +44 -0
  537. data/app/assets/components/prism/components/prism-yaml.min.js +1 -0
  538. data/app/assets/components/prism/components.js +362 -0
  539. data/app/assets/components/prism/examples.js +181 -0
  540. data/app/assets/components/prism/gulpfile.js +48 -0
  541. data/app/assets/components/prism/package.json +27 -0
  542. data/app/assets/components/prism/plugins/autolinker/prism-autolinker.css +3 -0
  543. data/app/assets/components/prism/plugins/autolinker/prism-autolinker.js +66 -0
  544. data/app/assets/components/prism/plugins/autolinker/prism-autolinker.min.js +1 -0
  545. data/app/assets/components/prism/plugins/file-highlight/prism-file-highlight.js +61 -0
  546. data/app/assets/components/prism/plugins/file-highlight/prism-file-highlight.min.js +1 -0
  547. data/app/assets/components/prism/plugins/highlight-keywords/prism-highlight-keywords.js +14 -0
  548. data/app/assets/components/prism/plugins/highlight-keywords/prism-highlight-keywords.min.js +1 -0
  549. data/app/assets/components/prism/plugins/ie8/prism-ie8.css +3 -0
  550. data/app/assets/components/prism/plugins/ie8/prism-ie8.js +42 -0
  551. data/app/assets/components/prism/plugins/ie8/prism-ie8.min.js +1 -0
  552. data/app/assets/components/prism/plugins/line-highlight/prism-line-highlight.css +47 -0
  553. data/app/assets/components/prism/plugins/line-highlight/prism-line-highlight.js +109 -0
  554. data/app/assets/components/prism/plugins/line-highlight/prism-line-highlight.min.js +1 -0
  555. data/app/assets/components/prism/plugins/line-numbers/prism-line-numbers.css +40 -0
  556. data/app/assets/components/prism/plugins/line-numbers/prism-line-numbers.js +38 -0
  557. data/app/assets/components/prism/plugins/line-numbers/prism-line-numbers.min.js +1 -0
  558. data/app/assets/components/prism/plugins/show-invisibles/prism-show-invisibles.css +20 -0
  559. data/app/assets/components/prism/plugins/show-invisibles/prism-show-invisibles.js +16 -0
  560. data/app/assets/components/prism/plugins/show-invisibles/prism-show-invisibles.min.js +1 -0
  561. data/app/assets/components/prism/plugins/show-language/prism-show-language.css +16 -0
  562. data/app/assets/components/prism/plugins/show-language/prism-show-language.js +20 -0
  563. data/app/assets/components/prism/plugins/show-language/prism-show-language.min.css +1 -0
  564. data/app/assets/components/prism/plugins/show-language/prism-show-language.min.js +1 -0
  565. data/app/assets/components/prism/plugins/wpd/prism-wpd.css +11 -0
  566. data/app/assets/components/prism/plugins/wpd/prism-wpd.js +163 -0
  567. data/app/assets/components/prism/plugins/wpd/prism-wpd.min.js +1 -0
  568. data/app/assets/components/prism/prism.js +672 -0
  569. data/app/assets/components/prism/themes/prism-coy.css +231 -0
  570. data/app/assets/components/prism/themes/prism-dark.css +126 -0
  571. data/app/assets/components/prism/themes/prism-funky.css +115 -0
  572. data/app/assets/components/prism/themes/prism-okaidia.css +119 -0
  573. data/app/assets/components/prism/themes/prism-tomorrow.css +119 -0
  574. data/app/assets/components/prism/themes/prism-twilight.css +199 -0
  575. data/app/assets/components/prism/themes/prism.css +135 -0
  576. data/app/assets/components/prism/vendor/promise.js +5 -0
  577. data/app/assets/components/prism-element/README.md +13 -0
  578. data/app/assets/components/prism-element/bower.json +29 -0
  579. data/app/assets/components/prism-element/prism-highlighter.html +95 -0
  580. data/app/assets/components/prism-element/prism-import.html +11 -0
  581. data/app/assets/components/promise-polyfill/Gruntfile.js +40 -0
  582. data/app/assets/components/promise-polyfill/LICENSE +20 -0
  583. data/app/assets/components/promise-polyfill/Promise-Statics.js +37 -0
  584. data/app/assets/components/promise-polyfill/Promise.js +128 -0
  585. data/app/assets/components/promise-polyfill/Promise.min.js +3 -0
  586. data/app/assets/components/promise-polyfill/README.md +13 -0
  587. data/app/assets/components/promise-polyfill/bower.json +31 -0
  588. data/app/assets/components/promise-polyfill/package.json +35 -0
  589. data/app/assets/components/promise-polyfill/promise-polyfill-lite.html +7 -0
  590. data/app/assets/components/promise-polyfill/promise-polyfill.html +2 -0
  591. data/app/assets/components/webcomponentsjs/CustomElements.js +956 -0
  592. data/app/assets/components/webcomponentsjs/CustomElements.min.js +11 -0
  593. data/app/assets/components/webcomponentsjs/HTMLImports.js +1078 -0
  594. data/app/assets/components/webcomponentsjs/HTMLImports.min.js +11 -0
  595. data/app/assets/components/webcomponentsjs/MutationObserver.js +344 -0
  596. data/app/assets/components/webcomponentsjs/MutationObserver.min.js +11 -0
  597. data/app/assets/components/webcomponentsjs/README.md +125 -0
  598. data/app/assets/components/webcomponentsjs/ShadowDOM.js +4414 -0
  599. data/app/assets/components/webcomponentsjs/ShadowDOM.min.js +15 -0
  600. data/app/assets/components/webcomponentsjs/bower.json +14 -0
  601. data/app/assets/components/webcomponentsjs/build.log +33 -0
  602. data/app/assets/components/webcomponentsjs/package.json +31 -0
  603. data/app/assets/components/webcomponentsjs/webcomponents-lite.js +2300 -0
  604. data/app/assets/components/webcomponentsjs/webcomponents-lite.min.js +13 -0
  605. data/app/assets/components/webcomponentsjs/webcomponents.js +7112 -0
  606. data/app/assets/components/webcomponentsjs/webcomponents.min.js +15 -0
  607. data/lib/polymer-iron-rails/engine.rb +4 -0
  608. data/lib/polymer-iron-rails/version.rb +3 -0
  609. data/lib/polymer-iron-rails.rb +2 -0
  610. metadata +694 -0
@@ -0,0 +1,714 @@
1
+ <!--
2
+ Copyright (c) 2014 The Polymer Project Authors. All rights reserved.
3
+ This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt
4
+ The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt
5
+ The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt
6
+ Code distributed by Google as part of the polymer project is also
7
+ subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
8
+ -->
9
+
10
+ <link rel="import" href="../polymer/polymer.html">
11
+ <link rel="import" href="../iron-a11y-keys-behavior/iron-a11y-keys-behavior.html">
12
+
13
+ <!--
14
+ `paper-ripple` provides a visual effect that other paper elements can
15
+ use to simulate a rippling effect emanating from the point of contact. The
16
+ effect can be visualized as a concentric circle with motion.
17
+
18
+ Example:
19
+
20
+ <paper-ripple></paper-ripple>
21
+
22
+ `paper-ripple` listens to "mousedown" and "mouseup" events so it would display ripple
23
+ effect when touches on it. You can also defeat the default behavior and
24
+ manually route the down and up actions to the ripple element. Note that it is
25
+ important if you call downAction() you will have to make sure to call
26
+ upAction() so that `paper-ripple` would end the animation loop.
27
+
28
+ Example:
29
+
30
+ <paper-ripple id="ripple" style="pointer-events: none;"></paper-ripple>
31
+ ...
32
+ downAction: function(e) {
33
+ this.$.ripple.downAction({x: e.x, y: e.y});
34
+ },
35
+ upAction: function(e) {
36
+ this.$.ripple.upAction();
37
+ }
38
+
39
+ Styling ripple effect:
40
+
41
+ Use CSS color property to style the ripple:
42
+
43
+ paper-ripple {
44
+ color: #4285f4;
45
+ }
46
+
47
+ Note that CSS color property is inherited so it is not required to set it on
48
+ the `paper-ripple` element directly.
49
+
50
+ By default, the ripple is centered on the point of contact. Apply the `recenters`
51
+ attribute to have the ripple grow toward the center of its container.
52
+
53
+ <paper-ripple recenters></paper-ripple>
54
+
55
+ You can also center the ripple inside its container from the start.
56
+
57
+ <paper-ripple center></paper-ripple>
58
+
59
+ Apply `circle` class to make the rippling effect within a circle.
60
+
61
+ <paper-ripple class="circle"></paper-ripple>
62
+
63
+ @group Paper Elements
64
+ @element paper-ripple
65
+ @hero hero.svg
66
+ @demo demo/index.html
67
+ -->
68
+
69
+ <dom-module id="paper-ripple">
70
+
71
+ <!--
72
+ Fired when the animation finishes. This is useful if you want to wait until the ripple
73
+ animation finishes to perform some action.
74
+
75
+ @event transitionend
76
+ @param {Object} detail
77
+ @param {Object} detail.node The animated node
78
+ -->
79
+
80
+ <style>
81
+ :host {
82
+ display: block;
83
+ position: absolute;
84
+ border-radius: inherit;
85
+ overflow: hidden;
86
+ top: 0;
87
+ left: 0;
88
+ right: 0;
89
+ bottom: 0;
90
+ }
91
+
92
+ :host([animating]) {
93
+ /* This resolves a rendering issue in Chrome (as of 40) where the
94
+ ripple is not properly clipped by its parent (which may have
95
+ rounded corners). See: http://jsbin.com/temexa/4
96
+
97
+ Note: We only apply this style conditionally. Otherwise, the browser
98
+ will create a new compositing layer for every ripple element on the
99
+ page, and that would be bad. */
100
+ -webkit-transform: translate(0, 0);
101
+ transform: translate3d(0, 0, 0);
102
+ }
103
+
104
+ :host([noink]) {
105
+ pointer-events: none;
106
+ }
107
+
108
+ #background,
109
+ #waves,
110
+ .wave-container,
111
+ .wave {
112
+ pointer-events: none;
113
+ position: absolute;
114
+ top: 0;
115
+ left: 0;
116
+ width: 100%;
117
+ height: 100%;
118
+ }
119
+
120
+ #background,
121
+ .wave {
122
+ opacity: 0;
123
+ }
124
+
125
+ #waves,
126
+ .wave {
127
+ overflow: hidden;
128
+ }
129
+
130
+ .wave-container,
131
+ .wave {
132
+ border-radius: 50%;
133
+ }
134
+
135
+ :host(.circle) #background,
136
+ :host(.circle) #waves {
137
+ border-radius: 50%;
138
+ }
139
+
140
+ :host(.circle) .wave-container {
141
+ overflow: hidden;
142
+ }
143
+
144
+ </style>
145
+ <template>
146
+ <div id="background"></div>
147
+ <div id="waves"></div>
148
+ </template>
149
+ </dom-module>
150
+ <script>
151
+ (function() {
152
+ var Utility = {
153
+ cssColorWithAlpha: function(cssColor, alpha) {
154
+ var parts = cssColor.match(/^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/);
155
+
156
+ if (typeof alpha == 'undefined') {
157
+ alpha = 1;
158
+ }
159
+
160
+ if (!parts) {
161
+ return 'rgba(255, 255, 255, ' + alpha + ')';
162
+ }
163
+
164
+ return 'rgba(' + parts[1] + ', ' + parts[2] + ', ' + parts[3] + ', ' + alpha + ')';
165
+ },
166
+
167
+ distance: function(x1, y1, x2, y2) {
168
+ var xDelta = (x1 - x2);
169
+ var yDelta = (y1 - y2);
170
+
171
+ return Math.sqrt(xDelta * xDelta + yDelta * yDelta);
172
+ },
173
+
174
+ now: (function() {
175
+ if (window.performance && window.performance.now) {
176
+ return window.performance.now.bind(window.performance);
177
+ }
178
+
179
+ return Date.now;
180
+ })()
181
+ };
182
+
183
+ /**
184
+ * @param {HTMLElement} element
185
+ * @constructor
186
+ */
187
+ function ElementMetrics(element) {
188
+ this.element = element;
189
+ this.width = this.boundingRect.width;
190
+ this.height = this.boundingRect.height;
191
+
192
+ this.size = Math.max(this.width, this.height);
193
+ }
194
+
195
+ ElementMetrics.prototype = {
196
+ get boundingRect () {
197
+ return this.element.getBoundingClientRect();
198
+ },
199
+
200
+ furthestCornerDistanceFrom: function(x, y) {
201
+ var topLeft = Utility.distance(x, y, 0, 0);
202
+ var topRight = Utility.distance(x, y, this.width, 0);
203
+ var bottomLeft = Utility.distance(x, y, 0, this.height);
204
+ var bottomRight = Utility.distance(x, y, this.width, this.height);
205
+
206
+ return Math.max(topLeft, topRight, bottomLeft, bottomRight);
207
+ }
208
+ };
209
+
210
+ /**
211
+ * @param {HTMLElement} element
212
+ * @constructor
213
+ */
214
+ function Ripple(element) {
215
+ this.element = element;
216
+ this.color = window.getComputedStyle(element).color;
217
+
218
+ this.wave = document.createElement('div');
219
+ this.waveContainer = document.createElement('div');
220
+ this.wave.style.backgroundColor = this.color;
221
+ this.wave.classList.add('wave');
222
+ this.waveContainer.classList.add('wave-container');
223
+ Polymer.dom(this.waveContainer).appendChild(this.wave);
224
+
225
+ this.resetInteractionState();
226
+ }
227
+
228
+ Ripple.MAX_RADIUS = 300;
229
+
230
+ Ripple.prototype = {
231
+ get recenters() {
232
+ return this.element.recenters;
233
+ },
234
+
235
+ get center() {
236
+ return this.element.center;
237
+ },
238
+
239
+ get mouseDownElapsed() {
240
+ var elapsed;
241
+
242
+ if (!this.mouseDownStart) {
243
+ return 0;
244
+ }
245
+
246
+ elapsed = Utility.now() - this.mouseDownStart;
247
+
248
+ if (this.mouseUpStart) {
249
+ elapsed -= this.mouseUpElapsed;
250
+ }
251
+
252
+ return elapsed;
253
+ },
254
+
255
+ get mouseUpElapsed() {
256
+ return this.mouseUpStart ?
257
+ Utility.now () - this.mouseUpStart : 0;
258
+ },
259
+
260
+ get mouseDownElapsedSeconds() {
261
+ return this.mouseDownElapsed / 1000;
262
+ },
263
+
264
+ get mouseUpElapsedSeconds() {
265
+ return this.mouseUpElapsed / 1000;
266
+ },
267
+
268
+ get mouseInteractionSeconds() {
269
+ return this.mouseDownElapsedSeconds + this.mouseUpElapsedSeconds;
270
+ },
271
+
272
+ get initialOpacity() {
273
+ return this.element.initialOpacity;
274
+ },
275
+
276
+ get opacityDecayVelocity() {
277
+ return this.element.opacityDecayVelocity;
278
+ },
279
+
280
+ get radius() {
281
+ var width2 = this.containerMetrics.width * this.containerMetrics.width;
282
+ var height2 = this.containerMetrics.height * this.containerMetrics.height;
283
+ var waveRadius = Math.min(
284
+ Math.sqrt(width2 + height2),
285
+ Ripple.MAX_RADIUS
286
+ ) * 1.1 + 5;
287
+
288
+ var duration = 1.1 - 0.2 * (waveRadius / Ripple.MAX_RADIUS);
289
+ var timeNow = this.mouseInteractionSeconds / duration;
290
+ var size = waveRadius * (1 - Math.pow(80, -timeNow));
291
+
292
+ return Math.abs(size);
293
+ },
294
+
295
+ get opacity() {
296
+ if (!this.mouseUpStart) {
297
+ return this.initialOpacity;
298
+ }
299
+
300
+ return Math.max(
301
+ 0,
302
+ this.initialOpacity - this.mouseUpElapsedSeconds * this.opacityDecayVelocity
303
+ );
304
+ },
305
+
306
+ get outerOpacity() {
307
+ // Linear increase in background opacity, capped at the opacity
308
+ // of the wavefront (waveOpacity).
309
+ var outerOpacity = this.mouseUpElapsedSeconds * 0.3;
310
+ var waveOpacity = this.opacity;
311
+
312
+ return Math.max(
313
+ 0,
314
+ Math.min(outerOpacity, waveOpacity)
315
+ );
316
+ },
317
+
318
+ get isOpacityFullyDecayed() {
319
+ return this.opacity < 0.01 &&
320
+ this.radius >= Math.min(this.maxRadius, Ripple.MAX_RADIUS);
321
+ },
322
+
323
+ get isRestingAtMaxRadius() {
324
+ return this.opacity >= this.initialOpacity &&
325
+ this.radius >= Math.min(this.maxRadius, Ripple.MAX_RADIUS);
326
+ },
327
+
328
+ get isAnimationComplete() {
329
+ return this.mouseUpStart ?
330
+ this.isOpacityFullyDecayed : this.isRestingAtMaxRadius;
331
+ },
332
+
333
+ get translationFraction() {
334
+ return Math.min(
335
+ 1,
336
+ this.radius / this.containerMetrics.size * 2 / Math.sqrt(2)
337
+ );
338
+ },
339
+
340
+ get xNow() {
341
+ if (this.xEnd) {
342
+ return this.xStart + this.translationFraction * (this.xEnd - this.xStart);
343
+ }
344
+
345
+ return this.xStart;
346
+ },
347
+
348
+ get yNow() {
349
+ if (this.yEnd) {
350
+ return this.yStart + this.translationFraction * (this.yEnd - this.yStart);
351
+ }
352
+
353
+ return this.yStart;
354
+ },
355
+
356
+ get isMouseDown() {
357
+ return this.mouseDownStart && !this.mouseUpStart;
358
+ },
359
+
360
+ resetInteractionState: function() {
361
+ this.maxRadius = 0;
362
+ this.mouseDownStart = 0;
363
+ this.mouseUpStart = 0;
364
+
365
+ this.xStart = 0;
366
+ this.yStart = 0;
367
+ this.xEnd = 0;
368
+ this.yEnd = 0;
369
+ this.slideDistance = 0;
370
+
371
+ this.containerMetrics = new ElementMetrics(this.element);
372
+ },
373
+
374
+ draw: function() {
375
+ var scale;
376
+ var translateString;
377
+ var dx;
378
+ var dy;
379
+
380
+ this.wave.style.opacity = this.opacity;
381
+
382
+ scale = this.radius / (this.containerMetrics.size / 2);
383
+ dx = this.xNow - (this.containerMetrics.width / 2);
384
+ dy = this.yNow - (this.containerMetrics.height / 2);
385
+
386
+
387
+ // 2d transform for safari because of border-radius and overflow:hidden clipping bug.
388
+ // https://bugs.webkit.org/show_bug.cgi?id=98538
389
+ this.waveContainer.style.webkitTransform = 'translate(' + dx + 'px, ' + dy + 'px)';
390
+ this.waveContainer.style.transform = 'translate3d(' + dx + 'px, ' + dy + 'px, 0)';
391
+ this.wave.style.webkitTransform = 'scale(' + scale + ',' + scale + ')';
392
+ this.wave.style.transform = 'scale3d(' + scale + ',' + scale + ',1)';
393
+ },
394
+
395
+ downAction: function(event) {
396
+ var xCenter = this.containerMetrics.width / 2;
397
+ var yCenter = this.containerMetrics.height / 2;
398
+
399
+ this.resetInteractionState();
400
+ this.mouseDownStart = Utility.now();
401
+
402
+ if (this.center) {
403
+ this.xStart = xCenter;
404
+ this.yStart = yCenter;
405
+ this.slideDistance = Utility.distance(
406
+ this.xStart, this.yStart, this.xEnd, this.yEnd
407
+ );
408
+ } else {
409
+ this.xStart = event ?
410
+ event.detail.x - this.containerMetrics.boundingRect.left :
411
+ this.containerMetrics.width / 2;
412
+ this.yStart = event ?
413
+ event.detail.y - this.containerMetrics.boundingRect.top :
414
+ this.containerMetrics.height / 2;
415
+ }
416
+
417
+ if (this.recenters) {
418
+ this.xEnd = xCenter;
419
+ this.yEnd = yCenter;
420
+ this.slideDistance = Utility.distance(
421
+ this.xStart, this.yStart, this.xEnd, this.yEnd
422
+ );
423
+ }
424
+
425
+ this.maxRadius = this.containerMetrics.furthestCornerDistanceFrom(
426
+ this.xStart,
427
+ this.yStart
428
+ );
429
+
430
+ this.waveContainer.style.top =
431
+ (this.containerMetrics.height - this.containerMetrics.size) / 2 + 'px';
432
+ this.waveContainer.style.left =
433
+ (this.containerMetrics.width - this.containerMetrics.size) / 2 + 'px';
434
+
435
+ this.waveContainer.style.width = this.containerMetrics.size + 'px';
436
+ this.waveContainer.style.height = this.containerMetrics.size + 'px';
437
+ },
438
+
439
+ upAction: function(event) {
440
+ if (!this.isMouseDown) {
441
+ return;
442
+ }
443
+
444
+ this.mouseUpStart = Utility.now();
445
+ },
446
+
447
+ remove: function() {
448
+ Polymer.dom(this.waveContainer.parentNode).removeChild(
449
+ this.waveContainer
450
+ );
451
+ }
452
+ };
453
+
454
+ Polymer({
455
+ is: 'paper-ripple',
456
+
457
+ behaviors: [
458
+ Polymer.IronA11yKeysBehavior
459
+ ],
460
+
461
+ properties: {
462
+ /**
463
+ * The initial opacity set on the wave.
464
+ *
465
+ * @attribute initialOpacity
466
+ * @type number
467
+ * @default 0.25
468
+ */
469
+ initialOpacity: {
470
+ type: Number,
471
+ value: 0.25
472
+ },
473
+
474
+ /**
475
+ * How fast (opacity per second) the wave fades out.
476
+ *
477
+ * @attribute opacityDecayVelocity
478
+ * @type number
479
+ * @default 0.8
480
+ */
481
+ opacityDecayVelocity: {
482
+ type: Number,
483
+ value: 0.8
484
+ },
485
+
486
+ /**
487
+ * If true, ripples will exhibit a gravitational pull towards
488
+ * the center of their container as they fade away.
489
+ *
490
+ * @attribute recenters
491
+ * @type boolean
492
+ * @default false
493
+ */
494
+ recenters: {
495
+ type: Boolean,
496
+ value: false
497
+ },
498
+
499
+ /**
500
+ * If true, ripples will center inside its container
501
+ *
502
+ * @attribute recenters
503
+ * @type boolean
504
+ * @default false
505
+ */
506
+ center: {
507
+ type: Boolean,
508
+ value: false
509
+ },
510
+
511
+ /**
512
+ * A list of the visual ripples.
513
+ *
514
+ * @attribute ripples
515
+ * @type Array
516
+ * @default []
517
+ */
518
+ ripples: {
519
+ type: Array,
520
+ value: function() {
521
+ return [];
522
+ }
523
+ },
524
+
525
+ /**
526
+ * True when there are visible ripples animating within the
527
+ * element.
528
+ */
529
+ animating: {
530
+ type: Boolean,
531
+ readOnly: true,
532
+ reflectToAttribute: true,
533
+ value: false
534
+ },
535
+
536
+ /**
537
+ * If true, the ripple will remain in the "down" state until `holdDown`
538
+ * is set to false again.
539
+ */
540
+ holdDown: {
541
+ type: Boolean,
542
+ value: false,
543
+ observer: '_holdDownChanged'
544
+ },
545
+
546
+ _animating: {
547
+ type: Boolean
548
+ },
549
+
550
+ _boundAnimate: {
551
+ type: Function,
552
+ value: function() {
553
+ return this.animate.bind(this);
554
+ }
555
+ }
556
+ },
557
+
558
+ get target () {
559
+ var ownerRoot = Polymer.dom(this).getOwnerRoot();
560
+ var target;
561
+
562
+ if (ownerRoot) {
563
+ target = ownerRoot.host;
564
+ }
565
+
566
+ if (!target) {
567
+ target = this.parentNode;
568
+ }
569
+
570
+ return target;
571
+ },
572
+
573
+ keyBindings: {
574
+ 'enter:keydown': '_onEnterKeydown',
575
+ 'space:keydown': '_onSpaceKeydown',
576
+ 'space:keyup': '_onSpaceKeyup'
577
+ },
578
+
579
+ attached: function() {
580
+ this._listen(this.target, 'up', this.upAction.bind(this));
581
+ this._listen(this.target, 'down', this.downAction.bind(this));
582
+
583
+ if (!this.target.hasAttribute('noink')) {
584
+ this.keyEventTarget = this.target;
585
+ }
586
+ },
587
+
588
+ get shouldKeepAnimating () {
589
+ for (var index = 0; index < this.ripples.length; ++index) {
590
+ if (!this.ripples[index].isAnimationComplete) {
591
+ return true;
592
+ }
593
+ }
594
+
595
+ return false;
596
+ },
597
+
598
+ simulatedRipple: function() {
599
+ this.downAction(null);
600
+
601
+ // Please see polymer/polymer#1305
602
+ this.async(function() {
603
+ this.upAction();
604
+ }, 1);
605
+ },
606
+
607
+ downAction: function(event) {
608
+ if (this.holdDown && this.ripples.length > 0) {
609
+ return;
610
+ }
611
+
612
+ var ripple = this.addRipple();
613
+
614
+ ripple.downAction(event);
615
+
616
+ if (!this._animating) {
617
+ this.animate();
618
+ }
619
+ },
620
+
621
+ upAction: function(event) {
622
+ if (this.holdDown) {
623
+ return;
624
+ }
625
+
626
+ this.ripples.forEach(function(ripple) {
627
+ ripple.upAction(event);
628
+ });
629
+
630
+ this.animate();
631
+ },
632
+
633
+ onAnimationComplete: function() {
634
+ this._animating = false;
635
+ this.$.background.style.backgroundColor = null;
636
+ this.fire('transitionend');
637
+ },
638
+
639
+ addRipple: function() {
640
+ var ripple = new Ripple(this);
641
+
642
+ Polymer.dom(this.$.waves).appendChild(ripple.waveContainer);
643
+ this.$.background.style.backgroundColor = ripple.color;
644
+ this.ripples.push(ripple);
645
+
646
+ this._setAnimating(true);
647
+
648
+ return ripple;
649
+ },
650
+
651
+ removeRipple: function(ripple) {
652
+ var rippleIndex = this.ripples.indexOf(ripple);
653
+
654
+ if (rippleIndex < 0) {
655
+ return;
656
+ }
657
+
658
+ this.ripples.splice(rippleIndex, 1);
659
+
660
+ ripple.remove();
661
+
662
+ if (!this.ripples.length) {
663
+ this._setAnimating(false);
664
+ }
665
+ },
666
+
667
+ animate: function() {
668
+ var index;
669
+ var ripple;
670
+
671
+ this._animating = true;
672
+
673
+ for (index = 0; index < this.ripples.length; ++index) {
674
+ ripple = this.ripples[index];
675
+
676
+ ripple.draw();
677
+
678
+ this.$.background.style.opacity = ripple.outerOpacity;
679
+
680
+ if (ripple.isOpacityFullyDecayed && !ripple.isRestingAtMaxRadius) {
681
+ this.removeRipple(ripple);
682
+ }
683
+ }
684
+
685
+ if (!this.shouldKeepAnimating && this.ripples.length === 0) {
686
+ this.onAnimationComplete();
687
+ } else {
688
+ window.requestAnimationFrame(this._boundAnimate);
689
+ }
690
+ },
691
+
692
+ _onEnterKeydown: function() {
693
+ this.downAction();
694
+ this.async(this.upAction, 1);
695
+ },
696
+
697
+ _onSpaceKeydown: function() {
698
+ this.downAction();
699
+ },
700
+
701
+ _onSpaceKeyup: function() {
702
+ this.upAction();
703
+ },
704
+
705
+ _holdDownChanged: function(holdDown) {
706
+ if (holdDown) {
707
+ this.downAction();
708
+ } else {
709
+ this.upAction();
710
+ }
711
+ }
712
+ });
713
+ })();
714
+ </script>