e4c2d579 |
#custom filters for Octopress |
3d2d1a8b |
require './plugins/backtick_code_block'
require './plugins/post_filters'
require './plugins/raw'
require 'rubypants' |
e4c2d579 |
module OctopressFilters |
3d2d1a8b |
include BacktickCodeBlock
include TemplateWrapper
def pre_filter(input)
input = render_code_block(input)
input.gsub /(<figure.+?>.+?<\/figure>)/m do
safe_wrap($1)
end
end
def post_filter(input)
input = unwrap(input)
RubyPants.new(input).to_html
end
end
module Jekyll
class ContentFilters < PostFilter
include OctopressFilters
def pre_render(post)
post.content = pre_filter(post.content)
end
def post_render(post)
post.content = post_filter(post.content)
end
end
end
module OctopressLiquidFilters |
353ccfd4 |
# Used on the blog index to split posts on the <!--more--> marker |
da38dbe5 |
def excerpt(input) |
353ccfd4 |
if input.index(/<!--\s*more\s*-->/i)
input.split(/<!--\s*more\s*-->/i)[0] |
f77db800 |
else
input
end
end |
596ec87c |
# Checks for excerpts (helpful for template conditionals)
def has_excerpt(input)
input =~ /<!--\s*more\s*-->/i ? true : false
end |
353ccfd4 |
# Summary is used on the Archive pages to return the first block of content from a post.
def summary(input)
if input.index(/\n\n/)
input.split(/\n\n/)[0] |
e4c2d579 |
else
input
end
end |
353ccfd4 |
|
0b5215c0 |
# Extracts raw content DIV from template, used for page description as {{ content }}
# contains complete sub-template code on main page level
def raw_content(input) |
3dbc379c |
/<div class="entry-content">(?<content>[\s\S]*?)<\/div>\s*<(footer|\/article)>/ =~ input |
0b5215c0 |
return (content.nil?) ? input : content
end
|
6315527b |
# Escapes CDATA sections in post content
def cdata_escape(input)
input.gsub(/<!\[CDATA\[/, '<![CDATA[').gsub(/\]\]>/, ']]>')
end
|
353ccfd4 |
# Replaces relative urls with full urls |
39d56bc9 |
def expand_urls(input, url='')
url ||= '/' |
a5f87149 |
input.gsub /(\s+(href|src)\s*=\s*["|']{1})(\/[^\"'>]*)/ do |
e4c2d579 |
$1+url+$3
end
end |
353ccfd4 |
|
39d56bc9 |
# Removes trailing forward slash from a string for easily appending url segments
def strip_slash(input)
if input =~ /(.+)\/$|^\/$/
input = $1
end
input
end
# Returns a url without the protocol (http://)
def shorthand_url(input) |
353ccfd4 |
input.gsub /(https?:\/\/)(\S+)/ do |
c7d5365f |
$2
end
end |
353ccfd4 |
# Returns a title cased string based on John Gruber's title case http://daringfireball.net/2008/08/title_case_update |
e4c2d579 |
def titlecase(input)
input.titlecase
end |
353ccfd4 |
# Returns a datetime if the input is a string |
c7d5365f |
def datetime(date) |
e4c2d579 |
if date.class == String
date = Time.parse(date)
end |
c7d5365f |
date
end |
353ccfd4 |
# Returns an ordidinal date eg July 22 2007 -> July 22nd 2007 |
c7d5365f |
def ordinalize(date)
date = datetime(date) |
f77db800 |
"#{date.strftime('%b')} #{ordinal(date.strftime('%e').to_i)}, #{date.strftime('%Y')}" |
e4c2d579 |
end |
353ccfd4 |
# Returns an ordinal number. 13 -> 13th, 21 -> 21st etc. |
e4c2d579 |
def ordinal(number)
if (11..13).include?(number.to_i % 100)
"#{number}<span>th</span>"
else
case number.to_i % 10
when 1; "#{number}<span>st</span>" |
ef3ff431 |
when 2; "#{number}<span>nd</span>" |
e4c2d579 |
when 3; "#{number}<span>rd</span>"
else "#{number}<span>th</span>"
end
end
end
end |
3d2d1a8b |
Liquid::Template.register_filter OctopressLiquidFilters |
d0f56ef1 |
|