Настроил css модули

This commit is contained in:
SleepWalker 2016-01-03 11:11:08 +02:00
parent 60ebce5284
commit 0a750b8cfa
5 changed files with 54 additions and 19 deletions

View File

@ -20,7 +20,7 @@
"intl-messageformat": "^1.1.0", "intl-messageformat": "^1.1.0",
"react": "^0.14.0", "react": "^0.14.0",
"react-dom": "^0.14.3", "react-dom": "^0.14.3",
"react-intl": "^2.0.0-beta-2", "react-intl": "^2.0.0-pr-3",
"react-redux": "^4.0.0", "react-redux": "^4.0.0",
"react-router": "^2.0.0-rc4", "react-router": "^2.0.0-rc4",
"redux": "^3.0.4", "redux": "^3.0.4",
@ -28,7 +28,6 @@
"redux-thunk": "^1.0.0" "redux-thunk": "^1.0.0"
}, },
"devDependencies": { "devDependencies": {
"autoprefixer-loader": "^2.0.0",
"babel-core": "^6.0.0", "babel-core": "^6.0.0",
"babel-eslint": "^5.0.0-beta6", "babel-eslint": "^5.0.0-beta6",
"babel-loader": "^6.0.0", "babel-loader": "^6.0.0",
@ -40,30 +39,32 @@
"babel-runtime": "^5.6.15", "babel-runtime": "^5.6.15",
"chai": "^3.0.0", "chai": "^3.0.0",
"chokidar": "^1.2.0", "chokidar": "^1.2.0",
"css-loader": "^0.9.1", "css-loader": "^0.23.0",
"cssnano": "^3.4.0",
"eslint": "^1.10.3", "eslint": "^1.10.3",
"eslint-plugin-react": "^3.13.1", "eslint-plugin-react": "^3.13.1",
"extract-text-webpack-plugin": "^0.9.1", "extract-text-webpack-plugin": "^0.9.1",
"html-webpack-plugin": "^1.7.0", "html-webpack-plugin": "^1.7.0",
"imports-loader": "^0.6.4", "imports-loader": "^0.6.4",
"karma": "^0.13.0", "karma": "*",
"karma-chai": "^0.1.0", "karma-chai": "*",
"karma-es5-shim": "^0.0.4", "karma-es5-shim": "*",
"karma-mocha": "^0.1.10", "karma-mocha": "^0.2.1",
"karma-nyan-reporter": "^0.0.60", "karma-nyan-reporter": "^0.2.3",
"karma-phantomjs-launcher": "^0.2.1", "karma-phantomjs-launcher": "*",
"karma-sinon": "^1.0.4", "karma-sinon": "^1.0.4",
"karma-sourcemap-loader": "^0.3.6", "karma-sourcemap-loader": "*",
"karma-webpack": "^1.5.1", "karma-webpack": "^1.5.1",
"less": "^2.4.0", "less": "^2.4.0",
"less-loader": "^2.0.0", "less-loader": "^2.0.0",
"mocha": "^2.2.5", "mocha": "^2.2.5",
"node-sass": "^3.4.2", "node-sass": "^3.4.2",
"phantomjs": "^1.9.18", "phantomjs": "^1.9.18",
"postcss-loader": "^0.8.0",
"react-addons-test-utils": "^0.14.3", "react-addons-test-utils": "^0.14.3",
"sass-loader": "^3.1.2", "sass-loader": "^3.1.2",
"sinon": "^1.15.3", "sinon": "^1.15.3",
"style-loader": "^0.8.3", "style-loader": "^0.13.0",
"webpack": "^1.12.9", "webpack": "^1.12.9",
"webpack-dev-server": "^1.14.0" "webpack-dev-server": "^1.14.0"
} }

View File

@ -3,9 +3,15 @@ import 'babel-polyfill';
import React from 'react'; import React from 'react';
import ReactDOM from 'react-dom'; import ReactDOM from 'react-dom';
import { createStore, combineReducers } from 'redux'; import { createStore, combineReducers, applyMiddleware } from 'redux';
import { Provider as ReduxProvider } from 'react-redux'; import { Provider as ReduxProvider } from 'react-redux';
// midleware, который позволяет возвращать из экшенов функции
// это полезно для работы с асинхронными действиями,
// а также дает возможность проверить какие-либо условия перед запуском экшена
// или даже вообще его не запускать в зависимости от условий
import thunk from 'redux-thunk';
import { Router, browserHistory } from 'react-router'; import { Router, browserHistory } from 'react-router';
import { syncReduxAndRouter, routeReducer } from 'redux-simple-router'; import { syncReduxAndRouter, routeReducer } from 'redux-simple-router';
@ -18,7 +24,10 @@ const reducer = combineReducers({
...reducers, ...reducers,
routing: routeReducer routing: routeReducer
}); });
const store = createStore(reducer);
const store = applyMiddleware(
thunk
)(createStore)(reducer);
syncReduxAndRouter(browserHistory, store); syncReduxAndRouter(browserHistory, store);

