ZMediumToMarkdown 1.9.5 → 1.9.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: d96b986a3f8f82236b20c8db706b3a6b4451b5822ab4c940e855ee6e819a0087
4
- data.tar.gz: 6cb9b1e76ba0486d4f96394c9153850185ddd9397f5b99ce29d896ad2f638e42
3
+ metadata.gz: cc121cbe8d2f06e2e6421872ff2f6950addd4affd46fe928172b9848da8e1517
4
+ data.tar.gz: 62e35936912a730a37c2424d6028fd3a780fe41aa0048ed717e81df02910dff2
5
5
  SHA512:
6
- metadata.gz: bdfdfc9d261bfc62114b799b657af0635f8c72415c040cd08934fd0fd84c7bcf73855f3204f5c6ce9248245d95e159ce4fda715f2460167f57ba53169d3b7f90
7
- data.tar.gz: e7555c35a30e63794f00be2503d345d44ea90d432da99ed2769fb6b348825eec4663ee74ccc21831d218ac26501268a3dbfb1cf70800c0839699cd8e280fdc18
6
+ metadata.gz: 6e76c68cc1c4f1f56bf35bc6517a0814c8263367f6ebda4e33591dd29667ae597a7a0b6da1ca1485245522e45d1a7dfbe739e9e996c0addb8ffc6d1600b1940b
7
+ data.tar.gz: cfe0bce95d184b67fb1afb2c84407478384b617665162dae9908fda1cfd8ff68094bbde65016b2872eea9d91e5e5987890f04e41e572175712cf0cdfa6210064
@@ -65,7 +65,6 @@ class Main
65
65
 
66
66
  opts.on('-v', '--version', 'Print current ZMediumToMarkdown Version & Output Path') do
67
67
  puts "Version:#{Helper.getLocalVersion().to_s}"
68
- puts "Output Path:#{outputFilePath.getAbsolutePath(nil)}"
69
68
 
70
69
  Helper.printNewVersionMessageIfExists()
71
70
  end
data/lib/Helper.rb CHANGED
@@ -98,7 +98,7 @@ class Helper
98
98
  end
99
99
  end
100
100
 
101
- def self.createPostInfo(postInfo)
101
+ def self.createPostInfo(postInfo, isForJekyll)
102
102
 
103
103
  title = postInfo.title.gsub("[","")
104
104
  title = title.gsub("]","")
@@ -109,6 +109,10 @@ class Helper
109
109
  result += "date: #{postInfo.firstPublishedAt.strftime('%Y-%m-%dT%H:%M:%S.%LZ')}\n"
110
110
  result += "categories: #{postInfo.collectionName}\n"
111
111
  result += "tags: [#{postInfo.tags.join(",")}]\n"
112
+ result += "description: #{postInfo.description}\n"
113
+ if isForJekyll
114
+ result += "render_with_liquid: false\n"
115
+ end
112
116
  result += "---\n"
113
117
  result += "\r\n"
114
118
 
@@ -182,16 +186,19 @@ class Helper
182
186
 
183
187
 
184
188
  def self.createWatermark(postURL)
185
- text = "\r\n\r\n\r\n"
186
- text += "+-----------------------------------------------------------------------------------+"
187
- text += "\r\n"
188
- text += "\r\n"
189
- text += "| **[View original post on Medium](#{postURL}) - Converted by [ZhgChgLi](https://zhgchg.li)/[ZMediumToMarkdown](https://github.com/ZhgChgLi/ZMediumToMarkdown)** |"
190
- text += "\r\n"
191
- text += "\r\n"
192
- text += "+-----------------------------------------------------------------------------------+"
193
- text += "\r\n"
189
+ text = ""
190
+
191
+ # text += "\r\n\r\n\r\n"
192
+ # text += "+-----------------------------------------------------------------------------------+"
193
+ # text += "\r\n"
194
+ # text += "\r\n"
195
+ # text += "| **[View original post on Medium](#{postURL}) - Converted by [ZhgChgLi](https://zhgchg.li)/[ZMediumToMarkdown](https://github.com/ZhgChgLi/ZMediumToMarkdown)** |"
196
+ # text += "\r\n"
197
+ # text += "\r\n"
198
+ # text += "+-----------------------------------------------------------------------------------+"
199
+ # text += "\r\n"
194
200
 
201
+ # no need to show any watermark :)
195
202
  text
196
203
  end
197
204
  end
@@ -4,7 +4,11 @@ require "Parsers/Parser"
4
4
  require 'Models/Paragraph'
5
5
 
6
6
  class CodeBlockParser < Parser
7
- attr_accessor :nextParser
7
+ attr_accessor :nextParser, :isForJekyll
8
+
9
+ def initialize(isForJekyll)
10
+ @isForJekyll = isForJekyll
11
+ end
8
12
 
9
13
  def self.getTypeString()
10
14
  'CODE_BLOCK'
@@ -20,7 +24,11 @@ class CodeBlockParser < Parser
20
24
 
21
25
  def parse(paragraph)
22
26
  if CodeBlockParser.isCodeBlock(paragraph)
23
- "```\n#{paragraph.text}\n```"
27
+ result = "```\n"
28
+
29
+ result += paragraph.text.chomp
30
+
31
+ result += "\n```"
24
32
  else
25
33
  if !nextParser.nil?
26
34
  nextParser.parse(paragraph)
