QOwnNotesQOwnNotes
Commencer
Installation
  • Ask question
  • Ask for feature
  • Report bug
  • Telegram Channel
  • Matrix/Element.io Room
  • Gitter Chat
  • IRC Channel
  • Mastodon
  • Twitter
  • Facebook
Faire un don
  • English
  • Deutsch
  • Italiano
  • Français
  • Español
  • فارسی
  • Nederlands
  • Magyar
  • العربية
  • Polski
  • 한국어
GitHub
Commencer
Installation
  • Ask question
  • Ask for feature
  • Report bug
  • Telegram Channel
  • Matrix/Element.io Room
  • Gitter Chat
  • IRC Channel
  • Mastodon
  • Twitter
  • Facebook
Faire un don
  • English
  • Deutsch
  • Italiano
  • Français
  • Español
  • فارسی
  • Nederlands
  • Magyar
  • العربية
  • Polski
  • 한국어
GitHub
  • Commencer

    • Aperçu
    • Concept
    • Démo QOwnNotes
    • Réduction
    • Importer des notes
    • Paramètres de l'interface de ligne de commande
    • Extension de navigateur QOwnNotes Web Companion
    • Gestionnaire de snippets en ligne de commande
    • Application Web QOwnNotes
    • App QOwnNotesAPI Nextcloud
    • Note relations panel
    • Recherche de notes
    • Raccourcis
    • Contrôle de version avec git
  • Installation

    • Installation
    • Installer sur Ubuntu Linux, elementary OS et Linux Mint
    • Installer sur Microsoft Windows™
    • Installer sur macOS™
    • Installer sur Debian Linux
    • Installer sur openSUSE Linux
    • Installer sur Fedora Linux
    • Installer depuis Snap
    • Installer en tant que Flatpak
    • Installer en tant qu'AppImage
    • Install via Nix
    • Installer sur Arch Linux
    • Installer sur Solus
    • Installer sur KaOS Linux
    • Installer sur CentOS Linux
    • Installer sur Raspberry Pi OS
    • Installer sur Gentoo Linux
    • Installer sur Funtoo Linux
    • Installer sur Void Linux
    • Installer sur Slackware Linux
    • Installer sur FreeBSD
    • Compiler QOwnNotes
  • Éditeur

    • Vérification orthographique
    • AI support
    • Formats d'heure
  • Scripting

    • QOwnNotes Scriptage
    • Méthodes et objets fournis par QOwnNotes
    • Crochets
    • Classes exposées
  • Contribuer

    • Être impliqué
    • Code de Conduite
    • Mainteneurs
    • Traduction
    • Faire un don
    • Les sponsors
  • FAQ

    • Comment puis-je simplement afficher le panneau d'aperçu sans le panneau d'édition des notes?
    • Where can I find what other people said about QOwnNotes?
    • Pourquoi des statistiques d'utilisation ?
  • Blog (en anglais)

    • /fr/blog/
    • /fr/blog/2025-07-22-Universal-binary-for-macOS.html
    • /fr/blog/2025-03-14-Note-relations-panel.html
    • /fr/blog/2024-05-17-AI-support-was-added-to-QOwnNotes.html
    • /fr/blog/2023-07-12-Source-Archive-switched-from-TuxFamily-to-GitHub-Releases.html
    • /fr/blog/2023-06-17-Nextcloud-Deck-integration-in-QOwnNotes.html
    • /fr/blog/2023-06-17-QOwnNotes-UI-End2End-Tests-with-the-help-of-NixOS.html
    • /fr/blog/2023-02-03-Test-Qt6-version-of-QOwnNotes-from-a-new-PPA-for-Ubuntu-Linux.html
    • /fr/blog/2023-01-29-Evernote-import-for-huge-files.html
    • /fr/blog/2022-12-06-Happy-1000th-release-of-QOwnNotes.html
    • /fr/blog/2022-10-15-Polish-website-translation.html
    • /fr/blog/2022-07-28-Working-with-multiple-notes.html
    • /fr/blog/2021-11-23-QOwnNotes-command-line-snippet-manager.html
    • /fr/blog/2021-11-15-Nextcloud-note-versions.html
    • /fr/blog/2021-11-11-Manage-orphaned-image-files-and-attachments.html
    • /fr/blog/2021-10-25-Linking-of-note-headings.html
    • /fr/blog/2021-08-31-Tor-Hidden-Service-Webpage.html
    • /fr/blog/2021-08-25-Use-workspaces-to-manage-different-kayouts-of-the-user-interface.html
    • /fr/blog/2021-08-25-Auto-complete-in-note-editor.html
    • /fr/blog/2021-08-22-Open-links-in-the-note-editor.html
    • /fr/blog/2021-08-21-Solve-simple-equations-in-the-note-editor.html
    • /fr/blog/2021-08-21-Auto-format-markdown-tables.html
    • /fr/blog/2021-08-20-QOwnNotes-Mastodon-page.html
    • /fr/blog/2021-08-20-Repository-for-Debian-11.html
    • /fr/blog/2021-07-18-Joplin-import.html
    • /fr/blog/2021-05-02-Send-photos-from-your-mobile-phone-to-QOwnNotes-on-the-desktop.html
    • /fr/blog/2021-01-28-Four-new-languages-added-to-the-website.html
    • /fr/blog/2021-01-16-QOwnNotes-Demo.html
    • /fr/blog/2020-11-10-Markdown-explanation.html
    • /fr/blog/2020-11-10-Webpage-translation.html
    • /fr/blog/2020-11-08-QOwnNotes-for-Ubuntu-21.04-Hirsute-Hippo.html
    • /fr/blog/2020-10-27-QOwnNotes-for-Fedora-33.html
    • /fr/blog/2020-10-26-Release-and-blog-posting-automation.html
    • /fr/blog/2020-10-26-Legacy-update-service-up-again.html
    • /fr/blog/2020-10-23-RSS-Feeds-are-back-in-place.html
    • /fr/blog/2019-08-12-Time-Flies-Podcast-episode-with-interview-about-QOwnNotes.html
    • /fr/blog/2019-01-16-Bookmark-management-with-QOwnNotes-and-Web-Companion-browser-extension.html
    • /fr/blog/2019-01-09-Firefox-extension-on-Firefox-Add-ons-page.html
    • /fr/blog/2018-12-31-Chrome-extension-in-Chrome-Web-Store.html
    • /fr/blog/2018-12-27-QOwnNotes-Web-Companion-Chrome-extension.html
    • /fr/blog/2018-12-23-500th-release-of-QOwnNotes.html
    • /fr/blog/2018-10-05-QOwnNotes-Telegram-Group.html
    • /fr/blog/2018-08-07-Vim-mode.html
    • /fr/blog/2018-03-29-QOwnNotes-for-openSUSE-Leap-15-SUSE-Linux-Enterprise-15-and-SUSE-Linux-Enterprise-12-SP3.html
    • /fr/blog/2018-01-11-QOwnNotes-featured-on-LINUX-Unplugged-podcast-and-by-Ubuntu.html
    • /fr/blog/2017-12-12-Interview-for-ownCloud.html
    • /fr/blog/2017-11-24-QOwnNotes-for-Fedora-27.html
    • /fr/blog/2017-10-01-QOwnNotes-reviewed-in-German-magazine-c't.html
    • /fr/blog/2017-07-05-QOwnNotesAPI-in-the-ownCloud-Marketplace.html
    • /fr/blog/2017-07-03-QOwnNotes-as-AppImage.html
    • /fr/blog/2017-06-26-QOwnNotes-for-Debian-9.0-Fedora-26-and-openSUSE-Leap-42.3.html
    • /fr/blog/2017-05-19-Script-repository-and-script-settings-variables.html
    • /fr/blog/2016-12-20-Fedora-25-release-and-new-documentation-page.html
    • /fr/blog/2016-11-23-Solus-package-for-QOwnNotes.html
    • /fr/blog/2016-11-05-Automatic-updates-in-Windows-and-macOS.html
    • /fr/blog/2016-10-02-Note-encryption-with-keybase.io-or-directly-with-PGP.html
    • /fr/blog/2016-09-24-Evernote-import.html
    • /fr/blog/2016-09-18-Portable-mode.html
    • /fr/blog/2016-09-05-QOwnNotes-on-webupd8.org.html
    • /fr/blog/2016-07-12-QOwnNotes-featured-on-the-Linux-Voice-Podcast.html
    • /fr/blog/2016-07-12-QOwnNotes-snap.html
    • /fr/blog/2016-07-11-QOwnNotes-review-in-British-magazine-Linux-Format.html
    • /fr/blog/2016-06-27-QOwnNotes-Slackware-Linux-Repository.html
    • /fr/blog/2016-06-22-QOwnNotes-review.html
    • /fr/blog/2016-05-25-QOwnNotes-IRC.html
    • /fr/blog/2016-05-13-QOwnNotes-now-has-scripting-support.html
    • /fr/blog/2016-03-28-QOwnNotes-is-the-Desktop-App-Pick-on-the-Linux-Action-Show.html
    • /fr/blog/2016-03-25-QOwnNotes-got-featured-in-Linux-Voice-25.html
    • /fr/blog/2016-03-01-QOwnNotes-Gentoo-Linux-Overlay.html
    • /fr/blog/2016-02-26-Translate-QOwnNotes-on-Crowdin.html
    • /fr/blog/2016-02-14-QOwnNotes-1.0-out-now-in-6-languages-and-with-Freedesktop-theme-icons-support.html
    • /fr/blog/2016-01-31-QOwnNotes-software-repository-for-Debian-Linux.html
    • /fr/blog/2016-01-30-QOwnNotes-package-on-the-Arch-User-Repository.html
    • /fr/blog/2016-01-27-QOwnNotes-software-repository-for-Arch-Linux.html
    • /fr/blog/2016-01-26-Webpage-redesign.html
    • /fr/blog/2016-01-13-Qt-widget-QMarkdownTextEdit-now-a-separate-project-for-developer's-pleasure.html
    • /fr/blog/2016-01-09-New-release-version-RSS-feed.html
    • /fr/blog/2016-01-07-New-Linux-software-repositories-and-todo-list-support.html
    • /fr/blog/2015-11-04-QOwnNotes-on-Linux-Unplugged.html
    • /fr/blog/2015-07-27-Build-and-release-systems-for-QOwnNotes-for-Linux-Mac-OS-X-and-Windows.html
    • /fr/blog/2015-03-23-Links-to-other-notes-or-files-are-now-possible-in-QOwnNotes.html
  • Changelog (en anglais)

    • QOwnNotes Changelog

