vegas-cmf / assets
Vegas CMF Assets
Installs: 186
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 9
Forks: 0
Open Issues: 0
Language:JavaScript
Requires
- php: ^5.5 || ^7.0
- ext-phalcon: ^3.0
- phalcon/incubator: ^3.0
Requires (Dev)
- phpunit/phpunit: 4.* || 5.*
- satooshi/php-coveralls: ^1.0
This package is not auto-updated.
Last update: 2022-08-15 05:22:48 UTC
README
To provide easiness of maintaining assets we prepared grunt and gulp tasks which allow you to download all dependencies from vendor directory. We have specified unique name - vegas.json
- to store project's dependencies (and their overrides) in external libraries.
Example vegas.json
{ "dependencies": { "bootstrap": "3.1.0" }, "exportsOverride": { "bootstrap": { "js": [ "dist/js/*.js", "dist/js/*.map" ], "css": [ "dist/css/*.css", "dist/css/*.map" ], "fonts": "dist/fonts/*.*" } } }
Requirements
Grunt
$ npm install --global grunt-cli
Gulp
If you have previously installed a version of gulp globally, please run npm rm --global gulp
to make sure your old version doesn't collide with gulp-cli.
$ npm install --global gulp-cli
Basic setup
Add the following script commands to your composer.json file
Grunt commands:
"scripts": { "post-install-cmd": [ "cp -n ./vendor/vegas-cmf/assets/Gruntfile.js ./Gruntfile.js", "cp -n ./vendor/vegas-cmf/assets/grunt_package.json ./package.json", "cp -n ./vendor/vegas-cmf/assets/bower.json ./bower_base.json" ], "post-update-cmd": [ "cp -n ./vendor/vegas-cmf/assets/Gruntfile.js ./Gruntfile.js || true", "cp -n ./vendor/vegas-cmf/assets/grunt_package.json ./package.json || true", "cp -n ./vendor/vegas-cmf/assets/bower.json ./bower_base.json || true" ] }
Gulp commands:
"scripts": { "post-install-cmd": [ "cp -n ./vendor/vegas-cmf/assets/gulpfile.js ./gulpfile.js", "cp -n ./vendor/vegas-cmf/assets/gulp_package.json ./package.json", "cp -n ./vendor/vegas-cmf/assets/bower.json ./bower_base.json" ], "post-update-cmd": [ "cp -n ./vendor/vegas-cmf/assets/gulpfile.js ./gulpfile.js || true", "cp -n ./vendor/vegas-cmf/assets/gulp_package.json ./package.json || true", "cp -n ./vendor/vegas-cmf/assets/bower.json ./bower_base.json || true" ] }
Run composer update or install command
php composer.phar update
Install NPM packages
npm install
Note: Use sudo in case of permission problems
Run
Merge all assets to bower file and run bower install by a simple shell command
grunt
or:
gulp
Custom options
You can also run bower install or bower update task without merging assets from vendor. For grunt:
grunt bower:update // update grunt bower:install // install
For gulp:
gulp bower
Vegas CMF Assets Manager
Within this package, an assets container has been delivered, it's based on Phalcon's one. Assets Manager allows you to easily add resources like JS scripts, CSS styles etc. To use this feature, please create shared service in your Vegas project, as follows:
namespace App\Shared; use Vegas\Di\Injector\SharedServiceProviderInterface; class AssetsManager implements SharedServiceProviderInterface { /** * @return string */ public function getName() { return 'assets'; } /** * @param \Phalcon\DiInterface $di * @return mixed */ public function getProvider(\Phalcon\DiInterface $di) { return function() use ($di) { return new Vegas\Assets\Manager(); }; } }
From this point, you will have a possibilty to invoke Manager methods, by following syntax:
// output JS files path
{{ assets.outputJs() }}
// output CSS files path
{{ assets.outputCss() }}
// add JS file to assets container
{{ assets.addJs('some/valid/path/to/js/file.js') }}
// add CSS file to assets container
{{ assets.addCss('some/valid/path/to/css/file.css') }}
####Note####
Keep it in mind, that config.php
file must be updated too.
'sharedServices' => [ ... 'App\Shared\AssetsManager' ]