intranet-pictures 2.1.0 → 3.0.0.rc1
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 +4 -4
- data/lib/intranet/pictures/json_db_provider.rb +39 -27
- data/lib/intranet/pictures/responder.rb +45 -75
- data/lib/intranet/pictures/version.rb +1 -1
- data/lib/intranet/resources/haml/pictures_home.haml +18 -25
- data/lib/intranet/resources/locales/en.yml +2 -15
- data/lib/intranet/resources/locales/fr.yml +2 -15
- data/lib/intranet/resources/www/jpictures.js +156 -32
- data/lib/intranet/resources/www/photoswipe/photoswipe-dynamic-caption-plugin.css +8 -3
- data/lib/intranet/resources/www/photoswipe/photoswipe-dynamic-caption-plugin.esm.js +195 -173
- data/lib/intranet/resources/www/style.css +87 -13
- data/spec/intranet/pictures/json_db_provider_spec.rb +40 -23
- data/spec/intranet/pictures/responder_spec.rb +124 -177
- data/spec/intranet/pictures/sample-db.json +13 -9
- metadata +4 -5
- data/lib/intranet/resources/haml/pictures_browse.haml +0 -14
@@ -3,10 +3,24 @@
|
|
3
3
|
* Design for the Pictures module of the IntraNet.
|
4
4
|
*/
|
5
5
|
|
6
|
-
|
6
|
+
/************************************ Tags ************************************/
|
7
7
|
|
8
|
-
|
9
|
-
|
8
|
+
button {
|
9
|
+
background: #ffffff;
|
10
|
+
border: 1px solid #eeeff2;
|
11
|
+
border-radius: 999em;
|
12
|
+
margin: 0px 4px 1em; /* top sides bottom */
|
13
|
+
padding: 10px 15px; /* top+bottom sides */
|
14
|
+
transition: all 0.2s;
|
15
|
+
cursor: pointer;
|
16
|
+
}
|
17
|
+
|
18
|
+
button.active {
|
19
|
+
background: #eaeaea;
|
20
|
+
}
|
21
|
+
|
22
|
+
button:hover, button:focus {
|
23
|
+
box-shadow: 0px 1px 5px rgba(0,0,0,0.08);
|
10
24
|
}
|
11
25
|
|
12
26
|
/******************************* Picture groups *******************************/
|
@@ -22,6 +36,13 @@ ul.groups {
|
|
22
36
|
ul.groups.wide {
|
23
37
|
grid-template-columns: repeat(2, 1fr);
|
24
38
|
}
|
39
|
+
|
40
|
+
/* Small screens only */
|
41
|
+
@media only screen and (max-width: 1023px), only screen and (max-device-width: 1023px) {
|
42
|
+
ul.groups { grid-template-columns: repeat(2, 1fr); }
|
43
|
+
ul.groups.wide { grid-template-columns: repeat(1, 1fr); }
|
44
|
+
}
|
45
|
+
|
25
46
|
ul.groups li {
|
26
47
|
display: block;
|
27
48
|
width: 100%;
|
@@ -34,19 +55,11 @@ ul.groups li {
|
|
34
55
|
border-radius: 3px;
|
35
56
|
justify-self: center;
|
36
57
|
}
|
37
|
-
ul.groups a {
|
38
|
-
color: black;
|
39
|
-
}
|
40
|
-
|
41
|
-
/* Small screens only */
|
42
|
-
@media only screen and (max-width: 1023px), only screen and (max-device-width: 1023px) {
|
43
|
-
ul.groups { grid-template-columns: repeat(2, 1fr); }
|
44
|
-
ul.groups.wide { grid-template-columns: repeat(1, 1fr); }
|
45
|
-
}
|
46
58
|
|
47
59
|
ul.groups li a {
|
48
60
|
display: block;
|
49
61
|
height: 100%;
|
62
|
+
color: black;
|
50
63
|
}
|
51
64
|
ul.groups li figure {
|
52
65
|
margin: 0px;
|
@@ -87,5 +100,66 @@ ul.groups li:hover, ul.groups li:focus {
|
|
87
100
|
|
88
101
|
.pswp .pswp__dynamic-caption--below {
|
89
102
|
max-width: 800px;
|
90
|
-
padding: 10px 20px
|
103
|
+
padding: 10px 20px; /* top/bottom sides */
|
104
|
+
}
|
105
|
+
|
106
|
+
.pswp .pswp__dynamic-caption--aside {
|
107
|
+
max-width: 400px;
|
108
|
+
width: 400px;
|
109
|
+
text-align: justify;
|
110
|
+
padding: 10px 20px; /* top/bottom sides */
|
111
|
+
}
|
112
|
+
|
113
|
+
.pswp .pswp__dynamic-caption--aside hr {
|
114
|
+
margin: 8px 0px; /* top/bottom sides */
|
115
|
+
background: rgba(255, 255, 255, 0.7);
|
116
|
+
height: 1px;
|
117
|
+
}
|
118
|
+
|
119
|
+
.pswp .pswp__caption__exif {
|
120
|
+
padding: .25em 0 .25em 2.5em; /* top right bottom left */
|
121
|
+
margin: .125em 0; /* top/bottom sides */
|
122
|
+
background-position: .5em center;
|
123
|
+
background-repeat: no-repeat;
|
124
|
+
background-size: 20px 20px;
|
125
|
+
}
|
126
|
+
|
127
|
+
.pswp .pswp__caption__exif_datetime {
|
128
|
+
background-image: url();
|
129
|
+
}
|
130
|
+
|
131
|
+
.pswp .pswp__caption__exif_author {
|
132
|
+
background-image: url();
|
133
|
+
}
|
134
|
+
|
135
|
+
.pswp .pswp__caption__exif_event {
|
136
|
+
background-image: url();
|
137
|
+
}
|
138
|
+
|
139
|
+
.pswp .pswp__caption__exif_location {
|
140
|
+
background-image: url();
|
141
|
+
}
|
142
|
+
|
143
|
+
.pswp .pswp__caption__exif_camera {
|
144
|
+
background-image: url();
|
145
|
+
}
|
146
|
+
|
147
|
+
.pswp .pswp__caption__exif_focal {
|
148
|
+
background-image: url();
|
149
|
+
}
|
150
|
+
|
151
|
+
.pswp .pswp__caption__exif_fstop {
|
152
|
+
background-image: url();
|
153
|
+
}
|
154
|
+
|
155
|
+
.pswp .pswp__caption__exif_shutter {
|
156
|
+
background-image: url();
|
157
|
+
}
|
158
|
+
|
159
|
+
.pswp .pswp__caption__exif_iso {
|
160
|
+
background-image: url();
|
161
|
+
}
|
162
|
+
|
163
|
+
.pswp .pswp__caption__exif_tags {
|
164
|
+
background-image: url();
|
91
165
|
}
|
@@ -14,16 +14,6 @@ RSpec.describe Intranet::Pictures::JsonDbProvider do
|
|
14
14
|
end
|
15
15
|
end
|
16
16
|
|
17
|
-
describe '#title' do
|
18
|
-
before do
|
19
|
-
@provider = described_class.new(File.join(__dir__, 'sample-db.json'))
|
20
|
-
end
|
21
|
-
|
22
|
-
it 'should return the gallery title' do
|
23
|
-
expect(@provider.title).to eql('My Gallery')
|
24
|
-
end
|
25
|
-
end
|
26
|
-
|
27
17
|
describe '#list_pictures' do
|
28
18
|
before do
|
29
19
|
@provider = described_class.new(File.join(__dir__, 'sample-db.json'))
|
@@ -32,42 +22,63 @@ RSpec.describe Intranet::Pictures::JsonDbProvider do
|
|
32
22
|
it 'should return the list of pictures without the uri key' do
|
33
23
|
expect(@provider.list_pictures).to eql(
|
34
24
|
[
|
35
|
-
{ 'datetime' => '2019:07:22 09:41:31', 'author' => 'John Doe', 'location' => 'Paris, France', 'camera' => 'Apple iPhone 11' },
|
36
|
-
{ 'datetime' => '2020:06:19 07:51:05', 'flash' => false, 'author' => 'Jane Doe', 'location' => 'Tokyo, Japan' },
|
37
|
-
{ 'datetime' => '2020:06:20 18:14:09', 'flash' => true, 'author' => 'Jane Doe', 'location' => 'New York, USA' },
|
38
|
-
{ 'datetime' => '2020:06:20 06:09:54', 'flash' => true, 'author' => 'Jane Doe', 'location' => 'Paris, France', 'camera' => 'Canon EOS 5D MARK IV' },
|
25
|
+
{ 'datetime' => '2019:07:22 09:41:31', 'author' => 'John Doe', 'location' => 'Paris, France', 'camera' => 'Apple iPhone 11', 'tags' => ['Modern art', 'Louvre'] },
|
26
|
+
{ 'datetime' => '2020:06:19 07:51:05', 'flash' => 'false', 'author' => 'Jane Doe', 'location' => 'Tokyo, Japan', 'tags' => ['MoMAK', 'Modern art', 'Cherry blossom'] },
|
27
|
+
{ 'datetime' => '2020:06:20 18:14:09', 'flash' => 'true', 'author' => 'Jane Doe', 'location' => 'New York, USA', 'tags' => 'Urban photography' },
|
28
|
+
{ 'datetime' => '2020:06:20 06:09:54', 'flash' => 'true', 'author' => 'Jane Doe', 'location' => 'Paris, France', 'camera' => 'Canon EOS 5D MARK IV', 'tags' => ['Louvre', 'Pyramid', 'Urban photography'] },
|
39
29
|
{ 'datetime' => '2019:07:22 09:45:17', 'author' => 'John Doe', 'location' => 'Tokyo, Japan' }
|
40
30
|
]
|
41
31
|
)
|
42
32
|
end
|
43
33
|
|
44
34
|
it 'should return only the pictures matching the given selector' do
|
35
|
+
# Select only singular string values
|
45
36
|
selector = { 'author' => 'Jane Doe' }
|
46
37
|
expect(@provider.list_pictures(selector)).to eql(
|
47
38
|
[
|
48
|
-
{ 'datetime' => '2020:06:19 07:51:05', 'flash' => false, 'author' => 'Jane Doe', 'location' => 'Tokyo, Japan' },
|
49
|
-
{ 'datetime' => '2020:06:20 18:14:09', 'flash' => true, 'author' => 'Jane Doe', 'location' => 'New York, USA' },
|
50
|
-
{ 'datetime' => '2020:06:20 06:09:54', 'flash' => true, 'author' => 'Jane Doe', 'location' => 'Paris, France', 'camera' => 'Canon EOS 5D MARK IV' }
|
39
|
+
{ 'datetime' => '2020:06:19 07:51:05', 'flash' => 'false', 'author' => 'Jane Doe', 'location' => 'Tokyo, Japan', 'tags' => ['MoMAK', 'Modern art', 'Cherry blossom'] },
|
40
|
+
{ 'datetime' => '2020:06:20 18:14:09', 'flash' => 'true', 'author' => 'Jane Doe', 'location' => 'New York, USA', 'tags' => 'Urban photography' },
|
41
|
+
{ 'datetime' => '2020:06:20 06:09:54', 'flash' => 'true', 'author' => 'Jane Doe', 'location' => 'Paris, France', 'camera' => 'Canon EOS 5D MARK IV', 'tags' => ['Louvre', 'Pyramid', 'Urban photography'] }
|
42
|
+
]
|
43
|
+
)
|
44
|
+
|
45
|
+
# Select singular or array string values
|
46
|
+
selector = { 'tags' => 'Urban photography' }
|
47
|
+
expect(@provider.list_pictures(selector)).to eql(
|
48
|
+
[
|
49
|
+
{ 'datetime' => '2020:06:20 18:14:09', 'flash' => 'true', 'author' => 'Jane Doe', 'location' => 'New York, USA', 'tags' => 'Urban photography' },
|
50
|
+
{ 'datetime' => '2020:06:20 06:09:54', 'flash' => 'true', 'author' => 'Jane Doe', 'location' => 'Paris, France', 'camera' => 'Canon EOS 5D MARK IV', 'tags' => ['Louvre', 'Pyramid', 'Urban photography'] }
|
51
|
+
]
|
52
|
+
)
|
53
|
+
|
54
|
+
# Multiple selectors are AND'ed together
|
55
|
+
selector = { 'tags' => 'Modern art', 'location' => 'Paris, France' }
|
56
|
+
expect(@provider.list_pictures(selector)).to eql(
|
57
|
+
[
|
58
|
+
{ 'datetime' => '2019:07:22 09:41:31', 'author' => 'John Doe', 'location' => 'Paris, France', 'camera' => 'Apple iPhone 11', 'tags' => ['Modern art', 'Louvre'] }
|
51
59
|
]
|
52
60
|
)
|
53
61
|
end
|
54
62
|
|
55
63
|
context 'given a valid +sort_by+ key' do
|
56
64
|
it 'should sort the pictures by the given key' do
|
65
|
+
# Ascending (default) sort order, sort key has only singular string values
|
57
66
|
selector = { 'author' => 'Jane Doe' }
|
58
67
|
expect(@provider.list_pictures(selector, 'location')).to eql(
|
59
68
|
[
|
60
|
-
{ 'datetime' => '2020:06:20 18:14:09', 'flash' => true, 'author' => 'Jane Doe', 'location' => 'New York, USA' },
|
61
|
-
{ 'datetime' => '2020:06:20 06:09:54', 'flash' => true, 'author' => 'Jane Doe', 'location' => 'Paris, France', 'camera' => 'Canon EOS 5D MARK IV' },
|
62
|
-
{ 'datetime' => '2020:06:19 07:51:05', 'flash' => false, 'author' => 'Jane Doe', 'location' => 'Tokyo, Japan' }
|
69
|
+
{ 'datetime' => '2020:06:20 18:14:09', 'flash' => 'true', 'author' => 'Jane Doe', 'location' => 'New York, USA', 'tags' => 'Urban photography' },
|
70
|
+
{ 'datetime' => '2020:06:20 06:09:54', 'flash' => 'true', 'author' => 'Jane Doe', 'location' => 'Paris, France', 'camera' => 'Canon EOS 5D MARK IV', 'tags' => ['Louvre', 'Pyramid', 'Urban photography'] },
|
71
|
+
{ 'datetime' => '2020:06:19 07:51:05', 'flash' => 'false', 'author' => 'Jane Doe', 'location' => 'Tokyo, Japan', 'tags' => ['MoMAK', 'Modern art', 'Cherry blossom'] }
|
63
72
|
]
|
64
73
|
)
|
65
74
|
|
75
|
+
# Descending sort order
|
76
|
+
selector = { 'author' => 'Jane Doe' }
|
66
77
|
expect(@provider.list_pictures(selector, 'datetime', false)).to eql(
|
67
78
|
[
|
68
|
-
{ 'datetime' => '2020:06:20 18:14:09', 'flash' => true, 'author' => 'Jane Doe', 'location' => 'New York, USA' },
|
69
|
-
{ 'datetime' => '2020:06:20 06:09:54', 'flash' => true, 'author' => 'Jane Doe', 'location' => 'Paris, France', 'camera' => 'Canon EOS 5D MARK IV' },
|
70
|
-
{ 'datetime' => '2020:06:19 07:51:05', 'flash' => false, 'author' => 'Jane Doe', 'location' => 'Tokyo, Japan' }
|
79
|
+
{ 'datetime' => '2020:06:20 18:14:09', 'flash' => 'true', 'author' => 'Jane Doe', 'location' => 'New York, USA', 'tags' => 'Urban photography' },
|
80
|
+
{ 'datetime' => '2020:06:20 06:09:54', 'flash' => 'true', 'author' => 'Jane Doe', 'location' => 'Paris, France', 'camera' => 'Canon EOS 5D MARK IV', 'tags' => ['Louvre', 'Pyramid', 'Urban photography'] },
|
81
|
+
{ 'datetime' => '2020:06:19 07:51:05', 'flash' => 'false', 'author' => 'Jane Doe', 'location' => 'Tokyo, Japan', 'tags' => ['MoMAK', 'Modern art', 'Cherry blossom'] }
|
71
82
|
]
|
72
83
|
)
|
73
84
|
end
|
@@ -78,6 +89,12 @@ RSpec.describe Intranet::Pictures::JsonDbProvider do
|
|
78
89
|
expect { @provider.list_pictures({}, 'invalid') }.to raise_error(KeyError)
|
79
90
|
end
|
80
91
|
end
|
92
|
+
|
93
|
+
context 'given an invalid +sort_by+ key with array values' do
|
94
|
+
it 'should raise KeyError' do
|
95
|
+
expect { @provider.list_pictures({}, 'tags') }.to raise_error(KeyError)
|
96
|
+
end
|
97
|
+
end
|
81
98
|
end
|
82
99
|
|
83
100
|
describe '#picture' do
|