2014-04-01 65 views
1

有沒有人得到ShopifyLiveReload他們的工作流程開發工作與grunt?請注意,在查看開發的實時預覽時,它不是本地存儲的,而是通過shopify的自定義網址進行的。Shopify livereload grunt

如果有人知道如何讓livereload去shopify上工作,我會更感激。

在此先感謝。

我Gruntfile:

'use strict'; 

// # Globbing 
// for performance reasons we're only matching one level down: 
// 'test/spec/{,*/}*.js' 
// use this if you want to match all subfolders: 
// 'test/spec/**/*.js' 

module.exports = function (grunt) { 
    // load all grunt tasks 
    require('matchdep').filterDev('grunt-*').forEach(grunt.loadNpmTasks); 

    // configurable paths 
    var yeomanConfig = { 
     app: '.', 
     dist: 'fahey-rodriguez4877-7509645' 
    }; 

    grunt.initConfig({ 
     yeoman: yeomanConfig, 
     watch: { 
      compass: { 
       files: ['<%= yeoman.app %>/styles/{,*/}*.{scss,sass}'], 
       tasks: ['compass:live'], 
       options: { 
        livereload: true 
       } 
      }, 
      css: { 
       files: ['.tmp/styles/*.css'], 
       tasks: ['cssmin'], 
       options: { 
        livereload: true 
       } 
      }, 
      js: { 
       files: ['<%= yeoman.app %>/scripts/*.js'], 
       tasks: ['concat:live'], 
       options: { 
        livereload: true 
       } 
      }, 
      update: { 
       files: ['<%= yeoman.app %>/{layout,templates,snippets}/*.liquid'], 
       tasks: ['sync'], 
       options: { 
        livereload: true 
       } 
      }, 
      config: { 
       files: ['<%= yeoman.app %>/config/*.{html,json}'], 
       tasks: ['copy'] 
      }, 
     }, 
     clean: { 
      dist: [ 
       '.tmp', 
       '<%= yeoman.dist %>/*' 
      ] 
     }, 
     jshint: { 
      options: { 
       jshintrc: '.jshintrc' 
      }, 
      all: [ 
       'Gruntfile.js', 
       '<%= yeoman.app %>/scripts/{,*/}*.js' 
      ] 
     }, 
     compass: { 
      options: { 
       sassDir: '<%= yeoman.app %>/styles', 
       cssDir: '.tmp/styles', 
       imagesDir: '<%= yeoman.app %>/assets', 
       javascriptsDir: '<%= yeoman.app %>/scripts', 
       fontsDir: '<%= yeoman.app %>/assets', 
       importPath: 'components', 
       relativeAssets: true 
      }, 
      dist: {}, 
      live: { 
       options: { 
        debugInfo: true, 
       } 
      } 
     }, 
     uglify: { 
      dist: { 
       files: { 
        '<%= yeoman.dist %>/assets/custom.modernizr.js': [ 
         '<%= yeoman.app %>/components/foundation/js/vendor/custom.modernizr.js' 
        ], 
        '<%= yeoman.dist %>/assets/main.js': [ 
         '<%= yeoman.app %>/components/foundation/js/vendor/jquery.js', 
         '<%= yeoman.app %>/components/foundation/js/foundation/foundation.js', 
         '<%= yeoman.app %>/components/foundation/js/foundation/foundation.*.js', 
         '<%= yeoman.app %>/scripts/{,*/}*.js' 
        ], 
       } 
      }, 
     }, 
     concat: { 
      live: { 
       files: { 
        '<%= yeoman.dist %>/assets/custom.modernizr.js': [ 
         '<%= yeoman.app %>/components/foundation/js/vendor/custom.modernizr.js' 
        ], 
        '<%= yeoman.dist %>/assets/main.js': [ 
         '<%= yeoman.app %>/components/foundation/js/vendor/jquery.js', 
         '<%= yeoman.app %>/components/foundation/js/foundation/foundation.js', 
         '<%= yeoman.app %>/components/foundation/js/foundation/foundation.*.js', 
         '<%= yeoman.app %>/scripts/{,*/}*.js' 
        ], 
       } 
      } 
     }, 
     imagemin: { 
      dist: { 
       files: [{ 
        expand: true, 
        cwd: '<%= yeoman.app %>/assets', 
        src: '{,*/}*.{png,jpg,jpeg}', 
        dest: '<%= yeoman.dist %>/assets' 
       }] 
      } 
     }, 
     cssmin: { 
      dist: { 
       files: { 
        '<%= yeoman.dist %>/assets/main.css': [ 
         '.tmp/styles/{,*/}*.css', 
         '<%= yeoman.app %>/styles/{,*/}*.css' 
        ] 
       } 
      } 
     }, 
     sync: { 
      main: { 
       files: [{ 
        cwd: '<%= yeoman.app %>', 
        src: [ 
          'assets/*', 
          'config/*', 
          'layout/*', 
          'snippets/*', 
          'templates/*', 
         ], 
        dest: '<%= yeoman.dist %>', 
       }] 
      } 
     }, 
     copy: { 
      dist: { 
       files: [{ 
        expand: true, 
        dot: true, 
        cwd: '<%= yeoman.app %>', 
        dest: '<%= yeoman.dist %>', 
        src: [ 
         'assets/*', 
         'config/*', 
         'layout/*', 
         'snippets/*', 
         'templates/*', 
        ] 
       },{ 
        expand: true, 
        cwd: '<%= yeoman.app %>/components/font-awesome/font', 
        dest: '<%= yeoman.dist %>/assets', 
        src: [ 
         '*' 
        ] 
       }] 
      }, 
     } 
    }); 

    grunt.renameTask('regarde', 'watch'); 

    grunt.registerTask('live', [ 
     'clean:dist', 
     'compass:live', 
     'cssmin', 
     'concat:live', 
     'copy', 
     'watch' 
    ]); 

    grunt.registerTask('build', [ 
     'clean:dist', 
     'compass:dist', 
     'cssmin', 
     'imagemin', 
     'uglify', 
     'copy' 
    ]); 

    grunt.registerTask('default', [ 
     'jshint', 
     'build' 
    ]); 
}; 

回答

0

嘿,這將是真棒,太,因爲我用LiveReload爲我所有的項目,但我認爲這是真正爲本地web開發服務器,而不是活的服務器,或者在這種情況下shopify這在這方面沒有給你任何類型的服務器級別控制。

但是,有這個真棒grunt task

它本質上是在本地編輯文件時監視任何文件變化,然後自動將它們上傳到各自的shopify商店/主題,我根本沒有任何問題,它是一個巨大的節省時間。

希望能幫到:)