Я использую datePicker от yii2-jui, и я хочу изменить используемую тему JQuery Ui. Я попытался внести исправленные изменения в myapp\vendor\yiisoft\yii2-jui\JuiAsset.php
class JuiAsset extends AssetBundle
{
public $sourcePath = '@bower/jquery-ui';
public $js = [
'jquery-ui.js',
];
public $css = [
'themes/THE_OTHER_THEME/jquery-ui.css',
];
public $depends = [
'yii\web\JqueryAsset',
];
}
Вот фрагмент представления _form
:
<?php
use yii\helpers\Html;
use yii\widgets\ActiveForm;
use yii\jui\DatePicker;
/* @var $this yii\web\View */
/* @var $model frontend\models\Profile */
/* @var $form yii\widgets\ActiveForm */
?>
...
<?php $form = ActiveForm::begin(); ?>
<?= $form->field($model, 'birthdate')->widget(DatePicker::className(), ['clientOptions' => ['dateFormat' => 'yy-mm-dd']]) ?>
Однако этот способ не является oop решением, чтобы получить то, что я хочу. Я не могу понять, что мне нужно сделать в моем представлении _form.php
чтобы он мог переопределить свойство объекта JuiAsset $css
Не только это не ООП, а изменение основных файлов Yii.
2 варианта:
EDIT: Вы сказали мне, что ищете что-то в комментариях
Yii::$app->set('assetManager' , [
'class' => 'yii\web\AssetManager',
'bundles' => [
'yii\widgets\ActiveFormAsset' => [
'js' => [],
'depends' => [
'yii\adminUi\assetsBundle\AdminUiActiveForm',
],
],
'yii\grid\GridViewAsset' => [
'depends' => [
'backend\assets\AppAsset'
],
],
],
'linkAssets' => true,
]);
немного устарел, но вы должны поместить переопределение assetManager в файл config/web.php в разделе "Компоненты" следующим образом:
$config = [
'id' => 'basic',
'basePath' => dirname(__DIR__),
'bootstrap' => ['log'],
'components' => [
'assetManager' => [
'bundles' => [
'yii\jui\JuiAsset' => [
'css' => [
'themes/flick/jquery-ui.css',
]
]
]
],
],];
я просто испытал это, поскольку я искал что-то похожее, работал просто отлично