Add typed shorthand markdown commands
This commit is contained in:
parent
53500c31f6
commit
6c21d8c857
@ -72,6 +72,7 @@ struct PageContentGenerator {
|
||||
|
||||
private func processMarkdownImage(markdown: Substring, html: String, page: Element) -> String {
|
||||
// Split the markdown data:image/s3,"s3://crabby-images/a25f8/a25f8a53f189c19baecb49f9197e2226d56c4d94" alt="alt"
|
||||
// There are several known shorthand commands
|
||||
// For images: data:image/s3,"s3://crabby-images/afcf4/afcf4aadb38e45079f10dd7a7334eba4839ed95d" alt="left_title"
|
||||
// For videos: data:image/s3,"s3://crabby-images/10a2a/10a2ae49799cb2d240e3e04223fcaaa512bafc00" alt="option1,option2,..."
|
||||
// For svg with custom area: data:image/s3,"s3://crabby-images/5f0de/5f0de5a13c522fc8e70bbee164595ca11ff48d22" alt="x,y,width,height"
|
||||
@ -80,17 +81,8 @@ struct PageContentGenerator {
|
||||
// External pages: data:image/s3,"s3://crabby-images/c7252/c72527c3e8be2c57e79dcaa3101c7956257bf63d" alt="external"
|
||||
let fileAndTitle = markdown.between("(", and: ")")
|
||||
let alt = markdown.between("[", and: "]").nonEmpty
|
||||
switch alt {
|
||||
case "download":
|
||||
return handleDownloadButtons(page: page, content: fileAndTitle)
|
||||
case "external":
|
||||
return handleExternalButtons(page: page, content: fileAndTitle)
|
||||
case "html":
|
||||
return handleExternalHTML(page: page, file: fileAndTitle)
|
||||
case "box":
|
||||
return handleSimpleBox(page: page, content: fileAndTitle)
|
||||
default:
|
||||
break
|
||||
if let alt = alt, let command = ShorthandMarkdownKey(rawValue: alt) {
|
||||
return handleShortHandCommand(command, page: page, content: fileAndTitle)
|
||||
}
|
||||
|
||||
let file = fileAndTitle.dropAfterFirst(" ")
|
||||
@ -109,6 +101,19 @@ struct PageContentGenerator {
|
||||
return handleFile(page: page, file: file, fileExtension: fileExtension)
|
||||
}
|
||||
|
||||
private func handleShortHandCommand(_ command: ShorthandMarkdownKey, page: Element, content: String) -> String {
|
||||
switch command {
|
||||
case .downloadButtons:
|
||||
return handleDownloadButtons(page: page, content: content)
|
||||
case .externalLink:
|
||||
return handleExternalButtons(page: page, content: content)
|
||||
case .includedHtml:
|
||||
return handleExternalHTML(page: page, file: content)
|
||||
case .box:
|
||||
return handleSimpleBox(page: page, content: content)
|
||||
}
|
||||
}
|
||||
|
||||
private func handleImage(page: Element, file: String, rightTitle: String?, leftTitle: String?) -> String {
|
||||
let imagePath = page.pathRelativeToRootForContainedInputFile(file)
|
||||
|
||||
|
24
Sources/Generator/Generators/ShorthandMarkdownKey.swift
Normal file
24
Sources/Generator/Generators/ShorthandMarkdownKey.swift
Normal file
@ -0,0 +1,24 @@
|
||||
import Foundation
|
||||
|
||||
enum ShorthandMarkdownKey: String {
|
||||
|
||||
/**
|
||||
A variable number of download buttons for file downloads
|
||||
*/
|
||||
case downloadButtons = "download"
|
||||
|
||||
/**
|
||||
A large button to an external page.
|
||||
*/
|
||||
case externalLink = "external"
|
||||
|
||||
/**
|
||||
Additional HTML code include verbatim into the page.
|
||||
*/
|
||||
case includedHtml = "html"
|
||||
|
||||
/**
|
||||
A box with a heading and a text description
|
||||
*/
|
||||
case box = "box"
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user