AboutDialog

class AboutDialog(pointer: <Error class: unknown class><<Error class: unknown class>>) : Dialog

A dialog showing information about the application.

about-dialog

an about dialog is typically opened when the user activates the About … item in the application's primary menu. All parts of the dialog are optional.

Main page

AdwAboutDialog prominently displays the application's icon, name, developer name and version. They can be set with the property@AboutDialog:application-icon, property@AboutDialog:application-name, property@AboutDialog:developer-name and property@AboutDialog:version respectively.

What's New

AdwAboutDialog provides a way for applications to display their release notes, set with the property@AboutDialog:release-notes property.

Release notes are formatted the same way as AppStream descriptions.

The supported formatting options are:

  • Paragraph (<p>)

  • Ordered list (<ol>), with list items (<li>)

  • Unordered list (<ul>), with list items (<li>)

Within paragraphs and list items, emphasis (<em>) and inline code (<code>) text styles are supported. The emphasis is rendered in italic, while inline code is shown in a monospaced font.

Any text outside paragraphs or list items is ignored.

Nested lists are not supported.

Only one version can be shown at a time. By default, the displayed version number matches property@AboutDialog:version. Use property@AboutDialog:release-notes-version to override it.

Details

The Details page displays the application comments and links.

The comments can be set with the property@AboutDialog:comments property. Unlike property@Gtk.AboutDialog:comments, this string can be long and detailed. It can also contain links and Pango markup.

To set the application website, use property@AboutDialog:website. To add extra links below the website, use method@AboutDialog.add_link.

If the Details page doesn't have any other content besides website, the website will be displayed on the main page instead.

Troubleshooting

AdwAboutDialog displays the following two links on the main page:

  • Support Questions, set with the property@AboutDialog:support-url property,

  • Report an Issue, set with the property@AboutDialog:issue-url property.

Additionally, applications can provide debugging information. It will be shown separately on the Troubleshooting page. Use the property@AboutDialog:debug-info property to specify it.

It's intended to be attached to issue reports when reporting issues against the application. As such, it cannot contain markup or links.

AdwAboutDialog provides a quick way to save debug information to a file. When saving, property@AboutDialog:debug-info-filename would be used as the suggested filename.

Credits and Acknowledgements

The Credits page has the following default sections:

  • Developers, set with the property@AboutDialog:developers property,

  • Designers, set with the property@AboutDialog:designers property,

  • Artists, set with the property@AboutDialog:artists property,

  • Documenters, set with the property@AboutDialog:documenters property,

  • Translators, set with the property@AboutDialog:translator-credits property.

When setting translator credits, use the strings "translator-credits" or "translator_credits" and mark them as translatable.

The default sections that don't contain any names won't be displayed.

The Credits page can also contain an arbitrary number of extra sections below the default ones. Use method@AboutDialog.add_credit_section to add them.

The Acknowledgements page can be used to acknowledge additional people and organizations for their non-development contributions. Use method@AboutDialog.add_acknowledgement_section to add sections to it. For example, it can be used to list backers in a crowdfunded project or to give special thanks.

Each of the people or organizations can have an email address or a website specified. To add a email address, use a string like Edgar Allan Poe <edgar@poe.com>. To specify a website with a title, use a string like The GNOME Project https://www.gnome.org:

about-dialog-credits

Legal

The Legal page displays the copyright and licensing information for the application and other modules.

The copyright string is set with the property@AboutDialog:copyright property and should be a short string of one or two lines, for example: © 2022 Example.

Licensing information can be quickly set from a list of known licenses with the property@AboutDialog:license-type property. If the application's license is not in the list, property@AboutDialog:license can be used instead.

To add information about other modules, such as application dependencies or data, use method@AboutDialog.add_legal_section.

Constructing

To make constructing an AdwAboutDialog as convenient as possible, you can use the function func@show_about_dialog which constructs and shows a dialog.

static void
show_about (GtkApplication *app)
{
const char *developers[] = {
"Angela Avery",
NULL
};

const char *designers[] = {
"GNOME Design Team",
NULL
};

adw_show_about_dialog (GTK_WIDGET (gtk_application_get_active_window (app)),
"application-name", _("Example"),
"application-icon", "org.example.App",
"version", "1.2.3",
"copyright", "© 2022 Angela Avery",
"issue-url", "https://gitlab.gnome.org/example/example/-/issues/",
"license-type", GTK_LICENSE_GPL_3_0,
"developers", developers,
"designers", designers,
"translator-credits", _("translator-credits"),
NULL);
}

CSS nodes

AdwAboutDialog has a main CSS node with the name dialog and the style class .about.

Since

1.5

Constructors

Link copied to clipboard
constructor()

Creates a new AdwAboutDialog.

constructor(resourcePath: String, releaseNotesVersion: String? = null)

Creates a new AdwAboutDialog using AppStream metadata.

constructor(pointer: <Error class: unknown class><<Error class: unknown class>>)

Types

Link copied to clipboard
object Companion

Properties

Link copied to clipboard
val adwAboutDialogPointer: <Error class: unknown class><<Error class: unknown class>>
Link copied to clipboard
val adwDialogPointer: <Error class: unknown class><<Error class: unknown class>>
Link copied to clipboard

The name of the application icon.

Link copied to clipboard

The name of the application.

Link copied to clipboard

The list of artists of the application.

Link copied to clipboard
open var canClose: Boolean

Whether the dialog can be closed.

Link copied to clipboard
open var child: <Error class: unknown class>?

The child widget of the AdwDialog.

Link copied to clipboard

The comments about the application.

Link copied to clipboard
open var contentHeight: <Error class: unknown class>

The height of the dialog's contents.

Link copied to clipboard
open var contentWidth: <Error class: unknown class>

The width of the dialog's contents.

Link copied to clipboard

The copyright information.

Link copied to clipboard

The current breakpoint.

Link copied to clipboard

The debug information.

Link copied to clipboard

The debug information filename.

Link copied to clipboard
open var defaultWidget: <Error class: unknown class>?

The default widget.

Link copied to clipboard

The list of designers of the application.

Link copied to clipboard

The developer name.

Link copied to clipboard

The list of developers of the application.

Link copied to clipboard

The list of documenters of the application.

Link copied to clipboard
open var focusWidget: <Error class: unknown class>?

The focus widget.

Link copied to clipboard

Whether to size content automatically.

Link copied to clipboard
open override val gtkAccessiblePointer: <Error class: unknown class><<Error class: unknown class>>
Link copied to clipboard
open override val gtkBuildablePointer: <Error class: unknown class><<Error class: unknown class>>
Link copied to clipboard
open override val gtkConstraintTargetPointer: <Error class: unknown class><<Error class: unknown class>>
Link copied to clipboard

The URL for the application's issue tracker.

Link copied to clipboard

The license text.

Link copied to clipboard
var licenseType: <Error class: unknown class>

The license type.

Link copied to clipboard

The dialog's presentation mode.

Link copied to clipboard

The release notes of the application.

Link copied to clipboard

The version described by the application's release notes.

Link copied to clipboard

The URL of the application's support page.

Link copied to clipboard
open var title: String

The title of the dialog.

Link copied to clipboard

The translator credits string.

Link copied to clipboard

The version of the application.

Link copied to clipboard

The URL of the application's website.

Functions

Link copied to clipboard
fun addAcknowledgementSection(name: String? = null, people: List<String>)

Adds a section to the Acknowledgements page.

Link copied to clipboard
open fun addBreakpoint(breakpoint: Breakpoint)

Adds @breakpoint to @self.

Link copied to clipboard
fun addCreditSection(name: String? = null, people: List<String>)

Adds an extra section to the Credits page.

Link copied to clipboard
fun addLegalSection(title: String, copyright: String? = null, licenseType: <Error class: unknown class>, license: String? = null)

Adds an extra section to the Legal page.

Link copied to clipboard
fun addLink(title: String, url: String)

Adds an extra link to the Details page.

Link copied to clipboard
open fun close(): Boolean

Attempts to close @self.

Link copied to clipboard
fun connectActivateLink(connectFlags: <Error class: unknown class> = ConnectFlags(0u), handler: (uri: String) -> Boolean): <Error class: unknown class>

Emitted when a URL is activated.

Link copied to clipboard
fun connectCloseAttempt(connectFlags: <Error class: unknown class> = ConnectFlags(0u), handler: () -> Unit): <Error class: unknown class>

Emitted when the close button or shortcut is used, or method@Dialog.close is called while property@Dialog:can-close is set to FALSE.

Link copied to clipboard
fun connectClosed(connectFlags: <Error class: unknown class> = ConnectFlags(0u), handler: () -> Unit): <Error class: unknown class>

Emitted when the dialog is successfully closed.

Link copied to clipboard
open fun forceClose()

Closes @self.

Link copied to clipboard
open fun present(parent: <Error class: unknown class>? = null)

Presents @self within @parent's window.