Files
danbooru/app/helpers/icon_helper.rb
evazion 8841de68ac posts: add adjustable thumbnail sizes (#4932).
Add a menu in the top right of the post index page that lets you select
the thumbnail size.

This menu is currently hidden until the new thumbnails have been generated.

On desktop, there are five thumbnail sizes:

* Small:    150x150 (https://danbooru.donmai.us/posts?size=150)
* Medium:   180x180 (https://danbooru.donmai.us/posts?size=180)
* Large:    225x225 (https://danbooru.donmai.us/posts?size=225)
* Huge:     270x270 (https://danbooru.donmai.us/posts?size=270)
* Gigantic: 360x360 (https://danbooru.donmai.us/posts?size=360)

On mobile, there are four sizes:

* Small:  150x150 / 3 posts per row (https://danbooru.donmai.us/posts?size=150)
* Medium: 180x180 / 2 posts per row (https://danbooru.donmai.us/posts?size=180)
* Large:  225x225 / 2 posts per row (https://danbooru.donmai.us/posts?size=225)
* Huge:   360x360 / 1 posts per row (https://danbooru.donmai.us/posts?size=360)

There are two extra sizes that aren't listed in the menu:

* 225x360 (https://danbooru.donmai.us/posts?size=225w)
* 270x360 (https://danbooru.donmai.us/posts?size=270w)

These sizes are good for tall thumbnails, but not so much for wide
thumbnails. They aren't listed because in practice they're a bit too big.

The 225x225 and 270x270 sizes are really just 360x360 thumbnails scaled
down in HTML. This means 225x225 and 360x360 thumbnails both use the
same amount of bandwidth.

Thumbnail size is currently a per-search option, not a persistent
account-level setting.

This changes the HTML structure of thumbnails somewhat, so this may
break userscripts and custom CSS.
2021-12-04 06:30:29 -06:00

285 lines
9.6 KiB
Ruby

module IconHelper
def icon_tag(icon_class, class: nil, **options)
klass = binding.local_variable_get(:class)
tag.i(class: "icon #{icon_class} #{klass}", **options)
end
def svg_icon_tag(type, path, class: nil, viewbox: "0 0 448 512", **options)
klass = binding.local_variable_get(:class)
tag.svg(class: "icon svg-icon #{type} #{klass}", role: "img", xmlns: "http://www.w3.org/2000/svg", viewBox: viewbox, **options) do
tag.path(fill: "currentColor", d: path)
end
end
def image_icon_tag(filename, class: nil, **options)
klass = binding.local_variable_get(:class)
tag.img(src: "/images/#{filename}", class: "icon #{klass}", **options)
end
# fontawesome.com/icons/arrow-alt-up
def upvote_icon(**options)
svg_icon_tag("upvote-icon", "M272 480h-96c-13.3 0-24-10.7-24-24V256H48.2c-21.4 0-32.1-25.8-17-41L207 39c9.4-9.4 24.6-9.4 34 0l175.8 176c15.1 15.1 4.4 41-17 41H296v200c0 13.3-10.7 24-24 24z", **options)
end
# fontawesome.com/icons/arrow-alt-down
def downvote_icon(**options)
svg_icon_tag("downvote-icon", "M176 32h96c13.3 0 24 10.7 24 24v200h103.8c21.4 0 32.1 25.8 17 41L241 473c-9.4 9.4-24.6 9.4-34 0L31.3 297c-15.1-15.1-4.4-41 17-41H152V56c0-13.3 10.7-24 24-24z", **options)
end
def sticky_icon(**options)
icon_tag("fas fa-thumbtack", **options)
end
def unsticky_icon(**options)
svg_icon_tag("unsticky-icon", "M306.5 186.6l-5.7-42.6H328c13.2 0 24-10.8 24-24V24c0-13.2-10.8-24-24-24H56C42.8 0 32 10.8 32 24v96c0 13.2 10.8 24 24 24h27.2l-5.7 42.6C29.6 219.4 0 270.7 0 328c0 13.2 10.8 24 24 24h144v104c0 .9.1 1.7.4 2.5l16 48c2.4 7.3 12.8 7.3 15.2 0l16-48c.3-.8.4-1.7.4-2.5V352h144c13.2 0 24-10.8 24-24 0-57.3-29.6-108.6-77.5-141.4zM50.5 304c8.3-38.5 35.6-70 71.5-87.8L138 96H80V48h224v48h-58l16 120.2c35.8 17.8 63.2 49.4 71.5 87.8z", **options)
end
def lock_icon(**options)
icon_tag("fas fa-lock", **options)
end
def delete_icon(**options)
icon_tag("fas fa-trash-alt", **options)
end
def undelete_icon(**options)
icon_tag("fas fa-trash-restore-alt", **options)
end
def private_icon(**options)
icon_tag("fas fa-hand-paper", **options)
end
def menu_icon(**options)
icon_tag("fas fa-bars", **options)
end
def close_icon(**options)
icon_tag("fas fa-times", **options)
end
def search_icon(**options)
icon_tag("fas fa-search", **options)
end
def bookmark_icon(**options)
icon_tag("fas fa-bookmark", **options)
end
def empty_heart_icon(**options)
icon_tag("far fa-heart", **options)
end
def solid_heart_icon(**options)
icon_tag("fas fa-heart", **options)
end
def comments_icon(**options)
icon_tag("far fa-comments", **options)
end
def spinner_icon(**options)
icon_tag("fas fa-spinner fa-spin", **options)
end
def external_link_icon(**options)
icon_tag("fas fa-external-link-alt", **options)
end
def checkmark_icon(**options)
icon_tag("fas fa-check-circle", **options)
end
def exclamation_icon(**options)
icon_tag("fas fa-exclamation-triangle", **options)
end
def meh_icon(**options)
icon_tag("far fa-meh", **options)
end
def avatar_icon(**options)
icon_tag("fas fa-user-circle", **options)
end
def medal_icon(**options)
icon_tag("fas fa-medal", **options)
end
def negative_icon(**options)
icon_tag("fas fa-times-circle", **options)
end
def message_icon(**options)
icon_tag("far fa-envelope", **options)
end
def gift_icon(**options)
icon_tag("fas fa-gift", **options)
end
def feedback_icon(**options)
icon_tag("fas fa-file-signature", **options)
end
def promotion_icon(**options)
icon_tag("fas fa-user-plus", **options)
end
def ban_icon(**options)
icon_tag("fas fa-user-slash", **options)
end
def chevron_left_icon(**options)
icon_tag("fas fa-chevron-left", **options)
end
def chevron_right_icon(**options)
icon_tag("fas fa-chevron-right", **options)
end
def ellipsis_icon(**options)
icon_tag("fas fa-ellipsis-h", **options)
end
def edit_icon(**options)
icon_tag("fas fa-edit", **options)
end
def flag_icon(**options)
icon_tag("fas fa-flag", **options)
end
def link_icon(**options)
icon_tag("fas fa-link", **options)
end
def plus_icon(**options)
icon_tag("fas fa-plus", **options)
end
def caret_down_icon(**options)
svg_icon_tag("caret-down-icon", "M310.6 246.6l-127.1 128C176.4 380.9 168.2 384 160 384s-16.38-3.125-22.63-9.375l-127.1-128C.2244 237.5-2.516 223.7 2.438 211.8S19.07 192 32 192h255.1c12.94 0 24.62 7.781 29.58 19.75S319.8 237.5 310.6 246.6z", viewbox: "0 0 320 512", **options)
end
# https://fontawesome.com/v6.0/icons/volume-high
def sound_icon(**options)
svg_icon_tag("sound-icon", "M412.6 182c-10.28-8.334-25.41-6.867-33.75 3.402c-8.406 10.24-6.906 25.35 3.375 33.74C393.5 228.4 400 241.8 400 255.1c0 14.17-6.5 27.59-17.81 36.83c-10.28 8.396-11.78 23.5-3.375 33.74c4.719 5.806 11.62 8.802 18.56 8.802c5.344 0 10.75-1.779 15.19-5.399C435.1 311.5 448 284.6 448 255.1S435.1 200.4 412.6 182zM473.1 108.2c-10.22-8.334-25.34-6.898-33.78 3.34c-8.406 10.24-6.906 25.35 3.344 33.74C476.6 172.1 496 213.3 496 255.1s-19.44 82.1-53.31 110.7c-10.25 8.396-11.75 23.5-3.344 33.74c4.75 5.775 11.62 8.771 18.56 8.771c5.375 0 10.75-1.779 15.22-5.431C518.2 366.9 544 313 544 255.1S518.2 145 473.1 108.2zM534.4 33.4c-10.22-8.334-25.34-6.867-33.78 3.34c-8.406 10.24-6.906 25.35 3.344 33.74C559.9 116.3 592 183.9 592 255.1s-32.09 139.7-88.06 185.5c-10.25 8.396-11.75 23.5-3.344 33.74C505.3 481 512.2 484 519.2 484c5.375 0 10.75-1.779 15.22-5.431C601.5 423.6 640 342.5 640 255.1S601.5 88.34 534.4 33.4zM301.2 34.98c-11.5-5.181-25.01-3.076-34.43 5.29L131.8 160.1H48c-26.51 0-48 21.48-48 47.96v95.92c0 26.48 21.49 47.96 48 47.96h83.84l134.9 119.8C272.7 477 280.3 479.8 288 479.8c4.438 0 8.959-.9314 13.16-2.835C312.7 471.8 320 460.4 320 447.9V64.12C320 51.55 312.7 40.13 301.2 34.98z", viewbox: "0 0 640 512", **options)
end
def globe_icon(**options)
icon_tag("fas fa-globe", **options)
end
def discord_icon(**options)
image_icon_tag("discord-logo.png", **options)
end
def github_icon(**options)
image_icon_tag("github-logo.png", **options)
end
def twitter_icon(**options)
image_icon_tag("twitter-logo.png", **options)
end
def external_site_icon(site_name, **options)
case site_name
when "Amazon"
image_icon_tag("amazon-logo.png", **options)
when "ArtStation"
image_icon_tag("artstation-logo.png", **options)
when "Ask.fm"
image_icon_tag("ask-fm-logo.png", **options)
when "BCY"
image_icon_tag("bcy-logo.png", **options)
when "Booth.pm"
image_icon_tag("booth-pm-logo.png", **options)
when "Circle.ms"
image_icon_tag("circle-ms-logo.png", **options)
when "Deviant Art"
image_icon_tag("deviantart-logo.png", **options)
when "DLSite"
image_icon_tag("dlsite-logo.png", **options)
when "Doujinshi.org"
image_icon_tag("doujinshi-org-logo.png", **options)
when "Erogamescape"
image_icon_tag("erogamescape-logo.png", **options)
when "Facebook"
image_icon_tag("facebook-logo.png", **options)
when "Fantia"
image_icon_tag("fantia-logo.png", **options)
when "FC2"
image_icon_tag("fc2-logo.png", **options)
when "Foundation"
image_icon_tag("foundation-logo.png", **options)
when "Gumroad"
image_icon_tag("gumroad-logo.png", **options)
when "Hentai Foundry"
image_icon_tag("hentai-foundry-logo.png", **options)
when "Instagram"
image_icon_tag("instagram-logo.png", **options)
when "Ko-fi"
image_icon_tag("ko-fi-logo.png", **options)
when "Livedoor"
image_icon_tag("livedoor-logo.png", **options)
when "Lofter"
image_icon_tag("lofter-logo.png", **options)
when "Mangaupdates"
image_icon_tag("mangaupdates-logo.png", **options)
when "Melonbooks"
image_icon_tag("melonbooks-logo.png", **options)
when "Mihuashi"
image_icon_tag("mihuashi-logo.png", **options)
when "Mixi.jp"
image_icon_tag("mixi-jp-logo.png", **options)
when "Nico Seiga"
image_icon_tag("nicoseiga-logo.png", **options)
when "Nijie"
image_icon_tag("nijie-logo.png", **options)
when "Patreon"
image_icon_tag("patreon-logo.png", **options)
when "pawoo.net"
image_icon_tag("pawoo-logo.png", **options)
when "Piapro.jp"
image_icon_tag("piapro-jp-logo.png", **options)
when "Picarto"
image_icon_tag("picarto-logo.png", **options)
when "Pixiv"
image_icon_tag("pixiv-logo.png", **options)
when "Pixiv Fanbox"
image_icon_tag("pixiv-fanbox-logo.png", **options)
when "Pixiv Sketch"
image_icon_tag("pixiv-sketch-logo.png", **options)
when "Plurk"
image_icon_tag("plurk-logo.png", **options)
when "Privatter"
image_icon_tag("privatter-logo.png", **options)
when "Sakura.ne.jp"
image_icon_tag("sakura-ne-jp-logo.png", **options)
when "Stickam"
image_icon_tag("stickam-logo.png", **options)
when "Skeb"
image_icon_tag("skeb-logo.png", **options)
when "Tinami"
image_icon_tag("tinami-logo.png", **options)
when "Tumblr"
image_icon_tag("tumblr-logo.png", **options)
when "Twitter"
image_icon_tag("twitter-logo.png", **options)
when "Toranoana"
image_icon_tag("toranoana-logo.png", **options)
when "Twitch"
image_icon_tag("twitch-logo.png", **options)
when "Weibo"
image_icon_tag("weibo-logo.png", **options)
when "Wikipedia"
image_icon_tag("wikipedia-logo.png", **options)
when "Youtube"
image_icon_tag("youtube-logo.png", **options)
else
globe_icon(**options)
end
end
end