Skip to content

Latest commit

 

History

History
155 lines (106 loc) · 3.79 KB

readme.md

File metadata and controls

155 lines (106 loc) · 3.79 KB

GruntJS & Nette Framework Sandbox

based on Nette Sandbox and grunt-usemin

Nette Framework is a popular tool for PHP web development. It is designed to be the most usable and friendliest as possible. It focuses on security and performance and is definitely one of the safest PHP frameworks.

Nette Framework speaks your language and helps you to easily build better websites.

What is GruntJS?

Grunt is a task-based command line build tool for JavaScript projects

Concept

use Grunt for combine and minify CSS and JavaScript files for projects that runs on php - Nette.

Install

install Composer

install Grunt

clone repository git clone git://github.com/chemix/Nette-Grunt.git

download dependencies via composer composer.phar install

download dependencies via npm npm install

Use

In Gruntfile.coffee update paths if you use other

  grunt.initConfig

    useminPrepare:
      html: ['app/templates/@layout.latte']
      options:
        dest: '.'

    netteBasePath:
      basePath: 'www'
      options:
        removeFromPath: ['app/templates/']

those files will be checked for script or link block definitions

Block definition:

CSS

<!-- build:css {$basePath}/css/screen.min.css -->
<link rel="stylesheet" media="screen,projection,tv" href="{$basePath}/css/reset.css">
<link rel="stylesheet" media="screen,projection,tv" href="{$basePath}/css/screen.css">
<link rel="stylesheet" media="screen,projection,tv" href="{$basePath}/css/hyperCSS3.css">
<!-- endbuild -->

or JavaScript

<!-- build:js {$basePath}/js/app.min.js -->
<script src="{$basePath}/js/netteForms.js"></script>
<script src="{$basePath}/js/helpers.js"></script>
<script src="{$basePath}/js/lightbox.js"></script>
<script src="{$basePath}/js/layout.js"></script>
<!-- endbuild -->

This is simple definition, grunt looks for block and create minified version js/screen.min.css and js/app.min.js

tadaa run grunt

Now we have minified versions, but not in templates

in BasePresenter we define version and mode for templates

$this->template->production = !$this->context->parameters['site']['develMode'];
$this->template->version = $this->context->parameters['site']['version'];

and set definition in config.neon

common:
	parameters:
		site:
			develMode: true
			version: devel

now we update templates like this

{if $production}
	<script src="{$basePath}/js/app.min.js?{$version}"></script>
{else}
	<!-- build:js {$basePath}/js/app.min.js -->
	<script src="{$basePath}/js/netteForms.js"></script>
	<script src="{$basePath}/js/helpers.js"></script>
	<script src="{$basePath}/js/lightbox.js"></script>
	<script src="{$basePath}/js/layout.js"></script>
	<!-- endbuild -->
{/if}

TODO

Make Latte macro and remove {if $develMode} & {$version}

{build js="$basePath/js/app.min.js"}
<script src="{$basePath}/js/netteForms.js"></script>
<script src="{$basePath}/js/helpers.js"></script>
<script src="{$basePath}/js/lightbox.js"></script>
<script src="{$basePath}/js/layout.js"></script>
{/build}

License : MIT license.md

Packages: