2019-08-10

const path = require('path');
const CSSSplitWebpackPlugin = require('css-split-webpack-plugin').default;
const replaceLib = require('antd-tools/lib/replaceLib');

const isDev = process.env.NODE_ENV === 'development';
const usePreact = process.env.REACT_ENV === 'preact';

const ThemeColorReplacer = require('webpack-theme-color-replacer');
const { generate } = require('@ant-design/colors/lib');

function alertBabelConfig(rules) {
rules.forEach(rule => {
if (rule.loader && rule.loader === 'babel-loader') {
if (rule.options.plugins.indexOf(replaceLib) === -1) {
rule.options.plugins.push(replaceLib);
}
// eslint-disable-next-line
rule.options.plugins = rule.options.plugins.filter(
plugin => !plugin.indexOf || plugin.indexOf('babel-plugin-add-module-exports') === -1,
);
// Add babel-plugin-add-react-displayname
rule.options.plugins.push(require.resolve('babel-plugin-add-react-displayname'));
} else if (rule.use) {
alertBabelConfig(rule.use);
}
});
}

const getAntdSerials = color => {
const lightNum = 9;
const devide10 = 10; // 淡化(即less的tint)

const lightens = new Array(lightNum).fill(undefined).map((_, i) => {
return ThemeColorReplacer.varyColor.lighten(color, i / devide10);
});
const colorPalettes = generate(color);
return lightens.concat(colorPalettes);
};

