2017-01-15 19:49:15 +00:00
|
|
|
/* eslint-disable no-process-env, no-console */
|
2016-09-18 19:51:20 +00:00
|
|
|
|
2017-01-15 19:49:15 +00:00
|
|
|
const path = require('path');
|
|
|
|
|
const config = require('./config');
|
|
|
|
|
const utils = require('./utils');
|
|
|
|
|
const webpack = require('webpack');
|
2017-08-22 16:26:53 +00:00
|
|
|
const projectRoot = path.resolve(__dirname, '../');
|
2017-01-15 19:49:15 +00:00
|
|
|
const autoprefixer = require('autoprefixer');
|
|
|
|
|
const postcssEasyImport = require('postcss-easy-import');
|
|
|
|
|
const IS_PROD = process.env.NODE_ENV === 'production';
|
|
|
|
|
|
|
|
|
|
const baseConfig = {
|
2016-09-18 19:51:20 +00:00
|
|
|
entry: {
|
|
|
|
|
app: './website/client/main.js',
|
|
|
|
|
},
|
|
|
|
|
output: {
|
|
|
|
|
path: config.build.assetsRoot,
|
2016-09-21 12:37:44 +00:00
|
|
|
publicPath: IS_PROD ? config.build.assetsPublicPath : config.dev.assetsPublicPath,
|
2016-09-18 19:51:20 +00:00
|
|
|
filename: '[name].js',
|
Client Redesign: Inventory pages, secondary menu, misc css and design items (#8631)
* add colors palette
* add secondary menu component and style it
* add box shadow to secondary menu
* misc css, fixes for secondary menu
* client: add equipment page with grouping, css: add some styles
* add typography
* more equipment
* stable: fix linting
* equipment: add styles (lots of general styles too)
* remove duplicate google fonts loading
* add dropdowns
* design: white search input background, remove gray from items
* start adding drawer and selected indicator
* wip equipment
* fix equipment
* equipment: correctly bind new properties on items.gear.equipped
* equipment: fix vue binding. version 2
* equipment: fix vue binding. version 3
* back to first fix for equip op, fix for sourcemaps, send http request when an item is equipped, load bootstrap-vue components where needed
* checkboxes and radio buttons
* correctly renders selected items in first postion during the first render
* add search
* general changes, constants part of app state, add popovers
* add toggle switch, rename css
* correct offset
* upgrade deps
* upgrade deps
* drawer and lot of other work
* update equipping mechanism
* finish equipment
* fix compilation and upgrade deps
* use v-show in place of v-if to fix ui issues
* v-show -> v-if
* fix linting in test/client
* fix es6 compilation in test/client
* fix babel compilation for tests
* fix groupsUtilities mixin tests
* client: buttons
* client: buttons: fix colors
* client: finish buttons and dropdowns
* upgrade bootstrap-vue, finish buttons and dropdowns
* fix tasks page layout
* misc fixes for buttons
* add textareas
* fix app menu
* add inputs
* fixes for toggleSwitch
* typography
* checkboxes and radio buttons
* add checkbox icon
* fix equip.js
* extract strings to newClient.json
* add Popover above 'Use Costume' / 'Auto Equip' slider - disable item select if costume-mode and 'useCostume' isn't active
* show "you have disabled your costume" error above the drawer items
* check errorMessage for null
* hide star if costume not enabled
* fix errorMessage (!errorMessage seems not to work for string)
* show minimize / expand icon - always centered by css
* drawer test
* drawer: fix centering on large screens
* fix show more button
* add margin when two dropdowns are next to each other
* adjust the page padding based on the drawer, misc fixes
* drawer fixes
2017-05-16 19:09:55 +00:00
|
|
|
devtoolModuleFilenameTemplate (info) {
|
|
|
|
|
// Fix source maps, code from
|
|
|
|
|
// https://github.com/Darkside73/bbsmile.com.ua/commit/3596d3c42ef91b69d8380359c3e8908edc08acdb
|
|
|
|
|
let filename = info.resourcePath;
|
|
|
|
|
if (info.resource.match(/\.vue$/) && !info.allLoaders.match(/type=script/)) {
|
|
|
|
|
filename = 'generated';
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return filename;
|
|
|
|
|
},
|
2016-09-18 19:51:20 +00:00
|
|
|
},
|
|
|
|
|
resolve: {
|
2017-02-15 16:24:37 +00:00
|
|
|
extensions: ['*', '.js', '.vue', '.json'],
|
|
|
|
|
modules: [
|
Client Redesign: Inventory pages, secondary menu, misc css and design items (#8631)
* add colors palette
* add secondary menu component and style it
* add box shadow to secondary menu
* misc css, fixes for secondary menu
* client: add equipment page with grouping, css: add some styles
* add typography
* more equipment
* stable: fix linting
* equipment: add styles (lots of general styles too)
* remove duplicate google fonts loading
* add dropdowns
* design: white search input background, remove gray from items
* start adding drawer and selected indicator
* wip equipment
* fix equipment
* equipment: correctly bind new properties on items.gear.equipped
* equipment: fix vue binding. version 2
* equipment: fix vue binding. version 3
* back to first fix for equip op, fix for sourcemaps, send http request when an item is equipped, load bootstrap-vue components where needed
* checkboxes and radio buttons
* correctly renders selected items in first postion during the first render
* add search
* general changes, constants part of app state, add popovers
* add toggle switch, rename css
* correct offset
* upgrade deps
* upgrade deps
* drawer and lot of other work
* update equipping mechanism
* finish equipment
* fix compilation and upgrade deps
* use v-show in place of v-if to fix ui issues
* v-show -> v-if
* fix linting in test/client
* fix es6 compilation in test/client
* fix babel compilation for tests
* fix groupsUtilities mixin tests
* client: buttons
* client: buttons: fix colors
* client: finish buttons and dropdowns
* upgrade bootstrap-vue, finish buttons and dropdowns
* fix tasks page layout
* misc fixes for buttons
* add textareas
* fix app menu
* add inputs
* fixes for toggleSwitch
* typography
* checkboxes and radio buttons
* add checkbox icon
* fix equip.js
* extract strings to newClient.json
* add Popover above 'Use Costume' / 'Auto Equip' slider - disable item select if costume-mode and 'useCostume' isn't active
* show "you have disabled your costume" error above the drawer items
* check errorMessage for null
* hide star if costume not enabled
* fix errorMessage (!errorMessage seems not to work for string)
* show minimize / expand icon - always centered by css
* drawer test
* drawer: fix centering on large screens
* fix show more button
* add margin when two dropdowns are next to each other
* adjust the page padding based on the drawer, misc fixes
* drawer fixes
2017-05-16 19:09:55 +00:00
|
|
|
path.join(projectRoot, 'website'),
|
|
|
|
|
path.join(projectRoot, 'test/client/unit'),
|
|
|
|
|
path.join(projectRoot, 'node_modules'),
|
2017-02-15 16:24:37 +00:00
|
|
|
],
|
2016-09-18 19:51:20 +00:00
|
|
|
alias: {
|
Client Redesign: Inventory pages, secondary menu, misc css and design items (#8631)
* add colors palette
* add secondary menu component and style it
* add box shadow to secondary menu
* misc css, fixes for secondary menu
* client: add equipment page with grouping, css: add some styles
* add typography
* more equipment
* stable: fix linting
* equipment: add styles (lots of general styles too)
* remove duplicate google fonts loading
* add dropdowns
* design: white search input background, remove gray from items
* start adding drawer and selected indicator
* wip equipment
* fix equipment
* equipment: correctly bind new properties on items.gear.equipped
* equipment: fix vue binding. version 2
* equipment: fix vue binding. version 3
* back to first fix for equip op, fix for sourcemaps, send http request when an item is equipped, load bootstrap-vue components where needed
* checkboxes and radio buttons
* correctly renders selected items in first postion during the first render
* add search
* general changes, constants part of app state, add popovers
* add toggle switch, rename css
* correct offset
* upgrade deps
* upgrade deps
* drawer and lot of other work
* update equipping mechanism
* finish equipment
* fix compilation and upgrade deps
* use v-show in place of v-if to fix ui issues
* v-show -> v-if
* fix linting in test/client
* fix es6 compilation in test/client
* fix babel compilation for tests
* fix groupsUtilities mixin tests
* client: buttons
* client: buttons: fix colors
* client: finish buttons and dropdowns
* upgrade bootstrap-vue, finish buttons and dropdowns
* fix tasks page layout
* misc fixes for buttons
* add textareas
* fix app menu
* add inputs
* fixes for toggleSwitch
* typography
* checkboxes and radio buttons
* add checkbox icon
* fix equip.js
* extract strings to newClient.json
* add Popover above 'Use Costume' / 'Auto Equip' slider - disable item select if costume-mode and 'useCostume' isn't active
* show "you have disabled your costume" error above the drawer items
* check errorMessage for null
* hide star if costume not enabled
* fix errorMessage (!errorMessage seems not to work for string)
* show minimize / expand icon - always centered by css
* drawer test
* drawer: fix centering on large screens
* fix show more button
* add margin when two dropdowns are next to each other
* adjust the page padding based on the drawer, misc fixes
* drawer fixes
2017-05-16 19:09:55 +00:00
|
|
|
website: path.resolve(projectRoot, 'website'),
|
|
|
|
|
common: path.resolve(projectRoot, 'website/common'),
|
|
|
|
|
client: path.resolve(projectRoot, 'website/client'),
|
|
|
|
|
assets: path.resolve(projectRoot, 'website/client/assets'),
|
|
|
|
|
components: path.resolve(projectRoot, 'website/client/components'),
|
2016-09-18 19:51:20 +00:00
|
|
|
},
|
|
|
|
|
},
|
2016-11-18 18:20:25 +00:00
|
|
|
plugins: [
|
2017-08-22 16:26:53 +00:00
|
|
|
new webpack.ContextReplacementPlugin(/moment[\\\/]locale$/, /^\.\/(NOT_EXISTING)$/),
|
2016-11-18 18:20:25 +00:00
|
|
|
],
|
2016-09-18 19:51:20 +00:00
|
|
|
module: {
|
2017-02-15 16:24:37 +00:00
|
|
|
rules: [
|
2016-09-18 19:51:20 +00:00
|
|
|
{
|
|
|
|
|
test: /\.vue$/,
|
2017-02-15 16:24:37 +00:00
|
|
|
loader: 'vue-loader',
|
|
|
|
|
options: {
|
|
|
|
|
loaders: utils.cssLoaders({
|
|
|
|
|
sourceMap: IS_PROD ?
|
|
|
|
|
config.build.productionSourceMap :
|
|
|
|
|
config.dev.cssSourceMap,
|
|
|
|
|
extract: IS_PROD,
|
|
|
|
|
}),
|
|
|
|
|
postcss: [
|
|
|
|
|
autoprefixer({
|
|
|
|
|
browsers: ['last 2 versions'],
|
|
|
|
|
}),
|
|
|
|
|
postcssEasyImport(),
|
|
|
|
|
],
|
|
|
|
|
},
|
2016-09-18 19:51:20 +00:00
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
test: /\.js$/,
|
2017-02-15 16:24:37 +00:00
|
|
|
loader: 'babel-loader',
|
Client Redesign: Inventory pages, secondary menu, misc css and design items (#8631)
* add colors palette
* add secondary menu component and style it
* add box shadow to secondary menu
* misc css, fixes for secondary menu
* client: add equipment page with grouping, css: add some styles
* add typography
* more equipment
* stable: fix linting
* equipment: add styles (lots of general styles too)
* remove duplicate google fonts loading
* add dropdowns
* design: white search input background, remove gray from items
* start adding drawer and selected indicator
* wip equipment
* fix equipment
* equipment: correctly bind new properties on items.gear.equipped
* equipment: fix vue binding. version 2
* equipment: fix vue binding. version 3
* back to first fix for equip op, fix for sourcemaps, send http request when an item is equipped, load bootstrap-vue components where needed
* checkboxes and radio buttons
* correctly renders selected items in first postion during the first render
* add search
* general changes, constants part of app state, add popovers
* add toggle switch, rename css
* correct offset
* upgrade deps
* upgrade deps
* drawer and lot of other work
* update equipping mechanism
* finish equipment
* fix compilation and upgrade deps
* use v-show in place of v-if to fix ui issues
* v-show -> v-if
* fix linting in test/client
* fix es6 compilation in test/client
* fix babel compilation for tests
* fix groupsUtilities mixin tests
* client: buttons
* client: buttons: fix colors
* client: finish buttons and dropdowns
* upgrade bootstrap-vue, finish buttons and dropdowns
* fix tasks page layout
* misc fixes for buttons
* add textareas
* fix app menu
* add inputs
* fixes for toggleSwitch
* typography
* checkboxes and radio buttons
* add checkbox icon
* fix equip.js
* extract strings to newClient.json
* add Popover above 'Use Costume' / 'Auto Equip' slider - disable item select if costume-mode and 'useCostume' isn't active
* show "you have disabled your costume" error above the drawer items
* check errorMessage for null
* hide star if costume not enabled
* fix errorMessage (!errorMessage seems not to work for string)
* show minimize / expand icon - always centered by css
* drawer test
* drawer: fix centering on large screens
* fix show more button
* add margin when two dropdowns are next to each other
* adjust the page padding based on the drawer, misc fixes
* drawer fixes
2017-05-16 19:09:55 +00:00
|
|
|
include: [
|
|
|
|
|
path.join(projectRoot, 'test'),
|
|
|
|
|
path.join(projectRoot, 'website'),
|
|
|
|
|
path.join(projectRoot, 'node_modules', 'bootstrap-vue'),
|
|
|
|
|
],
|
|
|
|
|
options: {
|
|
|
|
|
cacheDirectory: true,
|
|
|
|
|
},
|
2016-09-18 19:51:20 +00:00
|
|
|
},
|
|
|
|
|
{
|
2017-06-08 19:04:19 +00:00
|
|
|
test: /\.(png|jpe?g|gif)(\?.*)?$/,
|
2017-02-15 16:24:37 +00:00
|
|
|
loader: 'url-loader',
|
2016-09-18 19:51:20 +00:00
|
|
|
query: {
|
|
|
|
|
limit: 10000,
|
|
|
|
|
name: utils.assetsPath('img/[name].[hash:7].[ext]'),
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
|
2017-02-15 16:24:37 +00:00
|
|
|
loader: 'url-loader',
|
2016-09-18 19:51:20 +00:00
|
|
|
query: {
|
|
|
|
|
limit: 10000,
|
|
|
|
|
name: utils.assetsPath('fonts/[name].[hash:7].[ext]'),
|
|
|
|
|
},
|
|
|
|
|
},
|
2017-06-08 19:04:19 +00:00
|
|
|
{
|
|
|
|
|
test: /\.svg$/,
|
|
|
|
|
use: [
|
|
|
|
|
{ loader: 'svg-inline-loader' },
|
|
|
|
|
{ loader: 'svgo-loader' },
|
|
|
|
|
],
|
|
|
|
|
exclude: [path.resolve(projectRoot, 'website/client/assets/svg/for-css')],
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
test: /\.svg$/,
|
|
|
|
|
use: [
|
|
|
|
|
{ loader: 'svg-url-loader' },
|
|
|
|
|
{ loader: 'svgo-loader' },
|
|
|
|
|
],
|
|
|
|
|
include: [path.resolve(projectRoot, 'website/client/assets/svg/for-css')],
|
|
|
|
|
},
|
2016-09-18 19:51:20 +00:00
|
|
|
],
|
|
|
|
|
},
|
|
|
|
|
};
|
2016-09-21 12:37:44 +00:00
|
|
|
|
|
|
|
|
if (!IS_PROD) {
|
2017-01-16 17:31:29 +00:00
|
|
|
const eslintFriendlyFormatter = require('eslint-friendly-formatter'); // eslint-disable-line global-require
|
|
|
|
|
|
2017-02-15 16:24:37 +00:00
|
|
|
baseConfig.module.rules.unshift({
|
|
|
|
|
test: /\.(js|vue)$/,
|
|
|
|
|
loader: 'eslint-loader',
|
|
|
|
|
enforce: 'pre',
|
|
|
|
|
include: projectRoot,
|
|
|
|
|
options: {
|
|
|
|
|
formatter: eslintFriendlyFormatter,
|
|
|
|
|
emitWarning: true,
|
|
|
|
|
},
|
|
|
|
|
exclude: /node_modules/,
|
|
|
|
|
});
|
2016-09-21 12:37:44 +00:00
|
|
|
}
|
|
|
|
|
module.exports = baseConfig;
|