matestack-ui-core 1.0.0.rc.1 → 1.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (259) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +784 -18
  3. data/app/concepts/matestack/ui/core/abbr/abbr.haml +1 -1
  4. data/app/concepts/matestack/ui/core/abbr/abbr.rb +0 -8
  5. data/app/concepts/matestack/ui/core/action/action.haml +1 -1
  6. data/app/concepts/matestack/ui/core/actionview/dynamic.haml +4 -4
  7. data/app/concepts/matestack/ui/core/address/address.haml +2 -2
  8. data/app/concepts/matestack/ui/core/app/store.js +5 -1
  9. data/app/concepts/matestack/ui/core/area/area.haml +1 -1
  10. data/app/concepts/matestack/ui/core/area/area.rb +2 -16
  11. data/app/concepts/matestack/ui/core/article/article.haml +3 -3
  12. data/app/concepts/matestack/ui/core/article/article.rb +1 -1
  13. data/app/concepts/matestack/ui/core/aside/aside.haml +1 -1
  14. data/app/concepts/matestack/ui/core/aside/aside.rb +0 -1
  15. data/app/concepts/matestack/ui/core/async/async.js +6 -28
  16. data/app/concepts/matestack/ui/core/async/async.rb +11 -11
  17. data/app/concepts/matestack/ui/core/async/children_wrapper.haml +1 -1
  18. data/app/concepts/matestack/ui/core/b/b.haml +3 -3
  19. data/app/concepts/matestack/ui/core/b/b.rb +1 -1
  20. data/app/concepts/matestack/ui/core/bdi/bdi.haml +3 -3
  21. data/app/concepts/matestack/ui/core/bdi/bdi.rb +1 -0
  22. data/app/concepts/matestack/ui/core/bdo/bdo.haml +3 -3
  23. data/app/concepts/matestack/ui/core/bdo/bdo.rb +2 -7
  24. data/app/concepts/matestack/ui/core/blockquote/blockquote.haml +3 -3
  25. data/app/concepts/matestack/ui/core/blockquote/blockquote.rb +2 -7
  26. data/app/concepts/matestack/ui/core/br/br.haml +4 -4
  27. data/app/concepts/matestack/ui/core/br/br.rb +1 -1
  28. data/app/concepts/matestack/ui/core/button/button.haml +3 -3
  29. data/app/concepts/matestack/ui/core/button/button.rb +3 -7
  30. data/app/concepts/matestack/ui/core/cable/cable.haml +4 -0
  31. data/app/concepts/matestack/ui/core/cable/cable.js +100 -0
  32. data/app/concepts/matestack/ui/core/cable/cable.rb +28 -0
  33. data/app/concepts/matestack/ui/core/cable/children_wrapper.haml +2 -0
  34. data/app/concepts/matestack/ui/core/caption/caption.haml +3 -3
  35. data/app/concepts/matestack/ui/core/caption/caption.rb +1 -1
  36. data/app/concepts/matestack/ui/core/cite/cite.haml +3 -3
  37. data/app/concepts/matestack/ui/core/cite/cite.rb +1 -1
  38. data/app/concepts/matestack/ui/core/code/code.haml +3 -3
  39. data/app/concepts/matestack/ui/core/code/code.rb +1 -1
  40. data/app/concepts/matestack/ui/core/collection/content/content.js +2 -2
  41. data/app/concepts/matestack/ui/core/collection/content/content.rb +4 -6
  42. data/app/concepts/matestack/ui/core/collection/content/next/next.haml +1 -1
  43. data/app/concepts/matestack/ui/core/collection/content/page/link/link.haml +1 -1
  44. data/app/concepts/matestack/ui/core/collection/content/page/link/link.rb +1 -1
  45. data/app/concepts/matestack/ui/core/collection/content/previous/previous.haml +1 -1
  46. data/app/concepts/matestack/ui/core/collection/filter/filter.rb +1 -1
  47. data/app/concepts/matestack/ui/core/collection/filter/input/input.rb +11 -8
  48. data/app/concepts/matestack/ui/core/collection/filter/reset/reset.haml +1 -1
  49. data/app/concepts/matestack/ui/core/collection/filter/select/select.haml +6 -6
  50. data/app/concepts/matestack/ui/core/collection/filter/select/select.rb +10 -9
  51. data/app/concepts/matestack/ui/core/collection/filter/submit/submit.haml +1 -1
  52. data/app/concepts/matestack/ui/core/collection/order/order.rb +1 -1
  53. data/app/concepts/matestack/ui/core/collection/order/toggle/indicator/indicator.rb +5 -2
  54. data/app/concepts/matestack/ui/core/collection/order/toggle/toggle.haml +1 -1
  55. data/app/concepts/matestack/ui/core/collection/order/toggle/toggle.rb +0 -1
  56. data/app/concepts/matestack/ui/core/component/base.rb +10 -4
  57. data/app/concepts/matestack/ui/core/component/component.js +18 -1
  58. data/app/concepts/matestack/ui/core/component/dynamic.rb +2 -1
  59. data/app/concepts/matestack/ui/core/data/data.haml +3 -3
  60. data/app/concepts/matestack/ui/core/data/data.rb +2 -5
  61. data/app/concepts/matestack/ui/core/datalist/datalist.haml +2 -2
  62. data/app/concepts/matestack/ui/core/datalist/datalist.rb +1 -2
  63. data/app/concepts/matestack/ui/core/dd/dd.haml +3 -3
  64. data/app/concepts/matestack/ui/core/dd/dd.rb +1 -1
  65. data/app/concepts/matestack/ui/core/del/del.haml +3 -3
  66. data/app/concepts/matestack/ui/core/del/del.rb +2 -0
  67. data/app/concepts/matestack/ui/core/details/details.haml +1 -1
  68. data/app/concepts/matestack/ui/core/details/details.rb +1 -1
  69. data/app/concepts/matestack/ui/core/dfn/dfn.haml +3 -3
  70. data/app/concepts/matestack/ui/core/dfn/dfn.rb +1 -1
  71. data/app/concepts/matestack/ui/core/dialog/dialog.haml +3 -3
  72. data/app/concepts/matestack/ui/core/dialog/dialog.rb +2 -5
  73. data/app/concepts/matestack/ui/core/div/div.haml +1 -1
  74. data/app/concepts/matestack/ui/core/div/div.rb +0 -1
  75. data/app/concepts/matestack/ui/core/dl/dl.haml +3 -3
  76. data/app/concepts/matestack/ui/core/dl/dl.rb +2 -2
  77. data/app/concepts/matestack/ui/core/dt/dt.haml +3 -3
  78. data/app/concepts/matestack/ui/core/dt/dt.rb +1 -1
  79. data/app/concepts/matestack/ui/core/em/em.haml +3 -3
  80. data/app/concepts/matestack/ui/core/em/em.rb +1 -1
  81. data/app/concepts/matestack/ui/core/fieldset/fieldset.haml +4 -4
  82. data/app/concepts/matestack/ui/core/fieldset/fieldset.rb +3 -6
  83. data/app/concepts/matestack/ui/core/figure/figure.haml +1 -1
  84. data/app/concepts/matestack/ui/core/figure/figure.rb +0 -1
  85. data/app/concepts/matestack/ui/core/footer/footer.haml +1 -1
  86. data/app/concepts/matestack/ui/core/footer/footer.rb +0 -1
  87. data/app/concepts/matestack/ui/core/form/checkbox/base.rb +120 -0
  88. data/app/concepts/matestack/ui/core/form/checkbox/checkbox.js +15 -0
  89. data/app/concepts/matestack/ui/core/form/checkbox/checkbox.rb +7 -70
  90. data/app/concepts/matestack/ui/core/form/checkbox/mixin.js +80 -0
  91. data/app/concepts/matestack/ui/core/form/form.haml +1 -1
  92. data/app/concepts/matestack/ui/core/form/form.js +15 -46
  93. data/app/concepts/matestack/ui/core/form/form.rb +34 -28
  94. data/app/concepts/matestack/ui/core/form/input/base.rb +75 -0
  95. data/app/concepts/matestack/ui/core/form/input/input.js +15 -0
  96. data/app/concepts/matestack/ui/core/form/input/input.rb +8 -52
  97. data/app/concepts/matestack/ui/core/form/input/mixin.js +55 -0
  98. data/app/concepts/matestack/ui/core/form/radio/base.rb +90 -0
  99. data/app/concepts/matestack/ui/core/form/radio/mixin.js +62 -0
  100. data/app/concepts/matestack/ui/core/form/radio/radio.js +15 -0
  101. data/app/concepts/matestack/ui/core/form/radio/radio.rb +7 -62
  102. data/app/concepts/matestack/ui/core/form/select/base.rb +98 -0
  103. data/app/concepts/matestack/ui/core/form/select/mixin.js +58 -0
  104. data/app/concepts/matestack/ui/core/form/select/select.js +15 -0
  105. data/app/concepts/matestack/ui/core/form/select/select.rb +11 -80
  106. data/app/concepts/matestack/ui/core/form/submit/base.rb +12 -0
  107. data/app/concepts/matestack/ui/core/form/submit/submit.js +19 -0
  108. data/app/concepts/matestack/ui/core/form/submit/submit.rb +9 -6
  109. data/app/concepts/matestack/ui/core/form/textarea/base.rb +49 -0
  110. data/app/concepts/matestack/ui/core/form/textarea/mixin.js +41 -0
  111. data/app/concepts/matestack/ui/core/form/textarea/textarea.js +15 -0
  112. data/app/concepts/matestack/ui/core/form/textarea/textarea.rb +10 -21
  113. data/app/concepts/matestack/ui/core/header/header.haml +1 -1
  114. data/app/concepts/matestack/ui/core/header/header.rb +0 -1
  115. data/app/concepts/matestack/ui/core/heading/heading.haml +4 -49
  116. data/app/concepts/matestack/ui/core/heading/heading.rb +1 -3
  117. data/app/concepts/matestack/ui/core/hr/hr.haml +1 -1
  118. data/app/concepts/matestack/ui/core/hr/hr.rb +0 -1
  119. data/app/concepts/matestack/ui/core/icon/icon.haml +3 -3
  120. data/app/concepts/matestack/ui/core/icon/icon.rb +1 -1
  121. data/app/concepts/matestack/ui/core/iframe/iframe.haml +3 -3
  122. data/app/concepts/matestack/ui/core/iframe/iframe.rb +3 -10
  123. data/app/concepts/matestack/ui/core/img/img.haml +1 -1
  124. data/app/concepts/matestack/ui/core/img/img.rb +8 -8
  125. data/app/concepts/matestack/ui/core/input/input.rb +0 -4
  126. data/app/concepts/matestack/ui/core/ins/ins.haml +3 -3
  127. data/app/concepts/matestack/ui/core/ins/ins.rb +2 -6
  128. data/app/concepts/matestack/ui/core/isolated/children_wrapper.haml +1 -1
  129. data/app/concepts/matestack/ui/core/isolated/isolated.rb +1 -1
  130. data/app/concepts/matestack/ui/core/js/core.js +12 -0
  131. data/app/concepts/matestack/ui/core/kbd/kbd.haml +3 -3
  132. data/app/concepts/matestack/ui/core/kbd/kbd.rb +1 -0
  133. data/app/concepts/matestack/ui/core/label/label.haml +3 -3
  134. data/app/concepts/matestack/ui/core/label/label.rb +2 -6
  135. data/app/concepts/matestack/ui/core/legend/legend.haml +3 -3
  136. data/app/concepts/matestack/ui/core/legend/legend.rb +1 -1
  137. data/app/concepts/matestack/ui/core/li/li.haml +3 -3
  138. data/app/concepts/matestack/ui/core/li/li.rb +2 -1
  139. data/app/concepts/matestack/ui/core/link/link.haml +3 -3
  140. data/app/concepts/matestack/ui/core/link/link.rb +10 -14
  141. data/app/concepts/matestack/ui/core/main/main.haml +1 -1
  142. data/app/concepts/matestack/ui/core/main/main.rb +0 -1
  143. data/app/concepts/matestack/ui/core/map/map.haml +1 -1
  144. data/app/concepts/matestack/ui/core/map/map.rb +1 -7
  145. data/app/concepts/matestack/ui/core/mark/mark.haml +3 -3
  146. data/app/concepts/matestack/ui/core/mark/mark.rb +1 -0
  147. data/app/concepts/matestack/ui/core/meter/meter.haml +1 -1
  148. data/app/concepts/matestack/ui/core/meter/meter.rb +1 -10
  149. data/app/concepts/matestack/ui/core/nav/nav.haml +1 -1
  150. data/app/concepts/matestack/ui/core/nav/nav.rb +0 -1
  151. data/app/concepts/matestack/ui/core/noscript/noscript.haml +3 -3
  152. data/app/concepts/matestack/ui/core/noscript/noscript.rb +1 -1
  153. data/app/concepts/matestack/ui/core/object/object.haml +1 -1
  154. data/app/concepts/matestack/ui/core/object/object.rb +1 -11
  155. data/app/concepts/matestack/ui/core/ol/ol.haml +1 -1
  156. data/app/concepts/matestack/ui/core/ol/ol.rb +1 -1
  157. data/app/concepts/matestack/ui/core/onclick/onclick.haml +1 -1
  158. data/app/concepts/matestack/ui/core/optgroup/optgroup.haml +1 -1
  159. data/app/concepts/matestack/ui/core/optgroup/optgroup.rb +1 -6
  160. data/app/concepts/matestack/ui/core/option/option.haml +3 -3
  161. data/app/concepts/matestack/ui/core/option/option.rb +2 -8
  162. data/app/concepts/matestack/ui/core/output/output.haml +3 -3
  163. data/app/concepts/matestack/ui/core/output/output.rb +2 -7
  164. data/app/concepts/matestack/ui/core/page/content/content.rb +0 -1
  165. data/app/concepts/matestack/ui/core/page/page.haml +1 -1
  166. data/app/concepts/matestack/ui/core/paragraph/paragraph.haml +3 -3
  167. data/app/concepts/matestack/ui/core/paragraph/paragraph.rb +1 -1
  168. data/app/concepts/matestack/ui/core/param/param.haml +1 -1
  169. data/app/concepts/matestack/ui/core/param/param.rb +1 -6
  170. data/app/concepts/matestack/ui/core/partial/partial.rb +0 -1
  171. data/app/concepts/matestack/ui/core/picture/picture.haml +1 -1
  172. data/app/concepts/matestack/ui/core/pre/pre.haml +3 -3
  173. data/app/concepts/matestack/ui/core/pre/pre.rb +1 -1
  174. data/app/concepts/matestack/ui/core/progress/progress.haml +1 -1
  175. data/app/concepts/matestack/ui/core/progress/progress.rb +1 -10
  176. data/app/concepts/matestack/ui/core/q/q.haml +3 -3
  177. data/app/concepts/matestack/ui/core/q/q.rb +2 -7
  178. data/app/concepts/matestack/ui/core/rp/rp.haml +3 -3
  179. data/app/concepts/matestack/ui/core/rp/rp.rb +1 -1
  180. data/app/concepts/matestack/ui/core/rt/rt.haml +3 -3
  181. data/app/concepts/matestack/ui/core/rt/rt.rb +1 -1
  182. data/app/concepts/matestack/ui/core/ruby/ruby.haml +3 -3
  183. data/app/concepts/matestack/ui/core/ruby/ruby.rb +1 -1
  184. data/app/concepts/matestack/ui/core/s/s.haml +3 -3
  185. data/app/concepts/matestack/ui/core/s/s.rb +1 -1
  186. data/app/concepts/matestack/ui/core/samp/samp.haml +3 -3
  187. data/app/concepts/matestack/ui/core/samp/samp.rb +1 -0
  188. data/app/concepts/matestack/ui/core/section/section.haml +1 -1
  189. data/app/concepts/matestack/ui/core/section/section.rb +0 -1
  190. data/app/concepts/matestack/ui/core/{form/submit/submit.haml → select/select.haml} +1 -1
  191. data/app/concepts/matestack/ui/core/select/select.rb +7 -0
  192. data/app/concepts/matestack/ui/core/slot/slot.rb +0 -1
  193. data/app/concepts/matestack/ui/core/small/small.haml +3 -3
  194. data/app/concepts/matestack/ui/core/small/small.rb +1 -1
  195. data/app/concepts/matestack/ui/core/span/span.haml +3 -3
  196. data/app/concepts/matestack/ui/core/span/span.rb +1 -1
  197. data/app/concepts/matestack/ui/core/strong/strong.haml +3 -3
  198. data/app/concepts/matestack/ui/core/strong/strong.rb +1 -1
  199. data/app/concepts/matestack/ui/core/sub/sub.haml +3 -3
  200. data/app/concepts/matestack/ui/core/sub/sub.rb +1 -1
  201. data/app/concepts/matestack/ui/core/summary/summary.haml +3 -3
  202. data/app/concepts/matestack/ui/core/summary/summary.rb +1 -1
  203. data/app/concepts/matestack/ui/core/sup/sup.haml +3 -3
  204. data/app/concepts/matestack/ui/core/sup/sup.rb +1 -1
  205. data/app/concepts/matestack/ui/core/table/table.haml +1 -1
  206. data/app/concepts/matestack/ui/core/table/table.rb +0 -1
  207. data/app/concepts/matestack/ui/core/tbody/tbody.haml +1 -1
  208. data/app/concepts/matestack/ui/core/tbody/tbody.rb +0 -1
  209. data/app/concepts/matestack/ui/core/td/td.haml +3 -3
  210. data/app/concepts/matestack/ui/core/td/td.rb +2 -1
  211. data/app/concepts/matestack/ui/core/template/template.haml +1 -1
  212. data/app/concepts/matestack/ui/core/textarea/textarea.haml +4 -1
  213. data/app/concepts/matestack/ui/core/tfoot/tfoot.haml +1 -1
  214. data/app/concepts/matestack/ui/core/tfoot/tfoot.rb +0 -1
  215. data/app/concepts/matestack/ui/core/th/th.haml +3 -3
  216. data/app/concepts/matestack/ui/core/th/th.rb +2 -1
  217. data/app/concepts/matestack/ui/core/thead/thead.haml +1 -1
  218. data/app/concepts/matestack/ui/core/thead/thead.rb +0 -1
  219. data/app/concepts/matestack/ui/core/time/time.haml +1 -1
  220. data/app/concepts/matestack/ui/core/time/time.rb +1 -7
  221. data/app/concepts/matestack/ui/core/toggle/toggle.haml +1 -1
  222. data/app/concepts/matestack/ui/core/toggle/toggle.rb +4 -5
  223. data/app/concepts/matestack/ui/core/tr/tr.haml +1 -1
  224. data/app/concepts/matestack/ui/core/tr/tr.rb +0 -1
  225. data/app/concepts/matestack/ui/core/transition/transition.haml +3 -3
  226. data/app/concepts/matestack/ui/core/transition/transition.rb +13 -7
  227. data/app/concepts/matestack/ui/core/u/u.haml +3 -3
  228. data/app/concepts/matestack/ui/core/u/u.rb +1 -1
  229. data/app/concepts/matestack/ui/core/ul/ul.haml +1 -1
  230. data/app/concepts/matestack/ui/core/ul/ul.rb +0 -1
  231. data/app/concepts/matestack/ui/core/unescaped/unescaped.rb +2 -0
  232. data/app/concepts/matestack/ui/core/var/var.haml +3 -3
  233. data/app/concepts/matestack/ui/core/var/var.rb +1 -0
  234. data/app/concepts/matestack/ui/core/video/video.haml +2 -2
  235. data/app/concepts/matestack/ui/core/video/video.rb +3 -13
  236. data/app/concepts/matestack/ui/core/wbr/wbr.haml +5 -1
  237. data/app/concepts/matestack/ui/core/wbr/wbr.rb +1 -0
  238. data/app/concepts/matestack/ui/core/youtube/youtube.haml +1 -1
  239. data/app/concepts/matestack/ui/core/youtube/youtube.rb +18 -16
  240. data/app/helpers/matestack/ui/core/application_helper.rb +6 -2
  241. data/app/javascript/matestack-ui-core/index.js +12 -2
  242. data/app/lib/matestack/ui/core/has_view_context.rb +4 -2
  243. data/app/lib/matestack/ui/core/html_attributes.rb +1 -1
  244. data/app/lib/matestack/ui/core/properties.rb +95 -22
  245. data/app/lib/matestack/ui/core/rendering/main_renderer.rb +11 -7
  246. data/lib/matestack/ui/core/components.rb +6 -2
  247. data/lib/matestack/ui/core/version.rb +1 -1
  248. data/vendor/assets/javascripts/dist/matestack-ui-core.js +773 -99
  249. data/vendor/assets/javascripts/dist/matestack-ui-core.js.map +1 -1
  250. data/vendor/assets/javascripts/dist/matestack-ui-core.min.js +1 -1
  251. data/vendor/assets/javascripts/dist/matestack-ui-core.min.js.br +0 -0
  252. data/vendor/assets/javascripts/dist/matestack-ui-core.min.js.gz +0 -0
  253. data/vendor/assets/javascripts/dist/matestack-ui-core.min.js.map +1 -1
  254. data/vendor/assets/javascripts/dist/matestack-ui-core.min.js.map.br +0 -0
  255. data/vendor/assets/javascripts/dist/matestack-ui-core.min.js.map.gz +0 -0
  256. metadata +29 -8
  257. data/app/concepts/matestack/ui/core/collection/filter/input/input.haml +0 -2
  258. data/app/concepts/matestack/ui/core/component/rerender.rb +0 -8
  259. data/app/concepts/matestack/ui/core/form/select/select.haml +0 -9
