flat_rails 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (85) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +17 -0
  3. data/Gemfile +4 -0
  4. data/LICENSE.txt +22 -0
  5. data/README.md +29 -0
  6. data/Rakefile +1 -0
  7. data/app/assets/fonts/Flat-UI-Icons.dev.svg +140 -0
  8. data/app/assets/fonts/Flat-UI-Icons.eot +0 -0
  9. data/app/assets/fonts/Flat-UI-Icons.svg +140 -0
  10. data/app/assets/fonts/Flat-UI-Icons.ttf +0 -0
  11. data/app/assets/fonts/Flat-UI-Icons.woff +0 -0
  12. data/app/assets/fonts/icomoon-session.json +1 -0
  13. data/app/assets/images/demo/browser-2x.png +0 -0
  14. data/app/assets/images/demo/html-icon.png +0 -0
  15. data/app/assets/images/demo/logo-mask-2x.png +0 -0
  16. data/app/assets/images/demo/logo-mask.png +0 -0
  17. data/app/assets/images/demo/video.jpg +0 -0
  18. data/app/assets/images/favicon.ico +0 -0
  19. data/app/assets/images/footer/logo.png +0 -0
  20. data/app/assets/images/icons/Book@2x.png +0 -0
  21. data/app/assets/images/icons/Calendar@2x.png +0 -0
  22. data/app/assets/images/icons/Chat@2x.png +0 -0
  23. data/app/assets/images/icons/Clipboard@2x.png +0 -0
  24. data/app/assets/images/icons/Compas@2x.png +0 -0
  25. data/app/assets/images/icons/Gift-Box@2x.png +0 -0
  26. data/app/assets/images/icons/Infinity-Loop@2x.png +0 -0
  27. data/app/assets/images/icons/Mail@2x.png +0 -0
  28. data/app/assets/images/icons/Map@2x.png +0 -0
  29. data/app/assets/images/icons/Pensils@2x.png +0 -0
  30. data/app/assets/images/icons/Pocket@2x.png +0 -0
  31. data/app/assets/images/icons/Retina-Ready@2x.png +0 -0
  32. data/app/assets/images/icons/Toilet-Paper@2x.png +0 -0
  33. data/app/assets/images/icons/Watches@2x.png +0 -0
  34. data/app/assets/images/login/icon.png +0 -0
  35. data/app/assets/images/login/imac-2x.png +0 -0
  36. data/app/assets/images/login/imac.png +0 -0
  37. data/app/assets/images/switch/mask-square.png +0 -0
  38. data/app/assets/images/switch/mask.png +0 -0
  39. data/app/assets/images/tile/ribbon-2x.png +0 -0
  40. data/app/assets/images/tile/ribbon.png +0 -0
  41. data/app/assets/images/todo/done-2x.png +0 -0
  42. data/app/assets/images/todo/done.png +0 -0
  43. data/app/assets/images/todo/search-2x.png +0 -0
  44. data/app/assets/images/todo/search.png +0 -0
  45. data/app/assets/images/todo/todo-2x.png +0 -0
  46. data/app/assets/images/todo/todo.png +0 -0
  47. data/app/assets/images/video/fullscreen-2x.png +0 -0
  48. data/app/assets/images/video/fullscreen.png +0 -0
  49. data/app/assets/images/video/pause-2x.png +0 -0
  50. data/app/assets/images/video/pause.png +0 -0
  51. data/app/assets/images/video/play-2x.png +0 -0
  52. data/app/assets/images/video/play.png +0 -0
  53. data/app/assets/images/video/poster.jpg +0 -0
  54. data/app/assets/images/video/volume-full-2x.png +0 -0
  55. data/app/assets/images/video/volume-full.png +0 -0
  56. data/app/assets/images/video/volume-off-2x.png +0 -0
  57. data/app/assets/images/video/volume-off.png +0 -0
  58. data/app/assets/javascripts/application.js +68 -0
  59. data/app/assets/javascripts/bootstrap-select.js +412 -0
  60. data/app/assets/javascripts/bootstrap-switch.js +251 -0
  61. data/app/assets/javascripts/bootstrap.min.js +7 -0
  62. data/app/assets/javascripts/flatui-checkbox.js +112 -0
  63. data/app/assets/javascripts/flatui-radio.js +141 -0
  64. data/app/assets/javascripts/html5shiv.js +8 -0
  65. data/app/assets/javascripts/icon-font-ie7.js +57 -0
  66. data/app/assets/javascripts/jquery-1.8.3.min.js +2 -0
  67. data/app/assets/javascripts/jquery-ui-1.10.3.custom.min.js +6 -0
  68. data/app/assets/javascripts/jquery.placeholder.js +157 -0
  69. data/app/assets/javascripts/jquery.stacktable.js +54 -0
  70. data/app/assets/javascripts/jquery.tagsinput.js +355 -0
  71. data/app/assets/javascripts/jquery.ui.touch-punch.min.js +11 -0
  72. data/app/assets/stylesheets/bootstrap/css/bootstrap-docs.css +1067 -0
  73. data/app/assets/stylesheets/bootstrap/css/bootstrap-responsive.css +1109 -0
  74. data/app/assets/stylesheets/bootstrap/css/bootstrap.css +6167 -0
  75. data/app/assets/stylesheets/bootstrap/css/prettify.css +30 -0
  76. data/app/assets/stylesheets/bootstrap/img/glyphicons-halflings-white.png +0 -0
  77. data/app/assets/stylesheets/bootstrap/img/glyphicons-halflings.png +0 -0
  78. data/app/assets/stylesheets/bootstrap/js/application.js +156 -0
  79. data/app/assets/stylesheets/bootstrap/js/google-code-prettify/prettify.js +28 -0
  80. data/app/assets/stylesheets/bootstrap/js/holder.js +401 -0
  81. data/app/assets/stylesheets/flat-ui.css +3868 -0
  82. data/flat_rails.gemspec +23 -0
  83. data/lib/flat_rails/version.rb +3 -0
  84. data/lib/flat_rails.rb +5 -0
  85. metadata +156 -0
@@ -0,0 +1,30 @@
1
+ .com { color: #93a1a1; }
2
+ .lit { color: #195f91; }
3
+ .pun, .opn, .clo { color: #93a1a1; }
4
+ .fun { color: #dc322f; }
5
+ .str, .atv { color: #D14; }
6
+ .kwd, .prettyprint .tag { color: #1e347b; }
7
+ .typ, .atn, .dec, .var { color: teal; }
8
+ .pln { color: #48484c; }
9
+
10
+ .prettyprint {
11
+ padding: 8px;
12
+ background-color: #f7f7f9;
13
+ border: 1px solid #e1e1e8;
14
+ }
15
+ .prettyprint.linenums {
16
+ -webkit-box-shadow: inset 40px 0 0 #fbfbfc, inset 41px 0 0 #ececf0;
17
+ -moz-box-shadow: inset 40px 0 0 #fbfbfc, inset 41px 0 0 #ececf0;
18
+ box-shadow: inset 40px 0 0 #fbfbfc, inset 41px 0 0 #ececf0;
19
+ }
20
+
21
+ /* Specify class=linenums on a pre to get line numbering */
22
+ ol.linenums {
23
+ margin: 0 0 0 33px; /* IE indents via margin-left */
24
+ }
25
+ ol.linenums li {
26
+ padding-left: 12px;
27
+ color: #bebec5;
28
+ line-height: 20px;
29
+ text-shadow: 0 1px 0 #fff;
30
+ }
@@ -0,0 +1,156 @@
1
+ // NOTICE!! DO NOT USE ANY OF THIS JAVASCRIPT
2
+ // IT'S ALL JUST JUNK FOR OUR DOCS!
3
+ // ++++++++++++++++++++++++++++++++++++++++++
4
+
5
+ !function ($) {
6
+
7
+ $(function(){
8
+
9
+ var $window = $(window)
10
+
11
+ // Disable certain links in docs
12
+ $('section [href^=#]').click(function (e) {
13
+ e.preventDefault()
14
+ })
15
+
16
+ // side bar
17
+ setTimeout(function () {
18
+ $('.bs-docs-sidenav').affix({
19
+ offset: {
20
+ top: function () { return $window.width() <= 980 ? 290 : 210 }
21
+ , bottom: 270
22
+ }
23
+ })
24
+ }, 100)
25
+
26
+ // make code pretty
27
+ window.prettyPrint && prettyPrint()
28
+
29
+ // add-ons
30
+ $('.add-on :checkbox').on('click', function () {
31
+ var $this = $(this)
32
+ , method = $this.attr('checked') ? 'addClass' : 'removeClass'
33
+ $(this).parents('.add-on')[method]('active')
34
+ })
35
+
36
+ // add tipsies to grid for scaffolding
37
+ if ($('#gridSystem').length) {
38
+ $('#gridSystem').tooltip({
39
+ selector: '.show-grid > [class*="span"]'
40
+ , title: function () { return $(this).width() + 'px' }
41
+ })
42
+ }
43
+
44
+ // tooltip demo
45
+ $('.tooltip-demo').tooltip({
46
+ selector: "a[data-toggle=tooltip]"
47
+ })
48
+
49
+ $('.tooltip-test').tooltip()
50
+ $('.popover-test').popover()
51
+
52
+ // popover demo
53
+ $("a[data-toggle=popover]")
54
+ .popover()
55
+ .click(function(e) {
56
+ e.preventDefault()
57
+ })
58
+
59
+ // button state demo
60
+ $('#fat-btn')
61
+ .click(function () {
62
+ var btn = $(this)
63
+ btn.button('loading')
64
+ setTimeout(function () {
65
+ btn.button('reset')
66
+ }, 3000)
67
+ })
68
+
69
+ // carousel demo
70
+ $('#myCarousel').carousel()
71
+
72
+ // javascript build logic
73
+ var inputsComponent = $("#components.download input")
74
+ , inputsPlugin = $("#plugins.download input")
75
+ , inputsVariables = $("#variables.download input")
76
+
77
+ // toggle all plugin checkboxes
78
+ $('#components.download .toggle-all').on('click', function (e) {
79
+ e.preventDefault()
80
+ inputsComponent.attr('checked', !inputsComponent.is(':checked'))
81
+ })
82
+
83
+ $('#plugins.download .toggle-all').on('click', function (e) {
84
+ e.preventDefault()
85
+ inputsPlugin.attr('checked', !inputsPlugin.is(':checked'))
86
+ })
87
+
88
+ $('#variables.download .toggle-all').on('click', function (e) {
89
+ e.preventDefault()
90
+ inputsVariables.val('')
91
+ })
92
+
93
+ // request built javascript
94
+ $('.download-btn .btn').on('click', function () {
95
+
96
+ var css = $("#components.download input:checked")
97
+ .map(function () { return this.value })
98
+ .toArray()
99
+ , js = $("#plugins.download input:checked")
100
+ .map(function () { return this.value })
101
+ .toArray()
102
+ , vars = {}
103
+ , img = ['glyphicons-halflings.png', 'glyphicons-halflings-white.png']
104
+
105
+ $("#variables.download input")
106
+ .each(function () {
107
+ $(this).val() && (vars[ $(this).prev().text() ] = $(this).val())
108
+ })
109
+
110
+ $.ajax({
111
+ type: 'POST'
112
+ , url: /\?dev/.test(window.location) ? 'http://localhost:3000' : 'http://bootstrap.herokuapp.com'
113
+ , dataType: 'jsonpi'
114
+ , params: {
115
+ js: js
116
+ , css: css
117
+ , vars: vars
118
+ , img: img
119
+ }
120
+ })
121
+ })
122
+ })
123
+
124
+ // Modified from the original jsonpi https://github.com/benvinegar/jquery-jsonpi
125
+ $.ajaxTransport('jsonpi', function(opts, originalOptions, jqXHR) {
126
+ var url = opts.url;
127
+
128
+ return {
129
+ send: function(_, completeCallback) {
130
+ var name = 'jQuery_iframe_' + jQuery.now()
131
+ , iframe, form
132
+
133
+ iframe = $('<iframe>')
134
+ .attr('name', name)
135
+ .appendTo('head')
136
+
137
+ form = $('<form>')
138
+ .attr('method', opts.type) // GET or POST
139
+ .attr('action', url)
140
+ .attr('target', name)
141
+
142
+ $.each(opts.params, function(k, v) {
143
+
144
+ $('<input>')
145
+ .attr('type', 'hidden')
146
+ .attr('name', k)
147
+ .attr('value', typeof v == 'string' ? v : JSON.stringify(v))
148
+ .appendTo(form)
149
+ })
150
+
151
+ form.appendTo('body').submit()
152
+ }
153
+ }
154
+ })
155
+
156
+ }(window.jQuery)
@@ -0,0 +1,28 @@
1
+ var q=null;window.PR_SHOULD_USE_CONTINUATION=!0;
2
+ (function(){function L(a){function m(a){var f=a.charCodeAt(0);if(f!==92)return f;var b=a.charAt(1);return(f=r[b])?f:"0"<=b&&b<="7"?parseInt(a.substring(1),8):b==="u"||b==="x"?parseInt(a.substring(2),16):a.charCodeAt(1)}function e(a){if(a<32)return(a<16?"\\x0":"\\x")+a.toString(16);a=String.fromCharCode(a);if(a==="\\"||a==="-"||a==="["||a==="]")a="\\"+a;return a}function h(a){for(var f=a.substring(1,a.length-1).match(/\\u[\dA-Fa-f]{4}|\\x[\dA-Fa-f]{2}|\\[0-3][0-7]{0,2}|\\[0-7]{1,2}|\\[\S\s]|[^\\]/g),a=
3
+ [],b=[],o=f[0]==="^",c=o?1:0,i=f.length;c<i;++c){var j=f[c];if(/\\[bdsw]/i.test(j))a.push(j);else{var j=m(j),d;c+2<i&&"-"===f[c+1]?(d=m(f[c+2]),c+=2):d=j;b.push([j,d]);d<65||j>122||(d<65||j>90||b.push([Math.max(65,j)|32,Math.min(d,90)|32]),d<97||j>122||b.push([Math.max(97,j)&-33,Math.min(d,122)&-33]))}}b.sort(function(a,f){return a[0]-f[0]||f[1]-a[1]});f=[];j=[NaN,NaN];for(c=0;c<b.length;++c)i=b[c],i[0]<=j[1]+1?j[1]=Math.max(j[1],i[1]):f.push(j=i);b=["["];o&&b.push("^");b.push.apply(b,a);for(c=0;c<
4
+ f.length;++c)i=f[c],b.push(e(i[0])),i[1]>i[0]&&(i[1]+1>i[0]&&b.push("-"),b.push(e(i[1])));b.push("]");return b.join("")}function y(a){for(var f=a.source.match(/\[(?:[^\\\]]|\\[\S\s])*]|\\u[\dA-Fa-f]{4}|\\x[\dA-Fa-f]{2}|\\\d+|\\[^\dux]|\(\?[!:=]|[()^]|[^()[\\^]+/g),b=f.length,d=[],c=0,i=0;c<b;++c){var j=f[c];j==="("?++i:"\\"===j.charAt(0)&&(j=+j.substring(1))&&j<=i&&(d[j]=-1)}for(c=1;c<d.length;++c)-1===d[c]&&(d[c]=++t);for(i=c=0;c<b;++c)j=f[c],j==="("?(++i,d[i]===void 0&&(f[c]="(?:")):"\\"===j.charAt(0)&&
5
+ (j=+j.substring(1))&&j<=i&&(f[c]="\\"+d[i]);for(i=c=0;c<b;++c)"^"===f[c]&&"^"!==f[c+1]&&(f[c]="");if(a.ignoreCase&&s)for(c=0;c<b;++c)j=f[c],a=j.charAt(0),j.length>=2&&a==="["?f[c]=h(j):a!=="\\"&&(f[c]=j.replace(/[A-Za-z]/g,function(a){a=a.charCodeAt(0);return"["+String.fromCharCode(a&-33,a|32)+"]"}));return f.join("")}for(var t=0,s=!1,l=!1,p=0,d=a.length;p<d;++p){var g=a[p];if(g.ignoreCase)l=!0;else if(/[a-z]/i.test(g.source.replace(/\\u[\da-f]{4}|\\x[\da-f]{2}|\\[^UXux]/gi,""))){s=!0;l=!1;break}}for(var r=
6
+ {b:8,t:9,n:10,v:11,f:12,r:13},n=[],p=0,d=a.length;p<d;++p){g=a[p];if(g.global||g.multiline)throw Error(""+g);n.push("(?:"+y(g)+")")}return RegExp(n.join("|"),l?"gi":"g")}function M(a){function m(a){switch(a.nodeType){case 1:if(e.test(a.className))break;for(var g=a.firstChild;g;g=g.nextSibling)m(g);g=a.nodeName;if("BR"===g||"LI"===g)h[s]="\n",t[s<<1]=y++,t[s++<<1|1]=a;break;case 3:case 4:g=a.nodeValue,g.length&&(g=p?g.replace(/\r\n?/g,"\n"):g.replace(/[\t\n\r ]+/g," "),h[s]=g,t[s<<1]=y,y+=g.length,
7
+ t[s++<<1|1]=a)}}var e=/(?:^|\s)nocode(?:\s|$)/,h=[],y=0,t=[],s=0,l;a.currentStyle?l=a.currentStyle.whiteSpace:window.getComputedStyle&&(l=document.defaultView.getComputedStyle(a,q).getPropertyValue("white-space"));var p=l&&"pre"===l.substring(0,3);m(a);return{a:h.join("").replace(/\n$/,""),c:t}}function B(a,m,e,h){m&&(a={a:m,d:a},e(a),h.push.apply(h,a.e))}function x(a,m){function e(a){for(var l=a.d,p=[l,"pln"],d=0,g=a.a.match(y)||[],r={},n=0,z=g.length;n<z;++n){var f=g[n],b=r[f],o=void 0,c;if(typeof b===
8
+ "string")c=!1;else{var i=h[f.charAt(0)];if(i)o=f.match(i[1]),b=i[0];else{for(c=0;c<t;++c)if(i=m[c],o=f.match(i[1])){b=i[0];break}o||(b="pln")}if((c=b.length>=5&&"lang-"===b.substring(0,5))&&!(o&&typeof o[1]==="string"))c=!1,b="src";c||(r[f]=b)}i=d;d+=f.length;if(c){c=o[1];var j=f.indexOf(c),k=j+c.length;o[2]&&(k=f.length-o[2].length,j=k-c.length);b=b.substring(5);B(l+i,f.substring(0,j),e,p);B(l+i+j,c,C(b,c),p);B(l+i+k,f.substring(k),e,p)}else p.push(l+i,b)}a.e=p}var h={},y;(function(){for(var e=a.concat(m),
9
+ l=[],p={},d=0,g=e.length;d<g;++d){var r=e[d],n=r[3];if(n)for(var k=n.length;--k>=0;)h[n.charAt(k)]=r;r=r[1];n=""+r;p.hasOwnProperty(n)||(l.push(r),p[n]=q)}l.push(/[\S\s]/);y=L(l)})();var t=m.length;return e}function u(a){var m=[],e=[];a.tripleQuotedStrings?m.push(["str",/^(?:'''(?:[^'\\]|\\[\S\s]|''?(?=[^']))*(?:'''|$)|"""(?:[^"\\]|\\[\S\s]|""?(?=[^"]))*(?:"""|$)|'(?:[^'\\]|\\[\S\s])*(?:'|$)|"(?:[^"\\]|\\[\S\s])*(?:"|$))/,q,"'\""]):a.multiLineStrings?m.push(["str",/^(?:'(?:[^'\\]|\\[\S\s])*(?:'|$)|"(?:[^"\\]|\\[\S\s])*(?:"|$)|`(?:[^\\`]|\\[\S\s])*(?:`|$))/,
10
+ q,"'\"`"]):m.push(["str",/^(?:'(?:[^\n\r'\\]|\\.)*(?:'|$)|"(?:[^\n\r"\\]|\\.)*(?:"|$))/,q,"\"'"]);a.verbatimStrings&&e.push(["str",/^@"(?:[^"]|"")*(?:"|$)/,q]);var h=a.hashComments;h&&(a.cStyleComments?(h>1?m.push(["com",/^#(?:##(?:[^#]|#(?!##))*(?:###|$)|.*)/,q,"#"]):m.push(["com",/^#(?:(?:define|elif|else|endif|error|ifdef|include|ifndef|line|pragma|undef|warning)\b|[^\n\r]*)/,q,"#"]),e.push(["str",/^<(?:(?:(?:\.\.\/)*|\/?)(?:[\w-]+(?:\/[\w-]+)+)?[\w-]+\.h|[a-z]\w*)>/,q])):m.push(["com",/^#[^\n\r]*/,
11
+ q,"#"]));a.cStyleComments&&(e.push(["com",/^\/\/[^\n\r]*/,q]),e.push(["com",/^\/\*[\S\s]*?(?:\*\/|$)/,q]));a.regexLiterals&&e.push(["lang-regex",/^(?:^^\.?|[!+-]|!=|!==|#|%|%=|&|&&|&&=|&=|\(|\*|\*=|\+=|,|-=|->|\/|\/=|:|::|;|<|<<|<<=|<=|=|==|===|>|>=|>>|>>=|>>>|>>>=|[?@[^]|\^=|\^\^|\^\^=|{|\||\|=|\|\||\|\|=|~|break|case|continue|delete|do|else|finally|instanceof|return|throw|try|typeof)\s*(\/(?=[^*/])(?:[^/[\\]|\\[\S\s]|\[(?:[^\\\]]|\\[\S\s])*(?:]|$))+\/)/]);(h=a.types)&&e.push(["typ",h]);a=(""+a.keywords).replace(/^ | $/g,
12
+ "");a.length&&e.push(["kwd",RegExp("^(?:"+a.replace(/[\s,]+/g,"|")+")\\b"),q]);m.push(["pln",/^\s+/,q," \r\n\t\xa0"]);e.push(["lit",/^@[$_a-z][\w$@]*/i,q],["typ",/^(?:[@_]?[A-Z]+[a-z][\w$@]*|\w+_t\b)/,q],["pln",/^[$_a-z][\w$@]*/i,q],["lit",/^(?:0x[\da-f]+|(?:\d(?:_\d+)*\d*(?:\.\d*)?|\.\d\+)(?:e[+-]?\d+)?)[a-z]*/i,q,"0123456789"],["pln",/^\\[\S\s]?/,q],["pun",/^.[^\s\w"-$'./@\\`]*/,q]);return x(m,e)}function D(a,m){function e(a){switch(a.nodeType){case 1:if(k.test(a.className))break;if("BR"===a.nodeName)h(a),
13
+ a.parentNode&&a.parentNode.removeChild(a);else for(a=a.firstChild;a;a=a.nextSibling)e(a);break;case 3:case 4:if(p){var b=a.nodeValue,d=b.match(t);if(d){var c=b.substring(0,d.index);a.nodeValue=c;(b=b.substring(d.index+d[0].length))&&a.parentNode.insertBefore(s.createTextNode(b),a.nextSibling);h(a);c||a.parentNode.removeChild(a)}}}}function h(a){function b(a,d){var e=d?a.cloneNode(!1):a,f=a.parentNode;if(f){var f=b(f,1),g=a.nextSibling;f.appendChild(e);for(var h=g;h;h=g)g=h.nextSibling,f.appendChild(h)}return e}
14
+ for(;!a.nextSibling;)if(a=a.parentNode,!a)return;for(var a=b(a.nextSibling,0),e;(e=a.parentNode)&&e.nodeType===1;)a=e;d.push(a)}var k=/(?:^|\s)nocode(?:\s|$)/,t=/\r\n?|\n/,s=a.ownerDocument,l;a.currentStyle?l=a.currentStyle.whiteSpace:window.getComputedStyle&&(l=s.defaultView.getComputedStyle(a,q).getPropertyValue("white-space"));var p=l&&"pre"===l.substring(0,3);for(l=s.createElement("LI");a.firstChild;)l.appendChild(a.firstChild);for(var d=[l],g=0;g<d.length;++g)e(d[g]);m===(m|0)&&d[0].setAttribute("value",
15
+ m);var r=s.createElement("OL");r.className="linenums";for(var n=Math.max(0,m-1|0)||0,g=0,z=d.length;g<z;++g)l=d[g],l.className="L"+(g+n)%10,l.firstChild||l.appendChild(s.createTextNode("\xa0")),r.appendChild(l);a.appendChild(r)}function k(a,m){for(var e=m.length;--e>=0;){var h=m[e];A.hasOwnProperty(h)?window.console&&console.warn("cannot override language handler %s",h):A[h]=a}}function C(a,m){if(!a||!A.hasOwnProperty(a))a=/^\s*</.test(m)?"default-markup":"default-code";return A[a]}function E(a){var m=
16
+ a.g;try{var e=M(a.h),h=e.a;a.a=h;a.c=e.c;a.d=0;C(m,h)(a);var k=/\bMSIE\b/.test(navigator.userAgent),m=/\n/g,t=a.a,s=t.length,e=0,l=a.c,p=l.length,h=0,d=a.e,g=d.length,a=0;d[g]=s;var r,n;for(n=r=0;n<g;)d[n]!==d[n+2]?(d[r++]=d[n++],d[r++]=d[n++]):n+=2;g=r;for(n=r=0;n<g;){for(var z=d[n],f=d[n+1],b=n+2;b+2<=g&&d[b+1]===f;)b+=2;d[r++]=z;d[r++]=f;n=b}for(d.length=r;h<p;){var o=l[h+2]||s,c=d[a+2]||s,b=Math.min(o,c),i=l[h+1],j;if(i.nodeType!==1&&(j=t.substring(e,b))){k&&(j=j.replace(m,"\r"));i.nodeValue=
17
+ j;var u=i.ownerDocument,v=u.createElement("SPAN");v.className=d[a+1];var x=i.parentNode;x.replaceChild(v,i);v.appendChild(i);e<o&&(l[h+1]=i=u.createTextNode(t.substring(b,o)),x.insertBefore(i,v.nextSibling))}e=b;e>=o&&(h+=2);e>=c&&(a+=2)}}catch(w){"console"in window&&console.log(w&&w.stack?w.stack:w)}}var v=["break,continue,do,else,for,if,return,while"],w=[[v,"auto,case,char,const,default,double,enum,extern,float,goto,int,long,register,short,signed,sizeof,static,struct,switch,typedef,union,unsigned,void,volatile"],
18
+ "catch,class,delete,false,import,new,operator,private,protected,public,this,throw,true,try,typeof"],F=[w,"alignof,align_union,asm,axiom,bool,concept,concept_map,const_cast,constexpr,decltype,dynamic_cast,explicit,export,friend,inline,late_check,mutable,namespace,nullptr,reinterpret_cast,static_assert,static_cast,template,typeid,typename,using,virtual,where"],G=[w,"abstract,boolean,byte,extends,final,finally,implements,import,instanceof,null,native,package,strictfp,super,synchronized,throws,transient"],
19
+ H=[G,"as,base,by,checked,decimal,delegate,descending,dynamic,event,fixed,foreach,from,group,implicit,in,interface,internal,into,is,lock,object,out,override,orderby,params,partial,readonly,ref,sbyte,sealed,stackalloc,string,select,uint,ulong,unchecked,unsafe,ushort,var"],w=[w,"debugger,eval,export,function,get,null,set,undefined,var,with,Infinity,NaN"],I=[v,"and,as,assert,class,def,del,elif,except,exec,finally,from,global,import,in,is,lambda,nonlocal,not,or,pass,print,raise,try,with,yield,False,True,None"],
20
+ J=[v,"alias,and,begin,case,class,def,defined,elsif,end,ensure,false,in,module,next,nil,not,or,redo,rescue,retry,self,super,then,true,undef,unless,until,when,yield,BEGIN,END"],v=[v,"case,done,elif,esac,eval,fi,function,in,local,set,then,until"],K=/^(DIR|FILE|vector|(de|priority_)?queue|list|stack|(const_)?iterator|(multi)?(set|map)|bitset|u?(int|float)\d*)/,N=/\S/,O=u({keywords:[F,H,w,"caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END"+
21
+ I,J,v],hashComments:!0,cStyleComments:!0,multiLineStrings:!0,regexLiterals:!0}),A={};k(O,["default-code"]);k(x([],[["pln",/^[^<?]+/],["dec",/^<!\w[^>]*(?:>|$)/],["com",/^<\!--[\S\s]*?(?:--\>|$)/],["lang-",/^<\?([\S\s]+?)(?:\?>|$)/],["lang-",/^<%([\S\s]+?)(?:%>|$)/],["pun",/^(?:<[%?]|[%?]>)/],["lang-",/^<xmp\b[^>]*>([\S\s]+?)<\/xmp\b[^>]*>/i],["lang-js",/^<script\b[^>]*>([\S\s]*?)(<\/script\b[^>]*>)/i],["lang-css",/^<style\b[^>]*>([\S\s]*?)(<\/style\b[^>]*>)/i],["lang-in.tag",/^(<\/?[a-z][^<>]*>)/i]]),
22
+ ["default-markup","htm","html","mxml","xhtml","xml","xsl"]);k(x([["pln",/^\s+/,q," \t\r\n"],["atv",/^(?:"[^"]*"?|'[^']*'?)/,q,"\"'"]],[["tag",/^^<\/?[a-z](?:[\w-.:]*\w)?|\/?>$/i],["atn",/^(?!style[\s=]|on)[a-z](?:[\w:-]*\w)?/i],["lang-uq.val",/^=\s*([^\s"'>]*(?:[^\s"'/>]|\/(?=\s)))/],["pun",/^[/<->]+/],["lang-js",/^on\w+\s*=\s*"([^"]+)"/i],["lang-js",/^on\w+\s*=\s*'([^']+)'/i],["lang-js",/^on\w+\s*=\s*([^\s"'>]+)/i],["lang-css",/^style\s*=\s*"([^"]+)"/i],["lang-css",/^style\s*=\s*'([^']+)'/i],["lang-css",
23
+ /^style\s*=\s*([^\s"'>]+)/i]]),["in.tag"]);k(x([],[["atv",/^[\S\s]+/]]),["uq.val"]);k(u({keywords:F,hashComments:!0,cStyleComments:!0,types:K}),["c","cc","cpp","cxx","cyc","m"]);k(u({keywords:"null,true,false"}),["json"]);k(u({keywords:H,hashComments:!0,cStyleComments:!0,verbatimStrings:!0,types:K}),["cs"]);k(u({keywords:G,cStyleComments:!0}),["java"]);k(u({keywords:v,hashComments:!0,multiLineStrings:!0}),["bsh","csh","sh"]);k(u({keywords:I,hashComments:!0,multiLineStrings:!0,tripleQuotedStrings:!0}),
24
+ ["cv","py"]);k(u({keywords:"caller,delete,die,do,dump,elsif,eval,exit,foreach,for,goto,if,import,last,local,my,next,no,our,print,package,redo,require,sub,undef,unless,until,use,wantarray,while,BEGIN,END",hashComments:!0,multiLineStrings:!0,regexLiterals:!0}),["perl","pl","pm"]);k(u({keywords:J,hashComments:!0,multiLineStrings:!0,regexLiterals:!0}),["rb"]);k(u({keywords:w,cStyleComments:!0,regexLiterals:!0}),["js"]);k(u({keywords:"all,and,by,catch,class,else,extends,false,finally,for,if,in,is,isnt,loop,new,no,not,null,of,off,on,or,return,super,then,true,try,unless,until,when,while,yes",
25
+ hashComments:3,cStyleComments:!0,multilineStrings:!0,tripleQuotedStrings:!0,regexLiterals:!0}),["coffee"]);k(x([],[["str",/^[\S\s]+/]]),["regex"]);window.prettyPrintOne=function(a,m,e){var h=document.createElement("PRE");h.innerHTML=a;e&&D(h,e);E({g:m,i:e,h:h});return h.innerHTML};window.prettyPrint=function(a){function m(){for(var e=window.PR_SHOULD_USE_CONTINUATION?l.now()+250:Infinity;p<h.length&&l.now()<e;p++){var n=h[p],k=n.className;if(k.indexOf("prettyprint")>=0){var k=k.match(g),f,b;if(b=
26
+ !k){b=n;for(var o=void 0,c=b.firstChild;c;c=c.nextSibling)var i=c.nodeType,o=i===1?o?b:c:i===3?N.test(c.nodeValue)?b:o:o;b=(f=o===b?void 0:o)&&"CODE"===f.tagName}b&&(k=f.className.match(g));k&&(k=k[1]);b=!1;for(o=n.parentNode;o;o=o.parentNode)if((o.tagName==="pre"||o.tagName==="code"||o.tagName==="xmp")&&o.className&&o.className.indexOf("prettyprint")>=0){b=!0;break}b||((b=(b=n.className.match(/\blinenums\b(?::(\d+))?/))?b[1]&&b[1].length?+b[1]:!0:!1)&&D(n,b),d={g:k,h:n,i:b},E(d))}}p<h.length?setTimeout(m,
27
+ 250):a&&a()}for(var e=[document.getElementsByTagName("pre"),document.getElementsByTagName("code"),document.getElementsByTagName("xmp")],h=[],k=0;k<e.length;++k)for(var t=0,s=e[k].length;t<s;++t)h.push(e[k][t]);var e=q,l=Date;l.now||(l={now:function(){return+new Date}});var p=0,d,g=/\blang(?:uage)?-([\w.]+)(?!\S)/;m()};window.PR={createSimpleLexer:x,registerLangHandler:k,sourceDecorator:u,PR_ATTRIB_NAME:"atn",PR_ATTRIB_VALUE:"atv",PR_COMMENT:"com",PR_DECLARATION:"dec",PR_KEYWORD:"kwd",PR_LITERAL:"lit",
28
+ PR_NOCODE:"nocode",PR_PLAIN:"pln",PR_PUNCTUATION:"pun",PR_SOURCE:"src",PR_STRING:"str",PR_TAG:"tag",PR_TYPE:"typ"}})();
@@ -0,0 +1,401 @@
1
+ /*
2
+
3
+ Holder - 1.9 - client side image placeholders
4
+ (c) 2012-2013 Ivan Malopinsky / http://imsky.co
5
+
6
+ Provided under the Apache 2.0 License: http://www.apache.org/licenses/LICENSE-2.0
7
+ Commercial use requires attribution.
8
+
9
+ */
10
+
11
+ var Holder = Holder || {};
12
+ (function (app, win) {
13
+
14
+ var preempted = false,
15
+ fallback = false,
16
+ canvas = document.createElement('canvas');
17
+
18
+ //getElementsByClassName polyfill
19
+ document.getElementsByClassName||(document.getElementsByClassName=function(e){var t=document,n,r,i,s=[];if(t.querySelectorAll)return t.querySelectorAll("."+e);if(t.evaluate){r=".//*[contains(concat(' ', @class, ' '), ' "+e+" ')]",n=t.evaluate(r,t,null,0,null);while(i=n.iterateNext())s.push(i)}else{n=t.getElementsByTagName("*"),r=new RegExp("(^|\\s)"+e+"(\\s|$)");for(i=0;i<n.length;i++)r.test(n[i].className)&&s.push(n[i])}return s})
20
+
21
+ //getComputedStyle polyfill
22
+ window.getComputedStyle||(window.getComputedStyle=function(e,t){return this.el=e,this.getPropertyValue=function(t){var n=/(\-([a-z]){1})/g;return t=="float"&&(t="styleFloat"),n.test(t)&&(t=t.replace(n,function(){return arguments[2].toUpperCase()})),e.currentStyle[t]?e.currentStyle[t]:null},this})
23
+
24
+ //http://javascript.nwbox.com/ContentLoaded by Diego Perini with modifications
25
+ function contentLoaded(n,t){var l="complete",s="readystatechange",u=!1,h=u,c=!0,i=n.document,a=i.documentElement,e=i.addEventListener?"addEventListener":"attachEvent",v=i.addEventListener?"removeEventListener":"detachEvent",f=i.addEventListener?"":"on",r=function(e){(e.type!=s||i.readyState==l)&&((e.type=="load"?n:i)[v](f+e.type,r,u),!h&&(h=!0)&&t.call(n,null))},o=function(){try{a.doScroll("left")}catch(n){setTimeout(o,50);return}r("poll")};if(i.readyState==l)t.call(n,"lazy");else{if(i.createEventObject&&a.doScroll){try{c=!n.frameElement}catch(y){}c&&o()}i[e](f+"DOMContentLoaded",r,u),i[e](f+s,r,u),n[e](f+"load",r,u)}};
26
+
27
+ //https://gist.github.com/991057 by Jed Schmidt with modifications
28
+ function selector(a){
29
+ a=a.match(/^(\W)?(.*)/);var b=document["getElement"+(a[1]?a[1]=="#"?"ById":"sByClassName":"sByTagName")](a[2]);
30
+ var ret=[]; b!=null&&(b.length?ret=b:b.length==0?ret=b:ret=[b]); return ret;
31
+ }
32
+
33
+ //shallow object property extend
34
+ function extend(a,b){var c={};for(var d in a)c[d]=a[d];for(var e in b)c[e]=b[e];return c}
35
+
36
+ //hasOwnProperty polyfill
37
+ if (!Object.prototype.hasOwnProperty)
38
+ Object.prototype.hasOwnProperty = function(prop) {
39
+ var proto = this.__proto__ || this.constructor.prototype;
40
+ return (prop in this) && (!(prop in proto) || proto[prop] !== this[prop]);
41
+ }
42
+
43
+ function text_size(width, height, template) {
44
+ var dimension_arr = [height, width].sort();
45
+ var maxFactor = Math.round(dimension_arr[1] / 16),
46
+ minFactor = Math.round(dimension_arr[0] / 16);
47
+ var text_height = Math.max(template.size, maxFactor);
48
+ return {
49
+ height: text_height
50
+ }
51
+ }
52
+
53
+ function draw(ctx, dimensions, template, ratio) {
54
+ var ts = text_size(dimensions.width, dimensions.height, template);
55
+ var text_height = ts.height;
56
+ var width = dimensions.width * ratio, height = dimensions.height * ratio;
57
+ var font = template.font ? template.font : "sans-serif";
58
+ canvas.width = width;
59
+ canvas.height = height;
60
+ ctx.textAlign = "center";
61
+ ctx.textBaseline = "middle";
62
+ ctx.fillStyle = template.background;
63
+ ctx.fillRect(0, 0, width, height);
64
+ ctx.fillStyle = template.foreground;
65
+ ctx.font = "bold " + text_height + "px "+font;
66
+ var text = template.text ? template.text : (dimensions.width + "x" + dimensions.height);
67
+ if (ctx.measureText(text).width / width > 1) {
68
+ text_height = template.size / (ctx.measureText(text).width / width);
69
+ }
70
+ //Resetting font size if necessary
71
+ ctx.font = "bold " + (text_height * ratio) + "px "+font;
72
+ ctx.fillText(text, (width / 2), (height / 2), width);
73
+ return canvas.toDataURL("image/png");
74
+ }
75
+
76
+ function render(mode, el, holder, src) {
77
+ var dimensions = holder.dimensions,
78
+ theme = holder.theme,
79
+ text = holder.text ? decodeURIComponent(holder.text) : holder.text;
80
+ var dimensions_caption = dimensions.width + "x" + dimensions.height;
81
+ theme = (text ? extend(theme, { text: text }) : theme);
82
+ theme = (holder.font ? extend(theme, {font: holder.font}) : theme);
83
+
84
+ var ratio = 1;
85
+ if(window.devicePixelRatio && window.devicePixelRatio > 1){
86
+ ratio = window.devicePixelRatio;
87
+ }
88
+
89
+ if (mode == "image") {
90
+ el.setAttribute("data-src", src);
91
+ el.setAttribute("alt", text ? text : theme.text ? theme.text + " [" + dimensions_caption + "]" : dimensions_caption);
92
+
93
+ if(fallback || !holder.auto){
94
+ el.style.width = dimensions.width + "px";
95
+ el.style.height = dimensions.height + "px";
96
+ }
97
+
98
+ if (fallback) {
99
+ el.style.backgroundColor = theme.background;
100
+
101
+ }
102
+ else{
103
+ el.setAttribute("src", draw(ctx, dimensions, theme, ratio));
104
+ }
105
+ } else {
106
+ if (!fallback) {
107
+ el.style.backgroundImage = "url(" + draw(ctx, dimensions, theme, ratio) + ")";
108
+ el.style.backgroundSize = dimensions.width+"px "+dimensions.height+"px";
109
+ }
110
+ }
111
+ };
112
+
113
+ function fluid(el, holder, src) {
114
+ var dimensions = holder.dimensions,
115
+ theme = holder.theme,
116
+ text = holder.text;
117
+ var dimensions_caption = dimensions.width + "x" + dimensions.height;
118
+ theme = (text ? extend(theme, {
119
+ text: text
120
+ }) : theme);
121
+
122
+ var fluid = document.createElement("div");
123
+
124
+ fluid.style.backgroundColor = theme.background;
125
+ fluid.style.color = theme.foreground;
126
+ fluid.className = el.className + " holderjs-fluid";
127
+ fluid.style.width = holder.dimensions.width + (holder.dimensions.width.indexOf("%")>0?"":"px");
128
+ fluid.style.height = holder.dimensions.height + (holder.dimensions.height.indexOf("%")>0?"":"px");
129
+ fluid.id = el.id;
130
+
131
+ el.style.width=0;
132
+ el.style.height=0;
133
+
134
+ if (theme.text) {
135
+ fluid.appendChild(document.createTextNode(theme.text))
136
+ } else {
137
+ fluid.appendChild(document.createTextNode(dimensions_caption))
138
+ fluid_images.push(fluid);
139
+ setTimeout(fluid_update, 0);
140
+ }
141
+
142
+ el.parentNode.insertBefore(fluid, el.nextSibling)
143
+
144
+ if(window.jQuery){
145
+ jQuery(function($){
146
+ $(el).on("load", function(){
147
+ el.style.width = fluid.style.width;
148
+ el.style.height = fluid.style.height;
149
+ $(el).show();
150
+ $(fluid).remove();
151
+ });
152
+ })
153
+ }
154
+ }
155
+
156
+ function fluid_update() {
157
+ for (i in fluid_images) {
158
+ if(!fluid_images.hasOwnProperty(i)) continue;
159
+ var el = fluid_images[i],
160
+ label = el.firstChild;
161
+
162
+ el.style.lineHeight = el.offsetHeight+"px";
163
+ label.data = el.offsetWidth + "x" + el.offsetHeight;
164
+ }
165
+ }
166
+
167
+ function parse_flags(flags, options) {
168
+
169
+ var ret = {
170
+ theme: settings.themes.gray
171
+ }, render = false;
172
+
173
+ for (sl = flags.length, j = 0; j < sl; j++) {
174
+ var flag = flags[j];
175
+ if (app.flags.dimensions.match(flag)) {
176
+ render = true;
177
+ ret.dimensions = app.flags.dimensions.output(flag);
178
+ } else if (app.flags.fluid.match(flag)) {
179
+ render = true;
180
+ ret.dimensions = app.flags.fluid.output(flag);
181
+ ret.fluid = true;
182
+ } else if (app.flags.colors.match(flag)) {
183
+ ret.theme = app.flags.colors.output(flag);
184
+ } else if (options.themes[flag]) {
185
+ //If a theme is specified, it will override custom colors
186
+ ret.theme = options.themes[flag];
187
+ } else if (app.flags.text.match(flag)) {
188
+ ret.text = app.flags.text.output(flag);
189
+ } else if(app.flags.font.match(flag)){
190
+ ret.font = app.flags.font.output(flag);
191
+ }
192
+ else if(app.flags.auto.match(flag)){
193
+ ret.auto = true;
194
+ }
195
+ }
196
+
197
+ return render ? ret : false;
198
+
199
+ };
200
+
201
+ if (!canvas.getContext) {
202
+ fallback = true;
203
+ } else {
204
+ if (canvas.toDataURL("image/png")
205
+ .indexOf("data:image/png") < 0) {
206
+ //Android doesn't support data URI
207
+ fallback = true;
208
+ } else {
209
+ var ctx = canvas.getContext("2d");
210
+ }
211
+ }
212
+
213
+ var fluid_images = [];
214
+
215
+ var settings = {
216
+ domain: "holder.js",
217
+ images: "img",
218
+ bgnodes: ".holderjs",
219
+ themes: {
220
+ "gray": {
221
+ background: "#eee",
222
+ foreground: "#aaa",
223
+ size: 12
224
+ },
225
+ "social": {
226
+ background: "#3a5a97",
227
+ foreground: "#fff",
228
+ size: 12
229
+ },
230
+ "industrial": {
231
+ background: "#434A52",
232
+ foreground: "#C2F200",
233
+ size: 12
234
+ }
235
+ },
236
+ stylesheet: ".holderjs-fluid {font-size:16px;font-weight:bold;text-align:center;font-family:sans-serif;margin:0}"
237
+ };
238
+
239
+
240
+ app.flags = {
241
+ dimensions: {
242
+ regex: /^(\d+)x(\d+)$/,
243
+ output: function (val) {
244
+ var exec = this.regex.exec(val);
245
+ return {
246
+ width: +exec[1],
247
+ height: +exec[2]
248
+ }
249
+ }
250
+ },
251
+ fluid: {
252
+ regex: /^([0-9%]+)x([0-9%]+)$/,
253
+ output: function (val) {
254
+ var exec = this.regex.exec(val);
255
+ return {
256
+ width: exec[1],
257
+ height: exec[2]
258
+ }
259
+ }
260
+ },
261
+ colors: {
262
+ regex: /#([0-9a-f]{3,})\:#([0-9a-f]{3,})/i,
263
+ output: function (val) {
264
+ var exec = this.regex.exec(val);
265
+ return {
266
+ size: settings.themes.gray.size,
267
+ foreground: "#" + exec[2],
268
+ background: "#" + exec[1]
269
+ }
270
+ }
271
+ },
272
+ text: {
273
+ regex: /text\:(.*)/,
274
+ output: function (val) {
275
+ return this.regex.exec(val)[1];
276
+ }
277
+ },
278
+ font: {
279
+ regex: /font\:(.*)/,
280
+ output: function(val){
281
+ return this.regex.exec(val)[1];
282
+ }
283
+ },
284
+ auto: {
285
+ regex: /^auto$/
286
+ }
287
+ }
288
+
289
+ for (var flag in app.flags) {
290
+ if(!app.flags.hasOwnProperty(flag)) continue;
291
+ app.flags[flag].match = function (val) {
292
+ return val.match(this.regex)
293
+ }
294
+ }
295
+
296
+ app.add_theme = function (name, theme) {
297
+ name != null && theme != null && (settings.themes[name] = theme);
298
+ return app;
299
+ };
300
+
301
+ app.add_image = function (src, el) {
302
+ var node = selector(el);
303
+ if (node.length) {
304
+ for (var i = 0, l = node.length; i < l; i++) {
305
+ var img = document.createElement("img")
306
+ img.setAttribute("data-src", src);
307
+ node[i].appendChild(img);
308
+ }
309
+ }
310
+ return app;
311
+ };
312
+
313
+ app.run = function (o) {
314
+ var options = extend(settings, o), images = [];
315
+
316
+ if(options.images instanceof window.NodeList){
317
+ imageNodes = options.images;
318
+ }
319
+ else if(options.images instanceof window.Node){
320
+ imageNodes = [options.images];
321
+ }
322
+ else{
323
+ imageNodes = selector(options.images);
324
+ }
325
+
326
+ if(options.elements instanceof window.NodeList){
327
+ bgnodes = options.bgnodes;
328
+ }
329
+ else if(options.bgnodes instanceof window.Node){
330
+ bgnodes = [options.bgnodes];
331
+ }
332
+ else{
333
+ bgnodes = selector(options.bgnodes);
334
+ }
335
+
336
+ preempted = true;
337
+
338
+ for (i = 0, l = imageNodes.length; i < l; i++) images.push(imageNodes[i]);
339
+
340
+ var holdercss = document.getElementById("holderjs-style");
341
+
342
+ if(!holdercss){
343
+ holdercss = document.createElement("style");
344
+ holdercss.setAttribute("id", "holderjs-style");
345
+ holdercss.type = "text/css";
346
+ document.getElementsByTagName("head")[0].appendChild(holdercss);
347
+ }
348
+
349
+ if(holdercss.styleSheet){
350
+ holdercss.styleSheet += options.stylesheet;
351
+ }
352
+ else{
353
+ holdercss.textContent+= options.stylesheet;
354
+ }
355
+
356
+ var cssregex = new RegExp(options.domain + "\/(.*?)\"?\\)");
357
+
358
+ for (var l = bgnodes.length, i = 0; i < l; i++) {
359
+ var src = window.getComputedStyle(bgnodes[i], null)
360
+ .getPropertyValue("background-image");
361
+ var flags = src.match(cssregex);
362
+ if (flags) {
363
+ var holder = parse_flags(flags[1].split("/"), options);
364
+ if (holder) {
365
+ render("background", bgnodes[i], holder, src);
366
+ }
367
+ }
368
+ }
369
+
370
+ for (var l = images.length, i = 0; i < l; i++) {
371
+ var src = images[i].getAttribute("src") || images[i].getAttribute("data-src");
372
+ if (src != null && src.indexOf(options.domain) >= 0) {
373
+ var holder = parse_flags(src.substr(src.lastIndexOf(options.domain) + options.domain.length + 1)
374
+ .split("/"), options);
375
+ if (holder) {
376
+ if (holder.fluid) {
377
+ fluid(images[i], holder, src);
378
+ } else {
379
+ render("image", images[i], holder, src);
380
+ }
381
+ }
382
+ }
383
+ }
384
+ return app;
385
+ };
386
+
387
+ contentLoaded(win, function () {
388
+ if (window.addEventListener) {
389
+ window.addEventListener("resize", fluid_update, false);
390
+ window.addEventListener("orientationchange", fluid_update, false);
391
+ } else {
392
+ window.attachEvent("onresize", fluid_update)
393
+ }
394
+ preempted || app.run();
395
+ });
396
+
397
+ if ( typeof define === "function" && define.amd ) {
398
+ define( "Holder", [], function () { return app; } );
399
+ }
400
+
401
+ })(Holder, window);