Suralc
12 years ago
215 changed files with 8276 additions and 10496 deletions
@ -1,5 +1,4 @@ |
|||||||
<?php |
<?php |
||||||
|
|
||||||
return array( |
return array( |
||||||
'adminEmail' => 'admin@example.com', |
'adminEmail' => 'admin@example.com', |
||||||
); |
); |
||||||
|
@ -1,78 +1,19 @@ |
|||||||
body { |
body { |
||||||
padding-top: 20px; |
padding-top: 70px; |
||||||
padding-bottom: 60px; |
|
||||||
} |
} |
||||||
|
|
||||||
/* Custom container */ |
.footer { |
||||||
.container { |
border-top: 1px solid #ddd; |
||||||
margin: 0 auto; |
margin-top: 30px; |
||||||
max-width: 1000px; |
padding-top: 15px; |
||||||
|
padding-bottom: 30px; |
||||||
} |
} |
||||||
|
|
||||||
.container > hr { |
|
||||||
margin: 60px 0; |
|
||||||
} |
|
||||||
|
|
||||||
/* Main marketing message and sign up button */ |
|
||||||
.jumbotron { |
.jumbotron { |
||||||
margin: 80px 0; |
text-align: center; |
||||||
text-align: center; |
background-color: transparent; |
||||||
} |
|
||||||
|
|
||||||
.jumbotron h1 { |
|
||||||
font-size: 100px; |
|
||||||
line-height: 1; |
|
||||||
} |
|
||||||
|
|
||||||
.jumbotron .lead { |
|
||||||
font-size: 24px; |
|
||||||
line-height: 1.25; |
|
||||||
} |
} |
||||||
|
|
||||||
.jumbotron .btn { |
.jumbotron .btn { |
||||||
font-size: 21px; |
font-size: 21px; |
||||||
padding: 14px 24px; |
padding: 14px 24px; |
||||||
} |
|
||||||
|
|
||||||
/* Supporting marketing content */ |
|
||||||
.marketing { |
|
||||||
margin: 60px 0; |
|
||||||
} |
|
||||||
|
|
||||||
.marketing p + h4 { |
|
||||||
margin-top: 28px; |
|
||||||
} |
|
||||||
|
|
||||||
/* Customize the navbar links to be fill the entire space of the .navbar */ |
|
||||||
.navbar.fullwidth .navbar-inner { |
|
||||||
padding: 0; |
|
||||||
} |
|
||||||
|
|
||||||
.navbar.fullwidth .nav { |
|
||||||
margin: 0; |
|
||||||
display: table; |
|
||||||
width: 100%; |
|
||||||
} |
|
||||||
|
|
||||||
.navbar.fullwidth .nav li { |
|
||||||
display: table-cell; |
|
||||||
width: 1%; |
|
||||||
float: none; |
|
||||||
} |
|
||||||
|
|
||||||
.navbar.fullwidth .nav li a { |
|
||||||
font-weight: bold; |
|
||||||
text-align: center; |
|
||||||
border-left: 1px solid rgba(255, 255, 255, .75); |
|
||||||
border-right: 1px solid rgba(0, 0, 0, .1); |
|
||||||
} |
|
||||||
|
|
||||||
.navbar.fullwidth .nav li:first-child a { |
|
||||||
border-left: 0; |
|
||||||
border-radius: 3px 0 0 3px; |
|
||||||
} |
|
||||||
|
|
||||||
.navbar.fullwidth .nav li:last-child a { |
|
||||||
border-right: 0; |
|
||||||
border-radius: 0 3px 3px 0; |
|
||||||
} |
} |
||||||
|
@ -1,5 +1,4 @@ |
|||||||
<?php |
<?php |
||||||
|
|
||||||
return array( |
return array( |
||||||
'adminEmail' => 'admin@example.com', |
'adminEmail' => 'admin@example.com', |
||||||
); |
); |
||||||
|
@ -1,3 +1,3 @@ |
|||||||
<?php |
<?php |
||||||
return array( |
return array( |
||||||
); |
); |
||||||
|
@ -1,3 +1,3 @@ |
|||||||
<?php |
<?php |
||||||
return array( |
return array( |
||||||
); |
); |
||||||
|
@ -1,3 +1,3 @@ |
|||||||
<?php |
<?php |
||||||
return array( |
return array( |
||||||
); |
); |
||||||
|
@ -1,3 +1,3 @@ |
|||||||
<?php |
<?php |
||||||
return array( |
return array( |
||||||
); |
); |
||||||
|
@ -1,3 +1,3 @@ |
|||||||
<?php |
<?php |
||||||
return array( |
return array( |
||||||
); |
); |
||||||
|
@ -1,3 +1,3 @@ |
|||||||
<?php |
<?php |
||||||
return array( |
return array( |
||||||
); |
); |
||||||
|
@ -1,3 +1,3 @@ |
|||||||
<?php |
<?php |
||||||
return array( |
return array( |
||||||
); |
); |
||||||
|
@ -1,3 +1,3 @@ |
|||||||
<?php |
<?php |
||||||
return array( |
return array( |
||||||
); |
); |
||||||
|
@ -1,5 +1,4 @@ |
|||||||
<?php |
<?php |
||||||
|
|
||||||
return array( |
return array( |
||||||
'adminEmail' => 'admin@example.com', |
'adminEmail' => 'admin@example.com', |
||||||
); |
); |
||||||
|
@ -1,16 +1,16 @@ |
|||||||
<?php |
<?php |
||||||
use yii\helpers\Html; |
use yii\helpers\Html; |
||||||
|
|
||||||
/** |
/** |
||||||
* @var yii\base\View $this |
* @var yii\base\View $this |
||||||
*/ |
*/ |
||||||
$this->title = 'About'; |
$this->title = 'About'; |
||||||
$this->params['breadcrumbs'][] = $this->title; |
$this->params['breadcrumbs'][] = $this->title; |
||||||
?> |
?> |
||||||
<h1><?php echo Html::encode($this->title); ?></h1>
|
<div class="site-about"> |
||||||
|
<h1><?php echo Html::encode($this->title); ?></h1>
|
||||||
<p> |
|
||||||
This is the About page. You may modify the following file to customize its content: |
|
||||||
</p> |
|
||||||
|
|
||||||
<code><?php echo __FILE__; ?></code>
|
<p>This is the About page. You may modify the following file to customize its content:</p> |
||||||
|
|
||||||
|
<code><?php echo __FILE__; ?></code>
|
||||||
|
</div> |
||||||
|
@ -1,78 +1,19 @@ |
|||||||
body { |
body { |
||||||
padding-top: 20px; |
padding-top: 70px; |
||||||
padding-bottom: 60px; |
|
||||||
} |
} |
||||||
|
|
||||||
/* Custom container */ |
.footer { |
||||||
.container { |
border-top: 1px solid #ddd; |
||||||
margin: 0 auto; |
margin-top: 30px; |
||||||
max-width: 1000px; |
padding-top: 15px; |
||||||
|
padding-bottom: 30px; |
||||||
} |
} |
||||||
|
|
||||||
.container > hr { |
|
||||||
margin: 60px 0; |
|
||||||
} |
|
||||||
|
|
||||||
/* Main marketing message and sign up button */ |
|
||||||
.jumbotron { |
.jumbotron { |
||||||
margin: 80px 0; |
text-align: center; |
||||||
text-align: center; |
background-color: transparent; |
||||||
} |
|
||||||
|
|
||||||
.jumbotron h1 { |
|
||||||
font-size: 100px; |
|
||||||
line-height: 1; |
|
||||||
} |
|
||||||
|
|
||||||
.jumbotron .lead { |
|
||||||
font-size: 24px; |
|
||||||
line-height: 1.25; |
|
||||||
} |
} |
||||||
|
|
||||||
.jumbotron .btn { |
.jumbotron .btn { |
||||||
font-size: 21px; |
font-size: 21px; |
||||||
padding: 14px 24px; |
padding: 14px 24px; |
||||||
} |
|
||||||
|
|
||||||
/* Supporting marketing content */ |
|
||||||
.marketing { |
|
||||||
margin: 60px 0; |
|
||||||
} |
|
||||||
|
|
||||||
.marketing p + h4 { |
|
||||||
margin-top: 28px; |
|
||||||
} |
|
||||||
|
|
||||||
/* Customize the navbar links to be fill the entire space of the .navbar */ |
|
||||||
.navbar.fullwidth .navbar-inner { |
|
||||||
padding: 0; |
|
||||||
} |
|
||||||
|
|
||||||
.navbar.fullwidth .nav { |
|
||||||
margin: 0; |
|
||||||
display: table; |
|
||||||
width: 100%; |
|
||||||
} |
|
||||||
|
|
||||||
.navbar.fullwidth .nav li { |
|
||||||
display: table-cell; |
|
||||||
width: 1%; |
|
||||||
float: none; |
|
||||||
} |
|
||||||
|
|
||||||
.navbar.fullwidth .nav li a { |
|
||||||
font-weight: bold; |
|
||||||
text-align: center; |
|
||||||
border-left: 1px solid rgba(255, 255, 255, .75); |
|
||||||
border-right: 1px solid rgba(0, 0, 0, .1); |
|
||||||
} |
|
||||||
|
|
||||||
.navbar.fullwidth .nav li:first-child a { |
|
||||||
border-left: 0; |
|
||||||
border-radius: 3px 0 0 3px; |
|
||||||
} |
|
||||||
|
|
||||||
.navbar.fullwidth .nav li:last-child a { |
|
||||||
border-right: 0; |
|
||||||
border-radius: 0 3px 3px 0; |
|
||||||
} |
} |
||||||
|
@ -0,0 +1,29 @@ |
|||||||
|
<?php |
||||||
|
|
||||||
|
use yii\helpers\Html; |
||||||
|
|
||||||
|
/** |
||||||
|
* @var yii\base\View $this |
||||||
|
* @var string $name |
||||||
|
* @var string $message |
||||||
|
* @var Exception $exception |
||||||
|
*/ |
||||||
|
|
||||||
|
$this->title = $name; |
||||||
|
?> |
||||||
|
<div class="site-error"> |
||||||
|
|
||||||
|
<h1><?php echo Html::encode($this->title); ?></h1>
|
||||||
|
|
||||||
|
<div class="alert alert-danger"> |
||||||
|
<?php echo nl2br(Html::encode($message)); ?> |
||||||
|
</div> |
||||||
|
|
||||||
|
<p> |
||||||
|
The above error occurred while the Web server was processing your request. |
||||||
|
</p> |
||||||
|
<p> |
||||||
|
Please contact us if you think this is a server error. Thank you. |
||||||
|
</p> |
||||||
|
|
||||||
|
</div> |
@ -0,0 +1,138 @@ |
|||||||
|
Advanced application template |
||||||
|
============================= |
||||||
|
|
||||||
|
This template is for large projects developed in teams where backend is divided from frontend, application is deployed |
||||||
|
to multiple servers etc. This application template also goes a bit further regarding features and provides essential |
||||||
|
database, signup and password restore out of the box. |
||||||
|
|
||||||
|
Directory structure |
||||||
|
------------------- |
||||||
|
|
||||||
|
The root directory contains the following subdirectories: |
||||||
|
|
||||||
|
- `backend` - backend web application. |
||||||
|
- `common` - files common to all applications. |
||||||
|
- `console` - console application. |
||||||
|
- `environments` - environment configs. |
||||||
|
- `frontend` - frontend web application. |
||||||
|
|
||||||
|
Root directory contains a set of files. |
||||||
|
|
||||||
|
- `.gitignore` contains a list of directories ignored by git version system. If you need something never get to your source |
||||||
|
code repository, add it there. |
||||||
|
- `composer.json` - Composer config described in detail below. |
||||||
|
- `init` - initialization script described in "Composer config described in detail below". |
||||||
|
- `init.bat` - same for Windows. |
||||||
|
- `LICENSE.md` - license info. Put your project license there. Especially when opensourcing. |
||||||
|
- `README.md` - basic info about installing template. Consider replacing it with information about your project and its |
||||||
|
installation. |
||||||
|
- `requirements.php` - Yii requirements checker. |
||||||
|
- `yii` - console application bootstrap. |
||||||
|
- `yii.bat` - same for Windows. |
||||||
|
|
||||||
|
Applications |
||||||
|
------------ |
||||||
|
|
||||||
|
There are three applications in advanced template: frontend, backend and console. Frontend is typically what is presented |
||||||
|
to end user, the project itself. Backend is admin panel, analytics and such functionality. Console is typically used for |
||||||
|
cron jobs and low-level server management. Also it's used during application deployment and handles migrations and assets. |
||||||
|
|
||||||
|
There's also a `common` directory that contains files used by more than one application. For example, `User` model. |
||||||
|
|
||||||
|
frontend and backend are both web applications and both contain `web` directory. That's the webroot you should point your |
||||||
|
webserver to. |
||||||
|
|
||||||
|
Each application has its own namespace and alias corresponding to its name. Same applies to common directory. |
||||||
|
|
||||||
|
Configuration and environments |
||||||
|
------------------------------ |
||||||
|
|
||||||
|
There are multiple problems with straightforward approach to configuration: |
||||||
|
|
||||||
|
- Each team member has its own configuration options. Commiting such config will affect other team members. |
||||||
|
- Production database password and API keys should not end up in repository. |
||||||
|
- There are multiple servers: development, testing, production. Each should have its own configuration. |
||||||
|
- Defining all configuration options for each case is very repetitive and takes too much time to maintain. |
||||||
|
|
||||||
|
In order to solve these issues Yii introduces environments concept that is very simple. Each environment is represented |
||||||
|
by a set of files under `environments` directory. `init` command is used to switch between these. What is really does is |
||||||
|
just copying everything from environment directory over the root directory where all applications are. |
||||||
|
|
||||||
|
Typically environment contains application bootstrap files such as `index.php` and config files postfixed with |
||||||
|
`-local.php`. These are added to `.gitignore` and never added to source code repository. |
||||||
|
|
||||||
|
In order to avoid duplication configurations are overrding each other. For example, frontend reads configuration in the |
||||||
|
following order: |
||||||
|
|
||||||
|
- `frontend/config/main.php` |
||||||
|
- `frontend/config/main-local.php` |
||||||
|
|
||||||
|
Parameters are read in the following order: |
||||||
|
|
||||||
|
- `common/config/params.php` |
||||||
|
- `common/config/params-local.php` |
||||||
|
- `frontend/config/params.php` |
||||||
|
- `frontend/config/params-local.php` |
||||||
|
|
||||||
|
The later config file overrides the former. |
||||||
|
|
||||||
|
Another difference is that most application component configurations are moved to params. Since params are read from |
||||||
|
`common` as well it allows you to specify database connection in one file and it will be then used for all applications. |
||||||
|
|
||||||
|
Configuring Composer |
||||||
|
-------------------- |
||||||
|
|
||||||
|
After application template is installed it's a good idea to adjust defaul `composer.json` that can be found in the root |
||||||
|
directory: |
||||||
|
|
||||||
|
```javascript |
||||||
|
{ |
||||||
|
"name": "yiisoft/yii2-app-advanced", |
||||||
|
"description": "Yii 2 Advanced Application Template", |
||||||
|
"keywords": ["yii", "framework", "advanced", "application template"], |
||||||
|
"homepage": "http://www.yiiframework.com/", |
||||||
|
"type": "project", |
||||||
|
"license": "BSD-3-Clause", |
||||||
|
"support": { |
||||||
|
"issues": "https://github.com/yiisoft/yii2/issues?state=open", |
||||||
|
"forum": "http://www.yiiframework.com/forum/", |
||||||
|
"wiki": "http://www.yiiframework.com/wiki/", |
||||||
|
"irc": "irc://irc.freenode.net/yii", |
||||||
|
"source": "https://github.com/yiisoft/yii2" |
||||||
|
}, |
||||||
|
"minimum-stability": "dev", |
||||||
|
"require": { |
||||||
|
"php": ">=5.3.0", |
||||||
|
"yiisoft/yii2": "dev-master", |
||||||
|
"yiisoft/yii2-composer": "dev-master" |
||||||
|
}, |
||||||
|
"scripts": { |
||||||
|
"post-create-project-cmd": [ |
||||||
|
"yii\\composer\\InstallHandler::setPermissions" |
||||||
|
] |
||||||
|
}, |
||||||
|
"extra": { |
||||||
|
"yii-install-writable": [ |
||||||
|
"backend/runtime", |
||||||
|
"backend/web/assets", |
||||||
|
|
||||||
|
"console/runtime", |
||||||
|
"console/migrations", |
||||||
|
|
||||||
|
"frontend/runtime", |
||||||
|
"frontend/web/assets" |
||||||
|
] |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
``` |
||||||
|
|
||||||
|
First we're updating basic information. Change `name`, `description`, `keywords`, `homepage` and `support` to match |
||||||
|
your project. |
||||||
|
|
||||||
|
Now the interesting part. You can add more packages your application needs to `require` section. |
||||||
|
For example, to use markdown helper you need to add `michelf/php-markdown`. All these packages are coming from |
||||||
|
[packagist.org](https://packagist.org/) so feel free to browse the website for useful code. |
||||||
|
|
||||||
|
After your `composer.json` is changed you can run `php composer.phar update`, wait till packages are downloaded and |
||||||
|
installed and then just use them. Autoloading of classes will be handled automatically. |
@ -0,0 +1,142 @@ |
|||||||
|
Basic application template |
||||||
|
========================== |
||||||
|
|
||||||
|
This template is a perfect fit for small projects or learning Yii2. |
||||||
|
|
||||||
|
The application has four pages: the homepage, the about page, the contact page and the login page. |
||||||
|
The contact page displays a contact form that users can fill in to submit their inquiries to the webmaster, |
||||||
|
and the login page allows users to be authenticated before accessing privileged contents. |
||||||
|
|
||||||
|
Directory structure |
||||||
|
------------------- |
||||||
|
|
||||||
|
The basic application does not divide application directories much. Here's the basic structure: |
||||||
|
|
||||||
|
- `commands` - console controllers. |
||||||
|
- `config` - configuration. |
||||||
|
- `controllers` - web controllers. |
||||||
|
- `models` - application models. |
||||||
|
- `runtime` - logs, states, file cache. |
||||||
|
- `views` - view templates. |
||||||
|
- `web` - webroot. |
||||||
|
|
||||||
|
Root directory contains a set of files. |
||||||
|
|
||||||
|
- `.gitignore` contains a list of directories ignored by git version system. If you need something never get to your source |
||||||
|
code repository, add it there. |
||||||
|
- `codeception.yml` - Codeception config. |
||||||
|
- `composer.json` - Composer config described in detail below. |
||||||
|
- `LICENSE.md` - license info. Put your project license there. Especially when opensourcing. |
||||||
|
- `README.md` - basic info about installing template. Consider replacing it with information about your project and its |
||||||
|
installation. |
||||||
|
- `requirements.php` - Yii requirements checker. |
||||||
|
- `yii` - console application bootstrap. |
||||||
|
- `yii.bat` - same for Windows. |
||||||
|
|
||||||
|
|
||||||
|
### config |
||||||
|
|
||||||
|
This directory contains configuration files: |
||||||
|
|
||||||
|
- `AppAsset.php` - definition of application assets such as CSS, JavaScript etc. Check [Managing assets](assets.md) for |
||||||
|
details. |
||||||
|
- `console.php` - console application configuration. |
||||||
|
- `params.php` - common application parameters. |
||||||
|
- `web.php` - web application configuration. |
||||||
|
- `web-test.php` - web application configuration used when running functional tests. |
||||||
|
|
||||||
|
All these files except `AppAsset.php` are returning arrays used to configure corresponding application properties. Check |
||||||
|
[Configuration](configuration.md) guide section for details. |
||||||
|
|
||||||
|
### views |
||||||
|
|
||||||
|
Views directory contains templates your application is using. In the basic template there are: |
||||||
|
|
||||||
|
``` |
||||||
|
layouts |
||||||
|
main.php |
||||||
|
site |
||||||
|
about.php |
||||||
|
contact.php |
||||||
|
error.php |
||||||
|
index.php |
||||||
|
login.php |
||||||
|
``` |
||||||
|
|
||||||
|
`layouts` contains HTML layouts i.e. page markup except content: doctype, head section, main menu, footer etc. |
||||||
|
The rest are typically controller views. By convention these are located in subdirectories matching controller id. For |
||||||
|
`SiteController` views are under `site`. Names of the views themselves are typically match controller action names. |
||||||
|
Partials are often named starting with underscore. |
||||||
|
|
||||||
|
### web |
||||||
|
|
||||||
|
Directory is a webroot. Typically a webserver is pointed into it. |
||||||
|
|
||||||
|
``` |
||||||
|
assets |
||||||
|
css |
||||||
|
index.php |
||||||
|
index-test.php |
||||||
|
``` |
||||||
|
|
||||||
|
`assets` contains published asset files such as CSS, JavaScript etc. Publishing process is automatic so you don't need |
||||||
|
to do anything with this directory other than making sure Yii has enough permissions to write to it. |
||||||
|
|
||||||
|
`css` contains plain CSS files and is useful for global CSS that isn't going to be compressed or merged by assets manager. |
||||||
|
|
||||||
|
`index.php` is the main web application bootstrap and is the central entry point for it. `index-test.php` is the entry |
||||||
|
point for functional testing. |
||||||
|
|
||||||
|
Configuring Composer |
||||||
|
-------------------- |
||||||
|
|
||||||
|
After application template is installed it's a good idea to adjust defaul `composer.json` that can be found in the root |
||||||
|
directory: |
||||||
|
|
||||||
|
```javascript |
||||||
|
{ |
||||||
|
"name": "yiisoft/yii2-app-basic", |
||||||
|
"description": "Yii 2 Basic Application Template", |
||||||
|
"keywords": ["yii", "framework", "basic", "application template"], |
||||||
|
"homepage": "http://www.yiiframework.com/", |
||||||
|
"type": "project", |
||||||
|
"license": "BSD-3-Clause", |
||||||
|
"support": { |
||||||
|
"issues": "https://github.com/yiisoft/yii2/issues?state=open", |
||||||
|
"forum": "http://www.yiiframework.com/forum/", |
||||||
|
"wiki": "http://www.yiiframework.com/wiki/", |
||||||
|
"irc": "irc://irc.freenode.net/yii", |
||||||
|
"source": "https://github.com/yiisoft/yii2" |
||||||
|
}, |
||||||
|
"minimum-stability": "dev", |
||||||
|
"require": { |
||||||
|
"php": ">=5.3.0", |
||||||
|
"yiisoft/yii2": "dev-master", |
||||||
|
"yiisoft/yii2-composer": "dev-master" |
||||||
|
}, |
||||||
|
"scripts": { |
||||||
|
"post-create-project-cmd": [ |
||||||
|
"yii\\composer\\InstallHandler::setPermissions" |
||||||
|
] |
||||||
|
}, |
||||||
|
"extra": { |
||||||
|
"yii-install-writable": [ |
||||||
|
"runtime", |
||||||
|
"web/assets" |
||||||
|
], |
||||||
|
"yii-install-executable": [ |
||||||
|
"yii" |
||||||
|
] |
||||||
|
} |
||||||
|
} |
||||||
|
``` |
||||||
|
|
||||||
|
First we're updating basic information. Change `name`, `description`, `keywords`, `homepage` and `support` to match |
||||||
|
your project. |
||||||
|
|
||||||
|
Now the interesting part. You can add more packages your application needs to `require` section. |
||||||
|
For example, to use markdown helper you need to add `michelf/php-markdown`. All these packages are coming from |
||||||
|
[packagist.org](https://packagist.org/) so feel free to browse the website for useful code. |
||||||
|
|
||||||
|
After your `composer.json` is changed you can run `php composer.phar update`, wait till packages are downloaded and |
||||||
|
installed and then just use them. Autoloading of classes will be handled automatically. |
@ -0,0 +1,6 @@ |
|||||||
|
Twitter Bootstrap widgets |
||||||
|
========================= |
||||||
|
|
||||||
|
Overview |
||||||
|
-------- |
||||||
|
|
@ -1,69 +0,0 @@ |
|||||||
Bootstrap with Yii |
|
||||||
================== |
|
||||||
|
|
||||||
Yii provides a few ready-to-use application templates. Based on your needs, you may |
|
||||||
choose one of them to bootstrap your project. |
|
||||||
|
|
||||||
In the following, we describe how to get started with the "Yii 2 Basic Application Template". |
|
||||||
|
|
||||||
|
|
||||||
### Install via Composer |
|
||||||
|
|
||||||
If you do not have [Composer](http://getcomposer.org/), you may download it from |
|
||||||
[http://getcomposer.org/](http://getcomposer.org/) or run the following command on Linux/Unix/MacOS: |
|
||||||
|
|
||||||
~~~ |
|
||||||
curl -s http://getcomposer.org/installer | php |
|
||||||
~~~ |
|
||||||
|
|
||||||
You can then install the Bootstrap Application using the following command: |
|
||||||
|
|
||||||
~~~ |
|
||||||
php composer.phar create-project --stability=dev yiisoft/yii2-app-basic yii-basic |
|
||||||
~~~ |
|
||||||
|
|
||||||
Now you should be able to access the Bootstrap Application using the URL `http://localhost/yii-basic/web/`, |
|
||||||
assuming `yii-basic` is directly under the document root of your Web server. |
|
||||||
|
|
||||||
|
|
||||||
As you can see, the application has four pages: the homepage, the about page, |
|
||||||
the contact page and the login page. The contact page displays a contact |
|
||||||
form that users can fill in to submit their inquiries to the webmaster, |
|
||||||
and the login page allows users to be authenticated before accessing privileged contents. |
|
||||||
|
|
||||||
|
|
||||||
The following diagram shows the directory structure of this application. |
|
||||||
|
|
||||||
~~~ |
|
||||||
yii-basic/ |
|
||||||
yii yii command line script for Unix/Linux |
|
||||||
yii.bat yii command line script for Windows |
|
||||||
requirements.php the requirement checker script |
|
||||||
commands/ containing customized yii console commands |
|
||||||
config/ containing configuration files |
|
||||||
console.php the console application configuration |
|
||||||
main.php the Web application configuration |
|
||||||
controllers/ containing controller class files |
|
||||||
SiteController.php the default controller class |
|
||||||
vendor/ containing third-party extensions and libraries |
|
||||||
models/ containing model class files |
|
||||||
User.php the User model |
|
||||||
LoginForm.php the form model for 'login' action |
|
||||||
ContactForm.php the form model for 'contact' action |
|
||||||
runtime/ containing temporarily generated files |
|
||||||
views/ containing controller view and layout files |
|
||||||
layouts/ containing layout view files |
|
||||||
main.php the base layout shared by all pages |
|
||||||
site/ containing view files for the 'site' controller |
|
||||||
about.php the view for the 'about' action |
|
||||||
contact.php the view for the 'contact' action |
|
||||||
index.php the view for the 'index' action |
|
||||||
login.php the view for the 'login' action |
|
||||||
web/ containing Web-accessible resources |
|
||||||
index.php Web application entry script file |
|
||||||
assets/ containing published resource files |
|
||||||
css/ containing CSS files |
|
||||||
~~~ |
|
||||||
|
|
||||||
|
|
||||||
TBD |
|
@ -0,0 +1,98 @@ |
|||||||
|
Configuration |
||||||
|
============= |
||||||
|
|
||||||
|
In Yii application and majority of components have sensible defaults so it's unlikely you spend lots of time configuring |
||||||
|
it. Still there are some mandatory options such as database connection you should set up. |
||||||
|
|
||||||
|
How application is configured depends on application template but there are some genral principles applying in any case. |
||||||
|
|
||||||
|
Configuring options in bootstrap file |
||||||
|
------------------------------------- |
||||||
|
|
||||||
|
For each application in Yii there is at least one bootstrap file. For web applications it's typically `index.php`, for |
||||||
|
console applications it's `yii`. Both are doing nearly the same job: |
||||||
|
|
||||||
|
1. Setting common constants. |
||||||
|
2. Including Yii itself. |
||||||
|
3. Including Composer autoloader. |
||||||
|
4. Reading config file into `$config`. |
||||||
|
5. Creating new application instance using `$config` and running it. |
||||||
|
|
||||||
|
Bootstrap file is not the part of framework but your application so it's OK to adjust it to fit your application. Typical |
||||||
|
adjustments are the value of `YII_DEBUG` that should never be `true` on production and the way config is read. |
||||||
|
|
||||||
|
Configuring application instance |
||||||
|
-------------------------------- |
||||||
|
|
||||||
|
It was mentioned above that application is configured in bootstrap file when its instance is created. Config is typically |
||||||
|
stored in a PHP file in `/config` directory of the application and looks like the following: |
||||||
|
|
||||||
|
```php |
||||||
|
<?php |
||||||
|
return array( |
||||||
|
'id' => 'applicationId', |
||||||
|
'basePath' => dirname(__DIR__), |
||||||
|
'components' => array( |
||||||
|
// ... |
||||||
|
), |
||||||
|
'params' => require(__DIR__ . '/params.php'), |
||||||
|
); |
||||||
|
``` |
||||||
|
|
||||||
|
In the above array keys are names of application properties. Depending on application type you can check properies of |
||||||
|
either `\yii\web\Application` or `\yii\console\Application`. Both are extended from `\yii\base\Application`. |
||||||
|
|
||||||
|
> Note that you can configure not only public class properties but anything accessible via setter. For example, to |
||||||
|
configure runtime path you can use key named `runtimePath`. There's no such property in the application class but |
||||||
|
since there's a corresponding setter named `setRuntimePath` it will be properly configured. |
||||||
|
|
||||||
|
Configuring application components |
||||||
|
---------------------------------- |
||||||
|
|
||||||
|
Majority of Yii functionality are application components. These are attached to application via its `components` property: |
||||||
|
|
||||||
|
```php |
||||||
|
<?php |
||||||
|
return array( |
||||||
|
'id' => 'applicationId', |
||||||
|
'basePath' => dirname(__DIR__), |
||||||
|
'components' => array( |
||||||
|
'cache' => array( |
||||||
|
'class' => 'yii\caching\FileCache', |
||||||
|
), |
||||||
|
'user' => array( |
||||||
|
'identityClass' => 'app\models\User', |
||||||
|
), |
||||||
|
'errorHandler' => array( |
||||||
|
'errorAction' => 'site/error', |
||||||
|
), |
||||||
|
'log' => array( |
||||||
|
'traceLevel' => YII_DEBUG ? 3 : 0, |
||||||
|
'targets' => array( |
||||||
|
array( |
||||||
|
'class' => 'yii\log\FileTarget', |
||||||
|
'levels' => array('error', 'warning'), |
||||||
|
), |
||||||
|
), |
||||||
|
), |
||||||
|
), |
||||||
|
// ... |
||||||
|
); |
||||||
|
``` |
||||||
|
|
||||||
|
In the above four components are configured: `cache`, `user`, `errorHandler`, `log`. Each entry key is a component ID |
||||||
|
and the value is the configuration array. ID is used to access the component like `\Yii::$app->myComponent`. |
||||||
|
Configuration array has one special key named `class` that sets component class. The rest of the keys and values are used |
||||||
|
to configure component properties in the same way as top-level keys are used to configure application properties. |
||||||
|
|
||||||
|
Each application has predefined set of the components. In case of configuring one of these `class` key is omitted and |
||||||
|
application default class is used instead. You can check `registerCoreComponents` method of the application you are using |
||||||
|
to get a list of component IDs and corresponding classes. |
||||||
|
|
||||||
|
Note that Yii is smart enough to configure the component when it's actually used i.e. if `cache` is never used it will |
||||||
|
not be instantiated and configured at all. |
||||||
|
|
||||||
|
Setting component defaults classwide |
||||||
|
------------------------------------ |
||||||
|
|
||||||
|
TBD |
@ -0,0 +1,9 @@ |
|||||||
|
Debug toolbar and debugger |
||||||
|
========================== |
||||||
|
|
||||||
|
Overview |
||||||
|
-------- |
||||||
|
|
||||||
|
Creating your own panels |
||||||
|
------------------------ |
||||||
|
|
@ -0,0 +1,78 @@ |
|||||||
|
/** |
||||||
|
* Yii GridView widget. |
||||||
|
* |
||||||
|
* This is the JavaScript widget used by the yii\grid\GridView widget. |
||||||
|
* |
||||||
|
* @link http://www.yiiframework.com/
|
||||||
|
* @copyright Copyright (c) 2008 Yii Software LLC |
||||||
|
* @license http://www.yiiframework.com/license/
|
||||||
|
* @author Qiang Xue <qiang.xue@gmail.com> |
||||||
|
* @since 2.0 |
||||||
|
*/ |
||||||
|
(function ($) { |
||||||
|
$.fn.yiiGridView = function (method) { |
||||||
|
if (methods[method]) { |
||||||
|
return methods[method].apply(this, Array.prototype.slice.call(arguments, 1)); |
||||||
|
} else if (typeof method === 'object' || !method) { |
||||||
|
return methods.init.apply(this, arguments); |
||||||
|
} else { |
||||||
|
$.error('Method ' + method + ' does not exist on jQuery.yiiGridView'); |
||||||
|
return false; |
||||||
|
} |
||||||
|
}; |
||||||
|
|
||||||
|
var defaults = { |
||||||
|
}; |
||||||
|
|
||||||
|
var methods = { |
||||||
|
init: function (options) { |
||||||
|
return this.each(function () { |
||||||
|
var $e = $(this); |
||||||
|
var settings = $.extend({}, defaults, options || {}); |
||||||
|
$e.data('yiiGridView', { |
||||||
|
settings: settings |
||||||
|
}); |
||||||
|
}); |
||||||
|
}, |
||||||
|
|
||||||
|
setSelectionColumn: function (options) { |
||||||
|
var $grid = $(this); |
||||||
|
var data = $grid.data('yiiGridView'); |
||||||
|
data.selectionColumn = options.name; |
||||||
|
if (!options.multiple) { |
||||||
|
return; |
||||||
|
} |
||||||
|
$grid.on('click.yiiGridView', "input[name='" + options.checkAll + "']", function () { |
||||||
|
$grid.find("input[name='" + options.name + "']:enabled").prop('checked', this.checked); |
||||||
|
}); |
||||||
|
$grid.on('click.yiiGridView', "input[name='" + options.name + "']:enabled", function () { |
||||||
|
var all = $grid.find("input[name='" + options.name + "']").length == $grid.find("input[name='" + options.name + "']:checked").length; |
||||||
|
$grid.find("input[name='" + options.checkAll + "']").prop('checked', all); |
||||||
|
}); |
||||||
|
}, |
||||||
|
|
||||||
|
getSelectedRows: function () { |
||||||
|
var $grid = $(this); |
||||||
|
var data = $grid.data('yiiGridView'); |
||||||
|
var keys = []; |
||||||
|
if (data.selectionColumn) { |
||||||
|
$grid.find("input[name='" + data.selectionColumn + "']:checked").each(function () { |
||||||
|
keys.push($(this).parent().closest('tr').data('key')); |
||||||
|
}); |
||||||
|
} |
||||||
|
return keys; |
||||||
|
}, |
||||||
|
|
||||||
|
destroy: function () { |
||||||
|
return this.each(function () { |
||||||
|
$(window).unbind('.yiiGridView'); |
||||||
|
$(this).removeData('yiiGridView'); |
||||||
|
}); |
||||||
|
}, |
||||||
|
|
||||||
|
data: function() { |
||||||
|
return this.data('yiiGridView'); |
||||||
|
} |
||||||
|
}; |
||||||
|
})(window.jQuery); |
||||||
|
|
@ -1,25 +0,0 @@ |
|||||||
<?php |
|
||||||
/** |
|
||||||
* @link http://www.yiiframework.com/ |
|
||||||
* @copyright Copyright (c) 2008 Yii Software LLC |
|
||||||
* @license http://www.yiiframework.com/license/ |
|
||||||
*/ |
|
||||||
|
|
||||||
namespace yii\base; |
|
||||||
|
|
||||||
/** |
|
||||||
* UnknownClassException represents an exception caused by accessing an unknown class. |
|
||||||
* |
|
||||||
* @author Qiang Xue <qiang.xue@gmail.com> |
|
||||||
* @since 2.0 |
|
||||||
*/ |
|
||||||
class UnknownClassException extends Exception |
|
||||||
{ |
|
||||||
/** |
|
||||||
* @return string the user-friendly name of this exception |
|
||||||
*/ |
|
||||||
public function getName() |
|
||||||
{ |
|
||||||
return \Yii::t('yii', 'Unknown Class'); |
|
||||||
} |
|
||||||
} |
|
@ -1,26 +0,0 @@ |
|||||||
<?php |
|
||||||
/** |
|
||||||
* @link http://www.yiiframework.com/ |
|
||||||
* @copyright Copyright (c) 2008 Yii Software LLC |
|
||||||
* @license http://www.yiiframework.com/license/ |
|
||||||
*/ |
|
||||||
|
|
||||||
namespace yii\bootstrap; |
|
||||||
use yii\web\AssetBundle; |
|
||||||
|
|
||||||
/** |
|
||||||
* @author Qiang Xue <qiang.xue@gmail.com> |
|
||||||
* @since 2.0 |
|
||||||
*/ |
|
||||||
class AffixAsset extends AssetBundle |
|
||||||
{ |
|
||||||
public $sourcePath = '@yii/bootstrap/assets'; |
|
||||||
public $js = array( |
|
||||||
'js/bootstrap-affix.js', |
|
||||||
); |
|
||||||
public $depends = array( |
|
||||||
'yii\bootstrap\TransitionAsset', |
|
||||||
'yii\bootstrap\BootstrapAsset', |
|
||||||
'yii\web\JqueryAsset', |
|
||||||
); |
|
||||||
} |
|
@ -1,26 +0,0 @@ |
|||||||
<?php |
|
||||||
/** |
|
||||||
* @link http://www.yiiframework.com/ |
|
||||||
* @copyright Copyright (c) 2008 Yii Software LLC |
|
||||||
* @license http://www.yiiframework.com/license/ |
|
||||||
*/ |
|
||||||
|
|
||||||
namespace yii\bootstrap; |
|
||||||
use yii\web\AssetBundle; |
|
||||||
|
|
||||||
/** |
|
||||||
* @author Qiang Xue <qiang.xue@gmail.com> |
|
||||||
* @since 2.0 |
|
||||||
*/ |
|
||||||
class AlertAsset extends AssetBundle |
|
||||||
{ |
|
||||||
public $sourcePath = '@yii/bootstrap/assets'; |
|
||||||
public $js = array( |
|
||||||
'js/bootstrap-alert.js', |
|
||||||
); |
|
||||||
public $depends = array( |
|
||||||
'yii\bootstrap\TransitionAsset', |
|
||||||
'yii\bootstrap\BootstrapAsset', |
|
||||||
'yii\web\JqueryAsset', |
|
||||||
); |
|
||||||
} |
|
@ -1,26 +0,0 @@ |
|||||||
<?php |
|
||||||
/** |
|
||||||
* @link http://www.yiiframework.com/ |
|
||||||
* @copyright Copyright (c) 2008 Yii Software LLC |
|
||||||
* @license http://www.yiiframework.com/license/ |
|
||||||
*/ |
|
||||||
|
|
||||||
namespace yii\bootstrap; |
|
||||||
use yii\web\AssetBundle; |
|
||||||
|
|
||||||
/** |
|
||||||
* @author Qiang Xue <qiang.xue@gmail.com> |
|
||||||
* @since 2.0 |
|
||||||
*/ |
|
||||||
class ButtonAsset extends AssetBundle |
|
||||||
{ |
|
||||||
public $sourcePath = '@yii/bootstrap/assets'; |
|
||||||
public $js = array( |
|
||||||
'js/bootstrap-button.js', |
|
||||||
); |
|
||||||
public $depends = array( |
|
||||||
'yii\bootstrap\TransitionAsset', |
|
||||||
'yii\bootstrap\BootstrapAsset', |
|
||||||
'yii\web\JqueryAsset', |
|
||||||
); |
|
||||||
} |
|
@ -1,26 +0,0 @@ |
|||||||
<?php |
|
||||||
/** |
|
||||||
* @link http://www.yiiframework.com/ |
|
||||||
* @copyright Copyright (c) 2008 Yii Software LLC |
|
||||||
* @license http://www.yiiframework.com/license/ |
|
||||||
*/ |
|
||||||
|
|
||||||
namespace yii\bootstrap; |
|
||||||
use yii\web\AssetBundle; |
|
||||||
|
|
||||||
/** |
|
||||||
* @author Qiang Xue <qiang.xue@gmail.com> |
|
||||||
* @since 2.0 |
|
||||||
*/ |
|
||||||
class CarouselAsset extends AssetBundle |
|
||||||
{ |
|
||||||
public $sourcePath = '@yii/bootstrap/assets'; |
|
||||||
public $js = array( |
|
||||||
'js/bootstrap-carousel.js', |
|
||||||
); |
|
||||||
public $depends = array( |
|
||||||
'yii\bootstrap\TransitionAsset', |
|
||||||
'yii\bootstrap\BootstrapAsset', |
|
||||||
'yii\web\JqueryAsset', |
|
||||||
); |
|
||||||
} |
|
@ -1,26 +0,0 @@ |
|||||||
<?php |
|
||||||
/** |
|
||||||
* @link http://www.yiiframework.com/ |
|
||||||
* @copyright Copyright (c) 2008 Yii Software LLC |
|
||||||
* @license http://www.yiiframework.com/license/ |
|
||||||
*/ |
|
||||||
|
|
||||||
namespace yii\bootstrap; |
|
||||||
use yii\web\AssetBundle; |
|
||||||
|
|
||||||
/** |
|
||||||
* @author Qiang Xue <qiang.xue@gmail.com> |
|
||||||
* @since 2.0 |
|
||||||
*/ |
|
||||||
class CollapseAsset extends AssetBundle |
|
||||||
{ |
|
||||||
public $sourcePath = '@yii/bootstrap/assets'; |
|
||||||
public $js = array( |
|
||||||
'js/bootstrap-collapse.js', |
|
||||||
); |
|
||||||
public $depends = array( |
|
||||||
'yii\bootstrap\TransitionAsset', |
|
||||||
'yii\bootstrap\BootstrapAsset', |
|
||||||
'yii\web\JqueryAsset', |
|
||||||
); |
|
||||||
} |
|
@ -1,26 +0,0 @@ |
|||||||
<?php |
|
||||||
/** |
|
||||||
* @link http://www.yiiframework.com/ |
|
||||||
* @copyright Copyright (c) 2008 Yii Software LLC |
|
||||||
* @license http://www.yiiframework.com/license/ |
|
||||||
*/ |
|
||||||
|
|
||||||
namespace yii\bootstrap; |
|
||||||
use yii\web\AssetBundle; |
|
||||||
|
|
||||||
/** |
|
||||||
* @author Qiang Xue <qiang.xue@gmail.com> |
|
||||||
* @since 2.0 |
|
||||||
*/ |
|
||||||
class DropdownAsset extends AssetBundle |
|
||||||
{ |
|
||||||
public $sourcePath = '@yii/bootstrap/assets'; |
|
||||||
public $js = array( |
|
||||||
'js/bootstrap-dropdown.js', |
|
||||||
); |
|
||||||
public $depends = array( |
|
||||||
'yii\bootstrap\TransitionAsset', |
|
||||||
'yii\bootstrap\BootstrapAsset', |
|
||||||
'yii\web\JqueryAsset', |
|
||||||
); |
|
||||||
} |
|
@ -1,26 +0,0 @@ |
|||||||
<?php |
|
||||||
/** |
|
||||||
* @link http://www.yiiframework.com/ |
|
||||||
* @copyright Copyright (c) 2008 Yii Software LLC |
|
||||||
* @license http://www.yiiframework.com/license/ |
|
||||||
*/ |
|
||||||
|
|
||||||
namespace yii\bootstrap; |
|
||||||
use yii\web\AssetBundle; |
|
||||||
|
|
||||||
/** |
|
||||||
* @author Qiang Xue <qiang.xue@gmail.com> |
|
||||||
* @since 2.0 |
|
||||||
*/ |
|
||||||
class ModalAsset extends AssetBundle |
|
||||||
{ |
|
||||||
public $sourcePath = '@yii/bootstrap/assets'; |
|
||||||
public $js = array( |
|
||||||
'js/bootstrap-modal.js', |
|
||||||
); |
|
||||||
public $depends = array( |
|
||||||
'yii\bootstrap\TransitionAsset', |
|
||||||
'yii\bootstrap\BootstrapAsset', |
|
||||||
'yii\web\JqueryAsset', |
|
||||||
); |
|
||||||
} |
|
@ -1,24 +0,0 @@ |
|||||||
<?php |
|
||||||
/** |
|
||||||
* @link http://www.yiiframework.com/ |
|
||||||
* @copyright Copyright (c) 2008 Yii Software LLC |
|
||||||
* @license http://www.yiiframework.com/license/ |
|
||||||
*/ |
|
||||||
|
|
||||||
namespace yii\bootstrap; |
|
||||||
use yii\web\AssetBundle; |
|
||||||
|
|
||||||
/** |
|
||||||
* @author Qiang Xue <qiang.xue@gmail.com> |
|
||||||
* @since 2.0 |
|
||||||
*/ |
|
||||||
class ResponsiveAsset extends AssetBundle |
|
||||||
{ |
|
||||||
public $sourcePath = '@yii/bootstrap/assets'; |
|
||||||
public $css = array( |
|
||||||
'css/bootstrap-responsive.css', |
|
||||||
); |
|
||||||
public $depends = array( |
|
||||||
'yii\bootstrap\BootstrapAsset', |
|
||||||
); |
|
||||||
} |
|
@ -1,26 +0,0 @@ |
|||||||
<?php |
|
||||||
/** |
|
||||||
* @link http://www.yiiframework.com/ |
|
||||||
* @copyright Copyright (c) 2008 Yii Software LLC |
|
||||||
* @license http://www.yiiframework.com/license/ |
|
||||||
*/ |
|
||||||
|
|
||||||
namespace yii\bootstrap; |
|
||||||
use yii\web\AssetBundle; |
|
||||||
|
|
||||||
/** |
|
||||||
* @author Qiang Xue <qiang.xue@gmail.com> |
|
||||||
* @since 2.0 |
|
||||||
*/ |
|
||||||
class ScrollspyAsset extends AssetBundle |
|
||||||
{ |
|
||||||
public $sourcePath = '@yii/bootstrap/assets'; |
|
||||||
public $js = array( |
|
||||||
'js/bootstrap-scrollspy.js', |
|
||||||
); |
|
||||||
public $depends = array( |
|
||||||
'yii\bootstrap\TransitionAsset', |
|
||||||
'yii\bootstrap\BootstrapAsset', |
|
||||||
'yii\web\JqueryAsset', |
|
||||||
); |
|
||||||
} |
|
@ -1,26 +0,0 @@ |
|||||||
<?php |
|
||||||
/** |
|
||||||
* @link http://www.yiiframework.com/ |
|
||||||
* @copyright Copyright (c) 2008 Yii Software LLC |
|
||||||
* @license http://www.yiiframework.com/license/ |
|
||||||
*/ |
|
||||||
|
|
||||||
namespace yii\bootstrap; |
|
||||||
use yii\web\AssetBundle; |
|
||||||
|
|
||||||
/** |
|
||||||
* @author Qiang Xue <qiang.xue@gmail.com> |
|
||||||
* @since 2.0 |
|
||||||
*/ |
|
||||||
class TabAsset extends AssetBundle |
|
||||||
{ |
|
||||||
public $sourcePath = '@yii/bootstrap/assets'; |
|
||||||
public $js = array( |
|
||||||
'js/bootstrap-tab.js', |
|
||||||
); |
|
||||||
public $depends = array( |
|
||||||
'yii\bootstrap\TransitionAsset', |
|
||||||
'yii\bootstrap\BootstrapAsset', |
|
||||||
'yii\web\JqueryAsset', |
|
||||||
); |
|
||||||
} |
|
@ -1,26 +0,0 @@ |
|||||||
<?php |
|
||||||
/** |
|
||||||
* @link http://www.yiiframework.com/ |
|
||||||
* @copyright Copyright (c) 2008 Yii Software LLC |
|
||||||
* @license http://www.yiiframework.com/license/ |
|
||||||
*/ |
|
||||||
|
|
||||||
namespace yii\bootstrap; |
|
||||||
use yii\web\AssetBundle; |
|
||||||
|
|
||||||
/** |
|
||||||
* @author Qiang Xue <qiang.xue@gmail.com> |
|
||||||
* @since 2.0 |
|
||||||
*/ |
|
||||||
class TooltipAsset extends AssetBundle |
|
||||||
{ |
|
||||||
public $sourcePath = '@yii/bootstrap/assets'; |
|
||||||
public $js = array( |
|
||||||
'js/bootstrap-tooltip.js', |
|
||||||
); |
|
||||||
public $depends = array( |
|
||||||
'yii\bootstrap\TransitionAsset', |
|
||||||
'yii\bootstrap\BootstrapAsset', |
|
||||||
'yii\web\JqueryAsset', |
|
||||||
); |
|
||||||
} |
|
@ -1,26 +0,0 @@ |
|||||||
<?php |
|
||||||
/** |
|
||||||
* @link http://www.yiiframework.com/ |
|
||||||
* @copyright Copyright (c) 2008 Yii Software LLC |
|
||||||
* @license http://www.yiiframework.com/license/ |
|
||||||
*/ |
|
||||||
|
|
||||||
namespace yii\bootstrap; |
|
||||||
use yii\web\AssetBundle; |
|
||||||
|
|
||||||
/** |
|
||||||
* @author Qiang Xue <qiang.xue@gmail.com> |
|
||||||
* @since 2.0 |
|
||||||
*/ |
|
||||||
class TypeaheadAsset extends AssetBundle |
|
||||||
{ |
|
||||||
public $sourcePath = '@yii/bootstrap/assets'; |
|
||||||
public $js = array( |
|
||||||
'js/bootstrap-typeahead.js', |
|
||||||
); |
|
||||||
public $depends = array( |
|
||||||
'yii\bootstrap\TransitionAsset', |
|
||||||
'yii\bootstrap\BootstrapAsset', |
|
||||||
'yii\web\JqueryAsset', |
|
||||||
); |
|
||||||
} |
|
@ -1,24 +0,0 @@ |
|||||||
<?php |
|
||||||
/** |
|
||||||
* @link http://www.yiiframework.com/ |
|
||||||
* @copyright Copyright (c) 2008 Yii Software LLC |
|
||||||
* @license http://www.yiiframework.com/license/ |
|
||||||
*/ |
|
||||||
|
|
||||||
return array( |
|
||||||
yii\bootstrap\BootstrapAsset::className(), |
|
||||||
yii\bootstrap\ResponsiveAsset::className(), |
|
||||||
yii\bootstrap\DropdownAsset::className(), |
|
||||||
yii\bootstrap\TransitionAsset::className(), |
|
||||||
yii\bootstrap\AffixAsset::className(), |
|
||||||
yii\bootstrap\AlertAsset::className(), |
|
||||||
yii\bootstrap\ButtonAsset::className(), |
|
||||||
yii\bootstrap\CarouselAsset::className(), |
|
||||||
yii\bootstrap\CollapseAsset::className(), |
|
||||||
yii\bootstrap\ModalAsset::className(), |
|
||||||
yii\bootstrap\PopoverAsset::className(), |
|
||||||
yii\bootstrap\TooltipAsset::className(), |
|
||||||
yii\bootstrap\ScrollspyAsset::className(), |
|
||||||
yii\bootstrap\TabAsset::className(), |
|
||||||
yii\bootstrap\TypeaheadAsset::className(), |
|
||||||
); |
|
File diff suppressed because one or more lines are too long
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
File diff suppressed because it is too large
Load Diff
File diff suppressed because one or more lines are too long
Binary file not shown.
Binary file not shown.
After Width: | Height: | Size: 50 KiB |
Binary file not shown.
Binary file not shown.
Before Width: | Height: | Size: 8.6 KiB |
Before Width: | Height: | Size: 12 KiB |
@ -1,117 +0,0 @@ |
|||||||
/* ========================================================== |
|
||||||
* bootstrap-affix.js v2.3.2 |
|
||||||
* http://twitter.github.com/bootstrap/javascript.html#affix
|
|
||||||
* ========================================================== |
|
||||||
* Copyright 2012 Twitter, Inc. |
|
||||||
* |
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
|
||||||
* you may not use this file except in compliance with the License. |
|
||||||
* You may obtain a copy of the License at |
|
||||||
* |
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
* |
|
||||||
* Unless required by applicable law or agreed to in writing, software |
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS, |
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|
||||||
* See the License for the specific language governing permissions and |
|
||||||
* limitations under the License. |
|
||||||
* ========================================================== */ |
|
||||||
|
|
||||||
|
|
||||||
!function ($) { |
|
||||||
|
|
||||||
"use strict"; // jshint ;_;
|
|
||||||
|
|
||||||
|
|
||||||
/* AFFIX CLASS DEFINITION |
|
||||||
* ====================== */ |
|
||||||
|
|
||||||
var Affix = function (element, options) { |
|
||||||
this.options = $.extend({}, $.fn.affix.defaults, options) |
|
||||||
this.$window = $(window) |
|
||||||
.on('scroll.affix.data-api', $.proxy(this.checkPosition, this)) |
|
||||||
.on('click.affix.data-api', $.proxy(function () { setTimeout($.proxy(this.checkPosition, this), 1) }, this)) |
|
||||||
this.$element = $(element) |
|
||||||
this.checkPosition() |
|
||||||
} |
|
||||||
|
|
||||||
Affix.prototype.checkPosition = function () { |
|
||||||
if (!this.$element.is(':visible')) return |
|
||||||
|
|
||||||
var scrollHeight = $(document).height() |
|
||||||
, scrollTop = this.$window.scrollTop() |
|
||||||
, position = this.$element.offset() |
|
||||||
, offset = this.options.offset |
|
||||||
, offsetBottom = offset.bottom |
|
||||||
, offsetTop = offset.top |
|
||||||
, reset = 'affix affix-top affix-bottom' |
|
||||||
, affix |
|
||||||
|
|
||||||
if (typeof offset != 'object') offsetBottom = offsetTop = offset |
|
||||||
if (typeof offsetTop == 'function') offsetTop = offset.top() |
|
||||||
if (typeof offsetBottom == 'function') offsetBottom = offset.bottom() |
|
||||||
|
|
||||||
affix = this.unpin != null && (scrollTop + this.unpin <= position.top) ? |
|
||||||
false : offsetBottom != null && (position.top + this.$element.height() >= scrollHeight - offsetBottom) ? |
|
||||||
'bottom' : offsetTop != null && scrollTop <= offsetTop ? |
|
||||||
'top' : false |
|
||||||
|
|
||||||
if (this.affixed === affix) return |
|
||||||
|
|
||||||
this.affixed = affix |
|
||||||
this.unpin = affix == 'bottom' ? position.top - scrollTop : null |
|
||||||
|
|
||||||
this.$element.removeClass(reset).addClass('affix' + (affix ? '-' + affix : '')) |
|
||||||
} |
|
||||||
|
|
||||||
|
|
||||||
/* AFFIX PLUGIN DEFINITION |
|
||||||
* ======================= */ |
|
||||||
|
|
||||||
var old = $.fn.affix |
|
||||||
|
|
||||||
$.fn.affix = function (option) { |
|
||||||
return this.each(function () { |
|
||||||
var $this = $(this) |
|
||||||
, data = $this.data('affix') |
|
||||||
, options = typeof option == 'object' && option |
|
||||||
if (!data) $this.data('affix', (data = new Affix(this, options))) |
|
||||||
if (typeof option == 'string') data[option]() |
|
||||||
}) |
|
||||||
} |
|
||||||
|
|
||||||
$.fn.affix.Constructor = Affix |
|
||||||
|
|
||||||
$.fn.affix.defaults = { |
|
||||||
offset: 0 |
|
||||||
} |
|
||||||
|
|
||||||
|
|
||||||
/* AFFIX NO CONFLICT |
|
||||||
* ================= */ |
|
||||||
|
|
||||||
$.fn.affix.noConflict = function () { |
|
||||||
$.fn.affix = old |
|
||||||
return this |
|
||||||
} |
|
||||||
|
|
||||||
|
|
||||||
/* AFFIX DATA-API |
|
||||||
* ============== */ |
|
||||||
|
|
||||||
$(window).on('load', function () { |
|
||||||
$('[data-spy="affix"]').each(function () { |
|
||||||
var $spy = $(this) |
|
||||||
, data = $spy.data() |
|
||||||
|
|
||||||
data.offset = data.offset || {} |
|
||||||
|
|
||||||
data.offsetBottom && (data.offset.bottom = data.offsetBottom) |
|
||||||
data.offsetTop && (data.offset.top = data.offsetTop) |
|
||||||
|
|
||||||
$spy.affix(data) |
|
||||||
}) |
|
||||||
}) |
|
||||||
|
|
||||||
|
|
||||||
}(window.jQuery); |
|
@ -1,99 +0,0 @@ |
|||||||
/* ========================================================== |
|
||||||
* bootstrap-alert.js v2.3.2 |
|
||||||
* http://twitter.github.com/bootstrap/javascript.html#alerts
|
|
||||||
* ========================================================== |
|
||||||
* Copyright 2012 Twitter, Inc. |
|
||||||
* |
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
|
||||||
* you may not use this file except in compliance with the License. |
|
||||||
* You may obtain a copy of the License at |
|
||||||
* |
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
* |
|
||||||
* Unless required by applicable law or agreed to in writing, software |
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS, |
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|
||||||
* See the License for the specific language governing permissions and |
|
||||||
* limitations under the License. |
|
||||||
* ========================================================== */ |
|
||||||
|
|
||||||
|
|
||||||
!function ($) { |
|
||||||
|
|
||||||
"use strict"; // jshint ;_;
|
|
||||||
|
|
||||||
|
|
||||||
/* ALERT CLASS DEFINITION |
|
||||||
* ====================== */ |
|
||||||
|
|
||||||
var dismiss = '[data-dismiss="alert"]' |
|
||||||
, Alert = function (el) { |
|
||||||
$(el).on('click', dismiss, this.close) |
|
||||||
} |
|
||||||
|
|
||||||
Alert.prototype.close = function (e) { |
|
||||||
var $this = $(this) |
|
||||||
, selector = $this.attr('data-target') |
|
||||||
, $parent |
|
||||||
|
|
||||||
if (!selector) { |
|
||||||
selector = $this.attr('href') |
|
||||||
selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7
|
|
||||||
} |
|
||||||
|
|
||||||
$parent = $(selector) |
|
||||||
|
|
||||||
e && e.preventDefault() |
|
||||||
|
|
||||||
$parent.length || ($parent = $this.hasClass('alert') ? $this : $this.parent()) |
|
||||||
|
|
||||||
$parent.trigger(e = $.Event('close')) |
|
||||||
|
|
||||||
if (e.isDefaultPrevented()) return |
|
||||||
|
|
||||||
$parent.removeClass('in') |
|
||||||
|
|
||||||
function removeElement() { |
|
||||||
$parent |
|
||||||
.trigger('closed') |
|
||||||
.remove() |
|
||||||
} |
|
||||||
|
|
||||||
$.support.transition && $parent.hasClass('fade') ? |
|
||||||
$parent.on($.support.transition.end, removeElement) : |
|
||||||
removeElement() |
|
||||||
} |
|
||||||
|
|
||||||
|
|
||||||
/* ALERT PLUGIN DEFINITION |
|
||||||
* ======================= */ |
|
||||||
|
|
||||||
var old = $.fn.alert |
|
||||||
|
|
||||||
$.fn.alert = function (option) { |
|
||||||
return this.each(function () { |
|
||||||
var $this = $(this) |
|
||||||
, data = $this.data('alert') |
|
||||||
if (!data) $this.data('alert', (data = new Alert(this))) |
|
||||||
if (typeof option == 'string') data[option].call($this) |
|
||||||
}) |
|
||||||
} |
|
||||||
|
|
||||||
$.fn.alert.Constructor = Alert |
|
||||||
|
|
||||||
|
|
||||||
/* ALERT NO CONFLICT |
|
||||||
* ================= */ |
|
||||||
|
|
||||||
$.fn.alert.noConflict = function () { |
|
||||||
$.fn.alert = old |
|
||||||
return this |
|
||||||
} |
|
||||||
|
|
||||||
|
|
||||||
/* ALERT DATA-API |
|
||||||
* ============== */ |
|
||||||
|
|
||||||
$(document).on('click.alert.data-api', dismiss, Alert.prototype.close) |
|
||||||
|
|
||||||
}(window.jQuery); |
|
@ -1,105 +0,0 @@ |
|||||||
/* ============================================================ |
|
||||||
* bootstrap-button.js v2.3.2 |
|
||||||
* http://twitter.github.com/bootstrap/javascript.html#buttons
|
|
||||||
* ============================================================ |
|
||||||
* Copyright 2012 Twitter, Inc. |
|
||||||
* |
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
|
||||||
* you may not use this file except in compliance with the License. |
|
||||||
* You may obtain a copy of the License at |
|
||||||
* |
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
* |
|
||||||
* Unless required by applicable law or agreed to in writing, software |
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS, |
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|
||||||
* See the License for the specific language governing permissions and |
|
||||||
* limitations under the License. |
|
||||||
* ============================================================ */ |
|
||||||
|
|
||||||
|
|
||||||
!function ($) { |
|
||||||
|
|
||||||
"use strict"; // jshint ;_;
|
|
||||||
|
|
||||||
|
|
||||||
/* BUTTON PUBLIC CLASS DEFINITION |
|
||||||
* ============================== */ |
|
||||||
|
|
||||||
var Button = function (element, options) { |
|
||||||
this.$element = $(element) |
|
||||||
this.options = $.extend({}, $.fn.button.defaults, options) |
|
||||||
} |
|
||||||
|
|
||||||
Button.prototype.setState = function (state) { |
|
||||||
var d = 'disabled' |
|
||||||
, $el = this.$element |
|
||||||
, data = $el.data() |
|
||||||
, val = $el.is('input') ? 'val' : 'html' |
|
||||||
|
|
||||||
state = state + 'Text' |
|
||||||
data.resetText || $el.data('resetText', $el[val]()) |
|
||||||
|
|
||||||
$el[val](data[state] || this.options[state]) |
|
||||||
|
|
||||||
// push to event loop to allow forms to submit
|
|
||||||
setTimeout(function () { |
|
||||||
state == 'loadingText' ? |
|
||||||
$el.addClass(d).attr(d, d) : |
|
||||||
$el.removeClass(d).removeAttr(d) |
|
||||||
}, 0) |
|
||||||
} |
|
||||||
|
|
||||||
Button.prototype.toggle = function () { |
|
||||||
var $parent = this.$element.closest('[data-toggle="buttons-radio"]') |
|
||||||
|
|
||||||
$parent && $parent |
|
||||||
.find('.active') |
|
||||||
.removeClass('active') |
|
||||||
|
|
||||||
this.$element.toggleClass('active') |
|
||||||
} |
|
||||||
|
|
||||||
|
|
||||||
/* BUTTON PLUGIN DEFINITION |
|
||||||
* ======================== */ |
|
||||||
|
|
||||||
var old = $.fn.button |
|
||||||
|
|
||||||
$.fn.button = function (option) { |
|
||||||
return this.each(function () { |
|
||||||
var $this = $(this) |
|
||||||
, data = $this.data('button') |
|
||||||
, options = typeof option == 'object' && option |
|
||||||
if (!data) $this.data('button', (data = new Button(this, options))) |
|
||||||
if (option == 'toggle') data.toggle() |
|
||||||
else if (option) data.setState(option) |
|
||||||
}) |
|
||||||
} |
|
||||||
|
|
||||||
$.fn.button.defaults = { |
|
||||||
loadingText: 'loading...' |
|
||||||
} |
|
||||||
|
|
||||||
$.fn.button.Constructor = Button |
|
||||||
|
|
||||||
|
|
||||||
/* BUTTON NO CONFLICT |
|
||||||
* ================== */ |
|
||||||
|
|
||||||
$.fn.button.noConflict = function () { |
|
||||||
$.fn.button = old |
|
||||||
return this |
|
||||||
} |
|
||||||
|
|
||||||
|
|
||||||
/* BUTTON DATA-API |
|
||||||
* =============== */ |
|
||||||
|
|
||||||
$(document).on('click.button.data-api', '[data-toggle^=button]', function (e) { |
|
||||||
var $btn = $(e.target) |
|
||||||
if (!$btn.hasClass('btn')) $btn = $btn.closest('.btn') |
|
||||||
$btn.button('toggle') |
|
||||||
}) |
|
||||||
|
|
||||||
}(window.jQuery); |
|
@ -1,207 +0,0 @@ |
|||||||
/* ========================================================== |
|
||||||
* bootstrap-carousel.js v2.3.2 |
|
||||||
* http://twitter.github.com/bootstrap/javascript.html#carousel
|
|
||||||
* ========================================================== |
|
||||||
* Copyright 2012 Twitter, Inc. |
|
||||||
* |
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License"); |
|
||||||
* you may not use this file except in compliance with the License. |
|
||||||
* You may obtain a copy of the License at |
|
||||||
* |
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
* |
|
||||||
* Unless required by applicable law or agreed to in writing, software |
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS, |
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|
||||||
* See the License for the specific language governing permissions and |
|
||||||
* limitations under the License. |
|
||||||
* ========================================================== */ |
|
||||||
|
|
||||||
|
|
||||||
!function ($) { |
|
||||||
|
|
||||||
"use strict"; // jshint ;_;
|
|
||||||
|
|
||||||
|
|
||||||
/* CAROUSEL CLASS DEFINITION |
|
||||||
* ========================= */ |
|
||||||
|
|
||||||
var Carousel = function (element, options) { |
|
||||||
this.$element = $(element) |
|
||||||
this.$indicators = this.$element.find('.carousel-indicators') |
|
||||||
this.options = options |
|
||||||
this.options.pause == 'hover' && this.$element |
|
||||||
.on('mouseenter', $.proxy(this.pause, this)) |
|
||||||
.on('mouseleave', $.proxy(this.cycle, this)) |
|
||||||
} |
|
||||||
|
|
||||||
Carousel.prototype = { |
|
||||||
|
|
||||||
cycle: function (e) { |
|
||||||
if (!e) this.paused = false |
|
||||||
if (this.interval) clearInterval(this.interval); |
|
||||||
this.options.interval |
|
||||||
&& !this.paused |
|
||||||
&& (this.interval = setInterval($.proxy(this.next, this), this.options.interval)) |
|
||||||
return this |
|
||||||
} |
|
||||||
|
|
||||||
, getActiveIndex: function () { |
|
||||||
this.$active = this.$element.find('.item.active') |
|
||||||
this.$items = this.$active.parent().children() |
|
||||||
return this.$items.index(this.$active) |
|
||||||
} |
|
||||||
|
|
||||||
, to: function (pos) { |
|
||||||
var activeIndex = this.getActiveIndex() |
|
||||||
, that = this |
|
||||||
|
|
||||||
if (pos > (this.$items.length - 1) || pos < 0) return |
|
||||||
|
|
||||||
if (this.sliding) { |
|
||||||
return this.$element.one('slid', function () { |
|
||||||
that.to(pos) |
|
||||||
}) |
|
||||||
} |
|
||||||
|
|
||||||
if (activeIndex == pos) { |
|
||||||
return this.pause().cycle() |
|
||||||
} |
|
||||||
|
|
||||||
return this.slide(pos > activeIndex ? 'next' : 'prev', $(this.$items[pos])) |
|
||||||
} |
|
||||||
|
|
||||||
, pause: function (e) { |
|
||||||
if (!e) this.paused = true |
|
||||||
if (this.$element.find('.next, .prev').length && $.support.transition.end) { |
|
||||||
this.$element.trigger($.support.transition.end) |
|
||||||
this.cycle(true) |
|
||||||
} |
|
||||||
clearInterval(this.interval) |
|
||||||
this.interval = null |
|
||||||
return this |
|
||||||
} |
|
||||||
|
|
||||||
, next: function () { |
|
||||||
if (this.sliding) return |
|
||||||
return this.slide('next') |
|
||||||
} |
|
||||||
|
|
||||||
, prev: function () { |
|
||||||
if (this.sliding) return |
|
||||||
return this.slide('prev') |
|
||||||
} |
|
||||||
|
|
||||||
, slide: function (type, next) { |
|
||||||
var $active = this.$element.find('.item.active') |
|
||||||
, $next = next || $active[type]() |
|
||||||
, isCycling = this.interval |
|
||||||
, direction = type == 'next' ? 'left' : 'right' |
|
||||||
, fallback = type == 'next' ? 'first' : 'last' |
|
||||||
, that = this |
|
||||||
, e |
|
||||||
|
|
||||||
this.sliding = true |
|
||||||
|
|
||||||
isCycling && this.pause() |
|
||||||
|
|
||||||
$next = $next.length ? $next : this.$element.find('.item')[fallback]() |
|
||||||
|
|
||||||
e = $.Event('slide', { |
|
||||||
relatedTarget: $next[0] |
|
||||||
, direction: direction |
|
||||||
}) |
|
||||||
|
|
||||||
if ($next.hasClass('active')) return |
|
||||||
|
|
||||||
if (this.$indicators.length) { |
|
||||||
this.$indicators.find('.active').removeClass('active') |
|
||||||
this.$element.one('slid', function () { |
|
||||||
var $nextIndicator = $(that.$indicators.children()[that.getActiveIndex()]) |
|
||||||
$nextIndicator && $nextIndicator.addClass('active') |
|
||||||
}) |
|
||||||
} |
|
||||||
|
|
||||||
if ($.support.transition && this.$element.hasClass('slide')) { |
|
||||||
this.$element.trigger(e) |
|
||||||
if (e.isDefaultPrevented()) return |
|
||||||
$next.addClass(type) |
|
||||||
$next[0].offsetWidth // force reflow
|
|
||||||
$active.addClass(direction) |
|
||||||
$next.addClass(direction) |
|
||||||
this.$element.one($.support.transition.end, function () { |
|
||||||
$next.removeClass([type, direction].join(' ')).addClass('active') |
|
||||||
$active.removeClass(['active', direction].join(' ')) |
|
||||||
that.sliding = false |
|
||||||
setTimeout(function () { that.$element.trigger('slid') }, 0) |
|
||||||
}) |
|
||||||
} else { |
|
||||||
this.$element.trigger(e) |
|
||||||
if (e.isDefaultPrevented()) return |
|
||||||
$active.removeClass('active') |
|
||||||
$next.addClass('active') |
|
||||||
this.sliding = false |
|
||||||
this.$element.trigger('slid') |
|
||||||
} |
|
||||||
|
|
||||||
isCycling && this.cycle() |
|
||||||
|
|
||||||
return this |
|
||||||
} |
|
||||||
|
|
||||||
} |
|
||||||
|
|
||||||
|
|
||||||
/* CAROUSEL PLUGIN DEFINITION |
|
||||||
* ========================== */ |
|
||||||
|
|
||||||
var old = $.fn.carousel |
|
||||||
|
|
||||||
$.fn.carousel = function (option) { |
|
||||||
return this.each(function () { |
|
||||||
var $this = $(this) |
|
||||||
, data = $this.data('carousel') |
|
||||||
, options = $.extend({}, $.fn.carousel.defaults, typeof option == 'object' && option) |
|
||||||
, action = typeof option == 'string' ? option : options.slide |
|
||||||
if (!data) $this.data('carousel', (data = new Carousel(this, options))) |
|
||||||
if (typeof option == 'number') data.to(option) |
|
||||||
else if (action) data[action]() |
|
||||||
else if (options.interval) data.pause().cycle() |
|
||||||
}) |
|
||||||
} |
|
||||||
|
|
||||||
$.fn.carousel.defaults = { |
|
||||||
interval: 5000 |
|
||||||
, pause: 'hover' |
|
||||||
} |
|
||||||
|
|
||||||
$.fn.carousel.Constructor = Carousel |
|
||||||
|
|
||||||
|
|
||||||
/* CAROUSEL NO CONFLICT |
|
||||||
* ==================== */ |
|
||||||
|
|
||||||
$.fn.carousel.noConflict = function () { |
|
||||||
$.fn.carousel = old |
|
||||||
return this |
|
||||||
} |
|
||||||
|
|
||||||
/* CAROUSEL DATA-API |
|
||||||
* ================= */ |
|
||||||
|
|
||||||
$(document).on('click.carousel.data-api', '[data-slide], [data-slide-to]', function (e) { |
|
||||||
var $this = $(this), href |
|
||||||
, $target = $($this.attr('data-target') || (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7
|
|
||||||
, options = $.extend({}, $target.data(), $this.data()) |
|
||||||
, slideIndex |
|
||||||
|
|
||||||
$target.carousel(options) |
|
||||||
|
|
||||||
if (slideIndex = $this.attr('data-slide-to')) { |
|
||||||
$target.data('carousel').pause().to(slideIndex).cycle() |
|
||||||
} |
|
||||||
|
|
||||||
e.preventDefault() |
|
||||||
}) |
|
||||||
|
|
||||||
}(window.jQuery); |
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in new issue