@@ -1,4 +1,4 @@
1
- %abbr{@tag_attributes}
1
+ %abbr{ html_attributes }
2
2
  - if text.blank? && block_given?
3
3
  = yield
4
4
  - else
@@ -1,13 +1,5 @@
1
1
  module Matestack::Ui::Core::Abbr
2
2
  class Abbr < Matestack::Ui::Core::Component::Static
3
- requires :title
4
3
  optional :text
5
-
6
- def setup
7
- @tag_attributes.merge!({
8
- "title": title
9
- })
10
- end
11
-
12
4
  end
13
5
  end
@@ -1,3 +1,3 @@
1
- %a{@tag_attributes, "@click.prevent": "perform", "href": action_path}
1
+ %a{ html_attributes, "@click.prevent": "perform", "href": action_path }
2
2
  - if block_given?
3
3
  = yield
@@ -1,6 +1,6 @@
1
- %component{dynamic_tag_attributes}
1
+ %component{ dynamic_tag_attributes }
2
2
  %div
3
- %div{"v-if": "asyncTemplate == null"}
3
+ %div{ "v-if": "asyncTemplate == null" }
4
4
  = render_content
5
- %div{"v-if": "asyncTemplate != null"}
6
- %v-runtime-template{":template":"asyncTemplate"}
5
+ %div{ "v-if": "asyncTemplate != null" }
6
+ %v-runtime-template{ ":template":"asyncTemplate" }
@@ -1,5 +1,5 @@
1
- %address{@tag_attributes}
2
- - if text.nil? && block_given?
1
+ %address{ html_attributes }
2
+ - if text.blank? && block_given?
3
3
  = yield
4
4
  - else
5
5
  = text
@@ -40,7 +40,11 @@ const store = new Vuex.Store({
40
40
  return getScrollParent(node.parentNode)
41
41
  }
42
42
  }
43
- getScrollParent(document.getElementsByClassName("matestack-page-root")[0]).scrollTop = 0
43
+ var scrollParent = getScrollParent(document.getElementsByClassName("matestack-page-root")[0])
44
+ if(scrollParent){
45
+ scrollParent.scrollTop = 0;
46
+ }
47
+ // getScrollParent(document.getElementsByClassName("matestack-page-root")[0]).scrollTop = 0
44
48
  }
45
49
  },
46
50
  actions: {
@@ -1 +1 @@
1
- %area{@tag_attributes}
1
+ %area{ html_attributes, "coords": coords.join(',') }
@@ -1,20 +1,6 @@
1
1
  module Matestack::Ui::Core::Area
2
2
  class Area < Matestack::Ui::Core::Component::Static
3
- optional :alt, :coords, :download, :href, :hreflang, :media, :rel, :shape, :target, :type
4
-
5
- def setup
6
- @tag_attributes.merge!({
7
- alt: alt,
8
- coords: coords.join(','),
9
- download: download,
10
- href: href,
11
- hreflang: hreflang,
12
- media: media,
13
- rel: rel,
14
- shape: shape,
15
- target: target,
16
- type: type
17
- })
18
- end
3
+ html_attributes :alt, :download, :href, :hreflang, :media, :rel, :shape, :target, :type
4
+ optional :coords
19
5
  end
20
6
  end
@@ -1,5 +1,5 @@
1
- %article{@tag_attributes}
2
- - if options[:text].nil? && block_given?
1
+ %article{ html_attributes }
2
+ - if text.nil? && block_given?
3
3
  = yield
4
4
  - else
5
- = options[:text]
5
+ = text
@@ -1,5 +1,5 @@
1
1
  module Matestack::Ui::Core::Article
2
2
  class Article < Matestack::Ui::Core::Component::Static
3
-
3
+ optional :text
4
4
  end
5
5
  end
@@ -1,3 +1,3 @@
1
- %aside{@tag_attributes}
1
+ %aside{ html_attributes }
2
2
  - if block_given?
3
3
  = yield
@@ -1,5 +1,4 @@
1
1
  module Matestack::Ui::Core::Aside
2
2
  class Aside < Matestack::Ui::Core::Component::Static
3
-
4
3
  end
5
4
  end
@@ -76,19 +76,9 @@ const componentDef = {
76
76
  },
77
77
  created: function () {
78
78
  const self = this
79
- if(this.componentConfig["show_on"] != undefined){
80
- this.showing = false
81
- var show_events = this.componentConfig["show_on"].split(",")
82
- show_events.forEach(show_event => matestackEventHub.$on(show_event.trim(), self.show));
83
- }
84
- if(this.componentConfig["hide_on"] != undefined){
85
- var hide_events = this.componentConfig["hide_on"].split(",")
86
- hide_events.forEach(hide_event => matestackEventHub.$on(hide_event.trim(), self.hide));
87
- }
88
- if(this.componentConfig["rerender_on"] != undefined){
89
- var rerender_events = this.componentConfig["rerender_on"].split(",")
90
- rerender_events.forEach(rerender_event => matestackEventHub.$on(rerender_event.trim(), self.rerender));
91
- }
79
+ self.registerEvents(this.componentConfig['show_on'], self.show)
80
+ self.registerEvents(this.componentConfig['hide_on'], self.hide)
81
+ self.registerEvents(this.componentConfig['rerender_on'], self.rerender)
92
82
  if(this.componentConfig["show_on"] != undefined){
93
83
  this.showing = false
94
84
  }
@@ -106,21 +96,9 @@ const componentDef = {
106
96
  beforeDestroy: function() {
107
97
  const self = this
108
98
  clearTimeout(self.hideAfterTimeout)
109
- matestackEventHub.$off(this.componentConfig["rerender_on"], self.rerender);
110
- matestackEventHub.$off(this.componentConfig["show_on"], self.show);
111
- matestackEventHub.$off(this.componentConfig["hide_on"], self.hide);
112
- if(this.componentConfig["show_on"] != undefined){
113
- var shown_events = this.componentConfig["show_on"].split(",")
114
- shown_events.forEach(show_event => matestackEventHub.$off(show_event.trim(), self.show));
115
- }
116
- if(this.componentConfig["hide_on"] != undefined){
117
- var hiden_events = this.componentConfig["hide_on"].split(",")
118
- hiden_events.forEach(hide_event => matestackEventHub.$off(hide_event.trim(), self.hide));
119
- }
120
- if(this.componentConfig["rerender_on"] != undefined){
121
- var rerender_events = this.componentConfig["rerender_on"].split(",")
122
- rerender_events.forEach(rerender_event => matestackEventHub.$off(rerender_event.trim(), self.rerender));
123
- }
99
+ self.removeEvents(this.componentConfig["show_on"], self.show)
100
+ self.removeEvents(this.componentConfig["hide_on"], self.hide)
101
+ self.removeEvents(this.componentConfig["rerender_on"], self.rerender)
124
102
  },
125
103
  components: {
126
104
  VRuntimeTemplate: VRuntimeTemplate
@@ -1,21 +1,21 @@
1
1
  module Matestack::Ui::Core::Async
2
- class Async < Matestack::Ui::Core::Component::Rerender
2
+ class Async < Matestack::Ui::Core::Component::Dynamic
3
3
  vue_js_component_name "matestack-ui-core-async"
4
4
 
5
- optional :id # will be required in 1.0.0
5
+ requires :id # required since 1.1.0
6
6
 
7
7
  def initialize(*args)
8
8
  super
9
- ActiveSupport::Deprecation.warn(
10
- 'Calling async components without id is deprecated. Instead provide a unique id for async components.'
11
- ) if id.blank?
12
- @component_config[:component_key] = id || "async_#{Digest::SHA256.hexdigest(caller[3])}"
13
- if @included_config.present? && @included_config[:isolated_parent_class].present?
14
- @component_config[:parent_class] = @included_config[:isolated_parent_class]
9
+ component_config[:component_key] = id
10
+ if included_config.present? && included_config[:isolated_parent_class].present?
11
+ component_config[:parent_class] = included_config[:isolated_parent_class]
15
12
  end
16
- @tag_attributes.merge!({
13
+ end
14
+
15
+ def children_wrapper_attributes
16
+ html_attributes.merge({
17
17
  "v-if": "showing",
18
- id: @component_config[:component_key]
18
+ id: component_config[:component_key]
19
19
  })
20
20
  end
21
21
 
@@ -30,7 +30,7 @@ module Matestack::Ui::Core::Async
30
30
  end
31
31
 
32
32
  def get_component_key
33
- @component_config[:component_key]
33
+ component_config[:component_key]
34
34
  end
35
35
 
36
36
  end
@@ -1,2 +1,2 @@
1
- %div{@tag_attributes.merge(class: "matestack-async-component-root")}
1
+ %div{ children_wrapper_attributes.merge(class: "matestack-async-component-root") }
2
2
  =yield
@@ -1,5 +1,5 @@
1
- %b{@tag_attributes}
2
- - if options[:text].nil? && block_given?
1
+ %b{ html_attributes }
2
+ - if text.nil? && block_given?
3
3
  = yield
4
4
  - else
5
- = options[:text]
5
+ = text
@@ -1,5 +1,5 @@
1
1
  module Matestack::Ui::Core::B
2
2
  class B < Matestack::Ui::Core::Component::Static
3
-
3
+ optional :text
4
4
  end
5
5
  end
@@ -1,5 +1,5 @@
1
- %bdi{@tag_attributes}
2
- - if options[:text].blank? && block_given?
1
+ %bdi{ html_attributes }
2
+ - if text.blank? && block_given?
3
3
  = yield
4
4
  - else
5
- = options[:text]
5
+ = text
@@ -1,4 +1,5 @@
1
1
  module Matestack::Ui::Core::Bdi
2
2
  class Bdi < Matestack::Ui::Core::Component::Static
3
+ optional :text
3
4
  end
4
5
  end
@@ -1,5 +1,5 @@
1
- %bdo{@tag_attributes}
2
- - if options[:text].blank? && block_given?
1
+ %bdo{ html_attributes }
2
+ - if text.blank? && block_given?
3
3
  = yield
4
4
  - else
5
- = options[:text]
5
+ = text
@@ -1,11 +1,6 @@
1
1
  module Matestack::Ui::Core::Bdo
2
2
  class Bdo < Matestack::Ui::Core::Component::Static
3
- requires :dir
4
-
5
- def setup
6
- @tag_attributes.merge!({
7
- "dir": options[:dir]
8
- })
9
- end
3
+ html_attributes :dir
4
+ optional :text
10
5
  end
11
6
  end
@@ -1,5 +1,5 @@
1
- %blockquote{@tag_attributes}
2
- - if options[:text].nil? && block_given?
1
+ %blockquote{ html_attributes }
2
+ - if text.nil? && block_given?
3
3
  = yield
4
4
  - else
5
- = options[:text]
5
+ = text
@@ -1,11 +1,6 @@
1
1
  module Matestack::Ui::Core::Blockquote
2
2
  class Blockquote < Matestack::Ui::Core::Component::Static
3
-
4
- def setup
5
- @tag_attributes.merge!({
6
- "cite": options[:cite]
7
- })
8
- end
9
-
3
+ html_attributes :cite
4
+ optional :text
10
5
  end
11
6
  end
@@ -1,5 +1,5 @@
1
- - unless options[:times].nil?
2
- - options[:times].times do
3
- %br{@tag_attributes}
1
+ - unless times.nil?
2
+ - times.times do
3
+ %br{ html_attributes }
4
4
  - else
5
- %br{@tag_attributes}
5
+ %br{ html_attributes }
@@ -1,5 +1,5 @@
1
1
  module Matestack::Ui::Core::Br
2
2
  class Br < Matestack::Ui::Core::Component::Static
3
-
3
+ optional :times
4
4
  end
5
5
  end
@@ -1,5 +1,5 @@
1
- %button{@tag_attributes}
2
- - if options[:text].nil? && block_given?
1
+ %button{ html_attributes }
2
+ - if text.nil? && block_given?
3
3
  = yield
4
4
  - else
5
- = options[:text]
5
+ = text
@@ -1,11 +1,7 @@
1
1
  module Matestack::Ui::Core::Button
2
2
  class Button < Matestack::Ui::Core::Component::Static
3
-
4
- def setup
5
- @tag_attributes.merge!({
6
- "disabled": options[:disabled] ||= nil
7
- })
8
- end
9
-
3
+ html_attributes :autofocus, :disabled, :form, :formaction, :formenctype, :formmethod,
4
+ :formnovalidate, :formtarget, :name, :type, :value
5
+ optional :text
10
6
  end
11
7
  end
@@ -0,0 +1,4 @@
1
+ %component{dynamic_tag_attributes.merge('initial-template': "#{render_content}")}
2
+ %div{class: "matestack-cable-component-container", "v-bind:class": "{ 'loading': loading === true }"}
3
+ %div{class: "matestack-cable-component-wrapper", "v-if": "cableTemplate != null", "v-bind:class": "{ 'loading': loading === true }"}
4
+ %v-runtime-template{":template":"cableTemplate"}
@@ -0,0 +1,100 @@
1
+ import Vue from 'vue/dist/vue.esm'
2
+ import VRuntimeTemplate from "v-runtime-template"
3
+ import matestackEventHub from '../js/event-hub'
4
+ import componentMixin from '../component/component'
5
+
6
+ const componentDef = {
7
+ mixins: [componentMixin],
8
+ props: {
9
+ initialTemplate: String,
10
+ },
11
+ data: function(){
12
+ return {
13
+ cableTemplate: null,
14
+ cableTemplateDomElement: null,
15
+ loading: false,
16
+ event: {
17
+ data: {}
18
+ }
19
+ }
20
+ },
21
+ methods: {
22
+ append: function(payload){
23
+ var html = this.formatPayload(payload)
24
+ this.cableTemplateDomElement.insertAdjacentHTML(
25
+ 'beforeend',
26
+ html.join('')
27
+ )
28
+ this.updateCableTemplate()
29
+ },
30
+ prepend: function(payload){
31
+ var html = this.formatPayload(payload)
32
+ this.cableTemplateDomElement.insertAdjacentHTML(
33
+ 'afterbegin',
34
+ html.join('')
35
+ )
36
+ this.updateCableTemplate()
37
+ },
38
+ delete: function(payload){
39
+ var ids = this.formatPayload(payload)
40
+ ids.forEach(id =>
41
+ this.cableTemplateDomElement.querySelector('#' + id).remove()
42
+ )
43
+ this.updateCableTemplate()
44
+ },
45
+ update: function(payload){
46
+ const self = this
47
+ var html = this.formatPayload(payload)
48
+ html.forEach(function(elem){
49
+ var dom_elem = document.createElement('div')
50
+ dom_elem.innerHTML = elem
51
+ var id = dom_elem.firstChild.id
52
+ var old_elem = self.cableTemplateDomElement.querySelector('#' + id)
53
+ old_elem.parentNode.replaceChild(dom_elem.firstChild, old_elem)
54
+ })
55
+ this.updateCableTemplate()
56
+ },
57
+ replace: function(payload){
58
+ var html = this.formatPayload(payload)
59
+ this.cableTemplateDomElement.innerHTML = html.join('')
60
+ this.updateCableTemplate()
61
+ },
62
+ updateCableTemplate: function(){
63
+ this.cableTemplate = this.cableTemplateDomElement.outerHTML
64
+ },
65
+ formatPayload: function(payload){
66
+ if(!Array.isArray(payload.data)){
67
+ return [payload.data]
68
+ }
69
+ return payload.data
70
+ },
71
+ },
72
+ mounted: function() {
73
+ const self = this
74
+ var dom_elem = document.createElement('div')
75
+ dom_elem.innerHTML = this.initialTemplate
76
+ this.cableTemplateDomElement = dom_elem.querySelector("#" + this.componentConfig["id"])
77
+ this.cableTemplate = this.cableTemplateDomElement.outerHTML
78
+ this.registerEvents(this.componentConfig['append_on'], self.append)
79
+ this.registerEvents(this.componentConfig['prepend_on'], self.prepend)
80
+ this.registerEvents(this.componentConfig['delete_on'], self.delete)
81
+ this.registerEvents(this.componentConfig['update_on'], self.update)
82
+ this.registerEvents(this.componentConfig['replace_on'], self.replace)
83
+ },
84
+ beforeDestroy: function() {
85
+ const self = this
86
+ this.cableTemplate = null
87
+ this.removeEvents(this.componentConfig['append_on'], self.append)
88
+ this.removeEvents(this.componentConfig['prepend_on'], self.prepend)
89
+ this.removeEvents(this.componentConfig['delete_on'], self.delete)
90
+ this.removeEvents(this.componentConfig['update_on'], self.update)
91
+ this.removeEvents(this.componentConfig['replace_on'], self.replace)
92
+ },
93
+ components: {
94
+ VRuntimeTemplate: VRuntimeTemplate
95
+ }
96
+ }
97
+
98
+ let component = Vue.component('matestack-ui-core-cable', componentDef)
99
+
100
+ export default componentDef