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
@@ -0,0 +1,40 @@
1
+ <div class="bg-red-50 h-[calc(100vh_-_40px)] w-full overflow-y-auto">
2
+ <div>
3
+ <header class="px-8 py-6">
4
+ <h2 class="text-xl font-bold text-red-700"><%= @error.type %></h2>
5
+ </header>
6
+
7
+ <div class="px-8 py-6 mb-8 border-t border-b border-red-200 bg-red-100 text-base leading-relaxed">
8
+ <pre class="whitespace-pre-wrap font-ui leading-tight text-red-900"><%= @error.message %></pre>
9
+ </div>
10
+
11
+ <% if @error.file_path %>
12
+ <div class="text-sm mx-8 mb-3 font-mono">
13
+ <span><%= @error.relative_file_path %></span>
14
+ <% if @error.line_number %>
15
+ <span>[line <strong><%= @error.line_number %></strong>]</span>
16
+ <% end %>
17
+ </div>
18
+
19
+ <div class="px-8">
20
+ <%= lookbook_render :file_source,
21
+ file_path: @error.file_path,
22
+ highlight_lines: [@error.line_number],
23
+ lines_around_highlight: 5,
24
+ source: @error.source,
25
+ class: "border border-red-200" %>
26
+ </div>
27
+ <% end %>
28
+
29
+ <h3 class="font-bold mb-2 px-8 py-2 mt-8">Full stack trace:</h3>
30
+ <div class="text-xs font-mono w-full overflow-auto">
31
+ <div class="px-8 pb-10 text-gray-400 leading-relaxed whitespace-nowrap">
32
+ <% @error.backtrace.each do |line| %>
33
+ <div class="hover:text-gray-900 transition-colors duration-100">
34
+ <%= line %>
35
+ </div>
36
+ <% end %>
37
+ </div>
38
+ </div>
39
+ </div>
40
+ </div>
@@ -0,0 +1,10 @@
1
+ <%= render "lookbook/partials/blank_slate" do %>
2
+ <%= lookbook_render :message,
3
+ id: "not-found-message",
4
+ title: @error.message,
5
+ icon: :file_x,
6
+ icon_position: :right,
7
+ theme: :error do %>
8
+ <%= @error.detail || "It may have been moved or deleted." %>
9
+ <% end %>
10
+ <% end %>
@@ -1,25 +1,40 @@
1
- <div id="landing" class="flex flex-col items-center justify-center h-full w-full">
2
- <div class="text-center" id="landing-<%= @previews.any? ? "with" : "no" %>-content">
3
- <% if @config.project_name.downcase == "lookbook" %>
4
- <div class="flex justify-center pb-4">
5
- <svg class="flex-none mx-auto w-[140px]" viewBox="0 0 275 36">
6
- <g fill-rule="nonzero" fill="none">
7
- <path d="M4.536 35c-1.408 0-2.504-.392-3.288-1.176-.784-.784-1.176-1.88-1.176-3.288V5.576c0-1.44.384-2.544 1.152-3.312.768-.768 1.856-1.152 3.264-1.152 1.44 0 2.536.384 3.288 1.152.752.768 1.128 1.872 1.128 3.312v22.08h11.712c1.216 0 2.152.312 2.808.936.656.624.984 1.528.984 2.712 0 1.184-.328 2.096-.984 2.736-.656.64-1.592.96-2.808.96H4.536ZM42.066.632c3.425 0 6.425.72 9 2.16 2.577 1.44 4.585 3.464 6.025 6.072 1.44 2.608 2.16 5.672 2.16 9.192 0 2.624-.408 5.008-1.224 7.152-.816 2.144-1.984 3.992-3.504 5.544-1.52 1.552-3.336 2.736-5.448 3.552-2.112.816-4.448 1.224-7.008 1.224-3.424 0-6.432-.728-9.024-2.184-2.592-1.456-4.6-3.496-6.024-6.12-1.424-2.624-2.136-5.68-2.136-9.168 0-2.624.408-5.008 1.224-7.152.816-2.144 1.984-3.984 3.504-5.52 1.52-1.536 3.336-2.712 5.448-3.528C37.17 1.04 39.507.632 42.067.632Zm0 7.392c-1.663 0-3.095.392-4.295 1.176-1.2.784-2.12 1.92-2.76 3.408-.64 1.488-.96 3.304-.96 5.448 0 3.168.704 5.64 2.112 7.416 1.408 1.776 3.376 2.664 5.904 2.664 1.696 0 3.136-.4 4.32-1.2 1.07-.723 1.917-1.733 2.543-3.031-.39-1.314-.934-2.855-2.087-5.286-.07-.147-.07-.233 0-.38l2.187-5.84a8.262 8.262 0 0 0-1.06-1.735c-1.407-1.76-3.375-2.64-5.903-2.64ZM80.27.632c3.424 0 6.424.72 9 2.16 2.576 1.44 4.584 3.464 6.024 6.072 1.44 2.608 2.16 5.672 2.16 9.192 0 2.624-.408 5.008-1.224 7.152-.816 2.144-1.984 3.992-3.504 5.544-1.52 1.552-3.336 2.736-5.448 3.552-2.112.816-4.448 1.224-7.008 1.224-3.424 0-6.432-.728-9.024-2.184-2.592-1.456-4.6-3.496-6.024-6.12-1.424-2.624-2.136-5.68-2.136-9.168 0-2.624.408-5.008 1.224-7.152.816-2.144 1.984-3.984 3.504-5.52 1.52-1.536 3.336-2.712 5.448-3.528C75.373 1.04 77.71.632 80.27.632Zm0 7.392c-1.664 0-3.096.392-4.296 1.176-1.2.784-2.12 1.92-2.76 3.408-.64 1.488-.96 3.304-.96 5.448 0 3.168.704 5.64 2.112 7.416 1.408 1.776 3.376 2.664 5.904 2.664 1.696 0 3.136-.4 4.32-1.2.999-.675 1.804-1.6 2.416-2.775-.395-1.37-.933-2.95-2.162-5.542-.07-.147-.07-.233 0-.38l2.276-6.08a8.166 8.166 0 0 0-.946-1.495c-1.408-1.76-3.376-2.64-5.904-2.64Zm26.299 27.408c-1.408 0-2.496-.392-3.264-1.176-.768-.784-1.152-1.88-1.152-3.288V5.192c0-1.472.384-2.584 1.152-3.336.768-.752 1.856-1.128 3.264-1.128 1.44 0 2.536.376 3.288 1.128.752.752 1.128 1.864 1.128 3.336v10.464h.096l11.664-12.864a7.705 7.705 0 0 1 1.944-1.512c.688-.368 1.464-.552 2.328-.552 1.344 0 2.312.344 2.904 1.032.592.688.864 1.488.816 2.4-.048.912-.424 1.752-1.128 2.52l-11.616 12.336v-3.6l12.192 13.776c.832.928 1.248 1.88 1.248 2.856s-.328 1.784-.984 2.424c-.656.64-1.624.96-2.904.96-1.088 0-1.96-.216-2.616-.648-.656-.432-1.368-1.08-2.136-1.944L111.08 19.736h-.096v11.232c0 1.408-.368 2.504-1.104 3.288-.736.784-1.84 1.176-3.312 1.176Z" fill="#919191"/>
8
- <path d="M140.403 35c-1.504 0-2.648-.392-3.432-1.176-.784-.784-1.176-1.912-1.176-3.384V5.72c0-1.472.392-2.6 1.176-3.384.784-.784 1.928-1.176 3.432-1.176h11.712c2.432 0 4.504.36 6.216 1.08 1.712.72 3.016 1.736 3.912 3.048.896 1.312 1.344 2.848 1.344 4.608 0 1.984-.568 3.68-1.704 5.088-1.136 1.408-2.68 2.368-4.632 2.88v-.768c2.304.416 4.088 1.344 5.352 2.784 1.264 1.44 1.896 3.28 1.896 5.52 0 2.976-1.064 5.32-3.192 7.032-2.128 1.712-5.032 2.568-8.712 2.568h-12.192Zm3.84-6.48h7.152c1.632 0 2.824-.312 3.576-.936.752-.624 1.128-1.56 1.128-2.808 0-1.248-.376-2.176-1.128-2.784-.752-.608-1.944-.912-3.576-.912h-7.152v7.44Zm0-13.92h6.288c1.6 0 2.776-.288 3.528-.864.752-.576 1.128-1.456 1.128-2.64 0-1.184-.376-2.056-1.128-2.616-.752-.56-1.928-.84-3.528-.84h-6.288v6.96Zm41.034 20.928c-3.424 0-6.432-.728-9.024-2.184-2.592-1.456-4.6-3.496-6.024-6.12-1.424-2.624-2.136-5.68-2.136-9.168 0-2.624.408-5.008 1.224-7.152.816-2.144 1.984-3.984 3.504-5.52 1.52-1.536 3.336-2.712 5.448-3.528 2.112-.816 4.448-1.224 7.008-1.224 3.424 0 6.424.72 9 2.16 2.576 1.44 4.584 3.464 6.024 6.072 1.44 2.608 2.16 5.672 2.16 9.192 0 2.624-.408 5.008-1.224 7.152-.816 2.144-1.984 3.992-3.504 5.544-1.52 1.552-3.336 2.736-5.448 3.552-2.112.816-4.448 1.224-7.008 1.224Zm0-7.392c1.696 0 3.136-.4 4.32-1.2 1.184-.8 2.096-1.952 2.736-3.456.64-1.504.96-3.312.96-5.424 0-3.168-.704-5.632-2.112-7.392-1.408-1.76-3.376-2.64-5.904-2.64-1.664 0-3.096.392-4.296 1.176-1.2.784-2.12 1.92-2.76 3.408-.64 1.488-.96 3.304-.96 5.448 0 3.168.704 5.64 2.112 7.416 1.408 1.776 3.376 2.664 5.904 2.664Zm38.203 7.392c-3.424 0-6.432-.728-9.024-2.184-2.592-1.456-4.6-3.496-6.024-6.12-1.424-2.624-2.136-5.68-2.136-9.168 0-2.624.408-5.008 1.224-7.152.816-2.144 1.984-3.984 3.504-5.52 1.52-1.536 3.336-2.712 5.448-3.528 2.112-.816 4.448-1.224 7.008-1.224 3.424 0 6.424.72 9 2.16 2.576 1.44 4.584 3.464 6.024 6.072 1.44 2.608 2.16 5.672 2.16 9.192 0 2.624-.408 5.008-1.224 7.152-.816 2.144-1.984 3.992-3.504 5.544-1.52 1.552-3.336 2.736-5.448 3.552-2.112.816-4.448 1.224-7.008 1.224Zm0-7.392c1.696 0 3.136-.4 4.32-1.2 1.184-.8 2.096-1.952 2.736-3.456.64-1.504.96-3.312.96-5.424 0-3.168-.704-5.632-2.112-7.392-1.408-1.76-3.376-2.64-5.904-2.64-1.664 0-3.096.392-4.296 1.176-1.2.784-2.12 1.92-2.76 3.408-.64 1.488-.96 3.304-.96 5.448 0 3.168.704 5.64 2.112 7.416 1.408 1.776 3.376 2.664 5.904 2.664Zm26.299 7.296c-1.408 0-2.496-.392-3.264-1.176-.768-.784-1.152-1.88-1.152-3.288V5.192c0-1.472.384-2.584 1.152-3.336.768-.752 1.856-1.128 3.264-1.128 1.44 0 2.536.376 3.288 1.128.752.752 1.128 1.864 1.128 3.336v10.464h.096l11.664-12.864a7.705 7.705 0 0 1 1.944-1.512c.688-.368 1.464-.552 2.328-.552 1.344 0 2.312.344 2.904 1.032.592.688.864 1.488.816 2.4-.048.912-.424 1.752-1.128 2.52l-11.616 12.336v-3.6l12.192 13.776c.832.928 1.248 1.88 1.248 2.856s-.328 1.784-.984 2.424c-.656.64-1.624.96-2.904.96-1.088 0-1.96-.216-2.616-.648-.656-.432-1.368-1.08-2.136-1.944L254.29 19.736h-.096v11.232c0 1.408-.368 2.504-1.104 3.288-.736.784-1.84 1.176-3.312 1.176Z" fill="#ABABAB"/>
9
- </g>
10
- </svg>
11
- </div>
12
- <% elsif @config.project_name != false %>
13
- <h5 class="text-base text-lookbook-blank-slate-title truncate uppercase font-black tracking-wide mb-2">
14
- <%= @config.project_name %>
15
- </h5>
1
+ <%
2
+ sidebar_panels_config = @config.preview_inspector.sidebar_panels.map(&:to_sym)
3
+ %>
4
+
5
+ <%= render "lookbook/partials/blank_slate" do %>
6
+ <% if @blank_slate %>
7
+ <%= lookbook_render :message,
8
+ id: "welcome-message",
9
+ title: "Welcome to your Lookbook!",
10
+ icon: :logo do %>
11
+ <p>
12
+ There isn't much to see yet<% if sidebar_panels_config.any? %>, but<% end %>
13
+ <% if sidebar_panels_config.include?(:previews) %>
14
+ <%= link_to "component previews",
15
+ "#{@config.links.docs}/guide/previews",
16
+ target: "_blank"
17
+ %>
18
+ <% end %>
19
+ <% if sidebar_panels_config.many? %>and<% end %>
20
+ <% if sidebar_panels_config.include?(:pages) %>
21
+ <%= link_to "content pages",
22
+ "#{@config.links.docs}/guide/pages",
23
+ target: "_blank"
24
+ %>
25
+ <% end %>
26
+ <% if sidebar_panels_config.any? %>
27
+ will show up here as soon as they are added.
28
+ <% end %>
29
+ </p>
30
+ <% end %>
31
+ <% else %>
32
+ <%= lookbook_render :message,
33
+ id: "get-started-message",
34
+ title: @config.project_name,
35
+ icon: :inspect,
36
+ icon_position: :right do %>
37
+ <p>Select a preview from the nav to get started.</p>
38
+ <% end %>
16
39
  <% end %>
