By default, CodeIgniter starts up in production mode. This is a safety feature to keep your site a bit more secure in case settings are messed up once it is live. So first let’s fix that. Copy or renmae the env file to .env. Open it up.
This file contains server-specific settings. This means you never will need to commit any sensitive information to your version control system. It includes some of the most common ones you want to enter already, though they are all commented out. So uncomment the line with CI_ENVIRONMENT on it, and change production to development:
CI_ENVIRONMENT = development
{
"name": "moikzz",
"version": "4.0.0",
"description": "What is CodeIgniter ###################",
"author": "Moikzz",
"license": "ISC",
"private": true,
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1",
"build": "webpack --config webpack.config.js",
"watch": "webpack --watch"
},
"dependencies": {
"@babel/polyfill": "^7.8.7",
"cssnano": "^4.1.10",
"vue": "^2.6.11",
"vuetify": "^2.2.15",
"webpack": "^4.42.0"
},
"devDependencies": {
"@babel/core": "^7.8.7",
"@babel/preset-env": "^7.8.7",
"autoprefixer": "^9.7.4",
"babel-loader": "^8.0.6",
"postcss-loader": "^3.0.0",
"mini-css-extract-plugin": "^0.9.0",
"deepmerge": "^4.2.2",
"fibers": "^4.0.2",
"sass": "^1.26.2",
"sass-loader": "^8.0.2",
"vue-cli-plugin-vuetify": "~2.0.5",
"css-loader": "^3.4.2",
"webpack-cli": "^3.3.11"
},
"browserslist": [
"defaults",
"not ie < 11",
"last 2 versions",
"> 1%",
"iOS 7",
"last 3 iOS versions"
]
}
: npm install
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
// Webpack uses this to work with directories
const path = require('path');
// This is main configuration object.
// Here you write different options and tell Webpack what to do
module.exports = {
// Path to your entry point. From this file Webpack will begin his work
entry: './src/main.js',
// Path and filename of your result bundle.
// Webpack will bundle all JavaScript into this file
output: {
path: path.resolve(__dirname, 'public/src/'),
filename: 'bundle.js'
},
resolve: {
alias: {
'vue$': 'vue/dist/vue.esm.js'
},
extensions: ['*', '.js', '.vue', '.json']
},
module: {
rules: [{
test: /\.vue$/,
loader: 'vue-loader'
},
{
test: /\.js?$/,
exclude: /(node_modules)/,
use: {
loader: 'babel-loader',
options: {
presets: ['@babel/preset-env']
}
}
},
{
test: /\.(sa|sc|c)ss$/,
use: [ {
// After all CSS loaders we use plugin to do his work.
// It gets all transformed CSS and extracts it into separate
// single bundled file
loader: MiniCssExtractPlugin.loader
}, {
// This loader resolves url() and @imports inside CSS
loader: "css-loader",
},
{
// Then we apply postCSS fixes like autoprefixer and minifying
loader: "postcss-loader"
},
{
// First we transform SASS to standard CSS
loader: "sass-loader",
options: {
implementation: require("sass")
}
}
]
}
],
},
plugins: [
new MiniCssExtractPlugin({
filename: "bundle.css"
})
],
// Default mode for Webpack is production.
// Depending on mode Webpack will apply different things
// on final bundle. For now we don't need production's JavaScript
// minifying and other thing so let's set mode to development
mode: 'development'
};
// It is handy to not have those transformations while we developing
if(process.env.NODE_ENV === 'development') {
module.exports = {
plugins: [
require('autoprefixer'),
require('cssnano'),
// More postCSS modules here if needed
]
}
}
// src/main.js
import '@babel/polyfill'
import Vue from 'vue'
import vuetify from './plugins/vuetify' // path to vuetify export
import './sass/custom.scss' // path to custom sass
new Vue({
vuetify,
}).$mount('#app')
//src/plugins/vuetify.js
import Vue from 'vue'
import Vuetify from 'vuetify'
import 'vuetify/dist/vuetify.min.css'
Vue.use(Vuetify)
const opts = {}
export default new Vuetify(opts)
//--------------------------------------------------------------------
src/sass/custom.scss
//--------------------------------------------------------------------
<?php namespace App\Controllers;
class Home extends BaseController
{
protected $version = '1.0.0';
public function index()
{
helper('html');
$data['version'] = $this->version;
return view('welcome_message',$data);
}
}
--- Add your css & js files ---
// you need helper('html'); for the link_tag & script_tag //see helper
<?php echo link_tag('src/bundle.css?v='.$version); ?>
<?php echo script_tag('src/bundle.js?v='.$version); ?>
CodeIgniter is a PHP full-stack web framework that is light, fast, flexible, and secure. More information can be found at the official site.
This repository holds the distributable version of the framework, including the user guide. It has been built from the development repository.
This is pre-release code and should not be used in production sites.
More information about the plans for version 4 can be found in the announcement on the forums.
The user guide corresponding to this version of the framework can be found here.
index.php
is no longer in the root of the project! It has been moved inside the public folder,
for better security and separation of components.
This means that you should configure your web server to "point" to your project's public folder, and not to the project root. A better practice would be to configure a virtual host to point there. A poor practice would be to point your web server to the project root and expect to enter public/..., as the rest of your logic and the framework are exposed.
Please read the user guide for a better explanation of how CI4 works! The user guide updating and deployment is a bit awkward at the moment, but we are working on it!
We use Github issues, in our main repository, to track BUGS and to track approved DEVELOPMENT work packages. We use our forum to provide SUPPORT and to discuss FEATURE REQUESTS.
This repository is a "distribution" one, built by our release preparation script. Problems with it can be raised on our forum, or as issues in the main repository.
We welcome contributions from the community.
Please read the Contributing to CodeIgniter section in the development repository.
PHP version 7.2 or higher is required, with the following extensions installed:
Additionally, make sure that the following extensions are enabled in your PHP: