matestack-ui-core 1.3.1 → 2.1.0

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