PhpStorm 2020.3: PHP 8, атрибуты, PHPStan и Psalm, Xdebug 3, Tailwind CSS и совместная разработка

fujmbnjgazmhfzpbxmbzrusuefa.jpeg

Рады представить финальный мажорный релиз PhpStorm в этом году! Под катом подробный разбор всех изменений и новых возможностей.


PHP 8.0 выпущен. Большое спасибо всем контрибьюторам и менеджерам релиза!

PhpStorm 2020.3 поддерживает все последние изменения языка. Давайте рассмотрим, что доступно и как это использовать в IDE.

Версия языка в статусбаре


Теперь в статусной строке всегда отображается текущая версия PHP проекта. Оттуда же можно переключить версию.

c4b15351fc40e9d913f8207646ef5f47.gif

Если переключатель не активен, это означает, что ограничение на версию PHP задано в composer.json.

Именованные аргументы


В PHP 8 аргументы функций и методов могут передаваться путем указания имени параметра. Вызовы теперь автоматически задокументированы, а необязательные параметры стали необязательными в полном смысле слова.

С помощью квик-фикса Add name identifiers можно добавить имена к аргументам:

03e752c518f5fabe1c1bacb30b3b39f4.gif

Опечатки или ошибочные имена аргументов подсвечиваются:

18636c6715491c96d9654255f9384431.png

Если передаваемое значение совпадает со значением параметра по умолчанию, то его можно смело удалить:

96494a53f0b7f81f8a4ef5c3fc38a6cc.gif

Вместо массива options для передачи набора параметров можно использовать именованные аргументы, просто передавая только необходимые. Аргументы, передаваемые таким образом, в отличие от элементов массива, являются типобезопасными.

b9548bc79d64e1877409961f58075d23.png

Атрибуты


Атрибуты — это новый, структурированный способ указания метаданных в PHP вместо комментариев PHPDoc.

Чтобы создать атрибут, надо объявить класс и добавить маркер #[Attribute]. Здесь PhpStorm поможет с подсветкой, автодополнением кода, поиском использований, рефакторингами и прочим.

30901227677622eae18911f635be65a9.gif

Сам PHP проверяет валидность атрибутов только при вызове ReflectionAttribute::newInstance(). А если не обращаться к атрибутам через Reflection, то они полностью игнорируются, чтобы не загружать лишние классы и не создавать объекты.

А вот PhpStorm провалидирует все в редакторе, не запуская Reflection API. При этом проверяются следующие правила:

  • Указанный класс действительно может быть атрибутом.

    f2a5caae88bcd2ad7d795b951b8cc005.gif

  • Данный атрибут применяется только в разрешенных местах: класс, свойство, метод, параметр, функция или константа класса.

    6568ab55b17f5ae98f7e2bf676855ee6.png

  • Атрибут повторяется только в том случае, если он объявлен с флагом Attribute::IS_REPEATABLE.

    1f6b992ff87c844592dcbb49195d76fa.png


Вот атрибуты в действии с Symfony:

d736bace83cc443f781a2d958a5fba05.gif


Штормовские атрибуты PHP 8


Несколько атрибутов доступны в PhpStorm 2020.3 «из коробки» в неймспейсе \JetBrains\PhpStorm\.

Их сразу же можно использовать в своей кодовой базе, ничего не подключая.

А вот если вы дополнительно используете другие инструменты статического анализа и не хотите получать ошибок типа Class not found, то тогда, возможно, стоит добавить пакет атрибутов JetBrains/phpstorm-attributes как зависимость в composer.json.

#[Deprecated]


Используйте этот атрибут как PHPDoc-тег @deprecated, чтобы пометить методы, классы или константы классов, которые будут удалены в будущем.

Преимущество тут в том, что можно указать замену для устаревшего кода и пользователю будет проще обновиться.

Давайте посмотрим на реальный пример. В недавно выпущенном Symfony 5.2 метод \Symfony\Component\DependencyInjection\Alias::setPrivate() объявлен устаревшим. Если там добавить атрибут #[Deprecated], то можно упростить миграцию.

