cb-techservices / yii2-unsplash
This extension provides a Yii2 widget to display an image picker powered by Unsplash images API.
Installs: 26
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 2
Open Issues: 0
Type:yii2-extension
pkg:composer/cb-techservices/yii2-unsplash
Requires
- unsplash/unsplash: *
- yiisoft/yii2: ~2.0.0
This package is auto-updated.
Last update: 2025-09-27 11:51:41 UTC
README
This extension provides a Yii2 widget to display an image picker powered by Unsplash images API.
Installation
The preferred way to install this extension is through composer.
Either run
php composer.phar require --prefer-dist cb-techservices/yii2-unsplash "*"
or add
"cb-techservices/yii2-unsplash": "*"
to the require section of your composer.json file.
Configuration
Add the following to your main.php config file in your Yii project.
REQUIREMENT: You must have a valid developer account and "App" set up with Unsplash API. Once created, use the app's Access Key and the UTM Source (aka Application Name) for your Yii configuration.
'modules' => [
	'unsplash' => [
        'class' => 'cbtech\unsplash\UnsplashImagePickerModule',
        // ... other configurations for the module ...
        'params'=>[
        	'applicationId'	=> '{ACCESS_KEY}',
        	'utmSource' => '{UTM_SOURCE}',
        ]
    ],	
],
Usage
Once the extension AND module are installed, simply use it in your code by :
<?= \cbtech\unsplash\UnsplashImagePicker::widget([ "search"=>"colors", "page"=>1, "per_page"=>16, "orientation"=>"landscape", "button_text"=>"Choose photo from Unsplash", "button_class"=>"btn btn-success", "button_style"=>"margin-right:10px;", ]); ?>
Use Javascript and jQuery to listen for the 'unsplashDownload' event.
$(document).bind('unsplashDownload',"#unsplash-results",function(event, data){ console.log("Download Url = = " + data.downloadUrl); console.log("All photo view urls = = " + data.urls); $.ajax({ "method":"POST", "url":"/project/save-user-project-media-url-ajax", //This is a custom PHP script that recieves the download URL of the photo and downloads it to the server. "data":{downloadUrl: data.downloadUrl} }).done(function(response){ $(".file-default-preview").empty().html("<img src='" + response.data.media.url + "' style='width:200px;height:200px;object-fit:cover;'/>"); }); });
Example PHP action that receives the downloadUrl:
public function actionSaveUserProjectMediaUrlAjax(){ $downloadUrl = \Yii::$app->request->post("downloadUrl"); //Download URL sent via $_POST //Do something with the downloadUrl, like use it to download a copy of the photo to your server. }
Acknowledgments
- Official Unsplash PHP Library
- Unsplash Developer API
- Yii2 Framework  
License
Yii2 Unsplash Extension is available under the MIT license. See the LICENSE file for more info.
