salmanbe / filename
Laravel library to generate clean & pretty file name
Installs: 2 510
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 0
Open Issues: 0
Requires
- php: >=5.4.0
This package is auto-updated.
Last update: 2024-12-13 17:41:40 UTC
README
This library generates pretty, clean, user friendly, unique and well formatted file name.
Video Tutorial
Laravel Installation
Install using composer:
composer require salmanbe/filename
There is a service provider included for integration with the Laravel framework. This service should automatically be registered else to register the service provider, add the following to the providers array in config/app.php
:
Salmanbe\FileName\FileNameServiceProvider::class,
You can also add it as a Facade in config/app.php
:
'Filename' => Salmanbe\FileName\FileName::class,
Basic Usage
Add use Salmanbe\FileName\FileName;
or use FileName;
at top of the class where you want to use it.
$filename = 'visa-_ application With fréé.PNG';
echo FileName::get($filename); // visa-application-with-free-2021-02-16-001454.png
Options
You can generate configuration file by php artisan vendor:publish
command. Global file name generation options can be defined in it. However, you can override options by adding additional array parameter.
Timestamp
echo FileName::get($filename, ['timestamp' => 'Y-m-d']]);
You can override default timestamp format that is placed at the end of file name before extension.
Slugify
echo FileName::get($filename, ['slugify' => true]]);
Removes special characters from file name.
Limit
echo FileName::get($filename, ['limit' => 200]]);
Limit the total number of characters in file name to avoid very long file name. Default recommended maximum limit is 240.
Separator
echo FileName::get($filename, ['separator' => '_']]);
You can specify the separator between file name words. Default separator is '-'.
Uppercase
echo FileName::get($filename, ['uppercase' => true]]);
File name is generated by default in lower case. However, you can use this option to generate file name in upper case.
All Options
echo FileName::get($filename, [ 'limit' => 200, 'timestamp' => date('d-m-Y-His'), 'slugify' => true, 'separator' => '-', 'uppercase' => true ]);
Global Configuration
Run php artisan vendor:publish --provider="Salmanbe\FileName\FileNameServiceProvider"
to publish configuration file.
'timestamp' => 'Y-m-d-His',
If set to false then no timestamp will be added at the end of file name. It is possible to change the timestamp format. This value can be overridden when calling the function.
'limit' => 225,
If set to false then by default first 225 characters will be used. This value can be overridden when calling the function.
'slugify' => true,
If set to true then special characters will be removed from the file name. This value can be overridden when calling the function.
'separator' => '-',
If set then it will be used as separator between file name words. This value can be overridden when calling the function.
'uppercase' => false,
If set to true then file name will be in uppercase else lowercase. This value can be overridden when calling the function.
Uninstall
First remove Salmanbe\FileName\FileNameServiceProvider::class,
and
'Filename' => Salmanbe\FileName\FileName::class,
from config/app.php
if it was added.
Then Run composer remove salmanbe/filename
License
Laravel Perfect Filename is licensed under THE MIT License. Please see License File for more information.
Security contact information
To report a security vulnerability, follow these steps.