summaryrefslogtreecommitdiffstats
path: root/js/directive/NewsEnclosure.js
blob: c424b50c3ea75b86538f4af3f30e21098f6d22d1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
/**
 * ownCloud - News
 *
 * This file is licensed under the Affero General Public License version 3 or
 * later. See the COPYING file.
 *
 * @author Bernhard Posselt <dev@bernhard-posselt.com>
 * @copyright Bernhard Posselt 2014
 */
app.directive('newsEnclosure', function () {
    'use strict';
    return {
        restrict: 'E',
        scope: {
            link: '@',
            type: '@'
        },
        transclude: true,
        template: '<div>' +
            '<video controls preload="none" ' +
                'ng-show="mediaType==\'video\' && !cantPlay()">' +
                '<source ng-src="{{ link|trustUrl }}" type="{{ type }}">' +
            '</video>' +
            '<audio controls preload="none" ' +
                'ng-show="mediaType==\'audio\' && !cantPlay()">' +
                '<source ng-src="{{ link|trustUrl }}" type="{{ type }}">' +
            '</audio>' +
            '<div ng-transclude ng-show="cantPlay()"></div>' +
        '</div>',
        link: function (scope, elem) {
            if (scope.type.indexOf('audio') === 0) {
                scope.mediaType = 'audio';
            } else {
                scope.mediaType = 'video';
            }
            var source = elem.children()
                .children(scope.mediaType)
                .children('source')[0];

            var cantPlay = false;

            scope.cantPlay = function () {
                return cantPlay;
            };

            source.addEventListener('error', function () {
                scope.$apply(function () {
                    cantPlay = true;
                });
            });
        }
    };
});