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