]> BookStack Code Mirror - bookstack/commitdiff
Input WYSIWYG: Updated UpdateUrlCommand, Added chapter HTML display
authorDan Brown <redacted>
Mon, 18 Dec 2023 18:31:16 +0000 (18:31 +0000)
committerDan Brown <redacted>
Mon, 18 Dec 2023 18:31:16 +0000 (18:31 +0000)
app/Console/Commands/UpdateUrlCommand.php
resources/views/chapters/show.blade.php
tests/Commands/UpdateUrlCommandTest.php

index 27f84cc89f30689f40a87e80aaafa9181bcfb432..0c95b0a3c8a0e66e5cebf5a37969266ab37774b5 100644 (file)
@@ -46,6 +46,9 @@ class UpdateUrlCommand extends Command
         $columnsToUpdateByTable = [
             'attachments' => ['path'],
             'pages'       => ['html', 'text', 'markdown'],
+            'chapters'    => ['description_html'],
+            'books'       => ['description_html'],
+            'bookshelves' => ['description_html'],
             'images'      => ['url'],
             'settings'    => ['value'],
             'comments'    => ['html', 'text'],
index 0e5224d54783294da51558a0e3d231bdcb8919d1..6fe1ce431a242dd8db47e2cbd8d892da09101c48 100644 (file)
@@ -24,7 +24,7 @@
     <main class="content-wrap card">
         <h1 class="break-text">{{ $chapter->name }}</h1>
         <div refs="entity-search@contentView" class="chapter-content">
-            <p class="text-muted break-text">{!! nl2br(e($chapter->description)) !!}</p>
+            <p class="text-muted break-text">{!! $chapter->descriptionHtml() !!}</p>
             @if(count($pages) > 0)
                 <div class="entity-list book-contents">
                     @foreach($pages as $page)
index 280c81febd1cad9a67db4af638dd69ee4b0a2023..62c39c2741f7321d45eed4667725a07b8019f123 100644 (file)
@@ -2,6 +2,7 @@
 
 namespace Tests\Commands;
 
+use BookStack\Entities\Models\Entity;
 use Illuminate\Support\Facades\Artisan;
 use Symfony\Component\Console\Exception\RuntimeException;
 use Tests\TestCase;
@@ -24,6 +25,28 @@ class UpdateUrlCommandTest extends TestCase
         ]);
     }
 
+    public function test_command_updates_description_html()
+    {
+        /** @var Entity[] $models */
+        $models = [$this->entities->book(), $this->entities->chapter(), $this->entities->shelf()];
+
+        foreach ($models as $model) {
+            $model->description_html = '<a href="https://example.com/donkeys"></a>';
+            $model->save();
+        }
+
+        $this->artisan('bookstack:update-url https://example.com https://cats.example.com')
+            ->expectsQuestion("This will search for \"https://example.com\" in your database and replace it with  \"https://cats.example.com\".\nAre you sure you want to proceed?", 'y')
+            ->expectsQuestion('This operation could cause issues if used incorrectly. Have you made a backup of your existing database?', 'y');
+
+        foreach ($models as $model) {
+            $this->assertDatabaseHas($model->getTable(), [
+                'id'               => $model->id,
+                'description_html' => '<a href="https://cats.example.com/donkeys"></a>',
+            ]);
+        }
+    }
+
     public function test_command_requires_valid_url()
     {
         $badUrlMessage = 'The given urls are expected to be full urls starting with http:// or https://';
Morty Proxy This is a proxified and sanitized view of the page, visit original site.