gulpfile.js 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229
  1. 'use strict'
  2. const gulp = require('gulp')
  3. const watch = require('gulp-watch')
  4. const merge = require('merge-stream')
  5. const babel = require('gulp-babel')
  6. const uglify = require('gulp-uglify')
  7. const concat = require('gulp-concat')
  8. const nodemon = require('gulp-nodemon')
  9. const plumber = require('gulp-plumber')
  10. const zip = require('gulp-zip')
  11. const tar = require('gulp-tar')
  12. const gzip = require('gulp-gzip')
  13. const sass = require('gulp-sass')
  14. const cleanCSS = require('gulp-clean-css')
  15. const include = require('gulp-include')
  16. const run = require('run-sequence')
  17. /**
  18. * Paths
  19. *
  20. * @type {Object}
  21. */
  22. const paths = {
  23. scripts: {
  24. combine: [
  25. './node_modules/socket.io-client/dist/socket.io.min.js',
  26. './node_modules/jquery/dist/jquery.min.js',
  27. './node_modules/vue/dist/vue.min.js',
  28. './node_modules/jquery-smooth-scroll/jquery.smooth-scroll.min.js',
  29. './node_modules/jquery-simple-upload/simpleUpload.min.js',
  30. './node_modules/jquery-contextmenu/dist/jquery.contextMenu.min.js',
  31. './node_modules/sticky-js/dist/sticky.min.js',
  32. './node_modules/simplemde/dist/simplemde.min.js',
  33. './node_modules/ace-builds/src-min-noconflict/ace.js',
  34. './node_modules/ace-builds/src-min-noconflict/ext-modelist.js',
  35. './node_modules/ace-builds/src-min-noconflict/mode-markdown.js',
  36. './node_modules/ace-builds/src-min-noconflict/theme-tomorrow_night.js',
  37. './node_modules/filesize.js/dist/filesize.min.js',
  38. './node_modules/lodash/lodash.min.js'
  39. ],
  40. ace: [
  41. './node_modules/ace-builds/src-min-noconflict/mode-*.js',
  42. '!./node_modules/ace-builds/src-min-noconflict/mode-markdown.js'
  43. ],
  44. compile: [
  45. './client/js/*.js'
  46. ],
  47. watch: [
  48. './client/js/**/*.js'
  49. ]
  50. },
  51. css: {
  52. combine: [
  53. './node_modules/highlight.js/styles/tomorrow.css',
  54. './node_modules/simplemde/dist/simplemde.min.css'
  55. ],
  56. compile: [
  57. './client/scss/*.scss'
  58. ],
  59. includes: [
  60. './node_modules/requarks-core' //! MUST BE LAST
  61. ],
  62. watch: [
  63. './client/scss/**/*.scss',
  64. '../core/core-client/scss/**/*.scss'
  65. ]
  66. },
  67. fonts: [
  68. '../node_modules/requarks-core/core-client/fonts/**/*' //! MUST BE LAST
  69. ],
  70. deploy: [
  71. './**/*',
  72. '!client/js', '!client/js/**',
  73. '!client/scss', '!client/scss/**',
  74. '!coverage', '!coverage/**',
  75. '!data', '!data/**',
  76. '!dist', '!dist/**',
  77. '!node_modules', '!node_modules/**',
  78. '!npm', '!npm/**',
  79. '!repo', '!repo/**',
  80. '!test', '!test/**',
  81. '!gulpfile.js', '!config.yml'
  82. ]
  83. }
  84. /**
  85. * TASK - Starts server in development mode
  86. */
  87. gulp.task('server', ['scripts', 'css', 'fonts'], function () {
  88. nodemon({
  89. script: './server',
  90. ignore: ['assets/', 'client/', 'data/', 'repo/', 'tests/'],
  91. ext: 'js json',
  92. env: { 'NODE_ENV': 'development' }
  93. })
  94. })
  95. gulp.task('configure', ['scripts', 'css', 'fonts'], function () {
  96. nodemon({
  97. exec: 'node wiki configure',
  98. ignore: ['assets/', 'client/', 'data/', 'repo/', 'tests/'],
  99. ext: 'js json',
  100. env: { 'NODE_ENV': 'development' }
  101. })
  102. })
  103. /**
  104. * TASK - Process all scripts processes
  105. */
  106. gulp.task('scripts', ['scripts-libs', 'scripts-app'])
  107. /**
  108. * TASK - Combine js libraries
  109. */
  110. gulp.task('scripts-libs', function () {
  111. return merge(
  112. gulp.src(paths.scripts.combine)
  113. .pipe(concat('libs.js', {newLine: ';\n'}))
  114. .pipe(uglify({ mangle: false }))
  115. .pipe(gulp.dest('./assets/js')),
  116. gulp.src(paths.scripts.ace)
  117. .pipe(gulp.dest('./assets/js/ace'))
  118. )
  119. })
  120. /**
  121. * TASK - Combine, make compatible and compress js app scripts
  122. */
  123. gulp.task('scripts-app', function () {
  124. return gulp.src(paths.scripts.compile)
  125. .pipe(plumber())
  126. .pipe(include({ extensions: 'js' }))
  127. .pipe(babel())
  128. .pipe(uglify())
  129. .pipe(plumber.stop())
  130. .pipe(gulp.dest('./assets/js'))
  131. })
  132. /**
  133. * TASK - Process all css processes
  134. */
  135. gulp.task('css', ['css-libs', 'css-app'])
  136. /**
  137. * TASK - Combine css libraries
  138. */
  139. gulp.task('css-libs', function () {
  140. return gulp.src(paths.css.combine)
  141. .pipe(plumber())
  142. .pipe(concat('libs.css'))
  143. .pipe(cleanCSS({ keepSpecialComments: 0 }))
  144. .pipe(plumber.stop())
  145. .pipe(gulp.dest('./assets/css'))
  146. })
  147. /**
  148. * TASK - Combine app css
  149. */
  150. gulp.task('css-app', function () {
  151. return gulp.src(paths.css.compile)
  152. .pipe(plumber())
  153. .pipe(sass.sync({ includePaths: paths.css.includes }))
  154. .pipe(cleanCSS({ keepSpecialComments: 0 }))
  155. .pipe(plumber.stop())
  156. .pipe(gulp.dest('./assets/css'))
  157. })
  158. /**
  159. * TASK - Copy web fonts
  160. */
  161. gulp.task('fonts', function () {
  162. return gulp.src(paths.fonts)
  163. .pipe(gulp.dest('./assets/fonts'))
  164. })
  165. /**
  166. * TASK - Start dev watchers
  167. */
  168. gulp.task('watch', function () {
  169. return merge(
  170. watch(paths.scripts.watch, {base: './'}, function () { return gulp.start('scripts-app') }),
  171. watch(paths.css.watch, {base: './'}, function () { return gulp.start('css-app') })
  172. )
  173. })
  174. /**
  175. * TASK - Starts development server with watchers
  176. */
  177. gulp.task('default', ['watch', 'server'])
  178. gulp.task('default-configure', ['watch', 'configure'])
  179. gulp.task('dev', function () {
  180. paths.css.includes.pop()
  181. paths.css.includes.push('../core')
  182. paths.fonts.pop()
  183. paths.fonts.push('../core/core-client/fonts/**/*')
  184. return run('default')
  185. })
  186. gulp.task('dev-configure', function () {
  187. paths.css.includes.pop()
  188. paths.css.includes.push('../core')
  189. paths.fonts.pop()
  190. paths.fonts.push('../core/core-client/fonts/**/*')
  191. return run('default-configure')
  192. })
  193. /**
  194. * TASK - Creates deployment packages
  195. */
  196. gulp.task('deploy', ['scripts', 'css', 'fonts'], function () {
  197. var zipStream = gulp.src(paths.deploy)
  198. .pipe(zip('wiki-js.zip'))
  199. .pipe(gulp.dest('dist'))
  200. var targzStream = gulp.src(paths.deploy)
  201. .pipe(tar('wiki-js.tar'))
  202. .pipe(gzip())
  203. .pipe(gulp.dest('dist'))
  204. return merge(zipStream, targzStream)
  205. })