harbour-nextcloudnotes/qml/pages/NotePage.qml
2018-11-26 17:21:33 +01:00

150 lines
5.5 KiB
QML

import QtQuick 2.0
import Sailfish.Silica 1.0
Dialog {
id: noteDialog
function reloadContent() {
dialogHeader.title = account.model.get(noteIndex).title
contentLabel.plainText = account.model.get(noteIndex).content
contentLabel.parse()
}
acceptDestination: Qt.resolvedUrl("EditPage.qml")
acceptDestinationProperties: { account: account; noteIndex: noteIndex }
Component.onCompleted: acceptDestinationProperties = { account: account, noteIndex: noteIndex }
onStatusChanged: {
if (status === PageStatus.Active) {
account.getNote(account.model.get(noteIndex).id)
reloadContent()
}
}
Connections {
target: account/*.model.get(noteIndex)
onTitleChanged: {
console.log("Title changed")
dialogHeader.title = account.model.get(noteIndex).title
}
onContentChanged: {
console.log("Content changed")
contentLabel.plainText = account.model.get(noteIndex).content
contentLabel.parse()
}*/
onBusyChanged: {
if (account.busy === false) {
reloadContent()
}
}
}
property var account
property int noteIndex
property var markdown: [
{ regex: new RegExp(/^#\s(.*)$/gm), replace: '<h1>$1</h1>' },
{ regex: new RegExp(/^##\s(.*)$/gm), replace: '<h2>$1</h2>' },
{ regex: new RegExp(/^###\s(.*)$/gm), replace: '<h3>$1</h3>' },
{ regex: new RegExp(/^####\s(.*)$/gm), replace: '<h4>$1</h4>' },
{ regex: new RegExp(/^#####\s(.*)$/gm), replace: '<h5>$1</h5>' },
{ regex: new RegExp(/^######\s(.*)$/gm), replace: '<h6>$1</h6>' },
{ regex: new RegExp(/^-\s(.*)$/gm), replace: '<ul><li>$1</li></ul>' },
{ regex: new RegExp(/^\d{1,}.\s(.*)$/gm), replace: '<ol><li>$1</li></ol>' },
//{ regex: new RegExp(/(<li class="ul">[\s\S]*<\/li>)/igm), replace: '<ul>$1</ul>' },
//{ regex: new RegExp(/(<li class="ol">[\s\S]*<\/li>)/igm), replace: '<ol>$1</ol>' }
]
SilicaFlickable {
anchors.fill: parent
contentHeight: mainColumn.height
Column {
id: mainColumn
width: parent.width
RemorsePopup {
id: remorse
onTriggered: pageStack.pop()
}
PullDownMenu {
busy: account ? account.busy : false
MenuItem {
text: qsTr("Delete")
enabled: account ? true : false
//visible: appSettings.currentAccount >= 0
onClicked: remorse.execute("Deleting", function() { account.deleteNote(account.model.get(noteIndex).id) } )
}
MenuItem {
text: enabled ? qsTr("Reload") : qsTr("Updating...")
enabled: account ? !account.busy : false
//visible: appSettings.currentAccount >= 0
onClicked: account.getNote(account.model.get(noteIndex).id)
}
MenuLabel {
visible: appSettings.currentAccount >= 0
text: account ? (
qsTr("Last update") + ": " + (
new Date(account.update).valueOf() !== 0 ?
new Date(account.update).toLocaleString(Qt.locale(), Locale.ShortFormat) :
qsTr("never"))) : ""
}
}
DialogHeader {
id: dialogHeader
acceptText: qsTr("Edit")
cancelText: qsTr("Notes")
}
Column {
width: parent.width
spacing: Theme.paddingLarge
LinkedLabel {
id: contentLabel
x: Theme.horizontalPageMargin
width: parent.width - 2*x
textFormat: Text.StyledText
function parse() {
var lines = plainText.split('\n')
lines.splice(0,1);
var tmpText = lines.join('\n');
for (var i=0; i < markdown.length; i++) {
tmpText = tmpText.replace(markdown[i].regex, markdown[i].replace)
}
text = tmpText
//console.log(text)
}
}
Separator {
id: separator
width: parent.width
color: Theme.primaryColor
horizontalAlignment: Qt.AlignHCenter
}
Column {
width: parent.width
DetailItem {
label: qsTr("Modified")
value: new Date(account.model.get(noteIndex).modified * 1000).toLocaleString(Qt.locale(), Locale.ShortFormat)
}
DetailItem {
label: qsTr("Favorite")
value: account.model.get(noteIndex).favorite ? qsTr("yes") : qsTr("no")
}
DetailItem {
label: qsTr("Category")
value: account.model.get(noteIndex).category
visible: value.length > 0
}
}
}
}
VerticalScrollDecorator {}
}
}