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

    • Descripción general
    • Concepto
    • Demo de QOwnNotes
    • Markdown
    • Importar notas
    • Parámetros de la interfaz de las órdenes de terminal
    • Extensión del navegador QOwnNotes Web Companion
    • Gestor de fragmentos de órdenes de terminal
    • Aplicación web de QOwnNotes
    • QOwnNotesAPI Nextcloud App
    • Panel de relaciones de notas
    • Buscar notas
    • Atajos
    • Control de versiones de Git
  • Instalación

    • Instalación
    • Instalar en Ubuntu Linux, elementary OS y Linux Mint
    • Instalar en Microsoft Windows ™
    • Instalar en macOS ™
    • Instalar en Debian Linux
    • Instalar en openSUSE Linux
    • Instalar en Fedora Linux
    • Instalar como Snap
    • Instalar como Flatpak
    • Instalar como AppImage
    • Instalar mediante Nix
    • Instalar en Arch Linux
    • Instalar en Solus
    • Instalar en KaOS Linux
    • Instalar en CentOS Linux
    • Instalar en Raspberry Pi OS
    • Instalar en Gentoo Linux
    • Instalar en Funtoo Linux
    • Instalar en Void Linux
    • Instalar en Slackware Linux
    • Instalar en FreeBSD
    • Construir QOwnNotes
  • Editor

    • Revisión ortográfica
    • Soporte de IA
    • Formatos de hora
  • Scripting

    • Scripts de QOwnNotes
    • Métodos y objetos que proporciona QOwnNotes
    • Ganchos
    • Clases expuestas
  • Contribuir

    • Contribuir
    • Código de conducta
    • Mantenedores
    • Traducción
    • Donar
    • Patrocinadores
  • FAQ

    • ¿Cómo puedo mostrar el panel de vista previa sin el panel de edición de notas?
    • ¿Dónde puedo encontrar lo que otras personas dijeron sobre QOwnNotes?
    • ¿Por qué métricas?
  • Blog (en inglés)

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

    • QOwnNotes Changelog

Clases expuestas

Nota

Propiedades y métodos

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()
    // Devuelve la URL de la nota de Markdown para vincular a la nota con noteId
    Q_INVOKABLE QString getNoteUrlForLinkingToNoteId(int noteId)
};

Puede utilizar los métodos de Date para trabajar con fileCreated o fileLastModified.

Ejemplo

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

// renombra una nota a "nuevo nombre.md"
note.renameNoteFile("nuevo nombre");

// verifica si está permitido tener un nombre de archivo de nota diferente al del título
script.log(note.allowDifferentFileName());

NoteSubFolder

Propiedades y métodos

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();
};

Ejemplo

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

// imprimir todos los nombres de las subcarpetas
noteSubFolderQmlObj
  .fetchNoteSubFoldersByParentId(parentId)
  .forEach(function (nsf) {
    script.log(nsf.name);
  });

// obtener la subcarpeta de la nota activa
var noteSubFolder = noteSubFolderQmlObj.activeNoteSubFolder();

// imprimir la ruta completa y relativa de la subcarpeta de la nota activa
script.log(noteSubFolder.fullPath());
script.log(noteSubFolder.relativePath());

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

// iterar a través de las notas en la subcarpeta de la nota
for (var idx in noteSubFolder.notes) {
  var nota = noteSubFolder.notes[idx];
}

Etiqueta

Propiedades y métodos

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()
};

Ejemplo

// ¡No olvide usar “import QOwnNotesTypes 1.0” en la parte superior de su script!

// Obtener etiqueta "home"
var etiqueta = script.getTagByNameBreadcrumbList(["home"]);
// Obtener todas las notas etiquetadas con la etiqueta
var notas = etiqueta.notes;

// Iterar a través de las notas de la etiqueta
for (var idx in notas) {
  var nota = notas[idx];
  script.log(nota.name);
}

Puede encontrar mas ejemplos donde se usa TagApi en note-tagging-by-object.qml.

MainWindow

Propiedades y métodos

class MainWindow {
    Q_INVOKABLE void reloadTagTree();
    Q_INVOKABLE void reloadNoteSubFolderTree();
    Q_INVOKABLE void buildNotesIndexAndLoadNoteDirectoryList(
            bool forceBuild = false, bool forceLoad = false);
    Q_INVOKABLE void focusNoteTextEdit();
    // Crea una nueva subcarpeta de notas en la subcarpeta actual
    Q_INVOKABLE bool createNewNoteSubFolder(QString folderName = "");
    // Inserta HTML en la nota actual como Markdown
    // Este método también descarga imágenes remotas y transforma las URL de "data:image"
    // en imágenes almacenadas en el directorio de medios
    Q_INVOKABLE void insertHtmlAsMarkdownIntoCurrentNote(QString html);
    // Recarga la nota actual por ID
    // Esto es util cuando la ruta o el nombre de archivo de la nota actual ha cambiado
    Q_INVOKABLE void reloadCurrentNoteByNoteId();
    // Devuelve la lista de los UUID de los espacios de trabajo
    Q_INVOKABLE QStringList getWorkspaceUuidList();
    // Devuelve el UUID de un espacio de trabajo, pasando el nombre del espacio de trabajo
    Q_INVOKABLE QString getWorkspaceUuid(const QString &workspaceName);
    // Establece el espacio de trabajo actual por medio de un UUID
    Q_INVOKABLE void setCurrentWorkspace(const QString &uuid);
    // Cierra una pestaña de nota en un índice específico(devuelve verdadero si es exitoso)
    Q_INVOKABLE bool removeNoteTab(int index);
    // Devuelve una lista de IDs de las notas que están abiertas en pestañas
    Q_INVOKABLE QList<int> getNoteTabNoteIdList();
    // Salta a una etiqueta en el árbol de etiquetas
    Q_INVOKABLE bool jumpToTag(int tagId);
};

Ejemplo

// Forzar una recarga de la lista de notas
mainWindow.buildNotesIndexAndLoadNoteDirectoryList(true, true);

// Crear una nueva subcarpeta de notas "Mi carpeta estrafalaria" en la subcarpeta actual
mainWindow.createNewNoteSubFolder("Mi carpeta estrafalaria");

// Insertar HTML en la nota actual como Markdown
mainWindow.insertHtmlAsMarkdownIntoCurrentNote("<h2>mi título</h2>algo de texto");

// Establecer el espacio de trabajo "Edición" como espacio de trabajo actual
mainWindow.setCurrentWorkspace(mainWindow.getWorkspaceUuid("Edición"));

// Saltar a la etiqueta "prueba" en el árbol de etiquetas
// Hay un ejemplo en https://github.com/pbek/QOwnNotes/blob/main/docs/scripting/examples/custom-actions.qml
var etiqueta = script.getTagByNameBreadcrumbList(["prueba"]);
mainWindow.jumpToTag(etiqueta.id);

// Obtener todas las notas de las pestañas que están abiertas 
var IDnotas = mainWindow.getNoteTabNoteIdList();
IDnotas.forEach(function (IDnota){
  var nota = script.fetchNoteById(IDnota);

  // Hacer algo con la nota
});
Prev
Ganchos