@@ -74,7 +74,12 @@ class IframeParser < Parser
74
74
  gistHTML.search('a').each do |a|
75
75
  if a.text == 'view raw'
76
76
  gistRAW = Request.body(Request.URL(a['href']))
77
- result = "```#{lang}\n#{gistRAW}\n```"
77
+
78
+ result = "```#{lang}\n"
79
+
80
+ result += gistRAW.chomp
81
+
82
+ result += "\n```"
78
83
  end
79
84
  end
80
85
  else
@@ -4,7 +4,11 @@ require "Parsers/Parser"
4
4
  require 'Models/Paragraph'
5
5
 
6
6
  class PREParser < Parser
7
- attr_accessor :nextParser
7
+ attr_accessor :nextParser, :isForJekyll
8
+
9
+ def initialize(isForJekyll)
10
+ @isForJekyll = isForJekyll
11
+ end
8
12
 
9
13
  def self.isPRE(paragraph)
10
14
  if paragraph.nil?
@@ -17,10 +21,14 @@ class PREParser < Parser
17
21
  def parse(paragraph)
18
22
  if PREParser.isPRE(paragraph)
19
23
  result = "```\n"
24
+
20
25
  paragraph.text.each_line do |p|
21
26
  result += p
22
27
  end
28
+
29
+ result = result.chomp
23
30
  result += "\n```"
31
+
24
32
  result
25
33
  else
26
34
  if !nextParser.nil?
data/lib/Post.rb CHANGED
@@ -9,7 +9,7 @@ require 'date'
9
9
  class Post
10
10
 
11
11
  class PostInfo
12
- attr_accessor :title, :tags, :creator, :firstPublishedAt, :latestPublishedAt, :collectionName
12
+ attr_accessor :title, :tags, :creator, :firstPublishedAt, :latestPublishedAt, :collectionName, :description
13
13
  end
14
14
 
15
15
  def self.getPostIDFromPostURLString(postURLString)
@@ -60,6 +60,7 @@ class Post
60
60
 
61
61
  def self.parsePostInfoFromPostContent(content, postID)
62
62
  postInfo = PostInfo.new()
63
+ postInfo.description = content&.dig("Post:#{postID}", "previewContent", "subtitle")
63
64
  postInfo.title = content&.dig("Post:#{postID}", "title")
64
65
  postInfo.tags = content&.dig("Post:#{postID}", "tags").map{ |tag| tag["__ref"].gsub! 'Tag:', '' }
65
66
 
@@ -50,9 +50,9 @@ class ZMediumFetcher
50
50
  info += "-"
51
51
  end
52
52
  if !currentPostParagraphIndex.nil? && !totalPostParagraphsLength.nil?
53
- info += "[#{postPath[0..10]}...(#{currentPostParagraphIndex}/#{totalPostParagraphsLength})]"
53
+ info += "[#{postPath[0..15]}...(#{currentPostParagraphIndex}/#{totalPostParagraphsLength})]"
54
54
  else
55
- info += "[#{postPath[0..10]}...]"
55
+ info += "[#{postPath[0..15]}...]"
56
56
  end
57
57
  end
58
58
 
@@ -101,9 +101,9 @@ class ZMediumFetcher
101
101
  iframeParser.setNext(imgParser)
102
102
  bqParser = BQParser.new()
103
103
  imgParser.setNext(bqParser)
104
- preParser = PREParser.new()
104
+ preParser = PREParser.new(isForJekyll)
105
105
  bqParser.setNext(preParser)
106
- codeBlockParser = CodeBlockParser.new()
106
+ codeBlockParser = CodeBlockParser.new(isForJekyll)
107
107
  preParser.setNext(codeBlockParser)
108
108
  fallbackParser = FallbackParser.new()
109
109
  codeBlockParser.setNext(fallbackParser)
@@ -230,7 +230,7 @@ class ZMediumFetcher
230
230
  absolutePath = postPathPolicy.getAbsolutePath("#{postWithDatePath}.md")
231
231
 
232
232
  # if markdown file is exists and last modification time is >= latestPublishedAt(last update post time on medium)
233
- if File.file?(absolutePath) && File.mtime(absolutePath) >= postInfo.latestPublishedAt
233
+ if File.file?(absolutePath) && File.mtime(absolutePath).to_time.to_i >= postInfo.latestPublishedAt.to_i
234
234
  # Already downloaded and nothing has changed!, Skip!
235
235
  progress.currentPostParagraphIndex = paragraphs.length
236
236
  progress.message = "Skip, Post already downloaded and nothing has changed!"
@@ -239,7 +239,7 @@ class ZMediumFetcher
239
239
  Helper.createDirIfNotExist(postPathPolicy.getAbsolutePath(nil))
240
240
  File.open(absolutePath, "w+") do |file|
241
241
  # write postInfo into top
242
- file.puts(Helper.createPostInfo(postInfo))
242
+ file.puts(Helper.createPostInfo(postInfo, isForJekyll))
243
243
 
244
244
  index = 0
245
245
  paragraphs.each do |paragraph|
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: ZMediumToMarkdown
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.9.5
4
+ version: 1.9.8
5
5
  platform: ruby
6
6
  authors:
7
7
  - ZhgChgLi
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2022-06-21 00:00:00.000000000 Z
11
+ date: 2022-07-18 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: nokogiri