]> gitweb.stoutner.com Git - PrivacyBrowserPC.git/blobdiff - doc/index.docbook
Release 0.2.
[PrivacyBrowserPC.git] / doc / index.docbook
index b135352d27c5ce0756cb4c4f8e4fae2e99ba449e..4119aea7eb1f6a6d8d35ecdb03e2517c82a2f56d 100644 (file)
 <?xml version="1.0" ?>
-<!DOCTYPE book PUBLIC "-//KDE//DTD DocBook XML V4.5-Based Variant V1.1//EN" "dtd/kdedbx45.dtd" [
-  <!-- Define an entity for your application if it is not part of KDE
-       Git -->
-  <!ENTITY kmyapplication "<application>privacybrowserpc</application>">
-  <!ENTITY i18n-translatable-entity "<application>Translatable Entity</application>">
-  <!ENTITY % addindex "IGNORE">
-  <!ENTITY % English "INCLUDE">
-
-  <!-- Do not define any other entities; instead, use the entities
-       from entities/general.entities and en/user.entities. -->
-]>
 
 <!--
-Use this template for application docbooks
-For kioslave, systemsettings (kcontrol) modules and simple/short application docbooks use article-template.docbook
-Rename this template to index.docbook and place into the directory doc/ or doc/appname if you have several applications in one doc directory
--->
-
-<!-- kdoctemplate v0.13.0 2017-07-31 ltoscano
-     add CC BY-SA 4.0 International and set as default
-
-     kdoctemplate v0.12.0 2016-04-23 lueck
-     add translatable entities
-     remove help.menu.documentation entity
-     and add some examples how to use the common menus Settings and Help
-
-     kdoctemplate v0.11.0 2015-04-03 lueck
-     updated instructions for date + releaseinfo
-     remove ENTITY package - not used anymore
-     add info about KDE Games special chapters
-     Appendix Installation is now optional
-
-     kdoctemplate v0.10.0 2014-04-02 ltoscano
-     updated to KF5/kdoctools
-     references to KDE reworded
-
-     kdoctemplate v0.9.2 2012-10-15 pino
-     update versions to 4.9
-     update years to 2012
-     switch from CVS to Git
-     add id attribute to <book>
-     
-     kdoctemplate v0.9.1 2010-10-27 lueck
-     changed releaseinfo format
-     removed screenshot format="EPS
-     added comment when to write a command reference
-     added tip using id's in varlistentries
-     removed refentry stuff
-     
-     kdoctemplate v0.9 January 10 2003
-     Changes to comments to clarify entity usage January 10 2003
-     Minor update to "Credits and Licenses" section on August 24, 2000
-     Removed "Revision history" section on 22 January 2001
-     Changed to Installation/Help menu entities 18 October 2001
-     Other minor cleanup and changes 18 October 2001
-     FPI change and minor changes November 2002 -->
-
-<!--
-This template was designed by: David Rugge davidrugge@mindspring.com
-with lots of help from: Eric Bischoff ebisch@cybercable.tm.fr
-and Frederik Fouvry fouvry@sfs.nphil.uni-tuebingen.de
-of the KDE DocBook team.
-
-You may freely use this template for writing any sort of KDE documentation.
-If you have any changes or improvements, please let us know.
-
-Remember:
-- in XML, the case of the <tags> and attributes is relevant ;
-- also, quote all attributes.
-
-Please don't forget to remove all these comments in your final documentation,
-thanks ;-).
--->
-
-<!-- ................................................................ -->
-
-<!-- The language must NOT be changed here. -->
-<!-- If you are writing original documentation in a language other -->
-<!-- than English, change the language above ONLY, not here -->
-<!-- Change the value of id to the name of your application -->
-<book id="kmyapplication" lang="&language;">
-
-<!-- This header contains all of the meta-information for the document such
-as Authors, publish date, the abstract, and Keywords -->
-
-<bookinfo>
-<title>The &kmyapplication; Handbook</title>
-
-<authorgroup>
-<author>
-<!-- This is just put in as an example.  For real documentation, please
-     define a general entity in entities/contributor.entities, e.g.
-<!ENTITY George.N.Ugnacious "<personname><firstname>George</firstname><othername>N.</othername><surname>Ugnacious</surname></personname>">
-<!ENTITY George.N.Ugnacious.mail "<email>gnu@kde.org</email>">
-and use `&George.N.Ugnacious; &George.N.Ugnacious.mail;' in the author element.
- -->
-<personname>
-<firstname>George</firstname>
-<othername>N.</othername>
-<surname>Ugnacious</surname>
-</personname>
-<email>gnu@kde.org</email>
-</author>
-<!-- TRANS:ROLES_OF_TRANSLATORS -->
-</authorgroup>
-
-<copyright>
-<year>2015</year>
-<holder>George N. Ugnacious</holder>
-</copyright>
-<legalnotice>&CCBYSA4Notice;</legalnotice>
-
-<!-- Date of the documentation
-Change date/releaseinfo only if
-   docbook is updated and verified to be valid for the current app version
-   or
-   docbook is proofread and verified to be valid for the current app version
-Don't forget to include this last date.
-Please respect the format of the date (YYYY-MM-DD),it is used by scripts.
--->
-<date>2016-04-23</date>
-
-<!--version information of Frameworks/Plasma/Applications this documentation is valid for.
-Example:
-Frameworks xx.yy for docbooks in frameworks
-Plasma xx.yy for docbooks in plasma workspace
-Applications xx.yy for docbooks released as Applications
-xx.yy (Applications xx.yy) for docbooks with own version released as Applications
-$applicationname xx.yy for applications with independent release schedule (extragear/playground)
--->
-<releaseinfo>Frameworks xx.yy or Plasma xx.yy or Applications xx.yy or xx.yy (Applications xx.yy) or $applicationname xx.yy</releaseinfo>
-
-<!-- Abstract about this handbook -->
-
-<abstract>
-<para>
-&kmyapplication; is an application specially designed to do nothing you would
-ever want.
-</para>
-</abstract>
-
-<!-- This is a set of Keywords for indexing by search engines.
-Please at least include KDE, the KDE section it is in, the name
- of your application, and a few relevant keywords. -->
-
-<keywordset>
-<keyword>KDE</keyword>
-<keyword>kdeutils</keyword>
-<keyword>Kapp</keyword>
-<keyword>nothing</keyword>
-<keyword>nothing else</keyword>
-</keywordset>
-
-</bookinfo>
-
-<!-- The contents of the documentation begin here.  Label
-each chapter so with the id attribute. This is necessary for two reasons: it
-allows you to easily reference the chapter from other chapters of your
-document, and if there is no ID, the name of the generated HTML files will vary
-from time to time making it hard to manage for maintainers and for the CVS
-system. Any chapter labelled (OPTIONAL) may be left out at the author's
-discretion. Other chapters should not be left out in order to maintain a
-consistent documentation style across all KDE apps. -->
-
-
-<!-- KDE Games have special chapters
-
-Introduction
-
-How to play
-
-Game Rules, Strategies and Tips
-
-Interface Overview
-
-Frequently asked questions
-
-Credits and License
-
-Please use one of index.docbook files from kdegames
-
--->
-<chapter id="introduction">
-<title>Introduction</title>
-
-<!-- The introduction chapter contains a brief introduction for the
-application that explains what it does and where to report
-problems. Basically a long version of the abstract.  Don't include a
-revision history. (see installation appendix comment) -->
-
-<para>
-&kmyapplication; is a program that lets you do absolutely nothing. Please report
-any problems or feature requests to the &kde; mailing lists.
-</para>
-</chapter>
-
-<chapter id="using-kapp">
-<title>Using &kmyapplication;</title>
-
-<!-- This chapter should tell the user how to use your app. You should use as
-many sections (Chapter, Sect1, Sect3, etc...) as is necessary to fully document
-your application. -->
-
-<para>
-
-<!-- Note that all graphics should be in .png format. Use no gifs because of
-patent issues. -->
-
-<screenshot>
-<screeninfo>Here's a screenshot of &kmyapplication;</screeninfo>
-       <mediaobject>
-         <imageobject>
-           <imagedata fileref="screenshot.png" format="PNG"/>
-         </imageobject>
-         <textobject>
-           <phrase>Screenshot</phrase>
-         </textobject>
-       </mediaobject>
-</screenshot>
-</para>
-
-
-<sect1 id="kapp-features">
-<title>More &kmyapplication; features</title>
-
-<para>It slices! It dices! and it comes with a free toaster!</para>
-<para>
-The Squiggle Tool <guiicon><inlinemediaobject>
-         <imageobject>
-           <imagedata fileref="squiggle.png" format="PNG"/>
-         </imageobject>
-         <textobject>
-           <phrase>Squiggle</phrase>
-         </textobject>
-</inlinemediaobject></guiicon> is used to draw squiggly lines all over
-the &kmyapplication; main window. It's not a bug, it's a feature!
-</para>
-
-</sect1>
-</chapter>
-
-<chapter id="commands">
-<title>Command Reference</title>
-
-<!-- (OPTIONAL, BUT RECOMMENDED) This chapter should list all of the
-application windows and their menubar and toolbar commands for easy reference.
-Also include any keys that have a special function but have no equivalent in the
-menus or toolbars. 
-This may not be necessary for small apps or apps with no tool or menu bars.
-
-Don't bother users with well known kde menu items like Settings->Shortcuts etc. 
-
-Use cases for a command reference:
-
-Applications with many menu items (Kate/Konqueror) 
-Applications with different modes and menus (KWrite/Konqueror)
--> Enables search for menu items
-
-For Applications with default menu items and some special items where user 
-needs additional information use something like:
-"Apart from the common KDE menu items you find these action in the menu:
-
-File -> Special Action: Explanation of special action
-
-Tools -> Special Tool: Explanation of special tool
-
-Use variablelist markup for this
--->
-
-<sect1 id="kapp-mainwindow">
-<title>The main &kmyapplication; window</title>
-
-<sect2>
-<title>The File Menu</title>
-<para>
-<variablelist>
-<varlistentry  id="file-new">
-<!-- Tip: With id's here, then you can use them like 
-"select <xref linkend="file-new"/> to open the file dialog"
-which will be expanded to:
-"select File->New (Ctrl+N) to open the file dialog"
--->
-<term><menuchoice>
-<shortcut>
-<keycombo action="simul">&Ctrl;<keycap>N</keycap></keycombo>
-</shortcut>
-<guimenu>File</guimenu>
-<guimenuitem>New</guimenuitem>
-</menuchoice></term>
-<listitem><para><action>Creates a new document</action></para></listitem>
-</varlistentry>
-
-<varlistentry  id="file-save">
-<term><menuchoice>
-<shortcut>
-<keycombo action="simul">&Ctrl;<keycap>S</keycap></keycombo>
-</shortcut>
-<guimenu>File</guimenu>
-<guimenuitem>Save</guimenuitem>
-</menuchoice></term>
-<listitem><para><action>Saves the document</action></para></listitem>
-</varlistentry>
-
-<varlistentry  id="file-quit">
-<term><menuchoice>
-<shortcut>
-<keycombo action="simul">&Ctrl;<keycap>Q</keycap></keycombo>
-</shortcut>
-<guimenu>File</guimenu>
-<guimenuitem>Quit</guimenuitem>
-</menuchoice></term>
-<listitem><para><action>Quits</action> &kmyapplication;</para></listitem>
-</varlistentry>
-</variablelist>
-</para>
-
-</sect2>
-
-<!-- Examples how to use the common menus Settings and Help -->
-
-<sect2 id="settings-help-menu">
-<title>The Settings and Help Menu</title>
-<para>
-&kmyapplication; has the common &kde; <guimenu>Settings</guimenu> and <guimenu>Help</guimenu>
-menu items, for more information read the sections about the <ulink url="help:/fundamentals/ui.html#menus-settings"
->Settings Menu</ulink> and <ulink url="help:/fundamentals/ui.html#menus-help">Help Menu</ulink>
-of the &kde; Fundamentals.
-</para>
-</sect2>
-
-<sect2 id="help-menu1">
-<title>The Help Menu</title>
-<para>
-&kmyapplication; has the common &kde; <guimenu>Help</guimenu> menu item, for more information read the section
-about the <ulink url="help:/fundamentals/ui.html#menus-help">Help Menu</ulink> of the &kde; Fundamentals.
-</para>
-</sect2>
-
-<sect2 id="menu-commands">
-<title>Menu Items</title>
-<para>Apart from the common &kde; menus described in the <ulink url="help:/fundamentals/ui.html#menus">Menu</ulink>
-chapter of the &kde; Fundamentals documentation &kmyapplication; has these application specific menu entries:
-</para>
-<!-- variablelist -->
-</sect2>
-
-<sect2 id="help-menu2">
-<title>The Help Menu</title>
-<para>&kmyapplication; has a default &kde; <guimenu>Help</guimenu> menu as described in the
-<ulink url="help:/fundamentals/ui.html#menus-help">&kde; Fundamentals</ulink>
-with two additional entries:</para>
-<!-- variablelist -->
-</sect2>
-
-</sect1>
-</chapter>
-
-<chapter id="developers">
-<title>Developer's Guide to &kmyapplication;</title>
-
-<!-- (OPTIONAL) A Programming/Scripting reference chapter should be
-used for apps that use plugins or that provide their own scripting hooks
-and/or development libraries. -->
-
-<para>
-Programming &kmyapplication; plugins is a joy to behold.
-</para>
-
-
-</chapter>
-
-<chapter id="faq">
-<title>Questions and Answers</title>
-
-<!-- (OPTIONAL but recommended) This chapter should include all of the silly
-(and not-so-silly) newbie questions that fill up your mailbox. This chapter
-should be reserved for BRIEF questions and answers! If one question uses more
-than a page or so then it should probably be part of the
-"Using this Application" chapter instead. You should use links to
-cross-reference questions to the parts of your documentation that answer them.
-This is also a great place to provide pointers to other FAQ's if your users
-must do some complicated configuration on other programs in order for your
-application work. -->
-
-<qandaset id="faqlist">
-<qandaentry>
-<question>
-<para>My Mouse doesn't work. How do I quit &kmyapplication;?</para>
-</question>
-<answer>
-<para>You silly goose! Check out the <link linkend="commands">Commands
-Section</link> for the answer.</para>
-</answer>
-</qandaentry>
-<qandaentry>
-<question>
-<para>Why can I not twiddle my documents?</para>
-</question>
-<answer>
-<para>You can only twiddle your documents if you have the foobar.lib
-installed.</para>
-</answer>
-</qandaentry>
-</qandaset>
-</chapter>
-
-<chapter id="credits">
-
-<!-- Include credits for the programmers, documentation writers, and
-contributors here. The license for your software should then be included below
-the credits with a reference to the appropriate license file included in the KDE
-distribution. -->
-
-<title>Credits and License</title>
-
-<para>
-&kmyapplication;
-</para>
-<para>
-Program copyright 2010-2014 John Q. Hacker <email>jqh@kde.org</email>
-</para>
-<para>
-Contributors:
-<itemizedlist>
-<listitem><para>Konqui the &kde; Dragon <email>konqui@kde.org</email></para>
-</listitem>
-<listitem><para>Tux the &Linux; Penguin <email>tux@linux.org</email></para>
-</listitem>
-</itemizedlist>
-</para>
-
-<para>
-Documentation Copyright &copy; 2012-2014 George N. Ugnacious <email>gnu@kde.org</email>
-</para>
-
-<!-- TRANS:CREDIT_FOR_TRANSLATORS -->
-
-<!-- License for new documents after 2017-07-27 (or relicensed) -->
-
-&underCCBYSA4;           <!-- CC BY-SA 4.0: do not remove -->
-
-<!-- FDL: old license; only for reference (and old documents) -->
-<!--
-&underFDL;
--->
-
-<!-- Determine which license your application is licensed under,
-     and delete all the remaining licenses below:
-
-     (NOTE:  All documentation are licensed under the CC BY-SA 4.0,
-     regardless of what license the application uses) -->
-
-&underGPL;              <!-- GPL License -->
-&underBSDLicense;        <!-- BSD License -->
-&underArtisticLicense;   <!-- BSD Artistic License -->
-&underX11License;        <!-- X11 License  -->
+  Copyright 2023 Soren Stoutner <soren@stoutner.com>.
 
-</chapter>
+  This file is part of Privacy Browser PC <https://www.stoutner.com/privacy-browser-pc>.
 
-<!-- Appendix Installation is optional, usually not required
+  Permission is granted to copy, distribute and/or modify this document
+  under the terms of the GNU Free Documentation License, Version 1.3
+  or any later version published by the Free Software Foundation;
+  with no Invariant Sections, no Front-Cover Texts, and no Back-Cover Texts.
 
-Entities &install.intro.documentation; + &install.compile.documentation; will be removed in later kdoctools
+  You should have received a copy of the GNU Free Documentation License
+  along with Privacy Browser PC.  If not, see <http://www.gnu.org/licenses/>. -->
 
--->
-
-<appendix id="installation">
-<title>Installation</title>
-
-<sect1 id="getting-kapp">
-<title>How to obtain &kmyapplication;</title>
-
-<!-- This first entity contains boiler plate for applications that are
-part of KDE archive.  You should remove it if you are releasing your
-application -->
+<!DOCTYPE book PUBLIC "-//KDE//DTD DocBook XML V4.5-Based Variant V1.1//EN" "dtd/kdedbx45.dtd" [
+  <!-- Privacy Browser’s name -->
+  <!ENTITY privacybrowser "<application>Privacy Browser</application>">
 
-&install.intro.documentation;
+  <!-- People. -->
+  <!ENTITY Soren.Stoutner "<personname><firstname>Soren</firstname><surname>Stoutner</surname></personname>">
+  <!ENTITY Soren.Stoutner.mail "<email>soren@stoutner.com</email>">
 
-</sect1>
+  <!-- Set the language of this documentation. -->
+  <!ENTITY % English "INCLUDE">
 
-<sect1 id="requirements">
-<title>Requirements</title>
+  <!-- Default entries.  May not be needed. -->
+  <!ENTITY i18n-translatable-entity "<application>Translatable Entity</application>">
+  <!ENTITY % addindex "IGNORE">
+]>
 
-<!--
-List any special requirements for your application here. This should include:
-.Libraries or other software that is not included in kdesupport or kf5
-.Hardware requirements like amount of RAM, disk space, graphics card
-capabilities, screen resolution, special expansion cards, etc.
-.Operating systems the app will run on. If your app is designed only for a
-specific OS, (you wrote a graphical LILO configurator for example) put this
-information here.
--->
-
-<para>
-In order to successfully use &kmyapplication;, you need few libraries from
-&kf5; 5.1 (bar, baz). Foobar.lib is
-required in order to support the advanced &kmyapplication; features. &kmyapplication; uses
-about 5 megs of memory to run, but this may vary depending on your
-platform and configuration.
-</para>
-
-<para>
-All required libraries as well as &kmyapplication; itself can be found
-on <ulink url="ftp://ftp.kapp.org">The &kmyapplication; home page</ulink>.
-</para>
-
-<!-- For a list of updates, you may refer to the application web site
-or the ChangeLog file, or ... -->
-<para>
-You can find a list of changes at <ulink
-url="http://apps.kde.org/kapp">http://apps.kde.org/kapp</ulink>.
-</para>
-</sect1>
-
-<sect1 id="compilation">
-<title>Compilation and Installation</title>
-
-<!-- This entity contains the boilerplate text for standard -->
-<!-- compilation instructions.  If your application requires any -->
-<!-- special handling, remove it, and replace with your own text. -->
-
-&install.compile.documentation;
-
-</sect1>
-
-<sect1 id="configuration">
-<title>Configuration</title>
-
-<para>Don't forget to tell your system to start the <filename>dtd</filename>
-dicer-toaster daemon first, or &kmyapplication; won't work!</para>
-
-</sect1>
-
-</appendix>
-
-&documentation.index;
+<book id="privacybrowser" lang="&language;">
+  <bookinfo>
+    <title>The &privacybrowser; Handbook</title>
+
+    <authorgroup>
+      <author>&Soren.Stoutner; &Soren.Stoutner.mail;</author>
+
+      <!-- Add translators here.  TRANS:ROLES_OF_TRANSLATORS -->
+    </authorgroup>
+
+    <copyright>
+      <year>2016-2017, 2021-2023</year>
+      <holder>&Soren.Stoutner;</holder>
+    </copyright>
+
+    <!-- Documentation license. -->
+    <legalnotice>&FDLNotice;</legalnotice>
+
+    <!-- Last update. -->
+    <date>2023-04-17</date>
+
+    <!-- The version of Privacy Browser this documentation is written for. -->
+    <releaseinfo>&privacybrowser; version 0.2</releaseinfo>
+
+
+    <!-- Abstract about this handbook -->
+    <abstract>
+      <para>
+        &privacybrowser; is a web browser that respects your privacy.
+      </para>
+
+      <para>
+        The only way to prevent data from being abused is to prevent it from being collected in the first place.
+      </para>
+    </abstract>
+
+    <!-- This is a set of Keywords for indexing by search engines. -->
+    <keywordset>
+      <keyword>KDE</keyword>
+      <keyword>privacy</keyword>
+      <keyword>browser</keyword>
+    </keywordset>
+  </bookinfo>
+
+  <!-- Introduction. -->
+  <chapter id="introduction">
+    <title>Introduction</title>
+
+    <para>
+      &privacybrowser; is currently in an early alpha state.
+      Most of the features are not yet implemented, but I thought it would be useful to publish it so that users can track the progress and submit feedback.
+    </para>
+
+    <para>
+      To distinguish between the Android and the PC version, the website, issue tracker,
+      and code base refer to this version as <ulink url="https://www.stoutner.com/privacy-browser-pc/">Privacy Browser PC</ulink>.
+    </para>
+
+    <para>
+      The best place to discuss the development of Privacy Browser is <ulink url="https://redmine.stoutner.com/projects/privacy-browser-pc/boards">on the forum</ulink>.
+      I also frequently post on my <ulink url="https://fosstodon.org/@privacybrowser">Mastodon account</ulink> regarding the development status.
+    </para>
+
+    <!-- Qt WebEngine. -->
+    <sect1 id="qt-webengine">
+      <title>Qt WebEngine</title>
+
+      <para>
+        Privacy Browser uses <ulink url="https://doc.qt.io/qt-5/qtwebengine-index.html">Qt WebEngine</ulink> to render websites.
+        Qt WebEngine is based on the <ulink url="https://www.chromium.org/blink/">Chromium Blink</ulink> source code.
+        Because Privacy Browser is built on the <ulink url="https://api.kde.org/frameworks/index.html">KDE Framework</ulink>,
+        it currently uses the <ulink url="https://community.kde.org/Schedules/Plasma_6">Qt 5</ulink> packages.
+      </para>
+
+      <para>
+        The current Qt 5 packages are in long-term support mode.
+        From a feature perspective, Qt WebEngine 5.15.x is based on <ulink url="https://wiki.qt.io/QtWebEngine/ChromiumVersions">Chromium 87.0.4280.144</ulink>.
+        Security fixes are backported every few months with <ulink url="https://wiki.qt.io/Qt_5.15_Release#Release_Plan">each release</ulink>.
+      </para>
+    </sect1>
+
+    <!-- Bugs and missing features. -->
+    <sect1 id="bugs-and-missing-features">
+      <title>Bugs and Missing Features</title>
+
+      <para>
+        There is a list of feature requests and known bugs at <ulink url="https://redmine.stoutner.com/projects/privacy-browser-pc/issues">redmine.stoutner.com</ulink>.
+        Users should anticipate that all the current features of <ulink url="https://www.stoutner.com/privacy-browser-android/">Privacy Browser Android</ulink>
+        will also be implemented in Privacy Browser PC.
+        There is no need at this point to create features requests for these as they will be added as I start working on each feature and have a better idea of how they will be implemented.
+        However, each feature that has already been implemented should be bug free.
+        If you discover a bug that is not already documented at <ulink url="https://redmine.stoutner.com/projects/privacy-browser-pc/issues">redmine.stoutner.com</ulink> please add it.
+      </para>
+
+      <para>
+        Below is a list of known prominent bugs or missing features in this alpha release.
+      </para>
+
+      <itemizedlist>
+        <listitem><para>The page zoom is <ulink url="https://redmine.stoutner.com/issues/799">momentarily reset</ulink> every time a new URL is loaded.</para></listitem>
+        <listitem><para>If domain settings change the user agent, loading of the new URL is interrupted and the
+          <ulink url="https://redmine.stoutner.com/issues/821">previous site is reloaded</ulink>.</para></listitem>
+        <listitem><para>Browser <ulink url="https://redmine.stoutner.com/issues/831">error messages are not displayed</ulink> unless JavaScript is enabled.</para></listitem>
+        <listitem><para>Bookmarks are <ulink url="https://redmine.stoutner.com/issues/968">not yet implemented</ulink>.</para></listitem>
+        <listitem><para>Blocklists are <ulink url="https://redmine.stoutner.com/issues/969">not yet implemented</ulink>.</para></listitem>
+      </itemizedlist>
+    </sect1>
+  </chapter>
+
+  <!-- Using Privacy Browser. -->
+  <chapter id="using-privacy-browser">
+    <title>Using &privacybrowser;</title>
+
+    <para>
+      <mediaobject>
+        <imageobject>
+          <imagedata fileref="privacybrowser-window.png" format="PNG"/>
+        </imageobject>
+        <textobject>
+          <phrase>Screenshot</phrase>
+        </textobject>
+      </mediaobject>
+    </para>
+
+    <!-- JavaScript. -->
+    <sect1 id="javascript">
+      <title>JavaScript</title>
+
+      <para>
+        JavaScript allows web pages to run scripts (programs) on your device. It allows web pages to function more like apps, but it also allows web pages to spy on you.
+        Most of the tracking on the internet does not work when JavaScript is disabled.
+        JavaScript can be toggled by clicking on the privacy shield, which is blue if JavaScript is disabled and red when it is enabled.
+        <inlinemediaobject>
+          <imageobject>
+            <imagedata fileref="javascript.png" format="PNG"/>
+          </imageobject>
+          <textobject>
+            <phrase>JavaScript</phrase>
+          </textobject>
+        </inlinemediaobject>
+      </para>
+    </sect1>
+
+    <!-- Local Storage. -->
+    <sect1 id="local-storage">
+      <title>Local Storage</title>
+
+      <para>
+        <ulink url="https://doc.qt.io/qt-5/qwebenginecookiestore.html#setCookieFilter">Local storage</ulink>
+        in Privacy Browser encompasses cookies, DOM storage, IndexedDB, service workers, and the filesystem API.
+        Local storage can be toggled through an action on the toolbar.
+      </para>
+
+      <!-- Cookies. -->
+      <sect2 id="cookies">
+        <title>Cookies</title>
+
+        <para>
+          <ulink url="https://en.wikipedia.org/wiki/HTTP_cookie">Cookies</ulink>
+          allow websites to store small pieces of information for a specific host that are sent in the HTTP header every time the browser connects to that host.
+          Privacy Browser allows a maximum of <ulink url="http://browsercookielimits.iain.guru/">180 cookies with a maximum size of 4096 bytes per cookie</ulink> to be set per domain.
+          Cookies are often used to track users across the web, particularly third-party cookies (which are completely blocked in Privacy Browser).
+          They are also used as a security mechanism on websites where you log in to identify it is you as you browse from page to page on a site.
+        </para>
+
+        <para>
+          <mediaobject>
+            <imageobject>
+              <imagedata fileref="cookies.png" format="PNG"/>
+            </imageobject>
+            <textobject>
+              <phrase>Cookies</phrase>
+            </textobject>
+          </mediaobject>
+        </para>
+
+        <para>
+          The cookies dialog is opened from <xref linkend="settings-cookies"/>.
+          Durable cookies are shared with all tabs that are opened after they are made durable and are preserved even when Privacy Browser is restarted.
+          This allows users to stay logged in to sites of their choosing. No cookies are durable by default. Making a cookie durable requires specific user interaction.
+        </para>
+
+        <para>
+          All other cookies are specific to the tab where they are created and are destroyed when the tab is closed.
+        </para>
+      </sect2>
+
+      <!-- DOM storage. -->
+      <sect2 id="dom-storage">
+        <title>DOM storage</title>
+
+        <para>
+          <ulink url="https://en.wikipedia.org/wiki/Web_storage">DOM (Document Object Model) storage</ulink>, also knows as web storage, allows web pages to store information on a client device.
+          The storage capacity is larger than for cookies and the data is not automatically sent in the headers with every HTTP request.
+          In Privacy Browser, each website is allowed to store a <ulink url="https://arty.name/localstorage.html">5 MB of data</ulink> in DOM storage.
+          DOM storage requires JavaScript to function, and, in addition, requires an extra toggle to be enabled.
+          In Privacy Browser, DOM storage is limited to the tab where it is created and is destroyed when the tab is closed.
+        </para>
+      </sect2>
+
+      <!-- IndexedDB. -->
+      <sect2 id="indexeddb">
+        <title>IndexedDB</title>
+
+        <para>
+          <ulink url="https://developer.mozilla.org/en-US/docs/Web/API/IndexedDB_API">IndexedDB</ulink>
+          provides web pages with a local database where they can store â€śsignificant amounts of structured data”.
+          There is disagreement on the internet about the maximum size of an IndexedDB database, probably because the various rendering engines keep changing their mind.
+          But it is usually listed at somewhere between 20% and 80% of <emphasis>your entire hard drive</emphasis> with each individual domain limited to some segment of that.
+          IndexedDB requires JavaScript to function.
+          In Privacy Browser, this database is limited to the tab where it is created and is destroyed when the tab is closed.
+        </para>
+      </sect2>
+
+      <!-- Service Workers. -->
+      <sect2 id="service-workers">
+        <title>Service Workers</title>
+
+        <para>
+          <ulink url="https://developer.chrome.com/docs/workbox/service-worker-overview/">Service workers</ulink> are offline JavaScript proxies of a website. They have their own cache that is usually hidden and hard to clear.
+          They were designed by people who want the web browser to become the operating system and run full â€śapps”.
+          In Privacy Browser, service workers are limited to the tab where they are created and are destroyed when the tab is closed.
+        </para>
+      </sect2>
+
+      <!-- Filesystem API. -->
+      <sect2 id="filesystem-api">
+        <title>Filesystem API</title>
+
+        <para>
+          The <ulink url="https://developer.chrome.com/articles/file-system-access/">filesystem API</ulink> grants the browser direct access to the files on your system.
+          Like service workers, the filesystem API is a summarily bad idea thought up by those who want the browser to become an operating system.
+          Even when JavaScript and local storage are enabled, the filesystem API does not work in Privacy Browser.
+        </para>
+      </sect2>
+    </sect1>
+
+    <!-- User Agent. -->
+    <sect1 id="user-agent">
+      <title>User Agent</title>
+
+      <para>
+        The user agent is a text string that is sent as part of every HTTP header that identifies the browser to the web server.
+        Privacy Browser's default user agent is <code>PrivacyBrowser/1.0</code>.
+        Qt WebEngine 5.15.12’s default user agent is <code>Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) QtWebEngine/5.15.12 Chrome/87.0.4280.144 Safari/537.36</code>.
+      </para>
+
+      <para>
+        Over the years user agents have become quite lengthy,
+        partially because they tend to include a <ulink url="https://webaim.org/blog/user-agent-string-history/">brief history of the internet</ulink>.
+        In the modern world they serve almost no good purpose, but some web developers still think they need them so they can send different version of their website to different browsers.
+        Some servers <ulink url="https://www.stoutner.com/user-agent-problems/">refuse to function correctly</ulink> if they don't like the user agent that is sent.
+      </para>
+
+      <para>
+        At some point in the future Privacy Browser will send no user agent by default.
+        Not only is that currently impossible because the Qt WebEngine doesn't allow you to not send a user agent (I will probably have to fork it to enable that functionality),
+        but even web servers that don't care what the user agent is often refuse to send an answer if there is no user agent at all.
+        Getting rid of this relic of the internet is going to take some time and a retraining of common expectations.
+      </para>
+    </sect1>
+
+    <!-- Domain Settings. -->
+    <sect1 id="domain-settings">
+      <title>Domain Settings</title>
+
+      <para>
+        Domain setting make it easy to automatically change JavaScript, local storage, user agent, and other settings when the domain changes.
+        Domain settings for the current domain can be accessed through the domain settings button at the far right of the URL line edit.
+        Domain settings for all domains can be accessed through <xref linkend="settings-domain-settings"/>. When domain settings are active, the URL line edit will have a green background.
+      </para>
+    </sect1>
+
+    <!-- HTTP Pings. -->
+    <sect1 id="http-pings">
+      <title>HTTP Pings</title>
+
+      <para>
+        HTTP hyperlinks can have an extra <ulink url="https://developer.mozilla.org/en-US/docs/Web/HTML/Element/a#ping">ping attribute</ulink> that sends a POST request to a different URL.
+        These HTTP pings are commonly used for tracking.
+        <ulink url="https://www.theregister.com/2019/04/06/apple_safari_changes/">Most browsers</ulink> send HTTP pings without informing the user
+        <ulink url="https://lists.w3.org/Archives/Public/public-html/2018May/0027.html">in any way</ulink>
+        (despite what The Register article says, current versions of FireFox also happily send HTTP pings).
+      </para>
+
+      <para>
+        Privacy Browser blocks all HTTP pings and presents a dialog informing the user every time the current tab attempts to send one.
+        Hopefully, as more people become aware of what HTTP pings are, web sites will become more embarrassed about using them.
+        This is a classic example of how those who wrote the HTTP specs do not have the best interests of internet users at heart. I would like the day to come where they are removed from the specs.
+      </para>
+    </sect1>
+
+    <!-- Spell Checking. -->
+    <sect1 id="spell-checking">
+      <title>Spell Checking</title>
+
+      <para>
+        Privacy Browser uses the binary <filename>.bdic</filename> Hunspell dictionary format <ulink url="https://doc.qt.io/qt-5/qtwebengine-features.html#spellchecker">utilized by Qt WebEngine</ulink>
+        which was <ulink url="https://sites.google.com/a/chromium.org/dev/developers/how-tos/editing-the-spell-checking-dictionaries">created by Google for Chromium</ulink>.
+        Debian’s Hunspell dictionary language packages are slowly adding support for the <filename>.bdic</filename> format. Those which have are listed by Privacy Browser as suggested packages.
+      </para>
+
+      <para>
+        Once a <filename>.bdic</filename> dictionary is installed, it can be enabled in Privacy Browser’s settings.
+      </para>
+    </sect1>
+  </chapter>
+
+  <!-- Commands. -->
+  <chapter id="commands">
+    <title>Command Reference</title>
+
+    <!-- Main Window. -->
+    <sect1 id="main-window">
+      <title>Main Window</title>
+
+      <!-- File. -->
+      <sect2>
+        <title>File</title>
+
+        <variablelist>
+          <!-- New Tab. -->
+          <varlistentry id="file-new-tab">
+            <term>
+              <menuchoice>
+                <shortcut>
+                  <keycombo action="simul">&Ctrl;<keycap>T</keycap></keycombo>
+                </shortcut>
+                <guimenu>File</guimenu>
+                <guimenuitem>New Tab</guimenuitem>
+              </menuchoice>
+            </term>
+
+            <listitem>
+              <para>
+                Create a new tab.
+              </para>
+            </listitem>
+          </varlistentry>
+
+          <!-- New Window. -->
+          <varlistentry id="file-new-window">
+            <term>
+              <menuchoice>
+                <shortcut>
+                  <keycombo action="simul">&Ctrl;<keycap>N</keycap></keycombo>
+                </shortcut>
+                <guimenu>File</guimenu>
+                <guimenuitem>New Window</guimenuitem>
+              </menuchoice>
+            </term>
+
+            <listitem>
+              <para>
+                Create a new window.
+              </para>
+            </listitem>
+          </varlistentry>
+
+          <!-- Print. -->
+          <varlistentry  id="file-print">
+            <term>
+              <menuchoice>
+                <shortcut>
+                  <keycombo action="simul">&Ctrl;<keycap>P</keycap></keycombo>
+                </shortcut>
+                <guimenu>File</guimenu>
+                <guimenuitem>Print</guimenuitem>
+              </menuchoice>
+            </term>
+
+            <listitem>
+              <para>
+                Print the document.
+              </para>
+            </listitem>
+          </varlistentry>
+
+          <!-- Print Preview. -->
+          <varlistentry  id="file-print-preview">
+            <term>
+              <menuchoice>
+                <shortcut>
+                  <keycombo action="simul">&Ctrl;&Shift;<keycap>P</keycap></keycombo>
+                </shortcut>
+                <guimenu>File</guimenu>
+                <guimenuitem>Print Preview</guimenuitem>
+              </menuchoice>
+            </term>
+
+            <listitem>
+              <para>
+                Display the print preview dialog.
+              </para>
+            </listitem>
+          </varlistentry>
+
+          <!-- Quit. -->
+          <varlistentry  id="file-quit">
+            <term>
+              <menuchoice>
+                <shortcut>
+                  <keycombo action="simul">&Ctrl;<keycap>Q</keycap></keycombo>
+                </shortcut>
+                <guimenu>File</guimenu>
+                <guimenuitem>Quit</guimenuitem>
+              </menuchoice>
+            </term>
+
+            <listitem>
+              <para>
+                Quit &privacybrowser;.
+              </para>
+            </listitem>
+          </varlistentry>
+        </variablelist>
+      </sect2>
+
+      <!-- Edit. -->
+      <sect2>
+        <title>Edit</title>
+
+        <variablelist>
+          <!-- Find. -->
+          <varlistentry id="edit-find">
+            <term>
+              <menuchoice>
+                <shortcut>
+                  <keycombo action="simul">&Ctrl;<keycap>F</keycap></keycombo>
+                </shortcut>
+                <guimenu>Edit</guimenu>
+                <guimenuitem>Find</guimenuitem>
+              </menuchoice>
+            </term>
+
+            <listitem>
+              <para>
+                Display the find toolbar and focus the find text line edit. If the toolbar is already displayed, the find text line edit is refocused and the text it contains is selected.
+              </para>
+            </listitem>
+          </varlistentry>
+
+
+          <!-- Find Next. -->
+          <varlistentry id="edit-find-next">
+            <term>
+              <menuchoice>
+                <shortcut>
+                  <keycap>F3</keycap>
+                </shortcut>
+                <guimenu>Edit</guimenu>
+                <guimenuitem>Find Next</guimenuitem>
+              </menuchoice>
+            </term>
+
+            <listitem>
+              <para>
+                Find the next entry on the page that matches the specified text. This action is only displayed if the find toolbar is visible.
+              </para>
+            </listitem>
+          </varlistentry>
+
+          <!-- Find Previous. -->
+          <varlistentry id="edit-find-previous">
+            <term>
+              <menuchoice>
+                <shortcut>
+                  <keycombo action="simul">&Shift;<keycap>F3</keycap></keycombo>
+                </shortcut>
+                <guimenu>Edit</guimenu>
+                <guimenuitem>Find Previous</guimenuitem>
+              </menuchoice>
+            </term>
+
+            <listitem>
+              <para>
+                Find the previous entry on the page that matches the specified text. This action is only displayed if the find toolbar is visible.
+              </para>
+            </listitem>
+          </varlistentry>
+        </variablelist>
+      </sect2>
+
+      <!-- View. -->
+      <sect2>
+        <title>View</title>
+
+        <variablelist>
+          <!-- Refresh. -->
+          <varlistentry id="view-refresh">
+            <term>
+              <menuchoice>
+                <shortcut>
+                  <keycap>F5</keycap>
+                </shortcut>
+                <guimenu>View</guimenu>
+                <guimenuitem>Refresh</guimenuitem>
+              </menuchoice>
+            </term>
+
+            <listitem>
+              <para>
+                Reload the website in the current tab.
+              </para>
+            </listitem>
+          </varlistentry>
+
+          <!-- Full Screen Mode. -->
+          <varlistentry id="view-full-screen-mode">
+            <term>
+              <menuchoice>
+                <shortcut>
+                  <keycombo action="simul">&Ctrl;&Shift;<keycap>F</keycap></keycombo>
+                </shortcut>
+                <guimenu>View</guimenu>
+                <guimenuitem>Full Screen Mode</guimenuitem>
+              </menuchoice>
+            </term>
+
+            <listitem>
+              <para>
+                Toggle full screen mode. This performs the same action as <xref linkend="f11"/>.
+              </para>
+            </listitem>
+          </varlistentry>
+        </variablelist>
+      </sect2>
+
+      <!-- Go. -->
+      <sect2>
+        <title>Go</title>
+
+        <variablelist>
+          <!-- Back. -->
+          <varlistentry id="go-back">
+            <term>
+              <menuchoice>
+                <shortcut>
+                  <keycombo action="simul">&Alt;<keycap>Left</keycap></keycombo>
+                </shortcut>
+                <guimenu>Go</guimenu>
+                <guimenuitem>Back</guimenuitem>
+              </menuchoice>
+            </term>
+
+            <listitem>
+              <para>
+                Navigate back one step in the current tab’s history. The action is disabled if it is not possible to go back.
+              </para>
+            </listitem>
+          </varlistentry>
+
+          <!-- Forward. -->
+          <varlistentry id="go-forward">
+            <term>
+              <menuchoice>
+                <shortcut>
+                  <keycombo action="simul">&Alt;<keycap>Right</keycap></keycombo>
+                </shortcut>
+                <guimenu>Go</guimenu>
+                <guimenuitem>Forward</guimenuitem>
+              </menuchoice>
+            </term>
+
+            <listitem>
+              <para>
+                Navigate forward one step in the current tab’s history. The action is disabled if it is not possible to go forward.
+              </para>
+            </listitem>
+          </varlistentry>
+
+          <!-- Home. -->
+          <varlistentry id="go-home">
+            <term>
+              <menuchoice>
+                <shortcut>
+                  <keycombo action="simul">&Alt;<keycap>Home</keycap></keycombo>
+                </shortcut>
+                <guimenu>Go</guimenu>
+                <guimenuitem>Home</guimenuitem>
+              </menuchoice>
+            </term>
+
+            <listitem>
+              <para>
+                Load the home page in the current tab.
+              </para>
+            </listitem>
+          </varlistentry>
+        </variablelist>
+      </sect2>
+
+      <!-- On-The-Fly Settings. -->
+      <sect2>
+        <title>On-The-Fly Settings</title>
+
+        <!-- User Agent. -->
+        <sect3>
+          <title>User Agent</title>
+
+          <variablelist>
+            <!-- Privacy Browser. -->
+            <varlistentry id="user-agent-privacy-browser">
+              <term>
+                <menuchoice>
+                  <shortcut>
+                    <keycombo action="simul">&Ctrl;&Alt;<keycap>P</keycap></keycombo>
+                  </shortcut>
+                  <guimenu>On-The-Fly Settings</guimenu>
+                  <guisubmenu>User Agent</guisubmenu>
+                  <guimenuitem>Privacy Browser</guimenuitem>
+                </menuchoice>
+              </term>
+
+              <listitem>
+                <para>
+                  Use the Privacy Browser user agent for the current tab.
+                </para>
+              </listitem>
+            </varlistentry>
+
+            <!-- WebEngine Default. -->
+            <varlistentry id="user-agent-webengine-default">
+              <term>
+                <menuchoice>
+                  <shortcut>
+                    <keycombo action="simul">&Ctrl;&Alt;<keycap>W</keycap></keycombo>
+                  </shortcut>
+                  <guimenu>On-The-Fly Settings</guimenu>
+                  <guisubmenu>User Agent</guisubmenu>
+                  <guimenuitem>WebEngine Default</guimenuitem>
+                </menuchoice>
+              </term>
+
+              <listitem>
+                <para>
+                  Use the WebEngine Default user agent for the current tab.
+                </para>
+              </listitem>
+            </varlistentry>
+
+            <!-- Firefox on Linux. -->
+            <varlistentry id="user-agent-firefox-linux">
+              <term>
+                <menuchoice>
+                  <shortcut>
+                    <keycombo action="simul">&Ctrl;&Alt;<keycap>F</keycap></keycombo>
+                  </shortcut>
+                  <guimenu>On-The-Fly Settings</guimenu>
+                  <guisubmenu>User Agent</guisubmenu>
+                  <guimenuitem>Firefox on Linux</guimenuitem>
+                </menuchoice>
+              </term>
+
+              <listitem>
+                <para>
+                  Use the Firefox on Linux user agent for the current tab.
+                </para>
+              </listitem>
+            </varlistentry>
+
+            <!-- Chromium on Linux. -->
+            <varlistentry id="user-agent-chromium-linux">
+              <term>
+                <menuchoice>
+                  <shortcut>
+                    <keycombo action="simul">&Ctrl;&Alt;<keycap>C</keycap></keycombo>
+                  </shortcut>
+                  <guimenu>On-The-Fly Settings</guimenu>
+                  <guisubmenu>User Agent</guisubmenu>
+                  <guimenuitem>Chromium on Linux</guimenuitem>
+                </menuchoice>
+              </term>
+
+              <listitem>
+                <para>
+                  Use the Chromium on Linux user agent for the current tab.
+                </para>
+              </listitem>
+            </varlistentry>
+
+            <!-- Firefox on Windows. -->
+            <varlistentry id="user-agent-firefox-windows">
+              <term>
+                <menuchoice>
+                  <shortcut>
+                    <keycombo action="simul">&Ctrl;&Alt;&Shift;<keycap>F</keycap></keycombo>
+                  </shortcut>
+                  <guimenu>On-The-Fly Settings</guimenu>
+                  <guisubmenu>User Agent</guisubmenu>
+                  <guimenuitem>Firefox on Windows</guimenuitem>
+                </menuchoice>
+              </term>
+
+              <listitem>
+                <para>
+                  Use the Firefox on Windows user agent for the current tab.
+                </para>
+              </listitem>
+            </varlistentry>
+
+            <!-- Chrome on Windows. -->
+            <varlistentry id="user-agent-chrome-windows">
+              <term>
+                <menuchoice>
+                  <shortcut>
+                    <keycombo action="simul">&Ctrl;&Alt;&Shift;<keycap>C</keycap></keycombo>
+                  </shortcut>
+                  <guimenu>On-The-Fly Settings</guimenu>
+                  <guisubmenu>User Agent</guisubmenu>
+                  <guimenuitem>Chrome on Windows</guimenuitem>
+                </menuchoice>
+              </term>
+
+              <listitem>
+                <para>
+                  Use the Chrome on Windows user agent for the current tab.
+                </para>
+              </listitem>
+            </varlistentry>
+
+            <!-- Edge on Windows. -->
+            <varlistentry id="user-agent-edge-windows">
+              <term>
+                <menuchoice>
+                  <shortcut>
+                    <keycombo action="simul">&Ctrl;&Alt;<keycap>E</keycap></keycombo>
+                  </shortcut>
+                  <guimenu>On-The-Fly Settings</guimenu>
+                  <guisubmenu>User Agent</guisubmenu>
+                  <guimenuitem>Edge on Windows</guimenuitem>
+                </menuchoice>
+              </term>
+
+              <listitem>
+                <para>
+                  Use the Edge on Windows user agent for the current tab.
+                </para>
+              </listitem>
+            </varlistentry>
+
+            <!-- Safari on macOS. -->
+            <varlistentry id="user-agent-safari-macOS">
+              <term>
+                <menuchoice>
+                  <shortcut>
+                    <keycombo action="simul">&Ctrl;&Alt;<keycap>S</keycap></keycombo>
+                  </shortcut>
+                  <guimenu>On-The-Fly Settings</guimenu>
+                  <guisubmenu>User Agent</guisubmenu>
+                  <guimenuitem>Safari on macOS</guimenuitem>
+                </menuchoice>
+              </term>
+
+              <listitem>
+                <para>
+                  Use the Safari on macOS user agent for the current tab.
+                </para>
+              </listitem>
+            </varlistentry>
+
+            <!-- Custom User Agent. -->
+            <varlistentry id="user-agent-custom">
+              <term>
+                <menuchoice>
+                  <shortcut>
+                    <keycombo action="simul">&Alt;&Shift;<keycap>C</keycap></keycombo>
+                  </shortcut>
+                  <guimenu>On-The-Fly Settings</guimenu>
+                  <guisubmenu>User Agent</guisubmenu>
+                  <guimenuitem>Custom</guimenuitem>
+                </menuchoice>
+              </term>
+
+              <listitem>
+                <para>
+                  Use the custom user agent for the current tab. This action is only active if a custom user agent is set in the settings.
+                </para>
+              </listitem>
+            </varlistentry>
+          </variablelist>
+        </sect3>
+
+        <!-- Zoom. -->
+        <sect3>
+          <title>Zoom</title>
+
+          <variablelist>
+            <!-- Zoom Factor. -->
+            <varlistentry id="on-the-fly-settings-zoom-factor">
+              <term>
+                <menuchoice>
+                  <shortcut>
+                    <keycombo action="simul">&Ctrl;&Alt;<keycap>Z</keycap></keycombo>
+                  </shortcut>
+                  <guimenu>On-The-Fly Settings</guimenu>
+                  <guimenuitem>Zoom Factor</guimenuitem>
+                </menuchoice>
+              </term>
+
+              <listitem>
+                <para>
+                  Display the zoom factor dialog.
+                </para>
+              </listitem>
+            </varlistentry>
+          </variablelist>
+        </sect3>
+
+        <!-- Search Engine. -->
+        <sect3>
+          <title>Search Engine</title>
+
+          <variablelist>
+            <!-- Mojeek. -->
+            <varlistentry id="search-engine-mojeek">
+              <term>
+                <menuchoice>
+                  <shortcut>
+                    <keycombo action="simul">&Ctrl;&Shift;<keycap>M</keycap></keycombo>
+                  </shortcut>
+                  <guimenu>On-The-Fly Settings</guimenu>
+                  <guisubmenu>Search Engine</guisubmenu>
+                  <guimenuitem>Mojeek</guimenuitem>
+                </menuchoice>
+              </term>
+
+              <listitem>
+                <para>
+                  Use Mojeek as the search engine.
+                </para>
+              </listitem>
+            </varlistentry>
+
+            <!-- Monocles. -->
+            <varlistentry id="search-engine-monocles">
+              <term>
+                <menuchoice>
+                  <shortcut>
+                    <keycombo action="simul">&Ctrl;&Shift;<keycap>O</keycap></keycombo>
+                  </shortcut>
+                  <guimenu>On-The-Fly Settings</guimenu>
+                  <guisubmenu>Search Engine</guisubmenu>
+                  <guimenuitem>Monocles</guimenuitem>
+                </menuchoice>
+              </term>
+
+              <listitem>
+                <para>
+                  Use Mojeek as the search engine.
+                </para>
+              </listitem>
+            </varlistentry>
+
+            <!-- MetaGer. -->
+            <varlistentry id="search-engine-metager">
+              <term>
+                <menuchoice>
+                  <shortcut>
+                    <keycombo action="simul">&Ctrl;&Shift;<keycap>E</keycap></keycombo>
+                  </shortcut>
+                  <guimenu>On-The-Fly Settings</guimenu>
+                  <guisubmenu>Search Engine</guisubmenu>
+                  <guimenuitem>MetaGer</guimenuitem>
+                </menuchoice>
+              </term>
+
+              <listitem>
+                <para>
+                  Use MetaGer as the search engine.
+                </para>
+              </listitem>
+            </varlistentry>
+
+            <!-- Google. -->
+            <varlistentry id="search-engine-google">
+              <term>
+                <menuchoice>
+                  <shortcut>
+                    <keycombo action="simul">&Ctrl;&Shift;<keycap>G</keycap></keycombo>
+                  </shortcut>
+                  <guimenu>On-The-Fly Settings</guimenu>
+                  <guisubmenu>Search Engine</guisubmenu>
+                  <guimenuitem>Google</guimenuitem>
+                </menuchoice>
+              </term>
+
+              <listitem>
+                <para>
+                  Use Google as the search engine.
+                </para>
+              </listitem>
+            </varlistentry>
+
+            <!-- Bing. -->
+            <varlistentry id="search-engine-bing">
+              <term>
+                <menuchoice>
+                  <shortcut>
+                    <keycombo action="simul">&Ctrl;&Shift;<keycap>B</keycap></keycombo>
+                  </shortcut>
+                  <guimenu>On-The-Fly Settings</guimenu>
+                  <guisubmenu>Search Engine</guisubmenu>
+                  <guimenuitem>Bing</guimenuitem>
+                </menuchoice>
+              </term>
+
+              <listitem>
+                <para>
+                  Use Bing as the search engine.
+                </para>
+              </listitem>
+            </varlistentry>
+
+            <!-- Yahoo. -->
+            <varlistentry id="search-engine-yahoo">
+              <term>
+                <menuchoice>
+                  <shortcut>
+                    <keycombo action="simul">&Ctrl;&Shift;<keycap>Y</keycap></keycombo>
+                  </shortcut>
+                  <guimenu>On-The-Fly Settings</guimenu>
+                  <guisubmenu>Search Engine</guisubmenu>
+                  <guimenuitem>Yahoo</guimenuitem>
+                </menuchoice>
+              </term>
+
+              <listitem>
+                <para>
+                  Use Yahoo as the search engine.
+                </para>
+              </listitem>
+            </varlistentry>
+
+            <!-- Custom Search Engine. -->
+            <varlistentry id="search-engine-custom">
+              <term>
+                <menuchoice>
+                  <shortcut>
+                    <keycombo action="simul">&Ctrl;&Shift;<keycap>C</keycap></keycombo>
+                  </shortcut>
+                  <guimenu>On-The-Fly Settings</guimenu>
+                  <guisubmenu>Search Engine</guisubmenu>
+                  <guimenuitem>Custom</guimenuitem>
+                </menuchoice>
+              </term>
+
+              <listitem>
+                <para>
+                  Use the custom search engine. This action is only active if a custom search engine is set in the settings.
+                </para>
+              </listitem>
+            </varlistentry>
+          </variablelist>
+        </sect3>
+      </sect2>
+
+      <!-- Settings. -->
+      <sect2>
+        <title>Settings</title>
+
+        <variablelist>
+          <!-- Domain Settings. -->
+          <varlistentry id="settings-domain-settings">
+            <term>
+              <menuchoice>
+                <shortcut>
+                  <keycombo action="simul">&Ctrl;<keycap>D</keycap></keycombo>
+                </shortcut>
+                <guimenu>Settings</guimenu>
+                <guimenuitem>Domain Settings</guimenuitem>
+              </menuchoice>
+            </term>
+
+            <listitem>
+              <para>
+                Display the domain settings dialog.
+              </para>
+            </listitem>
+          </varlistentry>
+
+
+          <!-- Cookies. -->
+          <varlistentry id="settings-cookies">
+            <term>
+              <menuchoice>
+                <shortcut>
+                  <keycombo action="simul">&Ctrl;<keycap>;</keycap></keycombo>
+                </shortcut>
+                <guimenu>Settings</guimenu>
+                <guimenuitem>Cookies</guimenuitem>
+              </menuchoice>
+            </term>
+
+            <listitem>
+              <para>
+                Display the cookies dialog.
+              </para>
+            </listitem>
+          </varlistentry>
+        </variablelist>
+      </sect2>
+
+      <!-- Common Settings and Help Entries. -->
+      <sect2 id="common-settings-help-menus">
+        <title>Common Settings and Help Entries</title>
+
+        <para>
+          &privacybrowser; has many common &kde; <guimenu>Settings</guimenu> and <guimenu>Help</guimenu> menu items.
+          For more information read the sections about the <ulink url="help:/fundamentals/ui.html#menus-settings">Settings Menu</ulink>
+          and <ulink url="help:/fundamentals/ui.html#menus-help">Help Menu</ulink>.
+        </para>
+      </sect2>
+
+      <!-- Other Commands. -->
+      <sect2>
+        <title>Other Commands</title>
+
+        <variablelist>
+          <!-- F11. -->
+          <varlistentry id="f11">
+            <term>
+              <command>
+                <keycap>F11</keycap>
+              </command>
+            </term>
+
+            <listitem>
+              <para>
+                Toggle full screen mode. This performs the same action as <xref linkend="view-full-screen-mode"/>.
+              </para>
+            </listitem>
+          </varlistentry>
+
+          <!-- Escape. -->
+          <varlistentry id="escape">
+            <term>
+              <command>
+                <keycap>&Esc;</keycap>
+              </command>
+            </term>
+
+            <listitem>
+              <para>
+                Escape runs the first command that applies from the following list.
+              </para>
+
+              <itemizedlist>
+                <listitem>
+                  <para>
+                    Exit full screen browsing.
+                  </para>
+                </listitem>
+
+                <listitem>
+                  <para>
+                    Clear the find text line edit and the find text highlights.
+                  </para>
+                </listitem>
+
+                <listitem>
+                  <para>
+                    Hide the find text toolbar.
+                  </para>
+                </listitem>
+              </itemizedlist>
+            </listitem>
+          </varlistentry>
+        </variablelist>
+      </sect2>
+    </sect1>
+
+    <!-- Cookies Dialog. -->
+    <sect1 id="cookies-dialog">
+      <title>Cookies Dialog</title>
+
+      <para>
+        The cookies dialog is accessed through <xref linkend="settings-cookies"/> (see <xref linkend="cookies"/>).
+      </para>
+
+      <sect2 id="cookies-dialog-commands">
+        <title>Commands</title>
+
+        <variablelist>
+          <!-- Add Cookie. -->
+          <varlistentry id="add-cookie">
+            <term>
+              <command>
+                <keycap>A</keycap>
+              </command>
+            </term>
+
+            <listitem>
+              <para>
+                Open the add cookie dialog.
+              </para>
+            </listitem>
+          </varlistentry>
+
+          <!-- Edit Cookie. -->
+          <varlistentry id="edit-cookie">
+            <term>
+              <command>
+                <keycap>E</keycap>
+              </command>
+            </term>
+
+            <listitem>
+              <para>
+                Open the edit cookie dialog. This command is only valid if a cookie is currently selected.
+              </para>
+            </listitem>
+          </varlistentry>
+
+          <!-- Delete Cookies. -->
+          <varlistentry id="delete-cookies">
+            <term>
+              <command>
+                <keycap>D</keycap> or <keycap>&Del;</keycap>
+              </command>
+            </term>
+
+            <listitem>
+              <para>
+                Delete the currently selected cookies. A dialog will confirm the deletion before it is processed.
+              </para>
+            </listitem>
+          </varlistentry>
+
+          <!-- Delete All Cookies. -->
+          <varlistentry id="delete-all-cookie">
+            <term>
+              <command>
+                <keycap>L</keycap>
+              </command>
+            </term>
+
+            <listitem>
+              <para>
+                Delete all the cookies. A dialog will confirm the deletion before it is processed.
+              </para>
+            </listitem>
+          </varlistentry>
+
+          <!-- Close. -->
+          <varlistentry id="close-cookies-dialog">
+            <term>
+              <command>
+                <keycap>C</keycap> or <keycombo action="simul">&Ctrl;<keycap>Q</keycap></keycombo>
+              </command>
+            </term>
+
+            <listitem>
+              <para>
+                Close the cookies dialog.
+              </para>
+            </listitem>
+          </varlistentry>
+        </variablelist>
+      </sect2>
+    </sect1>
+
+    <!-- Save Dialog. -->
+    <sect1 id="save-dialog">
+      <title>Save Dialog</title>
+
+      <para>
+        The save dialog pops up when a download is initiated.
+      </para>
+
+      <sect2 id="save-dialog-commands">
+        <title>Commands</title>
+
+        <variablelist>
+          <!-- Save. -->
+          <varlistentry id="save-dialog-save">
+            <term>
+              <command>
+                <keycap>S</keycap>
+              </command>
+            </term>
+
+            <listitem>
+              <para>
+                Save the file.
+              </para>
+            </listitem>
+          </varlistentry>
+
+          <!-- Close. -->
+          <varlistentry id="save-dialog-close">
+            <term>
+              <command>
+                <keycap>C</keycap> or <keycombo action="simul">&Ctrl;<keycap>Q</keycap></keycombo>
+              </command>
+            </term>
+
+            <listitem>
+              <para>
+                Close the save dialog without saving the file.
+              </para>
+            </listitem>
+          </varlistentry>
+        </variablelist>
+      </sect2>
+    </sect1>
+  </chapter>
+
+  <!-- FAQ. -->
+  <chapter id="faq">
+    <title>Questions and Answers</title>
+
+    <qandaset id="faqlist">
+      <qandaentry>
+        <!-- Why are there no questions. -->
+        <question>
+          <para>Why are there no questions?</para>
+        </question>
+
+        <answer>
+          <para>Because Privacy Browser is so perfectly designed that none have ever been asked. Also, because this is the first release and nobody has had a chance to ask them yet. ;)</para>
+        </answer>
+      </qandaentry>
+    </qandaset>
+  </chapter>
+
+  <!-- Credits. -->
+  <chapter id="credits">
+    <title>Credits and License</title>
+
+    <para>
+      Privacy Browser PC copyright 2016-2017,2021-2023 Soren Stoutner <ulink url="mailto:soren@stoutner.com">soren@stoutner.com</ulink>.
+    </para>
+
+    <!-- Program. -->
+    <sect1 id="program">
+      <title>Program</title>
+
+      <para>
+        The source code is available at <ulink url="https://gitweb.stoutner.com/?p=PrivacyBrowserPC.git;a=summary">gitweb.stoutner.com</ulink>
+        or by running <filename>git clone https://git.stoutner.com/PrivacyBrowserPC.git</filename>.
+      </para>
+
+      <para>
+        Translators:
+        <itemizedlist>
+          <listitem><para>Translations will be added in a future release.</para></listitem>
+        </itemizedlist>
+      </para>
+
+      <!-- The program license. -->
+      &underGPL;
+    </sect1>
+
+    <!-- Documentation. -->
+    <sect1 id="documentation">
+      <title>Documentation</title>
+
+      <para>
+        <filename>doc/index.docbook</filename> and <filename>src/com.stoutner.privacybrowser.appdata.xml</filename> are released under the
+        <ulink url="https://www.gnu.org/licenses/fdl-1.3.html">GFDL-1.3 license</ulink> with no Front-Cover or Back-Cover Texts or Invariant Sections.
+        All other documentation is released under the <ulink url="https://www.gnu.org/licenses/gpl-3.0.html">GPLv3+ license</ulink>.
+      </para>
+
+      <!-- The documentation license. -->
+      &underFDL;
+    </sect1>
+
+    <!-- Icons. -->
+    <sect1 id="icons">
+      <title>Icons</title>
+
+      <para>
+        <inlinemediaobject>
+          <imageobject>
+            <imagedata fileref="privacybrowser.png" format="PNG"/>
+          </imageobject>
+          <textobject>
+            <phrase>Privacy Browser</phrase>
+          </textobject>
+        </inlinemediaobject>
+
+        <inlinemediaobject>
+          <imageobject>
+            <imagedata fileref="javascript.png" format="PNG"/>
+          </imageobject>
+          <textobject>
+            <phrase>JavaScript</phrase>
+          </textobject>
+        </inlinemediaobject>
+
+        <inlinemediaobject>
+          <imageobject>
+            <imagedata fileref="privacybrowser-monochrome.png" format="PNG"/>
+          </imageobject>
+          <textobject>
+            <phrase>Privacy Browser Monochrome</phrase>
+          </textobject>
+        </inlinemediaobject>
+
+        are derived from <filename>security</filename> and <filename>language</filename>, which are part of the <ulink url="https://fonts.google.com/icons">Android Material icon set</ulink>
+        and are released under the <ulink url="https://www.apache.org/licenses/LICENSE-2.0">Apache License 2.0</ulink>. Modifications copyright 2016-2017,2021-2023 Soren Stoutner.
+        The resulting images are released under the <ulink url="https://www.gnu.org/licenses/gpl-3.0.html">GPLv3+ license</ulink>.
+      </para>
+
+      <para>
+        <inlinemediaobject>
+          <imageobject>
+            <imagedata fileref="loading.gif" format="GIF"/>
+          </imageobject>
+          <textobject>
+            <phrase>Loading</phrase>
+          </textobject>
+        </inlinemediaobject>
+
+        comes from <ulink url="https://github.com/Codelessly/FlutterLoadingGIFs/blob/master/packages/cupertino_activity_indicator_selective.gif">FlutterLoadingGIFs</ulink>
+        where it is named <filename>cupertino_activity_indicator_selective.gif</filename>.
+        It is released under the <ulink url="https://opensource.org/license/0bsd/">Zero-Clause BSD License</ulink>.
+      </para>
+    </sect1>
+  </chapter>
 </book>
-
-<!--
-Local Variables:
-mode: xml
-sgml-minimize-attributes:nil
-sgml-general-insert-case:lower
-sgml-indent-step:0
-sgml-indent-data:nil
-End:
-
-vim:tabstop=2:shiftwidth=2:expandtab
-kate: space-indent on; indent-width 2; tab-width 2; indent-mode none;
--->