Giter Site home page Giter Site logo

geopattern's Introduction

GeoPattern

npm version build status downloads

This is a JavaScript port of jasonlong/geo_pattern with a live preview page and is derived from the background generator originally used for GitHub Guides.

Usage

Web

Include the minified script from your server. jQuery is optional.

<script src="js/jquery.min.js"></script> <!-- optional -->
<script src="js/geopattern.min.js"></script>

Or reference it from a CDN.

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.2.3/jquery.min.js"></script> <!-- optional -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/geopattern/1.2.3/js/geopattern.min.js"></script>

Use either the GeoPattern browser global or the jQuery plugin:

// Use the global...
var pattern = GeoPattern.generate('GitHub');
$('#geopattern').css('background-image', pattern.toDataUrl());

// ...or the plugin
$('#geopattern').geopattern('GitHub');

For backwards compatibility with the script on the Guides, the source hash for generation can be supplied with a data-title-sha attribute on the element. If the attribute exists, the generator will ignore the input string and use the supplied hash.

To run on Internet Explorer 9, the GeoPattern script requires polyfills for window.btoa() and Uint32Array.

View index.html on the gh-pages branch for a complete example.

Node.js

npm install geopattern

After requiring geopattern, the API is identical to the browser version, minus the jQuery plugin.

var GeoPattern = require('geopattern');
var pattern = GeoPattern.generate('GitHub');
pattern.toDataUrl(); // url("data:image/svg+xml;...

PS - If you are going to use Webpack (or any other bundler) to bundle geopattern and it will be used in a browser, ignore buffer shim from the bundling to decrease its size. See #32 for more details.

API

GeoPattern.generate(string, options)

Returns a newly-generated, tiling SVG Pattern.

  • string Will be hashed using the SHA1 algorithm, and the resulting hash will be used as the seed for generation.

  • options.color Specify an exact background color. This is a CSS hexadecimal color value.

  • options.baseColor Controls the relative background color of the generated image. The color is not identical to that used in the pattern because the hue is rotated by the generator. This is a CSS hexadecimal color value, which defaults to #933c3c.

  • options.generator Determines the pattern. All of the original patterns are available in this port, and their names are camelCased.

Pattern.color

Gets the pattern's background color as a hexadecimal string.

GeoPattern.generate('GitHub').color // => "#455e8a"

Pattern.toString() and Pattern.toSvg()

Gets the SVG string representing the pattern.

Pattern.toBase64()

Gets the SVG as a Base64-encoded string.

Pattern.toDataUri()

Gets the pattern as a data URI, i.e. data:image/svg+xml;base64,PHN2ZyB....

Pattern.toDataUrl()

Gets the pattern as a data URL suitable for use as a CSS background-image, i.e. url("data:image/svg+xml;base64,PHN2ZyB...").

License

Licensed under the terms of the MIT License, the full text of which can be read in LICENSE.

geopattern's People

Contributors

aviaryan avatar btmills avatar derhuerst avatar ricardopolo avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

geopattern's Issues

Change Size of the generated preview images?

Is it possible to change the size of the generated preview images within the geopattern.min.js ? In case I want to generate a bigger preview before returning the Base64 encoded String.

accessor on the main color of the pattern

Hello,

I would like to have

  • a geopattern, where the color C is automatically chosen from the seed
  • another region in my page with a blend rectangle with the same color spirit as the geopattern.

I saw that you calculate the rgb value of the color in generateBackground without storing it.

Would you agree to make this calculated color visible on the Pattern object ?

remove randomness

Is there any way to remove randomization seed for testing purposes?

Scale and Gradient opts

It isn't much, but I am willing to offer a 0.2 BTC bounty for the addition of scale and gradient opts to GeoPattern.generate() method.

