mirror of
https://github.com/tauri-apps/plugins-workspace.git
synced 2026-06-02 13:41:49 +02:00
22991af9f4
Co-authored-by: Amr Bashir <amr.bashir2015@gmail.com>
103 lines
2.1 KiB
TypeScript
103 lines
2.1 KiB
TypeScript
// Copyright 2019-2023 Tauri Programme within The Commons Conservancy
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
/**
|
|
* Get application metadata.
|
|
*
|
|
* The APIs must be added to [`tauri.allowlist.app`](https://tauri.app/v1/api/config/#allowlistconfig.app) in `tauri.conf.json`:
|
|
* ```json
|
|
* {
|
|
* "tauri": {
|
|
* "allowlist": {
|
|
* "app": {
|
|
* "all": true, // enable all app APIs
|
|
* "show": true,
|
|
* "hide": true
|
|
* }
|
|
* }
|
|
* }
|
|
* }
|
|
* ```
|
|
* It is recommended to allowlist only the APIs you use for optimal bundle size and security.
|
|
*
|
|
* @module
|
|
*/
|
|
|
|
import { invoke } from "@tauri-apps/api/tauri";
|
|
|
|
/**
|
|
* Gets the application version.
|
|
* @example
|
|
* ```typescript
|
|
* import { getVersion } from '@tauri-apps/plugin-app';
|
|
* const appVersion = await getVersion();
|
|
* ```
|
|
*
|
|
* @since 1.0.0
|
|
*/
|
|
async function getVersion(): Promise<string> {
|
|
return invoke("plugin:app|version");
|
|
}
|
|
|
|
/**
|
|
* Gets the application name.
|
|
* @example
|
|
* ```typescript
|
|
* import { getName } from '@tauri-apps/plugin-app';
|
|
* const appName = await getName();
|
|
* ```
|
|
*
|
|
* @since 1.0.0
|
|
*/
|
|
async function getName(): Promise<string> {
|
|
return invoke("plugin:app|name");
|
|
}
|
|
|
|
/**
|
|
* Gets the Tauri version.
|
|
*
|
|
* @example
|
|
* ```typescript
|
|
* import { getTauriVersion } from '@tauri-apps/plugin-app';
|
|
* const tauriVersion = await getTauriVersion();
|
|
* ```
|
|
*
|
|
* @since 1.0.0
|
|
*/
|
|
async function getTauriVersion(): Promise<string> {
|
|
return invoke("plugin:app|tauri_version");
|
|
}
|
|
|
|
/**
|
|
* Shows the application on macOS. This function does not automatically focus any specific app window.
|
|
*
|
|
* @example
|
|
* ```typescript
|
|
* import { show } from '@tauri-apps/plugin-app';
|
|
* await show();
|
|
* ```
|
|
*
|
|
* @since 1.2.0
|
|
*/
|
|
async function show(): Promise<void> {
|
|
return invoke("plugin:app|show");
|
|
}
|
|
|
|
/**
|
|
* Hides the application on macOS.
|
|
*
|
|
* @example
|
|
* ```typescript
|
|
* import { hide } from '@tauri-apps/plugin-app';
|
|
* await hide();
|
|
* ```
|
|
*
|
|
* @since 1.2.0
|
|
*/
|
|
async function hide(): Promise<void> {
|
|
return invoke("plugin:app|hide");
|
|
}
|
|
|
|
export { getName, getVersion, getTauriVersion, show, hide };
|