{"id":15016529,"url":"https://github.com/sb-ph/portfolio-starter","last_synced_at":"2025-07-04T23:04:46.200Z","repository":{"id":51494312,"uuid":"251010035","full_name":"sb-ph/portfolio-starter","owner":"sb-ph","description":"A starter kit for static portfolio sites","archived":false,"fork":false,"pushed_at":"2021-05-11T16:10:00.000Z","size":27258,"stargazers_count":42,"open_issues_count":11,"forks_count":4,"subscribers_count":2,"default_branch":"master","last_synced_at":"2024-10-31T11:51:32.004Z","etag":null,"topics":["11ty","eleventy","netlify","portfolio","website"],"latest_commit_sha":null,"homepage":"https://portfolio-starter.sb-ph.com","language":"HTML","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/sb-ph.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2020-03-29T10:53:50.000Z","updated_at":"2024-06-04T19:33:22.000Z","dependencies_parsed_at":"2022-08-22T01:21:03.597Z","dependency_job_id":null,"html_url":"https://github.com/sb-ph/portfolio-starter","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sb-ph%2Fportfolio-starter","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sb-ph%2Fportfolio-starter/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sb-ph%2Fportfolio-starter/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/sb-ph%2Fportfolio-starter/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/sb-ph","download_url":"https://codeload.github.com/sb-ph/portfolio-starter/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":223510342,"owners_count":17157306,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["11ty","eleventy","netlify","portfolio","website"],"created_at":"2024-09-24T19:49:02.121Z","updated_at":"2024-11-07T12:03:46.620Z","avatar_url":"https://github.com/sb-ph.png","language":"HTML","funding_links":[],"categories":[],"sub_categories":[],"readme":"\u003caside\u003e🚧 WORK IN PROGRESS\u003c/aside\u003e\n\n# ![Portfolio Starter](/content/media/banner.gif)\n\nThis is a lightweight portfolio starterkit built with [Eleventy](https://www.11ty.dev/). It is geared towards designers, illustrators, architects, and any other individuals who are interested in sharing their work and activity.\n\nThe intended user may not know how to code but is interested in the tech behind their website, is willing to write in [Markdown](https://daringfireball.net/projects/markdown/), and is happy to follow along with this documentation.\n\nVisit [portfolio-starter.sb-ph.com](https://portfolio-starter.sb-ph.com/) to check it out. The content and code in this repository drives the demo site.\n\n- [Features](#features)\n- [No-code setup](#no-code-setup)\n  - [1. Get a GitHub account](#1-get-a-github-account)\n  - [2. Get an account with a static hosting provider](#2-get-an-account-with-a-static-hosting-provider)\n  - [3. Deploy your website](#3-deploy-your-website)\n  - [4. Edit content in GitHub](#4-edit-content-in-github)\n- [Command line setup](#command-line-setup)\n  - [1. Set up repo locally and on GitHub](#1-set-up-your-repository)\n  - [2. Build or serve your website](#2-build-or-serve-your-website)\n  - [3. Deploy your website](#3-deploy-your-website)\n  - [4. Edit content locally](#4-edit-content-locally)\n- [Using a custom domain](#using-a-custom-domain)\n- [Updates and backups](#updates-and-backup)\n- [Content reference](#content-reference)\n  - [Global data](#global-data)\n  - [Markdown files and YAML frontmatter](#markdown-files-and-yaml-frontmatter)\n  - [Basic properties](#basic-properties)\n  - [Pages](#pages)\n  - [Posts](#posts)\n  - [Projects](#projects)\n  - [Homepage](#homepage)\n  - [Blog page](#blog-page)\n  - [Error page](#error-page)\n  - [RSS feed](#rss-feed)\n  - [Media](#media)\n- [Altering and extending your site](#altering-and-extending-your-site)\n\n## Features\n\n- Understated design with an eye towards accessibility [TODO]\n- A deliberately basic codebase that encourages tinkering and customisation even for people unfamiliar with code\n- Generates a static site; static sites tend to load a lot faster than database-driven websites and can be hosted for free\n- Supports posts, projects, pages, a one-level menu, and RSS out-of-the-box\n- Command line not required; you don’t have to use a code editor or the command line to edit or even deploy this website\n\n## No-code setup\n\n“No-code” is a _little_ bit of a misnomer. Your content files are technically written in code, but it is a very readable syntax called Markdown (more on this later). What we mean by “no-code” is that you won’t have to touch the command line, Git, or open a code editor on your computer.\n\n### 1. Get a GitHub account\n\nGitHub is a platform that stores code. Your website code and content are going to live on GitHub. If you have an account already, go ahead and log in. If not, [sign up for an account](https://github.com/join). The free individual account is sufficient.\n\n### 2. Get an account with a static hosting provider\n\n[Netlify](https://www.netlify.com/) and [ZEIT](https://zeit.co/) are hosting providers that offer generous free tiers for people with static websites such as this. Netlify is perhaps a _tiny_ bit more straightforward for the following steps and seems to be used by more Eleventy users, but they are both solid platforms. If you have an account with either of these platforms already, log in. If you don’t, sign up for one.\n\n### 3. Deploy your website\n\nBy clicking one of the buttons below, you will clone this repository (i.e. create a duplicate version that lives in your own GitHub account) and then deploy this new website to your static hosting.\n\nBefore proceeding, decide on a name for your repository. It should be something that is similar to the name of your site, but it should only include lowercase letters, numbers, and dashes. For example, the name of this repository is `portfolio-starter`.\n\n**If you have a Netlify account**, click this button and follow Netlify’s simple instructions to connect Netlify and GitHub:\n\n[![Deploy to Netlify](https://www.netlify.com/img/deploy/button.svg)](https://app.netlify.com/start/deploy?repository=https://github.com/sb-ph/portfolio-starter)\n\n**If you have a ZEIT account**, click the button below and then follow Zeit’s instructions:\n\n[![Deploy with ZEIT](https://zeit.co/button)](https://zeit.co/import/project?template=https://github.com/sb-ph/portfolio-starter)\n\nZeit’s instructions will walk you through how to install Zeit Now for GitHub so that it can create a repository for you and can deploy your changes. Give permission to all repositories when installing Zeit Now. Zeit should auto-detect that you are using Eleventy with settings as follows (you don’t need to worry about the development command):\n\nBuild command: `npx @11ty/eleventy`\nOutput directory: `_site`\n\n**When you have finished following the instructions above for Netlify or Zeit**, you will be redirected to your website dashboard. This displays your default subdomain and other important information about your site. You’ll also receive some emails letting you know that the services are connected.\n\nZeit allows you to select the visibility of your repository when you set it up. Netlify, on the other hand, automatically creates a public repository. See the [GitHub documentation](https://help.github.com/en/github/administering-a-repository/setting-repository-visibility) if you want to adjust the visibility of your repository.\n\n### 4. Edit content in GitHub\n\nTo edit or add content without the command line, you need to use GitHub’s interface to navigate your files within the [`/content`](/content) folder in your repository. See the [content reference](#content-reference) to learn more about the structure of the `/content` folder and each of the files within it, particularly the [global data](#global-data) file that includes your website title and URL.\n\nTo edit or delete an existing file, you must open the relevant file in GitHub and then click either the Edit button (the button with the pencil icon) or the Delete button (the button with the bin) in the upper-right corner above the page contents.\n\nIf you want to add a new page, you must navigate to the [`posts`](/content/posts), [`projects`](/content/projects), or [`pages`](/content/pages) folder depending on what you want to add and then click the “Create new file” button near the top of the page. This will open a new editor page where you can add your filename and file contents. Since all text content is written in Markdown, the filename must end in `md` (i.e. `my-post-name.md`).\n\nIf you want to add media, you must navigate to the [`media`](/content/media) folder and then click the “Upload files” button near the top of the page. This will give you an area to upload one or more files. See the [media guidance](#media) for tips on file types and sizes.\n\nTo save edits or additions made in GitHub, you must commit your changes using GitHub’s interface at the base of the page. If you hooked up Netlify or ZEIT in the previous step, a commit will also tell GitHub to automatically deploy your changes. For more on what a commit is, see the [GitHub Glossary](https://help.github.com/en/github/getting-started-with-github/github-glossary). When you commit an edit or an addition directly in GitHub, you can use the default commit message that is pre-filled and should commit directly to the `master` branch (the default setting).\n\n## Command line setup\n\nThe command line setup instructions assume that you have familiarity with the command line, that you have version 8 or higher of Node.js installed on your computer, and that you have a GitHub account.\n\n### 1. Set up your repository\n\nClone repository locally into a named project folder by running `git clone https://github.com/sb-ph/portfolio-starter.git my-website` and then change to the new project folder by running `cd my-website`. Run `npm install` to install the dependencies including Eleventy.\n\nRun `rm -rf .git` to remove the Git history for a fresh start, and then run `git init` to initialise a new git repo. Commit all of your files to create a new `master` branch, and then [add your project to GitHub using the command line](https://help.github.com/en/github/importing-your-projects-to-github/adding-an-existing-project-to-github-using-the-command-line).\n\n### 2. Build or serve your website\n\nTo build the website in to the gitignored `/_site` directory, run `npx @11ty/eleventy`. To spin up a server for local development or content editing, run `npx @11ty/eleventy --serve`. This will make your site available at \u003chttp://localhost:8080\u003e, and the site will automatically reload when you make any changes.\n\n### 3. Deploy your website\n\nIf you want to use Netlify or ZEIT, follow their documentation to get your repository hooked up to your hosting account for continuous deployment. If you want to use another hosting provider, you can find your static files in the `/_site` directory after you generate a build.\n\n### 4. Edit content locally\n\nTo edit content locally, spin up a server by running `npx @11ty/eleventy --serve` and then adjust the Markdown and JSON files within the `/content` directory. If your site is hooked up to continuous deployment, make sure you commit your changes to the right branch (probably `master`) otherwise they will not be deployed.\n\n## Using a custom domain\n\nNetlify and ZEIT give you a default subdomain automatically when you deploy your website, so this is an optional step. If you want to use your own domain, you should follow their instructions to set this up. [Read more about custom domains on ZEIT](https://zeit.co/docs/v2/custom-domains), or [read more about custom domains on Netlify](https://docs.netlify.com/domains-https/custom-domains/).\n\nBoth of these guides will walk you through how to set up your domain’s Domain Name System (DNS). Note that **DNS can be delicate.** The DNS records for your domain tell browsers where to find your website and tell email servers how to direct emails to you. Be sure to write down any existing DNS records before changing anything.\n\nIf you repoint the nameservers as part of the custom domain setup process and are already using your domain for email, you must add your MX records and any other records related to email to your new hosting provider _before_ you repoint the nameservers. If you do not, your email may go down.\n\n## Updates and backups\n\nIf you’re on an older version of Portfolio Starter and want to update it to a newer version, we recommend doing this manually by replacing all of the folders and files _except_ for the `/content` folder. You should back up your website before making any updates or major changes. Visit your repository homepage and click the green “Clone or download” button to download a zipped file of the entire repository, then store it somewhere safe.\n\n## Content reference\n\nAll of the content lives in the [`/content`](/content) folder. By default, Portfolio Starter is filled with the content in use on the [demo site](https://portfolio-starter.sb-ph.com/).\n\nThe content includes the [global data](#global-data), [Markdown files for each page](#markdown-files-and-yaml-frontmatter), and [media](#media). It is important to format and organise each of these files in a particular way so that your site deploys without errors and looks as expected.\n\n### Global data\n\nCertain metadata such as the site title and URL are used throughout the website. All of this global data is contained in the [`/content/_data/global.json`](/content/_data/global.json) file.\n\nThe details in this file should be set when the website is first set up and then likely will not be touched again unless the website is moved or the domain changes. This is an example of the `global.json` file:\n\n```json\n{\n  \"title\": \"Tortor Parturient Ridiculus\",\n  \"lang\": \"en\",\n  \"footer\": \"(c) Jane Doe, 2020\",\n  \"url\": \"https://tpr.com\",\n  \"author\": {\n    \"name\": \"Jane Doe\",\n    \"email\": \"mail@tpr.com\"\n  }\n}\n```\n\nThis is the only piece of content that must be written in JSON, a text format that is used to structure data. JSON syntax is _very_ strict. All keys (i.e. `title`) and all strings (i.e. `My website`) are enclosed in double quotes, and all properties (i.e. `\"title\": \"My website\"`) are separated by commas except for the last property. All JSON objects are enclosed in curly brackets `{}`. **Incorrect syntax in this file will result in an error, meaning your changes will not be deployed.**\n\nThese are the properties in more detail.\n\n| Key       | Format      | Default        | Description                                                                                                                           |\n| --------- | ----------- | -------------- | ------------------------------------------------------------------------------------------------------------------------------------- |\n| `author`  | JSON object | -              | A JSON object that includes the name and email address of the website author                                                          |\n| `footer`  | Markdown    | a short credit | The footer text written in Markdown                                                                                                   |\n| `lang`\\*  | text        | `en`           | The [IANA language tag](https://www.w3.org/International/questions/qa-html-language-declarations) that declares your website language |\n| `title`\\* | text        | -              | The title of your website                                                                                                             |\n| `url`\\*   | url         | -              | Your website URL                                                                                                                      |\n\nThe footer includes a short credit by default. Feel free to replace it with whatever text works best for you. This might include a copyright notice, a colophon, contact details or other salient information. The footer does not support line breaks.\n\n### Markdown files and YAML frontmatter\n\nAll of the main content pages including the [posts](#posts), [projects](#projects), [pages](#pages), [homepage](#homepage), [404 error page](#error), [blog](#blog-page), and [RSS feed](#rss-feed) are written in [Markdown](https://daringfireball.net/projects/markdown/). Markdown allows you to write using an easy-to-read, easy-to-write plain text format that can be converted to valid HTML. Visit the [markdown-it](https://markdown-it.github.io/) website for a full list of formatting options including lists, links, headings, and more. You can also take a look at the source for this README file; it’s written in Markdown too!\n\nAll Markdown files end in the `.md` extension, and this starterkit uses the rest of the filename to generate the page slug (the final part of a page’s URL).\n\nAny folders or files that are preceded by an underscore `_` will not be published. Because of that, you can use an underscore to create drafts such as `/content/posts/_testing-a-draft.md`. _However_, it is critical to remember that your draft will be visible to others in GitHub if your repository is public.\n\nEach Markdown file begins with [YAML](https://yaml.org/) frontmatter. YAML is a plain text syntax that allows human-readable text to be formatted as structured data. Frontmatter is the text at the top of the file that is fenced in by three dashes on either side, like so:\n\n```yaml\n---\nlayout: page\ntitle: Contact\ndescription: Get in touch with me via email or phone.\nimage: cloud-01.jpeg\n---\n\n```\n\nThe YAML frontmatter includes a series of properties\u0026mdash;keys and values separated by a colon\u0026mdash;that define page-specific metadata. Keys must always be written exactly as shown in this documentation. Writing `Layout` instead of `layout` for example will result in an error.\n\n### Basic properties\n\nThese are the basic YAML properties that should be used in the frontmatter on every page.\n\n| Key                  | Format | Default | Description                                                          |\n| -------------------- | ------ | ------- | -------------------------------------------------------------------- |\n| `description`        | text   | -       | Short description of the page contents                               |\n| `eleventyNavigation` | YAML   | -       | A YAML object, described below                                       |\n| `image`              | text   | -       | The filename of the image that should be used for social media cards |\n| `layout`\\*           | text   | -       | The page layout                                                      |\n| `permalink`          | text   | various | The page permalink                                                   |\n| `title`\\*            | text   | -       | The page title                                                       |\n\nThe page title and layout are required on every Markdown file. The page layout determines how the content is displayed. When creating new pages, you should use the `project`, `post`, or `page` layouts.\n\nThe `description` property is highly recommended for all pages since it is used for social media cards and displayed in search engine results. It should be between 50 and 160 characters, and it should never be duplicated across different pages.\n\nIf using an `image` for social media, refer to the documentation provided by the social media platforms for guidance about an appropriate image size. As a rule of thumb, a landscape-format 1200px wide JPG should be appropriate across most platforms.\n\nThe `permalink` property allows you to set the URL for a page or to turn it off completely. The permalinks are always generated automatically, so you should rarely need to use this property.\n\nThe `eleventyNavigation` property is slightly more complex. It tells the [Eleventy Navigation Plugin](https://www.11ty.dev/docs/plugins/navigation/) what to put in the menu. This is an example of the property in use on the About page [`/content/pages/about.md`](/content/pages/about.md):\n\n```yaml\n---\nlayout: default\ntitle: About\neleventyNavigation:\n  key: About\n  order: 0\n---\n\n```\n\nThe `key` sub-property tells Eleventy to add this page to the navigation with the text “About”. The `order` sub-property tells Eleventy that it should come first in the navigation.\n\nYou can also add external links to the navigation, for example a link to your GitHub. See the [`/content/pages/github.md`](/content/pages/github.md) page for an example with the following frontmatter:\n\nIf you want to add an external link to the navigation, you can create a new Markdown file (for example, `/content/external.md`) with the below frontmatter:\n\n```yaml\n---\neleventyNavigation:\n  key: GitHub \u0026nearr;\n  order: 3\n  url: http://github.com/sb-ph/portfolio-starter\npermalink: false\n---\n\n```\n\nThe `key` sub-property tells Eleventy to add this page to the navigation with the text “GitHub ” (`\u0026nearr;` is the HTML code for a northeast arrow). The `order` sub-property is set to 3 so that it comes last in the menu, and the `url` sub-property is set to the desired URL. The `permalink` property is set to false so that this doesn’t publish a corresponding page on our website.\n\n### Pages\n\nPages are found in the [`/content/pages`](/content/pages) folder.\n\nA page’s `layout` must be set to `page` in the frontmatter. Pages support only the [basic properties](#basic-properties) listed above.\n\n### Posts\n\nPosts are found in the [`/content/posts`](/content/posts) folder.\n\nA post’s `layout` must be set to `post` in the frontmatter. Posts support the [basic properties](#basic-properties) as well as the `date` property. This is an example of a post’s frontmatter:\n\n```yaml\n---\nlayout: post\ntitle: Demo post\ndate: 2020-03-29 18:00:00\n---\n\n```\n\nThe `date` property determines the publish date of the post and thus the order in the blog and RSS.\n\nYou can use the HTML comment `\u003c!--more--\u003e` within your Markdown content to generate an excerpt for your posts like so:\n\n```markdown\nMaecenas faucibus mollis interdum. Aenean eu leo quam. Pellentesque ornare sem lacinia quam venenatis vestibulum.\n\n\u003c!--more--\u003e\n\nInteger posuere erat a ante venenatis dapibus posuere velit aliquet. Donec ullamcorper nulla non metus auctor fringilla. Sed posuere consectetur est at lobortis.\n```\n\nIf you use the `more` comment, only the text preceding the comment will be displayed on the blog and a “Read more” link will be displayed after this excerpt.\n\n### Projects\n\nProjects are found in the [`/content/projects`](/content/projects) folder.\n\nA project’s `layout` must be set to `project` in the frontmatter. Projects support the [basic properties](#basic-properties) as well as the `dateStart`, `dateEnd`, and `media` properties. This is an example of the frontmatter for a project page.\n\n```yaml\n---\nlayout: project\ntitle: Your project title\ndateStart: 1988-02-01\ndateEnd: 2001-03-01\nmedia:\n  - type: image\n    filename: cloud-01.jpeg\n    size: md\n    alt: A cloud\n    caption: A collaboration with [Piper Haywood](https://piperhaywood.com)\n  - type: video\n    filename: ria-pacquee.mp4\n    controls: false\n    caption: A piece by [Ria Pacquée](http://riapacquee.com/)\n---\n\n```\n\nAnd these are the project-specific properties in more detail:\n\n| Key         | Format       | Default | Description                                             |\n| ----------- | ------------ | ------- | ------------------------------------------------------- |\n| `dateEnd`\\* | `YYYY-MM-DD` | -       | The end date of your project, used for sorting purposes |\n| `dateStart` | `YYYY-MM-DD` | -       | The start date of your project                          |\n| `media`     | YAML         | -       | A YAML list of media blocks, described below            |\n\nThe media property is a strictly-formatted YAML list that can contain image and video blocks. The properties that apply to both images and videos are outlined below.\n\n| Key          | Format   | Default | Description                                                      |\n| ------------ | -------- | ------- | ---------------------------------------------------------------- |\n| `caption`    | markdown | -       | A caption describing your media                                  |\n| `filename`\\* | text     | -       | The filename of your media                                       |\n| `height`     | integer  | -       | The height of your media in pixels                               |\n| `width`      | integer  | -       | The width of your media in pixels                                |\n| `size`       | text     | `lg`    | The size that the media should be displayed; `sm`, `md`, or `lg` |\n| `type`\\*     | text     | -       | `image` or `video`                                               |\n\nImage blocks support the following additional properties:\n\n| Key        | Format  | Default | Description                                                       |\n| ---------- | ------- | ------- | ----------------------------------------------------------------- |\n| `alt`\\*    | text    | -       | The alt text for your image                                       |\n| `featured` | boolean | false   | Whether or not the image should be used to represent this project |\n\nThe `featured` property is used to determine which image should be used to represent this project on the homepage. If multiple images are marked as featured, then the first one will be used.\n\nVideo blocks allow the following additional properties. Note that video autoplay is only supported in certain browsers and devices.\n\n| Key        | Format  | Default | Description                                           |\n| ---------- | ------- | ------- | ----------------------------------------------------- |\n| `controls` | boolean | false   | Whether or not the video controls should be displayed |\n| `loop`     | boolean | false   | Whether or not the video should loop                  |\n| `autoplay` | boolean | false   | Whether or not the video should automatically play    |\n| `muted`    | boolean | false   | Whether or not the video should be muted              |\n\n### Homepage\n\nThe homepage is the [`/content/index.md`](/content/index.md) file.\n\nThe homepage’s `layout` must be set to `home` in the frontmatter. The homepage supports most [basic properties](#basic-properties), however the `permalink` property must not be used.\n\nThe additional `entries` property allows you to specify exactly which projects you want to appear on the homepage. If the `entries` property is not filled out, then the homepage will automatically display all of the projects in order with the most recent first.\n\nThis is an example of the `entries` property in use:\n\n```yaml\n---\nlayout: home\nentries:\n  - portfolio-starter\n  - sample-project-muybridge\n  - sample-project-optics\n  - sample-project-eames\n  - sample-project-letters\n  - sample-project-traffic-signs\n---\n\n```\n\nThe first `featured` image for each project is shown. If no images are `featured`, then the first image will be shown.\n\n### Blog page\n\nThe blog page is the [`/content/posts.md`](/content/posts.md) file.\n\nThe blog page’s `layout` must be set to `posts` in the frontmatter. The blog page supports the [basic properties](#basic-properties). Markdown written beneath the frontmatter is not displayed.\n\n### Error page\n\nThe 404 error page is the [`/content/404.md`](/content/404.md) file.\n\nThe 404 error page’s `layout` must be set to `error` in the frontmatter. The error page supports only the `layout` and `title` [basic properties](#basic-properties). The `permalink` property must not be used.\n\n### RSS feed\n\nThe RSS page is the [`/content/rss.md`](/content/rss.md) file.\n\nThe RSS page’s `layout` must be set to `feed` in the frontmatter. The RSS page supports only the `layout` and `title` [basic properties](#basic-properties). The `permalink` property must not be used.\n\nThe RSS feed is automatically published to `/feed.xml`, so for example `https://yoursite.com/feed.xml`. If you want to add an RSS link in your navigation, see the [basic properties](#basic-properties) guidance to add an external link.\n\n## Media\n\nAll of the media is stored in the `/content/media` folder.\n\nMedia files must be as small as possible to save space in your GitHub repository and your hosting. [Read more about GitHub’s repository limits](https://help.github.com/en/github/managing-large-files/what-is-my-disk-quota). Smaller media files will also load faster for your readers.\n\nSmall images should be around 800px wide, medium images should be around 1400px wide, and large images should be around 3000px wide. Images with large areas of flat colour may work best as PNGs. Images with more detail such as photography should be saved as JPGs.\n\nThe more images you add to a page, the longer it will take for that page to load. Be judicious about how many images you add to any one page.\n\n## Altering and extending your site\n\nAs mentioned above, this is a deliberately basic codebase that welcomes tinkering.\n\nSmaller customisations such as altering the CSS can be done without the command line by editing the CSS file directly in GitHub. More extensive customisations are best done by developing locally with the command line. Refer to the [Eleventy documentation](https://www.11ty.dev/docs/) if you are interested in altering the [Nunjucks](https://mozilla.github.io/nunjucks/) layouts or snippets in [`/_includes`](/_includes).\n\nThese are a few suggestions for altering and extending this site:\n\n- Edit the CSS to change the fonts or background colours\n- Edit the [`/_includes/layouts/base.njk`](/_includes/layouts/base.njk) layout to create a more complex footer\n- Add tags to the blog\n- Add project attributes such as `client` or `category`\n- Add a Projects page that displays a list of all projects\n- Alter the templates to work with a content delivery network (CDN) such as [`imgix`](https://www.imgix.com/) so that your media doesn’t live on GitHub\n- Add your projects to AirTable and use their API to populate your website\n- Hook your site up to a content management system (CMS) like [Forestry](https://forestry.io/) or [Sanity](https://www.sanity.io/)\n\nIf you’re interested in our help making some modifications, just [get in touch](mailto:mail@sb-ph.com) and we’ll discuss!\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsb-ph%2Fportfolio-starter","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fsb-ph%2Fportfolio-starter","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fsb-ph%2Fportfolio-starter/lists"}