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.
@@ -3,10 +3,24 @@
3
3
  * Design for the Pictures module of the IntraNet.
4
4
  */
5
5
 
6
- /******************************* Recent groups ********************************/
6
+ /************************************ Tags ************************************/
7
7
 
8
- p.see_more {
9
- text-align: right;
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 10px;
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