jekyll-notion 0.0.0.beta.1 → 0.0.0.pre
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 +4 -4
- data/README.md +1 -1
- data/lib/jekyll-notion/document_without_a_file.rb +1 -1
- data/lib/jekyll-notion/generator.rb +19 -15
- data/lib/jekyll-notion/notion_database.rb +18 -11
- data/lib/jekyll-notion/notion_page.rb +3 -3
- data/lib/jekyll-notion/version.rb +1 -1
- data/lib/jekyll-notion.rb +10 -10
- metadata +30 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: b6adb6c98a4e57b71ac16f6e2266c71b6063beedfd960ba022d74783c0c2e6e3
|
4
|
+
data.tar.gz: 3db8e7873189c0fcd1644d051f0e099f0498eca922158c1bac9f34bbb2a84b9d
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: f9352dfc312103e5c846fe58b4053fa99cf93fedda66af3f037d21f6ccaba794b4589ec78b2b318a619d139d2025e0bedef0d03e364f0244a23d7ad835ae0d11
|
7
|
+
data.tar.gz: c88d36f84bbca91e46f892b64371fcf87baf2d06fa77ce41101841a7741ae90b5af79d8a756eb24c102b5843ad5fe00ed2638cdd7d0f843ee745b3172c06babb
|
data/README.md
CHANGED
@@ -46,7 +46,7 @@ notion:
|
|
46
46
|
```
|
47
47
|
|
48
48
|
The other properties are:
|
49
|
-
* `collection`:
|
49
|
+
* `collection`: the collection each page belongs to (posts by default),
|
50
50
|
* `filter`: the database query filter,
|
51
51
|
* `sort`: the database query sort,
|
52
52
|
* `frontmatter`: additional frontmatter to append to each page in the collection.
|
@@ -6,7 +6,7 @@ module JekyllNotion
|
|
6
6
|
if content =~ YAML_FRONT_MATTER_REGEXP
|
7
7
|
self.content = Regexp.last_match.post_match
|
8
8
|
data_file = SafeYAML.load(Regexp.last_match(1))
|
9
|
-
merge_data!(data_file, source
|
9
|
+
merge_data!(data_file, :source => "YAML front matter") if data_file
|
10
10
|
end
|
11
11
|
end
|
12
12
|
end
|
@@ -7,25 +7,24 @@ module JekyllNotion
|
|
7
7
|
def generate(site)
|
8
8
|
@site = site
|
9
9
|
|
10
|
-
return unless notion_token?
|
11
|
-
return unless config?
|
10
|
+
return unless notion_token? && config?
|
12
11
|
|
13
12
|
read_notion_database
|
14
13
|
end
|
15
14
|
|
16
15
|
def read_notion_database
|
17
|
-
@db = NotionDatabase.new(config
|
18
|
-
@db.pages do |page|
|
16
|
+
@db = NotionDatabase.new(:config => config)
|
17
|
+
@db.pages.each do |page|
|
19
18
|
@current_page = page
|
20
19
|
collection.docs << make_page
|
21
|
-
Jekyll.logger.info(
|
20
|
+
Jekyll.logger.info("Jekyll Notion:", "New notion page at #{collection.docs.last.path}")
|
22
21
|
end
|
23
22
|
end
|
24
23
|
|
25
24
|
def make_page
|
26
25
|
new_post = DocumentWithoutAFile.new(
|
27
26
|
"#{Dir.pwd}/_#{collection_name}/#{make_filename}",
|
28
|
-
{ site
|
27
|
+
{ :site => @site, :collection => collection }
|
29
28
|
)
|
30
29
|
new_post.content = "#{make_frontmatter}\n\n#{make_md}"
|
31
30
|
new_post.read
|
@@ -33,22 +32,27 @@ module JekyllNotion
|
|
33
32
|
end
|
34
33
|
|
35
34
|
def make_md
|
36
|
-
NotionToMd::Converter.new(page_id
|
35
|
+
NotionToMd::Converter.new(:page_id => current_page.id).convert
|
37
36
|
end
|
38
37
|
|
39
38
|
def make_frontmatter
|
40
39
|
<<~CONTENT
|
41
|
-
|
40
|
+
---
|
42
41
|
id: #{current_page.id}
|
43
42
|
title: #{current_page.title}
|
44
43
|
date: #{current_page.created_datetime}
|
45
44
|
cover: #{current_page.cover}
|
45
|
+
#{frontmatter}
|
46
46
|
---
|
47
47
|
CONTENT
|
48
48
|
end
|
49
49
|
|
50
|
+
def frontmatter
|
51
|
+
config.dig("database", "frontmatter").to_a.map { |k, v| "#{k}: #{v}" }.join('\n')
|
52
|
+
end
|
53
|
+
|
50
54
|
def make_filename
|
51
|
-
if collection_name ==
|
55
|
+
if collection_name == "posts"
|
52
56
|
"#{current_page.created_date}-#{current_page.title.downcase.parameterize}.md"
|
53
57
|
else
|
54
58
|
"#{current_page.title.downcase.parameterize}.md"
|
@@ -56,20 +60,20 @@ module JekyllNotion
|
|
56
60
|
end
|
57
61
|
|
58
62
|
def collection_name
|
59
|
-
config.dig(
|
63
|
+
config.dig("database", "collection") || "posts"
|
60
64
|
end
|
61
65
|
|
62
66
|
def collection
|
63
|
-
@site.
|
67
|
+
@collection ||= @site.collections[collection_name]
|
64
68
|
end
|
65
69
|
|
66
70
|
def config
|
67
|
-
@config ||= @site.config[
|
71
|
+
@config ||= @site.config["notion"] || {}
|
68
72
|
end
|
69
73
|
|
70
74
|
def notion_token?
|
71
|
-
if ENV[
|
72
|
-
Jekyll.logger.
|
75
|
+
if ENV["NOTION_TOKEN"].nil? || ENV["NOTION_TOKEN"].empty?
|
76
|
+
Jekyll.logger.warn("Jekyll Notion:", "NOTION_TOKEN not provided. Cannot read from Notion.")
|
73
77
|
return false
|
74
78
|
end
|
75
79
|
true
|
@@ -77,7 +81,7 @@ module JekyllNotion
|
|
77
81
|
|
78
82
|
def config?
|
79
83
|
if config.empty?
|
80
|
-
Jekyll.logger.
|
84
|
+
Jekyll.logger.warn("Jekyll Notion:", "No config provided.")
|
81
85
|
return false
|
82
86
|
end
|
83
87
|
true
|
@@ -7,36 +7,43 @@ module JekyllNotion
|
|
7
7
|
@config = config
|
8
8
|
end
|
9
9
|
|
10
|
-
def pages
|
10
|
+
def pages
|
11
|
+
return [] unless id?
|
12
|
+
|
11
13
|
@pages ||= @notion.database_query(query)[:results].map do |page|
|
12
|
-
NotionPage.new(page
|
14
|
+
NotionPage.new(:page => page, :layout => config["layout"])
|
13
15
|
end
|
14
|
-
|
15
|
-
return @pages unless block_given?
|
16
|
-
|
17
|
-
@pages.each(&block)
|
18
16
|
end
|
19
17
|
|
20
18
|
private
|
21
19
|
|
22
20
|
def config
|
23
|
-
@config[
|
21
|
+
@config["database"]
|
24
22
|
end
|
25
23
|
|
26
24
|
def filter
|
27
|
-
@config.dig(
|
25
|
+
@config.dig("database", "filter")
|
28
26
|
end
|
29
27
|
|
30
28
|
def sort
|
31
|
-
@config.dig(
|
29
|
+
@config.dig("database", "sort")
|
32
30
|
end
|
33
31
|
|
34
32
|
def id
|
35
|
-
@config.dig(
|
33
|
+
@config.dig("database", "id")
|
34
|
+
end
|
35
|
+
|
36
|
+
def id?
|
37
|
+
if id.nil? || id.empty?
|
38
|
+
Jekyll.logger.warn("Jekyll Notion:",
|
39
|
+
"database id is not provided. Cannot read from Notion.")
|
40
|
+
return false
|
41
|
+
end
|
42
|
+
true
|
36
43
|
end
|
37
44
|
|
38
45
|
def query
|
39
|
-
{ id
|
46
|
+
{ :id => id, :filter => filter, :sort => sort }
|
40
47
|
end
|
41
48
|
end
|
42
49
|
end
|
@@ -10,7 +10,7 @@ module JekyllNotion
|
|
10
10
|
end
|
11
11
|
|
12
12
|
def title
|
13
|
-
page.dig(:properties, :Name, :title).inject(
|
13
|
+
page.dig(:properties, :Name, :title).inject("") do |acc, slug|
|
14
14
|
acc + slug[:plain_text]
|
15
15
|
end
|
16
16
|
end
|
@@ -32,7 +32,7 @@ module JekyllNotion
|
|
32
32
|
end
|
33
33
|
|
34
34
|
def created_datetime
|
35
|
-
DateTime.parse(page[
|
35
|
+
DateTime.parse(page["created_time"])
|
36
36
|
end
|
37
37
|
|
38
38
|
def updated_date
|
@@ -40,7 +40,7 @@ module JekyllNotion
|
|
40
40
|
end
|
41
41
|
|
42
42
|
def updated_datetime
|
43
|
-
DateTime.parse(page[
|
43
|
+
DateTime.parse(page["last_edited_time"])
|
44
44
|
end
|
45
45
|
|
46
46
|
def url
|
data/lib/jekyll-notion.rb
CHANGED
@@ -1,20 +1,20 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
-
require
|
4
|
-
require
|
5
|
-
require
|
6
|
-
require
|
7
|
-
require
|
8
|
-
require
|
3
|
+
require "jekyll"
|
4
|
+
require "notion"
|
5
|
+
require "notion_to_md"
|
6
|
+
require "logger"
|
7
|
+
require "active_support/inflector"
|
8
|
+
require "jekyll-notion/generator"
|
9
9
|
|
10
10
|
NotionToMd::Logger.level = Logger::ERROR
|
11
11
|
|
12
12
|
Notion.configure do |config|
|
13
|
-
config.token = ENV[
|
13
|
+
config.token = ENV["NOTION_TOKEN"]
|
14
14
|
end
|
15
15
|
|
16
16
|
module JekyllNotion
|
17
|
-
autoload :DocumentWithoutAFile,
|
18
|
-
autoload :NotionDatabase,
|
19
|
-
autoload :NotionPage,
|
17
|
+
autoload :DocumentWithoutAFile, "jekyll-notion/document_without_a_file"
|
18
|
+
autoload :NotionDatabase, "jekyll-notion/notion_database"
|
19
|
+
autoload :NotionPage, "jekyll-notion/notion_page"
|
20
20
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: jekyll-notion
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0.0.
|
4
|
+
version: 0.0.0.pre
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Enrique Arias
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2022-01-
|
11
|
+
date: 2022-01-19 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activesupport
|
@@ -86,6 +86,34 @@ dependencies:
|
|
86
86
|
- - "~>"
|
87
87
|
- !ruby/object:Gem::Version
|
88
88
|
version: '2'
|
89
|
+
- !ruby/object:Gem::Dependency
|
90
|
+
name: rspec
|
91
|
+
requirement: !ruby/object:Gem::Requirement
|
92
|
+
requirements:
|
93
|
+
- - "~>"
|
94
|
+
- !ruby/object:Gem::Version
|
95
|
+
version: '3.0'
|
96
|
+
type: :development
|
97
|
+
prerelease: false
|
98
|
+
version_requirements: !ruby/object:Gem::Requirement
|
99
|
+
requirements:
|
100
|
+
- - "~>"
|
101
|
+
- !ruby/object:Gem::Version
|
102
|
+
version: '3.0'
|
103
|
+
- !ruby/object:Gem::Dependency
|
104
|
+
name: rubocop-jekyll
|
105
|
+
requirement: !ruby/object:Gem::Requirement
|
106
|
+
requirements:
|
107
|
+
- - "~>"
|
108
|
+
- !ruby/object:Gem::Version
|
109
|
+
version: 0.12.0
|
110
|
+
type: :development
|
111
|
+
prerelease: false
|
112
|
+
version_requirements: !ruby/object:Gem::Requirement
|
113
|
+
requirements:
|
114
|
+
- - "~>"
|
115
|
+
- !ruby/object:Gem::Version
|
116
|
+
version: 0.12.0
|
89
117
|
description:
|
90
118
|
email:
|
91
119
|
- emoriarty81@gmail.com
|