Documentation ¶
Overview ¶
Package articles implements an app for displaying articles from files.
This application is intended to display a collection of articles where each article is represented by a file. The file must have one of the following extensions:
.html, .txt, .md
To load articles written in markdown (.md extension), your application must import gnd.la/template/markdown, like e.g.
import ( _ "gnd.la/template/markdown" )
Each file is composed of first the article text and then a set of properties separated by one empty line. Each property takes the form:
[name] = value
Where value must a valid value for the property type. The currently parsed properties are:
- title (required): Indicates the article title and can be used to generate the article URL when no slug is specified.
- id (optional): The article id, used to reverse the article. If it's not present, the article filename without extension is used as its id.
- slug (optional): The article slug. If present, it overrides the generated value from the title.
- synopsis (optional): A small text about the article shown in article listings.
- updated (optional): Indicates an update to the file.
- priority (optional): When listing the articles, the ones with lower priority are shown first.
The title, slug and updated field might appear multiple times. It's recommended that if you change the title or the slug of an article, you do so by adding a new property BEFORE the previous one without deleting the old one. This allows the articles app to redirect users from the old URL to the new one.
This package also adds a template function named reverse_article. It can be used to find the URL of an article from its id. e.g.
{{ reverse_article "article-id" }}
The typical usage of this application is as follows:
myapp.Include("/articles/", articles.App, "articles-base.html") if _, err := articles.LoadDir(articles.App, pathutil.Relative("articles")); err != nil { panic(err) }
Also, this app can be included multiple times by cloning it:
articlesApp := articles.App.Clone() myapp.Include("/articles/", articlesApp, "articles-base.html") // Load articles from the "articles" dir if _, err := articles.LoadDir(articlesApp, pathutil.Relative("articles")); err != nil { panic(err) } // included a second time tutorialsApp := articles.App.Clone() tutorialsApp.SetName("Tutorials") // Set the listing title to Tutorials myapp.Include("/tutorials/", tutorialsApp, "articles-base.html") // Load articles from the "tutorials" dir if _, err := articles.LoadDir(tutorialsApp, pathutil.Relative("tutorials")); err != nil { panic(err) }
Index ¶
Constants ¶
const ( ArticleHandlerName = "articles-article" ArticleListHandlerName = "articles-list" )
Variables ¶
var ( ArticleHandler = app.NamedHandler(ArticleHandlerName, articleHandler) ArticleListHandler = app.NamedHandler(ArticleListHandlerName, articleListHandler) )
var (
App = app.New()
)
Functions ¶
func AppArticles ¶
AppArticles returns the articles loaded into the given App, or nil if no articles were loaded into it.
Types ¶
This section is empty.
Directories ¶
Path | Synopsis |
---|---|
Package article includes common types and functions for the articles app and command.
|
Package article includes common types and functions for the articles app and command. |
cmd
|
|
articles
The articles command is used for easily managing article files.
|
The articles command is used for easily managing article files. |