-
Notifications
You must be signed in to change notification settings - Fork 2
HowTo: Creating Custom Content Tag
Andrew vonderLuft edited this page Dec 4, 2024
·
1 revision
Here's an example of a very simple content tag that can be inserted anywhere to render random image of given dimentions:
Create file /lib/cms_tags/lorem_picsum.rb
. And require it from somewhere.
application.rb
is not a bad place.
# Renders image tag from http://picsum.photos
# Example: {{cms:lorem_picsum 400, 300}}
class LoremPicsum < ComfortableMediaSurfer::Content::Tag
attr_reader :path, :locals
def initialize(context:, params: [], source: "")
super
@width = params[0]
@height = params[1]
unless @width.present?
raise Error, "Need at least one dimension of the image"
end
end
def content
dimensions = [@width, @height].compact.join('/')
"<img src='https://picsum.photos/#{dimensions}'/>"
end
end
ComfortableMediaSurfer::Content::Renderer.register_tag(
:lorem_picsum, LoremPicsum
)
For inspiration, take a look at existing content tags: https://github.com/shakacode/comfortable-media-surfer/tree/main/lib/comfy/content/tags