01-25-2023 07:40 PM
If I have a class wire, and right-click on it, there's a menu option to view the class palette.
This palette will show every VI and typdef in the class, whether public or private.
Is there anyway to modify what VIs are shown on this palette? I have classes that are exposed to users as part of an API, there's no reason for them to ever see internal typdefs or private methods here...
Solved! Go to Solution.
01-25-2023 07:54 PM
Are they actually going to be able to get to the block diagram? That seems more dangerous than them being able to see what's inside the classes. And if, by "users" you mean "developers", why would you not want them to see this?
01-25-2023 09:10 PM - edited 01-25-2023 09:12 PM
Let's say my class consists of 50 VIs. 10 of them are public methods. 40 of them are private utility VIs. Perhaps there are some private typedefs too.
All of these will show up in the auto-generated palette when you right-click on a class wire.
However, if you're working in a block diagram that's not part of the class, only the public VIs of this class can be used (since the others are out of scope). The rest are just noise.
(And no, the class VIs would be password-protected so that users (developers) couldn't access the block diagrams of the class VIs)
01-25-2023 09:14 PM
I'll second the level of noise of that palette not filtering by scope. Especially in classes with multiple levels of hierarchy that palette almost becomes useless. I'm commenting to tag along if anyone has a solution to this. Maybe I'll throw developing a right-click plugin onto my todo list.
01-26-2023 09:17 AM
@_carl wrote:
Let's say my class consists of 50 VIs. 10 of them are public methods. 40 of them are private utility VIs. Perhaps there are some private typedefs too.
All of these will show up in the auto-generated palette when you right-click on a class wire.
However, if you're working in a block diagram that's not part of the class, only the public VIs of this class can be used (since the others are out of scope). The rest are just noise.
(And no, the class VIs would be password-protected so that users (developers) couldn't access the block diagrams of the class VIs)
Oh, I get it now. It just becomes very unwieldy. Sometimes "the more, the merrier" doesn't apply. It would be nice if you didn't have to wade through stuff you can't use.
01-26-2023 09:31 AM
Perhaps better illustrated with images. Anyway, thought I'd check to see if there was anything I was overlooking first, but... guessing I'm probably not missing something obvious. Moving this to the idea exchange!
01-26-2023 10:01 AM
This was a while ago but I think I already made an edit that did something like this because I also thought it was silly.
This functionality is implemented through a right-click menu plugin which (at the time) was completely unlocked so I just added some filtering which would take the list of all member VIs (including private) and remove from the list any private VIs that weren't part of the current class selection.
https://lavag.org/topic/21514-when-did-this-happen/#comment-131576
01-26-2023 11:47 AM
You know you can just make a custom palette menu for a class, right?
1. Use the standard palette editing tools in the Tools --> Advanced --> Edit palette set to create a custom palette for your class
2. When you're doing this, make the new palette a ".mnu" file and save it in the same directory as your .lvclass file
3. Finish your palette, exit and save changes
4. Go to the class, do the right-click "Add --> File..." option, and add the new menu file
5. Go to the class properties, and on the General Settings tab, find the dropdown for "Default Palette" and choose the .mnu file in question
Now whenever you right-click that you get your custom palette instead of the premade one that has everything in it.
01-26-2023 11:52 AM
@Kyle97330 wrote:
You know you can just make a custom palette menu for a class, right?
1. Use the standard palette editing tools in the Tools --> Advanced --> Edit palette set to create a custom palette for your class
2. When you're doing this, make the new palette a ".mnu" file and save it in the same directory as your .lvclass file
3. Finish your palette, exit and save changes
4. Go to the class, do the right-click "Add --> File..." option, and add the new menu file
5. Go to the class properties, and on the General Settings tab, find the dropdown for "Default Palette" and choose the .mnu file in question
Now whenever you right-click that you get your custom palette instead of the premade one that has everything in it.
Now you "just" have to do that for every custom class you use, and also remember to do it for every new one as well. I believe the desire is not to have to do that at all. I gave a Kudo to the linked Idea Exchange post.
Saying "Thanks that fixed it" or "Thanks that answers my question" and not giving a Kudo or Marked Solution, is like telling your waiter they did a great job and not leaving a tip. Please, tip your waiters.
01-26-2023 12:01 PM - edited 01-26-2023 12:02 PM
@Kyle97330 wrote:
You know you can just make a custom palette menu for a class, right?
No -- no I did not know that that hidden feature existed.
Certainly isn't a great general purpose solution, but, I think that might just work in my case. Thanks!