Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
Y
yii2
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
PSDI Army
yii2
Commits
1896dd17
Commit
1896dd17
authored
Aug 16, 2013
by
Qiang Xue
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
gii WIP
parent
94e4c076
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
26 changed files
with
371 additions
and
86 deletions
+371
-86
login.php
apps/advanced/backend/views/site/login.php
+1
-1
contact.php
apps/advanced/frontend/views/site/contact.php
+1
-1
login.php
apps/advanced/frontend/views/site/login.php
+1
-1
requestPasswordResetToken.php
...dvanced/frontend/views/site/requestPasswordResetToken.php
+1
-1
resetPassword.php
apps/advanced/frontend/views/site/resetPassword.php
+2
-3
signup.php
apps/advanced/frontend/views/site/signup.php
+1
-1
contact.php
apps/basic/views/site/contact.php
+1
-1
login.php
apps/basic/views/site/login.php
+1
-1
upgrade-from-v1.md
docs/guide/upgrade-from-v1.md
+1
-1
CodeFile.php
framework/yii/gii/CodeFile.php
+127
-0
Generator.php
framework/yii/gii/Generator.php
+0
-0
Module.php
framework/yii/gii/Module.php
+0
-1
main.css
framework/yii/gii/assets/main.css
+13
-0
DefaultController.php
framework/yii/gii/controllers/DefaultController.php
+29
-4
Generator.php
framework/yii/gii/generators/controller/Generator.php
+20
-30
controller.php
...rk/yii/gii/generators/controller/templates/controller.php
+8
-0
view.php
framework/yii/gii/generators/controller/templates/view.php
+8
-0
form.php
framework/yii/gii/generators/controller/views/form.php
+18
-27
Generator.php
framework/yii/gii/generators/crud/Generator.php
+5
-0
Generator.php
framework/yii/gii/generators/form/Generator.php
+6
-0
Generator.php
framework/yii/gii/generators/model/Generator.php
+5
-0
Generator.php
framework/yii/gii/generators/module/Generator.php
+6
-0
_files.php
framework/yii/gii/views/default/_files.php
+64
-0
index.php
framework/yii/gii/views/default/index.php
+2
-3
view.php
framework/yii/gii/views/default/view.php
+45
-5
css.php
framework/yii/requirements/views/web/css.php
+5
-5
No files found.
apps/advanced/backend/views/site/login.php
View file @
1896dd17
...
@@ -21,7 +21,7 @@ $this->params['breadcrumbs'][] = $this->title;
...
@@ -21,7 +21,7 @@ $this->params['breadcrumbs'][] = $this->title;
<?php
echo
$form
->
field
(
$model
,
'username'
);
?>
<?php
echo
$form
->
field
(
$model
,
'username'
);
?>
<?php
echo
$form
->
field
(
$model
,
'password'
)
->
passwordInput
();
?>
<?php
echo
$form
->
field
(
$model
,
'password'
)
->
passwordInput
();
?>
<?php
echo
$form
->
field
(
$model
,
'rememberMe'
)
->
checkbox
();
?>
<?php
echo
$form
->
field
(
$model
,
'rememberMe'
)
->
checkbox
();
?>
<div
class=
"form-
actions
"
>
<div
class=
"form-
group
"
>
<?php
echo
Html
::
submitButton
(
'Login'
,
array
(
'class'
=>
'btn btn-primary'
));
?>
<?php
echo
Html
::
submitButton
(
'Login'
,
array
(
'class'
=>
'btn btn-primary'
));
?>
</div>
</div>
<?php
ActiveForm
::
end
();
?>
<?php
ActiveForm
::
end
();
?>
...
...
apps/advanced/frontend/views/site/contact.php
View file @
1896dd17
...
@@ -29,7 +29,7 @@ $this->params['breadcrumbs'][] = $this->title;
...
@@ -29,7 +29,7 @@ $this->params['breadcrumbs'][] = $this->title;
'options'
=>
array
(
'class'
=>
'form-control'
),
'options'
=>
array
(
'class'
=>
'form-control'
),
'template'
=>
'<div class="row"><div class="col-lg-3">{image}</div><div class="col-lg-6">{input}</div></div>'
,
'template'
=>
'<div class="row"><div class="col-lg-3">{image}</div><div class="col-lg-6">{input}</div></div>'
,
));
?>
));
?>
<div
class=
"form-
actions
"
>
<div
class=
"form-
group
"
>
<?php
echo
Html
::
submitButton
(
'Submit'
,
array
(
'class'
=>
'btn btn-primary'
));
?>
<?php
echo
Html
::
submitButton
(
'Submit'
,
array
(
'class'
=>
'btn btn-primary'
));
?>
</div>
</div>
<?php
ActiveForm
::
end
();
?>
<?php
ActiveForm
::
end
();
?>
...
...
apps/advanced/frontend/views/site/login.php
View file @
1896dd17
...
@@ -24,7 +24,7 @@ $this->params['breadcrumbs'][] = $this->title;
...
@@ -24,7 +24,7 @@ $this->params['breadcrumbs'][] = $this->title;
<div
style=
"color:#999;margin:1em 0"
>
<div
style=
"color:#999;margin:1em 0"
>
If you forgot your password you can
<?php
echo
Html
::
a
(
'reset it'
,
array
(
'site/request-password-reset'
))
?>
.
If you forgot your password you can
<?php
echo
Html
::
a
(
'reset it'
,
array
(
'site/request-password-reset'
))
?>
.
</div>
</div>
<div
class=
"form-
actions
"
>
<div
class=
"form-
group
"
>
<?php
echo
Html
::
submitButton
(
'Login'
,
array
(
'class'
=>
'btn btn-primary'
));
?>
<?php
echo
Html
::
submitButton
(
'Login'
,
array
(
'class'
=>
'btn btn-primary'
));
?>
</div>
</div>
<?php
ActiveForm
::
end
();
?>
<?php
ActiveForm
::
end
();
?>
...
...
apps/advanced/frontend/views/site/requestPasswordResetToken.php
View file @
1896dd17
...
@@ -19,7 +19,7 @@ $this->params['breadcrumbs'][] = $this->title;
...
@@ -19,7 +19,7 @@ $this->params['breadcrumbs'][] = $this->title;
<div
class=
"col-lg-5"
>
<div
class=
"col-lg-5"
>
<?php
$form
=
ActiveForm
::
begin
(
array
(
'id'
=>
'request-password-reset-form'
));
?>
<?php
$form
=
ActiveForm
::
begin
(
array
(
'id'
=>
'request-password-reset-form'
));
?>
<?php
echo
$form
->
field
(
$model
,
'email'
);
?>
<?php
echo
$form
->
field
(
$model
,
'email'
);
?>
<div
class=
"form-
actions
"
>
<div
class=
"form-
group
"
>
<?php
echo
Html
::
submitButton
(
'Send'
,
array
(
'class'
=>
'btn btn-primary'
));
?>
<?php
echo
Html
::
submitButton
(
'Send'
,
array
(
'class'
=>
'btn btn-primary'
));
?>
</div>
</div>
<?php
ActiveForm
::
end
();
?>
<?php
ActiveForm
::
end
();
?>
...
...
apps/advanced/frontend/views/site/resetPassword.php
View file @
1896dd17
...
@@ -19,10 +19,10 @@ $this->params['breadcrumbs'][] = $this->title;
...
@@ -19,10 +19,10 @@ $this->params['breadcrumbs'][] = $this->title;
<div
class=
"col-lg-5"
>
<div
class=
"col-lg-5"
>
<?php
$form
=
ActiveForm
::
begin
(
array
(
'id'
=>
'reset-password-form'
));
?>
<?php
$form
=
ActiveForm
::
begin
(
array
(
'id'
=>
'reset-password-form'
));
?>
<?php
echo
$form
->
field
(
$model
,
'password'
)
->
passwordInput
();
?>
<?php
echo
$form
->
field
(
$model
,
'password'
)
->
passwordInput
();
?>
<div
class=
"form-
actions
"
>
<div
class=
"form-
group
"
>
<?php
echo
Html
::
submitButton
(
'Save'
,
array
(
'class'
=>
'btn btn-primary'
));
?>
<?php
echo
Html
::
submitButton
(
'Save'
,
array
(
'class'
=>
'btn btn-primary'
));
?>
</div>
</div>
<?php
ActiveForm
::
end
();
?>
<?php
ActiveForm
::
end
();
?>
</div>
</div>
</div>
</div>
</div>
</div>
\ No newline at end of file
apps/advanced/frontend/views/site/signup.php
View file @
1896dd17
...
@@ -21,7 +21,7 @@ $this->params['breadcrumbs'][] = $this->title;
...
@@ -21,7 +21,7 @@ $this->params['breadcrumbs'][] = $this->title;
<?php
echo
$form
->
field
(
$model
,
'username'
);
?>
<?php
echo
$form
->
field
(
$model
,
'username'
);
?>
<?php
echo
$form
->
field
(
$model
,
'email'
);
?>
<?php
echo
$form
->
field
(
$model
,
'email'
);
?>
<?php
echo
$form
->
field
(
$model
,
'password'
)
->
passwordInput
();
?>
<?php
echo
$form
->
field
(
$model
,
'password'
)
->
passwordInput
();
?>
<div
class=
"form-
actions
"
>
<div
class=
"form-
group
"
>
<?php
echo
Html
::
submitButton
(
'Signup'
,
array
(
'class'
=>
'btn btn-primary'
));
?>
<?php
echo
Html
::
submitButton
(
'Signup'
,
array
(
'class'
=>
'btn btn-primary'
));
?>
</div>
</div>
<?php
ActiveForm
::
end
();
?>
<?php
ActiveForm
::
end
();
?>
...
...
apps/basic/views/site/contact.php
View file @
1896dd17
...
@@ -37,7 +37,7 @@ $this->params['breadcrumbs'][] = $this->title;
...
@@ -37,7 +37,7 @@ $this->params['breadcrumbs'][] = $this->title;
'options'
=>
array
(
'class'
=>
'form-control'
),
'options'
=>
array
(
'class'
=>
'form-control'
),
'template'
=>
'<div class="row"><div class="col-lg-3">{image}</div><div class="col-lg-6">{input}</div></div>'
,
'template'
=>
'<div class="row"><div class="col-lg-3">{image}</div><div class="col-lg-6">{input}</div></div>'
,
));
?>
));
?>
<div
class=
"form-
actions
"
>
<div
class=
"form-
group
"
>
<?php
echo
Html
::
submitButton
(
'Submit'
,
array
(
'class'
=>
'btn btn-primary'
));
?>
<?php
echo
Html
::
submitButton
(
'Submit'
,
array
(
'class'
=>
'btn btn-primary'
));
?>
</div>
</div>
<?php
ActiveForm
::
end
();
?>
<?php
ActiveForm
::
end
();
?>
...
...
apps/basic/views/site/login.php
View file @
1896dd17
...
@@ -21,7 +21,7 @@ $this->params['breadcrumbs'][] = $this->title;
...
@@ -21,7 +21,7 @@ $this->params['breadcrumbs'][] = $this->title;
<?php
echo
$form
->
field
(
$model
,
'username'
);
?>
<?php
echo
$form
->
field
(
$model
,
'username'
);
?>
<?php
echo
$form
->
field
(
$model
,
'password'
)
->
passwordInput
();
?>
<?php
echo
$form
->
field
(
$model
,
'password'
)
->
passwordInput
();
?>
<?php
echo
$form
->
field
(
$model
,
'rememberMe'
)
->
checkbox
();
?>
<?php
echo
$form
->
field
(
$model
,
'rememberMe'
)
->
checkbox
();
?>
<div
class=
"form-
actions
"
>
<div
class=
"form-
group
"
>
<?php
echo
Html
::
submitButton
(
'Login'
,
array
(
'class'
=>
'btn btn-primary'
));
?>
<?php
echo
Html
::
submitButton
(
'Login'
,
array
(
'class'
=>
'btn btn-primary'
));
?>
</div>
</div>
<?php
ActiveForm
::
end
();
?>
<?php
ActiveForm
::
end
();
?>
...
...
docs/guide/upgrade-from-v1.md
View file @
1896dd17
...
@@ -338,7 +338,7 @@ It is represented as an `ActiveField` object. Using fields, you can build a form
...
@@ -338,7 +338,7 @@ It is represented as an `ActiveField` object. Using fields, you can build a form
<?php
$form
=
yii\widgets\ActiveForm
::
begin
();
?>
<?php
$form
=
yii\widgets\ActiveForm
::
begin
();
?>
<?php
echo
$form
->
field
(
$model
,
'username'
);
?>
<?php
echo
$form
->
field
(
$model
,
'username'
);
?>
<?php
echo
$form
->
field
(
$model
,
'password'
)
->
passwordInput
();
?>
<?php
echo
$form
->
field
(
$model
,
'password'
)
->
passwordInput
();
?>
<div
class=
"form-
actions
"
>
<div
class=
"form-
group
"
>
<?php
echo
Html
::
submitButton
(
'Login'
);
?>
<?php
echo
Html
::
submitButton
(
'Login'
);
?>
</div>
</div>
<?php
yii\widgets\ActiveForm
::
end
();
?>
<?php
yii\widgets\ActiveForm
::
end
();
?>
...
...
framework/yii/gii/CodeFile.php
0 → 100644
View file @
1896dd17
<?php
/**
* @link http://www.yiiframework.com/
* @copyright Copyright (c) 2008 Yii Software LLC
* @license http://www.yiiframework.com/license/
*/
namespace
yii\gii
;
use
Yii
;
use
yii\base\Object
;
/**
*
* @author Qiang Xue <qiang.xue@gmail.com>
* @since 2.0
*/
class
CodeFile
extends
Object
{
const
OP_NEW
=
'new'
;
const
OP_OVERWRITE
=
'overwrite'
;
const
OP_SKIP
=
'skip'
;
/**
* @var string the file path that the new code should be saved to.
*/
public
$path
;
/**
* @var mixed the newly generated code. If this is null, it means {@link path}
* should be treated as a directory.
*/
public
$content
;
/**
* @var string the operation to be performed
*/
public
$operation
;
/**
* @var string the error occurred when saving the code into a file
*/
public
$error
;
/**
* Constructor.
* @param string $path the file path that the new code should be saved to.
* @param string $content the newly generated code
*/
public
function
__construct
(
$path
,
$content
)
{
$this
->
path
=
strtr
(
$path
,
array
(
'/'
=>
DIRECTORY_SEPARATOR
,
'\\'
=>
DIRECTORY_SEPARATOR
));
$this
->
content
=
$content
;
if
(
is_file
(
$path
))
{
$this
->
operation
=
file_get_contents
(
$path
)
===
$content
?
self
::
OP_SKIP
:
self
::
OP_OVERWRITE
;
}
elseif
(
$content
===
null
)
// is dir
{
$this
->
operation
=
is_dir
(
$path
)
?
self
::
OP_SKIP
:
self
::
OP_NEW
;
}
else
{
$this
->
operation
=
self
::
OP_NEW
;
}
}
/**
* Saves the code into the file {@link path}.
*/
public
function
save
()
{
$module
=
Yii
::
$app
->
controller
->
module
;
if
(
$this
->
content
===
null
)
// a directory
{
if
(
!
is_dir
(
$this
->
path
))
{
$oldmask
=
@
umask
(
0
);
$result
=
@
mkdir
(
$this
->
path
,
$module
->
newDirMode
,
true
);
@
umask
(
$oldmask
);
if
(
!
$result
)
{
$this
->
error
=
"Unable to create the directory '
{
$this
->
path
}
'."
;
return
false
;
}
}
return
true
;
}
if
(
$this
->
operation
===
self
::
OP_NEW
)
{
$dir
=
dirname
(
$this
->
path
);
if
(
!
is_dir
(
$dir
))
{
$oldmask
=
@
umask
(
0
);
$result
=
@
mkdir
(
$dir
,
$module
->
newDirMode
,
true
);
@
umask
(
$oldmask
);
if
(
!
$result
)
{
$this
->
error
=
"Unable to create the directory '
$dir
'."
;
return
false
;
}
}
}
if
(
@
file_put_contents
(
$this
->
path
,
$this
->
content
)
===
false
)
{
$this
->
error
=
"Unable to write the file '
{
$this
->
path
}
'."
;
return
false
;
}
else
{
$oldmask
=
@
umask
(
0
);
@
chmod
(
$this
->
path
,
$module
->
newFileMode
);
@
umask
(
$oldmask
);
}
return
true
;
}
/**
* @return string the code file path relative to the application base path.
*/
public
function
getRelativePath
()
{
if
(
strpos
(
$this
->
path
,
Yii
::
$app
->
basePath
)
===
0
)
{
return
substr
(
$this
->
path
,
strlen
(
Yii
::
$app
->
basePath
)
+
1
);
}
else
{
return
$this
->
path
;
}
}
/**
* @return string the code file extension (e.g. php, txt)
*/
public
function
getType
()
{
if
((
$pos
=
strrpos
(
$this
->
path
,
'.'
))
!==
false
)
{
return
substr
(
$this
->
path
,
$pos
+
1
);
}
else
{
return
'unknown'
;
}
}
}
framework/yii/gii/Generator.php
View file @
1896dd17
This diff is collapsed.
Click to expand it.
framework/yii/gii/Module.php
View file @
1896dd17
...
@@ -53,7 +53,6 @@ class Module extends \yii\base\Module
...
@@ -53,7 +53,6 @@ class Module extends \yii\base\Module
{
{
parent
::
init
();
parent
::
init
();
foreach
(
array_merge
(
$this
->
coreGenerators
(),
$this
->
generators
)
as
$id
=>
$config
)
{
foreach
(
array_merge
(
$this
->
coreGenerators
(),
$this
->
generators
)
as
$id
=>
$config
)
{
$config
[
'id'
]
=
$id
;
$this
->
generators
[
$id
]
=
Yii
::
createObject
(
$config
);
$this
->
generators
[
$id
]
=
Yii
::
createObject
(
$config
);
}
}
}
}
...
...
framework/yii/gii/assets/main.css
View file @
1896dd17
...
@@ -41,3 +41,16 @@ body {
...
@@ -41,3 +41,16 @@ body {
.hint-block
{
.hint-block
{
display
:
none
;
display
:
none
;
}
}
table
.code-files
.file
{
}
table
.code-files
.action
{
width
:
100px
;
}
table
.code-files
.check
{
width
:
25px
;
text-align
:
center
;
}
framework/yii/gii/controllers/DefaultController.php
View file @
1896dd17
...
@@ -17,6 +17,13 @@ use yii\web\HttpException;
...
@@ -17,6 +17,13 @@ use yii\web\HttpException;
class
DefaultController
extends
Controller
class
DefaultController
extends
Controller
{
{
public
$layout
=
'generator'
;
public
$layout
=
'generator'
;
/**
* @var \yii\gii\Module
*/
public
$module
;
/**
* @var \yii\gii\Generator
*/
public
$generator
;
public
$generator
;
public
function
actionIndex
()
public
function
actionIndex
()
...
@@ -28,9 +35,19 @@ class DefaultController extends Controller
...
@@ -28,9 +35,19 @@ class DefaultController extends Controller
public
function
actionView
(
$id
)
public
function
actionView
(
$id
)
{
{
$generator
=
$this
->
loadGenerator
(
$id
);
$generator
=
$this
->
loadGenerator
(
$id
);
return
$this
->
render
(
'view'
,
array
(
$params
=
array
(
'generator'
=>
$generator
);
'generator'
=>
$generator
if
(
isset
(
$_POST
[
'preview'
])
||
isset
(
$_POST
[
'generate'
]))
{
));
if
(
$generator
->
validate
())
{
$files
=
$generator
->
prepare
();
if
(
isset
(
$_POST
[
'generate'
],
$_POST
[
'answers'
]))
{
$params
[
'result'
]
=
$generator
->
save
(
$files
,
$_POST
[
'answers'
]);
}
else
{
$params
[
'files'
]
=
$files
;
}
}
}
return
$this
->
render
(
'view'
,
$params
);
}
}
public
function
actionCode
(
$file
)
public
function
actionCode
(
$file
)
...
@@ -43,10 +60,18 @@ class DefaultController extends Controller
...
@@ -43,10 +60,18 @@ class DefaultController extends Controller
}
}
/**
* Loads the generator with the specified ID.
* @param string $id the ID of the generator to be loaded.
* @return \yii\gii\Generator the loaded generator
* @throws \yii\web\HttpException
*/
protected
function
loadGenerator
(
$id
)
protected
function
loadGenerator
(
$id
)
{
{
if
(
isset
(
$this
->
module
->
generators
[
$id
]))
{
if
(
isset
(
$this
->
module
->
generators
[
$id
]))
{
return
$this
->
generator
=
$this
->
module
->
generators
[
$id
];
$this
->
generator
=
$this
->
module
->
generators
[
$id
];
$this
->
generator
->
load
(
$_POST
);
return
$this
->
generator
;
}
else
{
}
else
{
throw
new
HttpException
(
404
,
"Code generator not found:
$id
"
);
throw
new
HttpException
(
404
,
"Code generator not found:
$id
"
);
}
}
...
...
framework/yii/gii/generators/controller/Generator.php
View file @
1896dd17
...
@@ -8,6 +8,8 @@
...
@@ -8,6 +8,8 @@
namespace
yii\gii\generators\controller
;
namespace
yii\gii\generators\controller
;
use
Yii
;
use
Yii
;
use
yii\gii\CodeFile
;
use
yii\helpers\Html
;
/**
/**
*
*
...
@@ -31,33 +33,25 @@ class Generator extends \yii\gii\Generator
...
@@ -31,33 +33,25 @@ class Generator extends \yii\gii\Generator
one or several controller actions and their corresponding views.'
;
one or several controller actions and their corresponding views.'
;
}
}
public
function
renderForm
()
{
return
Yii
::
$app
->
getView
()
->
renderFile
(
__DIR__
.
'/views/form.php'
,
array
(
'model'
=>
$this
,
));
}
public
function
rules
()
public
function
rules
()
{
{
return
array_merge
(
parent
::
rules
(),
array
(
return
array_merge
(
parent
::
rules
(),
array
(
array
(
'controller, actions, baseClass'
,
'filter'
,
'filter'
=>
'trim'
),
array
(
'controller, actions, baseClass'
,
'filter'
,
'filter'
=>
'trim'
),
array
(
'controller, baseClass'
,
'required'
),
array
(
'controller, baseClass'
,
'required'
),
array
(
'controller'
,
'match'
,
'pattern'
=>
'/^[\w+\\/]*$/'
,
'message'
=>
'
{attribute} should only contain word characters and slashes
.'
),
array
(
'controller'
,
'match'
,
'pattern'
=>
'/^[\w+\\/]*$/'
,
'message'
=>
'
Only word characters and slashes are allowed
.'
),
array
(
'actions'
,
'match'
,
'pattern'
=>
'/^\w+[\w\s,]*$/'
,
'message'
=>
'
{attribute} should only contain word characters, spaces and commas
.'
),
array
(
'actions'
,
'match'
,
'pattern'
=>
'/^\w+[\w\s,]*$/'
,
'message'
=>
'
Only word characters, spaces and commas are allowed
.'
),
array
(
'baseClass'
,
'match'
,
'pattern'
=>
'/^[a-zA-Z_][\w\\\\]*$/'
,
'message'
=>
'
{attribute} should only contain word characters and backslashes
.'
),
array
(
'baseClass'
,
'match'
,
'pattern'
=>
'/^[a-zA-Z_][\w\\\\]*$/'
,
'message'
=>
'
Only word characters and backslashes are allowed
.'
),
array
(
'baseClass'
,
'validateReservedWord'
,
'skipOnError'
=>
true
),
array
(
'baseClass'
,
'validateReservedWord'
,
'skipOnError'
=>
true
),
array
(
'baseClass, actions'
,
'sticky'
),
));
));
}
}
public
function
attributeLabels
()
public
function
attributeLabels
()
{
{
return
array
_merge
(
parent
::
attributeLabels
(),
array
(
return
array
(
'baseClass'
=>
'Base Class'
,
'baseClass'
=>
'Base Class'
,
'controller'
=>
'Controller ID'
,
'controller'
=>
'Controller ID'
,
'actions'
=>
'Action IDs'
,
'actions'
=>
'Action IDs'
,
)
)
;
);
}
}
public
function
requiredTemplates
()
public
function
requiredTemplates
()
...
@@ -70,32 +64,34 @@ class Generator extends \yii\gii\Generator
...
@@ -70,32 +64,34 @@ class Generator extends \yii\gii\Generator
public
function
successMessage
()
public
function
successMessage
()
{
{
$link
=
CHtml
::
link
(
'try it now'
,
Yii
::
app
()
->
createUrl
(
$this
->
controller
),
array
(
'target'
=>
'_blank'
));
$link
=
Html
::
a
(
'try it now'
,
Yii
::
$app
->
getUrlManager
()
->
createUrl
(
$this
->
controller
),
array
(
'target'
=>
'_blank'
));
return
"The controller has been generated successfully. You may
$link
."
;
return
"The controller has been generated successfully. You may
$link
."
;
}
}
public
function
prepare
()
public
function
prepare
()
{
{
$this
->
files
=
array
();
$files
=
array
();
$templatePath
=
$this
->
templatePath
;
$this
->
files
[]
=
new
CCodeFile
(
$templatePath
=
$this
->
getTemplatePath
();
$this
->
controllerFile
,
$files
[]
=
new
CodeFile
(
$this
->
getControllerFile
(),
$this
->
render
(
$templatePath
.
'/controller.php'
)
$this
->
render
(
$templatePath
.
'/controller.php'
)
);
);
foreach
(
$this
->
getActionIDs
()
as
$action
)
{
foreach
(
$this
->
getActionIDs
()
as
$action
)
{
$
this
->
files
[]
=
new
C
CodeFile
(
$
files
[]
=
new
CodeFile
(
$this
->
getViewFile
(
$action
),
$this
->
getViewFile
(
$action
),
$this
->
render
(
$templatePath
.
'/view.php'
,
array
(
'action'
=>
$action
))
$this
->
render
(
$templatePath
.
'/view.php'
,
array
(
'action'
=>
$action
))
);
);
}
}
return
$files
;
}
}
public
function
getActionIDs
()
public
function
getActionIDs
()
{
{
$actions
=
preg_split
(
'/[\s,]+/'
,
$this
->
actions
,
-
1
,
PREG_SPLIT_NO_EMPTY
);
$actions
=
array_unique
(
preg_split
(
'/[\s,]+/'
,
$this
->
actions
,
-
1
,
PREG_SPLIT_NO_EMPTY
));
$actions
=
array_unique
(
$actions
);
sort
(
$actions
);
sort
(
$actions
);
return
$actions
;
return
$actions
;
}
}
...
@@ -113,16 +109,16 @@ class Generator extends \yii\gii\Generator
...
@@ -113,16 +109,16 @@ class Generator extends \yii\gii\Generator
{
{
if
((
$pos
=
strpos
(
$this
->
controller
,
'/'
))
!==
false
)
{
if
((
$pos
=
strpos
(
$this
->
controller
,
'/'
))
!==
false
)
{
$id
=
substr
(
$this
->
controller
,
0
,
$pos
);
$id
=
substr
(
$this
->
controller
,
0
,
$pos
);
if
((
$module
=
Yii
::
app
()
->
getModule
(
$id
))
!==
null
)
{
if
((
$module
=
Yii
::
$app
->
getModule
(
$id
))
!==
null
)
{
return
$module
;
return
$module
;
}
}
}
}
return
Yii
::
app
()
;
return
Yii
::
$app
;
}
}
public
function
getControllerID
()
public
function
getControllerID
()
{
{
if
(
$this
->
getModule
()
!==
Yii
::
app
()
)
{
if
(
$this
->
getModule
()
!==
Yii
::
$app
)
{
$id
=
substr
(
$this
->
controller
,
strpos
(
$this
->
controller
,
'/'
)
+
1
);
$id
=
substr
(
$this
->
controller
,
strpos
(
$this
->
controller
,
'/'
)
+
1
);
}
else
{
}
else
{
$id
=
$this
->
controller
;
$id
=
$this
->
controller
;
...
@@ -157,10 +153,4 @@ class Generator extends \yii\gii\Generator
...
@@ -157,10 +153,4 @@ class Generator extends \yii\gii\Generator
}
}
return
$module
->
getControllerPath
()
.
'/'
.
$id
.
'Controller.php'
;
return
$module
->
getControllerPath
()
.
'/'
.
$id
.
'Controller.php'
;
}
}
public
function
getViewFile
(
$action
)
{
$module
=
$this
->
getModule
();
return
$module
->
getViewPath
()
.
'/'
.
$this
->
getControllerID
()
.
'/'
.
$action
.
'.php'
;
}
}
}
framework/yii/gii/generators/controller/templates/controller.php
0 → 100644
View file @
1896dd17
<?php
/**
* Created by JetBrains PhpStorm.
* User: qiang
* Date: 8/15/13
* Time: 4:45 PM
* To change this template use File | Settings | File Templates.
*/
framework/yii/gii/generators/controller/templates/view.php
0 → 100644
View file @
1896dd17
<?php
/**
* Created by JetBrains PhpStorm.
* User: qiang
* Date: 8/15/13
* Time: 4:46 PM
* To change this template use File | Settings | File Templates.
*/
framework/yii/gii/generators/controller/views/form.php
View file @
1896dd17
<?php
<?php
use
yii\helpers\Html
;
use
yii\helpers\Html
;
use
yii\widgets\ActiveForm
;
use
yii\widgets\ActiveForm
;
/**
/**
* @var yii\base\View $this
* @var yii\base\View $this
* @var yii\widgets\ActiveForm $form
* @var yii\widgets\ActiveForm $form
* @var yii\gii\generators\controller\Generator $generator
*/
*/
?>
?>
<div
class=
"controller-form"
>
<?php
echo
$form
->
field
(
$generator
,
'controller'
)
->
hint
(
'
<div
class=
"row"
>
Controller ID is case-sensitive and can contain module ID(s). For example:
<div
class=
"col-lg-6"
>
<ul>
<?php
$form
=
ActiveForm
::
begin
(
array
(
'id'
=>
'login-form'
));
?>
<li><code>order</code> generates <code>OrderController.php</code></li>
<?php
echo
$form
->
field
(
$model
,
'controller'
)
->
hint
(
'
<li><code>order-item</code> generates <code>OrderItemController.php</code></li>
Controller ID is case-sensitive and can contain module ID(s). For example:
<li><code>admin/user</code> generates <code>UserController.php</code> within the <code>admin</code> module.</li>
<ul>
</ul>
<li><code>order</code> generates <code>OrderController.php</code></li>
'
);
?>
<li><code>order-item</code> generates <code>OrderItemController.php</code></li>
<?php
echo
$form
->
field
(
$generator
,
'baseClass'
)
->
hint
(
'
<li><code>admin/user</code> generates <code>UserController.php</code> within the <code>admin</code> module.</li>
This is the class that the new controller class will extend from.
</ul>
Please make sure the class exists and can be autoloaded.
'
);
?>
'
);
?>
<?php
echo
$form
->
field
(
$model
,
'baseClass'
)
->
hint
(
'
<?php
echo
$form
->
field
(
$generator
,
'actions'
)
->
hint
(
'
This is the class that the new controller class will extend from.
Provide one or multiple action IDs to generate empty action method(s) in the controller.
Please make sure the class exists and can be autoloaded.
Separate multiple action IDs with commas or spaces.
'
);
?>
'
);
?>
<?php
echo
$form
->
field
(
$model
,
'actions'
)
->
hint
(
'
Provide one or multiple action IDs to generate empty action method(s) in the controller.
Separate multiple action IDs with commas or spaces.
'
);
?>
<div
class=
"form-actions"
>
<?php
echo
Html
::
submitButton
(
'Preview'
,
array
(
'class'
=>
'btn btn-primary'
));
?>
</div>
<?php
ActiveForm
::
end
();
?>
</div>
</div>
</div>
framework/yii/gii/generators/crud/Generator.php
View file @
1896dd17
...
@@ -24,4 +24,9 @@ class Generator extends \yii\gii\Generator
...
@@ -24,4 +24,9 @@ class Generator extends \yii\gii\Generator
return
'This generator generates a controller and views that implement CRUD (Create, Read, Update, Delete)
return
'This generator generates a controller and views that implement CRUD (Create, Read, Update, Delete)
operations for the specified data model.'
;
operations for the specified data model.'
;
}
}
public
function
getViewFile
()
{
return
__DIR__
.
'/views/form.php'
;
}
}
}
framework/yii/gii/generators/form/Generator.php
View file @
1896dd17
...
@@ -23,4 +23,10 @@ class Generator extends \yii\gii\Generator
...
@@ -23,4 +23,10 @@ class Generator extends \yii\gii\Generator
{
{
return
'This generator generates a view script file that displays a form to collect input for the specified model class.'
;
return
'This generator generates a view script file that displays a form to collect input for the specified model class.'
;
}
}
public
function
getViewFile
()
{
return
__DIR__
.
'/views/form.php'
;
}
}
}
framework/yii/gii/generators/model/Generator.php
View file @
1896dd17
...
@@ -23,4 +23,9 @@ class Generator extends \yii\gii\Generator
...
@@ -23,4 +23,9 @@ class Generator extends \yii\gii\Generator
{
{
return
'This generator generates a model class for the specified database table.'
;
return
'This generator generates a model class for the specified database table.'
;
}
}
public
function
getViewFile
()
{
return
__DIR__
.
'/views/form.php'
;
}
}
}
framework/yii/gii/generators/module/Generator.php
View file @
1896dd17
...
@@ -23,4 +23,10 @@ class Generator extends \yii\gii\Generator
...
@@ -23,4 +23,10 @@ class Generator extends \yii\gii\Generator
{
{
return
'This generator helps you to generate the skeleton code needed by a Yii module.'
;
return
'This generator helps you to generate the skeleton code needed by a Yii module.'
;
}
}
public
function
getViewFile
()
{
return
__DIR__
.
'/views/form.php'
;
}
}
}
framework/yii/gii/views/default/_files.php
0 → 100644
View file @
1896dd17
<?php
use
yii\gii\Generator
;
use
yii\helpers\Html
;
use
yii\gii\CodeFile
;
/**
* @var $this \yii\base\View
* @var $generator \yii\gii\Generator
* @var CodeFile[] $files
*/
?>
<table
class=
"table table-bordered table-striped table-condensed code-files"
>
<thead>
<tr>
<th
class=
"file"
>
Code File
</th>
<th
class=
"action"
>
Action
</th>
<th
class=
"check"
>
<?php
$count
=
0
;
foreach
(
$files
as
$file
)
{
if
(
$file
->
operation
!==
CodeFile
::
OP_SKIP
)
{
$count
++
;
}
}
if
(
$count
>
1
)
{
echo
'<input type="checkbox" name="checkAll" id="check-all" />'
;
}
?>
</th>
</tr>
</thead>
<tbody>
<?php
foreach
(
$files
as
$i
=>
$file
)
:
?>
<tr
class=
"
<?php
echo
$file
->
operation
;
?>
"
>
<td
class=
"file"
>
<?php
echo
Html
::
a
(
Html
::
encode
(
$file
->
getRelativePath
()),
array
(
'code'
,
'file'
=>
$i
),
array
(
'class'
=>
'view-code'
,
'rel'
=>
$file
->
path
));
?>
<?php
if
(
$file
->
operation
===
CodeFile
::
OP_OVERWRITE
)
:
?>
(
<?php
echo
Html
::
a
(
'diff'
,
array
(
'diff'
,
'file'
=>
$i
),
array
(
'class'
=>
'view-code'
,
'rel'
=>
$file
->
path
));
?>
)
<?php
endif
;
?>
</td>
<td
class=
"action"
>
<?php
if
(
$file
->
operation
===
CodeFile
::
OP_SKIP
)
{
echo
'unchanged'
;
}
else
{
echo
$file
->
operation
;
}
?>
</td>
<td
class=
"check"
>
<?php
if
(
$file
->
operation
===
CodeFile
::
OP_SKIP
)
{
echo
' '
;
}
else
{
$key
=
md5
(
$file
->
path
);
echo
Html
::
checkBox
(
"answers[
$key
]"
);
}
?>
</td>
</tr>
<?php
endforeach
;
?>
</tbody>
</table>
framework/yii/gii/views/default/index.php
View file @
1896dd17
...
@@ -19,16 +19,15 @@ $this->title = 'Welcome to Gii';
...
@@ -19,16 +19,15 @@ $this->title = 'Welcome to Gii';
<p
class=
"lead"
>
Start the fun with the following code generators:
</p>
<p
class=
"lead"
>
Start the fun with the following code generators:
</p>
<div
class=
"row"
>
<div
class=
"row"
>
<?php
foreach
(
array_values
(
$generators
)
as
$i
=>
$generator
)
:
?>
<?php
foreach
(
$generators
as
$id
=>
$generator
)
:
?>
<div
class=
"generator col-lg-4"
>
<div
class=
"generator col-lg-4"
>
<h3>
<?php
echo
Html
::
encode
(
$generator
->
getName
());
?>
</h3>
<h3>
<?php
echo
Html
::
encode
(
$generator
->
getName
());
?>
</h3>
<p>
<?php
echo
$generator
->
getDescription
();
?>
</p>
<p>
<?php
echo
$generator
->
getDescription
();
?>
</p>
<p>
<?php
echo
Html
::
a
(
'Start »'
,
$generator
->
getUrl
(
),
array
(
'class'
=>
'btn btn-default'
));
?>
</p>
<p>
<?php
echo
Html
::
a
(
'Start »'
,
array
(
'default/view'
,
'id'
=>
$id
),
array
(
'class'
=>
'btn btn-default'
));
?>
</p>
</div>
</div>
<?php
endforeach
;
?>
<?php
endforeach
;
?>
</div>
</div>
<p><a
class=
"btn btn-success"
href=
"http://www.yiiframework.com/extensions/?tag=gii"
>
Get More Generators
</a></p>
<p><a
class=
"btn btn-success"
href=
"http://www.yiiframework.com/extensions/?tag=gii"
>
Get More Generators
</a></p>
</div>
</div>
framework/yii/gii/views/default/view.php
View file @
1896dd17
<?php
<?php
use
yii\gii\Generator
;
use
yii\helpers\Html
;
use
yii\helpers\Html
;
use
yii\widgets\ActiveForm
;
use
yii\gii\CodeFile
;
/**
/**
* @var $this \yii\base\View
* @var yii\base\View $this
* @var $generator \yii\gii\Generator
* @var yii\gii\Generator $generator
* @var yii\widgets\ActiveForm $form
* @var string $result
* @var CodeFile[] $files
*/
*/
$this
->
title
=
$generator
->
getName
();
$this
->
title
=
$generator
->
getName
();
$templates
=
array
();
foreach
(
$generator
->
templates
as
$name
=>
$path
)
{
$templates
[
$name
]
=
"
$name
(
$path
)"
;
}
?>
?>
<div
class=
"default-view"
>
<div
class=
"default-view"
>
<h1>
<?php
echo
Html
::
encode
(
$generator
->
getName
());
?>
</h1>
<h1>
<?php
echo
Html
::
encode
(
$this
->
title
);
?>
</h1>
<p>
<?php
echo
$generator
->
getDescription
();
?>
</p>
<p>
<?php
echo
$generator
->
getDescription
();
?>
</p>
<?php
echo
$generator
->
renderForm
();
?>
<?php
$form
=
ActiveForm
::
begin
();
?>
<div
class=
"row"
>
<div
class=
"col-lg-6"
>
<?php
echo
$this
->
renderFile
(
$generator
->
getViewFile
(),
array
(
'generator'
=>
$generator
,
'form'
=>
$form
,
));
?>
<?php
echo
$form
->
field
(
$generator
,
'template'
)
->
label
(
array
(
'label'
=>
'Code Template'
))
->
dropDownList
(
$templates
)
->
hint
(
'
Please select which set of the templates should be used to generated the code.
'
);
?>
<div
class=
"form-group"
>
<?php
echo
Html
::
submitButton
(
'Preview'
,
array
(
'name'
=>
'preview'
,
'class'
=>
'btn btn-primary'
));
?>
<?php
if
(
isset
(
$files
))
:
?>
<?php
echo
Html
::
submitButton
(
'Generate'
,
array
(
'name'
=>
'generate'
,
'class'
=>
'btn btn-danger'
));
?>
<?php
endif
;
?>
</div>
</div>
</div>
<?php
if
(
isset
(
$result
))
{
echo
'<div class="result">'
.
$result
.
'</div>'
;
}
elseif
(
isset
(
$files
))
{
echo
$this
->
render
(
'_files'
,
array
(
'generator'
=>
$generator
,
'files'
=>
$files
,
));
}
?>
<?php
echo
$generator
->
renderFileList
();
?>
<?php
ActiveForm
::
end
();
?>
</div>
</div>
framework/yii/requirements/views/web/css.php
View file @
1896dd17
...
@@ -1627,7 +1627,7 @@ select:focus:invalid:focus {
...
@@ -1627,7 +1627,7 @@ select:focus:invalid:focus {
box-shadow
:
0
0
6px
#f8b9b7
;
box-shadow
:
0
0
6px
#f8b9b7
;
}
}
.form-
actions
{
.form-
group
{
padding
:
19px
20px
20px
;
padding
:
19px
20px
20px
;
margin-top
:
20px
;
margin-top
:
20px
;
margin-bottom
:
20px
;
margin-bottom
:
20px
;
...
@@ -1636,14 +1636,14 @@ select:focus:invalid:focus {
...
@@ -1636,14 +1636,14 @@ select:focus:invalid:focus {
*
zoom
:
1
;
*
zoom
:
1
;
}
}
.form-
actions
:before
,
.form-
group
:before
,
.form-
actions
:after
{
.form-
group
:after
{
display
:
table
;
display
:
table
;
line-height
:
0
;
line-height
:
0
;
content
:
""
;
content
:
""
;
}
}
.form-
actions
:after
{
.form-
group
:after
{
clear
:
both
;
clear
:
both
;
}
}
...
@@ -1991,7 +1991,7 @@ legend + .control-group {
...
@@ -1991,7 +1991,7 @@ legend + .control-group {
margin-top
:
10px
;
margin-top
:
10px
;
}
}
.form-horizontal
.form-
actions
{
.form-horizontal
.form-
group
{
padding-left
:
180px
;
padding-left
:
180px
;
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment