lookbook 2.0.5 → 2.3.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (424) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +5 -1
  3. data/app/components/lookbook/base_component.rb +1 -1
  4. data/app/components/lookbook/embed/inspector/component.html.erb +19 -4
  5. data/app/components/lookbook/embed/inspector/component.rb +1 -1
  6. data/app/components/lookbook/header/component.html.erb +4 -3
  7. data/app/components/lookbook/tag_component.rb +8 -1
  8. data/app/controllers/lookbook/application_controller.rb +11 -1
  9. data/app/controllers/lookbook/embeds_controller.rb +4 -4
  10. data/app/controllers/lookbook/inspector_controller.rb +1 -1
  11. data/app/controllers/lookbook/page_controller.rb +1 -1
  12. data/app/controllers/lookbook/pages_controller.rb +1 -1
  13. data/app/controllers/lookbook/previews_controller.rb +2 -2
  14. data/app/views/layouts/lookbook/application.html.erb +46 -37
  15. data/app/views/layouts/lookbook/embed.html.erb +6 -0
  16. data/app/views/lookbook/index.html.erb +21 -11
  17. data/app/views/lookbook/inspector/show.html.erb +3 -3
  18. data/app/views/lookbook/previews/group.html.erb +1 -0
  19. data/assets/css/lookbook.css +2 -2
  20. data/assets/icons/activity-square.svg +1 -0
  21. data/assets/icons/ampersand.svg +1 -0
  22. data/assets/icons/ampersands.svg +1 -0
  23. data/assets/icons/antenna.svg +1 -0
  24. data/assets/icons/app-window.svg +1 -0
  25. data/assets/icons/archive-x.svg +1 -0
  26. data/assets/icons/area-chart.svg +1 -0
  27. data/assets/icons/arrow-big-down-dash.svg +1 -0
  28. data/assets/icons/arrow-big-left-dash.svg +1 -0
  29. data/assets/icons/arrow-big-right-dash.svg +1 -0
  30. data/assets/icons/arrow-big-up-dash.svg +1 -0
  31. data/assets/icons/arrow-down-0-1.svg +1 -0
  32. data/assets/icons/arrow-down-1-0.svg +1 -0
  33. data/assets/icons/arrow-down-a-z.svg +1 -0
  34. data/assets/icons/arrow-down-from-line.svg +1 -0
  35. data/assets/icons/arrow-down-left-from-circle.svg +1 -0
  36. data/assets/icons/arrow-down-left-square.svg +1 -0
  37. data/assets/icons/arrow-down-narrow-wide.svg +1 -0
  38. data/assets/icons/arrow-down-right-from-circle.svg +1 -0
  39. data/assets/icons/arrow-down-right-square.svg +1 -0
  40. data/assets/icons/arrow-down-square.svg +1 -0
  41. data/assets/icons/arrow-down-to-dot.svg +1 -0
  42. data/assets/icons/arrow-down-to-line.svg +1 -0
  43. data/assets/icons/arrow-down-up.svg +1 -0
  44. data/assets/icons/arrow-down-wide-narrow.svg +1 -0
  45. data/assets/icons/arrow-down-z-a.svg +1 -0
  46. data/assets/icons/arrow-left-from-line.svg +1 -0
  47. data/assets/icons/arrow-left-square.svg +1 -0
  48. data/assets/icons/arrow-left-to-line.svg +1 -0
  49. data/assets/icons/arrow-right-from-line.svg +1 -0
  50. data/assets/icons/arrow-right-left.svg +1 -0
  51. data/assets/icons/arrow-right-square.svg +1 -0
  52. data/assets/icons/arrow-right-to-line.svg +1 -0
  53. data/assets/icons/arrow-up-0-1.svg +1 -0
  54. data/assets/icons/arrow-up-1-0.svg +1 -0
  55. data/assets/icons/arrow-up-a-z.svg +1 -0
  56. data/assets/icons/arrow-up-from-dot.svg +1 -0
  57. data/assets/icons/arrow-up-from-line.svg +1 -0
  58. data/assets/icons/arrow-up-left-from-circle.svg +1 -0
  59. data/assets/icons/arrow-up-left-square.svg +1 -0
  60. data/assets/icons/arrow-up-narrow-wide.svg +1 -0
  61. data/assets/icons/arrow-up-right-from-circle.svg +1 -0
  62. data/assets/icons/arrow-up-right-square.svg +1 -0
  63. data/assets/icons/arrow-up-square.svg +1 -0
  64. data/assets/icons/arrow-up-to-line.svg +1 -0
  65. data/assets/icons/arrow-up-wide-narrow.svg +1 -0
  66. data/assets/icons/arrow-up-z-a.svg +1 -0
  67. data/assets/icons/arrows-up-from-line.svg +1 -0
  68. data/assets/icons/atom.svg +1 -0
  69. data/assets/icons/badge-alert.svg +1 -0
  70. data/assets/icons/badge-cent.svg +1 -0
  71. data/assets/icons/badge-check.svg +1 -0
  72. data/assets/icons/badge-dollar-sign.svg +1 -0
  73. data/assets/icons/badge-euro.svg +1 -0
  74. data/assets/icons/badge-help.svg +1 -0
  75. data/assets/icons/badge-indian-rupee.svg +1 -0
  76. data/assets/icons/badge-info.svg +1 -0
  77. data/assets/icons/badge-japanese-yen.svg +1 -0
  78. data/assets/icons/badge-minus.svg +1 -0
  79. data/assets/icons/badge-percent.svg +1 -0
  80. data/assets/icons/badge-plus.svg +1 -0
  81. data/assets/icons/badge-pound-sterling.svg +1 -0
  82. data/assets/icons/badge-russian-ruble.svg +1 -0
  83. data/assets/icons/badge-swiss-franc.svg +1 -0
  84. data/assets/icons/badge-x.svg +1 -0
  85. data/assets/icons/badge.svg +1 -0
  86. data/assets/icons/ban.svg +1 -0
  87. data/assets/icons/bar-chart-big.svg +1 -0
  88. data/assets/icons/bar-chart-horizontal-big.svg +1 -0
  89. data/assets/icons/bell-dot.svg +1 -0
  90. data/assets/icons/biohazard.svg +1 -0
  91. data/assets/icons/blocks.svg +1 -0
  92. data/assets/icons/book-copy.svg +1 -0
  93. data/assets/icons/book-down.svg +1 -0
  94. data/assets/icons/book-key.svg +1 -0
  95. data/assets/icons/book-lock.svg +1 -0
  96. data/assets/icons/book-marked.svg +1 -0
  97. data/assets/icons/book-minus.svg +1 -0
  98. data/assets/icons/book-plus.svg +1 -0
  99. data/assets/icons/book-template.svg +1 -0
  100. data/assets/icons/book-up-2.svg +1 -0
  101. data/assets/icons/book-up.svg +1 -0
  102. data/assets/icons/book-x.svg +1 -0
  103. data/assets/icons/bookmark-check.svg +1 -0
  104. data/assets/icons/bookmark-x.svg +1 -0
  105. data/assets/icons/boom-box.svg +1 -0
  106. data/assets/icons/braces.svg +1 -0
  107. data/assets/icons/brackets.svg +1 -0
  108. data/assets/icons/brain-circuit.svg +1 -0
  109. data/assets/icons/brain-cog.svg +1 -0
  110. data/assets/icons/brain.svg +1 -0
  111. data/assets/icons/bring-to-front.svg +1 -0
  112. data/assets/icons/bug-off.svg +1 -0
  113. data/assets/icons/bug-play.svg +1 -0
  114. data/assets/icons/bus-front.svg +1 -0
  115. data/assets/icons/cable-car.svg +1 -0
  116. data/assets/icons/cable.svg +1 -0
  117. data/assets/icons/cake-slice.svg +1 -0
  118. data/assets/icons/candlestick-chart.svg +1 -0
  119. data/assets/icons/candy-cane.svg +1 -0
  120. data/assets/icons/car-front.svg +1 -0
  121. data/assets/icons/car-taxi-front.svg +1 -0
  122. data/assets/icons/case-lower.svg +1 -0
  123. data/assets/icons/case-sensitive.svg +1 -0
  124. data/assets/icons/case-upper.svg +1 -0
  125. data/assets/icons/cassette-tape.svg +1 -0
  126. data/assets/icons/castle.svg +1 -0
  127. data/assets/icons/chevron-down-circle.svg +1 -0
  128. data/assets/icons/chevron-down-square.svg +1 -0
  129. data/assets/icons/chevron-left-circle.svg +1 -0
  130. data/assets/icons/chevron-left-square.svg +1 -0
  131. data/assets/icons/chevron-right-circle.svg +1 -0
  132. data/assets/icons/chevron-right-square.svg +1 -0
  133. data/assets/icons/chevron-up-circle.svg +1 -0
  134. data/assets/icons/chevron-up-square.svg +1 -0
  135. data/assets/icons/church.svg +1 -0
  136. data/assets/icons/circle-dashed.svg +1 -0
  137. data/assets/icons/circle-dollar-sign.svg +1 -0
  138. data/assets/icons/circle-dot-dashed.svg +1 -0
  139. data/assets/icons/circle-equal.svg +1 -0
  140. data/assets/icons/circle-off.svg +1 -0
  141. data/assets/icons/circle-slash-2.svg +1 -0
  142. data/assets/icons/circle-slash.svg +1 -0
  143. data/assets/icons/circuit-board.svg +1 -0
  144. data/assets/icons/clipboard-paste.svg +1 -0
  145. data/assets/icons/club.svg +1 -0
  146. data/assets/icons/combine.svg +1 -0
  147. data/assets/icons/computer.svg +1 -0
  148. data/assets/icons/contact-2.svg +1 -0
  149. data/assets/icons/container.svg +1 -0
  150. data/assets/icons/copy-check.svg +1 -0
  151. data/assets/icons/copy-minus.svg +1 -0
  152. data/assets/icons/copy-plus.svg +1 -0
  153. data/assets/icons/copy-slash.svg +1 -0
  154. data/assets/icons/copy-x.svg +1 -0
  155. data/assets/icons/database-zap.svg +1 -0
  156. data/assets/icons/dessert.svg +1 -0
  157. data/assets/icons/disc-2.svg +1 -0
  158. data/assets/icons/disc-3.svg +1 -0
  159. data/assets/icons/donut.svg +1 -0
  160. data/assets/icons/door-closed.svg +1 -0
  161. data/assets/icons/door-open.svg +1 -0
  162. data/assets/icons/dot.svg +1 -0
  163. data/assets/icons/drama.svg +1 -0
  164. data/assets/icons/ferris-wheel.svg +1 -0
  165. data/assets/icons/file-code-2.svg +1 -0
  166. data/assets/icons/file-stack.svg +1 -0
  167. data/assets/icons/fish-symbol.svg +1 -0
  168. data/assets/icons/fold-horizontal.svg +1 -0
  169. data/assets/icons/fold-vertical.svg +1 -0
  170. data/assets/icons/folder-dot.svg +1 -0
  171. data/assets/icons/folder-git-2.svg +1 -0
  172. data/assets/icons/folder-git.svg +1 -0
  173. data/assets/icons/folder-kanban.svg +1 -0
  174. data/assets/icons/folder-open-dot.svg +1 -0
  175. data/assets/icons/folder-root.svg +1 -0
  176. data/assets/icons/folder-sync.svg +1 -0
  177. data/assets/icons/gallery-horizontal-end.svg +1 -0
  178. data/assets/icons/gallery-horizontal.svg +1 -0
  179. data/assets/icons/gallery-thumbnails.svg +1 -0
  180. data/assets/icons/gallery-vertical-end.svg +1 -0
  181. data/assets/icons/gallery-vertical.svg +1 -0
  182. data/assets/icons/gantt-chart-square.svg +1 -0
  183. data/assets/icons/gantt-chart.svg +1 -0
  184. data/assets/icons/gauge-circle.svg +1 -0
  185. data/assets/icons/goal.svg +1 -0
  186. data/assets/icons/grid-2x2.svg +1 -0
  187. data/assets/icons/grid-3x3.svg +1 -0
  188. data/assets/icons/group.svg +1 -0
  189. data/assets/icons/hard-drive-download.svg +1 -0
  190. data/assets/icons/hard-drive-upload.svg +1 -0
  191. data/assets/icons/hdmi-port.svg +1 -0
  192. data/assets/icons/hotel.svg +1 -0
  193. data/assets/icons/iteration-ccw.svg +1 -0
  194. data/assets/icons/iteration-cw.svg +1 -0
  195. data/assets/icons/kanban-square-dashed.svg +1 -0
  196. data/assets/icons/kanban-square.svg +1 -0
  197. data/assets/icons/kanban.svg +1 -0
  198. data/assets/icons/key-round.svg +1 -0
  199. data/assets/icons/key-square.svg +1 -0
  200. data/assets/icons/layout-panel-left.svg +1 -0
  201. data/assets/icons/layout-panel-top.svg +1 -0
  202. data/assets/icons/leafy-green.svg +1 -0
  203. data/assets/icons/ligature.svg +1 -0
  204. data/assets/icons/list-filter.svg +1 -0
  205. data/assets/icons/list-restart.svg +1 -0
  206. data/assets/icons/list-todo.svg +1 -0
  207. data/assets/icons/list-tree.svg +1 -0
  208. data/assets/icons/lollipop.svg +1 -0
  209. data/assets/icons/m-square.svg +1 -0
  210. data/assets/icons/mailbox.svg +1 -0
  211. data/assets/icons/memory-stick.svg +1 -0
  212. data/assets/icons/menu-square.svg +1 -0
  213. data/assets/icons/merge.svg +1 -0
  214. data/assets/icons/message-square-dashed.svg +1 -0
  215. data/assets/icons/message-square-plus.svg +1 -0
  216. data/assets/icons/messages-square.svg +1 -0
  217. data/assets/icons/monitor-check.svg +1 -0
  218. data/assets/icons/monitor-dot.svg +1 -0
  219. data/assets/icons/monitor-down.svg +1 -0
  220. data/assets/icons/monitor-pause.svg +1 -0
  221. data/assets/icons/monitor-play.svg +1 -0
  222. data/assets/icons/monitor-stop.svg +1 -0
  223. data/assets/icons/monitor-up.svg +1 -0
  224. data/assets/icons/monitor-x.svg +1 -0
  225. data/assets/icons/moon-star.svg +1 -0
  226. data/assets/icons/mouse-pointer-square-dashed.svg +1 -0
  227. data/assets/icons/mouse-pointer-square.svg +1 -0
  228. data/assets/icons/move-down-left.svg +1 -0
  229. data/assets/icons/move-down-right.svg +1 -0
  230. data/assets/icons/move-down.svg +1 -0
  231. data/assets/icons/move-left.svg +1 -0
  232. data/assets/icons/move-right.svg +1 -0
  233. data/assets/icons/move-up-left.svg +1 -0
  234. data/assets/icons/move-up-right.svg +1 -0
  235. data/assets/icons/move-up.svg +1 -0
  236. data/assets/icons/orbit.svg +1 -0
  237. data/assets/icons/panel-bottom-close.svg +1 -0
  238. data/assets/icons/panel-bottom-inactive.svg +1 -0
  239. data/assets/icons/panel-bottom-open.svg +1 -0
  240. data/assets/icons/panel-bottom.svg +1 -0
  241. data/assets/icons/panel-left-close.svg +1 -0
  242. data/assets/icons/panel-left-inactive.svg +1 -0
  243. data/assets/icons/panel-left-open.svg +1 -0
  244. data/assets/icons/panel-left.svg +1 -0
  245. data/assets/icons/panel-right-close.svg +1 -0
  246. data/assets/icons/panel-right-inactive.svg +1 -0
  247. data/assets/icons/panel-right-open.svg +1 -0
  248. data/assets/icons/panel-right.svg +1 -0
  249. data/assets/icons/panel-top-close.svg +1 -0
  250. data/assets/icons/panel-top-inactive.svg +1 -0
  251. data/assets/icons/panel-top-open.svg +1 -0
  252. data/assets/icons/panel-top.svg +1 -0
  253. data/assets/icons/parentheses.svg +1 -0
  254. data/assets/icons/parking-circle-off.svg +1 -0
  255. data/assets/icons/parking-circle.svg +1 -0
  256. data/assets/icons/parking-meter.svg +1 -0
  257. data/assets/icons/parking-square-off.svg +1 -0
  258. data/assets/icons/parking-square.svg +1 -0
  259. data/assets/icons/paw-print.svg +1 -0
  260. data/assets/icons/pc-case.svg +1 -0
  261. data/assets/icons/pen-line.svg +1 -0
  262. data/assets/icons/pen-square.svg +1 -0
  263. data/assets/icons/pen.svg +1 -0
  264. data/assets/icons/pencil-line.svg +1 -0
  265. data/assets/icons/pencil-ruler.svg +1 -0
  266. data/assets/icons/percent-circle.svg +1 -0
  267. data/assets/icons/percent-diamond.svg +1 -0
  268. data/assets/icons/percent-square.svg +1 -0
  269. data/assets/icons/pi-square.svg +1 -0
  270. data/assets/icons/pi.svg +1 -0
  271. data/assets/icons/pilcrow-square.svg +1 -0
  272. data/assets/icons/plane-landing.svg +1 -0
  273. data/assets/icons/plane-takeoff.svg +1 -0
  274. data/assets/icons/play-square.svg +1 -0
  275. data/assets/icons/plug-zap-2.svg +1 -0
  276. data/assets/icons/pocket-knife.svg +1 -0
  277. data/assets/icons/popcorn.svg +1 -0
  278. data/assets/icons/popsicle.svg +1 -0
  279. data/assets/icons/presentation.svg +1 -0
  280. data/assets/icons/projector.svg +1 -0
  281. data/assets/icons/rabbit.svg +1 -0
  282. data/assets/icons/radar.svg +1 -0
  283. data/assets/icons/radiation.svg +1 -0
  284. data/assets/icons/radio-tower.svg +1 -0
  285. data/assets/icons/rail-symbol.svg +1 -0
  286. data/assets/icons/rainbow.svg +1 -0
  287. data/assets/icons/rat.svg +1 -0
  288. data/assets/icons/ratio.svg +1 -0
  289. data/assets/icons/receipt.svg +1 -0
  290. data/assets/icons/redo-dot.svg +1 -0
  291. data/assets/icons/refresh-ccw-dot.svg +1 -0
  292. data/assets/icons/refresh-cw-off.svg +1 -0
  293. data/assets/icons/repeat-2.svg +1 -0
  294. data/assets/icons/replace-all.svg +1 -0
  295. data/assets/icons/replace.svg +1 -0
  296. data/assets/icons/roller-coaster.svg +1 -0
  297. data/assets/icons/rows.svg +1 -0
  298. data/assets/icons/satellite-dish.svg +1 -0
  299. data/assets/icons/satellite.svg +1 -0
  300. data/assets/icons/save-all.svg +1 -0
  301. data/assets/icons/scatter-chart.svg +1 -0
  302. data/assets/icons/school-2.svg +1 -0
  303. data/assets/icons/school.svg +1 -0
  304. data/assets/icons/scissors-line-dashed.svg +1 -0
  305. data/assets/icons/scissors-square-dashed-bottom.svg +1 -0
  306. data/assets/icons/scissors-square.svg +1 -0
  307. data/assets/icons/scroll-text.svg +1 -0
  308. data/assets/icons/search-check.svg +1 -0
  309. data/assets/icons/search-code.svg +1 -0
  310. data/assets/icons/search-slash.svg +1 -0
  311. data/assets/icons/search-x.svg +1 -0
  312. data/assets/icons/send-horizontal.svg +1 -0
  313. data/assets/icons/send-to-back.svg +1 -0
  314. data/assets/icons/shapes.svg +1 -0
  315. data/assets/icons/shell.svg +1 -0
  316. data/assets/icons/shield-ban.svg +1 -0
  317. data/assets/icons/shield-ellipsis.svg +1 -0
  318. data/assets/icons/shield-half.svg +1 -0
  319. data/assets/icons/shield-minus.svg +1 -0
  320. data/assets/icons/shield-plus.svg +1 -0
  321. data/assets/icons/shield-question.svg +1 -0
  322. data/assets/icons/shield-x.svg +1 -0
  323. data/assets/icons/ship-wheel.svg +1 -0
  324. data/assets/icons/shopping-basket.svg +1 -0
  325. data/assets/icons/sigma-square.svg +1 -0
  326. data/assets/icons/snail.svg +1 -0
  327. data/assets/icons/space.svg +1 -0
  328. data/assets/icons/spade.svg +1 -0
  329. data/assets/icons/sparkle.svg +1 -0
  330. data/assets/icons/sparkles.svg +1 -0
  331. data/assets/icons/speech.svg +1 -0
  332. data/assets/icons/spell-check-2.svg +1 -0
  333. data/assets/icons/spell-check.svg +1 -0
  334. data/assets/icons/split.svg +1 -0
  335. data/assets/icons/spray-can.svg +1 -0
  336. data/assets/icons/square-asterisk.svg +1 -0
  337. data/assets/icons/square-code.svg +1 -0
  338. data/assets/icons/square-dashed-bottom-code.svg +1 -0
  339. data/assets/icons/square-dashed-bottom.svg +1 -0
  340. data/assets/icons/square-dot.svg +1 -0
  341. data/assets/icons/square-equal.svg +1 -0
  342. data/assets/icons/square-slash.svg +1 -0
  343. data/assets/icons/square-stack.svg +1 -0
  344. data/assets/icons/squirrel.svg +1 -0
  345. data/assets/icons/step-back.svg +1 -0
  346. data/assets/icons/step-forward.svg +1 -0
  347. data/assets/icons/store.svg +1 -0
  348. data/assets/icons/table-properties.svg +1 -0
  349. data/assets/icons/tablet-smartphone.svg +1 -0
  350. data/assets/icons/tally-1.svg +1 -0
  351. data/assets/icons/tally-2.svg +1 -0
  352. data/assets/icons/tally-3.svg +1 -0
  353. data/assets/icons/tally-4.svg +1 -0
  354. data/assets/icons/tally-5.svg +1 -0
  355. data/assets/icons/test-tube-2.svg +1 -0
  356. data/assets/icons/test-tube.svg +1 -0
  357. data/assets/icons/test-tubes.svg +1 -0
  358. data/assets/icons/text-quote.svg +1 -0
  359. data/assets/icons/text-select.svg +1 -0
  360. data/assets/icons/text.svg +1 -0
  361. data/assets/icons/theater.svg +1 -0
  362. data/assets/icons/touchpad-off.svg +1 -0
  363. data/assets/icons/touchpad.svg +1 -0
  364. data/assets/icons/tractor.svg +1 -0
  365. data/assets/icons/traffic-cone.svg +1 -0
  366. data/assets/icons/train-front-tunnel.svg +1 -0
  367. data/assets/icons/train-front.svg +1 -0
  368. data/assets/icons/train-track.svg +1 -0
  369. data/assets/icons/tram-front.svg +1 -0
  370. data/assets/icons/triangle-right.svg +1 -0
  371. data/assets/icons/turtle.svg +1 -0
  372. data/assets/icons/undo-dot.svg +1 -0
  373. data/assets/icons/unfold-horizontal.svg +1 -0
  374. data/assets/icons/unfold-vertical.svg +1 -0
  375. data/assets/icons/ungroup.svg +1 -0
  376. data/assets/icons/unplug.svg +1 -0
  377. data/assets/icons/user-2.svg +1 -0
  378. data/assets/icons/user-check-2.svg +1 -0
  379. data/assets/icons/user-circle-2.svg +1 -0
  380. data/assets/icons/user-circle.svg +1 -0
  381. data/assets/icons/user-cog-2.svg +1 -0
  382. data/assets/icons/user-minus-2.svg +1 -0
  383. data/assets/icons/user-plus-2.svg +1 -0
  384. data/assets/icons/user-square-2.svg +1 -0
  385. data/assets/icons/user-square.svg +1 -0
  386. data/assets/icons/user-x-2.svg +1 -0
  387. data/assets/icons/users-2.svg +1 -0
  388. data/assets/icons/variable.svg +1 -0
  389. data/assets/icons/videotape.svg +1 -0
  390. data/assets/icons/wallet-2.svg +1 -0
  391. data/assets/icons/wallet-cards.svg +1 -0
  392. data/assets/icons/wallpaper.svg +1 -0
  393. data/assets/icons/warehouse.svg +1 -0
  394. data/assets/icons/whole-word.svg +1 -0
  395. data/assets/icons/workflow.svg +1 -0
  396. data/assets/js/app.js +6 -0
  397. data/config/app.yml +5 -0
  398. data/lib/lookbook/cable/cable.rb +2 -2
  399. data/lib/lookbook/engine.rb +3 -1
  400. data/lib/lookbook/entities/collections/preview_collection.rb +1 -4
  401. data/lib/lookbook/entities/entity.rb +4 -0
  402. data/lib/lookbook/entities/page_entity.rb +1 -1
  403. data/lib/lookbook/entities/scenario_entity.rb +1 -1
  404. data/lib/lookbook/entities/scenario_group_entity.rb +1 -1
  405. data/lib/lookbook/file_watcher.rb +1 -1
  406. data/lib/lookbook/helpers/ui_elements_helper.rb +3 -3
  407. data/lib/lookbook/param.rb +1 -1
  408. data/lib/lookbook/preview.rb +1 -0
  409. data/lib/lookbook/preview_controller_actions.rb +19 -16
  410. data/lib/lookbook/services/data/resolvers/data_resolver.rb +1 -1
  411. data/lib/lookbook/services/templates/action_view_config_handler.rb +50 -0
  412. data/lib/lookbook/stores/config_store.rb +4 -0
  413. data/lib/lookbook/theme.rb +2 -6
  414. data/lib/lookbook/version.rb +1 -1
  415. data/lib/lookbook/websocket.rb +1 -1
  416. data/public/lookbook-assets/css/lookbook.css +542 -389
  417. data/public/lookbook-assets/css/lookbook.css.map +1 -1
  418. data/public/lookbook-assets/js/iframe.js.map +1 -1
  419. data/public/lookbook-assets/js/index.js +902 -751
  420. data/public/lookbook-assets/js/index.js.map +1 -1
  421. data/public/lookbook-assets/js/lookbook-core.js +38 -1
  422. data/public/lookbook-assets/js/lookbook.js +121 -84
  423. metadata +382 -6
  424. data/lib/lookbook/services/templates/action_view_annotations_handler.rb +0 -21
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 304dad1bd141e24633de2a2ac09887d4ccc64b354adfe99c064364b1243871ec
4
- data.tar.gz: 89854b30eb17b5923ae5b44f5b7efd3c6a71b58d755196c3710d2274ca73e691
3
+ metadata.gz: '0277029efee9bfc07832f5bc2ea7d1a57063a81e2e2986978c93abca8750fbe2'
4
+ data.tar.gz: c03b8c178645b7dba6572d37711cb4664ea4175fa56430acd595a369069d54c9
5
5
  SHA512:
6
- metadata.gz: 6dae592f9af122d60314e043632b784110b5625e33340aff2b04833b343be4b48c04533c78ed557a7f8a09fad219fbf5cd9087e678cfb64d434bf6a9f6f23c1b
7
- data.tar.gz: 7451044704c8f68d8b2dc17bed7729b43424c08fed2ff4895a22d78fd64de1ec21831db1d6d7f2a9b8c220a7d51d7b22a513fe4baf9997288a4bb92cb90bb73f
6
+ metadata.gz: c34fbd701d1f7818dea444b9ad899b7dce012968a0cc0038dd197bf0e70ea2af105c2d299e3ac21302f9276d0dde162b56cfebb8f45ba4e7eb9c1ab1455c4555
7
+ data.tar.gz: 50613e6f04c758f5c93fa4ff659a0a0a4c1a903e80d167a3c1aead2f6e5af7278549b260255405c077fe1f35ba920fc050fdfdb0dab4d37ce7df18658f6ace47
data/README.md CHANGED
@@ -14,10 +14,14 @@
14
14
  ---
15
15
 
16
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. <a href="https://lookbook.build"><strong>Learn more &rarr;</strong></a>
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
22
  </div>
20
23
 
24
+
21
25
  ---
22
26
 
23
27
  [![Lookbook UI](.github/assets/lookbook_ui.png)](http://lookbook.build/)
@@ -1,6 +1,6 @@
1
1
  module Lookbook
2
2
  class BaseComponent < ViewComponent::Base
3
- include Lookbook::Engine.routes.url_helpers
3
+ send(:include, Lookbook::Engine.routes.url_helpers) # YARD parsing workaround: https://github.com/lsegal/yard/issues/546
4
4
  include Lookbook::UiElementsHelper
5
5
  include Lookbook::ClassNamesHelper if Engine.runtime_context.rails_older_than?("6.1.0")
6
6
 
@@ -9,7 +9,7 @@
9
9
  <h3 class="flex items-center space-x-1">
10
10
  <strong class="text-lookbook-embed-title"><%= target.preview.label %></strong>
11
11
  <% if scenarios.many? %>
12
- <%= select_tag("target", options_for_select(scenario_select_options, helpers.lookbook_embed_path(target.path)), "x-model": "targetPath", class: "!ml-2 compact") %>
12
+ <%= select_tag("target", options_for_select(scenario_select_options, helpers.lookbook_embed_path(target.lookup_path)), "x-model": "targetPath", class: "!ml-2 compact") %>
13
13
  <% else %>
14
14
  <span>(<%= target.label %>) </span>
15
15
  <% end %>
@@ -31,13 +31,13 @@
31
31
  <%= lookbook_render :button_group do |group| %>
32
32
  <% if display_action?(:inspect) %>
33
33
  <% group.with_button icon: :eye,
34
- href: helpers.lookbook_inspect_url(target.path, params),
34
+ href: helpers.lookbook_inspect_url(target.lookup_path, params),
35
35
  tooltip: "View in Inspector",
36
36
  target: "_top" %>
37
37
  <% end %>
38
38
  <% if display_action?(:open) %>
39
39
  <% group.with_button icon: :external_link,
40
- href: helpers.lookbook_preview_url(target.path, params),
40
+ href: helpers.lookbook_preview_url(target.lookup_path, params),
41
41
  tooltip: "Open in new window",
42
42
  target: "_blank" %>
43
43
  <% end %>
@@ -57,7 +57,7 @@
57
57
  x-ref="viewportWrapper">
58
58
  <%= lookbook_render :viewport,
59
59
  iframe_id: "#{id}-viewport",
60
- src: helpers.lookbook_preview_path(target.path, request.query_parameters.merge(lookbook_timestamp: Time.now, lookbook_embed: true)),
60
+ src: helpers.lookbook_preview_path(target.lookup_path, request.query_parameters.merge(lookbook_timestamp: Time.now, lookbook_embed: true)),
61
61
  alpine_data: "store",
62
62
  resize_height: false,
63
63
  class: "mb-[-2px] transition-[height] duration-150",
@@ -82,6 +82,21 @@
82
82
  <% end %>
83
83
  <% end %>
84
84
  <% end %>
85
+
86
+ <% toolbar.with_section align: :right, class: "flex-none relative z-10" do %>
87
+ <%= lookbook_render :button_group do |group| %>
88
+ <%= panels.select { |p| !p.disabled && p.copy }.each do |panel| %>
89
+ <% group.with_button id: "copy-panel-contents-button-#{panel.name}",
90
+ icon: :copy,
91
+ tooltip: "Copy panel contents",
92
+ copy: !!panel.copy,
93
+ "x-show": "store.activeTab === '#{panel.name}'",
94
+ cloak: true do %>
95
+ <%= panel.copy ? panel.copy : "" %>
96
+ <% end %>
97
+ <% end %>
98
+ <% end %>
99
+ <% end %>
85
100
  <% end %>
86
101
 
87
102
  <div class="bg-lookbook-drawer-bg">
@@ -40,7 +40,7 @@ module Lookbook
40
40
  end
41
41
 
42
42
  def scenario_select_options
43
- scenarios.map { |scenario| [scenario.label, helpers.lookbook_embed_path(scenario.path)] }
43
+ scenarios.map { |scenario| [scenario.label, helpers.lookbook_embed_path(scenario.lookup_path)] }
44
44
  end
45
45
 
46
46
  def display_option_controls?
@@ -29,6 +29,7 @@
29
29
  <% if @debug_menu %>
30
30
  <% group.with_button id: "debug-menu-button",
31
31
  icon: :help_circle,
32
+ tooltip: "Debug info",
32
33
  class: "!text-lookbook-header-text", "x-show": "!loading" do |button| %>
33
34
  <% menu = lookbook_render :debug_menu,
34
35
  version: Lookbook::VERSION,
@@ -50,8 +51,8 @@
50
51
  "x-show": "$store.layout.mobile && !sidebarHidden",
51
52
  "x-on:keydown.esc.window": "closeMobileSidebar",
52
53
  class: "!text-lookbook-header-text" %>
53
- <% end %>
54
+ <% end %>
54
55
  <% end %>
55
56
  <% end %>
56
-
57
- <% end %>
57
+
58
+ <% end %>
@@ -20,7 +20,14 @@ module Lookbook
20
20
  end
21
21
 
22
22
  def self.escape_attribute_key
23
- @escape_attribute_key ||= (Gem::Version.new(Rails.version) < Gem::Version.new("6.1.5.1")) ? :escape_attributes : :escape
23
+ @escape_attribute_key ||= (
24
+ (
25
+ Gem::Version.new(Rails.version) < Gem::Version.new("5.2.7.1")
26
+ ) || (
27
+ Gem::Version.new(Rails.version) >= Gem::Version.new("6") &&
28
+ Gem::Version.new(Rails.version) < Gem::Version.new("6.1.5.1")
29
+ )
30
+ ) ? :escape_attributes : :escape
24
31
  end
25
32
  end
26
33
  end
@@ -48,7 +48,8 @@ module Lookbook
48
48
  @config = Lookbook.config
49
49
  @engine = Lookbook.engine
50
50
  @embed = !!params[:lookbook_embed]
51
- @blank_slate = Engine.pages.none? && Engine.previews.none?
51
+ @sidebar_panels = sidebar_panels
52
+ @blank_slate = @sidebar_panels.none?
52
53
  end
53
54
 
54
55
  def raise_not_found(message = "Page not found")
@@ -56,6 +57,8 @@ module Lookbook
56
57
  end
57
58
 
58
59
  def handle_error(err)
60
+ raise err if Lookbook.config.preview_disable_error_handling
61
+
59
62
  @error = err.is_a?(Lookbook::Error) ? err : Lookbook::Error.new(original: err)
60
63
  @status_code = get_status_code(err)
61
64
 
@@ -71,6 +74,13 @@ module Lookbook
71
74
 
72
75
  private
73
76
 
77
+ def sidebar_panels
78
+ panels_config = Lookbook.config.preview_inspector.sidebar_panels.map(&:to_sym)
79
+ panels_config.select do |panel|
80
+ (panel == :pages && Engine.pages.any?) || (panel == :previews && Engine.previews.any?)
81
+ end
82
+ end
83
+
74
84
  def get_status_code(err)
75
85
  if err.respond_to?(:status)
76
86
  err.status
@@ -1,5 +1,5 @@
1
1
  module Lookbook
2
- class EmbedsController < ApplicationController
2
+ class EmbedsController < Lookbook::ApplicationController
3
3
  include ActionView::Helpers::SanitizeHelper
4
4
  include TargetableConcern
5
5
  include WithPreviewControllerConcern
@@ -21,7 +21,7 @@ module Lookbook
21
21
  if props.preview.present?
22
22
  preview = Engine.previews.find_by_preview_class(props.preview)
23
23
  if preview.present?
24
- props.scenarios ||= (props.scenario || "")
24
+ props.scenarios ||= props.scenario || ""
25
25
  scenario = preview.scenario(Array(props.scenarios).first)
26
26
 
27
27
  boolean_options = ["display_option_controls"]
@@ -53,7 +53,7 @@ module Lookbook
53
53
  embed_params[:_options] = SearchParamEncoder.call(options)
54
54
  embed_params.symbolize_keys!
55
55
 
56
- return redirect_to lookbook_embed_url(scenario ? scenario.path : preview.path, embed_params)
56
+ return redirect_to lookbook_embed_url(scenario ? scenario.lookup_path : preview.lookup_path, embed_params)
57
57
  end
58
58
  end
59
59
 
@@ -65,7 +65,7 @@ module Lookbook
65
65
  unless @target
66
66
  @target = @scenario_choices.first || @preview&.default_scenario
67
67
  if @target
68
- redirect_to lookbook_embed_path(@target.path, req_params)
68
+ redirect_to lookbook_embed_path(@target.lookup_path, req_params)
69
69
  else
70
70
  raise_not_found("Preview not found")
71
71
  end
@@ -1,5 +1,5 @@
1
1
  module Lookbook
2
- class InspectorController < ApplicationController
2
+ class InspectorController < Lookbook::ApplicationController
3
3
  include TargetableConcern
4
4
  include WithPanelsConcern
5
5
  include WithPreviewControllerConcern
@@ -15,7 +15,7 @@ module Lookbook
15
15
  @next_page = @pages.next(@page)
16
16
  @previous_page = @pages.previous(@page)
17
17
 
18
- content = ActionViewAnnotationsHandler.call(disable_annotations: true) do
18
+ content = ActionViewConfigHandler.call do
19
19
  render_to_string inline: @page.content, locals: {
20
20
  page: @page,
21
21
  next_page: @next_page,
@@ -1,5 +1,5 @@
1
1
  module Lookbook
2
- class PagesController < ApplicationController
2
+ class PagesController < Lookbook::ApplicationController
3
3
  helper_method :page_controller
4
4
 
5
5
  def self.controller_path
@@ -1,5 +1,5 @@
1
1
  module Lookbook
2
- class PreviewsController < ApplicationController
2
+ class PreviewsController < Lookbook::ApplicationController
3
3
  include TargetableConcern
4
4
  include WithPreviewControllerConcern
5
5
 
@@ -68,7 +68,7 @@ module Lookbook
68
68
 
69
69
  def permit_framing
70
70
  headers["X-Frame-Options"] = Lookbook.config.preview_embeds.policy if embedded?
71
- headers["X-Frame-Options"] = "SAMEORIGIN" if headers["X-Frame-Options"] == "DENY"
71
+ headers["X-Frame-Options"] = "SAMEORIGIN" if headers["X-Frame-Options"]&.upcase == "DENY"
72
72
  end
73
73
  end
74
74
  end
@@ -17,7 +17,7 @@
17
17
  project_name: @config.project_name,
18
18
  project_logo: @config.project_logo %>
19
19
 
20
- <% if @previews.any? || @pages.any? %>
20
+ <% unless @blank_slate %>
21
21
 
22
22
  <%= lookbook_render :split_layout,
23
23
  alpine_data: "$store.layout.main",
@@ -32,48 +32,57 @@
32
32
  "x-on:click.outside": "closeMobileSidebar",
33
33
  cloak: true do %>
34
34
 
35
- <%= lookbook_render :split_layout,
36
- alpine_data: "$store.layout.#{@pages.any? && @previews.any? ? "sidebar" : "singleSectionSidebar"}",
37
- style: "height: calc(100vh - 2.5rem);" do |layout| %>
35
+ <% if @sidebar_panels.any? %>
36
+ <%= lookbook_render :split_layout,
37
+ alpine_data: "$store.layout.#{@sidebar_panels.many? ? "sidebar" : "singleSectionSidebar"}",
38
+ style: "height: calc(100vh - 2.5rem);" do |layout| %>
38
39
 
39
- <% if @previews.any? %>
40
- <% layout.with_pane class: "overflow-hidden" do %>
41
- <%= lookbook_render :nav,
42
- id: "previews-nav",
43
- tree: @previews.to_tree,
44
- alpine_data: "$store.nav.previews" do |nav| %>
45
- <%= nav.with_toolbar do |toolbar| %>
46
- <% toolbar.with_section padded: true do %>
47
- <h4 class="pt-1"><%= @config.preview_collection_label %></h4>
48
- <% end %>
49
- <% toolbar.with_section align: :right, padded: false do %>
50
- <%= lookbook_render :button_group, size: :xs do |group| %>
51
- <% group.with_button icon: :minus_square,
52
- tooltip: "Collapse all",
53
- "x-on:click": "closeAll" %>
40
+ <% @sidebar_panels.each do |panel| %>
41
+ <% if panel == :previews && @previews.any? %>
42
+ <% layout.with_pane class: "overflow-hidden" do %>
43
+ <%= lookbook_render :nav,
44
+ id: "previews-nav",
45
+ tree: @previews.to_tree,
46
+ alpine_data: "$store.nav.previews" do |nav| %>
47
+ <%= nav.with_toolbar do |toolbar| %>
48
+ <% toolbar.with_section padded: true do %>
49
+ <h4 class="pt-1"><%= @config.preview_collection_label %></h4>
50
+ <% end %>
51
+ <% toolbar.with_section align: :right, padded: false do %>
52
+ <%= lookbook_render :button_group, size: :xs do |group| %>
53
+ <% group.with_button icon: :minus_square,
54
+ tooltip: "Collapse all",
55
+ "x-on:click": "closeAll" %>
56
+ <% end %>
57
+ <% end %>
58
+ <% end %>
59
+ <% if @config.preview_nav_filter %>
60
+ <% nav.with_filter store: "$store.nav.previews.filter", placeholder: "Filter previews by name&hellip;" %>
54
61
  <% end %>
55
62
  <% end %>
56
63
  <% end %>
57
- <% nav.with_filter store: "$store.nav.previews.filter", placeholder: "Filter previews by name&hellip;" %>
58
64
  <% end %>
59
- <% end %>
60
- <% end %>
61
65
 
62
- <% if @pages.any? %>
63
- <% layout.with_pane class: "overflow-hidden" do %>
64
- <%= lookbook_render :nav,
65
- id: "pages-nav",
66
- tree: @pages.to_tree,
67
- alpine_data: "$store.nav.pages" do |nav| %>
68
- <%= nav.with_toolbar do |toolbar| %>
69
- <% toolbar.with_section padded: true do %>
70
- <h4 class="pt-1"><%= @config.page_collection_label %></h4>
71
- <% end %>
72
- <% toolbar.with_section align: :right, padded: false do %>
73
- <%= lookbook_render :button_group, size: :xs do |group| %>
74
- <% group.with_button icon: :minus_square,
75
- tooltip: "Collapse all",
76
- "x-on:click": "closeAll" %>
66
+ <% if panel == :pages && @pages.any? %>
67
+ <% layout.with_pane class: "overflow-hidden" do %>
68
+ <%= lookbook_render :nav,
69
+ id: "pages-nav",
70
+ tree: @pages.to_tree,
71
+ alpine_data: "$store.nav.pages" do |nav| %>
72
+ <%= nav.with_toolbar do |toolbar| %>
73
+ <% toolbar.with_section padded: true do %>
74
+ <h4 class="pt-1"><%= @config.page_collection_label %></h4>
75
+ <% end %>
76
+ <% toolbar.with_section align: :right, padded: false do %>
77
+ <%= lookbook_render :button_group, size: :xs do |group| %>
78
+ <% group.with_button icon: :minus_square,
79
+ tooltip: "Collapse all",
80
+ "x-on:click": "closeAll" %>
81
+ <% end %>
82
+ <% end %>
83
+ <% end %>
84
+ <% if @config.page_nav_filter %>
85
+ <% nav.with_filter store: "$store.nav.pages.filter", placeholder: "Filter pages by name&hellip;" %>
77
86
  <% end %>
78
87
  <% end %>
79
88
  <% end %>
@@ -11,6 +11,12 @@
11
11
 
12
12
  <%= content_for?(:main) ? yield(:main) : yield %>
13
13
  </div>
14
+
15
+ <% if content_for? :dropdowns %>
16
+ <div class="hidden">
17
+ <%= content_for :dropdowns -%>
18
+ </div>
19
+ <% end %>
14
20
  <% end %>
15
21
 
16
22
  <%= render template: "layouts/lookbook/skeleton" %>
@@ -1,3 +1,7 @@
1
+ <%
2
+ sidebar_panels_config = @config.preview_inspector.sidebar_panels.map(&:to_sym)
3
+ %>
4
+
1
5
  <%= render "lookbook/partials/blank_slate" do %>
2
6
  <% if @blank_slate %>
3
7
  <%= lookbook_render :message,
@@ -5,17 +9,23 @@
5
9
  title: "Welcome to your Lookbook!",
6
10
  icon: :logo do %>
7
11
  <p>
8
- There isn't much to see yet, but
9
- <%= link_to "component previews",
10
- "#{@config.links.docs}/guide/previews",
11
- target: "_blank"
12
- %>
13
- and
14
- <%= link_to "content pages",
15
- "#{@config.links.docs}/guide/pages",
16
- target: "_blank"
17
- %>
18
- will show up here as soon as they are added.
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 %>
19
29
  </p>
20
30
  <% end %>
21
31
  <% else %>
@@ -63,7 +63,7 @@
63
63
  tooltip: "Open preview in new window",
64
64
  target: "_blank" %>
65
65
 
66
- <% group.with_button id: "show-drawer-button",
66
+ <% group.with_button id: "show-vertical-drawer-button",
67
67
  icon: "sidebar",
68
68
  tooltip: "Show drawer",
69
69
  "x-on:click": "$store.inspector.drawer.hidden = false",
@@ -71,7 +71,7 @@
71
71
  "x-show": "$store.inspector.drawer.hidden && vertical",
72
72
  cloak: true %>
73
73
 
74
- <% group.with_button id: "show-drawer-button",
74
+ <% group.with_button id: "show-bottom-drawer-button",
75
75
  icon: "credit-card",
76
76
  tooltip: "Show drawer",
77
77
  "x-on:click": "$store.inspector.drawer.hidden = false",
@@ -166,4 +166,4 @@
166
166
  </div>
167
167
  <% end %>
168
168
  <% end %>
169
- </main>
169
+ </main>
@@ -1,4 +1,5 @@
1
1
  <% if scenarios.many? %>
2
+ <% scenarios = scenarios.filter(&:visible?) %>
2
3
  <%# Render a group of scenarios %>
3
4
  <% scenarios.each do |scenario| %>
4
5
  <div style="margin-bottom: 30px !important; display: block !important;">
@@ -9,7 +9,7 @@
9
9
 
10
10
  @layer base {
11
11
  html {
12
- @apply scroll-smooth h-screen;
12
+ @apply scroll-smooth h-screen w-screen;
13
13
  }
14
14
 
15
15
  @media screen and (prefers-reduced-motion: reduce) {
@@ -19,7 +19,7 @@
19
19
  }
20
20
 
21
21
  body {
22
- @apply text-lookbook-text font-ui text-sm overflow-hidden;
22
+ @apply text-lookbook-text font-ui text-sm overflow-hidden w-screen;
23
23
  }
24
24
 
25
25
  [x-cloak] {
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><rect width="18" height="18" x="3" y="3" rx="2"/><path d="M17 12h-2l-2 5-2-10-2 5H7"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M17.5 12c0 4.4-3.6 8-8 8A4.5 4.5 0 0 1 5 15.5c0-6 8-4 8-8.5a3 3 0 1 0-6 0c0 3 2.5 8.5 12 13"/><path d="M16 12h3"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M10 17c-5-3-7-7-7-9a2 2 0 0 1 4 0c0 2.5-5 2.5-5 6 0 1.7 1.3 3 3 3 2.8 0 5-2.2 5-5"/><path d="M22 17c-5-3-7-7-7-9a2 2 0 0 1 4 0c0 2.5-5 2.5-5 6 0 1.7 1.3 3 3 3 2.8 0 5-2.2 5-5"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M2 12 7 2"/><path d="m7 12 5-10"/><path d="m12 12 5-10"/><path d="m17 12 5-10"/><path d="M4.5 7h15"/><path d="M12 16v6"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><rect x="2" y="4" width="20" height="16" rx="2"/><path d="M10 4v4"/><path d="M2 8h20"/><path d="M6 4v4"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><rect width="20" height="5" x="2" y="3" rx="1"/><path d="M4 8v11a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8"/><path d="m9.5 17 5-5"/><path d="m9.5 12 5 5"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M3 3v18h18"/><path d="M7 12v5h12V8l-5 5-4-4Z"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M15 5H9"/><path d="M15 9v3h4l-7 7-7-7h4V9h6z"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M19 15V9"/><path d="M15 15h-3v4l-7-7 7-7v4h3v6z"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M5 9v6"/><path d="M9 9h3V5l7 7-7 7v-4H9V9z"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M9 19h6"/><path d="M9 15v-3H5l7-7 7 7h-4v3H9z"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="m3 16 4 4 4-4"/><path d="M7 20V4"/><rect x="15" y="4" width="4" height="6" ry="2"/><path d="M17 20v-6h-2"/><path d="M15 20h4"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="m3 16 4 4 4-4"/><path d="M7 20V4"/><path d="M17 10V4h-2"/><path d="M15 10h4"/><rect x="15" y="14" width="4" height="6" ry="2"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="m3 16 4 4 4-4"/><path d="M7 20V4"/><path d="M20 8h-5"/><path d="M15 10V6.5a2.5 2.5 0 0 1 5 0V10"/><path d="M15 14h5l-5 6h5"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M19 3H5"/><path d="M12 21V7"/><path d="m6 15 6 6 6-6"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M2 12a10 10 0 1 1 10 10"/><path d="m2 22 10-10"/><path d="M8 22H2v-6"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><rect width="18" height="18" x="3" y="3" rx="2"/><path d="m16 8-8 8"/><path d="M16 16H8V8"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="m3 16 4 4 4-4"/><path d="M7 20V4"/><path d="M11 4h4"/><path d="M11 8h7"/><path d="M11 12h10"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M12 22a10 10 0 1 1 10-10"/><path d="M22 22 12 12"/><path d="M22 16v6h-6"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><rect width="18" height="18" x="3" y="3" rx="2"/><path d="m8 8 8 8"/><path d="M16 8v8H8"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><rect width="18" height="18" x="3" y="3" rx="2"/><path d="M12 8v8"/><path d="m8 12 4 4 4-4"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M12 2v14"/><path d="m19 9-7 7-7-7"/><circle cx="12" cy="21" r="1"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M12 17V3"/><path d="m6 11 6 6 6-6"/><path d="M19 21H5"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="m3 16 4 4 4-4"/><path d="M7 20V4"/><path d="m21 8-4-4-4 4"/><path d="M17 4v16"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="m3 16 4 4 4-4"/><path d="M7 20V4"/><path d="M11 4h10"/><path d="M11 8h7"/><path d="M11 12h4"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="m3 16 4 4 4-4"/><path d="M7 4v16"/><path d="M15 4h5l-5 6h5"/><path d="M15 20v-3.5a2.5 2.5 0 0 1 5 0V20"/><path d="M20 18h-5"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="m9 6-6 6 6 6"/><path d="M3 12h14"/><path d="M21 19V5"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><rect width="18" height="18" x="3" y="3" rx="2"/><path d="m12 8-4 4 4 4"/><path d="M16 12H8"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M3 19V5"/><path d="m13 6-6 6 6 6"/><path d="M7 12h14"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M3 5v14"/><path d="M21 12H7"/><path d="m15 18 6-6-6-6"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="m16 3 4 4-4 4"/><path d="M20 7H4"/><path d="m8 21-4-4 4-4"/><path d="M4 17h16"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><rect width="18" height="18" x="3" y="3" rx="2"/><path d="M8 12h8"/><path d="m12 16 4-4-4-4"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M17 12H3"/><path d="m11 18 6-6-6-6"/><path d="M21 5v14"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="m3 8 4-4 4 4"/><path d="M7 4v16"/><rect x="15" y="4" width="4" height="6" ry="2"/><path d="M17 20v-6h-2"/><path d="M15 20h4"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="m3 8 4-4 4 4"/><path d="M7 4v16"/><path d="M17 10V4h-2"/><path d="M15 10h4"/><rect x="15" y="14" width="4" height="6" ry="2"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="m3 8 4-4 4 4"/><path d="M7 4v16"/><path d="M20 8h-5"/><path d="M15 10V6.5a2.5 2.5 0 0 1 5 0V10"/><path d="M15 14h5l-5 6h5"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="m5 9 7-7 7 7"/><path d="M12 16V2"/><circle cx="12" cy="21" r="1"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="m18 9-6-6-6 6"/><path d="M12 3v14"/><path d="M5 21h14"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><path d="M2 8V2h6"/><path d="m2 2 10 10"/><path d="M12 2A10 10 0 1 1 2 12"/></svg>