Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/samvera/samvera.github.io
Public website for version controlled Samvera documentation (mostly Hyrax)
https://github.com/samvera/samvera.github.io
core-components samvera-community
Last synced: 14 days ago
JSON representation
Public website for version controlled Samvera documentation (mostly Hyrax)
- Host: GitHub
- URL: https://github.com/samvera/samvera.github.io
- Owner: samvera
- License: apache-2.0
- Created: 2016-02-18T15:43:02.000Z (almost 9 years ago)
- Default Branch: main
- Last Pushed: 2024-08-29T17:57:12.000Z (5 months ago)
- Last Synced: 2024-11-10T03:36:12.875Z (2 months ago)
- Topics: core-components, samvera-community
- Language: HTML
- Homepage: http://samvera.github.io
- Size: 12.7 MB
- Stars: 7
- Watchers: 65
- Forks: 17
- Open Issues: 120
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Support: SUPPORT.md
Awesome Lists containing this project
README
# samvera.github.io
Code:
[![Build Status](https://circleci.com/gh/samvera/samvera.github.io.svg?style=svg)](https://circleci.com/gh/samvera/samvera.github.io)Docs:
[![Contribution Guidelines](http://img.shields.io/badge/CONTRIBUTING-Guidelines-blue.svg)](./CONTRIBUTING.md)
[![Apache 2.0 License](http://img.shields.io/badge/APACHE2-license-blue.svg)](./LICENSE)Community Support: [![Samvera Community Slack](https://img.shields.io/badge/samvera-slack-blueviolet)](http://slack.samvera.org/)
## What is `samvera.github.io`?
This project serves as the public website for version-controlled Samvera documentation (with a specific focus towards [Hyrax](https://github.com/samvera/hyrax)).
## Product Owner & Maintenance
`samvera.github.io` was a Core Component of the Samvera Community. Given a decline in available labor required for maintenance, this project no longer has a dedicated Product Owner. The documentation for what this means can be found [here](http://samvera.github.io/core_components.html#requirements-for-a-core-component).
### Product Owner
**Vacant**
_Until a Product Owner has been identified, we ask that you please direct all requests for support, bug reports, and general questions to the [`#dev` Channel on the Samvera Slack](https://samvera.slack.com/app_redirect?channel=dev)._
# Help
The Samvera community is here to help. Please see our [support guide](./SUPPORT.md).
## How Does This Work?
We use a Jekyll-based custom theme for markup and display, and pages are published to http://samvera.github.io.
## Adding or Editing Content
These are community documents, so we rely on the pull request model. If you'd like to contribute content:
- clone this project (link on [samvera/samvera.github.io](http://samvera.github.io))
- make a branch for your new documentation
- run `bundle install`
- create/edit pages within the Samvera directory (e.g. [/pages/samvera/](https://github.com/samvera/samvera.github.io/tree/master/pages/samvera))
- add links to the page in home_sidebar.yml
- write content ([notes on writing content](#notes-on-writing-content))
- add/update [front matter](#basic-front-matter), including updating the last_updated date if content changed.
- [add versioning information](#versioning-information) for the gem version the document page describes
- update [browse pages](#browse-pages) if necessary
- submit a Pull RequestTo Test in Jekyll:
* Run the jekyll server
`bundle exec jekyll serve`
* View the documentation in a browser at http://localhost:4000### Basic Front Matter
The front matter on each page controls how the page is built and functions.Example front matter for page [Best Practices -> Coding Styles](https://raw.githubusercontent.com/samvera/samvera.github.io/master/pages/samvera/developer_resources/best_practices/coding_style.md)
```
---
title: "Coding Style with RuboCop"
permalink: best-practices-coding-styles.html
folder: samvera/best_practices/
sidebar: home_sidebar
keywords: ["Best Practices", "Coding Styles", "Rubocop"]
tags: [development_resources]
version:
id: 'hyrax_1.0-stable'
last_updated: March 30, 2017
---
```
#### Front Matter Options
* **title** [String] _(required)_ - The title displayed on the generated html page
* **permalink** [text] _(required)_ - The name of the generated html file that will be part of the url accessed by users
* **last_updated** [text] _(recommended)_ - Text version of updated date, to show in page footer.
* **keywords** [Array] _(recommended)_ - Used as titles in the generated `browse_pages.html` for browsing by keyword, and as keywords that get populated into the metadata for SEO
* **sidebar** [text] _(optional)_ - Default value is `home_sidebar`, and the only option at this point
* **version** [hash] _(optional)_ - Specifies the gem's name and version that this documentation page describes. See [Versioning Information](#versioning-information) for details.
* **toc** false _(optional)_ - Prevents display of formatting-based table of contents on page. Default value of true displays the table of content.
* **tags** [Array] _(optional)_ - Automatically populate pages for each of the 4 major categories included on the main page. If you use a tag, you should also add a summary. Valid tags values:
* getting_started
* development_resources
* production
* community
* **summary** [text] _(optional)_ - Adds formatted summary text, prefaced by a vertical bar, at the top of a page. Also used as the excerpt text on the 4 category pages linked from the main page.
* **layout** _(optional)_ - values:
* page _(default value)_
* post - adds breadcrumbs to the top of the page linking to corresponding tags page (see valid tags front matter above)
* deck - display as slideshow: see [Touring the Design Patterns in Samvera](http://samvera.github.io/touring_samvera_index.html)
* **folder** [text] _(optional)_ - The location of this `*.md` file under the pages directory. Does not appear to have any functionality.### Notes on writing content
You can highlight content with the following...
```
- This shows an info icon and provides the user additional information in a blue box.
```
![info box](https://github.com/samvera/samvera.github.io/tree/master/assets/images/readme_documentation/info_box.jpg "Info Box")
(Example: [code](https://raw.githubusercontent.com/samvera/samvera.github.io/master/pages/hydra/developer_resources/customize_metadata/hyrax_1.0/generate-work-type.md), [webpage](http://samvera.github.io/customize-metadata-generate-work-type.html))
```
- This shows a warning icon and provides the user warning information in a red box.
```
![warning box](https://github.com/samvera/samvera.github.io/tree/master/assets/images/readme_documentation/warning_box.jpg "Warning Box")
```
- This shows a question icon and provides the user with information in a yellow box indicating that there may be some uncertainty about a particular piece of information in the documentation.
```
![question box](https://github.com/samvera/samvera.github.io/tree/master/assets/images/readme_documentation/question_box.jpg "Question Box")
NOTE: You cannot use markdown in these boxes. For example, if you want a link, you will have to use an html anchor tag.
### Browse pages
This site incudes a generated browse page. Each page's frontmatter `keywords` values are used to populate the browse by keyword page. The keywords should be written as titles, in upper and lower case, as they will be directly used as text on the page.
When changes are committed, the page needs to be regenerated and included with the committed changes. To build and save the revised `browse_pages.html` file:
* Run command `SAVE_GENERATED_FILES=1 bundle exec jekyll build`
Be sure to include the generated file in your pull request.
### Versioning-information
The documentation on this site covers multiple gems and multiple versions of those gems. The recommended best practice is to specify the gem's name and version, including a link to the applicable branch in github. If there is documentation for multiple versions of the gem, then a selection list allows users to switch between versions.
#### Specifying gem name, version, and branch
##### Predefined version information
Common gems have version information encoded and can be referenced by id in front matter. The predefined version information is defined in [_includes/version_info/](https://github.com/samvera/samvera.github.io/tree/master/_includes/version_info)
Example for Hyrax v1.0 stable:
```
version:
id: 'hyrax_1.0-stable'
```
##### Custom version information
If the predefined version information does not exist. You can specify custom values in the front matter.
Example custom version information:
```
version:
label: 'Hydra Role Management v0.2.2'
branch:
label: 'master'
link: 'https://github.com/samvera/hydra-role-management'
```
##### Adding predefined version information for a gem version
It is good practice to add predefined version information, as this allows reuse and consistent encoding of gem names and versions.
Adding predefined version information is a two step process.
1. Add the version information to a new version file in directory [_includes/version_info/](https://github.com/samvera/samvera.github.io/tree/master/_includes/version_info) naming the file with the gem and verion number (e.g. version_hyrax_1.0-stable.html). Include in the new file assignments for version_label, branch_label, and branch_link.
Example assignments for Hyrax v1.0:
```
{% assign version_label = 'Hyrax stable v1.0' %}
{% assign branch_label = '1.0-stable' %}
{% assign branch_link = 'https://github.com/samvera/hyrax/tree/1-0-stable' %}
```
2. Add a new condition in [_includes/versions.html](https://github.com/samvera/samvera.github.io/tree/master/_includes/versions.html) that includes the predefined version information if its id is specified in front matter for a document. The condition in the case statement becomes the id that is used in front matter.
Example conditional include based on id:
```
{% case page.version.id %}
{% when 'hyrax_1.0-stable' %}
{% include version_info/version_hyrax_1.0-stable.html %}
...
{% endcase %}
```
#### Selector for switching versions
Identifying multiple versions is done by specifying each version in front matter including its label and link. If the version is the active version that the current page is describing, then also include `selected: 'true'`. The multi-version information is repeated on every version's page for the documentation topic.
Example front matter for multiple versions:
```
version:
versions:
- label: 'Hyrax 1.0'
link: 'what-happens-deposit-1.0.html'
selected: 'true'
- label: 'Hyrax 2.0'
link: 'what-happens-deposit-2.0.html'
```
## Our Theme
We use a Jekyll theme designed for [documentation](https://github.com/tomjohnson1492/documentation-theme-jekyll). We chose the Documentation Theme because of its excellent navigation and clear page layout, and for the ease of working in markdown.
## Contributing
If you're working on PR for this project, create a feature branch off of `main`.
This repository follows the [Samvera Community Code of Conduct](https://samvera.atlassian.net/wiki/spaces/samvera/pages/405212316/Code+of+Conduct) and [language recommendations](https://github.com/samvera/maintenance/blob/master/templates/CONTRIBUTING.md#language). Please ***do not*** create a branch called `master` for this repository or as part of your pull request; the branch will either need to be removed or renamed before it can be considered for inclusion in the code base and history of this repository.