Spotlight Content Here
Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/omnedia/ngx-spotlight
A simple component library to create a spotlight effect.
https://github.com/omnedia/ngx-spotlight
Last synced: about 2 months ago
JSON representation
A simple component library to create a spotlight effect.
- Host: GitHub
- URL: https://github.com/omnedia/ngx-spotlight
- Owner: omnedia
- License: mit
- Created: 2024-08-26T00:50:27.000Z (5 months ago)
- Default Branch: master
- Last Pushed: 2024-09-25T09:02:58.000Z (4 months ago)
- Last Synced: 2024-11-01T20:21:33.372Z (3 months ago)
- Language: TypeScript
- Size: 5.86 KB
- Stars: 0
- Watchers: 0
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- trackawesomelist - ngx-spotlight (⭐0) - An Angular library that creates a spotlight effect using SVG animations. The component highlights sections of your page when they enter the viewport, with customizable spotlight colors and optional animations. (Recently Updated / [Oct 01, 2024](/content/2024/10/01/README.md))
- awesome-angular - ngx-spotlight - An Angular library that creates a spotlight effect using SVG animations. The component highlights sections of your page when they enter the viewport, with customizable spotlight colors and optional animations. (Table of contents / Third Party Components)
- fucking-awesome-angular - ngx-spotlight - An Angular library that creates a spotlight effect using SVG animations. The component highlights sections of your page when they enter the viewport, with customizable spotlight colors and optional animations. (Table of contents / Third Party Components)
README
# ngx-spotlight
`@omnedia/ngx-spotlight` is an Angular library that creates a spotlight effect using SVG animations. The component highlights sections of your page when they enter the viewport, with customizable spotlight colors and optional animations. This is ideal for drawing attention to important content as users scroll through your Angular application.
## Features
- Customizable spotlight color for highlighting content.
- Animation that triggers when the spotlight enters the viewport.
- Lightweight and easy to integrate as a standalone component.
- Flexible styling via custom CSS classes and inline styles.## Installation
Install the library using npm:
```bash
npm install @omnedia/ngx-spotlight
```## Usage
Import the `NgxSpotlightComponent` in your Angular module or component:
```typescript
import { NgxSpotlightComponent } from '@omnedia/ngx-spotlight';@Component({
...
imports: [
...
NgxSpotlightComponent,
],
...
})
```Use the component in your template:
```html
Highlighted Content
```
## How It Works
- Spotlight Color: The spotlightColor input allows you to set the color of the spotlight effect, giving you full control over its visual style.
- Animation on Viewport Entry: The spotlight animation is triggered when the component enters the viewport using the IntersectionObserver API. Enable or disable this behavior with the animation input.
- Global and Custom Styling: The .om-spotlight container can be styled globally or with a custom styleClass. The spotlight effect itself is applied through SVG elements and animations.## API
```html
```
- `spotlightColor` (optional): The color of the spotlight effect. Accepts any valid CSS color value (e.g., '#ffcc00', '#00ffcc').
- `animation` (optional): A boolean to enable animation when the spotlight enters the viewport. Defaults to false.
- `styleClass` (optional): A custom CSS class to apply to the .om-spotlight container for additional styling.## Example
```html
This content is highlighted by the spotlight effect
```
This will create a spotlight effect with a reddish-orange color that animates when the content enters the viewport.
## Styling
- The Color can be styled by the API Input or via the styleClass in a global css file.
- To change the position where the spotlight is shining use the styleClass and move the spotlight around.### Custom Spotlight Styling Example
In this example, the spotlight is styled with custom colors via css:
```html
```
```css
/* Global Style */
.custom-spotlight {
--om-spotlight-color: #ffcc00;
}/* Component Style */
.content {
color: white;
font-size: 1.5rem;
position: relative;
z-index: 2;
}
```This example applies a yellow spotlight color.
## Contributing
Contributions are welcome. Please submit a pull request or open an issue to discuss your ideas.
## License
This project is licensed under the MIT License.