You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
core/src/factories/page.js

137 lines
2.8 KiB

1 year ago
const path = require('path')
const slugify = require('slugify')
const merge = require('lodash.merge')
const nunjucks = require('nunjucks')
const assign = require('assign-deep')
const parseMarkdownFile = require('./../parsers/markdown.js')
/**
* Page
*
*
* @author Björn Hase <me@herr-hase.wtf>
* @license http://opensource.org/licenses/MIT The MIT License
* @link https://gitea.node001.net/HerrHase/siteomat-webpack-plugin.git
*
*/
class Page {
/**
*
*
* @param {object} file
* @param {string} parent
* @param {string} fileString
* @param {object} [blocks=null]
*
*/
constructor(file, parent, fileString, blocks = {}) {
// parse file
const result = parseMarkdownFile(fileString)
// fields merge by default values
this._fields = merge({
view: 'page.njk',
1 year ago
extensions: 'html',
1 year ago
meta: {
robots: 'index'
1 year ago
},
hidden: false
1 year ago
}, result.fields)
// adding filename for html as pathname and relative path in structure
this._filename = this._resolveFilename(file)
1 year ago
this._slug = this._resolveSlug(this._filename)
this._path = this._resolvePath(parent)
this._permalink = this._path
if (this._slug) {
this._permalink = this._path + '/' + this._slug
}
this._filename += '.' + this._fields.extensions
1 year ago
this._content = result.content
this._blocks = blocks
}
/**
* create Page Object
*
*
* @return {object}
*
*/
get() {
return assign({
1 year ago
'content' : this._content,
'blocks' : this._blocks,
'path' : this._path + '/' + this._filename,
'permalink' : this._permalink,
'filename' : this._filename
1 year ago
}, this._fields)
}
1 year ago
/**
*
*
*/
_resolveSlug(filename) {
let slug = filename
if (slug === 'index') {
slug = ''
}
return slug
}
1 year ago
/**
* create html-filename = filename
*
* @param {string} file
* @return {string}
*
*/
_resolveFilename(file) {
let filename = file.name
if (filename === 'index.md') {
filename = 'index'
} else {
if (path.extname(filename) === '.md') {
filename = filename.replace('.md', '')
}
filename = slugify(filename)
}
1 year ago
return filename
1 year ago
}
/**
* pathname = parent
*
* @param {string} parent
* @return {string}
*
*/
1 year ago
_resolvePath(parent, slug) {
let path = parent
1 year ago
if (parent === '/') {
1 year ago
path = ''
1 year ago
}
1 year ago
return path
1 year ago
}
}
1 year ago
module.exports = Page