I am using the raw data so it has to alter the svg itself (can't use css or canvas hacks).

How to use the geopattern inside another svg?

I'm trying to set the geopattern as the fill for a svg polygon.

You can't set the css background-image on an svg. I suspect the answer is using a <pattern> definition, but I haven't been able to figure out a solution that works across all browsers.

SVG height is 684?

I'm not sure what's going on, but I have generated several patterns and they always resolve to the SVG height being 684 with a width of 100.

const pattern = GeoPattern.generate("d2040d8d-a0b2-40a3-9f48-db61f09cb47c")
console.log(pattern.toDataUri())
Output

data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMDAiIGhlaWdodD0iNjg0Ij48cmVjdCB4PSIwIiB5PSIwIiB3aWR0aD0iMTAwJSIgaGVpZ2h0PSIxMDAlIiBmaWxsPSJyZ2IoMjQwLDEwMSwzNikiPjwvcmVjdD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiNkZGQiIG9wYWNpdHk9IjAuMDIiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LC0xMzUpIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjZGRkIiBvcGFjaXR5PSIwLjAyIiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSw1NDkpIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMjIyIiBvcGFjaXR5PSIwLjEzMjY2NjY2NjY2NjY2NjY1IiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSwtMTE2KSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iIzIyMiIgb3BhY2l0eT0iMC4xMzI2NjY2NjY2NjY2NjY2NSIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsNTY4KSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iIzIyMiIgb3BhY2l0eT0iMC4wOTgiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LC05NykiPjwvcGF0aD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiMyMjIiIG9wYWNpdHk9IjAuMDk4IiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSw1ODcpIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMjIyIiBvcGFjaXR5PSIwLjA4MDY2NjY2NjY2NjY2NjY2IiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSwtNzgpIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMjIyIiBvcGFjaXR5PSIwLjA4MDY2NjY2NjY2NjY2NjY2IiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSw2MDYpIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMjIyIiBvcGFjaXR5PSIwLjA5OCIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsLTU5KSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iIzIyMiIgb3BhY2l0eT0iMC4wOTgiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDYyNSkiPjwvcGF0aD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiMyMjIiIG9wYWNpdHk9IjAuMDQ2IiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSwtNDApIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMjIyIiBvcGFjaXR5PSIwLjA0NiIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsNjQ0KSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2RkZCIgb3BhY2l0eT0iMC4wNTQ2NjY2NjY2NjY2NjY2NyIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsLTIxKSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2RkZCIgb3BhY2l0eT0iMC4wNTQ2NjY2NjY2NjY2NjY2NyIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsNjYzKSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2RkZCIgb3BhY2l0eT0iMC4wMiIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsLTIpIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjZGRkIiBvcGFjaXR5PSIwLjAyIiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSw2ODIpIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMjIyIiBvcGFjaXR5PSIwLjA4MDY2NjY2NjY2NjY2NjY2IiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSwxNykiPjwvcGF0aD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiMyMjIiIG9wYWNpdHk9IjAuMDgwNjY2NjY2NjY2NjY2NjYiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDcwMSkiPjwvcGF0aD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiNkZGQiIG9wYWNpdHk9IjAuMTA2NjY2NjY2NjY2NjY2NjciIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDM2KSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2RkZCIgb3BhY2l0eT0iMC4xMDY2NjY2NjY2NjY2NjY2NyIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsNzIwKSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2RkZCIgb3BhY2l0eT0iMC4xMDY2NjY2NjY2NjY2NjY2NyIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsNTUpIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjZGRkIiBvcGFjaXR5PSIwLjEwNjY2NjY2NjY2NjY2NjY3IiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSw3MzkpIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMjIyIiBvcGFjaXR5PSIwLjExNTMzMzMzMzMzMzMzMzM0IiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSw3NCkiPjwvcGF0aD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiMyMjIiIG9wYWNpdHk9IjAuMTE1MzMzMzMzMzMzMzMzMzQiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDc1OCkiPjwvcGF0aD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiMyMjIiIG9wYWNpdHk9IjAuMTMyNjY2NjY2NjY2NjY2NjUiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDkzKSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iIzIyMiIgb3BhY2l0eT0iMC4xMzI2NjY2NjY2NjY2NjY2NSIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsNzc3KSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2RkZCIgb3BhY2l0eT0iMC4xMjQwMDAwMDAwMDAwMDAwMSIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsMTEyKSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2RkZCIgb3BhY2l0eT0iMC4xMjQwMDAwMDAwMDAwMDAwMSIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsNzk2KSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iIzIyMiIgb3BhY2l0eT0iMC4wODA2NjY2NjY2NjY2NjY2NiIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsMTMxKSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iIzIyMiIgb3BhY2l0eT0iMC4wODA2NjY2NjY2NjY2NjY2NiIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsODE1KSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2RkZCIgb3BhY2l0eT0iMC4xNDEzMzMzMzMzMzMzMzMzNCIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsMTUwKSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2RkZCIgb3BhY2l0eT0iMC4xNDEzMzMzMzMzMzMzMzMzNCIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsODM0KSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2RkZCIgb3BhY2l0eT0iMC4wODkzMzMzMzMzMzMzMzMzMyIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsMTY5KSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iI2RkZCIgb3BhY2l0eT0iMC4wODkzMzMzMzMzMzMzMzMzMyIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsODUzKSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iIzIyMiIgb3BhY2l0eT0iMC4xMzI2NjY2NjY2NjY2NjY2NSIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsMTg4KSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iIzIyMiIgb3BhY2l0eT0iMC4xMzI2NjY2NjY2NjY2NjY2NSIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsODcyKSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iIzIyMiIgb3BhY2l0eT0iMC4wNDYiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDIwNykiPjwvcGF0aD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiMyMjIiIG9wYWNpdHk9IjAuMDQ2IiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSw4OTEpIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjZGRkIiBvcGFjaXR5PSIwLjEwNjY2NjY2NjY2NjY2NjY3IiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSwyMjYpIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjZGRkIiBvcGFjaXR5PSIwLjEwNjY2NjY2NjY2NjY2NjY3IiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSw5MTApIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjZGRkIiBvcGFjaXR5PSIwLjA1NDY2NjY2NjY2NjY2NjY3IiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSwyNDUpIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjZGRkIiBvcGFjaXR5PSIwLjA1NDY2NjY2NjY2NjY2NjY3IiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSw5MjkpIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMjIyIiBvcGFjaXR5PSIwLjA0NiIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsMjY0KSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iIzIyMiIgb3BhY2l0eT0iMC4wNDYiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDk0OCkiPjwvcGF0aD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiNkZGQiIG9wYWNpdHk9IjAuMDg5MzMzMzMzMzMzMzMzMzMiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDI4MykiPjwvcGF0aD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiNkZGQiIG9wYWNpdHk9IjAuMDg5MzMzMzMzMzMzMzMzMzMiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDk2NykiPjwvcGF0aD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiMyMjIiIG9wYWNpdHk9IjAuMDgwNjY2NjY2NjY2NjY2NjYiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDMwMikiPjwvcGF0aD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiMyMjIiIG9wYWNpdHk9IjAuMDgwNjY2NjY2NjY2NjY2NjYiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDk4NikiPjwvcGF0aD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiNkZGQiIG9wYWNpdHk9IjAuMDIiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDMyMSkiPjwvcGF0aD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiNkZGQiIG9wYWNpdHk9IjAuMDIiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDEwMDUpIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMjIyIiBvcGFjaXR5PSIwLjExNTMzMzMzMzMzMzMzMzM0IiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSwzNDApIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMjIyIiBvcGFjaXR5PSIwLjExNTMzMzMzMzMzMzMzMzM0IiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSwxMDI0KSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iIzIyMiIgb3BhY2l0eT0iMC4wNjMzMzMzMzMzMzMzMzMzNCIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsMzU5KSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iIzIyMiIgb3BhY2l0eT0iMC4wNjMzMzMzMzMzMzMzMzMzNCIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsMTA0MykiPjwvcGF0aD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiMyMjIiIG9wYWNpdHk9IjAuMTMyNjY2NjY2NjY2NjY2NjUiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDM3OCkiPjwvcGF0aD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiMyMjIiIG9wYWNpdHk9IjAuMTMyNjY2NjY2NjY2NjY2NjUiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDEwNjIpIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjZGRkIiBvcGFjaXR5PSIwLjA4OTMzMzMzMzMzMzMzMzMzIiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSwzOTcpIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjZGRkIiBvcGFjaXR5PSIwLjA4OTMzMzMzMzMzMzMzMzMzIiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSwxMDgxKSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iIzIyMiIgb3BhY2l0eT0iMC4wMjg2NjY2NjY2NjY2NjY2NjciIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDQxNikiPjwvcGF0aD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiMyMjIiIG9wYWNpdHk9IjAuMDI4NjY2NjY2NjY2NjY2NjY3IiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSwxMTAwKSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iIzIyMiIgb3BhY2l0eT0iMC4xNSIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsNDM1KSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iIzIyMiIgb3BhY2l0eT0iMC4xNSIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsMTExOSkiPjwvcGF0aD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiNkZGQiIG9wYWNpdHk9IjAuMDM3MzMzMzMzMzMzMzMzMzMiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDQ1NCkiPjwvcGF0aD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiNkZGQiIG9wYWNpdHk9IjAuMDM3MzMzMzMzMzMzMzMzMzMiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDExMzgpIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMjIyIiBvcGFjaXR5PSIwLjExNTMzMzMzMzMzMzMzMzM0IiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSw0NzMpIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMjIyIiBvcGFjaXR5PSIwLjExNTMzMzMzMzMzMzMzMzM0IiBzdHJva2Utd2lkdGg9IjE5cHgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yNSwxMTU3KSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iIzIyMiIgb3BhY2l0eT0iMC4xNSIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsNDkyKSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iIzIyMiIgb3BhY2l0eT0iMC4xNSIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsMTE3NikiPjwvcGF0aD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiNkZGQiIG9wYWNpdHk9IjAuMDM3MzMzMzMzMzMzMzMzMzMiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDUxMSkiPjwvcGF0aD48cGF0aCBkPSJNMCA5MCBDIDE3LjUgMCwgMzIuNSAwLCA1MCA5MCBTIDgyLjUgMTgwLCAxMDAgOTAgUyAxMzIuNSAwLCAxNTAsIDkwIiBmaWxsPSJub25lIiBzdHJva2U9IiNkZGQiIG9wYWNpdHk9IjAuMDM3MzMzMzMzMzMzMzMzMzMiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDExOTUpIj48L3BhdGg+PHBhdGggZD0iTTAgOTAgQyAxNy41IDAsIDMyLjUgMCwgNTAgOTAgUyA4Mi41IDE4MCwgMTAwIDkwIFMgMTMyLjUgMCwgMTUwLCA5MCIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjMjIyIiBvcGFjaXR5PSIwLjA5OCIgc3Ryb2tlLXdpZHRoPSIxOXB4IiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgtMjUsNTMwKSI+PC9wYXRoPjxwYXRoIGQ9Ik0wIDkwIEMgMTcuNSAwLCAzMi41IDAsIDUwIDkwIFMgODIuNSAxODAsIDEwMCA5MCBTIDEzMi41IDAsIDE1MCwgOTAiIGZpbGw9Im5vbmUiIHN0cm9rZT0iIzIyMiIgb3BhY2l0eT0iMC4wOTgiIHN0cm9rZS13aWR0aD0iMTlweCIgdHJhbnNmb3JtPSJ0cmFuc2xhdGUoLTI1LDEyMTQpIj48L3BhdGg+PC9zdmc+

Paste the output into your browser location bar – you'll see that it's 100x684. What's going on here?

I'd expect it to at least return 100x100, maybe with an option of supplying my own height & width to better define the tile pattern.

Document options.hash

…or provide some other way of specifying the hash directly. Some idiot developer who most definitely was not myself from a few years ago decided to use user's email addresses to generate geopatterns, and now I need to either change the patterns for all users or compute the hashes server-side. It would be nice if this use case was handled/documented.

geopattern adds a large chunk after webpack build

I see that the minified version of geopattern in this repository is <20kb.
But when I bundle geopattern using webpack, it increases the size of the bundle by around 36kb.
What could be going wrong here?
I am importing geopattern as import GeoPattern from 'geopattern'.
My package.json has only the vendor packages as dependencies.

PS - Sorry, I know this is not the best place to ask this question but I couldn't find anything else.

const webpack = require('webpack');
const ExtractTextPlugin = require('extract-text-webpack-plugin');

module.exports = {
	entry: {
		app: './src/index.jsx',
		vendor: ['react', 'react-dom', 'geopattern', 'react-router-dom', 'redux']
	},
	module: {
		loaders: [{
			test: /\.jsx?$/,
			exclude: /node_modules/,
			loader: 'babel-loader',
			query: {
				presets: ['es2015', 'react']
			}
		}, {
			test: /\.css$/,
			use:  ExtractTextPlugin.extract({
				use: [{
					loader: 'css-loader',
					options: { importLoaders: 1, modules: true, localIdentName: '[local]-[hash:base64:5]' },
				}],
			}),
		}]
	},
	resolve: {
		extensions: ['.js', '.jsx']
	},
	output: {
		path: __dirname + '/dist',
		publicPath: '/dist/',
		filename: 'bundle.js'
	},
	plugins: [
		// extract text
		new ExtractTextPlugin("styles.css"),
		// minify
		new webpack.optimize.UglifyJsPlugin({
			mangle: true,
			compress: {
				warnings: false, // Suppress uglification warnings
				pure_getters: true,
				unsafe: true,
				unsafe_comps: true,
				screw_ie8: true,
				conditionals: true,
				unused: true,
				comparisons: true,
				sequences: true,
				dead_code: true,
				evaluate: true,
				if_return: true,
				join_vars: true
			},
			comments: false
		}),
		// vendor: https://webpack.github.io/docs/code-splitting.html#split-app-and-vendor-code
		new webpack.optimize.CommonsChunkPlugin({name: 'vendor', filename: 'vendor.bundle.js'})
	]
};

Get PNG images [Not an issue]

Close this after you have read it, it is not an issue with your lib at all.

I just wanted to say that I made a script that allows you to save a pattern as a PNG image, I hosted it in jsfiddle

Currently I use this when SVG images are not supported, this way I can generate the PNG image and use it in my projects... You may want to link to the script or not, just pointing out the possibility.

How to disable a pattern?

How can I disable a specific pattern when using geopattern? One of them doesn't look good in my context. I see geopattern takes a generator parameter, but I can't tell what I should supply there.

Can't find variable: Buffer

I realize this is NOT a react-native component, however, when using this on react-native, it complains 'Buffer' isn't available when running generate();

It worked beautifully prior, but after I upgraded to a newer version of iOS, it broke on this specifically. Not sure if that matters or not, but you should list buffer as a dependency.

Gap between repeats on Chrome

Chrome version: 57.0.2987.133 (64-bit)

I see gaps between repeated patterns in Chrome. I'm not sure if this is a browser bug or otherwise. You can test it by going to the demo site and typing "cs00".

screenshot 2017-04-24 23 31 21

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.