Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Browse files

missed some filename changes

  • Loading branch information...
commit c1e84d3041da817c13e5cbe06a01c5826bf7f3cd 1 parent e31f116
Scott Jehl authored
View
6 example/output/grunticon.loader.txt
@@ -0,0 +1,6 @@
+<!-- Unicode CSS Loader: place this in the head of your page -->
+<script>
+/* grunticon Stylesheet Loader | https://github.com/filamentgroup/grunticon | (c) 2012 Scott Jehl, Filament Group, Inc. | MIT license. */
+window.grunticon=function(a,b){if(!a||a.length!==3)return;var c=window,d=!!c.document.createElementNS&&!!c.document.createElementNS("http://www.w3.org/2000/svg","svg").createSVGRect,e=function(b){var e=c.document.createElement("link"),f=c.document.getElementsByTagName("script")[0];e.rel="stylesheet",e.href=a[b&&d?0:b?1:2],f.parentNode.insertBefore(e,f)},f=new c.Image;f.onerror=function(){e(!1)},f.onload=function(){e(f.width===1&&f.height===1)},f.src="data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///ywAAAAAAQABAAACAUwAOw=="};
@jefflembeck Owner

Yep, it's actually much easier to see over here: https://github.com/filamentgroup/grunticon/blob/master/tasks/grunticon/static/grunticon.loader.js#L8

This loader has two tests in it, one for svg support and one for datauri support. That 1x1px gif is to check for datauri support.

If it fails, it falls back to the non-encoded png CSS file.

@jiv-e
jiv-e added a note

I had already deleted my comment and moved it down to tasks/grunticon/static/grunticon.loader.js on this page.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
+grunticon( [ "/example/output/icons.data.svg.css", "/example/output/icons.data.png.css", "/example/output/icons.fallback.css" ] );</script>
+<noscript><link href="/example/output/icons.fallback.css" rel="stylesheet"></noscript>
View
6 example/output/icons.data.png.css
@@ -12,6 +12,8 @@
.icon-wee-gradients { background-image: url(data:image/png;base64,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); background-repeat: no-repeat; }
+.icon-wee-grunticon { background-image: url(data:image/png;base64,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); background-repeat: no-repeat; }
+
.icon-wee-Home_Media { background-image: url(data:image/png;base64,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); background-repeat: no-repeat; }
.icon-wee-Image_Exchange { background-image: url(data:image/png;base64,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); background-repeat: no-repeat; }
@@ -30,6 +32,4 @@
.icon-wee-plus { background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB4AAAAeCAYAAAA7MK6iAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEwAACxMBAJqcGAAAAfZJREFUSIntlbFrFFEQxr/Z7Msud0tM4WU5F9JECwlBTuQQW0EhlsHKP8DOIljY2AlaSer8I2IImMomKLFIAsbCNMceuYsiXKK7O/Mswt3t3nF72TXuWfhVbwdmfvvmm/ce8F8FibImaK1t3/fXp6fV9V5wCubPzq9nnue9PW8dMwfYKznWypvDF6VubH6mhqvO/VUAfw8MAKxZPh9/6H2rqUu45hBnqZELDACB9F2KJHv+H4D760gXBNaTAgNAOBGwBgLue8yS+VReUKsFQKaZHgBrrW2ttTcmZx4ADXqslLJFZGFM7qlhGI0hsO/763bZWmHNIw8IEWHr62YYB++199D2WrWIwp00KnPYEZG7hmHsJsxptVvba/uvbn06+jjmx/PpZX3t++KVpYdEtDnkMevkxF6kdGz6h8ChAEHGQTk3OLYeBJtLl2+grGZSC+y29+F3monY7WodZVUakXEmx3J6vITHzWbznlJqlXn0cBmGYR8H32qP3j2e7cbuVOt4fvPpFwnkIA3Mwg13zn1CRCeJHbuuuwFgIy1ZRBb4h+zEp9oyS5BADiqVynJablz5nkX8K3d1oc8ix9/jSd3VRbY6DuZJgQvz+KzVMY8L2vGpjqSz9eB11A3MWo7JIo0sRbKPIwARWSSi6kD4PRGd5KlXqH4DFj3WEVivzH4AAAAASUVORK5CYII=); background-repeat: no-repeat; }
-.icon-wee-star { background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACoAAAAqCAYAAADFw8lbAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEwAACxMBAJqcGAAABJ1JREFUWIXtmFtsFVUUhv+951ygrdBiLyqUA0VAUiQqMYhiQEOMGiIvSEQJUSPEC4oJiZcE5BINjWCi4gOK0fDgi76ohKgJeEGJDxoNgrZcWkgpvdHSc3p6rrP3+n2wJ2loD8zpGSAx/Ml6mdn7X1/WXjOzMsA1XZM/IumQVH77ar8NrU0eEcnu9NvXV4nIg27ik17rnmgWkeqrzZNX1vT9Ys7dRbf3KWutu81Pb9+OnuRiZvbOhO2Bcn/WlNblJCv98vcNVGxsIwY+rIQAEIDRhoiIWeeXvy+gInI/0/tmwe0GRAGioDI/OrStj4vI9X7k8AWUjG9AbHdVDjIXjG6fTNqX/MhRNKiILOTAd/VwO3AhqEr+EIB0PEGy/KqDUuIbEPuo+kLIXNiet6eQbtFVLQqU5AImDtwKtw0gRgyd3O/QdK0SkXFXHJRkiYhMF0luRd+umnzVzIX07IiQ3CQiEZKB0eTM+00WkbBSaiLJiQBqSdYDqVtAM5WSGI9MV4Cx3eUq8ZOnSkn5mh6nbHGcwWoqHeyGGtOiVPAfQDcBaAPQprU+6wnUWvsmkJoOZutAU4FMu8PMyVJm/q7Qpi0A0w2aLsDGPdYhj5wJUMEaIFADhiJphOqjauzUFJxqQgXaocItSoWPaq23jwhq3P5Wdea5WmZPAzZaHMxoFaiCLVvohm549UvllCzPXR529NZED/PEw3Ng+68s4KBYcncqEHnvc+WMfXLo9RF7lCb2uz3+yFyY81cELicpvS/pTNn2meOUrrnwXt6HyZq+X23j8nnadvk+BI8kjn9gQE/auscJlqwd6f5FIawbPWgbV9yjzFnfB+yh4oQl/U7tpo8dJ7w+35pLVsua2H7btHKRSrc6/uINqmpZVE96ZZfjhF+/2DJPx2pN/zem8ZnFOnV8VC/rfGLVir7g5JffV05486XWeu4/a+Jf2cbVD6nksWBRdINizareYOSFHUqFGrysL+hBsSa+Vw4/ugTZrtHR5XzKFwyEZr7ToHXoLa97CjtKpc+pYDWY7i4Ybqj02BlBIHCioD2FLKabncXk8Lmz0NDxxjDJ2wrJ7bmiJMfYTHc1Mn0osGOGK9UBmMRlA52K1OkApPj3P5MdgDLTCtlTyNFHJHa0PN+AXFCIhcr0BkRk4mUAlXrdf3zcJXswdKOnPmXsWCmAKb6D0rh3INGeP7kuA+rWntd3fnpA3/ttC2qWpi869Uf/rARws9f8nntUIzvTJDsxrEdVAIis7Nd1j7WowLg3tNZ7AUBEXuT01ets07uTVef3wz4SOnHWId25APZ4y+9BInKdzcYrkIkj9ycEAqB2WUIt+vqYM2PNs06o/PYcJABorXfqcNXswJytW/SCL5o5YZ4M3ctkB2DSs73k9ywRmWM6D51x982nu28+s39sSZt0TzPJYXPjSCJZQZtpMP0nm7OHnpecj0n3Nvv6L1VElrpNuwayv73mmoH2k2LMepIFj34icpN1Mx+Ynr9OmYNP0/QcOUWyzkdQs9GkOttp3c0ky4r3k2k2m9pjk11tJBf5gPifSFaKSJVvhoMSkVl+e17T/07/Aj3Cp7p9tcvlAAAAAElFTkSuQmCC); background-repeat: no-repeat; }
-
-.icon-wee-grunticon { background-image: url(data:image/png;base64,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); background-repeat: no-repeat; }
+.icon-wee-star { background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACoAAAAqCAYAAADFw8lbAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEwAACxMBAJqcGAAABJ1JREFUWIXtmFtsFVUUhv+951ygrdBiLyqUA0VAUiQqMYhiQEOMGiIvSEQJUSPEC4oJiZcE5BINjWCi4gOK0fDgi76ohKgJeEGJDxoNgrZcWkgpvdHSc3p6rrP3+n2wJ2loD8zpGSAx/Ml6mdn7X1/WXjOzMsA1XZM/IumQVH77ar8NrU0eEcnu9NvXV4nIg27ik17rnmgWkeqrzZNX1vT9Ys7dRbf3KWutu81Pb9+OnuRiZvbOhO2Bcn/WlNblJCv98vcNVGxsIwY+rIQAEIDRhoiIWeeXvy+gInI/0/tmwe0GRAGioDI/OrStj4vI9X7k8AWUjG9AbHdVDjIXjG6fTNqX/MhRNKiILOTAd/VwO3AhqEr+EIB0PEGy/KqDUuIbEPuo+kLIXNiet6eQbtFVLQqU5AImDtwKtw0gRgyd3O/QdK0SkXFXHJRkiYhMF0luRd+umnzVzIX07IiQ3CQiEZKB0eTM+00WkbBSaiLJiQBqSdYDqVtAM5WSGI9MV4Cx3eUq8ZOnSkn5mh6nbHGcwWoqHeyGGtOiVPAfQDcBaAPQprU+6wnUWvsmkJoOZutAU4FMu8PMyVJm/q7Qpi0A0w2aLsDGPdYhj5wJUMEaIFADhiJphOqjauzUFJxqQgXaocItSoWPaq23jwhq3P5Wdea5WmZPAzZaHMxoFaiCLVvohm549UvllCzPXR529NZED/PEw3Ng+68s4KBYcncqEHnvc+WMfXLo9RF7lCb2uz3+yFyY81cELicpvS/pTNn2meOUrrnwXt6HyZq+X23j8nnadvk+BI8kjn9gQE/auscJlqwd6f5FIawbPWgbV9yjzFnfB+yh4oQl/U7tpo8dJ7w+35pLVsua2H7btHKRSrc6/uINqmpZVE96ZZfjhF+/2DJPx2pN/zem8ZnFOnV8VC/rfGLVir7g5JffV05486XWeu4/a+Jf2cbVD6nksWBRdINizareYOSFHUqFGrysL+hBsSa+Vw4/ugTZrtHR5XzKFwyEZr7ToHXoLa97CjtKpc+pYDWY7i4Ybqj02BlBIHCioD2FLKabncXk8Lmz0NDxxjDJ2wrJ7bmiJMfYTHc1Mn0osGOGK9UBmMRlA52K1OkApPj3P5MdgDLTCtlTyNFHJHa0PN+AXFCIhcr0BkRk4mUAlXrdf3zcJXswdKOnPmXsWCmAKb6D0rh3INGeP7kuA+rWntd3fnpA3/ttC2qWpi869Uf/rARws9f8nntUIzvTJDsxrEdVAIis7Nd1j7WowLg3tNZ7AUBEXuT01ets07uTVef3wz4SOnHWId25APZ4y+9BInKdzcYrkIkj9ycEAqB2WUIt+vqYM2PNs06o/PYcJABorXfqcNXswJytW/SCL5o5YZ4M3ctkB2DSs73k9ywRmWM6D51x982nu28+s39sSZt0TzPJYXPjSCJZQZtpMP0nm7OHnpecj0n3Nvv6L1VElrpNuwayv73mmoH2k2LMepIFj34icpN1Mx+Ynr9OmYNP0/QcOUWyzkdQs9GkOttp3c0ky4r3k2k2m9pjk11tJBf5gPifSFaKSJVvhoMSkVl+e17T/07/Aj3Cp7p9tcvlAAAAAElFTkSuQmCC); background-repeat: no-repeat; }
View
6 example/output/icons.data.svg.css
@@ -12,6 +12,8 @@
.icon-wee-gradients { background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iaXNvLTg4NTktMSI/Pg0KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDE1LjAuMiwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgMCkgIC0tPg0KPCFET0NUWVBFIHN2ZyBQVUJMSUMgIi0vL1czQy8vRFREIFNWRyAxLjEvL0VOIiAiaHR0cDovL3d3dy53My5vcmcvR3JhcGhpY3MvU1ZHLzEuMS9EVEQvc3ZnMTEuZHRkIj4NCjxzdmcgdmVyc2lvbj0iMS4xIiBpZD0iTGF5ZXJfMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgeD0iMHB4IiB5PSIwcHgiDQoJIHdpZHRoPSIzMHB4IiBoZWlnaHQ9IjMwcHgiIHZpZXdCb3g9IjAgMCAzMCAzMCIgZW5hYmxlLWJhY2tncm91bmQ9Im5ldyAwIDAgMzAgMzAiIHhtbDpzcGFjZT0icHJlc2VydmUiPg0KPGc+DQoJDQoJCTxpbWFnZSBvdmVyZmxvdz0idmlzaWJsZSIgb3BhY2l0eT0iMC40IiB3aWR0aD0iMzMiIGhlaWdodD0iMzMiIHhsaW5rOmhyZWY9ImRhdGE6aW1hZ2UvcG5nO2Jhc2U2NCxpVkJPUncwS0dnb0FBQUFOU1VoRVVnQUFBQ0VBQUFBaENBWUFBQUJYNU1KdkFBQUFDWEJJV1hNQUFBc1NBQUFMRWdIUzNYNzhBQUFBCkdYUkZXSFJUYjJaMGQyRnlaUUJCWkc5aVpTQkpiV0ZuWlZKbFlXUjVjY2xsUEFBQUFnOUpSRUZVZU5yc21OdE9BakVRaHR1bEs0Z1EKNCtIQ3FEZSsvM05KTkI0SWNoS1czVG8xZnpkRExiV1ZGYmhna3ovTFVqcjlaanJiVGhIaUFDNFphc3p6WERZMVVGRVVPZ2tDZzB2MgptMjFnTlBUOTJRY2pOM2llZVNRU1lleGdsVWRya1ZHZXpobSt6NWxVSWdnSEtNMlkwQkxQRlRsY2d5Z25DaGFnVGVxU3pxQTJBNG1GCnNBQUwwZ3lha2o1Sks3VDlpSVNGeUFGd1NickN2UStRVmtTT2FBYXh4TUJEMGp2czIzWk5qbGNtR3NxVEN3YWlSN29tM1pOdUFkSkYKV3hZWmlSVzhIcEdlNFVTRmFVbUtoQUY0SU4wZ0dpZVJVMUpob0RraTBBWFluRTFKZ2Q5cEg0VE5pUjVBRE1BZDZaelVTWVNZSWFmTQo4NWowQ3RtSVNqTUxvYmZESm1jZkFCZE9Yc1JNUndmUFk5am9NUnZacGxkVXNvaTBRSHlDam0wWVRZRVFtQUxqekNsczVHNkNxOEJLCm1qbEFYREp5bldpeGRVWTVyN2tNTFZhK3lQZ1VzeSs1cTY3MDVWUW1kbk1GNFhjRkVieU9FRWVJZlVGb3A4SmF1MVJDNTZDaHdIYk8KcGRuOVZ3anRkQ3FaWXFvcnpiWnJ1M1ZiVmE0ekt1QkJ5VXF5QlNRUzk0NFo5ZzU3WDhCbXlVRlVZQnUyWmRrWWhZbjQ0MWIraHByQwoySmpBYm1rTFhoZENPd0FUZEg1Qys4Y1dSYzBqNlFVZ2MxN1ExT1dkQTFIQUE5TjVnTFpSQStYZEFEYW5IS0tPaEtGQm5Xa2hKcWlBCk5EbzFWZWdPRVluVnBzUjBJeUV3TGFPR1MvNDZKK3k1dzNjQzI4bmhoeDhKUTIrSGpjcS9Id01QNzBDOHI3OEd2Z1FZQU4yYUdRVUgKZkxCOEFBQUFBRWxGVGtTdVFtQ0MiIHRyYW5zZm9ybT0ibWF0cml4KDEgMCAwIDEgLTQgLTQpIj4NCgk8L2ltYWdlPg0KCTxnPg0KCQk8bGluZWFyR3JhZGllbnQgaWQ9IlNWR0lEXzFfIiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSIgeDE9IjEyLjUwMDUiIHkxPSIyMS4zMTI1IiB4Mj0iMTIuNTAwNSIgeTI9IjIuMzEzIj4NCgkJCTxzdG9wICBvZmZzZXQ9IjAiIHN0eWxlPSJzdG9wLWNvbG9yOiMzOUI1NEEiLz4NCgkJCTxzdG9wICBvZmZzZXQ9IjEiIHN0eWxlPSJzdG9wLWNvbG9yOiNEOUUwMjEiLz4NCgkJPC9saW5lYXJHcmFkaWVudD4NCgkJPHBhdGggZmlsbD0idXJsKCNTVkdJRF8xXykiIGQ9Ik0yMiwxOS4zMTJjMCwxLjEtMC45LDItMiwySDVjLTEuMSwwLTItMC45LTItMnYtMTVjMC0xLjEsMC45LTIsMi0yaDE1YzEuMSwwLDIsMC45LDIsMlYxOS4zMTJ6Ii8+DQoJCTxwYXRoIGZpbGw9Im5vbmUiIHN0cm9rZT0iI0ZGRkZGRiIgc3Ryb2tlLW1pdGVybGltaXQ9IjEwIiBkPSJNMjIsMTkuMzEyYzAsMS4xLTAuOSwyLTIsMkg1Yy0xLjEsMC0yLTAuOS0yLTJ2LTE1YzAtMS4xLDAuOS0yLDItMg0KCQkJaDE1YzEuMSwwLDIsMC45LDIsMlYxOS4zMTJ6Ii8+DQoJPC9nPg0KPC9nPg0KPGcgb3BhY2l0eT0iMC44Ij4NCgkNCgkJPGltYWdlIG92ZXJmbG93PSJ2aXNpYmxlIiBvcGFjaXR5PSIwLjQiIHdpZHRoPSIyOSIgaGVpZ2h0PSIyOCIgeGxpbms6aHJlZj0iZGF0YTppbWFnZS9wbmc7YmFzZTY0LGlWQk9SdzBLR2dvQUFBQU5TVWhFVWdBQUFCMEFBQUFjQ0FZQUFBQ2R6N1NxQUFBQUNYQklXWE1BQUFzU0FBQUxFZ0hTM1g3OEFBQUEKR1hSRldIUlRiMlowZDJGeVpRQkJaRzlpWlNCSmJXRm5aVkpsWVdSNWNjbGxQQUFBQXJaSlJFRlVlTnFzbHc5VDJrQVF4VU11Q1FXbApTcTFEYWNkYTIrLy9uZG95OXA5WXJGQUJReEwzNHR2NlhBNElNMlhtVFV6ZzdyZHZiMjl6dW1pUFQ1cW1MZWRjVUdWWk5wN0g3UUdLCjVkYXJoU3ZmNjIraUpnRzRYVUJNNnFERVA4WlY1UmlPQUxiQzNRNWdUS0MycUdQMFFwUlJJQXAvbkZ6Z0liQnJBUFN3QTlGTDBiR28KRHgzaDJTRUNTREdmSDF1cFFtQzNCWmpDU1U5MElocUlocUszb2plNGY0MEFlZ0FuNU5SRHl4RFliWEdvd0ZPQTNvcys0SHFHQUJSOApCTWNweG50Q2dXdE5FMmkxQnFXaTBaUXk4RUwwQ2RkejBUdTRQVVVXanJFRUdhYnp3SHRScm5CMjYyalJ0VXBUVEhCaWdCL2hjZ2gzCnJ3RFRkZTBpNEFxd0phVGdTdDB5Tk1aOUd4TU5BRkhnR1o3MThmMkJxV0pOYlFIWUhlVC9YckZiRjFqTERod01zWVlYZ0Evd3ZFdVEKeEd5WENJQzU2QzgwUjZyVjdTTVVxVzFoZ2c3Y2FQR2NJNEErZ0pscEN0eVpTZ0M4dzZub1ZqUVRMUkJNbmVLRWlwZTdqMjZYTGpscgowMTZNYVV4bHhoeWlDSFgvWnJSLzYwOGM2QTB0YW5rc2JuV2hNZHk5VXBQMmYyUDlVc2JSLy90VTFCQlkrcnorVFo3blZieGhjSUUxCllBVW5JVkNCN2JGQThjenRsbEZBRW9pVUIydlo2d1NwU1ZjRTRDcFFRRk5VNzVLNjA5TStwZXExVGI1SEc5OFdoQTNRUTY1RjMwVmYKUlNQUkQ5RU5nbjYrWmVvLzFzRVo0QmtCWTBybkNpN21jUFlid0JHZ2w2SXJiQmwxKzlRYzlOM0hMMkp6UW9nQ3FWeGd3Z2ttVitCbgpjamxCeXV1YThFVVU2cjJiS2xGQlMrbzJmNURPbjNEMUJSb2hnR3VrZk1tcGZRWkZpamNWRmNOdTRXQU1ONWVVVWdXTzhidUZkYm4yClBpV3czUWJhd0dmazhBclFiNlJmV0Z0dGZUbTlUemVmSEFKZ1hrTjFla1BnTVRUQmQzZnNVQnZDempQU0RzZWE1aWxwUnJDYzltVmsKZ1Z0UGd3Yk1YU3Fub2xMZDQ3dUMzZTE5QkZWd0FLN09DM01PMmdscmZNSm51SDhYbWdBcUJqWDkxK0pCZ0FFQTk3dVFZNklnMU04QQpBQUFBU1VWT1JLNUNZSUk9IiB0cmFuc2Zvcm09Im1hdHJpeCgxIDAgMCAxIDYgNykiPg0KCTwvaW1hZ2U+DQoJPGc+DQoJCTxyYWRpYWxHcmFkaWVudCBpZD0iU1ZHSURfMl8iIGN4PSIyMC42MDk0IiBjeT0iMTkuOTIxOSIgcj0iNy40MjE5IiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSI+DQoJCQk8c3RvcCAgb2Zmc2V0PSIwIiBzdHlsZT0ic3RvcC1jb2xvcjojMDBGRkZGIi8+DQoJCQk8c3RvcCAgb2Zmc2V0PSIxIiBzdHlsZT0ic3RvcC1jb2xvcjojMjlBQkUyIi8+DQoJCTwvcmFkaWFsR3JhZGllbnQ+DQoJCTxjaXJjbGUgZmlsbD0idXJsKCNTVkdJRF8yXykiIGN4PSIyMC42MDkiIGN5PSIxOS45MjIiIHI9IjcuNDIyIi8+DQoJCTxjaXJjbGUgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjRkZGRkZGIiBzdHJva2UtbWl0ZXJsaW1pdD0iMTAiIGN4PSIyMC42MDkiIGN5PSIxOS45MjIiIHI9IjcuNDIyIi8+DQoJPC9nPg0KPC9nPg0KPC9zdmc+DQo=); background-repeat: no-repeat; }
+.icon-wee-grunticon { background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDE1LjAuMCwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgMCkgIC0tPgo8IURPQ1RZUEUgc3ZnIFBVQkxJQyAiLS8vVzNDLy9EVEQgU1ZHIDEuMS8vRU4iICJodHRwOi8vd3d3LnczLm9yZy9HcmFwaGljcy9TVkcvMS4xL0RURC9zdmcxMS5kdGQiPgo8c3ZnIHZlcnNpb249IjEuMSIgaWQ9IkxheWVyXzEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4IgoJIHdpZHRoPSIxMDBweCIgaGVpZ2h0PSIxMDBweCIgdmlld0JveD0iMCAwIDEwMCAxMDAiIGVuYWJsZS1iYWNrZ3JvdW5kPSJuZXcgMCAwIDEwMCAxMDAiIHhtbDpzcGFjZT0icHJlc2VydmUiPgo8cGF0aCBmaWxsPSIjNDczRTEyIiBkPSJNNjguNzQ1LDY3LjIxN3YwLjA2M2wxMS40MDEsMy4wNTZsMC4wMDItMC4wMDF2MTEuNDgxYy0wLjAwMiwyLjQwOCwxLjk1Myw0LjM2Myw0LjM1OSw0LjM2MQoJYzIuNDA2LDAsNC4zODUtMS45NTMsNC4zODUtNC4zNjFWNjMuNjMxbC0xNi4yMjktNC4zNTRMNjguNzQ1LDY3LjIxN3oiLz4KPHBhdGggZmlsbD0iIzY4NTkzOCIgZD0iTTk2LjA1NywyOS42MmwtMTIuOTM2LTguNjAxTDk2Ljc4OC0wLjI0Nkw3OS42ODYsMTcuNjY5bC0xLjc4OS00LjA3MmwtMi4wMTcsOC4wM2wtMTkuMDk3LDE5Ljc2SDE5LjM3NgoJYzAtNS4yMzMtNC40MDktOS43NTUtOS42NzctOS43NTVDNC4zNCwzMS42MzIsMCwzNS45OTMsMCw0MS4zNTR2MTYuMTA1aDYuOTA2YzAsMCwwLTEzLjc5MywwLTE1Ljk0NwoJYzAtMi4xNTQsMC41MjItNS40OTcsMy41ODktNS40OTdjMy4xMTUsMCwzLjU3LDIuODk4LDMuNTg3LDUuMzcybDAsMGwtMC4wMDQsNC4zODRWNjQuOTJsLTMuNjEyLDUuNjU1Vjk0Ljk3CgljMCwyLjQwOSwxLjk3Niw0LjM2Miw0LjM4NCw0LjM2MmMyLjQwNiwwLDQuMzYxLTEuOTUzLDQuMzYxLTQuMzYyVjczLjg0OGw0LjgyMy03LjU4OGgzNC41NDJ2MjguNzEKCWMwLDIuNDA5LDEuOTU1LDQuMzYyLDQuMzYxLDQuMzYyYzIuNDA4LDAsNC4zODUtMS45NTMsNC4zODUtNC4zNjJWNjYuODg1bDE1LjE5NS0zMC43NjhsMTAuNDk0LDEuOTk4CgljMS44MzgsMC4zNDIsMy43OTMtMC40OTksNC43NjgtMi4yMzdDOTkuMDMyLDMzLjY4Niw5OC4yMzYsMzAuODY5LDk2LjA1NywyOS42MnoiLz4KPHBhdGggZmlsbD0iI0U1MjM1RiIgZD0iTTgzLjEyMSwyMS4wMTlMOTYuNzg4LTAuMjQ2TDc5LjY4NiwxNy42NjkiLz4KPC9zdmc+Cg==); background-repeat: no-repeat; }
+
.icon-wee-Home_Media { background-image: url(data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8"?>
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentScriptType="text/ecmascript" zoomAndPan="magnify" baseProfile="tiny" contentStyleType="text/css" version="1.1" width="44px" preserveAspectRatio="xMidYMid meet" viewBox="0 0 44 44" height="44px" x="0px" y="0px">
    <g>
        <rect width="43.999" fill="none" height="44"/>
    </g>
    <g>
        <path d="M 39.269 19.707 C 38.847 19.082 38.464 18.448 37.940002 17.905 C 36.093002 16.885 34.376003 15.451 32.644 14.252001 C 28.654001 11.488001 24.663002 8.724001 20.672 5.9610004 C 16.324001 8.957001 11.990001 11.974001 7.649001 14.979 C 6.287001 15.923 4.794001 16.781 3.526001 17.846 C 2.533001 18.679 1.868001 20.019001 1.151001 21.091 L 4.5490007 21.091 L 4.5490007 36.265 C 13.329 36.265 22.111 36.267 30.89 36.269 C 32.859 36.269 34.826 36.269 36.791 36.269 L 36.791 21.092 L 40.2 21.092 L 39.269 19.707 " fill-opacity="0.2"/>
        <path d="M 38.529 20.203 C 38.029 19.46 37.642998 18.794998 36.906 18.289 L 36.904 18.289 C 31.497 14.535999 26.083 10.789 20.671 7.0429993 C 16.746 9.757999 12.824999 12.478999 8.901999 15.195 C 7.6189995 16.084 6.3359995 16.972 5.0519996 17.862 C 4.6139994 18.166 4.042 18.466 3.6999996 18.887 C 3.3719995 19.293 3.1039996 19.771 2.8149996 20.203 L 5.44 20.203 L 5.44 35.377 C 14.299 35.377 23.159 35.377 32.017 35.377 C 33.311996 35.377 34.608997 35.377 35.901997 35.377 L 35.901997 20.203 L 38.529 20.203 " fill-opacity="0.4"/>
    </g>
    <g>
        <path fill="#636363" d="M 35.9 17.76 C 35.9 17.482 35.9 17.204 35.9 16.925001 L 34.698 16.925001 L 20.61 7.126 L 7.36 16.925 L 5.44 16.925 L 5.44 34.488 C 14.299999 34.488 23.159 34.488 32.019 34.488 C 33.314 34.488 34.609 34.488 35.903 34.488 L 35.903 18.587 C 36.065 18.423 36.228 18.26 36.391 18.098 L 35.9 17.76 "/>
        <linearGradient x1="188.6943" gradientTransform="matrix(1 0 0 -1 -168 -850)" y1="-883.6855" x2="188.6943" gradientUnits="userSpaceOnUse" y2="-858.1157" xlink:type="simple" xlink:actuate="onLoad" id="SVGID_1_" xlink:show="other">
            <stop stop-color="#e8e8e8" offset="0"/>
            <stop stop-color="#c9ccd9" offset="1"/>
        </linearGradient>
        <polyline fill="url(#SVGID_1_)" points="35.145,18.212 35.099,18.181 35.099,17.729 34.447,17.729 20.626,8.116 7.626,17.729    6.244,17.729 6.244,33.686 35.099,33.686 35.099,18.255 35.145,18.212  "/>
        <rect x="24.307" width="7.514" fill="#777777" y="22.729" height="7.514"/>
        <linearGradient x1="198.9297" gradientTransform="matrix(1 0 0 -1 -168 -850)" y1="-876.4849" x2="193.1953" gradientUnits="userSpaceOnUse" y2="-876.4849" xlink:type="simple" xlink:actuate="onLoad" id="SVGID_2_" xlink:show="other">
            <stop stop-color="#e8e8e8" offset="0"/>
            <stop stop-color="#c9ccd9" offset="1"/>
        </linearGradient>
        <polyline fill="url(#SVGID_2_)" points="25.196,23.619 30.931,23.619 30.931,29.352 25.196,29.352 25.196,23.619  "/>
        <polyline fill="#777777" points="31.288,26.039 28.468,26.039 28.468,23.273 27.66,23.273 27.66,26.039 24.838,26.039    24.838,26.844 27.66,26.844 27.66,29.473 28.468,29.473 28.468,26.844 31.288,26.844 31.288,26.039  "/>
        <rect x="11.224" width="8.009" fill="#513511" y="22.017" height="11.667"/>
        <linearGradient x1="183.2285" gradientTransform="matrix(1 0 0 -1 -168 -850)" y1="-882.793" x2="183.2285" gradientUnits="userSpaceOnUse" y2="-872.9082" xlink:type="simple" xlink:actuate="onLoad" id="SVGID_3_" xlink:show="other">
            <stop stop-color="#d16b07" offset="0"/>
            <stop stop-color="#9b510e" offset="1"/>
        </linearGradient>
        <polyline fill="url(#SVGID_3_)" points="12.115,22.908 18.342,22.908 18.342,32.793 12.115,32.793 12.115,22.908  "/>
        <g>
            <path fill="#513511" d="M 12.915 23.781 L 14.49 23.781 L 14.49 26.519001 L 14.473 26.519001 C 14.592 26.638 14.712 26.759 14.832 26.876001 L 14.848 26.876001 C 14.848 25.724 14.848 24.571001 14.848 23.421001 L 12.573 23.421001 C 12.7 23.531 12.816 23.652 12.915 23.781 M 14.67 26.521 L 14.67 26.699 L 14.67 26.521 z " fill-opacity="0.5"/>
            <path fill="#f4a44d" d="M 14.473 26.521 L 12.898 26.521 L 12.898 23.783 L 12.915 23.783 C 12.816 23.652 12.699 23.533 12.573 23.428001 L 12.539 23.428001 L 12.539 26.881 L 14.830999 26.881 C 14.712 26.76 14.593 26.639 14.473 26.521 " fill-opacity="0.5"/>
            <path fill="#513511" d="M 15.933 23.781 L 17.507 23.781 L 17.507 26.519001 L 17.49 26.519001 C 17.609 26.638 17.729 26.759 17.848999 26.876001 L 17.865 26.876001 C 17.865 25.724 17.865 24.571001 17.865 23.421001 L 15.589 23.421001 C 15.716 23.531 15.833 23.652 15.933 23.781 M 17.686 26.521 L 17.686 26.699 L 17.686 26.521 z " fill-opacity="0.5"/>
            <path fill="#f4a44d" d="M 17.49 26.521 L 15.914 26.521 L 15.914 23.783 L 15.933 23.783 C 15.834 23.652 15.716 23.533 15.589999 23.428001 L 15.556999 23.428001 L 15.556999 26.881 L 17.848999 26.881 C 17.729 26.76 17.609 26.639 17.49 26.521 " fill-opacity="0.5"/>
            <path fill="#513511" d="M 12.915 29.264 L 14.49 29.264 L 14.49 32.0 L 14.473 32.0 C 14.592 32.121 14.712 32.24 14.832 32.359 L 14.848 32.359 C 14.848 31.207 14.848 30.056002 14.848 28.904001 L 12.573 28.904001 C 12.7 29.012 12.816 29.135 12.915 29.264 M 14.67 32.0 L 14.67 32.182 L 14.67 32.0 z " fill-opacity="0.5"/>
            <path fill="#f4a44d" d="M 14.473 32.0 L 12.898 32.0 L 12.898 29.264 L 12.915 29.264 C 12.816 29.135 12.699 29.012 12.573 28.905 L 12.539 28.905 L 12.539 32.364002 L 14.830999 32.364002 C 14.712 32.24 14.593 32.121 14.473 32.0 " fill-opacity="0.5"/>
            <path fill="#513511" d="M 15.933 29.264 L 17.507 29.264 L 17.507 32.0 L 17.49 32.0 C 17.609 32.121 17.729 32.24 17.848999 32.359 L 17.865 32.359 C 17.865 31.207 17.865 30.056002 17.865 28.904001 L 15.589 28.904001 C 15.716 29.012 15.833 29.135 15.933 29.264 M 17.686 32.0 L 17.686 32.182 L 17.686 32.0 z " fill-opacity="0.5"/>
            <path fill="#f4a44d" d="M 17.49 32.0 L 15.914 32.0 L 15.914 29.264 L 15.933 29.264 C 15.834 29.135 15.716 29.012 15.589999 28.905 L 15.556999 28.905 L 15.556999 32.364002 L 17.848999 32.364002 C 17.729 32.24 17.609 32.121 17.49 32.0 " fill-opacity="0.5"/>
        </g>
        <polyline fill="#f9f9f9" fill-opacity="0.4" points="6.773,18.868 6.773,33.064 34.652,18.6 20.896,8.385 6.866,17.729    6.773,18.868  "/>
        <path fill="#990719" d="M 38.529 19.315 C 38.029 18.573 37.642998 17.906 36.904 17.401001 L 36.903 17.401001 C 31.496 13.649001 26.083 9.902 20.67 6.1550007 C 16.743 8.867001 12.823999 11.59 8.901 14.307001 C 7.618 15.196001 6.334 16.084002 5.051 16.974 C 4.612 17.278002 4.0420003 17.578001 3.6990001 17.999 C 3.371 18.402 3.104 18.881 2.815 19.313 L 6.91 19.313 C 11.514 16.161999 16.084 12.959999 20.67 9.783999 C 25.254 12.959 29.796001 16.210999 34.429 19.313 L 34.57 19.313 L 34.57 19.315 L 38.529 19.315 "/>
        <linearGradient x1="188.6719" gradientTransform="matrix(1 0 0 -1 -168 -850)" y1="-857.1309" x2="188.6719" gradientUnits="userSpaceOnUse" y2="-868.5112" xlink:type="simple" xlink:actuate="onLoad" id="SVGID_4_" xlink:show="other">
            <stop stop-color="#ff0000" offset="0"/>
            <stop stop-color="#a80000" offset="1"/>
        </linearGradient>
        <path fill="url(#SVGID_4_)" d="M 6.662 18.511 C 8.119 17.501 11.741 14.993 20.672 8.806999 C 25.342001 12.041999 30.017002 15.268 34.683 18.511 L 37.024 18.511 C 36.979 18.438 36.913 18.378 36.842 18.33 L 36.842 18.33 C 31.47 14.573999 26.062 10.864 20.674 7.13 C 17.131 9.584 13.587999 12.037001 10.044 14.491 C 9.089 15.153 8.134 15.815001 7.1779995 16.477 C 6.5139995 16.936998 5.8489995 17.397999 5.1849995 17.856998 C 4.9259996 18.034998 4.5029993 18.235998 4.3189993 18.508999 L 6.662 18.511 M 4.708 18.229 C 4.678 18.241 4.649 18.253 4.6200004 18.266 L 4.6200004 18.266 C 4.639 18.257 4.661 18.248 4.708 18.229 "/>
    </g>
    <g>
        <circle r="7.739" fill-opacity="0.4" cx="33.428" cy="31.176"/>
        <path d="M 25.221 31.176 C 25.223001 26.643002 28.895 22.967001 33.428 22.966 L 33.428 22.966 L 33.428 23.438 L 33.428 23.907 C 29.413002 23.907 26.157001 27.161 26.157001 31.178 L 26.157001 31.178 C 26.157001 35.193 29.413002 38.448997 33.428 38.448997 L 33.428 38.448997 C 37.444 38.449997 40.699 35.192997 40.699 31.177998 L 40.699 31.177998 C 40.699 27.159998 37.443 23.906998 33.428 23.906998 L 33.428 23.906998 L 33.428 23.437998 L 33.428 22.967999 C 37.961002 22.97 41.634003 26.642998 41.637 31.175999 L 41.637 31.175999 C 41.634003 35.709 37.961002 39.384 33.428 39.385 L 33.428 39.385 C 28.895 39.382 25.223 35.708 25.221 31.176 L 25.221 31.176 z " fill-opacity="0.2"/>
        <radialGradient gradientTransform="matrix(1 0 0 -1 -348.0039 -851.0117)" gradientUnits="userSpaceOnUse" xlink:type="simple" r="7.3477" xlink:actuate="onLoad" cx="381.4316" id="SVGID_5_" cy="-881.7188" xlink:show="other">
            <stop stop-color="#0082e2" offset="0"/>
            <stop stop-color="#25427c" offset="1"/>
        </radialGradient>
        <circle fill="url(#SVGID_5_)" r="7.348" cx="33.428" cy="30.707"/>
        <linearGradient x1="381.4854" gradientTransform="matrix(1 0 0 -1 -348.0039 -851.0117)" y1="-881.6563" x2="381.4854" gradientUnits="userSpaceOnUse" y2="-874.6055" xlink:type="simple" xlink:actuate="onLoad" id="SVGID_6_" xlink:show="other">
            <stop stop-color="#5487fc" offset="0"/>
            <stop stop-color="#c2f1ff" offset="1"/>
        </linearGradient>
        <path fill="url(#SVGID_6_)" d="M 40.531 30.656 C 40.531 26.761 37.373997 23.605 33.48 23.605 C 29.585 23.605 26.428999 26.761 26.428999 30.656 L 40.531 30.656 z "/>
        <radialGradient gradientTransform="matrix(1 0 0 -1 -736.0098 -1656.0234)" gradientUnits="userSpaceOnUse" xlink:type="simple" r="3.8318" xlink:actuate="onLoad" cx="770.832" id="SVGID_7_" cy="-1686.9141" xlink:show="other">
            <stop stop-color="#0082e2" offset="0"/>
            <stop stop-color="#25427c" offset="1"/>
        </radialGradient>
        <polygon fill="url(#SVGID_7_)" points="30.941,27.145 30.941,34.686 38.725,30.005  "/>
        <linearGradient x1="382.4961" gradientTransform="matrix(1 0 0 -1 -348.0039 -851.0117)" y1="-878.8662" x2="382.4961" gradientUnits="userSpaceOnUse" y2="-884.8301" xlink:type="simple" xlink:actuate="onLoad" id="SVGID_8_" xlink:show="other">
            <stop stop-color="#fff2fc" offset="0"/>
            <stop stop-color="#bdd0e0" offset="1"/>
        </linearGradient>
        <polygon fill="url(#SVGID_8_)" points="31.415,27.866 31.415,33.83 37.57,30.13  "/>
    </g>
</svg>
); background-repeat: no-repeat; }
.icon-wee-Image_Exchange { background-image: url(data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8"?>
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" contentScriptType="text/ecmascript" zoomAndPan="magnify" baseProfile="tiny" contentStyleType="text/css" version="1.1" width="44px" preserveAspectRatio="xMidYMid meet" viewBox="0 0 44 44" height="44px" x="0px" y="0px">
    <g>
        <g>
            <path d="M 5.027 8.896 C 5.027 17.796 5.027 26.695 5.027 35.598 C 5.027 35.721 5.027 35.843998 5.027 35.967 C 13.747999 35.967 22.469 35.967 31.192001 35.967 C 32.834 35.967 34.475002 35.967 36.118 35.967 L 36.118 35.966 L 39.167 35.966 C 39.167 26.958 39.168 17.951 39.169 8.942999 C 39.169 8.926999 39.169 8.911999 39.169 8.895999 L 5.027 8.895999 " fill-opacity="0.2" stroke-opacity="0.2"/>
            <path d="M 6.028 8.897 C 6.028 17.587 6.028 26.277 6.028 34.968 C 14.727 34.968 23.425 34.968 32.123 34.968 C 34.139 34.968 36.152 34.968 38.168 34.966 C 38.168 26.278 38.168 17.587 38.168 8.896999 L 6.028 8.896999 " fill-opacity="0.4" stroke-opacity="0.4"/>
            <linearGradient x1="78.0977" gradientTransform="matrix(1 0 0 -1 -56 -102)" y1="-110.897" x2="78.0977" gradientUnits="userSpaceOnUse" y2="-135.9678" xlink:type="simple" xlink:actuate="onLoad" id="SVGID_1_" xlink:show="other">
                <stop stop-color="#ececec" offset="0"/>
                <stop stop-color="#dcdcdc" offset="1"/>
            </linearGradient>
            <path fill="url(#SVGID_1_)" d="M 6.028 8.897 C 6.028 17.254002 6.028 25.611 6.028 33.968 C 14.727 33.968 23.425 33.968 32.123 33.968 C 34.139 33.968 36.152 33.968 38.168 33.966 C 38.168 25.61 38.168 17.254 38.168 8.896999 L 6.028 8.896999 "/>
            <linearGradient x1="280.0996" gradientTransform="matrix(1 0 0 -1 -258.002 -981.0039)" y1="-1012.9209" x2="280.0996" gradientUnits="userSpaceOnUse" y2="-991.9521" xlink:type="simple" xlink:actuate="onLoad" id="SVGID_2_" xlink:show="other">
                <stop stop-color="#ffffff" offset="0"/>
                <stop stop-color="#ffffff" offset="0.3571"/>
                <stop stop-color="#0aabff" offset="1"/>
            </linearGradient>
            <rect x="8.078" width="28.038" fill="url(#SVGID_2_)" y="10.948" height="20.969"/>
            <g>
                <linearGradient x1="277.5205" gradientTransform="matrix(1 0 0 -1 -258.002 -981.0039)" y1="-991.9473" x2="277.5205" gradientUnits="userSpaceOnUse" y2="-1012.9177" xlink:type="simple" xlink:actuate="onLoad" id="SVGID_3_" xlink:show="other">
                    <stop stop-color="#0032bf" offset="0"/>
                    <stop stop-color="#0032bf" offset="0.0714"/>
                    <stop stop-color="#7de0ff" offset="0.9231"/>
                    <stop stop-color="#7de0ff" offset="1"/>
                </linearGradient>
                <rect x="8.078" width="22.881" fill="url(#SVGID_3_)" y="25.823" height="6.094"/>
                <polygon fill="#453e60" points="35.588,26.41 35.063,23.714 27.387,18.558 26.506,18.91 25.686,19.085 23.313,17.357      22.288,18.383 18.362,15.687 17.308,17.796 15.022,17.445 8.078,21.182 8.078,26.686 13.792,26.41    "/>
                <linearGradient x1="284.5371" gradientTransform="matrix(1 0 0 -1 -258.002 -981.0039)" y1="-996.6909" x2="284.5371" gradientUnits="userSpaceOnUse" y2="-1006.9453" xlink:type="simple" xlink:actuate="onLoad" id="SVGID_4_" xlink:show="other">
                    <stop stop-color="#ffffff" offset="0"/>
                    <stop stop-color="#82d4ff" offset="1"/>
                </linearGradient>
                <path fill="url(#SVGID_4_)" d="M 18.567 17.065 C 18.567 17.065 19.005999 18.675001 19.005999 18.91 C 19.005999 19.145 17.717999 19.437 17.717999 19.437 L 18.068998 20.023 L 18.068998 20.491001 L 18.068998 21.136002 L 19.651 23.071001 C 19.651 23.071001 22.23 26.526001 26.857998 25.764002 C 31.486998 25.002003 35.353996 25.942001 35.353996 25.942001 L 35.353996 25.213001 L 35.060997 23.714 L 27.895 18.9 C 27.592001 18.779999 27.364 18.682 27.244 18.616 L 27.022 18.703999 C 27.014 19.041998 27.151 19.73 27.151 19.73 L 26.505999 19.73 L 25.685999 19.085 L 25.335 19.085 L 23.577 17.561998 L 23.107 17.561998 L 22.288 18.381998 L 21.939 18.143997 L 23.229 19.432997 C 23.229 19.432997 22.563 18.767996 21.939 18.142998 L 20.446 17.117998 L 20.446 17.117998 L 20.445 17.117998 L 19.640999 16.566998 L 19.357998 16.566998 L 18.734999 15.943997 L 18.359999 15.686997 L 18.265 15.877997 L 18.828999 16.800997 L 18.567 17.065 z " fill-opacity="0.9" stroke-opacity="0.9"/>
                <linearGradient x1="274.4258" gradientTransform="matrix(1 0 0 -1 -258.002 -981.0039)" y1="-1006.0039" x2="274.4258" gradientUnits="userSpaceOnUse" y2="-1008.2996" xlink:type="simple" xlink:actuate="onLoad" id="SVGID_5_" xlink:show="other">
                    <stop stop-color="#a3c600" offset="0"/>
                    <stop stop-color="#0a4d0a" offset="1"/>
                </linearGradient>
                <path fill="url(#SVGID_5_)" d="M 24.572 26.41 C 22.771 25.532999 11.761001 25.14 8.078001 25.036 L 8.078001 27.289999 C 12.745 27.309 26.585 27.389 24.572 26.41 z "/>
                <linearGradient x1="283.8906" gradientTransform="matrix(1 0 0 -1 -258.002 -981.0039)" y1="-1006.0664" x2="283.8906" gradientUnits="userSpaceOnUse" y2="-1015.7914" xlink:type="simple" xlink:actuate="onLoad" id="SVGID_6_" xlink:show="other">
                    <stop stop-color="#a8c600" offset="0"/>
                    <stop stop-color="#0a4d0a" offset="1"/>
                </linearGradient>
                <path fill="url(#SVGID_6_)" d="M 26.214 26.41 C 26.214 26.41 30.022001 26.41 31.02 27.112999 C 31.856 27.703 19.993 30.776999 15.661 31.917 L 36.119 31.917 L 36.119 26.982 C 35.39 26.163 34.418 25.062 34.418 25.062 L 26.214 26.41 z "/>
            </g>
            <g>
                <linearGradient x1="68.6914" gradientTransform="matrix(1 0 0 -1 -56 -102)" y1="-119.4448" x2="68.6914" gradientUnits="userSpaceOnUse" y2="-127.8232" xlink:type="simple" xlink:actuate="onLoad" id="SVGID_7_" xlink:show="other">
                    <stop stop-color="#22c600" offset="0"/>
                    <stop stop-color="#0a4d0a" offset="1"/>
                </linearGradient>
                <path fill="url(#SVGID_7_)" d="M 16.504 22.624 L 16.205 24.218 L 15.672 22.089 L 15.346 23.827002 L 14.576 20.750002 L 14.057 23.514002 L 13.366 20.750002 L 13.14 21.955002 L 12.438001 19.145002 L 11.978001 21.595003 L 10.940001 17.445004 L 9.782001 23.612003 L 9.0460005 20.669003 L 8.078 25.824003 C 11.153 25.824003 14.229 25.824003 17.304 25.824003 L 16.504 22.624 "/>
                <linearGradient x1="88.2441" gradientTransform="matrix(1 0 0 -1 -56 -102)" y1="-122.1572" x2="88.2441" gradientUnits="userSpaceOnUse" y2="-131.5049" xlink:type="simple" xlink:actuate="onLoad" id="SVGID_8_" xlink:show="other">
                    <stop stop-color="#22c600" offset="0"/>
                    <stop stop-color="#0a770a" offset="1"/>
                </linearGradient>
                <path fill="url(#SVGID_8_)" d="M 35.107 20.157 L 34.125 24.088999 L 33.809 22.404 L 32.842 26.271 L 32.114998 22.404 L 31.037998 26.713 L 30.579998 24.275 L 29.834997 27.257 L 29.415997 25.025 L 28.296997 29.504 C 30.902996 29.504 33.51 29.504 36.115997 29.504 C 36.115997 28.119 36.315998 26.595 36.059998 25.233 C 35.743 23.541 35.425 21.849 35.107 20.157 "/>
            </g>
            <g>
                <polygon fill="#ffffff" fill-opacity="0.3" stroke-opacity="0.3" points="6.028,8.897 6.028,10.948 6.028,21.182 6.028,25.037      6.028,25.824 6.028,26.686 6.028,27.29 6.028,31.917 6.028,33.968 6.108,33.968 37.872,8.897    "/>
            </g>
        </g>
        <g>
            <path d="M 38.891 25.97 C 38.659 25.893 38.409 26.028 38.310997 26.292 C 35.958996 32.586 31.863997 34.794 27.261997 34.818 C 22.939997 34.824 18.214996 32.773003 14.4489975 30.086 L 16.582998 25.331001 C 16.669998 25.137001 16.654999 24.908 16.546999 24.730001 C 16.439999 24.556002 16.255 24.464 16.071999 24.501001 L 3.71 26.883 C 3.5570002 26.911999 3.427 27.026 3.356 27.185999 C 3.284 27.348 3.284 27.536999 3.352 27.699999 L 8.796 40.656 C 8.877 40.845997 9.042 40.970997 9.224999 40.973 C 9.407999 40.977 9.577 40.862 9.662999 40.674 L 11.639999 36.392998 C 16.602 39.725 21.285 41.330997 25.369 41.331997 C 25.392 41.331997 25.414 41.331997 25.437 41.331997 C 32.732002 41.331997 38.075 35.989998 39.242 26.604996 C 39.275 26.32 39.124 26.047 38.891 25.97 z " fill-opacity="0.2" stroke-opacity="0.2"/>
            <path d="M 38.759 26.521 C 36.912 41.0 25.352 45.189 11.45 35.604 L 9.235 40.406 L 3.791 27.449 L 16.152 25.067999 L 13.806001 30.294998 C 21.695 36.102 34.02 39.344 38.759 26.521 z " fill-opacity="0.5" stroke-opacity="0.5"/>
            <linearGradient x1="-1166.2793" gradientTransform="matrix(-0.9907 -0.1358 -0.1358 0.9907 -979.5844 -1259.5889)" y1="1137.0039" x2="-1168.3231" gradientUnits="userSpaceOnUse" y2="1151.9115" xlink:type="simple" xlink:actuate="onLoad" id="SVGID_9_" xlink:show="other">
                <stop stop-color="#32abcc" offset="0"/>
                <stop stop-color="#0045bf" offset="1"/>
            </linearGradient>
            <path fill="url(#SVGID_9_)" d="M 38.928 25.352 C 37.08 39.83 25.52 44.021 11.619 34.438 L 9.405001 39.235 L 3.957 26.281 L 16.319 23.898 L 13.974 29.126001 C 21.865 34.932 34.188 38.172 38.928 25.352 z "/>
            <linearGradient x1="231.5439" gradientTransform="matrix(1 0 0 1 -212.0024 -849.0029)" y1="875.0273" x2="231.5439" gradientUnits="userSpaceOnUse" y2="886.3684" xlink:type="simple" xlink:actuate="onLoad" id="SVGID_10_" xlink:show="other">
                <stop stop-color="#33d9ff" offset="0"/>
                <stop stop-color="#00a8eb" offset="1"/>
            </linearGradient>
            <path fill="url(#SVGID_10_)" d="M 34.033 33.199 C 32.013 34.511 29.746 35.095 27.428001 35.08 C 22.623001 35.070004 17.566002 32.773003 13.584002 29.851002 L 13.008001 29.429 L 14.986001 25.023 L 5.0490007 26.935001 L 5.2400007 27.392002 C 9.746 31.146 25.146 42.686 34.033 33.199 z "/>
            <path d="M 40.447 19.054 L 35.001 6.098 C 34.92 5.907 34.754 5.785 34.57 5.78 C 34.39 5.775 34.217 5.8910003 34.132 6.079 L 32.157 10.360001 C 27.193 7.0270004 22.511002 5.4200006 18.427002 5.4180007 C 11.095 5.384 5.724 10.734 4.555 20.151 C 4.519 20.433998 4.6699996 20.705 4.9049997 20.785 C 5.139 20.861 5.39 20.723 5.4869995 20.462 C 7.832999 14.162 11.9279995 11.956 16.535 11.932 C 20.853 11.928 25.578 13.9800005 29.348 16.664 L 27.212 21.417 C 27.125 21.612 27.143 21.844 27.249 22.018 C 27.341 22.168999 27.488 22.257 27.646 22.258 C 27.671 22.258 27.7 22.254 27.723999 22.25 L 40.087997 19.869 C 40.240997 19.84 40.372997 19.727999 40.441998 19.567999 C 40.514 19.405 40.516 19.217 40.447 19.054 z " fill-opacity="0.2" stroke-opacity="0.2"/>
            <path d="M 5.038 20.235 C 6.885 5.7560005 18.446 1.5650005 32.348 11.150001 L 34.561 6.3500004 L 40.008 19.306 L 27.647 21.685 L 29.994999 16.459 C 22.101 10.655 9.775 7.413 5.038 20.235 z " fill-opacity="0.5" stroke-opacity="0.5"/>
            <linearGradient x1="846.9521" gradientTransform="matrix(0.9907 0.1358 0.1358 -0.9907 -696.8287 -969.0918)" y1="-881.6152" x2="844.9086" gradientUnits="userSpaceOnUse" y2="-866.7104" xlink:type="simple" xlink:actuate="onLoad" id="SVGID_11_" xlink:show="other">
                <stop stop-color="#32bd41" offset="0"/>
                <stop stop-color="#39bf3d" offset="0.0537"/>
                <stop stop-color="#55c52d" offset="0.2883"/>
                <stop stop-color="#69c922" offset="0.5245"/>
                <stop stop-color="#75cc1b" offset="0.7614"/>
                <stop stop-color="#79cd19" offset="1"/>
            </linearGradient>
            <path fill="url(#SVGID_11_)" d="M 5.038 19.231 C 6.885 4.753001 18.446 0.56300163 32.348 10.147001 L 34.561 5.3480015 L 40.008 18.302002 L 27.647 20.682003 L 29.994999 15.458003 C 22.101 9.651 9.775 6.409 5.038 19.231 z "/>
            <linearGradient x1="236.1943" gradientTransform="matrix(1 0 0 1 -212.0024 -849.0029)" y1="865.5469" x2="236.1943" gradientUnits="userSpaceOnUse" y2="854.3387" xlink:type="simple" xlink:actuate="onLoad" id="SVGID_12_" xlink:show="other">
                <stop stop-color="#32ed41" offset="0"/>
                <stop stop-color="#c9ff8f" offset="1"/>
            </linearGradient>
            <path fill="url(#SVGID_12_)" d="M 32.627 11.336 L 31.974998 10.884001 C 26.987 7.4440007 22.348999 5.8410006 18.429998 5.842001 C 14.76 5.87 11.728 7.245 9.512 9.869 C 13.14 7.8040004 21.79 6.0510006 38.872 17.535 L 34.529003 7.215 L 32.627 11.336 z "/>
        </g>
    </g>
</svg>
); background-repeat: no-repeat; }
@@ -30,6 +32,4 @@
.icon-wee-plus { background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDE1LjAuMCwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgMCkgIC0tPgo8IURPQ1RZUEUgc3ZnIFBVQkxJQyAiLS8vVzNDLy9EVEQgU1ZHIDEuMS8vRU4iICJodHRwOi8vd3d3LnczLm9yZy9HcmFwaGljcy9TVkcvMS4xL0RURC9zdmcxMS5kdGQiPgo8c3ZnIHZlcnNpb249IjEuMSIgaWQ9IkxheWVyXzEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4IgoJIHdpZHRoPSIzMHB4IiBoZWlnaHQ9IjMwcHgiIHZpZXdCb3g9IjAgMCAzMCAzMCIgZW5hYmxlLWJhY2tncm91bmQ9Im5ldyAwIDAgMzAgMzAiIHhtbDpzcGFjZT0icHJlc2VydmUiPgo8Zz4KCQoJCTxpbWFnZSBvdmVyZmxvdz0idmlzaWJsZSIgb3BhY2l0eT0iMC4zMyIgZW5hYmxlLWJhY2tncm91bmQ9Im5ldyAgICAiIHdpZHRoPSIzMyIgaGVpZ2h0PSIzMyIgeGxpbms6aHJlZj0iNjdBOEIzMUIucG5nIiAgdHJhbnNmb3JtPSJtYXRyaXgoMC45Njk3IDAgMCAwLjk2OTcgNC44ODI4MTJlLTA0IDApIj4KCTwvaW1hZ2U+Cgk8Zz4KCQkKCQkJPGxpbmVhckdyYWRpZW50IGlkPSJTVkdJRF8xXyIgZ3JhZGllbnRVbml0cz0idXNlclNwYWNlT25Vc2UiIHgxPSIxNS43Njg2IiB5MT0iMjcuMjMxNCIgeDI9IjE1Ljc2ODYiIHkyPSIzLjIzMDUiIGdyYWRpZW50VHJhbnNmb3JtPSJtYXRyaXgoMSAwIDAgLTEgMCAzMSkiPgoJCQk8c3RvcCAgb2Zmc2V0PSIwIiBzdHlsZT0ic3RvcC1jb2xvcjojOENDNjNGIi8+CgkJCTxzdG9wICBvZmZzZXQ9IjEiIHN0eWxlPSJzdG9wLWNvbG9yOiMwMDkyNDUiLz4KCQk8L2xpbmVhckdyYWRpZW50PgoJCTxwb2x5Z29uIGZpbGw9InVybCgjU1ZHSURfMV8pIiBwb2ludHM9IjI3Ljc3LDEzLjM3IDE4LjE3LDEzLjM3IDE4LjE3LDMuNzY5IDEzLjM3LDMuNzY5IDEzLjM3LDEzLjM3IDMuNzY5LDEzLjM3IDMuNzY5LDE4LjE3IAoJCQkxMy4zNywxOC4xNyAxMy4zNywyNy43NyAxOC4xNywyNy43NyAxOC4xNywxOC4xNyAyNy43NywxOC4xNyAJCSIvPgoJCTxwb2x5Z29uIGZpbGw9Im5vbmUiIHN0cm9rZT0iI0ZGRkZGRiIgc3Ryb2tlLW1pdGVybGltaXQ9IjEwIiBwb2ludHM9IjI3Ljc3LDEzLjM3IDE4LjE3LDEzLjM3IDE4LjE3LDMuNzY5IDEzLjM3LDMuNzY5IAoJCQkxMy4zNywxMy4zNyAzLjc2OSwxMy4zNyAzLjc2OSwxOC4xNyAxMy4zNywxOC4xNyAxMy4zNywyNy43NyAxOC4xNywyNy43NyAxOC4xNywxOC4xNyAyNy43NywxOC4xNyAJCSIvPgoJPC9nPgo8L2c+Cjwvc3ZnPgo=); background-repeat: no-repeat; }
-.icon-wee-star { background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4NCjwhLS0gR2VuZXJhdG9yOiBBZG9iZSBJbGx1c3RyYXRvciAxNS4wLjAsIFNWRyBFeHBvcnQgUGx1Zy1JbiAuIFNWRyBWZXJzaW9uOiA2LjAwIEJ1aWxkIDApICAtLT4NCjwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4wLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL1RSLzIwMDEvUkVDLVNWRy0yMDAxMDkwNC9EVEQvc3ZnMTAuZHRkIj4NCjxzdmcgdmVyc2lvbj0iMS4wIiBpZD0iTGF5ZXJfMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgeD0iMHB4IiB5PSIwcHgiDQoJIHdpZHRoPSI0MnB4IiBoZWlnaHQ9IjQycHgiIHZpZXdCb3g9IjAgMCA0MiA0MiIgZW5hYmxlLWJhY2tncm91bmQ9Im5ldyAwIDAgNDIgNDIiIHhtbDpzcGFjZT0icHJlc2VydmUiPg0KPGc+DQoJPGc+DQoJCQ0KCQkJPGxpbmVhckdyYWRpZW50IGlkPSJTVkdJRF8xXyIgZ3JhZGllbnRVbml0cz0idXNlclNwYWNlT25Vc2UiIHgxPSIyMC44OTA2IiB5MT0iNzg2Ljk4NDQiIHgyPSIyMC44OTA2IiB5Mj0iNzUyLjk4NTQiIGdyYWRpZW50VHJhbnNmb3JtPSJtYXRyaXgoMSAwIDAgMSAwIC03NDkpIj4NCgkJCTxzdG9wICBvZmZzZXQ9IjAiIHN0eWxlPSJzdG9wLWNvbG9yOiNGQkIwM0IiLz4NCgkJCTxzdG9wICBvZmZzZXQ9IjEiIHN0eWxlPSJzdG9wLWNvbG9yOiNGQ0VFMjEiLz4NCgkJPC9saW5lYXJHcmFkaWVudD4NCgkJPHBvbHlnb24gZmlsbD0idXJsKCNTVkdJRF8xXykiIHBvaW50cz0iMjAuODksMy45ODUgMjYuNDE0LDE1LjE3OCAzOC43NjYsMTYuOTcyIDI5LjgyNywyNS42ODQgMzEuOTM4LDM3Ljk4NCAyMC44OSwzMi4xNzcgDQoJCQk5Ljg0MiwzNy45ODQgMTEuOTUyLDI1LjY4NCAzLjAxNSwxNi45NzIgMTUuMzY2LDE1LjE3OCAJCSIvPg0KCQk8cG9seWdvbiBmaWxsPSJub25lIiBzdHJva2U9IiNGRkZGRkYiIHN0cm9rZS13aWR0aD0iMC43MzYxIiBzdHJva2UtbWl0ZXJsaW1pdD0iMTAiIHBvaW50cz0iMjAuODksMy45ODUgMjYuNDE0LDE1LjE3OCANCgkJCTM4Ljc2NiwxNi45NzIgMjkuODI3LDI1LjY4NCAzMS45MzgsMzcuOTg0IDIwLjg5LDMyLjE3NyA5Ljg0MiwzNy45ODQgMTEuOTUyLDI1LjY4NCAzLjAxNSwxNi45NzIgMTUuMzY2LDE1LjE3OCAJCSIvPg0KCTwvZz4NCjwvZz4NCjwvc3ZnPg0K); background-repeat: no-repeat; }
-
-.icon-wee-grunticon { background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDE1LjAuMCwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDYuMDAgQnVpbGQgMCkgIC0tPgo8IURPQ1RZUEUgc3ZnIFBVQkxJQyAiLS8vVzNDLy9EVEQgU1ZHIDEuMS8vRU4iICJodHRwOi8vd3d3LnczLm9yZy9HcmFwaGljcy9TVkcvMS4xL0RURC9zdmcxMS5kdGQiPgo8c3ZnIHZlcnNpb249IjEuMSIgaWQ9IkxheWVyXzEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4IgoJIHdpZHRoPSIxMDBweCIgaGVpZ2h0PSIxMDBweCIgdmlld0JveD0iMCAwIDEwMCAxMDAiIGVuYWJsZS1iYWNrZ3JvdW5kPSJuZXcgMCAwIDEwMCAxMDAiIHhtbDpzcGFjZT0icHJlc2VydmUiPgo8cGF0aCBmaWxsPSIjNDczRTEyIiBkPSJNNjguNzQ1LDY3LjIxN3YwLjA2M2wxMS40MDEsMy4wNTZsMC4wMDItMC4wMDF2MTEuNDgxYy0wLjAwMiwyLjQwOCwxLjk1Myw0LjM2Myw0LjM1OSw0LjM2MQoJYzIuNDA2LDAsNC4zODUtMS45NTMsNC4zODUtNC4zNjFWNjMuNjMxbC0xNi4yMjktNC4zNTRMNjguNzQ1LDY3LjIxN3oiLz4KPHBhdGggZmlsbD0iIzY4NTkzOCIgZD0iTTk2LjA1NywyOS42MmwtMTIuOTM2LTguNjAxTDk2Ljc4OC0wLjI0Nkw3OS42ODYsMTcuNjY5bC0xLjc4OS00LjA3MmwtMi4wMTcsOC4wM2wtMTkuMDk3LDE5Ljc2SDE5LjM3NgoJYzAtNS4yMzMtNC40MDktOS43NTUtOS42NzctOS43NTVDNC4zNCwzMS42MzIsMCwzNS45OTMsMCw0MS4zNTR2MTYuMTA1aDYuOTA2YzAsMCwwLTEzLjc5MywwLTE1Ljk0NwoJYzAtMi4xNTQsMC41MjItNS40OTcsMy41ODktNS40OTdjMy4xMTUsMCwzLjU3LDIuODk4LDMuNTg3LDUuMzcybDAsMGwtMC4wMDQsNC4zODRWNjQuOTJsLTMuNjEyLDUuNjU1Vjk0Ljk3CgljMCwyLjQwOSwxLjk3Niw0LjM2Miw0LjM4NCw0LjM2MmMyLjQwNiwwLDQuMzYxLTEuOTUzLDQuMzYxLTQuMzYyVjczLjg0OGw0LjgyMy03LjU4OGgzNC41NDJ2MjguNzEKCWMwLDIuNDA5LDEuOTU1LDQuMzYyLDQuMzYxLDQuMzYyYzIuNDA4LDAsNC4zODUtMS45NTMsNC4zODUtNC4zNjJWNjYuODg1bDE1LjE5NS0zMC43NjhsMTAuNDk0LDEuOTk4CgljMS44MzgsMC4zNDIsMy43OTMtMC40OTksNC43NjgtMi4yMzdDOTkuMDMyLDMzLjY4Niw5OC4yMzYsMzAuODY5LDk2LjA1NywyOS42MnoiLz4KPHBhdGggZmlsbD0iI0U1MjM1RiIgZD0iTTgzLjEyMSwyMS4wMTlMOTYuNzg4LTAuMjQ2TDc5LjY4NiwxNy42NjkiLz4KPC9zdmc+Cg==); background-repeat: no-repeat; }
+.icon-wee-star { background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4NCjwhLS0gR2VuZXJhdG9yOiBBZG9iZSBJbGx1c3RyYXRvciAxNS4wLjAsIFNWRyBFeHBvcnQgUGx1Zy1JbiAuIFNWRyBWZXJzaW9uOiA2LjAwIEJ1aWxkIDApICAtLT4NCjwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4wLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL1RSLzIwMDEvUkVDLVNWRy0yMDAxMDkwNC9EVEQvc3ZnMTAuZHRkIj4NCjxzdmcgdmVyc2lvbj0iMS4wIiBpZD0iTGF5ZXJfMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgeD0iMHB4IiB5PSIwcHgiDQoJIHdpZHRoPSI0MnB4IiBoZWlnaHQ9IjQycHgiIHZpZXdCb3g9IjAgMCA0MiA0MiIgZW5hYmxlLWJhY2tncm91bmQ9Im5ldyAwIDAgNDIgNDIiIHhtbDpzcGFjZT0icHJlc2VydmUiPg0KPGc+DQoJPGc+DQoJCQ0KCQkJPGxpbmVhckdyYWRpZW50IGlkPSJTVkdJRF8xXyIgZ3JhZGllbnRVbml0cz0idXNlclNwYWNlT25Vc2UiIHgxPSIyMC44OTA2IiB5MT0iNzg2Ljk4NDQiIHgyPSIyMC44OTA2IiB5Mj0iNzUyLjk4NTQiIGdyYWRpZW50VHJhbnNmb3JtPSJtYXRyaXgoMSAwIDAgMSAwIC03NDkpIj4NCgkJCTxzdG9wICBvZmZzZXQ9IjAiIHN0eWxlPSJzdG9wLWNvbG9yOiNGQkIwM0IiLz4NCgkJCTxzdG9wICBvZmZzZXQ9IjEiIHN0eWxlPSJzdG9wLWNvbG9yOiNGQ0VFMjEiLz4NCgkJPC9saW5lYXJHcmFkaWVudD4NCgkJPHBvbHlnb24gZmlsbD0idXJsKCNTVkdJRF8xXykiIHBvaW50cz0iMjAuODksMy45ODUgMjYuNDE0LDE1LjE3OCAzOC43NjYsMTYuOTcyIDI5LjgyNywyNS42ODQgMzEuOTM4LDM3Ljk4NCAyMC44OSwzMi4xNzcgDQoJCQk5Ljg0MiwzNy45ODQgMTEuOTUyLDI1LjY4NCAzLjAxNSwxNi45NzIgMTUuMzY2LDE1LjE3OCAJCSIvPg0KCQk8cG9seWdvbiBmaWxsPSJub25lIiBzdHJva2U9IiNGRkZGRkYiIHN0cm9rZS13aWR0aD0iMC43MzYxIiBzdHJva2UtbWl0ZXJsaW1pdD0iMTAiIHBvaW50cz0iMjAuODksMy45ODUgMjYuNDE0LDE1LjE3OCANCgkJCTM4Ljc2NiwxNi45NzIgMjkuODI3LDI1LjY4NCAzMS45MzgsMzcuOTg0IDIwLjg5LDMyLjE3NyA5Ljg0MiwzNy45ODQgMTEuOTUyLDI1LjY4NCAzLjAxNSwxNi45NzIgMTUuMzY2LDE1LjE3OCAJCSIvPg0KCTwvZz4NCjwvZz4NCjwvc3ZnPg0K); background-repeat: no-repeat; }
View
6 example/output/icons.fallback.css
@@ -12,6 +12,8 @@
.icon-wee-gradients { background-image: url(png/gradients.png); background-repeat: no-repeat; }
+.icon-wee-grunticon { background-image: url(png/grunticon.png); background-repeat: no-repeat; }
+
.icon-wee-Home_Media { background-image: url(png/Home_Media.png); background-repeat: no-repeat; }
.icon-wee-Image_Exchange { background-image: url(png/Image_Exchange.png); background-repeat: no-repeat; }
@@ -30,6 +32,4 @@
.icon-wee-plus { background-image: url(png/plus.png); background-repeat: no-repeat; }
-.icon-wee-star { background-image: url(png/star.png); background-repeat: no-repeat; }
-
-.icon-wee-grunticon { background-image: url(png/grunticon.png); background-repeat: no-repeat; }
+.icon-wee-star { background-image: url(png/star.png); background-repeat: no-repeat; }
View
BIN  example/output/png/grunticon.png
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
View
2  example/output/preview.html
@@ -17,6 +17,7 @@
<pre><code>.icon-wee-gear:</code></pre><div class="icon-wee-gear" style="width: 30px; height: 30px"></div><hr/>
<pre><code>.icon-wee-gradients-flat-opacity:</code></pre><div class="icon-wee-gradients-flat-opacity" style="width: 84.501px; height: 42px"></div><hr/>
<pre><code>.icon-wee-gradients:</code></pre><div class="icon-wee-gradients" style="width: 30px; height: 30px"></div><hr/>
+ <pre><code>.icon-wee-grunticon:</code></pre><div class="icon-wee-grunticon" style="width: 100px; height: 100px"></div><hr/>
<pre><code>.icon-wee-Home_Media:</code></pre><div class="icon-wee-Home_Media" style="width: 44px; height: 44px"></div><hr/>
<pre><code>.icon-wee-Image_Exchange:</code></pre><div class="icon-wee-Image_Exchange" style="width: 44px; height: 44px"></div><hr/>
<pre><code>.icon-wee-Internet:</code></pre><div class="icon-wee-Internet" style="width: 44px; height: 44px"></div><hr/>
@@ -27,6 +28,5 @@
<pre><code>.icon-wee-map:</code></pre><div class="icon-wee-map" style="width: 24px; height: 34px"></div><hr/>
<pre><code>.icon-wee-plus:</code></pre><div class="icon-wee-plus" style="width: 30px; height: 30px"></div><hr/>
<pre><code>.icon-wee-star:</code></pre><div class="icon-wee-star" style="width: 42px; height: 42px"></div><hr/>
- <pre><code>.icon-wee-grunticon:</code></pre><div class="icon-wee-grunticon" style="width: 100px; height: 100px"></div><hr/>
</body>
</html>
View
15 example/source/grunticon.svg
@@ -0,0 +1,15 @@
+<?xml version="1.0" encoding="utf-8"?>
+<!-- Generator: Adobe Illustrator 15.0.0, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
+<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
+<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
+ width="100px" height="100px" viewBox="0 0 100 100" enable-background="new 0 0 100 100" xml:space="preserve">
+<path fill="#473E12" d="M68.745,67.217v0.063l11.401,3.056l0.002-0.001v11.481c-0.002,2.408,1.953,4.363,4.359,4.361
+ c2.406,0,4.385-1.953,4.385-4.361V63.631l-16.229-4.354L68.745,67.217z"/>
+<path fill="#685938" d="M96.057,29.62l-12.936-8.601L96.788-0.246L79.686,17.669l-1.789-4.072l-2.017,8.03l-19.097,19.76H19.376
+ c0-5.233-4.409-9.755-9.677-9.755C4.34,31.632,0,35.993,0,41.354v16.105h6.906c0,0,0-13.793,0-15.947
+ c0-2.154,0.522-5.497,3.589-5.497c3.115,0,3.57,2.898,3.587,5.372l0,0l-0.004,4.384V64.92l-3.612,5.655V94.97
+ c0,2.409,1.976,4.362,4.384,4.362c2.406,0,4.361-1.953,4.361-4.362V73.848l4.823-7.588h34.542v28.71
+ c0,2.409,1.955,4.362,4.361,4.362c2.408,0,4.385-1.953,4.385-4.362V66.885l15.195-30.768l10.494,1.998
+ c1.838,0.342,3.793-0.499,4.768-2.237C99.032,33.686,98.236,30.869,96.057,29.62z"/>
+<path fill="#E5235F" d="M83.121,21.019L96.788-0.246L79.686,17.669"/>
+</svg>
View
101 tasks/grunticon.js
@@ -0,0 +1,101 @@
+/*
+ * grunticon
+ * https://github.com/filamentgroup/grunticon
+ *
+ * Copyright (c) 2012 Scott Jehl, Filament Group, Inc
+ * Licensed under the MIT license.
+ */
+
+module.exports = function(grunt ) {
+
+ grunt.registerTask( 'grunticon', 'A mystical CSS icon solution.', function() {
+
+ // just a quick starting message
+ grunt.log.write( "Look, it's a grunticon!\n" );
+
+ // get the config
+ var config = grunt.config.get( "grunticon" );
+
+ // fail if config or no src or dest config
+ if( !config || config.src === undefined || config.dest === undefined ){
+ grunt.fatal( "Oops! Please provide grunticon configuration for src and dest in your grunt.js file" );
+ return;
+ }
+
+ // make sure src and dest have / at the end
+ if( !config.src.match( /\/$/ ) ){
+ config.src += "/";
+ }
+ if( !config.dest.match( /\/$/ ) ){
+ config.dest += "/";
+ }
+
+ var asyncCSS = grunt.task.getFile( "grunticon/static/grunticon.loader.js" );
+ var asyncCSSBanner = grunt.task.getFile( "grunticon/static/grunticon.loader.banner.js" );
+ var previewHTMLsrc = grunt.task.getFile( "grunticon/static/preview.html" );
+
+ // CSS filenames with optional mixin from config
+ var datasvgcss = grunt.config.datasvgcss || "icons.data.svg.css";
+ var datapngcss = grunt.config.datapngcss || "icons.data.png.css";
+ var urlpngcss = grunt.config.urlpngcss || "icons.fallback.css";
+
+ //filename for generated output preview HTML file
+ var previewhtml = config.previewhtml || "preview.html";
+
+ //filename for generated loader HTML snippet file
+ var loadersnippet = config.loadersnippet || "grunticon.loader.txt";
+
+ // css references base path for the loader
+ var cssbasepath = config.cssbasepath || "/";
+
+ // folder name (within the output folder) for generated png files
+ var pngfolder = config.pngfolder || "png/";
+ // make sure pngfolder has / at the end
+ if( !pngfolder.match( /\/$/ ) ){
+ pngfolder += "/";
+ }
+
+ // css class prefix
+ var cssprefix = config.cssprefix || "icon";
+
+ // create the output directory
+ grunt.file.mkdir( config.dest );
+
+ // create the output icons directory
+ grunt.file.mkdir( config.dest + pngfolder );
+
+ // minify the source of the grunticon loader and write that to the output
+ grunt.log.write( "\ngrunticon now minifying the stylesheet loader source." );
+ var asyncsrc = grunt.file.read( asyncCSS );
+ var banner = grunt.file.read( asyncCSSBanner );
+ var min = banner + "\n" + grunt.helper('uglify', asyncsrc );
+ var loaderCodeDest = config.dest + loadersnippet;
+ grunt.file.write( loaderCodeDest, min );
+ grunt.log.write( "\ngrunticon loader file created." );
+
+ // take it to phantomjs to do the rest
+ grunt.log.write( "\ngrunticon now spawning phantomjs..." );
+
+ grunt.utils.spawn({
+ cmd: 'phantomjs',
+ args: [
+ grunt.task.getFile('grunticon/phantom.js'),
+ config.src,
+ config.dest,
+ loaderCodeDest,
+ previewHTMLsrc,
+ datasvgcss,
+ datapngcss,
+ urlpngcss,
+ previewhtml,
+ pngfolder,
+ cssprefix,
+ cssbasepath
+ ],
+ fallback: ''
+ }, function(err, result, code) {
+ // TODO boost this up a bit.
+ grunt.log.write("\nSomething went wrong with phantomjs...");
+ });
+ });
+};
View
159 tasks/grunticon/phantom.js
@@ -0,0 +1,159 @@
+/*
+ * grunticon
+ * https://github.com/filamentgroup/grunticon
+ *
+ * Copyright (c) 2012 Scott Jehl, Filament Group, Inc
+ * Licensed under the MIT license.
+ */
+
+/*global phantom:true*/
+/*global window:true*/
+/*global btoa:true*/
+
+/*
+phantom args sent from grunticon.js:
+ [0] - input directory path
+ [1] - output directory path
+ [2] - asyncCSS output file path
+ [3] - preview.html static file path
+ [4] - CSS filename for datasvg css
+ [5] - CSS filename for datapng css
+ [6] - CSS filename for urlpng css
+ [7] - filename for preview HTML file
+ [8] - png folder name
+ [9] - css classname prefix
+ [10] - css basepath prefix
+*/
+
+var fs = require( "fs" );
+var inputdir = phantom.args[0];
+var outputdir = phantom.args[1];
+var pngout = phantom.args[8];
+var cssprefix = phantom.args[9];
+var files = fs.list( inputdir );
+var currfile = 0;
+var pngcssrules = [];
+var pngdatacssrules = [];
+var datacssrules = [];
+var htmlpreviewbody = [];
+var fallbackcss = phantom.args[6];
+var pngdatacss = phantom.args[5];
+var datacss = phantom.args[4];
+var cssbasepath = phantom.args[10];
+
+
+// increment the current file index and process it
+function nextFile(){
+ currfile++;
+ processFile();
+}
+
+// files have all been processed. write the css and html files and return
+function finishUp(){
+
+ // make the preview HTML file and asyncCSS loader file
+ var asyncCSS = fs.read( phantom.args[2] );
+
+ // copy above for a slightly different output in the preview html file (different paths)
+ var asyncCSSpreview = asyncCSS;
+
+ // open up the static html document
+ var htmldoc = fs.read( phantom.args[3]);
+
+ // noscript for the snippet file
+ var noscript = '<noscript><link href="' + cssbasepath + outputdir + fallbackcss + '" rel="stylesheet"></noscript>';
+
+ // noscript for the preview file
+ var noscriptpreview = '<noscript><link href="' + fallbackcss + '" rel="stylesheet"></noscript>';
+
+ // add custom function call to asyncCSS
+ asyncCSS += '\ngrunticon( [ "' + cssbasepath + outputdir + datacss +'", "' + cssbasepath + outputdir + pngdatacss +'", "' + cssbasepath + outputdir + fallbackcss +'" ] );';
+ asyncCSSpreview += '\ngrunticon( [ "'+ datacss +'", "'+ pngdatacss +'", "'+ fallbackcss +'" ] );';
+
+ // add async loader to the top
+ htmldoc = htmldoc.replace( /<script>/, "<script>\n\t" + asyncCSSpreview );
+
+ //add noscript
+ htmldoc = htmldoc.replace( /<\/script>/, "</script>\n\t" + noscriptpreview );
+
+ // add icons to the body
+ htmldoc = htmldoc.replace( /<\/body>/, htmlpreviewbody.join( "\n\t" ) + "\n</body>" );
+
+ // write the preview html file
+ fs.write( outputdir + phantom.args[7], htmldoc );
+
+ // write CSS files
+ fs.write( outputdir + fallbackcss, pngcssrules.join( "\n\n" ) );
+ fs.write( outputdir + pngdatacss, pngdatacssrules.join( "\n\n" ) );
+ fs.write( outputdir + datacss, datacssrules.join( "\n\n" ) );
+
+ // overwrite the snippet HTML
+ fs.write( phantom.args[2], "<!-- Unicode CSS Loader: place this in the head of your page -->\n<script>\n" + asyncCSS + "</script>\n" + noscript );
+}
+
+// process an svg file from the source directory
+function processFile(){
+ var theFile = files[ currfile ];
+
+ if( theFile ){
+ // only parse svg files
+ if( theFile.match( /\.svg$/i ) ){
+ (function(){
+ var page = require( "webpage" ).create();
+ var svgdata = fs.read( inputdir + theFile ) || "";
+ var svgdatauri = "data:image/svg+xml;base64,";
+ var pngdatauri = "data:image/png;base64,";
+
+ // kill the ".svg" at the end of the filename
+ var filenamenoext = theFile.replace( /\.svg$/i, "" );
+
+ // get svg element's dimensions so we can set the viewport dims later
+ var frag = window.document.createElement( "div" );
+ frag.innerHTML = svgdata;
+ var svgelem = frag.querySelector( "svg" );
+ var width = svgelem.getAttribute( "width" );
+ var height = svgelem.getAttribute( "height" );
+
+ // get base64 of svg file
+ svgdatauri += btoa(svgdata);
+
+ // add rules to svg data css file
+ datacssrules.push( "." + cssprefix + filenamenoext + " { background-image: url(" + svgdatauri + "); background-repeat: no-repeat; }" );
@staabm
staabm added a note

@scottjehl wouldn't it make sense to use the shortcut css property "background" instead, to save a few bytes?

filenamenoext + " { background: url(" + svgdatauri + ") no-repeat; }"

could prepare a PR if you like it.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
+
+ // add rules to png url css file
+ pngcssrules.push( "." + cssprefix + filenamenoext + " { background-image: url(" + pngout + filenamenoext + ".png" + "); background-repeat: no-repeat; }" );
@staabm
staabm added a note

same as above

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
+
+ // add markup to the preview html file
+ htmlpreviewbody.push( '<pre><code>.' + cssprefix + filenamenoext + ':</code></pre><div class="' + cssprefix + filenamenoext + '" style="width: '+ width +'; height: '+ height +'"></div><hr/>' );
+
+ // set page viewport size to svg dimensions
+ page.viewportSize = { width: parseFloat(width), height: parseFloat(height) };
+
+ // open svg file in webkit to make a png
+ page.open( inputdir + theFile, function( status ){
+
+ // create png file
+ page.render( outputdir + pngout + filenamenoext + ".png" );
+
+ // create png data URI
+ pngdatacssrules.push( "." + cssprefix + filenamenoext + " { background-image: url(" + pngdatauri + page.renderBase64( "png" ) + "); background-repeat: no-repeat; }" );
@staabm
staabm added a note

another one here

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
+
+ // process the next svg
+ nextFile();
+ } );
+ }());
+ }
+ else {
+ // process the next svg
+ nextFile();
+ }
+ }
+ else {
+ // fin
+ finishUp();
+ phantom.exit();
+ }
+}
+
+// go ahead with the first file
+processFile();
View
1  tasks/grunticon/static/grunticon.loader.banner.js
@@ -0,0 +1 @@
+/* grunticon Stylesheet Loader | https://github.com/filamentgroup/grunticon | (c) 2012 Scott Jehl, Filament Group, Inc. | MIT license. */
View
32 tasks/grunticon/static/grunticon.loader.js
@@ -0,0 +1,32 @@
+window.grunticon = function( css, foo ){
+ // expects a css array with 3 items representing CSS paths to datasvg, datapng, urlpng
+ if( !css || css.length !== 3 ){
+ return;
+ }
+
+ // Thanks Modernizr & Erik Dahlstrom
+ var w = window,
+ svg = !!w.document.createElementNS && !!w.document.createElementNS('http://www.w3.org/2000/svg', 'svg').createSVGRect,
+
+ loadCSS = function( data ){
+ var link = w.document.createElement( "link" ),
+ ref = w.document.getElementsByTagName( "script" )[ 0 ];
+ link.rel = "stylesheet";
+ link.href = css[ data && svg ? 0 : data ? 1 : 2 ];
+ ref.parentNode.insertBefore( link, ref );
+ },
+
+ // Thanks Modernizr
+ img = new w.Image();
+
+ img.onerror = function(){
+ loadCSS( false );
+ };
+
+ img.onload = function(){
+ loadCSS( img.width === 1 && img.height === 1 );
+ };
+
+ img.src = "data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///ywAAAAAAQABAAACAUwAOw==";
@jiv-e
jiv-e added a note

Can somebody explain the purpose of the encoded 1 x 1px gif as an img.src value?

@jiv-e
jiv-e added a note

Ok... I found this: Modernizr/Modernizr#14
--> http://weston.ruter.net/2009/05/07/detecting-support-for-data-uris/

It's a CSS data uri test. If the 1 x 1px gif is loaded correctly loadCSS will have 'true' as an argument. Variable svg is svg support test. On line 15 you can see how these variables determine which CSS file to load. CSS array is the parameter of the grunticon function so css[0], css[1] and css[2] are references to the generated CSS files.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
+};
+// Call grunticon() here to load CSS:
View
10 tasks/grunticon/static/preview.html
@@ -0,0 +1,10 @@
+<!doctype HTML>
+<html>
+ <head>
+ <title>Icons Preview!</title>
+ <script>
+ </script>
+ </head>
+ <body>
+ </body>
+</html>
@staabm

@scottjehl wouldn't it make sense to use the shortcut css property "background" instead, to save a few bytes?

filenamenoext + " { background: url(" + svgdatauri + ") no-repeat; }"

could prepare a PR if you like it.

@staabm

another one here

@jefflembeck

Yep, it's actually much easier to see over here: https://github.com/filamentgroup/grunticon/blob/master/tasks/grunticon/static/grunticon.loader.js#L8

This loader has two tests in it, one for svg support and one for datauri support. That 1x1px gif is to check for datauri support.

If it fails, it falls back to the non-encoded png CSS file.

@jiv-e

Can somebody explain the purpose of the encoded 1 x 1px gif as an img.src value?

@jiv-e

Ok... I found this: Modernizr/Modernizr#14
--> http://weston.ruter.net/2009/05/07/detecting-support-for-data-uris/

It's a CSS data uri test. If the 1 x 1px gif is loaded correctly loadCSS will have 'true' as an argument. Variable svg is svg support test. On line 15 you can see how these variables determine which CSS file to load. CSS array is the parameter of the grunticon function so css[0], css[1] and css[2] are references to the generated CSS files.

@jiv-e

I had already deleted my comment and moved it down to tasks/grunticon/static/grunticon.loader.js on this page.

Please sign in to comment.
Something went wrong with that request. Please try again.