lookbook 1.5.2 → 2.3.7

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 (1204) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +33 -35
  3. data/app/components/lookbook/base_component.rb +3 -1
  4. data/app/components/lookbook/button/component.html.erb +14 -25
  5. data/app/components/lookbook/button/component.js +24 -7
  6. data/app/components/lookbook/button/component.rb +16 -25
  7. data/app/components/lookbook/code/component.rb +0 -2
  8. data/app/components/lookbook/code/highlight_github.css +16 -17
  9. data/app/components/lookbook/copy_button/component.html.erb +5 -5
  10. data/app/components/lookbook/copy_button/component.js +1 -1
  11. data/app/components/lookbook/copy_button/component.rb +6 -3
  12. data/app/components/lookbook/debug_menu/component.html.erb +3 -2
  13. data/app/components/lookbook/debug_menu/component.rb +12 -1
  14. data/app/components/lookbook/dimensions_display/component.html.erb +4 -4
  15. data/app/components/lookbook/dimensions_display/component.js +4 -7
  16. data/app/components/lookbook/display_options/editor/component.html.erb +1 -1
  17. data/app/components/lookbook/display_options/field/component.css +0 -26
  18. data/app/components/lookbook/display_options/field/component.html.erb +1 -1
  19. data/app/components/lookbook/display_options/field/component.js +1 -1
  20. data/app/components/lookbook/embed/component.html.erb +6 -51
  21. data/app/components/lookbook/embed/component.rb +17 -16
  22. data/app/components/lookbook/embed/inspector/component.html.erb +117 -0
  23. data/app/components/lookbook/embed/inspector/component.js +58 -0
  24. data/app/components/lookbook/embed/inspector/component.rb +64 -0
  25. data/app/components/lookbook/embed_code_dropdown/component.css +19 -0
  26. data/app/components/lookbook/embed_code_dropdown/component.html.erb +64 -0
  27. data/app/components/lookbook/embed_code_dropdown/component.js +3 -0
  28. data/app/components/lookbook/embed_code_dropdown/component.rb +51 -0
  29. data/app/components/lookbook/file_source/component.html.erb +9 -0
  30. data/app/components/lookbook/file_source/component.rb +73 -0
  31. data/app/components/lookbook/filter/component.html.erb +15 -15
  32. data/app/components/lookbook/header/component.css +12 -0
  33. data/app/components/lookbook/header/component.html.erb +28 -19
  34. data/app/components/lookbook/header/component.rb +9 -3
  35. data/app/components/lookbook/icon/component.css +9 -1
  36. data/app/components/lookbook/icon/component.html.erb +3 -3
  37. data/app/components/lookbook/icon/component.rb +7 -8
  38. data/app/components/lookbook/icon_button/component.html.erb +20 -0
  39. data/app/components/lookbook/icon_button/component.rb +46 -0
  40. data/app/components/lookbook/logo/component.html.erb +6 -0
  41. data/app/components/lookbook/logo/component.rb +15 -0
  42. data/app/components/lookbook/message/component.css +34 -0
  43. data/app/components/lookbook/message/component.html.erb +26 -0
  44. data/app/components/lookbook/message/component.rb +13 -0
  45. data/app/components/lookbook/nav/component.html.erb +1 -2
  46. data/app/components/lookbook/nav/directory/component.html.erb +4 -4
  47. data/app/components/lookbook/nav/entity/component.html.erb +9 -6
  48. data/app/components/lookbook/nav/entity/component.rb +3 -3
  49. data/app/components/lookbook/nav/item/component.js +9 -11
  50. data/app/components/lookbook/nav/item/component.rb +1 -1
  51. data/app/components/lookbook/page_tabs/component.html.erb +4 -4
  52. data/app/components/lookbook/params/editor/component.html.erb +1 -1
  53. data/app/components/lookbook/params/editor/component.rb +2 -1
  54. data/app/components/lookbook/params/field/component.css +3 -3
  55. data/app/components/lookbook/params/field/component.rb +2 -2
  56. data/app/components/lookbook/prose/component.css +14 -1
  57. data/app/components/lookbook/prose/component.html.erb +6 -1
  58. data/app/components/lookbook/prose/component.rb +3 -5
  59. data/app/components/lookbook/split_layout/component.html.erb +4 -4
  60. data/app/components/lookbook/tab_panels/component.rb +1 -1
  61. data/app/components/lookbook/tabs/component.html.erb +2 -2
  62. data/app/components/lookbook/tabs/component.js +2 -2
  63. data/app/components/lookbook/tabs/dropdown_tab/component.html.erb +1 -1
  64. data/app/components/lookbook/tabs/tab/component.html.erb +2 -2
  65. data/app/components/lookbook/tag_component.rb +10 -2
  66. data/app/components/lookbook/text_button/component.html.erb +26 -0
  67. data/app/components/lookbook/text_button/component.rb +42 -0
  68. data/app/components/lookbook/toolbar/component.html.erb +1 -1
  69. data/app/components/lookbook/viewport/component.html.erb +8 -8
  70. data/app/components/lookbook/viewport/component.rb +0 -4
  71. data/app/controllers/concerns/lookbook/targetable_concern.rb +27 -35
  72. data/app/controllers/concerns/lookbook/with_panels_concern.rb +30 -0
  73. data/app/controllers/concerns/lookbook/with_preview_controller_concern.rb +24 -5
  74. data/app/controllers/lookbook/application_controller.rb +55 -24
  75. data/app/controllers/lookbook/embeds_controller.rb +147 -0
  76. data/app/controllers/lookbook/inspector_controller.rb +5 -32
  77. data/app/controllers/lookbook/page_controller.rb +8 -7
  78. data/app/controllers/lookbook/pages_controller.rb +17 -30
  79. data/app/controllers/lookbook/preview_controller.rb +45 -0
  80. data/app/controllers/lookbook/previews_controller.rb +36 -32
  81. data/app/helpers/lookbook/application_helper.rb +12 -18
  82. data/app/views/layouts/lookbook/application.html.erb +104 -60
  83. data/app/views/layouts/lookbook/embed.html.erb +34 -0
  84. data/app/views/layouts/lookbook/skeleton.html.erb +16 -15
  85. data/app/views/lookbook/embeds/show.html.erb +12 -0
  86. data/app/views/lookbook/errors/default.html.erb +40 -0
  87. data/app/views/lookbook/errors/not_found.html.erb +10 -0
  88. data/app/views/lookbook/index.html.erb +39 -24
  89. data/app/views/lookbook/inspector/inputs/_color.html.erb +2 -1
  90. data/app/views/lookbook/inspector/inputs/_text_two_step.html.erb +19 -0
  91. data/app/views/lookbook/inspector/inputs/_toggle.html.erb +1 -1
  92. data/app/views/lookbook/inspector/panels/_notes.html.erb +1 -1
  93. data/app/views/lookbook/inspector/panels/_output.html.erb +3 -3
  94. data/app/views/lookbook/inspector/panels/_preview.html.erb +1 -0
  95. data/app/views/lookbook/inspector/panels/_source.html.erb +6 -6
  96. data/app/views/lookbook/inspector/show.html.erb +142 -123
  97. data/app/views/lookbook/pages/show.html.erb +91 -36
  98. data/app/views/lookbook/partials/_blank_slate.html.erb +7 -0
  99. data/app/views/lookbook/partials/_iframe_content_scripts.html.erb +1 -0
  100. data/app/views/lookbook/partials/_user_styles.html.erb +5 -0
  101. data/app/views/lookbook/previews/group.html.erb +15 -0
  102. data/app/views/lookbook/previews/preview.html.erb +13 -0
  103. data/app/views/lookbook/previews/show.html.erb +1 -0
  104. data/assets/css/fonts.css +33 -0
  105. data/{app/assets/lookbook → assets}/css/lookbook.css +23 -3
  106. data/{app/assets/lookbook → assets}/css/themes/blue.css +14 -1
  107. data/{app/assets/lookbook → assets}/css/themes/green.css +14 -1
  108. data/{app/assets/lookbook → assets}/css/themes/indigo.css +14 -1
  109. data/{app/assets/lookbook → assets}/css/themes/rose.css +14 -1
  110. data/{app/assets/lookbook → assets}/css/themes/zinc.css +14 -1
  111. data/{app/assets/lookbook → assets}/css/tooltip.css +9 -6
  112. data/assets/fonts/Inter-italic.var.woff2 +0 -0
  113. data/assets/fonts/Inter-roman.var.woff2 +0 -0
  114. data/assets/fonts/SourceCodeVariable-Italic.ttf.woff2 +0 -0
  115. data/assets/fonts/SourceCodeVariable-Roman.ttf.woff2 +0 -0
  116. data/assets/icons/accessibility.svg +1 -0
  117. data/assets/icons/activity.svg +1 -0
  118. data/assets/icons/air-vent.svg +1 -0
  119. data/assets/icons/airplay.svg +1 -0
  120. data/assets/icons/alarm-check.svg +1 -0
  121. data/assets/icons/alarm-clock-off.svg +1 -0
  122. data/assets/icons/alarm-clock.svg +1 -0
  123. data/assets/icons/alarm-minus.svg +1 -0
  124. data/assets/icons/alarm-plus.svg +1 -0
  125. data/assets/icons/album.svg +1 -0
  126. data/assets/icons/alert-circle.svg +1 -0
  127. data/assets/icons/alert-octagon.svg +1 -0
  128. data/assets/icons/alert-triangle.svg +1 -0
  129. data/assets/icons/align-center-horizontal.svg +1 -0
  130. data/assets/icons/align-center-vertical.svg +1 -0
  131. data/assets/icons/align-center.svg +1 -0
  132. data/assets/icons/align-end-horizontal.svg +1 -0
  133. data/assets/icons/align-end-vertical.svg +1 -0
  134. data/assets/icons/align-horizontal-distribute-center.svg +1 -0
  135. data/assets/icons/align-horizontal-distribute-end.svg +1 -0
  136. data/assets/icons/align-horizontal-distribute-start.svg +1 -0
  137. data/assets/icons/align-horizontal-justify-center.svg +1 -0
  138. data/assets/icons/align-horizontal-justify-end.svg +1 -0
  139. data/assets/icons/align-horizontal-justify-start.svg +1 -0
  140. data/assets/icons/align-horizontal-space-around.svg +1 -0
  141. data/assets/icons/align-horizontal-space-between.svg +1 -0
  142. data/assets/icons/align-justify.svg +1 -0
  143. data/assets/icons/align-left.svg +1 -0
  144. data/assets/icons/align-right.svg +1 -0
  145. data/assets/icons/align-start-horizontal.svg +1 -0
  146. data/assets/icons/align-start-vertical.svg +1 -0
  147. data/assets/icons/align-vertical-distribute-center.svg +1 -0
  148. data/assets/icons/align-vertical-distribute-end.svg +1 -0
  149. data/assets/icons/align-vertical-distribute-start.svg +1 -0
  150. data/assets/icons/align-vertical-justify-center.svg +1 -0
  151. data/assets/icons/align-vertical-justify-end.svg +1 -0
  152. data/assets/icons/align-vertical-justify-start.svg +1 -0
  153. data/assets/icons/align-vertical-space-around.svg +1 -0
  154. data/assets/icons/align-vertical-space-between.svg +1 -0
  155. data/assets/icons/anchor.svg +1 -0
  156. data/assets/icons/angry.svg +1 -0
  157. data/assets/icons/annoyed.svg +1 -0
  158. data/assets/icons/aperture.svg +1 -0
  159. data/assets/icons/apple.svg +1 -0
  160. data/assets/icons/archive-restore.svg +1 -0
  161. data/assets/icons/archive.svg +1 -0
  162. data/assets/icons/armchair.svg +1 -0
  163. data/assets/icons/arrow-big-down.svg +1 -0
  164. data/assets/icons/arrow-big-left.svg +1 -0
  165. data/assets/icons/arrow-big-right.svg +1 -0
  166. data/assets/icons/arrow-big-up.svg +1 -0
  167. data/assets/icons/arrow-down-circle.svg +1 -0
  168. data/assets/icons/arrow-down-left.svg +1 -0
  169. data/assets/icons/arrow-down-right.svg +1 -0
  170. data/assets/icons/arrow-down.svg +1 -0
  171. data/assets/icons/arrow-left-circle.svg +1 -0
  172. data/assets/icons/arrow-left-right.svg +1 -0
  173. data/assets/icons/arrow-left.svg +1 -0
  174. data/assets/icons/arrow-right-circle.svg +1 -0
  175. data/assets/icons/arrow-right.svg +1 -0
  176. data/assets/icons/arrow-up-circle.svg +1 -0
  177. data/assets/icons/arrow-up-down.svg +1 -0
  178. data/assets/icons/arrow-up-left.svg +1 -0
  179. data/assets/icons/arrow-up-right.svg +1 -0
  180. data/assets/icons/arrow-up.svg +1 -0
  181. data/assets/icons/asterisk.svg +1 -0
  182. data/assets/icons/at-sign.svg +1 -0
  183. data/assets/icons/award.svg +1 -0
  184. data/assets/icons/axe.svg +1 -0
  185. data/assets/icons/axis-3d.svg +1 -0
  186. data/assets/icons/baby.svg +1 -0
  187. data/assets/icons/backpack.svg +1 -0
  188. data/assets/icons/baggage-claim.svg +1 -0
  189. data/assets/icons/banana.svg +1 -0
  190. data/assets/icons/banknote.svg +1 -0
  191. data/assets/icons/bar-chart-2.svg +1 -0
  192. data/assets/icons/bar-chart-3.svg +1 -0
  193. data/assets/icons/bar-chart-4.svg +1 -0
  194. data/assets/icons/bar-chart-horizontal.svg +1 -0
  195. data/assets/icons/bar-chart.svg +1 -0
  196. data/assets/icons/baseline.svg +1 -0
  197. data/assets/icons/bath.svg +1 -0
  198. data/assets/icons/battery-charging.svg +1 -0
  199. data/assets/icons/battery-full.svg +1 -0
  200. data/assets/icons/battery-low.svg +1 -0
  201. data/assets/icons/battery-medium.svg +1 -0
  202. data/assets/icons/battery-warning.svg +1 -0
  203. data/assets/icons/battery.svg +1 -0
  204. data/assets/icons/beaker.svg +1 -0
  205. data/assets/icons/bean-off.svg +1 -0
  206. data/assets/icons/bean.svg +1 -0
  207. data/assets/icons/bed-double.svg +1 -0
  208. data/assets/icons/bed-single.svg +1 -0
  209. data/assets/icons/bed.svg +1 -0
  210. data/assets/icons/beef.svg +1 -0
  211. data/assets/icons/beer.svg +1 -0
  212. data/assets/icons/bell-minus.svg +1 -0
  213. data/assets/icons/bell-off.svg +1 -0
  214. data/assets/icons/bell-plus.svg +1 -0
  215. data/assets/icons/bell-ring.svg +1 -0
  216. data/assets/icons/bell.svg +1 -0
  217. data/assets/icons/bike.svg +1 -0
  218. data/assets/icons/binary.svg +1 -0
  219. data/assets/icons/bird.svg +1 -0
  220. data/assets/icons/bitcoin.svg +1 -0
  221. data/assets/icons/blinds.svg +1 -0
  222. data/assets/icons/bluetooth-connected.svg +1 -0
  223. data/assets/icons/bluetooth-off.svg +1 -0
  224. data/assets/icons/bluetooth-searching.svg +1 -0
  225. data/assets/icons/bluetooth.svg +1 -0
  226. data/assets/icons/bold.svg +1 -0
  227. data/assets/icons/bomb.svg +1 -0
  228. data/assets/icons/bone.svg +1 -0
  229. data/assets/icons/book-open-check.svg +1 -0
  230. data/assets/icons/book-open.svg +1 -0
  231. data/assets/icons/book.svg +1 -0
  232. data/assets/icons/bookmark-minus.svg +1 -0
  233. data/assets/icons/bookmark-plus.svg +1 -0
  234. data/assets/icons/bookmark.svg +1 -0
  235. data/assets/icons/bot.svg +1 -0
  236. data/assets/icons/box-select.svg +1 -0
  237. data/assets/icons/box.svg +1 -0
  238. data/assets/icons/boxes.svg +1 -0
  239. data/assets/icons/briefcase.svg +1 -0
  240. data/assets/icons/brush.svg +1 -0
  241. data/assets/icons/bug.svg +1 -0
  242. data/assets/icons/building-2.svg +1 -0
  243. data/assets/icons/building.svg +1 -0
  244. data/assets/icons/bus.svg +1 -0
  245. data/assets/icons/cake.svg +1 -0
  246. data/assets/icons/calculator.svg +1 -0
  247. data/assets/icons/calendar-check-2.svg +1 -0
  248. data/assets/icons/calendar-check.svg +1 -0
  249. data/assets/icons/calendar-clock.svg +1 -0
  250. data/assets/icons/calendar-days.svg +1 -0
  251. data/assets/icons/calendar-heart.svg +1 -0
  252. data/assets/icons/calendar-minus.svg +1 -0
  253. data/assets/icons/calendar-off.svg +1 -0
  254. data/assets/icons/calendar-plus.svg +1 -0
  255. data/assets/icons/calendar-range.svg +1 -0
  256. data/assets/icons/calendar-search.svg +1 -0
  257. data/assets/icons/calendar-x-2.svg +1 -0
  258. data/assets/icons/calendar-x.svg +1 -0
  259. data/assets/icons/calendar.svg +1 -0
  260. data/assets/icons/camera-off.svg +1 -0
  261. data/assets/icons/camera.svg +1 -0
  262. data/assets/icons/candy-off.svg +1 -0
  263. data/assets/icons/candy.svg +1 -0
  264. data/assets/icons/car.svg +1 -0
  265. data/assets/icons/carrot.svg +1 -0
  266. data/assets/icons/cast.svg +1 -0
  267. data/assets/icons/cat.svg +1 -0
  268. data/assets/icons/check-check.svg +1 -0
  269. data/assets/icons/check-circle-2.svg +1 -0
  270. data/assets/icons/check-circle.svg +1 -0
  271. data/assets/icons/check-square.svg +1 -0
  272. data/assets/icons/check.svg +1 -0
  273. data/assets/icons/chef-hat.svg +1 -0
  274. data/assets/icons/cherry.svg +1 -0
  275. data/assets/icons/chevron-down.svg +1 -0
  276. data/assets/icons/chevron-first.svg +1 -0
  277. data/assets/icons/chevron-last.svg +1 -0
  278. data/assets/icons/chevron-left.svg +1 -0
  279. data/assets/icons/chevron-right.svg +1 -0
  280. data/assets/icons/chevron-up.svg +1 -0
  281. data/assets/icons/chevrons-down-up.svg +1 -0
  282. data/assets/icons/chevrons-down.svg +1 -0
  283. data/assets/icons/chevrons-left-right.svg +1 -0
  284. data/assets/icons/chevrons-left.svg +1 -0
  285. data/assets/icons/chevrons-right-left.svg +1 -0
  286. data/assets/icons/chevrons-right.svg +1 -0
  287. data/assets/icons/chevrons-up-down.svg +1 -0
  288. data/assets/icons/chevrons-up.svg +1 -0
  289. data/assets/icons/chrome.svg +1 -0
  290. data/assets/icons/cigarette-off.svg +1 -0
  291. data/assets/icons/cigarette.svg +1 -0
  292. data/assets/icons/circle-dot.svg +1 -0
  293. data/assets/icons/circle-ellipsis.svg +1 -0
  294. data/assets/icons/circle-slashed.svg +1 -0
  295. data/assets/icons/circle.svg +1 -0
  296. data/assets/icons/citrus.svg +1 -0
  297. data/assets/icons/clapperboard.svg +1 -0
  298. data/assets/icons/clipboard-check.svg +1 -0
  299. data/assets/icons/clipboard-copy.svg +1 -0
  300. data/assets/icons/clipboard-edit.svg +1 -0
  301. data/assets/icons/clipboard-list.svg +1 -0
  302. data/assets/icons/clipboard-signature.svg +1 -0
  303. data/assets/icons/clipboard-type.svg +1 -0
  304. data/assets/icons/clipboard-x.svg +1 -0
  305. data/assets/icons/clipboard.svg +1 -0
  306. data/assets/icons/clock-1.svg +1 -0
  307. data/assets/icons/clock-10.svg +1 -0
  308. data/assets/icons/clock-11.svg +1 -0
  309. data/assets/icons/clock-12.svg +1 -0
  310. data/assets/icons/clock-2.svg +1 -0
  311. data/assets/icons/clock-3.svg +1 -0
  312. data/assets/icons/clock-4.svg +1 -0
  313. data/assets/icons/clock-5.svg +1 -0
  314. data/assets/icons/clock-6.svg +1 -0
  315. data/assets/icons/clock-7.svg +1 -0
  316. data/assets/icons/clock-8.svg +1 -0
  317. data/assets/icons/clock-9.svg +1 -0
  318. data/assets/icons/clock.svg +1 -0
  319. data/assets/icons/cloud-cog.svg +1 -0
  320. data/assets/icons/cloud-drizzle.svg +1 -0
  321. data/assets/icons/cloud-fog.svg +1 -0
  322. data/assets/icons/cloud-hail.svg +1 -0
  323. data/assets/icons/cloud-lightning.svg +1 -0
  324. data/assets/icons/cloud-moon-rain.svg +1 -0
  325. data/assets/icons/cloud-moon.svg +1 -0
  326. data/assets/icons/cloud-off.svg +1 -0
  327. data/assets/icons/cloud-rain-wind.svg +1 -0
  328. data/assets/icons/cloud-rain.svg +1 -0
  329. data/assets/icons/cloud-snow.svg +1 -0
  330. data/assets/icons/cloud-sun-rain.svg +1 -0
  331. data/assets/icons/cloud-sun.svg +1 -0
  332. data/assets/icons/cloud.svg +1 -0
  333. data/assets/icons/cloudy.svg +1 -0
  334. data/assets/icons/clover.svg +1 -0
  335. data/assets/icons/code-2.svg +1 -0
  336. data/assets/icons/code.svg +1 -0
  337. data/assets/icons/codepen.svg +1 -0
  338. data/assets/icons/codesandbox.svg +1 -0
  339. data/assets/icons/coffee.svg +1 -0
  340. data/assets/icons/cog.svg +1 -0
  341. data/assets/icons/coins.svg +1 -0
  342. data/assets/icons/columns.svg +1 -0
  343. data/assets/icons/command.svg +1 -0
  344. data/assets/icons/compass.svg +1 -0
  345. data/assets/icons/component.svg +1 -0
  346. data/assets/icons/concierge-bell.svg +1 -0
  347. data/assets/icons/construction.svg +1 -0
  348. data/assets/icons/contact.svg +1 -0
  349. data/assets/icons/contrast.svg +1 -0
  350. data/assets/icons/cookie.svg +1 -0
  351. data/assets/icons/copy.svg +1 -0
  352. data/assets/icons/copyleft.svg +1 -0
  353. data/assets/icons/copyright.svg +1 -0
  354. data/assets/icons/corner-down-left.svg +1 -0
  355. data/assets/icons/corner-down-right.svg +1 -0
  356. data/assets/icons/corner-left-down.svg +1 -0
  357. data/assets/icons/corner-left-up.svg +1 -0
  358. data/assets/icons/corner-right-down.svg +1 -0
  359. data/assets/icons/corner-right-up.svg +1 -0
  360. data/assets/icons/corner-up-left.svg +1 -0
  361. data/assets/icons/corner-up-right.svg +1 -0
  362. data/assets/icons/cpu.svg +1 -0
  363. data/assets/icons/creative-commons.svg +1 -0
  364. data/assets/icons/credit-card.svg +1 -0
  365. data/assets/icons/croissant.svg +1 -0
  366. data/assets/icons/crop.svg +1 -0
  367. data/assets/icons/cross.svg +1 -0
  368. data/assets/icons/crosshair.svg +1 -0
  369. data/assets/icons/crown.svg +1 -0
  370. data/assets/icons/cup-soda.svg +1 -0
  371. data/assets/icons/curly-braces.svg +1 -0
  372. data/assets/icons/currency.svg +1 -0
  373. data/assets/icons/database-backup.svg +1 -0
  374. data/assets/icons/database.svg +1 -0
  375. data/assets/icons/delete.svg +1 -0
  376. data/assets/icons/diamond.svg +1 -0
  377. data/assets/icons/dice-1.svg +1 -0
  378. data/assets/icons/dice-2.svg +1 -0
  379. data/assets/icons/dice-3.svg +1 -0
  380. data/assets/icons/dice-4.svg +1 -0
  381. data/assets/icons/dice-5.svg +1 -0
  382. data/assets/icons/dice-6.svg +1 -0
  383. data/assets/icons/dices.svg +1 -0
  384. data/assets/icons/diff.svg +1 -0
  385. data/assets/icons/disc.svg +1 -0
  386. data/assets/icons/divide-circle.svg +1 -0
  387. data/assets/icons/divide-square.svg +1 -0
  388. data/assets/icons/divide.svg +1 -0
  389. data/assets/icons/dna-off.svg +1 -0
  390. data/assets/icons/dna.svg +1 -0
  391. data/assets/icons/dog.svg +1 -0
  392. data/assets/icons/dollar-sign.svg +1 -0
  393. data/assets/icons/download-cloud.svg +1 -0
  394. data/assets/icons/download.svg +1 -0
  395. data/assets/icons/dribbble.svg +1 -0
  396. data/assets/icons/droplet.svg +1 -0
  397. data/assets/icons/droplets.svg +1 -0
  398. data/assets/icons/drumstick.svg +1 -0
  399. data/assets/icons/dumbbell.svg +1 -0
  400. data/assets/icons/ear-off.svg +1 -0
  401. data/assets/icons/ear.svg +1 -0
  402. data/assets/icons/edit-2.svg +1 -0
  403. data/assets/icons/edit-3.svg +1 -0
  404. data/assets/icons/edit.svg +1 -0
  405. data/assets/icons/egg-fried.svg +1 -0
  406. data/assets/icons/egg-off.svg +1 -0
  407. data/assets/icons/egg.svg +1 -0
  408. data/assets/icons/equal-not.svg +1 -0
  409. data/assets/icons/equal.svg +1 -0
  410. data/assets/icons/eraser.svg +1 -0
  411. data/assets/icons/euro.svg +1 -0
  412. data/assets/icons/expand.svg +1 -0
  413. data/assets/icons/external-link.svg +1 -0
  414. data/assets/icons/eye-off.svg +1 -0
  415. data/assets/icons/eye.svg +1 -0
  416. data/assets/icons/facebook.svg +1 -0
  417. data/assets/icons/factory.svg +1 -0
  418. data/assets/icons/fan.svg +1 -0
  419. data/assets/icons/fast-forward.svg +1 -0
  420. data/assets/icons/feather.svg +1 -0
  421. data/assets/icons/figma.svg +1 -0
  422. data/assets/icons/file-archive.svg +1 -0
  423. data/assets/icons/file-audio-2.svg +1 -0
  424. data/assets/icons/file-audio.svg +1 -0
  425. data/assets/icons/file-axis-3d.svg +1 -0
  426. data/assets/icons/file-badge-2.svg +1 -0
  427. data/assets/icons/file-badge.svg +1 -0
  428. data/assets/icons/file-bar-chart-2.svg +1 -0
  429. data/assets/icons/file-bar-chart.svg +1 -0
  430. data/assets/icons/file-box.svg +1 -0
  431. data/assets/icons/file-check-2.svg +1 -0
  432. data/assets/icons/file-check.svg +1 -0
  433. data/assets/icons/file-clock.svg +1 -0
  434. data/assets/icons/file-code.svg +1 -0
  435. data/assets/icons/file-cog-2.svg +1 -0
  436. data/assets/icons/file-cog.svg +1 -0
  437. data/assets/icons/file-diff.svg +1 -0
  438. data/assets/icons/file-digit.svg +1 -0
  439. data/assets/icons/file-down.svg +1 -0
  440. data/assets/icons/file-edit.svg +1 -0
  441. data/assets/icons/file-heart.svg +1 -0
  442. data/assets/icons/file-image.svg +1 -0
  443. data/assets/icons/file-input.svg +1 -0
  444. data/assets/icons/file-json-2.svg +1 -0
  445. data/assets/icons/file-json.svg +1 -0
  446. data/assets/icons/file-key-2.svg +1 -0
  447. data/assets/icons/file-key.svg +1 -0
  448. data/assets/icons/file-line-chart.svg +1 -0
  449. data/assets/icons/file-lock-2.svg +1 -0
  450. data/assets/icons/file-lock.svg +1 -0
  451. data/assets/icons/file-minus-2.svg +1 -0
  452. data/assets/icons/file-minus.svg +1 -0
  453. data/assets/icons/file-output.svg +1 -0
  454. data/assets/icons/file-pie-chart.svg +1 -0
  455. data/assets/icons/file-plus-2.svg +1 -0
  456. data/assets/icons/file-plus.svg +1 -0
  457. data/assets/icons/file-question.svg +1 -0
  458. data/assets/icons/file-scan.svg +1 -0
  459. data/assets/icons/file-search-2.svg +1 -0
  460. data/assets/icons/file-search.svg +1 -0
  461. data/assets/icons/file-signature.svg +1 -0
  462. data/assets/icons/file-spreadsheet.svg +1 -0
  463. data/assets/icons/file-symlink.svg +1 -0
  464. data/assets/icons/file-terminal.svg +1 -0
  465. data/assets/icons/file-text.svg +1 -0
  466. data/assets/icons/file-type-2.svg +1 -0
  467. data/assets/icons/file-type.svg +1 -0
  468. data/assets/icons/file-up.svg +1 -0
  469. data/assets/icons/file-video-2.svg +1 -0
  470. data/assets/icons/file-video.svg +1 -0
  471. data/assets/icons/file-volume-2.svg +1 -0
  472. data/assets/icons/file-volume.svg +1 -0
  473. data/assets/icons/file-warning.svg +1 -0
  474. data/assets/icons/file-x-2.svg +1 -0
  475. data/assets/icons/file-x.svg +1 -0
  476. data/assets/icons/file.svg +1 -0
  477. data/assets/icons/files.svg +1 -0
  478. data/assets/icons/film.svg +1 -0
  479. data/assets/icons/filter-x.svg +1 -0
  480. data/assets/icons/filter.svg +1 -0
  481. data/assets/icons/fingerprint.svg +1 -0
  482. data/assets/icons/fish-off.svg +1 -0
  483. data/assets/icons/fish.svg +1 -0
  484. data/assets/icons/flag-off.svg +1 -0
  485. data/assets/icons/flag-triangle-left.svg +1 -0
  486. data/assets/icons/flag-triangle-right.svg +1 -0
  487. data/assets/icons/flag.svg +1 -0
  488. data/assets/icons/flame.svg +1 -0
  489. data/assets/icons/flashlight-off.svg +1 -0
  490. data/assets/icons/flashlight.svg +1 -0
  491. data/assets/icons/flask-conical-off.svg +1 -0
  492. data/assets/icons/flask-conical.svg +1 -0
  493. data/assets/icons/flask-round.svg +1 -0
  494. data/assets/icons/flip-horizontal-2.svg +1 -0
  495. data/assets/icons/flip-horizontal.svg +1 -0
  496. data/assets/icons/flip-vertical-2.svg +1 -0
  497. data/assets/icons/flip-vertical.svg +1 -0
  498. data/assets/icons/flower-2.svg +1 -0
  499. data/assets/icons/flower.svg +1 -0
  500. data/assets/icons/focus.svg +1 -0
  501. data/assets/icons/folder-archive.svg +1 -0
  502. data/assets/icons/folder-check.svg +1 -0
  503. data/assets/icons/folder-clock.svg +1 -0
  504. data/assets/icons/folder-closed.svg +1 -0
  505. data/assets/icons/folder-cog-2.svg +1 -0
  506. data/assets/icons/folder-cog.svg +1 -0
  507. data/assets/icons/folder-down.svg +1 -0
  508. data/assets/icons/folder-edit.svg +1 -0
  509. data/assets/icons/folder-heart.svg +1 -0
  510. data/assets/icons/folder-input.svg +1 -0
  511. data/assets/icons/folder-key.svg +1 -0
  512. data/assets/icons/folder-lock.svg +1 -0
  513. data/assets/icons/folder-minus.svg +1 -0
  514. data/assets/icons/folder-open.svg +1 -0
  515. data/assets/icons/folder-output.svg +1 -0
  516. data/assets/icons/folder-plus.svg +1 -0
  517. data/assets/icons/folder-search-2.svg +1 -0
  518. data/assets/icons/folder-search.svg +1 -0
  519. data/assets/icons/folder-symlink.svg +1 -0
  520. data/assets/icons/folder-tree.svg +1 -0
  521. data/assets/icons/folder-up.svg +1 -0
  522. data/assets/icons/folder-x.svg +1 -0
  523. data/assets/icons/folder.svg +1 -0
  524. data/assets/icons/folders.svg +1 -0
  525. data/assets/icons/footprints.svg +1 -0
  526. data/assets/icons/forklift.svg +1 -0
  527. data/assets/icons/form-input.svg +1 -0
  528. data/assets/icons/forward.svg +1 -0
  529. data/assets/icons/frame.svg +1 -0
  530. data/assets/icons/framer.svg +1 -0
  531. data/assets/icons/frown.svg +1 -0
  532. data/assets/icons/fuel.svg +1 -0
  533. data/assets/icons/function-square.svg +1 -0
  534. data/assets/icons/gamepad-2.svg +1 -0
  535. data/assets/icons/gamepad.svg +1 -0
  536. data/assets/icons/gauge.svg +1 -0
  537. data/assets/icons/gavel.svg +1 -0
  538. data/assets/icons/gem.svg +1 -0
  539. data/assets/icons/ghost.svg +1 -0
  540. data/assets/icons/gift.svg +1 -0
  541. data/assets/icons/git-branch-plus.svg +1 -0
  542. data/assets/icons/git-branch.svg +1 -0
  543. data/assets/icons/git-commit.svg +1 -0
  544. data/assets/icons/git-compare.svg +1 -0
  545. data/assets/icons/git-fork.svg +1 -0
  546. data/assets/icons/git-merge.svg +1 -0
  547. data/assets/icons/git-pull-request-closed.svg +1 -0
  548. data/assets/icons/git-pull-request-draft.svg +1 -0
  549. data/assets/icons/git-pull-request.svg +1 -0
  550. data/assets/icons/github.svg +1 -0
  551. data/assets/icons/gitlab.svg +1 -0
  552. data/assets/icons/glass-water.svg +1 -0
  553. data/assets/icons/glasses.svg +1 -0
  554. data/assets/icons/globe-2.svg +1 -0
  555. data/assets/icons/globe.svg +1 -0
  556. data/assets/icons/grab.svg +1 -0
  557. data/assets/icons/graduation-cap.svg +1 -0
  558. data/assets/icons/grape.svg +1 -0
  559. data/assets/icons/grid.svg +1 -0
  560. data/assets/icons/grip-horizontal.svg +1 -0
  561. data/assets/icons/grip-vertical.svg +1 -0
  562. data/assets/icons/grip.svg +1 -0
  563. data/assets/icons/hammer.svg +1 -0
  564. data/assets/icons/hand-metal.svg +1 -0
  565. data/assets/icons/hand.svg +1 -0
  566. data/assets/icons/hard-drive.svg +1 -0
  567. data/assets/icons/hard-hat.svg +1 -0
  568. data/assets/icons/hash.svg +1 -0
  569. data/assets/icons/haze.svg +1 -0
  570. data/assets/icons/heading-1.svg +1 -0
  571. data/assets/icons/heading-2.svg +1 -0
  572. data/assets/icons/heading-3.svg +1 -0
  573. data/assets/icons/heading-4.svg +1 -0
  574. data/assets/icons/heading-5.svg +1 -0
  575. data/assets/icons/heading-6.svg +1 -0
  576. data/assets/icons/heading.svg +1 -0
  577. data/assets/icons/headphones.svg +1 -0
  578. data/assets/icons/heart-crack.svg +1 -0
  579. data/assets/icons/heart-handshake.svg +1 -0
  580. data/assets/icons/heart-off.svg +1 -0
  581. data/assets/icons/heart-pulse.svg +1 -0
  582. data/assets/icons/heart.svg +1 -0
  583. data/assets/icons/help-circle.svg +1 -0
  584. data/assets/icons/helping-hand.svg +1 -0
  585. data/assets/icons/hexagon.svg +1 -0
  586. data/assets/icons/highlighter.svg +1 -0
  587. data/assets/icons/history.svg +1 -0
  588. data/assets/icons/home.svg +1 -0
  589. data/assets/icons/hop-off.svg +1 -0
  590. data/assets/icons/hop.svg +1 -0
  591. data/assets/icons/hourglass.svg +1 -0
  592. data/assets/icons/ice-cream-2.svg +1 -0
  593. data/assets/icons/ice-cream.svg +1 -0
  594. data/assets/icons/image-minus.svg +1 -0
  595. data/assets/icons/image-off.svg +1 -0
  596. data/assets/icons/image-plus.svg +1 -0
  597. data/assets/icons/image.svg +1 -0
  598. data/assets/icons/import.svg +1 -0
  599. data/assets/icons/inbox.svg +1 -0
  600. data/assets/icons/indent.svg +1 -0
  601. data/assets/icons/indian-rupee.svg +1 -0
  602. data/assets/icons/infinity.svg +1 -0
  603. data/assets/icons/info.svg +1 -0
  604. data/assets/icons/inspect.svg +1 -0
  605. data/assets/icons/instagram.svg +1 -0
  606. data/assets/icons/italic.svg +1 -0
  607. data/assets/icons/japanese-yen.svg +1 -0
  608. data/assets/icons/joystick.svg +1 -0
  609. data/assets/icons/key.svg +1 -0
  610. data/assets/icons/keyboard.svg +1 -0
  611. data/assets/icons/lamp-ceiling.svg +1 -0
  612. data/assets/icons/lamp-desk.svg +1 -0
  613. data/assets/icons/lamp-floor.svg +1 -0
  614. data/assets/icons/lamp-wall-down.svg +1 -0
  615. data/assets/icons/lamp-wall-up.svg +1 -0
  616. data/assets/icons/lamp.svg +1 -0
  617. data/assets/icons/landmark.svg +1 -0
  618. data/assets/icons/languages.svg +1 -0
  619. data/assets/icons/laptop-2.svg +1 -0
  620. data/assets/icons/laptop.svg +1 -0
  621. data/assets/icons/lasso-select.svg +1 -0
  622. data/assets/icons/lasso.svg +1 -0
  623. data/assets/icons/laugh.svg +1 -0
  624. data/assets/icons/layers.svg +1 -0
  625. data/assets/icons/layout-dashboard.svg +1 -0
  626. data/assets/icons/layout-grid.svg +1 -0
  627. data/assets/icons/layout-list.svg +1 -0
  628. data/assets/icons/layout-template.svg +1 -0
  629. data/assets/icons/layout.svg +1 -0
  630. data/assets/icons/leaf.svg +1 -0
  631. data/assets/icons/library.svg +1 -0
  632. data/assets/icons/life-buoy.svg +1 -0
  633. data/assets/icons/lightbulb-off.svg +1 -0
  634. data/assets/icons/lightbulb.svg +1 -0
  635. data/assets/icons/line-chart.svg +1 -0
  636. data/assets/icons/link-2-off.svg +1 -0
  637. data/assets/icons/link-2.svg +1 -0
  638. data/assets/icons/link.svg +1 -0
  639. data/assets/icons/linkedin.svg +1 -0
  640. data/assets/icons/list-checks.svg +1 -0
  641. data/assets/icons/list-end.svg +1 -0
  642. data/assets/icons/list-minus.svg +1 -0
  643. data/assets/icons/list-music.svg +1 -0
  644. data/assets/icons/list-ordered.svg +1 -0
  645. data/assets/icons/list-plus.svg +1 -0
  646. data/assets/icons/list-start.svg +1 -0
  647. data/assets/icons/list-video.svg +1 -0
  648. data/assets/icons/list-x.svg +1 -0
  649. data/assets/icons/list.svg +1 -0
  650. data/assets/icons/loader-2.svg +1 -0
  651. data/assets/icons/loader.svg +1 -0
  652. data/assets/icons/locate-fixed.svg +1 -0
  653. data/assets/icons/locate-off.svg +1 -0
  654. data/assets/icons/locate.svg +1 -0
  655. data/assets/icons/lock.svg +1 -0
  656. data/assets/icons/log-in.svg +1 -0
  657. data/assets/icons/log-out.svg +1 -0
  658. data/assets/icons/luggage.svg +1 -0
  659. data/assets/icons/magnet.svg +1 -0
  660. data/assets/icons/mail-check.svg +1 -0
  661. data/assets/icons/mail-minus.svg +1 -0
  662. data/assets/icons/mail-open.svg +1 -0
  663. data/assets/icons/mail-plus.svg +1 -0
  664. data/assets/icons/mail-question.svg +1 -0
  665. data/assets/icons/mail-search.svg +1 -0
  666. data/assets/icons/mail-warning.svg +1 -0
  667. data/assets/icons/mail-x.svg +1 -0
  668. data/assets/icons/mail.svg +1 -0
  669. data/assets/icons/mails.svg +1 -0
  670. data/assets/icons/map-pin-off.svg +1 -0
  671. data/assets/icons/map-pin.svg +1 -0
  672. data/assets/icons/map.svg +1 -0
  673. data/assets/icons/martini.svg +1 -0
  674. data/assets/icons/maximize-2.svg +1 -0
  675. data/assets/icons/maximize.svg +1 -0
  676. data/assets/icons/medal.svg +1 -0
  677. data/assets/icons/megaphone-off.svg +1 -0
  678. data/assets/icons/megaphone.svg +1 -0
  679. data/assets/icons/meh.svg +1 -0
  680. data/assets/icons/menu.svg +1 -0
  681. data/assets/icons/message-circle.svg +1 -0
  682. data/assets/icons/message-square.svg +1 -0
  683. data/assets/icons/mic-2.svg +1 -0
  684. data/assets/icons/mic-off.svg +1 -0
  685. data/assets/icons/mic.svg +1 -0
  686. data/assets/icons/microscope.svg +1 -0
  687. data/assets/icons/microwave.svg +1 -0
  688. data/assets/icons/milestone.svg +1 -0
  689. data/assets/icons/milk-off.svg +1 -0
  690. data/assets/icons/milk.svg +1 -0
  691. data/assets/icons/minimize-2.svg +1 -0
  692. data/assets/icons/minimize.svg +1 -0
  693. data/assets/icons/minus-circle.svg +1 -0
  694. data/assets/icons/minus-square.svg +1 -0
  695. data/assets/icons/minus.svg +1 -0
  696. data/assets/icons/monitor-off.svg +1 -0
  697. data/assets/icons/monitor-smartphone.svg +1 -0
  698. data/assets/icons/monitor-speaker.svg +1 -0
  699. data/assets/icons/monitor.svg +1 -0
  700. data/assets/icons/moon.svg +1 -0
  701. data/assets/icons/more-horizontal.svg +1 -0
  702. data/assets/icons/more-vertical.svg +1 -0
  703. data/assets/icons/mountain-snow.svg +1 -0
  704. data/assets/icons/mountain.svg +1 -0
  705. data/assets/icons/mouse-pointer-2.svg +1 -0
  706. data/assets/icons/mouse-pointer-click.svg +1 -0
  707. data/assets/icons/mouse-pointer.svg +1 -0
  708. data/assets/icons/mouse.svg +1 -0
  709. data/assets/icons/move-3d.svg +1 -0
  710. data/assets/icons/move-diagonal-2.svg +1 -0
  711. data/assets/icons/move-diagonal.svg +1 -0
  712. data/assets/icons/move-horizontal.svg +1 -0
  713. data/assets/icons/move-vertical.svg +1 -0
  714. data/assets/icons/move.svg +1 -0
  715. data/assets/icons/music-2.svg +1 -0
  716. data/assets/icons/music-3.svg +1 -0
  717. data/assets/icons/music-4.svg +1 -0
  718. data/assets/icons/music.svg +1 -0
  719. data/assets/icons/navigation-2-off.svg +1 -0
  720. data/assets/icons/navigation-2.svg +1 -0
  721. data/assets/icons/navigation-off.svg +1 -0
  722. data/assets/icons/navigation.svg +1 -0
  723. data/assets/icons/network.svg +1 -0
  724. data/assets/icons/newspaper.svg +1 -0
  725. data/assets/icons/nfc.svg +1 -0
  726. data/assets/icons/nut-off.svg +1 -0
  727. data/assets/icons/nut.svg +1 -0
  728. data/assets/icons/octagon.svg +1 -0
  729. data/assets/icons/option.svg +1 -0
  730. data/assets/icons/outdent.svg +1 -0
  731. data/assets/icons/package-2.svg +1 -0
  732. data/assets/icons/package-check.svg +1 -0
  733. data/assets/icons/package-minus.svg +1 -0
  734. data/assets/icons/package-open.svg +1 -0
  735. data/assets/icons/package-plus.svg +1 -0
  736. data/assets/icons/package-search.svg +1 -0
  737. data/assets/icons/package-x.svg +1 -0
  738. data/assets/icons/package.svg +1 -0
  739. data/assets/icons/paint-bucket.svg +1 -0
  740. data/assets/icons/paintbrush-2.svg +1 -0
  741. data/assets/icons/paintbrush.svg +1 -0
  742. data/assets/icons/palette.svg +1 -0
  743. data/assets/icons/palmtree.svg +1 -0
  744. data/assets/icons/paperclip.svg +1 -0
  745. data/assets/icons/party-popper.svg +1 -0
  746. data/assets/icons/pause-circle.svg +1 -0
  747. data/assets/icons/pause-octagon.svg +1 -0
  748. data/assets/icons/pause.svg +1 -0
  749. data/assets/icons/pen-tool.svg +1 -0
  750. data/assets/icons/pencil.svg +1 -0
  751. data/assets/icons/percent.svg +1 -0
  752. data/assets/icons/person-standing.svg +1 -0
  753. data/assets/icons/phone-call.svg +1 -0
  754. data/assets/icons/phone-forwarded.svg +1 -0
  755. data/assets/icons/phone-incoming.svg +1 -0
  756. data/assets/icons/phone-missed.svg +1 -0
  757. data/assets/icons/phone-off.svg +1 -0
  758. data/assets/icons/phone-outgoing.svg +1 -0
  759. data/assets/icons/phone.svg +1 -0
  760. data/assets/icons/picture-in-picture-2.svg +1 -0
  761. data/assets/icons/picture-in-picture.svg +1 -0
  762. data/assets/icons/pie-chart.svg +1 -0
  763. data/assets/icons/piggy-bank.svg +1 -0
  764. data/assets/icons/pilcrow.svg +1 -0
  765. data/assets/icons/pill.svg +1 -0
  766. data/assets/icons/pin-off.svg +1 -0
  767. data/assets/icons/pin.svg +1 -0
  768. data/assets/icons/pipette.svg +1 -0
  769. data/assets/icons/pizza.svg +1 -0
  770. data/assets/icons/plane.svg +1 -0
  771. data/assets/icons/play-circle.svg +1 -0
  772. data/assets/icons/play.svg +1 -0
  773. data/assets/icons/plug-2.svg +1 -0
  774. data/assets/icons/plug-zap.svg +1 -0
  775. data/assets/icons/plug.svg +1 -0
  776. data/assets/icons/plus-circle.svg +1 -0
  777. data/assets/icons/plus-square.svg +1 -0
  778. data/assets/icons/plus.svg +1 -0
  779. data/assets/icons/pocket.svg +1 -0
  780. data/assets/icons/podcast.svg +1 -0
  781. data/assets/icons/pointer.svg +1 -0
  782. data/assets/icons/pound-sterling.svg +1 -0
  783. data/assets/icons/power-off.svg +1 -0
  784. data/assets/icons/power.svg +1 -0
  785. data/assets/icons/printer.svg +1 -0
  786. data/assets/icons/puzzle.svg +1 -0
  787. data/assets/icons/qr-code.svg +1 -0
  788. data/assets/icons/quote.svg +1 -0
  789. data/assets/icons/radio-receiver.svg +1 -0
  790. data/assets/icons/radio.svg +1 -0
  791. data/assets/icons/rectangle-horizontal.svg +1 -0
  792. data/assets/icons/rectangle-vertical.svg +1 -0
  793. data/assets/icons/recycle.svg +1 -0
  794. data/assets/icons/redo-2.svg +1 -0
  795. data/assets/icons/redo.svg +1 -0
  796. data/assets/icons/refresh-ccw.svg +1 -0
  797. data/assets/icons/refresh-cw.svg +1 -0
  798. data/assets/icons/refrigerator.svg +1 -0
  799. data/assets/icons/regex.svg +1 -0
  800. data/assets/icons/remove-formatting.svg +1 -0
  801. data/assets/icons/repeat-1.svg +1 -0
  802. data/assets/icons/repeat.svg +1 -0
  803. data/assets/icons/reply-all.svg +1 -0
  804. data/assets/icons/reply.svg +1 -0
  805. data/assets/icons/rewind.svg +1 -0
  806. data/assets/icons/rocket.svg +1 -0
  807. data/assets/icons/rocking-chair.svg +1 -0
  808. data/assets/icons/rotate-3d.svg +1 -0
  809. data/assets/icons/rotate-ccw.svg +1 -0
  810. data/assets/icons/rotate-cw.svg +1 -0
  811. data/assets/icons/router.svg +1 -0
  812. data/assets/icons/rss.svg +1 -0
  813. data/assets/icons/ruler.svg +1 -0
  814. data/assets/icons/russian-ruble.svg +1 -0
  815. data/assets/icons/sailboat.svg +1 -0
  816. data/assets/icons/salad.svg +1 -0
  817. data/assets/icons/sandwich.svg +1 -0
  818. data/assets/icons/save.svg +1 -0
  819. data/assets/icons/scale-3d.svg +1 -0
  820. data/assets/icons/scale.svg +1 -0
  821. data/assets/icons/scaling.svg +1 -0
  822. data/assets/icons/scan-face.svg +1 -0
  823. data/assets/icons/scan-line.svg +1 -0
  824. data/assets/icons/scan.svg +1 -0
  825. data/assets/icons/scissors.svg +1 -0
  826. data/assets/icons/screen-share-off.svg +1 -0
  827. data/assets/icons/screen-share.svg +1 -0
  828. data/assets/icons/scroll.svg +1 -0
  829. data/assets/icons/search.svg +1 -0
  830. data/assets/icons/send.svg +1 -0
  831. data/assets/icons/separator-horizontal.svg +1 -0
  832. data/assets/icons/separator-vertical.svg +1 -0
  833. data/assets/icons/server-cog.svg +1 -0
  834. data/assets/icons/server-crash.svg +1 -0
  835. data/assets/icons/server-off.svg +1 -0
  836. data/assets/icons/server.svg +1 -0
  837. data/assets/icons/settings-2.svg +1 -0
  838. data/assets/icons/settings.svg +1 -0
  839. data/assets/icons/share-2.svg +1 -0
  840. data/assets/icons/share.svg +1 -0
  841. data/assets/icons/sheet.svg +1 -0
  842. data/assets/icons/shield-alert.svg +1 -0
  843. data/assets/icons/shield-check.svg +1 -0
  844. data/assets/icons/shield-close.svg +1 -0
  845. data/assets/icons/shield-off.svg +1 -0
  846. data/assets/icons/shield.svg +1 -0
  847. data/assets/icons/ship.svg +1 -0
  848. data/assets/icons/shirt.svg +1 -0
  849. data/assets/icons/shopping-bag.svg +1 -0
  850. data/assets/icons/shopping-cart.svg +1 -0
  851. data/assets/icons/shovel.svg +1 -0
  852. data/assets/icons/shower-head.svg +1 -0
  853. data/assets/icons/shrink.svg +1 -0
  854. data/assets/icons/shrub.svg +1 -0
  855. data/assets/icons/shuffle.svg +1 -0
  856. data/assets/icons/sidebar-close.svg +1 -0
  857. data/assets/icons/sidebar-open.svg +1 -0
  858. data/assets/icons/sidebar.svg +1 -0
  859. data/assets/icons/sigma.svg +1 -0
  860. data/assets/icons/signal-high.svg +1 -0
  861. data/assets/icons/signal-low.svg +1 -0
  862. data/assets/icons/signal-medium.svg +1 -0
  863. data/assets/icons/signal-zero.svg +1 -0
  864. data/assets/icons/signal.svg +1 -0
  865. data/assets/icons/siren.svg +1 -0
  866. data/assets/icons/skip-back.svg +1 -0
  867. data/assets/icons/skip-forward.svg +1 -0
  868. data/assets/icons/skull.svg +1 -0
  869. data/assets/icons/slack.svg +1 -0
  870. data/assets/icons/slash.svg +1 -0
  871. data/assets/icons/slice.svg +1 -0
  872. data/assets/icons/sliders-horizontal.svg +1 -0
  873. data/assets/icons/sliders.svg +1 -0
  874. data/assets/icons/smartphone-charging.svg +1 -0
  875. data/assets/icons/smartphone-nfc.svg +1 -0
  876. data/assets/icons/smartphone.svg +1 -0
  877. data/assets/icons/smile-plus.svg +1 -0
  878. data/assets/icons/smile.svg +1 -0
  879. data/assets/icons/snowflake.svg +1 -0
  880. data/assets/icons/sofa.svg +1 -0
  881. data/assets/icons/sort-asc.svg +1 -0
  882. data/assets/icons/sort-desc.svg +1 -0
  883. data/assets/icons/soup.svg +1 -0
  884. data/assets/icons/speaker.svg +1 -0
  885. data/assets/icons/spline.svg +1 -0
  886. data/assets/icons/split-square-horizontal.svg +1 -0
  887. data/assets/icons/split-square-vertical.svg +1 -0
  888. data/assets/icons/sprout.svg +1 -0
  889. data/assets/icons/square.svg +1 -0
  890. data/assets/icons/stamp.svg +1 -0
  891. data/assets/icons/star-half.svg +1 -0
  892. data/assets/icons/star-off.svg +1 -0
  893. data/assets/icons/star.svg +1 -0
  894. data/assets/icons/stethoscope.svg +1 -0
  895. data/assets/icons/sticker.svg +1 -0
  896. data/assets/icons/sticky-note.svg +1 -0
  897. data/assets/icons/stop-circle.svg +1 -0
  898. data/assets/icons/stretch-horizontal.svg +1 -0
  899. data/assets/icons/stretch-vertical.svg +1 -0
  900. data/assets/icons/strikethrough.svg +1 -0
  901. data/assets/icons/subscript.svg +1 -0
  902. data/assets/icons/subtitles.svg +1 -0
  903. data/assets/icons/sun-dim.svg +1 -0
  904. data/assets/icons/sun-medium.svg +1 -0
  905. data/assets/icons/sun-moon.svg +1 -0
  906. data/assets/icons/sun-snow.svg +1 -0
  907. data/assets/icons/sun.svg +1 -0
  908. data/assets/icons/sunrise.svg +1 -0
  909. data/assets/icons/sunset.svg +1 -0
  910. data/assets/icons/superscript.svg +1 -0
  911. data/assets/icons/swiss-franc.svg +1 -0
  912. data/assets/icons/switch-camera.svg +1 -0
  913. data/assets/icons/sword.svg +1 -0
  914. data/assets/icons/swords.svg +1 -0
  915. data/assets/icons/syringe.svg +1 -0
  916. data/assets/icons/table-2.svg +1 -0
  917. data/assets/icons/table.svg +1 -0
  918. data/assets/icons/tablet.svg +1 -0
  919. data/assets/icons/tablets.svg +1 -0
  920. data/assets/icons/tag.svg +1 -0
  921. data/assets/icons/tags.svg +1 -0
  922. data/assets/icons/target.svg +1 -0
  923. data/assets/icons/tent.svg +1 -0
  924. data/assets/icons/terminal-square.svg +1 -0
  925. data/assets/icons/terminal.svg +1 -0
  926. data/assets/icons/text-cursor-input.svg +1 -0
  927. data/assets/icons/text-cursor.svg +1 -0
  928. data/assets/icons/thermometer-snowflake.svg +1 -0
  929. data/assets/icons/thermometer-sun.svg +1 -0
  930. data/assets/icons/thermometer.svg +1 -0
  931. data/assets/icons/thumbs-down.svg +1 -0
  932. data/assets/icons/thumbs-up.svg +1 -0
  933. data/assets/icons/ticket.svg +1 -0
  934. data/assets/icons/timer-off.svg +1 -0
  935. data/assets/icons/timer-reset.svg +1 -0
  936. data/assets/icons/timer.svg +1 -0
  937. data/assets/icons/toggle-left.svg +1 -0
  938. data/assets/icons/toggle-right.svg +1 -0
  939. data/assets/icons/tornado.svg +1 -0
  940. data/assets/icons/tower-control.svg +1 -0
  941. data/assets/icons/toy-brick.svg +1 -0
  942. data/assets/icons/train.svg +1 -0
  943. data/assets/icons/trash-2.svg +1 -0
  944. data/assets/icons/trash.svg +1 -0
  945. data/assets/icons/tree-deciduous.svg +1 -0
  946. data/assets/icons/tree-pine.svg +1 -0
  947. data/assets/icons/trees.svg +1 -0
  948. data/assets/icons/trello.svg +1 -0
  949. data/assets/icons/trending-down.svg +1 -0
  950. data/assets/icons/trending-up.svg +1 -0
  951. data/assets/icons/triangle.svg +1 -0
  952. data/assets/icons/trophy.svg +1 -0
  953. data/assets/icons/truck.svg +1 -0
  954. data/assets/icons/tv-2.svg +1 -0
  955. data/assets/icons/tv.svg +1 -0
  956. data/assets/icons/twitch.svg +1 -0
  957. data/assets/icons/twitter.svg +1 -0
  958. data/assets/icons/type.svg +1 -0
  959. data/assets/icons/umbrella.svg +1 -0
  960. data/assets/icons/underline.svg +1 -0
  961. data/assets/icons/undo-2.svg +1 -0
  962. data/assets/icons/undo.svg +1 -0
  963. data/assets/icons/unlink-2.svg +1 -0
  964. data/assets/icons/unlink.svg +1 -0
  965. data/assets/icons/unlock.svg +1 -0
  966. data/assets/icons/upload-cloud.svg +1 -0
  967. data/assets/icons/upload.svg +1 -0
  968. data/assets/icons/usb.svg +1 -0
  969. data/assets/icons/user-check.svg +1 -0
  970. data/assets/icons/user-cog.svg +1 -0
  971. data/assets/icons/user-minus.svg +1 -0
  972. data/assets/icons/user-plus.svg +1 -0
  973. data/assets/icons/user-x.svg +1 -0
  974. data/assets/icons/user.svg +1 -0
  975. data/assets/icons/users.svg +1 -0
  976. data/assets/icons/utensils-crossed.svg +1 -0
  977. data/assets/icons/utensils.svg +1 -0
  978. data/assets/icons/utility-pole.svg +1 -0
  979. data/assets/icons/vegan.svg +1 -0
  980. data/assets/icons/venetian-mask.svg +1 -0
  981. data/assets/icons/verified.svg +1 -0
  982. data/assets/icons/vibrate-off.svg +1 -0
  983. data/assets/icons/vibrate.svg +1 -0
  984. data/assets/icons/video-off.svg +1 -0
  985. data/assets/icons/video.svg +1 -0
  986. data/assets/icons/view.svg +1 -0
  987. data/assets/icons/voicemail.svg +1 -0
  988. data/assets/icons/volume-1.svg +1 -0
  989. data/assets/icons/volume-2.svg +1 -0
  990. data/assets/icons/volume-x.svg +1 -0
  991. data/assets/icons/volume.svg +1 -0
  992. data/assets/icons/vote.svg +1 -0
  993. data/assets/icons/wallet.svg +1 -0
  994. data/assets/icons/wand-2.svg +1 -0
  995. data/assets/icons/wand.svg +1 -0
  996. data/assets/icons/watch.svg +1 -0
  997. data/assets/icons/waves.svg +1 -0
  998. data/assets/icons/webcam.svg +1 -0
  999. data/assets/icons/webhook.svg +1 -0
  1000. data/assets/icons/wheat-off.svg +1 -0
  1001. data/assets/icons/wheat.svg +1 -0
  1002. data/assets/icons/wifi-off.svg +1 -0
  1003. data/assets/icons/wifi.svg +1 -0
  1004. data/assets/icons/wind.svg +1 -0
  1005. data/assets/icons/wine-off.svg +1 -0
  1006. data/assets/icons/wine.svg +1 -0
  1007. data/assets/icons/wrap-text.svg +1 -0
  1008. data/assets/icons/wrench.svg +1 -0
  1009. data/assets/icons/x-circle.svg +1 -0
  1010. data/assets/icons/x-octagon.svg +1 -0
  1011. data/assets/icons/x-square.svg +1 -0
  1012. data/assets/icons/x.svg +1 -0
  1013. data/assets/icons/youtube.svg +1 -0
  1014. data/assets/icons/zap-off.svg +1 -0
  1015. data/assets/icons/zap.svg +1 -0
  1016. data/assets/icons/zoom-in.svg +1 -0
  1017. data/assets/icons/zoom-out.svg +1 -0
  1018. data/assets/img/favicon_dark.svg +1 -0
  1019. data/assets/img/favicon_light.svg +1 -0
  1020. data/{app/assets/lookbook → assets}/js/app.js +35 -8
  1021. data/{app/assets/lookbook → assets}/js/helpers/dom.js +4 -7
  1022. data/assets/js/helpers/request.js +14 -0
  1023. data/{app/assets/lookbook → assets}/js/helpers/string.js +4 -11
  1024. data/{app/assets/lookbook/js/lookbook.js → assets/js/index.js} +2 -2
  1025. data/assets/js/lib/lookbook.js +125 -0
  1026. data/{app/assets/lookbook → assets}/js/lib/tippy.js +1 -0
  1027. data/assets/js/lookbook-core.js +1 -0
  1028. data/assets/js/lookbook.js +2 -0
  1029. data/config/app.yml +51 -18
  1030. data/config/inputs.yml +2 -2
  1031. data/config/panels.yml +23 -25
  1032. data/config/routes.rb +7 -1
  1033. data/config/tags.yml +10 -2
  1034. data/lib/lookbook/cable/cable.rb +53 -0
  1035. data/lib/lookbook/engine.rb +178 -86
  1036. data/lib/lookbook/entities/collections/concerns/hierarchical_collection.rb +9 -4
  1037. data/lib/lookbook/entities/collections/entity_collection.rb +11 -6
  1038. data/lib/lookbook/entities/collections/page_collection.rb +35 -8
  1039. data/lib/lookbook/entities/collections/preview_collection.rb +51 -17
  1040. data/lib/lookbook/entities/collections/render_target_collection.rb +4 -0
  1041. data/lib/lookbook/entities/collections/scenario_collection.rb +4 -0
  1042. data/lib/lookbook/entities/concerns/annotatable_entity.rb +84 -0
  1043. data/lib/lookbook/entities/concerns/{inspectable.rb → inspectable_entity.rb} +18 -2
  1044. data/lib/lookbook/entities/concerns/locatable_entity.rb +116 -0
  1045. data/lib/lookbook/entities/concerns/navigable_entity.rb +62 -0
  1046. data/lib/lookbook/entities/entity.rb +40 -9
  1047. data/lib/lookbook/entities/page_entity.rb +142 -0
  1048. data/lib/lookbook/entities/{page_section.rb → page_section_entity.rb} +5 -1
  1049. data/lib/lookbook/entities/preview_entity.rb +214 -0
  1050. data/lib/lookbook/entities/renderable_entity.rb +101 -0
  1051. data/lib/lookbook/entities/rendered_scenario_entity.rb +69 -0
  1052. data/lib/lookbook/entities/scenario_entity.rb +182 -0
  1053. data/lib/lookbook/entities/scenario_group_entity.rb +135 -0
  1054. data/lib/lookbook/file_watcher.rb +13 -35
  1055. data/lib/lookbook/helpers/class_names_helper.rb +28 -0
  1056. data/lib/lookbook/helpers/page_helper.rb +43 -0
  1057. data/{app/helpers/lookbook → lib/lookbook/helpers}/preview_helper.rb +3 -0
  1058. data/lib/lookbook/helpers/ui_elements_helper.rb +91 -0
  1059. data/lib/lookbook/param.rb +8 -2
  1060. data/lib/lookbook/preview.rb +85 -0
  1061. data/lib/lookbook/preview_after_render.rb +13 -0
  1062. data/lib/lookbook/preview_controller_actions.rb +64 -0
  1063. data/lib/lookbook/preview_parser.rb +4 -2
  1064. data/lib/lookbook/reloaders.rb +75 -0
  1065. data/lib/lookbook/runtime_context.rb +49 -0
  1066. data/lib/lookbook/services/data/resolvers/data_resolver.rb +5 -7
  1067. data/lib/lookbook/services/entities/page_tree_builder.rb +40 -0
  1068. data/lib/lookbook/services/entities/preview_tree_builder.rb +34 -0
  1069. data/lib/lookbook/services/list_resolver.rb +35 -0
  1070. data/lib/lookbook/services/markdown_renderer.rb +10 -2
  1071. data/lib/lookbook/services/priority_prefix_parser.rb +16 -0
  1072. data/lib/lookbook/services/tags/tag_options_parser.rb +13 -4
  1073. data/lib/lookbook/services/templates/action_view_config_handler.rb +50 -0
  1074. data/lib/lookbook/services/urls/data_uri_encoder.rb +14 -0
  1075. data/lib/lookbook/services/urls/file_data_uri_encoder.rb +24 -0
  1076. data/lib/lookbook/services/urls/search_param_encoder.rb +16 -0
  1077. data/lib/lookbook/services/urls/search_param_parser.rb +7 -6
  1078. data/lib/lookbook/stores/config_store.rb +63 -26
  1079. data/lib/lookbook/stores/hook_store.rb +0 -10
  1080. data/lib/lookbook/stores/input_store.rb +8 -4
  1081. data/lib/lookbook/stores/panel_store.rb +30 -49
  1082. data/lib/lookbook/stores/tag_store.rb +6 -5
  1083. data/lib/lookbook/support/deprecation.rb +5 -0
  1084. data/lib/lookbook/support/errors/config_error.rb +2 -2
  1085. data/lib/lookbook/support/errors/error.rb +64 -0
  1086. data/lib/lookbook/support/errors/parser_error.rb +2 -2
  1087. data/lib/lookbook/support/errors/preview_template_error.rb +7 -0
  1088. data/lib/lookbook/support/errors/routing_error.rb +7 -0
  1089. data/lib/lookbook/support/errors/template_error.rb +7 -0
  1090. data/lib/lookbook/support/evented_file_update_checker.rb +69 -0
  1091. data/lib/lookbook/support/null_websocket.rb +9 -0
  1092. data/lib/lookbook/support/store.rb +10 -1
  1093. data/lib/lookbook/support/tree_node.rb +7 -7
  1094. data/lib/lookbook/support/utils/path_utils.rb +9 -3
  1095. data/lib/lookbook/support/utils/utils.rb +9 -1
  1096. data/lib/lookbook/support/utils/where.rb +49 -0
  1097. data/lib/lookbook/tags/after_render_tag.rb +7 -0
  1098. data/lib/lookbook/tags/param_tag.rb +14 -4
  1099. data/lib/lookbook/tags/{position_tag.rb → priority_tag.rb} +4 -4
  1100. data/lib/lookbook/tags/renders_tag.rb +4 -0
  1101. data/lib/lookbook/tags/tag_provider.rb +3 -0
  1102. data/lib/lookbook/tags/type_tag.rb +7 -0
  1103. data/lib/lookbook/tags/yard_tag.rb +15 -11
  1104. data/lib/lookbook/theme.rb +2 -6
  1105. data/lib/lookbook/version.rb +1 -1
  1106. data/lib/lookbook/websocket.rb +6 -53
  1107. data/lib/lookbook.rb +180 -54
  1108. data/public/lookbook-assets/Inter-italic.var.53a0de5f.woff2 +0 -0
  1109. data/public/lookbook-assets/Inter-italic.var.69eb0fe1.woff2 +0 -0
  1110. data/public/lookbook-assets/Inter-italic.var.736a7044.woff2 +0 -0
  1111. data/public/lookbook-assets/Inter-roman.var.b695afbe.woff2 +0 -0
  1112. data/public/lookbook-assets/Inter-roman.var.d4f9805a.woff2 +0 -0
  1113. data/public/lookbook-assets/Inter-roman.var.fbdd51d0.woff2 +0 -0
  1114. data/public/lookbook-assets/SourceCodeVariable-Italic.cad97b83.otf +0 -0
  1115. data/public/lookbook-assets/SourceCodeVariable-Italic.ttf.09b4354a.woff2 +0 -0
  1116. data/public/lookbook-assets/SourceCodeVariable-Italic.ttf.a93fa22f.woff2 +0 -0
  1117. data/public/lookbook-assets/SourceCodeVariable-Italic.ttf.fcd7e9f4.woff2 +0 -0
  1118. data/public/lookbook-assets/SourceCodeVariable-Roman.185ddb17.otf +0 -0
  1119. data/public/lookbook-assets/SourceCodeVariable-Roman.ttf.118e9f22.woff2 +0 -0
  1120. data/public/lookbook-assets/SourceCodeVariable-Roman.ttf.91043609.woff2 +0 -0
  1121. data/public/lookbook-assets/SourceCodeVariable-Roman.ttf.f1c8fcce.woff2 +0 -0
  1122. data/public/lookbook-assets/css/lookbook.css +1538 -717
  1123. data/public/lookbook-assets/css/lookbook.css.map +1 -1
  1124. data/public/lookbook-assets/css/themes/blue.css +14 -2
  1125. data/public/lookbook-assets/css/themes/blue.css.map +1 -1
  1126. data/public/lookbook-assets/css/themes/green.css +14 -2
  1127. data/public/lookbook-assets/css/themes/green.css.map +1 -1
  1128. data/public/lookbook-assets/css/themes/indigo.css +14 -2
  1129. data/public/lookbook-assets/css/themes/indigo.css.map +1 -1
  1130. data/public/lookbook-assets/css/themes/rose.css +14 -2
  1131. data/public/lookbook-assets/css/themes/rose.css.map +1 -1
  1132. data/public/lookbook-assets/css/themes/zinc.css +14 -2
  1133. data/public/lookbook-assets/css/themes/zinc.css.map +1 -1
  1134. data/public/lookbook-assets/img/lucide-sprite.svg +4960 -0
  1135. data/public/lookbook-assets/js/{embed.js → iframe.js} +196 -195
  1136. data/public/lookbook-assets/js/iframe.js.map +1 -0
  1137. data/public/lookbook-assets/js/index.js +13739 -0
  1138. data/public/lookbook-assets/js/index.js.map +1 -0
  1139. data/public/lookbook-assets/js/lookbook-core.js +87 -0
  1140. data/public/lookbook-assets/js/lookbook.js +248 -12835
  1141. metadata +1057 -118
  1142. data/app/assets/lookbook/js/helpers/request.js +0 -16
  1143. data/app/components/lookbook/embed/component.js +0 -39
  1144. data/app/components/lookbook/icon/component.js +0 -5
  1145. data/app/helpers/lookbook/component_helper.rb +0 -84
  1146. data/app/helpers/lookbook/output_helper.rb +0 -19
  1147. data/app/helpers/lookbook/page_helper.rb +0 -34
  1148. data/app/views/layouts/lookbook/inspector.html.erb +0 -7
  1149. data/app/views/layouts/lookbook/page.html.erb +0 -53
  1150. data/app/views/layouts/lookbook/shell.html.erb +0 -25
  1151. data/app/views/layouts/lookbook/standalone.html.erb +0 -5
  1152. data/app/views/lookbook/404.html.erb +0 -15
  1153. data/app/views/lookbook/error.html.erb +0 -46
  1154. data/app/views/lookbook/preview.html.erb +0 -14
  1155. data/config/hooks.yml +0 -4
  1156. data/lib/lookbook/entities/collections/component_collection.rb +0 -4
  1157. data/lib/lookbook/entities/collections/preview_example_collection.rb +0 -4
  1158. data/lib/lookbook/entities/component.rb +0 -31
  1159. data/lib/lookbook/entities/concerns/annotatable.rb +0 -58
  1160. data/lib/lookbook/entities/concerns/locatable.rb +0 -73
  1161. data/lib/lookbook/entities/concerns/navigable.rb +0 -43
  1162. data/lib/lookbook/entities/page.rb +0 -80
  1163. data/lib/lookbook/entities/preview.rb +0 -87
  1164. data/lib/lookbook/entities/preview_example.rb +0 -104
  1165. data/lib/lookbook/entities/preview_group.rb +0 -52
  1166. data/lib/lookbook/error.rb +0 -120
  1167. data/lib/lookbook/features.rb +0 -24
  1168. data/lib/lookbook/preview_actions.rb +0 -43
  1169. data/lib/lookbook/process.rb +0 -21
  1170. data/lib/lookbook/rendered_example.rb +0 -37
  1171. data/lib/lookbook/services/entities/entity_tree_builder.rb +0 -45
  1172. data/lib/lookbook/services/position_prefix_parser.rb +0 -16
  1173. data/lib/lookbook/services/templates/action_view_annotations_handler.rb +0 -21
  1174. data/lib/lookbook/services/urls/search_param_builder.rb +0 -13
  1175. data/lib/lookbook/support/errors/lookbook_error.rb +0 -21
  1176. data/lib/lookbook/tags/component_tag.rb +0 -13
  1177. data/lib/tasks/lookbook_tasks.rake +0 -10
  1178. data/public/lookbook-assets/css/app.css +0 -2341
  1179. data/public/lookbook-assets/css/app.css.map +0 -11
  1180. data/public/lookbook-assets/css/themes/zinc.css.map.91837.5 +0 -1
  1181. data/public/lookbook-assets/feather-sprite.svg +0 -1
  1182. data/public/lookbook-assets/js/app.js +0 -10862
  1183. data/public/lookbook-assets/js/app.js.map +0 -2571
  1184. data/public/lookbook-assets/js/embed.js.91837.6 +0 -0
  1185. data/public/lookbook-assets/js/embed.js.map +0 -1
  1186. data/public/lookbook-assets/js/lookbook.js.map +0 -1
  1187. /data/{app/assets/lookbook → assets}/js/components/clipboard.js +0 -0
  1188. /data/{app/assets/lookbook → assets}/js/components/params_input.js +0 -0
  1189. /data/{app/assets/lookbook → assets}/js/components/tooltip.js +0 -0
  1190. /data/{app/assets/lookbook → assets}/js/config.js +0 -0
  1191. /data/{app/assets/lookbook → assets}/js/helpers/build.js +0 -0
  1192. /data/{app/assets/lookbook → assets}/js/helpers/layout.js +0 -0
  1193. /data/{app/assets/lookbook/js/embed.js → assets/js/iframe.js} +0 -0
  1194. /data/{app/assets/lookbook → assets}/js/lib/socket.js +0 -0
  1195. /data/{app/assets/lookbook → assets}/js/plugins/logger.js +0 -0
  1196. /data/{app/assets/lookbook → assets}/js/stores/filter.js +0 -0
  1197. /data/{app/assets/lookbook → assets}/js/stores/inspector.js +0 -0
  1198. /data/{app/assets/lookbook → assets}/js/stores/layout.js +0 -0
  1199. /data/{app/assets/lookbook → assets}/js/stores/nav.js +0 -0
  1200. /data/{app/assets/lookbook → assets}/js/stores/pages.js +0 -0
  1201. /data/{app/assets/lookbook → assets}/js/stores/settings.js +0 -0
  1202. /data/{app/assets/lookbook → assets}/js/stores/workbench.js +0 -0
  1203. /data/{app/channels/lookbook → lib/lookbook/cable}/connection.rb +0 -0
  1204. /data/{app/channels/lookbook → lib/lookbook/cable}/reload_channel.rb +0 -0
