mirror of
https://gitea.invidious.io/iv-org/shard-kemal.git
synced 2024-08-15 00:53:36 +00:00
Don't load unless caller and content matches for content_for
This commit is contained in:
parent
ce2ffed705
commit
e6e70fe222
1 changed files with 11 additions and 4 deletions
|
@ -1,6 +1,6 @@
|
||||||
require "kilt"
|
require "kilt"
|
||||||
|
|
||||||
CONTENT_FOR_BLOCKS = Hash(String, Proc(String)).new
|
CONTENT_FOR_BLOCKS = Hash(String, Tuple(String, Proc(String))).new
|
||||||
|
|
||||||
# <tt>content_for</tt> is a set of helpers that allows you to capture
|
# <tt>content_for</tt> is a set of helpers that allows you to capture
|
||||||
# blocks inside views to be rendered later during the request. The most
|
# blocks inside views to be rendered later during the request. The most
|
||||||
|
@ -31,20 +31,27 @@ CONTENT_FOR_BLOCKS = Hash(String, Proc(String)).new
|
||||||
# Then you can put <tt><%= yield_content :scripts_and_styles %></tt> on your
|
# Then you can put <tt><%= yield_content :scripts_and_styles %></tt> on your
|
||||||
# layout, inside the <head> tag, and each view can call <tt>content_for</tt>
|
# layout, inside the <head> tag, and each view can call <tt>content_for</tt>
|
||||||
# setting the appropriate set of tags that should be added to the layout.
|
# setting the appropriate set of tags that should be added to the layout.
|
||||||
macro content_for(key)
|
macro content_for(key, file = __FILE__)
|
||||||
CONTENT_FOR_BLOCKS[{{key}}] = ->() {
|
proc = ->() {
|
||||||
__kilt_io__ = MemoryIO.new
|
__kilt_io__ = MemoryIO.new
|
||||||
{{ yield }}
|
{{ yield }}
|
||||||
__kilt_io__.to_s
|
__kilt_io__.to_s
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CONTENT_FOR_BLOCKS[{{key}}] = Tuple.new {{file}}, proc
|
||||||
nil
|
nil
|
||||||
end
|
end
|
||||||
|
|
||||||
macro yield_content(key)
|
macro yield_content(key)
|
||||||
CONTENT_FOR_BLOCKS[{{key}}].call if CONTENT_FOR_BLOCKS.has_key?({{key}})
|
if CONTENT_FOR_BLOCKS.has_key?({{key}})
|
||||||
|
__caller_filename__ = CONTENT_FOR_BLOCKS[{{key}}][0]
|
||||||
|
proc = CONTENT_FOR_BLOCKS[{{key}}][1]
|
||||||
|
proc.call if __content_filename__ == __caller_filename__
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
macro render(filename, layout)
|
macro render(filename, layout)
|
||||||
|
__content_filename__ = {{filename}}
|
||||||
content = render {{filename}}
|
content = render {{filename}}
|
||||||
render {{layout}}
|
render {{layout}}
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue