chore(add husky): add standard and commitlint

This commit is contained in:
youxingzhi
2018-12-11 11:16:29 +08:00
parent 2b2b1419ad
commit 867ef2a7fa
8 changed files with 31 additions and 17 deletions

2
.commitlintrc.yml Normal file
View File

@@ -0,0 +1,2 @@
extends:
- "@commitlint/config-conventional"

3
.czrc Normal file
View File

@@ -0,0 +1,3 @@
{
"path": "cz-conventional-changelog"
}

4
.huskyrc.yml Normal file
View File

@@ -0,0 +1,4 @@
hooks:
pre-commit:
- npm run standard
commit-msg: commitlint -E HUSKY_GIT_PARAMS

View File

@@ -1,5 +1,4 @@
var webpack = require('webpack'); var path = require('path')
var path = require('path');
var projectRoot = path.resolve(__dirname, '../') var projectRoot = path.resolve(__dirname, '../')

View File

@@ -2,9 +2,6 @@ var webpack = require('webpack')
var merge = require('webpack-merge') var merge = require('webpack-merge')
var HtmlWebpackPlugin = require('html-webpack-plugin') var HtmlWebpackPlugin = require('html-webpack-plugin')
var baseConfig = require('./webpack.base.conf') var baseConfig = require('./webpack.base.conf')
var path = require('path')
var projectRoot = path.resolve(__dirname, '../')
module.exports = merge(baseConfig, { module.exports = merge(baseConfig, {
entry: './dev/index.js', entry: './dev/index.js',

View File

@@ -4,6 +4,8 @@
"description": "A vue component for tree structure. Support adding treenode/leafnode, editing node's name and dragging.", "description": "A vue component for tree structure. Support adding treenode/leafnode, editing node's name and dragging.",
"main": "dist/vue-tree-list.min.js", "main": "dist/vue-tree-list.min.js",
"scripts": { "scripts": {
"commit": "npx git-cz",
"standard": "standard",
"test": "karma start --single-run", "test": "karma start --single-run",
"unit": "karma start --watch", "unit": "karma start --watch",
"coveralls": "npm run test -- --report lcovonly && cat ./coverage/lcov.info | coveralls", "coveralls": "npm run test -- --report lcovonly && cat ./coverage/lcov.info | coveralls",
@@ -26,6 +28,8 @@
}, },
"homepage": "https://github.com/ParadeTo/vue-tree-list#readme", "homepage": "https://github.com/ParadeTo/vue-tree-list#readme",
"devDependencies": { "devDependencies": {
"@commitlint/cli": "^7.2.1",
"@commitlint/config-conventional": "^7.1.2",
"autoprefixer": "^6.4.0", "autoprefixer": "^6.4.0",
"babel-core": "^6.0.0", "babel-core": "^6.0.0",
"babel-eslint": "^7.0.0", "babel-eslint": "^7.0.0",
@@ -39,6 +43,8 @@
"cross-env": "^5.0.1", "cross-env": "^5.0.1",
"css-loader": "^0.26.2", "css-loader": "^0.26.2",
"file-loader": "^0.10.1", "file-loader": "^0.10.1",
"html-webpack-plugin": "^2.8.1",
"husky": "^1.2.0",
"isparta": "^4.0.0", "isparta": "^4.0.0",
"isparta-loader": "^2.0.0", "isparta-loader": "^2.0.0",
"less": "^2.7.2", "less": "^2.7.2",
@@ -46,6 +52,7 @@
"sinon": "^2.3.5", "sinon": "^2.3.5",
"sinon-chai": "^2.11.0", "sinon-chai": "^2.11.0",
"sourcemap": "^0.1.0", "sourcemap": "^0.1.0",
"standard": "^12.0.1",
"url-loader": "^0.5.7", "url-loader": "^0.5.7",
"vue": "^2.3.4", "vue": "^2.3.4",
"vue-loader": "^11.1.3", "vue-loader": "^11.1.3",
@@ -53,7 +60,9 @@
"vue-template-compiler": "^2.2.0", "vue-template-compiler": "^2.2.0",
"webpack": "^1.13.2", "webpack": "^1.13.2",
"webpack-dev-server": "1.14.0", "webpack-dev-server": "1.14.0",
"webpack-merge": "^0.14.1", "webpack-merge": "^0.14.1"
"html-webpack-plugin": "^2.8.1" },
"dependencies": {
"cz-conventional-changelog": "^2.1.0"
} }
} }

View File

@@ -7,21 +7,21 @@ var handlerCache
exports.addHandler = function (element, type, handler) { exports.addHandler = function (element, type, handler) {
handlerCache = handler handlerCache = handler
if (element.addEventListener) { if (element.addEventListener) {
element.addEventListener(type, handler, false); element.addEventListener(type, handler, false)
} else if (element.attachEvent) { } else if (element.attachEvent) {
element.attachEvent("on" + type, handler); element.attachEvent('on' + type, handler)
} else { } else {
element["on" + type] = handler; element['on' + type] = handler
} }
} }
exports.removeHandler = function (element, type) { exports.removeHandler = function (element, type) {
if (element.removeEventListener) { if (element.removeEventListener) {
element.removeEventListener(type, handlerCache, false); element.removeEventListener(type, handlerCache, false)
} else if (element.detachEvent) { } else if (element.detachEvent) {
element.detachEvent("on" + type, handlerCache); element.detachEvent('on' + type, handlerCache)
} else { } else {
element["on" + type] = null; element['on' + type] = null
} }
} }