This repository holds the content being posted to our dev.to organization. Given that the process of publishing is automated, the directory structure of where each user places their content is standardized and mandatory.
Every content creator owns their specific portion of the posts directory. Within this directory is where all articles and assets are to be placed.
The mandatory part is that you must create your own directory within posts
named exactly as your Github username.
How you decide to organize the contents within your directory is up to you. However, we do recommend the following structure:
cloudx-labs/posts/
├── README.md
├── ...
├── posts
│ └──<your github username>
│ ├── one-article.md
│ ├── another-article.md
│ ├── ...
│ └── assets
│ ├── cover1.png
│ └── cover2.png
│ └── ...
- Contact Pablo Romeo or Axel Navarro on Slack to get invited into the DEV.to Organization and to set up your API key.
- Read the Dev.to - Editor Guide to get insights on what formatting is supported and the recommended sizes for cover and content images.
- Create a feature branch, start writing your first draft and open a pull-request once you want to get some feedback from reviewers 😃
Articles published by the automated process support referencing your content such as images using relative paths.
So for including images from your assets
directory you'd have something similar to:
data:image/s3,"s3://crabby-images/0a54e/0a54e60232f93af514d4b3831328d96632a2daf3" alt="My text"
Besides the usual Markdown, articles that are published automatically must contain a Header called Front Matter.
Such as:
---
title: The title of your article
published: false
description: A description for your article
tags: 'one-tag, another-tag'
cover_image: ./assets/path-to-cover.png
---
You can see an actual published article with the header here.
The most important attribute in the header is published
. It determines if your article is still a draft or if it should be made public.
Therefore, if you open a pull-request with:
published: false
: Once merged the article will be available as a Draft in DEV.to for you to review online.published: true
: Once merged your article is public.
Once the PR is merged, additional properties will be added automatically into the Front Matter header, such id
and date
:
id: 123456
date: '2022-02-02T18:50:58Z'
IMPORTANT: Don't manually edit those two properties, you could lose content or create duplicates.
All pull-requests will run markdownlint for you.
But we recommend installing extensions for your Editor, such as markdownlint for VSCode or setting up husky to add the pre-commit hook available already in this repo.
Due to how the Dev.to REST Api works, unfortunately it does not yet support linking a user's article to an organization.
Because of that, once you merge a PR for a draft article, or directly publish it, you must manually edit the post and change it from Personal
to Cloud(x);
.