Compare commits
	
		
			9 Commits
		
	
	
		
			experiment
			...
			5a7e309c24
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 5a7e309c24 | |||
| f509668c47 | |||
| e063ed7f75 | |||
| 9192c0beb2 | |||
| 3ee5b1adfc | |||
| 2180b62bf1 | |||
|   | bf49d8321f | ||
|   | 28aa03b31a | ||
| fa6499e3da | 
							
								
								
									
										6
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -7,10 +7,6 @@ release/ | ||||
| enc_temp_folder/ | ||||
| ui_* | ||||
| *autosave | ||||
| doc/~$ree_thoughts.docx | ||||
| doc/~WRL0004.tmp | ||||
| UsersC998D~1.HOLAppDataLocalTemptmpj0mbo3rd | ||||
| xml/fitzefatz.xml | ||||
| build* | ||||
| doc/ | ||||
| src/xtree.vcxproj.user | ||||
| doc/html/ | ||||
|   | ||||
							
								
								
									
										77
									
								
								README.md
									
									
									
									
									
								
							
							
						
						| @@ -1,4 +1,27 @@ | ||||
| # XTree | ||||
| # xtree | ||||
|  | ||||
| Bla blu moo! | ||||
|  | ||||
| ... | ||||
|  | ||||
| ## Build | ||||
|  | ||||
| ``` | ||||
| git clone https://gitea.sourceworx.org/chris/xtree.git | ||||
| cd xtree/src | ||||
| qmake xtree.pro | ||||
| make | ||||
| ``` | ||||
|  | ||||
| ## Verzeichnisstruktur | ||||
|  | ||||
| |  | | ||||
| |--------| | ||||
| | `deprecated/` | Reste & Fehlversuche | ||||
| | `doc/` | Quellcode-Dokumentation | ||||
| | `qml/` | QML Quellcode | ||||
| | `src/` | c++ -Quellcode | ||||
| | `xml/` | XML modeldefinition & Demodaten | ||||
|  | ||||
| ## keys | ||||
|  | ||||
| @@ -65,3 +88,55 @@ die Testfiles. | ||||
| - [ ] ```class XQModelHub : public XQModel, public XQModelReader```: etwas fragwürdig, spart aber leidige Verpointerungen | ||||
|  | ||||
|  | ||||
| # libPiGPIO | ||||
|  | ||||
| libPiGPIO: Eine C++ Softwarebibliothek für den Pi4 zur Einbindung elektronischer Steuerelemente | ||||
|  | ||||
| ## Getting started | ||||
|  | ||||
| To make it easy for you to get started with GitLab, here's a list of recommended next steps. | ||||
|  | ||||
| Already a pro? Just edit this README.md and make it your own. Want to make it easy? [Use the template at the bottom](#editing-this-readme)! | ||||
|  | ||||
| ## Add your files | ||||
|  | ||||
| - [ ] [Create](https://docs.gitlab.com/ee/user/project/repository/web_editor.html#create-a-file) or [upload](https://docs.gitlab.com/ee/user/project/repository/web_editor.html#upload-a-file) files | ||||
| - [ ] [Add files using the command line](https://docs.gitlab.com/ee/gitlab-basics/add-file.html#add-a-file-using-the-command-line) or push an existing Git repository with the following command: | ||||
|  | ||||
| ``` | ||||
| mkdir existing_repo | ||||
| git remote add origin http://sourceworx.org:9099/opensource/libpigpio.git | ||||
| git branch -M main | ||||
| git push -uf origin main | ||||
| ``` | ||||
|  | ||||
| ## Integrate with your tools | ||||
|  | ||||
| - [ ] [Set up project integrations](http://sourceworx.org:9099/opensource/libpigpio/-/settings/integrations) | ||||
|  | ||||
| ## Collaborate with your team | ||||
|  | ||||
| - [ ] [Invite team members and collaborators](https://docs.gitlab.com/ee/user/project/members/) | ||||
| - [ ] [Create a new merge request](https://docs.gitlab.com/ee/user/project/merge_requests/creating_merge_requests.html) | ||||
| - [ ] [Automatically close issues from merge requests](https://docs.gitlab.com/ee/user/project/issues/managing_issues.html#closing-issues-automatically) | ||||
| - [ ] [Enable merge request approvals](https://docs.gitlab.com/ee/user/project/merge_requests/approvals/) | ||||
| - [ ] [Automatically merge when pipeline succeeds](https://docs.gitlab.com/ee/user/project/merge_requests/merge_when_pipeline_succeeds.html) | ||||
|  | ||||
| ## Test and Deploy | ||||
|  | ||||
| Use the built-in continuous integration in GitLab. | ||||
|  | ||||
| - [ ] [Get started with GitLab CI/CD](https://docs.gitlab.com/ee/ci/quick_start/index.html) | ||||
| - [ ] [Analyze your code for known vulnerabilities with Static Application Security Testing(SAST)](https://docs.gitlab.com/ee/user/application_security/sast/) | ||||
| - [ ] [Deploy to Kubernetes, Amazon EC2, or Amazon ECS using Auto Deploy](https://docs.gitlab.com/ee/topics/autodevops/requirements.html) | ||||
| - [ ] [Use pull-based deployments for improved Kubernetes management](https://docs.gitlab.com/ee/user/clusters/agent/) | ||||
| - [ ] [Set up protected environments](https://docs.gitlab.com/ee/ci/environments/protected_environments.html) | ||||
|  | ||||
| *** | ||||
|  | ||||
| # Editing this README | ||||
|  | ||||
| When you're ready to make this README your own, just edit this file and use the handy template below (or feel free to structure it however you want - this is just a starting point!).  Thank you to [makeareadme.com](https://www.makeareadme.com/) for this template. | ||||
|  | ||||
| ## Suggestions for a good README | ||||
| Every project is different, so consider which of these sections apply to yours. The sections used in the template are suggestions for most open source projects. Also keep in mind that while a README can be too long and detailed, too long is better than too short. If you think your README is too long, consider utilizing another form of documentation rather than cutting out information. | ||||
|   | ||||
							
								
								
									
										2987
									
								
								doc/Doxyfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										6
									
								
								doc/doxygen-awesome-css/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,6 @@ | ||||
| docs/html | ||||
| .DS_Store | ||||
| .idea | ||||
|  | ||||
| node_modules | ||||
| *.tgz | ||||
							
								
								
									
										3
									
								
								doc/doxygen-awesome-css/.npmignore
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,3 @@ | ||||
| * | ||||
| !doxygen-awesome* | ||||
|  | ||||
							
								
								
									
										2932
									
								
								doc/doxygen-awesome-css/Doxyfile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
							
								
								
									
										21
									
								
								doc/doxygen-awesome-css/LICENSE
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,21 @@ | ||||
| MIT License | ||||
|  | ||||
| Copyright (c) 2021 - 2023 jothepro | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
| of this software and associated documentation files (the "Software"), to deal | ||||
| in the Software without restriction, including without limitation the rights | ||||
| to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
| copies of the Software, and to permit persons to whom the Software is | ||||
| furnished to do so, subject to the following conditions: | ||||
|  | ||||
| The above copyright notice and this permission notice shall be included in all | ||||
| copies or substantial portions of the Software. | ||||
|  | ||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
| IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
| AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
| LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
| OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||
| SOFTWARE. | ||||
							
								
								
									
										39
									
								
								doc/doxygen-awesome-css/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,39 @@ | ||||
| # SPDX-FileCopyrightText: 2022 Andrea Pappacoda <andrea@pappacoda.it> | ||||
| # SPDX-License-Identifier: MIT | ||||
|  | ||||
| .POSIX: | ||||
|  | ||||
| PROJECT = doxygen-awesome-css | ||||
|  | ||||
| # Paths | ||||
| PREFIX = /usr/local | ||||
| DATADIR = share | ||||
| INSTALLDIR = $(DESTDIR)$(PREFIX)/$(DATADIR)/$(PROJECT) | ||||
|  | ||||
| # Utilities | ||||
| INSTALL = install -m 644 | ||||
| MKDIR = mkdir -p | ||||
| RM = rm -f | ||||
|  | ||||
| # Files to be installed | ||||
| FILES = doxygen-awesome-darkmode-toggle.js \ | ||||
|   doxygen-awesome-fragment-copy-button.js \ | ||||
|   doxygen-awesome-interactive-toc.js \ | ||||
|   doxygen-awesome-paragraph-link.js \ | ||||
|   doxygen-awesome-sidebar-only-darkmode-toggle.css \ | ||||
|   doxygen-awesome-sidebar-only.css \ | ||||
|   doxygen-awesome-tabs.js \ | ||||
|   doxygen-awesome.css | ||||
|  | ||||
| # Empty targets so that `make` and `make clean` do not cause errors | ||||
| all: | ||||
| clean: | ||||
|  | ||||
| install: | ||||
| 	$(MKDIR) $(INSTALLDIR) | ||||
| 	$(INSTALL) $(FILES) $(INSTALLDIR)/ | ||||
|  | ||||
| uninstall: | ||||
| 	$(RM) -r $(INSTALLDIR)/ | ||||
|  | ||||
| .PHONY: all clean install uninstall | ||||
							
								
								
									
										207
									
								
								doc/doxygen-awesome-css/README.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,207 @@ | ||||
| #  Doxygen Awesome | ||||
|  | ||||
| [](https://github.com/jothepro/doxygen-awesome-css/releases/latest) | ||||
| [](https://github.com/jothepro/doxygen-awesome-css/blob/main/LICENSE) | ||||
|  | ||||
|  | ||||
| <div class="title_screenshot"> | ||||
|  | ||||
|  | ||||
|  | ||||
| </div> | ||||
|  | ||||
| **Doxygen Awesome** is a custom CSS theme for Doxygen HTML documentation with lots of customization parameters. | ||||
|  | ||||
| ## Motivation | ||||
|  | ||||
| I really like how the Doxygen HTML documentation is structured! But IMHO it looks a bit outdated. | ||||
|  | ||||
| This theme is an attempt to update the visuals of Doxygen without changing its overall layout too much. | ||||
|  | ||||
| ## Features | ||||
|  | ||||
| - 🌈 Clean, modern design | ||||
| - 🚀 Heavily customizable by adjusting CSS variables | ||||
| - 🧩 No changes to the HTML structure of Doxygen are required | ||||
| - 📱 Improved mobile usability | ||||
| - 🌘 Dark mode support! | ||||
| - 🥇 Works best with **doxygen 1.9.1** - **1.9.4** and **1.9.6** - **1.12.0** | ||||
|  | ||||
| ## Examples | ||||
|  | ||||
| Some websites using this theme: | ||||
|  | ||||
| - [Documentation of this repository](https://jothepro.github.io/doxygen-awesome-css/) | ||||
| - [wxWidgets](https://docs.wxwidgets.org/3.2/) | ||||
| - [OpenCV 5.x](https://docs.opencv.org/5.x/) | ||||
| - [Zephyr](https://docs.zephyrproject.org/latest/doxygen/html/index.html) | ||||
| - [FELTOR](https://mwiesenberger.github.io/feltor/dg/html/modules.html) | ||||
| - [Spatial Audio Framework (SAF)](https://leomccormack.github.io/Spatial_Audio_Framework/index.html) | ||||
| - [Randolf Richardson's C++ classes](https://www.randolf.ca/c++/docs/) | ||||
| - [libCloudSync](https://jothepro.github.io/libCloudSync/) | ||||
| - [libsl3](https://a4z.github.io/libsl3/) | ||||
| - [DuMu<sup>x</sup>](https://dumux.org/docs/doxygen/master/) | ||||
|  | ||||
| ## Installation | ||||
|  | ||||
| To use the theme when generating your documentation, bring the required CSS and JS files from this repository into your project. | ||||
|  | ||||
| This can be done in several ways: | ||||
|  | ||||
| - manually copying the files | ||||
| - adding the project as a Git submodule | ||||
| - downloading the project with CMake FetchContent | ||||
| - adding the project as a npm/xpm dependency | ||||
| - installing the theme system-wide | ||||
|  | ||||
| All theme files are located in the root of this repository and start with the prefix `doxygen-awesome-`. You may not need all of them. Follow the install instructions to figure out what files are required for your setup. | ||||
|  | ||||
| ### Git submodule | ||||
| For projects that use git, add the repository as a submodule and check out the desired release: | ||||
|  | ||||
| ```sh | ||||
| git submodule add https://github.com/jothepro/doxygen-awesome-css.git | ||||
| cd doxygen-awesome-css | ||||
| git checkout v2.3.4 | ||||
| ``` | ||||
|  | ||||
| ### CMake with FetchContent | ||||
|  | ||||
| For project that build with CMake, the `FetchContent` module can be used to download the repository at configure-time. | ||||
|  | ||||
| Add the following snippet to your `CMakeLists.txt` | ||||
|  | ||||
| ```cmake | ||||
| include(FetchContent) | ||||
| FetchContent_Declare( | ||||
|     doxygen-awesome-css | ||||
|     URL https://github.com/jothepro/doxygen-awesome-css/archive/refs/heads/main.zip | ||||
| ) | ||||
| FetchContent_MakeAvailable(doxygen-awesome-css) | ||||
|  | ||||
| # Save the location the files were cloned into | ||||
| # This allows us to get the path to doxygen-awesome.css | ||||
| FetchContent_GetProperties(doxygen-awesome-css SOURCE_DIR AWESOME_CSS_DIR) | ||||
|  | ||||
| # Generate the Doxyfile | ||||
| set(DOXYFILE_IN ${CMAKE_CURRENT_SOURCE_DIR}/doc/Doxyfile.in) | ||||
| set(DOXYFILE_OUT ${CMAKE_CURRENT_BINARY_DIR}/Doxyfile) | ||||
| configure_file(${DOXYFILE_IN} ${DOXYFILE_OUT} @ONLY) | ||||
| ``` | ||||
|  | ||||
| This downloads the latest main (but any other revision could be used) and unpacks in the build folder. The `Doxyfile.in` can reference this location in the `HTML_EXTRA_STYLESHEET` field | ||||
|  | ||||
| ```text | ||||
| HTML_EXTRA_STYLESHEET  = @AWESOME_CSS_DIR@/doxygen-awesome.css | ||||
| ``` | ||||
|  | ||||
| When the configure stage of CMake is run, the `Doxyfile.in` is rendered to Doxyfile and Doxygen can be run as usual. | ||||
|  | ||||
| ### npm/xpm dependency | ||||
|  | ||||
| In the npm ecosystem, this project can be added as a development dependency | ||||
| to your project: | ||||
|  | ||||
| ```sh | ||||
| cd your-project | ||||
| npm install https://github.com/jothepro/doxygen-awesome-css#v2.3.4 --save-dev | ||||
|  | ||||
| ls -l node_module/@jothepro/doxygen-awesome-css | ||||
| ``` | ||||
|  | ||||
| Similarly, in the [xPack](https://xpack.github.io) ecosystem, this project can be added | ||||
| as a development dependency to an [`xpm`](https://xpack.github.io/xpm/) | ||||
| managed project. | ||||
|  | ||||
| ### System-wide | ||||
|  | ||||
| You can even install the theme system-wide by running `make install`. | ||||
| The files will be installed to `/usr/local/share/` by default, | ||||
| but you can customize the install location with `make PREFIX=/my/custom/path install`. | ||||
|  | ||||
| ### Choosing a layout | ||||
|  | ||||
| There are two layout options. Choose one of them and configure Doxygen accordingly: | ||||
|  | ||||
| <div class="tabbed"> | ||||
|  | ||||
| - <b class="tab-title">Base Theme</b><div class="darkmode_inverted_image"> | ||||
|      | ||||
|     </div> | ||||
|     Comes with the typical Doxygen titlebar. Optionally the treeview in the sidebar can be enabled. | ||||
|  | ||||
|     Required files: `doxygen-awesome.css` | ||||
|  | ||||
|     Required `Doxyfile` configuration: | ||||
|     ``` | ||||
|     GENERATE_TREEVIEW      = YES # optional. Also works without treeview | ||||
|     DISABLE_INDEX = NO | ||||
|     FULL_SIDEBAR = NO | ||||
|     HTML_EXTRA_STYLESHEET  = doxygen-awesome-css/doxygen-awesome.css | ||||
|     HTML_COLORSTYLE        = LIGHT # required with Doxygen >= 1.9.5 | ||||
|     ``` | ||||
|  | ||||
| - <b class="tab-title">Sidebar-Only Theme</b><div class="darkmode_inverted_image"> | ||||
|      | ||||
|     </div> | ||||
|     Hides the top titlebar to give more space to the content. The treeview must be enabled in order for this theme to work. | ||||
|  | ||||
|     Required files: `doxygen-awesome.css`, `doxygen-awesome-sidebar-only.css` | ||||
|  | ||||
|     Required `Doxyfile` configuration: | ||||
|     ``` | ||||
|  | ||||
|     GENERATE_TREEVIEW      = YES # required! | ||||
|     DISABLE_INDEX          = NO | ||||
|     FULL_SIDEBAR           = NO | ||||
|     HTML_EXTRA_STYLESHEET  = doxygen-awesome-css/doxygen-awesome.css \ | ||||
|                             doxygen-awesome-css/doxygen-awesome-sidebar-only.css | ||||
|     HTML_COLORSTYLE        = LIGHT # required with Doxygen >= 1.9.5 | ||||
|     ``` | ||||
|  | ||||
| </div> | ||||
|  | ||||
| <br> | ||||
|  | ||||
| @warning | ||||
| - This theme is not compatible with the `FULL_SIDEBAR = YES` option provided by Doxygen! | ||||
| - `HTML_COLORSTYLE` must be set to `LIGHT` since Doxygen 1.9.5! | ||||
|  | ||||
| ### Further installation instructions | ||||
|  | ||||
| - [Installing extensions](docs/extensions.md) | ||||
| - [Customizing the theme (colors, spacing, border-radius, ...)](docs/customization.md) | ||||
| - [Tips and Tricks for further configuration](docs/tricks.md) | ||||
|  | ||||
| ## Browser support | ||||
|  | ||||
| Tested with | ||||
|  | ||||
| - Chrome 119, Chrome 119 for Android, Chrome 119 for iOS | ||||
| - Safari 17, Safari for iOS 16 | ||||
| - Firefox 118, Firefox 120 for Android, Firefox 119 for iOS | ||||
| - Edge 119 | ||||
| - Opera 108 | ||||
|  | ||||
|  | ||||
| The theme does not strive to be backward compatible with (significantly) older browser versions. | ||||
|  | ||||
|  | ||||
| ## Credits | ||||
|  | ||||
| Thanks for all the bug reports and inspiring feedback on GitHub! | ||||
|  | ||||
| Special thanks to all the contributors: | ||||
| <br><br> | ||||
| <a href="https://github.com/jothepro/doxygen-awesome-css/graphs/contributors"> | ||||
|     <img src="https://contrib.rocks/image?repo=jothepro/doxygen-awesome-css" /> | ||||
| </a> | ||||
|  | ||||
|  | ||||
| <div class="section_buttons"> | ||||
|  | ||||
| |                        Read Next | | ||||
| |---------------------------------:| | ||||
| | [Extensions](docs/extensions.md) | | ||||
|  | ||||
| </div> | ||||
							
								
								
									
										121
									
								
								doc/doxygen-awesome-css/docs/customization.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,121 @@ | ||||
| # Customization | ||||
|  | ||||
| [TOC] | ||||
|  | ||||
|  | ||||
| ## CSS-Variables | ||||
|  | ||||
| This theme is highly customizable because a lot of things are parameterized with CSS variables. | ||||
|  | ||||
| Just to give you an idea of how flexible the styling is, click this button: | ||||
|  | ||||
| <div class="alter-theme-button" onclick="toggle_alternative_theme()" onkeypress="if (event.keyCode == 13) toggle_alternative_theme()" tabindex=0>Alter theme</div> | ||||
|  | ||||
| <br><hr> | ||||
|  | ||||
| ### Setup | ||||
|  | ||||
| It is recommended to add your own `custom.css` and overwrite the variables there: | ||||
| ``` | ||||
| HTML_EXTRA_STYLESHEET  = doxygen-awesome.css custom.css | ||||
| ``` | ||||
|  | ||||
| Make sure to override the variables in the correct spot. All variables should be customized where they have been defined, in the `html` tag selector: | ||||
|  | ||||
| ```css | ||||
| html { | ||||
|     /* override light-mode variables here */ | ||||
| } | ||||
| ``` | ||||
|  | ||||
| For dark-mode overrides, you have to choose where to put them, depending on whether the dark-mode toggle extension is installed or not: | ||||
|  | ||||
| <div class="tabbed"> | ||||
|  | ||||
| - <b class="tab-title">dark-mode toggle is installed</b> | ||||
|     ```css | ||||
|     html.dark-mode { | ||||
|         /* define dark-mode variable overrides here if you DO use doxygen-awesome-darkmode-toggle.js */ | ||||
|     } | ||||
|     ``` | ||||
| - <b class="tab-title">dark-mode toggle is **NOT** installed</b> | ||||
|    The dark-mode is enabled automatically depending on the system preference: | ||||
|     ```css | ||||
|     @media (prefers-color-scheme: dark) { | ||||
|         html:not(.light-mode) { | ||||
|             /* define dark-mode variable overrides here if you DON'T use doxygen-awesome-darkmode-toggle.js */ | ||||
|         } | ||||
|     } | ||||
|     ``` | ||||
|  | ||||
| </div> | ||||
|  | ||||
| ### Available variables | ||||
|  | ||||
| The following list gives an overview of the variables defined in [`doxygen-awesome.css`](https://github.com/jothepro/doxygen-awesome-css/blob/main/doxygen-awesome.css). | ||||
|  | ||||
| The list is not complete. To explore all available variables, have a look at the CSS starting from [here](https://github.com/jothepro/doxygen-awesome-css/blob/main/doxygen-awesome.css#L30). | ||||
| All variables are defined at the beginning of the stylesheet. | ||||
|  | ||||
| | Parameter                           | Default (Light)                                             | Default (Dark)                                              | | ||||
| | :---------------------------------- | :---------------------------------------------------------- | :---------------------------------------------------------- | | ||||
| | **Color Scheme**:<br>primary theme colors. This will affect the entire websites color scheme: links, arrows, labels, ...                                      ||| | ||||
| | `--primary-color`                   | <code style="background:#1779c4;color:white">#1779c4</code> | <code style="background:#1982d2;color:white">#1982d2</code> | | ||||
| | `--primary-dark-color`              | <code style="background:#335c80;color:white">#335c80</code> | <code style="background:#5ca8e2;color:black">#5ca8e2</code> | | ||||
| | `--primary-light-color`             | <code style="background:#70b1e9;color:black">#70b1e9</code> | <code style="background:#4779ac;color:white">#4779ac</code> | | ||||
| | **Page Colors**:<br>background and foreground (text-color) of the documentation.                                                                              ||| | ||||
| | `--page-background-color`           | <code style="background:#ffffff;color:black">#ffffff</code> | <code style="background:#1C1D1F;color:white">#1C1D1F</code> | | ||||
| | `--page-foreground-color`           | <code style="background:#2f4153;color:white">#2f4153</code> | <code style="background:#d2dbde;color:black">#d2dbde</code> | | ||||
| | `--page-secondary-foreground-color` | <code style="background:#6f7e8e;color:white">#6f7e8e</code> | <code style="background:#859399;color:white">#859399</code> | | ||||
| | **Spacing:**<br>default spacings. Most ui components reference these values for spacing, to provide uniform spacing on the page.                              ||| | ||||
| | `--spacing-small`                   | `5px`                                                       |                                                             | | ||||
| | `--spacing-medium`                  | `10px`                                                      |                                                             | | ||||
| | `--spacing-large`                   | `16px`                                                      |                                                             | | ||||
| | **Border Radius**:<br>border radius for all rounded ui components. Will affect many components, like dropdowns, memitems, codeblocks, ...                     ||| | ||||
| | `--border-radius-small`             | `4px`                                                       |                                                             | | ||||
| | `--border-radius-medium`            | `6px`                                                       |                                                             | | ||||
| | `--border-radius-large`             | `8px`                                                       |                                                             | | ||||
| | **Content Width**:<br>The content is centered and constrained in its width. To make the content fill the whole page, set the following variable to `auto`.    ||| | ||||
| | `--content-maxwidth`                | `1000px`                                                    |                                                             | | ||||
| | **Code Fragment Colors**:<br>Color-Scheme of multiline codeblocks                                                                                             ||| | ||||
| | `--fragment-background`             | <code style="background:#F8F9FA;color:black">#F8F9FA</code> | <code style="background:#282c34;color:white">#282c34</code> | | ||||
| | `--fragment-foreground`             | <code style="background:#37474F;color:white">#37474F</code> | <code style="background:#dbe4eb;color:black">#dbe4eb</code> | | ||||
| | **Arrow Opacity**:<br>By default the arrows in the sidebar are only visible on hover. You can override this behavior so they are visible all the time.       ||| | ||||
| | `--side-nav-arrow-opacity`          | `0`                                                         |                                                             | | ||||
| | `--side-nav-arrow-hover-opacity`    | `0.9`                                                       |                                                             | | ||||
| | ...and many more                                                                                                                                              ||| | ||||
|  | ||||
|  | ||||
| If you miss a configuration option or find a bug, please consider [opening an issue](https://github.com/jothepro/doxygen-awesome-css/issues)! | ||||
|  | ||||
| ## Doxygen generator | ||||
|  | ||||
| The theme overrides most colors with the `--primary-color-*` variables. | ||||
|  | ||||
| But there are a few small images and graphics that the theme cannot adjust or replace. To make these blend in better with | ||||
| the rest, it is recommended to adjust the [doxygen color settings](https://www.doxygen.nl/manual/customize.html#minor_tweaks_colors)  | ||||
| to something that matches the chosen color scheme. | ||||
|  | ||||
| For the default color scheme, these values work out quite well: | ||||
|  | ||||
| ``` | ||||
| # Doxyfile | ||||
| HTML_COLORSTYLE_HUE    = 209 | ||||
| HTML_COLORSTYLE_SAT    = 255 | ||||
| HTML_COLORSTYLE_GAMMA  = 113 | ||||
| ``` | ||||
|  | ||||
| ## Share your customizations | ||||
|  | ||||
| If you have customized the theme with custom colors, spacings, font-sizes, etc. and you want to share your creation with others, you can do this [here](https://github.com/jothepro/doxygen-awesome-css/discussions/13). | ||||
|  | ||||
| I am always curious to learn about how you made the theme look even better! | ||||
|  | ||||
|  | ||||
| <div class="section_buttons"> | ||||
|  | ||||
| | Previous                    |                       Next | | ||||
| |:----------------------------|---------------------------:| | ||||
| | [Extensions](extensions.md) | [Tips & Tricks](tricks.md) | | ||||
|  | ||||
| </div> | ||||
							
								
								
									
										284
									
								
								doc/doxygen-awesome-css/docs/extensions.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,284 @@ | ||||
| # Extensions | ||||
|  | ||||
| [TOC] | ||||
|  | ||||
| On top of the base theme provided by `doxygen-awesome.css`, this repository comes with Javascript extensions that require additional setup steps to get them running. | ||||
|  | ||||
| The extensions require customizations in the header HTML template. | ||||
| This is how you can create the default template with Doxygen: | ||||
|  | ||||
| 1. Create default header template: | ||||
|     ```sh | ||||
|     doxygen -w html header.html delete_me.html delete_me.css | ||||
|     ``` | ||||
|  | ||||
| 2. Reference the template  in your `Doxyfile`: | ||||
|     ``` | ||||
|     HTML_HEADER            = header.html | ||||
|     ``` | ||||
|  | ||||
| [More details on header customization](https://www.doxygen.nl/manual/customize.html#minor_tweaks_header_css) | ||||
|  | ||||
| ## Dark Mode Toggle {#extension-dark-mode-toggle} | ||||
|  | ||||
| Adds a button next to the search bar to enable and disable the dark theme variant manually: | ||||
|  | ||||
| <div class="darkmode_inverted_image bordered_image"> | ||||
|  | ||||
| {width=250px} | ||||
| </div> | ||||
|  | ||||
| ### Installation | ||||
|  | ||||
| 1. Add the required resources in your `Doxyfile`: | ||||
|    - **HTML_EXTRA_FILES:** `doxygen-awesome-darkmode-toggle.js` | ||||
|    - **HTML_EXTRA_STYLESHEET:** `doxygen-awesome-sidebar-only-darkmode-toggle.css` | ||||
|         <em>(ONLY required for the sidebar-only theme variant!)</em> | ||||
| 2. In the `header.html` template, include `doxygen-awesome-darkmode-toggle.js` at the end of the `<head>` and then initialize it: | ||||
|     ```html | ||||
|    <html>  | ||||
|        <head> | ||||
|            <!-- ... other metadata & script includes ... --> | ||||
|            <script type="text/javascript" src="$relpath^doxygen-awesome-darkmode-toggle.js"></script> | ||||
|            <script type="text/javascript"> | ||||
|                DoxygenAwesomeDarkModeToggle.init() | ||||
|            </script> | ||||
|        </head> | ||||
|        <body> | ||||
|     ``` | ||||
|  | ||||
| ### Customizing | ||||
|  | ||||
| Changing the tooltip of the button: | ||||
| ```js | ||||
| DoxygenAwesomeDarkModeToggle.title = "Zwischen hellem/dunklem Modus wechseln" | ||||
| ``` | ||||
|  | ||||
| Changing Icons. Both Emoji or SVG icons are supported: | ||||
| ```js | ||||
| DoxygenAwesomeDarkModeToggle.lightModeIcon = '🌞' | ||||
| // icon from https://fonts.google.com/icons | ||||
| DoxygenAwesomeDarkModeToggle.darkModeIcon = `<svg xmlns="http://www.w3.org/2000/svg" enable-background="new 0 0 24 24" height="24px" viewBox="0 0 24 24" width="24px" fill="#009793"><g><rect fill="none" height="24" width="24"/></g><g><g><path d="M8.1,14.15C9.77,14.63,11,16.17,11,18c0,0.68-0.19,1.31-0.48,1.87c0.48,0.09,0.97,0.14,1.48,0.14 c1.48,0,2.9-0.41,4.13-1.15c-2.62-0.92-5.23-2.82-6.8-5.86C7.74,9.94,7.78,7.09,8.29,4.9c-2.57,1.33-4.3,4.01-4.3,7.1c0,0,0,0,0,0 c0.01,0,0.01,0,0.02,0C5.66,12,7.18,12.83,8.1,14.15z" opacity=".3"/><path d="M19.78,17.51c-2.47,0-6.57-1.33-8.68-5.43C8.77,7.57,10.6,3.6,11.63,2.01C6.27,2.2,1.98,6.59,1.98,12 c0,0.14,0.02,0.28,0.02,0.42C2.61,12.16,3.28,12,3.98,12c0,0,0,0,0,0c0-3.09,1.73-5.77,4.3-7.1C7.78,7.09,7.74,9.94,9.32,13 c1.57,3.04,4.18,4.95,6.8,5.86c-1.23,0.74-2.65,1.15-4.13,1.15c-0.5,0-1-0.05-1.48-0.14c-0.37,0.7-0.94,1.27-1.64,1.64 c0.98,0.32,2.03,0.5,3.11,0.5c3.5,0,6.58-1.8,8.37-4.52C20.18,17.5,19.98,17.51,19.78,17.51z"/><path d="M7,16l-0.18,0C6.4,14.84,5.3,14,4,14c-1.66,0-3,1.34-3,3s1.34,3,3,3c0.62,0,2.49,0,3,0c1.1,0,2-0.9,2-2 C9,16.9,8.1,16,7,16z"/></g></g></svg>` | ||||
| ``` | ||||
|  | ||||
| All customizations must be applied before calling `DoxygenAwesomeDarkModeToggle.init()`! | ||||
|  | ||||
|  | ||||
| ## Fragment Copy Button {#extension-copy-button} | ||||
|  | ||||
| Shows a copy button when the user hovers over a code fragment: | ||||
|  | ||||
| <div class="darkmode_inverted_image bordered_image"> | ||||
|  | ||||
| {width=490} | ||||
| </div> | ||||
|  | ||||
| ### Installation | ||||
|  | ||||
| 1. Add the required resources in your `Doxyfile`: | ||||
|    - **HTML_EXTRA_FILES:** `doxygen-awesome-fragment-copy-button.js` | ||||
|    - **HTML_COPY_CLIPBOARD:** `NO` required with Doxygen >= 1.10.0 | ||||
| 2. In the `header.html` template, include `doxygen-awesome-fragment-copy-button.js` at the end of the `<head>` and then initialize it: | ||||
|     ```html | ||||
|    <html> | ||||
|        <head> | ||||
|            <!-- ... other metadata & script includes ... --> | ||||
|            <script type="text/javascript" src="$relpath^doxygen-awesome-fragment-copy-button.js"></script> | ||||
|            <script type="text/javascript"> | ||||
|                DoxygenAwesomeFragmentCopyButton.init() | ||||
|            </script> | ||||
|        </head> | ||||
|        <body> | ||||
|     ``` | ||||
|  | ||||
| ### Customizing | ||||
|  | ||||
| The tooltip of the button can be changed: | ||||
| ```js | ||||
| DoxygenAwesomeFragmentCopyButton.title = "In die Zwischenablage kopieren" | ||||
| ``` | ||||
|  | ||||
| The icon can be changed. It must be an SVG: | ||||
| ```js | ||||
| DoxygenAwesomeFragmentCopyButton.copyIcon = `<svg ...>` | ||||
| DoxygenAwesomeFragmentCopyButton.successIcon = `<svg ...>` | ||||
| ``` | ||||
|  | ||||
| All customizations must be applied before calling `DoxygenAwesomeDarkModeToggle.init()`! | ||||
|  | ||||
| ## Paragraph Linking {#extension-para} | ||||
|  | ||||
| Provides a button on hover behind every headline to allow easy creation of a permanent link to the headline: | ||||
|  | ||||
| <div class="darkmode_inverted_image bordered_image"> | ||||
|  | ||||
| {width=220} | ||||
| </div> | ||||
|  | ||||
| Works for all headlines and for many documentation section titles. | ||||
|  | ||||
| ### Installation | ||||
|  | ||||
| 1. Add the required resources in your `Doxyfile`: | ||||
|    - **HTML_EXTRA_FILES:** `doxygen-awesome-paragraph-link.js` | ||||
| 2. In the `header.html` template, include `doxygen-awesome-paragraph-link.js` at the end of the `<head>` and then initialize it: | ||||
|     ```html | ||||
|    <html> | ||||
|        <head> | ||||
|            <!-- ... other metadata & script includes ... --> | ||||
|            <script type="text/javascript" src="$relpath^doxygen-awesome-paragraph-link.js"></script> | ||||
|            <script type="text/javascript"> | ||||
|                DoxygenAwesomeParagraphLink.init() | ||||
|            </script> | ||||
|        </head> | ||||
|        <body> | ||||
|     ``` | ||||
|  | ||||
| ### Customizing | ||||
|  | ||||
| The button tooltip can be changed: | ||||
| ```js | ||||
| DoxygenAwesomeParagraphLink.title = "Abschnitt verknüpfen" | ||||
| ``` | ||||
|  | ||||
| The icon of the button can be changed. Both plain characters or SVG icons are supported: | ||||
| ```js | ||||
| DoxygenAwesomeParagraphLink.icon = "¶" | ||||
| ``` | ||||
|  | ||||
| All customizations must be applied before calling `DoxygenAwesomeParagraphLink.init()`! | ||||
|  | ||||
| ## Interactive TOC {#extension-toc} | ||||
|  | ||||
| On large screens, the Table of Contents (TOC) is anchored on the top right of the page. This extension visualizes the reading progress by dynamically highlighting the currently active section. | ||||
|  | ||||
| On small screens, the extension hides the TOC by default. The user can open it manually when needed: | ||||
|  | ||||
|  | ||||
| <div class="darkmode_inverted_image bordered_image"> | ||||
|  | ||||
| {width=380} | ||||
| </div> | ||||
|  | ||||
| ### Installation | ||||
|  | ||||
| 1. Add the required resources in your `Doxyfile`: | ||||
|    - **HTML_EXTRA_FILES:** `doxygen-awesome-interactive-toc.js` | ||||
| 2. In the `header.html` template, include `doxygen-awesome-interactive-toc.js` at the end of the `<head>` and then initialize it: | ||||
|     ```html | ||||
|    <html> | ||||
|        <head> | ||||
|            <!-- ... other metadata & script includes ... --> | ||||
|            <script type="text/javascript" src="$relpath^doxygen-awesome-interactive-toc.js"></script> | ||||
|            <script type="text/javascript"> | ||||
|                DoxygenAwesomeInteractiveToc.init() | ||||
|            </script> | ||||
|        </head> | ||||
|        <body> | ||||
|     ``` | ||||
|  | ||||
| ### Customizing | ||||
|  | ||||
| The offset for when a headline is considered active can be changed. A smaller value means that the headline of the section must be closer to the top of the viewport before it is highlighted in the TOC: | ||||
| ```js | ||||
| DoxygenAwesomeInteractiveToc.topOffset = 45 | ||||
| ``` | ||||
|  | ||||
| Hiding the TOC on small screens can be disabled. It is still interactive and can be hidden by the user but will now be open by default: | ||||
| ```js | ||||
| DoxygenAwesomeInteractiveToc.hideMobileMenu = false | ||||
| ``` | ||||
|  | ||||
| ## Tabs {#extension-tabs} | ||||
|  | ||||
| @warning Experimental feature! Please report bugs [here](https://github.com/jothepro/doxygen-awesome-css/issues). | ||||
|  | ||||
| This extension allows to arrange list content in tabs: | ||||
|  | ||||
| <div class="tabbed"> | ||||
|  | ||||
| - <b class="tab-title">Tab 1</b> | ||||
|     This is the content of tab 1 | ||||
| - <b class="tab-title">Tab 2</b> | ||||
|     This is the content of tab 2 | ||||
|     1. it has a list | ||||
|     2. with multiple items | ||||
|  | ||||
| </div> | ||||
|  | ||||
|  | ||||
| ### Installation | ||||
|  | ||||
| 1. Add the required resources in your `Doxyfile`: | ||||
|    - **HTML_EXTRA_FILES:** `doxygen-awesome-tabs.js` | ||||
| 2. In the `header.html` template, include `doxygen-awesome-tabs.js` at the end of the `<head>` and then initialize it: | ||||
|     ```html | ||||
|    <html> | ||||
|        <head> | ||||
|            <!-- ... other metadata & script includes ... --> | ||||
|            <script type="text/javascript" src="$relpath^doxygen-awesome-tabs.js"></script> | ||||
|            <script type="text/javascript"> | ||||
|                DoxygenAwesomeTabs.init() | ||||
|            </script> | ||||
|        </head> | ||||
|        <body> | ||||
|     ``` | ||||
|  | ||||
| ### Usage | ||||
|  | ||||
| Each list that is supposed to be displayed as tabs has to be wrapped with the `tabbed` CSS class. | ||||
| Each item in the list must start with an element that has the class `tab-title`. It will then be used as tab title. | ||||
|  | ||||
| ```md | ||||
| <div class="tabbed"> | ||||
|  | ||||
| - <b class="tab-title">Tab 1</b> This is the content of tab 1 | ||||
| - <b class="tab-title">Tab 2</b> This is the content of tab 2 | ||||
|  | ||||
| </div> | ||||
| ``` | ||||
|  | ||||
| ## Page Navigation {#extension-page-navigation} | ||||
|  | ||||
| @warning Experimental feature! Please report bugs [here](https://github.com/jothepro/doxygen-awesome-css/issues). | ||||
|  | ||||
| To allow the user to easily navigate from one document to another, "Next" and "Previous" buttons can be added at the end of a Markdown document. | ||||
|  | ||||
| ### Installation | ||||
|  | ||||
| The feature is shipped inside the default `doxygen-awesome.css`. No additional stylesheets or scripts need to be added. | ||||
|  | ||||
| ### Usage | ||||
|  | ||||
| The following conditions must be met for the feature to work properly: | ||||
| - The navigation must be inside a Markdown table with 1-2 columns. | ||||
| - The alignment of the column defines the alignment of the arrow on the navigation button. | ||||
| - the table must be wrapped inside a `<div>` with the class `section_buttons`. | ||||
|  | ||||
| <div class="tabbed"> | ||||
|  | ||||
| - <span class="tab-title">Code</span> | ||||
|     ```md | ||||
|     <div class="section_buttons"> | ||||
|  | ||||
|     | Previous          |                              Next | | ||||
|     |:------------------|----------------------------------:| | ||||
|     | [Home](README.md) | [Customization](customization.md) | | ||||
|  | ||||
|     </div> | ||||
|     ``` | ||||
| - <span class="tab-title">Result</span> | ||||
|     <div class="section_buttons"> | ||||
|     | Previous          |                              Next | | ||||
|     |:------------------|----------------------------------:| | ||||
|     | [Home](README.md) | [Customization](customization.md) | | ||||
|     </div> | ||||
|  | ||||
| </div> | ||||
|  | ||||
| <div class="section_buttons"> | ||||
|  | ||||
| | Previous          |                              Next | | ||||
| |:------------------|----------------------------------:| | ||||
| | [Home](README.md) | [Customization](customization.md) | | ||||
| </div> | ||||
							
								
								
									
										
											BIN
										
									
								
								doc/doxygen-awesome-css/docs/img/darkmode_toggle.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 11 KiB | 
							
								
								
									
										
											BIN
										
									
								
								doc/doxygen-awesome-css/docs/img/fancy_scrollbars_firefox.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 36 KiB | 
							
								
								
									
										
											BIN
										
									
								
								doc/doxygen-awesome-css/docs/img/fancy_scrollbars_webkit.gif
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 5.4 MiB | 
							
								
								
									
										
											BIN
										
									
								
								doc/doxygen-awesome-css/docs/img/fragment_copy_button.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 32 KiB | 
							
								
								
									
										
											BIN
										
									
								
								doc/doxygen-awesome-css/docs/img/interactive_toc_mobile.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 16 KiB | 
							
								
								
									
										
											BIN
										
									
								
								doc/doxygen-awesome-css/docs/img/paragraph_link.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 12 KiB | 
							
								
								
									
										127
									
								
								doc/doxygen-awesome-css/docs/tricks.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,127 @@ | ||||
| # Tips & Tricks | ||||
|  | ||||
| [TOC] | ||||
|  | ||||
| ## Diagrams with Graphviz {#tricks-graphviz} | ||||
|  | ||||
| To get the best-looking class diagrams for your documentation, generate them with Graphviz as vector graphics with transparent background: | ||||
|  | ||||
| ``` | ||||
| # Doxyfile | ||||
| HAVE_DOT = YES | ||||
| DOT_IMAGE_FORMAT = svg | ||||
| DOT_TRANSPARENT = YES | ||||
| ``` | ||||
|  | ||||
| In case `INTERACTIVE_SVG = YES` is set in the Doxyfile, all user-defined dotgraphs must be wrapped with the `interactive_dotgraph` CSS class for them to be rendered correctly: | ||||
|  | ||||
| ```md | ||||
| <div class="interactive_dotgraph"> | ||||
|  | ||||
| \dotfile graph.dot | ||||
|  | ||||
| </div> | ||||
| ``` | ||||
|  | ||||
| @note Both the default overflow scrolling behavior in this theme and the interactive editor enabled by `INTERACTIVE_SVG` are unsatisfying workarounds IMHO. Consider designing your graphs to be narrow enough to fit the page to avoid scrolling. | ||||
|  | ||||
| ## Disable Dark Mode {#tricks-darkmode} | ||||
|  | ||||
| If you don't want the theme to automatically switch to dark mode depending on the browser preference, | ||||
| you can disable dark mode by adding the `light-mode` class to the HTML tag in the header template: | ||||
|  | ||||
| ```html | ||||
| <html xmlns="http://www.w3.org/1999/xhtml" class="light-mode"> | ||||
| ``` | ||||
|  | ||||
| The same can be done to always enable dark mode: | ||||
|  | ||||
| ```html | ||||
| <html xmlns="http://www.w3.org/1999/xhtml" class="dark-mode"> | ||||
| ``` | ||||
|  | ||||
|  | ||||
| @warning This only works if you don't use the dark-mode toggle extension. | ||||
|  | ||||
| ## Choosing Sidebar Width {#tricks-sidebar} | ||||
|  | ||||
| If you have enabled the sidebar-only theme variant, make sure to carefully choose a proper width for your sidebar. | ||||
| It should be wide enough to hold the icon, project title and version number. If the content is too wide, it will be | ||||
| cut off. | ||||
|  | ||||
| ```css | ||||
| html { | ||||
|     /* Make sure sidebar is wide enough to contain the page title (logo + title + version) */ | ||||
|     --side-nav-fixed-width: 335px; | ||||
| } | ||||
| ``` | ||||
|  | ||||
| The chosen width should also be set in the Doxyfile: | ||||
|  | ||||
| ``` | ||||
| # Doxyfile | ||||
| TREEVIEW_WIDTH = 335 | ||||
| ``` | ||||
|  | ||||
| ## Formatting Tables {#tricks-tables} | ||||
|  | ||||
| By default tables in this theme are left-aligned and as wide as required to fit their content. | ||||
| Those properties can be changed for individual tables. | ||||
|  | ||||
| ### Centering | ||||
|  | ||||
| Tables can be centered by wrapping them in the `<center>` HTML tag. | ||||
|  | ||||
| <div class="tabbed"> | ||||
|  | ||||
| - <span class="tab-title">Code</span> | ||||
|     ```md | ||||
|     <center> | ||||
|         | This table | is centered          | | ||||
|         |------------|----------------------| | ||||
|         | test 1     | test 2               | | ||||
|     </center> | ||||
|     ``` | ||||
| - <span class="tab-title">Result</span> | ||||
|     <center> | ||||
|         | This table | is centered | | ||||
|         |------------|----------------------| | ||||
|         | test 1     | test 2               | | ||||
|     </center> | ||||
|  | ||||
| </div> | ||||
|  | ||||
|  | ||||
|  | ||||
| ### Full Width | ||||
|  | ||||
| To make tables span the full width of the page, no matter how wide the content is, wrap the table in the `full_width_table` CSS class. | ||||
|  | ||||
| @warning Apply with caution! This breaks the overflow scrolling of the table. Content might be cut off on small screens! | ||||
|  | ||||
| <div class="tabbed"> | ||||
|  | ||||
| - <span class="tab-title">Code</span> | ||||
|     ```md | ||||
|     <div class="full_width_table"> | ||||
|         | This table | spans the full width | | ||||
|         |------------|----------------------| | ||||
|         | test 1     | test 2               | | ||||
|     </div> | ||||
|     ``` | ||||
| - <span class="tab-title">Result</span> | ||||
|     <div class="full_width_table"> | ||||
|         | This table | spans the full width | | ||||
|         |------------|----------------------| | ||||
|         | test 1     | test 2               | | ||||
|     </div> | ||||
|  | ||||
| </div> | ||||
|  | ||||
| <div class="section_buttons"> | ||||
|  | ||||
| | Previous                          |                                   Next | | ||||
| |:----------------------------------|---------------------------------------:| | ||||
| | [Customization](customization.md) | [Example](https://jothepro.github.io/doxygen-awesome-css/class_my_library_1_1_example.html) | | ||||
|  | ||||
| </div> | ||||
							
								
								
									
										157
									
								
								doc/doxygen-awesome-css/doxygen-awesome-darkmode-toggle.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,157 @@ | ||||
| /** | ||||
|  | ||||
| Doxygen Awesome | ||||
| https://github.com/jothepro/doxygen-awesome-css | ||||
|  | ||||
| MIT License | ||||
|  | ||||
| Copyright (c) 2021 - 2023 jothepro | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
| of this software and associated documentation files (the "Software"), to deal | ||||
| in the Software without restriction, including without limitation the rights | ||||
| to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
| copies of the Software, and to permit persons to whom the Software is | ||||
| furnished to do so, subject to the following conditions: | ||||
|  | ||||
| The above copyright notice and this permission notice shall be included in all | ||||
| copies or substantial portions of the Software. | ||||
|  | ||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
| IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
| AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
| LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
| OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||
| SOFTWARE. | ||||
|  | ||||
| */ | ||||
|  | ||||
| class DoxygenAwesomeDarkModeToggle extends HTMLElement { | ||||
|     // SVG icons from https://fonts.google.com/icons | ||||
|     // Licensed under the Apache 2.0 license: | ||||
|     // https://www.apache.org/licenses/LICENSE-2.0.html | ||||
|     static lightModeIcon = `<svg xmlns="http://www.w3.org/2000/svg" enable-background="new 0 0 24 24" height="24px" viewBox="0 0 24 24" width="24px" fill="#FCBF00"><rect fill="none" height="24" width="24"/><circle cx="12" cy="12" opacity=".3" r="3"/><path d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"/></svg>` | ||||
|     static darkModeIcon = `<svg xmlns="http://www.w3.org/2000/svg" enable-background="new 0 0 24 24" height="24px" viewBox="0 0 24 24" width="24px" fill="#FE9700"><rect fill="none" height="24" width="24"/><path d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27 C17.45,17.19,14.93,19,12,19c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z" opacity=".3"/><path d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"/></svg>` | ||||
|     static title = "Toggle Light/Dark Mode" | ||||
|  | ||||
|     static prefersLightModeInDarkModeKey = "prefers-light-mode-in-dark-mode" | ||||
|     static prefersDarkModeInLightModeKey = "prefers-dark-mode-in-light-mode" | ||||
|  | ||||
|     static _staticConstructor = function() { | ||||
|         DoxygenAwesomeDarkModeToggle.enableDarkMode(DoxygenAwesomeDarkModeToggle.userPreference) | ||||
|         // Update the color scheme when the browsers preference changes | ||||
|         // without user interaction on the website. | ||||
|         window.matchMedia('(prefers-color-scheme: dark)').addEventListener('change', event => { | ||||
|             DoxygenAwesomeDarkModeToggle.onSystemPreferenceChanged() | ||||
|         }) | ||||
|         // Update the color scheme when the tab is made visible again. | ||||
|         // It is possible that the appearance was changed in another tab  | ||||
|         // while this tab was in the background. | ||||
|         document.addEventListener("visibilitychange", visibilityState => { | ||||
|             if (document.visibilityState === 'visible') { | ||||
|                 DoxygenAwesomeDarkModeToggle.onSystemPreferenceChanged() | ||||
|             } | ||||
|         }); | ||||
|     }() | ||||
|  | ||||
|     static init() { | ||||
|         $(function() { | ||||
|             $(document).ready(function() { | ||||
|                 const toggleButton = document.createElement('doxygen-awesome-dark-mode-toggle') | ||||
|                 toggleButton.title = DoxygenAwesomeDarkModeToggle.title | ||||
|                 toggleButton.updateIcon() | ||||
|  | ||||
|                 window.matchMedia('(prefers-color-scheme: dark)').addEventListener('change', event => { | ||||
|                     toggleButton.updateIcon() | ||||
|                 }) | ||||
|                 document.addEventListener("visibilitychange", visibilityState => { | ||||
|                     if (document.visibilityState === 'visible') { | ||||
|                         toggleButton.updateIcon() | ||||
|                     } | ||||
|                 }); | ||||
|  | ||||
|                 $(document).ready(function(){ | ||||
|                     document.getElementById("MSearchBox").parentNode.appendChild(toggleButton) | ||||
|                 }) | ||||
|                 $(window).resize(function(){ | ||||
|                     document.getElementById("MSearchBox").parentNode.appendChild(toggleButton) | ||||
|                 }) | ||||
|             }) | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     constructor() { | ||||
|         super(); | ||||
|         this.onclick=this.toggleDarkMode | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @returns `true` for dark-mode, `false` for light-mode system preference | ||||
|      */ | ||||
|     static get systemPreference() { | ||||
|         return window.matchMedia('(prefers-color-scheme: dark)').matches | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @returns `true` for dark-mode, `false` for light-mode user preference | ||||
|      */ | ||||
|     static get userPreference() { | ||||
|         return (!DoxygenAwesomeDarkModeToggle.systemPreference && localStorage.getItem(DoxygenAwesomeDarkModeToggle.prefersDarkModeInLightModeKey)) ||  | ||||
|         (DoxygenAwesomeDarkModeToggle.systemPreference && !localStorage.getItem(DoxygenAwesomeDarkModeToggle.prefersLightModeInDarkModeKey)) | ||||
|     } | ||||
|  | ||||
|     static set userPreference(userPreference) { | ||||
|         DoxygenAwesomeDarkModeToggle.darkModeEnabled = userPreference | ||||
|         if(!userPreference) { | ||||
|             if(DoxygenAwesomeDarkModeToggle.systemPreference) { | ||||
|                 localStorage.setItem(DoxygenAwesomeDarkModeToggle.prefersLightModeInDarkModeKey, true) | ||||
|             } else { | ||||
|                 localStorage.removeItem(DoxygenAwesomeDarkModeToggle.prefersDarkModeInLightModeKey) | ||||
|             } | ||||
|         } else { | ||||
|             if(!DoxygenAwesomeDarkModeToggle.systemPreference) { | ||||
|                 localStorage.setItem(DoxygenAwesomeDarkModeToggle.prefersDarkModeInLightModeKey, true) | ||||
|             } else { | ||||
|                 localStorage.removeItem(DoxygenAwesomeDarkModeToggle.prefersLightModeInDarkModeKey) | ||||
|             } | ||||
|         } | ||||
|         DoxygenAwesomeDarkModeToggle.onUserPreferenceChanged() | ||||
|     } | ||||
|  | ||||
|     static enableDarkMode(enable) { | ||||
|         if(enable) { | ||||
|             DoxygenAwesomeDarkModeToggle.darkModeEnabled = true | ||||
|             document.documentElement.classList.add("dark-mode") | ||||
|             document.documentElement.classList.remove("light-mode") | ||||
|         } else { | ||||
|             DoxygenAwesomeDarkModeToggle.darkModeEnabled = false | ||||
|             document.documentElement.classList.remove("dark-mode") | ||||
|             document.documentElement.classList.add("light-mode") | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     static onSystemPreferenceChanged() { | ||||
|         DoxygenAwesomeDarkModeToggle.darkModeEnabled = DoxygenAwesomeDarkModeToggle.userPreference | ||||
|         DoxygenAwesomeDarkModeToggle.enableDarkMode(DoxygenAwesomeDarkModeToggle.darkModeEnabled) | ||||
|     } | ||||
|  | ||||
|     static onUserPreferenceChanged() { | ||||
|         DoxygenAwesomeDarkModeToggle.enableDarkMode(DoxygenAwesomeDarkModeToggle.darkModeEnabled) | ||||
|     } | ||||
|  | ||||
|     toggleDarkMode() { | ||||
|         DoxygenAwesomeDarkModeToggle.userPreference = !DoxygenAwesomeDarkModeToggle.userPreference | ||||
|         this.updateIcon() | ||||
|     } | ||||
|  | ||||
|     updateIcon() { | ||||
|         if(DoxygenAwesomeDarkModeToggle.darkModeEnabled) { | ||||
|             this.innerHTML = DoxygenAwesomeDarkModeToggle.darkModeIcon | ||||
|         } else { | ||||
|             this.innerHTML = DoxygenAwesomeDarkModeToggle.lightModeIcon | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| customElements.define("doxygen-awesome-dark-mode-toggle", DoxygenAwesomeDarkModeToggle); | ||||
| @@ -0,0 +1,85 @@ | ||||
| /** | ||||
|  | ||||
| Doxygen Awesome | ||||
| https://github.com/jothepro/doxygen-awesome-css | ||||
|  | ||||
| MIT License | ||||
|  | ||||
| Copyright (c) 2022 - 2023 jothepro | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
| of this software and associated documentation files (the "Software"), to deal | ||||
| in the Software without restriction, including without limitation the rights | ||||
| to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
| copies of the Software, and to permit persons to whom the Software is | ||||
| furnished to do so, subject to the following conditions: | ||||
|  | ||||
| The above copyright notice and this permission notice shall be included in all | ||||
| copies or substantial portions of the Software. | ||||
|  | ||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
| IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
| AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
| LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
| OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||
| SOFTWARE. | ||||
|  | ||||
| */ | ||||
|  | ||||
| class DoxygenAwesomeFragmentCopyButton extends HTMLElement { | ||||
|     constructor() { | ||||
|         super(); | ||||
|         this.onclick=this.copyContent | ||||
|     } | ||||
|     static title = "Copy to clipboard" | ||||
|     static copyIcon = `<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="24" height="24"><path d="M0 0h24v24H0V0z" fill="none"/><path d="M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z"/></svg>` | ||||
|     static successIcon = `<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="24" height="24"><path d="M0 0h24v24H0V0z" fill="none"/><path d="M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41L9 16.17z"/></svg>` | ||||
|     static successDuration = 980 | ||||
|     static init() { | ||||
|         $(function() { | ||||
|             $(document).ready(function() { | ||||
|                 if(navigator.clipboard) { | ||||
|                     const fragments = document.getElementsByClassName("fragment") | ||||
|                     for(const fragment of fragments) { | ||||
|                         const fragmentWrapper = document.createElement("div") | ||||
|                         fragmentWrapper.className = "doxygen-awesome-fragment-wrapper" | ||||
|                         const fragmentCopyButton = document.createElement("doxygen-awesome-fragment-copy-button") | ||||
|                         fragmentCopyButton.innerHTML = DoxygenAwesomeFragmentCopyButton.copyIcon | ||||
|                         fragmentCopyButton.title = DoxygenAwesomeFragmentCopyButton.title | ||||
|                  | ||||
|                         fragment.parentNode.replaceChild(fragmentWrapper, fragment) | ||||
|                         fragmentWrapper.appendChild(fragment) | ||||
|                         fragmentWrapper.appendChild(fragmentCopyButton) | ||||
|              | ||||
|                     } | ||||
|                 } | ||||
|             }) | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|  | ||||
|     copyContent() { | ||||
|         const content = this.previousSibling.cloneNode(true) | ||||
|         // filter out line number from file listings | ||||
|         content.querySelectorAll(".lineno, .ttc").forEach((node) => { | ||||
|             node.remove() | ||||
|         }) | ||||
|         let textContent = content.textContent | ||||
|         // remove trailing newlines that appear in file listings | ||||
|         let numberOfTrailingNewlines = 0 | ||||
|         while(textContent.charAt(textContent.length - (numberOfTrailingNewlines + 1)) == '\n') { | ||||
|             numberOfTrailingNewlines++; | ||||
|         } | ||||
|         textContent = textContent.substring(0, textContent.length - numberOfTrailingNewlines) | ||||
|         navigator.clipboard.writeText(textContent); | ||||
|         this.classList.add("success") | ||||
|         this.innerHTML = DoxygenAwesomeFragmentCopyButton.successIcon | ||||
|         window.setTimeout(() => { | ||||
|             this.classList.remove("success") | ||||
|             this.innerHTML = DoxygenAwesomeFragmentCopyButton.copyIcon | ||||
|         }, DoxygenAwesomeFragmentCopyButton.successDuration); | ||||
|     } | ||||
| } | ||||
|  | ||||
| customElements.define("doxygen-awesome-fragment-copy-button", DoxygenAwesomeFragmentCopyButton) | ||||
							
								
								
									
										91
									
								
								doc/doxygen-awesome-css/doxygen-awesome-interactive-toc.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,91 @@ | ||||
| /** | ||||
|  | ||||
| Doxygen Awesome | ||||
| https://github.com/jothepro/doxygen-awesome-css | ||||
|  | ||||
| MIT License | ||||
|  | ||||
| Copyright (c) 2022 - 2023 jothepro | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
| of this software and associated documentation files (the "Software"), to deal | ||||
| in the Software without restriction, including without limitation the rights | ||||
| to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
| copies of the Software, and to permit persons to whom the Software is | ||||
| furnished to do so, subject to the following conditions: | ||||
|  | ||||
| The above copyright notice and this permission notice shall be included in all | ||||
| copies or substantial portions of the Software. | ||||
|  | ||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
| IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
| AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
| LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
| OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||
| SOFTWARE. | ||||
|  | ||||
| */ | ||||
|  | ||||
| class DoxygenAwesomeInteractiveToc { | ||||
|     static topOffset = 38 | ||||
|     static hideMobileMenu = true | ||||
|     static headers = [] | ||||
|  | ||||
|     static init() { | ||||
|         window.addEventListener("load", () => { | ||||
|             let toc = document.querySelector(".contents > .toc") | ||||
|             if(toc) { | ||||
|                 toc.classList.add("interactive") | ||||
|                 if(!DoxygenAwesomeInteractiveToc.hideMobileMenu) { | ||||
|                     toc.classList.add("open") | ||||
|                 } | ||||
|                 document.querySelector(".contents > .toc > h3")?.addEventListener("click", () => { | ||||
|                     if(toc.classList.contains("open")) { | ||||
|                         toc.classList.remove("open") | ||||
|                     } else { | ||||
|                         toc.classList.add("open") | ||||
|                     } | ||||
|                 }) | ||||
|  | ||||
|                 document.querySelectorAll(".contents > .toc > ul a").forEach((node) => { | ||||
|                     let id = node.getAttribute("href").substring(1) | ||||
|                     DoxygenAwesomeInteractiveToc.headers.push({ | ||||
|                         node: node, | ||||
|                         headerNode: document.getElementById(id) | ||||
|                     }) | ||||
|  | ||||
|                     document.getElementById("doc-content")?.addEventListener("scroll",this.throttle(DoxygenAwesomeInteractiveToc.update, 100)) | ||||
|                 }) | ||||
|                 DoxygenAwesomeInteractiveToc.update() | ||||
|             } | ||||
|         }) | ||||
|     } | ||||
|  | ||||
|     static update() { | ||||
|         let active = DoxygenAwesomeInteractiveToc.headers[0]?.node | ||||
|         DoxygenAwesomeInteractiveToc.headers.forEach((header) => { | ||||
|             let position = header.headerNode.getBoundingClientRect().top | ||||
|             header.node.classList.remove("active") | ||||
|             header.node.classList.remove("aboveActive") | ||||
|             if(position < DoxygenAwesomeInteractiveToc.topOffset) { | ||||
|                 active = header.node | ||||
|                 active?.classList.add("aboveActive") | ||||
|             } | ||||
|         }) | ||||
|         active?.classList.add("active") | ||||
|         active?.classList.remove("aboveActive") | ||||
|     } | ||||
|  | ||||
|     static throttle(func, delay) { | ||||
|         let lastCall = 0; | ||||
|         return function (...args) { | ||||
|             const now = new Date().getTime(); | ||||
|             if (now - lastCall < delay) { | ||||
|                 return; | ||||
|             } | ||||
|             lastCall = now; | ||||
|             return setTimeout(() => {func(...args)}, delay); | ||||
|         }; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										51
									
								
								doc/doxygen-awesome-css/doxygen-awesome-paragraph-link.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,51 @@ | ||||
| /** | ||||
|  | ||||
| Doxygen Awesome | ||||
| https://github.com/jothepro/doxygen-awesome-css | ||||
|  | ||||
| MIT License | ||||
|  | ||||
| Copyright (c) 2022 - 2023 jothepro | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
| of this software and associated documentation files (the "Software"), to deal | ||||
| in the Software without restriction, including without limitation the rights | ||||
| to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
| copies of the Software, and to permit persons to whom the Software is | ||||
| furnished to do so, subject to the following conditions: | ||||
|  | ||||
| The above copyright notice and this permission notice shall be included in all | ||||
| copies or substantial portions of the Software. | ||||
|  | ||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
| IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
| AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
| LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
| OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||
| SOFTWARE. | ||||
|  | ||||
| */ | ||||
|  | ||||
| class DoxygenAwesomeParagraphLink { | ||||
|     // Icon from https://fonts.google.com/icons | ||||
|     // Licensed under the Apache 2.0 license: | ||||
|     // https://www.apache.org/licenses/LICENSE-2.0.html | ||||
|     static icon = `<svg xmlns="http://www.w3.org/2000/svg" height="20px" viewBox="0 0 24 24" width="20px"><path d="M0 0h24v24H0V0z" fill="none"/><path d="M17 7h-4v2h4c1.65 0 3 1.35 3 3s-1.35 3-3 3h-4v2h4c2.76 0 5-2.24 5-5s-2.24-5-5-5zm-6 8H7c-1.65 0-3-1.35-3-3s1.35-3 3-3h4V7H7c-2.76 0-5 2.24-5 5s2.24 5 5 5h4v-2zm-3-4h8v2H8z"/></svg>` | ||||
|     static title = "Permanent Link" | ||||
|     static init() { | ||||
|         $(function() { | ||||
|             $(document).ready(function() { | ||||
|                 document.querySelectorAll(".contents a.anchor[id], .contents .groupheader > a[id]").forEach((node) => { | ||||
|                     let anchorlink = document.createElement("a") | ||||
|                     anchorlink.setAttribute("href", `#${node.getAttribute("id")}`) | ||||
|                     anchorlink.setAttribute("title", DoxygenAwesomeParagraphLink.title) | ||||
|                     anchorlink.classList.add("anchorlink") | ||||
|                     node.classList.add("anchor") | ||||
|                     anchorlink.innerHTML = DoxygenAwesomeParagraphLink.icon | ||||
|                     node.parentElement.appendChild(anchorlink) | ||||
|                 }) | ||||
|             }) | ||||
|         }) | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,40 @@ | ||||
|  | ||||
| /** | ||||
|  | ||||
| Doxygen Awesome | ||||
| https://github.com/jothepro/doxygen-awesome-css | ||||
|  | ||||
| MIT License | ||||
|  | ||||
| Copyright (c) 2021 - 2023 jothepro | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
| of this software and associated documentation files (the "Software"), to deal | ||||
| in the Software without restriction, including without limitation the rights | ||||
| to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
| copies of the Software, and to permit persons to whom the Software is | ||||
| furnished to do so, subject to the following conditions: | ||||
|  | ||||
| The above copyright notice and this permission notice shall be included in all | ||||
| copies or substantial portions of the Software. | ||||
|  | ||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
| IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
| AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
| LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
| OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||
| SOFTWARE. | ||||
|  | ||||
| */ | ||||
|  | ||||
| @media screen and (min-width: 768px) { | ||||
|  | ||||
|     #MSearchBox { | ||||
|         width: calc(var(--side-nav-fixed-width) - calc(2 * var(--spacing-medium)) - var(--searchbar-height) - 1px); | ||||
|     } | ||||
|  | ||||
|     #MSearchField { | ||||
|         width: calc(var(--side-nav-fixed-width) - calc(2 * var(--spacing-medium)) - 66px - var(--searchbar-height)); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										116
									
								
								doc/doxygen-awesome-css/doxygen-awesome-sidebar-only.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,116 @@ | ||||
| /** | ||||
|  | ||||
| Doxygen Awesome | ||||
| https://github.com/jothepro/doxygen-awesome-css | ||||
|  | ||||
| MIT License | ||||
|  | ||||
| Copyright (c) 2021 - 2023 jothepro | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
| of this software and associated documentation files (the "Software"), to deal | ||||
| in the Software without restriction, including without limitation the rights | ||||
| to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
| copies of the Software, and to permit persons to whom the Software is | ||||
| furnished to do so, subject to the following conditions: | ||||
|  | ||||
| The above copyright notice and this permission notice shall be included in all | ||||
| copies or substantial portions of the Software. | ||||
|  | ||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
| IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
| AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
| LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
| OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||
| SOFTWARE. | ||||
|  | ||||
|  */ | ||||
|  | ||||
| html { | ||||
|     /* side nav width. MUST be = `TREEVIEW_WIDTH`. | ||||
|      * Make sure it is wide enough to contain the page title (logo + title + version) | ||||
|      */ | ||||
|     --side-nav-fixed-width: 335px; | ||||
|     --menu-display: none; | ||||
|  | ||||
|     --top-height: 120px; | ||||
|     --toc-sticky-top: -25px; | ||||
|     --toc-max-height: calc(100vh - 2 * var(--spacing-medium) - 25px); | ||||
| } | ||||
|  | ||||
| #projectname { | ||||
|     white-space: nowrap; | ||||
| } | ||||
|  | ||||
|  | ||||
| @media screen and (min-width: 768px) { | ||||
|     html { | ||||
|         --searchbar-background: var(--page-background-color); | ||||
|     } | ||||
|  | ||||
|     #side-nav { | ||||
|         min-width: var(--side-nav-fixed-width); | ||||
|         max-width: var(--side-nav-fixed-width); | ||||
|         top: var(--top-height); | ||||
|         overflow: visible; | ||||
|     } | ||||
|  | ||||
|     #nav-tree, #side-nav { | ||||
|         height: calc(100vh - var(--top-height)) !important; | ||||
|     } | ||||
|  | ||||
|     #nav-tree { | ||||
|         padding: 0; | ||||
|     } | ||||
|  | ||||
|     #top { | ||||
|         display: block; | ||||
|         border-bottom: none; | ||||
|         height: var(--top-height); | ||||
|         margin-bottom: calc(0px - var(--top-height)); | ||||
|         max-width: var(--side-nav-fixed-width); | ||||
|         overflow: hidden; | ||||
|         background: var(--side-nav-background); | ||||
|     } | ||||
|     #main-nav { | ||||
|         float: left; | ||||
|         padding-right: 0; | ||||
|     } | ||||
|  | ||||
|     .ui-resizable-handle { | ||||
|         cursor: default; | ||||
|         width: 1px !important; | ||||
|         background: var(--separator-color); | ||||
|         box-shadow: 0 calc(-2 * var(--top-height)) 0 0 var(--separator-color); | ||||
|     } | ||||
|  | ||||
|     #nav-path { | ||||
|         position: fixed; | ||||
|         right: 0; | ||||
|         left: var(--side-nav-fixed-width); | ||||
|         bottom: 0; | ||||
|         width: auto; | ||||
|     } | ||||
|  | ||||
|     #doc-content { | ||||
|         height: calc(100vh - 31px) !important; | ||||
|         padding-bottom: calc(3 * var(--spacing-large)); | ||||
|         padding-top: calc(var(--top-height) - 80px); | ||||
|         box-sizing: border-box; | ||||
|         margin-left: var(--side-nav-fixed-width) !important; | ||||
|     } | ||||
|  | ||||
|     #MSearchBox { | ||||
|         width: calc(var(--side-nav-fixed-width) - calc(2 * var(--spacing-medium))); | ||||
|     } | ||||
|  | ||||
|     #MSearchField { | ||||
|         width: calc(var(--side-nav-fixed-width) - calc(2 * var(--spacing-medium)) - 65px); | ||||
|     } | ||||
|  | ||||
|     #MSearchResultsWindow { | ||||
|         left: var(--spacing-medium) !important; | ||||
|         right: auto; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										90
									
								
								doc/doxygen-awesome-css/doxygen-awesome-tabs.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,90 @@ | ||||
| /** | ||||
|  | ||||
| Doxygen Awesome | ||||
| https://github.com/jothepro/doxygen-awesome-css | ||||
|  | ||||
| MIT License | ||||
|  | ||||
| Copyright (c) 2023 jothepro | ||||
|  | ||||
| Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
| of this software and associated documentation files (the "Software"), to deal | ||||
| in the Software without restriction, including without limitation the rights | ||||
| to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
| copies of the Software, and to permit persons to whom the Software is | ||||
| furnished to do so, subject to the following conditions: | ||||
|  | ||||
| The above copyright notice and this permission notice shall be included in all | ||||
| copies or substantial portions of the Software. | ||||
|  | ||||
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
| IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
| AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
| LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
| OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||
| SOFTWARE. | ||||
|  | ||||
| */ | ||||
|  | ||||
| class DoxygenAwesomeTabs { | ||||
|  | ||||
|     static init() { | ||||
|         window.addEventListener("load", () => { | ||||
|             document.querySelectorAll(".tabbed:not(:empty)").forEach((tabbed, tabbedIndex) => { | ||||
|                 let tabLinkList = []            | ||||
|                 tabbed.querySelectorAll(":scope > ul > li").forEach((tab, tabIndex) => { | ||||
|                     tab.id = "tab_" + tabbedIndex + "_" + tabIndex | ||||
|                     let header = tab.querySelector(".tab-title") | ||||
|                     let tabLink = document.createElement("button") | ||||
|                     tabLink.classList.add("tab-button") | ||||
|                     tabLink.appendChild(header) | ||||
|                     header.title = header.textContent | ||||
|                     tabLink.addEventListener("click", () => { | ||||
|                         tabbed.querySelectorAll(":scope > ul > li").forEach((tab) => { | ||||
|                             tab.classList.remove("selected") | ||||
|                         }) | ||||
|                         tabLinkList.forEach((tabLink) => { | ||||
|                             tabLink.classList.remove("active") | ||||
|                         }) | ||||
|                         tab.classList.add("selected") | ||||
|                         tabLink.classList.add("active") | ||||
|                     }) | ||||
|                     tabLinkList.push(tabLink) | ||||
|                     if(tabIndex == 0) { | ||||
|                         tab.classList.add("selected") | ||||
|                         tabLink.classList.add("active") | ||||
|                     } | ||||
|                 }) | ||||
|                 let tabsOverview = document.createElement("div") | ||||
|                 tabsOverview.classList.add("tabs-overview") | ||||
|                 let tabsOverviewContainer = document.createElement("div") | ||||
|                 tabsOverviewContainer.classList.add("tabs-overview-container") | ||||
|                 tabLinkList.forEach((tabLink) => { | ||||
|                     tabsOverview.appendChild(tabLink) | ||||
|                 }) | ||||
|                 tabsOverviewContainer.appendChild(tabsOverview) | ||||
|                 tabbed.before(tabsOverviewContainer) | ||||
|  | ||||
|                 function resize() { | ||||
|                     let maxTabHeight = 0 | ||||
|                     tabbed.querySelectorAll(":scope > ul > li").forEach((tab, tabIndex) => { | ||||
|                         let visibility = tab.style.display | ||||
|                         tab.style.display = "block" | ||||
|                         maxTabHeight = Math.max(tab.offsetHeight, maxTabHeight) | ||||
|                         tab.style.display = visibility | ||||
|                     }) | ||||
|                     tabbed.style.height = `${maxTabHeight + 10}px` | ||||
|                 } | ||||
|  | ||||
|                 resize() | ||||
|                 new ResizeObserver(resize).observe(tabbed) | ||||
|             }) | ||||
|         }) | ||||
|          | ||||
|     } | ||||
|  | ||||
|     static resize(tabbed) { | ||||
|          | ||||
|     } | ||||
| } | ||||
							
								
								
									
										2683
									
								
								doc/doxygen-awesome-css/doxygen-awesome.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,54 @@ | ||||
| html.alternative { | ||||
|     /* primary theme color. This will affect the entire websites color scheme: links, arrows, labels, ... */ | ||||
|     --primary-color: #AF7FE4; | ||||
|     --primary-dark-color: #9270E4; | ||||
|     --primary-light-color: #7aabd6; | ||||
|     --primary-lighter-color: #cae1f1; | ||||
|     --primary-lightest-color: #e9f1f8; | ||||
|  | ||||
|     /* page base colors */ | ||||
|     --page-background-color: white; | ||||
|     --page-foreground-color: #2c3e50; | ||||
|     --page-secondary-foreground-color: #67727e; | ||||
|  | ||||
|  | ||||
|     --border-radius-large: 22px; | ||||
|     --border-radius-small: 9px; | ||||
|     --border-radius-medium: 14px; | ||||
|     --spacing-small: 8px; | ||||
|     --spacing-medium: 14px; | ||||
|     --spacing-large: 19px; | ||||
|  | ||||
|     --top-height: 125px; | ||||
|  | ||||
|     --side-nav-background: #324067; | ||||
|     --side-nav-foreground: #F1FDFF; | ||||
|     --header-foreground: var(--side-nav-foreground); | ||||
|     --searchbar-background: var(--side-nav-foreground); | ||||
|     --searchbar-border-radius: var(--border-radius-medium); | ||||
|     --header-background: var(--side-nav-background); | ||||
|     --header-foreground: var(--side-nav-foreground); | ||||
|  | ||||
|     --toc-background: rgb(243, 240, 252); | ||||
|     --toc-foreground: var(--page-foreground-color); | ||||
| } | ||||
|  | ||||
| html.alternative.dark-mode { | ||||
|     color-scheme: dark; | ||||
|  | ||||
|     --primary-color: #AF7FE4; | ||||
|     --primary-dark-color: #9270E4; | ||||
|     --primary-light-color: #4779ac; | ||||
|     --primary-lighter-color: #191e21; | ||||
|     --primary-lightest-color: #191a1c; | ||||
|  | ||||
|     --page-background-color: #1C1D1F; | ||||
|     --page-foreground-color: #d2dbde; | ||||
|     --page-secondary-foreground-color: #859399; | ||||
|     --separator-color: #3a3246; | ||||
|     --side-nav-background: #171D32; | ||||
|     --side-nav-foreground: #F1FDFF; | ||||
|     --toc-background: #20142C; | ||||
|     --searchbar-background: var(--page-background-color); | ||||
|  | ||||
| } | ||||
							
								
								
									
										57
									
								
								doc/doxygen-awesome-css/doxygen-custom/custom.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,57 @@ | ||||
| .github-corner svg { | ||||
|     fill: var(--primary-light-color); | ||||
|     color: var(--page-background-color); | ||||
|     width: 72px; | ||||
|     height: 72px; | ||||
| } | ||||
|  | ||||
| @media screen and (max-width: 767px) { | ||||
|     .github-corner svg { | ||||
|         width: 50px; | ||||
|         height: 50px; | ||||
|     } | ||||
|     #projectnumber { | ||||
|         margin-right: 22px; | ||||
|     } | ||||
| } | ||||
|  | ||||
| .alter-theme-button { | ||||
|     display: inline-block; | ||||
|     cursor: pointer; | ||||
|     background: var(--primary-color); | ||||
|     color: var(--page-background-color) !important; | ||||
|     border-radius: var(--border-radius-medium); | ||||
|     padding: var(--spacing-small) var(--spacing-medium); | ||||
|     text-decoration: none; | ||||
| } | ||||
|  | ||||
| .alter-theme-button:hover { | ||||
|     background: var(--primary-dark-color); | ||||
| } | ||||
|  | ||||
| html.dark-mode .darkmode_inverted_image img, /* < doxygen 1.9.3 */ | ||||
| html.dark-mode .darkmode_inverted_image object[type="image/svg+xml"] /* doxygen 1.9.3 */ { | ||||
|     filter: brightness(89%) hue-rotate(180deg) invert(); | ||||
| } | ||||
|  | ||||
| .bordered_image { | ||||
|     border-radius: var(--border-radius-small); | ||||
|     border: 1px solid var(--separator-color); | ||||
|     display: inline-block; | ||||
|     overflow: hidden; | ||||
| } | ||||
|  | ||||
| html.dark-mode .bordered_image img, /* < doxygen 1.9.3 */ | ||||
| html.dark-mode .bordered_image object[type="image/svg+xml"] /* doxygen 1.9.3 */ { | ||||
|     border-radius: var(--border-radius-small); | ||||
| } | ||||
|  | ||||
| .title_screenshot { | ||||
|     filter: drop-shadow(0px 3px 10px rgba(0,0,0,0.22)); | ||||
|     max-width: 500px; | ||||
|     margin: var(--spacing-large) 0; | ||||
| } | ||||
|  | ||||
| .title_screenshot .caption { | ||||
|     display: none; | ||||
| } | ||||
							
								
								
									
										90
									
								
								doc/doxygen-awesome-css/doxygen-custom/header.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,90 @@ | ||||
| <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> | ||||
| <html xmlns="http://www.w3.org/1999/xhtml"> | ||||
| <head> | ||||
| <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> | ||||
| <meta http-equiv="X-UA-Compatible" content="IE=9"/> | ||||
| <meta name="generator" content="Doxygen $doxygenversion"/> | ||||
| <meta name="viewport" content="width=device-width, initial-scale=1"/> | ||||
|  | ||||
| <!-- BEGIN opengraph metadata --> | ||||
| <meta property="og:title" content="Doxygen Awesome" /> | ||||
| <meta property="og:image" content="https://repository-images.githubusercontent.com/348492097/4f16df80-88fb-11eb-9d31-4015ff22c452" /> | ||||
| <meta property="og:description" content="Custom CSS theme for doxygen html-documentation with lots of customization parameters." /> | ||||
| <meta property="og:url" content="https://jothepro.github.io/doxygen-awesome-css/" /> | ||||
| <!-- END opengraph metadata --> | ||||
|  | ||||
| <!-- BEGIN twitter metadata --> | ||||
| <meta name="twitter:image:src" content="https://repository-images.githubusercontent.com/348492097/4f16df80-88fb-11eb-9d31-4015ff22c452" /> | ||||
| <meta name="twitter:title" content="Doxygen Awesome" /> | ||||
| <meta name="twitter:description" content="Custom CSS theme for doxygen html-documentation with lots of customization parameters." /> | ||||
| <!-- END twitter metadata --> | ||||
|  | ||||
| <!--BEGIN PROJECT_NAME--><title>$projectname: $title</title><!--END PROJECT_NAME--> | ||||
| <!--BEGIN !PROJECT_NAME--><title>$title</title><!--END !PROJECT_NAME--> | ||||
| <link href="$relpath^tabs.css" rel="stylesheet" type="text/css"/> | ||||
| <link rel="icon" type="image/svg+xml" href="logo.drawio.svg"/> | ||||
| <script type="text/javascript" src="$relpath^jquery.js"></script> | ||||
| <script type="text/javascript" src="$relpath^dynsections.js"></script> | ||||
| <script type="text/javascript" src="$relpath^doxygen-awesome-darkmode-toggle.js"></script> | ||||
| <script type="text/javascript" src="$relpath^doxygen-awesome-fragment-copy-button.js"></script> | ||||
| <script type="text/javascript" src="$relpath^doxygen-awesome-paragraph-link.js"></script> | ||||
| <script type="text/javascript" src="$relpath^doxygen-awesome-interactive-toc.js"></script> | ||||
| <script type="text/javascript" src="$relpath^doxygen-awesome-tabs.js"></script> | ||||
| <script type="text/javascript" src="$relpath^toggle-alternative-theme.js"></script> | ||||
| <script type="text/javascript"> | ||||
|     DoxygenAwesomeFragmentCopyButton.init() | ||||
|     DoxygenAwesomeDarkModeToggle.init() | ||||
|     DoxygenAwesomeParagraphLink.init() | ||||
|     DoxygenAwesomeInteractiveToc.init() | ||||
|     DoxygenAwesomeTabs.init() | ||||
| </script> | ||||
| $treeview | ||||
| $search | ||||
| $mathjax | ||||
| <link href="$relpath^$stylesheet" rel="stylesheet" type="text/css" /> | ||||
| $extrastylesheet | ||||
| </head> | ||||
| <body> | ||||
|  | ||||
| <!-- https://tholman.com/github-corners/ --> | ||||
| <a href="https://github.com/jothepro/doxygen-awesome-css" class="github-corner" title="View source on GitHub" target="_blank" rel="noopener noreferrer"> | ||||
|     <svg viewBox="0 0 250 250" width="40" height="40" style="position: absolute; top: 0; border: 0; right: 0; z-index: 99;" aria-hidden="true"> | ||||
|     <path d="M0,0 L115,115 L130,115 L142,142 L250,250 L250,0 Z"></path><path d="M128.3,109.0 C113.8,99.7 119.0,89.6 119.0,89.6 C122.0,82.7 120.5,78.6 120.5,78.6 C119.2,72.0 123.4,76.3 123.4,76.3 C127.3,80.9 125.5,87.3 125.5,87.3 C122.9,97.6 130.6,101.9 134.4,103.2" fill="currentColor" style="transform-origin: 130px 106px;" class="octo-arm"></path><path d="M115.0,115.0 C114.9,115.1 118.7,116.5 119.8,115.4 L133.7,101.6 C136.9,99.2 139.9,98.4 142.2,98.6 C133.8,88.0 127.5,74.4 143.8,58.0 C148.5,53.4 154.0,51.2 159.7,51.0 C160.3,49.4 163.2,43.6 171.4,40.1 C171.4,40.1 176.1,42.5 178.8,56.2 C183.1,58.6 187.2,61.8 190.9,65.4 C194.5,69.0 197.7,73.2 200.1,77.6 C213.8,80.2 216.3,84.9 216.3,84.9 C212.7,93.1 206.9,96.0 205.4,96.6 C205.1,102.4 203.0,107.8 198.3,112.5 C181.9,128.9 168.3,122.5 157.7,114.1 C157.9,116.9 156.7,120.9 152.7,124.9 L141.0,136.5 C139.8,137.7 141.6,141.9 141.8,141.8 Z" fill="currentColor" class="octo-body"></path></svg></a><style>.github-corner:hover .octo-arm{animation:octocat-wave 560ms ease-in-out}@keyframes octocat-wave{0%,100%{transform:rotate(0)}20%,60%{transform:rotate(-25deg)}40%,80%{transform:rotate(10deg)}}@media (max-width:500px){.github-corner:hover .octo-arm{animation:none}.github-corner .octo-arm{animation:octocat-wave 560ms ease-in-out}}</style> | ||||
|  | ||||
|  | ||||
| <div id="top"><!-- do not remove this div, it is closed by doxygen! --> | ||||
|  | ||||
| <!--BEGIN TITLEAREA--> | ||||
| <div id="titlearea"> | ||||
| <table cellspacing="0" cellpadding="0"> | ||||
|  <tbody> | ||||
|  <tr style="height: 56px;"> | ||||
|   <!--BEGIN PROJECT_LOGO--> | ||||
|   <td id="projectlogo"><img alt="Logo" src="$relpath^$projectlogo"/></td> | ||||
|   <!--END PROJECT_LOGO--> | ||||
|   <!--BEGIN PROJECT_NAME--> | ||||
|   <td id="projectalign" style="padding-left: 0.5em;"> | ||||
|    <div id="projectname">$projectname | ||||
|    <!--BEGIN PROJECT_NUMBER--> <span id="projectnumber">$projectnumber</span><!--END PROJECT_NUMBER--> | ||||
|    </div> | ||||
|    <!--BEGIN PROJECT_BRIEF--><div id="projectbrief">$projectbrief</div><!--END PROJECT_BRIEF--> | ||||
|   </td> | ||||
|   <!--END PROJECT_NAME--> | ||||
|   <!--BEGIN !PROJECT_NAME--> | ||||
|    <!--BEGIN PROJECT_BRIEF--> | ||||
|     <td style="padding-left: 0.5em;"> | ||||
|     <div id="projectbrief">$projectbrief</div> | ||||
|     </td> | ||||
|    <!--END PROJECT_BRIEF--> | ||||
|   <!--END !PROJECT_NAME--> | ||||
|   <!--BEGIN DISABLE_INDEX--> | ||||
|    <!--BEGIN SEARCHENGINE--> | ||||
|    <td>$searchbox</td> | ||||
|    <!--END SEARCHENGINE--> | ||||
|   <!--END DISABLE_INDEX--> | ||||
|  </tr> | ||||
|  </tbody> | ||||
| </table> | ||||
| </div> | ||||
| <!--END TITLEAREA--> | ||||
| <!-- end header part --> | ||||
| @@ -0,0 +1,12 @@ | ||||
|  | ||||
| let original_theme_active = true; | ||||
|  | ||||
| function toggle_alternative_theme() { | ||||
|     if(original_theme_active) { | ||||
|         document.documentElement.classList.add("alternative") | ||||
|         original_theme_active = false; | ||||
|     } else { | ||||
|         document.documentElement.classList.remove("alternative") | ||||
|         original_theme_active = true; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										
											BIN
										
									
								
								doc/doxygen-awesome-css/img/screenshot.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 211 KiB | 
							
								
								
									
										
											BIN
										
									
								
								doc/doxygen-awesome-css/img/testimage.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 4.7 KiB | 
							
								
								
									
										117
									
								
								doc/doxygen-awesome-css/img/theme-variants-base.drawio.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,117 @@ | ||||
| <svg host="65bd71144e" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="491px" height="261px" viewBox="-0.5 -0.5 491 261" content="<mxfile><diagram id="6E4AiNPWWr3a8GvC3Ypl" name="Page-1">xZfLrpswEIafBqndIIzBwLK5tZt2k0pd+wQHrBqcOs6tT98xmABxmrYiUUEK+Pd1vhkPjofn1fmjorvys8yZ8MIgP3t44YVhihL4NcKlFZIkbYVC8byVUC+s+U9mxcCqB56z/aihllJovhuLG1nXbKNHGlVKnsbNtlKMZ93RgjnCekOFq37juS6tWXHQ658YL8puZhTYmop2ja2wL2kuTwMJLz08V1Lq9q06z5kw7Doubb/Vb2qvC1Os1n/ToVvHkYqDNc4uTF86awslDzsPz+BR58x0DKBE1cY6JoWSO69dypEpzc73vELfugl6wyFgmKyYVhdod+rRRpldZznAGhIrUuvO4tq3txherNH3AZA/2z+2+1RyzdY7ujG1Jwhv0EpdwfgLBK97reR3NpdCqqY3JktzQ00h6H5vBwEEmvKaKVt28V0dc8vvP3GKHE5zsMEs97m4ls09FUlXm6V+jNteNtVEkZ/a7DPgBi19Qlx0KI19hKfTCx16X7kW7I0qUN99oUdeUM1l7RkbwfRgzWB/le+nwd1yIQZoF8vlYrV6GKMvjcMGPUqyqPudzhU7XNfwZXCwPpfjKjH36zg+jFQUEj/Br4vU2CG6go8Ra4DOFKP5Rh2q3X4i0deSg4wHu3lwZQ7GuwGKsY9HF5nOM3EjtNnaD/ihKfy2kJUHekjM/aR0ihPkJ2GEcJJhFOAoHmVWdLu9Qzd4A+R3naM0TOLsTiDf+I6k052Q3vnIE6EtruZI0hEjPw7m7DXr2Q0kUphnk7q7AWDqdoy2znEroNWPfFfLmt2kGCtRwYsaioJtzQjGTRyOoB+sXPE8N5PcDZXxZjQLtGe1cPJp43x1U5qROEZdQIT/Ggyw24ahkJL4JcEAxf443dQN/pPg5S8=</diagram></mxfile>"> | ||||
|     <defs/> | ||||
|     <g> | ||||
|         <rect x="0" y="0" width="490" height="260" fill="rgb(255, 255, 255)" stroke="#6e6e6e" pointer-events="none"/> | ||||
|         <rect x="198.53" y="44.87" width="219.66" height="185.13" fill="rgb(255, 255, 255)" stroke="#e3e3e3" pointer-events="none"/> | ||||
|         <g transform="translate(-0.5 -0.5)"> | ||||
|             <switch> | ||||
|                 <foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"> | ||||
|                     <div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 218px; height: 1px; padding-top: 137px; margin-left: 200px;"> | ||||
|                         <div data-drawio-colors="color: rgb(0, 0, 0); " style="box-sizing: border-box; font-size: 0px; text-align: center;"> | ||||
|                             <div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: rgb(0, 0, 0); line-height: 1.2; pointer-events: none; white-space: normal; overflow-wrap: normal;"> | ||||
|                                 Content | ||||
|                             </div> | ||||
|                         </div> | ||||
|                     </div> | ||||
|                 </foreignObject> | ||||
|                 <text x="308" y="141" fill="rgb(0, 0, 0)" font-family="Helvetica" font-size="12px" text-anchor="middle"> | ||||
|                     Content | ||||
|                 </text> | ||||
|             </switch> | ||||
|         </g> | ||||
|         <rect x="0" y="0" width="490" height="44.87" fill="#deedff" stroke="#6e6e6e" pointer-events="none"/> | ||||
|         <g transform="translate(-0.5 -0.5)"> | ||||
|             <switch> | ||||
|                 <foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"> | ||||
|                     <div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 488px; height: 1px; padding-top: 22px; margin-left: 1px;"> | ||||
|                         <div data-drawio-colors="color: rgb(0, 0, 0); " style="box-sizing: border-box; font-size: 0px; text-align: center;"> | ||||
|                             <div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: rgb(0, 0, 0); line-height: 1.2; pointer-events: none; white-space: normal; overflow-wrap: normal;"> | ||||
|                                 Titlebar (Navigation + Search) | ||||
|                             </div> | ||||
|                         </div> | ||||
|                     </div> | ||||
|                 </foreignObject> | ||||
|                 <text x="245" y="26" fill="rgb(0, 0, 0)" font-family="Helvetica" font-size="12px" text-anchor="middle"> | ||||
|                     Titlebar (Navigation + Search) | ||||
|                 </text> | ||||
|             </switch> | ||||
|         </g> | ||||
|         <rect x="0" y="44.87" width="126.73" height="185.13" fill="#f7f7f7" stroke="#6e6e6e" pointer-events="none"/> | ||||
|         <g transform="translate(-0.5 -0.5)"> | ||||
|             <switch> | ||||
|                 <foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"> | ||||
|                     <div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 125px; height: 1px; padding-top: 137px; margin-left: 1px;"> | ||||
|                         <div data-drawio-colors="color: rgb(0, 0, 0); " style="box-sizing: border-box; font-size: 0px; text-align: center;"> | ||||
|                             <div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: rgb(0, 0, 0); line-height: 1.2; pointer-events: none; white-space: normal; overflow-wrap: normal;"> | ||||
|                                 Sidebar (Navigation) | ||||
|                             </div> | ||||
|                         </div> | ||||
|                     </div> | ||||
|                 </foreignObject> | ||||
|                 <text x="63" y="141" fill="rgb(0, 0, 0)" font-family="Helvetica" font-size="12px" text-anchor="middle"> | ||||
|                     Sidebar (Navigation) | ||||
|                 </text> | ||||
|             </switch> | ||||
|         </g> | ||||
|         <rect x="0" y="226.67" width="490" height="33.33" fill="rgb(255, 255, 255)" stroke="#6e6e6e" pointer-events="none"/> | ||||
|         <g transform="translate(-0.5 -0.5)"> | ||||
|             <switch> | ||||
|                 <foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"> | ||||
|                     <div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 488px; height: 1px; padding-top: 243px; margin-left: 1px;"> | ||||
|                         <div data-drawio-colors="color: rgb(0, 0, 0); " style="box-sizing: border-box; font-size: 0px; text-align: center;"> | ||||
|                             <div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: rgb(0, 0, 0); line-height: 1.2; pointer-events: none; white-space: normal; overflow-wrap: normal;"> | ||||
|                                 Footer (Breadcrumbs) | ||||
|                             </div> | ||||
|                         </div> | ||||
|                     </div> | ||||
|                 </foreignObject> | ||||
|                 <text x="245" y="247" fill="rgb(0, 0, 0)" font-family="Helvetica" font-size="12px" text-anchor="middle"> | ||||
|                     Footer (Breadcrumbs) | ||||
|                 </text> | ||||
|             </switch> | ||||
|         </g> | ||||
|         <rect x="371.72" y="14.87" width="101.38" height="16.67" rx="2.5" ry="2.5" fill="rgb(255, 255, 255)" stroke="#6e6e6e" pointer-events="none"/> | ||||
|         <g transform="translate(-0.5 -0.5)"> | ||||
|             <switch> | ||||
|                 <foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"> | ||||
|                     <div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 99px; height: 1px; padding-top: 23px; margin-left: 373px;"> | ||||
|                         <div data-drawio-colors="color: #262626; " style="box-sizing: border-box; font-size: 0px; text-align: center;"> | ||||
|                             <div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: rgb(38, 38, 38); line-height: 1.2; pointer-events: none; white-space: normal; overflow-wrap: normal;"> | ||||
|                                 Search | ||||
|                             </div> | ||||
|                         </div> | ||||
|                     </div> | ||||
|                 </foreignObject> | ||||
|                 <text x="422" y="27" fill="#262626" font-family="Helvetica" font-size="12px" text-anchor="middle"> | ||||
|                     Search | ||||
|                 </text> | ||||
|             </switch> | ||||
|         </g> | ||||
|         <g transform="translate(-0.5 -0.5)"> | ||||
|             <switch> | ||||
|                 <foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"> | ||||
|                     <div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe flex-start; width: 32px; height: 1px; padding-top: 23px; margin-left: 19px;"> | ||||
|                         <div data-drawio-colors="color: rgb(0, 0, 0); " style="box-sizing: border-box; font-size: 0px; text-align: left;"> | ||||
|                             <div style="display: inline-block; font-size: 20px; font-family: Helvetica; color: rgb(0, 0, 0); line-height: 1.2; pointer-events: none; white-space: normal; overflow-wrap: normal;"> | ||||
|                                 <font color="#262626"> | ||||
|                                     Title | ||||
|                                 </font> | ||||
|                             </div> | ||||
|                         </div> | ||||
|                     </div> | ||||
|                 </foreignObject> | ||||
|                 <text x="19" y="29" fill="rgb(0, 0, 0)" font-family="Helvetica" font-size="20px"> | ||||
|                     Tit... | ||||
|                 </text> | ||||
|             </switch> | ||||
|         </g> | ||||
|     </g> | ||||
|     <switch> | ||||
|         <g requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"/> | ||||
|         <a transform="translate(0,-5)" xlink:href="https://www.diagrams.net/doc/faq/svg-export-text-problems" target="_blank"> | ||||
|             <text text-anchor="middle" font-size="10px" x="50%" y="100%"> | ||||
|                 Text is not SVG - cannot display | ||||
|             </text> | ||||
|         </a> | ||||
|     </switch> | ||||
| </svg> | ||||
| After Width: | Height: | Size: 9.5 KiB | 
| @@ -0,0 +1,102 @@ | ||||
| <svg host="65bd71144e" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="491px" height="261px" viewBox="-0.5 -0.5 491 261" content="<mxfile><diagram id="6E4AiNPWWr3a8GvC3Ypl" name="Page-1">xZZNj5swEIZ/DdL2gjAGA8cmm7SX9pJKPTvBAasGU8f56q/vOJjFLOxqpbC7WIrMO/5gnhlP7OFldfmmaFP+kDkTXhjkFw8/emGYogR+jXBthSRJW6FQPG8l1Asb/o9ZMbDqkefsMBiopRSaN0NxJ+ua7fRAo0rJ83DYXorhrg0t2EjY7KgYq795rkvrVhz0+nfGi7LbGQXWUtFusBUOJc3l2ZHwysNLJaVue9VlyYRh13Fp561fsD59mGK1ftOErJ1xouJonbMfpq+dt4WSx2a8sN3rxJRmlynsdNut0HsGGcFkxbS6wrhzzy7KLJDS4RYSK1Ibr+Jpbu8SdKxX0x6+wUHwr86ZGR94eHEuuWabhu6M9Qz5C1qpK1j/EUH3oJX8w5ZSSHWbjcnKNLBMIMpeYPRJLLrz48BYylqb752XyerW7mXSWbPUj8Osf2z1sMUDEZ9YxYEIs3xCJjhi7GM8A0o0QrmBorSlyjPpTgTst9jCCylM7+EX14DWmIBJ8JOeeEE1l/WX+8jvuRAO93Vi2odkKQqJn4TvlajhiO4aaiIzcB8WitF8p45Vc7iT3jtRuriEIoSTDKMARzEe5C2Qggx1n1ESY4L9MIlTEgYkzUgcj3Hf0tl9yAz08Ti3GVW78hXa6B7aeyhCjh4S02aLApQHJwrpsHpEaBiEcSVBAfK7yVEK4cjGUUDPQ5nOEIVo4p+rrSuG1+1/tkNG/h7NjWHRw3OktgLZAtQuAHu3a7S2UVyBrX4teLWs2bPqYyUqeFHDq2B7s4KJE4eL01crVzzPzSaTuTI8u+YD7dUvDD4mGRCaDqN7JLHv5kJKJs7kDNkAr/0l8GZzbtJ49R8=</diagram></mxfile>"> | ||||
|     <defs/> | ||||
|     <g> | ||||
|         <rect x="0" y="0" width="490" height="260" fill="rgb(255, 255, 255)" stroke="#6e6e6e" pointer-events="none"/> | ||||
|         <rect x="198.53" y="16.67" width="219.66" height="233.33" fill="rgb(255, 255, 255)" stroke="#e3e3e3" pointer-events="none"/> | ||||
|         <g transform="translate(-0.5 -0.5)"> | ||||
|             <switch> | ||||
|                 <foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"> | ||||
|                     <div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 218px; height: 1px; padding-top: 133px; margin-left: 200px;"> | ||||
|                         <div data-drawio-colors="color: rgb(0, 0, 0); " style="box-sizing: border-box; font-size: 0px; text-align: center;"> | ||||
|                             <div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: rgb(0, 0, 0); line-height: 1.2; pointer-events: none; white-space: normal; overflow-wrap: normal;"> | ||||
|                                 Content | ||||
|                             </div> | ||||
|                         </div> | ||||
|                     </div> | ||||
|                 </foreignObject> | ||||
|                 <text x="308" y="137" fill="rgb(0, 0, 0)" font-family="Helvetica" font-size="12px" text-anchor="middle"> | ||||
|                     Content | ||||
|                 </text> | ||||
|             </switch> | ||||
|         </g> | ||||
|         <rect x="0" y="0" width="126.72" height="260" fill="#f7f7f7" stroke="#6e6e6e" pointer-events="none"/> | ||||
|         <g transform="translate(-0.5 -0.5)"> | ||||
|             <switch> | ||||
|                 <foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"> | ||||
|                     <div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 125px; height: 1px; padding-top: 130px; margin-left: 1px;"> | ||||
|                         <div data-drawio-colors="color: rgb(0, 0, 0); " style="box-sizing: border-box; font-size: 0px; text-align: center;"> | ||||
|                             <div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: rgb(0, 0, 0); line-height: 1.2; pointer-events: none; white-space: normal; overflow-wrap: normal;"> | ||||
|                                 Sidebar | ||||
|                                 <br/> | ||||
|                                 (Title + Navigation) | ||||
|                             </div> | ||||
|                         </div> | ||||
|                     </div> | ||||
|                 </foreignObject> | ||||
|                 <text x="63" y="134" fill="rgb(0, 0, 0)" font-family="Helvetica" font-size="12px" text-anchor="middle"> | ||||
|                     Sidebar... | ||||
|                 </text> | ||||
|             </switch> | ||||
|         </g> | ||||
|         <rect x="126.72" y="226.67" width="363.28" height="33.33" fill="rgb(255, 255, 255)" stroke="#6e6e6e" pointer-events="none"/> | ||||
|         <g transform="translate(-0.5 -0.5)"> | ||||
|             <switch> | ||||
|                 <foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"> | ||||
|                     <div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 361px; height: 1px; padding-top: 243px; margin-left: 128px;"> | ||||
|                         <div data-drawio-colors="color: rgb(0, 0, 0); " style="box-sizing: border-box; font-size: 0px; text-align: center;"> | ||||
|                             <div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: rgb(0, 0, 0); line-height: 1.2; pointer-events: none; white-space: normal; overflow-wrap: normal;"> | ||||
|                                 Footer (Breadcrumbs) | ||||
|                             </div> | ||||
|                         </div> | ||||
|                     </div> | ||||
|                 </foreignObject> | ||||
|                 <text x="308" y="247" fill="rgb(0, 0, 0)" font-family="Helvetica" font-size="12px" text-anchor="middle"> | ||||
|                     Footer (Breadcrumbs) | ||||
|                 </text> | ||||
|             </switch> | ||||
|         </g> | ||||
|         <rect x="12.67" y="41.67" width="101.38" height="16.67" rx="2.5" ry="2.5" fill="rgb(255, 255, 255)" stroke="#6e6e6e" pointer-events="none"/> | ||||
|         <g transform="translate(-0.5 -0.5)"> | ||||
|             <switch> | ||||
|                 <foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"> | ||||
|                     <div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 99px; height: 1px; padding-top: 50px; margin-left: 14px;"> | ||||
|                         <div data-drawio-colors="color: #262626; " style="box-sizing: border-box; font-size: 0px; text-align: center;"> | ||||
|                             <div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: rgb(38, 38, 38); line-height: 1.2; pointer-events: none; white-space: normal; overflow-wrap: normal;"> | ||||
|                                 Search | ||||
|                             </div> | ||||
|                         </div> | ||||
|                     </div> | ||||
|                 </foreignObject> | ||||
|                 <text x="63" y="54" fill="#262626" font-family="Helvetica" font-size="12px" text-anchor="middle"> | ||||
|                     Search | ||||
|                 </text> | ||||
|             </switch> | ||||
|         </g> | ||||
|         <g transform="translate(-0.5 -0.5)"> | ||||
|             <switch> | ||||
|                 <foreignObject pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility" style="overflow: visible; text-align: left;"> | ||||
|                     <div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe flex-start; width: 32px; height: 1px; padding-top: 20px; margin-left: 15px;"> | ||||
|                         <div data-drawio-colors="color: rgb(0, 0, 0); " style="box-sizing: border-box; font-size: 0px; text-align: left;"> | ||||
|                             <div style="display: inline-block; font-size: 20px; font-family: Helvetica; color: rgb(0, 0, 0); line-height: 1.2; pointer-events: none; white-space: normal; overflow-wrap: normal;"> | ||||
|                                 <font color="#262626"> | ||||
|                                     Title | ||||
|                                 </font> | ||||
|                             </div> | ||||
|                         </div> | ||||
|                     </div> | ||||
|                 </foreignObject> | ||||
|                 <text x="15" y="26" fill="rgb(0, 0, 0)" font-family="Helvetica" font-size="20px"> | ||||
|                     Tit... | ||||
|                 </text> | ||||
|             </switch> | ||||
|         </g> | ||||
|     </g> | ||||
|     <switch> | ||||
|         <g requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"/> | ||||
|         <a transform="translate(0,-5)" xlink:href="https://www.diagrams.net/doc/faq/svg-export-text-problems" target="_blank"> | ||||
|             <text text-anchor="middle" font-size="10px" x="50%" y="100%"> | ||||
|                 Text is not SVG - cannot display | ||||
|             </text> | ||||
|         </a> | ||||
|     </switch> | ||||
| </svg> | ||||
| After Width: | Height: | Size: 8.2 KiB | 
							
								
								
									
										169
									
								
								doc/doxygen-awesome-css/include/MyLibrary/example.hpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,169 @@ | ||||
| #pragma once | ||||
| #include <string> | ||||
|  | ||||
| namespace MyLibrary { | ||||
|  | ||||
| enum Color { red  = 1, green = 2, blue = 3 }; | ||||
|  | ||||
| /** | ||||
|  * @brief Example class to demonstrate the features of the custom CSS. | ||||
|  * | ||||
|  * @author jothepro | ||||
|  * | ||||
|  */ | ||||
| class Example { | ||||
| public: | ||||
|     /** | ||||
|      * @brief brief summary | ||||
|      * | ||||
|      * doxygen test documentation | ||||
|      * | ||||
|      * @param test this is the only parameter of this test function. It does nothing! | ||||
|      * | ||||
|      * # Supported elements | ||||
|      * | ||||
|      * These elements have been tested with the custom CSS. | ||||
|      * | ||||
|      * ## Tables | ||||
|      * | ||||
|      * <div class="tabbed"> | ||||
|      * | ||||
|      * - <b class="tab-title">Basic</b> | ||||
|      *   This theme supports normal markdown tables:<br> | ||||
|      *   | Item | Title | Description           | More                                       | | ||||
|      *   |-----:|-------|-----------------------|--------------------------------------------| | ||||
|      *   |    1 | Foo   | A placeholder         | Some lorem ipsum to make this table wider. | | ||||
|      *   |    2 | Bar   | Also a placeholder    | More lorem ipsum.                          | | ||||
|      *   |    3 | Baz   | The third placeholder | More lorem ipsum.                          | | ||||
|      * - <b class="tab-title">Centered</b> | ||||
|      *   <center> | ||||
|      *   A table can be centered with the `<center>` html tag:<br> | ||||
|      *   | Item | Title | Description           | More                                       | | ||||
|      *   |-----:|-------|-----------------------|--------------------------------------------| | ||||
|      *   |    1 | Foo   | A placeholder         | Some lorem ipsum to make this table wider. | | ||||
|      *   |    2 | Bar   | Also a placeholder    | More lorem ipsum.                          | | ||||
|      *   |    3 | Baz   | The third placeholder | More lorem ipsum.                          | | ||||
|      *   </center> | ||||
|      * - <b class="tab-title">Stretched</b> | ||||
|      *   A table wrapped in `<div class="full_width_table">` fills the full page width. | ||||
|      *   <div class="full_width_table"> | ||||
|      *   | Item | Title | Description           | More                                       | | ||||
|      *   |-----:|-------|-----------------------|--------------------------------------------| | ||||
|      *   |    1 | Foo   | A placeholder         | Some lorem ipsum to make this table wider. | | ||||
|      *   |    2 | Bar   | Also a placeholder    | More lorem ipsum.                          | | ||||
|      *   |    3 | Baz   | The third placeholder | More lorem ipsum.                          | | ||||
|      *   </div> | ||||
|      *   **Caution**: This will break the overflow scrolling support! | ||||
|      * - <b class="tab-title">Complex</b> | ||||
|      *   Complex [Doxygen tables](https://www.doxygen.nl/manual/tables.html) are also supported as seen in @ref multi_row "this example":<br> | ||||
|      *   <table> | ||||
|      *   <caption id="multi_row">Complex table</caption> | ||||
|      *   <tr><th>Column 1                      <th>Column 2        <th>Column 3 | ||||
|      *   <tr><td rowspan="2">cell row=1+2,col=1<td>cell row=1,col=2<td>cell row=1,col=3 | ||||
|      *   <tr><td rowspan="2">cell row=2+3,col=2                    <td>cell row=2,col=3 | ||||
|      *   <tr><td>cell row=3,col=1                                  <td>cell row=3,col=3 | ||||
|      *   </table> | ||||
|      * - <b class="tab-title">Overflow Scrolling</b> The table content is scrollable if the table gets too wide.<br> | ||||
|      *   | first_column | second_column | third_column | fourth_column | fifth_column | sixth_column | seventh_column | eighth_column | ninth_column | | ||||
|      *   |--------------|---------------|--------------|---------------|--------------|--------------|----------------|---------------|--------------| | ||||
|      *   | 1            | 2             | 3            | 4             | 5            | 6            | 7              | 8             | 9            | | ||||
|      * - <b class="tab-title">Images</b>A table can contain images:<br> | ||||
|      *   | Column 1                  | Column 2                                        | | ||||
|      *   |---------------------------|-------------------------------------------------| | ||||
|      *   |  | ← the image should not be inverted in dark-mode | | ||||
|      *  | ||||
|      * | ||||
|      * </div> | ||||
|      * | ||||
|      * ## Diagrams | ||||
|      * | ||||
|      * Graphviz diagrams support dark mode and can be scrolled once they get too wide: | ||||
|      * | ||||
|      * \dot Graphviz with a caption | ||||
|      *  digraph example { | ||||
|      *      node [fontsize="12"]; | ||||
|      *      rankdir="LR" | ||||
|      *      a -> b -> c -> d -> e -> f -> g -> h -> i -> j -> k; | ||||
|      *  } | ||||
|      *  \enddot | ||||
|      * | ||||
|      * ## Lists | ||||
|      * | ||||
|      * - element 1 | ||||
|      * - element 2 | ||||
|      * | ||||
|      * 1. element 1 | ||||
|      *    ``` | ||||
|      *    code in lists | ||||
|      *    ``` | ||||
|      * 2. element 2 | ||||
|      * | ||||
|      * ## Quotes | ||||
|      * | ||||
|      * > Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt  | ||||
|      * > ut labore et dolore magna aliqua. Vitae proin sagittis nisl rhoncus mattis rhoncus urna neque viverra.  | ||||
|      * > Velit sed ullamcorper morbi tincidunt ornare.  | ||||
|      * >  | ||||
|      * > Lorem ipsum dolor sit amet consectetur adipiscing elit duis. | ||||
|      * *- jothepro* | ||||
|      * | ||||
|      * ## Code block | ||||
|      * | ||||
|      * ```cpp | ||||
|      * auto x = "code within md fences"; | ||||
|      * ``` | ||||
|      * | ||||
|      * @code{.cpp} | ||||
|      * // code within @code block | ||||
|      * while(true) { | ||||
|      *    auto example = std::make_shared<Example>(5); | ||||
|      *    example->test("test"); | ||||
|      * } | ||||
|      * @endcode | ||||
|      * | ||||
|      *     // code within indented code block | ||||
|      *     auto test = std::shared_ptr<Example(5); | ||||
|      * | ||||
|      * | ||||
|      * Inline `code` elements in a text. *Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.* This also works within multiline text and does not break the `layout`. | ||||
|      * | ||||
|      * | ||||
|      * ## Special hints | ||||
|      * | ||||
|      * @warning this is a warning only for demonstration purposes | ||||
|      * | ||||
|      * @note this is a note to show that notes work. They can also include `code`: | ||||
|      * @code{.c} | ||||
|      * void this_looks_awesome(); | ||||
|      * @endcode | ||||
|      * | ||||
|      * @bug example bug | ||||
|      * | ||||
|      * @deprecated None of this will be deprecated, because it's beautiful! | ||||
|      * | ||||
|      * @invariant This is an invariant | ||||
|      * | ||||
|      * @pre This is a precondition | ||||
|      * | ||||
|      * @post This is a postcondition | ||||
|      * | ||||
|      * @todo This theme is never finished! | ||||
|      * | ||||
|      * @remark This is awesome! | ||||
|      * | ||||
|      */ | ||||
|     std::string test(const std::string& test); | ||||
|  | ||||
|     virtual int virtualfunc() = 0; | ||||
|  | ||||
|     static bool staticfunc(); | ||||
|  | ||||
|  | ||||
| }; | ||||
|  | ||||
| class SecondExample { | ||||
|     std::string foo(); | ||||
| } | ||||
|  | ||||
| } | ||||
|  | ||||
| @@ -0,0 +1,46 @@ | ||||
| #pragma once | ||||
| #include <string> | ||||
| #include "example.hpp" | ||||
| #include <iostream> | ||||
|  | ||||
| namespace MyLibrary { | ||||
|  | ||||
|     /** | ||||
|      * @brief some subclass | ||||
|      */ | ||||
|     template<typename TemplatedClass> | ||||
|     class SubclassExample : public Example { | ||||
|     public: | ||||
|  | ||||
|         /** | ||||
|          * @bug second bug | ||||
|          * @return | ||||
|          */ | ||||
|         int virtualfunc() override; | ||||
|  | ||||
|         /** | ||||
|          * @brief Template function function | ||||
|          */ | ||||
|         template <typename T> | ||||
|         std::shared_ptr<std::string> function_template_test(std::shared_ptr<T>& param); | ||||
|  | ||||
|         /** | ||||
|          * @brief Extra long function with lots of parameters and many template types. | ||||
|          * | ||||
|          * Also has a long return type. | ||||
|          * | ||||
|          * @param param1 first parameter | ||||
|          * @param param2 second parameter | ||||
|          * @param parameter3 third parameter | ||||
|          */ | ||||
|         template <typename T, typename Foo, typename Bar, typename Alice, typename Bob, typename Charlie, typename Hello, typename World> | ||||
|         std::pair<std::string, std::string> long_function_with_many_parameters(std::shared_ptr<T>& param1, std::shared_ptr<std::string>& param2, bool parameter3, Alice paramater4 Bob parameter 5) { | ||||
|             if(true) { | ||||
|                 std::cout << "this even has some code." << std::endl; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|     }; | ||||
|  | ||||
| } | ||||
|  | ||||
							
								
								
									
										1
									
								
								doc/doxygen-awesome-css/logo.drawio.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1 @@ | ||||
| <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="61px" height="74px" viewBox="-0.5 -0.5 61 74" content="<mxfile host="drawio-plugin" modified="2021-03-16T23:58:23.462Z" agent="5.0 (Macintosh; Intel Mac OS X 10_16_0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/84.0.4147.105 Safari/537.36" version="13.7.9" etag="JoeaGLJ54FcERO7YrWLQ" type="embed"><diagram id="JMB9aH8b_oZ7EWDuqJgx" name="Page-1">7VdNc5swEP01HDsjkGPDsSVJe+lMZnzoWYENaAwsI8ux6a+vCCtA4KSu62kmSS+M9LT7tB9P0uDxuDx8VaLOv2MKhRew9ODxay8Igigy3xZoCOC8AzIl0w7yB2AtfwKBjNCdTGHrGGrEQsvaBROsKki0gwmlcO+aPWDh7lqLDGbAOhHFHP0hU513aHjFBvwbyCy3O/uMVkphjQnY5iLF/QjiNx6PFaLuRuUhhqKtna1L53f7zGofmIJKn+RAcTyKYkfJUWC6sdlmCnc1mYHScDhWY3Fvzdk8Br/PzCgCsAStGmNCRJy2JDH4pIV8VMG+edS4rCcZcjMDSu+ZVP3fpwpV+rnVh5ndF5hsPP4l16VhvPbN8AErTWI0re7mMRaonpw5Y8tlHBvcsNzKwnpttVDaslZYgcXIhj3NFW56LS1bbrM44l6m4Wq5MLhxzEDfgZKmAKDWtUhklRFNgqVM7LYb0Enu8I9j9dkVC80KtgS6Lb3fGnYVgXSm/1Ez2fFu7oeTYA/CuIUWU1AILR9d/mN9pR3uUJqde7F88leOWhYLl2GLO5UAOY2FP+GxMm3c6CwNlXlKY9oompFZ3Rps59EOkuw8BoH2BTtNs8EfaZbUdYZkXQGuXhDgR9DYRBycXURj00D+UmMT2ktJLnr9B8HG0IzFcPkHYfUe3oPZqfOjMEiDs1+KEw5n9P/+/1f3f/gq1394lt7erqQ+0HVvpsPPRWc+/KHxm18=</diagram></mxfile>"><defs/><g><path d="M 13 57 L 13.01 57.01 L 15.87 50.14 L 18.37 43.14 L 20.91 36.15 L 23.67 29.25 L 26.4 22.33 Q 30 13 33.71 22.28 L 33.55 22.22 L 35.48 26.91 L 37.49 31.64 L 39.48 36.36 L 41.2 40.97 L 43.05 45.63" fill="none" stroke="#010508" stroke-opacity="0.1" stroke-width="6" stroke-linejoin="round" stroke-linecap="round" stroke-miterlimit="10" pointer-events="stroke"/><path d="M 47.51 56.77 L 47.65 56.93 L 45.43 54.91 L 43.41 53.11 L 41.43 51.35 L 39.63 49.8 L 37.48 47.86 L 37.39 47.64 L 39.79 47.17 L 41.9 45.98 L 44.24 45.37 L 46.48 44.52 L 48.62 43.4 L 48.54 43.39 L 48.58 46.09 L 48.04 48.74 L 48.04 51.43 L 47.8 54.1 L 47.51 56.77 Z Z" fill-opacity="0.1" fill="#010508" stroke="#010508" stroke-opacity="0.1" stroke-width="6" stroke-linejoin="round" stroke-linecap="round" stroke-miterlimit="10" pointer-events="all"/><path d="M 10 43 L 9.94 42.88 L 12.16 41.98 L 14.31 40.96 L 16.51 40.01 L 18.62 38.89 L 20.88 38.1 Q 30 34 40 34 L 40 33.75 L 42 33.83 L 44 33.8 L 46 33.79 L 48 34.05 L 50 34" fill="none" stroke="#010508" stroke-opacity="0.1" stroke-width="7" stroke-linejoin="round" stroke-linecap="round" stroke-miterlimit="10" pointer-events="stroke"/><path d="M 10 54 L 9.97 53.99 L 12.69 47.07 L 15.43 40.16 L 18.07 33.21 L 20.65 26.24 L 23.4 19.33 Q 27 10 30.71 19.28 L 30.66 19.26 L 32.46 23.91 L 34.55 28.66 L 36.26 33.27 L 38.35 38.03 L 40.05 42.63" fill="none" stroke="#1982d2" stroke-width="6" stroke-linejoin="round" stroke-linecap="round" stroke-miterlimit="10" pointer-events="stroke"/><path d="M 44.51 53.77 L 44.56 53.83 L 42.48 51.97 L 40.5 50.21 L 38.48 48.41 L 36.41 46.56 L 34.48 44.86 L 34.55 45.02 L 36.72 44 L 39 43.24 L 41.21 42.28 L 43.48 41.51 L 45.62 40.4 L 45.78 40.42 L 45.51 43.09 L 45.01 45.74 L 44.87 48.42 L 44.94 51.12 L 44.51 53.77 Z Z" fill="#1982d2" stroke="#1982d2" stroke-width="6" stroke-linejoin="round" stroke-linecap="round" stroke-miterlimit="10" pointer-events="all"/><path d="M 7 40 L 7.02 40.05 L 9.28 39.25 L 11.33 38 L 13.48 36.96 L 15.73 36.14 L 17.88 35.1 Q 27 31 37 31 L 37 30.79 L 39 31.11 L 41 30.85 L 43 30.78 L 45 30.89 L 47 31" fill="none" stroke="#1982d2" stroke-width="8" stroke-linejoin="round" stroke-linecap="round" stroke-miterlimit="10" pointer-events="stroke"/></g></svg> | ||||
| After Width: | Height: | Size: 3.5 KiB | 
							
								
								
									
										34
									
								
								doc/doxygen-awesome-css/package.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,34 @@ | ||||
| { | ||||
|   "name": "@jothepro/doxygen-awesome-css", | ||||
|   "version": "2.3.4", | ||||
|   "description": "Custom CSS theme for doxygen html-documentation with lots of customization parameters.", | ||||
|   "main": "", | ||||
|   "scripts": { | ||||
|     "npm-pack": "npm pack", | ||||
|     "test": "echo \"Error: no test specified\" && exit 1" | ||||
|   }, | ||||
|   "repository": { | ||||
|     "type": "git", | ||||
|     "url": "https://github.com/jothepro/doxygen-awesome-css.git" | ||||
|   }, | ||||
|   "homepage": "https://jothepro.github.io/doxygen-awesome-css/", | ||||
|   "bugs": { | ||||
|     "url": "https://github.com/jothepro/doxygen-awesome-css/issues" | ||||
|   }, | ||||
|   "keywords": [ | ||||
|     "doxygen", | ||||
|     "css", | ||||
|     "theme", | ||||
|     "awesome" | ||||
|   ], | ||||
|   "author": { | ||||
|     "name": "jothepro", | ||||
|     "url": "https://github.com/jothepro", | ||||
|     "git": "https://github.com/jothepro/doxygen-awesome-css" | ||||
|   }, | ||||
|   "license": "MIT", | ||||
|   "config": {}, | ||||
|   "dependencies": {}, | ||||
|   "devDependencies": {}, | ||||
|   "xpack": {} | ||||
| } | ||||
| @@ -36,9 +36,6 @@ XQChildModel::XQChildModel( QObject *parent ) | ||||
| void XQChildModel::addModelData( const XQNodePtr& contentRoot ) | ||||
| { | ||||
|  | ||||
|   setObjectName( contentRoot->to_string() ); | ||||
|   //qDebug() << " --- create Model Data: " << contentRoot->to_string(); | ||||
|  | ||||
|   // Die Datenbasis als shared_ptr sichern | ||||
|   _contentRoot = contentRoot; | ||||
|  | ||||
|   | ||||
| @@ -103,6 +103,7 @@ void XQMainWindow::initMainWindow() | ||||
|  | ||||
|   try | ||||
|   { | ||||
|  | ||||
|     // hand over undostack | ||||
|     _mainModel.setUndoStack(&_undoStack); | ||||
|     // hand over left side navigation tree | ||||
| @@ -110,12 +111,17 @@ void XQMainWindow::initMainWindow() | ||||
|     // #1. init the left side main tree view | ||||
|     _mainModel.initModel( c_MainModelName ); | ||||
|  | ||||
|     // 1: Wiebelbach | ||||
|     // 2: Gerbrunn | ||||
|     // 3: TBB | ||||
|  | ||||
|     // #2. load demo data | ||||
|     loadDocument( c_DocumentFileName1 ); | ||||
|     loadDocumentQML( c_DocumentFileName2 ); | ||||
|     loadDocument( c_DocumentFileName2, true ); | ||||
|     //loadDocument( c_DocumentFileName2 ); | ||||
|     //loadDocument( c_DocumentFileName3 ); | ||||
|  | ||||
|  | ||||
|     qDebug() << " --- all here: " << XQNode::s_Count; | ||||
|  | ||||
|   }   | ||||
| @@ -254,7 +260,7 @@ void XQMainWindow::onTreeViewItemClicked( const XQItem& item ) | ||||
|  | ||||
| void XQMainWindow::onTreeViewItemChanged(const XQItem& item ) | ||||
| { | ||||
|   qDebug() << " --- TREE VIEW itemChanged:" << item.text() << " : " << item.parent()->text()  << " : " << (void*)&_mainModel << " : " << (void*) sender(); | ||||
|   qDebug() << " --- TREE VIEW itemChanged: text" << item.text() << " parent: " << item.parent()->text()  << " type: " << item.itemType().text() << " : " << (void*)&_mainModel << " : " << (void*) sender(); | ||||
|   // hier müssen wir erst das projekt aktivieren | ||||
|   XQItem* xqItem = static_cast<XQItem*>(item.parent()); | ||||
|   onTreeViewItemClicked( *xqItem ); | ||||
| @@ -263,7 +269,7 @@ void XQMainWindow::onTreeViewItemChanged(const XQItem& item ) | ||||
|     int idx = _tabWidget->currentIndex(); | ||||
|     if(_documentStore.contains(idx) ) | ||||
|     { | ||||
|       qDebug() << " --- should toggle: " << item.text(); | ||||
|       qDebug() << " --- Has Document and might toggle: " << item.text(); | ||||
|       XQViewModel& childModel = *_documentStore[idx].viewModel; | ||||
|       childModel.onToggleSection(item.text()); | ||||
|     } | ||||
| @@ -297,18 +303,15 @@ void XQMainWindow::onSectionCreated( const XQModelSection& section ) | ||||
| //! SLOT, der aufgerufen wird, wenn eine section getoggelt wurde. | ||||
|  | ||||
| void XQMainWindow::onSectionToggled( const XQModelSection& section ) | ||||
| { | ||||
|   qDebug() << " --- XXX section toggled: " << section.contentType() << ":" << section.sheetRootNode()->to_string(); | ||||
| {  | ||||
|   for (int row = 0; row < _currentProjectItem->rowCount(); ++row) | ||||
|   { | ||||
|     for (int row = 0; row < _currentProjectItem->rowCount(); ++row) | ||||
|     QStandardItem* child = _currentProjectItem->child(row); | ||||
|     if (child->text() == section.contentType() ) | ||||
|     { | ||||
|       QStandardItem* child = _currentProjectItem->child(row); | ||||
|       if (child->text() == section.contentType() ) | ||||
|       { | ||||
|         bool checked = (child->checkState() == Qt::Checked); | ||||
|         child->setCheckState( checked ?  Qt::Unchecked :Qt::Checked ); | ||||
|         break; | ||||
|       } | ||||
|       bool checked = (child->checkState() == Qt::Checked); | ||||
|       child->setCheckState( checked ?  Qt::Unchecked :Qt::Checked ); | ||||
|       break; | ||||
|     } | ||||
|   } | ||||
| } | ||||
| @@ -328,6 +331,104 @@ void XQMainWindow::setChildTabByName( const QString& key ) | ||||
|   } | ||||
| } | ||||
|  | ||||
|  | ||||
| XQNodePtr XQMainWindow::createDataTree( const QString& fileName ) | ||||
| { | ||||
|   // gibts die Datei? | ||||
|   if( !QFile::exists( fileName) ) | ||||
|     throw XQException( "no such file", fileName ); | ||||
|  | ||||
|   XQNodeFactory treeLoader; | ||||
|   // xml daten laden | ||||
|   XQNodePtr rawTree = treeLoader.load_tree( qPrintable(fileName) ); | ||||
|   // versteckten root node ignorieren | ||||
|   return rawTree->first_child(); | ||||
| } | ||||
|  | ||||
|  | ||||
| XQChildModel* XQMainWindow::createChildModel( const XQNodePtr& contentRoot ) | ||||
| { | ||||
|   // Ein neues Child-Model erzeugen | ||||
|   XQChildModel* childModel = new XQChildModel(this); | ||||
|  | ||||
|   connect( childModel, SIGNAL(sectionCreated(XQModelSection)), this, SLOT(onSectionCreated(XQModelSection)) ); | ||||
|   connect( childModel, SIGNAL(sectionToggled(XQModelSection)), this, SLOT(onSectionToggled(XQModelSection)) ); | ||||
|  | ||||
|   // Den globalen undo-stack ... | ||||
|   childModel->setUndoStack(&_undoStack); | ||||
|  | ||||
|   // die Modelstruktur anlegen | ||||
|   childModel->initModel( c_ChildModelName ); | ||||
|  | ||||
|   // model inhalte laden | ||||
|   childModel->addModelData( contentRoot->first_child() ); | ||||
|   childModel->setObjectName( contentRoot->friendly_name() ); | ||||
|  | ||||
|   return childModel; | ||||
|  | ||||
| } | ||||
|  | ||||
| //! liest eine XML datei namens 'fileName' | ||||
|  | ||||
| void XQMainWindow::loadDocument( const QString& fileName, bool useQML ) | ||||
| { | ||||
|  | ||||
|   // Datenbaum laden | ||||
|   XQNodePtr contentRoot = createDataTree( fileName ); | ||||
|  | ||||
|   // Falls schon vorhanden ... | ||||
|   const QString& pID   = contentRoot->attribute(c_ProjectID); | ||||
|   int idx = _documentStore.indexOf( pID ); | ||||
|   if( idx > -1 ) | ||||
|   { | ||||
|     const XQDocument& document = _documentStore.at(idx); | ||||
|     QMessageBox::warning( this, "Load Document", QString("File: %1 already loaded.").arg( fileName ) ); | ||||
|     _mainTreeView->setCurrentIndex( document.treeItem->index() ); | ||||
|     _tabWidget->setCurrentIndex( idx ); | ||||
|     // ... wird nichts wieter unternommen | ||||
|     return; | ||||
|   } | ||||
|  | ||||
|   // 'friendly Name' ist ein Link auf ein anderes Attribute | ||||
|   // das als Namen verwendet wird. | ||||
|   const QString& fName = contentRoot->friendly_name(); | ||||
|   QString pTabTitle = QString("Project %1: %2").arg( pID, fName ); | ||||
|  | ||||
|    // neuen eintrag im übsichts-baum erzeugen | ||||
|   _currentProjectItem = _mainModel.addProjectItem( contentRoot ); | ||||
|   // Kindmodel für den Datenbaum erzeugen. | ||||
|   XQChildModel* childModel = createChildModel(contentRoot); | ||||
|  | ||||
|   _documentStore.addDocument( fileName, fName, _currentProjectItem, childModel ); | ||||
|  | ||||
|  | ||||
|   QWidget* childView{}; | ||||
|   if(useQML) | ||||
|   { | ||||
|     XQQuickWidget* quickView = new XQQuickWidget(_tabWidget); | ||||
|     //quickChild->setResizeMode(QQuickWidget::SizeViewToRootObject); | ||||
|  | ||||
|     quickView->rootContext()->setContextProperty("xtrChildModel", childModel); | ||||
|     quickView->setSource(QUrl("qrc:/xqtreeview.qml")); | ||||
|     childView = quickView; | ||||
|   } | ||||
|   else | ||||
|   { | ||||
|     // Eine neue TreeView erzeugn und im TabWidget parken. | ||||
|     XQTreeTable* treeTable = new XQTreeTable(_tabWidget); | ||||
|     // und die TreeView übergeben | ||||
|     childModel->setTreeTable(treeTable); | ||||
|     childView = treeTable; | ||||
|   } | ||||
|  | ||||
|   _tabWidget->addTab( childView, pTabTitle ); | ||||
|   _tabWidget->setCurrentWidget( childView ); | ||||
|   setWindowTitle( pTabTitle ); | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| void XQMainWindow::loadDocumentQML( const QString& fileName ) | ||||
| { | ||||
|   // gibts die Datei? | ||||
| @@ -356,74 +457,13 @@ void XQMainWindow::loadDocumentQML( const QString& fileName ) | ||||
|   //quickChild->setResizeMode(QQuickWidget::SizeViewToRootObject); | ||||
|  | ||||
|   quickChild->rootContext()->setContextProperty("xtrChildModel", childModel); | ||||
|    quickChild->setSource(QUrl("qrc:/xqtreeview.qml")); | ||||
|   quickChild->setSource(QUrl("qrc:/xqtreeview.qml")); | ||||
|   _tabWidget->addTab( quickChild, "QML:"+fName ); | ||||
|   _tabWidget->setCurrentWidget( quickChild ); | ||||
|   quickChild->setResizeMode(QQuickWidget::SizeRootObjectToView); | ||||
|  | ||||
| } | ||||
|  | ||||
| //! liest eine XML datei namens 'fileName' | ||||
|  | ||||
| void XQMainWindow::loadDocument( const QString& fileName ) | ||||
| { | ||||
|  | ||||
|   // gibts die Datei? | ||||
|   if( !QFile::exists( fileName) ) | ||||
|     throw XQException( "no such file", fileName ); | ||||
|  | ||||
|   XQNodeFactory treeLoader; | ||||
|   // xml daten laden | ||||
|   XQNodePtr rawTree = treeLoader.load_tree( qPrintable(fileName) ); | ||||
|   // versteckten root node ignorieren | ||||
|   XQNodePtr contentRoot = rawTree->first_child(); | ||||
|   // Project-ID behandeln | ||||
|   const QString& pID   = contentRoot->attribute(c_ProjectID); | ||||
|   int idx = _documentStore.indexOf( pID ); | ||||
|   if( idx > -1 ) | ||||
|   { | ||||
|     const XQDocument& document = _documentStore.at(idx); | ||||
|     QMessageBox::warning( this, "Load Document", QString("File: %1 already loaded.").arg( fileName ) ); | ||||
|     _mainTreeView->setCurrentIndex( document.treeItem->index() ); | ||||
|     _tabWidget->setCurrentIndex( idx ); | ||||
|     return; | ||||
|   } | ||||
|  | ||||
|   // 'friendly Name' ist ein Link auf ein anderes Attribute | ||||
|   // das als Namen verwendet wird. | ||||
|   const QString& fName = contentRoot->friendly_name(); | ||||
|   QString pTabTitle = QString("Project %1: %2").arg( pID, fName ); | ||||
|  | ||||
|   // Eine neue TreeView erzeugn und im TabWidget parken. | ||||
|   XQTreeTable* childTreeView = new XQTreeTable(_tabWidget); | ||||
|   _tabWidget->addTab( childTreeView, pTabTitle ); | ||||
|   _tabWidget->setCurrentWidget( childTreeView ); | ||||
|   setWindowTitle( pTabTitle ); | ||||
|  | ||||
|   // Ein neues Child-Model erzeugen | ||||
|   XQChildModel* childModel = new XQChildModel(this); | ||||
|  | ||||
|   connect( childModel, SIGNAL(sectionCreated(XQModelSection)), this, SLOT(onSectionCreated(XQModelSection)) ); | ||||
|   connect( childModel, SIGNAL(sectionToggled(XQModelSection)), this, SLOT(onSectionToggled(XQModelSection)) ); | ||||
|  | ||||
|   // Den globalen undo-stack ... | ||||
|   childModel->setUndoStack(&_undoStack); | ||||
|  | ||||
|   // und die TreeView übergeben | ||||
|   childModel->setTreeTable(childTreeView); | ||||
|  | ||||
|   // neuen eintrag im übsichts-baum erzeugen | ||||
|   _currentProjectItem = _mainModel.addProjectItem( contentRoot ); | ||||
|   _documentStore.addDocument( fileName, fName, _currentProjectItem, childModel ); | ||||
|  | ||||
|   // die Modelstruktur anlegen | ||||
|   childModel->initModel( c_ChildModelName ); | ||||
|  | ||||
|   // model inhalte laden | ||||
|   childModel->addModelData( contentRoot->first_child() ); | ||||
|  | ||||
|  | ||||
| } | ||||
|  | ||||
|  | ||||
| //! speichert ein XML unter dem 'filename' | ||||
|   | ||||
| @@ -61,15 +61,21 @@ public slots: | ||||
|  | ||||
|   void setChildTabByName( const QString& key ); | ||||
|  | ||||
|   // fixme implement | ||||
|   //void showDocument( const QString& key ){} | ||||
|   void loadDocument( const QString& fileName, bool useQML=false ); | ||||
|   void loadDocumentQML( const QString& fileName ); | ||||
|   void saveDocument( const QString& fileName ); | ||||
|  | ||||
|   static void setupWorkingDir(); | ||||
|  | ||||
|  | ||||
| protected: | ||||
|  | ||||
|   // fixme implement | ||||
|   void showDocument( const QString& key ){} | ||||
|   void loadDocument( const QString& fileName ); | ||||
|   void loadDocumentQML( const QString& fileName ); | ||||
|   void saveDocument( const QString& fileName ); | ||||
|   XQNodePtr     createDataTree( const QString& fileName ); | ||||
|   XQChildModel* createChildModel( const XQNodePtr& contentRoot ); | ||||
|  | ||||
|  | ||||
|  | ||||
|   QUndoStack      _undoStack; | ||||
|   XQDocumentStore _documentStore; | ||||
|   | ||||
| @@ -117,7 +117,7 @@ const XQModelSection& XQSectionManager::sectionByKey( const QString& sectionKey | ||||
|   if( hasValidSection( sectionKey ) ) | ||||
|     return _sections.at(sectionKey); | ||||
|  | ||||
|   throw XQException( "No section for key: ", sectionKey); | ||||
|   throw XQException( "No section for key", sectionKey); | ||||
|  | ||||
| } | ||||
|  | ||||
| @@ -137,7 +137,7 @@ const XQModelSection& XQSectionManager::sectionByRow(int itemRow ) const | ||||
|       return section; | ||||
|   } | ||||
|  | ||||
|   throw XQException( "No section for item row: ", QString::number(itemRow)); | ||||
|   throw XQException( "No section for item row", QString::number(itemRow)); | ||||
|  | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -181,8 +181,11 @@ void XQViewModel::addSection(const XQItemList& list, const XQNodePtr& sheetNode | ||||
| //! SLOT, toggled die section mit dem 'sectionKey' (hier: contentType) | ||||
|  | ||||
| void XQViewModel::onToggleSection(const QString& sectionKey ) | ||||
| {   | ||||
|   toggleSection( _sections.sectionByKey(sectionKey) ); | ||||
| { | ||||
|   qDebug() <<  " --- Model: " << this->objectName() << " should toggle: " << sectionKey << ": " << _sections.hasValidSection( sectionKey ); | ||||
|   _sections.dump(); | ||||
|   if(_sections.hasValidSection( sectionKey ) ) | ||||
|     toggleSection( _sections.sectionByKey(sectionKey) ); | ||||
| } | ||||
|  | ||||
|  | ||||
|   | ||||
| @@ -1,23 +1,22 @@ | ||||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <Components> | ||||
|     <Panel FriendlyName="@PanelName" Height="2,70" Manufacturer="JA Solar 1 XX" MaxAmpere="11" MaxVolt="67" PanelID="#1 JA 01" PanelName="JA 01 Solar T62B" WattPeak="620" Weight="12" Width="1,10"/> | ||||
|     <Panel FriendlyName="@PanelName" Height="1,70" Manufacturer="JA Solar 2" MaxAmpere="11" MaxVolt="42" PanelID="#2 JA 02" PanelName="JA 02 Solar X58C" WattPeak="440" Weight="12" Width="1,10"/> | ||||
|     <Panel FriendlyName="@PanelName" Height="2,70" Manufacturer="JA Solar 3" MaxAmpere="11" MaxVolt="67" PanelID="#3 JA 03" PanelName="JA 03 Solar T62B" WattPeak="620" Weight="12" Width="1,10"/> | ||||
|     <Panel FriendlyName="@PanelName" Height="1,70" Manufacturer="JA Solar 4" MaxAmpere="11" MaxVolt="42" PanelID="#4 JA 04" PanelName="JA 04 Solar X58C" WattPeak="440" Weight="12" Width="1,10"/> | ||||
|     <Panel FriendlyName="@PanelName" Height="1,70" Manufacturer="JA Solar 5" MaxAmpere="11" MaxVolt="42" PanelID="#5 JA 05" PanelName="JA 05 Solar X58C" WattPeak="440" Weight="12" Width="1,10"/> | ||||
|     <Panel FriendlyName="@PanelName" Height="1,70" Manufacturer="JA Solar 6" MaxAmpere="11" MaxVolt="42" PanelID="#6 JA 06" PanelName="JA 06 Solar X58C" WattPeak="440" Weight="12" Width="1,10"/> | ||||
|     <Inverter FriendlyName="@InverterName" InverterID="#1 HM600 01" InverterName="01 HM600 S2 TMax" Manufacturer="HoyMiles" MaxPowerInput="3000,00" MaxPowerInputChoice="2000;4000;6000" MaxPowerOutput="600" NumStrings="2" Weight="28"/> | ||||
|     <Inverter FriendlyName="@InverterName" InverterID="#2 HM800 02" InverterName="02 HM800 S2 TMax" Manufacturer="HoyMiles" MaxPowerInput="4000" MaxPowerInputChoice="4000;6000;8000" MaxPowerOutput="800" NumStrings="2" Weight="29"/> | ||||
|     <Inverter FriendlyName="@InverterName" InverterID="#3 HM1600 03" InverterName="03 HM1600 S4 TMax" Manufacturer="HoyMiles" MaxPowerInput="9000,00" MaxPowerInputChoice="6000;8000;10000" MaxPowerOutput="1600" NumStrings="4" Weight="32"/> | ||||
|     <Inverter FriendlyName="@InverterName" InverterID="#4 D12K 04" InverterName="04 HM600 S2 TMax" Manufacturer="Deye" MaxPowerInput="8000" MaxPowerInputChoice="6000;8000;12000" MaxPowerOutput="600" NumStrings="2" Weight="28"/> | ||||
|     <Battery BatteryID="#1 BYD 01" BatteryName="01 BYD T01 Stackable" Capacity="4500" FriendlyName="@BatteryName" Manufacturer="BYD" MaxCurrent="120" MaxVolt="48" Yield="90"> | ||||
|         <Images FrontView="image.png" InstalledView="installed.png" PackageView="package.png"/> | ||||
|         <Documents Certificate="certificate.pdf" Manual="manual.docx"/> | ||||
|     <Panel FriendlyName="@PanelName" Height="2,70" Manufacturer="Jingli Solar" MaxAmpere="11" MaxVolt="67" PanelID="Jingli 01" PanelName="Jingli 01 Solar T62B" WattPeak="620" Weight="12" Width="1,10"> | ||||
|         <AdditionalData DataItem="Image" DataValue="image.png"/> | ||||
|         <AdditionalData DataItem="Manual" DataValue="manual.docx"/> | ||||
|         <AdditionalData DataItem="Certificate" DataValue="certificate.pdf"/> | ||||
|     </Panel> | ||||
|     <Panel FriendlyName="@PanelName" Height="1,70" Manufacturer="Jingli Solar" MaxAmpere="11" MaxVolt="42" PanelID="Jingli 02" PanelName="Jingli 02 Solar X58C" WattPeak="440" Weight="12" Width="1,10"/> | ||||
|     <Panel FriendlyName="@PanelName" Height="2,70" Manufacturer="Jingli Solar" MaxAmpere="11" MaxVolt="67" PanelID="Jingli 03" PanelName="Jingli 03 Solar T62B" WattPeak="620" Weight="12" Width="1,10"/> | ||||
|     <Inverter FriendlyName="@InverterName" InverterID="HM600 01" InverterName="01 HM600 S2 TMax" Manufacturer="HoyMiles" MaxPowerInput="4000" MaxPowerInputChoice="2000;4000;6000" MaxPowerOutput="600" NumStrings="2" Weight="28"/> | ||||
|     <Inverter FriendlyName="@InverterName" InverterID="HM800 02" InverterName="02 HM800 S2 TMax" Manufacturer="HoyMiles" MaxPowerInput="4000" MaxPowerInputChoice="2000;4000;6000" MaxPowerOutput="800" NumStrings="2" Weight="29"/> | ||||
|     <Inverter FriendlyName="@InverterName" InverterID="HM1600 03" InverterName="03 HM1600 S4 TMax" Manufacturer="HoyMiles" MaxPowerInput="4000" MaxPowerInputChoice="2000;4000;6000" MaxPowerOutput="1600" NumStrings="4" Weight="32"/> | ||||
|     <Inverter FriendlyName="@InverterName" InverterID="D12K 04" InverterName="04 HM600 S2 TMax" Manufacturer="Deye" MaxPowerInput="4000" MaxPowerInputChoice="2000;4000;6000" MaxPowerOutput="600" NumStrings="2" Weight="28"/> | ||||
|     <Battery BatteryID="BYD 01" BatteryName="FIRZ!" Capacity="4500" FriendlyName="@BatteryName" Manufacturer="BYD" MaxCurrent="120" MaxVolt="48" Yield="88"> | ||||
|         <AdditionalData DataItem="Image" DataValue="image.png"/> | ||||
|         <AdditionalData DataItem="Manual" DataValue="manual.docx"/> | ||||
|         <AdditionalData DataItem="Certificate" DataValue="certificate.pdf"/> | ||||
|     </Battery> | ||||
|     <Battery BatteryID="#2 BYD 02" BatteryName="02 BYD T02 Stackable" Capacity="9000" FriendlyName="@BatteryName" Manufacturer="BYD" MaxCurrent="120" MaxVolt="48" Yield="94"/> | ||||
|     <Battery BatteryID="#3 BYD 03" BatteryName="03 BYD T01 Stackable" Capacity="4500" FriendlyName="@BatteryName" Manufacturer="BYD" MaxCurrent="120" MaxVolt="48" Yield="86"/> | ||||
|     <Battery BatteryID="#4 BYD 04" BatteryName="04 BYD T02 Stackable" Capacity="9000" FriendlyName="@BatteryName" Manufacturer="BYD" MaxCurrent="120" MaxVolt="48" Yield="91"/> | ||||
|     <Battery BatteryID="#5 GroWatt 05 G2K" BatteryName="05 BYD T01 Stackable" Capacity="4500" FriendlyName="@BatteryName" Manufacturer="GroWatt" MaxCurrent="120" MaxVolt="48" Yield="94"/> | ||||
|     <Battery BatteryID="#6 GroWatt 06 G4K" BatteryName="06 BYD T02 Stackable" Capacity="9000" FriendlyName="@BatteryName" Manufacturer="GroWatt" MaxCurrent="120" MaxVolt="48" Yield="49"/> | ||||
|     <Battery BatteryID="#7 Pyne 07 G4K" BatteryName="07 Pyne K7 Stackable" Capacity="9000" FriendlyName="@BatteryName" Manufacturer="PyNe" MaxCurrent="120" MaxVolt="48" Yield="68"/> | ||||
|     <Battery BatteryID="BYD 04" BatteryName="04 BYD T02 Stackable" Capacity="9000" FriendlyName="@BatteryName" Manufacturer="BYD" MaxCurrent="120" MaxVolt="48" Yield="32"/> | ||||
|     <Battery BatteryID="GroWatt 05 G2K" BatteryName="05 BYD T01 Stackable" Capacity="4500" FriendlyName="@BatteryName" Manufacturer="PylonTech" MaxCurrent="120" MaxVolt="48" Yield="46"/> | ||||
|     <Battery BatteryID="GroWatt 06 G4K" BatteryName="06 BYD T02 Stackable" Capacity="9000" FriendlyName="@BatteryName" Manufacturer="PylonTech" MaxCurrent="120" MaxVolt="48" Yield="94"/> | ||||
| </Components> | ||||
|   | ||||