arclight 0.5.0 → 1.0.0.beta1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (216) hide show
  1. checksums.yaml +4 -4
  2. data/.eslintrc +11 -4
  3. data/.github/workflows/ruby.yml +24 -11
  4. data/.rspec +0 -1
  5. data/.rubocop.yml +286 -2
  6. data/.rubocop_todo.yml +18 -195
  7. data/CONTRIBUTING.md +5 -5
  8. data/Gemfile +12 -12
  9. data/README.md +18 -12
  10. data/app/assets/javascripts/arclight/arclight.js +3 -7
  11. data/app/assets/javascripts/arclight/oembed_viewer.js +64 -39
  12. data/app/assets/javascripts/arclight/truncate_controller.js +27 -0
  13. data/app/assets/stylesheets/arclight/application.scss +1 -5
  14. data/app/assets/stylesheets/arclight/modules/hierarchy_and_online_contents.scss +104 -130
  15. data/app/assets/stylesheets/arclight/modules/icons.scss +14 -3
  16. data/app/assets/stylesheets/arclight/modules/layout.scss +120 -100
  17. data/app/assets/stylesheets/arclight/modules/mastheads.scss +15 -57
  18. data/app/assets/stylesheets/arclight/modules/repositories.scss +2 -2
  19. data/app/assets/stylesheets/arclight/modules/repository_card.scss +4 -48
  20. data/app/assets/stylesheets/arclight/modules/search_results.scss +86 -35
  21. data/app/assets/stylesheets/arclight/modules/show_collection.scss +5 -32
  22. data/app/assets/stylesheets/arclight/modules/truncator.scss +56 -0
  23. data/app/assets/stylesheets/arclight/variables.scss +7 -4
  24. data/app/components/arclight/access_component.html.erb +14 -0
  25. data/app/components/arclight/access_component.rb +25 -0
  26. data/app/components/arclight/bookmark_component.html.erb +25 -0
  27. data/app/components/arclight/bookmark_component.rb +9 -0
  28. data/app/components/arclight/breadcrumb_component.rb +40 -0
  29. data/app/components/arclight/breadcrumbs_hierarchy_component.html.erb +34 -0
  30. data/app/components/arclight/breadcrumbs_hierarchy_component.rb +25 -0
  31. data/app/components/arclight/collection_context_component.html.erb +12 -0
  32. data/app/components/arclight/collection_context_component.rb +27 -0
  33. data/app/components/arclight/collection_info_component.html.erb +28 -0
  34. data/app/components/arclight/collection_info_component.rb +26 -0
  35. data/app/components/arclight/collection_sidebar_component.html.erb +15 -0
  36. data/app/components/arclight/collection_sidebar_component.rb +41 -0
  37. data/app/{views/catalog/_search_results_repository.html.erb → components/arclight/constraints_component.html.erb} +2 -1
  38. data/app/components/arclight/constraints_component.rb +17 -0
  39. data/app/components/arclight/document_collection_context_component.html.erb +29 -0
  40. data/app/components/arclight/document_collection_context_component.rb +28 -0
  41. data/app/components/arclight/document_collection_hierarchy_component.html.erb +46 -0
  42. data/app/components/arclight/document_collection_hierarchy_component.rb +62 -0
  43. data/app/components/arclight/document_component.html.erb +39 -0
  44. data/app/components/arclight/document_component.rb +49 -0
  45. data/app/components/arclight/document_components_hierarchy_component.html.erb +32 -0
  46. data/app/components/arclight/document_components_hierarchy_component.rb +28 -0
  47. data/app/components/arclight/document_download_component.html.erb +24 -0
  48. data/app/components/arclight/document_download_component.rb +71 -0
  49. data/app/components/arclight/embed_component.html.erb +10 -0
  50. data/app/components/arclight/embed_component.rb +43 -0
  51. data/app/components/arclight/group_component.html.erb +30 -0
  52. data/app/components/arclight/group_component.rb +23 -0
  53. data/app/components/arclight/header_component.html.erb +5 -0
  54. data/app/components/arclight/header_component.rb +10 -0
  55. data/app/components/arclight/index_metadata_field_component.html.erb +17 -0
  56. data/app/components/arclight/index_metadata_field_component.rb +20 -0
  57. data/app/components/arclight/masthead_component.html.erb +15 -0
  58. data/app/components/arclight/masthead_component.rb +10 -0
  59. data/app/components/arclight/metadata_section_component.html.erb +13 -0
  60. data/app/components/arclight/metadata_section_component.rb +22 -0
  61. data/app/components/arclight/oembed_viewer_component.html.erb +5 -0
  62. data/app/components/arclight/oembed_viewer_component.rb +16 -0
  63. data/app/components/arclight/online_content_filter_component.html.erb +15 -0
  64. data/app/components/arclight/online_content_filter_component.rb +19 -0
  65. data/app/components/arclight/online_status_indicator_component.rb +19 -0
  66. data/app/components/arclight/repository_breadcrumb_component.html.erb +10 -0
  67. data/app/components/arclight/repository_breadcrumb_component.rb +17 -0
  68. data/app/components/arclight/repository_location_component.html.erb +20 -0
  69. data/app/components/arclight/repository_location_component.rb +10 -0
  70. data/app/components/arclight/search_bar_component.html.erb +25 -0
  71. data/app/components/arclight/search_bar_component.rb +32 -0
  72. data/app/components/arclight/search_result_breadcrumbs_component.html.erb +3 -0
  73. data/app/components/arclight/search_result_breadcrumbs_component.rb +37 -0
  74. data/app/components/arclight/search_result_component.html.erb +20 -0
  75. data/app/components/arclight/search_result_component.rb +24 -0
  76. data/app/components/arclight/search_result_title_component.html.erb +13 -0
  77. data/app/components/arclight/search_result_title_component.rb +15 -0
  78. data/app/components/arclight/sidebar_component.html.erb +9 -0
  79. data/app/components/arclight/sidebar_component.rb +19 -0
  80. data/app/components/arclight/upper_metadata_layout_component.rb +10 -0
  81. data/app/components/blacklight/icons/bookmark_component.rb +12 -0
  82. data/app/components/blacklight/icons/collection_component.rb +14 -0
  83. data/app/components/blacklight/icons/compact_component.rb +12 -0
  84. data/app/components/blacklight/icons/container_component.rb +14 -0
  85. data/app/components/blacklight/icons/ead_component.rb +12 -0
  86. data/app/components/blacklight/icons/file_component.rb +14 -0
  87. data/app/components/blacklight/icons/folder_component.rb +12 -0
  88. data/app/components/blacklight/icons/online_component.rb +15 -0
  89. data/app/components/blacklight/icons/pdf_component.rb +12 -0
  90. data/app/components/blacklight/icons/repository_component.rb +12 -0
  91. data/app/controllers/arclight/repositories_controller.rb +4 -4
  92. data/app/{controllers/concerns → helpers}/arclight/ead_format_helpers.rb +4 -7
  93. data/app/helpers/arclight/field_config_helpers.rb +26 -0
  94. data/app/helpers/arclight_helper.rb +15 -253
  95. data/app/models/arclight/document_downloads.rb +12 -15
  96. data/app/models/arclight/parent.rb +5 -0
  97. data/app/models/arclight/parents.rb +2 -1
  98. data/app/models/arclight/requests/aeon_external_request.rb +1 -1
  99. data/app/models/arclight/requests/aeon_web_ead.rb +8 -3
  100. data/app/models/arclight/requests/google_form.rb +8 -3
  101. data/app/models/concerns/arclight/catalog.rb +25 -15
  102. data/app/models/concerns/arclight/search_behavior.rb +12 -26
  103. data/app/models/concerns/arclight/solr_document.rb +70 -73
  104. data/app/presenters/arclight/show_presenter.rb +34 -7
  105. data/app/views/arclight/_requests.html.erb +2 -2
  106. data/app/views/arclight/repositories/_repository.html.erb +21 -40
  107. data/app/views/arclight/repositories/index.html.erb +3 -1
  108. data/app/views/arclight/repositories/show.html.erb +4 -6
  109. data/app/views/arclight/requests/_aeon_external_request_endpoint.html.erb +4 -5
  110. data/app/views/arclight/requests/_aeon_web_ead.html.erb +2 -3
  111. data/app/views/arclight/requests/_google_form.html.erb +4 -6
  112. data/app/views/catalog/_group.html.erb +1 -18
  113. data/app/views/catalog/_group_toggle.html.erb +1 -1
  114. data/app/views/catalog/_search_results_header.html.erb +3 -0
  115. data/app/views/catalog/hierarchy.html.erb +19 -0
  116. data/app/views/catalog/index.html.erb +16 -7
  117. data/app/views/shared/_breadcrumbs.html.erb +2 -14
  118. data/app/views/shared/_main_menu_links.html.erb +1 -1
  119. data/arclight.gemspec +7 -6
  120. data/config/breadcrumbs.rb +24 -0
  121. data/config/i18n-tasks.yml +9 -8
  122. data/config/importmap.rb +3 -0
  123. data/config/locales/arclight.en.yml +31 -30
  124. data/config/routes.rb +1 -1
  125. data/docker-compose.yml +16 -0
  126. data/lib/arclight/digital_object.rb +2 -1
  127. data/lib/arclight/engine.rb +18 -31
  128. data/lib/arclight/exceptions.rb +1 -0
  129. data/lib/arclight/hash_absolute_xpath.rb +2 -1
  130. data/lib/arclight/normalized_id.rb +2 -0
  131. data/lib/arclight/normalized_title.rb +2 -0
  132. data/lib/arclight/repository.rb +43 -54
  133. data/lib/arclight/routes/hierarchy.rb +19 -0
  134. data/lib/arclight/routes.rb +8 -0
  135. data/lib/arclight/traject/ead2_component_config.rb +292 -0
  136. data/lib/arclight/traject/ead2_config.rb +66 -287
  137. data/lib/arclight/version.rb +1 -1
  138. data/lib/arclight/year_range.rb +4 -3
  139. data/lib/arclight.rb +6 -1
  140. data/lib/generators/arclight/install_generator.rb +59 -21
  141. data/lib/generators/arclight/templates/arclight.scss +4 -3
  142. data/lib/generators/arclight/templates/catalog_controller.rb +150 -169
  143. data/lib/generators/arclight/templates/config/locales/arclight.en.yml +53 -0
  144. data/lib/generators/arclight/templates/config/repositories.yml +20 -27
  145. data/lib/tasks/index.rake +14 -17
  146. data/package.json +11 -13
  147. data/solr/conf/schema.xml +40 -36
  148. data/solr/conf/solrconfig.xml +33 -31
  149. data/tasks/arclight.rake +8 -7
  150. data/template.rb +0 -1
  151. metadata +111 -104
  152. data/.babelrc +0 -3
  153. data/app/assets/javascripts/arclight/collection_navigation.js +0 -100
  154. data/app/assets/javascripts/arclight/collection_scrollspy.js +0 -6
  155. data/app/assets/javascripts/arclight/context_navigation.js +0 -351
  156. data/app/assets/javascripts/arclight/truncator.js.erb +0 -29
  157. data/app/assets/stylesheets/arclight/bootstrap_overrides.scss +0 -26
  158. data/app/assets/stylesheets/arclight/modules/context_navigation.scss +0 -75
  159. data/app/controllers/concerns/arclight/field_config_helpers.rb +0 -102
  160. data/app/factories/blacklight_field_configuration_factory.rb +0 -30
  161. data/app/views/arclight/repositories/_in_person_repository.html.erb +0 -19
  162. data/app/views/arclight/repositories/_repository_contact.html.erb +0 -9
  163. data/app/views/arclight/viewers/_oembed.html.erb +0 -8
  164. data/app/views/catalog/_access_contents.html.erb +0 -15
  165. data/app/views/catalog/_arclight_abstract_or_scope.html.erb +0 -5
  166. data/app/views/catalog/_arclight_bookmark_control.html.erb +0 -38
  167. data/app/views/catalog/_arclight_document_header_icon.html.erb +0 -1
  168. data/app/views/catalog/_arclight_document_index_header.html.erb +0 -13
  169. data/app/views/catalog/_arclight_document_index_header_hierarchy_default.html.erb +0 -0
  170. data/app/views/catalog/_arclight_document_index_header_online_contents_default.html.erb +0 -0
  171. data/app/views/catalog/_arclight_index_compact_default.html.erb +0 -22
  172. data/app/views/catalog/_arclight_index_default.html.erb +0 -45
  173. data/app/views/catalog/_arclight_index_group_document_compact_default.html.erb +0 -19
  174. data/app/views/catalog/_arclight_index_group_document_default.html.erb +0 -18
  175. data/app/views/catalog/_arclight_online_content_indicator.html.erb +0 -3
  176. data/app/views/catalog/_arclight_rangelimit.html.erb +0 -24
  177. data/app/views/catalog/_arclight_viewer_default.html.erb +0 -1
  178. data/app/views/catalog/_collection_contents.html.erb +0 -4
  179. data/app/views/catalog/_collection_context.html.erb +0 -15
  180. data/app/views/catalog/_collection_context_nav.html.erb +0 -12
  181. data/app/views/catalog/_collection_online_contents.html.erb +0 -17
  182. data/app/views/catalog/_component_context.html.erb +0 -5
  183. data/app/views/catalog/_containers.html.erb +0 -3
  184. data/app/views/catalog/_context_card.html.erb +0 -27
  185. data/app/views/catalog/_context_sidebar.html.erb +0 -8
  186. data/app/views/catalog/_custom_metadata.html.erb +0 -16
  187. data/app/views/catalog/_document_downloads.html.erb +0 -14
  188. data/app/views/catalog/_group_header_compact_default.html.erb +0 -15
  189. data/app/views/catalog/_group_header_default.html.erb +0 -20
  190. data/app/views/catalog/_home.html.erb +0 -1
  191. data/app/views/catalog/_index_breadcrumb_default.html.erb +0 -6
  192. data/app/views/catalog/_index_collection_context_default.html.erb +0 -53
  193. data/app/views/catalog/_index_default.html.erb +0 -17
  194. data/app/views/catalog/_index_header.html.erb +0 -7
  195. data/app/views/catalog/_index_header_online_contents_default.html.erb +0 -1
  196. data/app/views/catalog/_index_online_contents_default.html.erb +0 -6
  197. data/app/views/catalog/_online_content_label.html.erb +0 -5
  198. data/app/views/catalog/_search_form.html.erb +0 -38
  199. data/app/views/catalog/_search_results.html.erb +0 -28
  200. data/app/views/catalog/_show_actions_box_default.html.erb +0 -27
  201. data/app/views/catalog/_show_breadcrumbs_default.html.erb +0 -6
  202. data/app/views/catalog/_show_collection.html.erb +0 -66
  203. data/app/views/catalog/_show_default.html.erb +0 -70
  204. data/app/views/catalog/_show_upper_metadata_collection.html.erb +0 -1
  205. data/app/views/catalog/_show_upper_metadata_default.html.erb +0 -14
  206. data/app/views/catalog/_sort_and_per_page.html.erb +0 -8
  207. data/app/views/catalog/_within_collection_dropdown.html.erb +0 -26
  208. data/app/views/layouts/catalog_result.html.erb +0 -7
  209. data/app/views/shared/_context_sidebar.html.erb +0 -8
  210. data/app/views/shared/_header_navbar.html.erb +0 -61
  211. data/app/views/shared/_show_breadcrumbs.html.erb +0 -27
  212. data/lib/arclight/viewer.rb +0 -45
  213. data/lib/arclight/viewers/oembed.rb +0 -57
  214. data/solr/conf/scripts.conf +0 -24
  215. data/vendor/assets/javascripts/responsiveTruncator.js +0 -69
  216. data/vendor/assets/javascripts/stickyfill.js +0 -480
