- 
                Notifications
    You must be signed in to change notification settings 
- Fork 233
Proof of concept for Columns as a Service #903
base: master
Are you sure you want to change the base?
Proof of concept for Columns as a Service #903
Conversation
| @Seb33300 @mwansinck I'd like to hear your opinion about this PR. I've also changed the service names to FQCN, so we'll have to bump the version to 1.3? | 
| 
 Code seems OK, but the requirement that a Column must be a services shouldn't be necessary, it will break existing setups (mainly those based on Symfony <= 3.4). It should be possible to first check if a service exists (when written in FCQN notation) and fallback tot the current logic with a E_USER_DEPRECATED notice to warn user this will be removed in a 2.0 release. You could also add services alias for each changed service name to keep backward compatibility. For example, see below Also, if you are going to use FCQN instead of service keys, you could also replace the service dependencies tot FCQN's, or better use autowiring instead. (will break Symfony < 3.4 setups however). But that could be done in another PR. Also added some comments on your code. In general good idea and the implementation is cleaner than my earlier PR. We would very like to see this released as soon as possible ;-) | 
| I'm sorry, I dont really have the time to look into this pull request yet | 
| 
 Anything we can do to help? We would like to see this functionality being merged. | 
| I came across  | 
| 
@stephan I have an opinion on this issue. I write after   work. Wait.
Stephan Vierkant <notifications@github.com> schrieb am Di., 16. Juli 2019
15:53:…  I came across Factory::create(). Should we put the logic for creating a
 column in this class? I don't use the Editor so I'm not sure how that'll
 work.
 —
 You are receiving this because your review was requested.
 Reply to this email directly, view it on GitHub
 <#903?email_source=notifications&email_token=AAWT2DHR7PPIKEBZVS3VG33P7XHHJA5CNFSM4H5GGGMKYY3PNVWWK3TUL52HS4DFVREXG43VMVBW63LNMVXHJKTDN5WW2ZLOORPWSZGOD2A5PMQ#issuecomment-511825842>,
 or mute the thread
 <https://github.com/notifications/unsubscribe-auth/AAWT2DC7H4ZIBLHOJ6VS2DLP7XHHJANCNFSM4H5GGGMA>
 .
 | 
| I'm always open to new cool ideas, but the following comments: This software now has good download rates. So let's talk about Maintaining Open Source Software. I think it's good practice not to merge API changes into the current stable branch if these changes are not backwards compatible. It follows that you should first think about whether a 2.0 or a test branch makes sense. So a kind of sandbox. The versions should be designed this way. MAJOR version when you make incompatible API changes, The idea should also be checked to see if the base is right. By base I mean the implementation of the columns. In my opinion, I built there complete bullshit. Keyword: "diamond problem". That needs to be redone. My (self-critical) opinion. There is too much inheritance in it. Other programmers rebuild the bundle with a new name and do not realize that they are copying crap right now. We will not be able to fulfill every wish immediately. We can not fix every bug or fix any issues. Everything should be well considered. @stephan: the idea is good. keep it up. But please not in version 1, which is stable. But hey ... you're the boss. | 
| @stwe I agree breaking changes should be backwards compatible. However I do also think that the concept "Columns as a service" can be written in such way it is backwards compatible. Also, the base isn't complete bullshit if you ask me, the concept of columns is very similar to that of Symfony forms. Of course there is always room for improvements, but it still works. That this software has good download rates is good. You should however keep up changes and improvements to prevent other bundles (included forks) will eventually catch up. | 
| I agree, this should be backwards compatible. @mwansinck How about putting this logic in the Factory? Can we inject the columns into that class in a backwards compatible way? | 
        
          
                Datatable/Column/ColumnBuilder.php
              
                Outdated
          
        
      | use Sg\DatatablesBundle\Datatable\Factory; | ||
| use Twig_Environment; | ||
| use Exception; | ||
| use function array_key_exists; | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In my opinion, remove the use function ....; lines because they don't have any advantage
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'll remove this. Let's discuss this in #912.
        
          
                Datatable/Column/ColumnBuilder.php
              
                Outdated
          
        
      | use function array_key_exists; | ||
| use function sprintf; | ||
| use function trigger_error; | ||
| use const E_USER_DEPRECATED; | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can also be removed, because it's a global constant
        
          
                Datatable/Column/ColumnBuilder.php
              
                Outdated
          
        
      | /** | ||
| * Column services | ||
| * | ||
| * @var \Symfony\Component\DependencyInjection\Argument\RewindableGenerator | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
change to iterable
        
          
                Datatable/Column/ColumnBuilder.php
              
                Outdated
          
        
      | $column = Factory::create($class, ColumnInterface::class); | ||
| if (is_object($class)) { | ||
| $column = Factory::create($class, ColumnInterface::class); | ||
| @trigger_error(sprintf('Using an object as column type is deprecated since 1.3 and will be removed in 2.0. Use a class name (FQCN) instead.'), E_USER_DEPRECATED); | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is this going to be releases as a 1.3 version or could we add this to the 1.2 release
| Sg\DatatablesBundle\Datatable\AbstractDatatable: | ||
| abstract: true | ||
| arguments: | ||
| - '@security.authorization_checker' | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
No need to specify service arguments because they can be autowired (or is this needed because of the latest argument for the colums, if so, we could reverse order of arguments).
        
          
                Resources/config/services.yml
              
                Outdated
          
        
      | Sg\DatatablesBundle\Datatable\DatatableFactory: | ||
| public: true | ||
| arguments: | ||
| - '@security.authorization_checker' | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
No need to specify service arguments because they can be autowired
| 
 I think its possible, by adding a else-if at line 133 to check for the ColumnInterface and implementing the logic within the else-if block. Other classes created by the factory could be handled in the same way (in ClassName::class notation) as well but maybe thats out-of-scope for now. | 
# Conflicts: # Datatable/AbstractDatatable.php # Datatable/Column/ColumnBuilder.php
| I've changed the LinkColumn (introduced in #839, ping @philippemilink) into a column as a service. Tests are failing, haven't looked into that yet. | 
| Any idea how to fix the tests? I have really no idea how to mock the  Or can we use  | 
# Conflicts: # Datatable/AbstractDatatable.php # Datatable/Column/AbstractColumn.php # Datatable/Column/ColumnBuilder.php # Datatable/Factory.php # DependencyInjection/SgDatatablesExtension.php
| You should  | 
# Conflicts: # Datatable/AbstractDatatable.php # Datatable/Column/AbstractColumn.php # Datatable/Column/ColumnBuilder.php
| @stephanvierkant May I suggest closing this PR ? Latest commits are almost a year old, or do you still plan on continue on this? | 
| I'm using this fork in my own application, but maybe it's better to create a new PR instead. | 
| @stephanvierkant: Your last comment got me coding my thoughts on Column after a long time. See 2.0 branch. | 
…onse\DatatableQueryBuilder::$columnNames is deprecated
Yet another *aaS-solution! May I introduce to you: (a very very early stage proof of concept) Columns as a Service! See #902
Symfony Forms can be uses as a service, so you can use Dependency Injection to use components like the Routing Component in your Forms. This PR adds this to Datatable-columns as while. Take this example from my application. I'm using Selectize as a filter and I'm injection the options from a JSON-file.
Noticeable changes:
new VirttualColumn()) or a non-FQCN string (virtual_column)sg_datatables.*I'd like to hear your thoughts about this PR, I'm not sure this is the right way to do it. (but it works on my machine ;))