Skip to content

Commit dcaa121

Browse files
committed
Button Image Styles
1 parent f378872 commit dcaa121

33 files changed

+47
-19
lines changed

README.md

+15-1
Original file line numberDiff line numberDiff line change
@@ -28,4 +28,18 @@ To execute wallaby tests run:
2828
mix test --only wallaby
2929
```
3030

31-
For example, we have a `/screenshots` folder with screenshots of every page at different screen sizes in order to ensure consistent responsive styles across devices.
31+
For example, we have a `/screenshots` folder with screenshots of every page at different screen sizes in order to ensure consistent responsive styles across devices.
32+
33+
## Webp Conversion
34+
35+
We use .webp images for performance optimization. We can convert an image to .web using the webp library
36+
37+
```
38+
$ sudo apt install webp
39+
```
40+
41+
Then simply convert the image.
42+
43+
```elixir
44+
$ cwebp -q 60 my_image.png -o my_image.webp
45+
```

lib/elixir_newbie_web/live/home_live.ex

+32-18
Original file line numberDiff line numberDiff line change
@@ -12,29 +12,38 @@ defmodule ElixirNewbieWeb.HomeLive do
1212

1313
def render(assigns) do
1414
~H"""
15-
<section class="bg-[url('/images/background-smoke-transparent.webp')] flex-col h-screen min-h-screen bg-black bg-no-repeat bg-cover">
15+
<%!-- without overflow hidden the page sometimes provides a scrollbar due to animations --%>
16+
<section class="bg-[url('/images/HomeBackground.webp')] flex-col h-screen min-h-screen bg-black bg-no-repeat bg-cover overflow-hidden">
1617
<.navigation/>
1718
<section class="mx-auto flex w-full flex-col gap-12 4k:mt-36 4k:w-1/2 4k:gap-36 sm:w-full md:w-3/4 lg:w-full lg:flex-row xl:w-3/4 xl:gap-24">
1819
<article class="grid h-fit w-full grid-cols-6 grid-rows-6">
19-
<img
20-
class="aspect-square relative col-start-1 col-end-6 row-start-1 row-end-6 rounded-full border-t-4 border-l-4 border-white"
21-
alt="home page icon of a wizard"
22-
src="images/home_page_icon_reduced.webp"
23-
/>
20+
<.link target="_blank" navigate="https://dockyard.com/blog/2022/07/26/what-to-expect-from-the-dockyard-academy-q-a-with-instructor-brooklin-myers" class={"aspect-square relative col-start-1 col-end-6 row-start-1 row-end-6 rounded-full border-t-4 border-l-4 border-white overflow-hidden"}>
21+
<p class={[
22+
"text-center flex items-center justify-center absolute h-full w-full text-white text-2xl",
23+
"transition ease-in-out duration-300 opacity-0 hover:cursor-pointer hover:bg-black/50 hover:opacity-100"
24+
]}>
25+
Brooklin Myers
26+
</p>
27+
<img
28+
class="h-full w-full"
29+
alt="home page icon of a wizard"
30+
src="images/HomeWizard.webp"
31+
/>
32+
</.link>
2433
<%= if @ready_for_animations do %>
25-
<.round_link link={"https://discord.gg/XBAAmuZGXU"} position={"row-start-5 col-start-2 relative right-2 top-1/3"} logo={"images/discord_icon.png"}>Join our Discord</.round_link>
26-
<.round_link link={"https://twitter.com/BrooklinJMyers"} position={"row-start-3 col-start-5 relative left-1/2 bottom-1/3"} logo={"images/twitter_icon_reduced.webp"}>Twitter</.round_link>
27-
<.round_link link={"https://github.com/BrooklinJazz"} position={"relative col-start-5 relative left-1/3 sm:left-1/4 row-start-4"} logo={"images/github_icon_reduced.webp"}>GitHub</.round_link>
28-
<.round_link link={"https://www.linkedin.com/in/brooklinmyers/"} position={"row-start-5 col-start-4 relative left-1/2"} logo={"images/linkedin_icon_reduced.webp"}>Linkedin</.round_link>
29-
<.round_link link={"https://github.com/DockYard-Academy/beta_curriculum"} position={"row-start-5 col-start-3 relative left-1/4 top-1/2"} logo={"images/dockyard_academy_icon_reduced.webp"}>Dockyard Academy</.round_link>
34+
<.round_link link={"https://discord.gg/XBAAmuZGXU"} position={"row-start-5 col-start-2 relative right-2 top-1/3"} logo={"images/DiscordIcon.webp"}>Join our Discord</.round_link>
35+
<.round_link link={"https://twitter.com/BrooklinJMyers"} position={"row-start-3 col-start-5 relative left-1/2 bottom-1/3"} logo={"images/TwitterIcon.webp"}>Twitter</.round_link>
36+
<.round_link link={"https://github.com/BrooklinJazz"} position={"relative col-start-5 relative left-1/3 sm:left-1/4 row-start-4"} logo={"images/GitHubIcon.webp"}>GitHub</.round_link>
37+
<.round_link link={"https://www.linkedin.com/in/brooklinmyers/"} position={"row-start-5 col-start-4 relative left-1/2"} logo={"images/LinkedinIcon.webp"}>Linkedin</.round_link>
38+
<.round_link link={"https://github.com/DockYard-Academy/beta_curriculum"} position={"row-start-5 col-start-3 relative left-1/4 top-1/2"} logo={"images/DockYardAcademyIcon.webp"}>Dockyard Academy</.round_link>
3039
<% end %>
3140
</article>
3241
<article class="flex w-full flex-col text-2xl text-white 4k:text-4xl lg:text-2xl">
3342
<h1>Greetings, traveler, My name is Brooklin. I am here to teach you Elixir. Where should we start?</h1>
34-
<.rectangle_link navigate={~p"/blog"} src="images/blog_button_reduced.webp" alt="Magic Psychedelic Books">1. Read the Blog</.rectangle_link>
35-
<.rectangle_link navigate={~p"/podcast"} src="images/podcast_button_reduced.webp" alt="Avatar-like half face">2. Listen to the Podcast</.rectangle_link>
36-
<.rectangle_link navigate={~p"/resources"} src="images/resources_button_reduced.webp" alt="Fantasy Mushroom Forest">3. Explore Learning Resources</.rectangle_link>
37-
<.rectangle_link navigate={~p"/community"} src="images/resources_button_community.png" alt="Fantasy Mushroom Forest">4. Join The Community</.rectangle_link>
43+
<.rectangle_link navigate={~p"/blog"} src="images/BlogButton.webp" alt="Fantasy Book Shelf">1. Read the Blog</.rectangle_link>
44+
<.rectangle_link navigate={~p"/podcast"} src="images/PodcastButton.webp" alt="Fantasy Face In Flowers">2. Listen to the Podcast</.rectangle_link>
45+
<.rectangle_link navigate={~p"/resources"} src="images/ResourcesButton.webp" alt="Fantasy Mushroom Forest">3. Explore Learning Resources</.rectangle_link>
46+
<.rectangle_link navigate={~p"/community"} src="images/CommunityButton.webp" alt="Fantasy Village">4. Join The Community</.rectangle_link>
3847
</article>
3948
</section>
4049
</section>
@@ -46,11 +55,15 @@ defmodule ElixirNewbieWeb.HomeLive do
4655
<.link
4756
navigate={@navigate}
4857
class={[
49-
"mt-4 xl:mt-8 text-left relative rounded-3xl aspect-[7/1]",
50-
"transition duration-500 ease-in-out ring ring-white hover:ring-offset-2 overflow-hidden"
58+
"mt-4 xl:mt-8 text-left relative rounded-3xl aspect-[7/1] overflow-hidden",
59+
"transition duration-500 ease-in-out ring ring-white hover:ring-offset-2"
5160
]}
5261
>
53-
<h2 class={"absolute flex h-full w-full items-center pl-16"} ><%= render_slot(@inner_block) %></h2>
62+
<h2 class={
63+
[
64+
"absolute flex h-full w-full items-center pl-16",
65+
"transition duration-300 ease-in-out bg-black/30 hover:bg-black/0"
66+
]}><%= render_slot(@inner_block) %></h2>
5467
<img alt={@alt} src={@src} class="w-full rounded-3xl object-cover"/>
5568
</.link>
5669
"""
@@ -61,6 +74,7 @@ defmodule ElixirNewbieWeb.HomeLive do
6174
<.link
6275
href={@link}
6376
class={"#{@position} group animate-fade-in"}
77+
target="_blank"
6478
>
6579
<div class="transition duration-300 ease-in-out group-hover:scale-110">
6680
<div class="animate-spin-slow absolute h-full w-full rounded-full border-l-2 border-cyan-600"/>
File renamed without changes.
-3.12 MB
Binary file not shown.

priv/static/images/CommunityBackgroundImage.png:Zone.Identifier

Whitespace-only changes.
-3.72 MB
Binary file not shown.
-3.14 MB
Binary file not shown.
-3.8 MB
Binary file not shown.
-2.99 MB
Binary file not shown.
462 KB
Loading
24.6 KB
Binary file not shown.

priv/static/images/DiscordIcon.webp

9.98 KB
Binary file not shown.
File renamed without changes.
File renamed without changes.
18 KB
Binary file not shown.
File renamed without changes.

priv/static/images/discord_icon.png

-250 KB
Binary file not shown.
-95 KB
Binary file not shown.

priv/static/images/github_icon.webp

-90.9 KB
Binary file not shown.

priv/static/images/linkedin_icon.webp

-93.6 KB
Binary file not shown.
-110 KB
Binary file not shown.
-2.36 MB
Binary file not shown.

priv/static/images/resources_button_community.png:Zone.Identifier

Whitespace-only changes.
-8.44 KB
Binary file not shown.

priv/static/images/twitter_icon.webp

-91.5 KB
Binary file not shown.

0 commit comments

Comments
 (0)