#[Deprecated(
   reason: 'since Symfony 5.2, use setPublic() instead',
   replacement: '%class%->setPublic(!%parameter0%)'
)]

537b2b87221513bc5994ee77312283ed.gif

#[ArrayShape]


Этот атрибут полезен для работы с простыми структурами данных или объектоподобными массивами, когда по какой-то причине нельзя объявить класс.

Синтаксис вот такой:

#[ArrayShape([
// ‘key’ => ’type’,
   ‘key1’ => ‘int’,
   ‘key2’ => ‘string’,
   ‘key3’ => ‘Foo’,
   ‘key3’ => App\PHP 8\Foo::class,
])]
function functionName(...): array

Тип может быть указан как строка или как ссылка на класс в виде FQN строки или константы ::class.

1f790dbd77616c7db9f0609a8585bf74.gif

Массив, который определяет «форму», можно вынести в константу и переиспользовать:

const  MY_ARRAY_SHAPE = [];
#[ArrayShape(MY_ARRAY_SHAPE)]

aba0fe78c740c1b4a669b04a7332723a.gif

В PhpStorm мы уже проаннотировали атрибутом #[ArrayShape] некоторые стандартные функции PHP, например parse_url().

К счастью, синтаксис однострочных атрибутов обратно совместим. То есть, если записать #[ArrayShape] в одну строку в проекте на PHP 7, то интерпретатор PHP воспримет эту строку как комментарий.

В отличие от интерпретатора PHP, PhpStorm все равно будет анализировать атрибуты! Так что, даже если ваш проект работает на PHP 7.4 или ниже, вы все равно получите пользу от добавления #[ArrayShape].

#[Immutable]


Неизменяемые объекты не могут быть изменены после инициализации или создания. Их использование делает состояние программы более предсказуемым и облегчает отладку.

Атрибутом #[Immutable] можно пометить весь класс или конкретные свойства, чтобы показать, что они не могут быть изменены.

PhpStorm будет проверять использование таких объектов и свойств и подсвечивать попытки изменения.

3f89d5e0c6d393c5189b96dbbf0fe9d2.png

Изменение свойства по умолчанию разрешено в конструкторе, но можно также разрешить и в методах private/protected. Это делается с помощью констант CONSTRUCTOR_WRITE_SCOPE, PRIVATE_WRITE_SCOPE, PROTECTED_WRITE_SCOPE, передаваемых в конструктор #[Immutable].

370ab217c38d24459500d2fdfae95671.gif

#[Pure]


Этим атрибутом помечаются чистые функции, то есть те, которые не производят никаких побочных эффектов. Такие функции можно безопасно удалить, если результат их выполнения впоследствии не используется.

3081d2f5090a919c4ef05e954c9d6efc.png

Если функция помечена как чистая, но в ее теле есть попытка изменить что-то за пределами из внешнего скоупа, то PhpStorm подсветит небезопасный код.

046319e6c8da8ac2e3101e9e1e18b360.gif

Все стандартные чистые функции PHP уже помечены этим атрибутом в PhpStorm.

#[ExpectedValues]


С помощью этого атрибута можно указать, какие значения функция принимает в качестве параметров, а какие может возвращать.

Это практически то же самое, что делает expectedArguments() в .phpstorm.meta.php. Разница лишь в том, что мета-версия, скорее, вспомогательная, а атрибут жестко указывает, что других возможных значений нет.

Например, рассмотрим функцию count:

count ( array|Countable $array_or_countable [, int $mode = COUNT_NORMAL ] ) : int


Еe второй аргумент — целое число, но на самом деле это не произвольное целое число, а одна из констант COUNT_NORMAL или COUNT_RECURSIVE.

Вот как атрибут #[ExpectedValues] улучшит ситуацию:

453cc76d8e4a486a7559b8439b3520dd.png

То есть появилось автодополнение, а если передано что-то другое, то подсвечивается ошибка.

Как указать возможные значения или битовые маски
Ожидаемые значения передаются в конструктор атрибута и могут быть одним из следующих:
  • Числа: #[ExpectedValues(values: [1,2,3])]
  • Строковые литералы: #[ExpectedValues(values: [‘red’, ‘black’, ‘green’])]
  • Константы: #[ExpectedValues(values: [COUNT_NORMAL, COUNT_RECURSIVE])]
  • Константы класса: #[ExpectedValues(values: [Code::OK, Code::ERROR])]

И есть несколько способов указать ожидаемые аргументы:

  • #[ExpectedValues(values: [1,2,3])] означает, что ожидается только одно из значений.
  • #[ExpectedValues(flags: [1, 2, 3])] означает, что ожидается битовая маска заданных значений, например 1 | 3.
  • #[ExpectedValues(valuesFromClass: MyClass::class)] означает, что ожидается любая из констант класса `MyClass`.
  • #[ExpectedValues(flagsFromClass: ExpectedValues::class)] означает, что ожидается битовая маска констант из класса `MyClass`.

Еще один пример #[ExpectedValues]


Возьмем хелпер response() из Laravel. В качестве второго параметра он принимает статус код HTTP.

Есть две проблемы

  • Нет автодополнения с возможными кодами
  • Нет проверки правильности значения в редакторе

21605bf4fbd2e492fd22cbd86d530461.gif

Давайте исправим это, добавив атрибут #[ExpectedValues(valuesFromClass: Response::class)]

a9444f851a022e64bac9bc6baa87d25b.gif

#[NoReturn]


Некоторые функции могут приводить к остановке выполнения скрипта. Если отметить такие функции как точки выхода атрибутом #[NoReturn], то улучшится анализ потока управления.

57922919524fab885866d3653ad6fef9.gif

#[Language]


Этот атрибут можно добавить к строковым параметрам, в которых ожидается текст на каком-либо языке, например RegExp, SQL, DQL и так далее.

Для аргументов появится подсветка и дополнительные возможности.

ac5330a76a9d326858d1a34b342b24de.gif

Вернемся к новым возможностям PHP 8.

Объявление свойств в конструкторе


Обычные свойства можно преобразовать в promoted или обратно с помощью квик-фикса Convert to promoted property.

04301ed3a99023b6728ee475eb668c95.gif

PhpStorm гарантирует, что свойства используются только способом, разрешенным в PHP 8:

  • Можно декларировать свойства только в конструкторе.
  • Нельзя объявлять в абстрактном конструкторе.
  • Нельзя объявлять свойство variadic таким образом.
  • Свойство не может иметь тип 'Callable'.
  • Не допускается переопределение свойства.

9b676ba8adfcdd6e81a49ebaac168f70.png
9437fd9c34ae6c64b6c198f10a5aa9ee.png

Если свойство объявлено новым способом, но в теле конструктора осталась инициализация, то PhpStorm предложит ее удалить.

04aac520e0574a3aa1af9eb15c84d4d0.gif

Выражение match


Новое выражение похоже на switch, но использует строгое сравнение и может быть присвоено переменной или возвращено.

PhpStorm определяет, может ли блок switch быть переделан в match, и сделает это автоматически с помощью квик-фикса по нажатию Alt+Enter:

72db93d6a14d7040201a07de8ffce6b9.gif

Может быть трудно увидеть неправильное использование нового выражения, поэтому PhpStorm подсветит все ошибки.

6ae575b9c9542f15f6a5ff4aeb2d2070.gif
3c49569e3d1b55999540c6ca58d30db5.png

Будут обнаружены дублирующиеся значения в условиях:

f4db6bb759a32f73fe46aaaac6295d3e.gif

Выражение match с одной веткой и веткой по умолчанию может быть безопасно заменено на тернарное выражение.

17e248e8703b85fd6e3b1e9a2f956486.gif

А если осталась только ветка по умолчанию, то соответствие match вообще не понадобится.

