Skip to content
This repository has been archived by the owner on Oct 7, 2021. It is now read-only.

Support dynamic creation of palette #350

Open
laeubi opened this issue Aug 24, 2020 · 16 comments
Open

Support dynamic creation of palette #350

laeubi opened this issue Aug 24, 2020 · 16 comments

Comments

@laeubi
Copy link

laeubi commented Aug 24, 2020

Currently one needs to add an extension point for each palette item.
If one wraps a collection of items unknown in advance (e.g. wrapping services into actors) it would be nice to have some kind of dynamism here.

I see two possible options:

  1. ModelElementClassProvider service registrations could carry the metadata required as service-properties, this would also allow to register the same actor class multiple times (currently each actor has to have its own class name to be used with the extension point), e.g.
    groupName="My Dynamic Group"
    displayName="The Actor"
    ... and so on ...
  2. Add some kind of GroupProviderService that is queried for the necessary information by given an actor class, e.g.
    GroupProviderService#getGroupName(Object actor);
    GroupProviderService#getDisplayName(Object actor);
    ... and so on ...

of course it would also be possible to combine both approaches.

@laeubi
Copy link
Author

laeubi commented Aug 29, 2020

@cxbrooks Can you tell how complex that would be and if this possibly could make it into the next release?

@cxbrooks
Copy link
Contributor

I have no experience with that code, so I'm not likely to do the work myself. However, I'd happily include changes written by someone else in the release.

There are some notes at http://wiki.eclipse.org/Triquetrum/Extending_Triquetrum that might be of interest.

@laeubi
Copy link
Author

laeubi commented Sep 1, 2020

@cxbrooks thanks for the info, I have taken a look at the code and it seems possible to inject data from different source here but found that Ptolemy actors are identified in the model by their class name and it seems there is no concept of an "actor-id".
That would mean that each actor has to be implemented as its own class and it is not possible to wrap existing classes easily with a generic actor class implementation?

Do you know if I'm missing something?

@cxbrooks
Copy link
Contributor

cxbrooks commented Sep 1, 2020

Yes, each Ptolemy actor is a separate Java class. They do all inherit from ptolemy.actor.Actor. Wrapping existing classes in a generic actor class that invokes the methods of the actual actor via reflection would be possible. I'm not sure if this helps, but for example, we use Tcl (as in Tcl/Tk) as an interpreted language to build models using actors by instantiating the actor, setting parameters, connecting ports and then invoking run. All of these steps are done by invoking methods via reflection.

@erwindl0
Copy link
Contributor

erwindl0 commented Sep 1, 2020

In our Passerelle product, built on Ptolemy, we introduced a "ServiceBasedActor" generic actor implementation.
I started something similar in Triquetrum with org.eclipse.triquetrum.processing.actor.TaskBasedActor.

It's built on the concept of submitting a Task that is then picked up by a task broker and service implementation based on configured task type.

So if you can wrap existing logic/classes in OSGi services that implement org.eclipse.triquetrum.processing.service.TaskProcessingService, this approach for a generic actor may be of help.

There is some info on this approach on https://wiki.eclipse.org/Triquetrum/Task-based_processing
Trial/example implementations can be found in org.eclipse.triquetrum.processing.service.impl.example and org.eclipse.triquetrum.processing.test.

There are also actor implementations where the actual actor logic can be implemented in Python or Javascript, as another approach to have a limited palette and then extra configuration in the actor itself to pick the desired behaviour/implementation.

@laeubi
Copy link
Author

laeubi commented Sep 3, 2020

Yes OSGi Services are definatly possible, will each task get its won palette entry? Or will there be only one "Task" and the actuall class to be used is a config property?

@erwindl0
Copy link
Contributor

erwindl0 commented Sep 3, 2020 via email

@laeubi
Copy link
Author

laeubi commented Sep 3, 2020

Yeah there might be more than one specialization but think for example about 'StorelessUnivariateStatistic' there are different implementations and I just don't write the same actor over and over again with just one class exchanged. Or even an UnivarianteFunction....

