If you set a test value, query will work. But always, only with this test value. However, this does not solve the problem I pointed out above. The problem is that data binding does not work in the query. There are simply no values transmitted. Therefore, it is not possible to get dynamic data for the parameter.
I found the reason why I get the error. I'll leave a solution here, for those who need to get something similar.
In order for the field to have a correct appearance on the client side and no errors occur, it is necessary to assign alias to the conditional IF in a custom query:
SELECT id, make, IF (:P1 = 2, model, null) AS zzz
FROM cars