module.exports = {
port: 8001,
hash: true,
source: {
components: './components',
docs: './docs',
changelog: ['CHANGELOG.zh-CN.md', 'CHANGELOG.en-US.md'],
},
theme: './site/theme',
htmlTemplate: './site/theme/static/template.html',
themeConfig: {
categoryOrder: {
'Ant Design': 0,
原則: 1,
Principles: 1,
視覺(jué): 2,
Visual: 2,
模式: 3,
Patterns: 3,
其他: 6,
Other: 6,
Components: 100,
},
typeOrder: {
General: 0,
Layout: 1,
Navigation: 2,
'Data Entry': 3,
'Data Display': 4,
Feedback: 5,
Other: 6,
Deprecated: 7,
通用: 0,
布局: 1,
導(dǎo)航: 2,
數(shù)據(jù)錄入: 3,
數(shù)據(jù)展示: 4,
反饋: 5,
其他: 6,
廢棄: 7,
},
docVersions: {
'0.9.x': 'http://09x.ant.design',
'0.10.x': 'http://010x.ant.design',
'0.11.x': 'http://011x.ant.design',
'0.12.x': 'http://012x.ant.design',
'1.x': 'http://1x.ant.design',
'2.x': 'http://2x.ant.design',
},
},
filePathMapper(filePath) {
if (filePath === '/index.html') {
return ['/index.html', '/index-cn.html'];
}
if (filePath.endsWith('/index.html')) {
return [filePath, filePath.replace(//index.html/, '-cn/index.html')]; } if (filePath !== '/404.html' && filePath !== '/index-cn.html') { return [filePath, filePath.replace(/\.html/, '-cn.html')];
}
return filePath;
},
doraConfig: {
verbose: true,
},
lessConfig: {
javascriptEnabled: true,
},
webpackConfig(config) {
// eslint-disable-next-line
config.resolve.alias = {
'antd/lib': path.join(process.cwd(), 'components'),
'antd/es': path.join(process.cwd(), 'components'),
antd: path.join(process.cwd(), 'index'),
site: path.join(process.cwd(), 'site'),
'react-router': 'react-router/umd/ReactRouter',
};

// eslint-disable-next-line
config.externals = {
  'react-router-dom': 'ReactRouterDOM',
};

if (usePreact) {
  // eslint-disable-next-line
  config.resolve.alias = Object.assign({}, config.resolve.alias, {
    react: 'preact-compat',
    'react-dom': 'preact-compat',
    'create-react-class': 'preact-compat/lib/create-react-class',
    'react-router': 'react-router',
  });
}

if (isDev) {
  // eslint-disable-next-line
  config.devtool = 'source-map';
}

alertBabelConfig(config.module.rules);

config.plugins.push(new CSSSplitWebpackPlugin({ size: 4000 }));
config.plugins.push(new ThemeColorReplacer({
  fileName: 'css/theme-colors-[contenthash:8].css',
  matchColors: getAntdSerials('#1890ff'),

  // 主色系列
  // 改變樣式選擇器,解決樣式覆蓋問(wèn)題
  changeSelector(selector) {
    switch (selector) {
      case '.ant-calendar-today .ant-calendar-date':
        return ':not(.ant-calendar-selected-date)' + selector;

      case '.ant-btn:focus,.ant-btn:hover':
        return '.ant-btn:focus:not(.ant-btn-primary),.ant-btn:hover:not(.ant-btn-primary)';

      case '.ant-btn.active,.ant-btn:active':
        return '.ant-btn.active:not(.ant-btn-primary),.ant-btn:active:not(.ant-btn-primary)';

      default:
        return selector;
    }
  },
}));
return config;

},

devServerConfig: {
public: process.env.DEV_HOST || 'localhost',
disableHostCheck: !!process.env.DEV_HOST,
},

htmlTemplateExtraData: {
isDev,
usePreact,
},
};

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末效床,一起剝皮案震驚了整個(gè)濱河市睹酌,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌剩檀,老刑警劉巖憋沿,帶你破解...
    沈念sama閱讀 218,640評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異沪猴,居然都是意外死亡辐啄,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,254評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)运嗜,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)壶辜,“玉大人,你說(shuō)我怎么就攤上這事担租≡颐瘢” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,011評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵奋救,是天一觀的道長(zhǎng)岭参。 經(jīng)常有香客問(wèn)我,道長(zhǎng)尝艘,這世上最難降的妖魔是什么演侯? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,755評(píng)論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮利耍,結(jié)果婚禮上蚌本,老公的妹妹穿的比我還像新娘盔粹。我一直安慰自己,他們只是感情好程癌,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,774評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布舷嗡。 她就那樣靜靜地躺著,像睡著了一般嵌莉。 火紅的嫁衣襯著肌膚如雪进萄。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,610評(píng)論 1 305
  • 那天锐峭,我揣著相機(jī)與錄音中鼠,去河邊找鬼。 笑死沿癞,一個(gè)胖子當(dāng)著我的面吹牛援雇,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播椎扬,決...
    沈念sama閱讀 40,352評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼惫搏,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了蚕涤?” 一聲冷哼從身側(cè)響起筐赔,我...
    開(kāi)封第一講書(shū)人閱讀 39,257評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎揖铜,沒(méi)想到半個(gè)月后茴丰,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,717評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡天吓,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,894評(píng)論 3 336
  • 正文 我和宋清朗相戀三年贿肩,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片失仁。...
    茶點(diǎn)故事閱讀 40,021評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡尸曼,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出萄焦,到底是詐尸還是另有隱情控轿,我是刑警寧澤,帶...
    沈念sama閱讀 35,735評(píng)論 5 346
  • 正文 年R本政府宣布拂封,位于F島的核電站茬射,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏冒签。R本人自食惡果不足惜在抛,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,354評(píng)論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望萧恕。 院中可真熱鬧刚梭,春花似錦肠阱、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,936評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至衅金,卻和暖如春噪伊,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背氮唯。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,054評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工鉴吹, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人惩琉。 一個(gè)月前我還...
    沈念sama閱讀 48,224評(píng)論 3 371
  • 正文 我出身青樓豆励,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親瞒渠。 傳聞我的和親對(duì)象是個(gè)殘疾皇子肆糕,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,974評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • // eslint-disable-next-line eslint-comments/disable-enabl...
    gitblong閱讀 385評(píng)論 0 0
  • Day 1 Python的特性 @(第一張Python基礎(chǔ))[MeiCheng|幫助|Markdown] Pyth...
    Masom閱讀 143評(píng)論 0 0
  • 我懼怕思想的無(wú)味、語(yǔ)言的空洞在孝,我站在樓頂往下望,并沒(méi)有看到人流的涌動(dòng)淮摔,只有我的影子落在地上私沮。 它在看我,像是注視著...
    五色浮元子_閱讀 199評(píng)論 0 0
  • 最近參加的一些活動(dòng)中和橙,不乏行業(yè)大咖和知名人士仔燕,當(dāng)寒暄一陣覺(jué)得氣場(chǎng)相符,對(duì)方一般會(huì)加個(gè)微信然后優(yōu)雅恰當(dāng)?shù)卣f(shuō)句“下次聊...
    木子小陽(yáng)閱讀 42,228評(píng)論 132 1,170
  • 聽(tīng)說(shuō)過(guò)偷錢(qián)魔招,第一次知道竟然還有偷路的晰搀! 最近,江蘇宿遷經(jīng)開(kāi)區(qū)的一條路上近800米的水泥路面竟然“不翼而飛”办斑,好好的...
    寫(xiě)作的技巧閱讀 170評(píng)論 0 0