@@ -1,17 +1,23 @@
1
1
  <%= render_component_tag :header do %>
2
2
  <%= lookbook_render :toolbar, class: "!bg-lookbook-header-bg !text-lookbook-header-text !border-lookbook-header-border" do |toolbar| %>
3
3
  <% toolbar.with_section padded: true do %>
4
- <% if branding.present? %>
5
- <a
6
- <% if landing_path %>href="<%= landing_path %>"<% end %>
7
- class="text-sm truncate uppercase font-black tracking-wider text-lookbook-branding-text">
8
- <%= branding %>
9
- </a>
10
- <% end %>
4
+ <a <% if landing_path %>href="<%= landing_path %>"<% end %> class="flex items-center space-x-3">
5
+ <% if project_logo.present? %>
6
+ <i class="header-project-icon">
7
+ <%== project_logo %>
8
+ </i>
9
+ <% elsif project_logo != false %>
10
+ <%= lookbook_render :logo, size: 3.7 %>
11
+ <% end %>
12
+ <% if project_name.present? %>
13
+ <span class="text-sm truncate uppercase font-black tracking-wider text-lookbook-branding-text">
14
+ <%= project_name %>
15
+ </span>
16
+ <% end %>
17
+ </a>
11
18
  <% end %>
12
19
 
