Skip to content

Commit 8a4421c

Browse files
committedJul 15, 2015
Add feature pages (to be written)
Signed-off-by: Chris Warrick <kwpolska@gmail.com>
1 parent 37fbc66 commit 8a4421c

File tree

6 files changed

+238
-0
lines changed

6 files changed

+238
-0
lines changed
 

‎stories/features/cli.rst

+10
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
.. title: Friendly CLI
2+
.. slug: cli
3+
.. date: 2015-07-10 15:39:26 UTC
4+
.. tags:
5+
.. category:
6+
.. link:
7+
.. description:
8+
.. type: text
9+
10+
Write your page here.

‎stories/features/compoments.rst

+10
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
.. title: Components
2+
.. slug: compoments
3+
.. date: 2015-07-10 15:39:05 UTC
4+
.. tags:
5+
.. category:
6+
.. link:
7+
.. description:
8+
.. type: text
9+
10+
Write your page here.

‎stories/features/fast.rst

+10
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
.. title: Fast
2+
.. slug: fast
3+
.. date: 2015-07-10 15:38:40 UTC
4+
.. tags:
5+
.. category:
6+
.. link:
7+
.. description:
8+
.. type: text
9+
10+
Write your page here.

‎stories/features/formats.rst

+10
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
.. title: Input Formats
2+
.. slug: formats
3+
.. date: 2015-07-10 15:38:52 UTC
4+
.. tags:
5+
.. category:
6+
.. link:
7+
.. description:
8+
.. type: text
9+
10+
Write your page here.

‎stories/features/index.rst

+139
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,139 @@
1+
.. title: Features
2+
.. slug: index
3+
.. date: 2015-07-10 15:34:49 UTC
4+
.. tags:
5+
.. category:
6+
.. link:
7+
.. description:
8+
.. type: text
9+
10+
.. class:: alert alert-info
11+
.. contents::
12+
13+
14+
.. raw:: html
15+
16+
<div class="feature-icon feature-icon-static pull-left">
17+
<a href="/features/static.html"><span class="fa-stack fa-3x">
18+
<i class="fa fa-circle fa-stack-2x"></i>
19+
<i class="fa fa-server fa-stack-1x fa-inverse"></i>
20+
</span></a></div>
21+
22+
Static sites
23+
============
24+
25+
Static websites are safer, use fewer resources, and avoid vendor and platform
26+
lock-in. You can host a Nikola website on any web server, big or small. It’s
27+
just a bunch of HTML files and assets.
28+
29+
`Explore in depth » </features/static.html>`__
30+
31+
.. raw:: html
32+
33+
<div class="feature-icon feature-icon-fast pull-left">
34+
<a href="/features/fast.html"><span class="fa-stack fa-3x">
35+
<i class="fa fa-circle fa-stack-2x"></i>
36+
<i class="fa fa-bolt fa-stack-1x fa-inverse"></i>
37+
</span></a></div>
38+
39+
Incremental builds
40+
==================
41+
42+
Nikola is fast. We use `doit <http://pydoit.org/>`_, which provides incremental
43+
rebuilds — in other words, we rebuild only the pages that need rebuilding,
44+
saving CPU time, wall clock time and upload bandwidth.
45+
46+
`Explore in depth » </features/fast.rst>`__
47+
48+
.. raw:: html
49+
50+
<div class="feature-icon feature-icon-input pull-left">
51+
<a href="/features/input.html"><span class="fa-stack fa-3x">
52+
<i class="fa fa-circle fa-stack-2x"></i>
53+
<i class="fa fa-file-text fa-stack-1x fa-inverse"></i>
54+
</span></a></div>
55+
56+
Multiple input formats
57+
======================
58+
59+
Nikola will take input in many formats. Out of the box, we support
60+
reStructuredText, Markdown, IPython (Jupyter) Notebooks and HTML, and have
61+
plugins for many other formats.
62+
63+
`Explore in depth » </features/input.html>`__
64+
65+
.. raw:: html
66+
67+
<div class="feature-icon feature-icon-components pull-left">
68+
<a href="/features/components.html"><span class="fa-stack fa-3x">
69+
<i class="fa fa-circle fa-stack-2x"></i>
70+
<i class="fa fa-cubes fa-stack-1x fa-inverse"></i>
71+
</span></a></div>
72+
73+
Built-in components
74+
===================
75+
76+
Nikola comes with everything you need to build a modern website: blogs (with
77+
comments, tags, categories, archives, RSS/Atom feeds), multilingual support,
78+
easy image galleries, and code listings.
79+
80+
`Explore in depth » </features/components.html>`__
81+
82+
.. raw:: html
83+
84+
<div class="feature-icon feature-icon-extensible pull-left">
85+
<a href="/extending.html"><span class="fa-stack fa-3x">
86+
<i class="fa fa-circle fa-stack-2x"></i>
87+
<i class="fa fa-code fa-stack-1x fa-inverse"></i>
88+
</span></a></div>
89+
90+
Extensible
91+
==========
92+
93+
Nikola is extensible. You can write a plugin to add any feature you want in a
94+
few lines of Python, or write your own theme in Mako or Jinja2. Or find
95+
something in the `Plugin <https://plugins.getnikola.com/>`__ and `Theme <http://themes.getnikola.com/>`__ Indexes.
96+
97+
`Read the extending documentation » </extending.html>`__
98+
99+
.. raw:: html
100+
101+
<div class="feature-icon feature-icon-cli pull-left">
102+
<a href="/features/cli.html"><span class="fa-stack fa-3x">
103+
<i class="fa fa-circle fa-stack-2x"></i>
104+
<i class="fa fa-terminal fa-stack-1x fa-inverse"></i>
105+
</span></a></div>
106+
107+
Friendly CLI
108+
============
109+
110+
Nikola has a friendly user interface that gets you up and running quickly and
111+
simplifies your work. You do not need to memorize headers just to create a post
112+
— we’ll write them for you.
113+
114+
`Explore in depth » </features/cli.html>`__
115+
116+
.. raw:: html
117+
118+
<div class="feature-icon feature-icon-coil pull-left">
119+
<a href="https://coil.readthedocs.org/"><span class="fa-stack fa-3x">
120+
<i class="fa fa-circle fa-stack-2x"></i>
121+
<i class="fa fa-users fa-stack-1x fa-inverse"></i>
122+
</span></a></div>
123+
124+
Coil CMS — a CMS for Nikola
125+
===========================
126+
127+
If you want to use Nikola for a website that has content authored by people who
128+
do not like command-line interfaces or who would prefer to use a WYSIWYG
129+
editor, we have a solution for you.
130+
131+
Coil CMS is a basic CMS (with user management and a WYSIWYG HTML editor), which
132+
uses Nikola to generate the pages, combining the best of both worlds: you (or
133+
your editors) can easily create content, while the site is based on resilient
134+
static pages. Users don’t even have to know what Nikola, Python or static websites
135+
are. They just write their content. The only difference is that they (or
136+
someone with the necessary permissions) need to click a *Rebuild* button to
137+
make their changes show up on the website.
138+
139+
`Read Coil CMS documentation » <https://coil.readthedocs.org/>`__

‎stories/features/static.rst

+59
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,59 @@
1+
.. title: Static
2+
.. slug: static
3+
.. date: 2015-07-10 15:38:32 UTC
4+
.. tags:
5+
.. category:
6+
.. link:
7+
.. description:
8+
.. type: text
9+
10+
Most "modern" websites are *dynamic* in the sense that the contents of the site
11+
live in a database, and are converted into presentation-ready HTML only when a
12+
user wants to see the page. That's great. However, it presents some minor issues
13+
that static site generators try to solve.
14+
15+
In a static site, the whole site, every page, *everything*, is created before
16+
the first user even sees it and uploaded to the server as a simple folder full
17+
of HTML files (and images, CSS, etc).
18+
19+
So, let's see some reasons for using static sites:
20+
21+
Security
22+
Dynamic sites are prone to experience security issues. The solution for that
23+
is constant vigilance, keeping the software behind the site updated, and
24+
plain old good luck. The stack of software used to provide a static site,
25+
like those Nikola generates, is much smaller (Just a web server).
26+
27+
A smaller software stack implies less security risk.
28+
29+
Obsolescense
30+
If you create a site using (for example) WordPress, what happens when WordPress
31+
releases a new version? You have to update your WordPress. That is not optional,
32+
because of security and support issues. If I release a new version of Nikola, and
33+
you don't update, *nothing* happens. You can continue to use the version you
34+
have now forever, no problems.
35+
36+
Also, in the longer term, the very foundations of dynamic sites shift. Can you
37+
still deploy a blog software based on Django 0.96? What happens when your
38+
host stops supporting the php version you rely on? And so on.
39+
40+
You may say those are long term issues, or that they won't matter for years. Well,
41+
I believe things should work forever, or as close to it as we can make them.
42+
Nikola's static output and its input files will work as long as you can install
43+
a Python 2.7/3.3 or newer under Linux, Windows, or OS X and can find a server
44+
that sends files over HTTP. That's probably 10 or 15 years at least.
45+
46+
Also, static sites are easily handled by the Internet Archive.
47+
48+
Cost and Performance
49+
On dynamic sites, every time a reader wants a page, a whole lot of database
50+
queries are made. Then a whole pile of code chews that data, and HTML is
51+
produced, which is sent to the user. All that requires CPU and memory.
52+
53+
On a static site, the highly optimized HTTP server reads the file from disk
54+
(or, if it's a popular file, from disk cache), and sends it to the user. You could
55+
probably serve a bazillion (technical term) pageviews from a phone using
56+
static sites.
57+
58+
Lock-in
59+
On server-side blog platforms, sometimes you can't export your own data, or

0 commit comments

Comments
 (0)
Please sign in to comment.