markdown-magic 3.0.2 → 3.0.4

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.
Files changed (40) hide show
  1. package/README.md +295 -101
  2. package/cli.js +4 -1
  3. package/lib/block-parser.js +32 -28
  4. package/lib/block-parser.test.js +2 -0
  5. package/lib/cli.js +101 -22
  6. package/lib/cli.test.js +12 -12
  7. package/lib/index.js +418 -119
  8. package/lib/process-contents.js +59 -23
  9. package/lib/process-file.js +39 -4
  10. package/lib/transforms/code.js +33 -10
  11. package/lib/transforms/file.js +4 -2
  12. package/lib/transforms/index.js +114 -0
  13. package/lib/transforms/sectionToc.js +2 -2
  14. package/lib/transforms/toc.js +22 -4
  15. package/lib/transforms/wordCount.js +2 -2
  16. package/lib/utils/fs.js +8 -172
  17. package/lib/utils/fs.test.js +4 -162
  18. package/lib/utils/hash-file.js +28 -0
  19. package/lib/utils/logs.js +16 -2
  20. package/lib/utils/syntax.js +1 -0
  21. package/lib/utils/text.js +1 -1
  22. package/lib/utils/toposort.js +131 -0
  23. package/package.json +4 -3
  24. package/lib/globals.d.ts +0 -66
  25. package/lib/utils/md/filters.js +0 -20
  26. package/lib/utils/md/find-code-blocks.js +0 -88
  27. package/lib/utils/md/find-date.js +0 -32
  28. package/lib/utils/md/find-frontmatter.js +0 -92
  29. package/lib/utils/md/find-frontmatter.test.js +0 -17
  30. package/lib/utils/md/find-html-tags.js +0 -105
  31. package/lib/utils/md/find-images-md.js +0 -27
  32. package/lib/utils/md/find-images.js +0 -107
  33. package/lib/utils/md/find-links.js +0 -220
  34. package/lib/utils/md/find-unmatched-html-tags.js +0 -32
  35. package/lib/utils/md/fixtures/2022-01-22-date-in-filename.md +0 -14
  36. package/lib/utils/md/fixtures/file-with-frontmatter.md +0 -32
  37. package/lib/utils/md/fixtures/file-with-links.md +0 -153
  38. package/lib/utils/md/md.test.js +0 -105
  39. package/lib/utils/md/parse.js +0 -146
  40. package/lib/utils/md/utils.js +0 -19
