matestack-ui-core 0.7.6 → 1.2.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (298) hide show
  1. checksums.yaml +4 -4
  2. data/LICENSE +8 -0
  3. data/README.md +695 -121
  4. data/app/concepts/matestack/ui/core/abbr/abbr.haml +3 -3
  5. data/app/concepts/matestack/ui/core/abbr/abbr.rb +1 -8
  6. data/app/concepts/matestack/ui/core/action/action.haml +1 -1
  7. data/app/concepts/matestack/ui/core/action/action.rb +23 -19
  8. data/app/concepts/matestack/ui/core/actionview/dynamic.haml +4 -4
  9. data/app/concepts/matestack/ui/core/address/address.haml +3 -3
  10. data/app/concepts/matestack/ui/core/address/address.rb +1 -1
  11. data/app/concepts/matestack/ui/core/app/app.haml +2 -3
  12. data/app/concepts/matestack/ui/core/app/app.js +4 -1
  13. data/app/concepts/matestack/ui/core/app/app.rb +32 -56
  14. data/app/concepts/matestack/ui/core/app/store.js +27 -1
  15. data/app/concepts/matestack/ui/core/area/area.haml +1 -1
  16. data/app/concepts/matestack/ui/core/area/area.rb +2 -14
  17. data/app/concepts/matestack/ui/core/article/article.haml +3 -3
  18. data/app/concepts/matestack/ui/core/article/article.rb +1 -1
  19. data/app/concepts/matestack/ui/core/aside/aside.haml +1 -1
  20. data/app/concepts/matestack/ui/core/aside/aside.rb +0 -1
  21. data/app/concepts/matestack/ui/core/async/async.haml +6 -2
  22. data/app/concepts/matestack/ui/core/async/async.js +43 -31
  23. data/app/concepts/matestack/ui/core/async/async.rb +29 -4
  24. data/app/concepts/matestack/ui/core/async/children_wrapper.haml +2 -0
  25. data/app/concepts/matestack/ui/core/b/b.haml +3 -3
  26. data/app/concepts/matestack/ui/core/b/b.rb +1 -1
  27. data/app/concepts/matestack/ui/core/bdi/bdi.haml +3 -3
  28. data/app/concepts/matestack/ui/core/bdi/bdi.rb +1 -0
  29. data/app/concepts/matestack/ui/core/bdo/bdo.haml +3 -3
  30. data/app/concepts/matestack/ui/core/bdo/bdo.rb +2 -7
  31. data/app/concepts/matestack/ui/core/blockquote/blockquote.haml +3 -3
  32. data/app/concepts/matestack/ui/core/blockquote/blockquote.rb +2 -7
  33. data/app/concepts/matestack/ui/core/br/br.haml +4 -4
  34. data/app/concepts/matestack/ui/core/br/br.rb +1 -1
  35. data/app/concepts/matestack/ui/core/button/button.haml +3 -3
  36. data/app/concepts/matestack/ui/core/button/button.rb +3 -7
  37. data/app/concepts/matestack/ui/core/cable/cable.haml +4 -0
  38. data/app/concepts/matestack/ui/core/cable/cable.js +100 -0
  39. data/app/concepts/matestack/ui/core/cable/cable.rb +28 -0
  40. data/app/concepts/matestack/ui/core/cable/children_wrapper.haml +2 -0
  41. data/app/concepts/matestack/ui/core/caption/caption.haml +3 -3
  42. data/app/concepts/matestack/ui/core/caption/caption.rb +1 -1
  43. data/app/concepts/matestack/ui/core/cite/cite.haml +3 -3
  44. data/app/concepts/matestack/ui/core/cite/cite.rb +1 -1
  45. data/app/concepts/matestack/ui/core/code/code.haml +3 -3
  46. data/app/concepts/matestack/ui/core/code/code.rb +1 -1
  47. data/app/concepts/matestack/ui/core/collection/content/content.js +2 -2
  48. data/app/concepts/matestack/ui/core/collection/content/content.rb +4 -6
  49. data/app/concepts/matestack/ui/core/collection/content/next/next.haml +1 -1
  50. data/app/concepts/matestack/ui/core/collection/content/page/link/link.haml +1 -1
  51. data/app/concepts/matestack/ui/core/collection/content/page/link/link.rb +5 -3
  52. data/app/concepts/matestack/ui/core/collection/content/previous/previous.haml +1 -1
  53. data/app/concepts/matestack/ui/core/collection/filter/filter.rb +4 -5
  54. data/app/concepts/matestack/ui/core/collection/filter/input/input.rb +11 -8
  55. data/app/concepts/matestack/ui/core/collection/filter/reset/reset.haml +1 -1
  56. data/app/concepts/matestack/ui/core/collection/filter/select/select.haml +10 -0
  57. data/app/concepts/matestack/ui/core/collection/filter/select/select.rb +30 -0
  58. data/app/concepts/matestack/ui/core/collection/filter/submit/submit.haml +1 -1
  59. data/app/concepts/matestack/ui/core/collection/helper.rb +14 -6
  60. data/app/concepts/matestack/ui/core/collection/order/order.js +1 -1
  61. data/app/concepts/matestack/ui/core/collection/order/order.rb +4 -5
  62. data/app/concepts/matestack/ui/core/collection/order/toggle/indicator/indicator.rb +9 -5
  63. data/app/concepts/matestack/ui/core/collection/order/toggle/toggle.haml +1 -1
  64. data/app/concepts/matestack/ui/core/collection/order/toggle/toggle.rb +0 -1
  65. data/app/concepts/matestack/ui/core/component/base.rb +430 -0
  66. data/app/concepts/matestack/ui/core/component/children.haml +2 -2
  67. data/app/concepts/matestack/ui/core/component/component.js +9 -46
  68. data/app/concepts/matestack/ui/core/component/dynamic.haml +1 -1
  69. data/app/concepts/matestack/ui/core/component/dynamic.rb +25 -247
  70. data/app/concepts/matestack/ui/core/component/static.rb +3 -12
  71. data/app/concepts/matestack/ui/core/data/data.haml +3 -3
  72. data/app/concepts/matestack/ui/core/data/data.rb +2 -5
  73. data/app/concepts/matestack/ui/core/datalist/datalist.haml +2 -2
  74. data/app/concepts/matestack/ui/core/datalist/datalist.rb +1 -2
  75. data/app/concepts/matestack/ui/core/dd/dd.haml +3 -3
  76. data/app/concepts/matestack/ui/core/dd/dd.rb +1 -1
  77. data/app/concepts/matestack/ui/core/del/del.haml +3 -3
  78. data/app/concepts/matestack/ui/core/del/del.rb +2 -0
  79. data/app/concepts/matestack/ui/core/details/details.haml +1 -1
  80. data/app/concepts/matestack/ui/core/details/details.rb +1 -1
  81. data/app/concepts/matestack/ui/core/dfn/dfn.haml +3 -3
  82. data/app/concepts/matestack/ui/core/dfn/dfn.rb +1 -1
  83. data/app/concepts/matestack/ui/core/dialog/dialog.haml +3 -3
  84. data/app/concepts/matestack/ui/core/dialog/dialog.rb +2 -5
  85. data/app/concepts/matestack/ui/core/div/div.haml +1 -1
  86. data/app/concepts/matestack/ui/core/div/div.rb +0 -1
  87. data/app/concepts/matestack/ui/core/dl/dl.haml +3 -3
  88. data/app/concepts/matestack/ui/core/dl/dl.rb +2 -2
  89. data/app/concepts/matestack/ui/core/dt/dt.haml +3 -3
  90. data/app/concepts/matestack/ui/core/dt/dt.rb +1 -1
  91. data/app/concepts/matestack/ui/core/em/em.haml +3 -3
  92. data/app/concepts/matestack/ui/core/em/em.rb +1 -1
  93. data/app/concepts/matestack/ui/core/fieldset/fieldset.haml +4 -4
  94. data/app/concepts/matestack/ui/core/fieldset/fieldset.rb +3 -6
  95. data/app/concepts/matestack/ui/core/figure/figure.haml +1 -1
  96. data/app/concepts/matestack/ui/core/figure/figure.rb +0 -1
  97. data/app/concepts/matestack/ui/core/footer/footer.haml +1 -1
  98. data/app/concepts/matestack/ui/core/footer/footer.rb +0 -1
  99. data/app/concepts/matestack/ui/core/form/checkbox/checkbox.rb +79 -0
  100. data/app/concepts/matestack/ui/core/form/form.haml +1 -1
  101. data/app/concepts/matestack/ui/core/form/form.js +25 -20
  102. data/app/concepts/matestack/ui/core/form/form.rb +35 -24
  103. data/app/concepts/matestack/ui/core/form/has_errors.rb +54 -0
  104. data/app/concepts/matestack/ui/core/form/has_input_html_attributes.rb +13 -0
  105. data/app/concepts/matestack/ui/core/form/input/input.rb +32 -52
  106. data/app/concepts/matestack/ui/core/form/radio/radio.rb +71 -0
  107. data/app/concepts/matestack/ui/core/form/select/select.haml +9 -80
  108. data/app/concepts/matestack/ui/core/form/select/select.rb +41 -56
  109. data/app/concepts/matestack/ui/core/form/submit/submit.haml +1 -1
  110. data/app/concepts/matestack/ui/core/form/submit/submit.rb +5 -2
  111. data/app/concepts/matestack/ui/core/form/textarea/textarea.rb +28 -0
  112. data/app/concepts/matestack/ui/core/form/utils.rb +47 -0
  113. data/app/concepts/matestack/ui/core/header/header.haml +1 -1
  114. data/app/concepts/matestack/ui/core/header/header.rb +0 -1
  115. data/app/concepts/matestack/ui/core/heading/heading.haml +4 -49
  116. data/app/concepts/matestack/ui/core/heading/heading.rb +1 -1
  117. data/app/concepts/matestack/ui/core/hr/hr.haml +1 -1
  118. data/app/concepts/matestack/ui/core/hr/hr.rb +0 -1
  119. data/app/concepts/matestack/ui/core/icon/icon.haml +3 -3
  120. data/app/concepts/matestack/ui/core/icon/icon.rb +1 -1
  121. data/app/concepts/matestack/ui/core/iframe/iframe.haml +3 -3
  122. data/app/concepts/matestack/ui/core/iframe/iframe.rb +3 -10
  123. data/app/concepts/matestack/ui/core/img/img.haml +1 -1
  124. data/app/concepts/matestack/ui/core/img/img.rb +8 -8
  125. data/app/concepts/matestack/ui/core/input/input.haml +1 -2
  126. data/app/concepts/matestack/ui/core/input/input.rb +4 -4
  127. data/app/concepts/matestack/ui/core/ins/ins.haml +3 -3
  128. data/app/concepts/matestack/ui/core/ins/ins.rb +2 -6
  129. data/app/concepts/matestack/ui/core/isolated/children_wrapper.haml +2 -0
  130. data/app/concepts/matestack/ui/core/isolated/isolated.haml +10 -0
  131. data/app/concepts/matestack/ui/core/isolated/isolated.js +108 -0
  132. data/app/concepts/matestack/ui/core/isolated/isolated.rb +59 -0
  133. data/app/concepts/matestack/ui/core/js/core.js +6 -4
  134. data/app/concepts/matestack/ui/core/kbd/kbd.haml +3 -3
  135. data/app/concepts/matestack/ui/core/kbd/kbd.rb +1 -0
  136. data/app/concepts/matestack/ui/core/label/label.haml +3 -3
  137. data/app/concepts/matestack/ui/core/label/label.rb +2 -6
  138. data/app/concepts/matestack/ui/core/legend/legend.haml +3 -3
  139. data/app/concepts/matestack/ui/core/legend/legend.rb +1 -1
  140. data/app/concepts/matestack/ui/core/li/li.haml +3 -3
  141. data/app/concepts/matestack/ui/core/li/li.rb +2 -1
  142. data/app/concepts/matestack/ui/core/link/link.haml +3 -3
  143. data/app/concepts/matestack/ui/core/link/link.rb +10 -14
  144. data/app/concepts/matestack/ui/core/main/main.haml +1 -1
  145. data/app/concepts/matestack/ui/core/main/main.rb +0 -1
  146. data/app/concepts/matestack/ui/core/map/map.haml +1 -1
  147. data/app/concepts/matestack/ui/core/map/map.rb +1 -7
  148. data/app/concepts/matestack/ui/core/mark/mark.haml +3 -3
  149. data/app/concepts/matestack/ui/core/mark/mark.rb +1 -0
  150. data/app/concepts/matestack/ui/core/meter/meter.haml +1 -1
  151. data/app/concepts/matestack/ui/core/meter/meter.rb +1 -10
  152. data/app/concepts/matestack/ui/core/nav/nav.haml +1 -1
  153. data/app/concepts/matestack/ui/core/nav/nav.rb +0 -1
  154. data/app/concepts/matestack/ui/core/noscript/noscript.haml +3 -3
  155. data/app/concepts/matestack/ui/core/noscript/noscript.rb +1 -1
  156. data/app/concepts/matestack/ui/core/object/object.haml +1 -1
  157. data/app/concepts/matestack/ui/core/object/object.rb +1 -11
  158. data/app/concepts/matestack/ui/core/ol/ol.haml +1 -1
  159. data/app/concepts/matestack/ui/core/ol/ol.rb +1 -1
  160. data/app/concepts/matestack/ui/core/onclick/onclick.haml +1 -1
  161. data/app/concepts/matestack/ui/core/onclick/onclick.rb +1 -0
  162. data/app/concepts/matestack/ui/core/optgroup/optgroup.haml +1 -1
  163. data/app/concepts/matestack/ui/core/optgroup/optgroup.rb +1 -6
  164. data/app/concepts/matestack/ui/core/option/option.haml +3 -3
  165. data/app/concepts/matestack/ui/core/option/option.rb +2 -8
  166. data/app/concepts/matestack/ui/core/output/output.haml +3 -3
  167. data/app/concepts/matestack/ui/core/output/output.rb +2 -7
  168. data/app/concepts/matestack/ui/core/page/{content.js → content/content.js} +8 -2
  169. data/app/concepts/matestack/ui/core/page/content/content.rb +28 -0
  170. data/app/concepts/matestack/ui/core/page/page.haml +3 -9
  171. data/app/concepts/matestack/ui/core/page/page.rb +15 -179
  172. data/app/concepts/matestack/ui/core/paragraph/paragraph.haml +3 -3
  173. data/app/concepts/matestack/ui/core/paragraph/paragraph.rb +1 -1
  174. data/app/concepts/matestack/ui/core/param/param.haml +1 -1
  175. data/app/concepts/matestack/ui/core/param/param.rb +1 -6
  176. data/app/concepts/matestack/ui/core/partial/partial.rb +0 -1
  177. data/app/concepts/matestack/ui/core/picture/picture.haml +1 -1
  178. data/app/concepts/matestack/ui/core/pre/pre.haml +3 -3
  179. data/app/concepts/matestack/ui/core/pre/pre.rb +1 -1
  180. data/app/concepts/matestack/ui/core/progress/progress.haml +1 -1
  181. data/app/concepts/matestack/ui/core/progress/progress.rb +1 -10
  182. data/app/concepts/matestack/ui/core/q/q.haml +3 -3
  183. data/app/concepts/matestack/ui/core/q/q.rb +2 -7
  184. data/app/concepts/matestack/ui/core/rp/rp.haml +3 -3
  185. data/app/concepts/matestack/ui/core/rp/rp.rb +1 -1
  186. data/app/concepts/matestack/ui/core/rt/rt.haml +3 -3
  187. data/app/concepts/matestack/ui/core/rt/rt.rb +1 -1
  188. data/app/concepts/matestack/ui/core/ruby/ruby.haml +3 -3
  189. data/app/concepts/matestack/ui/core/ruby/ruby.rb +1 -1
  190. data/app/concepts/matestack/ui/core/s/s.haml +3 -3
  191. data/app/concepts/matestack/ui/core/s/s.rb +1 -1
  192. data/app/concepts/matestack/ui/core/samp/samp.haml +3 -3
  193. data/app/concepts/matestack/ui/core/samp/samp.rb +1 -0
  194. data/app/concepts/matestack/ui/core/section/section.haml +1 -1
  195. data/app/concepts/matestack/ui/core/section/section.rb +0 -1
  196. data/app/concepts/matestack/ui/core/slot/slot.rb +1 -2
  197. data/app/concepts/matestack/ui/core/small/small.haml +3 -3
  198. data/app/concepts/matestack/ui/core/small/small.rb +1 -1
  199. data/app/concepts/matestack/ui/core/span/span.haml +3 -3
  200. data/app/concepts/matestack/ui/core/span/span.rb +1 -1
  201. data/app/concepts/matestack/ui/core/strong/strong.haml +3 -3
  202. data/app/concepts/matestack/ui/core/strong/strong.rb +1 -1
  203. data/app/concepts/matestack/ui/core/sub/sub.haml +3 -3
  204. data/app/concepts/matestack/ui/core/sub/sub.rb +1 -1
  205. data/app/concepts/matestack/ui/core/summary/summary.haml +3 -3
  206. data/app/concepts/matestack/ui/core/summary/summary.rb +1 -1
  207. data/app/concepts/matestack/ui/core/sup/sup.haml +3 -3
  208. data/app/concepts/matestack/ui/core/sup/sup.rb +1 -1
  209. data/app/concepts/matestack/ui/core/table/table.haml +1 -1
  210. data/app/concepts/matestack/ui/core/table/table.rb +0 -1
  211. data/app/concepts/matestack/ui/core/tbody/tbody.haml +1 -1
  212. data/app/concepts/matestack/ui/core/tbody/tbody.rb +0 -1
  213. data/app/concepts/matestack/ui/core/td/td.haml +3 -3
  214. data/app/concepts/matestack/ui/core/td/td.rb +2 -1
  215. data/app/concepts/matestack/ui/core/template/template.haml +1 -1
  216. data/app/concepts/matestack/ui/core/textarea/textarea.haml +5 -0
  217. data/app/concepts/matestack/ui/core/textarea/textarea.rb +10 -0
  218. data/app/concepts/matestack/ui/core/tfoot/tfoot.haml +1 -1
  219. data/app/concepts/matestack/ui/core/tfoot/tfoot.rb +0 -1
  220. data/app/concepts/matestack/ui/core/th/th.haml +3 -3
  221. data/app/concepts/matestack/ui/core/th/th.rb +2 -1
  222. data/app/concepts/matestack/ui/core/thead/thead.haml +1 -1
  223. data/app/concepts/matestack/ui/core/thead/thead.rb +0 -1
  224. data/app/concepts/matestack/ui/core/time/time.haml +1 -1
  225. data/app/concepts/matestack/ui/core/time/time.rb +1 -7
  226. data/app/concepts/matestack/ui/core/toggle/toggle.haml +2 -0
  227. data/app/concepts/matestack/ui/core/toggle/toggle.js +71 -0
  228. data/app/concepts/matestack/ui/core/toggle/toggle.rb +13 -0
  229. data/app/concepts/matestack/ui/core/tr/tr.haml +1 -1
  230. data/app/concepts/matestack/ui/core/tr/tr.rb +0 -1
  231. data/app/concepts/matestack/ui/core/transition/transition.haml +3 -3
  232. data/app/concepts/matestack/ui/core/transition/transition.js +1 -0
  233. data/app/concepts/matestack/ui/core/transition/transition.rb +14 -7
  234. data/app/concepts/matestack/ui/core/u/u.haml +3 -3
  235. data/app/concepts/matestack/ui/core/u/u.rb +1 -1
  236. data/app/concepts/matestack/ui/core/ul/ul.haml +1 -1
  237. data/app/concepts/matestack/ui/core/ul/ul.rb +0 -1
  238. data/app/concepts/matestack/ui/core/unescaped/unescaped.rb +3 -1
  239. data/app/concepts/matestack/ui/core/var/var.haml +3 -3
  240. data/app/concepts/matestack/ui/core/var/var.rb +1 -0
  241. data/app/concepts/matestack/ui/core/video/video.haml +2 -2
  242. data/app/concepts/matestack/ui/core/video/video.rb +4 -14
  243. data/app/concepts/matestack/ui/core/view/view.haml +1 -0
  244. data/app/concepts/matestack/ui/core/view/view.rb +30 -0
  245. data/app/concepts/matestack/ui/core/wbr/wbr.haml +5 -1
  246. data/app/concepts/matestack/ui/core/wbr/wbr.rb +1 -0
  247. data/app/concepts/matestack/ui/core/youtube/youtube.haml +1 -1
  248. data/app/concepts/matestack/ui/core/youtube/youtube.rb +18 -16
  249. data/app/helpers/matestack/ui/core/application_helper.rb +94 -21
  250. data/app/lib/matestack/ui/component.rb +1 -0
  251. data/app/lib/matestack/ui/core/has_view_context.rb +6 -4
  252. data/app/lib/matestack/ui/core/html_attributes.rb +43 -0
  253. data/app/lib/matestack/ui/core/properties.rb +161 -0
  254. data/app/lib/matestack/ui/core/rendering/default_renderer_class_determiner.rb +33 -0
  255. data/app/lib/matestack/ui/core/rendering/main_renderer.rb +203 -0
  256. data/app/lib/matestack/ui/isolated_component.rb +1 -0
  257. data/app/lib/matestack/ui/vue_js_component.rb +1 -0
  258. data/lib/matestack/ui/core.rb +4 -2
  259. data/lib/matestack/ui/core/cell.rb +0 -2
  260. data/lib/matestack/ui/core/component/registry.rb +47 -0
  261. data/lib/matestack/ui/core/components.rb +269 -0
  262. data/lib/matestack/ui/core/dsl.rb +6 -0
  263. data/lib/matestack/ui/core/engine.rb +16 -0
  264. data/lib/matestack/ui/core/version.rb +1 -1
  265. data/vendor/assets/javascripts/dist/matestack-ui-core.js +467 -142
  266. data/vendor/assets/javascripts/dist/matestack-ui-core.js.map +1 -1
  267. data/vendor/assets/javascripts/dist/matestack-ui-core.min.js +1 -1
  268. data/vendor/assets/javascripts/dist/matestack-ui-core.min.js.br +0 -0
  269. data/vendor/assets/javascripts/dist/matestack-ui-core.min.js.gz +0 -0
  270. data/vendor/assets/javascripts/dist/matestack-ui-core.min.js.map +1 -1
  271. data/vendor/assets/javascripts/dist/matestack-ui-core.min.js.map.br +0 -0
  272. data/vendor/assets/javascripts/dist/matestack-ui-core.min.js.map.gz +0 -0
  273. metadata +50 -63
  274. data/MIT-LICENSE +0 -20
  275. data/app/concepts/matestack/ui/core/absolute/absolute.haml +0 -3
  276. data/app/concepts/matestack/ui/core/absolute/absolute.rb +0 -17
  277. data/app/concepts/matestack/ui/core/collection/filter/input/input.haml +0 -2
  278. data/app/concepts/matestack/ui/core/component/response.haml +0 -2
  279. data/app/concepts/matestack/ui/core/component/response_dynamic.haml +0 -7
  280. data/app/concepts/matestack/ui/core/component/response_dynamic_without_rerender.haml +0 -3
  281. data/app/concepts/matestack/ui/core/component/static.haml +0 -1
  282. data/app/concepts/matestack/ui/core/form/inline/inline.haml +0 -6
  283. data/app/concepts/matestack/ui/core/form/inline/inline.rb +0 -9
  284. data/app/concepts/matestack/ui/core/form/input/input.haml +0 -46
  285. data/app/concepts/matestack/ui/core/html/html.haml +0 -3
  286. data/app/concepts/matestack/ui/core/html/html.js +0 -10
  287. data/app/concepts/matestack/ui/core/html/html.rb +0 -17
  288. data/app/concepts/matestack/ui/core/isolate/isolate.haml +0 -2
  289. data/app/concepts/matestack/ui/core/isolate/isolate.rb +0 -11
  290. data/app/concepts/matestack/ui/core/page/content.haml +0 -7
  291. data/app/concepts/matestack/ui/core/page/content.rb +0 -5
  292. data/app/concepts/matestack/ui/core/pg/pg.haml +0 -5
  293. data/app/concepts/matestack/ui/core/pg/pg.rb +0 -5
  294. data/app/lib/matestack/ui/core/app_node.rb +0 -53
  295. data/app/lib/matestack/ui/core/component_node.rb +0 -87
  296. data/app/lib/matestack/ui/core/page_node.rb +0 -100
  297. data/app/lib/matestack/ui/core/render.rb +0 -89
  298. data/app/lib/matestack/ui/core/to_cell.rb +0 -129
@@ -1,5 +1,5 @@
1
- %del{@tag_attributes.merge({:cite => options[:cite], :datetime => options[:datetime]})}
2
- - if options[:text].nil? && block_given?
1
+ %del{ html_attributes }
2
+ - if text.nil? && block_given?
3
3
  = yield
4
4
  - else
5
- = options[:text]
5
+ = text
@@ -1,4 +1,6 @@
1
1
  module Matestack::Ui::Core::Del
2
2
  class Del < Matestack::Ui::Core::Component::Static
3
+ html_attributes :cite, :datetime
4
+ optional :text
3
5
  end
4
6
  end
@@ -1,3 +1,3 @@
1
- %details{@tag_attributes}
1
+ %details{ html_attributes }
2
2
  - if block_given?
3
3
  = yield
@@ -1,5 +1,5 @@
1
1
  module Matestack::Ui::Core::Details
2
2
  class Details < Matestack::Ui::Core::Component::Static
3
-
3
+ html_attributes :open
4
4
  end
5
5
  end
@@ -1,5 +1,5 @@
1
- %dfn{@tag_attributes}
2
- - if options[:text].nil? && block_given?
1
+ %dfn{ html_attributes }
2
+ - if text.nil? && block_given?
3
3
  = yield
4
4
  - else