13
- <% toolbar.with_section padded: false, align: :right, class: "flex items-center" do %>
14
-
20
+ <% toolbar.with_section padded: false, align: :right, class: "flex items-center -mt-px" do %>
15
21
  <div x-show="loading" x-cloak>
16
22
  <svg class="animate-spin h-3.5 w-3.5 text-lookbook-header-text opacity-60" xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24">
17
23
  <circle class="opacity-25" cx="12" cy="12" r="10" stroke="currentColor" stroke-width="4"></circle>
@@ -21,29 +27,32 @@
21
27
 
22
28
  <%= lookbook_render :button_group do |group| %>
23
29
  <% if @debug_menu %>
24
- <% group.with_button icon: :help_circle, class: "opacity-50 hover:opacity-100 transition !text-lookbook-header-text", "x-show": "!loading" do |button| %>
30
+ <% group.with_button id: "debug-menu-button",
31
+ icon: :help_circle,
32
+ tooltip: "Debug info",
33
+ class: "!text-lookbook-header-text", "x-show": "!loading" do |button| %>
25
34
  <% menu = lookbook_render :debug_menu,
26
35
  version: Lookbook::VERSION,
27
36
  docs_url: "https://lookbook.build/guide",
28
- repo_url: "https://github.com/ViewComponent/lookbook" do %>
29
- <%= helpers.pretty_json(Lookbook.debug_data) %>
37
+ repo_url: "https://github.com/lookbook-hq/lookbook" do %>
38
+ <%= debug_data %>
30
39
  <% end %>
31
- <% button.with_dropdown({}).with_content(menu) %>
40
+ <% button.with_dropdown.with_content(menu) %>
32
41
  <% end %>
33
42
  <% end %>
34
43
 
35
44
  <% group.with_button icon: :menu,
36
- "@click.stop": "toggleSidebar",
45
+ "x-on:click.stop": "toggleSidebar",
37
46
  "x-show": "$store.layout.mobile && sidebarHidden",
38
47
  class: "!text-lookbook-header-text" %>
39
48
 
40
49
  <% group.with_button icon: :x,
41
- "@click.stop": "toggleSidebar",
50
+ "x-on:click.stop": "toggleSidebar",
42
51
  "x-show": "$store.layout.mobile && !sidebarHidden",
43
- "@keydown.esc.window": "closeMobileSidebar",
52
+ "x-on:keydown.esc.window": "closeMobileSidebar",
44
53
  class: "!text-lookbook-header-text" %>
45
- <% end %>
54
+ <% end %>
46
55
  <% end %>
47
56
  <% end %>
48
-
49
- <% end %>
57
+
58
+ <% end %>
@@ -1,14 +1,20 @@
1
1
  module Lookbook
2
2
  class Header::Component < Lookbook::BaseComponent
3
- renders_one :branding
3
+ attr_reader :project_logo, :project_name
4
4
 
5
- def initialize(debug_menu: false, **html_attrs)
5
+ def initialize(debug_menu: false, project_name: nil, project_logo: nil, **html_attrs)
6
6
  @debug_menu = debug_menu
7
+ @project_logo = project_logo
8
+ @project_name = project_name
7
9
  super(**html_attrs)
8
10
  end
9
11
 
10
12
  def landing_path
11
- helpers.landing_path if defined? helpers.landing_path
13
+ helpers.lookbook_landing_path if defined? helpers.lookbook_landing_path
14
+ end
15
+
16
+ def debug_data
17
+ JSON.pretty_generate(Lookbook.debug_data)
12
18
  end
13
19
  end
14
20
  end
@@ -3,9 +3,17 @@
3
3
  @apply transition block flex-none leading-none;
4
4
 
5
5
  svg {
6
- @apply w-full h-full stroke-current stroke-2 fill-transparent;
6
+ @apply w-full h-full stroke-current fill-transparent;
7
7
  stroke-linecap: round;
8
8
  stroke-linejoin: round;
9
9
  }
10
+
11
+ &.icon-stroke-2 svg {
12
+ stroke-width: 2;
13
+ }
14
+
15
+ &.icon-stroke-1 svg {
16
+ stroke-width: 1;
17
+ }
10
18
  }
