forked from sonyboy232/better-docs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
component.js
109 lines (102 loc) · 3.18 KB
/
component.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
var reactDocs = require('react-docgen')
var vueDocs = require('vue-docgen-api')
var fs = require('fs')
var path = require('path')
exports.handlers = {
beforeParse: function(e) {
if (path.extname(e.filename) === '.vue') {
e.componentInfo = vueDocs.parse(e.filename)
var script = e.source.match(new RegExp('<script>(.*?)</script>', 's'))
e.source = script[1]
}
},
newDoclet: function({ doclet }) {
var filePath = path.join(doclet.meta.path, doclet.meta.filename)
const componentTag = (doclet.tags || []).find(tag => tag.title === 'component')
if (componentTag) {
if (path.extname(filePath) === '.vue') {
doclet.component = parseVue(filePath, doclet)
doclet.component.type = 'vue'
} else {
doclet.component = parseReact(filePath, doclet)
doclet.component.type = 'react'
}
doclet.kind = 'class'
} else {
if (path.extname(filePath) === '.vue') {
const docGen = vueDocs.parse(filePath)
const name = docGen.displayName
if (doclet.kind === 'function' || doclet.kind === 'event') {
doclet.memberof = name
} else {
doclet.undocumented = true
}
}
if (path.extname(filePath) === '.jsx') {
if (doclet.kind !== 'function' && doclet.kind !== 'event') {
doclet.undocumented = true
}
}
}
}
}
var parseReact = function (filePath, doclet) {
if (path.extname(filePath) === '.tsx') {
return {
props: [],
displayName: doclet.name,
filePath: filePath,
}
}
var src = fs.readFileSync(filePath, 'UTF-8')
var docGen
try {
docGen = reactDocs.parse(src, reactDocs.resolver.findAllComponentDefinitions)
} catch (error) {
if (error.message === 'No suitable component definition found.') {
return {
props: [],
filePath: filePath,
displayName: doclet.name,
}
} else {
throw error
}
}
return {
props: Object.entries(docGen.props || {}).map(([key, prop]) => ({
name: key,
description: prop.description,
type: prop.type ? prop.type.name : prop.flowType.name,
required: typeof prop.required === 'boolean' && prop.required,
defaultValue: prop.defaultValue
? (prop.defaultValue.computed ? 'function()' : prop.defaultValue.value)
: undefined
})),
displayName: docGen.displayName,
filePath: filePath,
}
}
var parseVue = function (filePath, doclet) {
const docGen = vueDocs.parse(filePath)
doclet.name = doclet.longname = docGen.displayName
return {
displayName: docGen.displayName,
filePath: filePath,
props: Object.values(docGen.props || {}).map(prop => ({
name: prop.name,
description: prop.description,
type: prop.type ? prop.type.name : prop.flowType.name,
required: typeof prop.required === 'boolean' && prop.required,
defaultValue: prop.defaultValue
? (prop.defaultValue.func ? 'function()' : prop.defaultValue.value)
: undefined
})),
slots: Object.keys(docGen.slots || {}).map(key => ({
name: key,
description: docGen.slots[key].description,
}))
}
}
exports.parseVue = parseVue
exports.parseReact = parseReact