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,7 +1,7 @@
1
1
  import Vue from "vue/dist/vue.esm";
2
2
 
3
- import formTextareaMixin from "./mixin";
4
- import componentMixin from "../../component/component";
3
+ import formTextareaMixin from "./textarea_mixin";
4
+ import componentMixin from "../mixin";
5
5
 
6
6
  const componentDef = {
7
7
  mixins: [componentMixin, formTextareaMixin],
@@ -0,0 +1,37 @@
1
+ module Matestack
2
+ module Ui
3
+ module VueJs
4
+ module Components
5
+ module Form
6
+ class Textarea < Matestack::Ui::VueJs::Components::Form::Base
7
+ vue_name 'matestack-ui-core-form-textarea'
8
+
9
+ def response
10
+ div class: 'matestack-ui-core-form-textarea' do
11
+ label input_label, ":for": id if input_label
12
+ textarea textarea_attributes
13
+ render_errors
14
+ end
15
+ end
16
+
17
+ def textarea_attributes
18
+ attributes
19
+ end
20
+
21
+ def component_id
22
+ "textarea-component-for-#{key}"
23
+ end
24
+
25
+ def vue_props
26
+ {
27
+ init_value: init_value,
28
+ key: key
29
+ }
30
+ end
31
+
32
+ end
33
+ end
34
+ end
35
+ end
36
+ end
37
+ end
@@ -7,32 +7,28 @@ const formTextareaMixin = {
7
7
  for (let key in this.$refs) {
8
8
  let initValue = this.$refs[key]["attributes"]["init-value"];
9
9
 
10
+ self.$set(self.$parent.data, key.replace("input.", ""), null)
11
+
10
12
  if (initValue) {
11
- data[key.replace("input.", "")] = initValue["value"];
12
- Object.assign(self.$parent.data, data);
13
+ self.setValue(initValue["value"])
13
14
  self.afterInitialize(initValue["value"])
14
15
  } else {
15
- data[key.replace("input.", "")] = null;
16
- Object.assign(self.$parent.data, data);
16
+ self.setValue(null)
17
17
  self.afterInitialize(null)
18
18
  }
19
19
  }
20
-
21
- //without the timeout it's somehow not working
22
- setTimeout(function () {
23
- self.$forceUpdate()
24
- }, 1);
25
20
  },
26
21
  inputChanged: function (key) {
22
+ if (this.$parent.isNestedForm){
23
+ this.$parent.data["_destroy"] = false;
24
+ }
27
25
  this.$parent.resetErrors(key);
28
- this.$forceUpdate();
29
26
  },
30
27
  afterInitialize: function(value){
31
28
  // can be used in the main component for further initialization steps
32
29
  },
33
30
  setValue: function (value){
34
- this.$parent.data[this.componentConfig["key"]] = value
35
- this.$forceUpdate();
31
+ this.$parent.data[this.props["key"]] = value
36
32
  }
37
33
  }
38
34
 
@@ -1,10 +1,10 @@
1
1
  import Vue from 'vue/dist/vue.esm'
2
2
  import axios from 'axios'
3
3
  import VRuntimeTemplate from "v-runtime-template"
4
- import matestackEventHub from '../js/event-hub'
4
+ import matestackEventHub from '../event_hub'
5
5
 
