elastic-svg
Advanced tools
Comparing version 0.1.0 to 0.1.1
@@ -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; |
75
index.js
@@ -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
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
No tests
QualityPackage does not have any tests. This is a strong signal of a poorly maintained or low quality package.
Found 1 instance in 1 package
426543
15
383
1
65
1