4e32371531691225c7ee84a15820d0a7.gif

Наконец, если в разных ветвях одинаковые тела, они могут быть объединены.

5853cf401dc5ecbca8ba1c569945dd69.gif

Оператор nullsafe


Вместо кучи условий с проверкой на null теперь можно использовать цепочку вызовов с новыми оператором ?->.

PhpStorm проверит правильность использования оператора:

5cc904a65e494c10feb531e3fb9d24f4.png

Висячая запятая


Теперь допустимо добавлять запятую после последнего аргумента при вызове функций и в списке замыканий use.

48468cdb1ee36ba5ff17433d11442192.gif

Non-capturing catches


В PHP 8 можно ловить исключение в catch-блоке без переменной.

e94ebb368a00d8dfa44d439cd2d6eb24.gif

Выражение throw


Бросать исключения теперь можно в стрелочных функциях и в коротких операторах ??, а также в тернарном ? :.

8adcd1a7cc42b2cc5987621e75249fc8.png

Можно использовать сокращение thr и нажать tab — это live template.

5e046b82ec4ea10399d1d7212af64a09.gif

Константа :: class на объектах


Раньше, чтобы получить FQN объекта, нужно было использовать функцию get_class(). В PHP 8 вызов get_class($object) можно смело заменить на $object::class.

Собственно, по нажатию Alt+Enter такую замену и можно сделать. Неправильное использование константы ::class PhpStorm подсветит.

b41b41ba8b848d1a565120a1c27e3d8c.gif

Новые функции для строк: str_contains (), str_starts_with (), str_ends_with ()


How do I check if a string contains a specific word? — самый просматриваемый вопрос по PHP на Stack Overflow. В PHP 8 есть четкий ответ на этот вопрос: использовать функцию str_contains().

PhpStorm 2020.3 находит вызовы strpos(), которые можно заменить на str_contains():

51aa209ebeaae949bfe794ed39a248a2.gif

Есть также новые str_starts_with() и str_ends_with() для определения того, начинается или заканчивается ли строка определенной подстрокой. PhpStorm подсвечивает, где вызовы substr() можно заменить новыми альтернативами:

7075f142c0db750c9d51e042ad847031.gif

Reclassified engine warnings


В PHP 8 для многих ошибок был пересмотрен тип бросаемого предупреждения. А именно, вместо Notice во многих случаях будет Exception или Type Error.

В PhpStorm в связи с этим некоторые инспекции имеют два разных уровня severity: для PHP 8 и для более старых версий.

cb6e45c688aa1daff490616e33bd5944.gif

Это все из наиболее заметного по PHP 8. Есть еще целая куча изменений помельче, которые будут видны при обновлении на PHP 8.

Поддержка Psalm и PHPStan


Оба статических анализатора можно использовать в PhpStorm 2020.3 для подсветки проблем непосредственно в редакторе.

c0fd66ae87ce2f0b2b5460b0a88a60b5.gif

Если PHPStan или Psalm добавлены как зависимости в composer.json, то рядом с ними будет значок гаечного ключа, открывающий настройки инструмента.

cc90efc32cb66dd82ee72597b830a5d0.gif

Оттуда можно перейти к настройкам инспекции и включить подсветку в редакторе. Это делается выбором соответствующей инспекции в списке PHP | Quality tools в Settings/Preferences | Editor | Inspections.

️ Лучше включить только один из инструментов, а не оба одновременно.

83c5dbbf7faa6e9cd72889e5d8cbd244.gif

Тут же можно указать путь к конфигурационному файлу и настроить аргументы командной строки.

️ PHPStan может работать без конфигурационного файла, а для Psalm он требуется обязательно. Если в корневом каталоге есть psalm.xml или phpstan.neon, PhpStorm подтянет их автоматически.

Когда все настроено, откройте любой файл, и вы увидите подсветку от статических анализаторов. Может быть небольшая задержка перед тем, как появится подсветка.

