tsme
v1.0.3
Published
Trivial Server for Markdown via Express. Runs stand-alone or as middleware. Includes Bootstrap-based example content
Downloads
8
Maintainers
Readme
tsme
Trivial Server for Markdown via Express
A simple Express application that serves static markdown content transformed to HTML through marked and Handlebars. Intended to support light production use, it can be run stand-alone but is expected mostly to be used as middleware in a larger Express-based web site/application.
TSME can be installed either directly from the GitHub repository or as an NPM module. However you install, there are several directories in the TSME repository intended as examples of ways to structure the content that TSME serves, and not actually expected to be used outside of TSME development and test:
- You'll want your own
content
directory (which can be named whatever you want). This will contain content for individual pages in markdown (in a directory hierarchy that matches the URL scheme you want for your site), Handlebars templates used to serve the HTML generated from your markdown, and any custom assets that must be served along with your pages. - There will have to be a
public
directory if you run TSME stand-alone or in an Express configuration that doesn't serve static assets using another component. TSME will try to serve non-markdown HTTP requests by looking in thepublic
directory. The name and location of this directory is not currently configurable (see our To-Do list below). But, in a production environment, static assets should be served by a real web server or CDN prior to reaching TSME, anyway. - You may want an
envs
directory. TSME takes all of its configuration from environment variables, and reads them via theenvironmental
package. In addition to the JavaScript for reading environment variables, environmental has a recommended arrangement of shell scripts used to set those variables' values. TSME uses this convention, but you don't have to in order to use TSME--any mechanism that sets information in the shell environment that node uses when executing TSME will do. - You may want a
bower
configuration. TSME includes very minimal example content, but the example Handlebars templates include Twitterbootstrap
for page styling.
Installing from GitHub
TSME's dependencies and tool chain are intended to be familiar to anyone who has built Express web applications in the past.
- Have
node
,npm
, andgrunt
installed - Clone TSME's git repository onto your local system
- In the repository,
npm install
to load dependencies npm start
to start the example server locally- navigating a browser to
http://localhost:3000/
will give you the markdown fromcontent/pages/index.md
Installing as an NPM
The TSME package can be installed simply by referencing it
from your package.json
.
Note that as part of the install,
in addition to loading other NPM packages that TSME uses,
npm install
will run bower
to install the dependencies for TSME's
sample content, and configure the envs
and public
directories to serve the sample content. These steps are
unnecessary when you're using TSME in a production environment,
but hopefully the additional dependency downloads will not
cause you problems.
Conventions
- TSME assumes that markdown file names have the extension
.md
- TSME uses Handlebars to load files from your
content/templates
directory, so naming there must conform to its conventions. - TSME relies on the directory structure under
content/pages
matching the URL structure of (the portion of) your site served by TSME. - TSME will use a non-default Handlebars template for a markdown
if
- there is a template whose base name matches the name of the markdown file, and
- it is located in a directory under
content/templates
that matches the path to the markdown file undercontent/pages
.
- Files from
content/pages
that do not have matching Handlebars templates are served usingcontent/templates/default.hbs
.
To-Do
There are some configuration improvements that are obvious, but not immediately necessary for the use of TSME that is driving its development. Pull requests are always welcome, but particularly for these:
- Make the location of the
public
directory configurable. - Fetch
cover.css
from the bootstrap examples live on installation rather than having it committed in TSME's repository. - Support an "installing in production" environment
variable that would cause
grunt install
(used bynpm install
) to skipbower
and copying things around within TSME's directory structure. - Include sample files in
envs
for production-like configurations to demonstrate asset loading from CDNs. - Make
app/handlebars_helpers/index.js#inProductionLikeEnvironment
more configurable.
More significant planned development includes:
- Have a mechanism for setting a unique title for each page.
- Extract the JavaScript code used in TSME's sample page templates for asset loading into a separate, reusable file (without making it dependent on any external JS).
- Allow for there to be a
default.hbs
file in each directory undercontent/templates
, and look for those first when a markdown file doesn't have an exactly-matching Handlebars template. - Have a wildcard-like mechanism allowing multiple markdown files to be matched with the same non-default template.