nexmo_markdown_renderer 0.6.0 → 0.7.4
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/nexmo_markdown_renderer/filters/concerns/prism_code_snippet.rb +8 -1
- data/lib/nexmo_markdown_renderer/filters/i18n/frontmatter_filter.rb +13 -2
- data/lib/nexmo_markdown_renderer/filters/i18n/smartling/frontmatter_filter.rb +19 -3
- data/lib/nexmo_markdown_renderer/filters/markdown_filter.rb +4 -2
- data/lib/nexmo_markdown_renderer/filters/snippet_variables_filter.rb +6 -2
- data/lib/nexmo_markdown_renderer/models/use_case.rb +1 -1
- data/lib/nexmo_markdown_renderer/pipelines/smartling/download.rb +1 -2
- data/lib/nexmo_markdown_renderer/pipelines/smartling/preprocessor.rb +1 -1
- data/lib/nexmo_markdown_renderer/services/doc_finder.rb +2 -2
- data/lib/version.rb +1 -1
- metadata +2 -3
- data/lib/nexmo_markdown_renderer/filters/i18n/smartling/code_block_filter.rb +0 -20
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 223be8922220948e621ffb0b0c8ff486358f8262b3507071f7fc78817f6d0e24
|
4
|
+
data.tar.gz: 933d10ac4261586660cbc3642fbd9f6b2ed78249222d822b76b1798f708cf0da
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 46ebc7af03925d304df282b1fe09bbcd6bb3d6be83ca6e02db2b2220dfeff924f6e0d640be7ff2cf8416566653123a7472f822de75aa2162262e34c005ab6808
|
7
|
+
data.tar.gz: 7cfe33bd3212392b6654a60ac2148817525abb530080701359648d9d6e67603063755db5eca09e1ee4b534f5490b4113a5b94116d5a178c06da6e324f75557ba
|
@@ -2,9 +2,16 @@ module Nexmo
|
|
2
2
|
module Markdown
|
3
3
|
module Concerns
|
4
4
|
module PrismCodeSnippet
|
5
|
+
include OcticonsHelper
|
6
|
+
|
5
7
|
def code_snippet_body(lexer, body)
|
6
8
|
<<~HEREDOC
|
7
|
-
<
|
9
|
+
<div class="copy-wrapper">
|
10
|
+
<div class="copy-button" data-lang="#{code_language_to_prism(lexer.tag)}" data-section="code">
|
11
|
+
#{octicon "clippy", :class => 'top left'} <span>#{::I18n.t('code_snippets.copy_to_clipboard') }</span>
|
12
|
+
</div>
|
13
|
+
<pre class="#{prism_css_classes(lexer)}"><code>#{body}</code></pre>
|
14
|
+
</div>
|
8
15
|
HEREDOC
|
9
16
|
end
|
10
17
|
|
@@ -4,9 +4,20 @@ module Nexmo
|
|
4
4
|
class FrontmatterFilter < Banzai::Filter
|
5
5
|
def call(input)
|
6
6
|
input.gsub(/\A(---.+?---)/mo) do |frontmatter|
|
7
|
-
frontmatter.gsub(
|
8
|
-
|
7
|
+
output = frontmatter.gsub(/^languages:\n(^\s+- ([a-zA-Z]+)\n)+/) do |languages|
|
8
|
+
languages.gsub(/^\s+- ([a-zA-Z]+)\n+/) do |language|
|
9
|
+
" - ```#{$1}```\n\n"
|
10
|
+
end
|
9
11
|
end
|
12
|
+
output = output.gsub(/^(\w*:)(.*)\n/) do |_key|
|
13
|
+
if $1 == "products:"
|
14
|
+
"```#{$1}#{$2}```\n\n"
|
15
|
+
else
|
16
|
+
"```#{$1}```#{$2}\n\n"
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
output
|
10
21
|
end
|
11
22
|
end
|
12
23
|
end
|
@@ -1,17 +1,33 @@
|
|
1
|
-
module Nexmo
|
1
|
+
module Nexmo
|
2
2
|
module Markdown
|
3
3
|
module I18n
|
4
4
|
module Smartling
|
5
5
|
class FrontmatterFilter < Banzai::Filter
|
6
6
|
def call(input)
|
7
|
-
input.gsub(/\A\*\*\* \*\* \* \*\* \*\*\*\n*(
|
8
|
-
front = $1.gsub(/`(.*)
|
7
|
+
input.gsub(/\A\*\*\* \*\* \* \*\* \*\*\*\n*(.*?\n)!?(\*\*\* \*\* \* \*\* \*\*\*|----+)\n*/m) do |_frontmatter|
|
8
|
+
front = $1.gsub(/`products: (.*)`\n\n/) do |products|
|
9
|
+
"products: #{$1}\n\n"
|
10
|
+
end
|
11
|
+
|
12
|
+
front = front.gsub(/`(.*):`(.*)/) do |_config|
|
9
13
|
"#{$1}: #{$2}"
|
10
14
|
end
|
15
|
+
|
16
|
+
front = front.gsub(/languages: \n\n(.*)\n/m) do |_languages|
|
17
|
+
languages = $1.split("\n\n").map do |lang|
|
18
|
+
lang.gsub(/\* `(.*)`/) { |_l| " - #{$1}" }
|
19
|
+
end
|
20
|
+
<<~LANGUAGES
|
21
|
+
languages:
|
22
|
+
#{languages.join("\n")}
|
23
|
+
LANGUAGES
|
24
|
+
end
|
25
|
+
|
11
26
|
<<~FRONTMATTER
|
12
27
|
---
|
13
28
|
#{front}
|
14
29
|
---
|
30
|
+
|
15
31
|
FRONTMATTER
|
16
32
|
end
|
17
33
|
end
|
@@ -91,8 +91,10 @@ module Nexmo
|
|
91
91
|
code.gsub! /^ /, "\t"
|
92
92
|
end
|
93
93
|
|
94
|
-
formatter
|
95
|
-
formatter.format(lexer.lex(code))
|
94
|
+
formatter ||= Rouge::Formatters::HTML.new
|
95
|
+
highlighted_source = formatter.format(lexer.lex(code))
|
96
|
+
|
97
|
+
code_snippet_body(lexer, highlighted_source)
|
96
98
|
end
|
97
99
|
end
|
98
100
|
end
|
@@ -13,12 +13,16 @@ module Nexmo
|
|
13
13
|
-- | --
|
14
14
|
HEREDOC
|
15
15
|
config.each do |key|
|
16
|
+
|
16
17
|
details = variables[key]
|
17
18
|
raise "#{key} is not a valid snippet variable" unless details
|
18
|
-
|
19
|
+
|
20
|
+
# We have some variables in the format TO_NUMBER.SMS etc, and we only want to render the first segment
|
21
|
+
# This can be multiple segments e.g. UUID.MODIFY.VOICE will be rendered as UUID
|
22
|
+
title = key.split('.').first
|
19
23
|
|
20
24
|
output += <<~HEREDOC
|
21
|
-
`#{
|
25
|
+
`#{title}` | #{details}
|
22
26
|
HEREDOC
|
23
27
|
end
|
24
28
|
|
data/lib/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: nexmo_markdown_renderer
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.7.4
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Nexmo
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2020-
|
11
|
+
date: 2020-12-22 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: banzai
|
@@ -260,7 +260,6 @@ files:
|
|
260
260
|
- lib/nexmo_markdown_renderer/filters/frontmatter_filter.rb
|
261
261
|
- lib/nexmo_markdown_renderer/filters/heading_filter.rb
|
262
262
|
- lib/nexmo_markdown_renderer/filters/i18n/frontmatter_filter.rb
|
263
|
-
- lib/nexmo_markdown_renderer/filters/i18n/smartling/code_block_filter.rb
|
264
263
|
- lib/nexmo_markdown_renderer/filters/i18n/smartling/escape_filter.rb
|
265
264
|
- lib/nexmo_markdown_renderer/filters/i18n/smartling/frontmatter_filter.rb
|
266
265
|
- lib/nexmo_markdown_renderer/filters/icon_filter.rb
|
@@ -1,20 +0,0 @@
|
|
1
|
-
module Nexmo
|
2
|
-
module Markdown
|
3
|
-
module I18n
|
4
|
-
module Smartling
|
5
|
-
class CodeBlockFilter < Banzai::Filter
|
6
|
-
def call(input)
|
7
|
-
input.gsub(/\n\n\s{4}(.*?)\n\n/m) do
|
8
|
-
<<~CODE_BLOCK
|
9
|
-
|
10
|
-
````
|
11
|
-
#{$1.split(/\n\s{4}/).join("\n")}
|
12
|
-
````
|
13
|
-
CODE_BLOCK
|
14
|
-
end
|
15
|
-
end
|
16
|
-
end
|
17
|
-
end
|
18
|
-
end
|
19
|
-
end
|
20
|
-
end
|