Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Dev #203

Open
wants to merge 121 commits into
base: master
Choose a base branch
from
Open

Dev #203

Changes from 1 commit
Commits
Show all changes
121 commits
Select commit Hold shift + click to select a range
965ecd9
file type in catalog fields
noumo Oct 1, 2015
06868c7
add slug immutable setting
noumo Oct 9, 2015
76bbf2f
add fancybox asset
noumo Oct 9, 2015
4c2876d
image upload rework
noumo Oct 9, 2015
ee7850e
Settings refactoring
noumo Oct 9, 2015
264fc45
settings refactor
noumo Oct 9, 2015
066be79
add immutable
noumo Oct 9, 2015
37e242f
add tags
noumo Oct 9, 2015
3ea8f82
minor improves
noumo Oct 9, 2015
c1489d0
upload and image refactor
noumo Oct 9, 2015
a450529
images and behaviors refactor
noumo Oct 12, 2015
d287582
new redactor widget
noumo Oct 13, 2015
d7b2f35
change controller behavior to actions
noumo Oct 13, 2015
1df2b04
new module Entity
noumo Oct 13, 2015
3a6e6b7
Update composer.json
noumo Oct 13, 2015
7bc22b0
Update composer.json
noumo Oct 13, 2015
1e98159
Update composer.json
noumo Oct 13, 2015
e9b37c3
Update composer.json
noumo Oct 13, 2015
ac9bb1f
Update composer.json
noumo Oct 13, 2015
b83c941
new module Entity
noumo Oct 15, 2015
9aba462
new standalone frontend toolbar
noumo Oct 15, 2015
7ecbcf5
update changes
noumo Oct 15, 2015
3a19564
Merge branch 'dev' of https://github.com/noumo/easyii into dev
noumo Oct 15, 2015
1ad306b
install 0.91
noumo Oct 19, 2015
bef9616
move logs to system
noumo Oct 19, 2015
0667672
set datetimepicker to 4.7.14 version
noumo Oct 19, 2015
661142e
insert entity module
noumo Oct 19, 2015
5129310
debug
noumo Oct 19, 2015
5fd66e0
new welcome page
noumo Oct 23, 2015
984ca4e
make install form more simple
noumo Oct 23, 2015
17de746
install fix
noumo Oct 23, 2015
d1dac26
url fix
noumo Oct 23, 2015
b65af05
easyii typo fix
noumo Oct 23, 2015
6bbe6b4
hr move
noumo Oct 23, 2015
c16a22a
new module class fix
noumo Oct 23, 2015
f374555
get upload url fix
noumo Oct 23, 2015
efad94e
default robot email fix
noumo Oct 23, 2015
9d746dc
new settings visibility fix
noumo Oct 23, 2015
748218a
settings name fix
noumo Oct 23, 2015
b7bce75
google client namespace fix
noumo Oct 23, 2015
eb48296
cache filename fix
noumo Oct 23, 2015
1adc307
echo widget
noumo Oct 23, 2015
cb12c27
btn group remove uppercase
noumo Oct 23, 2015
5bd2727
locale fix
noumo Oct 23, 2015
b1ae809
notify sort
noumo Oct 23, 2015
54d3a66
Settings fix
noumo Oct 23, 2015
4679a86
getpathurl fix
noumo Nov 17, 2015
112e25f
set yii2 version to >=2.0.6
noumo Nov 17, 2015
6ca8164
api items and last rework
noumo Nov 17, 2015
d314307
add category select in add/edit item
noumo Nov 20, 2015
a2b816a
code refactoring
noumo Nov 20, 2015
61e0d71
guestbook fix
noumo Nov 20, 2015
997ec4f
allow to select 1 cat
noumo Nov 20, 2015
5739b44
create time fix
noumo Nov 20, 2015
64a71a4
robot_email install fix
noumo Nov 23, 2015
8e2bda5
Replace apostrophe with html entity. See #103
boehsermoe Dec 22, 2015
d5cd58f
Merge pull request #104 from boehsermoe/issue103
noumo Jan 22, 2016
6312c4e
fix easyii-shop/issues/5
noumo Jan 22, 2016
16d657d
Merge branch 'dev' of https://github.com/noumo/easyii into dev
noumo Jan 22, 2016
a75aeb6
undefined index fix
noumo Feb 4, 2016
c21a33b
ga widget fix
noumo Feb 10, 2016
3ff4d3c
fix getModuleName
noumo Feb 11, 2016
6f5b2ef
remove deprecated setting
noumo Feb 11, 2016
83fe9b0
empty cats fix
noumo Feb 11, 2016
9b3f0a0
redactor upload fix
noumo Feb 12, 2016
e600ae3
Change event does not work with jQuery 2.*
boehsermoe Feb 13, 2016
9b820bd
Merge branch 'dev' of https://github.com/noumo/easyii into switcher-fix
boehsermoe Feb 13, 2016
83f9b57
Merge pull request #117 from boehsermoe/switcher-fix
noumo Feb 13, 2016
3cb2d09
Update CHANGELOG.md
noumo Mar 6, 2016
b0987a6
category children
noumo Mar 11, 2016
3bafa3d
Merge branch 'dev' of https://github.com/noumo/easyii into dev
noumo Mar 11, 2016
7ed94b6
create new by slug api fix
noumo Mar 11, 2016
21b24fd
small refactor
noumo Mar 20, 2016
f1652b2
new faq settings - htmlEditors
noumo Mar 22, 2016
dd82433
add children to modules
noumo Mar 23, 2016
a92ded0
i18 minor fix
noumo Mar 23, 2016
47bd215
add decsription to category
noumo Mar 23, 2016
676422b
add description to category object
noumo Mar 23, 2016
172d7a0
add get to some methods
noumo Mar 23, 2016
e99bf45
get children fix
noumo Mar 23, 2016
2ee693e
i18n catalog item fix
noumo Mar 24, 2016
d9618c5
magic methods fix
noumo Mar 24, 2016
e48f16d
small fixes
noumo Mar 27, 2016
24e9e44
fields refactor
noumo Mar 27, 2016
7fe1ca6
remove action
noumo Mar 27, 2016
c910e06
new field type - address
noumo Mar 27, 2016
684f7bd
add gm_api_key setting
noumo Mar 27, 2016
0e5f3b0
refactor items with fields
noumo Mar 27, 2016
1e7d22e
big fckng id renaming
noumo Mar 29, 2016
82a4b4e
not ready change
noumo Mar 29, 2016
f9c3090
JsonColumns behavior
noumo Mar 30, 2016
7c7b6f0
fixes
noumo Mar 31, 2016
d023742
new SlugBehavior
noumo Apr 2, 2016
e770419
small refactor
noumo Apr 3, 2016
f2e5fef
Merge branch 'dev' of https://github.com/noumo/easyii into dev
noumo Apr 3, 2016
12e4891
almost ready
noumo Apr 3, 2016
c364055
fixes
noumo Apr 3, 2016
ea87380
fix migration
noumo Apr 3, 2016
08ec45d
fixes
noumo Apr 3, 2016
00c79d6
fixes
noumo Apr 4, 2016
c568bd8
rename file
noumo Apr 5, 2016
8dc7b42
fix find by slug
noumo Apr 12, 2016
96623e9
Merge pull request #131 from noumo/master
noumo Apr 19, 2016
0717b18
fixes
noumo Apr 21, 2016
b3ea0f3
Merge branch 'dev' of git://github.com/noumo/easyii into dev
noumo Apr 21, 2016
9a3d026
add children
noumo Apr 22, 2016
5206e5d
Merge branch 'dev' of https://github.com/noumo/easyii into dev
noumo Apr 22, 2016
0fbb81e
fix
noumo Apr 25, 2016
74a8800
Merge branch 'dev' of git://github.com/noumo/easyii into dev
noumo Apr 25, 2016
ed3ddeb
fix live edit for admins
noumo Apr 26, 2016
a67995e
Merge branch 'dev' of https://github.com/noumo/easyii into dev
noumo Apr 26, 2016
7a50515
i18 fix
noumo Apr 26, 2016
3d3c232
change category sort dir
noumo Apr 26, 2016
dc4fe16
allow empty text
noumo Apr 26, 2016
d434eaf
show ids for admin
noumo Apr 26, 2016
3d53bf0
refactoring
noumo Apr 26, 2016
f41c825
fix
noumo Apr 26, 2016
792dd2e
generate menu fix
noumo Apr 26, 2016
b12f847
show empty text on front
noumo Apr 26, 2016
bb434ca
filters refactor
noumo Apr 26, 2016
6bd677a
update conditions
noumo Apr 26, 2016
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
new module Entity
category refactor
new field type date
pre 0.9 release changes
  • Loading branch information
