2015-10-25 06:17:45 +01:00
|
|
|
# Pony.fm - A community for pony fan music.
|
|
|
|
# Copyright (C) 2015 Peter Deltchev
|
|
|
|
#
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU Affero General Public License as published by
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program 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 program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
2016-02-14 17:14:30 +01:00
|
|
|
module.exports = angular.module('ponyfm').directive 'pfmSrcLoader', () ->
|
2015-10-25 03:35:37 +01:00
|
|
|
(scope, element, attrs) ->
|
|
|
|
size = attrs.pfmSrcSize || 'normal'
|
|
|
|
element.css {opacity: .5}
|
2015-08-31 17:42:21 +02:00
|
|
|
|
2015-10-25 03:35:37 +01:00
|
|
|
update = (val) ->
|
|
|
|
element.attr 'src', '/images/icons/loading_' + size + '.png'
|
2015-08-31 17:42:21 +02:00
|
|
|
|
2015-10-25 03:35:37 +01:00
|
|
|
image = element.clone()
|
|
|
|
image.removeAttr 'pfm-src-loader'
|
|
|
|
image.removeAttr 'pfm-src-size'
|
2015-08-31 17:42:21 +02:00
|
|
|
|
2015-10-25 03:35:37 +01:00
|
|
|
# If the given value is null, don't bother trying to
|
|
|
|
# load something - it will result in an HTTP error.
|
|
|
|
if val
|
|
|
|
image[0].onload = ->
|
|
|
|
element.attr 'src', val
|
|
|
|
element.css {opacity: 0}
|
|
|
|
element.animate {opacity: 1}, 250
|
2015-08-31 17:42:21 +02:00
|
|
|
|
2015-10-25 03:35:37 +01:00
|
|
|
image[0].src = val
|
2015-08-31 17:42:21 +02:00
|
|
|
|
2015-10-25 03:35:37 +01:00
|
|
|
update scope.$eval attrs.pfmSrcLoader
|
2015-08-31 17:42:21 +02:00
|
|
|
|
2015-10-25 03:35:37 +01:00
|
|
|
scope.$watch attrs.pfmSrcLoader, update
|