matestack-ui-core 1.3.0 → 2.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (397) hide show
  1. checksums.yaml +4 -4
  2. data/LICENSE +17 -5
  3. data/README.md +98 -113
  4. data/Rakefile +0 -2
  5. data/lib/matestack/ui/app.rb +1 -0
  6. data/lib/matestack/ui/component.rb +1 -0
  7. data/lib/matestack/ui/core.rb +58 -10
  8. data/lib/matestack/ui/core/app.rb +36 -0
  9. data/lib/matestack/ui/core/base.rb +109 -0
  10. data/lib/matestack/ui/core/component.rb +8 -0
  11. data/lib/matestack/ui/core/context.rb +17 -0
  12. data/lib/matestack/ui/core/helper.rb +91 -0
  13. data/lib/matestack/ui/core/page.rb +63 -0
  14. data/lib/matestack/ui/core/properties.rb +105 -0
  15. data/lib/matestack/ui/core/slots.rb +15 -0
  16. data/lib/matestack/ui/core/tag_helper.rb +94 -0
  17. data/lib/matestack/ui/core/version.rb +1 -1
  18. data/lib/matestack/ui/core/vue_attributes.rb +13 -0
  19. data/lib/matestack/ui/page.rb +1 -0
  20. data/{app/concepts/matestack/ui/core → lib/matestack/ui/vue_js}/app/app.js +2 -3
  21. data/{app/concepts/matestack/ui/core → lib/matestack/ui/vue_js}/app/location.js +0 -0
  22. data/{app/concepts/matestack/ui/core → lib/matestack/ui/vue_js}/app/store.js +1 -1
  23. data/lib/matestack/ui/vue_js/components.rb +94 -0
  24. data/lib/matestack/ui/vue_js/components/action.js +151 -0
  25. data/lib/matestack/ui/vue_js/components/action.rb +46 -0
  26. data/{app/concepts/matestack/ui/core/async → lib/matestack/ui/vue_js/components}/async.js +22 -22
  27. data/lib/matestack/ui/vue_js/components/async.rb +84 -0
  28. data/{app/concepts/matestack/ui/core/cable → lib/matestack/ui/vue_js/components}/cable.js +14 -14
  29. data/lib/matestack/ui/vue_js/components/cable.rb +69 -0
  30. data/{app/concepts/matestack/ui/core/collection/content → lib/matestack/ui/vue_js/components/collection}/content.js +21 -22
  31. data/lib/matestack/ui/vue_js/components/collection/content.rb +32 -0
  32. data/lib/matestack/ui/vue_js/components/collection/filter.js +45 -0
  33. data/lib/matestack/ui/vue_js/components/collection/filter.rb +29 -0
  34. data/lib/matestack/ui/vue_js/components/collection/filter_reset.rb +19 -0
  35. data/{app/concepts/matestack/ui/core → lib/matestack/ui/vue_js/components}/collection/helper.rb +68 -61
  36. data/lib/matestack/ui/vue_js/components/collection/next.rb +19 -0
  37. data/lib/matestack/ui/vue_js/components/collection/order.js +46 -0
  38. data/lib/matestack/ui/vue_js/components/collection/order.rb +28 -0
  39. data/lib/matestack/ui/vue_js/components/collection/order_toggle.rb +21 -0
  40. data/lib/matestack/ui/vue_js/components/collection/order_toggle_indicator.rb +30 -0
  41. data/lib/matestack/ui/vue_js/components/collection/page.rb +21 -0
  42. data/lib/matestack/ui/vue_js/components/collection/previous.rb +19 -0
  43. data/lib/matestack/ui/vue_js/components/form/base.rb +167 -0
  44. data/{app/concepts/matestack/ui/core/form/checkbox → lib/matestack/ui/vue_js/components/form}/checkbox.js +2 -2
  45. data/lib/matestack/ui/vue_js/components/form/checkbox.rb +105 -0
  46. data/{app/concepts/matestack/ui/core/form/checkbox/mixin.js → lib/matestack/ui/vue_js/components/form/checkbox_mixin.js} +5 -2
  47. data/lib/matestack/ui/vue_js/components/form/context.rb +15 -0
  48. data/{app/concepts/matestack/ui/core → lib/matestack/ui/vue_js/components}/form/form.js +53 -53
  49. data/lib/matestack/ui/vue_js/components/form/form.rb +64 -0
  50. data/{app/concepts/matestack/ui/core/form/input → lib/matestack/ui/vue_js/components/form}/input.js +2 -2
  51. data/lib/matestack/ui/vue_js/components/form/input.rb +37 -0
  52. data/{app/concepts/matestack/ui/core/form/input/mixin.js → lib/matestack/ui/vue_js/components/form/input_mixin.js} +5 -2
  53. data/{app/concepts/matestack/ui/core/form/radio → lib/matestack/ui/vue_js/components/form}/radio.js +2 -2
  54. data/lib/matestack/ui/vue_js/components/form/radio.rb +76 -0
  55. data/{app/concepts/matestack/ui/core/form/radio/mixin.js → lib/matestack/ui/vue_js/components/form/radio_mixin.js} +4 -1
  56. data/{app/concepts/matestack/ui/core/form/select → lib/matestack/ui/vue_js/components/form}/select.js +2 -2
  57. data/lib/matestack/ui/vue_js/components/form/select.rb +88 -0
  58. data/{app/concepts/matestack/ui/core/form/select/mixin.js → lib/matestack/ui/vue_js/components/form/select_mixin.js} +5 -2
  59. data/{app/concepts/matestack/ui/core/form/textarea → lib/matestack/ui/vue_js/components/form}/textarea.js +2 -2
  60. data/lib/matestack/ui/vue_js/components/form/textarea.rb +37 -0
  61. data/{app/concepts/matestack/ui/core/form/textarea/mixin.js → lib/matestack/ui/vue_js/components/form/textarea_mixin.js} +5 -2
  62. data/{app/concepts/matestack/ui/core/isolated → lib/matestack/ui/vue_js/components}/isolated.js +19 -19
  63. data/lib/matestack/ui/vue_js/components/isolated.rb +86 -0
  64. data/{app/concepts/matestack/ui/core/component/component.js → lib/matestack/ui/vue_js/components/mixin.js} +2 -2
  65. data/{app/concepts/matestack/ui/core/onclick → lib/matestack/ui/vue_js/components}/onclick.js +3 -4
  66. data/lib/matestack/ui/vue_js/components/onclick.rb +37 -0
  67. data/{app/concepts/matestack/ui/core/toggle → lib/matestack/ui/vue_js/components}/toggle.js +17 -17
  68. data/lib/matestack/ui/vue_js/components/toggle.rb +38 -0
  69. data/{app/concepts/matestack/ui/core/transition → lib/matestack/ui/vue_js/components}/transition.js +6 -6
  70. data/lib/matestack/ui/vue_js/components/transition.rb +40 -0
  71. data/lib/matestack/ui/vue_js/event_hub.js +5 -0
  72. data/{app/concepts/matestack/ui/core/js/helpers/query-params-helper.js → lib/matestack/ui/vue_js/helpers/query_params_helper.js} +0 -0
  73. data/lib/matestack/ui/vue_js/index.js +52 -0
  74. data/lib/matestack/ui/vue_js/initialize.rb +5 -0
  75. data/{app/concepts/matestack/ui/core/page/content → lib/matestack/ui/vue_js/page}/content.js +1 -1
  76. data/lib/matestack/ui/vue_js/vue.rb +63 -0
  77. data/lib/matestack/ui/vue_js_component.rb +2 -0
  78. metadata +77 -408
  79. data/app/concepts/matestack/ui/core/abbr/abbr.haml +0 -5
  80. data/app/concepts/matestack/ui/core/abbr/abbr.rb +0 -5
  81. data/app/concepts/matestack/ui/core/action/action.haml +0 -3
  82. data/app/concepts/matestack/ui/core/action/action.js +0 -152
  83. data/app/concepts/matestack/ui/core/action/action.rb +0 -80
  84. data/app/concepts/matestack/ui/core/actionview/dynamic.haml +0 -6
  85. data/app/concepts/matestack/ui/core/actionview/dynamic.rb +0 -28
  86. data/app/concepts/matestack/ui/core/actionview/static.haml +0 -1
  87. data/app/concepts/matestack/ui/core/actionview/static.rb +0 -28
  88. data/app/concepts/matestack/ui/core/address/address.haml +0 -5
  89. data/app/concepts/matestack/ui/core/address/address.rb +0 -5
  90. data/app/concepts/matestack/ui/core/app/app.haml +0 -3
  91. data/app/concepts/matestack/ui/core/app/app.rb +0 -51
  92. data/app/concepts/matestack/ui/core/area/area.haml +0 -1
  93. data/app/concepts/matestack/ui/core/area/area.rb +0 -6
  94. data/app/concepts/matestack/ui/core/article/article.haml +0 -5
  95. data/app/concepts/matestack/ui/core/article/article.rb +0 -5
  96. data/app/concepts/matestack/ui/core/aside/aside.haml +0 -3
  97. data/app/concepts/matestack/ui/core/aside/aside.rb +0 -4
  98. data/app/concepts/matestack/ui/core/async/async.haml +0 -6
  99. data/app/concepts/matestack/ui/core/async/async.rb +0 -37
  100. data/app/concepts/matestack/ui/core/async/children_wrapper.haml +0 -2
  101. data/app/concepts/matestack/ui/core/b/b.haml +0 -5
  102. data/app/concepts/matestack/ui/core/b/b.rb +0 -5
  103. data/app/concepts/matestack/ui/core/bdi/bdi.haml +0 -5
  104. data/app/concepts/matestack/ui/core/bdi/bdi.rb +0 -5
  105. data/app/concepts/matestack/ui/core/bdo/bdo.haml +0 -5
  106. data/app/concepts/matestack/ui/core/bdo/bdo.rb +0 -6
  107. data/app/concepts/matestack/ui/core/blockquote/blockquote.haml +0 -5
  108. data/app/concepts/matestack/ui/core/blockquote/blockquote.rb +0 -6
  109. data/app/concepts/matestack/ui/core/br/br.haml +0 -5
  110. data/app/concepts/matestack/ui/core/br/br.rb +0 -5
  111. data/app/concepts/matestack/ui/core/button/button.haml +0 -5
  112. data/app/concepts/matestack/ui/core/button/button.rb +0 -7
  113. data/app/concepts/matestack/ui/core/cable/cable.haml +0 -4
  114. data/app/concepts/matestack/ui/core/cable/cable.rb +0 -28
  115. data/app/concepts/matestack/ui/core/cable/children_wrapper.haml +0 -2
  116. data/app/concepts/matestack/ui/core/caption/caption.haml +0 -5
  117. data/app/concepts/matestack/ui/core/caption/caption.rb +0 -5
  118. data/app/concepts/matestack/ui/core/cite/cite.haml +0 -5
  119. data/app/concepts/matestack/ui/core/cite/cite.rb +0 -5
  120. data/app/concepts/matestack/ui/core/code/code.haml +0 -5
  121. data/app/concepts/matestack/ui/core/code/code.rb +0 -5
  122. data/app/concepts/matestack/ui/core/collection/content/content.rb +0 -16
  123. data/app/concepts/matestack/ui/core/collection/content/next/next.haml +0 -3
  124. data/app/concepts/matestack/ui/core/collection/content/next/next.rb +0 -5
  125. data/app/concepts/matestack/ui/core/collection/content/page/link/link.haml +0 -3
  126. data/app/concepts/matestack/ui/core/collection/content/page/link/link.rb +0 -7
  127. data/app/concepts/matestack/ui/core/collection/content/previous/previous.haml +0 -3
  128. data/app/concepts/matestack/ui/core/collection/content/previous/previous.rb +0 -5
  129. data/app/concepts/matestack/ui/core/collection/filter/filter.js +0 -48
  130. data/app/concepts/matestack/ui/core/collection/filter/filter.rb +0 -16
  131. data/app/concepts/matestack/ui/core/collection/filter/input/input.rb +0 -28
  132. data/app/concepts/matestack/ui/core/collection/filter/reset/reset.haml +0 -3
  133. data/app/concepts/matestack/ui/core/collection/filter/reset/reset.rb +0 -5
  134. data/app/concepts/matestack/ui/core/collection/filter/select/select.haml +0 -10
  135. data/app/concepts/matestack/ui/core/collection/filter/select/select.rb +0 -30
  136. data/app/concepts/matestack/ui/core/collection/filter/submit/submit.haml +0 -3
  137. data/app/concepts/matestack/ui/core/collection/filter/submit/submit.rb +0 -5
  138. data/app/concepts/matestack/ui/core/collection/order/order.js +0 -56
  139. data/app/concepts/matestack/ui/core/collection/order/order.rb +0 -16
  140. data/app/concepts/matestack/ui/core/collection/order/toggle/indicator/indicator.rb +0 -17
  141. data/app/concepts/matestack/ui/core/collection/order/toggle/toggle.haml +0 -3
  142. data/app/concepts/matestack/ui/core/collection/order/toggle/toggle.rb +0 -4
  143. data/app/concepts/matestack/ui/core/component/anonym-dynamic-component.js +0 -10
  144. data/app/concepts/matestack/ui/core/component/base.rb +0 -430
  145. data/app/concepts/matestack/ui/core/component/children.haml +0 -2
  146. data/app/concepts/matestack/ui/core/component/dynamic.haml +0 -6
  147. data/app/concepts/matestack/ui/core/component/dynamic.rb +0 -47
  148. data/app/concepts/matestack/ui/core/component/dynamic_without_rerender.haml +0 -2
  149. data/app/concepts/matestack/ui/core/component/static.rb +0 -7
  150. data/app/concepts/matestack/ui/core/data/data.haml +0 -5
  151. data/app/concepts/matestack/ui/core/data/data.rb +0 -6
  152. data/app/concepts/matestack/ui/core/datalist/datalist.haml +0 -3
  153. data/app/concepts/matestack/ui/core/datalist/datalist.rb +0 -4
  154. data/app/concepts/matestack/ui/core/dd/dd.haml +0 -5
  155. data/app/concepts/matestack/ui/core/dd/dd.rb +0 -5
  156. data/app/concepts/matestack/ui/core/del/del.haml +0 -5
  157. data/app/concepts/matestack/ui/core/del/del.rb +0 -6
  158. data/app/concepts/matestack/ui/core/details/details.haml +0 -3
  159. data/app/concepts/matestack/ui/core/details/details.rb +0 -5
  160. data/app/concepts/matestack/ui/core/dfn/dfn.haml +0 -5
  161. data/app/concepts/matestack/ui/core/dfn/dfn.rb +0 -6
  162. data/app/concepts/matestack/ui/core/dialog/dialog.haml +0 -5
  163. data/app/concepts/matestack/ui/core/dialog/dialog.rb +0 -6
  164. data/app/concepts/matestack/ui/core/div/div.haml +0 -3
  165. data/app/concepts/matestack/ui/core/div/div.rb +0 -4
  166. data/app/concepts/matestack/ui/core/dl/dl.haml +0 -5
  167. data/app/concepts/matestack/ui/core/dl/dl.rb +0 -5
  168. data/app/concepts/matestack/ui/core/dt/dt.haml +0 -5
  169. data/app/concepts/matestack/ui/core/dt/dt.rb +0 -5
  170. data/app/concepts/matestack/ui/core/em/em.haml +0 -5
  171. data/app/concepts/matestack/ui/core/em/em.rb +0 -5
  172. data/app/concepts/matestack/ui/core/fieldset/fieldset.haml +0 -5
  173. data/app/concepts/matestack/ui/core/fieldset/fieldset.rb +0 -6
  174. data/app/concepts/matestack/ui/core/figure/figure.haml +0 -3
  175. data/app/concepts/matestack/ui/core/figure/figure.rb +0 -4
  176. data/app/concepts/matestack/ui/core/footer/footer.haml +0 -3
  177. data/app/concepts/matestack/ui/core/footer/footer.rb +0 -4
  178. data/app/concepts/matestack/ui/core/form/checkbox/base.rb +0 -120
  179. data/app/concepts/matestack/ui/core/form/checkbox/checkbox.rb +0 -16
  180. data/app/concepts/matestack/ui/core/form/form.haml +0 -2
  181. data/app/concepts/matestack/ui/core/form/form.rb +0 -104
  182. data/app/concepts/matestack/ui/core/form/has_errors.rb +0 -54
  183. data/app/concepts/matestack/ui/core/form/has_input_html_attributes.rb +0 -13
  184. data/app/concepts/matestack/ui/core/form/input/base.rb +0 -75
  185. data/app/concepts/matestack/ui/core/form/input/input.rb +0 -17
  186. data/app/concepts/matestack/ui/core/form/radio/base.rb +0 -90
  187. data/app/concepts/matestack/ui/core/form/radio/radio.rb +0 -16
  188. data/app/concepts/matestack/ui/core/form/select/base.rb +0 -98
  189. data/app/concepts/matestack/ui/core/form/select/select.rb +0 -19
  190. data/app/concepts/matestack/ui/core/form/submit/base.rb +0 -12
  191. data/app/concepts/matestack/ui/core/form/submit/submit.js +0 -19
  192. data/app/concepts/matestack/ui/core/form/submit/submit.rb +0 -15
  193. data/app/concepts/matestack/ui/core/form/textarea/base.rb +0 -49
  194. data/app/concepts/matestack/ui/core/form/textarea/textarea.rb +0 -17
  195. data/app/concepts/matestack/ui/core/form/utils.rb +0 -47
  196. data/app/concepts/matestack/ui/core/header/header.haml +0 -3
  197. data/app/concepts/matestack/ui/core/header/header.rb +0 -4
  198. data/app/concepts/matestack/ui/core/heading/heading.haml +0 -5
  199. data/app/concepts/matestack/ui/core/heading/heading.rb +0 -5
  200. data/app/concepts/matestack/ui/core/hr/hr.haml +0 -1
  201. data/app/concepts/matestack/ui/core/hr/hr.rb +0 -4
  202. data/app/concepts/matestack/ui/core/icon/icon.haml +0 -5
  203. data/app/concepts/matestack/ui/core/icon/icon.rb +0 -5
  204. data/app/concepts/matestack/ui/core/iframe/iframe.haml +0 -5
  205. data/app/concepts/matestack/ui/core/iframe/iframe.rb +0 -7
  206. data/app/concepts/matestack/ui/core/img/img.haml +0 -1
  207. data/app/concepts/matestack/ui/core/img/img.rb +0 -15
  208. data/app/concepts/matestack/ui/core/input/input.haml +0 -1
  209. data/app/concepts/matestack/ui/core/input/input.rb +0 -9
  210. data/app/concepts/matestack/ui/core/ins/ins.haml +0 -5
  211. data/app/concepts/matestack/ui/core/ins/ins.rb +0 -6
  212. data/app/concepts/matestack/ui/core/isolated/children_wrapper.haml +0 -2
  213. data/app/concepts/matestack/ui/core/isolated/isolated.haml +0 -10
  214. data/app/concepts/matestack/ui/core/isolated/isolated.rb +0 -59
  215. data/app/concepts/matestack/ui/core/js/core.js +0 -66
  216. data/app/concepts/matestack/ui/core/js/event-hub.js +0 -5
  217. data/app/concepts/matestack/ui/core/kbd/kbd.haml +0 -5
  218. data/app/concepts/matestack/ui/core/kbd/kbd.rb +0 -5
  219. data/app/concepts/matestack/ui/core/label/label.haml +0 -5
  220. data/app/concepts/matestack/ui/core/label/label.rb +0 -6
  221. data/app/concepts/matestack/ui/core/legend/legend.haml +0 -5
  222. data/app/concepts/matestack/ui/core/legend/legend.rb +0 -5
  223. data/app/concepts/matestack/ui/core/li/li.haml +0 -5
  224. data/app/concepts/matestack/ui/core/li/li.rb +0 -6
  225. data/app/concepts/matestack/ui/core/link/link.haml +0 -5
  226. data/app/concepts/matestack/ui/core/link/link.rb +0 -23
  227. data/app/concepts/matestack/ui/core/main/main.haml +0 -3
  228. data/app/concepts/matestack/ui/core/main/main.rb +0 -4
  229. data/app/concepts/matestack/ui/core/map/map.haml +0 -3
  230. data/app/concepts/matestack/ui/core/map/map.rb +0 -5
  231. data/app/concepts/matestack/ui/core/mark/mark.haml +0 -5
  232. data/app/concepts/matestack/ui/core/mark/mark.rb +0 -5
  233. data/app/concepts/matestack/ui/core/meter/meter.haml +0 -4
  234. data/app/concepts/matestack/ui/core/meter/meter.rb +0 -5
  235. data/app/concepts/matestack/ui/core/nav/nav.haml +0 -3
  236. data/app/concepts/matestack/ui/core/nav/nav.rb +0 -4
  237. data/app/concepts/matestack/ui/core/noscript/noscript.haml +0 -5
  238. data/app/concepts/matestack/ui/core/noscript/noscript.rb +0 -5
  239. data/app/concepts/matestack/ui/core/object/object.haml +0 -1
  240. data/app/concepts/matestack/ui/core/object/object.rb +0 -5
  241. data/app/concepts/matestack/ui/core/ol/ol.haml +0 -3
  242. data/app/concepts/matestack/ui/core/ol/ol.rb +0 -5
  243. data/app/concepts/matestack/ui/core/onclick/onclick.haml +0 -2
  244. data/app/concepts/matestack/ui/core/onclick/onclick.rb +0 -6
  245. data/app/concepts/matestack/ui/core/optgroup/optgroup.haml +0 -3
  246. data/app/concepts/matestack/ui/core/optgroup/optgroup.rb +0 -5
  247. data/app/concepts/matestack/ui/core/option/option.haml +0 -5
  248. data/app/concepts/matestack/ui/core/option/option.rb +0 -6
  249. data/app/concepts/matestack/ui/core/output/output.haml +0 -5
  250. data/app/concepts/matestack/ui/core/output/output.rb +0 -6
  251. data/app/concepts/matestack/ui/core/page/content/content.rb +0 -28
  252. data/app/concepts/matestack/ui/core/page/page.haml +0 -3
  253. data/app/concepts/matestack/ui/core/page/page.rb +0 -30
  254. data/app/concepts/matestack/ui/core/paragraph/paragraph.haml +0 -5
  255. data/app/concepts/matestack/ui/core/paragraph/paragraph.rb +0 -5
  256. data/app/concepts/matestack/ui/core/param/param.haml +0 -1
  257. data/app/concepts/matestack/ui/core/param/param.rb +0 -5
  258. data/app/concepts/matestack/ui/core/partial/partial.haml +0 -2
  259. data/app/concepts/matestack/ui/core/partial/partial.rb +0 -4
  260. data/app/concepts/matestack/ui/core/picture/picture.haml +0 -3
  261. data/app/concepts/matestack/ui/core/picture/picture.rb +0 -4
  262. data/app/concepts/matestack/ui/core/plain/plain.rb +0 -9
  263. data/app/concepts/matestack/ui/core/pre/pre.haml +0 -5
  264. data/app/concepts/matestack/ui/core/pre/pre.rb +0 -5
  265. data/app/concepts/matestack/ui/core/progress/progress.haml +0 -3
  266. data/app/concepts/matestack/ui/core/progress/progress.rb +0 -5
  267. data/app/concepts/matestack/ui/core/q/q.haml +0 -5
  268. data/app/concepts/matestack/ui/core/q/q.rb +0 -6
  269. data/app/concepts/matestack/ui/core/rp/rp.haml +0 -5
  270. data/app/concepts/matestack/ui/core/rp/rp.rb +0 -5
  271. data/app/concepts/matestack/ui/core/rt/rt.haml +0 -5
  272. data/app/concepts/matestack/ui/core/rt/rt.rb +0 -5
  273. data/app/concepts/matestack/ui/core/ruby/ruby.haml +0 -5
  274. data/app/concepts/matestack/ui/core/ruby/ruby.rb +0 -5
  275. data/app/concepts/matestack/ui/core/s/s.haml +0 -5
  276. data/app/concepts/matestack/ui/core/s/s.rb +0 -6
  277. data/app/concepts/matestack/ui/core/samp/samp.haml +0 -5
  278. data/app/concepts/matestack/ui/core/samp/samp.rb +0 -5
  279. data/app/concepts/matestack/ui/core/section/section.haml +0 -3
  280. data/app/concepts/matestack/ui/core/section/section.rb +0 -4
  281. data/app/concepts/matestack/ui/core/select/select.haml +0 -3
  282. data/app/concepts/matestack/ui/core/select/select.rb +0 -7
  283. data/app/concepts/matestack/ui/core/slot/slot.haml +0 -2
  284. data/app/concepts/matestack/ui/core/slot/slot.rb +0 -4
  285. data/app/concepts/matestack/ui/core/small/small.haml +0 -5
  286. data/app/concepts/matestack/ui/core/small/small.rb +0 -5
  287. data/app/concepts/matestack/ui/core/span/span.haml +0 -5
  288. data/app/concepts/matestack/ui/core/span/span.rb +0 -5
  289. data/app/concepts/matestack/ui/core/strong/strong.haml +0 -5
  290. data/app/concepts/matestack/ui/core/strong/strong.rb +0 -5
  291. data/app/concepts/matestack/ui/core/sub/sub.haml +0 -5
  292. data/app/concepts/matestack/ui/core/sub/sub.rb +0 -5
  293. data/app/concepts/matestack/ui/core/summary/summary.haml +0 -5
  294. data/app/concepts/matestack/ui/core/summary/summary.rb +0 -5
  295. data/app/concepts/matestack/ui/core/sup/sup.haml +0 -5
  296. data/app/concepts/matestack/ui/core/sup/sup.rb +0 -5
  297. data/app/concepts/matestack/ui/core/table/table.haml +0 -3
  298. data/app/concepts/matestack/ui/core/table/table.rb +0 -4
  299. data/app/concepts/matestack/ui/core/tbody/tbody.haml +0 -3
  300. data/app/concepts/matestack/ui/core/tbody/tbody.rb +0 -4
  301. data/app/concepts/matestack/ui/core/td/td.haml +0 -5
  302. data/app/concepts/matestack/ui/core/td/td.rb +0 -6
  303. data/app/concepts/matestack/ui/core/template/template.haml +0 -3
  304. data/app/concepts/matestack/ui/core/template/template.rb +0 -4
  305. data/app/concepts/matestack/ui/core/textarea/textarea.haml +0 -5
  306. data/app/concepts/matestack/ui/core/textarea/textarea.rb +0 -10
  307. data/app/concepts/matestack/ui/core/tfoot/tfoot.haml +0 -3
  308. data/app/concepts/matestack/ui/core/tfoot/tfoot.rb +0 -4
  309. data/app/concepts/matestack/ui/core/th/th.haml +0 -5
  310. data/app/concepts/matestack/ui/core/th/th.rb +0 -6
  311. data/app/concepts/matestack/ui/core/thead/thead.haml +0 -3
  312. data/app/concepts/matestack/ui/core/thead/thead.rb +0 -4
  313. data/app/concepts/matestack/ui/core/time/time.haml +0 -3
  314. data/app/concepts/matestack/ui/core/time/time.rb +0 -5
  315. data/app/concepts/matestack/ui/core/toggle/toggle.haml +0 -2
  316. data/app/concepts/matestack/ui/core/toggle/toggle.rb +0 -13
  317. data/app/concepts/matestack/ui/core/tr/tr.haml +0 -3
  318. data/app/concepts/matestack/ui/core/tr/tr.rb +0 -4
  319. data/app/concepts/matestack/ui/core/transition/transition.haml +0 -5
  320. data/app/concepts/matestack/ui/core/transition/transition.rb +0 -38
  321. data/app/concepts/matestack/ui/core/u/u.haml +0 -5
  322. data/app/concepts/matestack/ui/core/u/u.rb +0 -6
  323. data/app/concepts/matestack/ui/core/ul/ul.haml +0 -3
  324. data/app/concepts/matestack/ui/core/ul/ul.rb +0 -4
  325. data/app/concepts/matestack/ui/core/unescaped/unescaped.rb +0 -9
  326. data/app/concepts/matestack/ui/core/var/var.haml +0 -5
  327. data/app/concepts/matestack/ui/core/var/var.rb +0 -5
  328. data/app/concepts/matestack/ui/core/video/video.haml +0 -3
  329. data/app/concepts/matestack/ui/core/video/video.rb +0 -13
  330. data/app/concepts/matestack/ui/core/view/view.haml +0 -1
  331. data/app/concepts/matestack/ui/core/view/view.rb +0 -30
  332. data/app/concepts/matestack/ui/core/wbr/wbr.haml +0 -5
  333. data/app/concepts/matestack/ui/core/wbr/wbr.rb +0 -5
  334. data/app/concepts/matestack/ui/core/youtube/youtube.haml +0 -1
  335. data/app/concepts/matestack/ui/core/youtube/youtube.rb +0 -28
  336. data/app/helpers/matestack/ui/core/application_helper.rb +0 -111
  337. data/app/javascript/matestack-ui-core/index.js +0 -32
  338. data/app/javascript/matestack-ui-core/styles/index.scss +0 -5
  339. data/app/javascript/packs/matestack-ui-core.js +0 -8
  340. data/app/lib/matestack/ui/app.rb +0 -1
  341. data/app/lib/matestack/ui/component.rb +0 -1
  342. data/app/lib/matestack/ui/core/has_view_context.rb +0 -16
  343. data/app/lib/matestack/ui/core/html_attributes.rb +0 -43
  344. data/app/lib/matestack/ui/core/properties.rb +0 -161
  345. data/app/lib/matestack/ui/core/rendering/default_renderer_class_determiner.rb +0 -33
  346. data/app/lib/matestack/ui/core/rendering/main_renderer.rb +0 -203
  347. data/app/lib/matestack/ui/dynamic_actionview_component.rb +0 -1
  348. data/app/lib/matestack/ui/dynamic_component.rb +0 -1
  349. data/app/lib/matestack/ui/isolated_component.rb +0 -1
  350. data/app/lib/matestack/ui/page.rb +0 -1
  351. data/app/lib/matestack/ui/static_actionview_component.rb +0 -1
  352. data/app/lib/matestack/ui/static_component.rb +0 -1
  353. data/app/lib/matestack/ui/vue_js_component.rb +0 -1
  354. data/config/routes.rb +0 -2
  355. data/lib/generators/matestack/app/USAGE +0 -21
  356. data/lib/generators/matestack/app/app_generator.rb +0 -25
  357. data/lib/generators/matestack/app/templates/app/controllers/%file_name%_controller.rb.tt +0 -5
  358. data/lib/generators/matestack/app/templates/app/matestack/apps/%file_name%.rb.tt +0 -28
  359. data/lib/generators/matestack/component/USAGE +0 -20
  360. data/lib/generators/matestack/component/component_generator.rb +0 -29
  361. data/lib/generators/matestack/component/templates/app/matestack/components/%namespace%/%file_name%.haml.tt +0 -5
  362. data/lib/generators/matestack/component/templates/app/matestack/components/%namespace%/%file_name%.js.tt +0 -17
  363. data/lib/generators/matestack/component/templates/app/matestack/components/%namespace%/%file_name%.rb.tt +0 -11
  364. data/lib/generators/matestack/component/templates/app/matestack/components/%namespace%/%file_name%.scss.tt +0 -1
  365. data/lib/generators/matestack/core/component/USAGE +0 -16
  366. data/lib/generators/matestack/core/component/component_generator.rb +0 -23
  367. data/lib/generators/matestack/core/component/templates/app/concepts/matestack/ui/core/%file_name%/%file_name%.haml.tt +0 -5
  368. data/lib/generators/matestack/core/component/templates/app/concepts/matestack/ui/core/%file_name%/%file_name%.rb.tt +0 -4
  369. data/lib/generators/matestack/core/component/templates/docs/components/%file_name%.md.tt +0 -45
  370. data/lib/generators/matestack/core/component/templates/spec/usage/components/%file_name%_spec.rb +0 -31
  371. data/lib/generators/matestack/page/USAGE +0 -28
  372. data/lib/generators/matestack/page/page_generator.rb +0 -54
  373. data/lib/generators/matestack/page/templates/app/matestack/pages/%app_name%/%namespace%/%file_name%.rb.tt +0 -29
  374. data/lib/matestack/ui/core/cell.rb +0 -31
  375. data/lib/matestack/ui/core/component/registry.rb +0 -47
  376. data/lib/matestack/ui/core/components.rb +0 -271
  377. data/lib/matestack/ui/core/dsl.rb +0 -6
  378. data/lib/matestack/ui/core/engine.rb +0 -35
  379. data/lib/tasks/matestack/ui/core_tasks.rake +0 -4
  380. data/vendor/assets/javascripts/dist/manifest.json +0 -18
  381. data/vendor/assets/javascripts/dist/manifest.json.br +0 -0
  382. data/vendor/assets/javascripts/dist/manifest.json.gz +0 -0
  383. data/vendor/assets/javascripts/dist/matestack-ui-core.css +0 -3
  384. data/vendor/assets/javascripts/dist/matestack-ui-core.css.map +0 -1
  385. data/vendor/assets/javascripts/dist/matestack-ui-core.js +0 -17734
  386. data/vendor/assets/javascripts/dist/matestack-ui-core.js.map +0 -1
  387. data/vendor/assets/javascripts/dist/matestack-ui-core.min.css +0 -0
  388. data/vendor/assets/javascripts/dist/matestack-ui-core.min.js +0 -3
  389. data/vendor/assets/javascripts/dist/matestack-ui-core.min.js.LICENSE.txt +0 -18
  390. data/vendor/assets/javascripts/dist/matestack-ui-core.min.js.br +0 -0
  391. data/vendor/assets/javascripts/dist/matestack-ui-core.min.js.gz +0 -0
  392. data/vendor/assets/javascripts/dist/matestack-ui-core.min.js.map +0 -1
  393. data/vendor/assets/javascripts/dist/matestack-ui-core.min.js.map.br +0 -0
  394. data/vendor/assets/javascripts/dist/matestack-ui-core.min.js.map.gz +0 -0
  395. data/vendor/assets/javascripts/matestack-ui-core.js.erb +0 -2
  396. data/vendor/assets/stylesheets/dist +0 -1
  397. data/vendor/assets/stylesheets/matestack-ui-core.css.erb +0 -2
