Dynamically populating dropdown input slots

And also extremely cursed lol

Hey unrelated, but how do you add a left input arrow in snapblocks?

Who the hell flagged this for off topic, I literally said unrelated because snapblocks doesn't recognize list unless it has @delInput so I wanted to know how to add it

Not a real issue (IMAO), since you can choose appropriate names for the inputs, like in:

… and rightly so :wink:

IIRC this approach provides (or provided) better runtime performance. Don’t know why.

Granted.

@delInput
@delInput :: other

I also created a guide on how to use snapblocks, which goes over many things: How to write snapblocks

Thanks! IMO, you should make a symbol just called @addDelInput or something if you haven't already that does both

honestly, i think it would have been better if we could just say @DI @AI, or @DAI as an abbreviation.

Also, 3 new blocks, no idea what they do but im trying to figure it out. (also I think this topic would make more sense in Development because this feature is not done yet)

set slot [ V] to []::control probably does

for you

EDIT: No it just automatically sets the content of the input to it, not add an option
Jens and the rest of the Snap programming team are really going crazy with these amazing updates!

ezgif-1-e335db829b

Oooh that's neat

the set slot block can actually be used for non-menu slots!

oh, that's actually pretty useful!

I like this. :slight_smile: It inspired me to make a simpler version of this here: Snap! ! Backpack 10.2

Brian, I do love the changes here for dynamic menus. I thought it was really interesting with the C+C library. But wouldn't it be confusing to have custom-block-special blocks in the stage? I would recommend adding a new palette to the block dialog so that it would be separated better. If not, a small indication that should be added to the "block blocks" is with the new cube or cubeSolid symbols, like so:
blocksblocks

or I could propose a new symbol, $blockManipulator, could look like this: blockManipulator
These changes are really interesting and would definitely attract a few library creators. :slight_smile:

One idea that I've thought of, is splitting then into a section in the control category, and adding a label text for the section. I know it's possible, since it's used for the lists category, and dev mode blocks.

We've been talking about "drawers," a feature in which the section label text would have an arrowhead after it that you'd click to make those blocks appear. The main blocks would always be visible, and the specialist blocks would be hidden but discoverable to keep the palette smallish.

I've also been thinking about splitting the Control category, or about introducing one or two new categories, one of which would be "Blocks", and it would contain the rings (from current Operators), all the blocks in the Control palette that have rings (RUN, LAUNCH, CALL, PIPE, TELL, ASK), and then all the metaprogramming ones from WHEN (anything) IS EDITED downwards. Introducing 2 new category buttons would also let us put the "other" blocks into their own palette.

I vote for splitting Lists from Variables!

I agree, since having an empty category (by default) would probably confuse new users (like, "why is there a category with no blocks?").

My idea about Other is that we should rename it to Custom and it should include all the custom blocks in addition to them being in the category matching their color. Other would still be a block category; its blocks would be gray and would live only in the Custom palette. Jens doesn't like the idea, though.

I'm trying to get the label name of the reporter from within the dynamic menu script without having to explicity drop the block itself - i.e I'd like it to work for any block.

I've tried the usual suspects (caller/script etc) but not having any joy

Is this currently possible?

listmenu script pic

image

the label of the block instance? That's currently not yet exposed to other scripts except the definition body. But internally it's totally there. But ... where should we draw the line? What's the point of exposing it? You know the label, because you've defined the block, right?