summaryrefslogtreecommitdiff
path: root/_plugins
diff options
context:
space:
mode:
Diffstat (limited to '_plugins')
-rw-r--r--_plugins/IncludeProjectTag.rb32
-rw-r--r--_plugins/ProjectGenerator.rb28
2 files changed, 60 insertions, 0 deletions
diff --git a/_plugins/IncludeProjectTag.rb b/_plugins/IncludeProjectTag.rb
new file mode 100644
index 0000000..81d1b41
--- /dev/null
+++ b/_plugins/IncludeProjectTag.rb
@@ -0,0 +1,32 @@
+module Jekyll
+ class InputProjectTag < Liquid::Tag
+
+ def initialize(tag_name, text, tokens)
+ super
+ @text = text;
+ end
+
+ def render(context)
+ site = context.environments.first['site']
+
+ #set your project dir.
+ dir = 'Projects'
+ if defined? site.projects_dir
+ dir = site.projects_dir
+ end
+ source = site['source']
+
+ #render the variable to the markdown filename
+ content = Liquid::Template.parse(@text).render(context.environments.first)
+ path = File.join(File.join(source, dir), content);
+
+ input = IO.read(path.strip())
+
+ #render the markdown file with the variables of the project.
+ return Liquid::Template.parse(input).render(context)
+
+ end
+ end
+end
+
+Liquid::Template.register_tag('include_project', Jekyll::InputProjectTag)
diff --git a/_plugins/ProjectGenerator.rb b/_plugins/ProjectGenerator.rb
new file mode 100644
index 0000000..2e57f8e
--- /dev/null
+++ b/_plugins/ProjectGenerator.rb
@@ -0,0 +1,28 @@
+module Jekyll
+
+ class ProjectPage < Page
+ def initialize(site, base, dir, project)
+ @site = site
+ @base = base
+ @dir = dir
+ @name = project['name'] + '.html'
+
+ self.process(@name)
+ self.read_yaml(File.join(base, '_layouts'), 'project.html')
+ self.data['project_name'] = project['name']
+
+ self.data['file'] = project['file']
+ end
+ end
+
+ class ProjectGenerator < Generator
+ safe true
+
+ def generate(site)
+ dir = site.config['projects_dir'] || 'Projects'
+ site.config['projects'].each do |project|
+ site.pages << ProjectPage.new(site, site.source, dir, project)
+ end
+ end
+ end
+end