FlickrCollage 0.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/.gitignore +5 -0
- data/FlickrCollage.gemspec +33 -0
- data/Gemfile +4 -0
- data/Gemfile.lock +68 -0
- data/LICENSE.txt +8 -0
- data/README.md +102 -0
- data/Rakefile +56 -0
- data/bin/FlickrCollage +61 -0
- data/bin/console +14 -0
- data/bin/setup +8 -0
- data/doc/FlickrCollage.html +187 -0
- data/doc/FlickrCollage/Dictionary.html +408 -0
- data/doc/FlickrCollage/Flickr.html +880 -0
- data/doc/FlickrCollage/Image.html +1611 -0
- data/doc/_index.html +146 -0
- data/doc/class_list.html +51 -0
- data/doc/css/common.css +1 -0
- data/doc/css/full_list.css +58 -0
- data/doc/css/style.css +481 -0
- data/doc/file.README.html +171 -0
- data/doc/file_list.html +56 -0
- data/doc/flickrCollage.jpg +0 -0
- data/doc/frames.html +17 -0
- data/doc/index.html +171 -0
- data/doc/js/app.js +243 -0
- data/doc/js/full_list.js +216 -0
- data/doc/js/jquery.js +4 -0
- data/doc/method_list.html +203 -0
- data/doc/top-level-namespace.html +112 -0
- data/lib/FlickrCollage.rb +399 -0
- data/lib/FlickrCollage/version.rb +3 -0
- data/tmp/Giant Robots Smashing into Other Giant Robots.jpg +0 -0
- data/tmp/cat.jpg +0 -0
- metadata +215 -0
@@ -0,0 +1,171 @@
|
|
1
|
+
<!DOCTYPE html>
|
2
|
+
<html>
|
3
|
+
<head>
|
4
|
+
<meta charset="UTF-8">
|
5
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
6
|
+
<title>
|
7
|
+
File: README
|
8
|
+
|
9
|
+
— Documentation by YARD 0.9.5
|
10
|
+
|
11
|
+
</title>
|
12
|
+
|
13
|
+
<link rel="stylesheet" href="css/style.css" type="text/css" charset="utf-8" />
|
14
|
+
|
15
|
+
<link rel="stylesheet" href="css/common.css" type="text/css" charset="utf-8" />
|
16
|
+
|
17
|
+
<script type="text/javascript" charset="utf-8">
|
18
|
+
pathId = "README";
|
19
|
+
relpath = '';
|
20
|
+
</script>
|
21
|
+
|
22
|
+
|
23
|
+
<script type="text/javascript" charset="utf-8" src="js/jquery.js"></script>
|
24
|
+
|
25
|
+
<script type="text/javascript" charset="utf-8" src="js/app.js"></script>
|
26
|
+
|
27
|
+
|
28
|
+
</head>
|
29
|
+
<body>
|
30
|
+
<div class="nav_wrap">
|
31
|
+
<iframe id="nav" src="file_list.html"></iframe>
|
32
|
+
<div id="resizer"></div>
|
33
|
+
</div>
|
34
|
+
|
35
|
+
<div id="main" tabindex="-1">
|
36
|
+
<div id="header">
|
37
|
+
<div id="menu">
|
38
|
+
|
39
|
+
<a href="_index.html">Index</a> »
|
40
|
+
<span class="title">File: README</span>
|
41
|
+
|
42
|
+
</div>
|
43
|
+
|
44
|
+
<div id="search">
|
45
|
+
|
46
|
+
<a class="full_list_link" id="class_list_link"
|
47
|
+
href="class_list.html">
|
48
|
+
|
49
|
+
<svg width="24" height="24">
|
50
|
+
<rect x="0" y="4" width="24" height="4" rx="1" ry="1"></rect>
|
51
|
+
<rect x="0" y="12" width="24" height="4" rx="1" ry="1"></rect>
|
52
|
+
<rect x="0" y="20" width="24" height="4" rx="1" ry="1"></rect>
|
53
|
+
</svg>
|
54
|
+
</a>
|
55
|
+
|
56
|
+
</div>
|
57
|
+
<div class="clear"></div>
|
58
|
+
</div>
|
59
|
+
|
60
|
+
<iframe id="search_frame" src="file_list.html"></iframe>
|
61
|
+
|
62
|
+
<div id="content"><div id='filecontents'>
|
63
|
+
<h1 id="label-FlickrCollage">FlickrCollage</h1>
|
64
|
+
|
65
|
+
<p>This gem creates collage from 10 top-rated Flickr images for your keywords.
|
66
|
+
It's a part of coding challenge and it's fun.</p>
|
67
|
+
|
68
|
+
<p><img src="doc/flickrCollage.jpg"></p>
|
69
|
+
|
70
|
+
<h2 id="label-Installation">Installation</h2>
|
71
|
+
|
72
|
+
<p>There are two ways of installing gem:</p>
|
73
|
+
<ul><li>
|
74
|
+
<p>Just for collage creating</p>
|
75
|
+
</li></ul>
|
76
|
+
|
77
|
+
<pre class="code ruby"><code class="ruby">$ gem install https://github.com/CrCs2O4/FlickrCollage.git
|
78
|
+
|
79
|
+
# see help
|
80
|
+
$ flickrCollage -h</code></pre>
|
81
|
+
<ul><li>
|
82
|
+
<p>Clone and install dependencies</p>
|
83
|
+
</li></ul>
|
84
|
+
|
85
|
+
<pre class="code ruby"><code class="ruby">$ git clone https://github.com/CrCs2O4/FlickrCollage.git
|
86
|
+
$ cd FlickrCollage
|
87
|
+
$ bundle exec bin/setup
|
88
|
+
|
89
|
+
# see help
|
90
|
+
$ bundle exec bin/FlickrCollage -h
|
91
|
+
|
92
|
+
# run tests
|
93
|
+
$ bundle exec rake</code></pre>
|
94
|
+
|
95
|
+
<h2 id="label-Usage">Usage</h2>
|
96
|
+
|
97
|
+
<pre class="code ruby"><code class="ruby">$ flickrCollage city cityscape skyline architecture building skyscraper dawn twilight business finance
|
98
|
+
|
99
|
+
# use some random keywords from dictionary
|
100
|
+
$ flickrCollage city cityscape skyline
|
101
|
+
|
102
|
+
# set collage filename
|
103
|
+
$ flickrCollage city cityscape skyline -f my_awesome_collage
|
104
|
+
|
105
|
+
# set working path
|
106
|
+
$ flickrCollage city cityscape skyline -p ~/Pictures/
|
107
|
+
|
108
|
+
# view debug info
|
109
|
+
$ flickrCollage city cityscape skyline --log-level=debug
|
110
|
+
|
111
|
+
$ flickrCollage -h
|
112
|
+
|
113
|
+
Usage: FlickrCollage [options] [keywords]
|
114
|
+
|
115
|
+
Create collage from 10 top-rated Flickr images for your keywords
|
116
|
+
|
117
|
+
v0.1.0
|
118
|
+
|
119
|
+
Options:
|
120
|
+
-h, --help Show command line help
|
121
|
+
--api_key api_key Flickr api-key
|
122
|
+
--shared_secret shared_secretFlickr shared-secret
|
123
|
+
-w, --width width Set image width for crop
|
124
|
+
-e, --height height Set image height for crop
|
125
|
+
-p, --path path Path for collage
|
126
|
+
-f, --file file Filename for collage
|
127
|
+
-s, --save Don't delete downloaded images
|
128
|
+
--version Show help/version info
|
129
|
+
--log-level LEVEL Set the logging level
|
130
|
+
(debug|info|warn|error|fatal)
|
131
|
+
(Default: info)
|
132
|
+
|
133
|
+
Arguments:
|
134
|
+
|
135
|
+
keywords
|
136
|
+
Your keywords for Flickr images (optional)</code></pre>
|
137
|
+
|
138
|
+
<h2 id="label-Development">Development</h2>
|
139
|
+
|
140
|
+
<p>After checking out the repo, run <code>bundle exec bin/setup</code> to
|
141
|
+
install dependencies. You can also run <code>bundle exec bin/console</code>
|
142
|
+
for an interactive prompt that will allow you to experiment.</p>
|
143
|
+
|
144
|
+
<p>To run app just type <code>bundle exec bin/FlickrCollage</code></p>
|
145
|
+
|
146
|
+
<p>To run test <code>bundle exec rake</code></p>
|
147
|
+
|
148
|
+
<p>To view docs <code>yard doc</code></p>
|
149
|
+
|
150
|
+
<p>To install this gem onto your local machine, run <code>bundle exec rake
|
151
|
+
install</code>. To release a new version, update the version number in
|
152
|
+
<code>version.rb</code>, and then run <code>bundle exec rake
|
153
|
+
release</code>, which will create a git tag for the version, push git
|
154
|
+
commits and tags, and push the <code>.gem</code> file to <a
|
155
|
+
href="https://rubygems.org">rubygems.org</a>.</p>
|
156
|
+
|
157
|
+
<h2 id="label-Contributing">Contributing</h2>
|
158
|
+
|
159
|
+
<p>Bug reports and pull requests are welcome on GitHub at <a
|
160
|
+
href="https://github.com/CrCs2O4/FlickrCollage">github.com/CrCs2O4/FlickrCollage</a></p>
|
161
|
+
</div></div>
|
162
|
+
|
163
|
+
<div id="footer">
|
164
|
+
Generated on Mon Oct 24 09:56:49 2016 by
|
165
|
+
<a href="http://yardoc.org" title="Yay! A Ruby Documentation Tool" target="_parent">yard</a>
|
166
|
+
0.9.5 (ruby-2.3.1).
|
167
|
+
</div>
|
168
|
+
|
169
|
+
</div>
|
170
|
+
</body>
|
171
|
+
</html>
|
data/doc/file_list.html
ADDED
@@ -0,0 +1,56 @@
|
|
1
|
+
<!DOCTYPE html>
|
2
|
+
<html>
|
3
|
+
<head>
|
4
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
5
|
+
<meta charset="utf-8" />
|
6
|
+
|
7
|
+
<link rel="stylesheet" href="css/full_list.css" type="text/css" media="screen" charset="utf-8" />
|
8
|
+
|
9
|
+
<link rel="stylesheet" href="css/common.css" type="text/css" media="screen" charset="utf-8" />
|
10
|
+
|
11
|
+
|
12
|
+
|
13
|
+
<script type="text/javascript" charset="utf-8" src="js/jquery.js"></script>
|
14
|
+
|
15
|
+
<script type="text/javascript" charset="utf-8" src="js/full_list.js"></script>
|
16
|
+
|
17
|
+
|
18
|
+
<title>File List</title>
|
19
|
+
<base id="base_target" target="_parent" />
|
20
|
+
</head>
|
21
|
+
<body>
|
22
|
+
<div id="content">
|
23
|
+
<div class="fixed_header">
|
24
|
+
<h1 id="full_list_header">File List</h1>
|
25
|
+
<div id="full_list_nav">
|
26
|
+
|
27
|
+
<span><a target="_self" href="class_list.html">
|
28
|
+
Classes
|
29
|
+
</a></span>
|
30
|
+
|
31
|
+
<span><a target="_self" href="method_list.html">
|
32
|
+
Methods
|
33
|
+
</a></span>
|
34
|
+
|
35
|
+
<span><a target="_self" href="file_list.html">
|
36
|
+
Files
|
37
|
+
</a></span>
|
38
|
+
|
39
|
+
</div>
|
40
|
+
|
41
|
+
<div id="search">Search: <input type="text" /></div>
|
42
|
+
</div>
|
43
|
+
|
44
|
+
<ul id="full_list" class="file">
|
45
|
+
|
46
|
+
|
47
|
+
<li id="object_README" class="odd">
|
48
|
+
<div class="item"><span class="object_link"><a href="index.html" title="README">README</a></span></div>
|
49
|
+
</li>
|
50
|
+
|
51
|
+
|
52
|
+
|
53
|
+
</ul>
|
54
|
+
</div>
|
55
|
+
</body>
|
56
|
+
</html>
|
Binary file
|
data/doc/frames.html
ADDED
@@ -0,0 +1,17 @@
|
|
1
|
+
<!DOCTYPE html>
|
2
|
+
<html>
|
3
|
+
<head>
|
4
|
+
<meta charset="utf-8">
|
5
|
+
<title>Documentation by YARD 0.9.5</title>
|
6
|
+
</head>
|
7
|
+
<script type="text/javascript" charset="utf-8">
|
8
|
+
var match = unescape(window.location.hash).match(/^#!(.+)/);
|
9
|
+
var name = match ? match[1] : 'index.html';
|
10
|
+
name = name.replace(/^(\w+):\/\//, '').replace(/^\/\//, '');
|
11
|
+
window.top.location = name;
|
12
|
+
</script>
|
13
|
+
<noscript>
|
14
|
+
<h1>Oops!</h1>
|
15
|
+
<h2>YARD requires JavaScript!</h2>
|
16
|
+
</noscript>
|
17
|
+
</html>
|
data/doc/index.html
ADDED
@@ -0,0 +1,171 @@
|
|
1
|
+
<!DOCTYPE html>
|
2
|
+
<html>
|
3
|
+
<head>
|
4
|
+
<meta charset="UTF-8">
|
5
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
6
|
+
<title>
|
7
|
+
File: README
|
8
|
+
|
9
|
+
— Documentation by YARD 0.9.5
|
10
|
+
|
11
|
+
</title>
|
12
|
+
|
13
|
+
<link rel="stylesheet" href="css/style.css" type="text/css" charset="utf-8" />
|
14
|
+
|
15
|
+
<link rel="stylesheet" href="css/common.css" type="text/css" charset="utf-8" />
|
16
|
+
|
17
|
+
<script type="text/javascript" charset="utf-8">
|
18
|
+
pathId = "README";
|
19
|
+
relpath = '';
|
20
|
+
</script>
|
21
|
+
|
22
|
+
|
23
|
+
<script type="text/javascript" charset="utf-8" src="js/jquery.js"></script>
|
24
|
+
|
25
|
+
<script type="text/javascript" charset="utf-8" src="js/app.js"></script>
|
26
|
+
|
27
|
+
|
28
|
+
</head>
|
29
|
+
<body>
|
30
|
+
<div class="nav_wrap">
|
31
|
+
<iframe id="nav" src="class_list.html"></iframe>
|
32
|
+
<div id="resizer"></div>
|
33
|
+
</div>
|
34
|
+
|
35
|
+
<div id="main" tabindex="-1">
|
36
|
+
<div id="header">
|
37
|
+
<div id="menu">
|
38
|
+
|
39
|
+
<a href="_index.html">Index</a> »
|
40
|
+
<span class="title">File: README</span>
|
41
|
+
|
42
|
+
</div>
|
43
|
+
|
44
|
+
<div id="search">
|
45
|
+
|
46
|
+
<a class="full_list_link" id="class_list_link"
|
47
|
+
href="class_list.html">
|
48
|
+
|
49
|
+
<svg width="24" height="24">
|
50
|
+
<rect x="0" y="4" width="24" height="4" rx="1" ry="1"></rect>
|
51
|
+
<rect x="0" y="12" width="24" height="4" rx="1" ry="1"></rect>
|
52
|
+
<rect x="0" y="20" width="24" height="4" rx="1" ry="1"></rect>
|
53
|
+
</svg>
|
54
|
+
</a>
|
55
|
+
|
56
|
+
</div>
|
57
|
+
<div class="clear"></div>
|
58
|
+
</div>
|
59
|
+
|
60
|
+
<iframe id="search_frame" src="class_list.html"></iframe>
|
61
|
+
|
62
|
+
<div id="content"><div id='filecontents'>
|
63
|
+
<h1 id="label-FlickrCollage">FlickrCollage</h1>
|
64
|
+
|
65
|
+
<p>This gem creates collage from 10 top-rated Flickr images for your keywords.
|
66
|
+
It's a part of coding challenge and it's fun.</p>
|
67
|
+
|
68
|
+
<p><img src="doc/flickrCollage.jpg"></p>
|
69
|
+
|
70
|
+
<h2 id="label-Installation">Installation</h2>
|
71
|
+
|
72
|
+
<p>There are two ways of installing gem:</p>
|
73
|
+
<ul><li>
|
74
|
+
<p>Just for collage creating</p>
|
75
|
+
</li></ul>
|
76
|
+
|
77
|
+
<pre class="code ruby"><code class="ruby">$ gem install https://github.com/CrCs2O4/FlickrCollage.git
|
78
|
+
|
79
|
+
# see help
|
80
|
+
$ flickrCollage -h</code></pre>
|
81
|
+
<ul><li>
|
82
|
+
<p>Clone and install dependencies</p>
|
83
|
+
</li></ul>
|
84
|
+
|
85
|
+
<pre class="code ruby"><code class="ruby">$ git clone https://github.com/CrCs2O4/FlickrCollage.git
|
86
|
+
$ cd FlickrCollage
|
87
|
+
$ bundle exec bin/setup
|
88
|
+
|
89
|
+
# see help
|
90
|
+
$ bundle exec bin/FlickrCollage -h
|
91
|
+
|
92
|
+
# run tests
|
93
|
+
$ bundle exec rake</code></pre>
|
94
|
+
|
95
|
+
<h2 id="label-Usage">Usage</h2>
|
96
|
+
|
97
|
+
<pre class="code ruby"><code class="ruby">$ flickrCollage city cityscape skyline architecture building skyscraper dawn twilight business finance
|
98
|
+
|
99
|
+
# use some random keywords from dictionary
|
100
|
+
$ flickrCollage city cityscape skyline
|
101
|
+
|
102
|
+
# set collage filename
|
103
|
+
$ flickrCollage city cityscape skyline -f my_awesome_collage
|
104
|
+
|
105
|
+
# set working path
|
106
|
+
$ flickrCollage city cityscape skyline -p ~/Pictures/
|
107
|
+
|
108
|
+
# view debug info
|
109
|
+
$ flickrCollage city cityscape skyline --log-level=debug
|
110
|
+
|
111
|
+
$ flickrCollage -h
|
112
|
+
|
113
|
+
Usage: FlickrCollage [options] [keywords]
|
114
|
+
|
115
|
+
Create collage from 10 top-rated Flickr images for your keywords
|
116
|
+
|
117
|
+
v0.1.0
|
118
|
+
|
119
|
+
Options:
|
120
|
+
-h, --help Show command line help
|
121
|
+
--api_key api_key Flickr api-key
|
122
|
+
--shared_secret shared_secretFlickr shared-secret
|
123
|
+
-w, --width width Set image width for crop
|
124
|
+
-e, --height height Set image height for crop
|
125
|
+
-p, --path path Path for collage
|
126
|
+
-f, --file file Filename for collage
|
127
|
+
-s, --save Don't delete downloaded images
|
128
|
+
--version Show help/version info
|
129
|
+
--log-level LEVEL Set the logging level
|
130
|
+
(debug|info|warn|error|fatal)
|
131
|
+
(Default: info)
|
132
|
+
|
133
|
+
Arguments:
|
134
|
+
|
135
|
+
keywords
|
136
|
+
Your keywords for Flickr images (optional)</code></pre>
|
137
|
+
|
138
|
+
<h2 id="label-Development">Development</h2>
|
139
|
+
|
140
|
+
<p>After checking out the repo, run <code>bundle exec bin/setup</code> to
|
141
|
+
install dependencies. You can also run <code>bundle exec bin/console</code>
|
142
|
+
for an interactive prompt that will allow you to experiment.</p>
|
143
|
+
|
144
|
+
<p>To run app just type <code>bundle exec bin/FlickrCollage</code></p>
|
145
|
+
|
146
|
+
<p>To run test <code>bundle exec rake</code></p>
|
147
|
+
|
148
|
+
<p>To view docs <code>yard doc</code></p>
|
149
|
+
|
150
|
+
<p>To install this gem onto your local machine, run <code>bundle exec rake
|
151
|
+
install</code>. To release a new version, update the version number in
|
152
|
+
<code>version.rb</code>, and then run <code>bundle exec rake
|
153
|
+
release</code>, which will create a git tag for the version, push git
|
154
|
+
commits and tags, and push the <code>.gem</code> file to <a
|
155
|
+
href="https://rubygems.org">rubygems.org</a>.</p>
|
156
|
+
|
157
|
+
<h2 id="label-Contributing">Contributing</h2>
|
158
|
+
|
159
|
+
<p>Bug reports and pull requests are welcome on GitHub at <a
|
160
|
+
href="https://github.com/CrCs2O4/FlickrCollage">github.com/CrCs2O4/FlickrCollage</a></p>
|
161
|
+
</div></div>
|
162
|
+
|
163
|
+
<div id="footer">
|
164
|
+
Generated on Mon Oct 24 09:56:49 2016 by
|
165
|
+
<a href="http://yardoc.org" title="Yay! A Ruby Documentation Tool" target="_parent">yard</a>
|
166
|
+
0.9.5 (ruby-2.3.1).
|
167
|
+
</div>
|
168
|
+
|
169
|
+
</div>
|
170
|
+
</body>
|
171
|
+
</html>
|
data/doc/js/app.js
ADDED
@@ -0,0 +1,243 @@
|
|
1
|
+
(function() {
|
2
|
+
|
3
|
+
var localStorage = {}, sessionStorage = {};
|
4
|
+
try { localStorage = window.localStorage; } catch (e) { }
|
5
|
+
try { sessionStorage = window.sessionStorage; } catch (e) { }
|
6
|
+
|
7
|
+
function createSourceLinks() {
|
8
|
+
$('.method_details_list .source_code').
|
9
|
+
before("<span class='showSource'>[<a href='#' class='toggleSource'>View source</a>]</span>");
|
10
|
+
$('.toggleSource').toggle(function() {
|
11
|
+
$(this).parent().nextAll('.source_code').slideDown(100);
|
12
|
+
$(this).text("Hide source");
|
13
|
+
},
|
14
|
+
function() {
|
15
|
+
$(this).parent().nextAll('.source_code').slideUp(100);
|
16
|
+
$(this).text("View source");
|
17
|
+
});
|
18
|
+
}
|
19
|
+
|
20
|
+
function createDefineLinks() {
|
21
|
+
var tHeight = 0;
|
22
|
+
$('.defines').after(" <a href='#' class='toggleDefines'>more...</a>");
|
23
|
+
$('.toggleDefines').toggle(function() {
|
24
|
+
tHeight = $(this).parent().prev().height();
|
25
|
+
$(this).prev().css('display', 'inline');
|
26
|
+
$(this).parent().prev().height($(this).parent().height());
|
27
|
+
$(this).text("(less)");
|
28
|
+
},
|
29
|
+
function() {
|
30
|
+
$(this).prev().hide();
|
31
|
+
$(this).parent().prev().height(tHeight);
|
32
|
+
$(this).text("more...");
|
33
|
+
});
|
34
|
+
}
|
35
|
+
|
36
|
+
function createFullTreeLinks() {
|
37
|
+
var tHeight = 0;
|
38
|
+
$('.inheritanceTree').toggle(function() {
|
39
|
+
tHeight = $(this).parent().prev().height();
|
40
|
+
$(this).parent().toggleClass('showAll');
|
41
|
+
$(this).text("(hide)");
|
42
|
+
$(this).parent().prev().height($(this).parent().height());
|
43
|
+
},
|
44
|
+
function() {
|
45
|
+
$(this).parent().toggleClass('showAll');
|
46
|
+
$(this).parent().prev().height(tHeight);
|
47
|
+
$(this).text("show all");
|
48
|
+
});
|
49
|
+
}
|
50
|
+
|
51
|
+
function searchFrameButtons() {
|
52
|
+
$('.full_list_link').click(function() {
|
53
|
+
toggleSearchFrame(this, $(this).attr('href'));
|
54
|
+
return false;
|
55
|
+
});
|
56
|
+
window.addEventListener('message', function(e) {
|
57
|
+
if (e.data === 'navEscape') {
|
58
|
+
$('#search_frame').slideUp(100);
|
59
|
+
$('#search a').removeClass('active inactive');
|
60
|
+
$(window).focus();
|
61
|
+
}
|
62
|
+
});
|
63
|
+
|
64
|
+
$(window).resize(function() {
|
65
|
+
if ($('#search:visible').length === 0) {
|
66
|
+
$('#search_frame').slideUp(100);
|
67
|
+
$('#search a').removeClass('active inactive');
|
68
|
+
$(window).focus();
|
69
|
+
}
|
70
|
+
});
|
71
|
+
}
|
72
|
+
|
73
|
+
function toggleSearchFrame(id, link) {
|
74
|
+
var frame = $('#search_frame');
|
75
|
+
$('#search a').removeClass('active').addClass('inactive');
|
76
|
+
if (frame.attr('src') === link && frame.css('display') !== "none") {
|
77
|
+
frame.slideUp(100);
|
78
|
+
$('#search a').removeClass('active inactive');
|
79
|
+
}
|
80
|
+
else {
|
81
|
+
$(id).addClass('active').removeClass('inactive');
|
82
|
+
if (frame.attr('src') !== link) frame.attr('src', link);
|
83
|
+
frame.slideDown(100);
|
84
|
+
}
|
85
|
+
}
|
86
|
+
|
87
|
+
function linkSummaries() {
|
88
|
+
$('.summary_signature').click(function() {
|
89
|
+
document.location = $(this).find('a').attr('href');
|
90
|
+
});
|
91
|
+
}
|
92
|
+
|
93
|
+
function summaryToggle() {
|
94
|
+
$('.summary_toggle').click(function(e) {
|
95
|
+
e.preventDefault();
|
96
|
+
localStorage.summaryCollapsed = $(this).text();
|
97
|
+
$('.summary_toggle').each(function() {
|
98
|
+
$(this).text($(this).text() == "collapse" ? "expand" : "collapse");
|
99
|
+
var next = $(this).parent().parent().nextAll('ul.summary').first();
|
100
|
+
if (next.hasClass('compact')) {
|
101
|
+
next.toggle();
|
102
|
+
next.nextAll('ul.summary').first().toggle();
|
103
|
+
}
|
104
|
+
else if (next.hasClass('summary')) {
|
105
|
+
var list = $('<ul class="summary compact" />');
|
106
|
+
list.html(next.html());
|
107
|
+
list.find('.summary_desc, .note').remove();
|
108
|
+
list.find('a').each(function() {
|
109
|
+
$(this).html($(this).find('strong').html());
|
110
|
+
$(this).parent().html($(this)[0].outerHTML);
|
111
|
+
});
|
112
|
+
next.before(list);
|
113
|
+
next.toggle();
|
114
|
+
}
|
115
|
+
});
|
116
|
+
return false;
|
117
|
+
});
|
118
|
+
if (localStorage.summaryCollapsed == "collapse") {
|
119
|
+
$('.summary_toggle').first().click();
|
120
|
+
} else { localStorage.summaryCollapsed = "expand"; }
|
121
|
+
}
|
122
|
+
|
123
|
+
function generateTOC() {
|
124
|
+
if ($('#filecontents').length === 0) return;
|
125
|
+
var _toc = $('<ol class="top"></ol>');
|
126
|
+
var show = false;
|
127
|
+
var toc = _toc;
|
128
|
+
var counter = 0;
|
129
|
+
var tags = ['h2', 'h3', 'h4', 'h5', 'h6'];
|
130
|
+
var i;
|
131
|
+
if ($('#filecontents h1').length > 1) tags.unshift('h1');
|
132
|
+
for (i = 0; i < tags.length; i++) { tags[i] = '#filecontents ' + tags[i]; }
|
133
|
+
var lastTag = parseInt(tags[0][1], 10);
|
134
|
+
$(tags.join(', ')).each(function() {
|
135
|
+
if ($(this).parents('.method_details .docstring').length != 0) return;
|
136
|
+
if (this.id == "filecontents") return;
|
137
|
+
show = true;
|
138
|
+
var thisTag = parseInt(this.tagName[1], 10);
|
139
|
+
if (this.id.length === 0) {
|
140
|
+
var proposedId = $(this).attr('toc-id');
|
141
|
+
if (typeof(proposedId) != "undefined") this.id = proposedId;
|
142
|
+
else {
|
143
|
+
var proposedId = $(this).text().replace(/[^a-z0-9-]/ig, '_');
|
144
|
+
if ($('#' + proposedId).length > 0) { proposedId += counter; counter++; }
|
145
|
+
this.id = proposedId;
|
146
|
+
}
|
147
|
+
}
|
148
|
+
if (thisTag > lastTag) {
|
149
|
+
for (i = 0; i < thisTag - lastTag; i++) {
|
150
|
+
var tmp = $('<ol/>'); toc.append(tmp); toc = tmp;
|
151
|
+
}
|
152
|
+
}
|
153
|
+
if (thisTag < lastTag) {
|
154
|
+
for (i = 0; i < lastTag - thisTag; i++) toc = toc.parent();
|
155
|
+
}
|
156
|
+
var title = $(this).attr('toc-title');
|
157
|
+
if (typeof(title) == "undefined") title = $(this).text();
|
158
|
+
toc.append('<li><a href="#' + this.id + '">' + title + '</a></li>');
|
159
|
+
lastTag = thisTag;
|
160
|
+
});
|
161
|
+
if (!show) return;
|
162
|
+
html = '<div id="toc"><p class="title hide_toc"><a href="#"><strong>Table of Contents</strong></a></p></div>';
|
163
|
+
$('#content').prepend(html);
|
164
|
+
$('#toc').append(_toc);
|
165
|
+
$('#toc .hide_toc').toggle(function() {
|
166
|
+
$('#toc .top').slideUp('fast');
|
167
|
+
$('#toc').toggleClass('hidden');
|
168
|
+
$('#toc .title small').toggle();
|
169
|
+
}, function() {
|
170
|
+
$('#toc .top').slideDown('fast');
|
171
|
+
$('#toc').toggleClass('hidden');
|
172
|
+
$('#toc .title small').toggle();
|
173
|
+
});
|
174
|
+
}
|
175
|
+
|
176
|
+
function navResizeFn(e) {
|
177
|
+
if (e.which !== 1) {
|
178
|
+
navResizeFnStop();
|
179
|
+
return;
|
180
|
+
}
|
181
|
+
|
182
|
+
sessionStorage.navWidth = e.pageX.toString();
|
183
|
+
$('.nav_wrap').css('width', e.pageX);
|
184
|
+
$('.nav_wrap').css('-ms-flex', 'inherit');
|
185
|
+
}
|
186
|
+
|
187
|
+
function navResizeFnStop() {
|
188
|
+
$(window).unbind('mousemove', navResizeFn);
|
189
|
+
window.removeEventListener('message', navMessageFn, false);
|
190
|
+
}
|
191
|
+
|
192
|
+
function navMessageFn(e) {
|
193
|
+
if (e.data.action === 'mousemove') navResizeFn(e.data.event);
|
194
|
+
if (e.data.action === 'mouseup') navResizeFnStop();
|
195
|
+
}
|
196
|
+
|
197
|
+
function navResizer() {
|
198
|
+
$('#resizer').mousedown(function(e) {
|
199
|
+
e.preventDefault();
|
200
|
+
$(window).mousemove(navResizeFn);
|
201
|
+
window.addEventListener('message', navMessageFn, false);
|
202
|
+
});
|
203
|
+
$(window).mouseup(navResizeFnStop);
|
204
|
+
|
205
|
+
if (sessionStorage.navWidth) {
|
206
|
+
navResizeFn({which: 1, pageX: parseInt(sessionStorage.navWidth, 10)});
|
207
|
+
}
|
208
|
+
}
|
209
|
+
|
210
|
+
function navExpander() {
|
211
|
+
var done = false, timer = setTimeout(postMessage, 500);
|
212
|
+
function postMessage() {
|
213
|
+
if (done) return;
|
214
|
+
clearTimeout(timer);
|
215
|
+
var opts = { action: 'expand', path: pathId };
|
216
|
+
document.getElementById('nav').contentWindow.postMessage(opts, '*');
|
217
|
+
done = true;
|
218
|
+
}
|
219
|
+
|
220
|
+
window.addEventListener('message', function(event) {
|
221
|
+
if (event.data === 'navReady') postMessage();
|
222
|
+
return false;
|
223
|
+
}, false);
|
224
|
+
}
|
225
|
+
|
226
|
+
function mainFocus() {
|
227
|
+
$('#main')[0].focus();
|
228
|
+
}
|
229
|
+
|
230
|
+
$(document).ready(function() {
|
231
|
+
navResizer();
|
232
|
+
navExpander();
|
233
|
+
createSourceLinks();
|
234
|
+
createDefineLinks();
|
235
|
+
createFullTreeLinks();
|
236
|
+
searchFrameButtons();
|
237
|
+
linkSummaries();
|
238
|
+
summaryToggle();
|
239
|
+
generateTOC();
|
240
|
+
mainFocus();
|
241
|
+
});
|
242
|
+
|
243
|
+
})();
|