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

Pivot table on ManyToMany relationships #89

Open
CSenshi opened this issue Nov 22, 2020 · 1 comment
Open

Pivot table on ManyToMany relationships #89

CSenshi opened this issue Nov 22, 2020 · 1 comment
Labels
good first issue Good for newcomers

Comments

@CSenshi
Copy link

CSenshi commented Nov 22, 2020

First Thing First... Great Package! 💯

Now about issue: When you have ManyToMany relationship (via belongsToMany) and try to generate diagram, it will include pivot table in diagram, but without proper naming. It will be called 'Pivot'.

For Example: below I have included 2 classes that are connected via M:M relationship and they both have pivot table name (buyer_seller) included in their relationship but on the diagram it still shows table as 'Pivot'.

  • Classes:
    •  class Buyer extends Model
       {
           public function buyer()
           {
               return $this->belongsToMany(Seller::class, 'buyer_seller');
           }
       }
    •   class Seller extends Model
        {
            public function buyer()
            {
                return $this->belongsToMany(Buyer::class, 'buyer_seller');
            }
        }
  • Diagram:
    Screenshot from 2020-11-23 01-52-11

P.S. I don't know if it's my fault or not, but as far as I have read documentation there is nothing written about this exact case. So it would be nice to have feature to enable pivot table naming in diagram.

@w0rd-driven
Copy link

The offending line is https://github.com/beyondcode/laravel-er-diagram-generator/blob/master/src/GraphBuilder.php#L173 as the $label variable in this instance is what produces the word "Pivot".

The variable $pivotTable is what we're both looking for and I've patched in the following snippet right before the line I linked as:

if ($label == "Pivot") {
    $label = studly_case($pivotTable);
}

This is not 100% ideal because it removes the underscores but title case doesn't work for my schema either because the database uses tables like addressTypes and I want to preserve the word boundaries.

I'm not keen on managing the fork long term but I also don't know a good way to turn this into a general feature. A label of addresses_addressTypes (the value of variable $pivotTable) in a sea of Addresses or Users models looks out of place.

Now that I think about it, I bet if we both used an explicit Pivot model class perhaps this wouldn't be a concern? The line $label = (new \ReflectionClass($pivotClass))->getShortName(); is looking for a class that by default is Pivot until you substitute with a custom class. In later versions of Laravel there's https://laravel.com/docs/8.x/eloquent-relationships#customizing-the-pivot-attribute-name that may change the name but what I'm talking about is more like https://laravel.com/docs/8.x/eloquent-relationships#defining-custom-intermediate-table-models. I'm not really in a place to take either approach but I'm willing to bet one or the other would address the problem without having to change anything in this package.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
good first issue Good for newcomers
Projects
None yet
Development

No branches or pull requests

3 participants