Move webshortcut model to timeline
This commit is contained in:
109
src/timeline/models/webshortcutmodel.h
Normal file
109
src/timeline/models/webshortcutmodel.h
Normal file
@@ -0,0 +1,109 @@
|
||||
// SPDX-FileCopyrightText: 2021 Carl Schwan <carl@carlschwan.eu>
|
||||
// SPDX-License-Identifier: LGPL-2.0-or-later
|
||||
|
||||
#pragma once
|
||||
|
||||
#include <QAbstractListModel>
|
||||
#include <QQmlEngine>
|
||||
#include <memory>
|
||||
|
||||
struct WebShortcutModelPrivate;
|
||||
|
||||
/**
|
||||
* @class WebShortcutModel
|
||||
*
|
||||
* This class defines the model for listing web shortcuts for a specified selectedText.
|
||||
*
|
||||
* This can be used as follows in your QML code:
|
||||
*
|
||||
* ```qml
|
||||
* QQC2.Menu {
|
||||
* id: webshortcutmenu
|
||||
*
|
||||
* title: i18n("Search for '%1'", webshortcutmodel.trunkatedSearchText)
|
||||
* property bool isVisible: selectedText && selectedText.length > 0 && webshortcutmodel.enabled
|
||||
* Component.onCompleted: webshortcutmenu.parent.visible = isVisible
|
||||
* onIsVisibleChanged: webshortcutmenu.parent.visible = isVisible
|
||||
* Instantiator {
|
||||
* model: WebShortcutModel {
|
||||
* id: webshortcutmodel
|
||||
* selectedText: loadRoot.selectedText
|
||||
* onOpenUrl: Qt.openUrlExternally(url)
|
||||
* }
|
||||
* delegate: QQC2.MenuItem {
|
||||
* text: model.display
|
||||
* icon.name: model.decoration
|
||||
* onTriggered: webshortcutmodel.trigger(model.edit)
|
||||
* }
|
||||
* onObjectAdded: webshortcutmenu.insertItem(0, object)
|
||||
* }
|
||||
* QQC2.MenuSeparator {}
|
||||
* QQC2.MenuItem {
|
||||
* text: i18n("Configure Web Shortcuts…")
|
||||
* icon.name: "configure"
|
||||
* onTriggered: webshortcutmodel.configureWebShortcuts()
|
||||
* }
|
||||
* }
|
||||
* ```
|
||||
*/
|
||||
class WebShortcutModel : public QAbstractListModel
|
||||
{
|
||||
Q_OBJECT
|
||||
QML_ELEMENT
|
||||
|
||||
/**
|
||||
* @brief The text to find web shortcuts for.
|
||||
*/
|
||||
Q_PROPERTY(QString selectedText READ selectedText WRITE setSelectedText NOTIFY selectedTextChanged)
|
||||
|
||||
/**
|
||||
* @brief The selectedText elided at a set width.
|
||||
*/
|
||||
Q_PROPERTY(QString trunkatedSearchText READ trunkatedSearchText NOTIFY selectedTextChanged)
|
||||
|
||||
/**
|
||||
* @brief Whether web shortcuts are available.
|
||||
*/
|
||||
Q_PROPERTY(bool enabled READ enabled CONSTANT)
|
||||
public:
|
||||
explicit WebShortcutModel(QObject *parent = nullptr);
|
||||
~WebShortcutModel();
|
||||
|
||||
QString selectedText() const;
|
||||
void setSelectedText(const QString &selectedText);
|
||||
|
||||
QString trunkatedSearchText() const;
|
||||
|
||||
bool enabled() const;
|
||||
|
||||
/**
|
||||
* @brief Get the given role value at the given index.
|
||||
*
|
||||
* @sa QAbstractItemModel::data
|
||||
*/
|
||||
QVariant data(const QModelIndex &index, int role) const override;
|
||||
|
||||
/**
|
||||
* @brief Number of rows in the model.
|
||||
*
|
||||
* @sa QAbstractItemModel::rowCount
|
||||
*/
|
||||
int rowCount(const QModelIndex &parent) const override;
|
||||
|
||||
/**
|
||||
* @brief Trigger the openUrl signal for the given web shortcut.
|
||||
*/
|
||||
Q_INVOKABLE void trigger(const QString &data);
|
||||
|
||||
/**
|
||||
* @brief Request the menu for configuring web shortcut settings be opened.
|
||||
*/
|
||||
Q_INVOKABLE void configureWebShortcuts();
|
||||
|
||||
Q_SIGNALS:
|
||||
void selectedTextChanged();
|
||||
void openUrl(const QUrl &url);
|
||||
|
||||
private:
|
||||
std::unique_ptr<WebShortcutModelPrivate> d;
|
||||
};
|
||||
Reference in New Issue
Block a user