Skip to content

Commit

Permalink
docs: support VitePress official docs 🚀
Browse files Browse the repository at this point in the history
  • Loading branch information
Avivbens committed Apr 19, 2024
1 parent 62b2563 commit dc17a67
Show file tree
Hide file tree
Showing 21 changed files with 1,886 additions and 185 deletions.
129 changes: 3 additions & 126 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,8 @@ installs apps, configures your dev system, and personalizes your working station

[!["Buy Me A Coffee"](https://www.buymeacoffee.com/assets/img/custom_images/orange_img.png)](https://www.buymeacoffee.com/kcao7snkgx)

### [Read Our Official Docs 📚](https://github.com/Avivbens/shell-config/pages)

</div>

<div align="left">
Expand All @@ -29,33 +31,7 @@ sudo cd && /bin/bash -c "$(curl -fsSLk https://raw.githubusercontent.com/avivben

`shell-config` is your go-to CLI tool for seamless MacOS configuration, app installation and zsh aliases commands.

Set up the very same environment, with a personalization touch just for your needs, on all your Macs in minutes, and enjoy a consistent experience across all your devices.

## CLI Features

📦 **Effortless App Installation:**

- Install apps with default selections or customized user profiles.
- Choose what suits **your needs**, whether you're a developer, designer, or data scientist. 💻

🐚 **Plug & Play Shell Settings:**

- Optimize your command line with bash functions and aliases.
- Tailor your shell experience by enabling or disabling specific features.

🔄 **Version Control:**

- Effortlessly switch between CLI versions and receive notifications about new updates.

🖥️ **MacOS Compatibility:**

- Compatible with MacOS 11 and above, ensuring seamless integration across all MacOS architectures. 🍏💻

🛠️ **Generate & Manage Assets Files:**

- Easily generate or update asset files like `.npmrc` and `.gitconfig` with the settings you need.
- `shell-config` supports multiple profiles, allowing you to create and manage various configurations for different projects or team requirements.
- Seamlessly switch between profiles to adapt your environment to the task at hand.
Set up the very same environment, with a personalization touch just for your needs, on every MacOS machine within minutes, enjoy a consistent experience across all devices.

</div>

Expand All @@ -73,107 +49,8 @@ If you're facing issues like the following, **FORCE QUIT** the terminal and open
Error: Cannot find module '*/shell-config/*'
```

## CLI Usage

Opt-in OR opt-out global bash functions and configurations.

```bash
shell-config shell
```

<br>

Select apps to install.
<br>
We're now support [preferences based on your selection!](#Screenshots)
<br>
**Pay attention to passwords inputs if needed!**

```bash
shell-config install
```

<br>

Apply npmrc and gitconfig files, with secrets.
Support multiple accounts.
<br>
Pay attention to passwords inputs if needed!

```bash
shell-config assets
```

<br>

Install external shell configurations - share your bash functions with others!

```bash
shell-config external --help
```

<br>

Select CLI version / update version, target is optional - default is latest

```bash
shell-config update --target {version}
```

## Supported Terminal Features

- System commands
- Git commands
- Node & NPM commands
- Google-Cloud-Sdk
- Homebrew
- Fig
- Autosuggest
- Autocomplete
- Colored Correct Code
- Mongodb
- Redis
- Angular
- Nestjs
- Typescript

<br>

# Modules federation

### Entry points

- [.entry-point](zsh/.entry-point.sh) - entry point from `.zshrc`, contains `source` commands for all modules, load the `.zshrc.extends` file
- [.zshrc.extends](zsh/.zshrc.extends.sh) - entry point for all modules, imports them from `.zshrc.extends.*.sh` files

### Modules

- [Git](zsh/extends/.zshrc.extends.git.sh)
- [VSCode](zsh/extends/.zshrc.extends.vscode.sh)
- [Npm](zsh/extends/.zshrc.extends.npm.sh)
- [Angular](zsh/extends/.zshrc.extends.angular.sh)
- [MongoDB](zsh/extends/.zshrc.extends.mongo.sh)
- [Python](zsh/extends/.zshrc.extends.python.sh)
- [Redis](zsh/extends/.zshrc.extends.redis.sh)
- [Nest](zsh/extends/.zshrc.extends.nest.sh)
- [Theme](zsh/extends/.zshrc.extends.theme.sh)

<br>

## Contributing

Good to know that you want to contribute to this project! 🎉

See [CONTRIBUTING.md](CONTRIBUTING.md)

## Screenshots

<div align="center">

<img src="docs/install-options.jpg" style="width: 49%; object-fit: cover; border-radius: 10px;">
<img src="docs/shell-command.jpg" style="width: 49%; object-fit: cover; border-radius: 10px;">
<img src="docs/assets-command.jpg" style="width: 49%; object-fit: cover; border-radius: 10px;">
<img #tags-pref src="docs/select-tags.jpg" style="width: 49%; object-fit: cover; border-radius: 10px;">
<img src="docs/install-command.jpg" style="width: 49%; object-fit: cover; border-radius: 10px;">

</div>
1 change: 1 addition & 0 deletions docs/.vitepress/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
cache/**/*
36 changes: 36 additions & 0 deletions docs/.vitepress/config.mts
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
import { defineConfig } from 'vitepress'
import { remoteDefaultBranch, repositoryFullname } from './constants/repository.mjs'
import { NAVBAR } from './navbar.config.mjs'
import { SIDEBAR } from './sidebar.config.mjs'

// https://vitepress.dev/reference/site-config
export default defineConfig({
title: 'Shell Config',
description: 'CLI Tool for MacOS setup - apps, shell, assets, etc',
base: `/pages/${repositoryFullname}/`,
cleanUrls: true,
ignoreDeadLinks: false,
outDir: '../dist/docs/',
markdown: {
defaultHighlightLang: 'typescript',
breaks: true,
lineNumbers: true,
},
themeConfig: {
// https://vitepress.dev/reference/default-theme-config
nav: NAVBAR,
sidebar: SIDEBAR,
socialLinks: [
//
{ icon: 'github', link: `https://github.com/${repositoryFullname}#readme` },
],
search: { provider: 'local' },
editLink: {
pattern: `https://github.com/${repositoryFullname}/edit/${remoteDefaultBranch}/docs/:path`,
text: 'Edit this page on GitHub',
},
lastUpdated: {
formatOptions: { dateStyle: 'medium' },
},
},
})
26 changes: 26 additions & 0 deletions docs/.vitepress/constants/repository.mts
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
import { execSync } from 'node:child_process';
import { env } from 'node:process';

