Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

elastic-svg

Package Overview
Dependencies
Maintainers
1
Versions
9
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

elastic-svg - npm Package Compare versions

Comparing version 0.1.0 to 0.1.1

examples/iframes/elasticC.html

242

dist/elasticSVG.js

@@ -1,89 +0,5 @@

var elasticSVG =
/******/ (function(modules) { // webpackBootstrap
/******/ // The module cache
/******/ var installedModules = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/
/******/ // Check if module is in cache
/******/ if(installedModules[moduleId]) {
/******/ return installedModules[moduleId].exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = installedModules[moduleId] = {
/******/ i: moduleId,
/******/ l: false,
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
/******/
/******/ // Flag the module as loaded
/******/ module.l = true;
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/******/
/******/ // expose the modules object (__webpack_modules__)
/******/ __webpack_require__.m = modules;
/******/
/******/ // expose the module cache
/******/ __webpack_require__.c = installedModules;
/******/
/******/ // define getter function for harmony exports
/******/ __webpack_require__.d = function(exports, name, getter) {
/******/ if(!__webpack_require__.o(exports, name)) {
/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
/******/ }
/******/ };
/******/
/******/ // define __esModule on exports
/******/ __webpack_require__.r = function(exports) {
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ }
/******/ Object.defineProperty(exports, '__esModule', { value: true });
/******/ };
/******/
/******/ // create a fake namespace object
/******/ // mode & 1: value is a module id, require it
/******/ // mode & 2: merge all properties of value into the ns
/******/ // mode & 4: return value when already ns object
/******/ // mode & 8|1: behave like require
/******/ __webpack_require__.t = function(value, mode) {
/******/ if(mode & 1) value = __webpack_require__(value);
/******/ if(mode & 8) return value;
/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
/******/ var ns = Object.create(null);
/******/ __webpack_require__.r(ns);
/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
/******/ return ns;
/******/ };
/******/
/******/ // getDefaultExport function for compatibility with non-harmony modules
/******/ __webpack_require__.n = function(module) {
/******/ var getter = module && module.__esModule ?
/******/ function getDefault() { return module['default']; } :
/******/ function getModuleExports() { return module; };
/******/ __webpack_require__.d(getter, 'a', getter);
/******/ return getter;
/******/ };
/******/
/******/ // Object.prototype.hasOwnProperty.call
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
/******/
/******/ // __webpack_public_path__
/******/ __webpack_require__.p = "";
/******/
/******/
/******/ // Load entry module and return exports
/******/ return __webpack_require__(__webpack_require__.s = "./index.js");
/******/ })
/************************************************************************/
/******/ ({
var elasticSVG;elasticSVG =
/******/ (() => { // webpackBootstrap
/******/ "use strict";
/******/ var __webpack_modules__ = ({

@@ -94,13 +10,20 @@ /***/ "./index.js":

\******************/
/*! exports provided: default */
/***/ (function(module, __webpack_exports__, __webpack_require__) {
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "default", function() { return elasticSVG; });
// v0.0.8
/* harmony export */ __webpack_require__.d(__webpack_exports__, {
/* harmony export */ "default": () => (/* binding */ elasticSVG)
/* harmony export */ });
// v0.1.1
function elasticSVG(selector, opts) {
opts = opts || {}; // containing DOM element, which defaults to body
opts = opts || {};
var hasWidth = opts.hasOwnProperty("width");
var hasHeight = opts.hasOwnProperty("height");
var hasAspect = opts.hasOwnProperty("aspect"); // containing DOM element, which defaults to body
var parent = document.querySelectorAll(selector || "body");
if (selector instanceof Element) {
var parent = selector;
} else {
var parent = document.querySelectorAll(selector || "body");
}

@@ -112,22 +35,43 @@ if (!parent || !parent.length) {

parent = parent[0]; // you can specify a width if you like, or we'll snap to size of container
parent = parent[0];
var initialWidth = parent.clientWidth; // you can specify a width if you like, or we'll snap to size of container
var base = {
width: typeof opts.width !== "undefined" ? opts.width : parent.clientWidth,
width: null,
height: null,
aspect: null,
scale: 1
}; // we need to remember the original width for scaling purposes
base.original_width = base.width; // you can either specify the height or the aspect ratio. If neither is specified, refaults to roughly the golden ratio
// you can either specify the height and width, which will computed the aspect ration, or one of these and the aspect ratio.
// If neither is specified, defaults to roughly the golden ratio
// specifying the height keeps the svg at a standard height and only resizes the width
// specifying the aspect ratio resizes both
if (typeof opts.height !== "undefined") {
if (hasWidth && hasHeight) {
if (hasAspect) {
console.log("Overriding aspect ratio since both `width` and `height` are specified");
opts.aspect = opts.height / opts.width;
}
base.width = opts.width;
base.height = opts.height;
base.aspect = base.height / base.width;
} else {
opts.aspect = typeof opts.aspect !== "undefined" ? opts.aspect : 0.618;
base.height = base.width * opts.aspect;
} // create a new SVG element
// if has neither an aspect or BOTH a width and height, default to approximately the golden ratio
opts.aspect = opts.aspect || 0.618;
if (hasWidth && !hasHeight) {
base.width = opts.width;
base.height = base.width * opts.aspect;
} else if (hasHeight) {
base.height = opts.height;
base.width = base.height / opts.aspect;
} else {
// if only has aspect
base.width = initialWidth;
base.height = base.width * opts.aspect;
}
}
base.original_width = base.width; // create a new SVG element
var xmlns = "http://www.w3.org/2000/svg";

@@ -145,7 +89,9 @@ var svg = document.createElementNS(xmlns, "svg");

function resize() {
console.log("resizing base");
var hasWidth = opts.hasOwnProperty("width");
var hasHeight = opts.hasOwnProperty("height");
var hasAspect = opts.hasOwnProperty("aspect");
base.width = parent.clientWidth;
svg.setAttributeNS(null, "width", base.width); // only resize the height if aspect was specified instead of height
svg.setAttributeNS(null, "width", base.width); // if `height` is not specified, resize it to the aspect ratio
if (opts.aspect) {
if (!hasHeight) {
base.height = base.width * opts.aspect;

@@ -155,2 +101,3 @@ svg.setAttributeNS(null, "height", base.height);

base.aspect = base.height / base.width;
base.scale = base.width / base.original_width; // optional callback

@@ -165,4 +112,5 @@

resize();
});
resize(); // call this on load since sometimes the initial conditions are wider than container
}); // manually trigger a page resize and run the resize function once
window.dispatchEvent(new Event('resize')); // resize(); // call this on load since sometimes the initial conditions are wider than container
// methods

@@ -179,3 +127,15 @@

};
/*
base.changeWidth = function(width) {
base.width = width;
if (opts.aspect) {
opts.aspect = base.height / base.width;
} else {
opts.width = width;
}
svg.setAttributeNS(null, "width", base.width);
}
*/
base.changeHeight = function (height) {

@@ -203,3 +163,63 @@ base.height = height;

/******/ })["default"];
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://elasticSVG/webpack/bootstrap","webpack://elasticSVG/./index.js"],"names":["elasticSVG","selector","opts","parent","document","querySelectorAll","length","console","log","base","width","clientWidth","scale","original_width","height","aspect","xmlns","svg","createElementNS","setAttributeNS","appendChild","resize","onResize","window","addEventListener","setResize","f","changeAspect","changeHeight","triggerResize"],"mappings":"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","file":"elasticSVG.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = \"./index.js\");\n","// v0.0.8\n\nexport default function elasticSVG(selector, opts) {\n\topts = opts || {};\n\n\t// containing DOM element, which defaults to body\n\tvar parent = document.querySelectorAll(selector || \"body\");\n\n\tif (!parent || !parent.length) {\n\t\tconsole.log(\"Couldn't find a parent for elasticSVG making the selector '\" + selector + \"'\");\n\t\treturn;\n\t}\n\n\tparent = parent[0];\n\n\t// you can specify a width if you like, or we'll snap to size of container\n\tvar base = {\n\t\twidth: typeof opts.width !== \"undefined\" ? opts.width : parent.clientWidth,\n\t\tscale: 1\n\t};\n\n\t// we need to remember the original width for scaling purposes\n\tbase.original_width = base.width;\n\n\t// you can either specify the height or the aspect ratio. If neither is specified, refaults to roughly the golden ratio\n\t// specifying the height keeps the svg at a standard height and only resizes the width\n\t// specifying the aspect ratio resizes both\n    if (typeof opts.height !== \"undefined\") {\n    \tbase.height = opts.height;\n    \tbase.aspect = base.height / base.width;\n    } else {\n\t    opts.aspect = typeof opts.aspect !== \"undefined\" ? opts.aspect : 0.618;\n\t\tbase.height = base.width * opts.aspect;\n    }\n\n\t// create a new SVG element\n    var xmlns = \"http://www.w3.org/2000/svg\";\n    var svg = document.createElementNS(xmlns, \"svg\");\n\tsvg.setAttributeNS(null, \"width\", base.width);\n\tsvg.setAttributeNS(null, \"height\", base.height);\n\tparent.appendChild(svg);\n\t\n\t// setting resize to \"auto\" sets the viewport to the original width and height so that the SVG always scales\n    if (opts.resize && opts.resize == \"auto\") {\n\t\tsvg.setAttributeNS(null, \"viewBox\", \"0 0 \" + base.width + \" \" + base.height);\n    }\n\n\t// function called when the window resizes\t\t\n\tfunction resize() { \n\t\tconsole.log(\"resizing base\");\n\t\tbase.width = parent.clientWidth;\n\t\tsvg.setAttributeNS(null, \"width\", base.width);\n\n\t\t// only resize the height if aspect was specified instead of height\n\t\tif (opts.aspect) {\n\t\t    base.height = base.width * opts.aspect;\n\t\t\tsvg.setAttributeNS(null, \"height\", base.height);\n\t\t}\n\n\t    base.scale = base.width / base.original_width;\n\n\t\t// optional callback\n\t\tif (opts.onResize) {\n\t\t\topts.onResize(base.width, base.height, base.scale, svg);\n\t\t}\n\t}\n\n\twindow.addEventListener(\"resize\", function() {\n\t\tresize();\n\t});\n\n\tresize(); // call this on load since sometimes the initial conditions are wider than container\n\n\t// methods\n\tbase.setResize = function(f) {\n\t\topts.onResize = f;\n\t}\n\n\tbase.changeAspect = function(aspect) {\n\t\topts.aspect = aspect;\n\t\tbase.height = base.width * opts.aspect;\n\t\tsvg.setAttributeNS(null, \"height\", base.height);\n\t}\n\n\tbase.changeHeight = function(height) {\n    \tbase.height = height;\n    \tif (opts.aspect) {\n\t    \topts.aspect = base.height / base.width;\n\t    } else {\n\t    \topts.height = height;\n\t    }\n\t\tsvg.setAttributeNS(null, \"height\", base.height);\n\t}\n\n\tbase.triggerResize = function() {\n\t\tresize();\n\t}\n\n\tbase.svg = svg;\n\treturn base;\n}"],"sourceRoot":""}
/******/ });
/************************************************************************/
/******/ // The module cache
/******/ var __webpack_module_cache__ = {};
/******/
/******/ // The require function
/******/ function __webpack_require__(moduleId) {
/******/ // Check if module is in cache
/******/ if(__webpack_module_cache__[moduleId]) {
/******/ return __webpack_module_cache__[moduleId].exports;
/******/ }
/******/ // Create a new module (and put it into the cache)
/******/ var module = __webpack_module_cache__[moduleId] = {
/******/ // no module.id needed
/******/ // no module.loaded needed
/******/ exports: {}
/******/ };
/******/
/******/ // Execute the module function
/******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
/******/
/******/ // Return the exports of the module
/******/ return module.exports;
/******/ }
/******/
/************************************************************************/
/******/ /* webpack/runtime/define property getters */
/******/ (() => {
/******/ // define getter functions for harmony exports
/******/ __webpack_require__.d = (exports, definition) => {
/******/ for(var key in definition) {
/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
/******/ }
/******/ }
/******/ };
/******/ })();
/******/
/******/ /* webpack/runtime/hasOwnProperty shorthand */
/******/ (() => {
/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
/******/ })();
/******/
/******/ /* webpack/runtime/make namespace object */
/******/ (() => {
/******/ // define __esModule on exports
/******/ __webpack_require__.r = (exports) => {
/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
/******/ }
/******/ Object.defineProperty(exports, '__esModule', { value: true });
/******/ };
/******/ })();
/******/
/************************************************************************/
/******/ // module exports must be returned from runtime so entry inlining is disabled
/******/ // startup
/******/ // Load entry module and return exports
/******/ return __webpack_require__("./index.js");
/******/ })()
.default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack://elasticSVG/./index.js","webpack://elasticSVG/webpack/bootstrap","webpack://elasticSVG/webpack/runtime/define property getters","webpack://elasticSVG/webpack/runtime/hasOwnProperty shorthand","webpack://elasticSVG/webpack/runtime/make namespace object","webpack://elasticSVG/webpack/startup"],"names":["elasticSVG","selector","opts","hasWidth","hasOwnProperty","hasHeight","hasAspect","Element","parent","document","querySelectorAll","length","console","log","initialWidth","clientWidth","base","width","height","aspect","scale","original_width","xmlns","svg","createElementNS","setAttributeNS","appendChild","resize","onResize","window","addEventListener","dispatchEvent","Event","setResize","f","changeAspect","changeHeight","triggerResize"],"mappings":"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","file":"elasticSVG.js","sourcesContent":["// v0.1.1\n\nexport default function elasticSVG(selector, opts) {\n\topts = opts || {};\n\n\tlet hasWidth = opts.hasOwnProperty(\"width\");\n\tlet hasHeight = opts.hasOwnProperty(\"height\");\n\tlet hasAspect = opts.hasOwnProperty(\"aspect\");\n\n\t// containing DOM element, which defaults to body\n\n\tif (selector instanceof Element) {\n\t\tvar parent = selector;\n\t} else {\n\t\tvar parent = document.querySelectorAll(selector || \"body\");\n\t}\n\n\tif (!parent || !parent.length) {\n\t\tconsole.log(\"Couldn't find a parent for elasticSVG making the selector '\" + selector + \"'\");\n\t\treturn;\n\t}\n\n\tparent = parent[0];\n\n\tlet initialWidth = parent.clientWidth;\n\n\t// you can specify a width if you like, or we'll snap to size of container\n\tvar base = {\n\t\twidth: null,\n\t\theight: null,\n\t\taspect: null,\n\t\tscale: 1\n\t};\n\n\t// we need to remember the original width for scaling purposes\n\n\t// you can either specify the height and width, which will computed the aspect ration, or one of these and the aspect ratio.\n\t// If neither is specified, defaults to roughly the golden ratio\n\t// specifying the height keeps the svg at a standard height and only resizes the width\n\t// specifying the aspect ratio resizes both\n\n\tif (hasWidth && hasHeight) {\n\t\tif (hasAspect) {\n\t\t\tconsole.log(\"Overriding aspect ratio since both `width` and `height` are specified\");\n\t\t\topts.aspect = opts.height / opts.width;\n\t\t}\n\t\tbase.width = opts.width; \n\t\tbase.height = opts.height; \n\t} else { // if has neither an aspect or BOTH a width and height, default to approximately the golden ratio\n\t    opts.aspect = opts.aspect || 0.618;\n\n\t\tif (hasWidth && !hasHeight) {\n\t\t\tbase.width = opts.width; \n\t\t\tbase.height = base.width * opts.aspect;\n\t\t} else if (hasHeight) {\n\t\t\tbase.height = opts.height;\n\t\t\tbase.width = base.height / opts.aspect;\n\t\t} else { // if only has aspect\n\t\t\tbase.width = initialWidth;\n\t\t\tbase.height = base.width * opts.aspect;\n\t\t}\n\t}\n\n\tbase.original_width = base.width;\n\n\n\t// create a new SVG element\n    var xmlns = \"http://www.w3.org/2000/svg\";\n    var svg = document.createElementNS(xmlns, \"svg\");\n\tsvg.setAttributeNS(null, \"width\", base.width);\n\tsvg.setAttributeNS(null, \"height\", base.height);\n\tparent.appendChild(svg);\n\t\n\t// setting resize to \"auto\" sets the viewport to the original width and height so that the SVG always scales\n    if (opts.resize && opts.resize == \"auto\") {\n\t\tsvg.setAttributeNS(null, \"viewBox\", \"0 0 \" + base.width + \" \" + base.height);\n    }\n\n\t// function called when the window resizes\t\t\n\tfunction resize() { \n\t\tlet hasWidth = opts.hasOwnProperty(\"width\");\n\t\tlet hasHeight = opts.hasOwnProperty(\"height\");\n\t\tlet hasAspect = opts.hasOwnProperty(\"aspect\");\n\n\t\tbase.width = parent.clientWidth;\n\t\tsvg.setAttributeNS(null, \"width\", base.width);\n\t\t\n\t\t// if `height` is not specified, resize it to the aspect ratio\n\t\tif (!hasHeight) {\n\t\t\tbase.height = base.width * opts.aspect;\n\t\t\tsvg.setAttributeNS(null, \"height\", base.height);\t\t\t\t\n\t\t}\n\n\t\tbase.aspect = base.height / base.width;\n\t    base.scale = base.width / base.original_width;\n\n\t\t// optional callback\n\t\tif (opts.onResize) {\n\t\t\topts.onResize(base.width, base.height, base.scale, svg);\n\t\t}\n\t}\n\n\twindow.addEventListener(\"resize\", function() {\n\t\tresize();\n\t});\n\n\t// manually trigger a page resize and run the resize function once\n\twindow.dispatchEvent(new Event('resize'));\n\n\t// resize(); // call this on load since sometimes the initial conditions are wider than container\n\n\t// methods\n\tbase.setResize = function(f) {\n\t\topts.onResize = f;\n\t}\n\n\tbase.changeAspect = function(aspect) {\n\t\topts.aspect = aspect;\n\t\tbase.height = base.width * opts.aspect;\n\t\tsvg.setAttributeNS(null, \"height\", base.height);\n\t}\n\n\t/*\n\tbase.changeWidth = function(width) {\n    \tbase.width = width;\n    \tif (opts.aspect) {\n\t    \topts.aspect = base.height / base.width;\n\t    } else {\n\t    \topts.width = width;\n\t    }\n\t\tsvg.setAttributeNS(null, \"width\", base.width);\n\t}\n\t*/\n\n\tbase.changeHeight = function(height) {\n    \tbase.height = height;\n    \tif (opts.aspect) {\n\t    \topts.aspect = base.height / base.width;\n\t    } else {\n\t    \topts.height = height;\n\t    }\n\t\tsvg.setAttributeNS(null, \"height\", base.height);\n\t}\n\n\tbase.triggerResize = function() {\n\t\tresize();\n\t}\n\n\tbase.svg = svg;\n\treturn base;\n}","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tif(__webpack_module_cache__[moduleId]) {\n\t\treturn __webpack_module_cache__[moduleId].exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","// module exports must be returned from runtime so entry inlining is disabled\n// startup\n// Load entry module and return exports\nreturn __webpack_require__(\"./index.js\");\n"],"sourceRoot":""}

@@ -1,1 +0,1 @@

var elasticSVG=function(t){var e={};function i(n){if(e[n])return e[n].exports;var r=e[n]={i:n,l:!1,exports:{}};return t[n].call(r.exports,r,r.exports,i),r.l=!0,r.exports}return i.m=t,i.c=e,i.d=function(t,e,n){i.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:n})},i.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},i.t=function(t,e){if(1&e&&(t=i(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var n=Object.create(null);if(i.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var r in t)i.d(n,r,function(e){return t[e]}.bind(null,r));return n},i.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return i.d(e,"a",e),e},i.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},i.p="",i(i.s=0)}([function(t,e,i){"use strict";function n(t,e){e=e||{};var i=document.querySelectorAll(t||"body");if(i&&i.length){i=i[0];var n={width:void 0!==e.width?e.width:i.clientWidth,scale:1};n.original_width=n.width,void 0!==e.height?(n.height=e.height,n.aspect=n.height/n.width):(e.aspect=void 0!==e.aspect?e.aspect:.618,n.height=n.width*e.aspect);var r=document.createElementNS("http://www.w3.org/2000/svg","svg");return r.setAttributeNS(null,"width",n.width),r.setAttributeNS(null,"height",n.height),i.appendChild(r),e.resize&&"auto"==e.resize&&r.setAttributeNS(null,"viewBox","0 0 "+n.width+" "+n.height),window.addEventListener("resize",function(){o()}),o(),n.setResize=function(t){e.onResize=t},n.changeAspect=function(t){e.aspect=t,n.height=n.width*e.aspect,r.setAttributeNS(null,"height",n.height)},n.changeHeight=function(t){n.height=t,e.aspect?e.aspect=n.height/n.width:e.height=t,r.setAttributeNS(null,"height",n.height)},n.triggerResize=function(){o()},n.svg=r,n}function o(){console.log("resizing base"),n.width=i.clientWidth,r.setAttributeNS(null,"width",n.width),e.aspect&&(n.height=n.width*e.aspect,r.setAttributeNS(null,"height",n.height)),n.scale=n.width/n.original_width,e.onResize&&e.onResize(n.width,n.height,n.scale,r)}console.log("Couldn't find a parent for elasticSVG making the selector '"+t+"'")}i.r(e),i.d(e,"default",function(){return n})}]).default;
var elasticSVG;elasticSVG=(()=>{"use strict";var t={89:(t,e,i)=>{function h(t,e){var i=(e=e||{}).hasOwnProperty("width"),h=e.hasOwnProperty("height"),n=e.hasOwnProperty("aspect");if(t instanceof Element)var r=t;else r=document.querySelectorAll(t||"body");if(r&&r.length){var s=(r=r[0]).clientWidth,a={width:null,height:null,aspect:null,scale:1};i&&h?(n&&(console.log("Overriding aspect ratio since both `width` and `height` are specified"),e.aspect=e.height/e.width),a.width=e.width,a.height=e.height):(e.aspect=e.aspect||.618,i&&!h?(a.width=e.width,a.height=a.width*e.aspect):h?(a.height=e.height,a.width=a.height/e.aspect):(a.width=s,a.height=a.width*e.aspect)),a.original_width=a.width;var o=document.createElementNS("http://www.w3.org/2000/svg","svg");return o.setAttributeNS(null,"width",a.width),o.setAttributeNS(null,"height",a.height),r.appendChild(o),e.resize&&"auto"==e.resize&&o.setAttributeNS(null,"viewBox","0 0 "+a.width+" "+a.height),window.addEventListener("resize",(function(){c()})),window.dispatchEvent(new Event("resize")),a.setResize=function(t){e.onResize=t},a.changeAspect=function(t){e.aspect=t,a.height=a.width*e.aspect,o.setAttributeNS(null,"height",a.height)},a.changeHeight=function(t){a.height=t,e.aspect?e.aspect=a.height/a.width:e.height=t,o.setAttributeNS(null,"height",a.height)},a.triggerResize=function(){c()},a.svg=o,a}function c(){e.hasOwnProperty("width");var t=e.hasOwnProperty("height");e.hasOwnProperty("aspect"),a.width=r.clientWidth,o.setAttributeNS(null,"width",a.width),t||(a.height=a.width*e.aspect,o.setAttributeNS(null,"height",a.height)),a.aspect=a.height/a.width,a.scale=a.width/a.original_width,e.onResize&&e.onResize(a.width,a.height,a.scale,o)}console.log("Couldn't find a parent for elasticSVG making the selector '"+t+"'")}i.d(e,{default:()=>h})}},e={};function i(h){if(e[h])return e[h].exports;var n=e[h]={exports:{}};return t[h](n,n.exports,i),n.exports}return i.d=(t,e)=>{for(var h in e)i.o(e,h)&&!i.o(t,h)&&Object.defineProperty(t,h,{enumerable:!0,get:e[h]})},i.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),i(89)})().default;