But it would still be good to have each one as one palette item (as I simply can iterate over a list of implementations and create new StorelessUnivariateStatisticWrapper(...).

Do you think that would be possible or are the palette items strictly bound to the Ptolemy Actor model? What I have in mind would be something like a Service interface that provides the following attributes:

  • an id (e.g. StorelessUnivariateStatisticWrapper.Mean)
  • the label
  • the group
  • an icon
  • a factory method that creates a new Object instance that is an PtolemyClass (in this case StorelessUnivariateStatisticWrapper)

and then appears in the palette as if

  • I have created a dedicated class
  • I have created a corresponding plugin.xml created

This would greatly simplify the integration of existing functionality into Triquetrum.

@erwindl0
Copy link
Contributor

erwindl0 commented Sep 3, 2020 via email

@laeubi
Copy link
Author

laeubi commented Sep 3, 2020

@erwindl0 many thanks that sounds like exactly what I'm looking for! I'll hopefully be able to try this out next week and will give feedback.

@laeubi
Copy link
Author

laeubi commented Sep 11, 2020

@erwindl0 I'm now able to create dynamic entries in the palette

public class MyPaletteEntryProvider implements PaletteEntryProvider {

	public MyPaletteEntryProvider() {
		System.out.println("Provider created!");
	}

	@Override
	public IConfigurationElement[] getPaletteEntries() {
		PaletteGroup group = new PaletteGroup("Test Me");

		createEntry("Entry 1", "MyPaletteEntryProvider.item1", group);
		createEntry("Entry 2", "MyPaletteEntryProvider.item2", group);
		return new IConfigurationElement[] { group };

	}

	private void createEntry(String name, String id, PaletteGroup group) {
		Map<String, String> attributes = new HashMap<>();
		String pceType = "entry";
		attributes.put(DISPLAY_NAME, name);
		attributes.put(CLASS, MyWrappActor.class.getName());
		attributes.put(TYPE, BoCategory.Actor.name());
		attributes.put("MyIdProperty", id);
		PaletteConfigurationElement pce = new PaletteConfigurationElement(pceType,
				"org.eclipse.triquetrum.workflow.editor", attributes);
		group.addChild(name, pce);
	}
}

I'm trying to add a custom attribute attributes.put("MyIdProperty", id); to distinguish between actors using the same class MyWrappActor.class, but I'm not sure if these are passed to the actor and how I can access this. Is this already supported/possible to pass attributes that way?

@laeubi
Copy link
Author

laeubi commented Sep 12, 2020

I think i got it working :-) I'll prepare a PR with the changes necessary, just one thing, when I go to "edit properties" of an palette item there pops up a dialog where icon, wrapped type ... can be edited, is it possible to replace this dialog with a custom one that configures special properties of the actor instead?

laeubi pushed a commit to laeubisoft/triquetrum that referenced this issue Sep 12, 2020
laeubi added a commit to laeubisoft/triquetrum that referenced this issue Sep 12, 2020
…fully classes

Signed-off-by: Christoph Läubrich <laeubi@laeubi-soft.de>
@erwindl0
Copy link
Contributor

I'm trying to add a custom attribute attributes.put("MyIdProperty", id); to distinguish between actors using the same class MyWrappActor.class, but I'm not sure if these are passed to the actor and how I can access this. Is this already supported/possible to pass attributes that way?

I think that's feasible, but would need to investigate if it's really operational. There's a section in org.eclipse.triquetrum.workflow.editor.features.ModelElementCreateFeature.create(ICreateContext), lines 161-165 that is meant to pass the palette attributes on to the created model element.

@erwindl0
Copy link
Contributor

I think i got it working :-) I'll prepare a PR with the changes necessary, just one thing, when I go to "edit properties" of an palette item there pops up a dialog where icon, wrapped type ... can be edited, is it possible to replace this dialog with a custom one that configures special properties of the actor instead?

great stuff! I'll check the PR asap.

Replacing/customizing the actor configuration dialog per type of actor is not really feasible at this moment I'm afraid.
The approach based on EMF Forms ties a form's view model to an EMF type. As we have just one base EMF Actor type, this is quite limited now. I would need to check if EMF Forms has features to inject custom view models or so, but that will probably not be easy if there's no corresponding structure within the ecore model.

@cxbrooks
Copy link
Contributor

I'm sorry that I missed the PR before releasing 0.4. Should the PR be merged?

@laeubi
Copy link
Author

laeubi commented Oct 29, 2020

Sure, better late than never :-)
Let me know if I should adjust anything.

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

No branches or pull requests

3 participants