From 03171c509b7e61c0f41061768697784384d5f403 Mon Sep 17 00:00:00 2001 From: Sally McGrath Date: Mon, 27 Mar 2023 10:34:27 +0100 Subject: [PATCH 01/12] add an example project --- index.html | 37 +++++++++++++++++++++++++++++++------ 1 file changed, 31 insertions(+), 6 deletions(-) diff --git a/index.html b/index.html index 7b0d8b5a..b76f5bbc 100644 --- a/index.html +++ b/index.html @@ -59,12 +59,37 @@

My Name

Projects Showcase

-

- Lorem, ipsum dolor sit amet consectetur adipisicing elit. Nulla nisi - excepturi quidem, eum rem doloribus quam aspernatur hic enim eligendi - commodi minima ullam necessitatibus, cumque blanditiis, nihil magni - amet consectetur? -

+

Contact me

From 2b589e7639154274eb4a0eb28807b3a57b316ca1 Mon Sep 17 00:00:00 2001 From: Sally McGrath Date: Mon, 27 Mar 2023 10:35:15 +0100 Subject: [PATCH 02/12] annotated styles for example page - added some interesting links to explain some concepts used here - an example card layout using grid - my standard rules for images --- style.css | 102 +++++++++++++++++++++++++++++++++++++++++++++++++++--- 1 file changed, 98 insertions(+), 4 deletions(-) diff --git a/style.css b/style.css index c911f90c..ec5097cb 100644 --- a/style.css +++ b/style.css @@ -1,4 +1,7 @@ -/* Design tokens */ +/* Design tokens. +With tokens, stick to communicating the PURPOSE not the VALUE. +Code should explain, not mystify, your design. +*/ :root { --paper: hsla(251, 28%, 88%, 0.99); --ink: hsla(244, 16%, 17%, 0.95); @@ -6,8 +9,22 @@ --font: "Raleway", system-ui, sans-serif; --gap: 20px; --container: clamp(280px, calc(100vw - calc(var(--gap) * 2)), 1180px); + /* https://web.dev/accessible-tap-targets/ */ + --tap-target: 48px; + --box: clamp(280px, 50vw + 2px, 530px); } -/* General Styles */ + +/* Hey look, dark mode is +so easy with design tokens done this way +*/ +@media (prefers-color-scheme: dark) { + :root { + --ink: hsla(252, 38%, 92%, 0.99); + --paper: hsla(244, 16%, 17%, 1); + } +} + +/* General styles */ html, body { scroll-behavior: smooth; @@ -34,7 +51,12 @@ a:focus { color: var(--brand); border-color: currentColor; } -/* Site header and navigation */ +p a:any-link { + border-color: var(--brand); +} +/* Site header and navigation +https://elad.medium.com/css-position-sticky-how-it-really-works-54cd01dc2d46 +*/ body > header { background: var(--paper); display: flex; @@ -50,8 +72,80 @@ nav ul { gap: var(--gap); } -/* Text readability */ +/* Text readability +https://baymard.com/blog/line-length-readability +*/ section p { line-height: 1.5; max-width: 55ch; } +/* targeted resets +We're resetting elements with a class - ANY class +- on the grounds that if you added a class, +you added your own styles +*/ +h3[class] { + margin: 0 auto 0 0; +} +ul[class], +li[class] { + margin: 0; + padding: 0; +} + +/* Basic image rules +Don't size images in css, size their containers +Just make images take up the entire space you give them +in every context +*/ +svg { + height: 100%; + width: auto; + min-width: var(--tap-target); +} + +img { + width: 100%; + height: 100%; + max-width: 100%; + object-fit: cover; +} + +picture { + height: auto; + overflow: hidden; +} +/* +I would start breaking this up into component files now btw! +*/ +.showcase { + display: flex; + flex-flow: row wrap; + gap: var(--gap); +} +/* +Here's an example of a grid layout. Notice there's no margin, padding, or sizes given on elements +All the spacing and sizing is set on the template, and the elements +are just slotted in. +The little dots are how we precisely place and size white-space +https://www.interaction-design.org/literature/article/the-power-of-white-space +*/ + +.project { + display: grid; + grid-template: + "picture picture picture" var(--box) + "....... ....... ......." calc(var(--gap) / 2) + "....... heading ......." min-content + "....... blurb ......." auto / + var(--gap) var(--box) var(--gap); +} +.project__picture { + grid-area: picture; +} +.project__heading { + grid-area: heading; +} +.project__blurb { + grid-area: blurb; +} From 23da459d509de0aea16b319ee2e274cea739365d Mon Sep 17 00:00:00 2001 From: Sally McGrath Date: Mon, 27 Mar 2023 10:35:49 +0100 Subject: [PATCH 03/12] A new challenge for module 1 New readme --- README.md | 46 +++++++++++++++++++++++++++++++++++++--------- 1 file changed, 37 insertions(+), 9 deletions(-) diff --git a/README.md b/README.md index 98549832..bbc02378 100644 --- a/README.md +++ b/README.md @@ -1,18 +1,46 @@ # Portfolio -Your starting portfolio, to iterate on. +Module 1 iteration of your portfolio. We've got a lot of new concepts here so you might want to work through this in your study group, or bring to class for help. ## Learning Objectives -- Customise the starting portfolio with your professional details -- Iterate on your portfolio every module -- Review your colleague's portfolio +- [ ] Branch from a branch in Git +- [ ] PR from a branch to a branch in GitHub +- [ ] Create a personal case study for a project ## Requirements -At Code Your Future, we expect everyone to graduate with a unique professional portfolio. Begin building this portfolio as soon as you begin our Software Development Course. At first, your portfolio will be a simple HTML/CSS page deployed to Github Pages or Netlify. This is your MVP. +We are using a different type of pull request workflow from your main coursework. We're doing this because we need lots of practice with Git to be ready to contribute to shared repos like professional developers. In previous years, we only opened PRs to main all the way through the course, and then in Final Projects it was really hard to learn branching and merging. So let's practice a different workflow now. -Every module, you will _iterate_ on your portfolio, adding a new project and improving your design and presentation. By the time you apply to Final Projects, your portfolio will help you show you are ready to be accepted on to a Final Projects team. +## Git Ready: Putting our code in the right place + +The instructions here are given for the command line, but you could just as easily do this in GitHub Desktop or GitKraken. + +1. Switch into the branch called `git checkout Module-HTML-CSS` to access this Readme +1. From `Module-HTML-CSS`, create a new branch `git checkout -b your-name-portfolio` +1. Make a new directory `mkdir your-name-portfolio` +1. Move your starter files into this directory `mv index.html style.css your-name-portfolio` +1. Change into the new directory `cd your-name-portfolio` +1. Check you are in the right branch `git branch --show-current` + +## Git Set: Making changes + +1. Open the project in your code editor +1. Make your changes +1. Check your changes with `git status` +1. Add your files to the staging area `git add index.html style.css` . _Remember, don't `git add .` or you could add files you don't mean to._ +1. Commit your changes often `git commit -m "YOUR COMMIT MESSAGE"` + +Your case study should be a short description of the project, including: the problem it solves, the technologies used, the approach taken, a link to the deployed project, and a link to the code on GitHub. + +Explain the problem and your solution in your own words, and don't just copy and paste the project brief. The point of a portfolio is to make _you stand out_, so write in your own voice. It's fine to choose something that you didn't work on all by yourself, but make sure you explain what part you did. + +## Git Go: Making a pull request + +1. Stage your files: `git add index.html style.css` . _Remember, don't `git add .` or you could add files you don't mean to._ +1. Commit your changes `git commit -m "YOUR COMMIT MESSAGE"` +1. Push your changes to GitHub `git push origin your-name-portfolio` +1. Open a pull request to merge your branch into `Module-HTML-CSS` . If you have the [GitHub CLI](https://cli.github.com/manual/gh_pr_create) installed, you can do this with `gh pr create --base Module-HTML-CSS --head your-name-portfolio`. Otherwise do it in the GitHub UI or your Git client. ## Acceptance Criteria @@ -26,6 +54,6 @@ Every module, you will _iterate_ on your portfolio, adding a new project and imp ## Resources -- [Josh Comeau on building your early career profile](https://www.youtube.com/watch?v=OXiaEXfkAec) -- [How to Build an Effective Dev Portfolio](https://www.joshwcomeau.com/effective-portfolio/) -- [CYF Graduate Module](https://module-graduates.codeyourfuture.io/) +- [Powerful Git Completion with ohmyzsh](https://github.com/ohmyzsh/ohmyzsh) +- [GitKraken](https://www.gitkraken.com/) +- [GitLens](https://marketplace.visualstudio.com/items?itemName=eamodio.gitlens/) From 413820e72f14c34efe0fbfbbc3e41610329c3f4a Mon Sep 17 00:00:00 2001 From: Sally McGrath Date: Mon, 27 Mar 2023 10:42:54 +0100 Subject: [PATCH 04/12] move files into dir as per readme --- index.html => example-name-portfolio/index.html | 0 style.css => example-name-portfolio/style.css | 0 2 files changed, 0 insertions(+), 0 deletions(-) rename index.html => example-name-portfolio/index.html (100%) rename style.css => example-name-portfolio/style.css (100%) diff --git a/index.html b/example-name-portfolio/index.html similarity index 100% rename from index.html rename to example-name-portfolio/index.html diff --git a/style.css b/example-name-portfolio/style.css similarity index 100% rename from style.css rename to example-name-portfolio/style.css From 15d60bfc64453b96010aa84d93129763ab708272 Mon Sep 17 00:00:00 2001 From: Sally McGrath Date: Mon, 27 Mar 2023 10:50:33 +0100 Subject: [PATCH 05/12] clarify they may use THIS code Just don't want everyone copypasting the Agency theme like usual --- README.md | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/README.md b/README.md index bbc02378..f6e904ca 100644 --- a/README.md +++ b/README.md @@ -2,6 +2,10 @@ Module 1 iteration of your portfolio. We've got a lot of new concepts here so you might want to work through this in your study group, or bring to class for help. +_Keep your changes simple!_ + +We are using a different type of pull request workflow from your main coursework. We're doing this because we need lots of practice with Git to be ready to contribute to shared repos like professional developers. In previous cohorts, we only opened PRs to main all the way through the course, and then in Final Projects it was really hard to learn real branching and merging. So let's practice a different workflow now. + ## Learning Objectives - [ ] Branch from a branch in Git @@ -10,7 +14,9 @@ Module 1 iteration of your portfolio. We've got a lot of new concepts here so yo ## Requirements -We are using a different type of pull request workflow from your main coursework. We're doing this because we need lots of practice with Git to be ready to contribute to shared repos like professional developers. In previous years, we only opened PRs to main all the way through the course, and then in Final Projects it was really hard to learn branching and merging. So let's practice a different workflow now. +Your case study should be a short description of the project, including: the problem it solves, the technologies used, the approach taken, a link to the deployed project, and a link to the code on GitHub. + +Explain the problem and your solution in your own words, and don't just copy and paste the project brief. The point of a portfolio is to make _you stand out_, so write in your own voice. It's fine to choose something that you didn't work on all by yourself, but make sure you explain what part you did. ## Git Ready: Putting our code in the right place @@ -31,10 +37,6 @@ The instructions here are given for the command line, but you could just as easi 1. Add your files to the staging area `git add index.html style.css` . _Remember, don't `git add .` or you could add files you don't mean to._ 1. Commit your changes often `git commit -m "YOUR COMMIT MESSAGE"` -Your case study should be a short description of the project, including: the problem it solves, the technologies used, the approach taken, a link to the deployed project, and a link to the code on GitHub. - -Explain the problem and your solution in your own words, and don't just copy and paste the project brief. The point of a portfolio is to make _you stand out_, so write in your own voice. It's fine to choose something that you didn't work on all by yourself, but make sure you explain what part you did. - ## Git Go: Making a pull request 1. Stage your files: `git add index.html style.css` . _Remember, don't `git add .` or you could add files you don't mean to._ @@ -45,7 +47,7 @@ Explain the problem and your solution in your own words, and don't just copy and ## Acceptance Criteria - [ ] My portfolio introduces me and my work -- [ ] The design and code is my own, not a template or tutorial +- [ ] The design and code is my own, not a template or tutorial (you can use this code as a starting point) - [ ] Each project is linked to my code on Github and the deployed project - [ ] I have published my professional contact information on my portfolio - [ ] My Accessibility and SEO scores are 100 on Lighthouse From 5876e29ef56fada35c7d526a322bafe270e106d9 Mon Sep 17 00:00:00 2001 From: Barath Vignarajah Date: Sat, 19 Oct 2024 07:23:57 +0100 Subject: [PATCH 06/12] Adding starter files --- index.html | 102 +++++++++++++++++++++++++++++++++++++++++++++++++++++ style.css | 57 ++++++++++++++++++++++++++++++ 2 files changed, 159 insertions(+) create mode 100644 index.html create mode 100644 style.css diff --git a/index.html b/index.html new file mode 100644 index 00000000..7b0d8b5a --- /dev/null +++ b/index.html @@ -0,0 +1,102 @@ + + + + + + My Portfolio + + + + + + + + + + +
+

My Name

+ +
+
+
+

About Me

+

+ Lorem, ipsum dolor sit amet consectetur adipisicing elit. Nulla nisi + excepturi quidem, eum rem doloribus quam aspernatur hic enim eligendi + commodi minima ullam necessitatibus, cumque blanditiis, nihil magni + amet consectetur? +

+
+
+

Projects Showcase

+

+ Lorem, ipsum dolor sit amet consectetur adipisicing elit. Nulla nisi + excepturi quidem, eum rem doloribus quam aspernatur hic enim eligendi + commodi minima ullam necessitatibus, cumque blanditiis, nihil magni + amet consectetur? +

+
+
+

Contact me

+

+ Lorem, ipsum dolor sit amet consectetur adipisicing elit. Nulla nisi + excepturi quidem, eum rem doloribus quam aspernatur hic enim eligendi + commodi minima ullam necessitatibus, cumque blanditiis, nihil magni + amet consectetur? +

+
+
+ + + diff --git a/style.css b/style.css new file mode 100644 index 00000000..c911f90c --- /dev/null +++ b/style.css @@ -0,0 +1,57 @@ +/* Design tokens */ +:root { + --paper: hsla(251, 28%, 88%, 0.99); + --ink: hsla(244, 16%, 17%, 0.95); + --brand: hsla(0, 79%, 63%, 0.9); + --font: "Raleway", system-ui, sans-serif; + --gap: 20px; + --container: clamp(280px, calc(100vw - calc(var(--gap) * 2)), 1180px); +} +/* General Styles */ +html, +body { + scroll-behavior: smooth; + background: var(--paper); + color: var(--ink); + font-family: var(--font); +} +body { + display: grid; + margin: auto; + min-height: 100vh; + gap: var(--gap); + max-width: var(--container); +} +a, +a:any-link { + color: currentColor; + text-decoration: none; + border-bottom: 2px solid transparent; + transition: border-color ease-in-out 0.3s; +} +a:hover, +a:focus { + color: var(--brand); + border-color: currentColor; +} +/* Site header and navigation */ +body > header { + background: var(--paper); + display: flex; + justify-content: space-between; + align-items: center; + position: sticky; + top: 0; + z-index: 1; +} +nav ul { + display: flex; + list-style: none; + gap: var(--gap); +} + +/* Text readability */ +section p { + line-height: 1.5; + max-width: 55ch; +} From 997341461c201cf0ebbe3c046f8da39ec14ef242 Mon Sep 17 00:00:00 2001 From: Pezhman-Azizi <80008463+Pezhman-Azizi@users.noreply.github.com> Date: Tue, 22 Oct 2024 21:30:38 +0100 Subject: [PATCH 07/12] Add new paragraphs to 'About me', 'Project showcase', and 'Contact me' sections. --- index.html | 33 ++++++++++++++++++++------------- style.css | 6 ++++++ 2 files changed, 26 insertions(+), 13 deletions(-) diff --git a/index.html b/index.html index 7b0d8b5a..69b45a24 100644 --- a/index.html +++ b/index.html @@ -38,7 +38,7 @@
-

My Name

+

Pezhman Azizi

From 517a78d7a23928f885f2a8d73738d6cd8bc60bb5 Mon Sep 17 00:00:00 2001 From: Pezhman-Azizi <80008463+Pezhman-Azizi@users.noreply.github.com> Date: Tue, 22 Oct 2024 23:29:22 +0100 Subject: [PATCH 10/12] =?UTF-8?q?Gave=20the=20buttons=20more=20room=20so?= =?UTF-8?q?=20they=20aren=E2=80=99t=20cramped?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- index.html | 2 +- style.css | 3 +++ 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/index.html b/index.html index e35246ef..b2801cd3 100644 --- a/index.html +++ b/index.html @@ -67,7 +67,7 @@

Pezhman Azizi

Git and Github Fundamentals:
Introduced users to the essential concepts of Git and GitHub, demonstrating their importance as version control tools in professional web development. Utilized form features and the first child pseudo-class to create a user-friendly interface. Successfully addressed layout issues by applying relative positioning to the footer.
- +

diff --git a/style.css b/style.css index 712a1f02..1fc6b037 100644 --- a/style.css +++ b/style.css @@ -110,10 +110,13 @@ button { cursor: pointer; font-weight: bold; transition: background-color 0.3s ease; + box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); + margin: 10px 0; } button:hover { background-color: hsla(0, 79%, 63%, 1); } + /*----------------------------------------------------------- Contact Section */ .contact-me { list-style: none; From d0d61d9d1db26d6e0de5a98fd7c8a051ca44044d Mon Sep 17 00:00:00 2001 From: Pezhman-Azizi <80008463+Pezhman-Azizi@users.noreply.github.com> Date: Wed, 23 Oct 2024 13:00:26 +0100 Subject: [PATCH 11/12] Gave the 'Contact Me' section a fresh, modern look and centered it nicely on the page --- index.html | 2 +- style.css | 49 +++++++++++++++++++++++++++++++++++++++++++++++-- 2 files changed, 48 insertions(+), 3 deletions(-) diff --git a/index.html b/index.html index b2801cd3..a973db8b 100644 --- a/index.html +++ b/index.html @@ -63,7 +63,7 @@

Pezhman Azizi

Kermanshah Website:
Showcase Kermanshah's rich culture, customs, music, and stunning sights. Designed with user-friendly navigation and a responsive layout to ensure accessibility on all devices. Overcame challenges in creating a fully responsive design to provide the best possible user experience.
-
+
Git and Github Fundamentals:
Introduced users to the essential concepts of Git and GitHub, demonstrating their importance as version control tools in professional web development. Utilized form features and the first child pseudo-class to create a user-friendly interface. Successfully addressed layout issues by applying relative positioning to the footer.
diff --git a/style.css b/style.css index 1fc6b037..455aff37 100644 --- a/style.css +++ b/style.css @@ -81,9 +81,54 @@ section p { .contact-me{ list-style: none; + display: flex; + justify-content: center; + gap: var(--gap); + flex-wrap: wrap; /* Ensure responsiveness on smaller screens */ + padding: 2rem; +} + +.contact-me li { + margin: 0.5rem; + background-color: white; + padding: 1rem; + border-radius: 8px; + box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); + transition: transform 0.3s ease, box-shadow 0.3s ease; +} + +.contact-me li:hover { + transform: translateY(-5px); + box-shadow: 0 6px 12px rgba(0, 0, 0, 0.2); } +.contact-me a { + color: var(--ink); + font-weight: bold; + display: flex; + align-items: center; + justify-content: center; + text-align: center; + padding: 0.5rem 1rem; + transition: color 0.3s ease; +} +.contact-me a:hover { + color: var(--brand); +} + +/*------------------------------------------------------------ Contact Icons */ +.contact-me a::before { + content: '📧'; /* Example icon for email */ + margin-right: 8px; + font-size: 1.2rem; +} +.contact-me a[href^="tel"]::before { + content: '📞'; /* Icon for phone */ +} +.contact-me a[href^="https"]::before { + content: '🔗'; /* Icon for LinkedIn */ +} /*------------------------------------------------------------- Project Cards */ #projects { display: grid; @@ -124,7 +169,7 @@ button:hover { .contact-me li { margin: 0.5rem 0; } -/*----------------------------------------------------------- Footer Styling */ +/*------------------------------------------------------------ Footer Styling */ footer { background-color: var(--ink); color: white; @@ -137,7 +182,7 @@ footer a { text-decoration: none; } -/*----------------------------------------------------------- Responsiveness */ +/*------------------------------------------------------------ Responsiveness */ @media (max-width: 768px) { header { flex-direction: column; From e123889f1e0db2629b962d42703138cd2bd69cb6 Mon Sep 17 00:00:00 2001 From: Pezhman-Azizi <80008463+Pezhman-Azizi@users.noreply.github.com> Date: Wed, 23 Oct 2024 13:24:09 +0100 Subject: [PATCH 12/12] updated footer text and added copyright section for a more personalized touch --- style.css | 43 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 43 insertions(+) diff --git a/style.css b/style.css index 455aff37..db7aba9c 100644 --- a/style.css +++ b/style.css @@ -165,10 +165,53 @@ button:hover { /*----------------------------------------------------------- Contact Section */ .contact-me { list-style: none; + display: flex; + justify-content: center; + gap: var(--gap); + flex-wrap: wrap; /* Ensure responsiveness on smaller screens */ + padding: 2rem; } .contact-me li { margin: 0.5rem 0; + background-color: white; + padding: 1rem; + border-radius: 8px; + box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); + transition: transform 0.3s ease, box-shadow 0.3s ease; +} +.contact-me li:hover { + transform: translateY(-5px); + box-shadow: 0 6px 12px rgba(0, 0, 0, 0.2); } + +.contact-me a { + color: var(--ink); + font-weight: bold; + display: flex; + align-items: center; + justify-content: center; + text-align: center; + padding: 0.5rem 1rem; + transition: color 0.3s ease; +} + +.contact-me a:hover { + color: var(--brand); +} + +/*------------------------------------------------------------ Contact Icons */ +.contact-me a::before { + content: '📧'; /* Example icon for email */ + margin-right: 8px; + font-size: 1.2rem; +} +.contact-me a[href^="tel"]::before { + content: '📞'; /* Icon for phone */ +} +.contact-me a[href^="https"]::before { + content: '🔗'; /* Icon for LinkedIn */ +} + /*------------------------------------------------------------ Footer Styling */ footer { background-color: var(--ink);