6
6
  const componentDef = {
7
- props: ['componentConfig', 'params'],
7
+ props: ['props', 'params'],
8
8
  data: function(){
9
9
  return {
10
10
  isolatedTemplate: null,
@@ -17,10 +17,10 @@ const componentDef = {
17
17
  var self = this;
18
18
  self.loading = true;
19
19
  self.loadingError = false;
20
- if(self.componentConfig["rerender_delay"] != undefined){
20
+ if(self.props["rerender_delay"] != undefined){
21
21
  setTimeout(function () {
22
22
  self.renderIsolatedContent();
23
- }, parseInt(this.componentConfig["rerender_delay"]));
23
+ }, parseInt(this.props["rerender_delay"]));
24
24
  } else {
25
25
  self.renderIsolatedContent();
26
26
  }
@@ -36,8 +36,8 @@ const componentDef = {
36
36
  'X-CSRF-Token': document.getElementsByName("csrf-token")[0].getAttribute('content')
37
37
  },
38
38
  params: {
39
- "component_class": self.componentConfig["component_class"],
40
- "public_options": self.componentConfig["public_options"]
39
+ "component_class": self.props["component_class"],
40
+ "public_options": self.props["public_options"]
41
41
  }
42
42
  })
43
43
  .then(function(response){
@@ -48,7 +48,7 @@ const componentDef = {
48
48
  })
49
49
  .catch(function(error){
50
50
  self.loadingError = true;
51
- matestackEventHub.$emit('isolate_rerender_error', { class: self.componentConfig["component_class"] })
51
+ matestackEventHub.$emit('isolate_rerender_error', { class: self.props["component_class"] })
52
52
  })
53
53
  },
54
54
  startDefer: function(){
@@ -56,7 +56,7 @@ const componentDef = {
56
56
  self.loading = true;
57
57
  setTimeout(function () {
58
58
  self.renderIsolatedContent()
59
- }, parseInt(this.componentConfig["defer"]));
59
+ }, parseInt(this.props["defer"]));
60
60
  }
61
61
  },
62
62
  created: function () {
@@ -64,16 +64,16 @@ const componentDef = {
64
64
  },
65
65
  beforeDestroy: function() {
66
66
  const self = this
67
- if(this.componentConfig["rerender_on"] != undefined){
68
- var rerender_events = this.componentConfig["rerender_on"].split(",")
67
+ if(this.props["rerender_on"] != undefined){
68
+ var rerender_events = this.props["rerender_on"].split(",")
69
69
  rerender_events.forEach(rerender_event => matestackEventHub.$off(rerender_event.trim(), self.renderIsolatedContent));
70
70
  }
71
71
  },
72
72
  mounted: function (){
73
73
  const self = this
74
- if(this.componentConfig["init_on"] === undefined || this.componentConfig["init_on"] === null){
75
- if(self.componentConfig["defer"] == true || Number.isInteger(self.componentConfig["defer"])){
76
- if(!isNaN(self.componentConfig["defer"])){
74
+ if(this.props["init_on"] === undefined || this.props["init_on"] === null){
75
+ if(self.props["defer"] == true || Number.isInteger(self.props["defer"])){
76
+ if(!isNaN(self.props["defer"])){
77
77
  self.startDefer()
78
78
  }
79
79
  else{
@@ -81,19 +81,19 @@ const componentDef = {
81
81
  }
82
82
  }
83
83
  }else{
84
- if(self.componentConfig["defer"] != undefined){
85
- if(!isNaN(self.componentConfig["defer"])){
86
- var init_on_events = this.componentConfig["init_on"].split(",")
84
+ if(self.props["defer"] != undefined){
85
+ if(!isNaN(self.props["defer"])){
86
+ var init_on_events = this.props["init_on"].split(",")
87
87
  init_on_events.forEach(init_on_event => matestackEventHub.$on(init_on_event.trim(), self.startDefer));
88
88
  }
89
89
  }else{
90
- var init_on_events = this.componentConfig["init_on"].split(",")
90
+ var init_on_events = this.props["init_on"].split(",")
91
91
  init_on_events.forEach(init_on_event => matestackEventHub.$on(init_on_event.trim(), self.renderIsolatedContent));
92
92
  }
93
93
  }
94
94
 
95
- if(this.componentConfig["rerender_on"] != undefined){
96
- var rerender_events = this.componentConfig["rerender_on"].split(",")
95
+ if(this.props["rerender_on"] != undefined){
96
+ var rerender_events = this.props["rerender_on"].split(",")
97
97
  rerender_events.forEach(rerender_event => matestackEventHub.$on(rerender_event.trim(), self.rerender));
98
98
  }
99
99
 
@@ -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