5
- = options[:text]
5
+ = text
@@ -1,6 +1,6 @@
1
1
  module Matestack::Ui::Core::Dfn
2
2
  class Dfn < Matestack::Ui::Core::Component::Static
3
-
3
+ optional :text
4
4
  end
5
5
  end
6
6
 
@@ -1,5 +1,5 @@
1
- %dialog{@tag_attributes}
2
- - if options[:text].blank? && block_given?
1
+ %dialog{ html_attributes }
2
+ - if text.nil? && block_given?
3
3
  = yield
4
4
  - else
5
- = options[:text]
5
+ = text
@@ -1,9 +1,6 @@
1
1
  module Matestack::Ui::Core::Dialog
2
2
  class Dialog < Matestack::Ui::Core::Component::Static
3
- def setup
4
- @tag_attributes.merge!({
5
- "open": options[:open] ||= nil
6
- })
7
- end
3
+ html_attributes :open
4
+ optional :text
8
5
  end
9
6
  end
@@ -1,3 +1,3 @@
1
- %div{@tag_attributes}
1
+ %div{ html_attributes }
2
2
  - if block_given?
3
3
  = yield
@@ -1,5 +1,4 @@
1
1
  module Matestack::Ui::Core::Div
2
2
  class Div < Matestack::Ui::Core::Component::Static
3
-
4
3
  end
5
4
  end
@@ -1,5 +1,5 @@
1
- %dl{@tag_attributes}
2
- - if options[:text].nil? && block_given?
1
+ %dl{ html_attributes }
2
+ - if text.nil? && block_given?
3
3
  = yield
4
4
  - else
5
- = options[:text]
5
+ = text
@@ -1,5 +1,5 @@
1
1
  module Matestack::Ui::Core::Dl
2
2
  class Dl < Matestack::Ui::Core::Component::Static
3
-
3
+ optional :text
4
4
  end
5
- end
5
+ end
@@ -1,5 +1,5 @@
1
- %dt{@tag_attributes}
2
- - if options[:text].nil? && block_given?
1
+ %dt{ html_attributes }
2
+ - if text.nil? && block_given?
3
3
  = yield
4
4
  - else
5
- = options[:text]
5
+ = text
@@ -1,5 +1,5 @@
1
1
  module Matestack::Ui::Core::Dt
2
2
  class Dt < Matestack::Ui::Core::Component::Static
3
-
3
+ optional :text
4
4
  end
5
5
  end
@@ -1,5 +1,5 @@
1
- %em{@tag_attributes}
2
- - if options[:text].nil? && block_given?
1
+ %em{ html_attributes }
2
+ - if text.nil? && block_given?
3
3
  = yield
4
4
  - else
5
- = options[:text]
5
+ = text
@@ -1,5 +1,5 @@
1
1
  module Matestack::Ui::Core::Em
2
2
  class Em < Matestack::Ui::Core::Component::Static
3
-
3
+ optional :text
4
4
  end
5
5
  end
@@ -1,5 +1,5 @@
1
- %fieldset{@tag_attributes}
2
- -if options[:text].nil? && block_given?
1
+ %fieldset{ html_attributes }
2
+ - if text.nil? && block_given?
3
3
  = yield
4
- - else
5
- = options[:text]
4
+ - else
5
+ = text
@@ -1,9 +1,6 @@
1
1
  module Matestack::Ui::Core::Fieldset
2
2
  class Fieldset < Matestack::Ui::Core::Component::Static
3
- def setup
4
- @tag_attributes.merge!({
5
- disabled: options[:disabled]
6
- })
7
- end
3
+ html_attributes :disabled, :form, :name
4
+ optional :text
8
5
  end
9
- end
6
+ end
@@ -1,3 +1,3 @@
1
- %figure{@tag_attributes}
1
+ %figure{ html_attributes }
2
2
  - if block_given?
3
3
  = yield
@@ -1,5 +1,4 @@
1
1
  module Matestack::Ui::Core::Figure
2
2
  class Figure < Matestack::Ui::Core::Component::Static
3
-
4
3
  end
5
4
  end
@@ -1,3 +1,3 @@
1
- %footer{@tag_attributes}
1
+ %footer{ html_attributes }
2
2
  - if block_given?
3
3
  = yield
@@ -1,5 +1,4 @@
1
1
  module Matestack::Ui::Core::Footer
2
2
  class Footer < Matestack::Ui::Core::Component::Static
3
-
4
3
  end
5
4
  end
@@ -0,0 +1,79 @@
1
+ require_relative '../utils'
2
+ require_relative '../has_input_html_attributes'
3
+ require_relative '../has_errors'
4
+ module Matestack::Ui::Core::Form::Checkbox
5
+ class Checkbox < Matestack::Ui::Core::Component::Static
6
+ include Matestack::Ui::Core::Form::Utils
7
+ include Matestack::Ui::Core::Form::HasInputHtmlAttributes
8
+ include Matestack::Ui::Core::Form::HasErrors
9
+
10
+ requires :key
11
+ optional :value, :false_value, :multiple, :init, for: { as: :input_for }, label: { as: :input_label }, options: { as: :checkbox_options }
12
+
13
+ def response
14
+ # multiple values
15
+ if checkbox_options
16
+ checkbox_options.to_a.each do |item|
17
+ input html_attributes.merge(
18
+ attributes: vue_attributes,
19
+ type: :checkbox,
20
+ id: "#{id_for_item(item_value(item))}",
21
+ name: item_name(item),
22
+ value: item_value(item)
23
+ )
24
+ label text: item_name(item), for: id_for_item(item_value(item))
25
+ end
26
+ # checked/unchecked checkbox
27
+ else
28
+ form_input type: :hidden, key: key, value: (false_value || 0), errors: false
29
+ form_input type: :checkbox, key: key, value: checked_value, id: id_for_item(value), errors: false
30
+ label text: input_label, for: id_for_item(value)
31
+ end
32
+ render_errors
33
+ end
34
+
35
+ def vue_attributes
36
+ (options[:attributes] || {}).merge({
37
+ "@change": change_event,
38
+ ref: "select.multiple.#{attr_key}",
39
+ 'init-value': init_value,
40
+ 'v-bind:class': "{ '#{input_error_class}': #{error_key} }",
41
+ 'value-type': value_type,
42
+ "#{v_model_type}": input_key,
43
+ })
44
+ end
45
+
46
+ def value_type
47
+ item_value(checkbox_options.first).is_a?(Integer) ? Integer : nil
48
+ end
49
+
50
+ def item_value(item)
51
+ item.is_a?(Array) ? item.last : item
52
+ end
53
+
54
+ def item_name(item)
55
+ item.is_a?(Array) ? item.first : item
56
+ end
57
+
58
+ def checked_value
59
+ value || 1
60
+ end
61
+
62
+ def v_model_type
63
+ if checkbox_options && checkbox_options.first.is_a?(Integer)
64
+ 'v-model.number'
65
+ else
66
+ 'v-model'
67
+ end
68
+ end
69
+
70
+ def change_event
71
+ "inputChanged('#{attr_key}')"
72
+ end
73
+
74
+ def id_for_item(value)
75
+ "#{html_attributes[:id]}_#{value}"
76
+ end
77
+
78
+ end
79
+ end
@@ -1,2 +1,2 @@
1
- %form{@tag_attributes}
1
+ %form{ form_attributes }
2
2
  = yield
@@ -10,8 +10,8 @@ const componentDef = {
10
10
  data: function () {
11
11
  return {
12
12
  data: {},
13
- showInlineForm: false,
14
13
  errors: {},
14
+ loading: false
15
15
  };
16
16
  },
17
17
  methods: {
@@ -24,22 +24,20 @@ const componentDef = {
24
24
  updateFormValue: function (key, value) {
25
25
  this.data[key] = value;
26
26
  },
27
+ hasErrors: function(){
28
+ //https://stackoverflow.com/a/27709663/13886137
29
+ for (var key in this.errors) {
30
+ if (this.errors[key] !== null && this.errors[key] != ""){
31
+ return true;
32
+ }
33
+ }
34
+ return false;
35
+ },
27
36
  resetErrors: function (key) {
28
37
  if (this.errors[key]) {
29
38
  this.errors[key] = null;
30
39
  }
31
40
  },
32
- launchInlineForm: function (key, value) {
33
- this.showInlineForm = true;
34
- this.data[key] = value;
35
- const self = this;
36
- setTimeout(function () {
37
- self.$refs.inlineinput.focus();
38
- }, 300);
39
- },
40
- closeInlineForm: function () {
41
- this.showInlineForm = false;
42
- },
43
41
  setProps: function (flat, newVal) {
44
42
  for (var i in flat) {
45
43
  if (flat[i] === null){
@@ -126,15 +124,21 @@ const componentDef = {
126
124
  },
127
125
  perform: function(){
128
126
  const self = this
129
- if (self.componentConfig["emit"] != undefined) {
130
- matestackEventHub.$emit(self.componentConfig["emit"]);
131
- }
132
- if (self.componentConfig["delay"] != undefined) {
133
- setTimeout(function () {
127
+ var form = self.$el.tagName == 'FORM' ? self.$el : self.$el.querySelector('form');
128
+ if(form.checkValidity()){
129
+ self.loading = true;
130
+ if (self.componentConfig["emit"] != undefined) {
131
+ matestackEventHub.$emit(self.componentConfig["emit"]);
132
+ }
133
+ if (self.componentConfig["delay"] != undefined) {
134
+ setTimeout(function () {
135
+ self.sendRequest()
136
+ }, parseInt(self.componentConfig["delay"]));
137
+ } else {
134
138
  self.sendRequest()
135
- }, parseInt(self.componentConfig["delay"]));
139
+ }
136
140
  } else {
137
- this.sendRequest()
141
+ matestackEventHub.$emit('static_form_errors');
138
142
  }
139
143
  },
140
144
  sendRequest: function(){
@@ -178,6 +182,7 @@ const componentDef = {
178
182
  }
179
183
  axios(axios_config)
180
184
  .then(function (response) {
185
+ self.loading = false;
181
186
  if (self.componentConfig["success"] != undefined && self.componentConfig["success"]["emit"] != undefined) {
182
187
  matestackEventHub.$emit(self.componentConfig["success"]["emit"], response.data);
183
188
  }
@@ -233,9 +238,9 @@ const componentDef = {
233
238
  self.setProps(self.data, null);
234
239
  self.initValues();
235
240
  }
236
- self.showInlineForm = false;
237
241
  })
238
242
  .catch(function (error) {
243
+ self.loading = false;
239
244
  if (error.response && error.response.data && error.response.data.errors) {
240
245
  self.errors = error.response.data.errors;
241
246
  }
@@ -1,44 +1,55 @@
1
1
  module Matestack::Ui::Core::Form
2
2
  class Form < Matestack::Ui::Core::Component::Dynamic
3
+ vue_js_component_name "matestack-ui-core-form"
4
+
5
+ html_attributes :'accept-charset', :action, :autocomplete, :enctype, :method, :name, :novalidate, :rel, :target
3
6
 
4
- REQUIRED_KEYS = [:for, :path, :method]
7
+ requires :path, for: { as: :for_option }, method: { as: :form_method }
8
+ optional :success, :failure, :multipart, params: { as: :form_params }
5
9
 
6
10
  def setup
7
11
  begin
8
12
  @component_config[:for] = form_wrapper
9
13
  @component_config[:submit_path] = submit_path
10
- @component_config[:method] = options[:method]
11
- @component_config[:success] = options[:success]
12
- @component_config[:multipart] = options[:multipart] == true
13
- unless options[:success].nil?
14
- unless options[:success][:transition].nil?
15
- @component_config[:success][:transition][:path] = transition_path options[:success]
14
+ @component_config[:method] = form_method
15
+ @component_config[:success] = success
16
+ @component_config[:multipart] = multipart == true
17
+ unless success.nil?
18
+ unless success[:transition].nil?
19
+ @component_config[:success][:transition][:path] = transition_path success
16
20
  end
17
- unless options[:success][:redirect].nil?
18
- @component_config[:success][:redirect][:path] = redirect_path options[:success]
21
+ unless success[:redirect].nil?
22
+ @component_config[:success][:redirect][:path] = redirect_path success
19
23
  end
20
24
  end
21
- @component_config[:failure] = options[:failure]
22
- unless options[:failure].nil?
23
- unless options[:failure][:transition].nil?
24
- @component_config[:failure][:transition][:path] = transition_path options[:failure]
25
+ @component_config[:failure] = failure
26
+ unless failure.nil?
27
+ unless failure[:transition].nil?
28
+ @component_config[:failure][:transition][:path] = transition_path failure
25
29
  end
26
- unless options[:failure][:redirect].nil?
27
- @component_config[:failure][:redirect][:path] = redirect_path options[:failure]
30
+ unless failure[:redirect].nil?
31
+ @component_config[:failure][:redirect][:path] = redirect_path failure
28
32
  end
29
33
  end
30
- @tag_attributes.merge!({"@submit.prevent": true})
31
34
  rescue => e
32
35
  raise "Form component could not be setted up. Reason: #{e}"
33
36
  end
34
37
  end
35
38
 
39
+ def form_attributes
40
+ html_attributes.merge({
41
+ "@submit.prevent": true,
42
+ "class": "matestack-form #{options[:class]}",
43
+ "v-bind:class": "{ 'has-errors': hasErrors(), 'loading': loading }"
44
+ })
45
+ end
46
+
36
47
  def submit_path
37
48
  begin
38
- if options[:path].is_a?(Symbol)
39
- return ::Rails.application.routes.url_helpers.send(options[:path], options[:params])
49
+ if path.is_a?(Symbol)
50
+ return ::Rails.application.routes.url_helpers.send(path, form_params)
40
51
  else
41
- return options[:path]
52
+ return path
42
53
  end
43
54
  rescue
44
55
  raise "Submit path not found"
@@ -76,15 +87,15 @@ module Matestack::Ui::Core::Form
76
87
  end
77
88
 
78
89
  def form_wrapper
79
- case options[:for]
90
+ case for_option
80
91
  when Symbol
81
- return options[:for]
92
+ return for_option
82
93
  when String
83
- return options[:for]
94
+ return for_option
84
95
  end
85
96
 
86
- if options[:for].respond_to?(:model_name)
87
- return options[:for].model_name.singular
97
+ if for_option.respond_to?(:model_name)
98
+ return for_option.model_name.singular
88
99
  end
89
100
  end
90
101