A vanilla HTML/JS/CSS template for creating stories using stadtpuls.com sensor data.
Stadtpuls (german for "city pulse") is Berlin's open platform for sensor data. Hardware hobbyists, activists, public institutions but also businesses can use Stadtpuls to share their sensor data to the world and enable others to leverage it for other purposes. Think of it as the GitHub for sensor data.
Stadtpuls is an open source project by the CityLAB Berlin, a project of the Technologiestiftung Berlin, supported by the Senate Chancellery Berlin.
Stadtpuls stories are standalone web articles that show how sensor data can be used in creative ways by combining text, images, static charts and interactive data visualizations to gather compelling insights. Which streets are the loudest? Which neighborhoods contribute most to the CO2 emissions and why? What are the favorite Sunday walk routes? Stadtpuls provides interesting live sensor data which can be used for citizen science projects for free. Stories are like advanced blog articles in the form of micro-sites. They tell stories through data.
This repo requires neither NodeJS nor a build tool. It is intentionally vanilla in order to make it easier for anybody with basic HTML/CSS/JavaScript skills to dive straight into creating their own story.
It does, however, import some external CSS stylesheets and JavaScript scripts for convenience. Those are:
- Tailwind Preflight:
A CSS reset setup created by TailwindCSS build on top of modern-normalize. - Tailwind Typography:
A CSS stylesheet that provides a set of prose classes to add beautiful typographic defaults to the article main text area. - Highlight JS:
A JS plugin that provides syntax highlighting for code blocks. - Highlight JS - Theme "Shades of Purple":
A CSS stylesheet for styling code highlighted by the Highlight JS plugin. - Chart.js:
A JS charting library used to display data visualization (You could also use D3.js or any other library instead). - Mapbox GL JS:
A JS library for creating interactive web maps. Used for the display of sensor cards (can be removed if not used). - Mapbox GL CSS:
The CSS styles associated withe the Mapbox GL JS library (can be removed if not used).
The above libraries are useful for specific reasons (as cited above), however, none of these are mandatory. Therefore, feel free to add or remove any library you deem important to tell your own story.
This repository is intended to be extended with your own compelling stories! There are two ways you can go about using the code:
The easiest way is to download the whole repository and simply directly modify the files (see below for more information on how to do it).
The advantage of this solution is that it is easy and straight forward. The disadvantage is that you won't be able to receive the updates we push to our own template. If you don't care about the updates, this solution is for you.
This solution is more advanced and requires you to be familiar with git and GitHub's Pull Request feature. Because GitHub repositories are versioned via git, you can have your own local copy of the code, make changes, and later request the author of the original code (in this case us) to merge your local changes into the main repository.
If you aren't familiar with theses concepts, stick to the first solution or learn more about what a Pull Request is.
The code structure is simple and minimal. Here is an overview of the most important areas:
.
├── design-resources # Design files for creating imagery
├── src # All the code happens here
│ ├── common # Common resources used by all stories
│ ├── template # The folder to duplicate to make your changes into
│ │ ├── images # Images Specific to your story
│ │ ├── vendor # External libraries particular to your story (optional)
│ │ ├── index.html # The main file, in which your story is written
│ │ ├── styles.css # Your custom CSS styles go here (optional)
│ │ └── charts.js # The JS for rendering your story charts goes here
│ ├── one-story-here # The folder to duplicate to put your changes into
│ ├── another-story-here # The folder to duplicate to put your changes into
│ └── index.html # The file with an overview of all stories.
├── .gitignore # Tells git what to ignore for versioning
├── .prettierrc.js # Tells prettier how to format code
└── README.md # This very file
You will need to create your own folder with you own story code. This mostly consists of an index.html
file and an images
folder. In the src
folder, there is a folder called template
. Duplicate this folder and rename it after your story. The name of the folder should contain only URL-compatible characters (you can turn the name of your story title into a URL compatible string here).
If you need a specific JS library or particular CSS styles, add the relevant files within your newly created folder following the structure of the common
folder (see "The Code Structure" section above). Don't forget to link the files in your index.html
file too.
Once this is done, you will be able to add your story to the list in the overview. This happens in the index.html
placed directly in the src
folder. In this file, find the first anchor tag with the stories-list-item
class, duplicate it, and adapt its content and URLs based on your new story. Make sure to respect the sorting, which is newest first, oldest last.
Aside from the story's content itself, there are a few things you should change first.
Search and replace the following texts in the index.html
with your values:
STORY_TITLE
:
The title of your article/story (about 65 to 70 characters including spaces)STORY_DESCRIPTION
:
A short description of your article/story (about 120 to 158 characters including spaces)STORY_KEYWORD
:
A coma-separated list keywords related to your article/story (between 10 to 30 keywords)STORY_AUTHOR_TWITTER_ACCOUNT
:
The author's twitter username (If not needed/wanted, remove the relevant HTML/CSS code)STORY_SLUG
:
If you publish the story yourself, change the whole URL. Otherwise, replaceSTORY_SLUG
with the name of the story in "slug" form. You can slugify the story title here.STORY_PUBLICATION_DATE
:
The official publication date of your story.
Caution: Replace N
by the author's number
STORY_AUTHOR_N_DISPLAY_NAME
:
The author's display name.STORY_AUTHOR_N_ROLE
:
The author's role (eg. "Open Data Researcher").STORY_AUTHOR_N_BIO
:
A super short bio (eg. "Dr. Benjamin Seibel leitet das Ideation & Prototyping Lab und betreute zuvor Open Data-Projekte bei der Technologiestiftung Berlin.").STORY_AUTHOR_N_STADTPULS_USERNAME
:
Stadtpuls.com username (You can find it in the URL of the author's profile page on Stadtpuls.com).STORY_AUTHOR_N_TWITTER_USERNAME
:
author's twitter.com username (Or Remove the HTML link if not wished).STORY_AUTHOR_N_PORTFOLIO_URL
:
author's portfolio URL (Or Remove the HTML link if not wished).
Some images should be adapted as well:
src/YOUR-STORY/images/social-image.jpg
: This file is the preview that is displayed when sharing via social media or messenger apps such as Slack or WhatsApp.src/YOUR-STORY/images/author-1.png
andsrc/YOUR-STORY/images/author-2.png
: The portraits of the authors.
These images were made with the Sketch app. The design files are in the design-resources
folder. Additionally we provide Adobe Photoshop templates which are also in the design-resources
folder. If you don't own Photoshop, you can use the free and open source Krita App to open the Photoshop templates.
The main content of the story happens in the <article>
HTML tag. However, the hero section containing the title, authors and publication date are placed within the <header>
tag.
Basic formatting tags such as <strong>
, <em>
, <blockquote>
, <h1>
to <h6>
, <code>
, <p>
, etc. are formatted automatically. This is due to the prose
CSS class applied to their parent <section>
elements. These automatic styles are provided by the Tailwind Typography and some custom adaptations in the styles.css
file.
There are a few CSS classes that help with styling:
.lead
:
This CSS class adds an "introduction" style. Slightly bigger and lighter, the.lead
class should be used at the beginning of an article to incentivize users to start reading further..alert
:
Alerts are styled boxes that are highlighted. They can be used to momentarily derivate from the main content and provide context information. They come in the following flavors:.alert.alert-info
(should be used by default),.alert.alert-warning
,.alert.alert-success
,.alert.alert-error
.wide-block
:
Utility CSS class to create blocks that are wider than the main text content. Useful for bringing rhythm and/or placing larger charts..tag
:
Utility to highlight a text referencing a specific dataset in a chart with the same color. Can set the color using the CSS variable--data-color
. This can be set on an element-basis with an inline style tag. (Example:<span class="tag" style="--data-color: var(--purple)">Datenarchitektur</span>
)
There is a special HTML structure and JavaScript code that can be used to show a little Card showing information about a Stadtpuls sensor. Just add the HTML element below, and information about the sensor with the provided ID will be fetched and automatically filled into the a tag.
HTML:
<a class="sensor-card" data-sensor-id="10"></a>
If you have NodeJS installed, you can use browser-sync
to auto watch and reload your code in a little development server. This makes it faster and more convenient. You can use the following command in the terminal:
npx browser-sync start -s 'src' -f 'src' --no-notify --host $LOCAL_IP --port 9000
Did you create your own story? Great! We can highlight and promote your story on our website and social media channels. Create a Pull Request or send us the zipped code folder at info@stadtpuls.com. We'll take care of the rest and get in touch with you once all is ready!
Thanks goes to these wonderful people (emoji key):
Lucas Vogel 💻 🎨 📖 |
Dennis Ostendorf 💻 |
Fabian Morón Zirfas 💻 📖 🖋 |
Lisa-Stubert 🖋 💻 |
Ester 🖋 |
Ingo Hinterding 💻 🖋 📖 |
This project follows the all-contributors specification. Contributions of any kind welcome!
Texts and content available as CC BY.
|
A project by:
|
Supported by:
|