@@ -1,220 +0,0 @@
1
- const { onlyUnique, isImage, isRelative } = require('./filters')
2
- const { findMarkdownImages } = require('./find-images-md')
3
- // Alt https://github.com/MikeKovarik/link-extract
4
-
5
- // https://regex101.com/r/In5HtG/3
6
- // const LIVE_LINKS_REGEX = /(?:['"(])((?:https?:\/\/)[\w\d\-_,./?=#%:+&]{3,})/gmi
7
- // https://regex101.com/r/In5HtG/4
8
- const LIVE_LINKS_REGEX = /['"(]((?:https?:\/\/)[\w\d\-_,./?=#%:+&]{3,})|<(\S*:\/\/\S*)>/gmi
9
- // https://regex101.com/r/Nywerx/3
10
- const RELATIVE_LINKS_REGEX = /(src|href|\()=?(['"/])(?!(?:(?:https?|ftp):\/\/|data:))(\.?\/)?([\w\d-_./,?=#%:+&]+)(?:['")])?/gim
11
- // https://regex101.com/r/u2DwY2/2/
12
- const MARKDOWN_IMAGE_REGEX = /!\[[^\]]*\]\((.*?)\s*("(?:.*[^"])")?\s*\)/g
13
- // https://regex101.com/r/UeQ049/2 <https://www.markdownguide.org>
14
- const ANGLE_LINKS = /(<)(\S*[@:]\S*)(>)/
15
-
16
- const LINK_PATTERN = /^https?:\/\//
17
-
18
- function isLocal(link) {
19
- return isRelative(link)
20
- }
21
-
22
- function isRemote(link) {
23
- return !isRelative(link)
24
- }
25
-
26
- /**
27
- * @typedef {object} findLinksOpts
28
- * @property {Record<string,any>} [frontmatter] - Frontmatter data
29
- * @property {boolean} [unique=true] - ensure links unique
30
- */
31
-
32
- /**
33
- * @typedef {object} findLinksResult
34
- * @property {string[]} links - All images
35
- * @property {string[]} images - All live image links
36
- */
37
-
38
- /**
39
- * Finds all links in text relative or otherwise
40
- * @param {string} text
41
- * @param {findLinksOpts} opts
42
- * @returns {findLinksResult}
43
- */
44
- function findLinks(text, opts = {}) {
45
- const { unique = true, frontmatter } = opts
46
-
47
- const absoluteLinks = findAbsoluteLinks(text)
48
- // console.log('absoluteLinks', absoluteLinks)
49
- const relativeLinks = findRelativeLinks(text)
50
- // console.log('relativeLinks', relativeLinks)
51
- const frontmatterLinks = (frontmatter) ? findLinksInFrontMatter(frontmatter) : []
52
- // console.log('frontmatterLinks', frontmatterLinks)
53
- const markdownImages = findMarkdownImages(text)
54
- // console.log('markdownImages', markdownImages)
55
- const foundLinks = frontmatterLinks
56
- .concat(absoluteLinks)
57
- .concat(relativeLinks)
58
- .concat(markdownImages)
59
-
60
- const allLinks = (!unique) ? foundLinks : foundLinks.filter(onlyUnique)
61
-
62
- let _images = markdownImages
63
- let _links = []
64
- for (let i = 0; i < allLinks.length; i++) {
65
- if (isImage(allLinks[i])) {
66
- _images.push(allLinks[i])
67
- } else {
68
- _links.push(allLinks[i])
69
- }
70
- }
71
- // const allImages = normalLinks.filter((link) => isImage(link)).concat(mdLinks)
72
- // const links = normalLinks.filter((link) => !isImage(link))
73
- const images = _images.filter(onlyUnique)
74
- const links = _links.filter(onlyUnique).filter(function(el) {
75
- return images.indexOf(el) < 0
76
- })
77
-
78
- return {
79
- links,
80
- images
81
- }
82
- /*
83
- // Old return https://github.com/DavidWells/markdown-magic/blob/b148b4ad3876c4ea07371451d230a5e9cec57ce5/lib/utils/md/find-links.js#L32-L44
84
- return {
85
- // all,
86
- // live,
87
- // relative,
88
- // frontmatter: frontmatterLinks,
89
- links: {
90
- all: allLink,
91
- relative: allLink.filter(isLocal),
92
- live: allLink.filter(isRemote)
93
- },
94
- images: {
95
- all: allImg,
96
- relative: allImg.filter(isLocal),
97
- live: allImg.filter(isRemote)
98
- },
99
- }
100
- */
101
- }
102
-
103
- function findMarkdownImageLinks(text) {
104
- let matches
105
- let imageLinks = []
106
- while ((matches = MARKDOWN_IMAGE_REGEX.exec(text)) !== null) {
107
- if (matches.index === MARKDOWN_IMAGE_REGEX.lastIndex) {
108
- MARKDOWN_IMAGE_REGEX.lastIndex++ // avoid infinite loops with zero-width matches
109
- }
110
- const [ match, image, altText ] = matches
111
- imageLinks.push(image)
112
- }
113
- return imageLinks.filter(onlyUnique)
114
- }
115
-
116
- /**
117
- * Finds all links in markdown <a>, <img> and md link format []()
118
- * @param {string} text
119
- * @returns
120
- */
121
- function findAbsoluteLinks(text) {
122
- let matches
123
- let links = []
124
- while ((matches = LIVE_LINKS_REGEX.exec(text)) !== null) {
125
- if (matches.index === LIVE_LINKS_REGEX.lastIndex) {
126
- LIVE_LINKS_REGEX.lastIndex++ // avoid infinite loops with zero-width matches
127
- }
128
- const [ match, url, bracketLink ] = matches
129
- links.push(url || bracketLink)
130
- }
131
- return links.filter(onlyUnique)
132
- }
133
-
134
- /*
135
- Match relative links
136
- <h1 jdjdjjdjd=lksjskljfsdlk="jdjdj">Netlify + FaunaDB &nbsp;&nbsp;&nbsp;
137
- <a href="https://app.netlify.com/start/deploy?repository=https://github.com/netlify/netlify-faunadb-example&stack=fauna">
138
- <img src="../../../../img/deploy/lol.svg">
139
- </a>
140
- </h1>
141
- [link](/my-great-page)
142
- <a href="img/deploy/one.svg">cool</a>
143
- <img src="img/deploy/duplicate.svg" />
144
- <img src="img/deploy/duplicate.svg" >
145
- <img src="/img/deploy/three.svg" />
146
- <img src='/img/deploy/four.svg' />
147
- <img src='./img/deploy/five.svg' />
148
- <img src='../img/deploy/button.svg' />
149
- <img src='../../img/deploy/button.svg' />
150
- <img src="https://www.netlify.com/img/deploy/button.svg" />
151
- <img src="https://www.netlify.com/img/deploy/button.svg" />
152
- ![The San Juan Mountains are beautiful!](/assets/images/san-juan-mountains.jpg "San Juan Mountains")
153
- */
154
-
155
- function findRelativeLinks(text) {
156
- let matches
157
- let relLinks = []
158
- while ((matches = RELATIVE_LINKS_REGEX.exec(text)) !== null) {
159
- if (matches.index === RELATIVE_LINKS_REGEX.lastIndex) {
160
- RELATIVE_LINKS_REGEX.lastIndex++ // avoid infinite loops with zero-width matches
161
- }
162
- // console.log(matches)
163
- const [ match, _, start, link, x ] = matches
164
- const one = (start === '/') ? start : ''
165
- const two = (link === '/') ? link : ''
166
- relLinks.push(`${one}${two}${x}`)
167
- }
168
- return relLinks.filter(onlyUnique)
169
- }
170
-
171
- function findLinksInFrontMatter(data) {
172
- const yamlStrings = traverse(data)
173
- // console.log('yamlStrings', yamlStrings)
174
- const linksInYml = yamlStrings.map((string) => {
175
- if (LINK_PATTERN.test(string)) {
176
- return [string]
177
- }
178
- // console.log('string', string)
179
- const results = findLinks(string)
180
- return results.links.concat(results.images)
181
- })
182
- .filter((x) => {
183
- if (x && x.length) {
184
- return x.length
185
- }
186
- return false
187
- })
188
- .flat()
189
- // console.log('linksInYml', linksInYml)
190
- return linksInYml
191
- }
192
-
193
- function traverse(x, arr = []) {
194
- if (typeof x === 'string') {
195
- arr.push(x)
196
- } else if (Array.isArray(x)) {
197
- traverseArray(x, arr)
198
- } else if ((typeof x === 'object') && (x !== null)) {
199
- traverseObject(x, arr)
200
- }
201
- return arr
202
- }
203
- function traverseArray(arr, acc) {
204
- for (let i = 0; i < arr.length; i++) {
205
- traverse(arr[i], acc)
206
- }
207
- }
208
- function traverseObject(obj, acc) {
209
- for (var key in obj) {
210
- if (obj.hasOwnProperty(key)) {
211
- traverse(obj[key], acc)
212
- }
213
- }
214
- }
215
-
216
- module.exports = {
217
- findLinks,
218
- findAbsoluteLinks,
219
- findRelativeLinks
220
- }
@@ -1,32 +0,0 @@
1
- const { getLineNumberFromMatch } = require('./utils')
2
-
3
- // https://regex101.com/r/he9l06/2
4
- // http://xahlee.info/js/html5_non-closing_tag.html
5
- // voidTags
6
- const CLOSE_TAG_REGEX = /<(br|hr|img|embed|col|link|meta)(([^>]*)([^/])(>)|>)/g
7
-
8
- function findUnmatchedHtmlTags(block, filePath) {
9
- let matches
10
- let errors = []
11
- const msg = (filePath) ? ` in ${filePath}` : ''
12
- while ((matches = CLOSE_TAG_REGEX.exec(block)) !== null) {
13
- if (matches.index === CLOSE_TAG_REGEX.lastIndex) {
14
- CLOSE_TAG_REGEX.lastIndex++ // avoid infinite loops with zero-width matches
15
- }
16
- // console.log(matches)
17
- const [ _, tag, insideOrEnd ] = matches
18
- const lineNumber = getLineNumberFromMatch(block, matches)
19
- const fixed = (insideOrEnd === '>') ? '/>' : `${insideOrEnd.substring(0, insideOrEnd.length - 1)}/>`
20
- errors.push({
21
- message: `Unclosing HTML tag on line ${lineNumber}${msg}.\n Need closing tag "/>" on: \n${_}`,
22
- brokenTag: _,
23
- correctUsage: `<${tag}${fixed}`
24
- })
25
- }
26
- return errors
27
- }
28
-
29
- module.exports = {
30
- CLOSE_TAG_REGEX,
31
- findUnmatchedHtmlTags,
32
- }
@@ -1,14 +0,0 @@
1
- ---
2
- title: Welcome to ABC
3
- description: 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'
4
- thumbnail: https://dope-frontmatter.com/img/deploy/button.svg
5
- categories:
6
- - company
7
- authors:
8
- - Bob Bob
9
- - Joe Smoe
10
- ---
11
-
12
- **Welcome to ABC!** Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur [keynote presentation](https://youtu.be/A1bL4pHuivU).
13
-
14
-
@@ -1,32 +0,0 @@
1
- ---
2
- draft: true
3
- template: page
4
- path: /foo/bar
5
- title: Default title
6
- components:
7
- - type: PageHeading
8
- heading: Nice
9
- subHeading: Add it
10
- - type: content
11
- content: >-
12
- Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur
13
-
14
-
15
- Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur
16
- - type: content
17
- content: |-
18
- More content
19
-
20
- <ComponentXyz />
21
-
22
- stuff
23
-
24
- ---
25
- - type: content
26
- content: Even more content
27
- seo:
28
- title: xyz
29
- description: seo description here
30
- updatedBy: David Wells
31
- updatedAt: 2022-11-10T01:52:37.383Z
32
- ---
@@ -1,153 +0,0 @@
1
- ---
2
- title: Welcome to ABC
3
- description: 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'
4
- date: '2020-06-30'
5
- thumbnail: https://dope-frontmatter.com/img/deploy/button.svg
6
- components:
7
- - type: PageHeading
8
- heading: Nice
9
- subHeading: Add it
10
- - type: content
11
- content: >-
12
- Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur
13
-
14
- <a href="https://funky-frontmatter.com">funky</a>
15
-
16
- <img src='/img/in-nested-frontmatter/button.svg' />
17
-
18
- ![The San Juan Mountains are beautiful!](/assets/images/lol-frontmatter.jpg)
19
-
20
- <img src='https://frontmatter.com/img/deploy/button.svg' />
21
-
22
- we've created a [detailed blog post](https://www.front.com/blog/open-beta-changes) to help those with the migration process. We're confident these changes, once released, will make for a significantly better experience for current and future users.
23
- categories:
24
- - company
25
- authors:
26
- - Bob Bob
27
- - Joe Smoe
28
- ---
29
-
30
- **Welcome to ABC!** Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur [keynote presentation](https://youtu.be/A1bL4pHuivU).
31
-
32
- <img src='/img/deploy/button.svg' />
33
-
34
- <img src='./img/deploy/button.svg' />
35
-
36
- <img src='../img/deploy/button.svg' />
37
-
38
- <img src="https://www.netlify.com/img/deploy/button.svg" />
39
-
40
- <img src="https://www.netlify.com/img/deploy/button.svg" />
41
-
42
- <img src='https://fooo.com/img/deploy/button.svg' />
43
-
44
- ![The San Juan Mountains are beautiful!](/assets/images/lol.jpg)
45
-
46
- ![The San Juan Mountains are beautiful!](assets/images/san-juan-mountains.jpg)
47
-
48
- ![](https://res.cloudinary.com/ABC/image/upload/f_auto,q_auto/c_fill,w_1200/v1668114635/what-you-can-build_p8uape.png)
49
-
50
- ![](https://avatars2.githubusercontent.com/u/532272?v=3&s=400)
51
-
52
- This is the weird markdown link syntax <https://foooooooooooo.com>
53
-
54
- this is less than sign
55
-
56
- Hear Bob Bobster discuss the evolution of Serverless and the launch of ABC at the AWS Serverless Community Day.
57
-
58
- <iframe width="560" height="315" src="https://www.youtube.com/embed/KX7tj3giizI" frameBorder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowFullScreen></iframe>
59
-
60
- <a href="https://app.netlify.com/start/deploy">
61
- <img src="/img/deploy/button.svg">
62
- </a>
63
-
64
- <a href="/foobar">
65
- <img src="/img/deploy/button.svg">
66
- </a>
67
-
68
-
69
- <a href="https://www.yoursite.com/pricing?utm_source=active%20users&utm_medium=email&utm_campaign=feature%20launch&utm_content=bottom%20cta%20button">
70
- Utm params link
71
- </a>
72
-
73
-
74
- Title xyz
75
- ============================
76
-
77
- Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est, qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt ut labore et dolore magnam aliquam quaerat voluptatem
78
-
79
- Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est, qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt ut labore et dolore magnam aliquam quaerat voluptatem
80
-
81
- Legacy Alternatives
82
- ===================
83
-
84
- It vero eos et accusamus et iusto odio dignissimos ducimus qui blanditiis praesentium voluptatum deleniti atque corrupti quos dolores et quas molestias excepturi sint occaecati cupiditate non provident, similique sunt in culpa qui officia deserunt mollitia animi, id est laborum et dolorum fuga. Et harum quidem rerum facilis est et expedita distinctio. Nam libero tempore, cum soluta nobis est eligendi optio cumque nihil impedit quo minus id
85
-
86
- Escaping the "Single Box" Blockchain Limitation
87
- ===============================================
88
-
89
- Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est, qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt ut labore et dolore magnam aliquam quaerat voluptatem.
90
-
91
- <Author foo='bar' foo='bing'>
92
- <Child />
93
- </Author>
94
-
95
- ```graphql
96
- mutation _files__add($input: ABC_File_Input_!, $syncMode: ABC_SyncMode = NODE_COMMITTED)
97
- ```
98
-
99
- To override the default, include the `syncMode` option as such:
100
-
101
- ```js
102
- /* Hello there */
103
- const response = await entities.product.add(
104
- {
105
- name: 'super-widget',
106
- inventory: 100,
107
- },
108
- {
109
- syncMode: 'ASYNC', <-- example syncMode instruction
110
- }
111
- );
112
-
113
- console.log(response?.transaction?.transactionId);
114
- console.log(response?.transaction?._id);
115
- ```
116
-
117
- Title xyz
118
- ===========================
119
-
120
- At vero eos et accusamus et iusto odio dignissimos ducimus qui blanditiis praesentium voluptatum deleniti atque corrupti quos dolores et quas molestias excepturi sint occaecati cupiditate non provident, similique sunt in culpa qui officia deserunt mollitia animi, id est laborum et dolorum fuga. Et harum quidem rerum facilis est et expedita distinctio. Nam libero tempore, cum soluta nobis est eligendi optio cumque nihil impedit quo minus id quod maxime placeat facere possimus, omnis voluptas assumenda est, omnis dolor repellendus. Temporibus autem quibusdam et aut officiis debitis aut rerum necessitatibus saepe eveniet ut et voluptates repudiandae sint et molestiae non recusandae. Itaque earum rerum hic tenetur a sapiente delectus, ut aut reiciendis voluptatibus maiores alias consequatur aut perferendis doloribus asperiores repellat
121
-
122
- At vero eos et accusamus et iusto odio dignissimos ducimus qui blanditiis praesentium voluptatum deleniti atque corrupti quos dolores et quas molestias excepturi sint occaecati cupiditate non provident, similique sunt in culpa qui officia deserunt mollitia animi, id est laborum et dolorum fuga. Et harum quidem rerum facilis est et expedita distinctio. Nam libero tempore, cum soluta nobis est eligendi optio cumque nihil impedit quo minus id quod maxime placeat facere possimus, omnis voluptas assumenda est, omnis dolor repellendus. Temporibus autem quibusdam et aut officiis debitis aut rerum necessitatibus saepe eveniet ut et voluptates repudiandae sint et molestiae non recusandae. Itaque earum rerum hic tenetur a sapiente delectus, ut aut reiciendis voluptatibus maiores alias consequatur aut perferendis doloribus asperiores repellat
123
-
124
- <!-- doc-gen {{functionName}} foo={{ rad: 'yellow' }} -->
125
- xyz
126
- <!-- end-doc-gen -->
127
-
128
- Hello title
129
- =======================
130
-
131
- At vero eos et accusamus et iusto odio dignissimos ducimus qui blanditiis praesentium voluptatum deleniti atque corrupti quos dolores et quas molestias excepturi sint occaecati cupiditate non provident, similique sunt in culpa qui officia deserunt mollitia animi, id est laborum et dolorum fuga. Et harum quidem rerum facilis est et expedita distinctio. Nam libero tempore, cum soluta nobis est eligendi optio cumque nihil impedit quo minus id quod maxime placeat facere possimus, omnis voluptas assumenda est, omnis dolor repellendus. Temporibus autem quibusdam et aut officiis debitis aut rerum necessitatibus saepe eveniet ut et voluptates repudiandae sint et molestiae non recusandae. Itaque earum rerum hic tenetur a sapiente delectus, ut aut reiciendis voluptatibus maiores alias consequatur aut perferendis doloribus asperiores repellat remaining confident that their solutions will work on _any_ public cloud, not just a single vendor. Interested in experiencing it for yourself? [Sign up](https://ABC.com/sign-up) to join our preview access program, starting in late July.
132
-
133
-
134
- <!-- doc-gen {{functionName}}
135
- foo={{ rad: 'yellow' }}
136
- baz=bar
137
- fun=['array']
138
- -->
139
- xyz
140
- <!-- end-doc-gen -->
141
-
142
-
143
- We’re excited to be on this journey to help customers solve some of their greatest challenges by making code and data easier to share, protect, and secure. **Welcome to ABC and welcome to a new era of sharing made easy!**
144
-
145
- <Author
146
- arr={['one', 'two']}
147
- foo={{ "bar": true }}
148
- baz='string'
149
- />
150
-
151
- _Bob & Joe_
152
-
153
- _Looking for your next great opportunity?_ [_We’re hiring!_](http://jobs.ABC.net)
@@ -1,105 +0,0 @@
1
- const fs = require('fs')
2
- const path = require('path')
3
- const { test } = require('uvu')
4
- const assert = require('uvu/assert')
5
- const { deepLog } = require('../logs')
6
- const { parseMarkdown } = require('./parse')
7
- const { findLinks } = require('./find-links')
8
- const { parseFrontmatter } = require('./find-frontmatter')
9
-
10
- const FILE_PATH = path.join(__dirname, 'fixtures/file-with-links.md')
11
- // const FILE_PATH = path.join(__dirname, 'fixtures/2022-01-22-date-in-filename.md')
12
- const fileContents = fs.readFileSync(FILE_PATH, 'utf-8')
13
-
14
- test('parseMarkdown API', async () => {
15
- const res = parseMarkdown(fileContents, { filePath: FILE_PATH })
16
- assert.is(typeof res, 'object')
17
- assert.is(typeof res.ast, 'object')
18
- assert.is(typeof res.data, 'object')
19
- assert.is(typeof res.content, 'string')
20
- assert.is(typeof res.codeBlocks, 'object')
21
- assert.is(Array.isArray(res.errors), true)
22
- })
23
-
24
- test('Verify contents', async () => {
25
- const res = parseMarkdown(fileContents, {
26
- filePath: FILE_PATH
27
- })
28
- deepLog('Results:', res)
29
- assert.equal(res.links, [
30
- 'https://funky-frontmatter.com',
31
- 'https://www.front.com/blog/open-beta-changes',
32
- 'https://youtu.be/A1bL4pHuivU',
33
- 'https://foooooooooooo.com',
34
- 'https://www.youtube.com/embed/KX7tj3giizI',
35
- 'https://app.netlify.com/start/deploy',
36
- 'https://www.yoursite.com/pricing?utm_source=active%20users&utm_medium=email&utm_campaign=feature%20launch&utm_content=bottom%20cta%20button',
37
- 'https://ABC.com/sign-up',
38
- 'http://jobs.ABC.net',
39
- '/foobar'
40
- ])
41
- assert.equal(res.images, [
42
- '/assets/images/lol-frontmatter.jpg',
43
- '/assets/images/lol.jpg',
44
- 'assets/images/san-juan-mountains.jpg',
45
- 'https://res.cloudinary.com/ABC/image/upload/f_auto,q_auto/c_fill,w_1200/v1668114635/what-you-can-build_p8uape.png',
46
- 'https://avatars2.githubusercontent.com/u/532272?v=3&s=400',
47
- 'https://dope-frontmatter.com/img/deploy/button.svg',
48
- 'https://frontmatter.com/img/deploy/button.svg',
49
- '/img/in-nested-frontmatter/button.svg',
50
- 'https://www.netlify.com/img/deploy/button.svg',
51
- 'https://fooo.com/img/deploy/button.svg',
52
- '/img/deploy/button.svg',
53
- 'img/deploy/button.svg',
54
- '../img/deploy/button.svg'
55
- ])
56
- })
57
-
58
- test('opts - includeAst false', async () => {
59
- const res = parseMarkdown(fileContents, {
60
- filePath: FILE_PATH,
61
- })
62
- // deepLog('Results:', res)
63
- assert.ok(Array.isArray(res.ast))
64
- /* Disable AST */
65
- const resTwo = parseMarkdown(fileContents, {
66
- filePath: FILE_PATH,
67
- includeAst: false,
68
- })
69
- // deepLog('Results two:', resTwo)
70
- assert.ok(typeof resTwo.ast === 'undefined')
71
- })
72
-
73
- test('opts - includeImages false', async () => {
74
- const res = parseMarkdown(fileContents, {
75
- filePath: FILE_PATH,
76
- // includeAst: false,
77
- includeImages: false,
78
- })
79
- deepLog('Results:', res)
80
- assert.ok(typeof res.links === 'object')
81
- assert.ok(typeof res.images === 'undefined')
82
- })
83
-
84
- test('opts - includeLinks false', async () => {
85
- const res = parseMarkdown(fileContents, {
86
- filePath: FILE_PATH,
87
- includeLinks: false,
88
- })
89
- deepLog('Results:', res)
90
- assert.ok(typeof res.links === 'undefined')
91
- assert.ok(typeof res.images === 'object')
92
- })
93
-
94
- // test('File have correct extensions', async () => {
95
- // const { data } = parseFrontmatter(fileWithLinks, FILE_PATH)
96
- // console.log('frontmatter data', data)
97
- // const links = findLinks(fileWithLinks, { frontmatter: data })
98
- // // console.log('links', links)
99
- // // console.log('FILE_PATH', FILE_PATH)
100
- // // console.log('parseMarkdown')
101
- // // const x = parseMarkdown(fileWithLinks, { filePath: FILE_PATH })
102
- // // deepLog(x)
103
- // })
104
-
105
- test.run()