mirror of
https://github.com/element-plus/element-plus.git
synced 2025-01-18 10:59:10 +08:00
87a16f24d3
* chore: add components-helper * docs: unified style * docs: unified style * docs: unified style * docs: unified style * chore: replace Accepted Values for icon * chore: delete vetur folder * chore: add components-helper * docs: unified style * docs: unified style * docs: unified style * docs: unified style * chore: replace Accepted Values for icon * chore: delete vetur folder
65 lines
2.3 KiB
JavaScript
65 lines
2.3 KiB
JavaScript
/* eslint-disable @typescript-eslint/no-var-requires */
|
|
const helper = require('components-helper')
|
|
const { name, version } = require('../package.json')
|
|
const icon = require('../website/icon.json')
|
|
const icons = icon.map(item => 'el-icon-' + item).join('/')
|
|
const tagVer = process.env.TAG_VERSION
|
|
const _version = tagVer ? tagVer.startsWith('v') ? tagVer.slice(1) : tagVer : version
|
|
|
|
helper({
|
|
name,
|
|
version: _version,
|
|
entry: 'website/docs/en-US/!(custom-theme|datetime-picker|i18n|installation|message-box|message|migration-from-2.x|notification|quickstart|transition|typography).md',
|
|
outDir: 'lib',
|
|
reComponentName,
|
|
reDocUrl,
|
|
reAttribute,
|
|
props: 'Attributes',
|
|
propsName: 'Attribute',
|
|
propsOptions: 'Accepted Values',
|
|
eventsName: 'Event Name',
|
|
tableRegExp: '#+\\s+(.*\\s*Attributes|.*\\s*Events|.*\\s*Slots|.*\\s*Directives)\\s*\\n+(\\|?.+\\|.+)\\n\\|?\\s*:?-+:?\\s*\\|.+((\\n\\|?.+\\|.+)+)',
|
|
})
|
|
|
|
function reComponentName(title) {
|
|
return 'el-' + title.replace(/\B([A-Z])/g, '-$1').replace(/[ ]+/g, '-').toLowerCase()
|
|
}
|
|
|
|
function reDocUrl(fileName, header) {
|
|
const docs = 'https://element-plus.org/#/en-US/component/'
|
|
const _header = header ? header.replace(/[ ]+/g, '-').toLowerCase() : undefined
|
|
return docs + fileName + (_header ? '#' + _header : '')
|
|
}
|
|
|
|
function reAttribute(value, key, item) {
|
|
const _value = value.match(/^\*\*(.*)\*\*$/)
|
|
const str = _value ? _value[1]: value
|
|
|
|
if (key === 'Accepted Values' && /icon/i.test(item[0])) {
|
|
return icons
|
|
} else if (key === 'Name' && /^(-|—)$/.test(str)) {
|
|
return 'default'
|
|
} else if (str === '' || /^(-|—)$/.test(str)) {
|
|
return undefined
|
|
} else if (key === 'Attribute' && /v-model:(.+)/.test(str)){
|
|
const _str = str.match(/v-model:(.+)/)
|
|
return _str ? _str[1] : undefined
|
|
} else if (key === 'Attribute' && /v-model/.test(str)) {
|
|
return 'model-value'
|
|
} else if (key === 'Attribute') {
|
|
return str.replace(/\B([A-Z])/g, '-$1').toLowerCase()
|
|
} else if (key === 'Type') {
|
|
return str
|
|
.replace(/\s*\/\s*/g, '|')
|
|
.replace(/\s*,\s*/g, '|')
|
|
.replace(/\(.*\)/g, '')
|
|
.toLowerCase()
|
|
} else if (key === 'Accepted Values') {
|
|
return /\[.+\]\(.+\)/.test(str) || /^\*$/.test(str)
|
|
? undefined
|
|
: str.replace(/`/g, '')
|
|
} else {
|
|
return str
|
|
}
|
|
}
|