3
src/index.scss Normal file
View File

@ -0,0 +1,3 @@
.testClass {
background: #f00;
}

View File

@ -4,6 +4,8 @@ import { Link } from 'react-router';
import { FormattedMessage } from 'react-intl'; import { FormattedMessage } from 'react-intl';
import styles from 'index.scss';
function CoreLayout(props) { function CoreLayout(props) {
return ( return (
<div> <div>
@ -23,7 +25,7 @@ function HomeView() {
return ( return (
<div> <div>
Home! Home!
<Link to="/auth">Auth</Link> <Link className={styles.testClass} to="/auth">Auth</Link>
</div> </div>
); );
} }

View File

@ -4,11 +4,14 @@ var path = require('path');
var webpack = require('webpack'); var webpack = require('webpack');
var ExtractTextPlugin = require('extract-text-webpack-plugin'); var ExtractTextPlugin = require('extract-text-webpack-plugin');
var HtmlWebpackPlugin = require('html-webpack-plugin'); var HtmlWebpackPlugin = require('html-webpack-plugin');
var cssnano = require('cssnano');
const API_HOST = 'http://account.l'; const API_HOST = 'http://account.l';
// TODO: https://babeljs.io/docs/plugins/ // TODO: https://babeljs.io/docs/plugins/
// TODO: отдельные конфиги для env (аля https://github.com/davezuko/react-redux-starter-kit) // TODO: отдельные конфиги для env (аля https://github.com/davezuko/react-redux-starter-kit)
// https://github.com/glenjamin/ultimate-hot-reloading-example ( обратить внимание на плагины babel )
// https://github.com/gajus/react-css-modules ( + BrowserSync)
var isProduction = process.argv.some(function(arg) { var isProduction = process.argv.some(function(arg) {
return arg === '-p'; return arg === '-p';
@ -18,6 +21,8 @@ var isTest = process.argv.some(function(arg) {
return arg.indexOf('karma') !== -1; return arg.indexOf('karma') !== -1;
}); });
const CSS_LOADER = 'style!css?modules&importLoaders=1&localIdentName=[path][name]-[local]!postcss';
var webpackConfig = { var webpackConfig = {
entry: { entry: {
app: path.join(__dirname, 'src'), app: path.join(__dirname, 'src'),
@ -90,7 +95,7 @@ var webpackConfig = {
{ {
test: /\.scss$/, test: /\.scss$/,
extractInProduction: true, extractInProduction: true,
loader: 'style!css!autoprefixer?browsers=last 3 versions!sass' loader: CSS_LOADER + '!sass'
}, },
{ {
test: /\.jsx?$/, test: /\.jsx?$/,
@ -103,16 +108,31 @@ var webpackConfig = {
}, },
{ // DEPRECATED { // DEPRECATED
test: /i18n\/.*\.less$/, test: /i18n\/.*\.less$/,
loader: 'style!css!autoprefixer?browsers=last 3 versions!less' loader: CSS_LOADER + '!less'
}, },
{ // DEPRECATED { // DEPRECATED
test: /\.less$/, test: /\.less$/,
extractInProduction: true, extractInProduction: true,
exclude: /i18n\/.*\.less$/, exclude: /i18n\/.*\.less$/,
loader: 'style!css!autoprefixer?browsers=last 3 versions!less' loader: CSS_LOADER + '!less'
} }
] ]
},
postcss: [
cssnano({
sourcemap: !isProduction,
autoprefixer: {
add: true,
remove: true,
browsers: ['last 2 versions']
},
safe: true,
discardComments: {
removeAll: true
} }
})
]
}; };
@ -124,7 +144,7 @@ if (isProduction) {
} }
}); });
webpackConfig.plugins.push(new ExtractTextPlugin('dist/styles.css', { webpackConfig.plugins.push(new ExtractTextPlugin('styles.css', {
allChunks: true allChunks: true
})); }));