Passer au contenu principal

Intégrer des fichiers supplémentaires

Vous devrez peut-être inclure des fichiers supplémentaires dans votre paquet d'application qui ne font pas partie de votre interface (votre distDir) directement ou qui sont trop gros pour être inclus dans le binaire. Nous appelons ces fichiers ressources.

Pour regrouper les fichiers de votre choix, vous pouvez ajouter la propriété resources au bundle tauri > dans votre fichier tauri.conf.json.

En savoir plus sur la configuration de tauri.conf.json ici.

resources attend une liste de chaînes de caractères ciblant des fichiers avec des chemins absolus ou relatifs. Il supporte les motifs glob au cas où vous auriez besoin d'inclure plusieurs fichiers à partir d'un répertoire.

Voici un exemple pour illustrer la configuration. Ce n'est pas un fichier tauri.conf.json complet :

tauri.conf.json
{
"tauri": {
"bundle": {
"resources": [
"/absolute/path/to/textfile.txt",
"relative/path/to/jsonfile.json",
"resources/*"
]
},
"allowlist": {
"fs": {
"scope": ["$RESOURCE/*"]
}
}
}
}
note

Les chemins et chemins absolus contenant les composants parents (../) ne peuvent être autorisés que via "$RESOURCE/*". Les chemins relatifs tels que "path/to/file.txt" peuvent être autorisés explicitement via "$RESOURCE/path/to/file.txt".

Accès aux fichiers en JavaScript

Dans cet exemple, nous voulons regrouper d'autres fichiers json i18n qui ressemblent à ceci :

de.json
{
"hello": "Guten Tag!",
"bye": "Auf Wiedersehen!"
}

Dans ce cas, nous stockons ces fichiers dans un répertoire lang à côté du tauri.conf.json. Pour cela, nous ajoutons "lang/*" à ressources et $RESOURCE/lang/* à la portée des fs comme indiqué ci-dessus.

Notez que vous devez configurer la liste d'autorisations pour activer path > all et les fs APIs dont vous avez besoin, dans cet exemple fs > readTextFile.

import { resolveResource } from '@tauri-apps/api/path'
// ou `window.__TAURI__.path.resolveResource`
import { readTextFile } from '@tauri-apps/api/fs'
// ou window.__TAURI__.fs.readTextFile`

// `lang/de.json` est la valeur spécifier dans `tauri.conf.json > tauri > bundle > resources`
const resourcePath = await resolveResource('lang/de.json')
const langDe = JSON.parse(await readTextFile(resourcePath))

console.log(langDe.hello) // 'Guten Tag! ' est affiché dans la console de développement

Accès aux fichiers dans Rust

Ceci est basé sur l'exemple ci-dessus. On the Rust side, you need an instance of the PathResolver which you can get from App and AppHandle:

tauri::Builder::default()
.setup(|app| {
let resource_path = app.path_resolver()
.resolve_resource("lang/de.json")
.expect("failed to resolve resource");

let file = std::fs::File::open(&resource_path).unwrap();
let lang_de: serde_json::Value = serde_json::from_reader(file).unwrap();

println!("{}", lang_de.get("hello").unwrap()); // Affiche 'Guten Tag!' dans le terminal

Ok(())
})
#[tauri::command]
fn hello(handle: tauri::AppHandle) -> String {
let resource_path = handle.path_resolver()
.resolve_resource("lang/de.json")
.expect("failed to resolve resource");

let file = std::fs::File::open(&resource_path).unwrap();
let lang_de: serde_json::Value = serde_json::from_reader(file).unwrap();

lang_de.get("hello").unwrap()
}