loadViewsFrom(__DIR__ . '/../../resources/views', 'seller'); // Load translation $this->loadTranslationsFrom(__DIR__ . '/../../resources/lang', 'seller'); // 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->registerFacade(); $this->app->register(\Crm\Seller\Providers\AuthServiceProvider::class); $this->app->register(\Crm\Seller\Providers\RouteServiceProvider::class); } /** * Register the vault facade without the user having to add it to the app.php file. * * @return void */ public function registerFacade() { $this->app->bind('crm.seller', function($app) { return $this->app->make(Seller::class); }); } /** * Merges user's and seller's configs. * * @return void */ protected function mergeConfig() { $this->mergeConfigFrom( __DIR__ . '/../../config/config.php', 'crm.seller' ); $this->mergeConfigFrom( __DIR__ . '/../../config/seller.php', 'crm.seller.seller' ); } /** * Get the services provided by the provider. * * @return array */ public function provides() { return ['crm.seller']; } /** * Publish resources. * * @return void */ private function publishResources() { // Publish configuration file $this->publishes([__DIR__ . '/../../config/' => config_path('crm/seller')], 'config'); // Publish admin view $this->publishes([__DIR__ . '/../../resources/views' => base_path('resources/views/vendor/seller')], 'view'); // Publish language files $this->publishes([__DIR__ . '/../../resources/lang' => base_path('resources/lang/vendor/seller')], 'lang'); // Publish public files and assets. $this->publishes([__DIR__ . '/public/' => public_path('/')], 'public'); } }