coprl 0.1.0 → 3.0.0.beta.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (631) hide show
  1. checksums.yaml +4 -4
  2. data/.circleci/config.yml +59 -6
  3. data/.gem_release.yml +1 -0
  4. data/.github/ISSUE_TEMPLATE/bug_report.md +38 -0
  5. data/.github/ISSUE_TEMPLATE/feature_request.md +20 -0
  6. data/.github/ISSUE_TEMPLATE/questions-support.md +10 -0
  7. data/.github/workflows/semantic-release.yml +43 -0
  8. data/.gitignore +50 -7
  9. data/.releaserc +11 -0
  10. data/.ruby-version +2 -0
  11. data/CHANGELOG.md +244 -0
  12. data/CODE-OF-CONDUCT.md +73 -0
  13. data/CONTRIBUTING.md +60 -0
  14. data/Gemfile +35 -6
  15. data/Gemfile.lock +245 -0
  16. data/HISTORY.md +61 -0
  17. data/{LICENSE.txt → LICENSE} +6 -6
  18. data/Procfile +1 -0
  19. data/README.md +126 -19
  20. data/ROADMAP.md +6 -0
  21. data/Rakefile +3 -9
  22. data/app/demo/components.pom +19 -0
  23. data/app/demo/components/avatars.pom +40 -0
  24. data/app/demo/components/badges.pom +26 -0
  25. data/app/demo/components/buttons.pom +63 -0
  26. data/app/demo/components/cards.pom +84 -0
  27. data/app/demo/components/chips.pom +103 -0
  28. data/app/demo/components/content.pom +111 -0
  29. data/app/demo/components/date_fields.pom +106 -0
  30. data/app/demo/components/datetime_fields.pom +113 -0
  31. data/app/demo/components/dialogs.pom +195 -0
  32. data/app/demo/components/drawers.pom +35 -0
  33. data/app/demo/components/expansion_panels.pom +20 -0
  34. data/app/demo/components/fabs-mini.pom +17 -0
  35. data/app/demo/components/fabs.pom +16 -0
  36. data/app/demo/components/file_inputs.pom +52 -0
  37. data/app/demo/components/footers.pom +36 -0
  38. data/app/demo/components/headers.pom +101 -0
  39. data/app/demo/components/hidden_fields.pom +18 -0
  40. data/app/demo/components/icons.pom +125 -0
  41. data/app/demo/components/image_lists.pom +100 -0
  42. data/app/demo/components/images.pom +45 -0
  43. data/app/demo/components/layouts.pom +54 -0
  44. data/app/demo/components/lists.pom +168 -0
  45. data/app/demo/components/menus.pom +53 -0
  46. data/app/demo/components/multi_selects.pom +29 -0
  47. data/app/demo/components/nav/drawer.pom +5 -0
  48. data/app/demo/components/nav/menu.pom +53 -0
  49. data/app/demo/components/nav/pattern_drawer.pom +5 -0
  50. data/app/demo/components/nav/pattern_menu.pom +12 -0
  51. data/app/demo/components/number_fields.pom +53 -0
  52. data/app/demo/components/padding.pom +96 -0
  53. data/app/demo/components/progress.pom +71 -0
  54. data/app/demo/components/selects.pom +69 -0
  55. data/app/demo/components/sliders.pom +54 -0
  56. data/app/demo/components/snackbar.pom +35 -0
  57. data/app/demo/components/snackbar_attached.pom +6 -0
  58. data/app/demo/components/steppers.pom +178 -0
  59. data/app/demo/components/tab_bars.pom +66 -0
  60. data/app/demo/components/tables.pom +121 -0
  61. data/app/demo/components/text_areas.pom +38 -0
  62. data/app/demo/components/text_fields.pom +114 -0
  63. data/app/demo/components/time_fields.pom +59 -0
  64. data/app/demo/components/toggles.pom +122 -0
  65. data/app/demo/components/tooltips.pom +119 -0
  66. data/app/demo/components/unordered_list.pom +81 -0
  67. data/app/demo/custom_css.pom +37 -0
  68. data/app/demo/events.pom +29 -0
  69. data/app/demo/events/actions/autocomplete.pom +32 -0
  70. data/app/demo/events/actions/clear.pom +25 -0
  71. data/app/demo/events/actions/deletes.pom +24 -0
  72. data/app/demo/events/actions/dialog.pom +19 -0
  73. data/app/demo/events/actions/dialogs/discard.pom +9 -0
  74. data/app/demo/events/actions/dialogs/show_dialog.pom +11 -0
  75. data/app/demo/events/actions/dialogs/trigger.pom +86 -0
  76. data/app/demo/events/actions/last_response.pom +40 -0
  77. data/app/demo/events/actions/loads.pom +29 -0
  78. data/app/demo/events/actions/posts.pom +23 -0
  79. data/app/demo/events/actions/prompt_if_dirty.pom +54 -0
  80. data/app/demo/events/actions/replace_text.pom +6 -0
  81. data/app/demo/events/actions/replaces.pom +21 -0
  82. data/app/demo/events/actions/snackbar.pom +19 -0
  83. data/app/demo/events/actions/toggle_visiblity.pom +22 -0
  84. data/app/demo/events/actions/updates.pom +24 -0
  85. data/app/demo/events/content_as_form.pom +313 -0
  86. data/app/demo/events/field_level.pom +20 -0
  87. data/app/demo/events/form_level.pom +24 -0
  88. data/app/demo/events/halted.pom +23 -0
  89. data/app/demo/events/nav/drawer.pom +25 -0
  90. data/app/demo/events/parallel.pom +44 -0
  91. data/app/demo/events/tagged_input.pom +37 -0
  92. data/app/demo/formatting_tokens.pom +125 -0
  93. data/app/demo/hello_world.pom +3 -0
  94. data/app/demo/helpers/indented_grid.rb +14 -0
  95. data/app/demo/index.pom +26 -0
  96. data/app/demo/markdown.pom +67 -0
  97. data/app/demo/namespaces.pom +89 -0
  98. data/app/demo/nav/top_nav.pom +60 -0
  99. data/app/demo/patterns.pom +19 -0
  100. data/app/demo/patterns/drag_drop.pom +89 -0
  101. data/app/demo/patterns/floating_card.pom +29 -0
  102. data/app/demo/patterns/search_select.pom +106 -0
  103. data/app/demo/plugins/animate.pom +144 -0
  104. data/app/demo/plugins/cacheable.pom +64 -0
  105. data/app/demo/plugins/chart.pom +254 -0
  106. data/app/demo/plugins/clipboard.pom +21 -0
  107. data/app/demo/plugins/color_picker.pom +17 -0
  108. data/app/demo/plugins/google_maps.pom +24 -0
  109. data/app/demo/plugins/iframe.pom +14 -0
  110. data/app/demo/plugins/image_crop.pom +44 -0
  111. data/app/demo/plugins/index.pom +29 -0
  112. data/app/demo/plugins/markup.pom +14 -0
  113. data/app/demo/plugins/nav/drawer.pom +19 -0
  114. data/app/demo/plugins/script.pom +17 -0
  115. data/app/demo/plugins/scroll_to.pom +22 -0
  116. data/app/demo/plugins/timer.pom +24 -0
  117. data/app/demo/shared/code.pom +20 -0
  118. data/app/demo/shared/context_list.pom +29 -0
  119. data/app/demo/shared/debug.pom +17 -0
  120. data/app/demo/styles.pom +42 -0
  121. data/bin/console +14 -7
  122. data/component-status.yml +219 -0
  123. data/config.ru +55 -0
  124. data/coprl.gemspec +35 -27
  125. data/docs/migrating_from_v2_to_v3.md +33 -0
  126. data/docs/settings.md +81 -0
  127. data/exe/coprl +2 -2
  128. data/lib/coprl.rb +22 -4
  129. data/lib/coprl/container_methods.rb +40 -0
  130. data/lib/coprl/logger_methods.rb +11 -0
  131. data/lib/coprl/parameters.rb +73 -0
  132. data/lib/coprl/presenters/api/app.rb +86 -0
  133. data/lib/coprl/presenters/api/router.rb +10 -0
  134. data/lib/coprl/presenters/app.rb +55 -0
  135. data/lib/coprl/presenters/cli.rb +38 -0
  136. data/lib/coprl/presenters/container_item.rb +16 -0
  137. data/lib/coprl/presenters/demo/dragon_drop.rb +48 -0
  138. data/lib/coprl/presenters/demo/echo.rb +36 -0
  139. data/lib/coprl/presenters/demo/search-terms.yml +50 -0
  140. data/lib/coprl/presenters/demo/search.rb +29 -0
  141. data/lib/coprl/presenters/demo/slow.rb +18 -0
  142. data/lib/coprl/presenters/dsl/components/actions/autocomplete.rb +15 -0
  143. data/lib/coprl/presenters/dsl/components/actions/base.rb +69 -0
  144. data/lib/coprl/presenters/dsl/components/actions/clear.rb +15 -0
  145. data/lib/coprl/presenters/dsl/components/actions/close_dialog.rb +17 -0
  146. data/lib/coprl/presenters/dsl/components/actions/deletes.rb +15 -0
  147. data/lib/coprl/presenters/dsl/components/actions/dialog.rb +15 -0
  148. data/lib/coprl/presenters/dsl/components/actions/loads.rb +31 -0
  149. data/lib/coprl/presenters/dsl/components/actions/navigates.rb +15 -0
  150. data/lib/coprl/presenters/dsl/components/actions/post_message.rb +17 -0
  151. data/lib/coprl/presenters/dsl/components/actions/posts.rb +20 -0
  152. data/lib/coprl/presenters/dsl/components/actions/prompt_if_dirty.rb +15 -0
  153. data/lib/coprl/presenters/dsl/components/actions/remove.rb +15 -0
  154. data/lib/coprl/presenters/dsl/components/actions/replaces.rb +25 -0
  155. data/lib/coprl/presenters/dsl/components/actions/snackbar.rb +15 -0
  156. data/lib/coprl/presenters/dsl/components/actions/stepper.rb +15 -0
  157. data/lib/coprl/presenters/dsl/components/actions/toggle_disabled.rb +15 -0
  158. data/lib/coprl/presenters/dsl/components/actions/toggle_visibility.rb +15 -0
  159. data/lib/coprl/presenters/dsl/components/actions/updates.rb +20 -0
  160. data/lib/coprl/presenters/dsl/components/avatar.rb +22 -0
  161. data/lib/coprl/presenters/dsl/components/badge.rb +19 -0
  162. data/lib/coprl/presenters/dsl/components/base.rb +103 -0
  163. data/lib/coprl/presenters/dsl/components/button.rb +60 -0
  164. data/lib/coprl/presenters/dsl/components/card.rb +135 -0
  165. data/lib/coprl/presenters/dsl/components/checkbox.rb +17 -0
  166. data/lib/coprl/presenters/dsl/components/chip.rb +50 -0
  167. data/lib/coprl/presenters/dsl/components/chipset.rb +33 -0
  168. data/lib/coprl/presenters/dsl/components/content.rb +57 -0
  169. data/lib/coprl/presenters/dsl/components/date_field.rb +34 -0
  170. data/lib/coprl/presenters/dsl/components/datetime_base.rb +46 -0
  171. data/lib/coprl/presenters/dsl/components/datetime_field.rb +23 -0
  172. data/lib/coprl/presenters/dsl/components/dialog.rb +80 -0
  173. data/lib/coprl/presenters/dsl/components/drawer.rb +45 -0
  174. data/lib/coprl/presenters/dsl/components/event.rb +183 -0
  175. data/lib/coprl/presenters/dsl/components/event_base.rb +18 -0
  176. data/lib/coprl/presenters/dsl/components/expansion_panel.rb +49 -0
  177. data/lib/coprl/presenters/dsl/components/file_input.rb +34 -0
  178. data/lib/coprl/presenters/dsl/components/footer.rb +25 -0
  179. data/lib/coprl/presenters/dsl/components/form.rb +33 -0
  180. data/lib/coprl/presenters/dsl/components/grid.rb +110 -0
  181. data/lib/coprl/presenters/dsl/components/header.rb +58 -0
  182. data/lib/coprl/presenters/dsl/components/hidden_field.rb +23 -0
  183. data/lib/coprl/presenters/dsl/components/icon.rb +18 -0
  184. data/lib/coprl/presenters/dsl/components/icon_base.rb +22 -0
  185. data/lib/coprl/presenters/dsl/components/icon_toggle.rb +19 -0
  186. data/lib/coprl/presenters/dsl/components/image.rb +84 -0
  187. data/lib/coprl/presenters/dsl/components/image_list.rb +43 -0
  188. data/lib/coprl/presenters/dsl/components/input.rb +30 -0
  189. data/lib/coprl/presenters/dsl/components/link.rb +33 -0
  190. data/lib/coprl/presenters/dsl/components/list.rb +47 -0
  191. data/lib/coprl/presenters/dsl/components/lists/action.rb +69 -0
  192. data/lib/coprl/presenters/dsl/components/lists/actions.rb +60 -0
  193. data/lib/coprl/presenters/dsl/components/lists/header.rb +19 -0
  194. data/lib/coprl/presenters/dsl/components/lists/line.rb +105 -0
  195. data/lib/coprl/presenters/dsl/components/lists/separator.rb +16 -0
  196. data/lib/coprl/presenters/dsl/components/menu.rb +123 -0
  197. data/lib/coprl/presenters/dsl/components/mixins/append.rb +20 -0
  198. data/lib/coprl/presenters/dsl/components/mixins/attaches.rb +22 -0
  199. data/lib/coprl/presenters/dsl/components/mixins/avatar.rb +15 -0
  200. data/lib/coprl/presenters/dsl/components/mixins/buttons.rb +15 -0
  201. data/lib/coprl/presenters/dsl/components/mixins/chips.rb +18 -0
  202. data/lib/coprl/presenters/dsl/components/mixins/chipset.rb +19 -0
  203. data/lib/coprl/presenters/dsl/components/mixins/common.rb +55 -0
  204. data/lib/coprl/presenters/dsl/components/mixins/content.rb +15 -0
  205. data/lib/coprl/presenters/dsl/components/mixins/date_time_fields.rb +26 -0
  206. data/lib/coprl/presenters/dsl/components/mixins/dialogs.rb +16 -0
  207. data/lib/coprl/presenters/dsl/components/mixins/event.rb +17 -0
  208. data/lib/coprl/presenters/dsl/components/mixins/expansion_panels.rb +15 -0
  209. data/lib/coprl/presenters/dsl/components/mixins/file_inputs.rb +16 -0
  210. data/lib/coprl/presenters/dsl/components/mixins/google_maps.rb +15 -0
  211. data/lib/coprl/presenters/dsl/components/mixins/grids.rb +15 -0
  212. data/lib/coprl/presenters/dsl/components/mixins/helpers.rb +20 -0
  213. data/lib/coprl/presenters/dsl/components/mixins/icons.rb +16 -0
  214. data/lib/coprl/presenters/dsl/components/mixins/image_lists.rb +15 -0
  215. data/lib/coprl/presenters/dsl/components/mixins/images.rb +15 -0
  216. data/lib/coprl/presenters/dsl/components/mixins/last_response.rb +48 -0
  217. data/lib/coprl/presenters/dsl/components/mixins/menus.rb +15 -0
  218. data/lib/coprl/presenters/dsl/components/mixins/padding.rb +42 -0
  219. data/lib/coprl/presenters/dsl/components/mixins/progress.rb +16 -0
  220. data/lib/coprl/presenters/dsl/components/mixins/selects.rb +22 -0
  221. data/lib/coprl/presenters/dsl/components/mixins/sliders.rb +15 -0
  222. data/lib/coprl/presenters/dsl/components/mixins/snackbars.rb +17 -0
  223. data/lib/coprl/presenters/dsl/components/mixins/steppers.rb +15 -0
  224. data/lib/coprl/presenters/dsl/components/mixins/tab_bars.rb +17 -0
  225. data/lib/coprl/presenters/dsl/components/mixins/tables.rb +15 -0
  226. data/lib/coprl/presenters/dsl/components/mixins/text_fields.rb +36 -0
  227. data/lib/coprl/presenters/dsl/components/mixins/toggles.rb +35 -0
  228. data/lib/coprl/presenters/dsl/components/mixins/tooltips.rb +17 -0
  229. data/lib/coprl/presenters/dsl/components/mixins/typography.rb +117 -0
  230. data/lib/coprl/presenters/dsl/components/mixins/yield_to.rb +15 -0
  231. data/lib/coprl/presenters/dsl/components/multi_select.rb +56 -0
  232. data/lib/coprl/presenters/dsl/components/number_field.rb +20 -0
  233. data/lib/coprl/presenters/dsl/components/page.rb +28 -0
  234. data/lib/coprl/presenters/dsl/components/page_title.rb +31 -0
  235. data/lib/coprl/presenters/dsl/components/progress.rb +27 -0
  236. data/lib/coprl/presenters/dsl/components/radio_button.rb +14 -0
  237. data/lib/coprl/presenters/dsl/components/rich_text_area.rb +20 -0
  238. data/lib/coprl/presenters/dsl/components/select.rb +72 -0
  239. data/lib/coprl/presenters/dsl/components/separator.rb +21 -0
  240. data/lib/coprl/presenters/dsl/components/slider.rb +38 -0
  241. data/lib/coprl/presenters/dsl/components/snackbar.rb +32 -0
  242. data/lib/coprl/presenters/dsl/components/stepper.rb +96 -0
  243. data/lib/coprl/presenters/dsl/components/switch.rb +14 -0
  244. data/lib/coprl/presenters/dsl/components/tab_bar.rb +50 -0
  245. data/lib/coprl/presenters/dsl/components/table.rb +193 -0
  246. data/lib/coprl/presenters/dsl/components/text_area.rb +19 -0
  247. data/lib/coprl/presenters/dsl/components/text_field.rb +113 -0
  248. data/lib/coprl/presenters/dsl/components/time_field.rb +21 -0
  249. data/lib/coprl/presenters/dsl/components/toggle_base.rb +25 -0
  250. data/lib/coprl/presenters/dsl/components/tooltip.rb +24 -0
  251. data/lib/coprl/presenters/dsl/components/typography.rb +31 -0
  252. data/lib/coprl/presenters/dsl/components/unordered_list.rb +50 -0
  253. data/lib/coprl/presenters/dsl/definer.rb +9 -0
  254. data/lib/coprl/presenters/dsl/definition.rb +34 -0
  255. data/lib/coprl/presenters/dsl/invalid_presenter.rb +8 -0
  256. data/lib/coprl/presenters/dsl/lockable.rb +11 -0
  257. data/lib/coprl/presenters/dsl/protect_from_forgery.rb +43 -0
  258. data/lib/coprl/presenters/dsl/user_interface.rb +157 -0
  259. data/lib/coprl/presenters/errors.rb +1 -0
  260. data/lib/coprl/presenters/errors/invalid_dsl.rb +8 -0
  261. data/lib/coprl/presenters/errors/parameter_validation.rb +8 -0
  262. data/lib/coprl/presenters/errors/unprocessable.rb +8 -0
  263. data/lib/coprl/presenters/generators/inflectors.rb +59 -0
  264. data/lib/coprl/presenters/generators/plugin.rb +136 -0
  265. data/lib/coprl/presenters/generators/templates/plugin/.github/workflows/semantic-release.yml +41 -0
  266. data/lib/coprl/presenters/generators/templates/plugin/.gitignore +12 -0
  267. data/lib/coprl/presenters/generators/templates/plugin/.releaserc +15 -0
  268. data/lib/coprl/presenters/generators/templates/plugin/.ruby-version +1 -0
  269. data/lib/coprl/presenters/generators/templates/plugin/Gemfile.tt +6 -0
  270. data/lib/coprl/presenters/generators/templates/plugin/LICENSE.txt.tt +21 -0
  271. data/lib/coprl/presenters/generators/templates/plugin/README.md.tt +34 -0
  272. data/lib/coprl/presenters/generators/templates/plugin/demo/plugin.pom.tt +15 -0
  273. data/lib/coprl/presenters/generators/templates/plugin/lib/coprl/presenters/plugins/components/actions/action.rb.tt +16 -0
  274. data/lib/coprl/presenters/generators/templates/plugin/lib/coprl/presenters/plugins/components/actions/dsl.rb.tt +22 -0
  275. data/lib/coprl/presenters/generators/templates/plugin/lib/coprl/presenters/plugins/components/component.rb.tt +18 -0
  276. data/lib/coprl/presenters/generators/templates/plugin/lib/coprl/presenters/plugins/components/dsl.rb.tt +19 -0
  277. data/lib/coprl/presenters/generators/templates/plugin/lib/coprl/presenters/plugins/helpers/helper.rb.tt +15 -0
  278. data/lib/coprl/presenters/generators/templates/plugin/lib/coprl/presenters/plugins/plugin.rb.tt +9 -0
  279. data/lib/coprl/presenters/generators/templates/plugin/lib/coprl/presenters/plugins/version.rb.tt +3 -0
  280. data/lib/coprl/presenters/generators/templates/plugin/lib/coprl/presenters/plugins/web_client/components/actions/data.rb.tt +17 -0
  281. data/lib/coprl/presenters/generators/templates/plugin/lib/coprl/presenters/plugins/web_client/components/render.rb.tt +27 -0
  282. data/lib/coprl/presenters/generators/templates/plugin/presenter_plugin.gemspec.tt +22 -0
  283. data/lib/coprl/presenters/generators/templates/plugin/views/assets/css/components/component.css.tt +21 -0
  284. data/lib/coprl/presenters/generators/templates/plugin/views/assets/js/components/actions/action.js.tt +15 -0
  285. data/lib/coprl/presenters/generators/templates/plugin/views/assets/js/components/component.js.tt +39 -0
  286. data/lib/coprl/presenters/generators/templates/plugin/views/components/application/component.erb.tt +14 -0
  287. data/lib/coprl/presenters/generators/templates/plugin/views/components/application/component_header.erb.tt +20 -0
  288. data/lib/coprl/presenters/helpers.rb +12 -0
  289. data/lib/coprl/presenters/helpers/date.rb +22 -0
  290. data/lib/coprl/presenters/helpers/errors.rb +11 -0
  291. data/lib/coprl/presenters/helpers/inflector.rb +16 -0
  292. data/lib/coprl/presenters/helpers/rails.rb +43 -0
  293. data/lib/coprl/presenters/helpers/rails/currency.rb +16 -0
  294. data/lib/coprl/presenters/helpers/rails/model_table.rb +60 -0
  295. data/lib/coprl/presenters/helpers/redact.rb +13 -0
  296. data/lib/coprl/presenters/helpers/route.rb +24 -0
  297. data/lib/coprl/presenters/helpers/time.rb +27 -0
  298. data/lib/coprl/presenters/namespace.rb +12 -0
  299. data/lib/coprl/presenters/pluggable.rb +37 -0
  300. data/lib/coprl/presenters/plugins.rb +7 -0
  301. data/lib/coprl/presenters/rails/engine.rb +19 -0
  302. data/lib/coprl/presenters/rails/railtie.rb +41 -0
  303. data/lib/coprl/presenters/registry.rb +64 -0
  304. data/lib/coprl/presenters/router.rb +59 -0
  305. data/lib/coprl/presenters/settings.rb +81 -0
  306. data/lib/coprl/presenters/version.rb +7 -0
  307. data/lib/coprl/presenters/views.rb +17 -0
  308. data/lib/coprl/presenters/web_client/app.rb +121 -0
  309. data/lib/coprl/presenters/web_client/component_decorator_factory.rb +27 -0
  310. data/lib/coprl/presenters/web_client/component_html_decorator.rb +50 -0
  311. data/lib/coprl/presenters/web_client/component_renderer.rb +49 -0
  312. data/lib/coprl/presenters/web_client/custom_css.rb +66 -0
  313. data/lib/coprl/presenters/web_client/custom_render.rb +31 -0
  314. data/lib/coprl/presenters/web_client/helpers/color.rb +18 -0
  315. data/lib/coprl/presenters/web_client/helpers/drag_and_drop.rb +21 -0
  316. data/lib/coprl/presenters/web_client/helpers/equal.rb +7 -0
  317. data/lib/coprl/presenters/web_client/helpers/expand_hash.rb +19 -0
  318. data/lib/coprl/presenters/web_client/helpers/form_helpers.rb +14 -0
  319. data/lib/coprl/presenters/web_client/helpers/headers.rb +40 -0
  320. data/lib/coprl/presenters/web_client/helpers/html_safe.rb +8 -0
  321. data/lib/coprl/presenters/web_client/helpers/includes.rb +11 -0
  322. data/lib/coprl/presenters/web_client/helpers/inflector.rb +7 -0
  323. data/lib/coprl/presenters/web_client/helpers/markdown.rb +29 -0
  324. data/lib/coprl/presenters/web_client/helpers/padding_helpers.rb +21 -0
  325. data/lib/coprl/presenters/web_client/helpers/rails.rb +12 -0
  326. data/lib/coprl/presenters/web_client/helpers/rails/escape_html.rb +9 -0
  327. data/lib/coprl/presenters/web_client/helpers/rails/local_variables.rb +11 -0
  328. data/lib/coprl/presenters/web_client/helpers/rails/namespaced.rb +12 -0
  329. data/lib/coprl/presenters/web_client/helpers/rails/partials.rb +20 -0
  330. data/lib/coprl/presenters/web_client/helpers/rails/raw.rb +9 -0
  331. data/lib/coprl/presenters/web_client/helpers/rails/safe_markdown.rb +9 -0
  332. data/lib/coprl/presenters/web_client/helpers/render_component.rb +11 -0
  333. data/lib/coprl/presenters/web_client/helpers/shared.rb +18 -0
  334. data/lib/coprl/presenters/web_client/helpers/sinatra.rb +11 -0
  335. data/lib/coprl/presenters/web_client/helpers/sinatra/escape_html.rb +9 -0
  336. data/lib/coprl/presenters/web_client/helpers/sinatra/local_variables.rb +11 -0
  337. data/lib/coprl/presenters/web_client/helpers/sinatra/partials.rb +27 -0
  338. data/lib/coprl/presenters/web_client/helpers/sinatra/raw.rb +9 -0
  339. data/lib/coprl/presenters/web_client/helpers/sinatra/safe_markdown.rb +10 -0
  340. data/lib/coprl/presenters/web_client/helpers/snake_to_camel.rb +12 -0
  341. data/lib/coprl/presenters/web_client/helpers/transform_hash.rb +20 -0
  342. data/lib/coprl/presenters/web_client/helpers/unique_id.rb +7 -0
  343. data/lib/coprl/presenters/web_client/plugin_headers.rb +37 -0
  344. data/lib/coprl/presenters/web_client/plugin_views_path.rb +35 -0
  345. data/lib/coprl/presenters/web_client/router.rb +10 -0
  346. data/lib/coprl/serializer.rb +43 -0
  347. data/lib/coprl/symbol/to_str.rb +29 -0
  348. data/lib/coprl/trace.rb +17 -0
  349. data/lib/hash_ext/traverse.rb +14 -0
  350. data/public/bundle.css +18256 -0
  351. data/public/bundle.js +60201 -0
  352. data/public/dialog-polyfill.js +738 -0
  353. data/public/favicon.ico +0 -0
  354. data/public/img/demo/dog.png +0 -0
  355. data/public/img/demo/grace-hopper-headshot.png +0 -0
  356. data/public/img/demo/grace-hopper-wide.png +0 -0
  357. data/public/img/demo/grace-hopper.png +0 -0
  358. data/public/img/demo/image_card.jpg +0 -0
  359. data/public/img/demo/rx.png +0 -0
  360. data/public/img/demo/welcome_card.jpg +0 -0
  361. data/public/img/settings/blue.png +0 -0
  362. data/public/img/settings/green.png +0 -0
  363. data/public/img/settings/orange.png +0 -0
  364. data/public/img/settings/purple.png +0 -0
  365. data/public/img/settings/red.png +0 -0
  366. data/public/img/settings/teal.png +0 -0
  367. data/public/img/settings/white.png +0 -0
  368. data/public/img/settings/yellow.png +0 -0
  369. data/public/presenters/custom_css.css +26 -0
  370. data/public/scripts.js +289 -0
  371. data/public/style-bundle.js +73 -0
  372. data/public/styles.css +16 -0
  373. data/public/wc.js +52956 -0
  374. data/rails-engine/app/controllers/coprl_controller.rb +43 -0
  375. data/rails-engine/app/helpers/coprl_helper.rb +3 -0
  376. data/rails-engine/app/views/application/_show.html.pom +2 -0
  377. data/rails-engine/app/views/coprl/show.html.pom +2 -0
  378. data/rails-engine/app/views/layouts/coprl.html.erb +21 -0
  379. data/rails-engine/config.ru +1 -0
  380. data/rails-engine/config/initializers/presenters.rb +43 -0
  381. data/rails-engine/config/initializers/session.rb +8 -0
  382. data/rails-engine/config/routes.rb +14 -0
  383. data/scripts/build.sh +10 -0
  384. data/views/mdc/.babelrc +8 -0
  385. data/views/mdc/.eslintrc.yml +24 -0
  386. data/views/mdc/.gitignore +1 -0
  387. data/views/mdc/.nvmrc +1 -0
  388. data/views/mdc/assets/js/app.js +34 -0
  389. data/views/mdc/assets/js/components/base-component.js +163 -0
  390. data/views/mdc/assets/js/components/base-container.js +87 -0
  391. data/views/mdc/assets/js/components/base-toggle.js +56 -0
  392. data/views/mdc/assets/js/components/button.js +77 -0
  393. data/views/mdc/assets/js/components/cards.js +14 -0
  394. data/views/mdc/assets/js/components/checkboxes.js +15 -0
  395. data/views/mdc/assets/js/components/chips.js +109 -0
  396. data/views/mdc/assets/js/components/content.js +14 -0
  397. data/views/mdc/assets/js/components/data-tables.js +15 -0
  398. data/views/mdc/assets/js/components/datetime.js +186 -0
  399. data/views/mdc/assets/js/components/dialogs.js +135 -0
  400. data/views/mdc/assets/js/components/drag_n_drop.js +182 -0
  401. data/views/mdc/assets/js/components/drawer.js +43 -0
  402. data/views/mdc/assets/js/components/events.js +277 -0
  403. data/views/mdc/assets/js/components/events/action_parameter.js +62 -0
  404. data/views/mdc/assets/js/components/events/action_parameter.test.js +62 -0
  405. data/views/mdc/assets/js/components/events/autocomplete.js +94 -0
  406. data/views/mdc/assets/js/components/events/base.js +167 -0
  407. data/views/mdc/assets/js/components/events/clears.js +29 -0
  408. data/views/mdc/assets/js/components/events/close_dialog.js +50 -0
  409. data/views/mdc/assets/js/components/events/dialog.js +43 -0
  410. data/views/mdc/assets/js/components/events/encode.js +8 -0
  411. data/views/mdc/assets/js/components/events/errors.js +225 -0
  412. data/views/mdc/assets/js/components/events/loads.js +62 -0
  413. data/views/mdc/assets/js/components/events/navigates.js +19 -0
  414. data/views/mdc/assets/js/components/events/plugin.js +18 -0
  415. data/views/mdc/assets/js/components/events/post_message.js +21 -0
  416. data/views/mdc/assets/js/components/events/posts.js +222 -0
  417. data/views/mdc/assets/js/components/events/prompt_if_dirty.js +67 -0
  418. data/views/mdc/assets/js/components/events/removes.js +21 -0
  419. data/views/mdc/assets/js/components/events/replaces.js +135 -0
  420. data/views/mdc/assets/js/components/events/snackbar.js +23 -0
  421. data/views/mdc/assets/js/components/events/stepper.js +21 -0
  422. data/views/mdc/assets/js/components/events/toggle_disabled.js +41 -0
  423. data/views/mdc/assets/js/components/events/toggle_visibility.js +72 -0
  424. data/views/mdc/assets/js/components/file-inputs.js +76 -0
  425. data/views/mdc/assets/js/components/form-fields.js +16 -0
  426. data/views/mdc/assets/js/components/forms.js +14 -0
  427. data/views/mdc/assets/js/components/get_event_target.js +15 -0
  428. data/views/mdc/assets/js/components/grid.js +21 -0
  429. data/views/mdc/assets/js/components/header.js +20 -0
  430. data/views/mdc/assets/js/components/hidden-fields.js +44 -0
  431. data/views/mdc/assets/js/components/icon-toggles.js +14 -0
  432. data/views/mdc/assets/js/components/images.js +19 -0
  433. data/views/mdc/assets/js/components/initialize.js +82 -0
  434. data/views/mdc/assets/js/components/lists.js +92 -0
  435. data/views/mdc/assets/js/components/menus.js +79 -0
  436. data/views/mdc/assets/js/components/mixins/dirtyable.js +22 -0
  437. data/views/mdc/assets/js/components/mixins/event-handler.js +13 -0
  438. data/views/mdc/assets/js/components/mixins/visibility-observer.js +35 -0
  439. data/views/mdc/assets/js/components/multi-select.js +75 -0
  440. data/views/mdc/assets/js/components/plugins.js +86 -0
  441. data/views/mdc/assets/js/components/progress.js +31 -0
  442. data/views/mdc/assets/js/components/radios.js +14 -0
  443. data/views/mdc/assets/js/components/rich-text-area.js +227 -0
  444. data/views/mdc/assets/js/components/rich-text-area/horizontal-rule-blot.js +23 -0
  445. data/views/mdc/assets/js/components/root_document.js +5 -0
  446. data/views/mdc/assets/js/components/selects.js +56 -0
  447. data/views/mdc/assets/js/components/sliders.js +67 -0
  448. data/views/mdc/assets/js/components/snackbar.js +26 -0
  449. data/views/mdc/assets/js/components/steppers.js +48 -0
  450. data/views/mdc/assets/js/components/switches.js +14 -0
  451. data/views/mdc/assets/js/components/tab-bars.js +28 -0
  452. data/views/mdc/assets/js/components/text-fields.js +157 -0
  453. data/views/mdc/assets/js/components/tooltip.js +17 -0
  454. data/views/mdc/assets/js/components/typography.js +28 -0
  455. data/views/mdc/assets/js/components/uninitialize.js +7 -0
  456. data/views/mdc/assets/js/config.js +27 -0
  457. data/views/mdc/assets/js/mdl-stepper.js +1108 -0
  458. data/views/mdc/assets/js/utils/compatibility.js +9 -0
  459. data/views/mdc/assets/js/utils/config.js +73 -0
  460. data/views/mdc/assets/js/utils/config.test.js +59 -0
  461. data/views/mdc/assets/js/utils/form-data.js +12 -0
  462. data/views/mdc/assets/js/utils/urls.js +57 -0
  463. data/views/mdc/assets/js/wc.js +111 -0
  464. data/views/mdc/assets/scss/app.scss +47 -0
  465. data/views/mdc/assets/scss/components/avatar.scss +85 -0
  466. data/views/mdc/assets/scss/components/button.scss +76 -0
  467. data/views/mdc/assets/scss/components/card.scss +60 -0
  468. data/views/mdc/assets/scss/components/checkbox.scss +1 -0
  469. data/views/mdc/assets/scss/components/chip.scss +34 -0
  470. data/views/mdc/assets/scss/components/content.scss +36 -0
  471. data/views/mdc/assets/scss/components/data-table.scss +91 -0
  472. data/views/mdc/assets/scss/components/datetime.scss +29 -0
  473. data/views/mdc/assets/scss/components/dialog.scss +8 -0
  474. data/views/mdc/assets/scss/components/drag_n_drop.scss +17 -0
  475. data/views/mdc/assets/scss/components/drawer.scss +82 -0
  476. data/views/mdc/assets/scss/components/expansion-panel.scss +153 -0
  477. data/views/mdc/assets/scss/components/fab.scss +27 -0
  478. data/views/mdc/assets/scss/components/file-input.scss +18 -0
  479. data/views/mdc/assets/scss/components/grid.scss +81 -0
  480. data/views/mdc/assets/scss/components/header.scss +21 -0
  481. data/views/mdc/assets/scss/components/icon-button-toggles.scss +2 -0
  482. data/views/mdc/assets/scss/components/icon.scss +57 -0
  483. data/views/mdc/assets/scss/components/image-list.scss +18 -0
  484. data/views/mdc/assets/scss/components/image.scss +22 -0
  485. data/views/mdc/assets/scss/components/list.scss +43 -0
  486. data/views/mdc/assets/scss/components/menu.scss +28 -0
  487. data/views/mdc/assets/scss/components/multi-select.scss +44 -0
  488. data/views/mdc/assets/scss/components/progress.scss +1 -0
  489. data/views/mdc/assets/scss/components/radio.scss +4 -0
  490. data/views/mdc/assets/scss/components/rich-text-area.scss +73 -0
  491. data/views/mdc/assets/scss/components/select.scss +23 -0
  492. data/views/mdc/assets/scss/components/separator.scss +3 -0
  493. data/views/mdc/assets/scss/components/slider.scss +1 -0
  494. data/views/mdc/assets/scss/components/snackbar.scss +5 -0
  495. data/views/mdc/assets/scss/components/stepper.scss +235 -0
  496. data/views/mdc/assets/scss/components/switch.scss +15 -0
  497. data/views/mdc/assets/scss/components/tab-bars.scss +4 -0
  498. data/views/mdc/assets/scss/components/textfield.scss +19 -0
  499. data/views/mdc/assets/scss/components/tooltip.scss +3 -0
  500. data/views/mdc/assets/scss/components/typography.scss +35 -0
  501. data/views/mdc/assets/scss/components/unordered-lists.scss +17 -0
  502. data/views/mdc/assets/scss/components/vendor/quill.snow.css +945 -0
  503. data/views/mdc/assets/scss/material.blue_grey-orange.min.css +8 -0
  504. data/views/mdc/assets/scss/media.scss +39 -0
  505. data/views/mdc/assets/scss/palette.scss +16 -0
  506. data/views/mdc/assets/scss/styles.scss +54 -0
  507. data/views/mdc/assets/scss/theme.scss +78 -0
  508. data/views/mdc/body/_dismissable-drawer.erb +34 -0
  509. data/views/mdc/body/_footer.erb +1 -0
  510. data/views/mdc/body/_header.erb +39 -0
  511. data/views/mdc/body/_modal-drawer.erb +35 -0
  512. data/views/mdc/body/_postamble.erb +17 -0
  513. data/views/mdc/body/_preamble.erb +26 -0
  514. data/views/mdc/body/_snackbar.erb +16 -0
  515. data/views/mdc/body/drawer/_divider.erb +1 -0
  516. data/views/mdc/body/drawer/_item.erb +13 -0
  517. data/views/mdc/body/drawer/_label.erb +1 -0
  518. data/views/mdc/body/drawers/_menu.erb +25 -0
  519. data/views/mdc/body/footers/_large.erb +27 -0
  520. data/views/mdc/body/footers/_menu_item.erb +6 -0
  521. data/views/mdc/body/footers/_small.erb +14 -0
  522. data/views/mdc/components/_avatar.erb +31 -0
  523. data/views/mdc/components/_badge.erb +2 -0
  524. data/views/mdc/components/_body.erb +2 -0
  525. data/views/mdc/components/_button.erb +28 -0
  526. data/views/mdc/components/_caption.erb +2 -0
  527. data/views/mdc/components/_card.erb +71 -0
  528. data/views/mdc/components/_checkbox.erb +34 -0
  529. data/views/mdc/components/_chip.erb +56 -0
  530. data/views/mdc/components/_chipset.erb +17 -0
  531. data/views/mdc/components/_content.erb +36 -0
  532. data/views/mdc/components/_date.erb +1 -0
  533. data/views/mdc/components/_datetime.erb +33 -0
  534. data/views/mdc/components/_dialog.erb +50 -0
  535. data/views/mdc/components/_event.erb +12 -0
  536. data/views/mdc/components/_expansion_panel.erb +13 -0
  537. data/views/mdc/components/_file_input.erb +17 -0
  538. data/views/mdc/components/_form.erb +14 -0
  539. data/views/mdc/components/_grid.erb +43 -0
  540. data/views/mdc/components/_headline.erb +4 -0
  541. data/views/mdc/components/_hidden_field.erb +5 -0
  542. data/views/mdc/components/_icon.erb +35 -0
  543. data/views/mdc/components/_icon_toggle.erb +16 -0
  544. data/views/mdc/components/_image.erb +25 -0
  545. data/views/mdc/components/_image_list.erb +38 -0
  546. data/views/mdc/components/_link.erb +4 -0
  547. data/views/mdc/components/_list.erb +20 -0
  548. data/views/mdc/components/_menu.erb +45 -0
  549. data/views/mdc/components/_multi_select.erb +33 -0
  550. data/views/mdc/components/_number_field.erb +38 -0
  551. data/views/mdc/components/_overline.erb +2 -0
  552. data/views/mdc/components/_page_title.erb +4 -0
  553. data/views/mdc/components/_progress.erb +11 -0
  554. data/views/mdc/components/_radio_button.erb +20 -0
  555. data/views/mdc/components/_render.erb +3 -0
  556. data/views/mdc/components/_rich_text_area.erb +22 -0
  557. data/views/mdc/components/_select.erb +43 -0
  558. data/views/mdc/components/_separator.erb +3 -0
  559. data/views/mdc/components/_slider.erb +43 -0
  560. data/views/mdc/components/_snackbar.erb +13 -0
  561. data/views/mdc/components/_stepper.erb +47 -0
  562. data/views/mdc/components/_subtitle.erb +4 -0
  563. data/views/mdc/components/_switch.erb +29 -0
  564. data/views/mdc/components/_tab_bar.erb +35 -0
  565. data/views/mdc/components/_table.erb +28 -0
  566. data/views/mdc/components/_text_area.erb +18 -0
  567. data/views/mdc/components/_text_field.erb +39 -0
  568. data/views/mdc/components/_time.erb +1 -0
  569. data/views/mdc/components/_tooltip.erb +5 -0
  570. data/views/mdc/components/_typography.erb +15 -0
  571. data/views/mdc/components/_unordered_list.erb +10 -0
  572. data/views/mdc/components/actions/autocomplete.rb +8 -0
  573. data/views/mdc/components/actions/clear.rb +11 -0
  574. data/views/mdc/components/actions/close_dialog.rb +10 -0
  575. data/views/mdc/components/actions/delete.rb +11 -0
  576. data/views/mdc/components/actions/dialog.rb +11 -0
  577. data/views/mdc/components/actions/loads.rb +17 -0
  578. data/views/mdc/components/actions/navigates.rb +11 -0
  579. data/views/mdc/components/actions/post.rb +14 -0
  580. data/views/mdc/components/actions/post_message.rb +10 -0
  581. data/views/mdc/components/actions/prompt_if_dirty.rb +17 -0
  582. data/views/mdc/components/actions/remove.rb +10 -0
  583. data/views/mdc/components/actions/replaces.rb +16 -0
  584. data/views/mdc/components/actions/resolver.rb +39 -0
  585. data/views/mdc/components/actions/snackbar.rb +12 -0
  586. data/views/mdc/components/actions/stepper.rb +10 -0
  587. data/views/mdc/components/actions/toggle_disabled.rb +10 -0
  588. data/views/mdc/components/actions/toggle_visibility.rb +10 -0
  589. data/views/mdc/components/actions/update.rb +10 -0
  590. data/views/mdc/components/buttons/_button.erb +27 -0
  591. data/views/mdc/components/buttons/_fab.erb +23 -0
  592. data/views/mdc/components/buttons/_icon.erb +24 -0
  593. data/views/mdc/components/buttons/_image.erb +25 -0
  594. data/views/mdc/components/list/_actions.erb +6 -0
  595. data/views/mdc/components/list/_avatar.erb +6 -0
  596. data/views/mdc/components/list/_checkbox.erb +5 -0
  597. data/views/mdc/components/list/_header.erb +37 -0
  598. data/views/mdc/components/list/_hidden_field.erb +3 -0
  599. data/views/mdc/components/list/_icon.erb +6 -0
  600. data/views/mdc/components/list/_info.erb +1 -0
  601. data/views/mdc/components/list/_line.erb +45 -0
  602. data/views/mdc/components/list/_menu.erb +28 -0
  603. data/views/mdc/components/list/_separator.erb +1 -0
  604. data/views/mdc/components/list/actions/_button.erb +1 -0
  605. data/views/mdc/components/list/actions/_checkbox.erb +1 -0
  606. data/views/mdc/components/list/actions/_icon.erb +1 -0
  607. data/views/mdc/components/list/actions/_icon_toggle.erb +1 -0
  608. data/views/mdc/components/list/actions/_radio_button.erb +1 -0
  609. data/views/mdc/components/list/actions/_switch.erb +1 -0
  610. data/views/mdc/components/shared/_hint_error_display.erb +9 -0
  611. data/views/mdc/components/shared/_input_label.erb +7 -0
  612. data/views/mdc/components/stepper/_step.erb +33 -0
  613. data/views/mdc/components/table/_checkbox.erb +20 -0
  614. data/views/mdc/components/table/_column.erb +18 -0
  615. data/views/mdc/components/table/_footer.erb +8 -0
  616. data/views/mdc/components/table/_header.erb +17 -0
  617. data/views/mdc/components/table/_pagination.erb +11 -0
  618. data/views/mdc/components/table/_row.erb +16 -0
  619. data/views/mdc/components/unordered_list/_icon.erb +2 -0
  620. data/views/mdc/components/unordered_list/_list_item.erb +7 -0
  621. data/views/mdc/init-depends.sh +2 -0
  622. data/views/mdc/layout.erb +18 -0
  623. data/views/mdc/package-lock.json +16461 -0
  624. data/views/mdc/package.json +76 -0
  625. data/views/mdc/web.erb +5 -0
  626. data/views/mdc/webpack.config.js +60 -0
  627. metadata +914 -19
  628. data/.rspec +0 -3
  629. data/.rubocop.yml +0 -10
  630. data/CODE_OF_CONDUCT.md +0 -84
  631. data/lib/coprl/version.rb +0 -5
@@ -1,6 +1,6 @@
1
- The MIT License (MIT)
1
+ MIT License
2
2
 
3
- Copyright (c) 2021 Russell Edens
3
+ Copyright (c) 2018 Russell Edens
4
4
 
5
5
  Permission is hereby granted, free of charge, to any person obtaining a copy
6
6
  of this software and associated documentation files (the "Software"), to deal
@@ -9,13 +9,13 @@ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
9
  copies of the Software, and to permit persons to whom the Software is
10
10
  furnished to do so, subject to the following conditions:
11
11
 
12
- The above copyright notice and this permission notice shall be included in
13
- all copies or substantial portions of the Software.
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
14
 
15
15
  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
16
  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
17
  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
18
  AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
19
  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
21
- THE SOFTWARE.
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
data/Procfile ADDED
@@ -0,0 +1 @@
1
+ web: rackup -p $PORT
data/README.md CHANGED
@@ -1,43 +1,150 @@
1
- # Coprl
1
+ # COmmon PResenter Language (COPRL)
2
2
 
3
- Welcome to your new gem! In this directory, you'll find the files you need to be able to package up your Ruby library into a gem. Put your Ruby code in the file `lib/coprl`. To experiment with that code, run `bin/console` for an interactive prompt.
3
+ ![alt text](https://media.giphy.com/media/13LEyaRbQbiWdi/giphy.gif "Power Washer for Building User Interfaces")
4
4
 
5
- TODO: Delete this and the text above, and describe your gem
5
+ ## TLDR;
6
+ Do you wish you could write a modern user interface in Ruby?
6
7
 
7
- ## Installation
8
+ Now you can. Presenters are a Ruby DSL for rendering user interfaces.
8
9
 
9
- Add this line to your application's Gemfile:
10
+ * Presenters are a power washer for building user interfaces
11
+ * Presenters are to HTML/User Interfaces what C is to assembly
12
+ * A presenter generates a Presenter Object Model (POM)
13
+ * A POM fully describes a user interface
14
+ * A POM client can fully render user interface from POM
10
15
 
11
- ```ruby
12
- gem 'coprl'
13
- ```
16
+ The semantics are adopted from [Material Design](https://material.io/).
14
17
 
15
- And then execute:
18
+ ## Why?
16
19
 
17
- $ bundle install
20
+ Building a user interface should like Ruby itself:
21
+ > ... a focus on simplicity and productivity. It has an elegant syntax that is natural to read and easy to write.
18
22
 
19
- Or install it yourself as:
23
+ Instead building a user interface has turned into:
24
+ > How many languages/technologies/frameworks do I need to learn to build a rich user interface/experience?"
20
25
 
21
- $ gem install coprl
26
+ A typical web client requires at a minimum the following: HTML, CSS, Javascript, in addition we need Ruby on the server, plus some SQL.
27
+ That is 5 technologies/languages.
28
+ Now lets talk about a new client like an iOS or Android client. If we go native, we can now add Java and Swift to that list. We are up to 7 technologies/languages!
29
+ We didn't even add any popular extras like coffeescript, haml, sass, and we left out frameworks.
22
30
 
31
+ What if you could write all your user interface in Ruby and have it rendered natively in ANY client? The COPRL _enable_ that. It is a Ruby DSL that describes a user interface.
32
+ It generates an intermediate Presenter Object Model (POM).
33
+ The POM is a declarative user interface that can be rendered by a POM client.
34
+ The presenters gem provides a web client as a fully functional implementation that both renders natively as a Rails templating engine and as a Rack app.
35
+
36
+ This concept was initially inspired by the Presenters concepts of Ivar Jacobson as presented by Robert Martin.
37
+
38
+ ## Demo
39
+
40
+ [Demo]
41
+
42
+ Or to run locally:
43
+
44
+ git clone git@github.com:rx/presenters.git
45
+ cd presenters/
46
+ bundle install
47
+ bundle exec rackup
48
+
49
+ open http://localhost:9292
50
+
51
+ > Note: Demo defaults to Ruby version 2.7.3 in the .ruby-version file. If you want to run a different version
52
+ > -- set RBENV_VERSION to your desired version.
53
+ > For example:
54
+ > ```
55
+ > RBENV_VERSION=2.5.5 bundle insatall
56
+ > RBENV_VERSION=2.5.5 bundle exec rackup```
57
+
58
+ To see the POM:
59
+
60
+ open http://localhost:9292/index.pom
61
+
23
62
  ## Usage
24
63
 
25
- TODO: Write usage instructions here
64
+ ### Rails
65
+ Presenters are a view templating language in Rails.
66
+ You can mix and match presenters with your existing views,
67
+ use them as new views, or call them as partials in existing views.
68
+
69
+ #### 1) Add presenters to Gemfile
70
+ gem 'coprl'
71
+
72
+ #### 2) Require coprl in config/application.rb
73
+ require 'coprl'
74
+
75
+ #### 3) Mount presenters in config/routes.rb
76
+
77
+ mount Coprl::Presenters::Rails::Engine => "/"
78
+
79
+ #### 4) Create the file app/view/hello_world.html.pom with the contents
80
+
81
+ Coprl::Presenters.define(:hello_world) do
82
+ heading 'hello world'
83
+ end
84
+
85
+ Navigate to [locahost:3000/hello_world](http://127.0.0.1:3000/hello_world)
86
+
87
+ Use the [Demo] to get example code to drop into your presenters.
88
+
89
+ #### Optional — Setting the root route
90
+ If you name a presenter :index and want the root of the app to serve up that presenter add the following to your `config/initializers/routes.rb`
26
91
 
27
- ## Development
92
+ root 'coprl#show'
28
93
 
29
- After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake spec` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
94
+ #### Optionally use presenters as partials from ERB/HAML
95
+ You can render a presenter as a partial from other templating laguages (erb, haml):
30
96
 
31
- To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and the created tag, and push the `.gem` file to [rubygems.org](https://rubygems.org).
97
+ <%= render 'show', presenter: 'hello_world' %>
98
+
99
+ You need to add the following to your layout to use presenters as a partial alongside other erb's, haml or any other rails templating language.
100
+
101
+ ##### Inside the &lt;head&gt; tag add the following:
102
+
103
+ <title><%= @pom.page.title if @pom.page %></title>
104
+ <%= coprl_headers(@base_url, request, @pom) %>
105
+
106
+ ##### Inside the &lt;body&gt; tag, around you existing yield add the following:
107
+
108
+ <%= partial "body/preamble", :locals => {pom:@pom} %>
109
+ <%= yield %>
110
+ <%= partial "body/postamble", :locals => {pom:@pom} %>
111
+
112
+ ### Rack
113
+ #### 1) To use it, add this line to your Gemfile:
114
+
115
+ gem 'coprl'
116
+
117
+ #### 2) Create the file app/presenters/index.pom with the contents:
118
+
119
+ Coprl::Presenters.define(:hello_world) do
120
+ heading 'hello world'
121
+ end
122
+
123
+ Presenters are rack based. If your framework uses a rack config file add the following:
124
+ use Coprl::Presenters::WebClient::App
125
+ # the api is optional
126
+ # use Coprl::Presenters::Api::App
127
+
128
+ Start your app and goto [/hello_world](http://127.0.0.1:3000/hello_world)
129
+
130
+ Use the [Demo] to get example code to drop into your presenters.
131
+
132
+ ## Status
133
+ This project is in a released status.
134
+
135
+ [![CircleCI](https://circleci.com/gh/rx/presenters.svg?style=svg)](https://circleci.com/gh/rx/presenters)
136
+ [![License](https://img.shields.io/badge/license-MIT-blue.svg?style=plastic)](https://raw.githubusercontent.com/rx/presenters/master/LICENSE)
32
137
 
33
138
  ## Contributing
34
139
 
35
- Bug reports and pull requests are welcome on GitHub at https://github.com/[USERNAME]/coprl. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the [code of conduct](https://github.com/[USERNAME]/coprl/blob/master/CODE_OF_CONDUCT.md).
140
+ Bug reports and pull requests are welcome on GitHub at https://github.com/rx/presenters.
36
141
 
37
142
  ## License
38
143
 
39
- The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).
144
+ The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).
40
145
 
41
146
  ## Code of Conduct
42
147
 
43
- Everyone interacting in the Coprl project's codebases, issue trackers, chat rooms and mailing lists is expected to follow the [code of conduct](https://github.com/[USERNAME]/coprl/blob/master/CODE_OF_CONDUCT.md).
148
+ Everyone interacting in the COPRL projects codebases, issue trackers, chat rooms and mailing lists is expected to follow the [code of conduct](https://github.com/coprl/coprl/blob/master/CODE-OF-CONDUCT.md).
149
+
150
+ [Demo]:https://coprl-ruby.herokuapp.com/
data/ROADMAP.md ADDED
@@ -0,0 +1,6 @@
1
+ # Coprl::Presenters Roadmap
2
+
3
+ This is the roadmap for the presenters. It outlines the development direction.
4
+
5
+ ## Web-Client
6
+ * Conversion to MDC for existing MDL components
data/Rakefile CHANGED
@@ -1,12 +1,6 @@
1
- # frozen_string_literal: true
2
-
3
- require "bundler/gem_tasks"
4
- require "rspec/core/rake_task"
1
+ require 'bundler/gem_tasks'
2
+ require 'rspec/core/rake_task'
5
3
 
6
4
  RSpec::Core::RakeTask.new(:spec)
7
5
 
8
- require "rubocop/rake_task"
9
-
10
- RuboCop::RakeTask.new
11
-
12
- task default: %i[spec rubocop]
6
+ task default: :spec
@@ -0,0 +1,19 @@
1
+ require_relative 'helpers/indented_grid'
2
+
3
+ Coprl::Presenters.define('components') do
4
+ helpers Demo::Helpers::IndentedGrid
5
+ attach 'top_nav'
6
+ attach 'component_drawer'
7
+ page_title 'Components'
8
+
9
+ indented_grid do
10
+ grid do
11
+ column 12 do
12
+ icon 'fa-hand-point-left', position: :left
13
+ subheading 'Select a component'
14
+ end
15
+ end
16
+ end
17
+ attach :code, file: __FILE__
18
+
19
+ end
@@ -0,0 +1,40 @@
1
+ Coprl::Presenters.define(:avatars) do
2
+ attach :top_nav
3
+ attach :component_drawer
4
+ page_title 'Avatars'
5
+
6
+ grid do
7
+ column 1
8
+ column 10 do
9
+ body 'An avatar can contain an image or icon. Avatars can be used within a list line, the media section of a card, a content block or column.'
10
+
11
+ grid do
12
+ column 6 do
13
+ headline 'Types'
14
+ body '**With an Icon**'
15
+ avatar :thumb_up
16
+ body '**With an Image**'
17
+ avatar 'img/demo/grace-hopper-headshot.png'
18
+ end
19
+ end
20
+
21
+ grid do
22
+ column 6 do
23
+ headline 'Sizes'
24
+ body '**small**'
25
+ avatar :person, size: :small
26
+ body '**medium** (default)'
27
+ avatar 'img/demo/grace-hopper-headshot.png', size: :medium
28
+ body '**large**'
29
+ avatar :cake, size: :large
30
+ body '**x-large**'
31
+ avatar :golf_course, size: 'x-large'
32
+ body '**xx-large**'
33
+ avatar 'img/demo/grace-hopper-headshot.png', size: 'xx-large'
34
+ end
35
+ end
36
+
37
+ end
38
+ end
39
+
40
+ end
@@ -0,0 +1,26 @@
1
+ require_relative '../helpers/indented_grid'
2
+
3
+ Coprl::Presenters.define(:badges) do
4
+ helpers Demo::Helpers::IndentedGrid
5
+
6
+ attach :top_nav
7
+ attach :component_drawer
8
+ page_title 'Badges'
9
+ indented_grid do
10
+
11
+
12
+ headline 'Number'
13
+ badge 1, icon: :account_box
14
+
15
+ headline 'Icon'
16
+ badge '♥', icon: :account_box
17
+
18
+ headline 'Number'
19
+ badge 1, text: 'Inbox'
20
+
21
+ headline 'Icon'
22
+ badge '♥', text: 'Mood'
23
+
24
+ attach :code, file: __FILE__
25
+ end
26
+ end
@@ -0,0 +1,63 @@
1
+ require_relative '../helpers/indented_grid'
2
+
3
+ Coprl::Presenters.define(:buttons) do
4
+ helpers Demo::Helpers::IndentedGrid
5
+ attach :top_nav
6
+ attach :component_drawer
7
+ page_title 'Buttons'
8
+
9
+ indented_grid do
10
+
11
+
12
+ # Raised buttons
13
+ headline 'Raised Button'
14
+ button 'Button', type: :raised
15
+
16
+ subheading 'Disabled'
17
+ button 'Button', type: :raised, disabled: true
18
+
19
+ subheading ' Accent colored'
20
+ button 'Button', type: :raised, color: :secondary
21
+
22
+ headline 'Flat button'
23
+ button 'Button'
24
+
25
+ subheading 'Disabled'
26
+ button 'Button', type: :flat, disabled: true
27
+
28
+ subheading 'Accent colored flat'
29
+ button 'Button', type: :flat, color: :secondary
30
+
31
+ subheading 'Aligned'
32
+ grid do
33
+ column 3 do
34
+ button 'Not Aligned'
35
+ button 'Right', position: :right
36
+ button 'Left', position: :left
37
+ end
38
+ end
39
+
40
+ # Icon Buttons
41
+ headline 'Icon button'
42
+ button icon: :mood
43
+ subheading 'Colored'
44
+ button icon: :mood, color: :primary
45
+ button icon: :mood, color: :secondary
46
+
47
+ subheading 'with text'
48
+ button "I'm happy", icon: :mood
49
+
50
+ headline 'Image button'
51
+ button type: :image do
52
+ image 'img/demo/grace-hopper-wide.png'
53
+ end
54
+
55
+ subheading 'with icon'
56
+ button type: :image do
57
+ image 'img/demo/grace-hopper-wide.png'
58
+ icon :link
59
+ end
60
+
61
+ attach :code, file: __FILE__
62
+ end
63
+ end
@@ -0,0 +1,84 @@
1
+ require_relative '../helpers/indented_grid'
2
+
3
+ Coprl::Presenters.define(:cards) do
4
+ helpers Demo::Helpers::IndentedGrid
5
+ attach :top_nav
6
+ attach :component_drawer
7
+ page_title 'Cards'
8
+
9
+ indented_grid do
10
+ headline 'Wide'
11
+ card width: '512px' do
12
+ media do
13
+ image 'img/demo/welcome_card.jpg', width: 512, height: 176
14
+ title 'Welcome', color: :white, position: :bottom
15
+ button icon: :share_icon, color: :white do
16
+ menu do
17
+ item 'Share with mom'
18
+ end
19
+ end
20
+ end
21
+ text "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Mauris sagittis pellentesque lacus eleifend lacinia... "
22
+
23
+ actions do
24
+ button 'Get Started', color: :primary
25
+ end
26
+ end
27
+
28
+ blank
29
+ headline 'Square', inline: true
30
+ switch checked: true do
31
+ tooltip 'Hide/Show Square Card'
32
+ event :click do
33
+ toggle_visibility 'square_card'
34
+ end
35
+ end
36
+ card id: 'square_card', width: '330px' do
37
+ media height: '200px', color: '#46B6AC' do
38
+ image 'img/demo/dog.png', position: [:bottom, :right]
39
+ title 'Update', color: :white, position: :bottom
40
+ end
41
+ text "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Aenan convallis."
42
+
43
+ actions do
44
+ button 'View Updates', color: :primary
45
+ end
46
+ end
47
+
48
+ headline 'Image'
49
+ card width: '330px' do
50
+ media do
51
+ image 'img/demo/image_card.jpg', width: 330, height: 330
52
+ title 'image.jpg', position: :bottom, color: :white
53
+ end
54
+ end
55
+
56
+ headline 'Event'
57
+ card width: '330px' do
58
+ media height: '230px', color: :MidnightBlue do
59
+ title ['Featured event:',
60
+ "May 24, 2016",
61
+ "7-11pm"],
62
+ color: :white, position: :top
63
+ end
64
+ actions do
65
+ button 'Add to Calendar', color: :secondary
66
+ button icon: :event, color: :secondary
67
+ end
68
+ end
69
+
70
+ #
71
+ # headline 'Example'
72
+ # card width: '21rem', height: '42rem' do
73
+ # title ['Auckland Sky Tower',
74
+ # 'Auckland, New Zealand'] do
75
+ # background 'https://www.askideas.com/media/43/The-Sky-Tower-In-Auckland-New-Zealand.jpg'
76
+ # end
77
+ # text ["The Sky Tower is an observation and telecommunications tower located in Auckland,",
78
+ # "New Zealand. It is 328 metres (1,076 ft) tall, making it the tallest man-made structure",
79
+ # "in the Southern Hemisphere."].join(' ')
80
+ # end
81
+
82
+ attach :code, file: __FILE__
83
+ end
84
+ end