Classes exposées

Note

Propriétés et méthodes

class NoteApi {
    Q_PROPERTY(int id)
    Q_PROPERTY(QString name)
    Q_PROPERTY(QString fileName)
    Q_PROPERTY(QString fullNoteFilePath)
    Q_PROPERTY(QString fullNoteFileDirPath)
    Q_PROPERTY(QString relativeNoteFileDirPath)
    Q_PROPERTY(int noteSubFolderId)
    Q_PROPERTY(QString noteText)
    Q_PROPERTY(QString decryptedNoteText)
    Q_PROPERTY(bool hasDirtyData)
    Q_PROPERTY(QQmlListProperty<TagApi> tags)
    Q_PROPERTY(QDateTime fileCreated)
    Q_PROPERTY(QDateTime fileLastModified)
    Q_INVOKABLE QStringList tagNames()
    Q_INVOKABLE bool addTag(QString tagName)
    Q_INVOKABLE bool removeTag(QString tagName)
    Q_INVOKABLE bool renameNoteFile(QString newName)
    Q_INVOKABLE QString toMarkdownHtml(bool forExport = true)
    Q_INVOKABLE QString getFileURLFromFileName(QString localFileName)
    Q_INVOKABLE bool allowDifferentFileName()
    // Returns the Markdown note url for linking to the note with noteId
    Q_INVOKABLE QString getNoteUrlForLinkingToNoteId(int noteId)
};

Vous pouvez utiliser les méthodes de Date pour travailler avec fileCreated ou fileLastModified.

Exemple

script.log(note.fileCreated.toISOString());
script.log(note.fileLastModified.getFullYear());

// renomme une note en tant que "nouveau nom.md"
note.renameNoteFile("nouveau nom");

// vérifie si il est permis d'avoir un nom de fichier de note différent du titre
script.log(note.allowDifferentFileName());

NoteSubFolder

Propriétés et méthodes

class NoteSubFolderApi {
    Q_PROPERTY(int id)
    Q_PROPERTY(QString name)
    Q_PROPERTY(QQmlListProperty<NoteApi> notes)
    Q_INVOKABLE static NoteSubFolderApi *fetchNoteSubFolderById(int id);
    Q_INVOKABLE static NoteSubFolderApi *activeNoteSubFolder();
    Q_INVOKABLE static QList<QObject*> fetchNoteSubFoldersByParentId(int parentId);
    Q_INVOKABLE QString relativePath();
    Q_INVOKABLE QString fullPath();
};

Exemple

var noteSubFolderQmlObj = Qt.createQmlObject(
  "import QOwnNotesTypes 1.0; NoteSubFolder{}",
  mainWindow,
  "noteSubFolder",
);

// print all subfolder names
noteSubFolderQmlObj
  .fetchNoteSubFoldersByParentId(parentId)
  .forEach(function (nsf) {
    script.log(nsf.name);
  });

