-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: overhaul README.md for ngx-dev-toolbar
- Updated the README to reflect the new library name "Angular Dev Toolbar" and enhanced its presentation with badges for npm version, downloads, license, Angular compatibility, and GitHub stars. - Added a detailed introduction and feature list, highlighting the toolbar's capabilities such as feature flags, language switching, and theme management. - Included installation instructions, usage examples, and configuration details for key features like feature flags and language switcher. - Improved visual elements with images and a demo GIF to showcase the toolbar's functionality. - Enhanced the overall structure for better readability and user engagement.
- Loading branch information
1 parent
311648d
commit 2ae01b1
Showing
1 changed file
with
254 additions
and
4 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,7 +1,257 @@ | ||
# ngx-dev-toolbar | ||
# Angular Dev Toolbar | ||
|
||
This library was generated with [Nx](https://nx.dev). | ||
<div align="center"> | ||
|
||
## Running unit tests | ||
[data:image/s3,"s3://crabby-images/a538c/a538c4bfccc642b837487c9f47d9d6548ab6990a" alt="npm version"](https://www.npmjs.com/package/ngx-dev-toolbar) | ||
[data:image/s3,"s3://crabby-images/e65b1/e65b189f19f57856a4ad37d783d488a5ef7d70e4" alt="Downloads"](https://www.npmjs.com/package/ngx-dev-toolbar) | ||
[data:image/s3,"s3://crabby-images/3d5f8/3d5f8d9eda84af2e06554f4c4a6a608516fd7aae" alt="License"](https://github.com/yourusername/ngx-dev-toolbar/blob/main/LICENSE) | ||
[data:image/s3,"s3://crabby-images/79abf/79abfa6cc4a24d9857edb377470e0e58c645d0e5" alt="Angular"](https://angular.io/) | ||
[data:image/s3,"s3://crabby-images/2b18e/2b18e77c39a2835ad9a9cd72a9e106680efc548d" alt="GitHub Stars"](https://github.com/alfredoperez/ngx-dev-toolbar) | ||
|
||
Run `nx test ngx-dev-toolbar` to execute the unit tests. | ||
<h3>A powerful development toolbar for Angular applications that helps developers to interact with the application in a more efficient way.</h3> | ||
|
||
<p align="center"> | ||
<img src="./docs/images/demo.gif" alt="Dev Toolbar Demo" width="600px" /> | ||
</p> | ||
|
||
</div> | ||
|
||
## ✨ Why ngx-dev-toolbar? | ||
|
||
<div align="center"> | ||
<table> | ||
<tr> | ||
<td align="center">🚥</td> | ||
<td>Toggle feature flags without backend changes</td> | ||
</tr> | ||
<td align="center">🌍</td> | ||
<td>Switch languages instantly</td> | ||
</tr> | ||
<td align="center">🎨</td> | ||
<td>Switch themes on the fly</td> | ||
</tr> | ||
<td align="center">👤</td> | ||
<td>Change user sessions effortlessly</td> | ||
</tr> | ||
<td align="center">🔄</td> | ||
<td>Mock network requests in real-time</td> | ||
</tr> | ||
</table> | ||
</div> | ||
|
||
No more context switching or backend dependencies - everything you need is right in your browser! | ||
|
||
## 🎯 Features | ||
|
||
<div class="feature-grid"> | ||
|
||
### 📦 Available Tools | ||
|
||
- Feature Flags | ||
- Language Switcher | ||
- Themes `Coming Soon` | ||
- User Session `Coming Soon` | ||
- Network Requests Mocker `Coming Soon` | ||
|
||
### 🛠️ Extensible | ||
|
||
- Create custom tools | ||
- Add your own functionality | ||
|
||
### 🔒 Production Ready | ||
|
||
- Hidden by default in production | ||
- Zero production impact | ||
- Secure implementation | ||
|
||
### 💾 Persistent State | ||
|
||
- Settings persist across reloads | ||
- Import/Export configuration `Coming Soon` | ||
|
||
</div> | ||
|
||
## 📱 Quick Start | ||
|
||
<details> | ||
<summary><b>1. Installation</b></summary> | ||
|
||
```bash | ||
npm install ngx-dev-toolbar --save-dev | ||
``` | ||
|
||
</details> | ||
|
||
<details> | ||
<summary><b>2. Import Component</b></summary> | ||
|
||
```typescript | ||
import { DevToolbarComponent } from 'ngx-dev-toolbar'; | ||
|
||
@Component({ | ||
imports: [DevToolbarComponent], | ||
template: ` <ndt-dev-toolbar> </ndt-dev-toolbar>`, | ||
}) | ||
export class AppComponent {} | ||
``` | ||
|
||
</details> | ||
|
||
## Available Tools | ||
|
||
The tools come with a default implementation, but you can create your own tools and add them to the toolbar. | ||
|
||
They have a service that you can use to interact with them. | ||
|
||
### Feature Flags | ||
|
||
#### Configuration | ||
|
||
In order to use the feature flags tool, you need to import the `DevToolbarFeatureFlagService` and inject it in your component. | ||
|
||
Then you just need to call the `setAvailableOptions` method with the available feature flags that can come from your backend or a third party service. | ||
|
||
```typescript | ||
import { DevToolbarFeatureFlagService } from 'ngx-dev-toolbar'; | ||
import { inject } from '@angular/core'; | ||
|
||
@Component({ | ||
// ... component decorator | ||
}) | ||
export class AppComponent { | ||
private featureFlagsService = inject(DevToolbarFeatureFlagService); | ||
|
||
constructor() { | ||
// Set available feature flags | ||
this.featureFlagsService.setAvailableOptions([ | ||
{ id: 'darkMode', name: 'Dark Mode' }, | ||
{ id: 'betaFeatures', name: 'Beta Features' }, | ||
{ id: 'experimentalUI', name: 'Experimental UI' }, | ||
]); | ||
} | ||
} | ||
``` | ||
|
||
Once it is added you should see them in the Feature Flags tool in the Angular Dev Toolbar. | ||
|
||
data:image/s3,"s3://crabby-images/99759/9975936bbded35ed5b82c9e2e118ab4f8c88aaba" alt="Feature Flags Tool" | ||
|
||
#### Usage | ||
|
||
```typescript | ||
@Component({ | ||
// ... component decorator | ||
}) | ||
export class FeatureComponent { | ||
private featureFlagsService = inject(DevToolbarFeatureFlagService); | ||
|
||
ngOnInit() { | ||
this.featureFlagsService.getForcedValues().subscribe((forcedFlags) => { | ||
const isDarkMode = forcedFlags.some((flag) => flag.id === 'darkMode'); | ||
// Apply dark mode logic | ||
}); | ||
} | ||
} | ||
``` | ||
|
||
#### Dev Toolbar Interface | ||
|
||
[Screenshot placeholder showing the feature flags interface in the dev toolbar] | ||
|
||
### Language Switcher | ||
|
||
#### Configuration | ||
|
||
```typescript | ||
import { DevToolbarLanguageService } from 'ngx-dev-toolbar'; | ||
import { inject } from '@angular/core'; | ||
|
||
@Component({ | ||
// ... component decorator | ||
}) | ||
export class AppComponent { | ||
private languageService = inject(DevToolbarLanguageService); | ||
|
||
constructor() { | ||
// Set available languages | ||
this.languageService.setAvailableOptions([ | ||
{ code: 'en', name: 'English' }, | ||
{ code: 'es', name: 'Spanish' }, | ||
{ code: 'fr', name: 'French' }, | ||
]); | ||
} | ||
} | ||
``` | ||
|
||
#### Usage | ||
|
||
```typescript | ||
@Component({ | ||
// ... component decorator | ||
}) | ||
export class TranslatedComponent { | ||
private languageService = inject(DevToolbarLanguageService); | ||
|
||
ngOnInit() { | ||
this.languageService.getForcedValues().subscribe(([selectedLang]) => { | ||
// Update component's language | ||
this.currentLanguage = selectedLang.code; | ||
this.loadTranslations(); | ||
}); | ||
} | ||
} | ||
``` | ||
|
||
## Contributing | ||
|
||
We welcome contributions! Please see our [contributing guidelines](https://github.com/alfredoperez/ngx-dev-toolbar/blob/main/CONTRIBUTING.md) for details. | ||
|
||
## License | ||
|
||
This project is licensed under the MIT License - see the [LICENSE](https://github.com/alfredoperez/ngx-dev-toolbar/blob/main/LICENSE) file for details. | ||
|
||
## Support | ||
|
||
<div align="center"> | ||
|
||
<table> | ||
<tr> | ||
<td align="center"> | ||
<a href="https://alfredoperez.github.io/ngx-dev-toolbar/"> | ||
📚 | ||
<br /> | ||
Documentation | ||
</a> | ||
</td> | ||
<td align="center"> | ||
<a href="https://github.com/alfredoperez/ngx-dev-toolbar/issues"> | ||
🐛 | ||
<br /> | ||
Issue Tracker | ||
</a> | ||
</td> | ||
<td align="center"> | ||
<a href="https://github.com/alfredoperez/ngx-dev-toolbar/discussions"> | ||
💬 | ||
<br /> | ||
Discussions | ||
</a> | ||
</td> | ||
</tr> | ||
</table> | ||
|
||
</div> | ||
|
||
## 🌟 Stay Connected | ||
|
||
<div align="center"> | ||
|
||
[data:image/s3,"s3://crabby-images/a6c70/a6c703c578d0c0f075263623cba3849ed867e2ba" alt="LinkedIn"](https://www.linkedin.com/in/alfredo-perez/) | ||
[data:image/s3,"s3://crabby-images/3bb78/3bb7878e5c344c0d5bc214a670e1bbfb3fe447b7" alt="Bluesky"](https://bsky.app/profile/alfredo-perez.bsky.social) | ||
[data:image/s3,"s3://crabby-images/2b18e/2b18e77c39a2835ad9a9cd72a9e106680efc548d" alt="GitHub Stars"](https://github.com/alfredoperez/ngx-dev-toolbar) | ||
|
||
<hr /> | ||
|
||
<p>Built with ❤️ using <a href="https://nx.dev">Nx</a></p> | ||
|
||
</div> |