@@ -1,53 +1,9 @@
1
1
  .al-repository {
2
- background-color: $gray-200;
3
2
  border: $default-border-styling;
4
- margin-bottom: $spacer;
5
-
6
- .al-repository-information {
7
- font-size: $font-size-sm;
8
- padding: $spacer;
9
-
10
- @media (min-width: 992px) {
11
- padding-left: 0;
12
- }
13
-
14
- address {
15
- margin-bottom: 0;
16
- }
17
-
18
- .repo-name {
19
- margin-bottom: $spacer;
20
- }
21
-
22
- .al-repository-contact,
23
- .al-repository-extra-collection-count {
24
- font-weight: 300;
25
- }
26
-
27
- .al-repository-street-address {
28
- margin-bottom: 0.5rem;
29
- }
30
-
31
- .al-repository-description {
32
- margin-right: $spacer;
33
- padding-left: $spacer * 2;
34
-
35
- @media (min-width: 992px) {
36
- border-left: $default-border-styling;
37
- }
38
- }
39
-
40
- .al-repository-extra {
41
- text-align: center;
42
-
43
- .al-repository-extra-collection-count {
44
- font-style: italic;
45
- margin-bottom: $spacer;
46
- }
3
+ }
47
4
 
48
- .al-repository-collection-count {
49
- font-weight: $font-weight-bold;
50
- }
51
- }
5
+ @include media-breakpoint-up(sm) {
6
+ .al-repository-description {
7
+ border-left: $default-border-styling;
52
8
  }
53
9
  }
@@ -1,5 +1,4 @@
1
- .documents-list,
2
- .documents-online_contents {
1
+ .documents-list {
3
2
  margin-bottom: $spacer;
4
3
 
5
4
  // Result item header
@@ -28,10 +27,6 @@
28
27
  }
29
28
  }
30
29
 
31
- form.bookmark-toggle.col-auto {
32
- padding-right: 0;
33
- }
34
-
35
30
  .breadcrumb-links,
36
31
  .al-document-creator,
37
32
  .al-document-extent,
@@ -50,19 +45,17 @@ article.document {
50
45
  .blacklight-icons svg {
51
46
  fill: $secondary;
52
47
  }
53
- .blacklight-icons.al-online-content-icon svg {
54
- fill: $green;
48
+ .al-online-content-icon .blacklight-icons svg {
49
+ fill: $online-icon-color;
55
50
  }
56
51
  div.breadcrumb-links,
57
- div.al-document-abstract-or-scope,
58
- div.al-document-creator {
52
+ dd.al-document-abstract-or-scope,
53
+ dd.al-document-creator {
59
54
  margin-top: ($spacer * .5);
60
55
  }
61
- }
62
56
 
63
- .documents-compact {
64
- h3 {
65
- font-size: $h5-font-size;
57
+ form.bookmark-toggle.col-auto {
58
+ padding-right: 0;
66
59
  }
67
60
  }
68
61
 
@@ -97,6 +90,7 @@ article.document {
97
90
 
98
91
  .al-grouped-more {
99
92
  border-bottom: $default-border-styling;
93
+ margin-bottom: $spacer;
100
94
  padding: ($spacer * .5) 0;
101
95
  }
102
96
 
@@ -119,15 +113,6 @@ article.document {
119
113
  }
120
114
  }
121
115
 
122
- .documents-compact {
123
- .document {
124
- .breadcrumb-links,
125
- .al-repository-footer {
126
- font-size: $font-size-sm;
127
- }
128
- }
129
- }
130
-
131
116
  .al-data-range-histogram {
132
117
  margin-bottom: $spacer;
133
118
  }
@@ -141,22 +126,34 @@ article.document {
141
126
  .documents-compact {
142
127
  margin-bottom: $spacer;
143
128
 
129
+ h3 {
130
+ font-size: $h5-font-size;
131
+ }
132
+
144
133
  .document {
145
134
  border-bottom: $default-border-styling;
135
+ display: flex;
146
136
  padding: $spacer 0;
147
137
 
148
138
  &:first-child {
149
139
  padding-top: 0;
150
140
  }
141
+ .breadcrumb-links,
142
+ .al-repository-footer {
143
+ font-size: $font-size-sm;
144
+ }
151
145
  }
152
146
  }
153
147
 
154
148
  .index-document-functions {
155
149
  display: flex;
150
+ @extend .justify-content-end;
156
151
  }
157
152
 
158
153
  .al-document-container.text-muted {
159
154
  color: $gray-600 !important;
155
+ font-size: 16px;
156
+ float: right;
160
157
  }
161
158
 
162
159
  .col-no-left-padding {
@@ -167,23 +164,13 @@ article.document {
167
164
  padding-right: 0 !important;
168
165
  }
169
166
 
170
- .breadcrumb .media .col, h1.media .col {
171
- flex-basis: auto;
172
- }
173
-
174
- .breadcrumb .media svg, h1.media svg {
175
- fill: $gray-600;
176
- }
177
-
178
167
  .breadcrumb-links a {
179
- border-bottom: 1px dashed $gray-600;
168
+ text-decoration-style: dotted;
180
169
  color: $body-color;
181
170
 
182
171
  &:hover,
183
172
  &:active {
184
- border-color: inherit;
185
- border-bottom-style: solid;
186
- text-decoration: none;
173
+ text-decoration-style: solid;
187
174
  }
188
175
  }
189
176
 
@@ -198,3 +185,67 @@ article.document {
198
185
  .btn-outline-secondary:not(:disabled):not(.disabled).active svg, .btn-outline-secondary:hover svg {
199
186
  fill: $white;
200
187
  }
188
+
189
+ .sort-pagination {
190
+ flex-wrap: wrap;
191
+ }
192
+
193
+ .search-widgets {
194
+ width: 100%;
195
+ align-items: center;
196
+ flex-wrap: wrap;
197
+ justify-content: flex-end;
198
+ }
199
+
200
+
201
+ .result-type-group {
202
+ order: -1;
203
+ flex-grow: 1;
204
+ &.btn-group>.btn {
205
+ flex-grow: 0;
206
+ }
207
+ }
208
+ @include media-breakpoint-down(md) {
209
+ .result-type-group {
210
+ margin-bottom: 0.5rem;
211
+ width: 100%;
212
+ }
213
+
214
+ .search-widgets {
215
+ justify-content: flex-start;
216
+ }
217
+ }
218
+
219
+ .show-document {
220
+ .al-contents {
221
+ .breadcrumb-links {
222
+ display: none;
223
+ }
224
+
225
+ .sort-pagination {
226
+ margin-bottom: 0;
227
+ }
228
+
229
+ article {
230
+ padding-left: 1rem;
231
+ padding-right: 1rem;
232
+ }
233
+
234
+ article:first-child {
235
+ padding-top: 1rem;
236
+ }
237
+
238
+ article:nth-child(odd) {
239
+ background-color: $gray-100;
240
+ }
241
+
242
+ .index_title {
243
+ font-size: 1rem;
244
+ }
245
+
246
+ .bookmark-toggle {
247
+ display: none;
248
+ }
249
+
250
+ }
251
+ }
@@ -1,37 +1,15 @@
1
1
  // Collection context
2
- .al-sticky-sidebar {
3
- position: sticky;
4
- top: 0;
5
- }
6
-
7
2
  .al-show-sub-heading {
8
3
  font-size: $h6-font-size;
9
4
  text-transform: uppercase;
10
-
11
- + dl > dt {
12
- font-size: $font-size-sm;
13
- margin-top: 4px;
14
- text-transform: uppercase;
15
- }
16
5
  }
17
6
 
18
7
  .al-collection-actions-menu {
19
8
  float: right;
20
9
  }
21
10
 
22
- .al-online-content-icon .blacklight-icons svg {
23
- fill: $green;
24
- }
25
-
26
- p.media .col {
27
- flex: auto;
28
- }
29
- // Access tab
30
- #access {
31
- dl dt {
32
- font-size: $font-size-sm;
33
- }
34
-
11
+ // Access
12
+ #access-and-use {
35
13
  dl dd {
36
14
  line-height: 1.4;
37
15
  margin-bottom: $spacer;
@@ -45,21 +23,16 @@ p.media .col {
45
23
  }
46
24
 
47
25
  .al-in-person-repository-name,
48
- .al-in-person-repository-location,
49
- .al-in-person-repository-contact {
26
+ .al-in-person-repository-location {
50
27
  font-size: $font-size-sm;
51
28
  line-height: 1.25;
52
29
  }
53
30
 
54
31
  .al-repository-contact-city_state_zip_country {
55
- margin-bottom: ($spacer / 2);
32
+ margin-bottom: ($spacer * 0.5);
56
33
  }
57
34
  }
58
35
 
59
36
  .al-digital-object.breadcrumb-item {
60
- margin-bottom: ($spacer / 2);
61
- }
62
-
63
- p.media.breadcrumb-item {
64
- margin-bottom: ($spacer / 2);
37
+ margin-bottom: ($spacer * 0.5);
65
38
  }
@@ -0,0 +1,56 @@
1
+ .truncator {
2
+ // content is clamped to 3 lines unless expanded
3
+ .content {
4
+ overflow: hidden;
5
+ display: -webkit-box;
6
+ text-overflow: ellipsis;
7
+ -webkit-box-orient: vertical;
8
+ -webkit-line-clamp: 3;
9
+ }
10
+
11
+ &.expanded .content {
12
+ display: initial;
13
+ }
14
+
15
+ // safari truncation fix
16
+ .content > * {
17
+ margin: 0;
18
+ }
19
+
20
+ // expand/collapse toggle is only shown if content is truncated
21
+ button {
22
+ display: none;
23
+ }
24
+
25
+ &.truncated button {
26
+ display: inline-block;
27
+ }
28
+
29
+ // "view more"/"view less" text swaps when content is expanded
30
+ .view-more {
31
+ display: inline;
32
+ }
33
+
34
+ .view-less {
35
+ display: none;
36
+ }
37
+
38
+ &.expanded {
39
+ .view-more {
40
+ display: none;
41
+ }
42
+
43
+ .view-less {
44
+ display: inline;
45
+ }
46
+ }
47
+
48
+ // icon rotates when content is expanded
49
+ .icon::before {
50
+ content: "▶";
51
+ }
52
+
53
+ &.expanded .icon::before {
54
+ content: "▼";
55
+ }
56
+ }
@@ -1,12 +1,15 @@
1
1
  // Colors
2
- $background-highlight: #ffffaa;
3
- $default-border-color: $border-color;
2
+ $online-icon-color: $green !default;
3
+ $background-highlight: #ffffaa !default;
4
+ $default-border-color: $border-color !default;
5
+ $light-icon-color: #f5f5f5 !default;
6
+ $dark-icon-color: $secondary !default;
4
7
 
5
8
  // Spacing
6
- $result-item-body-padding: 12px;
9
+ $result-item-body-padding: 12px !default;
7
10
 
8
11
  // Mixins
9
- $default-border-styling: 1px solid $default-border-color;
12
+ $default-border-styling: 1px solid $default-border-color !default;
10
13
 
11
14
  @mixin extent-badge {
12
15
  background-color: $gray-200;
@@ -0,0 +1,14 @@
1
+
2
+ <% access_content = capture do %>
3
+ <%= render Arclight::MetadataSectionComponent.with_collection(section_names,
4
+ metadata_attr: { layout: Arclight::UpperMetadataLayoutComponent },
5
+ presenter: presenter) %>
6
+ <% end %>
7
+
8
+ <% if access_content.present? %>
9
+ <div id="<%= t('arclight.views.show.sections.access_field').parameterize %>">
10
+ <h2 class="al-show-sub-heading"><%= t 'arclight.views.show.sections.access_field' %></h2>
11
+
12
+ <%= access_content%>
13
+ </div>
14
+ <% end %>
@@ -0,0 +1,25 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Arclight
4
+ # Render access information for a document
5
+ class AccessComponent < ViewComponent::Base
6
+ def initialize(presenter:)
7
+ super
8
+ @show_config = presenter.configuration.show
9
+ @presenter = presenter
10
+ end
11
+
12
+ attr_reader :presenter, :show_config
13
+
14
+ delegate :collection?, to: :presenter
15
+
16
+ # @return Array<Symbol> a list of metadata section names
17
+ def section_names
18
+ return Array(collection_access_items) if collection?
19
+
20
+ Array(component_access_items)
21
+ end
22
+
23
+ delegate :collection_access_items, :component_access_items, to: :show_config
24
+ end
25
+ end
@@ -0,0 +1,25 @@
1
+ <% if current_or_guest_user %>
2
+ <%= form_tag(bookmark_path,
3
+ authenticity_token: false,
4
+ method: bookmarked? ? :delete : :put,
5
+ class: "bookmark-toggle ms-2",
6
+ data: {
7
+ 'doc-id' => document.id,
8
+ present: "#{blacklight_icon(:bookmark).html_safe}<span class=\"sr-only visually-hidden\">#{t('blacklight.search.bookmarks.present')}</span>",
9
+ absent: "#{blacklight_icon(:bookmark).html_safe}<span class=\"sr-only visually-hidden\">#{t('blacklight.search.bookmarks.absent')}</span>",
10
+ inprogress: t('blacklight.search.bookmarks.inprogress')
11
+ }) do %>
12
+ <div class="checkbox toggle-bookmark">
13
+ <label class="toggle-bookmark" data-checkboxsubmit-target="label">
14
+ <input type="checkbox" class="toggle-bookmark" data-checkboxsubmit-target="checkbox">
15
+ <span data-checkboxsubmit-target="span"><%= bookmarked? ? "#{blacklight_icon(:bookmark).html_safe}<span class=\"sr-only visually-hidden\">#{t('blacklight.search.bookmarks.present')}</span>".html_safe : "#{blacklight_icon(:bookmark).html_safe}<span class=\"sr-only visually-hidden\">#{t('blacklight.search.bookmarks.absent')}</span>".html_safe %></span>
16
+ </label>
17
+ </div>
18
+
19
+ <%= submit_tag(t(bookmarked? ? 'remove.button' : 'add.button', scope: 'blacklight.bookmarks'),
20
+ id: "bookmark_toggle_#{document.id.to_s.parameterize}",
21
+ class: "bookmark-#{bookmarked? ? 'remove' : 'add'} btn btn-outline-secondary") %>
22
+ <% end %>
23
+ <% else %>
24
+ &nbsp;
25
+ <% end %>
@@ -0,0 +1,9 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Arclight
4
+ # A component to render a bookmark button for a document
5
+ class BookmarkComponent < Blacklight::Document::BookmarkComponent
6
+ delegate :current_or_guest_user, :blacklight_icon, to: :helpers
7
+ attr_accessor :document
8
+ end
9
+ end
@@ -0,0 +1,40 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Arclight
4
+ # Display the document hierarchy as "breadcrumbs"
5
+ class BreadcrumbComponent < ViewComponent::Base
6
+ # @param [Integer] count if provided the number of bookmarks is limited to this number
7
+ def initialize(document:, count: nil, offset: 0)
8
+ @document = document
9
+ @count = count
10
+ @offset = offset
11
+ super
12
+ end
13
+
14
+ def call
15
+ breadcrumb_links = components.drop(@offset)
16
+
17
+ if @count && breadcrumb_links.length > @count
18
+ breadcrumb_links = breadcrumb_links.first(@count)
19
+ breadcrumb_links << tag.li('&hellip;'.html_safe, class: 'breadcrumb-item')
20
+ end
21
+ tag.ol class: 'breadcrumb' do
22
+ safe_join(breadcrumb_links)
23
+ end
24
+ end
25
+
26
+ def components
27
+ return to_enum(:components) unless block_given?
28
+
29
+ yield build_repository_link
30
+
31
+ @document.parents.each do |parent|
32
+ yield tag.li(class: 'breadcrumb-item') { link_to(parent.label, solr_document_path(parent.global_id)) }
33
+ end
34
+ end
35
+
36
+ def build_repository_link
37
+ render Arclight::RepositoryBreadcrumbComponent.new(document: @document)
38
+ end
39
+ end
40
+ end
@@ -0,0 +1,34 @@
1
+ <ol class="breadcrumb">
2
+ <li class="breadcrumb-home-link">
3
+ <%= link_to t('arclight.routes.home'), root_path %>
4
+ </li>
5
+ <li class="breadcrumb-item breadcrumb-item-1">
6
+ <span aria-hidden="true"><%= blacklight_icon :repository, classes: 'al-repository-content-icon' %></span>
7
+ <span class="breadcrumb-text"><%= repository %></span>
8
+ <ol class="breadcrumb">
9
+ <% if collection %>
10
+ <li class="breadcrumb-item breadcrumb-item-2">
11
+ <span aria-hidden="true"><%= blacklight_icon :collection, classes: 'al-collection-content-icon' %></span>
12
+ <span class="breadcrumb-text"><%= link_to collection.label, solr_document_path(collection.global_id) %></span>
13
+
14
+ <ol class="breadcrumb">
15
+ <% parents_under_collection.each do |parent| %>
16
+ <li class="breadcrumb-item breadcrumb-item-3">
17
+ <span class="breadcrumb-text"><%= link_to parent.label, solr_document_path(parent.global_id) %></span>
18
+ </li>
19
+ <% end %>
20
+
21
+ <li class="breadcrumb-item breadcrumb-item-4">
22
+ <span class="breadcrumb-text"><%= @presenter.heading %></span>
23
+ </li>
24
+ </ol>
25
+ </li>
26
+ <% else # this is a collection %>
27
+ <li class="breadcrumb-item breadcrumb-item-4">
28
+ <span aria-hidden="true"><%= blacklight_icon :collection, classes: 'al-collection-content-icon' %></span>
29
+ <span class="breadcrumb-text"><%= @presenter.heading %></span>
30
+ </li>
31
+ <% end %>
32
+ </ol>
33
+ </li>
34
+ </ol>
@@ -0,0 +1,25 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Arclight
4
+ # Render the hierarchy for a document
5
+ class BreadcrumbsHierarchyComponent < ViewComponent::Base
6
+ delegate :document, to: :@presenter
7
+ delegate :blacklight_icon, to: :helpers
8
+
9
+ def initialize(presenter:)
10
+ super
11
+
12
+ @presenter = presenter
13
+ collections, @parents_under_collection = document.parents.partition(&:collection?)
14
+ @collection = collections.first
15
+ end
16
+
17
+ attr_reader :collection, :parents_under_collection
18
+
19
+ def repository
20
+ return tag.span(t('arclight.show_breadcrumb_label')) if document.repository_config.blank?
21
+
22
+ link_to(document.repository_config.name, helpers.arclight_engine.repository_path(document.repository_config.slug))
23
+ end
24
+ end
25
+ end
@@ -0,0 +1,12 @@
1
+ <div class='al-show-actions-box mb-3'>
2
+ <div class="al-actions-box-container">
3
+ <button type="button" class="btn-close d-lg-none float-end mt-1 me-1" data-bs-dismiss="offcanvas" data-bs-target="#sidebar" aria-label="Close"></button>
4
+ <h2>Collection</h2>
5
+ <h3><%= title %></h3>
6
+
7
+ <div class="al-collection-context-actions d-flex flex-wrap gap-1">
8
+ <%= document_download %>
9
+ <%= collection_info %>
10
+ </div>
11
+ </div>
12
+ </div>
@@ -0,0 +1,27 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Arclight
4
+ # Render various actions for a collection (e.g. requesting, download links, etc)
5
+ class CollectionContextComponent < ViewComponent::Base
6
+ def initialize(presenter:, download_component:)
7
+ super
8
+
9
+ @collection = presenter.document.collection
10
+ @download_component = download_component
11
+ end
12
+
13
+ attr_reader :collection
14
+
15
+ def title
16
+ collection.normalized_title
17
+ end
18
+
19
+ def document_download
20
+ render @download_component.new(downloads: collection.downloads) || Arclight::DocumentDownloadComponent.new(downloads: collection.downloads)
21
+ end
22
+
23
+ def collection_info
24
+ render Arclight::CollectionInfoComponent.new(collection: collection)
25
+ end
26
+ end
27
+ end
@@ -0,0 +1,28 @@
1
+ <div class='al-show-actions-box-info'>
2
+
3
+ <div class="dropdown">
4
+ <button class="dropdown-toggle btn btn-secondary btn-sm" type="button" data-bs-toggle="dropdown" aria-expanded="false">
5
+ <%= info_icon %> <%= t('.more_info') %>
6
+ </button>
7
+ <div class="dropdown-menu shadow-lg p-2" style="min-width: 300px;" >
8
+ <table style="width: 100%">
9
+ <tr>
10
+ <th scope="row"><%= t('.collection_id') %></th>
11
+ <td><%= collection_unitid %></td>
12
+ </tr>
13
+ <tr>
14
+ <th scope="row"><%= t('.total_components') %></th>
15
+ <td><%= total_component_count %></td>
16
+ </tr>
17
+ <tr>
18
+ <th scope="row"><%= t('.online_items') %></th>
19
+ <td><%= tag.span blacklight_icon(:online), class: 'al-online-content-icon' %><%= online_item_count %></td>
20
+ </tr>
21
+ <tr>
22
+ <th scope="row"><%= t('.last_indexed') %></th>
23
+ <td><%= last_indexed.strftime('%F') %></td>
24
+ </tr>
25
+ </table>
26
+ </div>
27
+ </div>
28
+ </div>
@@ -0,0 +1,26 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Arclight
4
+ # Render information about the collection
5
+ class CollectionInfoComponent < ViewComponent::Base
6
+ def initialize(collection:)
7
+ super
8
+
9
+ @collection = collection
10
+ end
11
+
12
+ attr_reader :collection
13
+
14
+ delegate :total_component_count, :online_item_count, :last_indexed, :collection_unitid, to: :collection
15
+ delegate :blacklight_icon, to: :helpers
16
+
17
+ def info_icon
18
+ icon = <<~SVG
19
+ <svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="bi bi-info-circle-fill" viewBox="0 0 16 16">
20
+ <path d="M8 16A8 8 0 1 0 8 0a8 8 0 0 0 0 16zm.93-9.412-1 4.705c-.07.34.029.533.304.533.194 0 .487-.07.686-.246l-.088.416c-.287.346-.92.598-1.465.598-.703 0-1.002-.422-.808-1.319l.738-3.468c.064-.293.006-.399-.287-.47l-.451-.081.082-.381 2.29-.287zM8 5.5a1 1 0 1 1 0-2 1 1 0 0 1 0 2z"/>
21
+ </svg>
22
+ SVG
23
+ icon.html_safe # rubocop:disable Rails/OutputSafety
24
+ end
25
+ end
26
+ end
@@ -0,0 +1,15 @@
1
+ <nav class="al-sidebar-navigation-context sidebar-section" aria-labelledby="collection-nav">
2
+ <h2 id="collection-nav"><%= t('arclight.views.show.context_nav.title') %></h2>
3
+ <ul class='nav flex-column'>
4
+ <% partials.each do |section| %>
5
+ <% next unless has_section?(section) %>
6
+ <li class='nav-item'>
7
+ <%= link_to section_label(section),
8
+ document_section_path(section),
9
+ class: 'nav-link pl-0 ps-0 py-1',
10
+ data: { turbolinks: 'false' }
11
+ %>
12
+ </li>
13
+ <% end %>
14
+ </ul>
15
+ </nav>