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
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: d6dfc00bd48155e8ce1a32cd2ad27668bb1b86a179ecbcce6236ea29f7cd4ef3
4
- data.tar.gz: 30abb627e57ba885312e2b9c4a70f7cfc2a8a27dc6d5fbb6fa721dca38ae913f
3
+ metadata.gz: d32ce1185c6e1b4bb8558b3be2189658a6d3d53e1c1e877aa4f0d20479ac1e4c
4
+ data.tar.gz: 644d7744ec1e423171543857e168bfea53ec1398f9f01332788091fb6dbedd62
5
5
  SHA512:
6
- metadata.gz: b6634bc5a89fe0b43c389bfeeaf521563d8de55fa2cf8a5778f7471a62bd69949ed79bbbc07a539b87882a0a4802515718a08e5fe7a6637f389c93b8e3bb961f
7
- data.tar.gz: 89e1af478c55cc5f62c532715432f958d8be1651531917828669104ac3b1aa74177fd14162353e583adc9632cb58529c3fa690ac8220b08006b0c568c3e8381d
6
+ metadata.gz: b23539320c7e73e54803315ccc523036d6b0f8dd1f74d368a6a4b34b43f77333e4b0b4a13fa69e94dd3d9310134396fd639531b1e3cf83def1e862c289f151e0
7
+ data.tar.gz: 32e5466b1a6be8237e617040abcf93ea6041803fca1e209bc984f0bc104b4a80eb733112f98d3ca3eca86372e6d0e4f2f2aeeda14fc966a1e34bb8c8fbb717ad
data/README.md CHANGED
@@ -1,27 +1,30 @@
1
+ <div align="center">
1
2
  <br>
2
- <img alt="Lookbook Logo" src=".github/assets/lookbook_logo.svg" width="180">
3
+ <p><a href="https://lookbook.build"><img src=".github/assets/lookbook_logo.svg" width="240"></a></p>
3
4
 
4
- A tool to help browse, develop, test & document [ViewComponents](https://viewcomponent.org/) in Ruby on Rails apps.
5
+ <p>A UI development environment for Ruby on Rails applications.</p>
5
6
 
6
- [![Gem version](https://img.shields.io/gem/v/lookbook)](https://rubygems.org/gems/lookbook)
7
- [![CI status](https://github.com/ViewComponent/lookbook/actions/workflows/ci.yml/badge.svg?branch=main)](https://github.com/ViewComponent/lookbook/actions/workflows/ci.yml)
8
- <br>
9
-
10
- ## Documentation
7
+ <p><strong><a href="https://lookbook.build">Documentation</a> &nbsp;|&nbsp; <a href="http://demo.lookbook.build/lookbook">Demo site</a></strong></p>
11
8
 
12
- **Lookbook guide and API docs**: [lookbook.build](https://lookbook.build)
9
+ <p><a href="https://rubygems.org/gems/lookbook"><img src="https://img.shields.io/gem/v/lookbook" alt="Gem version"></a>
10
+ <a href="https://github.com/lookbook-hq/lookbook/actions/workflows/ci.yml"><img src="https://github.com/lookbook-hq/lookbook/actions/workflows/ci.yml/badge.svg" alt="CI status"></a></p>
13
11
 
14
- > _Looking for pre-v1.0 documentation? [Head over here](https://github.com/ViewComponent/lookbook/tree/0.9.x)._
12
+ </div>
15
13
 
14
+ ---
16
15
 
17
- ## Demo
16
+ <div align="center">
17
+ Lookbook combines a powerful <strong>component browser</strong> and <strong>preview system</strong> with an <strong>integrated documentation engine</strong> to help teams build robust, modular, maintainable user interfaces.<br><br>
18
+ It's compatible with <a href="https://viewcomponent.org/">ViewComponent</a>, <a href="https://www.phlex.fun/">Phlex</a>, ActionView partials and more.
19
+ <br><br>
20
+ <a href="https://lookbook.build"><strong>Read the docs &rarr;</strong></a>
18
21
 
19
- ✨ **Online Demo**: [lookbook-demo-app.herokuapp.com/lookbook](https://lookbook-demo-app.herokuapp.com/lookbook)
22
+ </div>
20
23
 
21
- ✨ **Demo repo**: [github.com/ViewComponent/lookbook-demo](https://github.com/ViewComponent/lookbook-demo)
22
24
 
23
- [![Lookbook UI](.github/assets/lookbook_screenshot_v1.0_beta.png)](https://lookbook-demo-app.herokuapp.com/lookbook/)
25
+ ---
24
26
 
27
+ [![Lookbook UI](.github/assets/lookbook_ui.png)](http://lookbook.build/)
25
28
 
26
29
  ## Development
27
30
 
@@ -29,21 +32,9 @@ Lookbook is implemented as an isolated [Rails Engine](https://guides.rubyonrails
29
32
 
30
33
  This repository contains:
31
34
 
32
- * The Lookbook source code ([`/app`](https://github.com/ViewComponent/lookbook/tree/main/app), [`/lib`](https://github.com/ViewComponent/lookbook/tree/main/lib), [`/config`](https://github.com/ViewComponent/lookbook/tree/main/config), etc)
33
- * A '[workbench](#workbench)' app used for Lookbook component development ([`/workbench`](https://github.com/ViewComponent/lookbook/tree/main/workbench)).
34
- * The Lookbook [documentation site](#docs-site) source code and content ([`/docs`](https://github.com/ViewComponent/lookbook/tree/main/docs)).
35
- * A [test suite](#testing) with a 'runable' dummy app ([`/spec`](https://github.com/ViewComponent/lookbook/tree/main/spec)).
36
-
37
- ### Workbench
38
-
39
- To preview the Lookbook components within a Lookbook instance you can run the included `workbench` app:
40
-
41
- 1. Clone this repo
42
- 2. Install dependencies: `bundle install & npm install`
43
- 3. Start the app: `bin/workbench`
44
- 4. Visit http://localhost:4545/lookbook to view the Lookbook instance
45
-
46
- The `workbench` app will be started in development mode and any changes to Lookbook's views or assets will immediately be reflected in the UI.
35
+ * The Lookbook source code ([`/app`](https://github.com/lookbook-hq/lookbook/tree/main/app), [`/lib`](https://github.com/lookbook-hq/lookbook/tree/main/lib), [`/config`](https://github.com/lookbook-hq/lookbook/tree/main/config), etc)
36
+ * The Lookbook [documentation site](#docs-site) source code and content ([`/docs`](https://github.com/lookbook-hq/lookbook/tree/main/docs)).
37
+ * A [test suite](#testing) with a 'runable' dummy app ([`/spec`](https://github.com/lookbook-hq/lookbook/tree/main/spec)).
47
38
 
48
39
  ### Documentation site
49
40
 
@@ -58,29 +49,36 @@ To preview changes locally you can run a development version of the docs site:
58
49
 
59
50
  ### Testing
60
51
 
61
- Lookbook uses [RSpec](https://relishapp.com/rspec) for testing.
52
+ Lookbook uses [RSpec](https://relishapp.com/rspec). [Appraisal](https://github.com/thoughtbot/appraisal) is used to run tests against different Ruby and Rails versions.
62
53
 
63
- Tests can be run using the `rake spec` or `bundle exec rspec` commands.
54
+ Tests can be run using the `bundle exec appraisal rspec` command.
64
55
 
65
56
  The dummy app that the tests are being run against can be viewed by running the `bin/dummy` command and then browsing to http://localhost:9292/lookbook
66
57
 
58
+ ### Releases
59
+
60
+ Lookbook uses [Release It!](https://github.com/release-it/release-it) to automate the release process.
61
+
62
+ Running `npm run release` will start the process of publishing a new release and walks though all the steps from picking a version number to publishing the updated gem.
63
+
64
+ Publishing a release requires write permissions for this repository (lookbook-hq/lookbook) and 2FA publish permissions for Lookbook on RubyGems.
67
65
 
68
66
  ## Contributing
69
67
 
70
68
  Lookbook is an un-funded open source project and contributions of all types and sizes are most welcome!
71
69
 
72
- Please take the time to read over the [Contributing](./CONTRIBUTING.md) guide before making your first contribution and if anything isn't clear then [start a discussion](https://github.com/ViewComponent/lookbook/discussions) and we will do our best to help you out.
70
+ Please take the time to read over the [Contributing](./CONTRIBUTING.md) guide before making your first contribution and if anything isn't clear then [start a discussion](https://github.com/lookbook-hq/lookbook/discussions) and we will do our best to help you out.
73
71
 
74
72
  ## Contributors
75
73
 
76
74
  Lookbook was created by [Mark Perkins](https://github.com/allmarkedup) and continues to grow
77
- &amp; improve thanks to the ideas, suggestions and hard work of all of [these excellent humans](https://github.com/ViewComponent/lookbook/graphs/contributors):
75
+ &amp; improve thanks to the ideas, suggestions and hard work of all of [these excellent humans](https://github.com/lookbook-hq/lookbook/graphs/contributors):
78
76
  <br>
79
77
  <br>
80
- <a href="https://github.com/ViewComponent/lookbook/graphs/contributors">
81
- <img alt="Lookbook contributors" src="https://contrib.rocks/image?repo=ViewComponent/lookbook&columns=14" width="800" />
78
+ <a href="https://github.com/lookbook-hq/lookbook/graphs/contributors">
79
+ <img src="https://contrib.rocks/image?repo=lookbook-hq/lookbook&columns=14" width="800" />
82
80
  </a>
83
81
 
84
82
  ## License
85
83
 
86
- The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).
84
+ The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).
@@ -1,6 +1,8 @@
1
1
  module Lookbook
2
2
  class BaseComponent < ViewComponent::Base
3
- include Lookbook::ComponentHelper
3
+ send(:include, Lookbook::Engine.routes.url_helpers) # YARD parsing workaround: https://github.com/lsegal/yard/issues/546
4
+ include Lookbook::UiElementsHelper
5
+ include Lookbook::ClassNamesHelper if Engine.runtime_context.rails_older_than?("6.1.0")
4
6
 
5
7
  def initialize(alpine_data: [], **html_attrs)
6
8
  @alpine_data ||= alpine_data
@@ -1,28 +1,17 @@
1
- <%= render_component_tag tag_name,
2
- href: @href,
3
- class: [
4
- "block text-lookbook-icon-button-stroke focus:outline-none focus-visible:outline-none #{padding}",
5
- {
6
- "hover:text-lookbook-icon-button-stroke-hover": !@disabled,
7
- "cursor-[not-allowed] opacity-50": @disabled
8
- }
9
- ],
10
- disabled: @disabled,
11
- "@keydown.esc.stop": "hideDropdown",
12
- "@navigation:complete.window": "updateDropdown" do %>
13
- <span x-ref="icon">
14
- <%= icon || lookbook_render(:icon, name: @icon, size: icon_size, ":class": "{'animate-spin': _spinning}") %>
15
- </span>
16
- <% if @tooltip %>
17
- <label class="hidden" x-ref="tooltip"><%= @tooltip %></label>
18
- <% end %>
19
- <% if content %>
20
- <div x-ref="content"><%== content %></div>
21
- <% end %>
22
- <% if dropdown? %>
23
- <div class="hidden" x-ref="dropdown">
24
- <div class="bg-white divide-y divide-lookbook-divider text-left">
25
- <%== dropdown %>
1
+ <%= lookbook_render button_component.new(
2
+ id: id,
3
+ icon: icon,
4
+ **button_attrs,
5
+ "x-on:keydown.esc.stop.document": "hideDropdown",
6
+ "x-on:navigation:complete.window": "updateDropdown") do %>
7
+ <%= content %>
8
+ <% end %>
9
+
10
+ <% if dropdown? %>
11
+ <% content_for :dropdowns do %>
12
+ <div data-dropdown-id="<%= id %>">
13
+ <div class="divide-y divide-lookbook-divider text-left">
14
+ <%= dropdown %>
26
15
  </div>
27
16
  </div>
28
17
  <% end %>
@@ -1,21 +1,26 @@
1
- import tippy from "~/app/assets/lookbook/js/lib/tippy";
2
- import { initTooltip } from "~/app/assets/lookbook/js/components/tooltip";
1
+ import tippy from "~/assets/js/lib/tippy";
2
+ import { initTooltip } from "~/assets/js/components/tooltip";
3
3
 
4
4
  export default function buttonComponent() {
5
5
  let tooltip = null;
6
6
  let dropdown = null;
7
7
 
8
8
  return {
9
+ updateAfterNavigate: true,
10
+
9
11
  init() {
12
+ this.updateAfterNavigate =
13
+ this.$el.dataset.updateAfterNavigate !== "false";
14
+
10
15
  if (this.$refs.tooltip) {
11
16
  tooltip = initTooltip(this, {
12
17
  target: this.$refs.icon,
13
18
  });
14
19
  }
15
20
 
16
- if (this.$refs.dropdown) {
21
+ if (this.dropdownContent) {
17
22
  dropdown = tippy(this.$el, {
18
- content: this.$refs.dropdown.innerHTML,
23
+ content: this.dropdownContent,
19
24
  trigger: "click",
20
25
  theme: "menu",
21
26
  triggerTarget: this.$el,
@@ -32,6 +37,16 @@ export default function buttonComponent() {
32
37
  }
33
38
  },
34
39
 
40
+ get dropdownContent() {
41
+ if (this.$root && this.$root.id) {
42
+ const dropdown = document.querySelector(
43
+ `[data-dropdown-id="${this.$root.id}"]`
44
+ );
45
+ return dropdown ? dropdown.innerHTML : null;
46
+ }
47
+ return null;
48
+ },
49
+
35
50
  hideDropdown() {
36
51
  if (dropdown) {
37
52
  dropdown.hide();
@@ -41,9 +56,11 @@ export default function buttonComponent() {
41
56
  updateDropdown() {
42
57
  if (dropdown) {
43
58
  dropdown.hide();
44
- this.$nextTick(() => {
45
- dropdown.setContent(this.$refs.dropdown.innerHTML);
46
- });
59
+ if (this.updateAfterNavigate) {
60
+ this.$nextTick(() => {
61
+ dropdown.setContent(this.dropdownContent);
62
+ });
63
+ }
47
64
  }
48
65
  },
49
66
 
@@ -1,44 +1,35 @@
1
1
  module Lookbook
2
2
  class Button::Component < Lookbook::BaseComponent
3
- renders_one :icon, Lookbook::Icon::Component
4
3
  renders_one :dropdown
5
4
 
6
- ICON_SIZES = {
7
- xs: 3,
8
- sm: 3.5,
9
- md: 4,
10
- lg: 6
11
- }
5
+ attr_reader :id, :icon, :button_attrs
12
6
 
13
- def initialize(icon: nil, tooltip: nil, disabled: false, size: :md, href: nil, **html_attrs)
7
+ def initialize(id: nil, icon: nil, **html_attrs)
8
+ @id = id
14
9
  @icon = icon
15
- @tooltip = tooltip
16
- @disabled = disabled
17
- @size = size
18
- @href = href
19
- super(**html_attrs)
10
+ @button_attrs = html_attrs
20
11
  end
21
12
 
22
- def icon_size
23
- ICON_SIZES[@size]
13
+ def dropdown?
14
+ dropdown.present?
24
15
  end
25
16
 
26
- def padding
27
- [:xs, :sm].include?(@size) ? "p-1" : "p-2"
17
+ def text_button?
18
+ content.present?
28
19
  end
29
20
 
30
- def tag_name
31
- @href.present? ? :a : :button
21
+ def icon_button?
22
+ !text_button? && icon
32
23
  end
33
24
 
34
- def dropdown?
35
- dropdown.present?
25
+ def before_render
26
+ if dropdown? && id.nil?
27
+ raise "Dropdown buttons must be given an ID"
28
+ end
36
29
  end
37
30
 
38
- protected
39
-
40
- def alpine_component
41
- "buttonComponent"
31
+ def button_component
32
+ icon_button? ? IconButton::Component : TextButton::Component
42
33
  end
43
34
  end
44
35
  end
@@ -1,7 +1,5 @@
1
1
  module Lookbook
2
2
  class Code::Component < Lookbook::BaseComponent
3
- include Lookbook::OutputHelper
4
-
5
3
  def initialize(
6
4
  source: nil,
7
5
  language: :html,
@@ -162,14 +162,13 @@
162
162
  } /* Comment */
163
163
  .err {
164
164
  color: var(--hl-error-fg);
165
- background-color: var(--hl-error-bg);
166
165
  } /* Error */
167
166
  .g {
168
167
  color: var(--hl-subtle-fg);
169
168
  } /* Generic */
170
169
  .k {
171
170
  color: var(--hl-keyword);
172
- font-weight: bold;
171
+ font-weight: 600;
173
172
  } /* Keyword; catches prefixes and css3 */
174
173
  .l {
175
174
  color: var(--hl-subtle-fg);
@@ -180,7 +179,7 @@
180
179
  } /* Name */
181
180
  .o {
182
181
  color: var(--hl-operator);
183
- font-weight: bold;
182
+ font-weight: 600;
184
183
  } /* Operator */
185
184
  .x {
186
185
  color: var(--hl-subtle-fg);
@@ -194,7 +193,7 @@
194
193
  } /* Comment.Multiline */
195
194
  .cp {
196
195
  color: var(--hl-comment-preproc);
197
- font-weight: bold;
196
+ font-weight: 600;
198
197
  } /* Comment.Preproc */
199
198
  .c1 {
200
199
  color: var(--hl-comment);
@@ -203,7 +202,7 @@
203
202
  .cs {
204
203
  color: var(--hl-comment-special-fg);
205
204
  background-color: var(--hl-comment-special-bg);
206
- font-weight: bold;
205
+ font-weight: 600;
207
206
  font-style: italic;
208
207
  } /* Comment.Special */
209
208
  .gd {
@@ -232,38 +231,38 @@
232
231
  } /* Generic.Prompt */
233
232
  .gs {
234
233
  color: var(--hl-subtle-fg);
235
- font-weight: bold;
234
+ font-weight: 600;
236
235
  } /* Generic.Strong */
237
236
  .gu {
238
237
  color: var(--hl-subheading);
239
- font-weight: bold;
238
+ font-weight: 600;
240
239
  } /* Generic.Subheading */
241
240
  .gt {
242
241
  color: var(--hl-danger);
243
242
  } /* Generic.Traceback */
244
243
  .kc {
245
244
  color: var(--hl-keyword-crude);
246
- font-weight: bold;
245
+ font-weight: 600;
247
246
  } /* Keyword.Constant */
248
247
  .kd {
249
248
  color: var(--hl-keyword-crude);
250
- font-weight: bold;
249
+ font-weight: 600;
251
250
  } /* Keyword.Declaration */
252
251
  .kn {
253
252
  color: var(--hl-keyword-crude);
254
- font-weight: bold;
253
+ font-weight: 600;
255
254
  } /* Keyword.Namespace */
256
255
  .kp {
257
256
  color: var(--hl-keyword-crude);
258
- font-weight: bold;
257
+ font-weight: 600;
259
258
  } /* Keyword.Pseudo */
260
259
  .kr {
261
260
  color: var(--hl-keyword-crude);
262
- font-weight: bold;
261
+ font-weight: 600;
263
262
  } /* Keyword.Reserved */
264
263
  .kt {
265
264
  color: var(--hl-keyword-subtle);
266
- font-weight: bold;
265
+ font-weight: 600;
267
266
  } /* Keyword.Type */
268
267
  .ld {
269
268
  color: var(--hl-subtle-fg);
@@ -282,7 +281,7 @@
282
281
  } /* Name.Builtin */
283
282
  .nc {
284
283
  color: var(--hl-class);
285
- font-weight: bold;
284
+ font-weight: 600;
286
285
  } /* Name.Class */
287
286
  .no {
288
287
  color: var(--hl-variable);
@@ -295,11 +294,11 @@
295
294
  } /* Name.Entity */
296
295
  .ne {
297
296
  color: var(--hl-exception);
298
- font-weight: bold;
297
+ font-weight: 600;
299
298
  } /* Name.Exception */
300
299
  .nf {
301
300
  color: var(--hl-function);
302
- font-weight: bold;
301
+ font-weight: 600;
303
302
  } /* Name.Function */
304
303
  .nl {
305
304
  color: var(--hl-subtle-fg);
@@ -321,7 +320,7 @@
321
320
  } /* Name.Variable */
322
321
  .ow {
323
322
  color: var(--hl-word);
324
- font-weight: bold;
323
+ font-weight: 600;
325
324
  } /* Operator.Word */
326
325
  .w {
327
326
  color: var(--hl-whitespace);
@@ -1,10 +1,10 @@
1
- <%= lookbook_render :button,
1
+ <%= lookbook_render :icon_button,
2
2
  name: "copy-button",
3
- **@button_attrs,
3
+ **button_attrs,
4
4
  "x-data": prepare_alpine_data,
5
- "@click.prevent": "copyToClipboard" do |button| %>
6
- <% button.icon name: @icon, size: icon_size, "x-show": "!copied", cloak: true %>
7
- <%= icon :check, size: icon_size, class: "text-green-500", "x-show": "copied", cloak: true %>
5
+ "x-on:click.prevent": "copyToClipboard" do |button| %>
6
+ <% button.with_icon name: icon, size: icon_size, "x-show": "!copied", cloak: true %>
7
+ <% button.with_icon name: :check, size: icon_size, class: "text-green-500", "x-show": "copied", cloak: true %>
8
8
  <% if content %>
9
9
  <div x-ref="copyTarget" class="hidden"><%== content %></div>
10
10
  <% end %>
@@ -1,4 +1,4 @@
1
- import { initClipboard } from "~/app/assets/lookbook/js/components/clipboard";
1
+ import { initClipboard } from "~/assets/js/components/clipboard";
2
2
  import buttonComponent from "@components/button/component";
3
3
 
4
4
  export default function copyButtonComponent() {
@@ -1,19 +1,22 @@
1
1
  module Lookbook
2
2
  class CopyButton::Component < Lookbook::BaseComponent
3
- def initialize(target: nil, icon: :code, **attrs)
3
+ attr_reader :icon, :size, :target, :button_attrs
4
+
5
+ def initialize(target: nil, icon: :code, size: :md, **attrs)
4
6
  @icon = icon
7
+ @size = size
5
8
  @target = target
6
9
  @button_attrs = attrs
7
10
  end
8
11
 
9
12
  def icon_size
10
- Lookbook::Button::Component::ICON_SIZES[@size]
13
+ IconButton::Component::ICON_SIZES[size]
11
14
  end
12
15
 
13
16
  protected
14
17
 
15
18
  def alpine_data
16
- content ? nil : alpine_encode(@target)
19
+ content ? nil : alpine_encode(target)
17
20
  end
18
21
 
19
22
  def alpine_component
@@ -6,7 +6,7 @@
6
6
  <a href="#"
7
7
  class="text-xs flex items-center hover:underline"
8
8
  x-data="clipboardComponent"
9
- @click.prevent.stop="copyToClipboard('#debug-data')">
9
+ x-on:click.prevent.stop="copyToClipboard('#debug-data')">
10
10
  <span x-show="copied" x-cloak>
11
11
  <%= icon :check, size: 2.5, class: "text-green-600" %>
12
12
  </span>
@@ -20,13 +20,14 @@
20
20
  <li>
21
21
  <a href="#"
22
22
  class="text-xs flex items-center hover:underline"
23
- @click.stop="localStorage.clear(); window.location.reload();">
23
+ x-on:click.stop="localStorage.clear(); window.location.reload();">
24
24
  <%= icon :refresh_cw, size: 2.5 %>
25
25
  <span class="ml-2">Reset local storage</span>
26
26
  </a>
27
27
  </li>
28
28
  </ul>
29
29
  </div>
30
+
30
31
  <div class="flex items-center text-xs px-3 py-2 bg-zinc-50">
31
32
  <span class="opacity-70 mr-1">Lookbook</span>
32
33
  <span class="mr-6">v<%= @version %></span>
@@ -1,12 +1,23 @@
1
1
  module Lookbook
2
2
  class DebugMenu::Component < Lookbook::BaseComponent
3
- def initialize(version: nil, docs_url: nil, repo_url: nil, **html_attrs)
3
+ attr_reader :features
4
+
5
+ def initialize(version: nil, docs_url: nil, repo_url: nil, features: {}, **html_attrs)
4
6
  @version = version
5
7
  @docs_url = docs_url
6
8
  @repo_url = repo_url
9
+ @features = features
7
10
  super(**html_attrs)
8
11
  end
9
12
 
13
+ def auto_refresh_enabled?
14
+ feature(:auto_refresh, false)
15
+ end
16
+
17
+ def feature(name, fallback = nil)
18
+ features.fetch(name.to_sym, fallback)
19
+ end
20
+
10
21
  def debug_data
11
22
  content
12
23
  end
@@ -1,9 +1,9 @@
1
1
  <%= render_component_tag class: "flex items-center text-xs font-mono space-x-1 transition",
2
2
  ":class":"{'!opacity-100': resizing}",
3
- "@viewport:resize-start.window": "resizing = true",
4
- "@viewport:resize-complete.window": "resizing = false",
5
- "@dom:update-start.window": "tearDown",
6
- "@dom:update-complete.window": "createObserver",
3
+ "x-on:viewport:resize-start.window": "resizing = true",
4
+ "x-on:viewport:resize-complete.window": "resizing = false",
5
+ "x-on:dom:update-start.window": "tearDown",
6
+ "x-on:dom:update-complete.window": "createObserver",
7
7
  "x-show": "target" do %>
8
8
  <span x-text="`${width}px`"></span>
9
9
  <span class="opacity-70">x</span>
@@ -18,13 +18,10 @@ export default function dimensionsDisplayComponent(targetSelector) {
18
18
 
19
19
  createObserver() {
20
20
  if (this.target) {
21
- this.observer = observeSize(
22
- document.querySelector(targetSelector),
23
- ({ width, height }) => {
24
- this.width = width;
25
- this.height = height;
26
- }
27
- );
21
+ this.observer = observeSize(this.target, ({ width, height }) => {
22
+ this.width = width;
23
+ this.height = height;
24
+ });
28
25
  }
29
26
  },
30
27
 
@@ -1,6 +1,6 @@
1
1
  <%= render_component_tag class: "px-2" do %>
2
2
  <% if fields.many? %>
3
- <%= lookbook_render :button, icon: :settings, tooltip: "Display options" do |button| %>
3
+ <%= lookbook_render :button, id: "display-options-dropdown-button", icon: :settings, tooltip: "Display options", data: {update_after_navigate: false} do |button| %>
4
4
  <% button.with_dropdown do %>
5
5
  <div class="p-3 space-y-3">
6
6
  <%= safe_join(fields) %>
@@ -1,33 +1,7 @@
1
1
  @layer components {
2
2
  [data-component="display-options-field"] {
3
- [type="text"],
4
- [type="email"],
5
- [type="url"],
6
- [type="password"],
7
- [type="number"],
8
- [type="date"],
9
- [type="datetime-local"],
10
- [type="month"],
11
- [type="search"],
12
- [type="tel"],
13
- [type="time"],
14
- [type="week"],
15
- textarea,
16
- select {
17
- padding: 0.26rem 0.6rem;
18
- font-size: 0.8rem;
19
- line-height: 1.1rem;
20
- }
21
-
22
3
  label {
23
4
  @apply text-[0.82rem] text-lookbook-input-text cursor-pointer;
24
5
  }
25
-
26
- select {
27
- border-radius: 0.375rem;
28
- padding-right: 1.5rem;
29
- background-size: 1.2em 1.2em;
30
- background-position: right 0.4rem center;
31
- }
32
6
  }
33
7
  }
@@ -3,6 +3,6 @@
3
3
  <label for="<%= name %>">
4
4
  <%= name.to_s.titleize %>:
5
5
  </label>
6
- <%= select_tag(name, options_for_select(choices, value), "x-model": "value") %>
6
+ <%= select_tag(name, options_for_select(choices, value), "x-model": "value", class: "compact") %>
7
7
  </div>
8
8
  <% end %>
@@ -2,7 +2,7 @@ import Cookies from "js-cookie";
2
2
  import {
3
3
  parseSearchParamValue,
4
4
  buildSearchParamValue,
5
- } from "~/app/assets/lookbook/js/helpers/string";
5
+ } from "~/assets/js/helpers/string";
6
6
 
7
7
  export default function displayOptionsFieldComponent({ name, value }) {
8
8
  return {