X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/76eb8fc5d7ae739d880e7305aa5593aa11424e54..refs/pull/274/head:/app/Http/Controllers/HomeController.php diff --git a/app/Http/Controllers/HomeController.php b/app/Http/Controllers/HomeController.php index d0eb16399..f4706a5c4 100644 --- a/app/Http/Controllers/HomeController.php +++ b/app/Http/Controllers/HomeController.php @@ -2,43 +2,81 @@ namespace BookStack\Http\Controllers; -use Illuminate\Http\Request; - +use Activity; +use BookStack\Repos\EntityRepo; use BookStack\Http\Requests; -use BookStack\Http\Controllers\Controller; -use BookStack\Repos\BookRepo; -use BookStack\Services\ActivityService; -use BookStack\Services\Facades\Activity; +use Illuminate\Http\Response; +use Views; class HomeController extends Controller { - - protected $activityService; - protected $bookRepo; + protected $entityRepo; /** * HomeController constructor. - * @param ActivityService $activityService - * @param BookRepo $bookRepo + * @param EntityRepo $entityRepo */ - public function __construct(ActivityService $activityService, BookRepo $bookRepo) + public function __construct(EntityRepo $entityRepo) { - $this->activityService = $activityService; - $this->bookRepo = $bookRepo; + $this->entityRepo = $entityRepo; parent::__construct(); } /** * Display the homepage. - * * @return Response */ public function index() { - $books = $this->bookRepo->getAll(10); - $activity = $this->activityService->latest(); - return view('home', ['books' => $books, 'activity' => $activity]); + $activity = Activity::latest(10); + $draftPages = $this->signedIn ? $this->entityRepo->getUserDraftPages(6) : []; + $recentFactor = count($draftPages) > 0 ? 0.5 : 1; + $recents = $this->signedIn ? Views::getUserRecentlyViewed(12*$recentFactor, 0) : $this->entityRepo->getRecentlyCreated('book', 10*$recentFactor); + $recentlyCreatedPages = $this->entityRepo->getRecentlyCreated('page', 5); + $recentlyUpdatedPages = $this->entityRepo->getRecentlyUpdated('page', 5); + return view('home', [ + 'activity' => $activity, + 'recents' => $recents, + 'recentlyCreatedPages' => $recentlyCreatedPages, + 'recentlyUpdatedPages' => $recentlyUpdatedPages, + 'draftPages' => $draftPages + ]); + } + + /** + * Get a js representation of the current translations + * @return \Illuminate\Contracts\Routing\ResponseFactory|\Symfony\Component\HttpFoundation\Response + */ + public function getTranslations() { + $locale = trans()->getLocale(); + $cacheKey = 'GLOBAL_TRANSLATIONS_' . $locale; + if (cache()->has($cacheKey) && config('app.env') !== 'development') { + $resp = cache($cacheKey); + } else { + $translations = [ + // Get only translations which might be used in JS + 'common' => trans('common'), + 'components' => trans('components'), + 'entities' => trans('entities'), + 'errors' => trans('errors') + ]; + if ($locale !== 'en') { + $enTrans = [ + 'common' => trans('common', [], null, 'en'), + 'components' => trans('components', [], null, 'en'), + 'entities' => trans('entities', [], null, 'en'), + 'errors' => trans('errors', [], null, 'en') + ]; + $translations = array_replace_recursive($enTrans, $translations); + } + $resp = 'window.translations = ' . json_encode($translations); + cache()->put($cacheKey, $resp, 120); + } + + return response($resp, 200, [ + 'Content-Type' => 'application/javascript' + ]); } }