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

throws an error when an attribute is named 'kind' #88

Open
founded1898 opened this issue Jan 26, 2021 · 2 comments
Open

throws an error when an attribute is named 'kind' #88

founded1898 opened this issue Jan 26, 2021 · 2 comments

Comments

@founded1898
Copy link

Hi There

We're using spraypaint together with typescript and stumbled across an error when an attribute has the name kind.

this code here

import { Attr, Model, BelongsTo, SpraypaintBase } from "spraypaint";

@Model()
class Person extends SpraypaintBase {
  @Attr() name: string;
}

@Model()
class Dog extends SpraypaintBase {
  @Attr() name: string;
  @Attr() kind: string; // if renamed, things are working properly

  @BelongsTo() person: Person; // if removed, things are working properly
}

leads to the following error

TypeError: context.attributes is undefined
    getter attribute.ts:82
    get attribute.ts:93
    isModernDecoratorDescriptor decorators.ts:55
    fn decorators.ts:318
    __decorate index.ts:5
    <anonymous> index.ts:34
    <anonymous> index.ts:42
    <anonymous> index.ts:43

We figured out that the error only occurs if there is some kind of relationship on the model with the attribute.
See minimal demo here: https://stackblitz.com/edit/typescript-xyevlu?file=index.ts

Does someone know whats the problem here?

Thanks in advance.

@bronsonholden
Copy link

bronsonholden commented Mar 25, 2021

Just leafing through the code, it looks like the kind property is used internally. Unless I'm misunderstanding the code (cc: @richmolj ), defining an attribute adds a getter to SpraypaintBase that record class. kind is later evaluated on the object, which calls that getter and triggers the error (there's no instance to read the kind attribute from). Try it with the JS API, see if maybe you can work around it by just using the JS record definition just for this one model?

@bronsonholden
Copy link

Another interesting observation, if you define the Person association first, it works. 🤪

Model()
class Dog extends SpraypaintBase {
  @BelongsTo() person: Person;
  @Attr() name: string;
  @Attr() kind: string;
}

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

No branches or pull requests

2 participants