398 lines
32 KiB
QML
398 lines
32 KiB
QML
import QtQuick 2.2
|
|
import Sailfish.Silica 1.0
|
|
|
|
Page {
|
|
id: page
|
|
|
|
SilicaFlickable {
|
|
id: mainFlickable
|
|
anchors.fill: parent
|
|
contentHeight: column.height + Theme.paddingLarge
|
|
|
|
PullDownMenu {
|
|
MenuItem {
|
|
text: qsTr("View more on the web")
|
|
onClicked: Qt.openUrlExternally("https://github.com/showdownjs/showdown/wiki/Showdown's-Markdown-syntax")
|
|
}
|
|
|
|
MenuItem {
|
|
id: resetMenuItem
|
|
property bool allOpened: false
|
|
text: allOpened ? qsTr("Close previews") :
|
|
qsTr("Open previews")
|
|
onClicked: allOpened = !allOpened
|
|
}
|
|
}
|
|
|
|
Column {
|
|
id: column
|
|
width: parent.width
|
|
|
|
PageHeader {
|
|
title: qsTr("Markdown Syntax")
|
|
}
|
|
|
|
Loader {
|
|
sourceComponent: syntaxDrawer
|
|
property string title: qsTr("Paragraphs")
|
|
property string description: qsTr("Paragraphs in Showdown are just one or more lines of consecutive text followed by one or more blank lines.")
|
|
property string rawText:
|
|
"On July 2, an alien mothership entered Earth's orbit and deployed several dozen
|
|
saucer-shaped \"destroyer\" spacecraft, each 15 miles (24 km) wide.
|
|
|
|
On July 3, the Black Knights, a squadron of Marine Corps F/A-18 Hornets,
|
|
participated in an assault on a destroyer near the city of Los Angeles."
|
|
property string convertedText:
|
|
"<p>On July 2, an alien mothership entered Earth's orbit and deployed several dozen<br />
|
|
saucer-shaped \"destroyer\" spacecraft, each 15 miles (24 km) wide.</p>
|
|
<p>On July 3, the Black Knights, a squadron of Marine Corps F/A-18 Hornets,<br />
|
|
participated in an assault on a destroyer near the city of Los Angeles.</p>"
|
|
}
|
|
|
|
Loader {
|
|
sourceComponent: syntaxDrawer
|
|
property string title: qsTr("Headings")
|
|
property string description: qsTr("You can create a heading by adding one or more # symbols before your heading text. The number of # you use will determine the size of the heading.")
|
|
property string rawText:
|
|
"# The largest heading (an <h1> tag)
|
|
## The second largest heading (an <h2> tag)
|
|
### The third largest heading (an <h3> tag)
|
|
#### The 4th largest heading (an <h4> tag)
|
|
##### The 5th largest heading (an <h5> tag)
|
|
###### The 6th largest heading (an <h6> tag)"
|
|
property string convertedText:
|
|
"<h1 id=\"thelargestheadinganh1tag\">The largest heading (an \<h1> tag)</h1>
|
|
<h2 id=\"thesecondlargestheadinganh2tag\">The second largest heading (an \<h2> tag)</h2>
|
|
<h3 id=\"thethirdlargestheadinganh3tag\">The third largest heading (an \<h3> tag)</h3>
|
|
<h4 id=\"the4thlargestheadinganh4tag\">The 4th largest heading (an \<h4> tag)</h4>
|
|
<h5 id=\"the5thlargestheadinganh5tag\">The 5th largest heading (an \<h5> tag)</h5>
|
|
<h6 id=\"the6thlargestheadinganh6tag\">The 6th largest heading (an \<h6> tag)</h6>"
|
|
}
|
|
Loader {
|
|
sourceComponent: syntaxDrawer
|
|
property string description: qsTr("If, for some reason, you need to keep a leading or trailing #, you can either add a space or escape it:")
|
|
property string rawText:
|
|
"# # My header # #
|
|
# \\# My Header \\# #"
|
|
property string convertedText:
|
|
"<h1 id=\"myheader\"># My header #</h1>
|
|
<h1 id=\"myheader-1\"># My Header #</h1>"
|
|
}
|
|
|
|
Loader {
|
|
sourceComponent: syntaxDrawer
|
|
property string title: qsTr("Blockquotes")
|
|
property string description: qsTr("You can indicate blockquotes with a >.")
|
|
property string rawText:
|
|
"In the words of Abraham Lincoln:
|
|
|
|
> Pardon my french"
|
|
property string convertedText:
|
|
"<p>In the words of Abraham Lincoln:</p>
|
|
<blockquote>
|
|
<p>Pardon my french</p>
|
|
</blockquote>"
|
|
}
|
|
|
|
Loader {
|
|
sourceComponent: syntaxDrawer
|
|
property string title: qsTr("Bold and Italic")
|
|
property string description: qsTr("You can make text bold or italic.")
|
|
property string rawText:
|
|
"*This text will be italic*
|
|
**This text will be bold**"
|
|
property string convertedText:
|
|
"<p><em>This text will be italic</em><br />
|
|
<strong>This text will be bold</strong></p>"
|
|
}
|
|
Loader {
|
|
sourceComponent: syntaxDrawer
|
|
property string description: qsTr("Both bold and italic can use either a * or an _ around the text for styling. This allows you to combine both bold and italic if needed.")
|
|
property string rawText:
|
|
"**Everyone _must_ attend the meeting at 5 o'clock today.**"
|
|
property string convertedText:
|
|
"<p><strong>Everyone <em>must</em> attend the meeting at 5 o'clock today.</strong></p>"
|
|
}
|
|
|
|
Loader {
|
|
sourceComponent: syntaxDrawer
|
|
property string title: qsTr("Strikethrough")
|
|
property string description: qsTr("The syntax is the same as GFM, that is, by adding two tilde (~~) characters around a word or groups of words.")
|
|
property string rawText:
|
|
"a ~~strikethrough~~ element"
|
|
property string convertedText:
|
|
"<p>a <del>strikethrough</del> element</p>"
|
|
}
|
|
|
|
Loader {
|
|
sourceComponent: syntaxDrawer
|
|
property string title: qsTr("Emojis")
|
|
property string description: qsTr("Since version 1.8.0, showdown supports github's emojis. A complete list of available emojis can be found here: https://github.com/showdownjs/showdown/wiki/emojis.")
|
|
property string rawText:
|
|
"this is a :smile: smile emoji"
|
|
property string convertedText:
|
|
"<p>this is a 🙂 smile emoji</p>"
|
|
}
|
|
|
|
Loader {
|
|
sourceComponent: syntaxDrawer
|
|
property string title: qsTr("Code formatting")
|
|
property string description: qsTr("Use single backticks (`) to format text in a special monospace format. Everything within the backticks appear as-is, with no other special formatting.")
|
|
property string rawText:
|
|
"Here's an idea: why don't we take `SuperiorProject` and turn it into `**Reasonable**Project`."
|
|
property string convertedText:
|
|
"<p>Here's an idea: why don't we take <code>SuperiorProject</code> and turn it into <code>**Reasonable**Project</code>.</p>"
|
|
}
|
|
Loader {
|
|
sourceComponent: syntaxDrawer
|
|
property string description: qsTr("To create blocks of code you should indent it by four spaces.")
|
|
property string rawText:
|
|
" this is a piece
|
|
of
|
|
code"
|
|
property string convertedText:
|
|
"<pre><code>this is a piece
|
|
of
|
|
code
|
|
</code></pre>"
|
|
}
|
|
|
|
Loader {
|
|
sourceComponent: syntaxDrawer
|
|
property string title: qsTr("Lists")
|
|
property string description: qsTr("You can make an unordered list by preceding list items with either a *, a - or a +. Markers are interchangeable too.")
|
|
property string rawText:
|
|
"* Item
|
|
+ Item
|
|
- Item"
|
|
property string convertedText:
|
|
"<ul>
|
|
<li>Item</li>
|
|
<li>Item</li>
|
|
<li>Item</li>
|
|
</ul>"
|
|
}
|
|
Loader {
|
|
sourceComponent: syntaxDrawer
|
|
property string description: qsTr("You can make an ordered list by preceding list items with a number.")
|
|
property string rawText:
|
|
"1. Item 1
|
|
2. Item 2
|
|
3. Item 3"
|
|
property string convertedText:
|
|
"<ol>
|
|
<li>Item 1</li>
|
|
<li>Item 2</li>
|
|
<li>Item 3</li>
|
|
</ol>"
|
|
}
|
|
Loader {
|
|
sourceComponent: syntaxDrawer
|
|
property string description: qsTr("TaskLists")
|
|
property string rawText:
|
|
"- [x] checked list item
|
|
- [ ] unchecked list item"
|
|
property string convertedText:
|
|
"<ul>
|
|
<li class=\"tasklist\"><a class=\"checkbox\" href=\"tasklist:uncheckbox_0\">☐ checked list item</a></li>
|
|
<li class=\"tasklist\"><a class=\"checkbox\" href=\"tasklist:checkbox_0\">☑ unchecked list item</li>
|
|
</ul>"
|
|
}
|
|
|
|
Loader {
|
|
sourceComponent: syntaxDrawer
|
|
property string title: qsTr("Links")
|
|
property string description: qsTr("Showdown will automagically turn every valid URL it finds in the text body to links for you. In the case of email addreses, Showdown will also perform a bit of randomized decimal and hex entity-encoding to help obscure your address from address-harvesting spambots.")
|
|
property string rawText:
|
|
"https://jolla.com
|
|
info@jolla.com
|
|
[Homepage - Jolla](https://jolla.com)
|
|
[Link to Jolla][1]
|
|
[jolla][]
|
|
|
|
[1]: https://jolla.com
|
|
[jolla]: https://jolla.com"
|
|
property string convertedText:
|
|
"<p><a href=\"https://jolla.com\">https://jolla.com</a><br />
|
|
<a href=\"mailto:info@jolla.com\">info@jolla.com</a><br />
|
|
<a href=\"https://jolla.com\">Homepage - Jolla</a><br />
|
|
<a href=\"https://jolla.com\">Link to Jolla</a><br />
|
|
<a href=\"https://jolla.com\">jolla</a></p>"
|
|
}
|
|
|
|
Loader {
|
|
sourceComponent: syntaxDrawer
|
|
property string title: qsTr("Images")
|
|
property string description: qsTr("Markdown uses an image syntax that is intended to resemble the syntax for links, also allowing for two styles: inline and reference.")
|
|
property string rawText:
|
|
"![Alt text](https://cloud.scharel.name/s/harbour-nextcloudnotes/download?path=/&files=nextcloud-logo-transparent.png \"Optional title\")
|
|
![Alt text][img]
|
|
|
|
[img]:
|
|
 \"Optional title\""
|
|
property string convertedText:
|
|
"<p><img src=\"https://cloud.scharel.name/s/harbour-nextcloudnotes/download?path=/&files=nextcloud-logo-transparent.png\" alt=\"Alt text\" title=\"Optional title\" /><br />
|
|
<img src=\"\" alt=\"Alt text\" title=\"Optional title\" /></p>"
|
|
}
|
|
|
|
Loader {
|
|
sourceComponent: syntaxDrawer
|
|
property string title: qsTr("Tables")
|
|
property string description: qsTr("Tables aren't part of the core Markdown spec, but they are part of GFM and Showdown supports them by turning on the option tables.
|
|
|
|
Colons can be used to align columns.
|
|
|
|
In the new version, the outer pipes (|) are optional, matching GFM spec.
|
|
|
|
You also don't need to make the raw Markdown line up prettily.
|
|
|
|
You can also use other markdown syntax inside them.")
|
|
property string rawText:
|
|
"| Tables | Are | Cool |
|
|
| ------------- |:-------------:| -----:|
|
|
| **col 3 is** | right-aligned | $1600 |
|
|
| col 2 is | *centered* | $12 |
|
|
| zebra stripes | ~~are neat~~ | $1 |"
|
|
property string convertedText:
|
|
"<table border='1' cellpadding='20'>
|
|
<thead>
|
|
<tr>
|
|
<th>Tables</th>
|
|
<th style=\"text-align:center;\">Are</th>
|
|
<th style=\"text-align:right;\">Cool</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
<tr>
|
|
<td><strong>col 3 is</strong></td>
|
|
<td style=\"text-align:center;\">right-aligned</td>
|
|
<td style=\"text-align:right;\">$1600</td>
|
|
</tr>
|
|
<tr>
|
|
<td>col 2 is</td>
|
|
<td style=\"text-align:center;\"><em>centered</em></td>
|
|
<td style=\"text-align:right;\">$12</td>
|
|
</tr>
|
|
<tr>
|
|
<td>zebra stripes</td>
|
|
<td style=\"text-align:center;\"><del>are neat</del></td>
|
|
<td style=\"text-align:right;\">$1</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>"
|
|
}
|
|
|
|
Loader {
|
|
sourceComponent: syntaxDrawer
|
|
property string title: qsTr("HTML")
|
|
property string description: qsTr("In most cases, HTML tags are leaved untouched in the output document.")
|
|
property string rawText:
|
|
"some markdown **here**
|
|
<div>this is *not* **parsed**</div>
|
|
Use <b>HTML</b> <i>Tags</i> to format your text."
|
|
property string convertedText:
|
|
"<p>some markdown <strong>here</strong></p>
|
|
<div>this is *not* **parsed**</div>
|
|
<p>Use <b>HTML</b> <i>Tags</i> to format your text.</p>"
|
|
}
|
|
}
|
|
|
|
VerticalScrollDecorator { flickable: mainFlickable }
|
|
}
|
|
|
|
Component {
|
|
id: syntaxDrawer
|
|
|
|
Column {
|
|
width: page.width
|
|
|
|
SectionHeader {
|
|
text: title
|
|
}
|
|
|
|
Label {
|
|
x: Theme.horizontalPageMargin
|
|
width: parent.width - 2*x
|
|
bottomPadding: Theme.paddingLarge
|
|
wrapMode: Text.Wrap
|
|
color: Theme.secondaryColor
|
|
text: description
|
|
}
|
|
Separator {
|
|
width: parent.width
|
|
color: Theme.primaryColor
|
|
horizontalAlignment: Qt.AlignLeft
|
|
}
|
|
Drawer {
|
|
id: drawer
|
|
width: parent.width
|
|
height: rawTextLabel.height + 2*Theme.paddingLarge > 2*Theme.itemSizeHuge ? 2*Theme.itemSizeHuge : rawTextLabel.height + 2*Theme.paddingLarge
|
|
backgroundSize: height
|
|
hideOnMinimize: true
|
|
dock: Dock.Bottom
|
|
|
|
Connections {
|
|
target: resetMenuItem
|
|
onAllOpenedChanged: resetMenuItem.allOpened ? drawer.show() : drawer.hide()
|
|
}
|
|
|
|
foreground: SilicaFlickable {
|
|
id: rawTextFlickable
|
|
anchors.fill: parent
|
|
contentWidth: parent.width > rawTextLabel.contentWidth ? parent.width : rawTextLabel.contentWidth + 2*Theme.horizontalPageMargin
|
|
contentHeight: parent.height > rawTextLabel.height ? parent.height : rawTextLabel.height
|
|
BackgroundItem {
|
|
anchors.fill: parent
|
|
onClicked: drawer.show()
|
|
Label {
|
|
id: rawTextLabel
|
|
x: Theme.horizontalPageMargin
|
|
y: Theme.paddingLarge
|
|
color: parent.highlighted ? Theme.highlightColor : Theme.primaryColor
|
|
font.family: appSettings.useMonoFont ? "DejaVu Sans Mono" : Theme.fontFamily
|
|
textFormat: Text.PlainText
|
|
text: rawText
|
|
}
|
|
}
|
|
ScrollDecorator { /*flickable: rawTextFlickable*/ }
|
|
}
|
|
|
|
background: SilicaFlickable {
|
|
id: convertedTextFlickable
|
|
anchors.fill: parent
|
|
contentWidth: parent.width > convertedTextLabel.contentWidth ? parent.width : convertedTextLabel.contentWidth + 2*Theme.horizontalPageMargin
|
|
contentHeight: parent.height > convertedTextLabel.height ? parent.height : convertedTextLabel.height + 2*Theme.paddingLarge
|
|
BackgroundItem {
|
|
anchors.fill: parent
|
|
onClicked: drawer.hide()
|
|
LinkedLabel {
|
|
id: convertedTextLabel
|
|
x: Theme.horizontalPageMargin
|
|
y: Theme.paddingLarge
|
|
textFormat: Text.RichText
|
|
linkColor: Theme.primaryColor
|
|
defaultLinkActions: false
|
|
onLinkActivated: drawer.hide()
|
|
text: "<style>\n" +
|
|
"ul,ol,table,img { margin: " + Theme.paddingLarge + "px 0px; }\n" +
|
|
"a:link { color: " + Theme.primaryColor + "; }\n" +
|
|
"a.checkbox { text-decoration: none; padding: " + Theme.paddingSmall + "px; display: inline-block; }\n" +
|
|
"li.tasklist { font-size:large; margin: " + Theme.paddingMedium + "px 0px; }\n" +
|
|
"del { text-decoration: line-through; }\n" +
|
|
"table { border-color: " + Theme.secondaryColor + "; }\n" +
|
|
"</style>\n" + convertedText
|
|
}
|
|
}
|
|
ScrollDecorator { /*flickable: convertedTextFlickable*/ }
|
|
}
|
|
}
|
|
Separator {
|
|
width: parent.width
|
|
color: Theme.primaryColor
|
|
horizontalAlignment: Qt.AlignRight
|
|
}
|
|
}
|
|
}
|
|
|
|
allowedOrientations: appWindow.allowedOrientations
|
|
}
|