laragear / clipboard
Cut, copy and paste values inside your app.
Fund package maintenance!
Github Sponsorship
Paypal
Installs: 2 837
Dependents: 0
Suggesters: 0
Security: 0
Stars: 19
Watchers: 1
Forks: 1
Open Issues: 0
Requires
- php: 8.*
- illuminate/events: 9.*|10.*
- illuminate/support: 9.*|10.*
Requires (Dev)
- orchestra/testbench: ^7.22|8.*
This package is auto-updated.
Last update: 2024-10-30 02:16:22 UTC
README
Copy, cut & paste in your application. You read that right.
use Laragear\Clipboard\Facades\Clipboard; public function foo() { Clipboard::copy('test'); } public function bar() { Clipboard::paste(); // 'test' }
Become a sponsor
Your support allows me to keep this package free, up-to-date and maintainable. Alternatively, you can spread the word!
Requirements
- PHP 8 or later
- Laravel 9, 10 or later
Installation
You can install the package via composer:
composer require laragear/clipboard
Usage
The Clipboard works like your normal clipboard in your application.
Using the Clipboard to move around values inside the application allows you to avoid registering things into the Service Container unnecessarily, or moving a value around using functions or the cache.
Copy and paste
Copying a value will copy the reference of the object, or the value if is a primitive like a string
, int
or an array
, among others. It works like any other function.
use Laragear\Clipboard\Facades\Clipboard; use App\Models\Article; $article = Article::find(5); // Copy a value Clipboard::copy($article); // Edit the reference after has been copied. $article->title = 'The new title!';
Pasting will paste the value how many times you want. It accepts a default value in case the clipboard is empty.
// Paste a value Clipboard::paste()->title; // 'The new title'
Clone
Sometimes you may want to actually clone the object instead of copy its reference. For these cases, use the clone()
method.
use Laragear\Clipboard\Facades\Clipboard; use App\Models\Article; $article = Article::make(['title' => 'Original title']); // Clone an object Clipboard::clone($article);
Since it's a clone, the original variable will be different from the one pasted afterward.
$article->title = 'Different title'; echo Clipboard::paste()->title; // "Original title"
Cut and pull
Cut works like copy, but the value in the current context will be assigned null
.
use Laragear\Clipboard\Facades\Clipboard; $article = 'This is a big wall of text.'; // Cut a value Clipboard::cut($article); echo $article; // ''
Meanwhile, pull()
, will retrieve the value from the Clipboard and remove it from there. It accepts a default value in case the clipboard is empty.
use Laragear\Clipboard\Facades\Clipboard; $text = Clipboard::pull(); echo $text; // 'This is a big wall of text.'
Clearing
You can clear the Clipboard anytime using clear()
:
use Laragear\Clipboard\Facades\Clipboard; Clipboard::copy('I am going to dissapear.'); Clipboard::clear(); echo Clipboard::paste(); // ''
Method pass-through
For your convenience, you don't need to retrieve the Clipboard object to do something. The Clipboard will pass through all methods calls to the copied or cloned object.
use Laragear\Clipboard\Facades\Clipboard; use App\Models\Article; $article = Article::make(['title' => 'Original title']); // Copy a value Clipboard::copy($article); // Some lines after... Clipboard::save();
How this works?
It just registers a singleton that holds a value during the life of the request, or the entirety of the command. That's it.
Laravel Octane compatibility
- There are no singletons using a stale application instance.
- There are no singletons using a stale config instance.
- There are no singletons using a stale request instance.
- There are no static properties written during a request.
There should be no problems using this package with Laravel Octane.
Security
If you discover any security related issues, please email darkghosthunter@gmail.com instead of using the issue tracker.
License
This specific package version is licensed under the terms of the MIT License, at time of publishing.
Laravel is a Trademark of Taylor Otwell. Copyright © 2011-2023 Laravel LLC.