@@ -1,2 +0,2 @@

// v0.0.8
// v0.1.1

@@ -6,5 +6,14 @@ export default function elasticSVG(selector, opts) {

let hasWidth = opts.hasOwnProperty("width");
let hasHeight = opts.hasOwnProperty("height");
let hasAspect = opts.hasOwnProperty("aspect");
// containing DOM element, which defaults to body
var parent = document.querySelectorAll(selector || "body");
if (selector instanceof Element) {
var parent = selector;
} else {
var parent = document.querySelectorAll(selector || "body");
}
if (!parent || !parent.length) {

@@ -17,5 +26,9 @@ console.log("Couldn't find a parent for elasticSVG making the selector '" + selector + "'");

let initialWidth = parent.clientWidth;
// you can specify a width if you like, or we'll snap to size of container
var base = {
width: typeof opts.width !== "undefined" ? opts.width : parent.clientWidth,
width: null,
height: null,
aspect: null,
scale: 1

@@ -25,15 +38,33 @@ };

// we need to remember the original width for scaling purposes
base.original_width = base.width;
// you can either specify the height or the aspect ratio. If neither is specified, refaults to roughly the golden ratio
// you can either specify the height and width, which will computed the aspect ration, or one of these and the aspect ratio.
// If neither is specified, defaults to roughly the golden ratio
// specifying the height keeps the svg at a standard height and only resizes the width
// specifying the aspect ratio resizes both
if (typeof opts.height !== "undefined") {
base.height = opts.height;
base.aspect = base.height / base.width;
} else {
opts.aspect = typeof opts.aspect !== "undefined" ? opts.aspect : 0.618;
base.height = base.width * opts.aspect;
}
if (hasWidth && hasHeight) {
if (hasAspect) {
console.log("Overriding aspect ratio since both `width` and `height` are specified");
opts.aspect = opts.height / opts.width;
}
base.width = opts.width;
base.height = opts.height;
} else { // if has neither an aspect or BOTH a width and height, default to approximately the golden ratio
opts.aspect = opts.aspect || 0.618;
if (hasWidth && !hasHeight) {
base.width = opts.width;
base.height = base.width * opts.aspect;
} else if (hasHeight) {
base.height = opts.height;
base.width = base.height / opts.aspect;
} else { // if only has aspect
base.width = initialWidth;
base.height = base.width * opts.aspect;
}
}
base.original_width = base.width;
// create a new SVG element

@@ -53,11 +84,16 @@ var xmlns = "http://www.w3.org/2000/svg";

function resize() {
let hasWidth = opts.hasOwnProperty("width");
let hasHeight = opts.hasOwnProperty("height");
let hasAspect = opts.hasOwnProperty("aspect");
base.width = parent.clientWidth;
svg.setAttributeNS(null, "width", base.width);
// only resize the height if aspect was specified instead of height
if (opts.aspect) {
base.height = base.width * opts.aspect;
svg.setAttributeNS(null, "height", base.height);
// if `height` is not specified, resize it to the aspect ratio
if (!hasHeight) {
base.height = base.width * opts.aspect;
svg.setAttributeNS(null, "height", base.height);
}
base.aspect = base.height / base.width;
base.scale = base.width / base.original_width;

@@ -75,4 +111,7 @@

resize(); // call this on load since sometimes the initial conditions are wider than container
// manually trigger a page resize and run the resize function once
window.dispatchEvent(new Event('resize'));
// resize(); // call this on load since sometimes the initial conditions are wider than container
// methods

@@ -79,0 +118,0 @@ base.setResize = function(f) {

{
"name": "elastic-svg",
"version": "0.1.0",
"version": "0.1.1",
"description": "Responsive SVGs with no dependencies",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
"build": "bundle-module --entry=./index.js --name=elasticSVG --env=browser --output_dir=./dist",
"minify": "bundle-module --entry=./index.js --name=elasticSVG --env=browser --output_dir=./dist --min",
"watch": "bundle-module --entry=./index.js --name=elasticSVG --env=browser --output_dir=./dist --watch"
},

@@ -9,0 +11,0 @@ "repository": {

# Elastic SVG elements
=======
v0.1.0
v0.1.1

@@ -37,2 +37,3 @@ Scalable Vector Graphics are one of the Web's most triumphant technologies, but they're not as responsive as they might be. This is a very lightweight, dependency-free library that generates `svg` elements that fit to their container and scale <em>or don't scale</em> as desired.

| -------- | ----------- |
| `selector` | The CSS3 query selector or HTML element in which to create the `<svg>` |
| `width` | The initial width of the SVG. Defaults to width of parent |

@@ -58,2 +59,3 @@ | `height` | The initial height of the SVG. Defaults to the aspect ratio. |

## Change log
+ *v0.1.1*: Allowing for elements as well as selectors
+ *v0.1.0*: Removing an annoying console log

@@ -60,0 +62,0 @@ + *v0.0.8*: Made an ES6 module and created `./dist` from external packager

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc