loadViewsFrom(__DIR__ . '/../../resources/views', 'media_request'); // Load translation $this->loadTranslationsFrom(__DIR__ . '/../../resources/lang', 'media_request'); // Load migrations $this->loadMigrationsFrom(__DIR__ . '/../../database/migrations'); // Call pblish redources function $this->publishResources(); } /** * Register the service provider. * * @return void */ public function register() { $this->mergeConfig(); $this->registerMediaRequest(); $this->registerFacade(); $this->registerBindings(); //$this->registerCommands(); } /** * Register the application bindings. * * @return void */ protected function registerMediaRequest() { $this->app->bind('media_request', function($app) { return new MediaRequest($app); }); } /** * Register the vault facade without the user having to add it to the app.php file. * * @return void */ public function registerFacade() { $this->app->booting(function() { $loader = \Illuminate\Foundation\AliasLoader::getInstance(); $loader->alias('MediaRequest', 'Lavalite\MediaRequest\Facades\MediaRequest'); }); } /** * Register bindings for the provider. * * @return void */ public function registerBindings() { // Bind facade $this->app->bind('litepie.media_request', function ($app) { return $this->app->make('Litepie\MediaRequest\MediaRequest'); }); // Bind MediaRequest to repository $this->app->bind( 'Litepie\MediaRequest\Interfaces\MediaRequestRepositoryInterface', \Litepie\MediaRequest\Repositories\Eloquent\MediaRequestRepository::class ); $this->app->register(\Litepie\MediaRequest\Providers\AuthServiceProvider::class); $this->app->register(\Litepie\MediaRequest\Providers\RouteServiceProvider::class); } /** * Merges user's and media_request's configs. * * @return void */ protected function mergeConfig() { $this->mergeConfigFrom( __DIR__ . '/../../config/config.php', 'litepie.media_request' ); } /** * Register scaffolding command */ protected function registerCommands() { if ($this->app->runningInConsole()) { $this->commands([ Commands\MakeMediaRequest::class, ]); } } /** * Get the services provided by the provider. * * @return array */ public function provides() { return ['litepie.media_request']; } /** * Publish resources. * * @return void */ private function publishResources() { // Publish configuration file $this->publishes([__DIR__ . '/../../config/config.php' => config_path('litepie/media_request.php')], 'config'); // Publish admin view $this->publishes([__DIR__ . '/../../resources/views' => base_path('resources/views/vendor/media_request')], 'view'); // Publish language files $this->publishes([__DIR__ . '/../../resources/lang' => base_path('resources/lang/vendor/media_request')], 'lang'); // Publish public files and assets. $this->publishes([__DIR__ . '/public/' => public_path('/')], 'public'); } }