artisan-build/embeddable-links

A simple package to transform URLs into embedded links, transforming things like YouTube and video into embeds and using OpenGraph for any pages that have it.

Installs: 1

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 0

Forks: 0

pkg:composer/artisan-build/embeddable-links

dev-main 2025-10-28 09:23 UTC

This package is auto-updated.

Last update: 2025-10-28 11:19:57 UTC


README

Artisan Build Package Embeddable Links Logo

Embeddable Links

Transform URLs into rich embedded content for Laravel applications. Automatically detects and renders embeds for YouTube, Vimeo, GitHub Gists, and generates beautiful link preview cards using OpenGraph metadata.

Warning

This package is currently under active development, and we have not yet released a major version. Once a 0.* version has been tagged, we strongly recommend locking your application to a specific working version because we might make breaking changes even in patch releases until we've tagged 1.0.

Features

  • 🎥 Video Embeds: Native players for YouTube and Vimeo with responsive aspect ratios
  • 💻 Code Embeds: GitHub Gist embedding with syntax highlighting
  • 🔗 OpenGraph Cards: Beautiful link previews with title, image, and description
  • 🌐 Generic Fallback: Smart metadata extraction for any URL
  • Caching: Configurable metadata caching to minimize HTTP requests
  • 🎨 Flux UI: Built with Flux UI Pro components (customizable)
  • Validation: Laravel validation rule for embeddable URLs

Installation

composer require artisan-build/embeddable-links

Configuration

Publish the configuration file (optional):

php artisan vendor:publish --tag=embeddable-links-config

Environment Variables

EMBEDDABLE_LINKS_CACHE_ENABLED=true
EMBEDDABLE_LINKS_CACHE_TTL=86400  # 24 hours in seconds
EMBEDDABLE_LINKS_HTTP_TIMEOUT=5   # HTTP request timeout in seconds
EMBEDDABLE_LINKS_ASPECT_RATIO=16/9

Usage

Basic Blade Component

<x-embeddable-links-embed url="https://www.youtube.com/watch?v=dQw4w9WgXcQ" />

Custom Aspect Ratio

<x-embeddable-links-embed
    url="https://vimeo.com/123456789"
    aspect-ratio="4/3"
/>

Disable Caching

<x-embeddable-links-embed
    url="https://example.com/article"
    :cache="false"
/>

Custom Link Target

By default, OpenGraph and generic link cards open in a new tab (target="_blank"). You can override this:

<x-embeddable-links-embed
    url="https://example.com/article"
    target="_self"
/>

Supported Services

YouTube:

<x-embeddable-links-embed url="https://www.youtube.com/watch?v=VIDEO_ID" />
<x-embeddable-links-embed url="https://youtu.be/VIDEO_ID" />

Vimeo:

<x-embeddable-links-embed url="https://vimeo.com/VIDEO_ID" />

GitHub Gist:

<x-embeddable-links-embed url="https://gist.github.com/username/GIST_ID" />

Any URL with OpenGraph:

<x-embeddable-links-embed url="https://laravel.com/docs" />

URL Validation

Use the EmbeddableUrl validation rule:

use ArtisanBuild\EmbeddableLinks\Rules\EmbeddableUrl;

$request->validate([
    'url' => ['required', 'url', new EmbeddableUrl],
]);

Restrict to specific services:

$request->validate([
    'url' => ['required', 'url', new EmbeddableUrl(['youtube', 'vimeo'])],
]);

Programmatic Usage

use ArtisanBuild\EmbeddableLinks\Services\EmbedManager;

$manager = app(EmbedManager::class);
$html = $manager->embed('https://www.youtube.com/watch?v=dQw4w9WgXcQ');

Customization

Publish Views

php artisan vendor:publish --tag=embeddable-links-views

Views will be published to resources/views/vendor/embeddable-links/embeds/:

  • youtube.blade.php
  • vimeo.blade.php
  • github-gist.blade.php
  • opengraph.blade.php
  • generic.blade.php

Demo Page

Visit /embeddable-links-demo to see all embed types in action (development only).

Testing

composer test
composer test-coverage

Code Quality

composer lint       # Fix code style
composer stan       # Run static analysis
composer ready      # Run all checks

How It Works

  1. URL Detection: Parses URLs to identify service type (YouTube, Vimeo, Gist, or generic)
  2. Metadata Fetching: For generic URLs, fetches OpenGraph and HTML metadata
  3. Caching: Stores metadata in Laravel cache (default: 24 hours)
  4. Rendering: Uses service-specific Blade templates with Flux UI components

Requirements

  • PHP 8.3+
  • Laravel 11.0+
  • Flux UI Pro (for default card styles)

Memberware

This package is part of our internal toolkit and is optimized for our own purposes. We do not accept issues or PRs in this repository.

License

The MIT License (MIT). Please see License File for more information.