// get the active note subfolder
var noteSubFolder = noteSubFolderQmlObj.activeNoteSubFolder();

// print the full and relative path of the active note subfolder
script.log(noteSubFolder.fullPath());
script.log(noteSubFolder.relativePath());

script.log(noteSubFolder.id);
script.log(noteSubFolder.name);

// iterate through notes in note subfolder
for (var idx in noteSubFolder.notes) {
  var note = noteSubFolder.notes[idx];
}

Tag

Propriétés et méthodes

class TagApi {
    Q_PROPERTY(int id)
    Q_PROPERTY(QString name)
    Q_PROPERTY(int parentId)
    Q_PROPERTY(QQmlListProperty<NoteApi> notes)
    Q_INVOKABLE TagApi fetchByName(const QString &name, int parentId = 0)
    Q_INVOKABLE QStringList getParentTagNames()
};

Exemple

// Noubliez pas d'utiliser "import QOwnNotesTypes 1.0" en tête de votre script !

// Fetch tag "home"
var tag = script.getTagByNameBreadcrumbList(["home"]);
// Fetch all notes tagged with the tag
var notes = tag.notes;

// Iterate through notes of the tag
for (var idx in notes) {
  var note = notes[idx];
  script.log(note.name);
}

Vous trouverez ici d'autres exemples dans lesquels TagApi est utilisé : note-tagging-by-object.qml.

MainWindow

Propriétés et méthodes

class MainWindow {
    Q_INVOKABLE void reloadTagTree();
    Q_INVOKABLE void reloadNoteSubFolderTree();
    Q_INVOKABLE void buildNotesIndexAndLoadNoteDirectoryList(
            bool forceBuild = false, bool forceLoad = false);
    Q_INVOKABLE void focusNoteTextEdit();
    // Créer un nouveau sous-dossier de notes dans le sous-dossier courant
    Q_INVOKABLE bool createNewNoteSubFolder(QString folderName = "");
    // Insère le HTML dans la note courante au format MarkDown
    // Cette méthode télécharge également les images distantes et transforme les URL "data:image"
    // en images stockées localement dans le dossier media
    Q_INVOKABLE void insertHtmlAsMarkdownIntoCurrentNote(QString html);
    // Re-charge la note courante, par id
    // Ceci est utile quand le chemin ou le nom de fichier de la note courante ont changé
    Q_INVOKABLE void reloadCurrentNoteByNoteId();
    // Retourne la liste des UUID des espaces de travail
    Q_INVOKABLE QStringList getWorkspaceUuidList();
    // Retourne l'UUID correspondant au nom de l'espace de travail entré
    Q_INVOKABLE QString getWorkspaceUuid(const QString &workspaceName);
    // Définit l'espace de travail courant par son UUID
    Q_INVOKABLE void setCurrentWorkspace(const QString &uuid);
    // Ferme un onglet de note sur un index spécifique (retourne true en cas de succès)
    Q_INVOKABLE bool removeNoteTab(int index);
    // Saute à une étiquette dans l'arbre des étiquettes
    Q_INVOKABLE bool jumpToTag(int tagId);
};

Exemple

// Force a reload of the note list
mainWindow.buildNotesIndexAndLoadNoteDirectoryList(true, true);

// Creates a new note subfolder "My fancy folder" in the current subfolder
mainWindow.createNewNoteSubFolder("My fancy folder");

// Inserts html in the current note as markdown
mainWindow.insertHtmlAsMarkdownIntoCurrentNote("<h2>my headline
some text");

// Set 'Edit' workspace as current workspace
mainWindow.setCurrentWorkspace(mainWindow.getWorkspaceUuid("Edit"));

// Jump to the tag "test" in the tag tree
// There is an example in https://github.com/pbek/QOwnNotes/blob/main/docs/scripting/examples/custom-actions.qml
var tag = script.getTagByNameBreadcrumbList(["test"]);
mainWindow.jumpToTag(tag.id);

// Get all notes that are opened in tabs
var noteIds = mainWindow.getNoteTabNoteIdList();
noteIds.forEach(function (noteId) {
  var note = script.fetchNoteById(noteId);

  // do something with the note
});
Help us improve this page!
Prev
Crochets