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
@@ -0,0 +1,86 @@
1
+ module Matestack
2
+ module Ui
3
+ module VueJs
4
+ module Components
5
+ class Isolated < Matestack::Ui::VueJs::Vue
6
+ vue_name 'matestack-ui-core-isolate'
7
+
8
+ optional :defer, :init_on, :public_options, :rerender_on, :rerender_delay
9
+
10
+ def initialize(html_tag = nil, text = nil, options = {}, &block)
11
+ extract_options(text, options)
12
+ only_public_options!
13
+ isolated_parent = Matestack::Ui::Core::Context.isolated_parent
14
+ Matestack::Ui::Core::Context.isolated_parent = self
15
+ super(html_tag, text, options, &block)
16
+ Matestack::Ui::Core::Context.isolated_parent = isolated_parent
17
+ end
18
+
19
+ def create_children
20
+ # content only should be rendered if param :component_class is present
21
+ warn "[WARNING] '#{self.class}' was accessed but not authorized" unless authorized?
22
+ if params[:component_class].present?
23
+ self.response if authorized?
24
+ else
25
+ self.isolated do
26
+ self.response if authorized?
27
+ end
28
+ end
29
+ end
30
+
31
+ def isolated
32
+ Matestack::Ui::Core::Base.new(:component, component_attributes) do
33
+ div class: 'matestack-isolated-component-container', 'v-bind:class': '{ loading: loading === true }' do
34
+ if self.respond_to? :loading_state_element
35
+ div class: 'loading-state-element-wrapper', 'v-bind:class': '{ loading: loading === true }' do
36
+ loading_state_element
37
+ end
38
+ end
39
+ unless ctx.defer || ctx.init_on
40
+ div class: 'matestack-isolated-component-wrapper', 'v-if': 'isolatedTemplate == null', 'v-bind:class': '{ loading: loading === true }' do
41
+ div class: 'matestack-isolated-component-root' do
42
+ yield
43
+ end
44
+ end
45
+ end
46
+ div class: 'matestack-isolated-component-wrapper', 'v-if': 'isolatedTemplate != null', 'v-bind:class': '{ loading: loading === true }' do
47
+ div class: 'matestack-isolated-component-root' do
48
+ Matestack::Ui::Core::Base.new('v-runtime-template', ':template': 'isolatedTemplate')
49
+ end
50
+ end
51
+ end
52
+ end
53
+ end
54
+
55
+ def vue_props
56
+ {
57
+ component_class: self.class.name,
58
+ public_options: ctx.public_options,
59
+ defer: ctx.defer,
60
+ rerender_on: ctx.rerender_on,
61
+ rerender_delay: ctx.rerender_delay,
62
+ init_on: ctx.init_on,
63
+ }
64
+ end
65
+
66
+ def public_options
67
+ ctx.public_options || {}
68
+ end
69
+
70
+ def authorized?
71
+ raise "'authorized?' needs to be implemented by '#{self.class}'"
72
+ end
73
+
74
+ def only_public_options!
75
+ if self.options.except(:defer, :init_on, :public_options, :rerender_on, :rerender_delay).keys.any?
76
+ error_message = "isolated components can only take params in a public_options hash, which will be exposed to the client side in order to perform an async request with these params."
77
+ error_message << " Check your usages of '#{self.class}' components"
78
+ raise error_message
79
+ end
80
+ end
81
+
82
+ end
83
+ end
84
+ end
85
+ end
86
+ end
@@ -1,7 +1,7 @@
1
- import matestackEventHub from '../js/event-hub'
1
+ import matestackEventHub from '../event_hub'
2
2
 
3
3
  const componentMixin = {
4
- props: ['componentConfig', 'params'],
4
+ props: ['props', 'params'],
5
5
  methods: {
6
6
  registerEvents: function(events, callback){
7
7
  if(events != undefined){
@@ -1,7 +1,6 @@
1
1
  import Vue from 'vue/dist/vue.esm'
2
-
3
- import matestackEventHub from '../js/event-hub'
4
- import componentMixin from '../component/component'
2
+ import matestackEventHub from '../event_hub'
3
+ import componentMixin from './mixin'
5
4
 
6
5
  const componentDef = {
7
6
  mixins: [componentMixin],
@@ -10,7 +9,7 @@ const componentDef = {
10
9
  },
11
10
  methods: {
12
11
  perform: function(){
13
- matestackEventHub.$emit(this.componentConfig["emit"], this.componentConfig["data"])
12
+ matestackEventHub.$emit(this.props["emit"], this.props["data"])
14
13
  }
15
14
  }
16
15
  }
@@ -0,0 +1,37 @@
1
+ module Matestack
2
+ module Ui
3
+ module VueJs
4
+ module Components
5
+ class Onclick < Matestack::Ui::VueJs::Vue
6
+ vue_name 'matestack-ui-core-onclick'
7
+
8
+ optional :emit, :data
9
+
10
+ def response
11
+ a onclick_attributes do
12
+ yield
13
+ end
14
+ end
15
+
16
+ def onclick_attributes
17
+ options.merge({
18
+ class: "matestack-onclick-component-root",
19
+ '@click.prevent': 'perform',
20
+ href: "#"
21
+ })
22
+ end
23
+
24
+ protected
25
+
26
+ def vue_props
27
+ {
28
+ emit: ctx.emit,
29
+ data: ctx.data,
30
+ }
31
+ end
32
+
33
+ end
34
+ end
35
+ end
36
+ end
37
+ end
@@ -1,6 +1,6 @@
1
1
  import Vue from 'vue/dist/vue.esm'
2
- import matestackEventHub from '../js/event-hub'
3
- import componentMixin from '../component/component'
2
+ import matestackEventHub from '../event_hub'
3
+ import componentMixin from './mixin'
4
4
 
5
5
  const componentDef = {
6
6
  mixins: [componentMixin],
@@ -21,10 +21,10 @@ const componentDef = {
21
21
  }
22
22
  this.showing = true
23
23
  this.event.data = event_data
24
- if(this.componentConfig["hide_after"] != undefined){
24
+ if(this.props["hide_after"] != undefined){
25
25
  self.hide_after_timeout = setTimeout(function () {
26
26
  self.hide()
27
- }, parseInt(this.componentConfig["hide_after"]));
27
+ }, parseInt(this.props["hide_after"]));
28
28
  }
29
29
  },
30
30
  hide: function(){
@@ -34,33 +34,33 @@ const componentDef = {
34
34
  },
35
35
  created: function () {
36
36
  const self = this
37
- if(this.componentConfig["show_on"] != undefined){
37
+ if(this.props["show_on"] != undefined){
38
38
  this.showing = false
39
- var show_events = this.componentConfig["show_on"].split(",")
39
+ var show_events = this.props["show_on"].split(",")
40
40
  show_events.forEach(show_event => matestackEventHub.$on(show_event.trim(), self.show));
41
41
  }
42
- if(this.componentConfig["hide_on"] != undefined){
43
- var hide_events = this.componentConfig["hide_on"].split(",")
42
+ if(this.props["hide_on"] != undefined){
43
+ var hide_events = this.props["hide_on"].split(",")
44
44
  hide_events.forEach(hide_event => matestackEventHub.$on(hide_event.trim(), self.hide));
45
45
  }
46
- if(this.componentConfig["show_on"] != undefined){
46
+ if(this.props["show_on"] != undefined){
47
47
  this.showing = false
48
48
  }
49
- if(this.componentConfig["init_show"] == true){
49
+ if(this.props["init_show"] == true){
50
50
  this.showing = true
51
51
  }
52
52
  },
53
53
  beforeDestroy: function() {
54
54
  const self = this
55
55
  clearTimeout(self.hide_after_timeout)
56
- matestackEventHub.$off(this.componentConfig["show_on"], self.show);
57
- matestackEventHub.$off(this.componentConfig["hide_on"], self.hide);
58
- if(this.componentConfig["show_on"] != undefined){
59
- var shown_events = this.componentConfig["show_on"].split(",")
56
+ matestackEventHub.$off(this.props["show_on"], self.show);
57
+ matestackEventHub.$off(this.props["hide_on"], self.hide);
58
+ if(this.props["show_on"] != undefined){
59
+ var shown_events = this.props["show_on"].split(",")
60
60
  shown_events.forEach(show_event => matestackEventHub.$off(show_event.trim(), self.show));
61
61
  }
62
- if(this.componentConfig["hide_on"] != undefined){
63
- var hiden_events = this.componentConfig["hide_on"].split(",")
62
+ if(this.props["hide_on"] != undefined){
63
+ var hiden_events = this.props["hide_on"].split(",")
64
64
  hiden_events.forEach(hide_event => matestackEventHub.$off(hide_event.trim(), self.hide));
65
65
  }
66
66
  },
@@ -68,4 +68,4 @@ const componentDef = {
68
68
 
69
69
  let component = Vue.component('matestack-ui-core-toggle', componentDef)
70
70
 
71
- export default componentDef
71
+ export default componentDef
@@ -0,0 +1,38 @@
1
+ module Matestack
2
+ module Ui
3
+ module VueJs
4
+ module Components
5
+ class Toggle < Matestack::Ui::VueJs::Vue
6
+ vue_name 'matestack-ui-core-toggle'
7
+
8
+ optional :show_on, :hide_on, :hide_after, :init_show
9
+
10
+ def response
11
+ div toggle_attributes do
12
+ yield
13
+ end
14
+ end
15
+
16
+ def toggle_attributes
17
+ options.merge({
18
+ class: "matestack-toggle-component-root",
19
+ 'v-if': 'showing'
20
+ })
21
+ end
22
+
23
+ protected
24
+
25
+ def vue_props
26
+ {
27
+ show_on: ctx.show_on,
28
+ hide_on: ctx.hide_on,
29
+ hide_after: ctx.hide_after,
30
+ init_show: ctx.init_show,
31
+ }
32
+ end
33
+
34
+ end
35
+ end
36
+ end
37
+ end
38
+ end
@@ -1,7 +1,7 @@
1
1
  import Vue from 'vue/dist/vue.esm'
2
2
  import Vuex from 'vuex'
3
- import componentMixin from '../component/component'
4
- import matestackEventHub from '../js/event-hub'
3
+ import componentMixin from './mixin'
4
+ import matestackEventHub from '../event_hub'
5
5
 
6
6
  const componentDef = {
7
7
  mixins: [componentMixin],
@@ -10,10 +10,10 @@ const componentDef = {
10
10
  },
11
11
  computed: Vuex.mapState({
12
12
  isActive (state) {
13
- return (this.componentConfig["link_path"].split("?")[0]) === state.currentPathName
13
+ return (this.props["link_path"].split("?")[0]) === state.currentPathName
14
14
  },
15
15
  isChildActive (state) {
16
- return ((this.componentConfig["link_path"].split("?")[0]) !== state.currentPathName) && (state.currentPathName.indexOf(this.componentConfig["link_path"].split("?")[0]) !== -1)
16
+ return ((this.props["link_path"].split("?")[0]) !== state.currentPathName) && (state.currentPathName.indexOf(this.props["link_path"].split("?")[0]) !== -1)
17
17
  }
18
18
  }),
19
19
  methods: {
@@ -21,10 +21,10 @@ const componentDef = {
21
21
  const self = this
22
22
  matestackEventHub.$emit("page_loading_triggered", url);
23
23
  this.$store.commit('setPageLoading', true);
24
- if (self.componentConfig["delay"] != undefined) {
24
+ if (self.props["delay"] != undefined) {
25
25
  setTimeout(function () {
26
26
  self.performNavigation(url)
27
- }, parseInt(self.componentConfig["delay"]));
27
+ }, parseInt(self.props["delay"]));
28
28
  } else {
29
29
  this.performNavigation(url)
30
30
  }
@@ -0,0 +1,40 @@
1
+ module Matestack
2
+ module Ui
3
+ module VueJs
4
+ module Components
5
+ class Transition < Matestack::Ui::VueJs::Vue
6
+ vue_name 'matestack-ui-core-transition'
7
+
8
+ optional :path, :delay
9
+
10
+ def response
11
+ a attributes do
12
+ if block_given?
13
+ yield
14
+ end
15
+ plain self.text if self.text
16
+ end
17
+ end
18
+
19
+ protected
20
+
21
+ def attributes
22
+ options.merge({
23
+ href: ctx.path,
24
+ '@click.prevent': "navigateTo(\"#{ctx.path}\")",
25
+ "v-bind:class": "{ active: isActive, 'active-child': isChildActive }"
26
+ })
27
+ end
28
+
29
+ def vue_props
30
+ {
31
+ link_path: ctx.path,
32
+ delay: ctx.delay,
33
+ }
34
+ end
35
+
36
+ end
37
+ end
38
+ end
39
+ end
40
+ end
@@ -0,0 +1,5 @@
1
+ import Vue from 'vue/dist/vue.esm'
2
+
3
+ const eventHub = new Vue();
4
+
5
+ export default eventHub
@@ -0,0 +1,52 @@
1
+ // import Vue from 'vue/dist/vue.esm'
2
+ // import Vuex from 'vuex'
3
+ // import axios from 'axios'
4
+
5
+ import eventHub from './event_hub'
6
+
7
+ const matestackEventHub = eventHub // for compatibility with 1.x
8
+
9
+ import componentMixin from './components/mixin'
10
+
11
+ import app from './app/app'
12
+ import store from './app/store'
13
+
14
+ import pageContent from './page/content' //TODO Rename to page
15
+
16
+ import collectionContent from './components/collection/content'
17
+ import collectionFilter from './components/collection/filter'
18
+ import collectionOrder from './components/collection/order'
19
+
20
+ import toggle from './components/toggle'
21
+ import onclick from './components/onclick'
22
+ import transition from './components/transition'
23
+ import async from './components/async'
24
+ import action from './components/action'
25
+ import cable from './components/cable'
26
+ import isolate from './components/isolated'
27
+ import form from './components/form/form'
28
+ import formCheckbox from './components/form/checkbox'
29
+ import formInput from './components/form/input'
30
+ import formRadio from './components/form/radio'
31
+ import formSelect from './components/form/select'
32
+ import formTextarea from './components/form/textarea'
33
+
34
+ import formInputMixin from './components/form/input_mixin'
35
+ import formSelectMixin from './components/form/select_mixin'
36
+ import formRadioMixin from './components/form/radio_mixin'
37
+ import formCheckboxMixin from './components/form/checkbox_mixin'
38
+ import formTextareaMixin from './components/form/textarea_mixin'
39
+
40
+ const MatestackUiCore = {
41
+ store,
42
+ eventHub,
43
+ matestackEventHub, // for compatibility with 1.x
44
+ componentMixin,
45
+ formInputMixin,
46
+ formSelectMixin,
47
+ formCheckboxMixin,
48
+ formTextareaMixin,
49
+ formRadioMixin
50
+ }
51
+
52
+ export default MatestackUiCore
@@ -0,0 +1,5 @@
1
+ class Matestack::Ui::Core::Base
2
+
3
+ include Matestack::Ui::VueJs::Components
4
+
5
+ end
@@ -1,6 +1,6 @@
1
1
  import Vue from 'vue/dist/vue.esm'
2
2
  import Vuex from 'vuex'
3
- import componentMixin from '../../component/component'
3
+ import componentMixin from '../components/mixin'
4
4
 
5
5
  import VRuntimeTemplate from "v-runtime-template"
6
6
 
@@ -0,0 +1,63 @@
1
+ module Matestack
2
+ module Ui
3
+ module VueJs
4
+ class Vue < Matestack::Ui::Component
5
+
6
+ def initialize(html_tag = nil, text = nil, options = {}, &block)
7
+ extract_options(text, options)
8
+ super(html_tag, text, options, &block)
9
+ end
10
+
11
+ def create_children(&block)
12
+ vue_component do
13
+ self.response do
14
+ block.call if block_given?
15
+ end
16
+ end
17
+ end
18
+
19
+ def vue_component(&block)
20
+ Matestack::Ui::Core::Base.new(:component, component_attributes, &block)
21
+ end
22
+
23
+ def component_attributes
24
+ {
25
+ is: vue_name,
26
+ ref: component_id,
27
+ ':params': params.to_json,
28
+ ':props': self.vue_props.to_json,
29
+ 'inline-template': true
30
+ }
31
+ end
32
+
33
+ def component_id
34
+ options[:id] || nil
35
+ end
36
+
37
+ def vue_props
38
+ # raise "config needs to be overwritten by #{self.class}"
39
+ end
40
+ alias :config :vue_props
41
+
42
+ def vue_props
43
+ # raise "config needs to be overwritten by #{self.class}"
44
+ end
45
+
46
+ def self.vue_name(name = nil)
47
+ name ? @vue_name = name : @vue_name
48
+ end
49
+
50
+ def vue_name
51
+ raise "vue_name missing for #{self.class}" unless self.class.vue_name
52
+ self.class.vue_name
53
+ end
54
+
55
+ def self.inherited(subclass)
56
+ subclass.vue_name(self.vue_name)
57
+ super
58
+ end
59
+
60
+ end
61
+ end
62
+ end
63
+ end