@@ -1,7 +1,7 @@
1
1
  import Vue from "vue/dist/vue.esm";
2
2
 
3
- import formCheckboxMixin from "./mixin";
4
- import componentMixin from "../../component/component";
3
+ import formCheckboxMixin from "./checkbox_mixin";
4
+ import componentMixin from "../mixin";
5
5
 
6
6
  const componentDef = {
7
7
  mixins: [componentMixin, formCheckboxMixin],
@@ -0,0 +1,105 @@
1
+ module Matestack
2
+ module Ui
3
+ module VueJs
4
+ module Components
5
+ module Form
6
+ class Checkbox < Matestack::Ui::VueJs::Components::Form::Base
7
+ vue_name 'matestack-ui-core-form-checkbox'
8
+
9
+ def response
10
+ div class: 'matestack-ui-core-form-checkbox' do
11
+ render_options
12
+ render_errors
13
+ end
14
+ end
15
+
16
+ def render_options
17
+ if checkbox_options
18
+ render_checkbox_options
19
+ else
20
+ render_true_false_checkbox
21
+ end
22
+ end
23
+
24
+ def component_id
25
+ "checkbox-component-for-#{key}"
26
+ end
27
+
28
+ def vue_props
29
+ {
30
+ init_value: init_value,
31
+ key: key,
32
+ }
33
+ end
34
+
35
+ # checkbox rendering
36
+
37
+ def render_checkbox_options
38
+ checkbox_options.to_a.each do |item|
39
+ input checkbox_attributes(item)
40
+ label item_label(item), for: item_id(item)
41
+ end
42
+ end
43
+
44
+ def checkbox_attributes(item)
45
+ {
46
+ id: item_id(item),
47
+ type: :checkbox,
48
+ name: item_label(item),
49
+ value: item_value(item),
50
+ ref: "select.multiple.#{key}",
51
+ '@change': change_event,
52
+ 'init-value': (init_value || []).to_json,
53
+ 'v-bind:class': "{ '#{error_class}': #{error_key} }",
54
+ 'value-type': value_type(item),
55
+ "#{v_model_type(item)}": input_key,
56
+ }.merge(self.options)
57
+ end
58
+
59
+ def render_true_false_checkbox
60
+ input true_false_checkbox_attributes.merge(type: :hidden, id: nil, value: 0)
61
+ input true_false_checkbox_attributes.merge(type: :checkbox, id: item_id(1))
62
+ label input_label, for: item_id(1) if input_label
63
+ end
64
+
65
+ def true_false_checkbox_attributes
66
+ attributes.merge({
67
+ 'init-value': init_value_for_single_input,
68
+ })
69
+ end
70
+
71
+ def init_value_for_single_input
72
+ if init_value == true || init_value == 1
73
+ return "true"
74
+ end
75
+ if init_value == false || init_value == 0
76
+ return "false"
77
+ end
78
+ end
79
+
80
+ # checkbox options
81
+
82
+ def checkbox_options
83
+ @checkbox_options ||= options.delete(:options)
84
+ end
85
+
86
+ # calculated attributes
87
+
88
+ def item_value(item)
89
+ item.is_a?(Array) ? item.last : item
90
+ end
91
+
92
+ def item_label(item)
93
+ item.is_a?(Array) ? item.first : item
94
+ end
95
+
96
+ def item_id(item)
97
+ "#{id}_#{item_value(item).to_s.gsub(" ", '_')}"
98
+ end
99
+
100
+ end
101
+ end
102
+ end
103
+ end
104
+ end
105
+ end
@@ -59,18 +59,21 @@ const formCheckboxMixin = {
59
59
 
60
60
  //without the timeout it's somehow not working
61
61
  setTimeout(function () {
62
- self.$forceUpdate()
62
+ self.$parent.$forceUpdate();
63
+ self.$forceUpdate();
63
64
  }, 1);
64
65
  },
65
66
  inputChanged: function (key) {
66
67
  this.$parent.resetErrors(key);
68
+ this.$parent.$forceUpdate();
67
69
  this.$forceUpdate();
68
70
  },
69
71
  afterInitialize: function(value){
70
72
  // can be used in the main component for further initialization steps
71
73
  },
72
74
  setValue: function (value){
73
- this.$parent.data[this.componentConfig["key"]] = value
75
+ this.$parent.data[this.props["key"]] = value
76
+ this.$parent.$forceUpdate();
74
77
  this.$forceUpdate();
75
78
  }
76
79
  }
@@ -0,0 +1,15 @@
1
+ module Matestack
2
+ module Ui
3
+ module VueJs
4
+ module Components
5
+ module Form
6
+ class Context < ActiveSupport::CurrentAttributes
7
+
8
+ attribute :form_context
9
+
10
+ end
11
+ end
12
+ end
13
+ end
14
+ end
15
+ end
@@ -2,8 +2,8 @@ import Vue from "vue/dist/vue.esm";
2
2
  import Vuex from "vuex";
3
3
  import axios from "axios";
4
4
 
5
- import matestackEventHub from "../js/event-hub";
6
- import componentMixin from "../component/component";
5
+ import matestackEventHub from "../../event_hub";
6
+ import componentMixin from "../mixin";
7
7
 
8
8
  const componentDef = {
9
9
  mixins: [componentMixin],
@@ -77,15 +77,15 @@ const componentDef = {
77
77
  },
78
78
  shouldResetFormOnSuccessfulSubmit() {
79
79
  const self = this;
80
- if (self.componentConfig["success"] != undefined && self.componentConfig["success"]["reset"] != undefined) {
81
- return self.componentConfig["success"]["reset"];
80
+ if (self.props["success"] != undefined && self.props["success"]["reset"] != undefined) {
81
+ return self.props["success"]["reset"];
82
82
  } else {
83
83
  return self.shouldResetFormOnSuccessfulSubmitByDefault();
84
84
  }
85
85
  },
86
86
  shouldResetFormOnSuccessfulSubmitByDefault() {
87
87
  const self = this;
88
- if (self.componentConfig["method"] == "put") {
88
+ if (self.props["method"] == "put") {
89
89
  return false;
90
90
  } else {
91
91
  return true;
@@ -96,13 +96,13 @@ const componentDef = {
96
96
  var form = self.$el.tagName == 'FORM' ? self.$el : self.$el.querySelector('form');
97
97
  if(form.checkValidity()){
98
98
  self.loading = true;
99
- if (self.componentConfig["emit"] != undefined) {
100
- matestackEventHub.$emit(self.componentConfig["emit"]);
99
+ if (self.props["emit"] != undefined) {
100
+ matestackEventHub.$emit(self.props["emit"]);
101
101
  }
102
- if (self.componentConfig["delay"] != undefined) {
102
+ if (self.props["delay"] != undefined) {
103
103
  setTimeout(function () {
104
104
  self.sendRequest()
105
- }, parseInt(self.componentConfig["delay"]));
105
+ }, parseInt(self.props["delay"]));
106
106
  } else {
107
107
  self.sendRequest()
108
108
  }
@@ -113,25 +113,25 @@ const componentDef = {
113
113
  sendRequest: function(){
114
114
  const self = this;
115
115
  let payload = {};
116
- payload[self.componentConfig["for"]] = self.data;
116
+ payload[self.props["for"]] = self.data;
117
117
  let axios_config = {};
118
- if (self.componentConfig["multipart"] == true ) {
118
+ if (self.props["multipart"] == true ) {
119
119
  let form_data = new FormData();
120
120
  for (let key in self.data) {
121
121
  if (key.endsWith("[]")) {
122
122
  for (let i in self.data[key]) {
123
123
  let file = self.data[key][i];
124
- form_data.append(self.componentConfig["for"] + "[" + key.slice(0, -2) + "][]", file);
124
+ form_data.append(self.props["for"] + "[" + key.slice(0, -2) + "][]", file);
125
125
  }
126
126
  } else {
127
127
  if (self.data[key] != null){
128
- form_data.append(self.componentConfig["for"] + "[" + key + "]", self.data[key]);
128
+ form_data.append(self.props["for"] + "[" + key + "]", self.data[key]);
129
129
  }
130
130
  }
131
131
  }
132
132
  axios_config = {
133
- method: self.componentConfig["method"],
134
- url: self.componentConfig["submit_path"],
133
+ method: self.props["method"],
134
+ url: self.props["submit_path"],
135
135
  data: form_data,
136
136
  headers: {
137
137
  "X-CSRF-Token": document.getElementsByName("csrf-token")[0].getAttribute("content"),
@@ -140,8 +140,8 @@ const componentDef = {
140
140
  };
141
141
  } else {
142
142
  axios_config = {
143
- method: self.componentConfig["method"],
144
- url: self.componentConfig["submit_path"],
143
+ method: self.props["method"],
144
+ url: self.props["submit_path"],
145
145
  data: payload,
146
146
  headers: {
147
147
  "X-CSRF-Token": document.getElementsByName("csrf-token")[0].getAttribute("content"),
@@ -152,26 +152,26 @@ const componentDef = {
152
152
  axios(axios_config)
153
153
  .then(function (response) {
154
154
  self.loading = false;
155
- if (self.componentConfig["success"] != undefined && self.componentConfig["success"]["emit"] != undefined) {
156
- matestackEventHub.$emit(self.componentConfig["success"]["emit"], response.data);
155
+ if (self.props["success"] != undefined && self.props["success"]["emit"] != undefined) {
156
+ matestackEventHub.$emit(self.props["success"]["emit"], response.data);
157
157
  }
158
158
  // transition handling
159
- if (self.componentConfig["success"] != undefined
160
- && self.componentConfig["success"]["transition"] != undefined
159
+ if (self.props["success"] != undefined
160
+ && self.props["success"]["transition"] != undefined
161
161
  && (
162
- self.componentConfig["success"]["transition"]["follow_response"] == undefined
162
+ self.props["success"]["transition"]["follow_response"] == undefined
163
163
  ||
164
- self.componentConfig["success"]["transition"]["follow_response"] === false
164
+ self.props["success"]["transition"]["follow_response"] === false
165
165
  )
166
166
  && self.$store != undefined
167
167
  ) {
168
- let path = self.componentConfig["success"]["transition"]["path"]
168
+ let path = self.props["success"]["transition"]["path"]
169
169
  self.$store.dispatch('navigateTo', {url: path, backwards: false})
170
170
  return;
171
171
  }
172
- if (self.componentConfig["success"] != undefined
173
- && self.componentConfig["success"]["transition"] != undefined
174
- && self.componentConfig["success"]["transition"]["follow_response"] === true
172
+ if (self.props["success"] != undefined
173
+ && self.props["success"]["transition"] != undefined
174
+ && self.props["success"]["transition"]["follow_response"] === true
175
175
  && self.$store != undefined
176
176
  ) {
177
177
  let path = response.data["transition_to"] || response.request.responseURL
@@ -179,22 +179,22 @@ const componentDef = {
179
179
  return;
180
180
  }
181
181
  // redirect handling
182
- if (self.componentConfig["success"] != undefined
183
- && self.componentConfig["success"]["redirect"] != undefined
182
+ if (self.props["success"] != undefined
183
+ && self.props["success"]["redirect"] != undefined
184
184
  && (
185
- self.componentConfig["success"]["redirect"]["follow_response"] == undefined
185
+ self.props["success"]["redirect"]["follow_response"] == undefined
186
186
  ||
187
- self.componentConfig["success"]["redirect"]["follow_response"] === false
187
+ self.props["success"]["redirect"]["follow_response"] === false
188
188
  )
189
189
  && self.$store != undefined
190
190
  ) {
191
- let path = self.componentConfig["success"]["redirect"]["path"]
191
+ let path = self.props["success"]["redirect"]["path"]
192
192
  window.location.href = path
193
193
  return;
194
194
  }
195
- if (self.componentConfig["success"] != undefined
196
- && self.componentConfig["success"]["redirect"] != undefined
197
- && self.componentConfig["success"]["redirect"]["follow_response"] === true
195
+ if (self.props["success"] != undefined
196
+ && self.props["success"]["redirect"] != undefined
197
+ && self.props["success"]["redirect"]["follow_response"] === true
198
198
  && self.$store != undefined
199
199
  ) {
200
200
  let path = response.data["redirect_to"] || response.request.responseURL
@@ -213,26 +213,26 @@ const componentDef = {
213
213
  if (error.response && error.response.data && error.response.data.errors) {
214
214
  self.errors = error.response.data.errors;
215
215
  }
216
- if (self.componentConfig["failure"] != undefined && self.componentConfig["failure"]["emit"] != undefined) {
217
- matestackEventHub.$emit(self.componentConfig["failure"]["emit"], error.response.data);
216
+ if (self.props["failure"] != undefined && self.props["failure"]["emit"] != undefined) {
217
+ matestackEventHub.$emit(self.props["failure"]["emit"], error.response.data);
218
218
  }
219
219
  // transition handling
220
- if (self.componentConfig["failure"] != undefined
221
- && self.componentConfig["failure"]["transition"] != undefined
220
+ if (self.props["failure"] != undefined
221
+ && self.props["failure"]["transition"] != undefined
222
222
  && (
223
- self.componentConfig["failure"]["transition"]["follow_response"] == undefined
223
+ self.props["failure"]["transition"]["follow_response"] == undefined
224
224
  ||
225
- self.componentConfig["failure"]["transition"]["follow_response"] === false
225
+ self.props["failure"]["transition"]["follow_response"] === false
226
226
  )
227
227
  && self.$store != undefined
228
228
  ) {
229
- let path = self.componentConfig["failure"]["transition"]["path"]
229
+ let path = self.props["failure"]["transition"]["path"]
230
230
  self.$store.dispatch('navigateTo', {url: path, backwards: false})
231
231
  return;
232
232
  }
233
- if (self.componentConfig["failure"] != undefined
234
- && self.componentConfig["failure"]["transition"] != undefined
235
- && self.componentConfig["failure"]["transition"]["follow_response"] === true
233
+ if (self.props["failure"] != undefined
234
+ && self.props["failure"]["transition"] != undefined
235
+ && self.props["failure"]["transition"]["follow_response"] === true
236
236
  && self.$store != undefined
237
237
  ) {
238
238
  let path = error.response.data["transition_to"] || response.request.responseURL
@@ -240,22 +240,22 @@ const componentDef = {
240
240
  return;
241
241
  }
242
242
  // redirect handling
243
- if (self.componentConfig["failure"] != undefined
244
- && self.componentConfig["failure"]["redirect"] != undefined
243
+ if (self.props["failure"] != undefined
244
+ && self.props["failure"]["redirect"] != undefined
245
245
  && (
246
- self.componentConfig["failure"]["redirect"]["follow_response"] == undefined
246
+ self.props["failure"]["redirect"]["follow_response"] == undefined
247
247
  ||
248
- self.componentConfig["failure"]["redirect"]["follow_response"] === false
248
+ self.props["failure"]["redirect"]["follow_response"] === false
249
249
  )
250
250
  && self.$store != undefined
251
251
  ) {
252
- let path = self.componentConfig["failure"]["redirect"]["path"]
252
+ let path = self.props["failure"]["redirect"]["path"]
253
253
  window.location.href = path
254
254
  return;
255
255
  }
256
- if (self.componentConfig["failure"] != undefined
257
- && self.componentConfig["failure"]["redirect"] != undefined
258
- && self.componentConfig["failure"]["redirect"]["follow_response"] === true
256
+ if (self.props["failure"] != undefined
257
+ && self.props["failure"]["redirect"] != undefined
258
+ && self.props["failure"]["redirect"]["follow_response"] === true
259
259
  && self.$store != undefined
260
260
  ) {
261
261
  let path = error.response.data["redirect_to"] || response.request.responseURL
@@ -0,0 +1,64 @@
1
+ module Matestack
2
+ module Ui
3
+ module VueJs
4
+ module Components
5
+ module Form
6
+ class Form < Matestack::Ui::VueJs::Vue
7
+ vue_name 'matestack-ui-core-form'
8
+
9
+ optional :for, :path, :success, :failure, :multipart, :emit, :delay, :errors
10
+
11
+ # setup form context to allow child components like inputs to access the form configuration
12
+ def initialize(html_tag = nil, text = nil, options = {}, &block)
13
+ previous_form_context = Matestack::Ui::VueJs::Components::Form::Context.form_context
14
+ Matestack::Ui::VueJs::Components::Form::Context.form_context = self
15
+ super(html_tag, text, options, &block)
16
+ Matestack::Ui::VueJs::Components::Form::Context.form_context = previous_form_context
17
+ end
18
+
19
+ def response
20
+ form attributes do
21
+ yield
22
+ end
23
+ end
24
+
25
+ def attributes
26
+ {
27
+ class: 'matestack-form',
28
+ 'v-bind:class': "{ 'has-errors': hasErrors(), loading: loading }",
29
+ '@submit.prevent': 'perform',
30
+ }
31
+ end
32
+
33
+ def vue_props
34
+ {
35
+ for: for_attribute,
36
+ submit_path: ctx.path,
37
+ method: form_method,
38
+ success: ctx.success,
39
+ failure: ctx.failure,
40
+ multipart: !!ctx.multipart,
41
+ emit: ctx.emit,
42
+ delay: ctx.delay,
43
+ }
44
+ end
45
+
46
+ def for_attribute
47
+ return for_option.model_name.singular if for_option.respond_to?(:model_name)
48
+ for_option
49
+ end
50
+
51
+ def for_option
52
+ @for_option ||= ctx.for
53
+ end
54
+
55
+ def form_method
56
+ @form_method ||= options.delete(:method)
57
+ end
58
+
59
+ end
60
+ end
61
+ end
62
+ end
63
+ end
64
+ end
@@ -1,7 +1,7 @@
1
1
  import Vue from "vue/dist/vue.esm";
2
2
 
3
- import formInputMixin from "./mixin";
4
- import componentMixin from "../../component/component";
3
+ import formInputMixin from "./input_mixin";
4
+ import componentMixin from "../mixin";
5
5
 
6
6
  const componentDef = {
7
7
  mixins: [componentMixin, formInputMixin],