Commit 6e6dd66aec4d3ea19137855525d03469bc7a8621
1 parent
5b502e59
Exists in
master
and in
28 other branches
display embed url's for youtube and vimeo
Showing
4 changed files
with
107 additions
and
57 deletions
Show diff stats
plugins/video/lib/.video_block.rb.swp
No preview for this file type
plugins/video/lib/video_block.rb
@@ -3,43 +3,40 @@ class VideoBlock < Block | @@ -3,43 +3,40 @@ class VideoBlock < Block | ||
3 | settings_items :url, :type => :string, :default => "" | 3 | settings_items :url, :type => :string, :default => "" |
4 | settings_items :width, :type => :integer, :default => 400 | 4 | settings_items :width, :type => :integer, :default => 400 |
5 | settings_items :height, :type => :integer, :default => 315 | 5 | settings_items :height, :type => :integer, :default => 315 |
6 | - | ||
7 | - def is_valid_source? | ||
8 | - | ||
9 | - if url.match(/.*youtu(.be|be.com).*v=[[:alnum:]].*/) | ||
10 | - true | ||
11 | - elsif url.match(/^(http[s]?:\/\/)?(www.)?(vimeo.com|player.vimeo.com\/video)\/[[:digit:]].*/) | ||
12 | - true | ||
13 | - else | ||
14 | - false | ||
15 | - end | 6 | + |
7 | + def is_youtube? | ||
8 | + url.match(/.*(youtube.com.*v=[[:alnum:]]*|youtu.be\/[[:alnum:]]*).*/) ? true : false | ||
16 | end | 9 | end |
17 | 10 | ||
18 | - def is_file? | ||
19 | - false | 11 | + def is_vimeo? |
12 | + url.match(/^(http[s]?:\/\/)?(www.)?(vimeo.com|player.vimeo.com\/video)\/[[:digit:]]*/) ? true : false | ||
13 | + end | ||
20 | 14 | ||
21 | - extensions = [".mp4", ".ogg", ".ogv", ".wmv"] | ||
22 | - if extensions.include? url[-4, 4] | ||
23 | - true | ||
24 | - end | 15 | + def is_video_file? |
16 | + url.match(/.*(mp4|ogg|ogv|webm)$/) ? true : false | ||
25 | end | 17 | end |
26 | 18 | ||
19 | + #FIXME Make this test | ||
27 | def format_embed_video_url_for_youtube | 20 | def format_embed_video_url_for_youtube |
28 | - self.url.gsub("watch?v=", "embed/") | 21 | + "//www.youtube-nocookie.com/embed/#{extract_youtube_id}?rel=0&wmode=transparent" |
29 | end | 22 | end |
30 | 23 | ||
24 | + #FIXME Make this test | ||
31 | def format_embed_video_url_for_vimeo | 25 | def format_embed_video_url_for_vimeo |
32 | - self.url.gsub("vimeo.com/", "player.vimeo.com/video/") | 26 | + "//player.vimeo.com/video/#{extract_vimeo_id}" |
33 | end | 27 | end |
34 | 28 | ||
29 | + #FIXME Make this test | ||
35 | def self.description | 30 | def self.description |
36 | _('Add Video') | 31 | _('Add Video') |
37 | end | 32 | end |
38 | 33 | ||
34 | + #FIXME Make this test | ||
39 | def help | 35 | def help |
40 | _('This block presents a video block.') | 36 | _('This block presents a video block.') |
41 | end | 37 | end |
42 | 38 | ||
39 | + #FIXME Make this test | ||
43 | def content(args={}) | 40 | def content(args={}) |
44 | block = self | 41 | block = self |
45 | 42 | ||
@@ -47,10 +44,25 @@ class VideoBlock < Block | @@ -47,10 +44,25 @@ class VideoBlock < Block | ||
47 | render :file => 'video_block', :locals => { :block => block } | 44 | render :file => 'video_block', :locals => { :block => block } |
48 | end | 45 | end |
49 | end | 46 | end |
50 | - | ||
51 | 47 | ||
48 | + #FIXME Make this test | ||
52 | def cacheable? | 49 | def cacheable? |
53 | false | 50 | false |
54 | end | 51 | end |
52 | + | ||
53 | + private | ||
54 | + | ||
55 | + #FIXME Make this test | ||
56 | + def extract_youtube_id | ||
57 | + return nil unless is_youtube? | ||
58 | + youtube_match = url.match('v=([[:alnum:]]*)') | ||
59 | + youtube_match ||= url.match('youtu.be\/([[:alnum:]]*)') | ||
60 | + youtube_match[1] unless youtube_match.nil? | ||
61 | + end | ||
55 | 62 | ||
63 | + def extract_vimeo_id | ||
64 | + return nil unless is_vimeo? | ||
65 | + vimeo_match = url.match('([[:digit:]]*)$') | ||
66 | + vimeo_match[1] unless vimeo_match.nil? | ||
67 | + end | ||
56 | end | 68 | end |
plugins/video/test/unit/video_block_test.rb
@@ -3,101 +3,139 @@ class VideoBlockTest < ActiveSupport::TestCase | @@ -3,101 +3,139 @@ class VideoBlockTest < ActiveSupport::TestCase | ||
3 | 3 | ||
4 | ### Tests for YouTube | 4 | ### Tests for YouTube |
5 | 5 | ||
6 | - should "is_valid_source return true when the url contains http://youtube.com" do | 6 | + should "is_youtube return true when the url contains http://youtube.com" do |
7 | block = VideoBlock.new | 7 | block = VideoBlock.new |
8 | block.url = "http://youtube.com/?v=XXXXX" | 8 | block.url = "http://youtube.com/?v=XXXXX" |
9 | - assert block.is_valid_source? | 9 | + assert block.is_youtube? |
10 | end | 10 | end |
11 | 11 | ||
12 | - should "is_valid_source return true when the url contains https://youtube.com" do | 12 | + should "is_youtube return true when the url contains https://youtube.com" do |
13 | block = VideoBlock.new | 13 | block = VideoBlock.new |
14 | block.url = "https://youtube.com/?v=XXXXX" | 14 | block.url = "https://youtube.com/?v=XXXXX" |
15 | - assert block.is_valid_source? | 15 | + assert block.is_youtube? |
16 | end | 16 | end |
17 | 17 | ||
18 | - should "is_valid_source return true when the url contains https://www.youtube.com" do | 18 | + should "is_youtube return true when the url contains https://www.youtube.com" do |
19 | block = VideoBlock.new | 19 | block = VideoBlock.new |
20 | block.url = "https://www.youtube.com/?v=XXXXX" | 20 | block.url = "https://www.youtube.com/?v=XXXXX" |
21 | - assert block.is_valid_source? | 21 | + assert block.is_youtube? |
22 | end | 22 | end |
23 | 23 | ||
24 | - should "is_valid_source return true when the url contains www.youtube.com" do | 24 | + should "is_youtube return true when the url contains www.youtube.com" do |
25 | block = VideoBlock.new | 25 | block = VideoBlock.new |
26 | block.url = "www.youtube.com/?v=XXXXX" | 26 | block.url = "www.youtube.com/?v=XXXXX" |
27 | - assert block.is_valid_source? | 27 | + assert block.is_youtube? |
28 | end | 28 | end |
29 | 29 | ||
30 | - should "is_valid_source return true when the url contains youtube.com" do | 30 | + should "is_youtube return true when the url contains youtube.com" do |
31 | block = VideoBlock.new | 31 | block = VideoBlock.new |
32 | block.url = "youtube.com/?v=XXXXX" | 32 | block.url = "youtube.com/?v=XXXXX" |
33 | - assert block.is_valid_source? | 33 | + assert block.is_youtube? |
34 | end | 34 | end |
35 | 35 | ||
36 | - should "is_valid_source return false when the url not contains youtube video ID" do | 36 | + should "is_youtube return false when the url not contains youtube video ID" do |
37 | block = VideoBlock.new | 37 | block = VideoBlock.new |
38 | block.url = "youtube.com/" | 38 | block.url = "youtube.com/" |
39 | - assert !block.is_valid_source? | 39 | + assert !block.is_youtube? |
40 | end | 40 | end |
41 | 41 | ||
42 | - should "is_valid_source return false when the url contains empty youtube video ID" do | 42 | + should "is_youtube return false when the url contains empty youtube video ID" do |
43 | block = VideoBlock.new | 43 | block = VideoBlock.new |
44 | block.url = "youtube.com/?v=" | 44 | block.url = "youtube.com/?v=" |
45 | - assert !block.is_valid_source? | 45 | + assert !block.is_youtube? |
46 | end | 46 | end |
47 | 47 | ||
48 | - should "is_valid_source return false when the url contains an invalid youtube link" do | 48 | + should "is_youtube return false when the url contains an invalid youtube link" do |
49 | block = VideoBlock.new | 49 | block = VideoBlock.new |
50 | block.url = "http://www.yt.com/?v=XXXXX" | 50 | block.url = "http://www.yt.com/?v=XXXXX" |
51 | - assert !block.is_valid_source? | 51 | + assert !block.is_youtube? |
52 | end | 52 | end |
53 | 53 | ||
54 | #### Tests for Vimeo Videos | 54 | #### Tests for Vimeo Videos |
55 | 55 | ||
56 | - should "is_valid_source return true when the url contains http://vimeo.com" do | 56 | + should "is_vimeo return true when the url contains http://vimeo.com" do |
57 | block = VideoBlock.new | 57 | block = VideoBlock.new |
58 | block.url = "http://vimeo.com/98979" | 58 | block.url = "http://vimeo.com/98979" |
59 | - assert block.is_valid_source? | 59 | + assert block.is_vimeo? |
60 | end | 60 | end |
61 | 61 | ||
62 | - should "is_valid_source return true when the url contains https://vimeo.com" do | 62 | + should "is_vimeo return true when the url contains https://vimeo.com" do |
63 | block = VideoBlock.new | 63 | block = VideoBlock.new |
64 | block.url = "https://vimeo.com/989798" | 64 | block.url = "https://vimeo.com/989798" |
65 | - assert block.is_valid_source? | 65 | + assert block.is_vimeo? |
66 | end | 66 | end |
67 | 67 | ||
68 | - should "is_valid_source return true when the url contains https://www.vimeo.com" do | 68 | + should "is_vimeo return true when the url contains https://www.vimeo.com" do |
69 | block = VideoBlock.new | 69 | block = VideoBlock.new |
70 | block.url = "https://www.vimeo.com/98987" | 70 | block.url = "https://www.vimeo.com/98987" |
71 | - assert block.is_valid_source? | 71 | + assert block.is_vimeo? |
72 | end | 72 | end |
73 | 73 | ||
74 | - should "is_valid_source return true when the url contains www.vimeo.com" do | 74 | + should "is_vimeo return true when the url contains www.vimeo.com" do |
75 | block = VideoBlock.new | 75 | block = VideoBlock.new |
76 | block.url = "www.vimeo.com/989798" | 76 | block.url = "www.vimeo.com/989798" |
77 | - assert block.is_valid_source? | 77 | + assert block.is_vimeo? |
78 | end | 78 | end |
79 | 79 | ||
80 | - should "is_valid_source return true when the url contains vimeo.com" do | 80 | + should "is_vimeo return true when the url contains vimeo.com" do |
81 | block = VideoBlock.new | 81 | block = VideoBlock.new |
82 | block.url = "vimeo.com/09898" | 82 | block.url = "vimeo.com/09898" |
83 | - assert block.is_valid_source? | 83 | + assert block.is_vimeo? |
84 | end | 84 | end |
85 | 85 | ||
86 | - should "is_valid_source return false when the url not contains vimeo video ID" do | 86 | + should "is_vimeo return false when the url not contains vimeo video ID" do |
87 | block = VideoBlock.new | 87 | block = VideoBlock.new |
88 | block.url = "vimeo.com/home" | 88 | block.url = "vimeo.com/home" |
89 | - assert !block.is_valid_source? | 89 | + assert !block.is_vimeo? |
90 | end | 90 | end |
91 | 91 | ||
92 | - should "is_valid_source return false when the url contains empty vimeo video ID" do | 92 | + should "is_vimeo return false when the url contains empty vimeo video ID" do |
93 | block = VideoBlock.new | 93 | block = VideoBlock.new |
94 | block.url = "vimeo.com/" | 94 | block.url = "vimeo.com/" |
95 | - assert !block.is_valid_source? | 95 | + assert !block.is_vimeo? |
96 | end | 96 | end |
97 | 97 | ||
98 | - should "is_valid_source return false when the url contains an invalid vimeo link" do | 98 | + should "is_vimeo return false when the url contains an invalid vimeo link" do |
99 | block = VideoBlock.new | 99 | block = VideoBlock.new |
100 | block.url = "http://www.vmsd.com/98979" | 100 | block.url = "http://www.vmsd.com/98979" |
101 | - assert !block.is_valid_source? | 101 | + assert !block.is_vimeo? |
102 | end | 102 | end |
103 | + | ||
104 | + # Other video formats | ||
105 | + should "is_video return true if url ends with mp4" do | ||
106 | + block = VideoBlock.new | ||
107 | + block.url = "http://www.vmsd.com/98979.mp4" | ||
108 | + assert block.is_video_file? | ||
109 | + end | ||
110 | + | ||
111 | + should "is_video return true if url ends with ogg" do | ||
112 | + block = VideoBlock.new | ||
113 | + block.url = "http://www.vmsd.com/98979.ogg" | ||
114 | + assert block.is_video_file? | ||
115 | + end | ||
116 | + | ||
117 | + should "is_video return true if url ends with ogv" do | ||
118 | + block = VideoBlock.new | ||
119 | + block.url = "http://www.vmsd.com/98979.ogv" | ||
120 | + assert block.is_video_file? | ||
121 | + end | ||
122 | + | ||
123 | + should "is_video return true if url ends with webm" do | ||
124 | + block = VideoBlock.new | ||
125 | + block.url = "http://www.vmsd.com/98979.webm" | ||
126 | + assert block.is_video_file? | ||
127 | + end | ||
128 | + | ||
129 | + should "is_video return false if url ends without mp4, ogg, ogv, webm" do | ||
130 | + block = VideoBlock.new | ||
131 | + block.url = "http://www.vmsd.com/98979.mp4r" | ||
132 | + assert !block.is_video_file? | ||
133 | + block.url = "http://www.vmsd.com/98979.oggr" | ||
134 | + assert !block.is_video_file? | ||
135 | + block.url = "http://www.vmsd.com/98979.ogvr" | ||
136 | + assert !block.is_video_file? | ||
137 | + block.url = "http://www.vmsd.com/98979.webmr" | ||
138 | + assert !block.is_video_file? | ||
139 | + end | ||
140 | + | ||
103 | end | 141 | end |
plugins/video/views/video_block.rhtml
1 | <h3 class="block-title"> | 1 | <h3 class="block-title"> |
2 | - <span><%=block.title%></span> | 2 | + <span><%=block.title%></span> |
3 | </h3> | 3 | </h3> |
4 | <div class="video-block-data"> | 4 | <div class="video-block-data"> |
5 | <% if block.is_youtube? %> | 5 | <% if block.is_youtube? %> |
6 | - <%= render :partial => 'iframe_video_block', :locals => { :url => block.format_embed_video_url_for_youtube, :width => block.width, :height => block.height }%> | 6 | + <%= render :partial => 'iframe_video_block', :locals => { :url => block.format_embed_video_url_for_youtube, :width => block.width, :height => block.height }%> |
7 | <% elsif block.is_vimeo? %> | 7 | <% elsif block.is_vimeo? %> |
8 | - <%= render :partial => 'iframe_video_block', :locals => { :url => block.format_embed_video_url_for_vimeo, :width => block.width, :height => block.height }%> | ||
9 | - <% elsif block.is_file? %> | ||
10 | - <%= render :partial => 'html5_video_block', :locals => { :url => block.url, :width => block.width, :height => block.height }%> | 8 | + <%= render :partial => 'iframe_video_block', :locals => { :url => block.format_embed_video_url_for_vimeo, :width => block.width, :height => block.height }%> |
9 | + <% elsif block.is_video_file? %> | ||
10 | + <%= render :partial => 'html5_video_block', :locals => { :url => block.url, :width => block.width, :height => block.height }%> | ||
11 | <% else %> | 11 | <% else %> |
12 | - <%= "<span class='alert-block'> Cadastre uma nova URL (Vimeo, Youtube)</span>" %> | 12 | + <%= "<span class='alert-block'> Cadastre uma nova URL (Vimeo, Youtube)</span>" %> |
13 | <% end %> | 13 | <% end %> |
14 | 14 | ||
15 | </div> | 15 | </div> |