-
Notifications
You must be signed in to change notification settings - Fork 25
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
[Feature Request] Add ability to define "personal" Cellformatters #125
Comments
I would guess there is no real way to do this or I am missing something. It looks like "fmt" only takes the name of the CellFormatter and hence no way to pass in anything as it just operates on "data" which is "x". From code:
That is unfortunate as it would considerably clean up most evert single flex table I have. This all have customizations like this, consider this for NHL Hockey repeated one for every day of the week:
Or worse, this for 16 statistics x 4 sports (NHL, NFL, MLB, NBA) which is 48 times:
|
Assume I have a table with 10 columns. And what? The formula is placed inside some yaml file which is called by include. |
Interesting, but I would guess I would need an example because if you look those are not the same exact code. They differ by an index/name (like EventScore1 and EventScore2 .... for the different apperatus ) or x.stats.find(y=>y.abbreviation == 'PTS').displayValue and x.stats.find(y=>y.abbreviation == 'TS').displayValue and x.stats.find(y=>y.abbreviation == 'FS').displayValue ... They are different. I do not see how YAML includes solve this. To me YAML includes say copy this entre thing here. But if it is different in each case, then I need 10 different includes which is no better than what it is right now. Perhaps I am missing something though so an example of how one piece that selects different fields but has the same logic would be great. Maybe a more complete example, here is the code for all the modifies for that table:
Note the each one differs by multiple attributes used. What I thought would be easy though I cannot figure out. It would be something like I just have a separate JS file and load it (I have done that, it loaded on page load). I put a function in that file that should be accessible from anywhere I like. But If I test in the JS console, it cannot find my function no matter what I try. This to me would be the generic no code solution but I guess I do not understand how to inject a custom JS file and make those functions I define in it globally available. Example in a file riocrest-inject.js
Does it inject? Yes, I can see the message in the info console. And I see it loaded in the page.
In the console ...
All "There is no function named bingo" If someone has a pointer as to how I could write a function that would be known then I could do as I like without the "enhancement" because I should be able to do then:
That is much more manageable and understood to me. But if YAML includes can do this, I am all for it. |
To add to this as an update, I did the following: Changed the flex-table JS to add a function:
Then I changed that whole mess previous posted above with repetitive but different modifies to the following easy code:
It works perfectly. Now, a better implementation is not in hacking the core JS (with custom functions) but using some include and being able to load them and use them. Keep your personal JS function library. That is beyond my skills but to me that would be a super enhancement. |
OK, for anyone following this, I have done something that I believe minimizes changes to core and provides great flexibility. I used import to import a file that can contain a set of functions. Step one, one minor change to the core JS (only the first few lines shown here and only one is important -- the "import"):
This will import a separate JS file into a class named "plugin". The file would be located in the same directory as "flex-table-card.js" and named "flex-table-card-plugins.js". Of course you can change that name if you like. Step two, put your function(s) in this file which will be imported. You add the keyword "export" in front of the function so that it is exported and available within the core JS:
Step 3, use them! They are in the namespace "plugin" referred to on the "import" line. To use one you would call it by adding the namespace in front of the function name. So the example above becomes:
Now, if the install of flex-table would create an empty JS "plugins" file and never wiped it out on updates, it would provide this enhancement. Otherwise, on updates you could always reimplement this by adding the one line in the core JS. |
I think this is a great request. I'd certainly be willing to do any testing needing done during development. People have been doing some amazing things with the flex table card and I think this could take it over the top. It can't be an actual !include as the HA front end does not support it. Oh, I see @kbrown01 has already covered this! |
Yes. The real question is in implementation for the code owners. I would suggest it creates an empty "plugins" file to not get 404 errors on the import. BUT never overwrite that file on update. No sure how this is handled in Home Assistant world and hence beyond me. I know one could do it by creating a separate folder as the path to the import file is variable. On first install, create the card folder + JS and the Plugin folder and blank JS. On subsequent updates, only update the card folder and do not touch the plugin folder. I know how to do it "by hand" but I suspect it needs to be solved "generically" (as it should). |
I support this. Great idea. |
The approach here is indeed quite nice. |
@daringer I have not tried. Possibly a try-catch. I can test soon. I was hoping the code owner would take that on. |
I would also note that import works on classes too and IMHO cellformatter code should be handled this same way. |
While the code for Cellformatters is great, there are many highly custom uses that are not really something that should mess with the core JS. One should be able to drop in some file where personal CellFormatters can be defined and used withn their installation without breaking the core installation.
Example, take this:
No one want that code but me and possibly a few others that may display gymnastics statistics. The raw data is such that that
modify
is repeated for Event/Score 1 - 7 (think Floor, Bars, Vault, Beam, ...) and also All Around score.It would be much more valuable to write that simply as:
modify: "eventscore(x.EventPlace1, x.EventScore1)"
or
modify: "eventscore(x.AAPlace,x.AAScore)"
I have yet to test but I assume I could jut hack my formatter into the base class and test it but it would not stand through updates.
The text was updated successfully, but these errors were encountered: