lookbook 2.0.0.beta.6 → 2.0.0.beta.8

Sign up to get free protection for your applications and to get access to all the features.
Files changed (969) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +7 -0
  3. data/app/components/lookbook/page_tabs/component.html.erb +2 -2
  4. data/app/components/lookbook/params/field/component.rb +1 -1
  5. data/app/components/lookbook/prose/component.css +3 -1
  6. data/app/components/lookbook/prose/component.html.erb +1 -0
  7. data/app/components/lookbook/split_layout/component.html.erb +3 -3
  8. data/app/helpers/lookbook/application_helper.rb +1 -1
  9. data/app/views/lookbook/errors/default.html.erb +1 -1
  10. data/app/views/lookbook/inspector/show.html.erb +1 -0
  11. data/app/views/lookbook/pages/show.html.erb +65 -58
  12. data/assets/css/fonts.css +33 -0
  13. data/assets/css/lookbook.css +149 -0
  14. data/assets/css/themes/blue.css +79 -0
  15. data/assets/css/themes/green.css +79 -0
  16. data/assets/css/themes/indigo.css +79 -0
  17. data/assets/css/themes/rose.css +79 -0
  18. data/assets/css/themes/zinc.css +79 -0
  19. data/assets/css/tooltip.css +53 -0
  20. data/assets/fonts/Inter-italic.var.woff2 +0 -0
  21. data/assets/fonts/Inter-roman.var.woff2 +0 -0
  22. data/assets/fonts/SourceCodeVariable-Italic.ttf.woff2 +0 -0
  23. data/assets/fonts/SourceCodeVariable-Roman.ttf.woff2 +0 -0
  24. data/assets/icons/accessibility.svg +1 -0
  25. data/assets/icons/activity.svg +1 -0
  26. data/assets/icons/air-vent.svg +1 -0
  27. data/assets/icons/airplay.svg +1 -0
  28. data/assets/icons/alarm-check.svg +1 -0
  29. data/assets/icons/alarm-clock-off.svg +1 -0
  30. data/assets/icons/alarm-clock.svg +1 -0
  31. data/assets/icons/alarm-minus.svg +1 -0
  32. data/assets/icons/alarm-plus.svg +1 -0
  33. data/assets/icons/album.svg +1 -0
  34. data/assets/icons/alert-circle.svg +1 -0
  35. data/assets/icons/alert-octagon.svg +1 -0
  36. data/assets/icons/alert-triangle.svg +1 -0
  37. data/assets/icons/align-center-horizontal.svg +1 -0
  38. data/assets/icons/align-center-vertical.svg +1 -0
  39. data/assets/icons/align-center.svg +1 -0
  40. data/assets/icons/align-end-horizontal.svg +1 -0
  41. data/assets/icons/align-end-vertical.svg +1 -0
  42. data/assets/icons/align-horizontal-distribute-center.svg +1 -0
  43. data/assets/icons/align-horizontal-distribute-end.svg +1 -0
  44. data/assets/icons/align-horizontal-distribute-start.svg +1 -0
  45. data/assets/icons/align-horizontal-justify-center.svg +1 -0
  46. data/assets/icons/align-horizontal-justify-end.svg +1 -0
  47. data/assets/icons/align-horizontal-justify-start.svg +1 -0
  48. data/assets/icons/align-horizontal-space-around.svg +1 -0
  49. data/assets/icons/align-horizontal-space-between.svg +1 -0
  50. data/assets/icons/align-justify.svg +1 -0
  51. data/assets/icons/align-left.svg +1 -0
  52. data/assets/icons/align-right.svg +1 -0
  53. data/assets/icons/align-start-horizontal.svg +1 -0
  54. data/assets/icons/align-start-vertical.svg +1 -0
  55. data/assets/icons/align-vertical-distribute-center.svg +1 -0
  56. data/assets/icons/align-vertical-distribute-end.svg +1 -0
  57. data/assets/icons/align-vertical-distribute-start.svg +1 -0
  58. data/assets/icons/align-vertical-justify-center.svg +1 -0
  59. data/assets/icons/align-vertical-justify-end.svg +1 -0
  60. data/assets/icons/align-vertical-justify-start.svg +1 -0
  61. data/assets/icons/align-vertical-space-around.svg +1 -0
  62. data/assets/icons/align-vertical-space-between.svg +1 -0
  63. data/assets/icons/anchor.svg +1 -0
  64. data/assets/icons/angry.svg +1 -0
  65. data/assets/icons/annoyed.svg +1 -0
  66. data/assets/icons/aperture.svg +1 -0
  67. data/assets/icons/apple.svg +1 -0
  68. data/assets/icons/archive-restore.svg +1 -0
  69. data/assets/icons/archive.svg +1 -0
  70. data/assets/icons/armchair.svg +1 -0
  71. data/assets/icons/arrow-big-down.svg +1 -0
  72. data/assets/icons/arrow-big-left.svg +1 -0
  73. data/assets/icons/arrow-big-right.svg +1 -0
  74. data/assets/icons/arrow-big-up.svg +1 -0
  75. data/assets/icons/arrow-down-circle.svg +1 -0
  76. data/assets/icons/arrow-down-left.svg +1 -0
  77. data/assets/icons/arrow-down-right.svg +1 -0
  78. data/assets/icons/arrow-down.svg +1 -0
  79. data/assets/icons/arrow-left-circle.svg +1 -0
  80. data/assets/icons/arrow-left-right.svg +1 -0
  81. data/assets/icons/arrow-left.svg +1 -0
  82. data/assets/icons/arrow-right-circle.svg +1 -0
  83. data/assets/icons/arrow-right.svg +1 -0
  84. data/assets/icons/arrow-up-circle.svg +1 -0
  85. data/assets/icons/arrow-up-down.svg +1 -0
  86. data/assets/icons/arrow-up-left.svg +1 -0
  87. data/assets/icons/arrow-up-right.svg +1 -0
  88. data/assets/icons/arrow-up.svg +1 -0
  89. data/assets/icons/asterisk.svg +1 -0
  90. data/assets/icons/at-sign.svg +1 -0
  91. data/assets/icons/award.svg +1 -0
  92. data/assets/icons/axe.svg +1 -0
  93. data/assets/icons/axis-3d.svg +1 -0
  94. data/assets/icons/baby.svg +1 -0
  95. data/assets/icons/backpack.svg +1 -0
  96. data/assets/icons/baggage-claim.svg +1 -0
  97. data/assets/icons/banana.svg +1 -0
  98. data/assets/icons/banknote.svg +1 -0
  99. data/assets/icons/bar-chart-2.svg +1 -0
  100. data/assets/icons/bar-chart-3.svg +1 -0
  101. data/assets/icons/bar-chart-4.svg +1 -0
  102. data/assets/icons/bar-chart-horizontal.svg +1 -0
  103. data/assets/icons/bar-chart.svg +1 -0
  104. data/assets/icons/baseline.svg +1 -0
  105. data/assets/icons/bath.svg +1 -0
  106. data/assets/icons/battery-charging.svg +1 -0
  107. data/assets/icons/battery-full.svg +1 -0
  108. data/assets/icons/battery-low.svg +1 -0
  109. data/assets/icons/battery-medium.svg +1 -0
  110. data/assets/icons/battery-warning.svg +1 -0
  111. data/assets/icons/battery.svg +1 -0
  112. data/assets/icons/beaker.svg +1 -0
  113. data/assets/icons/bean-off.svg +1 -0
  114. data/assets/icons/bean.svg +1 -0
  115. data/assets/icons/bed-double.svg +1 -0
  116. data/assets/icons/bed-single.svg +1 -0
  117. data/assets/icons/bed.svg +1 -0
  118. data/assets/icons/beef.svg +1 -0
  119. data/assets/icons/beer.svg +1 -0
  120. data/assets/icons/bell-minus.svg +1 -0
  121. data/assets/icons/bell-off.svg +1 -0
  122. data/assets/icons/bell-plus.svg +1 -0
  123. data/assets/icons/bell-ring.svg +1 -0
  124. data/assets/icons/bell.svg +1 -0
  125. data/assets/icons/bike.svg +1 -0
  126. data/assets/icons/binary.svg +1 -0
  127. data/assets/icons/bird.svg +1 -0
  128. data/assets/icons/bitcoin.svg +1 -0
  129. data/assets/icons/blinds.svg +1 -0
  130. data/assets/icons/bluetooth-connected.svg +1 -0
  131. data/assets/icons/bluetooth-off.svg +1 -0
  132. data/assets/icons/bluetooth-searching.svg +1 -0
  133. data/assets/icons/bluetooth.svg +1 -0
  134. data/assets/icons/bold.svg +1 -0
  135. data/assets/icons/bomb.svg +1 -0
  136. data/assets/icons/bone.svg +1 -0
  137. data/assets/icons/book-open-check.svg +1 -0
  138. data/assets/icons/book-open.svg +1 -0
  139. data/assets/icons/book.svg +1 -0
  140. data/assets/icons/bookmark-minus.svg +1 -0
  141. data/assets/icons/bookmark-plus.svg +1 -0
  142. data/assets/icons/bookmark.svg +1 -0
  143. data/assets/icons/bot.svg +1 -0
  144. data/assets/icons/box-select.svg +1 -0
  145. data/assets/icons/box.svg +1 -0
  146. data/assets/icons/boxes.svg +1 -0
  147. data/assets/icons/briefcase.svg +1 -0
  148. data/assets/icons/brush.svg +1 -0
  149. data/assets/icons/bug.svg +1 -0
  150. data/assets/icons/building-2.svg +1 -0
  151. data/assets/icons/building.svg +1 -0
  152. data/assets/icons/bus.svg +1 -0
  153. data/assets/icons/cake.svg +1 -0
  154. data/assets/icons/calculator.svg +1 -0
  155. data/assets/icons/calendar-check-2.svg +1 -0
  156. data/assets/icons/calendar-check.svg +1 -0
  157. data/assets/icons/calendar-clock.svg +1 -0
  158. data/assets/icons/calendar-days.svg +1 -0
  159. data/assets/icons/calendar-heart.svg +1 -0
  160. data/assets/icons/calendar-minus.svg +1 -0
  161. data/assets/icons/calendar-off.svg +1 -0
  162. data/assets/icons/calendar-plus.svg +1 -0
  163. data/assets/icons/calendar-range.svg +1 -0
  164. data/assets/icons/calendar-search.svg +1 -0
  165. data/assets/icons/calendar-x-2.svg +1 -0
  166. data/assets/icons/calendar-x.svg +1 -0
  167. data/assets/icons/calendar.svg +1 -0
  168. data/assets/icons/camera-off.svg +1 -0
  169. data/assets/icons/camera.svg +1 -0
  170. data/assets/icons/candy-off.svg +1 -0
  171. data/assets/icons/candy.svg +1 -0
  172. data/assets/icons/car.svg +1 -0
  173. data/assets/icons/carrot.svg +1 -0
  174. data/assets/icons/cast.svg +1 -0
  175. data/assets/icons/cat.svg +1 -0
  176. data/assets/icons/check-check.svg +1 -0
  177. data/assets/icons/check-circle-2.svg +1 -0
  178. data/assets/icons/check-circle.svg +1 -0
  179. data/assets/icons/check-square.svg +1 -0
  180. data/assets/icons/check.svg +1 -0
  181. data/assets/icons/chef-hat.svg +1 -0
  182. data/assets/icons/cherry.svg +1 -0
  183. data/assets/icons/chevron-down.svg +1 -0
  184. data/assets/icons/chevron-first.svg +1 -0
  185. data/assets/icons/chevron-last.svg +1 -0
  186. data/assets/icons/chevron-left.svg +1 -0
  187. data/assets/icons/chevron-right.svg +1 -0
  188. data/assets/icons/chevron-up.svg +1 -0
  189. data/assets/icons/chevrons-down-up.svg +1 -0
  190. data/assets/icons/chevrons-down.svg +1 -0
  191. data/assets/icons/chevrons-left-right.svg +1 -0
  192. data/assets/icons/chevrons-left.svg +1 -0
  193. data/assets/icons/chevrons-right-left.svg +1 -0
  194. data/assets/icons/chevrons-right.svg +1 -0
  195. data/assets/icons/chevrons-up-down.svg +1 -0
  196. data/assets/icons/chevrons-up.svg +1 -0
  197. data/assets/icons/chrome.svg +1 -0
  198. data/assets/icons/cigarette-off.svg +1 -0
  199. data/assets/icons/cigarette.svg +1 -0
  200. data/assets/icons/circle-dot.svg +1 -0
  201. data/assets/icons/circle-ellipsis.svg +1 -0
  202. data/assets/icons/circle-slashed.svg +1 -0
  203. data/assets/icons/circle.svg +1 -0
  204. data/assets/icons/citrus.svg +1 -0
  205. data/assets/icons/clapperboard.svg +1 -0
  206. data/assets/icons/clipboard-check.svg +1 -0
  207. data/assets/icons/clipboard-copy.svg +1 -0
  208. data/assets/icons/clipboard-edit.svg +1 -0
  209. data/assets/icons/clipboard-list.svg +1 -0
  210. data/assets/icons/clipboard-signature.svg +1 -0
  211. data/assets/icons/clipboard-type.svg +1 -0
  212. data/assets/icons/clipboard-x.svg +1 -0
  213. data/assets/icons/clipboard.svg +1 -0
  214. data/assets/icons/clock-1.svg +1 -0
  215. data/assets/icons/clock-10.svg +1 -0
  216. data/assets/icons/clock-11.svg +1 -0
  217. data/assets/icons/clock-12.svg +1 -0
  218. data/assets/icons/clock-2.svg +1 -0
  219. data/assets/icons/clock-3.svg +1 -0
  220. data/assets/icons/clock-4.svg +1 -0
  221. data/assets/icons/clock-5.svg +1 -0
  222. data/assets/icons/clock-6.svg +1 -0
  223. data/assets/icons/clock-7.svg +1 -0
  224. data/assets/icons/clock-8.svg +1 -0
  225. data/assets/icons/clock-9.svg +1 -0
  226. data/assets/icons/clock.svg +1 -0
  227. data/assets/icons/cloud-cog.svg +1 -0
  228. data/assets/icons/cloud-drizzle.svg +1 -0
  229. data/assets/icons/cloud-fog.svg +1 -0
  230. data/assets/icons/cloud-hail.svg +1 -0
  231. data/assets/icons/cloud-lightning.svg +1 -0
  232. data/assets/icons/cloud-moon-rain.svg +1 -0
  233. data/assets/icons/cloud-moon.svg +1 -0
  234. data/assets/icons/cloud-off.svg +1 -0
  235. data/assets/icons/cloud-rain-wind.svg +1 -0
  236. data/assets/icons/cloud-rain.svg +1 -0
  237. data/assets/icons/cloud-snow.svg +1 -0
  238. data/assets/icons/cloud-sun-rain.svg +1 -0
  239. data/assets/icons/cloud-sun.svg +1 -0
  240. data/assets/icons/cloud.svg +1 -0
  241. data/assets/icons/cloudy.svg +1 -0
  242. data/assets/icons/clover.svg +1 -0
  243. data/assets/icons/code-2.svg +1 -0
  244. data/assets/icons/code.svg +1 -0
  245. data/assets/icons/codepen.svg +1 -0
  246. data/assets/icons/codesandbox.svg +1 -0
  247. data/assets/icons/coffee.svg +1 -0
  248. data/assets/icons/cog.svg +1 -0
  249. data/assets/icons/coins.svg +1 -0
  250. data/assets/icons/columns.svg +1 -0
  251. data/assets/icons/command.svg +1 -0
  252. data/assets/icons/compass.svg +1 -0
  253. data/assets/icons/component.svg +1 -0
  254. data/assets/icons/concierge-bell.svg +1 -0
  255. data/assets/icons/construction.svg +1 -0
  256. data/assets/icons/contact.svg +1 -0
  257. data/assets/icons/contrast.svg +1 -0
  258. data/assets/icons/cookie.svg +1 -0
  259. data/assets/icons/copy.svg +1 -0
  260. data/assets/icons/copyleft.svg +1 -0
  261. data/assets/icons/copyright.svg +1 -0
  262. data/assets/icons/corner-down-left.svg +1 -0
  263. data/assets/icons/corner-down-right.svg +1 -0
  264. data/assets/icons/corner-left-down.svg +1 -0
  265. data/assets/icons/corner-left-up.svg +1 -0
  266. data/assets/icons/corner-right-down.svg +1 -0
  267. data/assets/icons/corner-right-up.svg +1 -0
  268. data/assets/icons/corner-up-left.svg +1 -0
  269. data/assets/icons/corner-up-right.svg +1 -0
  270. data/assets/icons/cpu.svg +1 -0
  271. data/assets/icons/creative-commons.svg +1 -0
  272. data/assets/icons/credit-card.svg +1 -0
  273. data/assets/icons/croissant.svg +1 -0
  274. data/assets/icons/crop.svg +1 -0
  275. data/assets/icons/cross.svg +1 -0
  276. data/assets/icons/crosshair.svg +1 -0
  277. data/assets/icons/crown.svg +1 -0
  278. data/assets/icons/cup-soda.svg +1 -0
  279. data/assets/icons/curly-braces.svg +1 -0
  280. data/assets/icons/currency.svg +1 -0
  281. data/assets/icons/database-backup.svg +1 -0
  282. data/assets/icons/database.svg +1 -0
  283. data/assets/icons/delete.svg +1 -0
  284. data/assets/icons/diamond.svg +1 -0
  285. data/assets/icons/dice-1.svg +1 -0
  286. data/assets/icons/dice-2.svg +1 -0
  287. data/assets/icons/dice-3.svg +1 -0
  288. data/assets/icons/dice-4.svg +1 -0
  289. data/assets/icons/dice-5.svg +1 -0
  290. data/assets/icons/dice-6.svg +1 -0
  291. data/assets/icons/dices.svg +1 -0
  292. data/assets/icons/diff.svg +1 -0
  293. data/assets/icons/disc.svg +1 -0
  294. data/assets/icons/divide-circle.svg +1 -0
  295. data/assets/icons/divide-square.svg +1 -0
  296. data/assets/icons/divide.svg +1 -0
  297. data/assets/icons/dna-off.svg +1 -0
  298. data/assets/icons/dna.svg +1 -0
  299. data/assets/icons/dog.svg +1 -0
  300. data/assets/icons/dollar-sign.svg +1 -0
  301. data/assets/icons/download-cloud.svg +1 -0
  302. data/assets/icons/download.svg +1 -0
  303. data/assets/icons/dribbble.svg +1 -0
  304. data/assets/icons/droplet.svg +1 -0
  305. data/assets/icons/droplets.svg +1 -0
  306. data/assets/icons/drumstick.svg +1 -0
  307. data/assets/icons/dumbbell.svg +1 -0
  308. data/assets/icons/ear-off.svg +1 -0
  309. data/assets/icons/ear.svg +1 -0
  310. data/assets/icons/edit-2.svg +1 -0
  311. data/assets/icons/edit-3.svg +1 -0
  312. data/assets/icons/edit.svg +1 -0
  313. data/assets/icons/egg-fried.svg +1 -0
  314. data/assets/icons/egg-off.svg +1 -0
  315. data/assets/icons/egg.svg +1 -0
  316. data/assets/icons/equal-not.svg +1 -0
  317. data/assets/icons/equal.svg +1 -0
  318. data/assets/icons/eraser.svg +1 -0
  319. data/assets/icons/euro.svg +1 -0
  320. data/assets/icons/expand.svg +1 -0
  321. data/assets/icons/external-link.svg +1 -0
  322. data/assets/icons/eye-off.svg +1 -0
  323. data/assets/icons/eye.svg +1 -0
  324. data/assets/icons/facebook.svg +1 -0
  325. data/assets/icons/factory.svg +1 -0
  326. data/assets/icons/fan.svg +1 -0
  327. data/assets/icons/fast-forward.svg +1 -0
  328. data/assets/icons/feather.svg +1 -0
  329. data/assets/icons/figma.svg +1 -0
  330. data/assets/icons/file-archive.svg +1 -0
  331. data/assets/icons/file-audio-2.svg +1 -0
  332. data/assets/icons/file-audio.svg +1 -0
  333. data/assets/icons/file-axis-3d.svg +1 -0
  334. data/assets/icons/file-badge-2.svg +1 -0
  335. data/assets/icons/file-badge.svg +1 -0
  336. data/assets/icons/file-bar-chart-2.svg +1 -0
  337. data/assets/icons/file-bar-chart.svg +1 -0
  338. data/assets/icons/file-box.svg +1 -0
  339. data/assets/icons/file-check-2.svg +1 -0
  340. data/assets/icons/file-check.svg +1 -0
  341. data/assets/icons/file-clock.svg +1 -0
  342. data/assets/icons/file-code.svg +1 -0
  343. data/assets/icons/file-cog-2.svg +1 -0
  344. data/assets/icons/file-cog.svg +1 -0
  345. data/assets/icons/file-diff.svg +1 -0
  346. data/assets/icons/file-digit.svg +1 -0
  347. data/assets/icons/file-down.svg +1 -0
  348. data/assets/icons/file-edit.svg +1 -0
  349. data/assets/icons/file-heart.svg +1 -0
  350. data/assets/icons/file-image.svg +1 -0
  351. data/assets/icons/file-input.svg +1 -0
  352. data/assets/icons/file-json-2.svg +1 -0
  353. data/assets/icons/file-json.svg +1 -0
  354. data/assets/icons/file-key-2.svg +1 -0
  355. data/assets/icons/file-key.svg +1 -0
  356. data/assets/icons/file-line-chart.svg +1 -0
  357. data/assets/icons/file-lock-2.svg +1 -0
  358. data/assets/icons/file-lock.svg +1 -0
  359. data/assets/icons/file-minus-2.svg +1 -0
  360. data/assets/icons/file-minus.svg +1 -0
  361. data/assets/icons/file-output.svg +1 -0
  362. data/assets/icons/file-pie-chart.svg +1 -0
  363. data/assets/icons/file-plus-2.svg +1 -0
  364. data/assets/icons/file-plus.svg +1 -0
  365. data/assets/icons/file-question.svg +1 -0
  366. data/assets/icons/file-scan.svg +1 -0
  367. data/assets/icons/file-search-2.svg +1 -0
  368. data/assets/icons/file-search.svg +1 -0
  369. data/assets/icons/file-signature.svg +1 -0
  370. data/assets/icons/file-spreadsheet.svg +1 -0
  371. data/assets/icons/file-symlink.svg +1 -0
  372. data/assets/icons/file-terminal.svg +1 -0
  373. data/assets/icons/file-text.svg +1 -0
  374. data/assets/icons/file-type-2.svg +1 -0
  375. data/assets/icons/file-type.svg +1 -0
  376. data/assets/icons/file-up.svg +1 -0
  377. data/assets/icons/file-video-2.svg +1 -0
  378. data/assets/icons/file-video.svg +1 -0
  379. data/assets/icons/file-volume-2.svg +1 -0
  380. data/assets/icons/file-volume.svg +1 -0
  381. data/assets/icons/file-warning.svg +1 -0
  382. data/assets/icons/file-x-2.svg +1 -0
  383. data/assets/icons/file-x.svg +1 -0
  384. data/assets/icons/file.svg +1 -0
  385. data/assets/icons/files.svg +1 -0
  386. data/assets/icons/film.svg +1 -0
  387. data/assets/icons/filter-x.svg +1 -0
  388. data/assets/icons/filter.svg +1 -0
  389. data/assets/icons/fingerprint.svg +1 -0
  390. data/assets/icons/fish-off.svg +1 -0
  391. data/assets/icons/fish.svg +1 -0
  392. data/assets/icons/flag-off.svg +1 -0
  393. data/assets/icons/flag-triangle-left.svg +1 -0
  394. data/assets/icons/flag-triangle-right.svg +1 -0
  395. data/assets/icons/flag.svg +1 -0
  396. data/assets/icons/flame.svg +1 -0
  397. data/assets/icons/flashlight-off.svg +1 -0
  398. data/assets/icons/flashlight.svg +1 -0
  399. data/assets/icons/flask-conical-off.svg +1 -0
  400. data/assets/icons/flask-conical.svg +1 -0
  401. data/assets/icons/flask-round.svg +1 -0
  402. data/assets/icons/flip-horizontal-2.svg +1 -0
  403. data/assets/icons/flip-horizontal.svg +1 -0
  404. data/assets/icons/flip-vertical-2.svg +1 -0
  405. data/assets/icons/flip-vertical.svg +1 -0
  406. data/assets/icons/flower-2.svg +1 -0
  407. data/assets/icons/flower.svg +1 -0
  408. data/assets/icons/focus.svg +1 -0
  409. data/assets/icons/folder-archive.svg +1 -0
  410. data/assets/icons/folder-check.svg +1 -0
  411. data/assets/icons/folder-clock.svg +1 -0
  412. data/assets/icons/folder-closed.svg +1 -0
  413. data/assets/icons/folder-cog-2.svg +1 -0
  414. data/assets/icons/folder-cog.svg +1 -0
  415. data/assets/icons/folder-down.svg +1 -0
  416. data/assets/icons/folder-edit.svg +1 -0
  417. data/assets/icons/folder-heart.svg +1 -0
  418. data/assets/icons/folder-input.svg +1 -0
  419. data/assets/icons/folder-key.svg +1 -0
  420. data/assets/icons/folder-lock.svg +1 -0
  421. data/assets/icons/folder-minus.svg +1 -0
  422. data/assets/icons/folder-open.svg +1 -0
  423. data/assets/icons/folder-output.svg +1 -0
  424. data/assets/icons/folder-plus.svg +1 -0
  425. data/assets/icons/folder-search-2.svg +1 -0
  426. data/assets/icons/folder-search.svg +1 -0
  427. data/assets/icons/folder-symlink.svg +1 -0
  428. data/assets/icons/folder-tree.svg +1 -0
  429. data/assets/icons/folder-up.svg +1 -0
  430. data/assets/icons/folder-x.svg +1 -0
  431. data/assets/icons/folder.svg +1 -0
  432. data/assets/icons/folders.svg +1 -0
  433. data/assets/icons/footprints.svg +1 -0
  434. data/assets/icons/forklift.svg +1 -0
  435. data/assets/icons/form-input.svg +1 -0
  436. data/assets/icons/forward.svg +1 -0
  437. data/assets/icons/frame.svg +1 -0
  438. data/assets/icons/framer.svg +1 -0
  439. data/assets/icons/frown.svg +1 -0
  440. data/assets/icons/fuel.svg +1 -0
  441. data/assets/icons/function-square.svg +1 -0
  442. data/assets/icons/gamepad-2.svg +1 -0
  443. data/assets/icons/gamepad.svg +1 -0
  444. data/assets/icons/gauge.svg +1 -0
  445. data/assets/icons/gavel.svg +1 -0
  446. data/assets/icons/gem.svg +1 -0
  447. data/assets/icons/ghost.svg +1 -0
  448. data/assets/icons/gift.svg +1 -0
  449. data/assets/icons/git-branch-plus.svg +1 -0
  450. data/assets/icons/git-branch.svg +1 -0
  451. data/assets/icons/git-commit.svg +1 -0
  452. data/assets/icons/git-compare.svg +1 -0
  453. data/assets/icons/git-fork.svg +1 -0
  454. data/assets/icons/git-merge.svg +1 -0
  455. data/assets/icons/git-pull-request-closed.svg +1 -0
  456. data/assets/icons/git-pull-request-draft.svg +1 -0
  457. data/assets/icons/git-pull-request.svg +1 -0
  458. data/assets/icons/github.svg +1 -0
  459. data/assets/icons/gitlab.svg +1 -0
  460. data/assets/icons/glass-water.svg +1 -0
  461. data/assets/icons/glasses.svg +1 -0
  462. data/assets/icons/globe-2.svg +1 -0
  463. data/assets/icons/globe.svg +1 -0
  464. data/assets/icons/grab.svg +1 -0
  465. data/assets/icons/graduation-cap.svg +1 -0
  466. data/assets/icons/grape.svg +1 -0
  467. data/assets/icons/grid.svg +1 -0
  468. data/assets/icons/grip-horizontal.svg +1 -0
  469. data/assets/icons/grip-vertical.svg +1 -0
  470. data/assets/icons/grip.svg +1 -0
  471. data/assets/icons/hammer.svg +1 -0
  472. data/assets/icons/hand-metal.svg +1 -0
  473. data/assets/icons/hand.svg +1 -0
  474. data/assets/icons/hard-drive.svg +1 -0
  475. data/assets/icons/hard-hat.svg +1 -0
  476. data/assets/icons/hash.svg +1 -0
  477. data/assets/icons/haze.svg +1 -0
  478. data/assets/icons/heading-1.svg +1 -0
  479. data/assets/icons/heading-2.svg +1 -0
  480. data/assets/icons/heading-3.svg +1 -0
  481. data/assets/icons/heading-4.svg +1 -0
  482. data/assets/icons/heading-5.svg +1 -0
  483. data/assets/icons/heading-6.svg +1 -0
  484. data/assets/icons/heading.svg +1 -0
  485. data/assets/icons/headphones.svg +1 -0
  486. data/assets/icons/heart-crack.svg +1 -0
  487. data/assets/icons/heart-handshake.svg +1 -0
  488. data/assets/icons/heart-off.svg +1 -0
  489. data/assets/icons/heart-pulse.svg +1 -0
  490. data/assets/icons/heart.svg +1 -0
  491. data/assets/icons/help-circle.svg +1 -0
  492. data/assets/icons/helping-hand.svg +1 -0
  493. data/assets/icons/hexagon.svg +1 -0
  494. data/assets/icons/highlighter.svg +1 -0
  495. data/assets/icons/history.svg +1 -0
  496. data/assets/icons/home.svg +1 -0
  497. data/assets/icons/hop-off.svg +1 -0
  498. data/assets/icons/hop.svg +1 -0
  499. data/assets/icons/hourglass.svg +1 -0
  500. data/assets/icons/ice-cream-2.svg +1 -0
  501. data/assets/icons/ice-cream.svg +1 -0
  502. data/assets/icons/image-minus.svg +1 -0
  503. data/assets/icons/image-off.svg +1 -0
  504. data/assets/icons/image-plus.svg +1 -0
  505. data/assets/icons/image.svg +1 -0
  506. data/assets/icons/import.svg +1 -0
  507. data/assets/icons/inbox.svg +1 -0
  508. data/assets/icons/indent.svg +1 -0
  509. data/assets/icons/indian-rupee.svg +1 -0
  510. data/assets/icons/infinity.svg +1 -0
  511. data/assets/icons/info.svg +1 -0
  512. data/assets/icons/inspect.svg +1 -0
  513. data/assets/icons/instagram.svg +1 -0
  514. data/assets/icons/italic.svg +1 -0
  515. data/assets/icons/japanese-yen.svg +1 -0
  516. data/assets/icons/joystick.svg +1 -0
  517. data/assets/icons/key.svg +1 -0
  518. data/assets/icons/keyboard.svg +1 -0
  519. data/assets/icons/lamp-ceiling.svg +1 -0
  520. data/assets/icons/lamp-desk.svg +1 -0
  521. data/assets/icons/lamp-floor.svg +1 -0
  522. data/assets/icons/lamp-wall-down.svg +1 -0
  523. data/assets/icons/lamp-wall-up.svg +1 -0
  524. data/assets/icons/lamp.svg +1 -0
  525. data/assets/icons/landmark.svg +1 -0
  526. data/assets/icons/languages.svg +1 -0
  527. data/assets/icons/laptop-2.svg +1 -0
  528. data/assets/icons/laptop.svg +1 -0
  529. data/assets/icons/lasso-select.svg +1 -0
  530. data/assets/icons/lasso.svg +1 -0
  531. data/assets/icons/laugh.svg +1 -0
  532. data/assets/icons/layers.svg +1 -0
  533. data/assets/icons/layout-dashboard.svg +1 -0
  534. data/assets/icons/layout-grid.svg +1 -0
  535. data/assets/icons/layout-list.svg +1 -0
  536. data/assets/icons/layout-template.svg +1 -0
  537. data/assets/icons/layout.svg +1 -0
  538. data/assets/icons/leaf.svg +1 -0
  539. data/assets/icons/library.svg +1 -0
  540. data/assets/icons/life-buoy.svg +1 -0
  541. data/assets/icons/lightbulb-off.svg +1 -0
  542. data/assets/icons/lightbulb.svg +1 -0
  543. data/assets/icons/line-chart.svg +1 -0
  544. data/assets/icons/link-2-off.svg +1 -0
  545. data/assets/icons/link-2.svg +1 -0
  546. data/assets/icons/link.svg +1 -0
  547. data/assets/icons/linkedin.svg +1 -0
  548. data/assets/icons/list-checks.svg +1 -0
  549. data/assets/icons/list-end.svg +1 -0
  550. data/assets/icons/list-minus.svg +1 -0
  551. data/assets/icons/list-music.svg +1 -0
  552. data/assets/icons/list-ordered.svg +1 -0
  553. data/assets/icons/list-plus.svg +1 -0
  554. data/assets/icons/list-start.svg +1 -0
  555. data/assets/icons/list-video.svg +1 -0
  556. data/assets/icons/list-x.svg +1 -0
  557. data/assets/icons/list.svg +1 -0
  558. data/assets/icons/loader-2.svg +1 -0
  559. data/assets/icons/loader.svg +1 -0
  560. data/assets/icons/locate-fixed.svg +1 -0
  561. data/assets/icons/locate-off.svg +1 -0
  562. data/assets/icons/locate.svg +1 -0
  563. data/assets/icons/lock.svg +1 -0
  564. data/assets/icons/log-in.svg +1 -0
  565. data/assets/icons/log-out.svg +1 -0
  566. data/assets/icons/luggage.svg +1 -0
  567. data/assets/icons/magnet.svg +1 -0
  568. data/assets/icons/mail-check.svg +1 -0
  569. data/assets/icons/mail-minus.svg +1 -0
  570. data/assets/icons/mail-open.svg +1 -0
  571. data/assets/icons/mail-plus.svg +1 -0
  572. data/assets/icons/mail-question.svg +1 -0
  573. data/assets/icons/mail-search.svg +1 -0
  574. data/assets/icons/mail-warning.svg +1 -0
  575. data/assets/icons/mail-x.svg +1 -0
  576. data/assets/icons/mail.svg +1 -0
  577. data/assets/icons/mails.svg +1 -0
  578. data/assets/icons/map-pin-off.svg +1 -0
  579. data/assets/icons/map-pin.svg +1 -0
  580. data/assets/icons/map.svg +1 -0
  581. data/assets/icons/martini.svg +1 -0
  582. data/assets/icons/maximize-2.svg +1 -0
  583. data/assets/icons/maximize.svg +1 -0
  584. data/assets/icons/medal.svg +1 -0
  585. data/assets/icons/megaphone-off.svg +1 -0
  586. data/assets/icons/megaphone.svg +1 -0
  587. data/assets/icons/meh.svg +1 -0
  588. data/assets/icons/menu.svg +1 -0
  589. data/assets/icons/message-circle.svg +1 -0
  590. data/assets/icons/message-square.svg +1 -0
  591. data/assets/icons/mic-2.svg +1 -0
  592. data/assets/icons/mic-off.svg +1 -0
  593. data/assets/icons/mic.svg +1 -0
  594. data/assets/icons/microscope.svg +1 -0
  595. data/assets/icons/microwave.svg +1 -0
  596. data/assets/icons/milestone.svg +1 -0
  597. data/assets/icons/milk-off.svg +1 -0
  598. data/assets/icons/milk.svg +1 -0
  599. data/assets/icons/minimize-2.svg +1 -0
  600. data/assets/icons/minimize.svg +1 -0
  601. data/assets/icons/minus-circle.svg +1 -0
  602. data/assets/icons/minus-square.svg +1 -0
  603. data/assets/icons/minus.svg +1 -0
  604. data/assets/icons/monitor-off.svg +1 -0
  605. data/assets/icons/monitor-smartphone.svg +1 -0
  606. data/assets/icons/monitor-speaker.svg +1 -0
  607. data/assets/icons/monitor.svg +1 -0
  608. data/assets/icons/moon.svg +1 -0
  609. data/assets/icons/more-horizontal.svg +1 -0
  610. data/assets/icons/more-vertical.svg +1 -0
  611. data/assets/icons/mountain-snow.svg +1 -0
  612. data/assets/icons/mountain.svg +1 -0
  613. data/assets/icons/mouse-pointer-2.svg +1 -0
  614. data/assets/icons/mouse-pointer-click.svg +1 -0
  615. data/assets/icons/mouse-pointer.svg +1 -0
  616. data/assets/icons/mouse.svg +1 -0
  617. data/assets/icons/move-3d.svg +1 -0
  618. data/assets/icons/move-diagonal-2.svg +1 -0
  619. data/assets/icons/move-diagonal.svg +1 -0
  620. data/assets/icons/move-horizontal.svg +1 -0
  621. data/assets/icons/move-vertical.svg +1 -0
  622. data/assets/icons/move.svg +1 -0
  623. data/assets/icons/music-2.svg +1 -0
  624. data/assets/icons/music-3.svg +1 -0
  625. data/assets/icons/music-4.svg +1 -0
  626. data/assets/icons/music.svg +1 -0
  627. data/assets/icons/navigation-2-off.svg +1 -0
  628. data/assets/icons/navigation-2.svg +1 -0
  629. data/assets/icons/navigation-off.svg +1 -0
  630. data/assets/icons/navigation.svg +1 -0
  631. data/assets/icons/network.svg +1 -0
  632. data/assets/icons/newspaper.svg +1 -0
  633. data/assets/icons/nfc.svg +1 -0
  634. data/assets/icons/nut-off.svg +1 -0
  635. data/assets/icons/nut.svg +1 -0
  636. data/assets/icons/octagon.svg +1 -0
  637. data/assets/icons/option.svg +1 -0
  638. data/assets/icons/outdent.svg +1 -0
  639. data/assets/icons/package-2.svg +1 -0
  640. data/assets/icons/package-check.svg +1 -0
  641. data/assets/icons/package-minus.svg +1 -0
  642. data/assets/icons/package-open.svg +1 -0
  643. data/assets/icons/package-plus.svg +1 -0
  644. data/assets/icons/package-search.svg +1 -0
  645. data/assets/icons/package-x.svg +1 -0
  646. data/assets/icons/package.svg +1 -0
  647. data/assets/icons/paint-bucket.svg +1 -0
  648. data/assets/icons/paintbrush-2.svg +1 -0
  649. data/assets/icons/paintbrush.svg +1 -0
  650. data/assets/icons/palette.svg +1 -0
  651. data/assets/icons/palmtree.svg +1 -0
  652. data/assets/icons/paperclip.svg +1 -0
  653. data/assets/icons/party-popper.svg +1 -0
  654. data/assets/icons/pause-circle.svg +1 -0
  655. data/assets/icons/pause-octagon.svg +1 -0
  656. data/assets/icons/pause.svg +1 -0
  657. data/assets/icons/pen-tool.svg +1 -0
  658. data/assets/icons/pencil.svg +1 -0
  659. data/assets/icons/percent.svg +1 -0
  660. data/assets/icons/person-standing.svg +1 -0
  661. data/assets/icons/phone-call.svg +1 -0
  662. data/assets/icons/phone-forwarded.svg +1 -0
  663. data/assets/icons/phone-incoming.svg +1 -0
  664. data/assets/icons/phone-missed.svg +1 -0
  665. data/assets/icons/phone-off.svg +1 -0
  666. data/assets/icons/phone-outgoing.svg +1 -0
  667. data/assets/icons/phone.svg +1 -0
  668. data/assets/icons/picture-in-picture-2.svg +1 -0
  669. data/assets/icons/picture-in-picture.svg +1 -0
  670. data/assets/icons/pie-chart.svg +1 -0
  671. data/assets/icons/piggy-bank.svg +1 -0
  672. data/assets/icons/pilcrow.svg +1 -0
  673. data/assets/icons/pill.svg +1 -0
  674. data/assets/icons/pin-off.svg +1 -0
  675. data/assets/icons/pin.svg +1 -0
  676. data/assets/icons/pipette.svg +1 -0
  677. data/assets/icons/pizza.svg +1 -0
  678. data/assets/icons/plane.svg +1 -0
  679. data/assets/icons/play-circle.svg +1 -0
  680. data/assets/icons/play.svg +1 -0
  681. data/assets/icons/plug-2.svg +1 -0
  682. data/assets/icons/plug-zap.svg +1 -0
  683. data/assets/icons/plug.svg +1 -0
  684. data/assets/icons/plus-circle.svg +1 -0
  685. data/assets/icons/plus-square.svg +1 -0
  686. data/assets/icons/plus.svg +1 -0
  687. data/assets/icons/pocket.svg +1 -0
  688. data/assets/icons/podcast.svg +1 -0
  689. data/assets/icons/pointer.svg +1 -0
  690. data/assets/icons/pound-sterling.svg +1 -0
  691. data/assets/icons/power-off.svg +1 -0
  692. data/assets/icons/power.svg +1 -0
  693. data/assets/icons/printer.svg +1 -0
  694. data/assets/icons/puzzle.svg +1 -0
  695. data/assets/icons/qr-code.svg +1 -0
  696. data/assets/icons/quote.svg +1 -0
  697. data/assets/icons/radio-receiver.svg +1 -0
  698. data/assets/icons/radio.svg +1 -0
  699. data/assets/icons/rectangle-horizontal.svg +1 -0
  700. data/assets/icons/rectangle-vertical.svg +1 -0
  701. data/assets/icons/recycle.svg +1 -0
  702. data/assets/icons/redo-2.svg +1 -0
  703. data/assets/icons/redo.svg +1 -0
  704. data/assets/icons/refresh-ccw.svg +1 -0
  705. data/assets/icons/refresh-cw.svg +1 -0
  706. data/assets/icons/refrigerator.svg +1 -0
  707. data/assets/icons/regex.svg +1 -0
  708. data/assets/icons/remove-formatting.svg +1 -0
  709. data/assets/icons/repeat-1.svg +1 -0
  710. data/assets/icons/repeat.svg +1 -0
  711. data/assets/icons/reply-all.svg +1 -0
  712. data/assets/icons/reply.svg +1 -0
  713. data/assets/icons/rewind.svg +1 -0
  714. data/assets/icons/rocket.svg +1 -0
  715. data/assets/icons/rocking-chair.svg +1 -0
  716. data/assets/icons/rotate-3d.svg +1 -0
  717. data/assets/icons/rotate-ccw.svg +1 -0
  718. data/assets/icons/rotate-cw.svg +1 -0
  719. data/assets/icons/router.svg +1 -0
  720. data/assets/icons/rss.svg +1 -0
  721. data/assets/icons/ruler.svg +1 -0
  722. data/assets/icons/russian-ruble.svg +1 -0
  723. data/assets/icons/sailboat.svg +1 -0
  724. data/assets/icons/salad.svg +1 -0
  725. data/assets/icons/sandwich.svg +1 -0
  726. data/assets/icons/save.svg +1 -0
  727. data/assets/icons/scale-3d.svg +1 -0
  728. data/assets/icons/scale.svg +1 -0
  729. data/assets/icons/scaling.svg +1 -0
  730. data/assets/icons/scan-face.svg +1 -0
  731. data/assets/icons/scan-line.svg +1 -0
  732. data/assets/icons/scan.svg +1 -0
  733. data/assets/icons/scissors.svg +1 -0
  734. data/assets/icons/screen-share-off.svg +1 -0
  735. data/assets/icons/screen-share.svg +1 -0
  736. data/assets/icons/scroll.svg +1 -0
  737. data/assets/icons/search.svg +1 -0
  738. data/assets/icons/send.svg +1 -0
  739. data/assets/icons/separator-horizontal.svg +1 -0
  740. data/assets/icons/separator-vertical.svg +1 -0
  741. data/assets/icons/server-cog.svg +1 -0
  742. data/assets/icons/server-crash.svg +1 -0
  743. data/assets/icons/server-off.svg +1 -0
  744. data/assets/icons/server.svg +1 -0
  745. data/assets/icons/settings-2.svg +1 -0
  746. data/assets/icons/settings.svg +1 -0
  747. data/assets/icons/share-2.svg +1 -0
  748. data/assets/icons/share.svg +1 -0
  749. data/assets/icons/sheet.svg +1 -0
  750. data/assets/icons/shield-alert.svg +1 -0
  751. data/assets/icons/shield-check.svg +1 -0
  752. data/assets/icons/shield-close.svg +1 -0
  753. data/assets/icons/shield-off.svg +1 -0
  754. data/assets/icons/shield.svg +1 -0
  755. data/assets/icons/ship.svg +1 -0
  756. data/assets/icons/shirt.svg +1 -0
  757. data/assets/icons/shopping-bag.svg +1 -0
  758. data/assets/icons/shopping-cart.svg +1 -0
  759. data/assets/icons/shovel.svg +1 -0
  760. data/assets/icons/shower-head.svg +1 -0
  761. data/assets/icons/shrink.svg +1 -0
  762. data/assets/icons/shrub.svg +1 -0
  763. data/assets/icons/shuffle.svg +1 -0
  764. data/assets/icons/sidebar-close.svg +1 -0
  765. data/assets/icons/sidebar-open.svg +1 -0
  766. data/assets/icons/sidebar.svg +1 -0
  767. data/assets/icons/sigma.svg +1 -0
  768. data/assets/icons/signal-high.svg +1 -0
  769. data/assets/icons/signal-low.svg +1 -0
  770. data/assets/icons/signal-medium.svg +1 -0
  771. data/assets/icons/signal-zero.svg +1 -0
  772. data/assets/icons/signal.svg +1 -0
  773. data/assets/icons/siren.svg +1 -0
  774. data/assets/icons/skip-back.svg +1 -0
  775. data/assets/icons/skip-forward.svg +1 -0
  776. data/assets/icons/skull.svg +1 -0
  777. data/assets/icons/slack.svg +1 -0
  778. data/assets/icons/slash.svg +1 -0
  779. data/assets/icons/slice.svg +1 -0
  780. data/assets/icons/sliders-horizontal.svg +1 -0
  781. data/assets/icons/sliders.svg +1 -0
  782. data/assets/icons/smartphone-charging.svg +1 -0
  783. data/assets/icons/smartphone-nfc.svg +1 -0
  784. data/assets/icons/smartphone.svg +1 -0
  785. data/assets/icons/smile-plus.svg +1 -0
  786. data/assets/icons/smile.svg +1 -0
  787. data/assets/icons/snowflake.svg +1 -0
  788. data/assets/icons/sofa.svg +1 -0
  789. data/assets/icons/sort-asc.svg +1 -0
  790. data/assets/icons/sort-desc.svg +1 -0
  791. data/assets/icons/soup.svg +1 -0
  792. data/assets/icons/speaker.svg +1 -0
  793. data/assets/icons/spline.svg +1 -0
  794. data/assets/icons/split-square-horizontal.svg +1 -0
  795. data/assets/icons/split-square-vertical.svg +1 -0
  796. data/assets/icons/sprout.svg +1 -0
  797. data/assets/icons/square.svg +1 -0
  798. data/assets/icons/stamp.svg +1 -0
  799. data/assets/icons/star-half.svg +1 -0
  800. data/assets/icons/star-off.svg +1 -0
  801. data/assets/icons/star.svg +1 -0
  802. data/assets/icons/stethoscope.svg +1 -0
  803. data/assets/icons/sticker.svg +1 -0
  804. data/assets/icons/sticky-note.svg +1 -0
  805. data/assets/icons/stop-circle.svg +1 -0
  806. data/assets/icons/stretch-horizontal.svg +1 -0
  807. data/assets/icons/stretch-vertical.svg +1 -0
  808. data/assets/icons/strikethrough.svg +1 -0
  809. data/assets/icons/subscript.svg +1 -0
  810. data/assets/icons/subtitles.svg +1 -0
  811. data/assets/icons/sun-dim.svg +1 -0
  812. data/assets/icons/sun-medium.svg +1 -0
  813. data/assets/icons/sun-moon.svg +1 -0
  814. data/assets/icons/sun-snow.svg +1 -0
  815. data/assets/icons/sun.svg +1 -0
  816. data/assets/icons/sunrise.svg +1 -0
  817. data/assets/icons/sunset.svg +1 -0
  818. data/assets/icons/superscript.svg +1 -0
  819. data/assets/icons/swiss-franc.svg +1 -0
  820. data/assets/icons/switch-camera.svg +1 -0
  821. data/assets/icons/sword.svg +1 -0
  822. data/assets/icons/swords.svg +1 -0
  823. data/assets/icons/syringe.svg +1 -0
  824. data/assets/icons/table-2.svg +1 -0
  825. data/assets/icons/table.svg +1 -0
  826. data/assets/icons/tablet.svg +1 -0
  827. data/assets/icons/tablets.svg +1 -0
  828. data/assets/icons/tag.svg +1 -0
  829. data/assets/icons/tags.svg +1 -0
  830. data/assets/icons/target.svg +1 -0
  831. data/assets/icons/tent.svg +1 -0
  832. data/assets/icons/terminal-square.svg +1 -0
  833. data/assets/icons/terminal.svg +1 -0
  834. data/assets/icons/text-cursor-input.svg +1 -0
  835. data/assets/icons/text-cursor.svg +1 -0
  836. data/assets/icons/thermometer-snowflake.svg +1 -0
  837. data/assets/icons/thermometer-sun.svg +1 -0
  838. data/assets/icons/thermometer.svg +1 -0
  839. data/assets/icons/thumbs-down.svg +1 -0
  840. data/assets/icons/thumbs-up.svg +1 -0
  841. data/assets/icons/ticket.svg +1 -0
  842. data/assets/icons/timer-off.svg +1 -0
  843. data/assets/icons/timer-reset.svg +1 -0
  844. data/assets/icons/timer.svg +1 -0
  845. data/assets/icons/toggle-left.svg +1 -0
  846. data/assets/icons/toggle-right.svg +1 -0
  847. data/assets/icons/tornado.svg +1 -0
  848. data/assets/icons/tower-control.svg +1 -0
  849. data/assets/icons/toy-brick.svg +1 -0
  850. data/assets/icons/train.svg +1 -0
  851. data/assets/icons/trash-2.svg +1 -0
  852. data/assets/icons/trash.svg +1 -0
  853. data/assets/icons/tree-deciduous.svg +1 -0
  854. data/assets/icons/tree-pine.svg +1 -0
  855. data/assets/icons/trees.svg +1 -0
  856. data/assets/icons/trello.svg +1 -0
  857. data/assets/icons/trending-down.svg +1 -0
  858. data/assets/icons/trending-up.svg +1 -0
  859. data/assets/icons/triangle.svg +1 -0
  860. data/assets/icons/trophy.svg +1 -0
  861. data/assets/icons/truck.svg +1 -0
  862. data/assets/icons/tv-2.svg +1 -0
  863. data/assets/icons/tv.svg +1 -0
  864. data/assets/icons/twitch.svg +1 -0
  865. data/assets/icons/twitter.svg +1 -0
  866. data/assets/icons/type.svg +1 -0
  867. data/assets/icons/umbrella.svg +1 -0
  868. data/assets/icons/underline.svg +1 -0
  869. data/assets/icons/undo-2.svg +1 -0
  870. data/assets/icons/undo.svg +1 -0
  871. data/assets/icons/unlink-2.svg +1 -0
  872. data/assets/icons/unlink.svg +1 -0
  873. data/assets/icons/unlock.svg +1 -0
  874. data/assets/icons/upload-cloud.svg +1 -0
  875. data/assets/icons/upload.svg +1 -0
  876. data/assets/icons/usb.svg +1 -0
  877. data/assets/icons/user-check.svg +1 -0
  878. data/assets/icons/user-cog.svg +1 -0
  879. data/assets/icons/user-minus.svg +1 -0
  880. data/assets/icons/user-plus.svg +1 -0
  881. data/assets/icons/user-x.svg +1 -0
  882. data/assets/icons/user.svg +1 -0
  883. data/assets/icons/users.svg +1 -0
  884. data/assets/icons/utensils-crossed.svg +1 -0
  885. data/assets/icons/utensils.svg +1 -0
  886. data/assets/icons/utility-pole.svg +1 -0
  887. data/assets/icons/vegan.svg +1 -0
  888. data/assets/icons/venetian-mask.svg +1 -0
  889. data/assets/icons/verified.svg +1 -0
  890. data/assets/icons/vibrate-off.svg +1 -0
  891. data/assets/icons/vibrate.svg +1 -0
  892. data/assets/icons/video-off.svg +1 -0
  893. data/assets/icons/video.svg +1 -0
  894. data/assets/icons/view.svg +1 -0
  895. data/assets/icons/voicemail.svg +1 -0
  896. data/assets/icons/volume-1.svg +1 -0
  897. data/assets/icons/volume-2.svg +1 -0
  898. data/assets/icons/volume-x.svg +1 -0
  899. data/assets/icons/volume.svg +1 -0
  900. data/assets/icons/vote.svg +1 -0
  901. data/assets/icons/wallet.svg +1 -0
  902. data/assets/icons/wand-2.svg +1 -0
  903. data/assets/icons/wand.svg +1 -0
  904. data/assets/icons/watch.svg +1 -0
  905. data/assets/icons/waves.svg +1 -0
  906. data/assets/icons/webcam.svg +1 -0
  907. data/assets/icons/webhook.svg +1 -0
  908. data/assets/icons/wheat-off.svg +1 -0
  909. data/assets/icons/wheat.svg +1 -0
  910. data/assets/icons/wifi-off.svg +1 -0
  911. data/assets/icons/wifi.svg +1 -0
  912. data/assets/icons/wind.svg +1 -0
  913. data/assets/icons/wine-off.svg +1 -0
  914. data/assets/icons/wine.svg +1 -0
  915. data/assets/icons/wrap-text.svg +1 -0
  916. data/assets/icons/wrench.svg +1 -0
  917. data/assets/icons/x-circle.svg +1 -0
  918. data/assets/icons/x-octagon.svg +1 -0
  919. data/assets/icons/x-square.svg +1 -0
  920. data/assets/icons/x.svg +1 -0
  921. data/assets/icons/youtube.svg +1 -0
  922. data/assets/icons/zap-off.svg +1 -0
  923. data/assets/icons/zap.svg +1 -0
  924. data/assets/icons/zoom-in.svg +1 -0
  925. data/assets/icons/zoom-out.svg +1 -0
  926. data/assets/img/favicon_dark.svg +1 -0
  927. data/assets/img/favicon_light.svg +1 -0
  928. data/assets/js/app.js +112 -0
  929. data/assets/js/components/clipboard.js +47 -0
  930. data/assets/js/components/params_input.js +23 -0
  931. data/assets/js/components/tooltip.js +30 -0
  932. data/assets/js/config.js +24 -0
  933. data/assets/js/helpers/build.js +22 -0
  934. data/assets/js/helpers/dom.js +42 -0
  935. data/assets/js/helpers/layout.js +21 -0
  936. data/assets/js/helpers/request.js +14 -0
  937. data/assets/js/helpers/string.js +26 -0
  938. data/assets/js/iframe.js +1 -0
  939. data/assets/js/index.js +61 -0
  940. data/assets/js/lib/lookbook.js +123 -0
  941. data/assets/js/lib/socket.js +28 -0
  942. data/assets/js/lib/tippy.js +9 -0
  943. data/assets/js/lookbook-core.js +1 -0
  944. data/assets/js/lookbook.js +2 -0
  945. data/assets/js/plugins/logger.js +39 -0
  946. data/assets/js/stores/filter.js +11 -0
  947. data/assets/js/stores/inspector.js +31 -0
  948. data/assets/js/stores/layout.js +111 -0
  949. data/assets/js/stores/nav.js +22 -0
  950. data/assets/js/stores/pages.js +7 -0
  951. data/assets/js/stores/settings.js +7 -0
  952. data/assets/js/stores/workbench.js +29 -0
  953. data/lib/lookbook/engine.rb +14 -2
  954. data/lib/lookbook/version.rb +1 -1
  955. data/public/lookbook-assets/css/lookbook.css +85 -11
  956. data/public/lookbook-assets/css/lookbook.css.map +1 -1
  957. data/public/lookbook-assets/css/themes/blue.css +3 -0
  958. data/public/lookbook-assets/css/themes/blue.css.map +1 -1
  959. data/public/lookbook-assets/css/themes/green.css +3 -0
  960. data/public/lookbook-assets/css/themes/green.css.map +1 -1
  961. data/public/lookbook-assets/css/themes/indigo.css +3 -0
  962. data/public/lookbook-assets/css/themes/indigo.css.map +1 -1
  963. data/public/lookbook-assets/css/themes/rose.css +3 -0
  964. data/public/lookbook-assets/css/themes/rose.css.map +1 -1
  965. data/public/lookbook-assets/css/themes/zinc.css +3 -0
  966. data/public/lookbook-assets/css/themes/zinc.css.map +1 -1
  967. data/public/lookbook-assets/js/index.js +38 -38
  968. data/public/lookbook-assets/js/index.js.map +1 -1
  969. metadata +943 -2
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><polygon points="7.86 2 16.14 2 22 7.86 22 16.14 16.14 22 7.86 22 2 16.14 2 7.86 7.86 2"/><line x1="15" y1="9" x2="9" y2="15"/><line x1="9" y1="9" x2="15" y2="15"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><rect x="3" y="3" width="18" height="18" rx="2" ry="2"/><line x1="9" y1="9" x2="15" y2="15"/><line x1="15" y1="9" x2="9" y2="15"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><line x1="18" y1="6" x2="6" y2="18"/><line x1="6" y1="6" x2="18" y2="18"/></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 19c-2.3 0-6.4-.2-8.1-.6-.7-.2-1.2-.7-1.4-1.4-.3-1.1-.5-3.4-.5-5s.2-3.9.5-5c.2-.7.7-1.2 1.4-1.4C5.6 5.2 9.7 5 12 5s6.4.2 8.1.6c.7.2 1.2.7 1.4 1.4.3 1.1.5 3.4.5 5s-.2 3.9-.5 5c-.2.7-.7 1.2-1.4 1.4-1.7.4-5.8.6-8.1.6 0 0 0 0 0 0z"/><polygon points="10 15 15 12 10 9"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><polyline points="12.41 6.75 13 2 10.57 4.92"/><polyline points="18.57 12.91 21 10 15.66 10"/><polyline points="8 8 3 14 12 14 11 22 16 16"/><line x1="2" y1="2" x2="22" y2="22"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><polygon points="13 2 3 14 12 14 11 22 21 10 12 10 13 2"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><circle cx="11" cy="11" r="8"/><line x1="21" y1="21" x2="16.65" y2="16.65"/><line x1="11" y1="8" x2="11" y2="14"/><line x1="8" y1="11" x2="14" y2="11"/></svg>
@@ -0,0 +1 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24"><circle cx="11" cy="11" r="8"/><line x1="21" y1="21" x2="16.65" y2="16.65"/><line x1="8" y1="11" x2="14" y2="11"/></svg>
@@ -0,0 +1 @@
1
+ <svg viewBox='0 0 167 204' xmlns='http://www.w3.org/2000/svg'><g fill='#FFF' fill-rule='nonzero'><path d='M157 0c5.523 0 10 4.477 10 10v184c0 5.523-4.477 10-10 10H32.969C17 204 3.687 192.638.65 177.554A9.97 9.97 0 0 1 0 174c0-.512.011-1.017.033-1.516A33.115 33.115 0 0 1 0 171V33C0 14.778 14.758 0 32.969 0H157Zm-10 166H32.969c-8.292 0-12.22 2.22-12.871 6.606.79 6.424 6.253 11.394 12.87 11.394H147v-18Zm0-146H32.969c-7.056 0-12.8 5.65-12.965 12.689L20 33v114.762c3.932-1.167 8.3-1.762 12.969-1.762H147V20Z'/><path d='M64.022 126c-4.107 0-7.304-1.143-9.591-3.428-2.287-2.285-3.431-5.48-3.431-9.583l.14-63.978c0-4.197 1.12-7.415 3.36-9.653C56.74 37.119 59.916 36 64.023 36c4.2 0 7.398 1.12 9.592 3.358 2.193 2.238 3.29 5.456 3.29 9.653l-.14 55.584h34.166c3.547 0 6.277.91 8.19 2.728 1.915 1.819 2.871 4.454 2.871 7.905 0 3.45-.956 6.109-2.87 7.974-1.914 1.865-4.644 2.798-8.191 2.798H64.022Z'/></g></svg>
@@ -0,0 +1 @@
1
+ <svg viewBox='0 0 167 204' xmlns='http://www.w3.org/2000/svg'><g fill='#222222' fill-rule='nonzero'><path d='M157 0c5.523 0 10 4.477 10 10v184c0 5.523-4.477 10-10 10H32.969C17 204 3.687 192.638.65 177.554A9.97 9.97 0 0 1 0 174c0-.512.011-1.017.033-1.516A33.115 33.115 0 0 1 0 171V33C0 14.778 14.758 0 32.969 0H157Zm-10 166H32.969c-8.292 0-12.22 2.22-12.871 6.606.79 6.424 6.253 11.394 12.87 11.394H147v-18Zm0-146H32.969c-7.056 0-12.8 5.65-12.965 12.689L20 33v114.762c3.932-1.167 8.3-1.762 12.969-1.762H147V20Z'/><path d='M64.022 126c-4.107 0-7.304-1.143-9.591-3.428-2.287-2.285-3.431-5.48-3.431-9.583l.14-63.978c0-4.197 1.12-7.415 3.36-9.653C56.74 37.119 59.916 36 64.023 36c4.2 0 7.398 1.12 9.592 3.358 2.193 2.238 3.29 5.456 3.29 9.653l-.14 55.584h34.166c3.547 0 6.277.91 8.19 2.728 1.915 1.819 2.871 4.454 2.871 7.905 0 3.45-.956 6.109-2.87 7.974-1.914 1.865-4.644 2.798-8.191 2.798H64.022Z'/></g></svg>
data/assets/js/app.js ADDED
@@ -0,0 +1,112 @@
1
+ import createSocket from "./lib/socket";
2
+ import { morph } from "./helpers/dom";
3
+ import { fetchHTML } from "./helpers/request";
4
+ import { isExternalLink } from "./helpers/dom";
5
+
6
+ export default function app() {
7
+ return {
8
+ _requestsInProgress: 0,
9
+
10
+ version: Alpine.$persist("").as("lookbook-version"),
11
+
12
+ location: window.location,
13
+
14
+ get sidebarHidden() {
15
+ return this.$store.layout.sidebar.hidden;
16
+ },
17
+
18
+ get loading() {
19
+ return this._requestsInProgress > 0;
20
+ },
21
+
22
+ init() {
23
+ if (window.SOCKET_PATH) {
24
+ this.debug(`Lookbook socket created`);
25
+ const socket = createSocket(window.SOCKET_PATH);
26
+ socket.addListener("Lookbook::ReloadChannel", () => this.updateDOM());
27
+ }
28
+ },
29
+
30
+ navigateTo(path) {
31
+ this.debug(`Navigating to ${path}`);
32
+ history.pushState({}, null, path);
33
+ this.$dispatch("popstate");
34
+ },
35
+
36
+ async handleNavigation() {
37
+ this.debug("Navigating to ", window.location.pathname);
38
+ this.$dispatch("navigation:start");
39
+ this.location = window.location;
40
+ await this.updateDOM();
41
+ this.$dispatch("navigation:complete");
42
+ },
43
+
44
+ hijax(evt) {
45
+ const link = evt.target.closest("a[href]");
46
+ if (link) {
47
+ const external = isExternalLink(link);
48
+ const embedded = this.isEmbedded();
49
+
50
+ if (embedded && (!link.hasAttribute("target") || external)) {
51
+ evt.preventDefault();
52
+ window.top.location = link.href;
53
+ return;
54
+ } else if (!embedded && !external && !link.hasAttribute("target")) {
55
+ evt.preventDefault();
56
+ this.navigateTo(link.href);
57
+ return;
58
+ }
59
+ }
60
+ },
61
+
62
+ async updateDOM() {
63
+ this.debug("Starting DOM update");
64
+ this.$dispatch("dom:update-start");
65
+ this.requestStart();
66
+ try {
67
+ const { fragment, title } = await fetchHTML(
68
+ window.location,
69
+ `#${this.$root.id}`
70
+ );
71
+ morph(this.$root, fragment);
72
+ document.title = title;
73
+ this.requestEnd();
74
+ this.$dispatch("dom:update-complete");
75
+ this.debug("DOM update complete");
76
+ } catch (err) {
77
+ this.error(err);
78
+ window.location.reload();
79
+ }
80
+ },
81
+
82
+ toggleSidebar() {
83
+ this.$store.layout.sidebar.hidden = !this.$store.layout.sidebar.hidden;
84
+ },
85
+
86
+ closeMobileSidebar() {
87
+ if (this.$store.layout.mobile && !this.sidebarHidden) {
88
+ this.toggleSidebar();
89
+ }
90
+ },
91
+
92
+ requestStart() {
93
+ this._requestsInProgress += 1;
94
+ },
95
+
96
+ requestEnd() {
97
+ if (this._requestsInProgress > 0) {
98
+ this._requestsInProgress -= 1;
99
+ }
100
+ },
101
+
102
+ isEmbedded() {
103
+ try {
104
+ return window.self !== window.top;
105
+ } catch (e) {
106
+ return true;
107
+ }
108
+ },
109
+
110
+ ...Alpine.$log,
111
+ };
112
+ }
@@ -0,0 +1,47 @@
1
+ import { decodeEntities } from "../helpers/string";
2
+
3
+ function initClipboard(context = {}) {
4
+ let copyTimeout = null;
5
+
6
+ return Object.assign(context, {
7
+ copied: false,
8
+
9
+ async copyToClipboard(target = null) {
10
+ let targetEl;
11
+ if (this.$refs.copyTarget) {
12
+ targetEl = this.$refs.copyTarget;
13
+ } else if (typeof target === "string") {
14
+ targetEl = document.querySelector(target);
15
+ }
16
+
17
+ if (!targetEl) {
18
+ this.warn("Could not find copy target");
19
+ return false;
20
+ }
21
+
22
+ const content = decodeEntities(targetEl.innerHTML.trim());
23
+
24
+ await window.navigator.clipboard.writeText(content);
25
+ this.copied = true;
26
+
27
+ if (copyTimeout) {
28
+ clearTimeout(copyTimeout);
29
+ }
30
+
31
+ copyTimeout = setTimeout(() => {
32
+ this.copied = false;
33
+ this.onCopyComplete();
34
+ }, 1000);
35
+
36
+ return content;
37
+ },
38
+
39
+ onCopyComplete() {},
40
+ });
41
+ }
42
+
43
+ export default function clipboardComponent() {
44
+ return initClipboard({});
45
+ }
46
+
47
+ export { initClipboard };
@@ -0,0 +1,23 @@
1
+ export default function paramsInputComponent({ name, value }) {
2
+ return {
3
+ name,
4
+ value,
5
+
6
+ init() {
7
+ this.$watch("value", () => this.update());
8
+ },
9
+
10
+ update() {
11
+ if (this.validate()) {
12
+ const searchParams = new URLSearchParams(window.location.search);
13
+ searchParams.set(this.name, this.value);
14
+ const path = location.href.replace(location.search, "");
15
+ this.navigateTo(`${path}?${searchParams.toString()}`);
16
+ }
17
+ },
18
+
19
+ validate() {
20
+ return this.$root.reportValidity ? this.$root.reportValidity() : true;
21
+ },
22
+ };
23
+ }
@@ -0,0 +1,30 @@
1
+ import tippy from "../lib/tippy";
2
+
3
+ function tooltipCreator({ target }) {
4
+ const content =
5
+ this.$el.dataset.tooltipText ||
6
+ (this.$refs.tooltip ? this.$refs.tooltip.innerHTML : null);
7
+ if (content) {
8
+ return tippy(target || this.$refs.tooltipTarget || this.$el, {
9
+ delay: [200, 0],
10
+ content,
11
+ theme: "tooltip",
12
+ triggerTarget: this.$el,
13
+ onShow: () => this.$store.settings.showTooltips,
14
+ });
15
+ }
16
+ }
17
+
18
+ function initTooltip(context, opts) {
19
+ return tooltipCreator.bind(context)(opts || {});
20
+ }
21
+
22
+ export default function tooltipComponent() {
23
+ return {
24
+ init() {
25
+ initTooltip(this);
26
+ },
27
+ };
28
+ }
29
+
30
+ export { initTooltip };
@@ -0,0 +1,24 @@
1
+ export default {
2
+ desktopWidth: 768,
3
+ wideDesktopWidth: 1200,
4
+ sidebar: {
5
+ defaultWidth: 280,
6
+ minWidth: 200,
7
+ minSectionHeight: 200,
8
+ },
9
+ main: {
10
+ minWidth: 200,
11
+ },
12
+ inspector: {
13
+ drawer: {
14
+ defaultHeight: 300,
15
+ defaultWidth: 500,
16
+ minWidth: 350,
17
+ minHeight: 200,
18
+ },
19
+ preview: {
20
+ minHeight: 200,
21
+ minWidth: 200,
22
+ },
23
+ },
24
+ };
@@ -0,0 +1,22 @@
1
+ function getComponents(importObject, path = []) {
2
+ let components = {};
3
+ Object.keys(importObject).forEach((key) => {
4
+ if (key === "default") {
5
+ components[toCamel(path.join("_"))] = importObject[key];
6
+ } else {
7
+ components = {
8
+ ...components,
9
+ ...getComponents(importObject[key], [...path, key]),
10
+ };
11
+ }
12
+ });
13
+ return components;
14
+ }
15
+
16
+ function toCamel(s) {
17
+ return s.replace(/([-_][a-z])/gi, ($1) => {
18
+ return $1.toUpperCase().replace("-", "").replace("_", "");
19
+ });
20
+ }
21
+
22
+ export { getComponents };
@@ -0,0 +1,42 @@
1
+ function morph(from, to) {
2
+ Alpine.morph(from, to, {
3
+ key(el) {
4
+ return el.getAttribute("key") ? el.getAttribute("key") : el.id;
5
+ },
6
+ lookahead: true,
7
+ updating(el, toEl, childrenOnly, skip) {
8
+ if (!el.getAttribute) return;
9
+ if (el.getAttribute("data-morph-strategy") === "replace") {
10
+ el.innerHTML = toEl.innerHTML;
11
+ return skip();
12
+ } else if (el.getAttribute("data-morph-strategy") === "skip") {
13
+ return skip();
14
+ }
15
+ },
16
+ });
17
+ }
18
+
19
+ function getElementSize(el, opts = {}) {
20
+ const style = window.getComputedStyle(el, null);
21
+ return {
22
+ width: opts.includeMargins
23
+ ? el.offsetWidth +
24
+ parseInt(style.getPropertyValue("margin-left")) +
25
+ parseInt(style.getPropertyValue("margin-right"))
26
+ : el.offsetWidth,
27
+ height: opts.includeMargins
28
+ ? el.offsetHeight +
29
+ parseInt(style.getPropertyValue("margin-top")) +
30
+ parseInt(style.getPropertyValue("margin-bottom"))
31
+ : el.offsetHeight,
32
+ };
33
+ }
34
+
35
+ function isExternalLink(link) {
36
+ if (link.href) {
37
+ return link.host !== window.location.host;
38
+ }
39
+ return false;
40
+ }
41
+
42
+ export { morph, getElementSize, isExternalLink };
@@ -0,0 +1,21 @@
1
+ function addMediaQueryListener(condition, callback) {
2
+ const mediaQueryList = window.matchMedia(condition);
3
+ const handleChange = (mql) => callback(mql.matches);
4
+ handleChange(mediaQueryList);
5
+ mediaQueryList.addEventListener("change", (mql) => handleChange(mql));
6
+ return mediaQueryList;
7
+ }
8
+
9
+ function observeSize(element, callback = () => {}) {
10
+ const observer = new ResizeObserver((entries) => {
11
+ const rect = entries[0].target.getBoundingClientRect();
12
+ callback({
13
+ width: Math.round(rect.width),
14
+ height: Math.round(rect.height),
15
+ });
16
+ });
17
+ observer.observe(element);
18
+ return observer;
19
+ }
20
+
21
+ export { addMediaQueryListener, observeSize };
@@ -0,0 +1,14 @@
1
+ async function fetchHTML(url, selector) {
2
+ const response = await fetch(url || window.document.location);
3
+ const html = await response.text();
4
+ const doc = new DOMParser().parseFromString(html, "text/html");
5
+ return {
6
+ ok: response.ok,
7
+ fragment: selector ? doc.querySelector(selector).outerHTML : null,
8
+ title: doc.title,
9
+ response,
10
+ doc,
11
+ };
12
+ }
13
+
14
+ export { fetchHTML };
@@ -0,0 +1,26 @@
1
+ function decodeEntities(content) {
2
+ var txt = document.createElement("textarea");
3
+ txt.innerHTML = content;
4
+ return txt.value;
5
+ }
6
+
7
+ function prefixString(string, prefix = null) {
8
+ return prefix ? `${prefix}-${string}` : string;
9
+ }
10
+
11
+ function parseSearchParamValue(value) {
12
+ const json = decodeURIComponent(value);
13
+ return JSON.parse(json);
14
+ }
15
+
16
+ function buildSearchParamValue(data) {
17
+ const str = JSON.stringify(data);
18
+ return encodeURIComponent(str);
19
+ }
20
+
21
+ export {
22
+ prefixString,
23
+ decodeEntities,
24
+ parseSearchParamValue,
25
+ buildSearchParamValue,
26
+ };
@@ -0,0 +1 @@
1
+ import "iframe-resizer/js/iframeResizer.contentWindow";
@@ -0,0 +1,61 @@
1
+ import Alpine from "alpinejs";
2
+
3
+ import Morph from "@alpinejs/morph";
4
+ import Persist from "@alpinejs/persist";
5
+ import Collapse from "@alpinejs/morph";
6
+ import Tooltip from "@ryangjchandler/alpine-tooltip";
7
+
8
+ import Logger, { log } from "./plugins/logger";
9
+
10
+ import initLayoutStore from "./stores/layout";
11
+ import initNavStore from "./stores/nav";
12
+ import initInspectorStore from "./stores/inspector";
13
+ import initPagesStore from "./stores/pages";
14
+ import initSettingsStore from "./stores/settings";
15
+ import initWorkbenchStore from "./stores/workbench";
16
+
17
+ import app from "./app";
18
+
19
+ // Note: A ParcelJS issue prevents loading all depths of component JS files in one glob,
20
+ // so need to split it up. Path aliases also do not work with the glob imports.
21
+ import { getComponents } from "./helpers/build";
22
+ import * as components from "../../app/components/lookbook/*/*component.js";
23
+ import * as subComponents from "../../app/components/lookbook/*/*/component.js";
24
+ import * as jsComponents from "./components/*.js";
25
+
26
+ // Plugins
27
+
28
+ Alpine.plugin(Morph);
29
+ Alpine.plugin(Persist);
30
+ Alpine.plugin(Collapse);
31
+ Alpine.plugin(Tooltip);
32
+ Alpine.plugin(Logger);
33
+
34
+ // Stores
35
+ const prefix = window.APP_NAME;
36
+ Alpine.store("layout", initLayoutStore(Alpine, { prefix }));
37
+ Alpine.store("nav", initNavStore(Alpine, { prefix }));
38
+ Alpine.store("inspector", initInspectorStore(Alpine, { prefix }));
39
+ Alpine.store("pages", initPagesStore(Alpine, { prefix }));
40
+ Alpine.store("settings", initSettingsStore(Alpine, { prefix }));
41
+
42
+ if (process.env.NODE_ENV !== "production") {
43
+ Alpine.store("workbench", initWorkbenchStore(Alpine, { prefix }));
44
+ }
45
+
46
+ // Components
47
+
48
+ Alpine.data("app", app);
49
+
50
+ [components, subComponents, jsComponents].forEach((scripts) => {
51
+ const components = getComponents(scripts);
52
+ Object.keys(components).forEach((name) => {
53
+ Alpine.data(`${name}Component`, components[name]);
54
+ });
55
+ });
56
+
57
+ // Init
58
+
59
+ window.log = log;
60
+ window.Alpine = Alpine;
61
+ Alpine.start();
@@ -0,0 +1,123 @@
1
+ window.Lookbook = window.Lookbook || {};
2
+ window.Lookbook.initEmbeds = initEmbeds;
3
+
4
+ const embedUrlPrefix = "embed";
5
+ const whiteListedAttributes = [
6
+ "preview",
7
+ "scenario",
8
+ "panels",
9
+ "actions",
10
+ "param-*",
11
+ ];
12
+
13
+ function initEmbeds(root = document) {
14
+ if (typeof window.iFrameResize !== "function") {
15
+ console.error(
16
+ "Lookbook embeds require the 'iframe-resizer' library to be available. Skipping embed instantiation."
17
+ );
18
+ return;
19
+ }
20
+
21
+ if (typeof root === "string") {
22
+ root = document.querySelector(root);
23
+ }
24
+
25
+ if (!root) {
26
+ return console.error(
27
+ "Could not initialize Lookbook embeds. Root node not found."
28
+ );
29
+ }
30
+
31
+ const embeds = Array.from(root.querySelectorAll("lookbook-embed"));
32
+
33
+ embeds.forEach((embed) => {
34
+ const attrs = Array.from(embed.attributes);
35
+ const wrapper = createWrapper();
36
+ const iframe = createIframe(attrs);
37
+
38
+ wrapper.appendChild(iframe);
39
+ embed.replaceWith(wrapper);
40
+ });
41
+
42
+ window.iFrameResize({ checkOrigin: false }, "[data-lookbook-embed-iframe]");
43
+ }
44
+
45
+ function createWrapper() {
46
+ const wrapper = document.createElement("div");
47
+
48
+ wrapper.setAttribute("data-lookbook-embed", "");
49
+ wrapper.classList.add("lookbook-embed");
50
+
51
+ return wrapper;
52
+ }
53
+
54
+ function createIframe(attrs) {
55
+ const src = buildSrc(attrs);
56
+ const id = attrValue(attrs, "id");
57
+ const styles = attrValue(attrs, "style");
58
+ const classes = attrValue(attrs, "class", "")
59
+ .split(" ")
60
+ .map((c) => c.trim())
61
+ .filter((c) => c.length);
62
+
63
+ const iframe = document.createElement("iframe");
64
+ iframe.src = src;
65
+ if (id) iframe.id = id;
66
+
67
+ iframe.setAttribute("frameborder", 0);
68
+ iframe.setAttribute("data-lookbook-embed-iframe", "");
69
+
70
+ if (classes.length) iframe.classList.add(...classes);
71
+ if (styles) iframe.style.cssText = styles;
72
+
73
+ iframe.style.width = "100%";
74
+ iframe.style.transition = "height 0.3s";
75
+
76
+ return iframe;
77
+ }
78
+
79
+ function buildSrc(attrs) {
80
+ const appPath = attrValue(attrs, "app") || guessBasePath();
81
+ const props = {};
82
+
83
+ permittedAttrs(attrs).forEach(({ name, value }) => {
84
+ name = name.replace("-", "_").toLowerCase();
85
+ props[name] = value;
86
+ });
87
+
88
+ return encodeURI(
89
+ [appPath, embedUrlPrefix].join("/") + `?props=${JSON.stringify(props)}`
90
+ );
91
+ }
92
+
93
+ function attrValue(attrs, name, fallback = null) {
94
+ const attr = attrs.find((attr) => attr.name === name);
95
+ return attr ? attr.value : fallback;
96
+ }
97
+
98
+ function permittedAttrs(attrs) {
99
+ return attrs.filter((attr) => {
100
+ return whiteListedAttributes.find((key) => {
101
+ const name = attr.name;
102
+ return (
103
+ key === name ||
104
+ (key.includes("*") && name.startsWith(key.replace("*", "")))
105
+ );
106
+ });
107
+ });
108
+ }
109
+
110
+ function guessBasePath() {
111
+ const script =
112
+ document.currentScript ||
113
+ document.querySelector('script[src*="lookbook.js"]');
114
+ const scriptSrc = script.src;
115
+
116
+ if (scriptSrc && scriptSrc.includes("lookbook-assets")) {
117
+ return scriptSrc.replace("lookbook-assets/js/lookbook.js", "lookbook");
118
+ }
119
+
120
+ return `//${location.host}/lookbook`;
121
+ }
122
+
123
+ document.addEventListener("DOMContentLoaded", () => initEmbeds());
@@ -0,0 +1,28 @@
1
+ import { createConsumer } from "@rails/actioncable";
2
+ import { debounce } from "throttle-debounce";
3
+ import { log } from "../plugins/logger";
4
+
5
+ export default function socket(endpoint) {
6
+ const uid = (Date.now() + ((Math.random() * 100) | 0)).toString();
7
+ const consumer = createConsumer(`${endpoint}?uid=${uid}`);
8
+ return {
9
+ addListener(channel, callback) {
10
+ consumer.subscriptions.create(channel, {
11
+ received: debounce(
12
+ 200,
13
+ (data) => {
14
+ log.debug("Lookbook files changed");
15
+ callback(data);
16
+ },
17
+ { atBegin: true }
18
+ ),
19
+ connected() {
20
+ log.info("Lookbook websocket connected");
21
+ },
22
+ disconnected() {
23
+ log.info("Lookbook websocket disconnected");
24
+ },
25
+ });
26
+ },
27
+ };
28
+ }
@@ -0,0 +1,9 @@
1
+ import tippy from "tippy.js";
2
+
3
+ tippy.setDefaultProps({
4
+ allowHTML: true,
5
+ theme: "tooltip",
6
+ appendTo: document.getElementById("app"),
7
+ });
8
+
9
+ export default tippy;
@@ -0,0 +1 @@
1
+ import "./lib/lookbook";
@@ -0,0 +1,2 @@
1
+ import "iframe-resizer/js/iframeResizer";
2
+ import "./lib/lookbook";