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 | 3 | settings_items :url, :type => :string, :default => "" |
4 | 4 | settings_items :width, :type => :integer, :default => 400 |
5 | 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 | 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 | 17 | end |
26 | 18 | |
19 | + #FIXME Make this test | |
27 | 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 | 22 | end |
30 | 23 | |
24 | + #FIXME Make this test | |
31 | 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 | 27 | end |
34 | 28 | |
29 | + #FIXME Make this test | |
35 | 30 | def self.description |
36 | 31 | _('Add Video') |
37 | 32 | end |
38 | 33 | |
34 | + #FIXME Make this test | |
39 | 35 | def help |
40 | 36 | _('This block presents a video block.') |
41 | 37 | end |
42 | 38 | |
39 | + #FIXME Make this test | |
43 | 40 | def content(args={}) |
44 | 41 | block = self |
45 | 42 | |
... | ... | @@ -47,10 +44,25 @@ class VideoBlock < Block |
47 | 44 | render :file => 'video_block', :locals => { :block => block } |
48 | 45 | end |
49 | 46 | end |
50 | - | |
51 | 47 | |
48 | + #FIXME Make this test | |
52 | 49 | def cacheable? |
53 | 50 | false |
54 | 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 | 68 | end | ... | ... |
plugins/video/test/unit/video_block_test.rb
... | ... | @@ -3,101 +3,139 @@ class VideoBlockTest < ActiveSupport::TestCase |
3 | 3 | |
4 | 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 | 7 | block = VideoBlock.new |
8 | 8 | block.url = "http://youtube.com/?v=XXXXX" |
9 | - assert block.is_valid_source? | |
9 | + assert block.is_youtube? | |
10 | 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 | 13 | block = VideoBlock.new |
14 | 14 | block.url = "https://youtube.com/?v=XXXXX" |
15 | - assert block.is_valid_source? | |
15 | + assert block.is_youtube? | |
16 | 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 | 19 | block = VideoBlock.new |
20 | 20 | block.url = "https://www.youtube.com/?v=XXXXX" |
21 | - assert block.is_valid_source? | |
21 | + assert block.is_youtube? | |
22 | 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 | 25 | block = VideoBlock.new |
26 | 26 | block.url = "www.youtube.com/?v=XXXXX" |
27 | - assert block.is_valid_source? | |
27 | + assert block.is_youtube? | |
28 | 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 | 31 | block = VideoBlock.new |
32 | 32 | block.url = "youtube.com/?v=XXXXX" |
33 | - assert block.is_valid_source? | |
33 | + assert block.is_youtube? | |
34 | 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 | 37 | block = VideoBlock.new |
38 | 38 | block.url = "youtube.com/" |
39 | - assert !block.is_valid_source? | |
39 | + assert !block.is_youtube? | |
40 | 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 | 43 | block = VideoBlock.new |
44 | 44 | block.url = "youtube.com/?v=" |
45 | - assert !block.is_valid_source? | |
45 | + assert !block.is_youtube? | |
46 | 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 | 49 | block = VideoBlock.new |
50 | 50 | block.url = "http://www.yt.com/?v=XXXXX" |
51 | - assert !block.is_valid_source? | |
51 | + assert !block.is_youtube? | |
52 | 52 | end |
53 | 53 | |
54 | 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 | 57 | block = VideoBlock.new |
58 | 58 | block.url = "http://vimeo.com/98979" |
59 | - assert block.is_valid_source? | |
59 | + assert block.is_vimeo? | |
60 | 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 | 63 | block = VideoBlock.new |
64 | 64 | block.url = "https://vimeo.com/989798" |
65 | - assert block.is_valid_source? | |
65 | + assert block.is_vimeo? | |
66 | 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 | 69 | block = VideoBlock.new |
70 | 70 | block.url = "https://www.vimeo.com/98987" |
71 | - assert block.is_valid_source? | |
71 | + assert block.is_vimeo? | |
72 | 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 | 75 | block = VideoBlock.new |
76 | 76 | block.url = "www.vimeo.com/989798" |
77 | - assert block.is_valid_source? | |
77 | + assert block.is_vimeo? | |
78 | 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 | 81 | block = VideoBlock.new |
82 | 82 | block.url = "vimeo.com/09898" |
83 | - assert block.is_valid_source? | |
83 | + assert block.is_vimeo? | |
84 | 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 | 87 | block = VideoBlock.new |
88 | 88 | block.url = "vimeo.com/home" |
89 | - assert !block.is_valid_source? | |
89 | + assert !block.is_vimeo? | |
90 | 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 | 93 | block = VideoBlock.new |
94 | 94 | block.url = "vimeo.com/" |
95 | - assert !block.is_valid_source? | |
95 | + assert !block.is_vimeo? | |
96 | 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 | 99 | block = VideoBlock.new |
100 | 100 | block.url = "http://www.vmsd.com/98979" |
101 | - assert !block.is_valid_source? | |
101 | + assert !block.is_vimeo? | |
102 | 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 | 141 | end | ... | ... |
plugins/video/views/video_block.rhtml
1 | 1 | <h3 class="block-title"> |
2 | - <span><%=block.title%></span> | |
2 | + <span><%=block.title%></span> | |
3 | 3 | </h3> |
4 | 4 | <div class="video-block-data"> |
5 | 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 | 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 | 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 | 13 | <% end %> |
14 | 14 | |
15 | 15 | </div> | ... | ... |