11
19
  }
@@ -1,5 +1,5 @@
1
- <%= render_component_tag :i, style: "height: #{size_rems}; width: #{size_rems}; #{@html_attrs[:style]}" do %>
1
+ <%= render_component_tag :i, style: "height: #{size_rems}; width: #{size_rems}; #{@html_attrs[:style]}", class: "icon-stroke-#{stroke}" do %>
2
2
  <svg>
3
- <use :href="`/lookbook-assets/feather-sprite.svg#${iconName}`" x-cloak />
3
+ <use href="/lookbook-assets/img/lucide-sprite.svg#<%= @icon_name %>"></use>
4
4
  </svg>
5
- <% end %>
5
+ <% end %>
@@ -1,19 +1,18 @@
1
1
  module Lookbook
2
2
  class Icon::Component < Lookbook::BaseComponent
3
- def initialize(name:, size: 4, **html_attrs)
4
- @alpine_data = name.is_a?(Symbol) ? alpine_encode(name.to_s.tr("_", "-")) : name
3
+ ICON_CACHE = {}
4
+
5
+ attr_reader :stroke
6
+
7
+ def initialize(name:, size: 4, stroke: 2, **html_attrs)
8
+ @icon_name = name.to_s.tr("_", "-")
5
9
  @size = size || 4
10
+ @stroke = stroke
6
11
  super(**html_attrs)
7
12
  end
8
13
 
9
14
  def size_rems
10
15
  "#{@size * 0.25}rem"
11
16
  end
12
-
13
- protected
14
-
15
- def alpine_component
16
- "iconComponent"
17
- end
18
17
  end
19
18
  end
@@ -0,0 +1,20 @@
1
+ <%= render_component_tag tag_name,
2
+ id: id,
3
+ href: href,
4
+ class: [
5
+ "block text-lookbook-icon-button-stroke focus:outline-none focus-visible:outline-none #{padding}",
6
+ {
7
+ "hover:text-lookbook-icon-button-stroke-hover": !disabled,
8
+ "cursor-[not-allowed] opacity-50": disabled
9
+ }
10
+ ],
11
+ disabled: disabled,
12
+ aria: { label: tooltip } do %>
13
+ <span x-ref="icon">
14
+ <%= icons.present? ? safe_join(icons) : (lookbook_render(:icon, name: icon, size: icon_size, ":class": "{'animate-spin': _spinning}") if icon) %>
15
+ </span>
16
+ <% if tooltip %>
17
+ <label class="hidden" x-ref="tooltip"><%= tooltip %></label>
18
+ <% end %>
19
+ <%= content %>
20
+ <% end %>
@@ -0,0 +1,46 @@
1
+ module Lookbook
2
+ class IconButton::Component < Lookbook::BaseComponent
3
+ renders_many :icons, Lookbook::Icon::Component
4
+
5
+ ICON_SIZES = {
6
+ xs: 3,
7
+ sm: 3.5,
8
+ md: 4,
9
+ lg: 6
10
+ }
11
+
12
+ attr_reader :icon, :tooltip, :disabled, :size, :href
13
+
14
+ def initialize(id: nil, icon: nil, tooltip: nil, disabled: false, size: :md, href: nil, **html_attrs)
15
+ @id = id
16
+ @icon = icon
17
+ @tooltip = tooltip
18
+ @disabled = disabled
19
+ @size = size
20
+ @href = href
21
+ super(**html_attrs)
22
+ end
23
+
24
+ def id
25
+ @id ||= Utils.temp_id(prefix: "button")
26
+ end
27
+
28
+ def icon_size
29
+ ICON_SIZES[size]
30
+ end
31
+
32
+ def padding
33
+ [:xs, :sm].include?(size) ? "p-1" : "p-2"
34
+ end
35
+
36
+ def tag_name
37
+ href.present? ? :a : :button
38
+ end
39
+
40
+ protected
41
+
42
+ def alpine_component
43
+ "buttonComponent"
44
+ end
45
+ end
46
+ end
@@ -0,0 +1,6 @@
1
+ <svg width="<%= size_rems %>" viewBox="0 0 18 22" xmlns="http://www.w3.org/2000/svg">
2
+ <g stroke="currentColor" stroke-width="<%= stroke %>" fill="none" fill-rule="evenodd" stroke-linecap="round" stroke-linejoin="round">
3
+ <path d="M3.5 1H17v20H3.5A2.5 2.5 0 0 1 1 18.5v-15A2.5 2.5 0 0 1 3.5 1Z"/>
4
+ <path d="M1.153 19.36c0-.737.261-1.188.596-1.57.417-.475.985-.79 1.751-.79H17M6.801 5.1v7.554L6.8 12.7h5.57"/>
5
+ </g>
6
+ </svg>
@@ -0,0 +1,15 @@
1
+ module Lookbook
2
+ class Logo::Component < Lookbook::BaseComponent
3
+ attr_reader :stroke
4
+
5
+ def initialize(size: 4, stroke: 2, **html_attrs)
6
+ @size = size || 4
7
+ @stroke = stroke
8
+ super(**html_attrs)
9
+ end
10
+
11
+ def size_rems
12
+ "#{@size * 0.25}rem"
13
+ end
14
+ end
15
+ end
@@ -0,0 +1,34 @@
1
+ @layer components {
2
+ [data-component="message"] {
3
+ @apply bg-lookbook-message-bg p-4 xs:p-6 shadow border border-lookbook-divider rounded flex gap-6 w-full;
4
+
5
+ &.icon-right {
6
+ @apply flex-row-reverse items-center;
7
+ }
8
+
9
+ &.icon-left {
10
+ @apply items-start;
11
+ }
12
+
13
+ & .message-title {
14
+ @apply text-base text-lookbook-message-title uppercase font-bold tracking-wide mb-2;
15
+ overflow-wrap: anywhere;
16
+ }
17
+
18
+ & .message-icon {
19
+ @apply flex-none opacity-30 hidden xs:block;
20
+ }
21
+
22
+ &.theme-error {
23
+ @apply border-red-200;
24
+
25
+ & .message-title {
26
+ @apply text-red-700;
27
+ }
28
+
29
+ & .message-icon {
30
+ @apply text-red-600 opacity-50;
31
+ }
32
+ }
33
+ }
34
+ }
@@ -0,0 +1,26 @@
1
+ <%= render_component_tag class: {
2
+ "icon-left": (icon_position == :left),
3
+ "icon-right": (icon_position == :right),
4
+ "theme-info": (theme == :info),
5
+ "theme-error": (theme == :error),
6
+ } do %>
7
+ <% if icon_name %>
8
+ <div class="message-icon">
9
+ <% if icon_name == :logo %>
10
+ <%= lookbook_render :logo, stroke: 1, size: 10 %>
11
+ <% else %>
12
+ <%= icon icon_name, stroke: 1, size: 10 %>
13
+ <% end %>
14
+ </div>
15
+ <% end %>
16
+ <div class="flex-grow">
17
+ <% if title %>
18
+ <h4 class="message-title">
19
+ <%= title %>
20
+ </h4>
21
+ <% end %>
22
+ <div class="opacity-70">
23
+ <%= lookbook_render :prose, size: :sm, content: content %>
24
+ </div>
25
+ </div>
26
+ <% end %>
@@ -0,0 +1,13 @@
1
+ module Lookbook
2
+ class Message::Component < Lookbook::BaseComponent
3
+ attr_reader :title, :icon_name, :icon_position, :theme
4
+
5
+ def initialize(title: nil, icon: nil, icon_position: :left, theme: :info, **html_attrs)
6
+ @title = title
7
+ @icon_name = icon
8
+ @icon_position = icon_position
9
+ @theme = theme
10
+ super(**html_attrs)
11
+ end
12
+ end
13
+ end
@@ -1,5 +1,5 @@
1
1
  <%= render_component_tag class: "flex flex-col overflow-hidden h-full",
2
- "@filter:change.stop": "filter($event.detail.text)" do %>
2
+ "x-on:filter:change.stop": "filter($event.detail.text)" do %>
3
3
 
4
4
  <% if toolbar %>
5
5
  <%= toolbar %>
@@ -25,5 +25,4 @@
25
25
  </div>
26
26
  <% end %>
27
27
  </div>
28
-
29
28
  <% end %>
@@ -11,10 +11,10 @@
11
11
  style: "padding-left: #{left_pad}px",
12
12
  "x-bind": "bindings.toggle" do %>
13
13
  <div class="nav-action-inner">