17
- <div class="opacity-60">
18
- <% if @previews.any? %>
19
- <p>Select a preview from the nav to get started.</p>
20
- <% else %>
21
- <p><a class="underline" href="https://lookbook.build/guide/previews" target="_blank">Create a preview</a> to get started.</p>
22
- <% end %>
23
- </div>
24
- </div>
25
- </div>
40
+ <% end %>
@@ -1,5 +1,6 @@
1
1
  <%= text_field_tag(name, value,
2
2
  **input_options,
3
3
  type: "color",
4
- "x-model.throttle.300ms": "value"
4
+ "x-on:change.stop": "",
5
+ "x-on:blur": "value = $el.value",
5
6
  ) %>
@@ -0,0 +1,19 @@
1
+ <div x-data="{changed: false, applyChange(){ this.value = this.$refs.input.value; this.changed = false; }}">
2
+
3
+ <div x-on:change.stop="changed = ($event.target.value !== value)" class="flex items-center gap-2">
4
+ <%= text_field_tag(name, value,
5
+ **input_options,
6
+ type: input,
7
+ class: "flex-grow",
8
+ "x-ref": "input",
9
+ "x-on:keydown.enter.stop": "applyChange"
10
+ ) %>
11
+
12
+ <%= lookbook_render :button,
13
+ icon: :check,
14
+ tooltip: "Apply changes",
15
+ class: "flex-none !bg-lookbook-button-bg hover:!bg-lookbook-button-bg-hover rounded-md !text-lookbook-button-text",
16
+ "x-show": "changed",
17
+ "x-on:click": "applyChange" %>
18
+ </div>
19
+ </div>
@@ -15,6 +15,6 @@ span_classes = [
15
15
  class: class_names(button_classes),
16
16
  role: "switch",
17
17
  type: "button",
18
- "@click.stop": "value = value == 'true' ? 'false' : 'true'", escape: false do %>
18
+ "x-on:click.stop": "value = value == 'true' ? 'false' : 'true'", escape: false do %>
19
19
  <%= tag.span "aria-hidden": true, class: class_names(span_classes) %>
20
20
  <% end %>
@@ -1,4 +1,4 @@
1
- <% items = examples.select { |example| example.notes.present? } %>
1
+ <% items = scenarios.select { |scenario| scenario.notes.present? } %>
2
2
  <% if items.many? %>
3
3
  <div class="divide-y divide-dashed divide-lookbook-divider bg-lookbook-prose-bg h-full w-full">
4
4
  <% items.each do |item| %>
@@ -1,7 +1,7 @@
1
1
  <%= lookbook_render :code, line_numbers: true, full_height: true do -%>
2
- <% if examples.many? -%>
3
- <% examples.each do |example| -%><%== "<!-- #{example.label} -->\n#{beautify(example.output)}\n\n" -%><% end %>
2
+ <% if scenarios.many? -%>
3
+ <% scenarios.each do |scenario| -%><%== "<!-- #{scenario.label} -->\n#{scenario.beautified_output}\n\n" -%><% end %>
4
4
  <%- else -%>
5
- <%== beautify(examples.first.output) -%>
5
+ <%== scenarios.first.beautified_output -%>
6
6
  <%- end %>
7
7
  <% end %>
@@ -1,5 +1,6 @@
1
1
  <div class="overflow-hidden h-full w-full">
2
2
  <%= lookbook_render :viewport,
3
+ key: (lookbook_preview_path(request.query_parameters).force_encoding('UTF-8').parameterize unless Rails.env.test?),
3
4
  iframe_id: "preview-iframe",
4
5
  src: lookbook_preview_path(request.query_parameters.merge(lookbook_timestamp: Time.now)),
5
6
  alpine_data: "$store.inspector.main",
@@ -1,11 +1,11 @@
1
1
  <div class="h-full">
2
- <% if examples.many? %>
3
- <%= lookbook_render :code, language: examples.first.source_lang[:name], line_numbers: true, full_height: true do -%>
4
- <%- examples.each.with_index(1) do |example, i| -%>
5
- <%== "#{sprintf example.source_lang[:comment], example.label}\n#{example.source}\n#{"\n" if i < examples.size}" %><% end %>
2
+ <% if scenarios.many? %>
3
+ <%= lookbook_render :code, language: scenarios.first.source_lang[:name], line_numbers: true, full_height: true do -%>
4
+ <%- scenarios.each.with_index(1) do |scenario, i| -%>
5
+ <%== "#{sprintf scenario.source_lang[:comment], scenario.label}\n#{scenario.source}\n#{"\n" if i < scenarios.size}" %><% end %>
6
6
  <% end %>
7
7
  <% else %>
8
- <% example = examples.first %>
9
- <%= lookbook_render :code, language: example.source_lang[:name], line_numbers: true, full_height: true do %><%== example.source %><% end %>
8
+ <% scenario = scenarios.first %>
9
+ <%= lookbook_render :code, language: scenario.source_lang[:name], line_numbers: true, full_height: true do %><%== scenario.source %><% end %>
10
10
  <% end %>
11
11
  </div>
@@ -1,150 +1,169 @@
1
- <%= lookbook_render :split_layout,
2
- alpine_data: "$store.layout.inspector",
3
- ":class": "($store.inspector.drawer.hidden || #{@drawer_panels.none?}) && '!grid-rows-[1fr] !grid-cols-[1fr]'",
4
- data: {
5
- "preview-target": @target.id
6
- } do |layout| %>
7
-
8
- <%= layout.with_pane class: "flex flex-col h-full overflow-hidden",
9
- "x-effect": "forceOrientation = (layoutWidth < $store.inspector.minVerticalSplitWidth) ? 'horizontal' : null" do %>
10
-
11
- <%= lookbook_render :toolbar, id: "main-toolbar" do |toolbar| %>
12
- <% toolbar.with_section ":class": "layoutResizing && 'overflow-hidden'" do %>
13
- <%= lookbook_render :tabs, alpine_data: "$store.inspector.main", id: "inspector-tabs-main" do |tabs| %>
14
- <%= @main_panels.each do |panel| %>
15
- <% tabs.with_tab name: panel.name,
16
- label: panel.label,
17
- hotkey: panel.hotkey,
18
- disabled: panel.disabled %>
1
+ <main class="h-[calc(100vh_-_2.5rem)]">
2
+ <%= lookbook_render :split_layout,
3
+ id: "inspector",
4
+ alpine_data: "$store.layout.inspector",
5
+ ":class": "($store.inspector.drawer.hidden || #{@drawer_panels.none?}) && '!grid-rows-[1fr] !grid-cols-[1fr]'",
6
+ data: {
7
+ "preview-target": @target.id
8
+ } do |layout| %>
9
+
10
+ <%= layout.with_pane class: "flex flex-col h-full overflow-hidden",
11
+ "x-effect": "forceOrientation = (layoutWidth < $store.inspector.minVerticalSplitWidth) ? 'horizontal' : null" do %>
12
+
13
+ <%= lookbook_render :toolbar, id: "main-toolbar" do |toolbar| %>
14
+ <% toolbar.with_section ":class": "layoutResizing && 'overflow-hidden'" do %>
15
+ <%= lookbook_render :tabs, alpine_data: "$store.inspector.main", id: "inspector-tabs-main" do |tabs| %>
16
+ <%= @main_panels.each do |panel| %>
17
+ <% tabs.with_tab name: panel.name,
18
+ label: panel.label,
19
+ hotkey: panel.hotkey,
20
+ disabled: panel.disabled %>
21
+ <% end %>
19
22
  <% end %>
20
23
  <% end %>
21
- <% end %>
22
24
 
23
- <% toolbar.with_section align: :right, class: "flex-none" do %>
24
- <% if @dynamic_display_options.any? %>
25
- <%= lookbook_render "display_options/editor" do |editor| %>
26
- <% @dynamic_display_options.each do |key, opts| %>
27
- <% editor.with_field name: key, opts: opts, value: @static_display_options[key] %>
25
+ <% toolbar.with_section align: :right, class: "flex-none" do %>
26
+ <% if @dynamic_display_options.any? %>
27
+ <%= lookbook_render "display_options/editor" do |editor| %>
28
+ <% @dynamic_display_options.each do |key, opts| %>
29
+ <% editor.with_field name: key, opts: opts, value: @static_display_options[key] %>
30
+ <% end %>
28
31
  <% end %>
29
32
  <% end %>
30
33
  <% end %>
31
- <% end %>
32
-
33
- <% toolbar.with_section divide: :left, class: "flex-none relative z-10" do %>
34
- <%= lookbook_render :button_group do |group| %>
35
- <% group.with_button icon: :link,
36
- tooltip: "Copy preview URL",
37
- copy: true do %>
38
- <%= lookbook_inspect_url(@target.lookup_path, request.query_parameters) %>
39
- <% end %>
40
34
 
41
- <% if @pages.any? %>
42
- <% group.with_button icon: :code,
43
- tooltip: "Copy page embed code",
35
+ <% toolbar.with_section divide: :left, class: "flex-none relative z-10" do %>
36
+ <%= lookbook_render :button_group do |group| %>
37
+ <% if @engine.preview_embeds_allowed? %>
38
+ <%= group.with_button id: "embed-generator-dropdown-button", icon: :code_2, tooltip: "Get embed code" do |button| %>
39
+ <% button.with_dropdown.with_content(lookbook_render :embed_code_dropdown,
40
+ pages: @pages,
41
+ preview: @preview,
42
+ target: @target,
43
+ params: request.query_parameters,
44
+ policy: @config.preview_embeds.policy
45
+ ) %>
46
+ <% end %>
47
+ <% end %>
48
+ <% group.with_button id: "copy-preview-url-button",
49
+ icon: :link,
50
+ tooltip: "Copy preview URL",
44
51
  copy: true do %>
45
- &lt;%= embed <%= @preview.preview_class_name %>, :<%= @target.name %>, params: <%= request.query_parameters.deep_symbolize_keys.to_s %> %&gt;
52
+ <%= lookbook_inspect_url(@target.lookup_path, request.query_parameters) %>
46
53
  <% end %>
54
+
55
+ <% group.with_button id: "refresh-preview-button",
56
+ icon: :refresh_cw,
57
+ tooltip: "Refresh preview",
58
+ "x-on:click.stop": "startSpin(); $dispatch('viewport:reload'); stopSpin(500);" %>
59
+
60
+ <% group.with_button id: "open-preview-button",
61
+ icon: :external_link,
62
+ href: lookbook_preview_path(@target.lookup_path, request.query_parameters),
63
+ tooltip: "Open preview in new window",
64
+ target: "_blank" %>
65
+
66
+ <% group.with_button id: "show-vertical-drawer-button",
67
+ icon: "sidebar",
68
+ tooltip: "Show drawer",
69
+ "x-on:click": "$store.inspector.drawer.hidden = false",
70
+ class: "rotate-180",
71
+ "x-show": "$store.inspector.drawer.hidden && vertical",
72
+ cloak: true %>
73
+
74
+ <% group.with_button id: "show-bottom-drawer-button",
75
+ icon: "credit-card",
76
+ tooltip: "Show drawer",
77
+ "x-on:click": "$store.inspector.drawer.hidden = false",
78
+ class: "rotate-180",
79
+ "x-show": "$store.inspector.drawer.hidden && !vertical",
80
+ cloak: true %>
47
81
  <% end %>
48
-
49
- <% group.with_button icon: :refresh_cw,
50
- tooltip: "Refresh preview",
51
- "@click.stop": "startSpin(); $dispatch('viewport:reload'); stopSpin(500);" %>
52
-
53
- <% group.with_button icon: :external_link,
54
- href: lookbook_preview_path(@target.lookup_path, request.query_parameters),
55
- tooltip: "Open preview in new window",
56
- target: "_blank" %>
57
-
58
- <% group.with_button icon: "vertical ? 'sidebar' : 'credit-card'",
59
- tooltip: "Show drawer",
60
- "@click": "$store.inspector.drawer.hidden = false",
61
- class: "rotate-180",
62
- "x-show": "$store.inspector.drawer.hidden",
63
- cloak: true %>
64
82
  <% end %>
65
83
  <% end %>
66
- <% end %>
67
84
 
68
- <div class="h-full relative overflow-auto">
69
- <%= lookbook_render :tab_panels, alpine_data: "$store.inspector.main", id: "inspector-panels-main" do |tabs| %>
70
- <% @main_panels.each do |panel| %>
71
- <% tabs.with_panel name: panel.name do %>
72
- <%= lookbook_render :inspector_panel, name: panel.name do %>
73
- <%= render panel.partial, **@inspector_data, panel: panel, **panel.locals %>
85
+ <div class="h-full relative overflow-auto">
86
+ <%= lookbook_render :tab_panels, alpine_data: "$store.inspector.main", id: "inspector-panels-main" do |tabs| %>
87
+ <% @main_panels.each do |panel| %>
88
+ <% tabs.with_panel name: panel.name do %>
89
+ <%= lookbook_render :inspector_panel, name: panel.name do %>
90
+ <%= render panel.partial, **@inspector_data, panel: panel, **panel.locals %>
91
+ <% end %>
74
92
  <% end %>
75
93
  <% end %>
76
94
  <% end %>
77
- <% end %>
78
- </div>
79
- <% end %>
80
-
81
- <%= layout.with_pane class: "flex flex-col h-full overflow-hidden bg-lookbook-drawer-bg",
82
- "x-show": "!$store.inspector.drawer.hidden && #{@drawer_panels.any?}" do %>
95
+ </div>
96
+ <% end %>
83
97
 
84
- <%= lookbook_render :toolbar, id: "drawer-toolbar" do |toolbar| %>
85
- <% toolbar.with_section ":class": "layoutResizing && 'overflow-hidden'" do %>
86
- <%= lookbook_render :tabs, alpine_data: "$store.inspector.drawer", id: "inspector-tabs-drawer" do |tabs| %>
87
- <%= @drawer_panels.each do |panel| %>
88
- <% tabs.with_tab name: panel.name,
89
- label: panel.label,
90
- hotkey: panel.hotkey,
91
- disabled: panel.disabled %>
98
+ <%= layout.with_pane class: "flex flex-col h-full overflow-hidden bg-lookbook-drawer-bg",
99
+ "x-show": "!$store.inspector.drawer.hidden && #{@drawer_panels.any?}" do %>
100
+
101
+ <%= lookbook_render :toolbar, id: "drawer-toolbar" do |toolbar| %>
102
+ <% toolbar.with_section ":class": "layoutResizing && 'overflow-hidden'" do %>
103
+ <%= lookbook_render :tabs, alpine_data: "$store.inspector.drawer", id: "inspector-tabs-drawer" do |tabs| %>
104
+ <%= @drawer_panels.each do |panel| %>
105
+ <% tabs.with_tab name: panel.name,
106
+ label: panel.label,
107
+ hotkey: panel.hotkey,
108
+ disabled: panel.disabled %>
109
+ <% end %>
92
110
  <% end %>
93
111
  <% end %>
94
- <% end %>
95
112
 
96
- <% toolbar.with_section align: :right, class: "flex-none relative z-10" do %>
97
- <%= lookbook_render :button_group do |group| %>
98
- <%= @drawer_panels.select { |p| !p.disabled && p.copy }.each do |panel| %>
99
- <% group.with_button icon: :copy,
100
- tooltip: "Copy panel contents",
101
- copy: !!panel.copy,
102
- "x-show": "$store.inspector.drawer.activeTab === '#{panel.name}'",
103
- cloak: true do %>
104
- <%= panel.copy ? panel.copy : "" %>
105
- <% end %>
106
- <% end %>
113
+ <% toolbar.with_section align: :right, class: "flex-none relative z-10" do %>
114
+ <%= lookbook_render :button_group do |group| %>
115
+ <%= @drawer_panels.select { |p| !p.disabled && p.copy }.each do |panel| %>
116
+ <% group.with_button id: "copy-panel-contents-button",
117
+ icon: :copy,
118
+ tooltip: "Copy panel contents",
119
+ copy: !!panel.copy,
120
+ "x-show": "$store.inspector.drawer.activeTab === '#{panel.name}'",
121
+ cloak: true do %>
122
+ <%= panel.copy ? panel.copy : "" %>
123
+ <% end %>
124
+ <% end %>
125
+ <% end %>
107
126
  <% end %>
108
- <% end %>
109
-
110
- <% toolbar.with_section divide: :left, class: "flex-none relative z-10" do %>
111
- <%= lookbook_render :button_group do |group| %>
112
-
113
- <% group.with_button icon: :corner_up_right,
114
- tooltip: "Move drawer to right",
115
- "@click": "switchOrientation",
116
- "x-show": "horizontal && layoutWidth > $store.inspector.minVerticalSplitWidth",
117
- cloak: true %>
118
127
 
119
- <% group.with_button icon: :corner_up_right,
120
- "x-show": "horizontal && layoutWidth <= $store.inspector.minVerticalSplitWidth",
121
- disabled: true,
122
- cloak: true %>
123
-
124
- <% group.with_button icon: :corner_left_down,
125
- tooltip: "Move drawer to bottom",
126
- "@click": "switchOrientation",
127
- "x-show": "vertical",
128
- cloak: true %>
129
-
130
- <% group.with_button icon: :x_circle,
131
- tooltip: "Hide drawer",
132
- "@click": "$store.inspector.drawer.hidden = true",
133
- cloak: true %>
128
+ <% toolbar.with_section divide: :left, class: "flex-none relative z-10" do %>
129
+ <%= lookbook_render :button_group do |group| %>
130
+
131
+ <% group.with_button id: "drawer-to-right-button",
132
+ icon: :sidebar_open,
133
+ tooltip: "Pin drawer on right",
134
+ "x-on:click": "switchOrientation",
135
+ "x-show": "horizontal",
136
+ ":class": "{'pointer-events-none opacity-50 !cursor-not-allowed': horizontal && layoutWidth <= $store.inspector.minVerticalSplitWidth}",
137
+ cloak: true %>
138
+
139
+ <% group.with_button id: "drawer-to-bottom-button",
140
+ icon: :sidebar_open,
141
+ tooltip: "Pin drawer on bottom",
142
+ "x-on:click": "switchOrientation",
143
+ "x-show": "vertical",
144
+ class: "rotate-90",
145
+ cloak: true %>
146
+
147
+ <% group.with_button id: "hide-drawer-button",
148
+ icon: :x_circle,
149
+ tooltip: "Hide drawer",
150
+ "x-on:click": "$store.inspector.drawer.hidden = true",
151
+ cloak: true %>
152
+ <% end %>
134
153
  <% end %>
135
- <% end %>
136
- <% end %>
137
-
138
- <div class="h-full overflow-auto">
139
- <%= lookbook_render :tab_panels, alpine_data: "$store.inspector.drawer", id: "inspector-panels-drawer" do |tabs| %>
140
- <% @drawer_panels.each do |panel| %>
141
- <% tabs.with_panel name: panel.name do %>
142
- <%= lookbook_render :inspector_panel, name: panel.name do %>
143
- <%= render panel.partial, **@inspector_data, panel: panel, **panel.locals %>
154
+ <% end %>
155
+
156
+ <div class="h-full overflow-auto">
157
+ <%= lookbook_render :tab_panels, alpine_data: "$store.inspector.drawer", id: "inspector-panels-drawer" do |tabs| %>
158
+ <% @drawer_panels.each do |panel| %>
159
+ <% tabs.with_panel name: panel.name do %>
160
+ <%= lookbook_render :inspector_panel, name: panel.name do %>
161
+ <%= render panel.partial, **@inspector_data, panel: panel, **panel.locals %>
162
+ <% end %>
144
163
  <% end %>
145
164
  <% end %>
146
165
  <% end %>
147
- <% end %>
148
- </div>
166
+ </div>
167
+ <% end %>
149
168
  <% end %>
150
- <% end %>
169
+ </main>