Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/dan-smith-tech/shelf

A fully customisable, open-source browser startpage.
https://github.com/dan-smith-tech/shelf

browser-startpage css customisable html javascript open-source

Last synced: 2 months ago
JSON representation

A fully customisable, open-source browser startpage.

Awesome Lists containing this project

README

        


Logo

Shelf


A fully customisable, open-source browser startpage, built with vanilla HTML.






# Content

- [Motivation](#motivation)
- [Getting Started](#getting-started)
- [Documentation](#documentation)
- [Colour](#colour)
- [Clock](#clock)
- [Searchbar](#searchbar)
- [Change Search Engine](#change-search-engine)
- [Change Layout](#change-layout)
- [Delete](#delete)
- [Layout](#layout)
- [Change Height of Links](#change-height-of-links)
- [Change Links to be the Same Height](#change-links-to-be-the-same-height)
- [Content](#content)
- [Links](#links)
- [Headings](#headings)
- [Contributing](#contributing)
- [Forking Guidelines & License Notice](#forking-guidelines--license-notice)






# Motivation

I created Shelf because I wanted a locally-accessible browser startpage that enabled me to organise my bookmarks by relative size - to represent importance and to increase ease-of-access to the places I visit the most (also, I just wanted to experiment with some cool gradient designs). Additionally, I wanted my searchbar to be focused when the browser loads, to start searching as soon as it opens (without having to click on any input fields, because after all, if you're not clicking on a bookmark, you're probably opening your browser to search something up).

I like to use Shelf by keeping my most visited and important bookmarks as the largest link elements, whilst having the clock and searchbar right above them, for quick access.






# Getting Started

In order to customise _Shelf_ for your own browser, you will need to fork this repo so you can add your own content and change the layout. You can refer to [GitHub's forking documentation](https://docs.github.com/en/get-started/quickstart/fork-a-repo) if you need.

Once you have _Shelf_ downloaded locally on your machine, you will need to set it as your homepage for new windows in your browser. In order to accomplish this, you will need to head to your browser settings and set the startpage for new windows and tabs to be the location of the 'index.html' file in the _Shelf_ folder (e.g., if you are on Windows this may be 'file:///C:/Users/[your-name]/projects/shelf/index.html'). Below is a list of how to accomplish this on some of the most popular browsers.

- [Setting your homepage in Chrome](https://www.hellotech.com/guide/for/how-to-change-homepage-on-chrome)
- [Setting your homepage in Firefox](https://support.mozilla.org/en-US/kb/how-to-set-the-home-page)
- [Setting your homepage in Safari](https://support.apple.com/en-gb/guide/safari/ibrw1020/mac)
- [Setting your homepage in Opera](https://browserhow.com/how-to-change-homepage-url-on-opera-browser/)
- [Setting your homepage in Brave](https://browserpulse.com/how-to-change-brave-browser-default-homepage/)






# Documentation

The following sections detail how you can customise every part of _Shelf_ to create your very own browser startpage. However, if you are familiar with HTML, CSS, and JavaScript, you should of course experiment with more complicated customisations.




## Colour

By default, _Shelf_ uses its colour scheme of purples and reds.

If you want to use your own colours within _Shelf_, you simply need to change the values of the following variables (found at the top of the 'main.css' file). You can use [this](https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Colors/Color_picker_tool) colour picker tool to find the colour codes, and [this](https://cssgradient.io/) tool to create your own gradients.

```css
:root {
--color-text: white;
--color-primary: #a81759; /* Used for highlights */
--color-secondary: #171633; /* Used for backdrops of elements */
--color-tertiary: #111025; /* Used for the backdrop of the entire page */
--gradient-primary: linear-gradient(
45deg,
var(--color-primary) 0%,
#a81796 35%,
#6c17a8 65%,
#3917a8 100%
); /* Used for highlights */
--gradient-secondary: linear-gradient(
45deg,
var(--color-secondary) 0%,
#251633 35%,
#2c1633 65%,
#421531 100%
); /* Used for backdrops of elements */
}
```

You can also change the color of icons, by using [this](https://codepen.io/sosuke/pen/Pjoqqp) tool to convert a colour from HEX to a CSS filter property, which you can copy and replace in the following CSS class (found in the 'main.css' file).

```css
.grid-element svg {
filter: invert(100%) sepia(0%) saturate(2%) hue-rotate(128deg) brightness(
103%
) contrast(101%);
}
```




## Clock

By default, _Shelf_ has a clock at the top of the page.

If you want to remove the clock, you can delete the following HTML (found towards the top of the 'index.html' file).

```html

12:00

```

You will also need to remove the following JavaScript (found at the bottom of the 'main.js' file).

```javascript
const timeElement = document.querySelector("#time");
function updateTime() {
const date = new Date();
var hour = date.getHours().toString();
if (hour.length === 1) hour = "0" + hour;
var minute = date.getMinutes().toString();
if (minute.length === 1) minute = "0" + minute;
const seconds = date.getSeconds();

timeElement.textContent = hour + ":" + minute;
setTimeout(updateTime, 1 - seconds);
}
updateTime();
```




## Searchbar

By default, _Shelf_ has a searchbar at the top of the page, that searches with Google.


### Change Search Engine

If you want to change the search engine used, then you will need to change the value of the following JavaScript variable (found at the top of the 'main.js' file), to the query link of your desired search engine. For example, if you wanted to use DuckDuckGo, it would be 'https://duckduckgo.com/?q='.

```javascript
const searchEngine = "https://google.com/search?q=";
```

If you change the search engine, then you will also want to change the placeholder text in the search bar to reflect your choice. You can do this by replacing the 'placeholder' property in the following HTML (found towards the top of the 'index.html' file).

```html

```


### Change Layout

If you want the searchbar to fit with the rest of the grid, then you will need to delete the following CSS properties (found in the 'main.css' file). You may also want to refer to the [Layout](#layout) section, for more information on how elements of arranged in _Shelf_.

```css
#search {
width: 65em;
margin: 0 auto calc(2.85rem + var(--gap)) auto;
}
```


### Delete

If you want to remove the searchbar, you can delete the following HTML (found towards the top of the 'index.html' file).

```html



```

You will also need to remove the following JavaScript (found at the top of the 'main.js' file).

```javascript
const searchForm = document.querySelector("#search");
const searchBar = searchForm[0];
const searchEngine = "https://google.com/search?q=";
searchBar.focus();
searchForm.onsubmit = (e) => {
e.preventDefault();
const query = searchBar.value.replace(/ /g, "+");
if (validURL(query)) return (window.location.href = query);
else return (window.location.href = "" + searchEngine + query);
};
function validURL(str) {
var pattern = new RegExp(
"^(https?:\\/\\/)?" +
"((([a-z\\d]([a-z\\d-]*[a-z\\d])*)\\.)+[a-z]{2,}|" +
"((\\d{1,3}\\.){3}\\d{1,3}))" +
"(\\:\\d+)?(\\/[-a-z\\d%_.~+]*)*" +
"(\\?[;&a-z\\d%_.~+=-]*)?" +
"(\\#[-a-z\\d_]*)?$",
"i"
);
return !!pattern.test(str);
}
```




## Layout

Elements in _Shelf_ are arranged using CSS Grid.


### Change Height of Links

In order to change the smallest height that link elements can be, change the 'min-height' property in the following CSS class (found in 'main.css').

```css
.grid-element {
min-height: 6rem;
}
```


### Change Links to be the Same Height

In order to make all of the links have the same height (as opposed to filling the available space), change the 'grid-template-rows' property in the following CSS class (found in the 'main.css' file). Set the value to 'repeat(x, 1fr)', where x is the largest number of links you have (vertically) in any column.

```css
.grid-rows {
display: grid;
grid-template-rows: repeat(4, 1fr);
}
```




## Content

By default, _Shelf_ comes with a few demo bookmarks (such as YouTube, Spotify, and Gmail). However, you will of course want to change these in order to document your own links.


### Links

A link consists of the following HTML (found in the 'index.html' file).

```html


[INSERT-LINK-ICON-SVG-PATH]

[INSERT-LINK-NAME]



```

In order to create a new link, place one of these HTML elements in any of the 'grid-rows' HTML containers (found in the 'index.html' file), such as the following.

```html

```

Then fill in the URL and name fields. In order to find an icon for the link, you can use a range of websites that provide SVG icons. For the demo, I sourced all of the icons from [Boxicons](https://boxicons.com/). In order to do this, select the icon you want in Boxicons, and press the 'SVG CODE' button in the pop-up menu. The SVG will be copied to your clipboard.

When you copy an SVG from Boxicons, it looks like the following.

```html

```

Delete the 'style' attribute, and place it in your link element so that it looks like the following.

```html




YouTube



```

You can repeat this process as many times as you want, in order to create as many links as you need!


### Headings

If you want to add headings to each of the columns, you can add the following HTML nested as the first element under a 'grid-rows' container (found in the 'index.html' file).

```html


[INSERT-HEADING-NAME]



```

For example, a column could look like the following.

```html



Entertainment



...
...
...

```

If you make this change, you will also need to update the 'grid-rows' CSS class (found in the 'main.css' file) in order to structure the rows in each column correctly. All you have to do for this to work is add '6.5rem' (or, whatever height you have set your link elements to be - if you changed them) before the value already set for 'grid-template-rows'.

This means, if you have your link elements set to auto size (this is the default setting), your updated property value should look like the following.

```css
.grid-rows {
grid-template-rows: 6.5rem auto;
}
```

Or, if you changed your link elements to be the same height (in the [layout](#layout) section), your updated property value should look like the following (just apply the same rules to the 'repeat' function as detailed in the [layout](#layout) section, when setting the link elements to be the same size).

```css
.grid-rows {
grid-template-rows: 6.5rem repeat(4, 1fr);
}
```






# Contributing

If you think _Shelf_ is lacking in any way (whether that be the project itself, or the documentation), feel free to open a pull request with your changes or new features.






# Forking Guidelines & License Notice

I encourage everyone to fork this project and modify it to their needs, or to take pieces and incorporate those into their own projects (no credit is required).