14
- <%= icon nil,
15
- size: 3,
16
- class: "nav-toggle-icon",
17
- "x-effect": "iconName = open ? 'chevron-down' : 'chevron-right'" if children? %>
14
+ <% if children? %>
15
+ <%= icon "chevron-down", size: 3, class: "nav-toggle-icon", "x-show": "open", "x-cloak": "true" %>
16
+ <%= icon "chevron-right", size: 3, class: "nav-toggle-icon", "x-show": "!open", "x-cloak": "true" %>
17
+ <% end %>
18
18
  <%= icon nav_icon, size: 3.5, class: "mr-1.5 text-lookbook-nav-icon-stroke" %>
19
19
  <span class="truncate"><%= label %></span>
20
20
  </div>
@@ -2,8 +2,11 @@
2
2
  id: id,
3
3
  key: "#{id}-entity-#{type}",
4
4
  class: "list-none",
5
+ "x-init": "$nextTick(() => checkActive())",
5
6
  "x-show": "!filteredOut",
6
- data: { "entity-type": type },
7
+ "@navigation:complete.window": "checkActive",
8
+ # "x-effect": "active = ($refs.link && (window.location.pathname === $refs.link.getAttribute('href')))",
9
+ data: { "entity-type": type.to_s.tr("_","-") },
7
10
  cloak: true do %>
8
11
  <%= lookbook_tag href.present? ? :a : :button,
9
12
  href: href,
@@ -12,12 +15,12 @@
12
15
  style: "padding-left: #{left_pad}px",
13
16
  "x-bind": "bindings.#{href.present? ? "link" : "toggle"}" do %>
14
17
  <div class="nav-action-inner">
15
- <%= icon nil,
16
- size: 3,
17
- class: "nav-toggle-icon",
18
- "x-effect": "iconName = open ? 'chevron-down' : 'chevron-right'" if children? %>
18
+ <% if children? %>
19
+ <%= icon "chevron-down", size: 3, class: "nav-toggle-icon", "x-show": "open", "x-cloak": "true" %>
20
+ <%= icon "chevron-right", size: 3, class: "nav-toggle-icon", "x-show": "!open", "x-cloak": "true" %>
21
+ <% end %>
19
22
  <%= icon nav_icon, size: 3.5, class: "mr-1.5 text-lookbook-nav-icon-stroke" %>
20
- <span class="truncate <% if node.type == :preview %>font-bold<% end %>"><%= label %></span>
23
+ <span class="truncate <% if node.type == :preview %>font-semibold<% end %>"><%= label %></span>
21
24
  </div>
22
25
  <% end %>
23
26
 
@@ -3,8 +3,8 @@ module Lookbook
3
3
  ICONS = {
4
4
  page: :file,
5
5
  preview: :layers,
6
- example: :eye,
7
- group: :eye
6
+ scenario: :eye,
7
+ scenario_group: :eye
8
8
  }.freeze
9
9
 
10
10
  def nav_icon
@@ -24,7 +24,7 @@ module Lookbook
24
24
  end
25
25
 
26
26
  def type
27
- collapsed? ? :example : node.type
27
+ collapsed? ? :scenario : node.type
28
28
  end
29
29
 
30
30
  def collapsed?
@@ -6,20 +6,12 @@ export default function navItemComponent({ id, matchers }) {
6
6
  return {
7
7
  filteredOut: false,
8
8
 
9
+ active: false,
10
+
9
11
  get open() {
10
12
  return this.isCollection && this.isOpen(id);
11
13
  },
12
14
 
13
- get active() {
14
- if (this.$refs.link) {
15
- return (
16
- this.location &&
17
- this.location.pathname === this.$refs.link.getAttribute("href")
18
- );
19
- }
20
- return false;
21
- },
22
-
23
15
  get children() {
24
16
  return this.$refs.items ? Array.from(this.$refs.items.children) : [];
25
17
  },
@@ -28,6 +20,12 @@ export default function navItemComponent({ id, matchers }) {
28
20
  return !this.$refs.link;
29
21
  },
30
22
 
23
+ checkActive() {
24
+ this.active =
25
+ this.$refs.link &&
26
+ window.location.pathname === this.$refs.link.getAttribute("href");
27
+ },
28
+
31
29
  toggle() {
32
30
  this.toggleOpen(id);
33
31
  },
@@ -58,7 +56,7 @@ export default function navItemComponent({ id, matchers }) {
58
56
 
59
57
  bindings: {
60
58
  toggle: {
61
- ["@click.stop"]: "toggle",
59
+ ["x-on:click.stop"]: "toggle",
62
60
  ["x-ref"]: "toggle",
63
61
  },
64
62
  link: {
@@ -1,6 +1,6 @@
1
1
  module Lookbook
2
2
  class Nav::Item::Component < Lookbook::BaseComponent
3
- delegate :label, :depth, to: :node
3
+ delegate :label, :depth, :priority, to: :node
4
4
 
5
5
  attr_reader :node, :nav_id
6
6
 
@@ -1,15 +1,15 @@
1
1
  <%= render_component_tag "x-data": "{ activeTab: null }" do %>
2
- <div class="flex w-full border-b border-lookbook-divider mb-6">
2
+ <div class="flex w-full border-b border-lookbook-divider mb-6 lg:mb-8">
3
3
  <%= lookbook_render :tabs, theme: :page do |t| %>
4
4
  <% @tabs.each do |props| %>
5
- <%= t.tab **props %>
5
+ <%= t.with_tab **props %>
6
6
  <% end %>
7
7
  <% end %>
8
8
  </div>
9
9
  <%= lookbook_render :tab_panels do |t| %>
10
10
  <% @tabs.each do |props| %>
11
- <% t.panel name: props[:name] do %>
12
- <%= lookbook_render :prose, markdown: props[:markdown], class: "max-w-none flex-none" do %>
11
+ <% t.with_panel name: props[:name] do %>
12
+ <%= lookbook_render :prose, size: :md, markdown: props[:markdown], class: "max-w-none flex-none" do %>
13
13
  <%== props[:tab_content] %>
14
14
  <% end %>
15
15
  <% end %>
@@ -1,6 +1,6 @@
1
1
  <%= render_component_tag class: "overflow-hidden" do %>
2
2
  <div class="bg-lookbook-params-editor-bg border border-lookbook-divider rounded-md overflow-x-auto">
3
- <table class="border-collapse w-full" :class="narrow && 'linear'">
3
+ <table class="border-collapse w-full" x-bind:class="narrow && 'linear'">
4
4
  <thead>
5
5
  <tr>
6
6
  <th class="param-label">Param</th>
@@ -9,7 +9,7 @@ module Lookbook
9
9
  def initialize(**html_attrs)
10
10
  @field_count = -1
11
11
  @@input_styles = {}
12
- super(**html_attrs)
12
+ super
13
13
  end
14
14
 
15
15
  def before_render
@@ -23,6 +23,7 @@ module Lookbook
23
23
  end
24
24
 
25
25
  def self.add_styles(input, styles)
26
+ @@input_styles = {} unless defined?(@@input_styles)
26
27
  @@input_styles[input] ||= styles
27
28
  end
28
29
 
@@ -7,7 +7,7 @@
7
7
  }
8
8
 
9
9
  th {
10
- @apply font-bold py-4 px-4 align-middle text-left;
10
+ @apply font-semibold py-4 px-4 align-middle text-left;
11
11
  }
12
12
 
13
13
  th.param-label {
@@ -29,7 +29,7 @@
29
29
  }
30
30
 
31
31
  td.param-label {
32
- @apply font-bold;
32
+ @apply font-semibold;
33
33
  }
34
34
 
35
35
  .param-input-wrapper {
@@ -65,7 +65,7 @@
65
65
  }
66
66
 
67
67
  td.param-label {
68
- @apply font-bold;
68
+ @apply font-semibold;
69
69
  }
70
70
 
71
71
  td.param-description-empty {
@@ -14,10 +14,10 @@ module Lookbook
14
14
  styles, html = StylesExtractor.call(render_input)
15
15
  Editor::Component.add_styles(param.input, styles)
16
16
 
17
- escaped_value = json_escape(param.value.to_s)
17
+ escaped_value = html_escape(json_escape(param.value.to_s).gsub("\n", '\n'))
18
18
  wrapper_attrs = {
19
19
  data: {"param-input": param.input},
20
- "x-data": "paramsInputComponent({name: '#{param.name}', value: '#{escaped_value}'})"
20
+ "x-data": "paramsInputComponent({name: \"#{param.name}\", value: \"#{escaped_value}\"})"
21
21
  }
22
22
  @rendered_input = tag.div(**wrapper_attrs) { html.html_safe }
23
23
  end
@@ -1,12 +1,25 @@
1
1
  @layer components {
2
2
  [data-component="prose"] {
3
+ @apply font-prose;
4
+
5
+ /* letter-spacing: -0.015em !important; */
6
+
3
7
  [data-component="code"] {
4
8
  @apply border border-lookbook-divider rounded-md;
5
9
  }
6
10
 
7
11
  [data-component="embed"],
8
- [data-component="code"] {
12
+ [data-component="code"],
13
+ [data-lookbook-embed] {
9
14
  @apply my-8;
10
15
  }
16
+
17
+ [data-lookbook-embed] {
18
+ @apply rounded-md;
19
+ }
20
+ }
21
+
22
+ #page [data-component="prose"] h2 {
23
+ @apply border-b border-lookbook-divider pb-3;
11
24
  }
12
25
  }
@@ -1,3 +1,8 @@
1
- <%= render_component_tag class: "prose #{size_class} text-lookbook-prose-text bg-lookbook-prose-bg prose-a:text-lookbook-prose-link" do %>
1
+ <%= render_component_tag class: "
2
+ prose #{size_class}
3
+ text-lookbook-prose-text bg-lookbook-prose-bg prose-a:text-lookbook-prose-link
4
+ prose-headings:font-semibold
5
+ prose-h1:font-bold
6
+ " do %>
2
7
  <%== rendered_content %>
3
8
  <% end %>
@@ -1,15 +1,13 @@
1
1
  module Lookbook
2
2
  class Prose::Component < Lookbook::BaseComponent
3
- include Lookbook::OutputHelper
4
-
5
- def initialize(size: :md, markdown: true, **html_attrs)
3
+ def initialize(size: :sm, markdown: true, **html_attrs)
6
4
  @size = size
7
5
  @markdown = markdown
8
6
  super(**html_attrs)
9
7
  end
10
8
 
11
9
  def rendered_content
12
- @markdown ? markdown(content.strip_heredoc) : helpers.raw(content)
10
+ @markdown ? MarkdownRenderer.call(content.strip_heredoc) : helpers.raw(content)
13
11
  end
14
12
 
15
13
  def size_class
@@ -19,7 +17,7 @@ module Lookbook
19
17
  when :lg
20
18
  "prose-lg"
21
19
  else
22
- ""
20
+ "prose-sm lg:prose-base"
23
21
  end
24
22
  end
25
23
  end
@@ -2,10 +2,10 @@
2
2
  <% panes.each.with_index(1) do |pane, i| %>
3
3
  <%= pane %>
4
4
  <% if i < panes.size %>
5
- <div class="bg-lookbook-divider relative z-50" x-init="registerGutter">
6
- <div class="absolute z-10 bg-transparent hover:bg-lookbook-draggable-hint transition-all" :class="{
7
- 'w-[9px] h-full -translate-x-1/2 cursor-[col-resize]': vertical,
8
- 'h-[9px] w-full -translate-y-1/2 cursor-[row-resize]': horizontal
5
+ <div class="split-layout-gutter bg-lookbook-divider relative z-50" x-init="registerGutter">
6
+ <div class="absolute z-10 bg-transparent hover:bg-lookbook-draggable-hint transition-all" x-bind:class="{
7
+ 'w-[9px] h-full -translate-x-1/2 cursor-[col-resize] split-layout-gutter-vertical': vertical,
8
+ 'h-[9px] w-full -translate-y-1/2 cursor-[row-resize] split-layout-gutter-horizontal': horizontal
9
9
  }"></div>
10
10
  </div>
11
11
  <% end %>
@@ -8,7 +8,7 @@ module Lookbook
8
8
 
9
9
  def initialize(**html_attrs)
10
10
  @panel_counter = 0
11
- super(**html_attrs)
11
+ super
12
12
  end
13
13
 
14
14
  protected
@@ -9,8 +9,8 @@
9
9
  <%= safe_join(tabs) %>
10
10
  </div>
11
11
  <div x-ref="dropdownTrigger" class="absolute" x-show="hasHiddenTabs" :style="{left: `${triggerLeft}px`}">
12
- <%= lookbook_render :button, icon: :chevrons_right, "x-show": "visibleTabsCount > 0" %>
13
- <%= lookbook_render :button, icon: :menu, class: "-ml-3", "x-show": "visibleTabsCount === 0" %>
12
+ <%= lookbook_render :icon_button, icon: :chevrons_right, "x-show": "visibleTabsCount > 0" %>
13
+ <%= lookbook_render :icon_button, icon: :menu, class: "-ml-3", "x-show": "visibleTabsCount === 0" %>
14
14
  </div>
15
15
  <div class="hidden">
16
16
  <div x-ref="tabsDropdown" x-cloak>