feat: 更新valine方案

This commit is contained in:
neo 2021-03-19 00:27:23 +08:00
parent 69316d469d
commit 9aa504c325
7 changed files with 80 additions and 47 deletions

View File

@ -1,42 +0,0 @@
import { IApi } from 'dumi';
export default (api: IApi) => {
api.describe({
key: 'valine',
config: {
schema(joi) {
return joi.object();
},
},
});
const { valine = {} } = api.userConfig;
const { appId, appKey, el = '#vcomments' } = valine || {};
api.logger.log('insert Valine');
const valineScript = () => {
return `
(function(){
var script = document.createElement('script');
var m = document.getElementsByTagName('script')[0];
script.src = '//unpkg.com/valine/dist/Valine.min.js';
script.async = 'async';
script.addEventListener('load', function () {
new Valine({
el: '${el}',
appId: '${appId}',
appKey: '${appKey}'
})
}, false);
m.parentNode.insertBefore(script, m)
})();
`;
};
api.addHTMLScripts(() => [
{
content: valineScript(),
},
]);
};

View File

@ -5,6 +5,7 @@ import Navbar from 'dumi-theme-default/src/components/Navbar';
import SideMenu from 'dumi-theme-default/src/components/SideMenu';
import SlugList from 'dumi-theme-default/src/components/SlugList';
import SearchBar from 'dumi-theme-default/src/components/SearchBar';
import { ValineComment } from 'dumi';
import Notice from './Notice';
import './style/layout.less';
@ -117,7 +118,7 @@ const Layout: React.FC<IRouteComponentProps> = ({ children, location }) => {
{updatedTime}
</span>
</div>
<div id="vcomments"></div>
<ValineComment location={location} />
</>
)}
{(showHero || showFeatures) && meta.footer && (

View File

@ -0,0 +1,21 @@
import { useEffect } from 'react';
import Valine from 'valine';
export function ValineComment({ location }) {
const { pathname } = location;
useEffect(() => {
import('valine').then(Valine => {
console.log(Valine)
new Valine.default({
el: '{{{ el }}}',
appId: '{{{ appId }}}',
appKey: '{{{ appKey }}}'
})
})
}, [pathname])
return (
<div id="vcomments"/>
)
}

View File

@ -0,0 +1,52 @@
import { IApi } from 'dumi';
import { join } from 'path';
import { readFileSync } from 'fs';
export default (api: IApi) => {
const {
paths,
utils: { Mustache, winPath, lodash },
} = api;
api.describe({
key: 'valine',
config: {
default: {
el: '#vcomments',
appId: '',
appKey: '',
},
schema(joi) {
return joi.object({
el: joi.string(),
appId: joi.string(),
appKey: joi.string(),
});
},
},
});
// 生成临时文件
api.onGenerateFiles(async () => {
// Comment.tsx
const selectLang = readFileSync(join(__dirname, 'Comment.tpl'), 'utf-8');
const { appId, appKey, el = '#vcomments' } = api.userConfig.valine;
api.writeTmpFile({
path: 'plugin-valine/Comment.tsx',
content: Mustache.render(selectLang, {
el: el,
appId: appId,
appKey: appKey,
}),
});
});
api.addUmiExports(() => {
return {
exportAll: true,
source: `../plugin-valine/Comment`,
};
});
};

View File

@ -91,7 +91,7 @@ export default defineConfig({
appId: 'Ke6Uq74Gi6sdTxcDu4nJ6sdw-MdYXbMMI',
appKey: 'VtFD26towQ1JQxB9tLHd8odg',
},
plugins: ['./.dumi/theme/comment.ts'],
plugins: ['./.dumi/theme/plugin-valine/index.ts'],
exportStatic: {},
// more config: https://d.umijs.org/config
});

View File

@ -8,8 +8,8 @@ order: 4
遇到解决不了的问题,先删除`homebrew`目录再重新运行脚本安装。
- x86 上安装目录: /usr/local/Homebrew/
- arm 上安装目录: /opt/homebrew
- x86 上安装目录: `/usr/local/Homebrew/`
- arm 上安装目录: `/opt/homebrew`
## M1 芯片 Mac 如何安装

View File

@ -46,6 +46,7 @@
},
"dependencies": {
"@ant-design/icons": "^4.5.0",
"antd": "^4.13.1"
"antd": "^4.13.1",
"valine": "^1.4.14"
}
}