37b7d467bc226ad27f8d887596bfa7ec.gif

Аннотации


Все псалмовские аннотации @psalm-* теперь корректно подсвечиваются в редакторе. Но вообще, теперь можно смело убирать префикс @psalm- из тегов, то есть @psalm-return@return и @psalm-param@param.

e44306c84f93bdba3dbebf6c911d9029.png

Поддержка типов


Добавили поддержку некоторых типов Psalm и на основе информации из тегов улучшили наш вывод типов. Это сделало более точными проверки, генерацию кода и автодополнение.

Псевдотипы
Поддерживаются псалмовские псевдотипы, такие как scalar, numeric и т. п.

ccd42dba3957a7452b7da3d9ae4198db.png

Константы в типах
Пожжерживаются объединения констант и указание через * в тегах param и var.

109caaf61d3f2f9c100a4ae8fcb92a35.png

Тайпхинты для массивов
Описания массивов array тоже поддерживаются, в том числе вложенные.

7a0063e1e5b7b64e5b9d701d44cfb1d0.gif

Дженерики и @tempate
Поддержка дженериков — фича для продвинутых пользователей, у которой нет полной корректной спецификации и много граничных случаев. Тем не менее мы решили реализовать базовую поддержку для @template на основе синтаксиса Псалма, чтобы посмотреть, как это будет использоваться.

Пока поддерживается только самый примитивный случай, когда функция возвращает один из своих параметров.

329a46eed9454789111fc3a9d1d3a7c4.gif

Эта поддержка дженериков является очень базовой, ее можно считать экспериментальной. Хотим понять, как это будет использоваться и что нужно реализовать в первую очередь. Будем рады обратной связи, особенно в виде реальных примеров использования в наш трекер.


Xdebug 3


Обновился популярный отладчик для PHP, теперь он значительно быстрее в работе и проще в настройке. Более подробно об Xdebug 3 читайте в документе Upgrade guide.

Чтобы сконфигурировать Xdebug 3, теперь достаточно одной опции xdebug.mode (например так XDEBUG_MODE=debug).

Также был изменен дефолтный порт Xdebug: вместо 9000 теперь 9003. Чтобы упростить миграцию, PhpStorm по умолчанию слушает оба порта. Настройки портов и другие опции для Xdebug находятся в Preferences/Settings | Languages & Frameworks | PHP | Debug.

2a48157bddfecdca8c44663c7961061b.gif

Улучшения отладчика


Возможности по отладке в PhpStorm расширились двумя новыми фишками.

Интеркактивные хинты
Теперь в отладочном режиме вывод переменных можно развернуть, чтобы увидеть все поля. Тут же можно и изменить значения.

53fff67495f5fe78c4c79e4681827a66.gif

Inline Watches
В предыдущих версиях можно было добавить переменную или выражение в список watch и наблюдать, как меняется значение по шагам.

В PhpStorm 2020.3 можно добавлять вотчи непосредственно к контексте, и они будут отображаться рядом с кодом.

Нажмите Add as Inline Watch в попапе на хинте.
e768afc90f5b69b616545bd526777b3e.gif

Или нажмите Add Inline Watch в контекстном меню редактора.
65ed4d2004a9e045bb1a3bef9bd00267.gif

Или выделите переменную и в контекстном меню выберите Add Inline Watch.
118027a2e0e019375c1e663ffb3e1030.gif

Подсветка и переименование переменных в Twig


Выберите переменную или поместите на нее курсор, и все ее использования в шаблоне будут подсвечены. А чтобы переименовать все вхождения, нажмите Shift + F6.

16e2d2f3d291fa331fcd14a23a4e0c13.gif

Совместная разработка — Code With Me


В PhpStorm 2020.3 встроен плагин Code With Me — новый инструмент JetBrains для совместной разработки и парного программирования. С помощью него можно расшарить открытый проект с другими пользователями и работать над ним вместе в режиме реального времени. Подробнее про Code With Me в этих постах.

4da4794d02461069abddbe25f75425b0.gif

HTTP-клиент


Интеграция Guzzle с HTTP-клиентом в PhpStorm


Guzzle — один самых популярных HTTP клиентов для PHP. Представьте, что где-то в коде есть HTTP-запрос и хочется его потестировать, не запуская сам код. Раньше пришлось бы копировать все параметры вручную.

PhpStorm 2020.3 позволяет конвертировать простые запросы Guzzle в файлы .http. Если запрос поддерживается, то рядом с ним появится иконка. Нажав на нее, вы откроете новый scratch-файл с правильным URL, параметрами запроса, методами, заголовками, телом.

0afc7387abe6edb787424dd5548aa9e4.gif

Теперь из редактора запрос можно запустить и поиграться с ним, а затем сохранить его как http-файл в проекте.

Больше об HTTP-клиенте в видеообзоре.


Копировать HTTP-запрос в cURL


Чтобы экспортировать HTTP-запрос в cURL-строку, нажмите Alt+Enter на запросе в редакторе и выберите Convert to cURL and copy to clipboard. Теперь его можно вставить в терминал, документацию или любой инструмент тестирования API.

5143fd72f474ef6508951d8728fff201.gif

Редактор


Улучшения для Markdown


Для описания диаграмм и графиков можно использовать синтаксис Mermaid.js в markdown-файлах. PhpStorm теперь умеет рендерить превью для них прямо в редакторе. Включается в Preferences/Settings | Languages & Frameworks | Markdown.

ef67dcf963dc0c004c4c878f36e4776d.png

Еще теперь можно переформатировать содержимое файлов .md в соответствии с популярными стилями. Делается нажатием ⌘⌥L / Ctrl+Alt+L.

Настраивается в Preferences/Settings | Editor | Code Style | Markdown.

01b96d9c3ec687da1d0db78583970f86.gif

И наконец, если нажать кнопку Auto-Scroll Preview в правом верхнем углу редактора, то прокрутка превью и текста будет синхронизирована.

Улучшена проверка орфографии и грамматики


Опечатки и грамматические проблемы теперь можно исправлять намного быстрее:

  • Во-первых, во всплывающем окне появится объяснение ошибки.
  • А если нажать Alt+Enter на подсвеченном тексте, то варианты замены будут предложены наверху, а не спрятаны в подпункт, как раньше.

f58a178c4851da3e3b2b5527a274da25.gif

Сплит редактора перетаскиванием


Чтобы открыть несколько файлов бок о бок, просто перетащите вкладку в нужный угол экрана.

6b97ae25e8251a20c7e79c197516ec03.gif

Есть еще один способ открыть файл в сплит-режиме — Shift+Enter.
Комбинацию можно нажать на выбранном файле в Project view или в результатах поиска по файлам.

490a1538ac58fb943c2ad21993191405.gif

Вкладка предпросмотра


Если нужно быстро просмотреть файлы, то теперь не обязательно открывать каждый в отдельной вкладке. Можно использовать новую вкладку Preview tab.

Чтобы включить ее, нажмите на шестеренку в Project view и выберите Enable Preview Tab и Open Files with Single Click.

4c0a2e7675a84bbdcd6e244890dc53fc.gif

Еще можно просматривать файлы нажатием пробела в Project view, не открывая их.

3143225aa9ef154c6a3f18c6838df6e0.png

IDE


Улучшения для Search Everywhere

Результаты сгруппированы по релевантности:
2dfee654aff047f1621c096d5a5ba57f.png

Можно делать простые математические операции и не открывать гугл калькулятор:
4a22ec5c59c7243d72490e79e72558b5.png

Можно искать по истории Git:
d2e213f7bb81eb738b1c302507e372db.png

Автоматическое переключение на светлую или темную тему


В Preferences/Settings | Appearance & Behavior | Appearance | Theme выберите Sync with OS.

3003084e18ac0cbc802eef762016d8de.png

Новый набор горячих клавиш для macOS


Альтернативная раскладка горячих клавиш для macOS минимизирует использование функциональных клавиш, чтобы не надо было растягивать руку на всю клавиатуру при совершении основных действий. Например, вместо Fn+Shift+F6 для Rename рефакторинга используется ⌥+⌘+R.

e0a9653bbcf0e18de7157b2bc492ea5d.png

Слова вместо иконок для горячих клавиш macOS


Можно сделать так, чтобы вместо иконок типа ⌥ ⌘ отображались слова Alt, Cmd и т. п.

Включается в секции Registry опцией ide.macos.disable.native.shortcut.symbols. Чтобы получить доступ к реестру, используйте Find Action Cmd+Shift+A и напишите там Registry.

Установить PhpStorm как приложение по умолчанию для разных файлов


В Preferences | Settings / Editor / File Types нажать Associate file types with PhpStorm…. В диалоговом окне выберите расширения для файлов, и они будут открываться в PhpStorm.

На macOS требуется перезагрузка.

944ef6d9850f37f5e69fd960f8555909.gif

Шаблоны могут генерировать несколько файлов


Можно одновременно сгенерировать сразу несколько файлов, например скелет для модуля или комбо контроллер-вью.

В Preferences / Settings | Editor | File and Code Templates нажать на fe08f6c553331464055fdbc2db0119d7.png, чтобы создать новый шаблон, а затем нажать на иконку Create Child Template File c1faac8a26739bad75977ab194c65652.png.

В поле File name можно использовать переменные типа ${NAME}.

cc6ed4c11489037b51b0a8887549ae5a.gif

А вот пример того, как сгенерировать контроллер и шаблон в Symfony:

dccf21b09048505fe73b54e969126462.gif

Поддержка Git stage


Включить можно чекбоксом Enable staging area в Preferences/Settings | Version Control | Git.

В окне инструментов Commit (Cmd+0 / Alt+0) появятся две группы файлов: staged и unstaged.

Чтобы добавить файл в staged, нажмите на + напротив него.

4548d64ca4b31b2e4e4ae3b90dc164d9.gif

Или можно выбрать конкретные строки и добавить их иконкой в редакторе. В этом случае можно закоммитить часть изменений из файла, а над остальными продолжить работу.

cf12fbb08e32ab518c84c29aa630bf5e.png

Инструменты БД


PhpStorm «из коробки» включает в себя возможности DataGrip, которые охвачены в обзоре релиза DataGrip 2020.3 от наших коллег.

SQL для MongoDB


Теперь можно использовать SQL-запросы к MongoDB. PhpStorm 2020.3 поддерживает SELECT-запросы с JOIN, WHERE, GROUP BY, HAVING, ORDER BY, LIMIT, OFFSETи всеми функциями MongoDB кроме map, reduce, filter и let. Подробнее в блог-посте.

be2b1d33092d5691f7f85e9ab445e243.png

Веб


Как всегда, в PhpStorm входят все обновления из WebStorm 2020.3. Наиболее примечательной является поддержка Tailwind CSS.

Tailwind CSS


PhpStorm дополняет классы Tailwind в HTML-файлах и после директивы @apply. А также предоставит автодополнение псевдо-классов.

tailwind-completion-after-apply

Если навести указатель на класс в HTML и CSS файлах, то отобразится предпросмотр полученного CSS. Предпросмотр также доступен при автодополнении кода, во всплывающем окне документации F1 / Ctrl+Q.

tailwind-completion-for-pseudo-class-variants

PhpStorm поддерживает настройки из tailwind.config.js. Например, если определить тему с новыми цветами, то во всплывающем окне автодополнения будут созданные классы с именем кастомного цвета.

tailwind-customization-support

Скачать PhpStorm 2020.3 можно на странице «What«s new».

А вот видеоролик (на английском) с демонстрацией главных фич релиза:


На этом всё на этот раз. Будем рады вопросам, пожеланиям, баг-репортам и просто мыслям в комментариях.

© Habrahabr.ru