const remoteOrigin =
env.GITHUB_SERVER_URL && env.GITHUB_REPOSITORY
? `${env.GITHUB_SERVER_URL}/${env.GITHUB_REPOSITORY}.git`
: execSync('git remote get-url origin').toString().trim();

export const remoteBaseURL = new URL(remoteOrigin).origin;

export const repositoryLink = remoteOrigin.replace(/\.git$/m, '');

export const repositoryFullname = env.GITHUB_REPOSITORY || remoteOrigin.match(/^https:\/\/.*\/(.*\/.*).git$/m)?.[1];

// TODO: dynamically get the default branch
export const remoteDefaultBranch = 'master';

if (!remoteBaseURL) {
throw new Error('Could not find remote base URL!');
} else if (!repositoryLink) {
throw new Error('Could not find repository link!');
} else if (!repositoryFullname) {
throw new Error('Could not find repository fullname!');
} else if (!remoteDefaultBranch) {
throw new Error('Could not find remote default branch!');
}
3 changes: 3 additions & 0 deletions docs/.vitepress/navbar.config.mts
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
import { DefaultTheme } from 'vitepress';

export const NAVBAR: DefaultTheme.NavItem[] = [{ text: 'Home', link: '/' }];
42 changes: 42 additions & 0 deletions docs/.vitepress/sidebar.config.mts
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
import { DefaultTheme } from 'vitepress'

export const SIDEBAR: DefaultTheme.Sidebar = [
{
text: 'Commands',
collapsed: false,
base: '/app/commands/',
items: [
{
text: 'Install',
link: '/install.md',
},
{
text: 'Shell',
link: '/shell.md',
},
{
text: 'Assets',
link: '/assets.md',
},
{
text: 'Update',
link: '/update.md',
},
],
},
{
text: 'Troubleshooting',
collapsed: false,
base: '/app/troubleshooting/',
items: [
{
text: 'Permissions',
link: '/permissions.md',
},
{
text: 'Not Found',
link: '/not-found.md',
},
],
},
]
38 changes: 38 additions & 0 deletions docs/app/commands/assets.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
<script setup>
const repoUrl = 'https://github.com/Avivbens/shell-config/tree/HEAD'
</script>

# Assets Command

The `assets` command is used to configure your MacOS assets, such as `gitconfig` and `npmrc`.

## Usage

```bash
shell-config assets
```

Select and customize the assets according to your needs, by using the arrow keys and space bar to enter into menus. Press `Enter` to apply the selected assets.

For each selected asset, you'd be asked to provide the required information.

::: warning **Note ❗**
For some configuration, you may be asked to provide your password.
Pay attention to the password inputs if needed! *(key icon)*
:::

## Multi Profiles Support

Both `gitconfig` and `npmrc` assets support multi profiles.

You can create as many profiles as you wish, and simply switch between them using the `npmrc` NPM package / `swgit` command for `gitprofile`.

## Assets

- [Git Profile](https://github.com/Avivbens/shell-config/tree/HEAD/assets/.gitconfig.template)
- [npmrc Default](https://github.com/Avivbens/shell-config/tree/HEAD/assets/.npmrc.template)
- [npmrc Custom](https://github.com/Avivbens/shell-config/tree/HEAD/assets/.npmrc.custom.template)

## Examples

![Assets Page](../../assets/assets-command.jpg)
28 changes: 28 additions & 0 deletions docs/app/commands/install.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
# Install Command

The `install` command is used to install useful MacOS applications.

This command will install the application and all of its dependencies.

## Usage

```bash
shell-config install
```

Select the applications you want to install by using the arrow keys and space bar to select/deselect the applications. Press `Enter` to install the selected applications.

::: warning **Note ❗**
For some applications, you may be asked to provide your password.
Pay attention to the password inputs if needed! *(key icon)*
:::

## Profiles

You can set a predefined selected applications by using the profiles feature. Simply select the relevant profiles you'd like to have, and press `Enter` to preselect relevant applications.

## Examples

![Install Profiles](../../assets/select-tags.jpg)
![Install Options](../../assets/install-options.jpg)
![After Install](../../assets/install-command.jpg)
33 changes: 33 additions & 0 deletions docs/app/commands/shell.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
<script setup>
const repoUrl = 'https://github.com/Avivbens/shell-config/tree/HEAD'
</script>

# Shell Command

The `shell` command is used to configure the MacOS shell environment.

The command allow you to enable / disable bash functions and aliases by their modules, and to configure the shell prompt.

## Usage

```bash
shell-config shell
```

Enable / disable the modules according to your preferences, by using the arrow keys and space bar to select/deselect the modules. Press `Enter` to apply the selected modules.

## Modules

- [Git](https://github.com/Avivbens/shell-config/tree/HEAD/zsh/extends/.zshrc.extends.git.sh)
- [VSCode](https://github.com/Avivbens/shell-config/tree/HEAD/zsh/extends/.zshrc.extends.vscode.sh)
- [Npm](https://github.com/Avivbens/shell-config/tree/HEAD/zsh/extends/.zshrc.extends.npm.sh)
- [Angular](https://github.com/Avivbens/shell-config/tree/HEAD/zsh/extends/.zshrc.extends.angular.sh)
- [MongoDB](https://github.com/Avivbens/shell-config/tree/HEAD/zsh/extends/.zshrc.extends.mongo.sh)
- [Python](https://github.com/Avivbens/shell-config/tree/HEAD/zsh/extends/.zshrc.extends.python.sh)
- [Redis](https://github.com/Avivbens/shell-config/tree/HEAD/zsh/extends/.zshrc.extends.redis.sh)
- [Theme](https://github.com/Avivbens/shell-config/tree/HEAD/zsh/extends/.zshrc.extends.theme.sh)
<!-- - [Nest](https://github.com/Avivbens/shell-config/tree/HEAD/zsh/extends/.zshrc.extends.nest.sh) -->

## Examples

![Shell Command](../../assets/shell-command.jpg)
27 changes: 27 additions & 0 deletions docs/app/commands/update.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
# Update Command

The `update` command is used to update the shell-config CLI to the latest version.

You can also update the CLI to a specific version, by using the `-t / --target` flag, providing the version number as an argument.

With every update, you'd be asked to update the `shell-config` CLI. All existing configurations will be preserved, and new capabilities will be added.

## Usage

```bash
shell-config update
```

## Flags

### Upgrade / Downgrade to Specific Version

```bash
shell-config update -t <VERSION_HERE>
```

### Check for Updates

```bash
shell-config update -m
```
Loading

0 comments on commit dc17a67

Please sign in to comment.