Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

docs: updated README and release concurrency #1567

Merged
merged 5 commits into from
Sep 20, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion .github/workflows/release.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ env:


concurrency:
group: production-${{ github.ref }}
group: production-${{ github.workflow }}
cancel-in-progress: true

jobs:
Expand Down
1 change: 1 addition & 0 deletions .github/workflows/version-branch-update.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,7 @@ jobs:

- name: Netlify Build
run: |
make versions-ci
netlify build --context deploy-preview


Expand Down
147 changes: 115 additions & 32 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,10 +13,13 @@ There are two local development paths available; Docker based, and non-Docker ba

To contribute, we recommend having the following software installed locally on your workstation.

- Text Editor
- VScode or a text editor

- [Docker](https://docs.docker.com/desktop/)

- git configured and access to github repository
- node and npm (optional)

- Node.js and npm (optional)

## Local Development (Docker)

Expand All @@ -36,16 +39,24 @@ To start the Dockererized local development server, issue the command:
make docker-start
```

The local development server is ready when the following output is displayed in your terminal.
The local development server is ready when the following output is displayed in your terminal.

```shell
You can now view root in the browser.
Local: http://localhost:9000/
On Your Network: http://172.17.0.2:9000/
npm run start

> [email protected] start
> docusaurus start --host 0.0.0.0 --port 9000

Visit [http://localhost:9000](http://localhost:9000) to view the local development documentation site.
[INFO] Starting the development server...
[SUCCESS] Docusaurus website is running at: http://localhost:9000/

✔ Client
Compiled successfully in 8.39s

client (webpack 5.88.2) compiled successfully
```

Open up a browser and navigate to [http://localhost:9000](http://localhost:9000) to view the documentation website.

To exit from the local development Docker container. Press `Ctrl + Z`.

Expand All @@ -66,32 +77,31 @@ cd librarium
make init
```

# Documentation Content
## Documentation Content

Create a branch if needed. This will keep your work separated from the rest of your changes.
Create a branch to keep track of all your changes.

```sh
git checkout -b <branch_name>
```

To preview your changes use the following.
Make changes to any markdown files in the [`docs/docs-content`](./docs/docs-content/) folder.


Start the local development server and preview your changes by navigating to the documentation page you modified.
You can start the local development server by issuing the following command:


```sh
make start
```

This will open your browser to this address: http://localhost:9000

Open `~/Work/librarium/content/docs` in your editor and make changes. They should be synced up in the browser window.

When you are done with some changes you can create a commit
When you are done with your changes, stage your changes and create a commit

```sh
make commit MESSAGE="<your message here>"
git add -A && git commit -m "docs: your commit message here"
```

This will open your browser with the commit. Once the pull request is created a link will be added in the comments to preview the change in a staging environment.

## Creating Pages

The documentation website is structured in a sidebar with main pages and sub-pages. Main pages will contain an overview of the its sub pages.
Expand Down Expand Up @@ -150,23 +160,96 @@ The index document for a folder follows the naming convention below. Here are so
- Named as README (case-insensitive): `docs/Guides/README.mdx`
- Same name as the parent folder: `docs/Guides/Guides.md`

#### Referencing a page
### Markdown Links and URLs
Markdown links use file path references to link to other documentation pages.
The markdown link is composed of the file path to the page in context from the current file. All references to a another documentation page must end with the `.md` extension. Docusaurus will automatically remove the `.md` extension from the URL during the compile. The file path is needed for Docuasurus to generate the correct URL for the page when versioning is enabled.


The url of a page will be composed from the path of the file relative to the `content` directory.

**Example** docs/content/1-introduction/1-what-is.md will have http://localhost:9000/introduction/what-is as the url
The following example shows how to reference a page in various scenarios. Assume you have the following folder structure when reviewing the examples below:

karl-cardenas-coding marked this conversation as resolved.
Show resolved Hide resolved
In markdown you can reference this page relatively to the root of the domain using this syntax:
```shell
.
└── docs
└── docs-content
├── architecture
│   ├── grpc.md
│   └── ip-addresses.md
├── aws
│   └── iam-permissions.md
├── clusters
└── security.md
```

#### Same Folder

karl-cardenas-coding marked this conversation as resolved.
Show resolved Hide resolved
To link to a file in the same folder, you can use the following syntax:

```md
[Go to introduction](/introduction/what-is)
![Insert a description here](name_of_file.md)
```

You can also reference pages that reside in the document folder, such as index pages. An example is the Dev Engine index page `/docs/04.5-devx.md`. To reference the Dev Engine index page in a documentat page, referce the page by the title.
Because the file is in the same folder, you do not need to specify the path to the file. Docusaurus will automatically search the current folder for the file when compiling the markdown content.

So, if you are in the file `grpc.md` and want to reference the file `ip-addresses.md`, you would use the following syntax:

```md
![A list of all Palette public IP addresses](ip-addresses.md)
```

#### Different Folder

If you want to link to a file in a different folder, you have to specify the path to the file from where the current markdown file is located.

If you are in the file `security.md` and want to reference the file `iam-permissions.md`, you have to use the following syntax:

```md
[Go to Dev Enging](/devx)
![A list of all required IAM permissions for Palette](aws/iam-permissions.md)
```

If you are in the file `grpc.md` and want to reference the file `iam-permissions.md`, you have to use the following syntax:

```md
![A list of all required IAM permissions for Palette](../aws/iam-permissions.md)
```

#### A Heading in the Same File

To link to a heading in the same file, you can use the following syntax:

```md
[Link to a heading in the same file](#heading-name)
```

The `#` symbol is used to reference a heading in the same file. The heading name must be in lowercase and spaces must be replaced with a `-` symbol. Docusaurs by default uses dashes to separate words in the URL.

#### A Heading in a Different File

To link to a heading in a different file, you can use the following syntax:

```md
[Link to a heading in a different file](name_of_file.md#heading-name)
```
For example, if you are in the file `grpc.md` and want to reference the heading `Palette gRPC API` in the file `security.md`, you would use the following syntax:

```md
[Link to a heading in a different file](../security.md#palette-grpc-api)
```
The important thing to remember is that the `#` comes after the file name and before the heading name.

#### Exceptions

As of Docusarus `2.4.1`, the ability to link to documentation pages that belong to another plugin is unavailable. To work around this limitation, reference a documentation page by the URL path versus the file path.

```md
[Link to a page in another plugin](/api-content/authentication#api-key)
```

> [!WARNING]
> Be aware that this approach will break versioning. The user experience will be impacted as the user will be redirected to the latest version of the page.


In future releases, Docusaurus will support linking pages from other Docusarus plugins. Once this feature is available, this documentation will be updated.
### Redirects

To add a redirect to an existing documentation page you must add an entry to the [redirects.js](/src/shared/utils/redirects.js) file. Below is an example of what a redirect entry should look like.
Expand All @@ -178,7 +261,7 @@ To add a redirect to an existing documentation page you must add an entry to the
},
```

#### Multi Object Selector
### Multi Object Selector

The Packs integration page and the Service Listings page use a component to display the various offerings.
Packs intergations use the `<Packs />` component, whereas the Service Tiers from App Mode use the `<AppTiers />` component.
Expand All @@ -197,7 +280,7 @@ To add a Service to the Service List complete the following actions:
- Populate the page with content.


#### Images or other assets
### Images or other assets

All images must reside in the [`assets/docs/images`](./assets/docs/images/) folder.

Expand All @@ -218,7 +301,7 @@ Image size loading can be customised. You can provide eager-load to images in th
![alt text eager-load](/clusterprofiles.png)
```

#### Tabs component
### Tabs component

To use the tabs component you have to import it from the _shared_ folder

Expand All @@ -242,7 +325,7 @@ After that, you can use it like this
- the values can be one of the tab panel keys
- additionally you may refer to different sections from the inner tab using the anchor points(using the #section-1)

#### YouTube Video
### YouTube Video

To use a Youtube video us the YouTube component.

Expand All @@ -251,7 +334,7 @@ In your markdown file, use the component and ensure you specify a URL.
```js
<YouTube url="https://www.youtube.com/embed/wM3hcrHbAC0" title="Three Common Kubernetes Growing Pains - and how to solve them" />
```
### Points of interest component
### Points of Interest


```js
Expand Down