From a6d1484935117b592415ed7da4f7b91da15c08a0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Xe=CC=81fir=20Destiny?= Date: Wed, 23 Jul 2014 23:14:48 +0200 Subject: Final smash and tested with different type of audios and videos --- js/app/directives/audio.coffee | 4 +-- js/app/directives/video.coffee | 44 +++++++++++++++++++++++++++++++++ js/public/app.js | 56 ++++++++++++++++++++++++++++++++++++++++-- 3 files changed, 100 insertions(+), 4 deletions(-) create mode 100644 js/app/directives/video.coffee (limited to 'js') diff --git a/js/app/directives/audio.coffee b/js/app/directives/audio.coffee index 3d6d94062..719adc282 100644 --- a/js/app/directives/audio.coffee +++ b/js/app/directives/audio.coffee @@ -34,8 +34,8 @@ angular.module('News').directive 'newsAudio', -> '' link: (scope, elm, attrs) -> - source = elm.children().children('source')[0] - cantPlay = false + source = elm.children('audio').children('source')[0] + cantPlay = !document.createElement('audio').canPlayType(attrs['type']); source.addEventListener 'error', -> scope.$apply -> cantPlay = true diff --git a/js/app/directives/video.coffee b/js/app/directives/video.coffee new file mode 100644 index 000000000..cf7454f84 --- /dev/null +++ b/js/app/directives/video.coffee @@ -0,0 +1,44 @@ +### + +ownCloud - News + +@author Bernhard Posselt +@copyright 2012 Bernhard Posselt dev@bernhard-posselt.com + +This library is free software; you can redistribute it and/or +modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE +License as published by the Free Software Foundation; either +version 3 of the License, or any later version. + +This library is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +GNU AFFERO GENERAL PUBLIC LICENSE for more details. + +You should have received a copy of the GNU Affero General Public +License along with this library. If not, see . + +### + +angular.module('News').directive 'newsVideo', -> + directive = + restrict: 'E' + scope: + src: '@' + type: '@' + transclude: true + template: '' + + '' + + '' + link: (scope, elm, attrs) -> + source = elm.children('video').children('source')[0] + cantPlay = !document.createElement('video').canPlayType(attrs['type']); + source.addEventListener 'error', -> + scope.$apply -> + cantPlay = true + + scope.cantPlay = -> cantPlay + diff --git a/js/public/app.js b/js/public/app.js index c1c2363be..fcdf6934e 100644 --- a/js/public/app.js +++ b/js/public/app.js @@ -105,8 +105,60 @@ License along with this library. If not, see . template: '' + '' + '', link: function(scope, elm, attrs) { var cantPlay, source; - source = elm.children().children('source')[0]; - cantPlay = false; + source = elm.children('audio').children('source')[0]; + cantPlay = !document.createElement('audio').canPlayType(attrs['type']); + source.addEventListener('error', function() { + return scope.$apply(function() { + return cantPlay = true; + }); + }); + return scope.cantPlay = function() { + return cantPlay; + }; + } + }; + }); + +}).call(this); + +// Generated by CoffeeScript 1.6.3 +/* + +ownCloud - News + +@author Bernhard Posselt +@copyright 2012 Bernhard Posselt dev@bernhard-posselt.com + +This library is free software; you can redistribute it and/or +modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE +License as published by the Free Software Foundation; either +version 3 of the License, or any later version. + +This library is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +GNU AFFERO GENERAL PUBLIC LICENSE for more details. + +You should have received a copy of the GNU Affero General Public +License along with this library. If not, see . +*/ + + +(function() { + angular.module('News').directive('newsVideo', function() { + var directive; + return directive = { + restrict: 'E', + scope: { + src: '@', + type: '@' + }, + transclude: true, + template: '' + '' + '', + link: function(scope, elm, attrs) { + var cantPlay, source; + source = elm.children('video').children('source')[0]; + cantPlay = !document.createElement('video').canPlayType(attrs['type']); source.addEventListener('error', function() { return scope.$apply(function() { return cantPlay = true; -- cgit v1.2.3