| 
									
										
										
										
											2017-07-16 07:35:08 +02:00
										 |  |  | <?php | 
					
						
							| 
									
										
										
										
											2022-12-29 19:41:57 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-16 07:35:08 +02:00
										 |  |  | /** | 
					
						
							|  |  |  |  * IntroController.php | 
					
						
							| 
									
										
										
										
											2020-01-31 07:32:04 +01:00
										 |  |  |  * Copyright (c) 2019 james@firefly-iii.org | 
					
						
							| 
									
										
										
										
											2017-07-16 07:35:08 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This file is part of Firefly III (https://github.com/firefly-iii). | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  |  * it under the terms of the GNU Affero General Public License as | 
					
						
							|  |  |  |  * published by the Free Software Foundation, either version 3 of the | 
					
						
							|  |  |  |  * License, or (at your option) any later version. | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * GNU Affero General Public License for more details. | 
					
						
							| 
									
										
										
										
											2017-10-21 08:40:00 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-10-02 06:37:26 +02:00
										 |  |  |  * You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  |  * along with this program.  If not, see <https://www.gnu.org/licenses/>. | 
					
						
							| 
									
										
										
										
											2017-07-16 07:35:08 +02:00
										 |  |  |  */ | 
					
						
							|  |  |  | declare(strict_types=1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FireflyIII\Http\Controllers\Json; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-18 10:26:12 +02:00
										 |  |  | use FireflyIII\Exceptions\FireflyException; | 
					
						
							| 
									
										
										
										
											2021-04-06 17:00:16 +02:00
										 |  |  | use FireflyIII\Http\Controllers\Controller; | 
					
						
							| 
									
										
										
										
											2018-08-09 17:50:30 +02:00
										 |  |  | use FireflyIII\Support\Http\Controllers\GetConfigurationData; | 
					
						
							| 
									
										
										
										
											2018-07-08 12:28:42 +02:00
										 |  |  | use Illuminate\Http\JsonResponse; | 
					
						
							| 
									
										
										
										
											2017-07-16 07:35:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |  * Class IntroController. | 
					
						
							| 
									
										
										
										
											2017-07-16 07:35:08 +02:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2021-04-06 17:00:16 +02:00
										 |  |  | class IntroController extends Controller | 
					
						
							| 
									
										
										
										
											2017-07-16 07:35:08 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2018-08-09 17:50:30 +02:00
										 |  |  |     use GetConfigurationData; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-16 07:35:08 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-21 08:06:24 +02:00
										 |  |  |      * Returns the introduction wizard for a page. | 
					
						
							| 
									
										
										
										
											2017-07-16 07:35:08 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2022-12-31 07:33:44 +01:00
										 |  |  |     public function getIntroSteps(string $route, string $specificPage = null): JsonResponse | 
					
						
							| 
									
										
										
										
											2017-07-16 07:35:08 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2023-10-29 06:33:43 +01:00
										 |  |  |         app('log')->debug(sprintf('getIntroSteps for route "%s" and page "%s"', $route, $specificPage)); | 
					
						
							| 
									
										
										
										
											2024-01-01 14:43:56 +01:00
										 |  |  |         $specificPage ??= ''; | 
					
						
							| 
									
										
										
										
											2017-07-21 06:00:10 +02:00
										 |  |  |         $steps         = $this->getBasicSteps($route); | 
					
						
							|  |  |  |         $specificSteps = $this->getSpecificSteps($route, $specificPage); | 
					
						
							| 
									
										
										
										
											2022-11-04 05:11:05 +01:00
										 |  |  |         if (0 === count($specificSteps)) { | 
					
						
							| 
									
										
										
										
											2023-10-29 06:33:43 +01:00
										 |  |  |             app('log')->debug(sprintf('No specific steps for route "%s" and page "%s"', $route, $specificPage)); | 
					
						
							| 
									
										
										
										
											2017-12-29 09:05:35 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-10 20:30:09 +01:00
										 |  |  |             return response()->json($steps); | 
					
						
							| 
									
										
										
										
											2017-07-21 06:00:10 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |         if ($this->hasOutroStep($route)) { | 
					
						
							|  |  |  |             // save last step:
 | 
					
						
							| 
									
										
										
										
											2019-05-30 12:31:19 +02:00
										 |  |  |             $lastStep = $steps[count($steps) - 1]; | 
					
						
							| 
									
										
										
										
											2017-07-21 06:00:10 +02:00
										 |  |  |             // remove last step:
 | 
					
						
							|  |  |  |             array_pop($steps); | 
					
						
							|  |  |  |             // merge arrays and add last step again
 | 
					
						
							| 
									
										
										
										
											2024-01-01 14:43:56 +01:00
										 |  |  |             $steps    = array_merge($steps, $specificSteps); | 
					
						
							|  |  |  |             $steps[]  = $lastStep; | 
					
						
							| 
									
										
										
										
											2017-07-21 06:00:10 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |         if (!$this->hasOutroStep($route)) { | 
					
						
							|  |  |  |             $steps = array_merge($steps, $specificSteps); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-10 20:30:09 +01:00
										 |  |  |         return response()->json($steps); | 
					
						
							| 
									
										
										
										
											2017-07-21 06:00:10 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-21 08:06:24 +02:00
										 |  |  |      * Returns true if there is a general outro step. | 
					
						
							| 
									
										
										
										
											2017-07-21 06:00:10 +02:00
										 |  |  |      */ | 
					
						
							|  |  |  |     public function hasOutroStep(string $route): bool | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         $routeKey = str_replace('.', '_', $route); | 
					
						
							| 
									
										
										
										
											2023-10-29 06:33:43 +01:00
										 |  |  |         app('log')->debug(sprintf('Has outro step for route %s', $routeKey)); | 
					
						
							| 
									
										
										
										
											2017-07-21 06:00:10 +02:00
										 |  |  |         $elements = config(sprintf('intro.%s', $routeKey)); | 
					
						
							| 
									
										
										
										
											2019-06-22 13:09:25 +02:00
										 |  |  |         if (!is_array($elements)) { | 
					
						
							| 
									
										
										
										
											2017-07-22 10:50:30 +02:00
										 |  |  |             return false; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-01 14:43:56 +01:00
										 |  |  |         $hasStep  = array_key_exists('outro', $elements); | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-10-29 06:33:43 +01:00
										 |  |  |         app('log')->debug('Elements is array', $elements); | 
					
						
							|  |  |  |         app('log')->debug('Keys is', array_keys($elements)); | 
					
						
							|  |  |  |         app('log')->debug(sprintf('Keys has "outro": %s', var_export($hasStep, true))); | 
					
						
							| 
									
										
										
										
											2017-07-21 06:00:10 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-02 15:10:40 +02:00
										 |  |  |         return $hasStep; | 
					
						
							| 
									
										
										
										
											2017-07-21 06:00:10 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-07-23 07:35:30 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-23 07:30:05 +02:00
										 |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-21 08:06:24 +02:00
										 |  |  |      * Enable the boxes for a specific page again. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2021-09-18 10:26:12 +02:00
										 |  |  |      * @throws FireflyException | 
					
						
							| 
									
										
										
										
											2017-07-23 07:30:05 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2022-12-31 07:33:44 +01:00
										 |  |  |     public function postEnable(string $route, string $specialPage = null): JsonResponse | 
					
						
							| 
									
										
										
										
											2017-07-23 07:30:05 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2023-12-10 06:45:59 +01:00
										 |  |  |         $specialPage ??= ''; | 
					
						
							| 
									
										
										
										
											2024-01-01 14:43:56 +01:00
										 |  |  |         $route = str_replace('.', '_', $route); | 
					
						
							|  |  |  |         $key   = 'shown_demo_'.$route; | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |         if ('' !== $specialPage) { | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  |             $key .= '_'.$specialPage; | 
					
						
							| 
									
										
										
										
											2017-07-23 07:30:05 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-10-29 06:33:43 +01:00
										 |  |  |         app('log')->debug(sprintf('Going to mark the following route as NOT done: %s with special "%s" (%s)', $route, $specialPage, $key)); | 
					
						
							| 
									
										
										
										
											2018-07-14 16:08:34 +02:00
										 |  |  |         app('preferences')->set($key, false); | 
					
						
							| 
									
										
										
										
											2019-10-10 20:58:13 +02:00
										 |  |  |         app('preferences')->mark(); | 
					
						
							| 
									
										
										
										
											2017-07-23 07:30:05 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-29 19:41:57 +01:00
										 |  |  |         return response()->json(['message' => (string)trans('firefly.intro_boxes_after_refresh')]); | 
					
						
							| 
									
										
										
										
											2017-07-23 07:30:05 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-07-21 06:00:10 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							| 
									
										
										
										
											2018-07-21 08:06:24 +02:00
										 |  |  |      * Set that you saw them. | 
					
						
							|  |  |  |      * | 
					
						
							| 
									
										
										
										
											2021-09-18 10:26:12 +02:00
										 |  |  |      * @throws FireflyException | 
					
						
							| 
									
										
										
										
											2017-07-21 06:00:10 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2022-12-31 07:33:44 +01:00
										 |  |  |     public function postFinished(string $route, string $specialPage = null): JsonResponse | 
					
						
							| 
									
										
										
										
											2017-07-21 06:00:10 +02:00
										 |  |  |     { | 
					
						
							| 
									
										
										
										
											2023-12-10 06:45:59 +01:00
										 |  |  |         $specialPage ??= ''; | 
					
						
							| 
									
										
										
										
											2024-01-01 14:43:56 +01:00
										 |  |  |         $key = 'shown_demo_'.$route; | 
					
						
							| 
									
										
										
										
											2017-11-15 12:25:49 +01:00
										 |  |  |         if ('' !== $specialPage) { | 
					
						
							| 
									
										
										
										
											2023-12-20 19:35:52 +01:00
										 |  |  |             $key .= '_'.$specialPage; | 
					
						
							| 
									
										
										
										
											2017-07-22 10:50:30 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-10-29 06:33:43 +01:00
										 |  |  |         app('log')->debug(sprintf('Going to mark the following route as done: %s with special "%s" (%s)', $route, $specialPage, $key)); | 
					
						
							| 
									
										
										
										
											2018-07-14 16:08:34 +02:00
										 |  |  |         app('preferences')->set($key, true); | 
					
						
							| 
									
										
										
										
											2017-07-21 06:00:10 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-22 05:51:32 +02:00
										 |  |  |         return response()->json(['result' => sprintf('Reported demo watched for route "%s" (%s): %s.', $route, $specialPage, $key)]); | 
					
						
							| 
									
										
										
										
											2017-07-21 06:00:10 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-08-12 07:48:39 +02:00
										 |  |  | } |