noumo committed Oct 15, 2015

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
commit b83c9413fc25cb89e4e5f70664890437a3155ceb
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -6,6 +6,7 @@
* Tags added to gallery albums
* Added immutable setting to all sluggable behaviors
* Now using vova07 redactor widget
* New field types: html, file, date

//todo
insert new module settings
6 changes: 3 additions & 3 deletions actions/SortAction.php
Original file line number Diff line number Diff line change
@@ -19,12 +19,12 @@ public function run($id)
if(($model = $modelClass::findOne($id))) {
if($this->direction === 'up') {
$eq = '>';
$orderDir = 'ASC';
$orderDir = SORT_ASC;
} else {
$eq = '<';
$orderDir = 'DESC';
$orderDir = SORT_DESC;
}
$modelSwap = $modelClass::find()->where([$eq, $attribute, $model->{$attribute}])->orderBy([$attribute => $orderDir])->one();
$modelSwap = $modelClass::find()->where([$eq, $attribute, $model->{$attribute}])->orderBy([$attribute => $orderDir])->limit(1)->one();

if(!empty($modelSwap)) {
$newValue = $modelSwap->{$attribute};
16 changes: 10 additions & 6 deletions components/ApiObject.php
Original file line number Diff line number Diff line change
@@ -18,14 +18,17 @@ class ApiObject extends \yii\base\Object
* @param \yii\base\Model $model
*/
public function __construct($model){
$this->model = $model;
if($model) {
$this->model = $model;

foreach($model->attributes as $attribute => $value){
if($this->canSetProperty($attribute)){
$this->{$attribute} = $value;
foreach ($model->attributes as $attribute => $value) {
if ($this->canSetProperty($attribute)) {
$this->{$attribute} = $value;
}
}
} else {
$this->model = new \stdClass();
}

$this->init();
}

@@ -38,7 +41,8 @@ public function init(){}
* Returns object id
* @return int
*/
public function getId(){
public function getId($debug = false){

return $this->model->primaryKey;
}

25 changes: 19 additions & 6 deletions components/CategoryModel.php
Original file line number Diff line number Diff line change
@@ -20,8 +20,8 @@ class CategoryModel extends \yii\easyii\components\ActiveRecord
const STATUS_OFF = 0;
const STATUS_ON = 1;

static $FLAT;
static $TREE;
static $FLAT = [];
static $TREE = [];

public $parent;
public $children;
@@ -31,7 +31,7 @@ public function rules()
return [
['title', 'required'],
['title', 'trim'],
['title', 'string', 'max' => 128],
[['title', 'slug'], 'string', 'max' => 128],
['image_file', 'image'],
['slug', 'match', 'pattern' => static::$SLUG_PATTERN, 'message' => Yii::t('easyii', 'Slug can contain only 0-9, a-z and "-" characters (max: 128).')],
['slug', 'default', 'value' => null],
@@ -114,7 +114,8 @@ public static function cats()
$cache = Yii::$app->cache;
$key = static::tableName().'_flat';

if(!static::$FLAT) {
if(empty(static::$FLAT[$key])) {

$flat = $cache->get($key);
if (!$flat) {
$flat = static::generateFlat();
@@ -126,13 +127,25 @@ public static function cats()
'parent' => $cat->parent,
'children' => $cat->children
]);

$model->load((array)$cat, '');
$model->populateRelation('seo', new SeoText($cat->seo));
$model->setTagNames($cat->tags);
static::$FLAT[] = $model;
$model->afterFind();
static::$FLAT[$key][] = $model;
}
}
return static::$FLAT[$key];
}

public static function get($id_slug)
{
foreach(static::cats() as $cat){
if($cat->category_id == $id_slug || $cat->slug == $id_slug){
return $cat;
}
}
return static::$FLAT;
return null;
}

/**
2 changes: 1 addition & 1 deletion composer.json
Original file line number Diff line number Diff line change
@@ -27,7 +27,7 @@
"creocoder/yii2-nested-sets": "0.9.*",
"bower-asset/fancybox": "*",
"bower-asset/jquery.switcher": "*",
"bower-asset/eonasdan-bootstrap-datetimepicker": "*",
"bower-asset/eonasdan-bootstrap-datetimepicker": "4.7.*",
"2amigos/yii2-selectize-widget": "~1.0",
"vova07/yii2-imperavi-widget": "*",
"stojg/crop": "*"
1 change: 1 addition & 0 deletions controllers/ModulesController.php
Original file line number Diff line number Diff line change
@@ -223,6 +223,7 @@ public function actionCopy($id)
$fileContent = str_replace($oldModuleClass, $newModuleClass, $fileContent);
$fileContent = str_replace("Yii::t('easyii/".$module->name, "Yii::t('easyii/".$formModel->name, $fileContent);
$fileContent = str_replace("'".$module->name."'", "'".$formModel->name."'", $fileContent);
$fileContent = str_replace('/'.$module->name.'/', '/'.$formModel->name.'/', $fileContent);

file_put_contents($file, $fileContent);
}
5 changes: 2 additions & 3 deletions media/css/admin.css
Original file line number Diff line number Diff line change
@@ -101,9 +101,8 @@ html{
#admin-body .main .container-fluid{
padding: 20px;
}
#admin-body .main a, #admin-body .main .btn, #admin-body .main .form-control, .input-group-addon{
#admin-body .main a, #admin-body .main .btn, #admin-body .main .form-control, .input-group-addon, .selectize-input{
border-radius: 0 !important;
text-align: left;
}

#admin-body .table {
@@ -216,4 +215,4 @@ h4 b{
}
.glyphicon-menu-hamburger:before {
content: "\e055";
}
}
9 changes: 1 addition & 8 deletions modules/article/api/Article.php
Original file line number Diff line number Diff line change
@@ -37,7 +37,7 @@ class Article extends \yii\easyii\components\API
public function api_cat($id_slug)
{
if(!isset($this->_cats[$id_slug])) {
$this->_cats[$id_slug] = $this->findCategory($id_slug);
$this->_cats[$id_slug] = new CategoryObject(Category::get($id_slug));
}
return $this->_cats[$id_slug];
}
@@ -157,13 +157,6 @@ public function api_pages()
return $this->_adp ? LinkPager::widget(['pagination' => $this->_adp->pagination]) : '';
}

private function findCategory($id_slug)
{
$category = Category::find()->where(['or', 'category_id=:id_slug', 'slug=:id_slug'], [':id_slug' => $id_slug])->status(Item::STATUS_ON)->one();

return $category ? new CategoryObject($category) : null;
}

private function findItem($id_slug)
{
$article = Item::find()->where(['or', 'item_id=:id_slug', 'slug=:id_slug'], [':id_slug' => $id_slug])->status(Item::STATUS_ON)->one();
2 changes: 1 addition & 1 deletion modules/article/api/ArticleObject.php
Original file line number Diff line number Diff line change
@@ -36,7 +36,7 @@ public function getText(){
}

public function getCat(){
return Article::cats()[$this->category_id];
return Article::cat($this->category_id);
}

public function getTags(){
16 changes: 4 additions & 12 deletions modules/catalog/api/Catalog.php
Original file line number Diff line number Diff line change
@@ -36,7 +36,7 @@ class Catalog extends \yii\easyii\components\API
public function api_cat($id_slug)
{
if(!isset($this->_cats[$id_slug])) {
$this->_cats[$id_slug] = $this->findCategory($id_slug);
$this->_cats[$id_slug] = new CategoryObject(Category::get($id_slug));
}
return $this->_cats[$id_slug];
}
@@ -153,11 +153,11 @@ public static function applyFilters($filters, $query)
$price = $filters['price'];
if(is_array($price) && count($price) == 2) {
if(!$price[0]){
$query->andFilterWhere(['<=', 'price', (int)$price[1]]);
$query->andFilterWhere(['<=', 'price * ( 1 - discount / 100 )', (int)$price[1]]);
} elseif(!$price[1]) {
$query->andFilterWhere(['>=', 'price', (int)$price[0]]);
$query->andFilterWhere(['>=', 'price * ( 1 - discount / 100 )', (int)$price[0]]);
} else {
$query->andFilterWhere(['between', 'price', (int)$price[0], (int)$price[1]]);
$query->andFilterWhere(['between', 'price * ( 1 - discount / 100 )', (int)$price[0], (int)$price[1]]);
}
}
unset($filters['price']);
@@ -190,14 +190,6 @@ public static function applyFilters($filters, $query)
}
return $query;
}


private function findCategory($id_slug)
{
$category = Category::find()->where(['or', 'category_id=:id_slug', 'slug=:id_slug'], [':id_slug' => $id_slug])->status(Item::STATUS_ON)->one();

return $category ? new CategoryObject($category) : null;
}

private function findItem($id_slug)
{
1 change: 0 additions & 1 deletion modules/catalog/api/CategoryObject.php
Original file line number Diff line number Diff line change
@@ -34,7 +34,6 @@ public function items($options = [])
{
if(!$this->_items){
$this->_items = [];

$query = Item::find()->with('seo')->where(['category_id' => $this->id])->status(Item::STATUS_ON);

if(!empty($options['where'])){
2 changes: 1 addition & 1 deletion modules/catalog/api/ItemObject.php
Original file line number Diff line number Diff line change
@@ -27,7 +27,7 @@ public function getDescription(){
}

public function getCat(){
return Catalog::cats()[$this->category_id];
return Catalog::cat($this->category_id);
}

public function getPrice(){
5 changes: 3 additions & 2 deletions modules/catalog/controllers/ItemsController.php
Original file line number Diff line number Diff line change
@@ -10,6 +10,7 @@
use yii\easyii\helpers\Image;
use yii\easyii\helpers\Upload;
use yii\easyii\models\Setting;
use yii\easyii\widgets\DateTimePicker;
use yii\helpers\Url;
use yii\validators\FileValidator;
use yii\web\UploadedFile;
@@ -206,7 +207,7 @@ private function generateForm($fields, $data = null)
$isImage = preg_match('/\.(jpg|jpeg|png|gif|bmp)$/', $basename);

if($isImage) {
$result .= Html::a(Html::img(Image::thumb($value, 240, 180)), [$value], ['class' => 'fancybox']);
$result .= Html::a(Html::img(Image::thumb($value, 240, 180)), Upload::getFileUrl($value), ['class' => 'fancybox']);
} else {
$result .= Html::a($basename, [$value], ['target' => 'blank']);
}
@@ -216,7 +217,7 @@ private function generateForm($fields, $data = null)
}
elseif ($field->type === 'date') {
$result .= '<div class="form-group"><label>'. $field->title .'</label>';

$result .= DateTimePicker::widget(['name' => "Data[{$field->name}]", 'value' => $value]);
$result .= '</div>';
}
}
10 changes: 9 additions & 1 deletion modules/catalog/models/Category.php
Original file line number Diff line number Diff line change
@@ -10,14 +10,22 @@ class Category extends \yii\easyii\components\CategoryModel
'boolean' => 'Boolean',
'select' => 'Select',
'checkbox' => 'Checkbox',
'file' => 'File'
'file' => 'File',
'date' => 'Date'
];

public static function tableName()
{
return 'easyii_catalog_categories';
}

public function rules()
{
return array_merge([
['fields', 'safe'],
], parent::rules());
}

public function beforeSave($insert)
{
if (parent::beforeSave($insert)) {
46 changes: 28 additions & 18 deletions modules/entity/api/CategoryObject.php
Original file line number Diff line number Diff line change
@@ -3,6 +3,8 @@

use yii\data\ActiveDataProvider;
use yii\easyii\components\API;
use yii\easyii\helpers\Data;
use yii\easyii\modules\entity\models\Category;
use yii\easyii\modules\entity\models\Item;
use yii\helpers\Url;
use yii\widgets\LinkPager;
@@ -14,6 +16,7 @@ class CategoryObject extends \yii\easyii\components\ApiObject
public $tree;
public $fields;
public $depth;
public $cache;

private $_adp;
private $_items;
@@ -35,27 +38,34 @@ public function items($options = [])
if(!$this->_items){
$this->_items = [];

$query = Item::find()->with('seo')->where(['category_id' => $this->id])->status(Item::STATUS_ON);

if(!empty($options['where'])){
$query->andFilterWhere($options['where']);
}
if(!empty($options['orderBy'])){
$query->orderBy($options['orderBy']);
} else {
$query->sortDate();
}
if(!empty($options['filters'])){
$query = Catalog::applyFilters($options['filters'], $query);
if($this->cache)
{
$this->_items = Data::cache(Category::getCacheName($this->id), 3600, function(){
$items = [];
$query = Item::find()->where(['category_id' => $this->id])->status(Item::STATUS_ON)->sort();
foreach($query->all() as $item){
$items[] = new ItemObject($item);
}
return $items;
});
}
else
{
$query = Item::find()->where(['category_id' => $this->id])->status(Item::STATUS_ON);

$this->_adp = new ActiveDataProvider([
'query' => $query,
'pagination' => !empty($options['pagination']) ? $options['pagination'] : []
]);
if(!empty($options['where'])){
$query->andFilterWhere($options['where']);
}
$query->sort();

$this->_adp = new ActiveDataProvider([
'query' => $query,
'pagination' => !empty($options['pagination']) ? $options['pagination'] : []
]);

foreach($this->_adp->models as $model){
$this->_items[] = new ItemObject($model);
foreach($this->_adp->models as $model){
$this->_items[] = new ItemObject($model);
}
}
}
return $this->_items;
Loading