diff options
| author | Pliable Pixels <pliablepixels@users.noreply.github.com> | 2017-12-09 18:16:20 -0500 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2017-12-09 18:16:20 -0500 |
| commit | 30659a51cb9bf4d1b037acb876371a630f092b6d (patch) | |
| tree | 8e71d548378c4184239493716764a7befb9de394 /www/external/origjs/ng-image-appear.js | |
| parent | 7b3618fe68f9b08292cffa6406756aa6ee14e373 (diff) | |
| parent | 02b539d381517228fec72235c3b8c5a5659bd711 (diff) | |
Merge pull request #564 from pliablepixels/fcm
Fcm
Diffstat (limited to 'www/external/origjs/ng-image-appear.js')
| -rw-r--r-- | www/external/origjs/ng-image-appear.js | 361 |
1 files changed, 361 insertions, 0 deletions
diff --git a/www/external/origjs/ng-image-appear.js b/www/external/origjs/ng-image-appear.js new file mode 100644 index 00000000..e20a65e0 --- /dev/null +++ b/www/external/origjs/ng-image-appear.js @@ -0,0 +1,361 @@ +/* + ng-image-appear v1.11.5 + Copyright (c) 2016 Arun Michael Dsouza (amdsouza92@gmail.com) + Licence: MIT + Demo on CodePen - http://codepen.io/amdsouza92/full/aNQeWW/ +*/ + +(function() { + 'use strict'; + + // Declaring ngImageAppear module + var ngImageAppear = angular.module('ngImageAppear', []); + + // Default background color for image wrapper + var defaultBackgroundColor = '#f0f0f0'; + + // ngImageAppear initialization code + ngImageAppear.run(function() { + + // Creating default stylesheet for elements + var defaultStylesheet, + head = document.head; + + // Checking if default stylesheet already exists in DOM + if(defaultStylesheet === undefined) { + defaultStylesheet = document.createElement('style'); + + // Default CSS stylesheet + // Styles for elements + animations + var css = '@animation .ngImageAppearLoader {width: 40px; height: 40px; position: absolute; left: calc((100% - 40px) / 2); top: calc((100% - 40px) / 2);} .ngImageAppearPlaceholder {position: relative; display: inline-block; background-size: cover; background-repeat: no-repeat; background-position: center center; background-color: '+defaultBackgroundColor+';}'; + + // Adding CSS text to default stylesheet + defaultStylesheet.appendChild(document.createTextNode(css)); + + // Prepend default stylesheet to head + head.insertBefore(defaultStylesheet, head.firstChild); + } + }); + + // ngImageAppear directive + ngImageAppear.directive('ngImageAppear',['$timeout', function($timeout) { + return { + restrict: 'A', + link: function(scope, element, attrs) { + + // Set default CSS classes for elements + var defaultLoaderClass = 'ngImageAppearLoader', + defaultPlaceholderClass = 'ngImageAppearPlaceholder'; + + // Fetching element attributes + var transitionDurationAttr = attrs.transitionDuration, // Set transition duration + noLoaderAttr = element[0].hasAttribute('no-loader'), // Check if loader is to be hidden + placeholderAttr = attrs.placeholder, // Check if default placeholder image is to be shown + placeholderClassAttr = attrs.placeholderClass, // Set CSS class for placeholder (image wrapper) + placeholderStyleAttr = attrs.placeholderStyle, // Set CSS styles for placeholder (image wrapper) + bgColorAttr = attrs.bgColor, // Set loader wrapper background color + loaderImgAttr = attrs.loaderImg, // Set custom loader image + loaderClassAttr = attrs.loaderClass, // Set CSS class for loader element + loaderStyleAttr = attrs.loaderStyle, // Set custom styles for loader element + animationDurationAttr = attrs.animationDuration, // Set animation duration + animationAttr = attrs.animation, // Set animation type + isResponsiveAttr = element[0].hasAttribute('responsive'), // Check if image is to be set responsive or not + easingAttr = attrs.easing; // Set easing for transition/animation + + // Setting default loader attributes + var loaderSrc = '', + defaultPlaceholder = '', + loaderObject = { + 'className': defaultLoaderClass + }; + + // Attach CSS class to loader element if attribute is present + if(loaderClassAttr !== undefined) { + loaderObject.className += ' '+loaderClassAttr; + } + + // Set custom styles for loader element if attribute is present + if(loaderStyleAttr !== undefined && loaderStyleAttr !== '') { + loaderObject.style = loaderStyleAttr; + } + + // Setting values for element attributes + transitionDurationAttr = !transitionDurationAttr ? 0.7+'s' : transitionDurationAttr; // Set transition duration, default - 700ms + bgColorAttr = !bgColorAttr ? defaultBackgroundColor : bgColorAttr, // Set default bg color for loader wrapper + animationDurationAttr = !animationDurationAttr ? 0.7+'s' : animationDurationAttr; // Set transition duration, default - 700ms + easingAttr = !easingAttr ? 'ease-in-out' : easingAttr; // Set easing for transition, default - ease-in-out + + // Set custom loader image if present + loaderObject.src = loaderImgAttr ? loaderImgAttr : loaderSrc; + + // DOM manipulation element variable declarations + var imgElement, + parentElement, + imgWrapper, + loaderElement, + wrapperStyles = 'background-color: '+bgColorAttr+'; ', + setImageElementWidth, + isSmall = false, + hasShownLoader = false, + animationText; + + // Add placeholder image if attribute is present + if(placeholderAttr !== undefined) { + if(placeholderAttr === '') { + // Set default placeholder + wrapperStyles += 'background-image: url('+defaultPlaceholder+'); '; + } + else { + // Set custom placeholder + wrapperStyles += 'background-image: url('+placeholderAttr+'); '; + } + } + + // Function to render loader + function renderLoader() { + + // Show loader in DOM + function showLoader() { + loaderElement = document.createElement('img'); + + // Adding loader object properties to loader element + for(var key in loaderObject) { + loaderElement[key] = loaderObject[key]; + } + + // Set loader element's visual styles to null + loaderElement.style.margin = loaderElement.style.padding = loaderElement.style.border = loaderElement.style.borderRadius = 0; + loaderElement.style.boxShadow = loaderElement.style.float = 'none'; + loaderElement.style.transform = loaderElement.style.outline = ''; + + // Add loader to DOM + imgWrapper.appendChild(loaderElement); + hasShownLoader = true; + } + + // Check custom loader image extension + if(loaderImgAttr) { + + // Get filetype of image + var fileType = loaderImgAttr.split('.').pop(); + fileType = fileType.substring(0,3); + + // Show loader if gif file is present + if(fileType === 'gif') { + showLoader(); + } + // Else throw warning in console + else { + console.warn('The custom loader image should have a proper gif extension. Read full documentation here - https://github.com/ArunMichaelDsouza/ng-image-appear'); + } + } + else { + showLoader(); + } + } + + // Function to remove loader element from DOM + function removeLoader() { + + // Check for loader visibility flags + if(!isSmall && !noLoaderAttr && hasShownLoader) { + var elementLoader = element[0].nextSibling; // Get loader of current element + if(elementLoader) { + elementLoader.parentNode.removeChild(elementLoader); // Remove rendered loader from DOM + } + } + } + + // Function to remove wrapper element from DOM + function removeImgWrapper() { + + // Interval to check that image wrapper has been rendered in DOM + var intervalRemove = setInterval(function() { + if(imgWrapper !== undefined) { + clearInterval(intervalRemove); + + // Reset img wrapper CSS + imgWrapper.style.backgroundColor = imgWrapper.style.position = imgElement.style.width = imgElement.style.padding = imgElement.style.margin = imgElement.style.border = imgElement.style.borderRadius = imgElement.style.boxShadow = imgElement.style.float = imgElement.style.transform = imgElement.style.outline = ''; + + var wrapper = element[0].parentNode, + wrapperParent = wrapper.parentNode; + wrapperParent.replaceChild(element[0], wrapper); // Replace wrapper with actual image element + } + }, 1); + } + + // Function to render image wrapper in DOM + function renderImageWrapper(imgElementWidth, parentElementWidth, imgElementStyles) { + + // Append placeholder styles to image wrapper if attribute is present + if(placeholderStyleAttr !== undefined && placeholderStyleAttr !== '') { + wrapperStyles += placeholderStyleAttr; + } + + imgWrapper = document.createElement('div'); // Create wrapper element for image + imgWrapper.setAttribute('style', wrapperStyles); // Set default CSS for wrapper element + imgWrapper.className = defaultPlaceholderClass; // Attach default CSS placeholder class to image wrapper + + // Append placeholder custom class if attribute is present + if(placeholderClassAttr !== undefined && placeholderClassAttr !== '') { + imgWrapper.className += ' '+placeholderClassAttr; + } + + // Set default CSS width + unit for img element + if(isResponsiveAttr) { + // Set image element width in % + setImageElementWidth = Math.round((imgElementWidth * 100) / parentElementWidth); + setImageElementWidth+= '%'; + + // Set wrapper width to width of image element + imgWrapper.style.width = setImageElementWidth; + } + else { + // Set image element width in px + setImageElementWidth = Math.round(imgElementWidth); + setImageElementWidth+= 'px'; + + // Set wrapper width to width of image element + imgWrapper.style.width = setImageElementWidth; + } + + // Add image element styles to wrapper element + for(var property in imgElementStyles) { + imgWrapper.style[property] = imgElementStyles[property]; + } + + imgElement.style.width = '100%'; // Span image element to 100% width of wrapper + imgElement.style.padding = imgElement.style.margin = 0; // Set image element's margin/padding to 0 + + //PP + //parentElement.replaceChild(imgWrapper, imgElement); // Replace actual image element with wrapper element + imgElement.replaceWith(imgWrapper); + imgWrapper.appendChild(imgElement); // Append actual image element to wrapper element + // This will wrap the image element into a parent div tag used for showing the loader + + // Show loader if 'no-loader' attribute is not present + if(!noLoaderAttr) { + var imgWrapperWidth = imgWrapper.offsetWidth; + + // Show loader if wrapper width is more than 70px + imgWrapperWidth >= 70 ? renderLoader() : isSmall = true; + } + + // Create animation sequence if attribute is present + if(animationDurationAttr !== undefined && animationDurationAttr !== '') { + animationText = animationAttr+' '+animationDurationAttr+' '+easingAttr; + } + } + + // Function to get element's content width (without horizontal padding) + function getElementContentWidth(element, type) { + var styles = window.getComputedStyle(element), // Get computed styles of element + padding = parseFloat(styles.paddingLeft) + parseFloat(styles.paddingRight); // Get horizontal padding of element + + // Return content width + if(type === 'wrapper') { + return element.offsetWidth - padding; + } + else { + return element.offsetWidth; + } + } + + // Function to create image wrapper element + function generateImageWrapper() { + imgElement = element[0], // Get image element + parentElement = imgElement.parentNode; // Get parent of image element + + // Fire interval for checking image's width/height until calculated by DOM + var interval = setInterval(function() { + + // If image element's width and height have been calculated by DOM then clear interval + if(imgElement.offsetWidth !== 0 && imgElement.clientHeight !== 0) { + clearInterval(interval); + + // Get image element's visual styles and set it to wrapper element when rendered in DOM + var imgElementStyles = { + padding: window.getComputedStyle(imgElement).padding, + margin: window.getComputedStyle(imgElement).margin, + borderRadius: window.getComputedStyle(imgElement).borderRadius, + border: window.getComputedStyle(imgElement).border, + boxShadow: window.getComputedStyle(imgElement).boxShadow, + float: window.getComputedStyle(imgElement).float, + transform: window.getComputedStyle(imgElement).transform, + outline: window.getComputedStyle(imgElement).outline + }; + + // Set content width for parent, image elements + var parentElementWidth = getElementContentWidth(parentElement, 'wrapper'), + imgElementWidth = getElementContentWidth(element[0], 'image'); + + // Render image wrapper + renderImageWrapper(imgElementWidth, parentElementWidth, imgElementStyles); + } + }, 1); + } + + // Function to load image into DOM + function loadImage() { + removeLoader(); // Remove loader element once image is loaded + + removeImgWrapper(); // Remove image wrapper from DOM + + // Make element appear with transition/animation + $timeout(function() { + element.css({ + 'transition': ' all '+ transitionDurationAttr +' '+ easingAttr, // Set element transition + 'opacity': 1, // Show image element in view + 'animation': animationAttr ? animationText : '' // Set element animation + }); + }, 100); // Timeout to clear stack and rebuild DOM + } + + // Function to initiate actual image load + function onImageLoad() { + loadImage(); + element.unbind('load'); + } + + // Function to initialise directive + function initialize() { + + // Hide image element from view + element.css({ + 'opacity': 0 + }); + + // Create image wrapper for loader + generateImageWrapper(); + + // Check if image element has already been completely downloaded + if(element[0].complete) { + loadImage(); + } + else { + // Else detect image load event + element.bind('load', onImageLoad); + } + } + + // Function to get image element's source + function getImageSrc() { + return element[0].getAttribute('src'); + } + + // Attach a watcher to image element's source + scope.$watch(getImageSrc, function(newSrcValue, oldSrcValue) { + + // Check if the image element's source has actually changed + if(newSrcValue && newSrcValue !== oldSrcValue) { + initialize(); // Re-initialise directive + } + + }); + + // Initialise directive + initialize(); + } + }; + }]); +})(); |
