import QtQuick 2.0 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: "

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.

" } 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

tag) ## The second largest heading (an

tag) ### The third largest heading (an

tag) #### The 4th largest heading (an

tag) ##### The 5th largest heading (an

tag) ###### The 6th largest heading (an
tag)" property string convertedText: "

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)
" } 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: "

# My header #

# My Header #

" } 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: "

In the words of Abraham Lincoln:

Pardon my french

" } 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: "

This text will be italic
This text will be bold

" } 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: "

Everyone must attend the meeting at 5 o'clock today.

" } 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: "

a strikethrough element

" } 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: "

this is a 🙂 smile emoji

" } 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: "

Here's an idea: why don't we take SuperiorProject and turn it into **Reasonable**Project.

" } 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: "
this is a piece
of
code
" } 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: "" } 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: "
  1. Item 1
  2. Item 2
  3. Item 3
" } Loader { sourceComponent: syntaxDrawer property string description: qsTr("TaskLists") property string rawText: "- [x] checked list item - [ ] unchecked list item" property string convertedText: "" } 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: "

https://jolla.com
info@jolla.com
Homepage - Jolla
Link to Jolla
jolla

" } 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: "

\"Alt
\"Alt

" } 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: "
Tables Are Cool
col 3 is right-aligned $1600
col 2 is centered $12
zebra stripes are neat $1
" } 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**
this is *not* **parsed**
Use HTML Tags to format your text." property string convertedText: "

some markdown here

this is *not* **parsed**

Use HTML Tags to format your text.

" } } 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: "\n" + convertedText } } ScrollDecorator { /*flickable: convertedTextFlickable*/ } } } Separator { width: parent.width color: Theme.primaryColor horizontalAlignment: Qt.AlignRight } } } allowedOrientations: defaultAllowedOrientations }