These are the basics for a new project, described with initial commands and hints.
Setup Codeiginiter
Please make sure that you have properly configured composer on your machine before following the steps in this tutorial. More info here:
Assumptions made in the commands:
- Your projects folder is called "Code";
- The project we use is called "our_new_project";
Steps to follow:
cd Codecomposer create-project kenjis/codeigniter-composer-installer our_new_projectcd our_new_projectphp bin/install.php translations 3.1.0composer updatecomposer require kenjis/codeigniter-cli --devphp vendor/kenjis/codeigniter-cli/install.php- Move the contents of the public folder to the root of the project and edit the content of the index.php file to match the change (paths in $system_path and $application_folder);
php cli
Using:
- https://github.com/kenjis/codeigniter-composer-installer
- https://github.com/kenjis/codeigniter-cli
- https://www.youtube.com/watch?v=YFoFCD4D9qk
Setup bower, gulp and minimal packages
Please make sure that bower and npm are globally installed on your machine.
Steps to follow:
cd Codecd our_new_projectbower initbower install bootstrap --save-devnpm install --save-dev gulpnpm install --save-dev main-bower-filesnpm install --save-dev gulp-uglifynpm install --save-dev gulp-minifynpm install --save-dev gulp-concatnpm install --save-dev gulp-filternpm install --save-dev gulp-flattennpm install --save-dev gulp-replace
Create a file named gulpFile.js and edit its content to:
var gulp = require('gulp');
var mainBowerFiles = require('main-bower-files');
var concat = require('gulp-concat');
var uglify = require('gulp-uglify');
var minify = require('gulp-minify');
var filter = require('gulp-filter');
var flatten= require('gulp-flatten');
var replace= require('gulp-replace');
gulp.task('assets', function() {
return gulp.src(['bower_components/**/*'], {
base: './bower_components'
})
.pipe(filter([
'**/*.{png,gif,svg,jpeg,jpg,woff,woff2,eot,ttf}'
]))
.pipe(flatten({ includeParents: -1}))
.pipe(gulp.dest('./public/libraries/'));
});
gulp.task('js', function() {
gulp.src(mainBowerFiles('**/*.js'))
.pipe(concat('all.min.js'))
.pipe(uglify())
.pipe(gulp.dest('./public/libraries/'));
});
gulp.task('css', function() {
gulp.src(mainBowerFiles('**/*.{css,scss}', {
overrides: {
bootstrap: {
main: [
'./dist/css/bootstrap.min.css'
]
}
}
}))
.pipe(concat('all.min.css'))
.pipe(replace('../fonts', './fonts'))
.pipe(minify())
.pipe(gulp.dest('./public/libraries/'));
});
// The default task (called when you run `gulp` from cli)
gulp.task('default', ['assets', 'js', 'css']);Code language: PHP (php)
More steps:
gulp- Please remember to run the gulp command after adding any new library;
- Include the generated files in your project's header file:
<link type="text/css" rel="stylesheet" href="./public/libraries/all.min.css" media="all" /><script type="text/javascript" src="./public/libraries/all.min.js"></script>
Using:
